src/work/marci_graph_concept.txt
author marci
Mon, 12 Jan 2004 11:49:56 +0000
changeset 13 d33813af6e50
parent 9 a9ed3f1c2c63
child 15 e41c71268807
permissions -rw-r--r--
b_node bug correction
     1 ETIK-OL-NOLIB-NEGRES graph concept-ek.
     2 
     3  Ebben a dokumentacioban graph concept tervek es azok megvalositastarol irok. 
     4 A felsorolt rutinok, osztalyok egyaltalan nem kikristalyosodottak, 1-1 elemi 
     5 operacio elegzesere gyakran tobb mod is rendelkezesre all. A tervezesi fazisban pont annak kell kiderulnie, hogy milyen metodusok tavolithatok el, s milyen 
     6 ujakra van szukseg. 
     7 
     8  Megvalositottunk egy graph osztalyt mely listaban tarolja a pontokat, 
     9 az 1 pontbol kiindulo eleket, s az 1 pontba bemeno eleket. Konstrualni lehet 
    10 ures grafot, hozzaadni pontokat, eleket. Az incidenciat node_iteratorok-kal 
    11 ill. edge_iteratorokkal lehet megfigyelni. Adott tovabba 1 template osztaly, 
    12 a graf pontjaihoz vagy eleihez tetszoleges tipusu property hozzarendelesere, 
    13 a jelen megvalositas ezeket vektorben tarolja. Fontos azonban, hogy ezen 
    14 property_vector csak azokra a graf-objektumokra ervenyes, melyek 
    15 letrehozasanak pillanataban a grafhoz tartoznak. 
    16 
    17 marci_bfs.hh	      //bfs, tejesen kiserleti
    18 marci_graph_demo.cc  //peldaprogi a lisas graf hasznalatahoz
    19 marci_graph_traits.hh //alapertelmezett graph_traits
    20 marci_list_graph.hh  //list_graph megvalositas
    21 marci_max_flow.hh     //folyam, kiserleti
    22 marci_property_vector.hh //property vector megvalosites indexelt grafokhoz	
    23 graf es iterator tipusok:
    24 
    25 class list_graph	 
    26 
    27 class node_iterator      
    28 trivialis node iterator, csak cimezni lehet vele, pl property vectort
    29 
    30 class each_node_iterator
    31 node iterator a graf pontjainak bejarasara, node_iterator-a konvertalhato
    32 
    33 class edge_iterator
    34 trivialis edge iterator, csak cimezni lehet vele, pl property vectort
    35 
    36 class each_edge_iterator
    37 edge iterator a graf osszes elenek bejarasara
    38 
    39 class out_edge_iterator
    40 edge iterator 1 pont ki eleinek bejarasara, edge_iterator-a konvertalhato
    41 
    42 class in_edge_iterator
    43 edge iterator 1 pont be eleinek bejarasara, edge_iterator-a konvertalhato
    44       
    45 class sym_edge_iterator
    46 edge iterator 1 pont be es ki eleinek bejarasara, edge_iterator-a konvertalhato
    47 
    48 default constructor:
    49 
    50 list_graph() 
    51     
    52 A graf osztaly fobb publikus metodusai, az alapveto hasznalathoz:
    53 Hasonlo funkciok megvalosithatok 1 kesobb leirt modon, illetve 
    54 ezek kozul nehany az iteratorok metodusaival, megis azt javasolnam, hogy az 
    55 iteratorok metodusait ne hasznaljuk. Miert? Azt  szeretnenk, ha 1 ponthalmazon 
    56 van 2 graf, es csak az elhalmazhoz keszitunk uj iteratorokat, akkor pl 1 pont 
    57 out-edge-iteratora megkaphato legyen a grafbol es a node_iteratorbol. Ezert 
    58 out_edge_iterator(const node_iterator&) hasznalata nem javasolt, 
    59 esetleg majd szamuzzuk a concept-bol, s akkor nem nesz baj. 
    60 
    61 each_node_iterator first_node()
    62 each_edge_iterator first_edge()
    63 out_edge_iterator first_out_edge(const node_iterator&)
    64 in_edge_iterator first_in_edge(const node_iterator&)
    65 sym_edge_iterator first_sym_edge(const node_iterator&)
    66 
    67 node_iterator tail(const edge_iterator&)
    68 node_iterator head(const edge_iterator&)
    69 
    70 node_iterator a_node(const out_edge_iterator&)
    71 node_iterator a_node(const in_edge_iterator&)
    72 node_iterator a_node(const sym_edge_iterator&)
    73 //az out, in or sym edge iterator rogzitett pontjara ad 1 node_iterator-t
    74 
    75 node_iterator b_node(const out_edge_iterator&)
    76 node_iterator b_node(const in_edge_iterator&)
    77 node_iterator b_node(const sym_edge_iterator&)
    78 //az out, in or sym edge iterator nem rogzitett pontjara ad 1 node_iterator-t
    79 
    80 node_iterator invalid_node()
    81 edge_iterator invalid_edge()
    82 out_edge_iterator invalid_out_edge()
    83 in_edge_iterator invalid_in_edge()
    84 sym_edge_iterator invalid_sym_edge()
    85 
    86 //az iteratorok ures konstruktorai meghatarozatlan 
    87 tartalmu konstruktort adnak vissza, ezekkel a matodusokkal 
    88 lehet ervenytelent csinalni.
    89 Lehet hogy ezt az ures konstruktorral kellene, tessek vitatkozni.
    90 
    91 Kiserleti cellal ugyanezen fv-ek mas stilusu megvalositasai:
    92 
    93 void get_first(each_node_iterator&)
    94 void get_first(each_edge_iterator&)
    95 void get_first(out_edge_iterator&, const node_iterator&)
    96 void get_first(in_edge_iterator&, const node_iterator&)
    97 void get_first(sym_edge_iterator&, const node_iterator&)
    98 
    99 void get_tail(node_iterator&, const edge_iterator&)
   100 void get_head(node_iterator&, const edge_iterator&)
   101 
   102 void get_a_node(node_iterator&, const out_edge_iterator&)
   103 void get_a_node(node_iterator&, const in_edge_iterator&)
   104 void get_a_node(node_iterator&, const sym_edge_iterator&)
   105    
   106 void get_b_node(node_iterator&, const out_edge_iterator&)
   107 void get_b_node(node_iterator&, const in_edge_iterator&)
   108 void get_b_node(node_iterator&, const sym_edge_iterator&)
   109  
   110 void get_invalid(node_iterator&)
   111 void get_invalid(edge_iterator&)
   112 void get_invalid(out_edge_iterator&)
   113 void get_invalid(in_edge_iterator&)
   114 void get_invalid(sym_edge_iterator&)
   115  
   116 Pontok azonositasara de meginkabb property vectorokhoz:
   117 
   118 int id(const node_iterator&)
   119 int id(const edge_iterator&)
   120 
   121 Pontok es elek hozzaadasanak metodusai:
   122 
   123 node_iterator add_node()
   124 edge_iterator add_edge(const node_iterator&, const node_iterator&)
   125 
   126 Hogy konnyebb legyen a progikat tesztelni, nehany stream utasitas:
   127 ezek nem a list_graph metodusai
   128 
   129 friend std::ostream& operator<<(std::ostream&, const node_iterator&)
   130 friend std::ostream& operator<<(std::ostream&, const edge_iterator&)
   131 
   132 node_iterator metodusai:
   133 node_iterator()
   134 bool is_valid()
   135 ezek nem tagfuggvenyek:
   136 friend bool operator==(const node_iterator&, const node_iterator&)
   137 friend bool operator!=(const node_iterator& u, const node_iterator& v)
   138     
   139 each_node_iterator metodusai:
   140 ez publikusan szarmazik a node_iterator-bol, tehat a fentiek is.
   141 each_node_iterator()
   142 each_node_iterator& operator++()
   143 
   144 edge_iterator metodusai:
   145 edge_iterator()
   146 bool is_valid()
   147 ezek nem tagfvek:
   148 friend bool operator==(const edge_iterator&, const edge_iterator&)
   149 friend bool operator!=(const edge_iterator&, const edge_iterator&)
   150 ujra tagfv-ek.
   151 //node_iterator tail_node() const		nem javasolt
   152 //node_iterator head_node() const		nem javasolt
   153    
   154 each_edge_iterator metodusai:
   155 edge_iterator-bol szarmazik
   156 each_edge_iterator()
   157 each_edge_iterator& operator++()
   158  
   159 out_edge_iterator metodusai:
   160 edge_iterator-bol szarmazik
   161 out_edge_iterator()
   162 //out_edge_iterator(const node_iterator&)	nem javasolt
   163 out_edge_iterator& operator++()
   164 //node_iterator a_node() const		nem javasolt
   165 //node_iterator b_node() const 
   166     
   167  
   168 in_edge_iterator metodusai: 
   169 edge_iterator-bol szarmazik
   170 in_edge_iterator()
   171 //in_edge_iterator(const node_iterator&)	nem javasolt
   172 in_edge_iterator& operator++()
   173 //node_iterator a_node() const		nem javasolt
   174 //node_iterator b_node() const 
   175 
   176 
   177 sym_edge_iterator metodusai:
   178 edge_iterator-bol szarmazik
   179 sym_edge_iterator()
   180 //sym_edge_iterator(const node_iterator&)	nem javasolt
   181 sym_edge_iterator& operator++()
   182 //node_iterator a_node() const		nem javasolt
   183 //node_iterator b_node() const 
   184 		
   185 Node propery array-okrol:
   186 
   187 template <typename graph_type, typename T>
   188 class node_property_vector 
   189 
   190 metodusok:
   191 
   192 node_property_vector(graph_type&)
   193 node_property_vector(graph_type&, T a)
   194 fill constructor, a-val kitolt
   195 void put(graph_traits<graph_type>::node_iterator, const T&)
   196 T get(graph_traits<graph_type>::node_iterator)
   197 
   198 Ugyanez edge_property_array-okkal
   199 
   200 template <typename graph_type, typename T>
   201 class edge_property_vector
   202 
   203 edge_property_vector(graph_type&)
   204 edge_property_vector(graph_type&, T a)
   205 fill constructor, a-val kitolt
   206 void put(graph_traits<graph_type>::edge_iterator, const T&)
   207 get(graph_traits<graph_type>::edge_iterator)
   208 
   209  Ennyi nem javasolas utan, meg nehany szo.
   210  Alparral ugy gondoltuk, hogy az iterator 1 olyan egyszeru objetum legyen 
   211 csak, mellyel, ha ervenyes, akkor lehet tovabblepni 1 pont vagy ellistaban. 
   212 Az hogy valamilyen pont-iteratorbeol el-iteratort csinalunk, igenis legyen a 
   213 graf objektum feladata, hiszen igy lehet csinelni ugyanazon a ponthalmazon
   214 tobb grafot ugyanazon pont-iteratorokkal.
   215  Sokkal komolyabb kerdesek merultek fel azzal kapcsolatban, hogy hogyan adjuk 
   216 at a propertyket az algoritmusoknak, algoritmus-objektumoknak. 
   217 Errol majd kesobb.
   218 
   219 marci@cs.elte.hu
   220 
   221 
   222