COIN-OR::LEMON - Graph Library

source: lemon-0.x/src/work/marci/max_flow_1.cc @ 674:7733d18de0e8

Last change on this file since 674:7733d18de0e8 was 642:e812963087f0, checked in by marci, 21 years ago

To avoid confusion my old ListGraph? is can be used under name SageGraph?, work/sage_graph.h contains it.

File size: 1.6 KB
Line 
1// -*- c++ -*-
2#include <iostream>
3#include <fstream>
4
5#include <sage_graph.h>
6#include <hugo/smart_graph.h>
7#include <hugo/dimacs.h>
8#include <hugo/time_measure.h>
9//#include <graph_wrapper.h>
10#include <max_flow.h>
11//#include <preflow_res.h>
12#include <hugo/for_each_macros.h>
13
14using namespace hugo;
15
16// Use a DIMACS max flow file as stdin.
17// read_dimacs_demo < dimacs_max_flow_file
18
19
20int main(int, char **) {
21
22  typedef SageGraph MutableGraph;
23
24  typedef SmartGraph Graph;
25  //  typedef ListGraph Graph;
26  typedef Graph::Node Node;
27  typedef Graph::EdgeIt EdgeIt;
28
29
30  Graph g;
31  Node s, t;
32  Graph::EdgeMap<int> cap(g);
33  //readDimacsMaxFlow(std::cin, g, s, t, cap);
34  readDimacs(std::cin, g, cap, s, t);
35  Timer ts;
36  Graph::EdgeMap<int> flow(g); //0 flow
37  MaxFlow<Graph, int, Graph::EdgeMap<int>, Graph::EdgeMap<int> >
38    max_flow_test(g, s, t, cap, flow);
39
40  {
41    std::cout << "preflow ..." << std::endl;
42    FOR_EACH_LOC(Graph::EdgeIt, e, g) flow.set(e, 0);
43    ts.reset();
44    max_flow_test.preflowPhase1(MaxFlow<Graph, int, Graph::EdgeMap<int>, Graph::EdgeMap<int> >::ZERO_FLOW);
45    std::cout << "elapsed time: " << ts << std::endl;
46    std::cout << "flow value: "<< max_flow_test.flowValue() << std::endl;
47  }
48
49  {
50    std::cout << "preflow ..." << std::endl;
51    FOR_EACH_LOC(Graph::EdgeIt, e, g) flow.set(e, 0);
52    ts.reset();
53    max_flow_test.preflowPhase1(MaxFlow<Graph, int, Graph::EdgeMap<int>, Graph::EdgeMap<int> >::ZERO_FLOW);
54    std::cout << "elapsed time: " << ts << std::endl;
55    std::cout << "flow value: "<< max_flow_test.flowValue() << std::endl;
56  }
57
58
59  return 0;
60}
Note: See TracBrowser for help on using the repository browser.