Solved more problems related to GCell not owning north/east boundary.
* Bug: In Anabatic, in AutoHorizontal & AutoVertical, native constraints must use GCell::getConstraintsUMax(). * Bug: In Anabatic::GCell, correct terribly bad implementation of both getConstraintUmax(). In getSide(), use getConstraintUMax(). * Bug: In Anabatic::AutoContact, setCBUMax() must be set using the GCell getContraintUMax().
This commit is contained in:
parent
cbb5e8781d
commit
92522fef0b
|
@ -77,7 +77,7 @@ namespace Anabatic {
|
||||||
_gcell = source->getGCell();
|
_gcell = source->getGCell();
|
||||||
|
|
||||||
setOptimalMax( getGCell()->getYMax() );
|
setOptimalMax( getGCell()->getYMax() );
|
||||||
resetNativeConstraints( getGCell()->getYMin(), getGCell()->getYMax() );
|
resetNativeConstraints( getGCell()->getYMin(), getGCell()->getConstraintYMax() );
|
||||||
|
|
||||||
if (getGCell() != target->getGCell()) {
|
if (getGCell() != target->getGCell()) {
|
||||||
setFlags( SegGlobal );
|
setFlags( SegGlobal );
|
||||||
|
@ -88,7 +88,7 @@ namespace Anabatic {
|
||||||
if ( (gcell != getGCell()) and (gcell != target->getGCell()) )
|
if ( (gcell != getGCell()) and (gcell != target->getGCell()) )
|
||||||
gcell->addHSegment( this );
|
gcell->addHSegment( this );
|
||||||
mergeNativeMin( gcell->getYMin() );
|
mergeNativeMin( gcell->getYMin() );
|
||||||
mergeNativeMax( gcell->getYMax() );
|
mergeNativeMax( gcell->getConstraintYMax() );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -440,10 +440,10 @@ namespace Anabatic {
|
||||||
vector<GCell*> gcells;
|
vector<GCell*> gcells;
|
||||||
getGCells( gcells );
|
getGCells( gcells );
|
||||||
|
|
||||||
resetNativeConstraints( gcells[0]->getYMin(), gcells[0]->getYMax() );
|
resetNativeConstraints( gcells[0]->getYMin(), gcells[0]->getConstraintYMax() );
|
||||||
for ( GCell* gcell : gcells ) {
|
for ( GCell* gcell : gcells ) {
|
||||||
mergeNativeMin( gcell->getYMin() );
|
mergeNativeMin( gcell->getYMin() );
|
||||||
mergeNativeMax( gcell->getYMax() );
|
mergeNativeMax( gcell->getConstraintYMax() );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -749,8 +749,10 @@ namespace Anabatic {
|
||||||
if (doglegGCell != end) {
|
if (doglegGCell != end) {
|
||||||
GCell* gcell = doglegGCell;
|
GCell* gcell = doglegGCell;
|
||||||
do {
|
do {
|
||||||
if (gcell != begin)
|
if (gcell != begin) {
|
||||||
|
cdebug_log(149,0) << "| Remove from:" << gcell << endl;
|
||||||
gcell->removeHSegment( this );
|
gcell->removeHSegment( this );
|
||||||
|
}
|
||||||
gcell = gcell->getEast( getNativeMin() );
|
gcell = gcell->getEast( getNativeMin() );
|
||||||
} while ( gcell and (gcell != end) );
|
} while ( gcell and (gcell != end) );
|
||||||
}
|
}
|
||||||
|
|
|
@ -1896,7 +1896,7 @@ namespace Anabatic {
|
||||||
}
|
}
|
||||||
|
|
||||||
if (doglegGCell->getSide(getDirection()).intersect(getSpanU())) {
|
if (doglegGCell->getSide(getDirection()).intersect(getSpanU())) {
|
||||||
cdebug_log(149,0) << "Dogleg in " << this << endl;
|
cdebug_log(149,0) << "Dogleg in " << this << " spanU:" << getSpanU() << endl;
|
||||||
rflags = _makeDogleg( doglegGCell, flags );
|
rflags = _makeDogleg( doglegGCell, flags );
|
||||||
} else {
|
} else {
|
||||||
cdebug_log(149,0) << "Looking in aligneds." << endl;
|
cdebug_log(149,0) << "Looking in aligneds." << endl;
|
||||||
|
|
|
@ -71,7 +71,7 @@ namespace Anabatic {
|
||||||
_gcell = source->getGCell();
|
_gcell = source->getGCell();
|
||||||
|
|
||||||
setOptimalMax( getGCell()->getXMax() );
|
setOptimalMax( getGCell()->getXMax() );
|
||||||
resetNativeConstraints( getGCell()->getXMin(), getGCell()->getXMax() );
|
resetNativeConstraints( getGCell()->getXMin(), getGCell()->getConstraintXMax() );
|
||||||
|
|
||||||
if (getGCell() != target->getGCell()) {
|
if (getGCell() != target->getGCell()) {
|
||||||
setFlags( SegGlobal );
|
setFlags( SegGlobal );
|
||||||
|
@ -82,7 +82,7 @@ namespace Anabatic {
|
||||||
if ( (gcell != getGCell()) and (gcell != target->getGCell()) )
|
if ( (gcell != getGCell()) and (gcell != target->getGCell()) )
|
||||||
gcell->addVSegment( this );
|
gcell->addVSegment( this );
|
||||||
mergeNativeMin( gcell->getXMin() );
|
mergeNativeMin( gcell->getXMin() );
|
||||||
mergeNativeMax( gcell->getXMax() );
|
mergeNativeMax( gcell->getConstraintXMax() );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -376,10 +376,10 @@ namespace Anabatic {
|
||||||
vector<GCell*> gcells;
|
vector<GCell*> gcells;
|
||||||
getGCells( gcells );
|
getGCells( gcells );
|
||||||
|
|
||||||
resetNativeConstraints( gcells[0]->getXMin(), gcells[0]->getXMax() );
|
resetNativeConstraints( gcells[0]->getXMin(), gcells[0]->getConstraintXMax() );
|
||||||
for ( GCell* gcell : gcells ) {
|
for ( GCell* gcell : gcells ) {
|
||||||
mergeNativeMin( gcell->getXMin() );
|
mergeNativeMin( gcell->getXMin() );
|
||||||
mergeNativeMax( gcell->getXMax() );
|
mergeNativeMax( gcell->getConstraintXMax() );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1246,15 +1246,13 @@ namespace Anabatic {
|
||||||
|
|
||||||
if (_hsegments.size() == end) {
|
if (_hsegments.size() == end) {
|
||||||
cerr << Bug( "%s do not go through %s."
|
cerr << Bug( "%s do not go through %s."
|
||||||
, getString(segment).c_str()
|
, getString(segment).c_str(), _getString().c_str() ) << endl;
|
||||||
, _getString().c_str() ) << endl;
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (_hsegments.size() - end > 1)
|
if (_hsegments.size() - end > 1)
|
||||||
cerr << Bug( "%s has multiple occurrences of %s."
|
cerr << Bug( "%s has multiple occurrences of %s."
|
||||||
, _getString().c_str()
|
, _getString().c_str(), getString(segment).c_str() ) << endl;
|
||||||
, getString(segment).c_str() ) << endl;
|
|
||||||
|
|
||||||
_hsegments.erase( _hsegments.begin() + end, _hsegments.end() );
|
_hsegments.erase( _hsegments.begin() + end, _hsegments.end() );
|
||||||
}
|
}
|
||||||
|
|
|
@ -246,9 +246,9 @@ namespace Anabatic {
|
||||||
inline GCell* AutoContact::getGCell () const { return _gcell; }
|
inline GCell* AutoContact::getGCell () const { return _gcell; }
|
||||||
inline Box AutoContact::getConstraintBox () const { return Box(getCBXMin(),getCBYMin(),getCBXMax(),getCBYMax()); }
|
inline Box AutoContact::getConstraintBox () const { return Box(getCBXMin(),getCBYMin(),getCBXMax(),getCBYMax()); }
|
||||||
inline void AutoContact::setCBXMin ( DbU::Unit xMin ) { _dxMin = _getDeltaMin(xMin,_gcell->getXMin()); }
|
inline void AutoContact::setCBXMin ( DbU::Unit xMin ) { _dxMin = _getDeltaMin(xMin,_gcell->getXMin()); }
|
||||||
inline void AutoContact::setCBXMax ( DbU::Unit xMax ) { _dxMax = _getDeltaMax(xMax,_gcell->getXMin(),_gcell->getXMax()); }
|
inline void AutoContact::setCBXMax ( DbU::Unit xMax ) { _dxMax = _getDeltaMax(xMax,_gcell->getXMin(),_gcell->getConstraintXMax()); }
|
||||||
inline void AutoContact::setCBYMin ( DbU::Unit yMin ) { _dyMin = _getDeltaMin(yMin,_gcell->getYMin()); }
|
inline void AutoContact::setCBYMin ( DbU::Unit yMin ) { _dyMin = _getDeltaMin(yMin,_gcell->getYMin()); }
|
||||||
inline void AutoContact::setCBYMax ( DbU::Unit yMax ) { _dyMax = _getDeltaMax(yMax,_gcell->getYMin(),_gcell->getYMax()); }
|
inline void AutoContact::setCBYMax ( DbU::Unit yMax ) { _dyMax = _getDeltaMax(yMax,_gcell->getYMin(),_gcell->getConstraintYMax()); }
|
||||||
inline void AutoContact::setFlags ( unsigned int flags ) { _flags|= flags; }
|
inline void AutoContact::setFlags ( unsigned int flags ) { _flags|= flags; }
|
||||||
inline void AutoContact::unsetFlags ( unsigned int flags ) { _flags&=~flags; }
|
inline void AutoContact::unsetFlags ( unsigned int flags ) { _flags&=~flags; }
|
||||||
inline int AutoContact::_getDeltaMin ( DbU::Unit x, DbU::Unit xMin ) { if (x<xMin) return 0; return (int)DbU::toLambda(x-xMin); }
|
inline int AutoContact::_getDeltaMin ( DbU::Unit x, DbU::Unit xMin ) { if (x<xMin) return 0; return (int)DbU::toLambda(x-xMin); }
|
||||||
|
|
|
@ -337,10 +337,10 @@ namespace Anabatic {
|
||||||
: _northEdges[0]->getOpposite(this)->getYMin() - shrink; }
|
: _northEdges[0]->getOpposite(this)->getYMin() - shrink; }
|
||||||
|
|
||||||
inline DbU::Unit GCell::getConstraintXMax () const
|
inline DbU::Unit GCell::getConstraintXMax () const
|
||||||
{ return getXMax( _eastEdges .empty() ? -1 : 0 ); }
|
{ return getXMax( _eastEdges.empty() ? 0 : 1 ); }
|
||||||
|
|
||||||
inline DbU::Unit GCell::getConstraintYMax () const
|
inline DbU::Unit GCell::getConstraintYMax () const
|
||||||
{ return getYMax( _northEdges .empty() ? -1 : 0 ); }
|
{ return getYMax( _northEdges.empty() ? 0 : 1 ); }
|
||||||
|
|
||||||
inline Point GCell::getCenter () const
|
inline Point GCell::getCenter () const
|
||||||
{ return Point( (getXMin()+getXMax())/2, (getYMin()+getYMax())/2); }
|
{ return Point( (getXMin()+getXMax())/2, (getYMin()+getYMax())/2); }
|
||||||
|
@ -350,8 +350,8 @@ namespace Anabatic {
|
||||||
|
|
||||||
inline Interval GCell::getSide ( Flags direction ) const
|
inline Interval GCell::getSide ( Flags direction ) const
|
||||||
{
|
{
|
||||||
if (direction.isset(Flags::Vertical)) return Interval( getYMin(), getYMax() );
|
if (direction.isset(Flags::Vertical)) return Interval( getYMin(), getConstraintYMax() );
|
||||||
return Interval( getXMin(), getXMax() );
|
return Interval( getXMin(), getConstraintXMax() );
|
||||||
}
|
}
|
||||||
|
|
||||||
inline void GCell::setObserver ( size_t slot, BaseObserver* observer )
|
inline void GCell::setObserver ( size_t slot, BaseObserver* observer )
|
||||||
|
|
|
@ -292,7 +292,7 @@ namespace Katana {
|
||||||
vector<GCell*> gcells;
|
vector<GCell*> gcells;
|
||||||
_segment->getGCells( gcells );
|
_segment->getGCells( gcells );
|
||||||
|
|
||||||
if (gcells.size() < 2 ){
|
if (gcells.size() < 2) {
|
||||||
cerr << Bug( "relax() Cannot break %s,\n only in %s."
|
cerr << Bug( "relax() Cannot break %s,\n only in %s."
|
||||||
, getString(_segment).c_str()
|
, getString(_segment).c_str()
|
||||||
, getString(gcells[0]).c_str()
|
, getString(gcells[0]).c_str()
|
||||||
|
|
|
@ -622,7 +622,9 @@ namespace Katana {
|
||||||
cdebug_log(159,0) << "Expanding (after):" << _constraints << endl;
|
cdebug_log(159,0) << "Expanding (after):" << _constraints << endl;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
cdebug_log(159,0) << "| Raw Track Constraint: " << _constraints << endl;
|
cdebug_log(159,0) << "| Raw Track Constraint: " << _constraints
|
||||||
|
<< " [" << _constraints.getVMin()
|
||||||
|
<< "," << _constraints.getVMax() << "]" << endl;
|
||||||
|
|
||||||
_tracksNb = 0;
|
_tracksNb = 0;
|
||||||
|
|
||||||
|
|
|
@ -234,7 +234,7 @@ namespace Katana {
|
||||||
cdebug_log(159,0) << "getGCells(): sourceGCell: " << sourceGCell << endl;
|
cdebug_log(159,0) << "getGCells(): sourceGCell: " << sourceGCell << endl;
|
||||||
cdebug_log(159,0) << "getGCells(): targetGCell: " << targetGCell << endl;
|
cdebug_log(159,0) << "getGCells(): targetGCell: " << targetGCell << endl;
|
||||||
|
|
||||||
for( AutoSegment* segment : base()->getAligneds() ) {
|
for ( AutoSegment* segment : base()->getAligneds() ) {
|
||||||
cdebug_log(159,0) << "| " << segment << endl;
|
cdebug_log(159,0) << "| " << segment << endl;
|
||||||
|
|
||||||
Anabatic::GCell* gcell = segment->getAutoSource()->getGCell();
|
Anabatic::GCell* gcell = segment->getAutoSource()->getGCell();
|
||||||
|
@ -256,10 +256,12 @@ namespace Katana {
|
||||||
|
|
||||||
Flags side = (direction & Flags::Horizontal) ? Flags::EastSide : Flags::NorthSide;
|
Flags side = (direction & Flags::Horizontal) ? Flags::EastSide : Flags::NorthSide;
|
||||||
DbU::Unit axis = getAxis();
|
DbU::Unit axis = getAxis();
|
||||||
|
cdebug_log(159,0) << "* dir:" << side._getString() << " @" << DbU::getValueString(axis) << endl;
|
||||||
|
|
||||||
gcells.push_back( sourceGCell );
|
gcells.push_back( sourceGCell );
|
||||||
while ( sourceGCell != targetGCell ) {
|
while ( sourceGCell != targetGCell ) {
|
||||||
sourceGCell = sourceGCell->getNeighborAt( direction, axis );
|
sourceGCell = sourceGCell->getNeighborAt( direction, axis );
|
||||||
|
cdebug_log(159,0) << "| " << sourceGCell << endl;
|
||||||
if (not sourceGCell) break;
|
if (not sourceGCell) break;
|
||||||
|
|
||||||
gcells.push_back( sourceGCell );
|
gcells.push_back( sourceGCell );
|
||||||
|
@ -724,8 +726,8 @@ namespace Katana {
|
||||||
|
|
||||||
|
|
||||||
TrackElement* TrackSegment::makeDogleg ( Anabatic::GCell* dogLegGCell
|
TrackElement* TrackSegment::makeDogleg ( Anabatic::GCell* dogLegGCell
|
||||||
, TrackElement*& perpandicular
|
, TrackElement*& perpandicular
|
||||||
, TrackElement*& parallel
|
, TrackElement*& parallel
|
||||||
)
|
)
|
||||||
{
|
{
|
||||||
cdebug_log(159,0) << "TrackSegment::makeDogleg(GCell*)" << endl;
|
cdebug_log(159,0) << "TrackSegment::makeDogleg(GCell*)" << endl;
|
||||||
|
|
Loading…
Reference in New Issue