use of at.ac.tuwien.kr.alpha.api.programs.analysis.ComponentGraph.SCComponent in project Alpha by alpha-asp.
the class StratificationAlgorithmTest method stratifyTwoRulesTest.
@Test
public void stratifyTwoRulesTest() {
StringBuilder bld = new StringBuilder();
bld.append("b :- a.").append("\n");
bld.append("c :- b.").append("\n");
ASPCore2Program prog = parser.parse(bld.toString());
NormalProgram normalProg = normalizeTransform.apply(prog);
AnalyzedProgram analyzed = AnalyzedProgram.analyzeNormalProgram(normalProg);
DependencyGraph dg = analyzed.getDependencyGraph();
ComponentGraph cg = ComponentGraphImpl.buildComponentGraph(dg, StronglyConnectedComponentsAlgorithm.findStronglyConnectedComponents(dg));
List<SCComponent> strata = StratificationAlgorithm.calculateStratification(cg);
Predicate a = Predicates.getPredicate("a", 0);
Predicate b = Predicates.getPredicate("b", 0);
Predicate c = Predicates.getPredicate("c", 0);
assertEquals(3, strata.size());
assertTrue(predicateIsBeforePredicateInOrder(a, b, strata));
assertTrue(predicateIsBeforePredicateInOrder(b, c, strata));
assertTrue(predicateIsBeforePredicateInOrder(a, c, strata));
}
use of at.ac.tuwien.kr.alpha.api.programs.analysis.ComponentGraph.SCComponent in project Alpha by alpha-asp.
the class StratificationAlgorithmTest method avoidDuplicatesTest1.
@Test
public void avoidDuplicatesTest1() {
StringBuilder bld = new StringBuilder();
bld.append("b :- a.");
bld.append("c :- b.");
bld.append("c :- a.");
ASPCore2Program prog = parser.parse(bld.toString());
NormalProgram normalProg = normalizeTransform.apply(prog);
AnalyzedProgram analyzed = AnalyzedProgram.analyzeNormalProgram(normalProg);
DependencyGraph dg = analyzed.getDependencyGraph();
ComponentGraph cg = ComponentGraphImpl.buildComponentGraph(dg, StronglyConnectedComponentsAlgorithm.findStronglyConnectedComponents(dg));
List<SCComponent> strata = StratificationAlgorithm.calculateStratification(cg);
Predicate a = Predicates.getPredicate("a", 0);
Predicate b = Predicates.getPredicate("b", 0);
Predicate c = Predicates.getPredicate("c", 0);
assertTrue(predicateIsBeforePredicateInOrder(a, b, strata));
assertTrue(predicateIsBeforePredicateInOrder(b, c, strata));
assertTrue(predicateIsBeforePredicateInOrder(a, c, strata));
assertEquals(3, strata.size());
}
use of at.ac.tuwien.kr.alpha.api.programs.analysis.ComponentGraph.SCComponent in project Alpha by alpha-asp.
the class StratificationAlgorithmTest method stratifyOneRuleTest.
@Test
public void stratifyOneRuleTest() {
ASPCore2Program prog = parser.parse("a :- b.");
NormalProgram normalProg = normalizeTransform.apply(prog);
AnalyzedProgram analyzed = AnalyzedProgram.analyzeNormalProgram(normalProg);
DependencyGraph dg = analyzed.getDependencyGraph();
ComponentGraph cg = ComponentGraphImpl.buildComponentGraph(dg, StronglyConnectedComponentsAlgorithm.findStronglyConnectedComponents(dg));
List<SCComponent> strata = StratificationAlgorithm.calculateStratification(cg);
Predicate a = Predicates.getPredicate("a", 0);
Predicate b = Predicates.getPredicate("b", 0);
assertEquals(2, strata.size());
assertTrue(predicateIsBeforePredicateInOrder(b, a, strata));
}
use of at.ac.tuwien.kr.alpha.api.programs.analysis.ComponentGraph.SCComponent in project Alpha by alpha-asp.
the class StratificationAlgorithmTest method stratifyLargeGraphTest.
@Test
public void stratifyLargeGraphTest() {
StringBuilder bld = new StringBuilder();
bld.append("b :- a.");
bld.append("c :- b.");
bld.append("d :- c.");
bld.append("e :- d.");
bld.append("f :- not e.");
bld.append("g :- d, j, not f.");
bld.append("h :- not c.");
bld.append("i :- h, not j.");
bld.append("j :- h, not i.");
bld.append("k :- g, not l.");
bld.append("l :- g, not k.");
bld.append("m :- not k, not l.");
bld.append("n :- m, not i, not j.");
bld.append("p :- not m, not n.");
ASPCore2Program prog = parser.parse(bld.toString());
NormalProgram normalProg = normalizeTransform.apply(prog);
AnalyzedProgram analyzed = AnalyzedProgram.analyzeNormalProgram(normalProg);
DependencyGraph dg = analyzed.getDependencyGraph();
ComponentGraph cg = ComponentGraphImpl.buildComponentGraph(dg, StronglyConnectedComponentsAlgorithm.findStronglyConnectedComponents(dg));
List<SCComponent> strata = StratificationAlgorithm.calculateStratification(cg);
Predicate a = Predicates.getPredicate("a", 0);
Predicate b = Predicates.getPredicate("b", 0);
Predicate c = Predicates.getPredicate("c", 0);
Predicate d = Predicates.getPredicate("d", 0);
Predicate e = Predicates.getPredicate("e", 0);
Predicate f = Predicates.getPredicate("f", 0);
Predicate h = Predicates.getPredicate("h", 0);
assertTrue(predicateIsBeforePredicateInOrder(a, h, strata));
assertTrue(predicateIsBeforePredicateInOrder(b, h, strata));
assertTrue(predicateIsBeforePredicateInOrder(c, h, strata));
assertTrue(predicateIsBeforePredicateInOrder(a, f, strata));
assertTrue(predicateIsBeforePredicateInOrder(b, f, strata));
assertTrue(predicateIsBeforePredicateInOrder(c, f, strata));
assertTrue(predicateIsBeforePredicateInOrder(d, f, strata));
assertTrue(predicateIsBeforePredicateInOrder(e, f, strata));
}
use of at.ac.tuwien.kr.alpha.api.programs.analysis.ComponentGraph.SCComponent in project Alpha by alpha-asp.
the class StratificationAlgorithmTest method stratifyWithNegativeDependencyTest.
@Test
public void stratifyWithNegativeDependencyTest() {
StringBuilder bld = new StringBuilder();
bld.append("b :- a.").append("\n");
bld.append("c :- b.").append("\n");
bld.append("d :- not c.").append("\n");
bld.append("e :- d.").append("\n");
ASPCore2Program prog = parser.parse(bld.toString());
NormalProgram normalProg = normalizeTransform.apply(prog);
AnalyzedProgram analyzed = AnalyzedProgram.analyzeNormalProgram(normalProg);
DependencyGraph dg = analyzed.getDependencyGraph();
ComponentGraph cg = ComponentGraphImpl.buildComponentGraph(dg, StronglyConnectedComponentsAlgorithm.findStronglyConnectedComponents(dg));
List<SCComponent> strata = StratificationAlgorithm.calculateStratification(cg);
Predicate a = Predicates.getPredicate("a", 0);
Predicate b = Predicates.getPredicate("b", 0);
Predicate c = Predicates.getPredicate("c", 0);
Predicate d = Predicates.getPredicate("d", 0);
Predicate e = Predicates.getPredicate("e", 0);
assertEquals(5, strata.size());
assertTrue(predicateIsBeforePredicateInOrder(a, b, strata));
assertTrue(predicateIsBeforePredicateInOrder(b, c, strata));
assertTrue(predicateIsBeforePredicateInOrder(c, d, strata));
assertTrue(predicateIsBeforePredicateInOrder(d, e, strata));
}
Aggregations