summaryrefslogtreecommitdiffstats
path: root/src/map/if
diff options
context:
space:
mode:
authorAlan Mishchenko <alanmi@berkeley.edu>2011-10-04 18:43:23 +0700
committerAlan Mishchenko <alanmi@berkeley.edu>2011-10-04 18:43:23 +0700
commitd66b586330ba6e285fb12a4bc21779d4b88a403f (patch)
tree478ba55c55aea1a5a6b4c90ff3877509b11095e5 /src/map/if
parent8c302870f44d718261962d24e034ee19a8b6add8 (diff)
downloadabc-d66b586330ba6e285fb12a4bc21779d4b88a403f.tar.gz
abc-d66b586330ba6e285fb12a4bc21779d4b88a403f.tar.bz2
abc-d66b586330ba6e285fb12a4bc21779d4b88a403f.zip
Modified write_blif to output LUT structures.
Diffstat (limited to 'src/map/if')
-rw-r--r--src/map/if/ifDec16.c100
-rw-r--r--src/map/if/ifMan.c7
2 files changed, 87 insertions, 20 deletions
diff --git a/src/map/if/ifDec16.c b/src/map/if/ifDec16.c
index 39881875..87badfc4 100644
--- a/src/map/if/ifDec16.c
+++ b/src/map/if/ifDec16.c
@@ -194,7 +194,7 @@ static inline void If_CluSharp( word * pRes, word * pIn1, word * pIn2, int nVars
int w, nWords = If_CluWordNum( nVars );
for ( w = 0; w < nWords; w++ )
pRes[w] = pIn1[w] & ~pIn2[w];
-}
+}
static inline void If_CluOr( word * pRes, word * pIn1, word * pIn2, int nVars )
{
int w, nWords = If_CluWordNum( nVars );
@@ -203,8 +203,10 @@ static inline void If_CluOr( word * pRes, word * pIn1, word * pIn2, int nVars )
}
static inline word If_CluAdjust( word t, int nVars )
{
- assert( nVars >= 0 && nVars < 6 );
- t &= (1 << (1 << nVars)) - 1;
+ assert( nVars >= 0 && nVars <= 6 );
+ if ( nVars == 6 )
+ return t;
+ t &= (((word)1) << (1 << nVars)) - 1;
if ( nVars == 0 )
t |= t << (1<<nVars++);
if ( nVars == 1 )
@@ -703,11 +705,11 @@ int If_CluDetectSpecialCaseCofs( word * pF, int nVars, int iVar )
if ( Cof0 == 0 )
State[0]++;
- else if ( Cof0 == ~Truth6[iVar] )
+ else if ( Cof0 == ~0 )
State[1]++;
else if ( Cof1 == 0 )
State[2]++;
- else if ( Cof1 == ~Truth6[iVar] )
+ else if ( Cof1 == ~0 )
State[3]++;
else if ( Cof0 == ~Cof1 )
State[4]++;
@@ -1074,28 +1076,76 @@ static inline int If_CluSupport( word * t, int nVars )
Supp |= (1 << v);
return Supp;
}
+static inline void If_CluTruthShrink( word * pF, int nVars, int nVarsAll, unsigned Phase )
+{
+ word pG[CLU_WRD_MAX], * pIn = pF, * pOut = pG, * pTemp;
+ int i, k, Var = 0, Counter = 0;
+ assert( nVarsAll <= 16 );
+ for ( i = 0; i < nVarsAll; i++ )
+ if ( Phase & (1 << i) )
+ {
+ for ( k = i-1; k >= Var; k-- )
+ {
+ If_CluSwapAdjacent( pOut, pIn, k, nVarsAll );
+ pTemp = pIn; pIn = pOut, pOut = pTemp;
+ Counter++;
+ }
+ Var++;
+ }
+ assert( Var == nVars );
+ // swap if it was moved an odd number of times
+ if ( Counter & 1 )
+ If_CluCopy( pOut, pIn, nVarsAll );
+}
+int If_CluMinimumBase( word * t, int * pSupp, int nVarsAll, int * pnVars )
+{
+ int v, iVar = 0, uSupp = 0;
+ assert( nVarsAll <= 16 );
+ for ( v = 0; v < nVarsAll; v++ )
+ if ( If_CluHasVar( t, nVarsAll, v ) )
+ {
+ uSupp |= (1 << v);
+ if ( pSupp )
+ pSupp[iVar] = pSupp[v];
+ iVar++;
+ }
+ if ( pnVars )
+ *pnVars = iVar;
+ if ( If_CluSuppIsMinBase( uSupp ) )
+ return 0;
+ If_CluTruthShrink( t, iVar, nVarsAll, uSupp );
+ return 1;
+}
// returns the best group found
-If_Grp_t If_CluCheck( If_Man_t * p, word * pTruth0, int nVars, int nLutLeaf, int nLutRoot )
+If_Grp_t If_CluCheck( If_Man_t * p, word * pTruth0, int nVars, int nLutLeaf, int nLutRoot, If_Grp_t * pR, word * pFunc0, word * pFunc1 )
{
If_Grp_t G1 = {0}, R = {0}, * pHashed = NULL;
word Truth, pTruth[CLU_WRD_MAX], pF[CLU_WRD_MAX];//, pG[CLU_WRD_MAX];
int V2P[CLU_VAR_MAX+2], P2V[CLU_VAR_MAX+2], pCanonPerm[CLU_VAR_MAX];
int i, nSupp, uCanonPhase;
+ int nLutSize = p ? p->pPars->nLutSize : nVars;
assert( nVars <= CLU_VAR_MAX );
assert( nVars <= nLutLeaf + nLutRoot - 1 );
+ if ( pR )
+ {
+ pR->nVars = 0;
+ *pFunc0 = 0;
+ *pFunc1 = 0;
+ }
+
// canonicize truth table
- If_CluCopy( pTruth, pTruth0, p->pPars->nLutSize );
+ If_CluCopy( pTruth, pTruth0, nLutSize );
if ( 0 )
{
uCanonPhase = If_CluSemiCanonicize( pTruth, nVars, pCanonPerm );
- If_CluAdjustBig( pTruth, nVars, p->pPars->nLutSize );
+ If_CluAdjustBig( pTruth, nVars, nLutSize );
}
// If_CluSemiCanonicizeVerify( pTruth, pTruth0, nVars, pCanonPerm, uCanonPhase );
-// If_CluCopy( pTruth, pTruth0, p->pPars->nLutSize );
+// If_CluCopy( pTruth, pTruth0, nLutSize );
/*
@@ -1123,9 +1173,12 @@ If_Grp_t If_CluCheck( If_Man_t * p, word * pTruth0, int nVars, int nLutLeaf, int
// check hash table
- pHashed = If_CluHashLookup( p, pTruth );
- if ( pHashed && pHashed->nVars != CLU_UNUSED )
- return *pHashed;
+ if ( p )
+ {
+ pHashed = If_CluHashLookup( p, pTruth );
+ if ( pHashed && pHashed->nVars != CLU_UNUSED )
+ return *pHashed;
+ }
// detect easy cofs
G1 = If_CluDecUsingCofs( pTruth, nVars, nLutLeaf );
@@ -1169,7 +1222,7 @@ If_Grp_t If_CluCheck( If_Man_t * p, word * pTruth0, int nVars, int nLutLeaf, int
}
// derive
- if ( 0 )
+ if ( pR )
{
If_CluMoveGroupToMsb( pF, nVars, V2P, P2V, &G1 );
if ( G1.nMyu == 2 )
@@ -1177,17 +1230,32 @@ If_Grp_t If_CluCheck( If_Man_t * p, word * pTruth0, int nVars, int nLutLeaf, int
else
Truth = If_CluDeriveNonDisjoint( pF, nVars, V2P, P2V, &G1, &R );
+ *pFunc0 = If_CluAdjust( pF[0], R.nVars );
+ *pFunc1 = If_CluAdjust( Truth, G1.nVars );
+
// perform checking
if ( 0 )
{
If_CluCheckGroup( pTruth, nVars, &G1 );
If_CluVerify( pTruth, nVars, &G1, &R, Truth, pF );
}
+ *pR = R;
}
return pHashed ? (*pHashed = G1) : G1;
}
+// returns the best group found
+int If_CluCheckExt( If_Man_t * p, word * pTruth, int nVars, int nLutLeaf, int nLutRoot, char * pLut0, char * pLut1, word * pFunc0, word * pFunc1 )
+{
+ If_Grp_t G, R;
+ G = If_CluCheck( p, pTruth, nVars, nLutLeaf, nLutRoot, &R, pFunc0, pFunc1 );
+ memcpy( pLut0, &R, sizeof(If_Grp_t) );
+ memcpy( pLut1, &G, sizeof(If_Grp_t) );
+// memcpy( pLut2, &G2, sizeof(If_Grp_t) );
+ return (G.nVars > 0);
+}
+
// computes delay of the decomposition
float If_CluDelayMax( If_Grp_t * g, float * pDelays )
{
@@ -1251,7 +1319,7 @@ float If_CutDelayLutStruct( If_Man_t * p, If_Cut_t * pCut, char * pStr, float Wi
}
// derive the first group
- G1 = If_CluCheck( p, (word *)If_CutTruth(pCut), nLeaves, nLutLeaf, nLutRoot );
+ G1 = If_CluCheck( p, (word *)If_CutTruth(pCut), nLeaves, nLutLeaf, nLutRoot, NULL, NULL, NULL );
if ( G1.nVars == 0 )
return ABC_INFINITY;
@@ -1334,7 +1402,7 @@ int If_CutPerformCheck16( If_Man_t * p, unsigned * pTruth, int nVars, int nLeave
return 1;
// derive the first group
- G1 = If_CluCheck( p, (word *)pTruth, nLeaves, nLutLeaf, nLutRoot );
+ G1 = If_CluCheck( p, (word *)pTruth, nLeaves, nLutLeaf, nLutRoot, NULL, NULL, NULL );
if ( G1.nVars == 0 )
{
// printf( "-%d ", nLeaves );
@@ -1380,7 +1448,7 @@ void If_CluTest()
Kit_DsdPrintFromTruth( (unsigned*)&t, nVars ); printf( "\n" );
- G = If_CluCheck( NULL, &t, nVars, nLutLeaf, nLutRoot );
+ G = If_CluCheck( NULL, &t, nVars, nLutLeaf, nLutRoot, NULL, NULL, NULL );
If_CluPrintGroup( &G );
}
diff --git a/src/map/if/ifMan.c b/src/map/if/ifMan.c
index c6aaa9c4..b0f3537c 100644
--- a/src/map/if/ifMan.c
+++ b/src/map/if/ifMan.c
@@ -127,8 +127,7 @@ void If_ManRestart( If_Man_t * p )
***********************************************************************/
void If_ManStop( If_Man_t * p )
{
-// if ( p->nCutsUselessAll && p->pPars->fVerbose )
- if ( p->nCutsUselessAll )
+ if ( p->pPars->fVerbose && p->nCutsUselessAll )
{
int i;
for ( i = 0; i <= 16; i++ )
@@ -161,8 +160,8 @@ void If_ManStop( If_Man_t * p )
if ( p->vSwitching )
Vec_IntFree( p->vSwitching );
// hash table
- if ( p->nTableEntries )
- printf( "Entries = %d. Size = %d.\n", p->nTableEntries, p->nTableSize );
+ if ( p->pPars->fVerbose && p->nTableEntries )
+ printf( "Hash table: Entries = %7d. Size = %7d.\n", p->nTableEntries, p->nTableSize );
ABC_FREE( p->pHashTable );
if ( p->pMemEntries )
Mem_FixedStop( p->pMemEntries, 0 );