symmetrizer.java
来自「Java版的SAT求解器」· Java 代码 · 共 40 行
JAVA
40 行
package positronic.satisfiability.bitstringrelation.binary;
import positronic.satisfiability.bitstring.BitStringEqualizer;
import positronic.satisfiability.bitstring.IBitString;
import positronic.satisfiability.elements.Conjunction;
import positronic.satisfiability.elements.Disjunction;
import positronic.satisfiability.elements.IProblem;
import positronic.satisfiability.elements.Problem;
import positronic.satisfiability.exceptions.SymmetrizerException;
public class Symmetrizer extends Problem implements IProblem
{
private static final long serialVersionUID = 1L;
public Symmetrizer(BitStringBinaryRelation relation) throws Exception
{
if(relation==null)
throw new SymmetrizerException("A null BitStringBinaryRelation was passed to a constructor.");
IProblem accum1=null;
for(int i=0;i<relation.getSize();i++)
{
IBitString currleft=relation.getBitString(i,0);
IBitString currright=relation.getBitString(i,1);
IProblem accum2=null;
for(int j=0;j<relation.getSize();j++)
{
IProblem result=new Conjunction(new BitStringEqualizer(currright,relation.getBitString(j,0))
,new BitStringEqualizer(currleft,relation.getBitString(j,1)));
if(accum2==null)
accum2=result;
else
accum2=new Disjunction(accum2,result);
}
accum1=new Conjunction(accum1,accum2);
}
this.setClauses(accum1.getClauses());
}
}
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?