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