coriolis/anabatic/src
Jean-Paul Chaput 1a338f620c Corrections in the Dijkstra global routing (ripup) mechanism.
* Bug: In Anabatic::Dijkstra, the degree of a vertex (the number of neighbors
    belonging to the same net) was miscalculated. This was leading, in the
    materialize step to some feed-through vertexes not being broken.
    Leading in turn to incomplete transformation of the detailed routing.
      Also in _trackback(), the degree of the first vertex we were backtracking
    from was not incremented.
* Bug: In Anabatic::Dijkstra::materialize(), systematically use
    GCell::breakGoThrough() on both source and target. This is needed when
    we are in the ripup phase as both source and target can be go-through.
      This was also leading to incomplete detailed routing transformation.
* Change: In Anabatic::Edge::ripup(), ripup one third of the segments instead
    of thoses exeeding the global length threshold. This way we are sure to
    desaturate an edge. Needs to be further calibrated.
* Change: In Aanabatic::GCell::breakGoThrough(), no longer return NULL.
    Return existing gcontact if any. Break if it is a go-through and create
    a new gcontact in last resort. Maybe rename this function.
* New: In Anabatic::Configuration, new parameters:
    - anabatic.edgeHScaling, to adjust the length of the horizontal edges
        relative to the vertical ones (this is a ratio).
    - anabatic.globalIterations, set the maximum number of ripup passes
        of the global router.
* New: In CRL/etc/*/kite.conf, added new parameters anabatic.edgeHScaling
    and anabatic.globalIterations.
* New: In Katana::GlobalRoute::DigitalDistance, take into account the new
    edgeHScaling factor. Must be used when the capacity of V-edges differs
    greatly for H-edges (case of AMS 350nm c35b4 for instance).
* Bug: In Katana::GlobalRoute::DigitalDistance, the historic cost is
    computed for an edge length of "1". Must be multiplicated by the
    current edge length to have any measurable effect.
      This bug is finally explaining why the ripup was producing the
    same solutions over and over, the historical cost was negligible!
2018-04-16 12:10:48 +02:00
..
anabatic Corrections in the Dijkstra global routing (ripup) mechanism. 2018-04-16 12:10:48 +02:00
AnabaticEngine.cpp Corrections in the Dijkstra global routing (ripup) mechanism. 2018-04-16 12:10:48 +02:00
AutoContact.cpp Topology update was not correctly done after layer change. 2018-03-27 18:03:51 +02:00
AutoContactHTee.cpp Topology update was not correctly done after layer change. 2018-03-27 18:03:51 +02:00
AutoContactTerminal.cpp Topology update was not correctly done after layer change. 2018-03-27 18:03:51 +02:00
AutoContactTurn.cpp Topology update was not correctly done after layer change. 2018-03-27 18:03:51 +02:00
AutoContactVTee.cpp Topology update was not correctly done after layer change. 2018-03-27 18:03:51 +02:00
AutoHorizontal.cpp Disable dragging constraints for Device (analog) terminals. 2018-03-02 16:58:21 +01:00
AutoSegment.cpp Topology update was not correctly done after layer change. 2018-03-27 18:03:51 +02:00
AutoSegments.cpp Improved management of AutoContactTerminal for VH gauges (real ones). 2018-01-25 11:58:04 +01:00
AutoVertical.cpp Disable dragging constraints for Device (analog) terminals. 2018-03-02 16:58:21 +01:00
CMakeLists.txt Capacity managment by layer in Edges & GCells (plus fixes). 2018-02-21 00:16:50 +01:00
ChipTools.cpp Happy New Year 2018 ! Update license years... 2018-01-06 17:55:44 +01:00
Configuration.cpp Corrections in the Dijkstra global routing (ripup) mechanism. 2018-04-16 12:10:48 +02:00
Constants.cpp Capacity managment by layer in Edges & GCells (plus fixes). 2018-02-21 00:16:50 +01:00
Dijkstra.cpp Corrections in the Dijkstra global routing (ripup) mechanism. 2018-04-16 12:10:48 +02:00
Edge.cpp Corrections in the Dijkstra global routing (ripup) mechanism. 2018-04-16 12:10:48 +02:00
EdgeCapacity.cpp Capacity managment by layer in Edges & GCells (plus fixes). 2018-02-21 00:16:50 +01:00
Edges.cpp Happy New Year 2018 ! Update license years... 2018-01-06 17:55:44 +01:00
GCell.cpp Corrections in the Dijkstra global routing (ripup) mechanism. 2018-04-16 12:10:48 +02:00
LayerAssign.cpp Happy New Year 2018 ! Update license years... 2018-01-06 17:55:44 +01:00
Matrix.cpp Improve Edge ripup method. Improve two-metal terminal management. 2018-03-06 01:48:44 +01:00
NetBuilder.cpp Topology update was not correctly done after layer change. 2018-03-27 18:03:51 +02:00
NetBuilderHV.cpp Topology update was not correctly done after layer change. 2018-03-27 18:03:51 +02:00
NetBuilderM2.cpp Happy New Year 2018 ! Update license years... 2018-01-06 17:55:44 +01:00
NetBuilderVH.cpp Basic support for FreePDK 45 completed. 2018-02-17 20:27:38 +01:00
NetConstraints.cpp Basic support for FreePDK 45 completed. 2018-02-17 20:27:38 +01:00
NetOptimals.cpp Happy New Year 2018 ! Update license years... 2018-01-06 17:55:44 +01:00
PreRouteds.cpp Happy New Year 2018 ! Update license years... 2018-01-06 17:55:44 +01:00
PyAnabatic.cpp Happy New Year 2018 ! Update license years... 2018-01-06 17:55:44 +01:00
Session.cpp Basic support for FreePDK 45 completed. 2018-02-17 20:27:38 +01:00