doc/groups.dox
author deba
Tue, 31 Jan 2006 19:33:48 +0000
changeset 1931 6abf67b02ff5
parent 1866 c2de2ed28e59
child 1996 5dc13b93f8b4
permissions -rw-r--r--
New iterable map with comparable values
it uses linked lists and balanced binary tree

IterableBoolMap has ItemIt type as the other iterable maps

InvertableMap got ValueIterator
alpar@814
     1
alpar@678
     2
/**
alpar@678
     3
@defgroup datas Data Structures
alpar@921
     4
This group describes the several graph structures implemented in LEMON.
alpar@678
     5
*/
alpar@430
     6
alpar@678
     7
/**
alpar@678
     8
@defgroup graphs Graph Structures
alpar@678
     9
@ingroup datas
alpar@921
    10
\brief Graph structures implemented in LEMON.
alpar@430
    11
marci@1172
    12
The implementation of combinatorial algorithms heavily relies on 
marci@1172
    13
efficient graph implementations. LEMON offers data structures which are 
marci@1172
    14
planned to be easily used in an experimental phase of implementation studies, 
marci@1172
    15
and thereafter the program code can be made efficient by small modifications. 
alpar@430
    16
marci@1172
    17
The most efficient implementation of diverse applications require the usage of different physical graph implementations. These differences appear in the size of 
marci@1172
    18
graph we require to handle, memory or time usage limitations or in 
marci@1172
    19
the set of operations through which the graph can be accessed. 
marci@1172
    20
LEMON provides several physical graph structures to meet the 
marci@1172
    21
diverging requirements of the possible users. 
marci@1172
    22
In order to save on running time or on memory usage, some structures may 
marci@1172
    23
fail to provide some graph features like edge or node deletion.
marci@1172
    24
marci@1172
    25
Alteration of standard containers need a very limited number of 
marci@1172
    26
operations, these together satisfy the everyday requirements. 
marci@1172
    27
In the case of graph strutures, different operations are needed which do 
marci@1172
    28
not alter the physical graph, but gives an other view. If some nodes or 
marci@1172
    29
edges have to be hidden or the reverse oriented graph have to be used, then 
marci@1172
    30
this is the case. It also may happen that in a flow implemenation 
marci@1172
    31
the residual graph can be accessed by an other algorithm, or a node-set 
marci@1172
    32
is to be shrunk for an other algorithm. 
marci@1172
    33
LEMON also provides a variety of graphs for these requirements called 
alpar@1401
    34
\ref graph_adaptors "graph adaptors". Adaptors cannot be used alone but only 
marci@1172
    35
in conjunction with other graph representation. 
alpar@430
    36
alpar@678
    37
You are free to use the graph structure that fit your requirements
alpar@678
    38
the best, most graph algorithms and auxiliary data structures can be used
marci@1172
    39
with any graph structures. 
alpar@678
    40
*/
alpar@430
    41
alpar@678
    42
/**
deba@1866
    43
@defgroup semi_adaptors Semi-Adaptors Classes for Graphs
deba@1866
    44
@ingroup graphs
deba@1866
    45
\brief Graph types between real graphs and graph adaptors.
deba@1866
    46
deba@1866
    47
Graph types between real graphs and graph adaptors. These classes
deba@1866
    48
wrap graphs to give new functionality as the adaptors do it. But the
deba@1866
    49
other way they are not light-weigth structures as the adaptors.
deba@1866
    50
*/
deba@1866
    51
deba@1866
    52
/**
alpar@1043
    53
@defgroup maps Maps 
alpar@1043
    54
@ingroup datas
alpar@1043
    55
\brief Some special purpose map to make life easier.
alpar@1043
    56
alpar@1043
    57
LEMON provides several special maps that e.g. combine
alpar@1043
    58
new maps from existing ones.
alpar@1043
    59
*/
alpar@1043
    60
alpar@1402
    61
/**
alpar@1402
    62
@defgroup graph_maps Graph Maps 
alpar@1402
    63
@ingroup maps
alpar@1402
    64
\brief Special Graph-Related Maps.
alpar@1402
    65
alpar@1402
    66
These maps are specifically designed to assign values to the nodes and edges of
alpar@1402
    67
graphs.
alpar@1402
    68
*/
alpar@1402
    69
alpar@1402
    70
alpar@1402
    71
/**
alpar@1402
    72
\defgroup map_adaptors Map Adaptors
alpar@1402
    73
\ingroup maps
alpar@1402
    74
\brief Tools to create new maps from existing ones
alpar@1402
    75
alpar@1402
    76
Map adaptors are used to create "implicit" maps from other maps.
alpar@1402
    77
alpar@1536
    78
Most of them are \ref lemon::concept::ReadMap "ReadMap"s. They can
alpar@1402
    79
make arithmetic oprerations between one or two maps (negation, scalig,
alpar@1402
    80
addition, multiplication etc.) or e.g. convert a map to another one
alpar@1402
    81
of different Value type.
alpar@1402
    82
*/
alpar@1402
    83
alpar@1043
    84
/**
alpar@678
    85
@defgroup auxdat Auxiliary Data Structures
alpar@678
    86
@ingroup datas
alpar@921
    87
\brief Some data structures implemented in LEMON.
alpar@406
    88
alpar@921
    89
This group describes the data structures implemented in LEMON in
alpar@678
    90
order to make it easier to implement combinatorial algorithms.
alpar@678
    91
*/
alpar@406
    92
alpar@678
    93
/**
alpar@785
    94
@defgroup graphmapfactory Tools to Make It Easier to Make Graph Maps
alpar@785
    95
@ingroup auxdat
alpar@785
    96
\brief Tools to Make It Easier to Make Graph Maps.
alpar@785
    97
alpar@785
    98
This group describes the tools that makes it easier to make graph maps that
alpar@785
    99
dynamically update with the graph changes.
alpar@785
   100
*/
alpar@785
   101
alpar@785
   102
/**
alpar@678
   103
@defgroup galgs Graph Algorithms
alpar@678
   104
\brief This group describes the several graph algorithms
alpar@921
   105
implemented in LEMON.
alpar@947
   106
alpar@947
   107
This group describes the several graph algorithms
alpar@947
   108
implemented in LEMON.
alpar@947
   109
*/
alpar@947
   110
alpar@947
   111
/**
alpar@947
   112
@defgroup gutils General Graph Utilities
deba@1914
   113
@ingroup galgs
alpar@947
   114
\brief This group describes some simple general graph utilities.
alpar@947
   115
alpar@947
   116
This group describes some simple general graph utilities.
alpar@678
   117
*/
alpar@678
   118
alpar@678
   119
/**
alpar@1329
   120
@defgroup gen_opt_group General Optimization Tools
alpar@1329
   121
\brief This group describes some general optimization frameworks
alpar@1329
   122
implemented in LEMON.
alpar@1329
   123
alpar@1329
   124
\brief This group describes some general optimization frameworks
alpar@1329
   125
implemented in LEMON.
alpar@1329
   126
alpar@1329
   127
*/
alpar@1329
   128
alpar@1329
   129
/**
alpar@758
   130
@defgroup flowalgs Path and Flow Algorithms
alpar@678
   131
@ingroup galgs
alpar@758
   132
\brief This group describes the algorithms
alpar@758
   133
for finding paths and flows in graphs.
alpar@678
   134
*/
alpar@678
   135
alpar@678
   136
/**
deba@1750
   137
@defgroup topology Topology related algorithms
deba@1750
   138
@ingroup galgs
deba@1750
   139
\brief This group describes the algorithms
deba@1750
   140
for discover the topology of the graphs.
deba@1750
   141
*/
deba@1750
   142
deba@1750
   143
/**
alpar@1151
   144
@defgroup exceptions Exceptions
alpar@1151
   145
This group contains the exceptions thrown by LEMON library
alpar@1151
   146
*/
alpar@1151
   147
alpar@1151
   148
/**
alpar@678
   149
@defgroup misc Miscellaneous Tools
alpar@678
   150
Here you can find several useful tools for development,
alpar@678
   151
debugging and testing.
alpar@678
   152
*/
alpar@678
   153
alpar@678
   154
/**
alpar@1847
   155
@defgroup timecount Time measuring and Counting
alpar@1847
   156
@ingroup misc
alpar@1847
   157
Here you can find simple tools for measuring the performance
alpar@1847
   158
of algorithms.
alpar@1847
   159
*/
alpar@1847
   160
alpar@1847
   161
/**
alpar@1287
   162
@defgroup io_group Input Output
alpar@1287
   163
Here you can find tools for imporing and exporting graphs and graph related
alpar@1287
   164
data
alpar@1287
   165
*/
alpar@1287
   166
alpar@1287
   167
/**
klao@1030
   168
@defgroup concept Concepts
klao@959
   169
\brief Skeleton classes and concept checking classes
alpar@794
   170
klao@959
   171
This group describes the data/algorithm skeletons and concept checking
klao@1030
   172
classes implemented in LEMON.
klao@1030
   173
klao@1030
   174
One aim of these classes is to make it easier to check if a certain
klao@1030
   175
class or template function is correctly implemented.
klao@1030
   176
klao@1030
   177
The other (sometimes even more important) aim is to document the concepts.
klao@1030
   178
alpar@794
   179
*/
alpar@794
   180
klao@1030
   181
/**
klao@1030
   182
@defgroup graph_concepts Graph Structure Concepts
klao@1030
   183
@ingroup concept
klao@1030
   184
\brief Skeleton and concept checking classes for graph structures
klao@1030
   185
klao@1030
   186
This group contains the skeletons and concept checking classes of LEMON's
klao@1030
   187
graph structures and helper classes used to implement these.
klao@1030
   188
*/
alpar@794
   189
alpar@1587
   190
/* --- Unused group
alpar@678
   191
@defgroup experimental Experimental Structures and Algorithms
alpar@678
   192
This group contains some Experimental structures and algorithms.
alpar@678
   193
The stuff here is subject to change.
alpar@678
   194
*/
alpar@1151
   195
alpar@1558
   196
/**
athos@1582
   197
\anchor demoprograms
athos@1582
   198
alpar@1558
   199
@defgroup demos Demo programs
alpar@1558
   200
alpar@1559
   201
Some demo programs are listed here. Their full source codes can be found in
alpar@1558
   202
the \c demo subdirectory of the source tree.
alpar@1558
   203
ladanyi@1639
   204
The standard compilation procedure (<tt>./configure;make</tt>) will compile
ladanyi@1639
   205
them, as well. 
alpar@1558
   206
alpar@1558
   207
*/
alpar@1558
   208