Maximum Flow

Download

Download jar file or use maven. psjava requires Java 1.6 (or above)

<dependency>
    <groupId>org.psjava</groupId>
    <artifactId>psjava</artifactId>
    <version>0.1.19</version>
</dependency>

Example Code

// Construct a graph with capacities.

MutableCapacityGraph<String, Integer> capacityGraph = MutableCapacityGraph.create();
capacityGraph.insertVertex("A");
capacityGraph.insertVertex("B");
capacityGraph.insertVertex("C");
capacityGraph.insertVertex("D");
capacityGraph.addEdge("A", "B", 4);
capacityGraph.addEdge("A", "C", 2);
capacityGraph.addEdge("B", "C", 1);
capacityGraph.addEdge("B", "D", 4);
capacityGraph.addEdge("C", "D", 1);

// Choose Algorithm, and run it.

MaximumFlowAlgorithm algorithm = EdmondsKarpAlgorithm.getInstance();
MaximumFlowAlgorithmResult<Integer, CapacityEdge<String, Integer>> result = algorithm.calc(capacityGraph, "A", "D", IntegerNumberSystem.getInstance());

int maximumFlow = result.calcTotalFlow(); // must be 5

// Also, you can obtain the flows in each edges by retrieved flow function.

Function<CapacityEdge<String, Integer>, Integer> flowFunction = result.calcFlowFunction();
for (CapacityEdge<String, Integer> e : capacityGraph.getEdges("A")) {
	flowFunction.get(e);
}

See Also


Copyright 2014 psjava team. View on GitHub