diff options
author | Alan Mishchenko <alanmi@berkeley.edu> | 2015-01-31 11:10:07 -0800 |
---|---|---|
committer | Alan Mishchenko <alanmi@berkeley.edu> | 2015-01-31 11:10:07 -0800 |
commit | ff1fb1757bfee4a8b98fd1d0717e2b2ff860a10b (patch) | |
tree | 82c368d3092709c12dc495e2dc8e8e7c28e338af | |
parent | c58dd062591f47a79eee6b838b267e51534bbdd5 (diff) | |
download | abc-ff1fb1757bfee4a8b98fd1d0717e2b2ff860a10b.tar.gz abc-ff1fb1757bfee4a8b98fd1d0717e2b2ff860a10b.tar.bz2 abc-ff1fb1757bfee4a8b98fd1d0717e2b2ff860a10b.zip |
Preprocessing for multi-output PLA tables.
-rw-r--r-- | src/base/io/ioReadPla.c | 124 | ||||
-rw-r--r-- | src/misc/util/abc_global.h | 1 | ||||
-rw-r--r-- | src/misc/util/utilTruth.h | 18 |
3 files changed, 143 insertions, 0 deletions
diff --git a/src/base/io/ioReadPla.c b/src/base/io/ioReadPla.c index 1bd88bd9..46a9169e 100644 --- a/src/base/io/ioReadPla.c +++ b/src/base/io/ioReadPla.c @@ -19,6 +19,7 @@ ***********************************************************************/ #include "ioAbc.h" +#include "misc/util/utilTruth.h" ABC_NAMESPACE_IMPL_START @@ -33,6 +34,128 @@ static Abc_Ntk_t * Io_ReadPlaNetwork( Extra_FileReader_t * p, int fZeros ); /// FUNCTION DEFINITIONS /// //////////////////////////////////////////////////////////////////////// +static inline Io_CubesEqual( word * c1, word * c2, int nWords ) +{ + +} + +/**Function************************************************************* + + Synopsis [] + + Description [] + + SideEffects [] + + SeeAlso [] + +***********************************************************************/ +word ** Io_ReadPlaCubeSetup( Vec_Str_t * vSop ) +{ + char * pSop = Vec_StrArray( vSop ), * pCube, Lit; + int nCubes = Abc_SopGetCubeNum( pSop ); + int nVars = Abc_SopGetVarNum( pSop ); + int nWords = Abc_Bit6WordNum( 2*nVars ), c, v; + word ** pCs = ABC_ALLOC( word *, nCubes ); + pCs[0] = ABC_CALLOC( word, nCubes * nWords ); + for ( c = 1; c < nCubes; c++ ) + pCs[c] = pCs[c-1] + nWords; + c = 0; + Abc_SopForEachCube( pSop, nVars, pCube ) + { + Abc_CubeForEachVar( pCube, Lit, v ) + if ( Lit == '0' ) + Abc_TtSetBit( pCs[c], Abc_Var2Lit(v,0) ); + else if ( Lit == '1' ) + Abc_TtSetBit( pCs[c], Abc_Var2Lit(v,1) ); + c++; + } + assert( c == nCubes ); + return pCs; +} +void Io_ReadPlaCubeSetdown( Vec_Str_t * vSop, word ** pCs, int nCubes, int nVars ) +{ + char Symbs[3] = {'-', '0', '1'}; + int c, v, Lit; + Vec_StrClear( vSop ); + for ( c = 0; c < nCubes; c++ ) + { + for ( v = 0; v < nVars && ((Lit = Abc_TtGetQua(pCs[c], v)), 1); v++ ) + { + assert( Lit < 3 ); + Vec_StrPush( vSop, Symbs[Lit] ); + } + Vec_StrPrintStr( vSop, " 1\n" ); + } + Vec_StrPush( vSop, 0 ); +} +void Io_ReadPlaCubePreprocess( Vec_Str_t * vSop, int iCover, int fVerbose ) +{ + word ** pCs = Io_ReadPlaCubeSetup( vSop ); + int nCubes = Abc_SopGetCubeNum( Vec_StrArray(vSop) ); + int nVars = Abc_SopGetVarNum( Vec_StrArray(vSop) ); + int nWords = Abc_Bit6WordNum( 2*nVars ), c, c1, c2; + Vec_Bit_t * vMarks = Vec_BitStart( nCubes ); + if ( fVerbose ) + printf( "Cover %5d : V =%5d C =%5d P =%9d ", iCover, nVars, nCubes, nCubes*nCubes/2 ); + // check identical + for ( c1 = 0; c1 < nCubes; c1++ ) + if ( !Vec_BitEntry(vMarks, c1) ) + for ( c2 = c1 + 1; c2 < nCubes; c2++ ) + if ( !Vec_BitEntry(vMarks, c2) ) + if ( Abc_TtEqual(pCs[c1], pCs[c2], nWords) ) + Vec_BitWriteEntry( vMarks, c2, 1 ); + // remove identical + for ( c1 = c = 0; c1 < nCubes; c1++ ) + if ( !Vec_BitEntry(vMarks, c1) ) + { + if ( nCubes == c1 ) + c++; + else + Abc_TtCopy( pCs[c++], pCs[c1], nWords, 0 ); + } + if ( fVerbose ) + printf( " Equal =%5d", nCubes - c ); + // check contained + nCubes = c; + Vec_BitFill( vMarks, nCubes, 0 ); + for ( c1 = 0; c1 < nCubes; c1++ ) + if ( !Vec_BitEntry(vMarks, c1) ) + for ( c2 = c1 + 1; c2 < nCubes; c2++ ) + if ( !Vec_BitEntry(vMarks, c2) ) + { + if ( Abc_TtImply(pCs[c1], pCs[c2], nWords) ) + Vec_BitWriteEntry( vMarks, c2, 1 ); + else if ( Abc_TtImply(pCs[c2], pCs[c1], nWords) ) + { + Vec_BitWriteEntry( vMarks, c1, 1 ); + break; + } + } + // remove contained + for ( c1 = c = 0; c1 < nCubes; c1++ ) + if ( !Vec_BitEntry(vMarks, c1) ) + { + if ( nCubes == c1 ) + c++; + else + Abc_TtCopy( pCs[c++], pCs[c1], nWords, 0 ); + } + if ( fVerbose ) + printf( " Contain =%5d", nCubes - c ); + nCubes = c; + // check distance-1 + + // translate + Io_ReadPlaCubeSetdown( vSop, pCs, nCubes, nVars ); + // finalize + if ( fVerbose ) + printf( "\n" ); + Vec_BitFree( vMarks ); + ABC_FREE( pCs[0] ); + ABC_FREE( pCs ); +} + /**Function************************************************************* Synopsis [Reads the network from a PLA file.] @@ -270,6 +393,7 @@ Abc_Ntk_t * Io_ReadPlaNetwork( Extra_FileReader_t * p, int fZeros ) continue; } Vec_StrPush( ppSops[i], 0 ); + Io_ReadPlaCubePreprocess( ppSops[i], i, 0 ); pNode->pData = Abc_SopRegister( (Mem_Flex_t *)pNtk->pManFunc, ppSops[i]->pArray ); Vec_StrFree( ppSops[i] ); } diff --git a/src/misc/util/abc_global.h b/src/misc/util/abc_global.h index 6e112bb8..ac7b2bf3 100644 --- a/src/misc/util/abc_global.h +++ b/src/misc/util/abc_global.h @@ -254,6 +254,7 @@ static inline int Abc_Base10Log( unsigned n ) { int r; if ( n < static inline int Abc_Base16Log( unsigned n ) { int r; if ( n < 2 ) return n; for ( r = 0, n--; n; n /= 16, r++ ) {}; return r; } static inline char * Abc_UtilStrsav( char * s ) { return s ? strcpy(ABC_ALLOC(char, strlen(s)+1), s) : NULL; } static inline int Abc_BitWordNum( int nBits ) { return (nBits>>5) + ((nBits&31) > 0); } +static inline int Abc_Bit6WordNum( int nBits ) { return (nBits>>6) + ((nBits&63) > 0); } static inline int Abc_TruthWordNum( int nVars ) { return nVars <= 5 ? 1 : (1 << (nVars - 5)); } static inline int Abc_Truth6WordNum( int nVars ) { return nVars <= 6 ? 1 : (1 << (nVars - 6)); } static inline int Abc_InfoHasBit( unsigned * p, int i ) { return (p[(i)>>5] & (1<<((i) & 31))) > 0; } diff --git a/src/misc/util/utilTruth.h b/src/misc/util/utilTruth.h index 4d0bb9b6..fab5e936 100644 --- a/src/misc/util/utilTruth.h +++ b/src/misc/util/utilTruth.h @@ -150,11 +150,21 @@ static inline int Abc_TtGetBit( word * p, int i ) { return (int)(p[i static inline void Abc_TtSetBit( word * p, int i ) { p[i>>6] |= (((word)1)<<(i & 63)); } static inline void Abc_TtXorBit( word * p, int i ) { p[i>>6] ^= (((word)1)<<(i & 63)); } +// read/write k-th digit d of a quaternary number: +static inline int Abc_TtGetQua( word * p, int k ) { return (int)(p[k>>5] >> ((k<<1) & 63)) & 3; } +static inline void Abc_TtSetQua( word * p, int k, int d ) { p[k>>5] |= (((word)d)<<((k<<1) & 63)); } +static inline void Abc_TtXorQua( word * p, int k, int d ) { p[k>>5] ^= (((word)d)<<((k<<1) & 63)); } + // read/write k-th digit d of a hexadecimal number: static inline int Abc_TtGetHex( word * p, int k ) { return (int)(p[k>>4] >> ((k<<2) & 63)) & 15; } static inline void Abc_TtSetHex( word * p, int k, int d ) { p[k>>4] |= (((word)d)<<((k<<2) & 63)); } static inline void Abc_TtXorHex( word * p, int k, int d ) { p[k>>4] ^= (((word)d)<<((k<<2) & 63)); } +// read/write k-th digit d of a 256-base number: +static inline int Abc_TtGet256( word * p, int k ) { return (int)(p[k>>3] >> ((k<<3) & 63)) & 255; } +static inline void Abc_TtSet256( word * p, int k, int d ) { p[k>>3] |= (((word)d)<<((k<<3) & 63)); } +static inline void Abc_TtXor256( word * p, int k, int d ) { p[k>>3] ^= (((word)d)<<((k<<3) & 63)); } + /**Function************************************************************* Synopsis [] @@ -274,6 +284,14 @@ static inline int Abc_TtEqual( word * pIn1, word * pIn2, int nWords ) return 0; return 1; } +static inline int Abc_TtImply( word * pIn1, word * pIn2, int nWords ) +{ + int w; + for ( w = 0; w < nWords; w++ ) + if ( (pIn1[w] & pIn2[w]) != pIn1[w] ) + return 0; + return 1; +} static inline int Abc_TtCompare( word * pIn1, word * pIn2, int nWords ) { int w; |