当前位置: 首页>>代码示例>>Java>>正文


Java SimpleWeightedGraph类代码示例

本文整理汇总了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;
}
 
开发者ID:fnss,项目名称:fnss-java,代码行数:37,代码来源:JGraphTConverter.java

示例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();
}
 
开发者ID:IGNF,项目名称:geoxygene,代码行数:21,代码来源:SocialGraph.java

示例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;
}
 
开发者ID:IGNF,项目名称:geoxygene,代码行数:25,代码来源:GraphAnalysis.java

示例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;
}
 
开发者ID:IGNF,项目名称:geoxygene,代码行数:24,代码来源:GraphAnalysis.java

示例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;
}
 
开发者ID:IGNF,项目名称:geoxygene,代码行数:25,代码来源:GraphAnalysis.java

示例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;

}
 
开发者ID:IGNF,项目名称:geoxygene,代码行数:22,代码来源:GraphAnalysis.java

示例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;
}
 
开发者ID:vitrivr,项目名称:cineast,代码行数:23,代码来源:MST.java

示例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;
}
 
开发者ID:biojava,项目名称:biojava-spark,代码行数:25,代码来源:WeightedGraph.java

示例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;
}
 
开发者ID:biojava,项目名称:biojava-spark,代码行数:30,代码来源:WeightedGraph.java

示例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;
}
 
开发者ID:eishub,项目名称:BW4T,代码行数:21,代码来源:GraphHelper.java

示例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);
    }

}
 
开发者ID:eishub,项目名称:BW4T,代码行数:22,代码来源:PathPlanner.java

示例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;
    }
 
开发者ID:j123b567,项目名称:stack-usage,代码行数:23,代码来源:MinimumSpanningTreeTest.java

示例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;
}
 
开发者ID:openfurther,项目名称:further-open-core,代码行数:21,代码来源:GraphTestUtil.java

示例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;
}
 
开发者ID:IGNF,项目名称:geoxygene,代码行数:38,代码来源:GraphAnalysis.java


注:本文中的org.jgrapht.graph.SimpleWeightedGraph类示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。