* ./katabatic:
- In Session::_canonize(): if the canonical segment has never had it's axis sets, put it into *optimal* position instead of simply constraint compliant. Force realignment of the segment sets as rounding errors may introduce slight misalignment on the axis (causing error laters in the various contact topological updates). This also seems to solve the ludicrous problem of negative ratio of expansion wires... (segments *not* at their optimal position at the start). - In LayerAssign, KatabaticEngine::layerAssign(), suppress the triple loop enclosign the desaturation. Now desaturate each layer exactly once and from bottom to top.
This commit is contained in:
parent
8660c41144
commit
8634114021
|
@ -1,8 +1,7 @@
|
||||||
|
|
||||||
// -*- C++ -*-
|
// -*- C++ -*-
|
||||||
//
|
//
|
||||||
// This file is part of the Coriolis Software.
|
// This file is part of the Coriolis Software.
|
||||||
// Copyright (c) UPMC 2012-2012, All Rights Reserved
|
// Copyright (c) UPMC 2012-2013, All Rights Reserved
|
||||||
//
|
//
|
||||||
// +-----------------------------------------------------------------+
|
// +-----------------------------------------------------------------+
|
||||||
// | C O R I O L I S |
|
// | C O R I O L I S |
|
||||||
|
@ -194,8 +193,11 @@ namespace Katabatic {
|
||||||
else if (verticals [0] == NULL) message = "HTee is missing mandatory vertical segment.";
|
else if (verticals [0] == NULL) message = "HTee is missing mandatory vertical segment.";
|
||||||
else if (verticals [1] != NULL) message = "HTee has more than one vertical segment.";
|
else if (verticals [1] != NULL) message = "HTee has more than one vertical segment.";
|
||||||
else if ( (not _horizontal1->isCreated() and not _horizontal2->isCreated())
|
else if ( (not _horizontal1->isCreated() and not _horizontal2->isCreated())
|
||||||
and (_horizontal1->getY() != _horizontal2->getY()) )
|
and (_horizontal1->getY() != _horizontal2->getY()) ) {
|
||||||
message = "HTee has misaligned horizontal segments";
|
message = "HTee has misaligned horizontal segments";
|
||||||
|
message += " h1:" + getString(_horizontal1->getY());
|
||||||
|
message += " h2:" + getString(_horizontal2->getY());
|
||||||
|
}
|
||||||
if (not message.empty()) {
|
if (not message.empty()) {
|
||||||
showTopologyError( message );
|
showTopologyError( message );
|
||||||
setFlags( CntBadTopology );
|
setFlags( CntBadTopology );
|
||||||
|
|
|
@ -1,4 +1,3 @@
|
||||||
|
|
||||||
// -*- C++ -*-
|
// -*- C++ -*-
|
||||||
//
|
//
|
||||||
// This file is part of the Coriolis Software.
|
// This file is part of the Coriolis Software.
|
||||||
|
@ -646,7 +645,7 @@ namespace Katabatic {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
bool AutoSegment::toConstraintAxis ()
|
bool AutoSegment::toConstraintAxis ( unsigned int flags )
|
||||||
{
|
{
|
||||||
ltrace(200) << "toConstraintAxis() " << this << endl;
|
ltrace(200) << "toConstraintAxis() " << this << endl;
|
||||||
ltracein(200);
|
ltracein(200);
|
||||||
|
@ -668,13 +667,13 @@ namespace Katabatic {
|
||||||
}
|
}
|
||||||
|
|
||||||
if (getAxis() < constraintMin) {
|
if (getAxis() < constraintMin) {
|
||||||
setAxis( constraintMin );
|
setAxis( constraintMin, flags );
|
||||||
ltraceout(200);
|
ltraceout(200);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (getAxis() > constraintMax) {
|
if (getAxis() > constraintMax) {
|
||||||
setAxis( constraintMax );
|
setAxis( constraintMax, flags );
|
||||||
ltraceout(200);
|
ltraceout(200);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
@ -684,7 +683,7 @@ namespace Katabatic {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
bool AutoSegment::toOptimalAxis ()
|
bool AutoSegment::toOptimalAxis ( unsigned int flags )
|
||||||
{
|
{
|
||||||
ltrace(200) << "toOptimalAxis() " << this << endl;
|
ltrace(200) << "toOptimalAxis() " << this << endl;
|
||||||
ltracein(200);
|
ltracein(200);
|
||||||
|
@ -700,17 +699,19 @@ namespace Katabatic {
|
||||||
DbU::Unit optimalMax = min( max(getOptimalMax(),constraintMin), constraintMax );
|
DbU::Unit optimalMax = min( max(getOptimalMax(),constraintMin), constraintMax );
|
||||||
|
|
||||||
if (getAxis() < optimalMin) {
|
if (getAxis() < optimalMin) {
|
||||||
setAxis( optimalMin );
|
setAxis( optimalMin, flags );
|
||||||
ltraceout(200);
|
ltraceout(200);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (getAxis() > optimalMax) {
|
if (getAxis() > optimalMax) {
|
||||||
setAxis( optimalMax );
|
setAxis( optimalMax, flags );
|
||||||
ltraceout(200);
|
ltraceout(200);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (flags & KbRealignate) setAxis( getAxis(), flags );
|
||||||
|
|
||||||
ltraceout(200);
|
ltraceout(200);
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
|
@ -486,7 +486,7 @@ namespace Katabatic {
|
||||||
Session::revalidate();
|
Session::revalidate();
|
||||||
|
|
||||||
if (getConfiguration()->getAllowedDepth() > 2) {
|
if (getConfiguration()->getAllowedDepth() > 2) {
|
||||||
for ( int i=0 ; i < 3 ; i++ ) {
|
//for ( int i=0 ; i < 3 ; i++ ) {
|
||||||
for ( size_t depth=1 ; depth < getConfiguration()->getAllowedDepth()-2; ++depth ) {
|
for ( size_t depth=1 ; depth < getConfiguration()->getAllowedDepth()-2; ++depth ) {
|
||||||
_desaturate( depth, globalNets, total, global );
|
_desaturate( depth, globalNets, total, global );
|
||||||
if ( (depth > 1) and ((depth-1)%2 == 1) ) Session::revalidate();
|
if ( (depth > 1) and ((depth-1)%2 == 1) ) Session::revalidate();
|
||||||
|
@ -494,8 +494,8 @@ namespace Katabatic {
|
||||||
|
|
||||||
globalNets.clear ();
|
globalNets.clear ();
|
||||||
|
|
||||||
if (not _gcellGrid->updateDensity()) break;
|
// if (not _gcellGrid->updateDensity()) break;
|
||||||
}
|
//}
|
||||||
Session::revalidate();
|
Session::revalidate();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1,5 +1,4 @@
|
||||||
|
// -*- mode: C++; explicit-buffer-name: "Session.cpp<katabatic>" -*-
|
||||||
// -*- C++ -*-
|
|
||||||
//
|
//
|
||||||
// This file is part of the Coriolis Software.
|
// This file is part of the Coriolis Software.
|
||||||
// Copyright (c) UPMC 2008-2013, All Rights Reserved
|
// Copyright (c) UPMC 2008-2013, All Rights Reserved
|
||||||
|
@ -189,7 +188,9 @@ namespace Katabatic {
|
||||||
ltrace(159) << "Align @" << DbU::getLambda(canonical->getAxis())
|
ltrace(159) << "Align @" << DbU::getLambda(canonical->getAxis())
|
||||||
<< " on " << canonical << endl;
|
<< " on " << canonical << endl;
|
||||||
|
|
||||||
canonical->setAxis( canonical->getAxis(), KbRealignate );
|
//canonical->setAxis( canonical->getAxis(), KbRealignate );
|
||||||
|
if (canonical->isUnsetAxis()) canonical->toOptimalAxis( KbRealignate|KbPropagate );
|
||||||
|
else canonical->setAxis( canonical->getAxis(), KbRealignate|KbPropagate );
|
||||||
aligneds.clear();
|
aligneds.clear();
|
||||||
ltraceout(110);
|
ltraceout(110);
|
||||||
}
|
}
|
||||||
|
|
|
@ -250,8 +250,8 @@ namespace Katabatic {
|
||||||
virtual void invalidate ( unsigned int flags=KbPropagate );
|
virtual void invalidate ( unsigned int flags=KbPropagate );
|
||||||
void computeOptimal ( set<AutoSegment*>& processeds );
|
void computeOptimal ( set<AutoSegment*>& processeds );
|
||||||
void setAxis ( DbU::Unit, unsigned int flags=KbNoFlags );
|
void setAxis ( DbU::Unit, unsigned int flags=KbNoFlags );
|
||||||
bool toConstraintAxis ();
|
bool toConstraintAxis ( unsigned int flags=KbRealignate );
|
||||||
bool toOptimalAxis ();
|
bool toOptimalAxis ( unsigned int flags=KbRealignate );
|
||||||
// Collections & Filters.
|
// Collections & Filters.
|
||||||
AutoSegments getOnSourceContact ( unsigned int direction );
|
AutoSegments getOnSourceContact ( unsigned int direction );
|
||||||
AutoSegments getOnTargetContact ( unsigned int direction );
|
AutoSegments getOnTargetContact ( unsigned int direction );
|
||||||
|
|
Loading…
Reference in New Issue