本文整理汇总了Java中org.jgrapht.graph.SimpleWeightedGraph类的典型用法代码示例。如果您正苦于以下问题:Java SimpleWeightedGraph类的具体用法?Java SimpleWeightedGraph怎么用?Java SimpleWeightedGraph使用的例子?那么, 这里精选的类代码示例或许可以为您提供帮助。
SimpleWeightedGraph类属于org.jgrapht.graph包,在下文中一共展示了SimpleWeightedGraph类的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Java代码示例。
示例1: getWeightedGraph
import org.jgrapht.graph.SimpleWeightedGraph; //导入依赖的package包/类
/**
* Convert FNSS Topology to JGraphT weighted graph.
*
* The weights assigned to the edges of the returned graph are the link
* weights of the original FNSS topology. If the topology object does not
* have weights assigned, all nodes are assigned a weight equal to 1.
*
* Because of the specific limitations of JGraphT, the edges of the returned
* graph must be instances of JGraphT <code>DefaultWeightedEdge</code>, and
* do not hold capacity, buffer sizes and delay information possibly present
* in the original FNSS Topology. The returned graph maintains however
* link weight information.
*
* See examples for further information.
*
* @param topology FNSS Topology object
* @return A JGraphT weighted graph
*/
public static WeightedGraph<String, DefaultWeightedEdge> getWeightedGraph(Topology topology) {
WeightedGraph<String, DefaultWeightedEdge> graph = null;
if (topology.isDirected()) {
graph = new SimpleDirectedWeightedGraph<String, DefaultWeightedEdge>(DefaultWeightedEdge.class);
} else {
graph = new SimpleWeightedGraph<String, DefaultWeightedEdge>(DefaultWeightedEdge.class);
}
for(String node : topology.getAllNodes()) {
graph.addVertex(node);
}
for(Pair<String, String> endpoints : topology.getAllEdges()) {
float weight = topology.getEdge(endpoints).getWeight();
DefaultWeightedEdge edge = new DefaultWeightedEdge();
graph.addEdge(endpoints.getU(), endpoints.getV(), edge);
graph.setEdgeWeight(edge, weight);
}
return graph;
}
示例2: writeSimpleWeightedGraph2CSV
import org.jgrapht.graph.SimpleWeightedGraph; //导入依赖的package包/类
public static void writeSimpleWeightedGraph2CSV(SimpleWeightedGraph<Long, DefaultWeightedEdge> colocationgraph,
File file) throws IOException {
CSVWriter writer = new CSVWriter(new FileWriter(file), ';');
// write header
String[] line = new String[4];
line[0] = "source";
line[1] = "target";
line[2] = "weight";
line[3] = "type";
writer.writeNext(line);
for (DefaultWeightedEdge e : colocationgraph.edgeSet()) {
line = new String[4];
line[0] = String.valueOf(colocationgraph.getEdgeSource(e).longValue() + (long) 111);
line[1] = String.valueOf(colocationgraph.getEdgeTarget(e).longValue() + (long) 111);
line[2] = String.valueOf(colocationgraph.getEdgeWeight(e));
line[3] = "undirected";
writer.writeNext(line);
}
writer.close();
}
示例3: participationCoefficient
import org.jgrapht.graph.SimpleWeightedGraph; //导入依赖的package包/类
public static HashMap<Long, Double> participationCoefficient(
SimpleWeightedGraph<Long, DefaultWeightedEdge> simpleG1,
SimpleWeightedGraph<Long, DefaultWeightedEdge> simpleG2,
SimpleWeightedGraph<Long, DefaultWeightedEdge> simpleG3,
SimpleWeightedGraph<Long, DefaultWeightedEdge> simpleG4, HashMap<Long, Long> overlappingDegList) {
// nbLayer/(nbLayer-1)
Double m = Double.valueOf(4) / Double.valueOf(3);
HashMap<Long, Double> participationList = new HashMap<Long, Double>();
for (Long v : simpleG1.vertexSet()) {
Double overlap = Double.valueOf(overlappingDegList.get(v));
if (overlap == 0)
continue;
Double m1 = Double.valueOf(simpleG1.degreeOf(v)) / overlap;
Double m2 = Double.valueOf(simpleG2.degreeOf(v)) / overlap;
Double m3 = Double.valueOf(simpleG3.degreeOf(v)) / overlap;
Double m4 = Double.valueOf(simpleG4.degreeOf(v)) / overlap;
Double sum = m1 * m1 + m2 * m2 + m3 * m3 + m4 * m4;
Double pcoeff = m * (1 - sum);
participationList.put(v, pcoeff);
// System.out.println("Utilisateur : " + v + " - participation coeff
// : " + (double) pcoeff);
}
return participationList;
}
示例4: createSimpleAdjacencyMatrix
import org.jgrapht.graph.SimpleWeightedGraph; //导入依赖的package包/类
/**
* creates the adjacency matrix of a simple weighted graph
**/
public static double[][] createSimpleAdjacencyMatrix(SimpleWeightedGraph<Long, DefaultWeightedEdge> simpleG,
double threshold) {
HashMap<Long, Integer> contributorIndex = contributorIndex(simpleG);
// Crée une matrice de taille nbContributeurs x nbContributeurs
// initialisés à zéro par défaut
double[][] adj = new double[simpleG.vertexSet().size()][simpleG.vertexSet().size()];
for (DefaultWeightedEdge e : simpleG.edgeSet()) {
Long nodeI = simpleG.getEdgeSource(e);
Long nodeF = simpleG.getEdgeTarget(e);
double w = simpleG.getEdgeWeight(e);
// Remplit la matrice symétrique
int j = contributorIndex.get(nodeI);
int k = contributorIndex.get(nodeF);
if (w >= threshold) {
adj[j][k] = 1;
adj[k][j] = 1;
}
}
return adj;
}
示例5: createInteractionMatrix
import org.jgrapht.graph.SimpleWeightedGraph; //导入依赖的package包/类
public static double[][] createInteractionMatrix(SimpleWeightedGraph<Long, DefaultWeightedEdge> simpleG) {
HashMap<Long, Integer> contributorIndex = new HashMap<Long, Integer>();
int i = 0;
for (Long v : simpleG.vertexSet()) {
contributorIndex.put(v, i);
// System.out.println("Ajout de l'utilisateur " + v + " indice " +
// i);
i++;
}
// Crée une matrice de taille nbContributeurs x nbContributeurs
// initialisés à zéro par défaut
double[][] adj = new double[simpleG.vertexSet().size()][simpleG.vertexSet().size()];
for (DefaultWeightedEdge e : simpleG.edgeSet()) {
Long nodeI = simpleG.getEdgeSource(e);
Long nodeF = simpleG.getEdgeTarget(e);
double w = simpleG.getEdgeWeight(e);
// Remplit la matrice symétrique
int j = contributorIndex.get(nodeI);
int k = contributorIndex.get(nodeF);
adj[j][k] = w;
adj[k][j] = w;
}
return adj;
}
示例6: createMultiplexAdjacencyMatrix
import org.jgrapht.graph.SimpleWeightedGraph; //导入依赖的package包/类
/**
* creates the adjacency matrix of a multiplex system composed of 4 simple
* weighted graphs
**/
public static ArrayList<double[][]> createMultiplexAdjacencyMatrix(
SimpleWeightedGraph<Long, DefaultWeightedEdge> simpleG1,
SimpleWeightedGraph<Long, DefaultWeightedEdge> simpleG2,
SimpleWeightedGraph<Long, DefaultWeightedEdge> simpleG3,
SimpleWeightedGraph<Long, DefaultWeightedEdge> simpleG4) {
double[][] adjG1 = createSimpleAdjacencyMatrix(simpleG1, 1);
double[][] adjG2 = createSimpleAdjacencyMatrix(simpleG2, 1);
double[][] adjG3 = createSimpleAdjacencyMatrix(simpleG3, 1);
double[][] adjG4 = createSimpleAdjacencyMatrix(simpleG4, 0);
ArrayList<double[][]> adjMultiplex = new ArrayList<double[][]>();
adjMultiplex.add(adjG1);
adjMultiplex.add(adjG2);
adjMultiplex.add(adjG3);
adjMultiplex.add(adjG4);
return adjMultiplex;
}
示例7: getMST
import org.jgrapht.graph.SimpleWeightedGraph; //导入依赖的package包/类
private SimpleWeightedGraph<MSTNode<T>, DefaultWeightedEdge> getMST() {
if (graph.vertexSet().size() == 1)
{
return graph; // PrimMinimum
}
SpanningTree<DefaultWeightedEdge> internMst = new KruskalMinimumSpanningTree<>(graph)
.getSpanningTree();
Set<DefaultWeightedEdge> edges = internMst.getEdges();
Set<MSTNode<T>> nodes = graph.vertexSet();
SimpleWeightedGraph<MSTNode<T>, DefaultWeightedEdge> internSWG = new SimpleWeightedGraph<>(
DefaultWeightedEdge.class);
for (MSTNode<T> node : nodes) {
internSWG.addVertex(node);
}
for (DefaultWeightedEdge dwe : edges) {
DefaultWeightedEdge newEdge = internSWG.addEdge(graph.getEdgeSource(dwe),
graph.getEdgeTarget(dwe));
internSWG.setEdgeWeight(newEdge, graph.getEdgeWeight(dwe));
}
return internSWG;
}
示例8: build
import org.jgrapht.graph.SimpleWeightedGraph; //导入依赖的package包/类
/**
* Builds a simple weighted graph
* @param data The input list of tuples each holds two indices and distance between them
*/
public static Graph<Integer, DefaultWeightedEdge> build(List<Tuple3<Integer, Integer, Double>> data) {
// initialize a weighted graph
Graph<Integer, DefaultWeightedEdge> graph = new SimpleWeightedGraph<Integer, DefaultWeightedEdge>(DefaultWeightedEdge.class);
// add vertices and edges to the weighted graph
for (Tuple3<Integer, Integer, Double> t : data) {
int i = t._1();
int j = t._2();
double score = t._3();
graph.addVertex(i);
graph.addVertex(j);
DefaultWeightedEdge e = graph.addEdge(i, j);
((AbstractBaseGraph<Integer, DefaultWeightedEdge>) graph).setEdgeWeight(e, score);
}
return graph;
}
示例9: getMinimumSpanningTree
import org.jgrapht.graph.SimpleWeightedGraph; //导入依赖的package包/类
/**
* Builds a graph that contains a Minimum Spanning Tree
* @param graph The input weighted graph
*/
public static Graph<Integer, DefaultWeightedEdge> getMinimumSpanningTree(Graph<Integer, DefaultWeightedEdge> graph) {
// get the edges of a Minimum Spanning Tree generated for a weighted graph
PrimMinimumSpanningTree<Integer, DefaultWeightedEdge> tree = new PrimMinimumSpanningTree<Integer, DefaultWeightedEdge>(graph);
Set<DefaultWeightedEdge> mspEdges = tree.getMinimumSpanningTreeEdgeSet();
// build a new graph from the MST edges
Graph<Integer, DefaultWeightedEdge> mspGraph = new SimpleWeightedGraph<Integer, DefaultWeightedEdge>(DefaultWeightedEdge.class);
for (DefaultWeightedEdge e : mspEdges) {
int sourceV = graph.getEdgeSource(e);
int targetV = graph.getEdgeTarget(e);
mspGraph.addVertex(sourceV);
mspGraph.addVertex(targetV);
DefaultWeightedEdge edge = graph.getEdge(sourceV, targetV);
double w = graph.getEdgeWeight(edge);
mspGraph.addEdge(sourceV, targetV, edge);
((AbstractBaseGraph<Integer, DefaultWeightedEdge>) mspGraph).setEdgeWeight(edge, w);
}
return mspGraph;
}
示例10: generateZoneGraph
import org.jgrapht.graph.SimpleWeightedGraph; //导入依赖的package包/类
public static WeightedGraph<NdPoint, DefaultWeightedEdge> generateZoneGraph(Collection<Zone> allZones) {
WeightedGraph<NdPoint, DefaultWeightedEdge> graph = new SimpleWeightedGraph<NdPoint, DefaultWeightedEdge>(
DefaultWeightedEdge.class);
for (Zone p : allZones) {
graph.addVertex(p.getLocation());
}
for (Zone p1 : allZones) {
for (Zone p2 : p1.getNeighbours()) {
DefaultWeightedEdge edge = graph.addEdge(p1.getLocation(), p2.getLocation());
/**
* If we get edge==null, the edge already has been added.
*/
if (edge != null) {
graph.setEdgeWeight(edge, p1.distanceTo(p2));
}
}
}
return graph;
}
示例11: findPath
import org.jgrapht.graph.SimpleWeightedGraph; //导入依赖的package包/类
/**
* find a path from start to end point given a list of obstacles.
*
* @param obstacles set of all obstacles involved in the search.
* @return List of subsequent NdPoints from start to finish.
*/
public static List<NdPoint> findPath(List<Zone> allZones, List<BoundedMoveableObject> obstacles,
NdPoint startPoint, NdPoint endPoint, int botSize) {
SimpleWeightedGraph<NdPoint, DefaultWeightedEdge> graph = generateNdPointGraph(startPoint, allZones,
obstacles, botSize);
try {
NdPoint start = findNearestRoundedPoint(startPoint, graph);
NdPoint end = findNearestRoundedPoint(endPoint, graph);
return findPath(graph, start, end);
} catch (SpatialException ex) {
return new ArrayList<>(0);
}
}
示例12: createSimpleConnectedWeightedGraph
import org.jgrapht.graph.SimpleWeightedGraph; //导入依赖的package包/类
protected Graph<String, DefaultWeightedEdge> createSimpleConnectedWeightedGraph() {
Graph<String, DefaultWeightedEdge> g =
new SimpleWeightedGraph<String, DefaultWeightedEdge>(DefaultWeightedEdge.class);
double bias = 1;
g.addVertex(A);
g.addVertex(B);
g.addVertex(C);
g.addVertex(D);
g.addVertex(E);
AB = Graphs.addEdge(g, A, B, bias * 2);
AC = Graphs.addEdge(g, A, C, bias * 3);
BD = Graphs.addEdge(g, B, D, bias * 5);
CD = Graphs.addEdge(g, C, D, bias * 20);
DE = Graphs.addEdge(g, D, E, bias * 5);
AE = Graphs.addEdge(g, A, E, bias * 100);
return g;
}
示例13: match
import org.jgrapht.graph.SimpleWeightedGraph; //导入依赖的package包/类
static KuhnMunkresMinimalWeightBipartitePerfectMatching<V, WeightedEdge>
match(final double[][] costMatrix, final int partitionCardinality) {
List<? extends V> first = firstPartition.subList(0, partitionCardinality);
List<? extends V> second = secondPartition.subList(0, partitionCardinality);
WeightedGraph<V, WeightedEdge> target =
new SimpleWeightedGraph<V, WeightedEdge>(new EdgeFactory<V, WeightedEdge>() {
@Override
public WeightedEdge createEdge(V sourceVertex, V targetVertex) {
return WeightedEdge.make(sourceVertex, targetVertex);
}
});
WeightedGraphGeneratorAdapter<V, WeightedEdge, V> generator =
new SimpleWeightedBipartiteGraphMatrixGenerator<V, WeightedEdge>()
.first (first)
.second (second)
.weights(costMatrix);
generator.generateGraph(target, null, null);
return new KuhnMunkresMinimalWeightBipartitePerfectMatching<V, WeightedEdge>(target, first, second);
}
开发者ID:j123b567,项目名称:stack-usage,代码行数:26,代码来源:KuhnMunkresMinimalWeightBipartitePerfectMatchingTest.java
示例14: weightedDirectedGraph
import org.jgrapht.graph.SimpleWeightedGraph; //导入依赖的package包/类
/**
* Create a simple directed graph.
*/
@SuppressWarnings("boxing")
public static WeightedGraph<Integer, DefaultWeightedEdge> weightedDirectedGraph()
{
final WeightedGraph<Integer, DefaultWeightedEdge> g = new SimpleWeightedGraph<>(
DefaultWeightedEdge.class);
final Set<Integer> vertices = CollectionUtil.toSet(7, 5, 3, 11, 8, 2, 9, 10);
for (final Integer v : vertices)
{
g.addVertex(v);
}
final DefaultWeightedEdge e = g.addEdge(7, 8);
g.setEdgeWeight(e, 1.0d);
return g;
}
示例15: directedGraph2simpleGraph
import org.jgrapht.graph.SimpleWeightedGraph; //导入依赖的package包/类
/**
* converts a directed weighted graph into a simple weighted graph by
* keeping the maximum weight of 2 parallel edges
*/
public static SimpleWeightedGraph<Long, DefaultWeightedEdge> directedGraph2simpleGraph(
DefaultDirectedWeightedGraph<Long, DefaultWeightedEdge> directedG) {
SimpleWeightedGraph<Long, DefaultWeightedEdge> simpleG = new SimpleWeightedGraph<Long, DefaultWeightedEdge>(
DefaultWeightedEdge.class);
// Parcourt les sommets du graphe orienté et les copie dans le graphe
// simple
for (Long v : directedG.vertexSet()) {
simpleG.addVertex(v);
}
// Parcourt l'ensemble des arcs du graphe orienté
for (DefaultWeightedEdge e : directedG.edgeSet()) {
Long nodeIni = directedG.getEdgeSource(e);
Long nodeFin = directedG.getEdgeTarget(e);
double w = directedG.getEdgeWeight(e);
if (!simpleG.containsEdge(nodeIni, nodeFin)) {
simpleG.addEdge(nodeIni, nodeFin, e);
} else {
// On prend le poids max de deux arcs parallèles
DefaultWeightedEdge e1 = simpleG.getEdge(nodeFin, nodeIni);
if (simpleG.getEdgeWeight(e1) < w)
simpleG.setEdgeWeight(e1, w);
}
}
System.out.println("Graphe simple créé : " + simpleG.vertexSet().size() + " sommets et "
+ simpleG.edgeSet().size() + " arcs");
// for (DefaultWeightedEdge e : simpleG.edgeSet()) {
// if (simpleG.getEdgeSource(e) == (long) 210173)
// System.out.println(
// "Source 210173 - Target " + simpleG.getEdgeTarget(e) + " - Poids " +
// simpleG.getEdgeWeight(e));
// }
return simpleG;
}