本文整理匯總了Java中ap.parser.IFormula類的典型用法代碼示例。如果您正苦於以下問題:Java IFormula類的具體用法?Java IFormula怎麽用?Java IFormula使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。
IFormula類屬於ap.parser包,在下文中一共展示了IFormula類的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。
示例1: interpolate
import ap.parser.IFormula; //導入依賴的package包/類
public ProverExpr[] interpolate(int[][] partitionSeq) {
final ArrayBuffer<Set<Object>> args = new ArrayBuffer<Set<Object>>();
for (int i = 0; i < partitionSeq.length; ++i) {
final ArrayBuffer<Object> indexes = new ArrayBuffer<Object>();
for (int j = 0; j < partitionSeq[i].length; ++j)
indexes.$plus$eq(Integer.valueOf(partitionSeq[i][j]));
args.$plus$eq(indexes.toSet());
}
final Seq<IFormula> ints = api.getInterpolants(args.toSeq(),1000000);
final ProverExpr[] res = new ProverExpr[partitionSeq.length - 1];
for (int i = 0; i < partitionSeq.length - 1; ++i)
res[i] = new FormulaExpr(ints.apply(i));
return res;
}
示例2: and
import ap.parser.IFormula; //導入依賴的package包/類
@Override
public IFormula and(IExpression t1, IExpression t2) {
if (t1 == t2) {
return (IFormula) t1;
}
if (isTrue(t1)) {
return (IFormula) t2;
}
if (isTrue(t2)) {
return (IFormula) t1;
}
if (isFalse(t1)) {
return pFalse;
}
if (isFalse(t2)) {
return pFalse;
}
return simplify(new IBinFormula(IBinJunctor.And(), (IFormula) t1, (IFormula) t2));
}
示例3: or
import ap.parser.IFormula; //導入依賴的package包/類
@Override
public IFormula or(IExpression t1, IExpression t2) {
if (t1 == t2) {
return (IFormula) t1;
}
if (isTrue(t1)) {
return pTrue;
}
if (isTrue(t2)) {
return pTrue;
}
if (isFalse(t1)) {
return (IFormula) t2;
}
if (isFalse(t2)) {
return (IFormula) t1;
}
return simplify(new IBinFormula(IBinJunctor.Or(), (IFormula) t1, (IFormula) t2));
}
示例4: addConstraint
import ap.parser.IFormula; //導入依賴的package包/類
@Override
public Integer addConstraint(BooleanFormula f) {
Preconditions.checkState(!closed);
int termIndex = counter.getFreshId();
IFormula t = (IFormula) mgr.extractInfo(f);
// set partition number and add formula
api.setPartitionNumber(termIndex);
addConstraint0(t);
// reset partition number to magic number -1,
// which represents formulae belonging to all partitions.
api.setPartitionNumber(-1);
assertedFormulas.peek().add(termIndex);
annotatedTerms.put(termIndex, t);
return termIndex;
}
示例5: substitute
import ap.parser.IFormula; //導入依賴的package包/類
/**
* Simultaneously substitute <code>from</code> with <code>to</code>
* in <code>target</code>. <code>from</code> has to be an array of
* free or bound variables.
*/
public ProverExpr substitute(ProverExpr target,
ProverExpr[] from, ProverExpr[] to) {
assert(from.length == to.length);
final scala.collection.mutable.HashMap<ConstantTerm, ITerm> constantSubst =
new scala.collection.mutable.HashMap<ConstantTerm, ITerm>();
final scala.collection.mutable.HashMap<Predicate, IFormula> predicateSubst =
new scala.collection.mutable.HashMap<Predicate, IFormula>();
for (int i = 0; i < from.length; ++i) {
if (from[i] instanceof TermExpr) {
final ConstantTerm c = ((IConstant)((TermExpr)from[i]).term).c();
final ITerm t = ((TermExpr)to[i]).term;
constantSubst.put(c, t);
} else {
final Predicate p = ((IAtom)((FormulaExpr)from[i]).formula).pred();
assert(p.arity() == 0);
final IFormula f = ((FormulaExpr)to[i]).formula;
predicateSubst.put(p, f);
}
}
// We currently just assume that there are no clashes between substituted
// terms and predicates/formulae, and that the substitutions can be
// carried out in sequence
if (target instanceof TermExpr) {
final ITerm t1 = ((TermExpr)target).term;
final ITerm t2 = ConstantSubstVisitor$.MODULE$.apply(t1, constantSubst);
final ITerm t3 = PredicateSubstVisitor$.MODULE$.apply(t2, predicateSubst);
return new TermExpr(t3, target.getType());
} else {
final IFormula f1 = ((FormulaExpr)target).formula;
final IFormula f2 = ConstantSubstVisitor$.MODULE$.apply(f1, constantSubst);
final IFormula f3 = PredicateSubstVisitor$.MODULE$.apply(f2, predicateSubst);
return new FormulaExpr(f3);
}
}
示例6: simplify
import ap.parser.IFormula; //導入依賴的package包/類
@Override
protected IExpression simplify(IExpression f) {
// TODO this method is not tested, check it!
if (f instanceof IFormula) {
f = BooleanCompactifier.apply((IFormula) f);
}
return PartialEvaluator.apply(f);
}
示例7: ifThenElse
import ap.parser.IFormula; //導入依賴的package包/類
@Override
public IExpression ifThenElse(IExpression condition, IExpression t1, IExpression t2) {
if (t1 instanceof IFormula) {
return new IFormulaITE((IFormula) condition, (IFormula) t1, (IFormula) t2);
} else {
return new ITermITE((IFormula) condition, (ITerm) t1, (ITerm) t2);
}
}
示例8: not
import ap.parser.IFormula; //導入依賴的package包/類
@Override
public IFormula not(IExpression pBits) {
if (pBits instanceof INot) {
return ((INot) pBits).subformula(); // "not not a" == "a"
} else {
return new INot((IFormula) pBits);
}
}
示例9: simplify
import ap.parser.IFormula; //導入依賴的package包/類
/** simplification to avoid identical subgraphs: (a&b)&(a&c) --> a&(b&c), etc */
private IFormula simplify(IFormula f) {
if (f instanceof IBinFormula) {
final IBinFormula bin = (IBinFormula) f;
if (bin.f1() instanceof IBinFormula
&& bin.f2() instanceof IBinFormula
&& ((IBinFormula) bin.f1()).j().equals(((IBinFormula) bin.f2()).j())) {
Enumeration.Value operator = ((IBinFormula) f).j();
Enumeration.Value innerOperator = ((IBinFormula) bin.f1()).j();
IFormula s11 = ((IBinFormula) bin.f1()).f1();
IFormula s12 = ((IBinFormula) bin.f1()).f2();
IFormula s21 = ((IBinFormula) bin.f2()).f1();
IFormula s22 = ((IBinFormula) bin.f2()).f2();
// only check for object equality, for performance
if (s11 == s21) { // (ab)(ac) -> a(bc)
return new IBinFormula(innerOperator, s11, new IBinFormula(operator, s12, s22));
} else if (s11 == s22) { // (ab)(ca) -> a(bc)
return new IBinFormula(innerOperator, s11, new IBinFormula(operator, s12, s21));
} else if (s12 == s21) { // (ba)(ac) -> a(bc)
return new IBinFormula(innerOperator, s12, new IBinFormula(operator, s11, s22));
} else if (s12 == s22) { // (ba)(ca) -> a(bc)
return new IBinFormula(innerOperator, s12, new IBinFormula(operator, s11, s21));
}
}
}
// if we cannot simplify the formula, we create an abbreviation
// return getFormulaCreator().getEnv().abbrev(f);
return f;
}
示例10: addSymbol
import ap.parser.IFormula; //導入依賴的package包/類
/** add external definition: boolean variable. */
void addSymbol(IFormula f) {
Preconditions.checkState(!closed);
api.addBooleanVariable(f);
if (!trackingStack.isEmpty()) {
trackingStack.getLast().booleanSymbols.add(f);
}
}
示例11: parseStringToTerms
import ap.parser.IFormula; //導入依賴的package包/類
public List<? extends IExpression> parseStringToTerms(String s, PrincessFormulaCreator creator) {
Tuple3<
Seq<IFormula>, scala.collection.immutable.Map<IFunction, SMTFunctionType>,
scala.collection.immutable.Map<ConstantTerm, SMTType>>
triple = api.extractSMTLIBAssertionsSymbols(new StringReader(s));
List<? extends IExpression> formula = seqAsJavaList(triple._1());
Map<IFunction, SMTFunctionType> functionTypes = mapAsJavaMap(triple._2());
Map<ConstantTerm, SMTType> constantTypes = mapAsJavaMap(triple._3());
ImmutableSet.Builder<IExpression> declaredFunctions = ImmutableSet.builder();
for (IExpression f : formula) {
declaredFunctions.addAll(creator.extractVariablesAndUFs(f, true).values());
}
for (IExpression var : declaredFunctions.build()) {
if (var instanceof IConstant) {
SMTType type = constantTypes.get(((IConstant) var).c());
if (type instanceof SMTParser2InputAbsy.SMTArray) {
arrayVariablesCache.put(var.toString(), (ITerm) var);
} else {
intVariablesCache.put(var.toString(), (ITerm) var);
}
addSymbol((IConstant) var);
} else if (var instanceof IAtom) {
boolVariablesCache.put(((IAtom) var).pred().name(), (IFormula) var);
addSymbol((IAtom) var);
} else if (var instanceof IFunApp) {
IFunction fun = ((IFunApp) var).fun();
functionsCache.put(fun.name(), fun);
functionsReturnTypes.put(fun, convertToTermType(functionTypes.get(fun)));
addFunction(fun);
}
}
return formula;
}
示例12: getType
import ap.parser.IFormula; //導入依賴的package包/類
private static String getType(IExpression var) {
if (var instanceof IFormula) {
return "Bool";
// functions are included here, they cannot be handled separate for princess
} else if (var instanceof ITerm) {
return "Int";
}
throw new IllegalArgumentException("The given parameter is no variable or function");
}
示例13: tree2List
import ap.parser.IFormula; //導入依賴的package包/類
/** returns a post-order iteration of the tree. */
private List<BooleanFormula> tree2List(Tree<IFormula> tree) {
return from(Traverser.<Tree<IFormula>>forTree(node -> asJavaIterable(node.children()))
.depthFirstPostOrder(tree))
.transform(node -> mgr.encapsulateBooleanFormula(node.d()))
.toList();
}
示例14: mkQuantifier
import ap.parser.IFormula; //導入依賴的package包/類
@Override
public IExpression mkQuantifier(Quantifier q, List<IExpression> vars, IExpression body) {
checkArgument(body instanceof IFormula);
ap.terfor.conjunctions.Quantifier pq = (q == Quantifier.FORALL) ? ALL$.MODULE$ : EX$.MODULE$;
if (vars.size() == 0) {
// Body already contains bound variables.
return new IQuantified(pq, (IFormula) body);
} else {
return IExpression.quanConsts(
pq, iterableAsScalaIterable(toConstantTerm(vars)), (IFormula) body);
}
}
示例15: addConstraint
import ap.parser.IFormula; //導入依賴的package包/類
@Override
@Nullable
public Void addConstraint(BooleanFormula constraint) {
Preconditions.checkState(!closed);
final IFormula t = (IFormula) mgr.extractInfo(constraint);
final int formulaId = addAssertedFormula(t);
if (computeUnsatCores) {
api.setPartitionNumber(formulaId);
}
addConstraint0(t);
return null;
}