summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAlan Mishchenko <alanmi@berkeley.edu>2016-01-05 14:05:07 -0800
committerAlan Mishchenko <alanmi@berkeley.edu>2016-01-05 14:05:07 -0800
commit19ad75f125e5a99014d8549233f1d120acea9677 (patch)
tree96b13a36570b4b8d61b6effd523213e55962cef5
parent6642e40af55770233f0f5db0153a8edc5bd774b6 (diff)
downloadabc-19ad75f125e5a99014d8549233f1d120acea9677.tar.gz
abc-19ad75f125e5a99014d8549233f1d120acea9677.tar.bz2
abc-19ad75f125e5a99014d8549233f1d120acea9677.zip
Migrating back to using 'float' in area-flow computation in &nf.
-rw-r--r--src/aig/gia/gia.h1
-rw-r--r--src/aig/gia/giaNf.c144
-rw-r--r--src/map/mio/mio.h3
-rw-r--r--src/map/mio/mioUtils.c13
-rw-r--r--src/opt/sfm/sfmLib.c2
5 files changed, 86 insertions, 77 deletions
diff --git a/src/aig/gia/gia.h b/src/aig/gia/gia.h
index 87ce6b91..b282e0c8 100644
--- a/src/aig/gia/gia.h
+++ b/src/aig/gia/gia.h
@@ -318,6 +318,7 @@ struct Jf_Par_t_
word WordMapDelayTarget;
float MapDelay;
float MapArea;
+ float MapAreaF;
float MapDelayTarget;
float Epsilon;
float * pTimesArr;
diff --git a/src/aig/gia/giaNf.c b/src/aig/gia/giaNf.c
index 683aea5c..3ef3ff93 100644
--- a/src/aig/gia/giaNf.c
+++ b/src/aig/gia/giaNf.c
@@ -70,7 +70,7 @@ struct Nf_Mat_t_
unsigned fBest : 1; // best cut
Nf_Cfg_t Cfg; // input literals
word D; // delay
- word A; // area
+ float F; // area
};
typedef struct Nf_Obj_t_ Nf_Obj_t;
struct Nf_Obj_t_
@@ -103,7 +103,8 @@ struct Nf_Man_t_
int fUseEla; // use exact area
int nInvs; // the inverter count
word InvDelay; // inverter delay
- word InvArea; // inverter area
+ word InvAreaW; // inverter delay
+ float InvAreaF; // inverter area
// statistics
abctime clkStart; // starting time
double CutCount[6]; // cut counts
@@ -174,7 +175,7 @@ static inline int Nf_CfgCompl( Nf_Cfg_t Cfg, int i )
int Nf_StoCellIsDominated( Mio_Cell2_t * pCell, int * pFans, word * pProf )
{
int k;
- if ( pCell->Area < pProf[0] )
+ if ( pCell->AreaW < pProf[0] )
return 0;
for ( k = 0; k < (int)pCell->nFanins; k++ )
if ( pCell->Delays[Abc_Lit2Var(pFans[k])] < pProf[k+1] )
@@ -243,7 +244,7 @@ void Nf_StoCreateGateAdd( Nf_Man_t * pMan, word uTruth, int * pFans, int nFans,
if ( pMan->pPars->fPinFilter )
{
Vec_IntPush( vArrayProfs, Vec_WrdSize(vStore) );
- Vec_WrdPush( vStore, pCell->Area );
+ Vec_WrdPush( vStore, pCell->AreaW );
for ( k = 0; k < nFans; k++ )
Vec_WrdPush( vStore, pCell->Delays[Abc_Lit2Var(pFans[k])] );
}
@@ -316,7 +317,7 @@ void Nf_StoPrintOne( Nf_Man_t * p, int Count, int t, int i, int GateId, Nf_Cfg_t
printf( "%6d : ", t );
printf( "%6d : ", i );
printf( "Gate %16s ", pC->pName );
- printf( "Area =%8.2f ", Nf_Wrd2Flt(pC->Area) );
+ printf( "Area =%8.2f ", pC->AreaF );
printf( "In = %d ", pC->nFanins );
if ( Mat.fCompl )
printf( " compl " );
@@ -408,7 +409,8 @@ Nf_Man_t * Nf_StoCreate( Gia_Man_t * pGia, Jf_Par_t * pPars )
assert( Vec_WecSize(p->vTt2Match) == Vec_MemEntryNum(p->vTtMem) );
Nf_StoDeriveMatches( p, 0 );//pPars->fVerbose );
p->InvDelay = p->pCells[3].Delays[0];
- p->InvArea = p->pCells[3].Area;
+ p->InvAreaW = p->pCells[3].AreaW;
+ p->InvAreaF = p->pCells[3].AreaF;
Nf_ObjMatchD(p, 0, 0)->Gate = 0;
Nf_ObjMatchD(p, 0, 1)->Gate = 1;
// prepare cuts
@@ -995,7 +997,7 @@ void Nf_ManPrintStats( Nf_Man_t * p, char * pTitle )
return;
printf( "%s : ", pTitle );
printf( "Delay =%8.2f ", Nf_Wrd2Flt(p->pPars->WordMapDelay) );
- printf( "Area =%12.2f ", Nf_Wrd2Flt(p->pPars->WordMapArea) );
+ printf( "Area =%12.2f ", p->pPars->MapAreaF );
printf( "Gate =%6d ", (int)p->pPars->Area );
printf( "Inv =%6d ", (int)p->nInvs );
printf( "Edge =%7d ", (int)p->pPars->Edge );
@@ -1075,7 +1077,7 @@ void Nf_ManCutMatchPrint( Nf_Man_t * p, int iObj, char * pStr, Nf_Mat_t * pM )
pCell = Nf_ManCell( p, pM->Gate );
pCut = Nf_CutFromHandle( Nf_ObjCutSet(p, iObj), pM->CutH );
printf( "D =%6.2f ", Nf_Wrd2Flt(pM->D) );
- printf( "A =%6.2f ", Nf_Wrd2Flt(pM->A) );
+ printf( "A =%6.2f ", pM->F );
printf( "C = %d ", pM->fCompl );
// printf( "B = %d ", pM->fBest );
printf( " " );
@@ -1124,7 +1126,7 @@ void Nf_ManCutMatchOne( Nf_Man_t * p, int iObj, int * pCut, int * pCutSet )
pD = Nf_ObjMatchD( p, iObj, c );
pA = Nf_ObjMatchA( p, iObj, c );
pD->D = pA->D = 0;
- pD->A = pA->A = p->pCells[c ^ Const].Area;
+ pD->F = pA->F = p->pCells[c ^ Const].AreaF;
pD->CutH = pA->CutH = Nf_CutHandle(pCutSet, pCut);
pD->Gate = pA->Gate = c ^ Const;
// pD->Conf = pA->Conf = 0;
@@ -1141,7 +1143,8 @@ void Nf_ManCutMatchOne( Nf_Man_t * p, int iObj, int * pCut, int * pCutSet )
word Required = Nf_ObjRequired( p, iObj, fCompl );
Nf_Mat_t * pD = &pBest->M[fCompl][0];
Nf_Mat_t * pA = &pBest->M[fCompl][1];
- word Area = pC->Area, Delay = 0;
+ float AreaF = pC->AreaF;
+ word Delay = 0;
assert( nFans == (int)pC->nFanins );
Nf_CfgForEachVarCompl( Cfg, nFans, iFanin, fComplF, k )
{
@@ -1150,14 +1153,14 @@ void Nf_ManCutMatchOne( Nf_Man_t * p, int iObj, int * pCut, int * pCutSet )
if ( ArrivalA + pC->Delays[k] <= Required && Required != NF_INFINITY )
{
Delay = Abc_MaxWord( Delay, ArrivalA + pC->Delays[k] );
- Area += pBestF[iFanin]->M[fComplF][1].A;
+ AreaF += pBestF[iFanin]->M[fComplF][1].F;
}
else
{
if ( pD->D < NF_INFINITY && pA->D < NF_INFINITY && ArrivalD + pC->Delays[k] > Required )
break;
Delay = Abc_MaxWord( Delay, ArrivalD + pC->Delays[k] );
- Area += pBestF[iFanin]->M[fComplF][0].A;
+ AreaF += pBestF[iFanin]->M[fComplF][0].F;
}
}
if ( k < nFans )
@@ -1166,17 +1169,17 @@ void Nf_ManCutMatchOne( Nf_Man_t * p, int iObj, int * pCut, int * pCutSet )
if ( pD->D > Delay )
{
pD->D = Delay;
- pD->A = Area;
+ pD->F = AreaF;
pD->CutH = Nf_CutHandle(pCutSet, pCut);
pD->Gate = pC->Id;
pD->Cfg = Cfg;
pD->Cfg.fCompl = 0;
}
- if ( pA->A > Area )
+ if ( pA->F > AreaF )
{
pA->D = Delay;
- pA->A = Area;
+ pA->F = AreaF;
pA->CutH = Nf_CutHandle(pCutSet, pCut);
pA->Gate = pC->Id;
pA->Cfg = Cfg;
@@ -1193,10 +1196,10 @@ static inline void Nf_ObjPrepareCi( Nf_Man_t * p, int iObj, word Time )
pD0->D = pA0->D = pD->D = pA->D = Time;
pD->fCompl = 1;
pD->D += p->InvDelay;
- pD->A = p->InvArea;
+ pD->F = p->InvAreaF;
pA->fCompl = 1;
pA->D += p->InvDelay;
- pA->A = p->InvArea;
+ pA->F = p->InvAreaF;
Nf_ObjMatchD( p, iObj, 0 )->fBest = 1;
Nf_ObjMatchD( p, iObj, 1 )->fBest = 1;
}
@@ -1216,11 +1219,11 @@ static inline void Nf_ObjPrepareBuf( Nf_Man_t * p, Gia_Obj_t * pObj )
memset( Nf_ManObj(p, iObj), 0, sizeof(Nf_Obj_t) );
// set the direct phase
pDp->D = pAp->D = pDf->D;
- pDp->A = pAp->A = pDf->A; // do not pass flow???
+ pDp->F = pAp->F = pDf->F; // do not pass flow???
pDp->fBest = 1;
// set the inverted phase
pDn->D = pAn->D = pDf->D + p->InvDelay;
- pDn->A = pAn->A = pDf->A + p->InvArea;
+ pDn->F = pAn->F = pDf->F + p->InvAreaF;
pDn->fCompl = pAn->fCompl = 1;
pDn->fBest = 1;
}
@@ -1255,8 +1258,10 @@ void Nf_ManCutMatch( Nf_Man_t * p, int iObj )
Nf_Mat_t * pDn = &pBest->M[1][0];
Nf_Mat_t * pAp = &pBest->M[0][1];
Nf_Mat_t * pAn = &pBest->M[1][1];
- word FlowRefP = (word)(MIO_NUM * Nf_ObjFlowRefs(p, iObj, 0));
- word FlowRefN = (word)(MIO_NUM * Nf_ObjFlowRefs(p, iObj, 1));
+// word FlowRefP = (word)(MIO_NUM * Nf_ObjFlowRefs(p, iObj, 0));
+// word FlowRefN = (word)(MIO_NUM * Nf_ObjFlowRefs(p, iObj, 1));
+ float FlowRefPf = Nf_ObjFlowRefs(p, iObj, 0);
+ float FlowRefNf = Nf_ObjFlowRefs(p, iObj, 1);
int i, * pCut, * pCutSet = Nf_ObjCutSet( p, iObj );
word Required[2] = {0};
if ( p->Iter )
@@ -1266,10 +1271,10 @@ void Nf_ManCutMatch( Nf_Man_t * p, int iObj )
Required[1] = Nf_ObjRequired( p, iObj, 1 );
}
memset( pBest, 0, sizeof(Nf_Obj_t) );
- pDp->D = pDp->A = NF_INFINITY;
- pDn->D = pDn->A = NF_INFINITY;
- pAp->D = pAp->A = NF_INFINITY;
- pAn->D = pAn->A = NF_INFINITY;
+ pDp->D = NF_INFINITY; pDp->F = FLT_MAX;
+ pDn->D = NF_INFINITY; pDn->F = FLT_MAX;
+ pAp->D = NF_INFINITY; pAp->F = FLT_MAX;
+ pAn->D = NF_INFINITY; pAn->F = FLT_MAX;
Nf_SetForEachCut( pCutSet, pCut, i )
{
if ( Abc_Lit2Var(Nf_CutFunc(pCut)) >= Vec_WecSize(p->vTt2Match) )
@@ -1292,10 +1297,10 @@ void Nf_ManCutMatch( Nf_Man_t * p, int iObj )
}
*/
// divide by ref count
- pDp->A = pDp->A * MIO_NUM / FlowRefP;
- pAp->A = pAp->A * MIO_NUM / FlowRefP;
- pDn->A = pDn->A * MIO_NUM / FlowRefN;
- pAn->A = pAn->A * MIO_NUM / FlowRefN;
+ pDp->F = pDp->F / FlowRefPf;
+ pAp->F = pAp->F / FlowRefPf;
+ pDn->F = pDn->F / FlowRefNf;
+ pAn->F = pAn->F / FlowRefNf;
// add the inverters
assert( pDp->D < NF_INFINITY || pDn->D < NF_INFINITY );
@@ -1303,7 +1308,7 @@ void Nf_ManCutMatch( Nf_Man_t * p, int iObj )
{
*pDp = *pDn;
pDp->D += p->InvDelay;
- pDp->A += p->InvArea;
+ pDp->F += p->InvAreaF;
pDp->fCompl = 1;
if ( pAp->D == NF_INFINITY )
*pAp = *pDp;
@@ -1313,7 +1318,7 @@ void Nf_ManCutMatch( Nf_Man_t * p, int iObj )
{
*pDn = *pDp;
pDn->D += p->InvDelay;
- pDn->A += p->InvArea;
+ pDn->F += p->InvAreaF;
pDn->fCompl = 1;
if ( pAn->D == NF_INFINITY )
*pAn = *pDn;
@@ -1321,24 +1326,24 @@ void Nf_ManCutMatch( Nf_Man_t * p, int iObj )
}
//assert( pAp->A < NF_INFINITY || pAn->A < NF_INFINITY );
// try replacing pos with neg
- if ( pAp->D == NF_INFINITY || (pAp->A > pAn->A + p->InvArea && pAn->D + p->InvDelay <= Required[0]) )
+ if ( pAp->D == NF_INFINITY || (pAp->F > pAn->F + p->InvAreaF && pAn->D + p->InvDelay <= Required[0]) )
{
assert( p->Iter > 0 );
*pAp = *pAn;
pAp->D += p->InvDelay;
- pAp->A += p->InvArea;
+ pAp->F += p->InvAreaF;
pAp->fCompl = 1;
if ( pDp->D == NF_INFINITY )
*pDp = *pAp;
//printf( "Using inverter to improve area at node %d in phase %d.\n", iObj, 1 );
}
// try replacing neg with pos
- else if ( pAn->D == NF_INFINITY || (pAn->A > pAp->A + p->InvArea && pAp->D + p->InvDelay <= Required[1]) )
+ else if ( pAn->D == NF_INFINITY || (pAn->F > pAp->F + p->InvAreaF && pAp->D + p->InvDelay <= Required[1]) )
{
assert( p->Iter > 0 );
*pAn = *pAp;
pAn->D += p->InvDelay;
- pAn->A += p->InvArea;
+ pAn->F += p->InvAreaF;
pAn->fCompl = 1;
if ( pDn->D == NF_INFINITY )
*pDn = *pAn;
@@ -1353,21 +1358,21 @@ void Nf_ManCutMatch( Nf_Man_t * p, int iObj )
printf( "Object %d has pAp unassigned.\n", iObj );
if ( pAn->D == NF_INFINITY )
printf( "Object %d has pAn unassigned.\n", iObj );
-
+/*
pDp->A = Abc_MinWord( pDp->A, NF_INFINITY/MIO_NUM );
pDn->A = Abc_MinWord( pDn->A, NF_INFINITY/MIO_NUM );
pAp->A = Abc_MinWord( pAp->A, NF_INFINITY/MIO_NUM );
pAn->A = Abc_MinWord( pAn->A, NF_INFINITY/MIO_NUM );
-
+*/
assert( pDp->D < NF_INFINITY );
assert( pDn->D < NF_INFINITY );
assert( pAp->D < NF_INFINITY );
assert( pAn->D < NF_INFINITY );
- assert( pDp->A < NF_INFINITY );
- assert( pDn->A < NF_INFINITY );
- assert( pAp->A < NF_INFINITY );
- assert( pAn->A < NF_INFINITY );
+ assert( pDp->F < FLT_MAX );
+ assert( pDn->F < FLT_MAX );
+ assert( pAp->F < FLT_MAX );
+ assert( pAn->F < FLT_MAX );
/*
if ( p->Iter && (pDp->D > Required[0] || pDn->D > Required[1]) )
@@ -1487,7 +1492,7 @@ void Nf_ManSetMapRefsGate( Nf_Man_t * p, int iObj, word Required, Nf_Mat_t * pM
}
assert( Nf_CutSize(pCut) == (int)pCell->nFanins );
// update global stats
- p->pPars->WordMapArea += pCell->Area;
+ p->pPars->MapAreaF += pCell->AreaF;
p->pPars->Edge += Nf_CutSize(pCut);
p->pPars->Area++;
// update status of the gate
@@ -1521,7 +1526,8 @@ void Nf_ManPrintMatches( Nf_Man_t * p )
}
int Nf_ManSetMapRefs( Nf_Man_t * p )
{
- float Coef = 1.0 / (1.0 + (p->Iter + 1) * (p->Iter + 1));
+// float Coef = 1.0 / (1.0 + (p->Iter + 1) * (p->Iter + 1));
+ float Coef = 0.25;
float * pFlowRefs = Vec_FltArray( &p->vFlowRefs );
int * pMapRefs = Vec_IntArray( &p->vMapRefs );
int nLits = 2*Gia_ManObjNum(p->pGia);
@@ -1541,7 +1547,7 @@ int Nf_ManSetMapRefs( Nf_Man_t * p )
// compute area and edges
p->nInvs = 0;
- p->pPars->WordMapArea = 0;
+ p->pPars->MapAreaF = 0;
p->pPars->Area = p->pPars->Edge = 0;
Gia_ManForEachAndReverse( p->pGia, pObj, i )
{
@@ -1551,7 +1557,7 @@ int Nf_ManSetMapRefs( Nf_Man_t * p )
{
Nf_ObjMapRefInc( p, i, 0 );
Nf_ObjUpdateRequired( p, i, 0, Nf_ObjRequired(p, i, 1) - p->InvDelay );
- p->pPars->WordMapArea += p->InvArea;
+ p->pPars->MapAreaF += p->InvAreaF;
p->pPars->Edge++;
p->pPars->Area++;
p->nInvs++;
@@ -1618,7 +1624,7 @@ int Nf_ManSetMapRefs( Nf_Man_t * p )
// create gate
Nf_ManSetMapRefsGate( p, i, Required, pM );
// account for the inverter
- p->pPars->WordMapArea += p->InvArea;
+ p->pPars->MapAreaF += p->InvAreaF;
p->pPars->Edge++;
p->pPars->Area++;
p->nInvs++;
@@ -1650,7 +1656,7 @@ int Nf_ManSetMapRefs( Nf_Man_t * p )
pM = (pA->D <= Required) ? pA : pD;
assert( !pM->fCompl );
// account for the inverter
- p->pPars->WordMapArea += p->InvArea;
+ p->pPars->MapAreaF += p->InvAreaF;
p->pPars->Edge++;
p->pPars->Area++;
}
@@ -1667,7 +1673,7 @@ int Nf_ManSetMapRefs( Nf_Man_t * p )
{
Nf_ObjMapRefInc( p, Id, 0 );
Nf_ObjUpdateRequired( p, Id, 0, Required - p->InvDelay );
- p->pPars->WordMapArea += p->InvArea;
+ p->pPars->MapAreaF += p->InvAreaF;
p->pPars->Edge++;
p->pPars->Area++;
p->nInvs++;
@@ -1702,7 +1708,7 @@ word Nf_MatchDeref_rec( Nf_Man_t * p, int i, int c, Nf_Mat_t * pM )
assert( Nf_ObjMapRefNum(p, i, !c) > 0 );
if ( !Nf_ObjMapRefDec(p, i, !c) )
Area += Nf_MatchDeref_rec( p, i, !c, Nf_ObjMatchD(p, i, !c) );
- return Area + p->InvArea;
+ return Area + p->InvAreaW;
}
if ( Nf_ObjCutSetId(p, i) == 0 )
return 0;
@@ -1713,7 +1719,7 @@ word Nf_MatchDeref_rec( Nf_Man_t * p, int i, int c, Nf_Mat_t * pM )
if ( !Nf_ObjMapRefDec(p, iVar, fCompl) )
Area += Nf_MatchDeref_rec( p, iVar, fCompl, Nf_ObjMatchD(p, iVar, fCompl) );
}
- return Area + Nf_ManCell(p, pM->Gate)->Area;
+ return Area + Nf_ManCell(p, pM->Gate)->AreaW;
}
word Nf_MatchRef_rec( Nf_Man_t * p, int i, int c, Nf_Mat_t * pM, word Required, Vec_Int_t * vBackup )
{
@@ -1729,7 +1735,7 @@ word Nf_MatchRef_rec( Nf_Man_t * p, int i, int c, Nf_Mat_t * pM, word Required,
assert( Nf_ObjMapRefNum(p, i, !c) >= 0 );
if ( !Nf_ObjMapRefInc(p, i, !c) )
Area += Nf_MatchRef_rec( p, i, !c, Nf_ObjMatchD(p, i, !c), ReqFanin, vBackup );
- return Area + p->InvArea;
+ return Area + p->InvAreaW;
}
if ( Nf_ObjCutSetId(p, i) == 0 )
return 0;
@@ -1743,7 +1749,7 @@ word Nf_MatchRef_rec( Nf_Man_t * p, int i, int c, Nf_Mat_t * pM, word Required,
if ( !Nf_ObjMapRefInc(p, iVar, fCompl) )
Area += Nf_MatchRef_rec( p, iVar, fCompl, Nf_ObjMatchD(p, iVar, fCompl), ReqFanin, vBackup );
}
- return Area + Nf_ManCell(p, pM->Gate)->Area;
+ return Area + Nf_ManCell(p, pM->Gate)->AreaW;
}
word Nf_MatchRefArea( Nf_Man_t * p, int i, int c, Nf_Mat_t * pM, word Required )
{
@@ -1772,7 +1778,7 @@ void Nf_ManElaBestMatchOne( Nf_Man_t * p, int iObj, int c, int * pCut, int * pCu
pBestF[i] = Nf_ManObj( p, pFans[i] );
// consider matches of this function
memset( pMb, 0, sizeof(Nf_Mat_t) );
- pMb->D = pMb->A = NF_INFINITY;
+ pMb->D = NF_INFINITY; pMb->F = FLT_MAX;
// special cases
if ( nFans == 0 )
{
@@ -1780,14 +1786,14 @@ void Nf_ManElaBestMatchOne( Nf_Man_t * p, int iObj, int c, int * pCut, int * pCu
//printf( "Node %d(%d) is const\n", iObj, c );
assert( iFuncLit == 0 || iFuncLit == 1 );
pMb->D = 0;
- pMb->A = p->pCells[c ^ Const].Area;
+ pMb->F = p->pCells[c ^ Const].AreaF;
pMb->CutH = Nf_CutHandle(pCutSet, pCut);
pMb->Gate = c ^ Const;
// pMb->Conf = 0;
pMb->Cfg = Nf_Int2Cfg(0);
pMb->fBest = 1;
// compare
- if ( pRes->A > pMb->A || (pRes->A == pMb->A && pRes->D > pMb->D) )
+ if ( pRes->F > pMb->F || (pRes->F == pMb->F && pRes->D > pMb->D) )
*pRes = *pMb;
return;
}
@@ -1811,9 +1817,9 @@ void Nf_ManElaBestMatchOne( Nf_Man_t * p, int iObj, int c, int * pCut, int * pCu
}
if ( k < nFans )
continue;
- // create Cfgch
+ // create match
pMb->D = Delay;
- pMb->A = NF_INFINITY;
+ pMb->F = FLT_MAX;
pMb->fBest = 1;
pMb->fCompl = 0;
pMb->CutH = Nf_CutHandle(pCutSet, pCut);
@@ -1821,9 +1827,9 @@ void Nf_ManElaBestMatchOne( Nf_Man_t * p, int iObj, int c, int * pCut, int * pCu
pMb->Cfg = Cfg;
pMb->Cfg.fCompl = 0;
// compute area
- pMb->A = Nf_MatchRefArea( p, iObj, c, pMb, Required );
+ pMb->F = MIO_NUMINV * (ABC_INT64_T)Nf_MatchRefArea( p, iObj, c, pMb, Required );
// compare
- if ( pRes->A > pMb->A || (pRes->A == pMb->A && pRes->D > pMb->D) )
+ if ( pRes->F > pMb->F || (pRes->F == pMb->F && pRes->D > pMb->D) )
*pRes = *pMb;
}
}
@@ -1831,7 +1837,7 @@ void Nf_ManElaBestMatch( Nf_Man_t * p, int iObj, int c, Nf_Mat_t * pRes, word Re
{
int k, * pCut, * pCutSet = Nf_ObjCutSet( p, iObj );
memset( pRes, 0, sizeof(Nf_Mat_t) );
- pRes->D = pRes->A = NF_INFINITY;
+ pRes->D = NF_INFINITY; pRes->F = FLT_MAX;
Nf_SetForEachCut( pCutSet, pCut, k )
{
if ( Abc_Lit2Var(Nf_CutFunc(pCut)) >= Vec_WecSize(p->vTt2Match) )
@@ -1870,8 +1876,8 @@ void Nf_ManResetMatches( Nf_Man_t * p, int Round )
{
pDc = Nf_ObjMatchD( p, i, c );
pAc = Nf_ObjMatchA( p, i, c );
- pDc->A = pAc->A = 0;
- pDc->D = pMfan->D + (c ? p->InvArea : 0);
+ pDc->F = pAc->F = 0;
+ pDc->D = pMfan->D + (c ? p->InvDelay : 0);
assert( pDc->fBest );
assert( !pAc->fBest );
assert( c==0 || pDc->fCompl );
@@ -1883,7 +1889,7 @@ void Nf_ManResetMatches( Nf_Man_t * p, int Round )
{
pDc = Nf_ObjMatchD( p, i, c );
pAc = Nf_ObjMatchA( p, i, c );
- pDc->A = pAc->A = 0;
+ pDc->F = pAc->F = 0;
if ( Nf_ObjMapRefNum(p, i, c) )
{
assert( pDc->fBest != pAc->fBest );
@@ -1991,7 +1997,7 @@ void Nf_ManComputeMappingEla( Nf_Man_t * p )
// set best match
assert( pMb->fBest );
assert( pMb->D <= Required );
- assert( pMb->A == AreaAft );
+ //assert( pMb->F == MIO_NUMINV * (ABC_INT64_T)AreaAft );
assert( AreaBef >= AreaAft );
*pM = *pMb;
// update timing
@@ -2082,7 +2088,7 @@ void Nf_ManUpdateStats( Nf_Man_t * p )
Gia_Obj_t * pObj;
Mio_Cell2_t * pCell;
int i, c, Id, * pCut;
- p->pPars->WordMapArea = 0; p->nInvs = 0;
+ p->pPars->MapAreaF = 0; p->nInvs = 0;
p->pPars->Area = p->pPars->Edge = 0;
Gia_ManForEachAndReverse( p->pGia, pObj, i )
{
@@ -2090,7 +2096,7 @@ void Nf_ManUpdateStats( Nf_Man_t * p )
{
if ( Nf_ObjMapRefNum(p, i, 1) )
{
- p->pPars->WordMapArea += p->InvArea;
+ p->pPars->MapAreaF += p->InvAreaF;
p->pPars->Edge++;
p->pPars->Area++;
p->nInvs++;
@@ -2103,7 +2109,7 @@ void Nf_ManUpdateStats( Nf_Man_t * p )
pM = Nf_ObjMatchBest( p, i, c );
if ( pM->fCompl )
{
- p->pPars->WordMapArea += p->InvArea;
+ p->pPars->MapAreaF += p->InvAreaF;
p->pPars->Edge++;
p->pPars->Area++;
p->nInvs++;
@@ -2112,7 +2118,7 @@ void Nf_ManUpdateStats( Nf_Man_t * p )
pCut = Nf_CutFromHandle( Nf_ObjCutSet(p, i), pM->CutH );
pCell = Nf_ManCell( p, pM->Gate );
assert( Nf_CutSize(pCut) == (int)pCell->nFanins );
- p->pPars->WordMapArea += pCell->Area;
+ p->pPars->MapAreaF += pCell->AreaF;
p->pPars->Edge += Nf_CutSize(pCut);
p->pPars->Area++;
//printf( "%5d (%d) : Gate = %7s \n", i, c, pCell->pName );
@@ -2121,7 +2127,7 @@ void Nf_ManUpdateStats( Nf_Man_t * p )
Gia_ManForEachCiId( p->pGia, Id, i )
if ( Nf_ObjMapRefNum(p, Id, 1) )
{
- p->pPars->WordMapArea += p->InvArea;
+ p->pPars->MapAreaF += p->InvAreaF;
p->pPars->Edge++;
p->pPars->Area++;
p->nInvs++;
diff --git a/src/map/mio/mio.h b/src/map/mio/mio.h
index e4e15c6f..8fa3f71a 100644
--- a/src/map/mio/mio.h
+++ b/src/map/mio/mio.h
@@ -62,7 +62,8 @@ struct Mio_Cell2_t_
unsigned Id : 26; // gate ID
unsigned Type : 2; // gate type
unsigned nFanins : 4; // gate fanins
- word Area; // area
+ float AreaF; // area
+ word AreaW; // area
word uTruth; // truth table
word DelayAve; // average delay
word Delays[6]; // delay
diff --git a/src/map/mio/mioUtils.c b/src/map/mio/mioUtils.c
index 71ff2258..85b5c6d6 100644
--- a/src/map/mio/mioUtils.c
+++ b/src/map/mio/mioUtils.c
@@ -338,9 +338,9 @@ int Mio_AreaCompare2( Mio_Cell2_t * pG1, Mio_Cell2_t * pG2 )
return -1;
if ( pG1->nFanins > pG2->nFanins )
return 1;
- if ( pG1->Area < pG2->Area )
+ if ( pG1->AreaW < pG2->AreaW )
return -1;
- if ( pG1->Area > pG2->Area )
+ if ( pG1->AreaW > pG2->AreaW )
return 1;
// compare names
Comp = strcmp( pG1->pName, pG2->pName );
@@ -630,9 +630,9 @@ static inline int Mio_CompareTwo2( Mio_Cell2_t * pCell1, Mio_Cell2_t * pCell2 )
{
int Comp;
// compare areas
- if ( pCell1->Area > pCell2->Area )
+ if ( pCell1->AreaW > pCell2->AreaW )
return 1;
- if ( pCell1->Area < pCell2->Area )
+ if ( pCell1->AreaW < pCell2->AreaW )
return 0;
// compare delays
if ( pCell1->DelayAve > pCell2->DelayAve )
@@ -654,7 +654,8 @@ static inline void Mio_CollectCopy2( Mio_Cell2_t * pCell, Mio_Gate_t * pGate )
pCell->pName = pGate->pName;
pCell->vExpr = pGate->vExpr;
pCell->uTruth = pGate->uTruth;
- pCell->Area = (word)(MIO_NUM * pGate->dArea);
+ pCell->AreaF = pGate->dArea;
+ pCell->AreaW = (word)(MIO_NUM * pGate->dArea);
pCell->nFanins = pGate->nInputs;
pCell->pMioGate = pGate;
pCell->DelayAve = 0;
@@ -757,7 +758,7 @@ Mio_Cell2_t * Mio_CollectRootsNew2( Mio_Library_t * pLib, int nInputs, int * pnG
printf( "None\n" );
else
printf( "%-20s In = %d N = %3d A = %12.6f D = %12.6f\n",
- pCell->pName, pCell->nFanins, pCounts[i], MIO_NUMINV*(unsigned)pCell->Area, MIO_NUMINV*(unsigned)pCell->DelayAve );
+ pCell->pName, pCell->nFanins, pCounts[i], pCell->AreaF, MIO_NUMINV*(unsigned)pCell->DelayAve );
}
ABC_FREE( pCounts );
}
diff --git a/src/opt/sfm/sfmLib.c b/src/opt/sfm/sfmLib.c
index f9b2ef6a..1dffb164 100644
--- a/src/opt/sfm/sfmLib.c
+++ b/src/opt/sfm/sfmLib.c
@@ -323,7 +323,7 @@ void Sfm_LibPrepareAdd( Sfm_Lib_t * p, word * pTruth, int * Perm, int nFanins, M
{
Sfm_Fun_t * pObj;
int InvPerm[SFM_SUPP_MAX], Profile[SFM_SUPP_MAX];
- int Area = (int)pCellBot->Area + (pCellTop ? (int)pCellTop->Area : 0);
+ int Area = (int)pCellBot->AreaW + (pCellTop ? (int)pCellTop->AreaW : 0);
int i, k, Id, Prev, Offset, * pProf, iFunc = Vec_MemHashInsert( p->vTtMem, pTruth );
if ( iFunc == Vec_IntSize(&p->vLists) )
{