/*
* SPDX-FileCopyrightText: 2023 The Refinery Authors
*
* SPDX-License-Identifier: EPL-2.0
*/
package tools.refinery.store.reasoning.translator.multiobject;
import tools.refinery.store.model.Interpretation;
import tools.refinery.store.reasoning.ReasoningAdapter;
import tools.refinery.store.reasoning.refinement.AbstractPartialInterpretationRefiner;
import tools.refinery.store.reasoning.representation.PartialSymbol;
import tools.refinery.store.representation.Symbol;
import tools.refinery.store.representation.TruthValue;
import tools.refinery.store.representation.cardinality.CardinalityInterval;
import tools.refinery.store.representation.cardinality.CardinalityIntervals;
import tools.refinery.store.tuple.Tuple;
public class ExistsRefiner extends AbstractPartialInterpretationRefiner {
private final Interpretation countInterpretation;
private ExistsRefiner(ReasoningAdapter adapter, PartialSymbol partialSymbol,
Symbol countSymbol) {
super(adapter, partialSymbol);
countInterpretation = adapter.getModel().getInterpretation(countSymbol);
}
@Override
public boolean merge(Tuple key, TruthValue value) {
var currentCount = countInterpretation.get(key);
if (currentCount == null) {
return false;
}
CardinalityInterval newCount;
switch (value) {
case UNKNOWN -> {
return true;
}
case TRUE -> newCount = currentCount.meet(CardinalityIntervals.SOME);
case FALSE -> newCount = currentCount.meet(CardinalityIntervals.NONE);
case ERROR -> {
return false;
}
default -> throw new IllegalArgumentException("Unknown TruthValue: " + value);
}
if (newCount.isEmpty()) {
return false;
}
countInterpretation.put(key, newCount);
return true;
}
public static Factory of(Symbol countSymbol) {
return (adapter, partialSymbol) -> new ExistsRefiner(adapter, partialSymbol, countSymbol);
}
}