use of com.baidu.hugegraph.computer.core.graph.value.DoubleValue in project hugegraph-computer by hugegraph.
the class DefaultPropertiesTest method testHashCode.
@Test
public void testHashCode() {
DefaultProperties props = new DefaultProperties(graphFactory());
props.put("p1", new LongValue(1L));
props.put("p2", new DoubleValue(2.0D));
Assert.assertEquals(1073748897, props.hashCode());
}
use of com.baidu.hugegraph.computer.core.graph.value.DoubleValue in project hugegraph-computer by hugegraph.
the class DefaultPropertiesTest method testOverwrite.
@Test
public void testOverwrite() {
DefaultProperties properties = new DefaultProperties(graphFactory());
Assert.assertEquals(0, properties.get().size());
properties.put("p1", new LongValue(1L));
properties.put("p2", new DoubleValue(2.0D));
Assert.assertEquals(new LongValue(1L), properties.get("p1"));
properties.put("p1", new LongValue(2L));
Assert.assertEquals(new LongValue(2L), properties.get("p1"));
Map<String, Value> props = properties.get();
Assert.assertEquals(2, props.size());
Assert.assertEquals(new LongValue(2L), props.get("p1"));
Assert.assertEquals(new DoubleValue(2.0D), props.get("p2"));
}
use of com.baidu.hugegraph.computer.core.graph.value.DoubleValue in project hugegraph-computer by hugegraph.
the class PageRank method init.
@Override
public void init(Config config) {
this.alpha = config.getDouble(OPTION_ALPHA, ALPHA_DEFAULT_VALUE);
this.contribValue = new DoubleValue();
}
use of com.baidu.hugegraph.computer.core.graph.value.DoubleValue in project hugegraph-computer by hugegraph.
the class PageRank4Master method compute.
@Override
public boolean compute(MasterComputationContext context) {
LongValue danglingVerticesNum = context.aggregatedValue(AGGR_DANGLING_VERTICES_NUM);
DoubleValue danglingProbability = context.aggregatedValue(AGGR_COMULATIVE_DANGLING_PROBABILITY);
DoubleValue cumulativeProbability = context.aggregatedValue(AGGR_COMULATIVE_PROBABILITY);
DoubleValue l1NormDifference = context.aggregatedValue(AGGR_L1_NORM_DIFFERENCE_KEY);
StringBuilder sb = new StringBuilder();
sb.append("[Superstep ").append(context.superstep()).append("]").append(", dangling vertices num = ").append(danglingVerticesNum).append(", cumulative dangling probability = ").append(danglingProbability.value()).append(", cumulative probability = ").append(cumulativeProbability).append(", l1 norm difference = ").append(l1NormDifference.value());
LOG.info("PageRank running status: {}", sb);
double l1Diff = l1NormDifference.value();
if (context.superstep() > 1 && l1Diff <= this.l1DiffThreshold) {
return false;
} else {
return true;
}
}
use of com.baidu.hugegraph.computer.core.graph.value.DoubleValue in project hugegraph-computer by hugegraph.
the class ClosenessCentrality method compute0.
@Override
public void compute0(ComputationContext context, Vertex vertex) {
// Set empty map as initial value
vertex.value(new ClosenessValue());
// Send messages to adjacent edges
for (Edge edge : vertex.edges()) {
Id senderId = vertex.id();
// Get property value
double value = this.weightValue(edge.property(this.weightProp));
DoubleValue distance = new DoubleValue(value);
ClosenessMessage message = new ClosenessMessage(senderId, senderId, distance);
context.sendMessage(edge.targetId(), message);
}
}
Aggregations