|
TrueFormula.java
|
/* * Copyright (c) 2005, Regents of the University of California * All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * * * Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * * * Redistributions in binary form must reproduce the above copyright * notice, this list of conditions and the following disclaimer in * the documentation and/or other materials provided with the * distribution. * * * Neither the name of the University of California, Berkeley nor * the names of its contributors may be used to endorse or promote * products derived from this software without specific prior * written permission. * * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED * OF THE POSSIBILITY OF SUCH DAMAGE. */ package blog; import java.util.*;
| A Formula consisting of just the zero-ary logical operator "true", which is true in every world under every assignment. |
public class TrueFormula extends Formula {
| A canonical instance of TrueFormula. |
public static final TrueFormula TRUE = new TrueFormula();
| Creates a new TrueFormula. |
public TrueFormula() {
}
public Object evaluate(EvalContext context) {
return Boolean.TRUE;
}
| The standard form of the formula "true" is an empty conjunction, which is always true. |
public Formula getStandardForm() {
return new ConjFormula(Collections.EMPTY_LIST);
}
| A formula equivalent to the negation of "true" is the empty disjunction, which is always false. |
protected Formula getEquivToNegationInternal() {
return new DisjFormula(Collections.EMPTY_LIST);
}
| The CNF form of TrueFormula has no conjuncts. |
public ConjFormula getPropCNF() {
return new ConjFormula(Collections.EMPTY_LIST);
}
| The DNF form of TrueFormula has just one disjunct, which is an empty conjunction. |
public DisjFormula getPropDNF() {
return new DisjFormula(new ConjFormula(Collections.EMPTY_LIST));
}
public Set getSatisfiersIfExplicit(EvalContext context,
LogicalVar subject,
GenericObject genericObj) {
return Formula.ALL_OBJECTS;
}
public Set getNonSatisfiersIfExplicit(EvalContext context,
LogicalVar subject,
GenericObject genericObj) {
return Collections.EMPTY_SET;
}
| Any two instances of TrueFormula are equal. |
public boolean equals(Object o) {
return (o instanceof TrueFormula);
}
public int hashCode() {
return Boolean.TRUE.hashCode();
}
| Returns the string "true". |
public String toString() {
return "true";
}
public boolean checkTypesAndScope(Model model, Map scope) {
return true;
}
public ArgSpec getSubstResult(Substitution subst,
Set<LogicalVar> boundVars) {
return this;
}
}
This file was generated on Tue Jun 08 17:53:36 PDT 2010 from file TrueFormula.java
by the ilog.language.tools.Hilite Java tool written by Hassan Aït-Kaci