1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28 package org.sat4j.pb.constraints;
29
30 import java.math.BigInteger;
31
32 import org.sat4j.core.Vec;
33 import org.sat4j.core.VecInt;
34 import org.sat4j.minisat.constraints.card.MinWatchCard;
35 import org.sat4j.minisat.constraints.cnf.Clauses;
36 import org.sat4j.minisat.constraints.cnf.LearntBinaryClause;
37 import org.sat4j.minisat.constraints.cnf.LearntWLClause;
38 import org.sat4j.minisat.constraints.cnf.OriginalBinaryClause;
39 import org.sat4j.minisat.constraints.cnf.OriginalWLClause;
40 import org.sat4j.minisat.constraints.cnf.UnitClause;
41 import org.sat4j.minisat.core.Constr;
42 import org.sat4j.pb.constraints.pb.IDataStructurePB;
43 import org.sat4j.specs.ContradictionException;
44 import org.sat4j.specs.IVec;
45 import org.sat4j.specs.IVecInt;
46
47 public class CompetResolutionPBMixedWLClauseCardConstrDataStructure extends
48 PBMaxClauseCardConstrDataStructure {
49
50 private static final long serialVersionUID = 1L;
51
52 @Override
53 public Constr createClause(IVecInt literals) throws ContradictionException {
54 IVecInt v = Clauses.sanityCheck(literals, getVocabulary(), solver);
55 if (v == null)
56 return null;
57 if (v.size() == 2) {
58 return OriginalBinaryClause.brandNewClause(solver, getVocabulary(),
59 v);
60 }
61 return OriginalWLClause.brandNewClause(solver, getVocabulary(), v);
62 }
63
64 @Override
65 protected Constr constructClause(IVecInt v) {
66 if (v == null)
67 return null;
68 if (v.size() == 2) {
69 return OriginalBinaryClause.brandNewClause(solver, getVocabulary(),
70 v);
71 }
72 return OriginalWLClause.brandNewClause(solver, getVocabulary(), v);
73 }
74
75 @Override
76 protected Constr constructLearntClause(IVecInt resLits) {
77 if (resLits.size() == 1) {
78 return new UnitClause(resLits.last());
79 }
80 if (resLits.size() == 2) {
81 return new LearntBinaryClause(resLits, getVocabulary());
82 }
83 return new LearntWLClause(resLits, getVocabulary());
84 }
85
86 @Override
87 protected Constr constructCard(IVecInt theLits, int degree)
88 throws ContradictionException {
89 return MinWatchCard.minWatchCardNew(solver, getVocabulary(), theLits,
90 MinWatchCard.ATLEAST, degree);
91 }
92
93 @Override
94 protected Constr constructLearntCard(IDataStructurePB dspb) {
95 IVecInt resLits = new VecInt();
96 IVec<BigInteger> resCoefs = new Vec<BigInteger>();
97 dspb.buildConstraintFromConflict(resLits, resCoefs);
98 return new MinWatchCard(getVocabulary(), resLits, true, dspb
99 .getDegree().intValue());
100 }
101
102 }