/* -*- C++ -*-
*
* This file is a part of LEMON, a generic C++ optimization library
*
* Copyright (C) 2003-2008
* Egervary Jeno Kombinatorikus Optimalizalasi Kutatocsoport
* (Egervary Research Group on Combinatorial Optimization, EGRES).
*
* Permission to use, modify and distribute this software is granted
* provided that this copyright notice appears in all copies. For
* precise terms see the accompanying LICENSE file.
*
* This software is provided "AS IS" with no warranty of any kind,
* express or implied, and with no claim as to its suitability for any
* purpose.
*
*/
/// \ingroup demos
/// \file
/// \brief Node and edge disjoint paths in directed graph.
///
/// This demo program calculates how many edge disjoint and node disjoint
/// paths are in a directed graph between a source and a target node.
/// The edge disjoint paths can be computed with a flow algorithm,
/// in this example we use the Preflow algorithm class. To get the node
/// disjoint paths we should first adapt the graph with the SplitGraphAdaptor
/// and just then calculate the flow.
///
/// \include disjoint_paths_demo.cc
#include
#include
#include
#include
#include
#include
using namespace lemon;
using namespace std;
Color color(bool b) {
return b ? RED : BLACK;
}
int main() {
cout << "This program calculates the number "
"disjoint paths in a graph" << endl;
cout << "The graph is read from the disjoint_paths_demo.lgf file" << endl;
typedef SmartGraph Graph;
Graph graph;
Graph::NodeMap > coords(graph);
Graph::Node source, target;
GraphReader("disjoint_paths_demo.lgf", graph).
readNodeMap("coords", coords).
readNode("source", source).readNode("target", target).run();
typedef ConstMap Capacity;
Capacity capacity(1);
Graph::EdgeMap flow(graph);
Preflow preflow(graph, capacity, source, target);
preflow.run();
cout << "Number of edge disjoint paths: " << preflow.flowValue() << endl;
graphToEps(graph, "edge_disjoint_paths.eps").
title("edge disjoint paths").scaleToA4().
copyright("(C) 2003-2007 LEMON Project").drawArrows().
edgeColors(composeMap(functorMap(color), preflow.flowMap())).
coords(coords).run();
cout << "The paths are written into edge_disjoint_paths.eps" << endl;
typedef SplitGraphAdaptor SGraph;
SGraph sgraph(graph);
typedef ConstMap SCapacity;
SCapacity scapacity(1);
SGraph::EdgeMap sflow(sgraph);
Preflow spreflow(sgraph, scapacity,
SGraph::outNode(source),
SGraph::inNode(target));
spreflow.run();
cout << "Number of node disjoint paths: " << spreflow.flowValue() << endl;
graphToEps(sgraph, "node_disjoint_paths.eps").
title("node disjoint paths").scaleToA4().
copyright("(C) 2003-2007 LEMON Project").drawArrows().
edgeColors(composeMap(functorMap(color), spreflow.flowMap())).
coords(SGraph::combinedNodeMap(coords,
shiftMap(coords,
dim2::Point(5, 0)))).
run();
cout << "The paths are written into node_disjoint_paths.eps" << endl;
return 0;
}