NEWS
author Alpar Juttner <alpar@cs.elte.hu>
Wed, 07 Aug 2013 07:09:31 +0200
branch1.2
changeset 985 b9887ae63df0
parent 926 7887be87f4a0
child 989 e38c9a70375c
permissions -rw-r--r--
Merge #294 to branch 1.2
alpar@934
     1
2011-11-09 Version 1.2.3 released
alpar@934
     2
alpar@934
     3
        Bugfix release.
alpar@934
     4
alpar@934
     5
        #428: Add missing lemon/lemon.pc.cmake to the release tarball
alpar@934
     6
        #429: Fix VS warnings
alpar@934
     7
        #430: Fix LpBase::Constr two-side limit bug
alpar@934
     8
alpar@926
     9
2011-08-08 Version 1.2.2 released
alpar@926
    10
alpar@926
    11
        Bugfix release.
alpar@926
    12
alpar@926
    13
        #392: Bug fix in Dfs::start(s,t)
alpar@926
    14
        #414: Fix wrong initialization in Preflow
alpar@926
    15
        #404: Update Doxygen configuration
alpar@926
    16
        #416: Support tests with valgrind
alpar@926
    17
        #418: Better Win CodeBlock/MinGW support
alpar@926
    18
        #419: Backport build environment improvements from the main branch
alpar@926
    19
              - Build of mip_test and lp_test precede the running of the tests
alpar@926
    20
              - Also search for coin libs under ${COIN_ROOT_DIR}/lib/coin
alpar@926
    21
              - Do not look for COIN_VOL libraries
alpar@926
    22
        #382: Allow lgf file without Arc maps
alpar@926
    23
        #417: Bug fix in CostScaling
alpar@926
    24
alpar@897
    25
2010-10-21 Version 1.2.1 released
alpar@897
    26
alpar@897
    27
        Bugfix release.
alpar@897
    28
alpar@897
    29
        #366: Fix Pred[Matrix]MapPath::empty()
alpar@897
    30
        #371: Bug fix in (di)graphCopy()
alpar@897
    31
              The target graph is cleared before adding nodes and arcs/edges.
alpar@897
    32
alpar@897
    33
        #364: Add missing UndirectedTags
alpar@897
    34
        #368: Fix the usage of std::numeric_limits<>::min() in Network Simplex
alpar@897
    35
        #372: Fix a critical bug in preflow
alpar@897
    36
alpar@883
    37
2010-03-19 Version 1.2 released
alpar@883
    38
alpar@883
    39
        This is major feature release
alpar@883
    40
alpar@883
    41
        * New algorithms
alpar@883
    42
          * Bellman-Ford algorithm (#51)
alpar@883
    43
          * Minimum mean cycle algorithms (#179)
alpar@883
    44
            * Karp, Hartman-Orlin and Howard algorithms
alpar@883
    45
          * New minimum cost flow algorithms (#180)
alpar@883
    46
            * Cost Scaling algorithms
alpar@883
    47
            * Capacity Scaling algorithm
alpar@883
    48
            * Cycle-Canceling algorithms
alpar@883
    49
          * Planarity related algorithms (#62)
alpar@883
    50
            * Planarity checking algorithm
alpar@883
    51
            * Planar embedding algorithm
alpar@883
    52
            * Schnyder's planar drawing algorithm
alpar@883
    53
            * Coloring planar graphs with five or six colors
alpar@883
    54
          * Fractional matching algorithms (#314)
alpar@883
    55
        * New data structures
alpar@883
    56
          * StaticDigraph structure (#68)
alpar@883
    57
          * Several new priority queue structures (#50, #301)
alpar@883
    58
            * Fibonacci, Radix, Bucket, Pairing, Binomial
alpar@883
    59
              D-ary and fourary heaps (#301)
alpar@883
    60
          * Iterable map structures (#73)
alpar@883
    61
        * Other new tools and functionality
alpar@883
    62
          * Map utility functions (#320)
alpar@883
    63
          * Reserve functions are added to ListGraph and SmartGraph (#311)
alpar@883
    64
          * A resize() function is added to HypercubeGraph (#311)
alpar@883
    65
          * A count() function is added to CrossRefMap (#302)
alpar@883
    66
          * Support for multiple targets in Suurballe using fullInit() (#181)
alpar@883
    67
          * Traits class and named parameters for Suurballe (#323)
alpar@883
    68
          * Separate reset() and resetParams() functions in NetworkSimplex
alpar@883
    69
            to handle graph changes (#327)
alpar@883
    70
          * tolerance() functions are added to HaoOrlin (#306)
alpar@883
    71
        * Implementation improvements
alpar@883
    72
          * Improvements in weighted matching algorithms (#314)
alpar@883
    73
            * Jumpstart initialization
alpar@883
    74
          * ArcIt iteration is based on out-arc lists instead of in-arc lists
alpar@883
    75
            in ListDigraph (#311)
alpar@883
    76
          * Faster add row operation in CbcMip (#203)
alpar@883
    77
          * Better implementation for split() in ListDigraph (#311)
alpar@883
    78
          * ArgParser can also throw exception instead of exit(1) (#332)
alpar@883
    79
        * Miscellaneous
alpar@883
    80
          * A simple interactive bootstrap script
alpar@883
    81
          * Doc improvements (#62,#180,#299,#302,#303,#304,#307,#311,#331,#315,
alpar@883
    82
                #316,#319)
alpar@883
    83
            * BibTeX references in the doc (#184)
alpar@883
    84
          * Optionally use valgrind when running tests
alpar@883
    85
          * Also check ReferenceMapTag in concept checks (#312)
alpar@883
    86
          * dimacs-solver uses long long type by default.
alpar@883
    87
        * Several bugfixes (compared to release 1.1):
alpar@883
    88
          #295: Suppress MSVC warnings using pragmas
alpar@883
    89
          ----: Various CMAKE related improvements
alpar@883
    90
                * Remove duplications from doc/CMakeLists.txt
alpar@883
    91
                * Rename documentation install folder from 'docs' to 'html'
alpar@883
    92
                * Add tools/CMakeLists.txt to the tarball
alpar@883
    93
                * Generate and install LEMONConfig.cmake
alpar@883
    94
                * Change the label of the html project in Visual Studio
alpar@883
    95
                * Fix the check for the 'long long' type
alpar@883
    96
                * Put the version string into config.h
alpar@883
    97
                * Minor CMake improvements
alpar@883
    98
                * Set the version to 'hg-tip' if everything fails
alpar@883
    99
          #311: Add missing 'explicit' keywords
alpar@883
   100
          #302: Fix the implementation and doc of CrossRefMap
alpar@883
   101
          #308: Remove duplicate list_graph.h entry from source list
alpar@883
   102
          #307: Bugfix in Preflow and Circulation
alpar@883
   103
          #305: Bugfix and extension in the rename script
alpar@883
   104
          #312: Also check ReferenceMapTag in concept checks
alpar@883
   105
          #250: Bugfix in pathSource() and pathTarget()
alpar@883
   106
          #321: Use pathCopy(from,to) instead of copyPath(to,from)
alpar@883
   107
          #322: Distribure LEMONConfig.cmake.in
alpar@883
   108
          #330: Bug fix in map_extender.h
alpar@883
   109
          #336: Fix the date field comment of graphToEps() output
alpar@883
   110
          #323: Bug fix in Suurballe
alpar@883
   111
          #335: Fix clear() function in ExtendFindEnum
alpar@883
   112
          #337: Use void* as the LPX object pointer
alpar@883
   113
          #317: Fix (and improve) error message in mip_test.cc
alpar@883
   114
                Remove unnecessary OsiCbc dependency
alpar@883
   115
          #356: Allow multiple executions of weighted matching algorithms (#356)
alpar@883
   116
alpar@665
   117
2009-05-13 Version 1.1 released
alpar@665
   118
alpar@665
   119
        This is the second stable release of the 1.x series. It
alpar@665
   120
        features a better coverage of the tools available in the 0.x
alpar@665
   121
        series, a thoroughly reworked LP/MIP interface plus various
alpar@665
   122
        improvements in the existing tools.
alpar@665
   123
alpar@665
   124
        * Much improved M$ Windows support
alpar@665
   125
          * Various improvements in the CMAKE build system
alpar@665
   126
          * Compilation warnings are fixed/suppressed
alpar@665
   127
        * Support IBM xlC compiler
alpar@665
   128
        * New algorithms
alpar@665
   129
          * Connectivity related algorithms (#61)
alpar@665
   130
          * Euler walks (#65)
alpar@665
   131
          * Preflow push-relabel max. flow algorithm (#176)
alpar@665
   132
          * Circulation algorithm (push-relabel based) (#175)
alpar@665
   133
          * Suurballe algorithm (#47)
alpar@665
   134
          * Gomory-Hu algorithm (#66)
alpar@665
   135
          * Hao-Orlin algorithm (#58)
alpar@665
   136
          * Edmond's maximum cardinality and weighted matching algorithms
alpar@665
   137
            in general graphs (#48,#265)
alpar@665
   138
          * Minimum cost arborescence/branching (#60)
alpar@665
   139
          * Network Simplex min. cost flow algorithm (#234)
alpar@665
   140
        * New data structures
alpar@665
   141
          * Full graph structure (#57)
alpar@665
   142
          * Grid graph structure (#57)
alpar@665
   143
          * Hypercube graph structure (#57)
alpar@665
   144
          * Graph adaptors (#67)
alpar@665
   145
          * ArcSet and EdgeSet classes (#67)
alpar@665
   146
          * Elevator class (#174)
alpar@665
   147
        * Other new tools
alpar@665
   148
          * LP/MIP interface (#44)
alpar@665
   149
            * Support for GLPK, CPLEX, Soplex, COIN-OR CLP and CBC
alpar@665
   150
          * Reader for the Nauty file format (#55)
alpar@665
   151
          * DIMACS readers (#167)
alpar@665
   152
          * Radix sort algorithms (#72)
alpar@665
   153
          * RangeIdMap and CrossRefMap (#160)
alpar@665
   154
        * New command line tools
alpar@665
   155
          * DIMACS to LGF converter (#182)
alpar@665
   156
          * lgf-gen - a graph generator (#45)
alpar@665
   157
          * DIMACS solver utility (#226)
alpar@665
   158
        * Other code improvements
alpar@665
   159
          * Lognormal distribution added to Random (#102)
alpar@665
   160
          * Better (i.e. O(1) time) item counting in SmartGraph (#3)
alpar@665
   161
          * The standard maps of graphs are guaranteed to be
alpar@665
   162
            reference maps (#190)
alpar@665
   163
        * Miscellaneous
alpar@665
   164
          * Various doc improvements
alpar@665
   165
          * Improved 0.x -> 1.x converter script
alpar@665
   166
alpar@665
   167
        * Several bugfixes (compared to release 1.0):
alpar@665
   168
          #170: Bugfix SmartDigraph::split()
alpar@665
   169
          #171: Bugfix in SmartGraph::restoreSnapshot()
alpar@665
   170
          #172: Extended test cases for graphs and digraphs
alpar@665
   171
          #173: Bugfix in Random
alpar@665
   172
                * operator()s always return a double now
alpar@665
   173
                * the faulty real<Num>(Num) and real<Num>(Num,Num)
alpar@665
   174
                  have been removed
alpar@665
   175
          #187: Remove DijkstraWidestPathOperationTraits
alpar@665
   176
          #61:  Bugfix in DfsVisit
alpar@665
   177
          #193: Bugfix in GraphReader::skipSection()
alpar@665
   178
          #195: Bugfix in ConEdgeIt()
alpar@665
   179
          #197: Bugfix in heap unionfind
alpar@665
   180
                * This bug affects Edmond's general matching algorithms
alpar@665
   181
          #207: Fix 'make install' without 'make html' using CMAKE
alpar@665
   182
          #208: Suppress or fix VS2008 compilation warnings
alpar@665
   183
          ----: Update the LEMON icon
alpar@665
   184
          ----: Enable the component-based installer
alpar@665
   185
                (in installers made by CPACK)
alpar@665
   186
          ----: Set the proper version for CMAKE in the tarballs
alpar@665
   187
                (made by autotools)
alpar@665
   188
          ----: Minor clarification in the LICENSE file
alpar@665
   189
          ----: Add missing unistd.h include to time_measure.h
alpar@665
   190
          #204: Compilation bug fixed in graph_to_eps.h with VS2005
alpar@883
   191
          #214,#215: windows.h should never be included by LEMON headers
alpar@665
   192
          #230: Build systems check the availability of 'long long' type
alpar@665
   193
          #229: Default implementation of Tolerance<> is used for integer types
alpar@665
   194
          #211,#212: Various fixes for compiling on AIX
alpar@665
   195
          ----: Improvements in CMAKE config
alpar@665
   196
                - docs is installed in share/doc/
alpar@665
   197
                - detects newer versions of Ghostscript
alpar@665
   198
          #239: Fix missing 'inline' specifier in time_measure.h
alpar@665
   199
          #274,#280: Install lemon/config.h
alpar@665
   200
          #275: Prefix macro names with LEMON_ in lemon/config.h
alpar@665
   201
          ----: Small script for making the release tarballs added
alpar@665
   202
          ----: Minor improvement in unify-sources.sh (a76f55d7d397)
alpar@665
   203
alpar@496
   204
2009-03-27 LEMON joins to the COIN-OR initiative
alpar@496
   205
alpar@496
   206
        COIN-OR (Computational Infrastructure for Operations Research,
alpar@496
   207
        http://www.coin-or.org) project is an initiative to spur the
alpar@496
   208
        development of open-source software for the operations research
alpar@496
   209
        community.
alpar@496
   210
alpar@322
   211
2008-10-13 Version 1.0 released
alpar@262
   212
alpar@883
   213
        This is the first stable release of LEMON. Compared to the 0.x
alpar@883
   214
        release series, it features a considerably smaller but more
alpar@883
   215
        matured set of tools. The API has also completely revised and
alpar@883
   216
        changed in several places.
alpar@262
   217
alpar@883
   218
        * The major name changes compared to the 0.x series (see the
alpar@322
   219
          Migration Guide in the doc for more details)
alpar@262
   220
          * Graph -> Digraph, UGraph -> Graph
alpar@262
   221
          * Edge -> Arc, UEdge -> Edge
alpar@883
   222
          * source(UEdge)/target(UEdge) -> u(Edge)/v(Edge)
alpar@883
   223
        * Other improvements
alpar@883
   224
          * Better documentation
alpar@883
   225
          * Reviewed and cleaned up codebase
alpar@883
   226
          * CMake based build system (along with the autotools based one)
alpar@883
   227
        * Contents of the library (ported from 0.x)
alpar@883
   228
          * Algorithms
alpar@883
   229
            * breadth-first search (bfs.h)
alpar@883
   230
            * depth-first search (dfs.h)
alpar@883
   231
            * Dijkstra's algorithm (dijkstra.h)
alpar@883
   232
            * Kruskal's algorithm (kruskal.h)
alpar@883
   233
          * Data structures
alpar@883
   234
            * graph data structures (list_graph.h, smart_graph.h)
alpar@883
   235
            * path data structures (path.h)
alpar@883
   236
            * binary heap data structure (bin_heap.h)
alpar@883
   237
            * union-find data structures (unionfind.h)
alpar@883
   238
            * miscellaneous property maps (maps.h)
alpar@883
   239
            * two dimensional vector and bounding box (dim2.h)
alpar@262
   240
          * Concepts
alpar@883
   241
            * graph structure concepts (concepts/digraph.h, concepts/graph.h,
alpar@262
   242
              concepts/graph_components.h)
alpar@883
   243
            * concepts for other structures (concepts/heap.h, concepts/maps.h,
alpar@883
   244
              concepts/path.h)
alpar@883
   245
          * Tools
alpar@883
   246
            * Mersenne twister random number generator (random.h)
alpar@883
   247
            * tools for measuring cpu and wall clock time (time_measure.h)
alpar@883
   248
            * tools for counting steps and events (counter.h)
alpar@883
   249
            * tool for parsing command line arguments (arg_parser.h)
alpar@883
   250
            * tool for visualizing graphs (graph_to_eps.h)
alpar@883
   251
            * tools for reading and writing data in LEMON Graph Format
alpar@262
   252
              (lgf_reader.h, lgf_writer.h)
alpar@262
   253
            * tools to handle the anomalies of calculations with
alpar@883
   254
              floating point numbers (tolerance.h)
alpar@262
   255
            * tools to manage RGB colors (color.h)
alpar@883
   256
          * Infrastructure
alpar@883
   257
            * extended assertion handling (assert.h)
alpar@883
   258
            * exception classes and error handling (error.h)
alpar@883
   259
            * concept checking (concept_check.h)
alpar@883
   260
            * commonly used mathematical constants (math.h)