src/demo/dim_to_dot.cc
author deba
Thu, 11 Nov 2004 11:12:42 +0000
changeset 983 3095ff2b5c18
child 986 e997802b855c
permissions -rw-r--r--
UndirFullGraphBase is added
It is a graph base which contains only one way directed edges in a full graph.
     1 // -*- c++ -*-
     2 
     3 // Use a DIMACS max flow file as stdin.
     4 // dim_to_dot < dimacs_max_flow_file > dot_output_file
     5 // This program makes a dot file from a dimacs max flow file. 
     6 // This program can be an aid in making up to date visualized documantation 
     7 // of demo programs.
     8 
     9 #include <iostream>
    10 #include <fstream>
    11 
    12 #include <lemon/smart_graph.h>
    13 #include <lemon/dimacs.h>
    14 
    15 using namespace lemon;
    16 
    17 using std::cout;
    18 using std::endl;
    19 
    20 int main()
    21 {    
    22   typedef SmartGraph Graph;
    23 
    24   typedef Graph::Edge Edge;
    25   typedef Graph::Node Node;
    26   typedef Graph::EdgeIt EdgeIt;
    27   typedef Graph::NodeIt NodeIt;
    28   typedef Graph::EdgeMap<int> LengthMap;
    29 
    30   Graph g;
    31   Node s, t;
    32   LengthMap length(g);
    33 
    34   readDimacs(std::cin, g, length, s, t);
    35 
    36   cout << "digraph lemon_dot_example {" << endl;
    37   cout << "  node [ shape=ellipse, fontname=Helvetica, fontsize=10 ];" << endl;
    38   for(NodeIt n(g); n!=INVALID; ++n) {
    39     if (n==s) {
    40       cout << "  n" << g.id(n) 
    41 	   << " [ label=\"" << g.id(n) << " (s)\" ]; " << endl;
    42     } else {
    43       if (n==t) {
    44 	cout << "  n" << g.id(n) 
    45 	     << " [ label=\"" << g.id(n) << " (t)\" ]; " << endl; 
    46       } else {
    47 	cout << "  n" << g.id(n) 
    48 	     << " [ label=\"" << g.id(n) << "\" ]; " << endl; 
    49       }
    50     }
    51   }
    52   cout << "  edge [ shape=ellipse, fontname=Helvetica, fontsize=10 ];" << endl;
    53   for(EdgeIt e(g); e!=INVALID; ++e) {
    54     cout << "  n" << g.id(g.tail(e)) << " -> " << " n" << g.id(g.head(e))
    55 	 << " [ label=\"" << g.id(e) 
    56 	 << ", length:" << length[e] << "\" ]; " << endl;
    57   } 
    58   cout << "}" << endl;
    59 }