use of com.vaticle.typedb.core.traversal.common.VertexMap in project grakn by graknlabs.
the class TraversalTest method backtrack_seeks_do_not_skip_answers.
/**
* This test is interesting because it invalidates a traversal optimisation we implemented called `SeekStack`
* where we backtrack all the way back to the cause of a branch/closure failure, skipping all the query vertices
* that are planned in the middle.
*
* However this test shows that it is possible to successfully do a closure, then do perform a branch failure
* that because of the Seek optimisation jumps too far back and fails to generate other closure candidates, and
* misses an answer.
*/
@Ignore
@Test
public void backtrack_seeks_do_not_skip_answers() {
session = databaseMgr.session(database, Arguments.Session.Type.DATA);
// note: must insert in separate Tx's so that the relations are retrieved in a specific order later
try (CoreTransaction transaction = session.transaction(WRITE)) {
transaction.query().insert(TypeQL.parseQuery("insert $x isa person; (friend: $x) isa friendship;").asInsert());
transaction.commit();
}
try (CoreTransaction transaction = session.transaction(WRITE)) {
transaction.query().insert(TypeQL.parseQuery("insert" + "$y isa dog; (friend: $y) isa friendship;").asInsert());
transaction.commit();
}
try (CoreTransaction transaction = session.transaction(READ)) {
/*
match
$rel ($role: $friend);
$friend isa dog;
$rel isa $rel-type;
$rel-type type friendship, relates $role;
$role type friendship:friend;
*/
/*
1: ($rel-type *--[RELATES]--> $role)
2: ($rel-type <--[ISA]--* $rel) { isTransitive: true }
3: ($role <--[ISA]--* $rel:$role:$friend:1) { isTransitive: true }
4: ($rel *--[RELATING]--> $rel:$role:$friend:1)
5: ($rel:$role:$friend:1 <--[PLAYING]--* $friend)
*/
GraphProcedure.Builder proc = GraphProcedure.builder(5);
ProcedureVertex.Type rel_type = proc.namedType("rel-type", true);
rel_type.props().labels(set(Label.of("friendship")));
ProcedureVertex.Type role_type = proc.namedType("role-type");
role_type.props().labels(set(Label.of("friend", "friendship")));
ProcedureVertex.Thing rel = proc.namedThing("rel");
rel.props().types(set(Label.of("friendship")));
ProcedureVertex.Thing friend = proc.namedThing("friend");
friend.props().types(set(Label.of("dog")));
ProcedureVertex.Thing role = proc.scopedThing(rel, role_type, friend, 0);
proc.forwardRelates(1, rel_type, role_type);
proc.backwardIsa(2, rel_type, rel, true);
proc.backwardIsa(3, role_type, role, true);
proc.forwardRelating(4, rel, role);
proc.backwardPlaying(5, role, friend);
Traversal.Parameters params = new Traversal.Parameters();
Set<Identifier.Variable.Retrievable> filter = set(rel_type.id().asVariable().asRetrievable(), role_type.id().asVariable().asRetrievable(), rel.id().asVariable().asRetrievable(), friend.id().asVariable().asRetrievable());
GraphProcedure procedure = proc.build();
FunctionalIterator<VertexMap> vertices = procedure.iterator(transaction.traversal().graph(), params, filter);
assertEquals(1, vertices.count());
}
}
use of com.vaticle.typedb.core.traversal.common.VertexMap in project grakn by graknlabs.
the class RelationIterator method next.
@Override
public VertexMap next() {
if (!hasNext())
throw new NoSuchElementException();
VertexMap vertexMap = VertexMap.of(answer);
state = State.EMPTY;
return vertexMap;
}
use of com.vaticle.typedb.core.traversal.common.VertexMap in project grakn by graknlabs.
the class GraphProcedure method producer.
@Override
public FunctionalProducer<VertexMap> producer(GraphManager graphMgr, Traversal.Parameters params, Set<Identifier.Variable.Retrievable> filter, int parallelisation) {
if (LOG.isTraceEnabled()) {
LOG.trace(params.toString());
LOG.trace(this.toString());
}
assertWithinFilterBounds(filter);
if (startVertex().id().isRetrievable() && filter.contains(startVertex().id().asVariable().asRetrievable())) {
return async(startVertex().iterator(graphMgr, params).map(// TODO we can reduce the size of the distinct() set if the traversal engine doesn't overgenerate as much
v -> new GraphIterator(graphMgr, v, this, params, filter).distinct()), parallelisation);
} else {
// TODO we can reduce the size of the distinct() set if the traversal engine doesn't overgenerate as much
return async(startVertex().iterator(graphMgr, params).map(v -> new GraphIterator(graphMgr, v, this, params, filter)), parallelisation).distinct();
}
}
use of com.vaticle.typedb.core.traversal.common.VertexMap in project grakn by graknlabs.
the class TraversalTest method test_closure_backtrack_clears_scopes.
@Test
public void test_closure_backtrack_clears_scopes() {
session = databaseMgr.session(database, Arguments.Session.Type.SCHEMA);
try (TypeDB.Transaction transaction = session.transaction(WRITE)) {
TypeQLDefine query = TypeQL.parseQuery("define " + "lastname sub attribute, value string; " + "person sub entity, owns lastname; ");
transaction.query().define(query);
transaction.commit();
}
session.close();
session = databaseMgr.session(database, Arguments.Session.Type.DATA);
try (TypeDB.Transaction transaction = session.transaction(WRITE)) {
TypeQLInsert query = TypeQL.parseQuery("insert " + "$x isa person," + " has lastname \"Smith\"," + " has name \"Alex\";" + "$y isa person," + " has lastname \"Smith\"," + " has name \"John\";" + "$r (friend: $x, friend: $y) isa friendship, has ref 1;" + "$r1 (friend: $x, friend: $y) isa friendship, has ref 2;" + "$reflexive (friend: $x, friend: $x) isa friendship, has ref 3;").asInsert();
transaction.query().insert(query);
transaction.commit();
}
try (CoreTransaction transaction = session.transaction(READ)) {
GraphProcedure.Builder proc = GraphProcedure.builder(10);
/*
vertices:
$_0 [thing] { hasIID: false, types: [name], predicates: [= <STRING>] } (end) // Alex
$_1 [thing] { hasIID: false, types: [name], predicates: [= <STRING>] } (end) // John
$f1 [thing] { hasIID: false, types: [friendship], predicates: [] }
$n [thing] { hasIID: false, types: [lastname], predicates: [] } (start)
$r1 [thing] { hasIID: false, types: [ref], predicates: [= <LONG>] } (end) // 3
$r2 [thing] { hasIID: false, types: [ref], predicates: [= <LONG>] } (end) // 1
$refl [thing] { hasIID: false, types: [friendship], predicates: [] }
$x [thing] { hasIID: false, types: [person], predicates: [] }
$y [thing] { hasIID: false, types: [person], predicates: [] }
*/
ProcedureVertex.Thing _0 = proc.anonymousThing(0);
_0.props().predicate(Predicate.Value.String.of(TypeQLToken.Predicate.Equality.EQ));
_0.props().types(set(Label.of("name")));
ProcedureVertex.Thing _1 = proc.anonymousThing(1);
_1.props().predicate(Predicate.Value.String.of(TypeQLToken.Predicate.Equality.EQ));
_1.props().types(set(Label.of("name")));
ProcedureVertex.Thing f1 = proc.namedThing("f1");
f1.props().types(set(Label.of("friendship")));
ProcedureVertex.Thing refl = proc.namedThing("refl");
refl.props().types(set(Label.of("friendship")));
ProcedureVertex.Thing n = proc.namedThing("n", true);
n.props().types(set(Label.of("lastname")));
ProcedureVertex.Thing r1 = proc.namedThing("r1");
r1.props().predicate(Predicate.Value.Numerical.of(TypeQLToken.Predicate.Equality.EQ, PredicateArgument.Value.LONG));
r1.props().types(set(Label.of("ref")));
ProcedureVertex.Thing r2 = proc.namedThing("r2");
r2.props().predicate(Predicate.Value.Numerical.of(TypeQLToken.Predicate.Equality.EQ, PredicateArgument.Value.LONG));
r2.props().types(set(Label.of("ref")));
ProcedureVertex.Thing x = proc.namedThing("x");
x.props().types(set(Label.of("person")));
ProcedureVertex.Thing y = proc.namedThing("y");
y.props().types(set(Label.of("person")));
GraphTraversal.Thing.Parameters params = new GraphTraversal.Thing.Parameters();
params.pushValue(_0.id().asVariable(), Predicate.Value.String.of(TypeQLToken.Predicate.Equality.EQ), new GraphTraversal.Thing.Parameters.Value("Alex"));
params.pushValue(_1.id().asVariable(), Predicate.Value.String.of(TypeQLToken.Predicate.Equality.EQ), new GraphTraversal.Thing.Parameters.Value("John"));
params.pushValue(r1.id().asVariable(), Predicate.Value.Numerical.of(TypeQLToken.Predicate.Equality.EQ, PredicateArgument.Value.LONG), new GraphTraversal.Thing.Parameters.Value(3L));
params.pushValue(r2.id().asVariable(), Predicate.Value.Numerical.of(TypeQLToken.Predicate.Equality.EQ, PredicateArgument.Value.LONG), new GraphTraversal.Thing.Parameters.Value(1L));
/*
edges:
1: ($n <--[HAS]--* $x)
2: ($n <--[HAS]--* $y)
3: ($x *--[HAS]--> $_0)
4: ($x <--[ROLEPLAYER]--* $refl) { roleTypes: [friendship:friend] }
5: ($x <--[ROLEPLAYER]--* $refl) { roleTypes: [friendship:friend] }
6: ($x <--[ROLEPLAYER]--* $f1) { roleTypes: [friendship:friend] }
7: ($y *--[HAS]--> $_1)
8: ($y <--[ROLEPLAYER]--* $f1) { roleTypes: [friendship:friend] }
9: ($refl *--[HAS]--> $r1)
10: ($f1 *--[HAS]--> $r2)
*/
proc.backwardHas(1, n, x);
proc.backwardHas(2, n, y);
proc.forwardHas(3, x, _0);
proc.backwardRolePlayer(4, x, refl, set(Label.of("friend", "friendship")));
proc.backwardRolePlayer(5, x, refl, set(Label.of("friend", "friendship")));
proc.backwardRolePlayer(6, x, f1, set(Label.of("friend", "friendship")));
proc.forwardHas(7, y, _1);
proc.backwardRolePlayer(8, y, f1, set(Label.of("friend", "friendship")));
proc.forwardHas(9, refl, r1);
proc.forwardHas(10, f1, r2);
Set<Identifier.Variable.Retrievable> filter = set(n.id().asVariable().asRetrievable(), x.id().asVariable().asRetrievable(), y.id().asVariable().asRetrievable(), refl.id().asVariable().asRetrievable(), f1.id().asVariable().asRetrievable(), r1.id().asVariable().asRetrievable(), r1.id().asVariable().asRetrievable(), _0.id().asVariable().asRetrievable(), _1.id().asVariable().asRetrievable());
GraphProcedure procedure = proc.build();
FunctionalIterator<VertexMap> vertices = procedure.iterator(transaction.traversal().graph(), params, filter);
vertices.next();
}
session.close();
}
Aggregations