use of com.baidu.hugegraph.structure.traverser.FusiformSimilarity in project incubator-hugegraph-toolchain by apache.
the class FusiformSimilarityApiTest method testFusiformSimilarityTop.
@Test
public void testFusiformSimilarityTop() {
Object p1 = getVertexId("person", "name", "p1");
Object p2 = getVertexId("person", "name", "p2");
Object p3 = getVertexId("person", "name", "p3");
FusiformSimilarityRequest.Builder builder = FusiformSimilarityRequest.builder();
builder.sources().label("person").property("name", "p1");
builder.label("read").direction(Direction.OUT).minNeighbors(8).alpha(0.75D).top(2);
builder.capacity(-1).limit(-1);
FusiformSimilarityRequest request = builder.build();
FusiformSimilarity results = fusiformSimilarityAPI.post(request);
Assert.assertEquals(1, results.size());
Map.Entry<Object, Set<Similar>> entry = results.first();
Assert.assertEquals(p1, entry.getKey());
Assert.assertEquals(2, entry.getValue().size());
Set<Object> expected = ImmutableSet.of(p2, p3);
Set<Object> actual = entry.getValue().stream().map(Similar::id).collect(Collectors.toSet());
Assert.assertEquals(expected, actual);
builder = FusiformSimilarityRequest.builder();
builder.sources().label("person").property("name", "p1");
builder.label("read").direction(Direction.OUT).minNeighbors(6).alpha(0.8D).top(1);
builder.capacity(-1).limit(-1);
request = builder.build();
results = fusiformSimilarityAPI.post(request);
Assert.assertEquals(1, results.size());
entry = results.first();
Assert.assertEquals(p1, entry.getKey());
Assert.assertEquals(1, entry.getValue().size());
expected = ImmutableSet.of(p2);
actual = entry.getValue().stream().map(Similar::id).collect(Collectors.toSet());
Assert.assertEquals(expected, actual);
}
use of com.baidu.hugegraph.structure.traverser.FusiformSimilarity in project incubator-hugegraph-toolchain by apache.
the class FusiformSimilarityApiTest method testFusiformSimilarityMinGroupCount.
@Test
public void testFusiformSimilarityMinGroupCount() {
Object p1 = getVertexId("person", "name", "p1");
Object p2 = getVertexId("person", "name", "p2");
Object p3 = getVertexId("person", "name", "p3");
FusiformSimilarityRequest.Builder builder = FusiformSimilarityRequest.builder();
builder.sources().label("person").property("name", "p1");
builder.label("read").direction(Direction.OUT).minNeighbors(8).alpha(0.7D).groupProperty("city").minGroups(2);
builder.capacity(-1).limit(-1);
FusiformSimilarityRequest request = builder.build();
FusiformSimilarity results = fusiformSimilarityAPI.post(request);
Assert.assertEquals(1, results.size());
Map.Entry<Object, Set<Similar>> entry = results.first();
Assert.assertEquals(p1, entry.getKey());
Assert.assertEquals(2, entry.getValue().size());
Set<Object> expected = ImmutableSet.of(p2, p3);
Set<Object> actual = entry.getValue().stream().map(Similar::id).collect(Collectors.toSet());
Assert.assertEquals(expected, actual);
builder = FusiformSimilarityRequest.builder();
builder.sources().label("person").property("name", "p1");
builder.label("read").direction(Direction.OUT).minNeighbors(6).alpha(0.8D).groupProperty("city").minGroups(3);
builder.capacity(-1).limit(-1);
request = builder.build();
results = fusiformSimilarityAPI.post(request);
Assert.assertEquals(0, results.size());
}
use of com.baidu.hugegraph.structure.traverser.FusiformSimilarity in project incubator-hugegraph-toolchain by apache.
the class FusiformSimilarityApiTest method testFusiformSimilarityAlpha.
@Test
public void testFusiformSimilarityAlpha() {
Object p1 = getVertexId("person", "name", "p1");
Object p2 = getVertexId("person", "name", "p2");
Object p3 = getVertexId("person", "name", "p3");
FusiformSimilarityRequest.Builder builder = FusiformSimilarityRequest.builder();
builder.sources().label("person").property("name", "p1");
builder.label("read").direction(Direction.OUT).minNeighbors(8).alpha(0.75D).groupProperty("city").minGroups(2);
builder.capacity(-1).limit(-1);
FusiformSimilarityRequest request = builder.build();
FusiformSimilarity results = fusiformSimilarityAPI.post(request);
Assert.assertEquals(1, results.size());
Map.Entry<Object, Set<Similar>> entry = results.first();
Assert.assertEquals(p1, entry.getKey());
Assert.assertEquals(2, entry.getValue().size());
Set<Object> expected = ImmutableSet.of(p2, p3);
Set<Object> actual = entry.getValue().stream().map(Similar::id).collect(Collectors.toSet());
Assert.assertEquals(expected, actual);
builder = FusiformSimilarityRequest.builder();
builder.sources().label("person").property("name", "p1");
builder.label("read").direction(Direction.OUT).minNeighbors(6).alpha(0.83D).groupProperty("city").minGroups(2);
builder.capacity(-1).limit(-1);
request = builder.build();
results = fusiformSimilarityAPI.post(request);
Assert.assertEquals(1, results.size());
entry = results.first();
Assert.assertEquals(p1, entry.getKey());
Assert.assertEquals(1, entry.getValue().size());
expected = ImmutableSet.of(p2);
actual = entry.getValue().stream().map(Similar::id).collect(Collectors.toSet());
Assert.assertEquals(expected, actual);
}
use of com.baidu.hugegraph.structure.traverser.FusiformSimilarity in project incubator-hugegraph-toolchain by apache.
the class FusiformSimilarityApiTest method testFusiformSimilarityWithoutEdgeLabel.
@Test
public void testFusiformSimilarityWithoutEdgeLabel() {
Object p1 = getVertexId("person", "name", "p1");
Object p2 = getVertexId("person", "name", "p2");
Object p3 = getVertexId("person", "name", "p3");
FusiformSimilarityRequest.Builder builder = FusiformSimilarityRequest.builder();
builder.sources().ids(p1, p2, p3);
builder.direction(Direction.OUT).minNeighbors(8).alpha(0.875D);
builder.capacity(-1).limit(-1);
FusiformSimilarityRequest request = builder.build();
FusiformSimilarity results = fusiformSimilarityAPI.post(request);
Assert.assertEquals(3, results.size());
Map<Object, Set<Object>> expected = ImmutableMap.of(p1, ImmutableSet.of(p2, p3), p2, ImmutableSet.of(p1), p3, ImmutableSet.of(p1, p2));
for (Map.Entry<Object, Set<Similar>> e : results.similarsMap().entrySet()) {
Object key = e.getKey();
Set<Object> actual = e.getValue().stream().map(Similar::id).collect(Collectors.toSet());
Assert.assertEquals(expected.get(key), actual);
}
}
use of com.baidu.hugegraph.structure.traverser.FusiformSimilarity in project incubator-hugegraph-toolchain by apache.
the class FusiformSimilarityApiTest method testFusiformSimilarityMinSimilars.
@Test
public void testFusiformSimilarityMinSimilars() {
Object p1 = getVertexId("person", "name", "p1");
Object p2 = getVertexId("person", "name", "p2");
Object p3 = getVertexId("person", "name", "p3");
FusiformSimilarityRequest.Builder builder = FusiformSimilarityRequest.builder();
builder.sources().label("person").property("name", "p1");
builder.label("read").direction(Direction.OUT).minNeighbors(8).alpha(0.75D).minSimilars(3).groupProperty("city").minGroups(2);
builder.capacity(-1).limit(-1);
FusiformSimilarityRequest request = builder.build();
FusiformSimilarity results = fusiformSimilarityAPI.post(request);
Assert.assertEquals(0, results.size());
builder = FusiformSimilarityRequest.builder();
builder.sources().label("person").property("name", "p1");
builder.label("read").direction(Direction.OUT).minNeighbors(8).alpha(0.75D).minSimilars(2).groupProperty("city").minGroups(2);
builder.capacity(-1).limit(-1);
request = builder.build();
results = fusiformSimilarityAPI.post(request);
Assert.assertEquals(1, results.size());
Map.Entry<Object, Set<Similar>> entry = results.first();
Assert.assertEquals(p1, entry.getKey());
Assert.assertEquals(2, entry.getValue().size());
Set<Object> expected = ImmutableSet.of(p2, p3);
Set<Object> actual = entry.getValue().stream().map(Similar::id).collect(Collectors.toSet());
Assert.assertEquals(expected, actual);
builder = FusiformSimilarityRequest.builder();
builder.sources().label("person").property("name", "p1");
builder.label("read").direction(Direction.OUT).minNeighbors(8).alpha(0.75D).minSimilars(1).groupProperty("city").minGroups(2);
builder.capacity(-1).limit(-1);
request = builder.build();
results = fusiformSimilarityAPI.post(request);
Assert.assertEquals(1, results.size());
entry = results.first();
Assert.assertEquals(p1, entry.getKey());
Assert.assertEquals(2, entry.getValue().size());
Assert.assertEquals(expected, actual);
Assert.assertThrows(IllegalArgumentException.class, () -> {
FusiformSimilarityRequest.builder().minSimilars(0);
});
}
Aggregations