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


Java DijkstraShortestPath.findPathBetween方法代码示例

本文整理汇总了Java中org.jgrapht.alg.DijkstraShortestPath.findPathBetween方法的典型用法代码示例。如果您正苦于以下问题:Java DijkstraShortestPath.findPathBetween方法的具体用法?Java DijkstraShortestPath.findPathBetween怎么用?Java DijkstraShortestPath.findPathBetween使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在org.jgrapht.alg.DijkstraShortestPath的用法示例。


在下文中一共展示了DijkstraShortestPath.findPathBetween方法的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Java代码示例。

示例1: exampleGraph

import org.jgrapht.alg.DijkstraShortestPath; //导入方法依赖的package包/类
/**
 * Shows how to create an FNSS Topology, convert it to a JGraphT Graph and
 * then compute shortest paths
 */
public static void exampleGraph() {
	// create a simple FNSS topology
	Topology topology = new Topology();
	topology.addEdge("1", "2", new Edge());
	topology.addEdge("2", "3", new Edge());
	
	// convert to JGraphT
	Graph<String, Edge> graph = JGraphTConverter.getGraph(topology);
	
	// Find shortest paths
	String source = "3";
	String destination = "1";
	List<Edge> sp = DijkstraShortestPath.findPathBetween(graph, source, destination);
	
	// Print results
	System.out.println("Shortest path from " + source + " to " + destination + ":");
	for (Edge e : sp) {
		System.out.println(graph.getEdgeSource(e) + " -> " + graph.getEdgeTarget(e));
	}
}
 
开发者ID:fnss,项目名称:fnss-java,代码行数:25,代码来源:ExampleJGraphT.java

示例2: checkDeadlocks

import org.jgrapht.alg.DijkstraShortestPath; //导入方法依赖的package包/类
/**
    * Verify deadlock situation from serviceToID to serviceFromID, i.e., checks
    * if the serviceFromID is not a children node of the serviceToID! If a deadlock
    * is detected, the composition is not possible
    * 
    * @param serviceToID - ID of the service that has an input in the service for composition
    * @param serviceFromID - ID of the service that provides an output in the service composition
    * 
    * @return true if a deadlock situation is found and false otherwise
    * 
    */
   public boolean checkDeadlocks(String serviceToID, String serviceFromID){
       
       // - We do this, because the  was generating errors
       // when we were trying to find deadlock in not connected graphs, i.e., graphs
       // with parts that are connected!
       //If serviceToID has no children nodes, deadlock can not occur
       if(graphComposition.outgoingEdgesOf(serviceToID).isEmpty())
           return false;
       
       //Run DijkstraShortestPath algorithm to find paths between serviceToID and serviceFromID
       List path = DijkstraShortestPath.findPathBetween(graphComposition, serviceToID, serviceFromID);
     
       //If no paths were found, deadlock situation can not occur. Otherwise, deadlock is detected
       if(path == null)
           return false; 
else
           return true;
   }
 
开发者ID:usplssb,项目名称:SemanticSCo,代码行数:30,代码来源:ServiceComposer.java

示例3: getPathLengthInEdges

import org.jgrapht.alg.DijkstraShortestPath; //导入方法依赖的package包/类
/**
 * Gets the path length between two category nodes - measured in "edges".
 * @param node1 The first category node.
 * @param node2 The second category node.
 * @return The number of edges of the path between node1 and node2. 0, if the nodes are identical. -1, if no path exists.
 */
public int getPathLengthInEdges(Category node1, Category node2) {
    if (this.graph.containsVertex(node1.getPageId()) && this.graph.containsVertex(node2.getPageId())) {
        if (node1.getPageId() == node2.getPageId()) {
            return 0;
        }

        // get the path from root node to node 1
        List edgeList = DijkstraShortestPath.findPathBetween(undirectedGraph, node1.getPageId(), node2.getPageId());
        if (edgeList == null) {
            return -1;
        }
        else {
            return edgeList.size();
        }
    }
    // if the given nodes are not in the category graph, return -1
    else {
        return -1;
    }
}
 
开发者ID:dkpro,项目名称:dkpro-jwpl,代码行数:27,代码来源:CategoryGraph.java

示例4: getParseTreePath

import org.jgrapht.alg.DijkstraShortestPath; //导入方法依赖的package包/类
public List<GraphEdge> getParseTreePath(Artifact headWord1, Artifact headWord2) {
	
	List<GraphEdge> path = null;
	
	//link tokens
	 try {
		int word1Offset = headWord1.getWordIndex()+1;
		int word2Offset = headWord2.getWordIndex()+1;
		
		path = 
			DijkstraShortestPath.findPathBetween(sentenceTree, 
					headWord1.getContent()+word1Offset, 
					headWord2.getContent()+word2Offset);
	} catch (Exception e) {
		e.printStackTrace();
		System.out.println("error in getParseTreeDistance:"+headWord1+headWord2);
	}
	
	return path;
}
 
开发者ID:ehsane,项目名称:rainbownlp,代码行数:21,代码来源:DependenciesTreeUtil.java

示例5: findReachableSourceAttributes

import org.jgrapht.alg.DijkstraShortestPath; //导入方法依赖的package包/类
private Set<AttributeRef> findReachableSourceAttributes(AttributeRef targetAttribute, DirectedGraph<AttributeRef, DefaultEdge> dependencyGraph) {
    Set<AttributeRef> result = new HashSet<AttributeRef>();
    for (AttributeRef attribute : dependencyGraph.vertexSet()) {
        if (!attribute.isSource()) {
            continue;
        }
        if (result.contains(attribute)) {
            continue;
        }
        List path = DijkstraShortestPath.findPathBetween(dependencyGraph, attribute, targetAttribute);
        if (path != null) {
            result.add(attribute);
        }
    }
    return result;
}
 
开发者ID:donatellosantoro,项目名称:Llunatic,代码行数:17,代码来源:CheckConflicts.java

示例6: findPath

import org.jgrapht.alg.DijkstraShortestPath; //导入方法依赖的package包/类
/**
 * Find the list of point to be traversed from the start to the end using the DijkstraShortestPath algorithm.
 * 
 * @param graph
 *            the graph upon which we need to find the path
 * @param start
 *            the start node from which to navigate
 * @param end
 *            the end node to which to navigate to
 * @return the succession of node to traverse from start to end, empty if no path was found
 */
public static List<NdPoint> findPath(WeightedGraph<NdPoint, DefaultWeightedEdge> graph, NdPoint start,
        NdPoint end) {
    List<DefaultWeightedEdge> edgeList = DijkstraShortestPath.findPathBetween(graph, start, end);
    if (edgeList == null) {
        return new ArrayList<>(0);
    }

    List<NdPoint> path = new LinkedList<>();
    NdPoint current = start;
    path.add(current);
    // Add each path node, but also check for the order of the edges so that
    // the correct point (source or target) is added.
    for (DefaultWeightedEdge edge : edgeList) {
        current = GraphHelper.getOpposite(graph, edge, current);
        if (current != null) {
            path.add(current);
        }
    }
    return path;
}
 
开发者ID:eishub,项目名称:BW4T,代码行数:32,代码来源:PathPlanner.java

示例7: getPath

import org.jgrapht.alg.DijkstraShortestPath; //导入方法依赖的package包/类
@Override
public RoutingPath getPath(Device from, Device to) {
	List<Channel> path = DijkstraShortestPath.findPathBetween(
			getGraph(), from, to);
	if (path == null) {
		return null;
	}

	List<Device> nodes = new ArrayList<Device>();
	Device v = from;
	nodes.add(from);
	for (Channel e : path) {
		v = Graphs.getOppositeVertex(getGraph(), e, v);
		nodes.add(v);
	}

	return new RoutingPath(nodes, path);
}
 
开发者ID:flyroom,项目名称:PeerfactSimKOM_Clone,代码行数:19,代码来源:StarNetwork.java

示例8: getPath

import org.jgrapht.alg.DijkstraShortestPath; //导入方法依赖的package包/类
@Override
public RoutingPath getPath(Device from, Device to) {
	List<Channel> path = DijkstraShortestPath.findPathBetween(getGraph(),
			from, to);
	if (path == null) {
		return null;
	}

	List<Device> nodes = new ArrayList<Device>();
	Device v = from;
	nodes.add(from);
	for (Channel e : path) {
		v = Graphs.getOppositeVertex(getGraph(), e, v);
		nodes.add(v);
	}
	return new RoutingPath(nodes, path);
}
 
开发者ID:flyroom,项目名称:PeerfactSimKOM_Clone,代码行数:18,代码来源:RandomNetwork.java

示例9: exampleWeightedGraph

import org.jgrapht.alg.DijkstraShortestPath; //导入方法依赖的package包/类
/**
 * Shows how to create an FNSS Topology with weighted edges, convert it to
 * a JGraphT WeightedGraph and then compute shortest paths
 */
public static void exampleWeightedGraph() {
	
	// create unidrected topology
	Topology topology = new Topology();
	
	// Create edge with high weight and edge with low weight
	Edge edgeHighWeight = new Edge();
	edgeHighWeight.setWeight(1000);
	
	Edge edgeLowWeight = new Edge();
	edgeLowWeight.setWeight(1);
	
	// Assign edges to topology
	topology.addEdge("1", "4", edgeHighWeight);
	topology.addEdge("2", "3", edgeLowWeight);
	topology.addEdge("1", "2", edgeLowWeight);
	topology.addEdge("4", "3", edgeLowWeight);
	
	// convert to JGraphT
	WeightedGraph<String, DefaultWeightedEdge> graph = 
			JGraphTConverter.getWeightedGraph(topology);
	
	// Find shortest paths
	String source = "1";
	String destination = "3";
	List<DefaultWeightedEdge> sp = 
			DijkstraShortestPath.findPathBetween(graph, source, destination);
	
	// Print results
	System.out.println("Shortest path from " + source + " to " + destination + ":");
	for (DefaultWeightedEdge e : sp) {
		System.out.println(graph.getEdgeSource(e) + " -> " + graph.getEdgeTarget(e));
	}
}
 
开发者ID:fnss,项目名称:fnss-java,代码行数:39,代码来源:ExampleJGraphT.java

示例10: getPath

import org.jgrapht.alg.DijkstraShortestPath; //导入方法依赖的package包/类
public List<ITableRecordReference> getPath()
{
	final List<ITableRecordReference> result = new ArrayList<>();

	final AsUndirectedGraph<ITableRecordReference, DefaultEdge> undirectedGraph = new AsUndirectedGraph<>(g);

	final List<DefaultEdge> path = DijkstraShortestPath.<ITableRecordReference, DefaultEdge> findPathBetween(
			undirectedGraph, start, goal);
	if (path == null || path.isEmpty())
	{
		return ImmutableList.of();
	}
	result.add(start);
	for (final DefaultEdge e : path)
	{
		final ITableRecordReference edgeSource = undirectedGraph.getEdgeSource(e);
		if (!result.contains(edgeSource))
		{
			result.add(edgeSource);
		}
		else
		{
			result.add(undirectedGraph.getEdgeTarget(e));
		}
	}

	return ImmutableList.copyOf(result);
}
 
开发者ID:metasfresh,项目名称:metasfresh,代码行数:29,代码来源:FindPathIterateResult.java

示例11: existsPath

import org.jgrapht.alg.DijkstraShortestPath; //导入方法依赖的package包/类
private boolean existsPath(Set<Dependency> s1, Set<Dependency> s2) {
    for (Dependency dependency1 : s1) {
        for (Dependency dependency2 : s2) {
            List<DefaultEdge> path = DijkstraShortestPath.findPathBetween(dependencyGraph, dependency1, dependency2);
            if (path != null) {
                return true;
            }
        }
    }
    return false;
}
 
开发者ID:dbunibas,项目名称:BART,代码行数:12,代码来源:GenerateStratification.java

示例12: findRelatedAttributes

import org.jgrapht.alg.DijkstraShortestPath; //导入方法依赖的package包/类
private Set<AttributeRef> findRelatedAttributes(AttributeRef attribute, Set<String> pathCache, DirectedGraph<AttributeRef, ExtendedEdge> dependencyGraph) {
    //All attributes corresponding to vertices of paths that pass throught the vertex of attribute
    Set<AttributeRef> result = new HashSet<AttributeRef>();
    for (AttributeRef otherAttribute : dependencyGraph.vertexSet()) {
        if (attribute.equals(otherAttribute)) {
            result.add(otherAttribute);
            continue;
        }
        String attributePair = buildAttributePair(attribute, otherAttribute);
        if (pathCache.contains(attributePair)) {
            result.add(otherAttribute);
            continue;
        }
        List<ExtendedEdge> outPath = DijkstraShortestPath.findPathBetween(dependencyGraph, attribute, otherAttribute);
        if (logger.isDebugEnabled()) logger.debug("Finding path between " + attribute + " and " + otherAttribute);
        if (outPath != null) {
            if (logger.isDebugEnabled()) logger.debug("Path found");
            addVerticesInPath(outPath, result, pathCache, dependencyGraph);
            continue;
        }
        List<ExtendedEdge> inPath = DijkstraShortestPath.findPathBetween(dependencyGraph, otherAttribute, attribute);
        if (logger.isDebugEnabled()) logger.debug("Finding path between " + otherAttribute + " and " + attribute);
        if (inPath != null) {
            if (logger.isDebugEnabled()) logger.debug("Path found");
            addVerticesInPath(inPath, result, pathCache, dependencyGraph);
        }
    }
    return result;
}
 
开发者ID:donatellosantoro,项目名称:Llunatic,代码行数:30,代码来源:FindAttributesInSameCellGroup.java

示例13: existsPath

import org.jgrapht.alg.DijkstraShortestPath; //导入方法依赖的package包/类
private boolean existsPath(EGDStratum t1, EGDStratum t2) {
    for (ExtendedEGD dependency1 : t1.getExtendedDependencies()) {
        for (ExtendedEGD dependency2 : t2.getExtendedDependencies()) {
            List<DefaultEdge> path = DijkstraShortestPath.findPathBetween(dependencyGraph, dependency1, dependency2);
            if (path != null) {
                return true;
            }
        }
    }
    return false;
}
 
开发者ID:donatellosantoro,项目名称:Llunatic,代码行数:12,代码来源:AnalyzeDependencies.java

示例14: isReachable

import org.jgrapht.alg.DijkstraShortestPath; //导入方法依赖的package包/类
private boolean isReachable(AttributeRef attribute, Set<AttributeRef> initialAttributes, DirectedGraph<AttributeRef, ExtendedEdge> dependencyGraph) {
    for (AttributeRef initialAttribute : initialAttributes) {
        if (logger.isTraceEnabled()) logger.trace("Checking reachability of " + attribute + " from " + initialAttribute);
        if (!dependencyGraph.containsVertex(initialAttribute)) {
            continue;
        }
        List path = DijkstraShortestPath.findPathBetween(dependencyGraph, initialAttribute, attribute);
        if (path != null) {
            if (logger.isTraceEnabled()) logger.trace("Found!");
            return true;
        }
    }
    return false;
}
 
开发者ID:donatellosantoro,项目名称:Llunatic,代码行数:15,代码来源:FindAttributesWithLabeledNulls.java

示例15: isOfType

import org.jgrapht.alg.DijkstraShortestPath; //导入方法依赖的package包/类
public boolean isOfType(Type t, Type typeWanted)
{
	List<DefaultEdge> path = DijkstraShortestPath.findPathBetween(this.graph, t, typeWanted);
	return path != null;
}
 
开发者ID:guilhermekrz,项目名称:JavaFF,代码行数:6,代码来源:TypeGraph.java


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