mirror of https://github.com/YosysHQ/abc.git
Adding new NPN code developed by XueGong Zhou at Fudan University.
This commit is contained in:
parent
a6d489e7d8
commit
9ff7134f24
|
|
@ -6674,6 +6674,7 @@ usage:
|
|||
Abc_Print( -2, "\t 5: new fast hybrid semi-canonical form\n" );
|
||||
Abc_Print( -2, "\t 6: new phase canonical form\n" );
|
||||
Abc_Print( -2, "\t 7: new hierarchical matching\n" );
|
||||
Abc_Print( -2, "\t 8: hierarchical matching by XueGong Zhou at Fudan University, Shanghai\n" );
|
||||
Abc_Print( -2, "\t-N <num> : the number of support variables (binary files only) [default = unused]\n" );
|
||||
Abc_Print( -2, "\t-d : toggle dumping resulting functions into a file [default = %s]\n", fDumpRes? "yes": "no" );
|
||||
Abc_Print( -2, "\t-b : toggle dumping in binary format [default = %s]\n", fBinary? "yes": "no" );
|
||||
|
|
|
|||
|
|
@ -200,6 +200,8 @@ void Abc_TruthNpnPerform( Abc_TtStore_t * p, int NpnType, int fVerbose )
|
|||
pAlgoName = "new phase flipping ";
|
||||
else if ( NpnType == 7 )
|
||||
pAlgoName = "new hier. matching ";
|
||||
else if ( NpnType == 8 )
|
||||
pAlgoName = "new adap. matching ";
|
||||
|
||||
assert( p->nVars <= 16 );
|
||||
if ( pAlgoName )
|
||||
|
|
@ -293,13 +295,12 @@ void Abc_TruthNpnPerform( Abc_TtStore_t * p, int NpnType, int fVerbose )
|
|||
}
|
||||
else if ( NpnType == 7 )
|
||||
{
|
||||
extern unsigned Abc_TtCanonicizeHie( Abc_TtMan_t * p, word * pTruth, int nVars, char * pCanonPerm, int fExact );
|
||||
extern Abc_TtMan_t * Abc_TtManStart( int nVars );
|
||||
extern void Abc_TtManStop( Abc_TtMan_t * p );
|
||||
extern int Abc_TtManNumClasses( Abc_TtMan_t * p );
|
||||
extern unsigned Abc_TtCanonicizeHie(Abc_TtHieMan_t * p, word * pTruth, int nVars, char * pCanonPerm, int fExact );
|
||||
extern Abc_TtHieMan_t * Abc_TtHieManStart( int nVars, int nLevels );
|
||||
extern void Abc_TtHieManStop(Abc_TtHieMan_t * p );
|
||||
|
||||
int fExact = 0;
|
||||
Abc_TtMan_t * pMan = Abc_TtManStart( p->nVars );
|
||||
Abc_TtHieMan_t * pMan = Abc_TtHieManStart( p->nVars, 5 );
|
||||
for ( i = 0; i < p->nFuncs; i++ )
|
||||
{
|
||||
if ( fVerbose )
|
||||
|
|
@ -310,7 +311,27 @@ void Abc_TruthNpnPerform( Abc_TtStore_t * p, int NpnType, int fVerbose )
|
|||
printf( "\n" );
|
||||
}
|
||||
// nClasses = Abc_TtManNumClasses( pMan );
|
||||
Abc_TtManStop( pMan );
|
||||
Abc_TtHieManStop( pMan );
|
||||
}
|
||||
else if ( NpnType == 8 )
|
||||
{
|
||||
typedef unsigned(*TtCanonicizeFunc)(Abc_TtHieMan_t * p, word * pTruth, int nVars, char * pCanonPerm, int flag);
|
||||
unsigned Abc_TtCanonicizeWrap(TtCanonicizeFunc func, Abc_TtHieMan_t * p, word * pTruth, int nVars, char * pCanonPerm, int flag);
|
||||
unsigned Abc_TtCanonicizeAda(Abc_TtHieMan_t * p, word * pTruth, int nVars, char * pCanonPerm, int iThres);
|
||||
Abc_TtHieMan_t * Abc_TtHieManStart(int nVars, int nLevels);
|
||||
void Abc_TtHieManStop(Abc_TtHieMan_t * p);
|
||||
|
||||
int fHigh = 1, iEnumThres = 25;
|
||||
Abc_TtHieMan_t * pMan = Abc_TtHieManStart(p->nVars, 5);
|
||||
for ( i = 0; i < p->nFuncs; i++ )
|
||||
{
|
||||
if ( fVerbose )
|
||||
printf( "%7d : ", i );
|
||||
uCanonPhase = Abc_TtCanonicizeWrap(Abc_TtCanonicizeAda, pMan, p->pFuncs[i], p->nVars, pCanonPerm, fHigh*100 + iEnumThres);
|
||||
if ( fVerbose )
|
||||
Extra_PrintHex( stdout, (unsigned *)p->pFuncs[i], p->nVars ), Abc_TruthNpnPrint(pCanonPerm, uCanonPhase, p->nVars), printf( "\n" );
|
||||
}
|
||||
Abc_TtHieManStop(pMan);
|
||||
}
|
||||
else assert( 0 );
|
||||
clk = Abc_Clock() - clk;
|
||||
|
|
@ -375,7 +396,7 @@ int Abc_NpnTest( char * pFileName, int NpnType, int nVarNum, int fDumpRes, int f
|
|||
{
|
||||
if ( fVerbose )
|
||||
printf( "Using truth tables from file \"%s\"...\n", pFileName );
|
||||
if ( NpnType >= 0 && NpnType <= 7 )
|
||||
if ( NpnType >= 0 && NpnType <= 8 )
|
||||
Abc_TruthNpnTest( pFileName, NpnType, nVarNum, fDumpRes, fBinary, fVerbose );
|
||||
else
|
||||
printf( "Unknown canonical form value (%d).\n", NpnType );
|
||||
|
|
|
|||
|
|
@ -59,7 +59,7 @@ typedef enum {
|
|||
} Dau_DsdType_t;
|
||||
|
||||
typedef struct Dss_Man_t_ Dss_Man_t;
|
||||
typedef struct Abc_TtMan_t_ Abc_TtMan_t;
|
||||
typedef struct Abc_TtHieMan_t_ Abc_TtHieMan_t;
|
||||
|
||||
////////////////////////////////////////////////////////////////////////
|
||||
/// MACRO DEFINITIONS ///
|
||||
|
|
|
|||
File diff suppressed because it is too large
Load Diff
Loading…
Reference in New Issue