當前位置: 首頁>>代碼示例>>Java>>正文


Java MessageIterator類代碼示例

本文整理匯總了Java中org.apache.flink.graph.spargel.MessageIterator的典型用法代碼示例。如果您正苦於以下問題:Java MessageIterator類的具體用法?Java MessageIterator怎麽用?Java MessageIterator使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


MessageIterator類屬於org.apache.flink.graph.spargel包,在下文中一共展示了MessageIterator類的11個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: updateVertex

import org.apache.flink.graph.spargel.MessageIterator; //導入依賴的package包/類
@Override
public void updateVertex(Vertex<K, Double> vertex,
		MessageIterator<Double> inMessages) {

	Double minDistance = Double.MAX_VALUE;

	for (double msg : inMessages) {
		if (msg < minDistance) {
			minDistance = msg;
		}
	}

	if (vertex.getValue() > minDistance) {
		setNewVertexValue(minDistance);
	}
}
 
開發者ID:axbaretto,項目名稱:flink,代碼行數:17,代碼來源:SingleSourceShortestPaths.java

示例2: updateVertex

import org.apache.flink.graph.spargel.MessageIterator; //導入依賴的package包/類
@Override
public void updateVertex(Vertex<GradoopId, GradoopId> vertex,
  MessageIterator<GradoopId> messageIterator) throws Exception {

  GradoopId lastComponent = vertex.getValue();
  GradoopId newComponent = lastComponent;

  for (GradoopId messageComponent : messageIterator) {

    if (messageComponent.compareTo(newComponent) < 0) {
      newComponent = messageComponent;
    }
  }

  if (!lastComponent.equals(newComponent)) {
    setNewVertexValue(newComponent);
  }
}
 
開發者ID:dbs-leipzig,項目名稱:gradoop,代碼行數:19,代碼來源:BtgUpdater.java

示例3: updateVertex

import org.apache.flink.graph.spargel.MessageIterator; //導入依賴的package包/類
@Override
public void updateVertex(Vertex<Long, Double> vertex, MessageIterator<Double> inMessages) throws Exception {
	if (inMessages.hasNext()) {
		Long outDegree = getOutDegree() - 1;
		// check if the vertex has another SP-Edge
		if (outDegree <= 0) {
			// set own value to infinity
			setNewVertexValue(Double.MAX_VALUE);
		}
	}
}
 
開發者ID:axbaretto,項目名稱:flink,代碼行數:12,代碼來源:IncrementalSSSP.java

示例4: updateVertex

import org.apache.flink.graph.spargel.MessageIterator; //導入依賴的package包/類
@Override
public void updateVertex(Vertex<Long, Double> vertex, MessageIterator<Double> inMessages) {

	Double minDistance = Double.MAX_VALUE;

	for (double msg : inMessages) {
		if (msg < minDistance) {
			minDistance = msg;
		}
	}

	if (vertex.getValue() > minDistance) {
		setNewVertexValue(minDistance);
	}
}
 
開發者ID:axbaretto,項目名稱:flink,代碼行數:16,代碼來源:SingleSourceShortestPaths.java

示例5: updateVertex

import org.apache.flink.graph.spargel.MessageIterator; //導入依賴的package包/類
@Override
public void updateVertex(Vertex<K, Double> vertex, MessageIterator<Double> inMessages) {
	double rankSum = 0.0;
	for (double msg : inMessages) {
		rankSum += msg;
	}

	// apply the dampening factor / random jump
	double newRank = (beta * rankSum) + (1 - beta) / this.getNumberOfVertices();
	setNewVertexValue(newRank);
}
 
開發者ID:axbaretto,項目名稱:flink,代碼行數:12,代碼來源:PageRank.java

示例6: updateVertex

import org.apache.flink.graph.spargel.MessageIterator; //導入依賴的package包/類
@Override
public void updateVertex(Vertex<K, VV> vertex, MessageIterator<VV> messages) throws Exception {
	VV current = vertex.getValue();
	VV min = current;

	for (VV msg : messages) {
		if (msg.compareTo(min) < 0) {
			min = msg;
		}
	}

	if (!min.equals(current)) {
		setNewVertexValue(min);
	}
}
 
開發者ID:axbaretto,項目名稱:flink,代碼行數:16,代碼來源:ConnectedComponents.java

示例7: updateVertex

import org.apache.flink.graph.spargel.MessageIterator; //導入依賴的package包/類
public void updateVertex(Vertex<K, VV> vertex, MessageIterator<VV> inMessages) {
	Map<VV, Long> labelsWithFrequencies = new HashMap<>();

	long maxFrequency = 1;
	VV mostFrequentLabel = vertex.getValue();

	// store the labels with their frequencies
	for (VV msg : inMessages) {
		if (labelsWithFrequencies.containsKey(msg)) {
			long currentFreq = labelsWithFrequencies.get(msg);
			labelsWithFrequencies.put(msg, currentFreq + 1);
		} else {
			labelsWithFrequencies.put(msg, 1L);
		}
	}
	// select the most frequent label: if two or more labels have the
	// same frequency, the node adopts the label with the highest value
	for (Entry<VV, Long> entry : labelsWithFrequencies.entrySet()) {
		if (entry.getValue() == maxFrequency) {
			// check the label value to break ties
			if (entry.getKey().compareTo(mostFrequentLabel) > 0) {
				mostFrequentLabel = entry.getKey();
			}
		} else if (entry.getValue() > maxFrequency) {
			maxFrequency = entry.getValue();
			mostFrequentLabel = entry.getKey();
		}
	}
	setNewVertexValue(mostFrequentLabel);
}
 
開發者ID:axbaretto,項目名稱:flink,代碼行數:31,代碼來源:LabelPropagation.java

示例8: updateVertex

import org.apache.flink.graph.spargel.MessageIterator; //導入依賴的package包/類
@Override
public void updateVertex(Vertex<Long, Long> vertex, MessageIterator<Long> inMessages) {
	long superstep = getSuperstepNumber();
	aggregator.aggregate(superstep);

	setNewVertexValue(vertex.getValue() + 1);
}
 
開發者ID:axbaretto,項目名稱:flink,代碼行數:8,代碼來源:ScatterGatherConfigurationITCase.java

示例9: updateVertex

import org.apache.flink.graph.spargel.MessageIterator; //導入依賴的package包/類
/**
 * Updates the vertex value if it has changed.
 *
 * @param vertex  vertex to be updated
 * @param msg     message
 * @throws Exception
 */
@Override
public void updateVertex(Vertex<GradoopId, PropertyValue> vertex,
  MessageIterator<PropertyValue> msg) throws Exception {
  PropertyValue value = getNewValue(vertex,
    Lists.newArrayList(msg.iterator()));
  if (!vertex.getValue().equals(value)) {
    setNewVertexValue(value);
  }
}
 
開發者ID:dbs-leipzig,項目名稱:gradoop,代碼行數:17,代碼來源:LPUpdateFunction.java

示例10: updateVertex

import org.apache.flink.graph.spargel.MessageIterator; //導入依賴的package包/類
@Override
public void updateVertex(Vertex<K, Tuple2<Long, Double>> vertex,
						MessageIterator<Tuple2<Long, Double>> inMessages) throws Exception {

	// we would like these two maps to be ordered
	Map<Long, Double> receivedLabelsWithScores = new TreeMap<>();
	Map<Long, Double> labelsWithHighestScore = new TreeMap<>();

	for (Tuple2<Long, Double> message : inMessages) {
		// split the message into received label and score
		long receivedLabel = message.f0;
		double receivedScore = message.f1;

		// if the label was received before
		if (receivedLabelsWithScores.containsKey(receivedLabel)) {
			double newScore = receivedScore + receivedLabelsWithScores.get(receivedLabel);
			receivedLabelsWithScores.put(receivedLabel, newScore);
		} else {
			// first time we see the label
			receivedLabelsWithScores.put(receivedLabel, receivedScore);
		}

		// store the labels with the highest scores
		if (labelsWithHighestScore.containsKey(receivedLabel)) {
			double currentScore = labelsWithHighestScore.get(receivedLabel);
			if (currentScore < receivedScore) {
				// record the highest score
				labelsWithHighestScore.put(receivedLabel, receivedScore);
			}
		} else {
			// first time we see this label
			labelsWithHighestScore.put(receivedLabel, receivedScore);
		}
	}

	if (receivedLabelsWithScores.size() > 0) {
		// find the label with the highest score from the ones received
		double maxScore = -Double.MAX_VALUE;
		long maxScoreLabel = vertex.getValue().f0;
		for (long curLabel : receivedLabelsWithScores.keySet()) {

			if (receivedLabelsWithScores.get(curLabel) > maxScore) {
				maxScore = receivedLabelsWithScores.get(curLabel);
				maxScoreLabel = curLabel;
			}
		}

		// find the highest score of maxScoreLabel
		double highestScore = labelsWithHighestScore.get(maxScoreLabel);
		// re-score the new label
		if (maxScoreLabel != vertex.getValue().f0) {
			highestScore -= delta / getSuperstepNumber();
		}
		// else delta = 0
		// update own label
		setNewVertexValue(new Tuple2<>(maxScoreLabel, highestScore));
	}
}
 
開發者ID:axbaretto,項目名稱:flink,代碼行數:59,代碼來源:CommunityDetection.java

示例11: updateVertex

import org.apache.flink.graph.spargel.MessageIterator; //導入依賴的package包/類
@Override
public void updateVertex(Vertex<Long, Long> vertex, MessageIterator<Long> inMessages) {
	long superstep = getSuperstepNumber();
	Assert.assertEquals(true, vertex.getValue() == superstep);
	setNewVertexValue(vertex.getValue() + 1);
}
 
開發者ID:axbaretto,項目名稱:flink,代碼行數:7,代碼來源:CollectionModeSuperstepITCase.java


注:本文中的org.apache.flink.graph.spargel.MessageIterator類示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。