diff options
author | Alan Mishchenko <alanmi@berkeley.edu> | 2014-02-16 19:49:10 -0800 |
---|---|---|
committer | Alan Mishchenko <alanmi@berkeley.edu> | 2014-02-16 19:49:10 -0800 |
commit | 2140c1298cee7f7ae7310bf208374447c5a0321e (patch) | |
tree | 5c8a26045463ac176828b0a8f6d4b32883dafb35 /src | |
parent | 46532e6c2f3d0dabdb03daad5c55f6f732311797 (diff) | |
download | abc-2140c1298cee7f7ae7310bf208374447c5a0321e.tar.gz abc-2140c1298cee7f7ae7310bf208374447c5a0321e.tar.bz2 abc-2140c1298cee7f7ae7310bf208374447c5a0321e.zip |
Removing unused LMS code.
Diffstat (limited to 'src')
-rw-r--r-- | src/base/abc/abc.h | 23 | ||||
-rw-r--r-- | src/base/abci/abc.c | 909 | ||||
-rw-r--r-- | src/base/abci/abcIf.c | 10 | ||||
-rw-r--r-- | src/base/abci/abcRec.c | 3110 | ||||
-rw-r--r-- | src/base/abci/abcRec2.c | 2442 | ||||
-rw-r--r-- | src/base/abci/module.make | 2 | ||||
-rw-r--r-- | src/map/if/if.h | 12 | ||||
-rw-r--r-- | src/map/if/ifMap.c | 21 |
8 files changed, 6 insertions, 6523 deletions
diff --git a/src/base/abc/abc.h b/src/base/abc/abc.h index 0e9199f9..8d72cd5e 100644 --- a/src/base/abc/abc.h +++ b/src/base/abc/abc.h @@ -792,29 +792,6 @@ extern ABC_DLL void Abc_NtkShow6VarFunc( char * pF0, char * pF1 ); /*=== abcProve.c ==========================================================*/ extern ABC_DLL int Abc_NtkMiterProve( Abc_Ntk_t ** ppNtk, void * pParams ); extern ABC_DLL int Abc_NtkIvyProve( Abc_Ntk_t ** ppNtk, void * pPars ); -/*=== abcRec.c ==========================================================*/ -extern ABC_DLL void Abc_NtkRecStart( Abc_Ntk_t * pNtk, int nVars, int nCuts, int fTrim ); -extern ABC_DLL void Abc_NtkRecStop(); -extern ABC_DLL void Abc_NtkRecAdd( Abc_Ntk_t * pNtk, int fUseSOPB ); -extern ABC_DLL void Abc_NtkRecPs(int fPrintLib); -extern ABC_DLL void Abc_NtkRecFilter(int nLimit); -extern ABC_DLL void Abc_NtkRecLibMerge(Abc_Ntk_t * pNtk); -extern ABC_DLL Abc_Ntk_t * Abc_NtkRecUse(); -extern ABC_DLL int Abc_NtkRecIsRunning(); -extern ABC_DLL int Abc_NtkRecIsInTrimMode(); -extern ABC_DLL int Abc_NtkRecVarNum(); -extern ABC_DLL Vec_Int_t * Abc_NtkRecMemory(); -extern ABC_DLL int Abc_NtkRecStrashNode( Abc_Ntk_t * pNtkNew, Abc_Obj_t * pObj, unsigned * pTruth, int nVars ); -/*=== abcRec2.c ==========================================================*/ -extern ABC_DLL void Abc_NtkRecStart2( Gia_Man_t * p, int nVars, int nCuts, int fTrim ); -extern ABC_DLL void Abc_NtkRecStop2(); -extern ABC_DLL void Abc_NtkRecAdd2( Abc_Ntk_t * pNtk, int fUseSOPB ); -extern ABC_DLL void Abc_NtkRecPs2(int fPrintLib); -extern ABC_DLL Gia_Man_t * Abc_NtkRecGetGia(); -extern ABC_DLL void Abc_NtkRecLibMerge2(Gia_Man_t * pGia); -extern ABC_DLL int Abc_NtkRecIsRunning2(); -extern ABC_DLL int Abc_NtkRecIsInTrimMode2(); -extern ABC_DLL void Abc_NtkRecFilter2(int nLimit); /*=== abcRec3.c ==========================================================*/ extern ABC_DLL void Abc_NtkRecStart3( Gia_Man_t * p, int nVars, int nCuts, int fFuncOnly, int fVerbose ); extern ABC_DLL void Abc_NtkRecStop3(); diff --git a/src/base/abci/abc.c b/src/base/abci/abc.c index 08104383..b170bfc4 100644 --- a/src/base/abci/abc.c +++ b/src/base/abci/abc.c @@ -213,22 +213,6 @@ static int Abc_CommandFraigClean ( Abc_Frame_t * pAbc, int argc, cha static int Abc_CommandFraigSweep ( Abc_Frame_t * pAbc, int argc, char ** argv ); static int Abc_CommandFraigDress ( Abc_Frame_t * pAbc, int argc, char ** argv ); -static int Abc_CommandRecStart ( Abc_Frame_t * pAbc, int argc, char ** argv ); -static int Abc_CommandRecStop ( Abc_Frame_t * pAbc, int argc, char ** argv ); -static int Abc_CommandRecPs ( Abc_Frame_t * pAbc, int argc, char ** argv ); -static int Abc_CommandRecAdd ( Abc_Frame_t * pAbc, int argc, char ** argv ); -static int Abc_CommandRecUse ( Abc_Frame_t * pAbc, int argc, char ** argv ); -static int Abc_CommandRecFilter ( Abc_Frame_t * pAbc, int argc, char ** argv ); -static int Abc_CommandRecMerge ( Abc_Frame_t * pAbc, int argc, char ** argv ); - -static int Abc_CommandRecStart2 ( Abc_Frame_t * pAbc, int argc, char ** argv ); -static int Abc_CommandRecStop2 ( Abc_Frame_t * pAbc, int argc, char ** argv ); -static int Abc_CommandRecPs2 ( Abc_Frame_t * pAbc, int argc, char ** argv ); -static int Abc_CommandRecAdd2 ( Abc_Frame_t * pAbc, int argc, char ** argv ); -static int Abc_CommandRecDump2 ( Abc_Frame_t * pAbc, int argc, char ** argv ); -static int Abc_CommandRecMerge2 ( Abc_Frame_t * pAbc, int argc, char ** argv ); -static int Abc_CommandRecFilter2 ( Abc_Frame_t * pAbc, int argc, char ** argv ); - static int Abc_CommandRecStart3 ( Abc_Frame_t * pAbc, int argc, char ** argv ); static int Abc_CommandRecStop3 ( Abc_Frame_t * pAbc, int argc, char ** argv ); static int Abc_CommandRecPs3 ( Abc_Frame_t * pAbc, int argc, char ** argv ); @@ -782,22 +766,6 @@ void Abc_Init( Abc_Frame_t * pAbc ) Cmd_CommandAdd( pAbc, "Fraiging", "fraig_sweep", Abc_CommandFraigSweep, 1 ); Cmd_CommandAdd( pAbc, "Fraiging", "dress", Abc_CommandFraigDress, 1 ); - Cmd_CommandAdd( pAbc, "Choicing", "rec_start", Abc_CommandRecStart, 0 ); - Cmd_CommandAdd( pAbc, "Choicing", "rec_stop", Abc_CommandRecStop, 0 ); - Cmd_CommandAdd( pAbc, "Choicing", "rec_add", Abc_CommandRecAdd, 0 ); - Cmd_CommandAdd( pAbc, "Choicing", "rec_ps", Abc_CommandRecPs, 0 ); - Cmd_CommandAdd( pAbc, "Choicing", "rec_use", Abc_CommandRecUse, 1 ); - Cmd_CommandAdd( pAbc, "Choicing", "rec_filter", Abc_CommandRecFilter, 0 ); - Cmd_CommandAdd( pAbc, "Choicing", "rec_merge", Abc_CommandRecMerge, 0 ); - - Cmd_CommandAdd( pAbc, "Choicing", "rec_start2", Abc_CommandRecStart2, 0 ); - Cmd_CommandAdd( pAbc, "Choicing", "rec_stop2", Abc_CommandRecStop2, 0 ); - Cmd_CommandAdd( pAbc, "Choicing", "rec_ps2", Abc_CommandRecPs2, 0 ); - Cmd_CommandAdd( pAbc, "Choicing", "rec_add2", Abc_CommandRecAdd2, 0 ); - Cmd_CommandAdd( pAbc, "Choicing", "rec_dump2", Abc_CommandRecDump2, 1 ); - Cmd_CommandAdd( pAbc, "Choicing", "rec_filter2", Abc_CommandRecFilter2, 0 ); - Cmd_CommandAdd( pAbc, "Choicing", "rec_merge2", Abc_CommandRecMerge2, 0 ); - Cmd_CommandAdd( pAbc, "Choicing", "rec_start3", Abc_CommandRecStart3, 0 ); Cmd_CommandAdd( pAbc, "Choicing", "rec_stop3", Abc_CommandRecStop3, 0 ); Cmd_CommandAdd( pAbc, "Choicing", "rec_ps3", Abc_CommandRecPs3, 0 ); @@ -1053,10 +1021,6 @@ void Abc_End( Abc_Frame_t * pAbc ) Gia_ManStop( Abc_FrameGetGlobalFrame()->pGia ); if ( Abc_FrameGetGlobalFrame()->pGia2 ) Gia_ManStop( Abc_FrameGetGlobalFrame()->pGia2 ); - if ( Abc_NtkRecIsRunning() ) - Abc_NtkRecStop(); - if ( Abc_NtkRecIsRunning2() ) - Abc_NtkRecStop2(); if ( Abc_NtkRecIsRunning3() ) Abc_NtkRecStop3(); } @@ -13345,856 +13309,6 @@ usage: return 1; } - -/**Function************************************************************* - - Synopsis [] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -int Abc_CommandRecStart( Abc_Frame_t * pAbc, int argc, char ** argv ) -{ - Abc_Ntk_t * pNtk = Abc_FrameReadNtk(pAbc); - int c; - int nVars; - int nCuts; - int fTrim; - - pNtk = Abc_FrameReadNtk(pAbc); - // set defaults - nVars = 6; - nCuts = 32; - fTrim = 0; - Extra_UtilGetoptReset(); - while ( ( c = Extra_UtilGetopt( argc, argv, "KCth" ) ) != EOF ) - { - switch ( c ) - { - case 'K': - if ( globalUtilOptind >= argc ) - { - Abc_Print( -1, "Command line switch \"-K\" should be followed by an integer.\n" ); - goto usage; - } - nVars = atoi(argv[globalUtilOptind]); - globalUtilOptind++; - if ( nVars < 1 ) - goto usage; - break; - case 'C': - if ( globalUtilOptind >= argc ) - { - Abc_Print( -1, "Command line switch \"-C\" should be followed by an integer.\n" ); - goto usage; - } - nCuts = atoi(argv[globalUtilOptind]); - globalUtilOptind++; - if ( nCuts < 1 ) - goto usage; - break; - case 't': - fTrim ^= 1; - break; - case 'h': - goto usage; - default: - goto usage; - } - } - if ( !(nVars >= 3 && nVars <= 16) ) - { - Abc_Print( -1, "The range of allowed values is 3 <= K <= 16.\n" ); - return 0; - } - if ( Abc_NtkRecIsRunning() ) - { - Abc_Print( -1, "The AIG subgraph recording is already started.\n" ); - return 0; - } - if ( pNtk && !Abc_NtkIsStrash(pNtk) ) - { - Abc_Print( -1, "This command works only for AIGs; run strashing (\"st\").\n" ); - return 0; - } - Abc_NtkRecStart( pNtk, nVars, nCuts, fTrim ); - return 0; - -usage: - Abc_Print( -2, "usage: rec_start [-K num] [-C num] [-th]\n" ); - Abc_Print( -2, "\t starts recording AIG subgraphs (should be called for\n" ); - Abc_Print( -2, "\t an empty network or after reading in a previous record)\n" ); - Abc_Print( -2, "\t-K num : the largest number of inputs [default = %d]\n", nVars ); - Abc_Print( -2, "\t-C num : the max number of cuts used at a node (0 < num < 2^12) [default = %d]\n", nCuts ); - Abc_Print( -2, "\t-t : toggles the use of trimming [default = %s]\n", fTrim? "yes": "no" ); - Abc_Print( -2, "\t-h : print the command usage\n"); - return 1; -} - -/**Function************************************************************* - - Synopsis [] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -int Abc_CommandRecStop( Abc_Frame_t * pAbc, int argc, char ** argv ) -{ -// Abc_Ntk_t * pNtk = Abc_FrameReadNtk(pAbc); - int c; - // set defaults - Extra_UtilGetoptReset(); - while ( ( c = Extra_UtilGetopt( argc, argv, "dh" ) ) != EOF ) - { - switch ( c ) - { - case 'h': - goto usage; - default: - goto usage; - } - } - if ( !Abc_NtkRecIsRunning() ) - { - Abc_Print( -1, "This command works only after calling \"rec_start\".\n" ); - return 0; - } - Abc_NtkRecStop(); - return 0; - -usage: - Abc_Print( -2, "usage: rec_stop [-h]\n" ); - Abc_Print( -2, "\t cleans the internal storage for AIG subgraphs\n" ); - Abc_Print( -2, "\t-h : print the command usage\n"); - return 1; -} - -/**Function************************************************************* - - Synopsis [] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -int Abc_CommandRecPs( Abc_Frame_t * pAbc, int argc, char ** argv ) -{ -// Abc_Ntk_t * pNtk = Abc_FrameReadNtk(pAbc); - int c, fPrintLib = 0; - // set defaults - Extra_UtilGetoptReset(); - while ( ( c = Extra_UtilGetopt( argc, argv, "ph" ) ) != EOF ) - { - switch ( c ) - { - case 'p': - fPrintLib ^= 1; - break; - case 'h': - goto usage; - default: - goto usage; - } - } - if ( !Abc_NtkRecIsRunning() ) - { - Abc_Print( -1, "This command works for AIGs only after calling \"rec_start\".\n" ); - return 0; - } - Abc_NtkRecPs(fPrintLib); - return 0; - -usage: - Abc_Print( -2, "usage: rec_ps [-h]\n" ); - Abc_Print( -2, "\t prints statistics about the recorded AIG subgraphs\n" ); - Abc_Print( -2, "\t-h : print the command usage\n"); - return 1; -} - -/**Function************************************************************* - - Synopsis [] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -int Abc_CommandRecAdd( Abc_Frame_t * pAbc, int argc, char ** argv ) -{ - Abc_Ntk_t * pNtk = Abc_FrameReadNtk(pAbc); - int c; - int fUseSOPB = 0; - // set defaults - Extra_UtilGetoptReset(); - while ( ( c = Extra_UtilGetopt( argc, argv, "gh" ) ) != EOF ) - { - switch ( c ) - { - case 'g': - fUseSOPB = 1; - break; - case 'h': - goto usage; - default: - goto usage; - } - } - if ( !Abc_NtkIsStrash(pNtk) ) - { - Abc_Print( -1, "This command works for AIGs.\n" ); - return 0; - } - if ( !Abc_NtkRecIsRunning() ) - { - Abc_Print( -1, "This command works for AIGs after calling \"rec_start\".\n" ); - return 0; - } - Abc_NtkRecAdd( pNtk, fUseSOPB); - return 0; - -usage: - Abc_Print( -2, "usage: rec_add [-h]\n" ); - Abc_Print( -2, "\t adds subgraphs from the current network to the set\n" ); - Abc_Print( -2, "\t-h : print the command usage\n"); - return 1; -} - -/**Function************************************************************* - - Synopsis [] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -int Abc_CommandRecUse( Abc_Frame_t * pAbc, int argc, char ** argv ) -{ - Abc_Ntk_t * pNtk, * pNtkRes; - int c; - - pNtk = Abc_FrameReadNtk(pAbc); - // set defaults - Extra_UtilGetoptReset(); - while ( ( c = Extra_UtilGetopt( argc, argv, "dh" ) ) != EOF ) - { - switch ( c ) - { - case 'h': - goto usage; - default: - goto usage; - } - } - if ( !Abc_NtkRecIsRunning() ) - { - Abc_Print( -1, "This command works for AIGs only after calling \"rec_start\".\n" ); - return 0; - } - // get the new network - pNtkRes = Abc_NtkRecUse(); - if ( pNtkRes == NULL ) - { - Abc_Print( -1, "Transforming internal AIG subgraphs into an AIG with choices has failed.\n" ); - return 1; - } - // replace the current network - Abc_FrameReplaceCurrentNetwork( pAbc, pNtkRes ); - return 0; - -usage: - Abc_Print( -2, "usage: rec_use [-h]\n" ); - Abc_Print( -2, "\t transforms internal storage into an AIG with choices\n" ); - Abc_Print( -2, "\t-h : print the command usage\n"); - return 1; -} - -/**Function************************************************************* - - Synopsis [] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -int Abc_CommandRecFilter( Abc_Frame_t * pAbc, int argc, char ** argv ) -{ -// Abc_Ntk_t * pNtk = Abc_FrameReadNtk(pAbc); - int c, nLimit = 0; - // set defaults - Extra_UtilGetoptReset(); - while ( ( c = Extra_UtilGetopt( argc, argv, "Fh" ) ) != EOF ) - { - switch ( c ) - { - case 'F': - if ( globalUtilOptind >= argc ) - { - Abc_Print( -1, "Command line switch \"-F\" should be followed by an integer.\n" ); - goto usage; - } - nLimit = atoi(argv[globalUtilOptind]); - globalUtilOptind++; - if ( nLimit < 0 ) - goto usage; - break; - case 'h': - goto usage; - default: - goto usage; - } - } - if ( !Abc_NtkRecIsRunning() ) - { - Abc_Print( -1, "This command works for AIGs only after calling \"rec_start\".\n" ); - return 0; - } - if (!Abc_NtkRecIsInTrimMode()) - Abc_Print( 0, "This command works fine only in trim mode. Please call \"rec_start -t\" first.\n" ); - - Abc_NtkRecFilter(nLimit); - return 0; - -usage: - Abc_Print( -2, "usage: rec_filter [-h]\n" ); - Abc_Print( -2, "\t filter the library of the recorder\n" ); - Abc_Print( -2, "\t-F num : the limit number of function class [default = %d]\n", nLimit ); - Abc_Print( -2, "\t-h : print the command usage\n"); - return 1; -} - -/**Function************************************************************* - - Synopsis [] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -int Abc_CommandRecMerge( Abc_Frame_t * pAbc, int argc, char ** argv ) -{ - Abc_Ntk_t * pNtk; - int c; - - pNtk = Abc_FrameReadNtk(pAbc); - // set defaults - Extra_UtilGetoptReset(); - while ( ( c = Extra_UtilGetopt( argc, argv, "dh" ) ) != EOF ) - { - switch ( c ) - { - case 'h': - goto usage; - default: - goto usage; - } - } - if ( !Abc_NtkRecIsRunning() ) - { - Abc_Print( -1, "This command works for AIGs only after calling \"rec_start\".\n" ); - return 0; - } - Abc_NtkRecLibMerge(pNtk); - return 0; - -usage: - Abc_Print( -2, "usage: rec_merge [-h]\n" ); - Abc_Print( -2, "\t merge libraries\n" ); - Abc_Print( -2, "\t-h : print the command usage\n"); - return 1; -} - - -/**Function************************************************************* - - Synopsis [] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -int Abc_CommandRecStart2( Abc_Frame_t * pAbc, int argc, char ** argv ) -{ - //Abc_Ntk_t * pNtk = Abc_FrameReadNtk(pAbc); - char * FileName, * pTemp; - char ** pArgvNew; - int nArgcNew; - FILE * pFile; - Gia_Man_t * pGia = NULL; - int c; - int nVars; - int nCuts; - int fTrim; - - //pNtk = Abc_FrameReadNtk(pAbc); - // set defaults - nVars = 6; - nCuts = 32; - fTrim = 0; - Extra_UtilGetoptReset(); - while ( ( c = Extra_UtilGetopt( argc, argv, "KCth" ) ) != EOF ) - { - switch ( c ) - { - case 'K': - if ( globalUtilOptind >= argc ) - { - Abc_Print( -1, "Command line switch \"-K\" should be followed by an integer.\n" ); - goto usage; - } - nVars = atoi(argv[globalUtilOptind]); - globalUtilOptind++; - if ( nVars < 1 ) - goto usage; - break; - case 'C': - if ( globalUtilOptind >= argc ) - { - Abc_Print( -1, "Command line switch \"-C\" should be followed by an integer.\n" ); - goto usage; - } - nCuts = atoi(argv[globalUtilOptind]); - globalUtilOptind++; - if ( nCuts < 1 ) - goto usage; - break; - case 't': - fTrim ^= 1; - break; - case 'h': - goto usage; - default: - goto usage; - } - } - if ( !(nVars >= 3 && nVars <= 16) ) - { - Abc_Print( -1, "The range of allowed values is 3 <= K <= 16.\n" ); - return 0; - } - if ( Abc_NtkRecIsRunning() ) - { - Abc_Print( -1, "The AIG subgraph recording is already started.\n" ); - return 0; - } -// if ( pNtk && !Abc_NtkIsStrash(pNtk) ) -// { -// Abc_Print( -1, "This command works only for AIGs; run strashing (\"st\").\n" ); -// return 0; -// } - pArgvNew = argv + globalUtilOptind; - nArgcNew = argc - globalUtilOptind; - if ( nArgcNew != 1 ) - Abc_Print( 1, "File name is not given on the command line. Start a new record.\n" ); - else - { - // get the input file name - FileName = pArgvNew[0]; - // fix the wrong symbol - for ( pTemp = FileName; *pTemp; pTemp++ ) - if ( *pTemp == '>' ) - *pTemp = '\\'; - if ( (pFile = fopen( FileName, "r" )) == NULL ) - { - Abc_Print( -1, "Cannot open input file \"%s\". ", FileName ); - if ( (FileName = Extra_FileGetSimilarName( FileName, ".aig", NULL, NULL, NULL, NULL )) ) - Abc_Print( 1, "Did you mean \"%s\"?", FileName ); - Abc_Print( 1, "\n" ); - return 1; - } - fclose( pFile ); - pGia = Gia_AigerRead( FileName, 1, 0 ); - if ( pGia == NULL ) - { - Abc_Print( -1, "Reading AIGER has failed.\n" ); - return 0; - } - } - Abc_NtkRecStart2( pGia, nVars, nCuts, fTrim ); - return 0; - -usage: - Abc_Print( -2, "usage: rec_start2 [-K num] [-C num] [-th]\n" ); - Abc_Print( -2, "\t starts recording AIG subgraphs (should be called for\n" ); - Abc_Print( -2, "\t an empty network or after reading in a previous record)\n" ); - Abc_Print( -2, "\t-K num : the largest number of inputs [default = %d]\n", nVars ); - Abc_Print( -2, "\t-C num : the max number of cuts used at a node (0 < num < 2^12) [default = %d]\n", nCuts ); - Abc_Print( -2, "\t-t : toggles the use of trimming [default = %s]\n", fTrim? "yes": "no" ); - Abc_Print( -2, "\t-h : print the command usage\n"); - return 1; -} - - -/**Function************************************************************* - - Synopsis [] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -int Abc_CommandRecStop2( Abc_Frame_t * pAbc, int argc, char ** argv ) -{ -// Abc_Ntk_t * pNtk = Abc_FrameReadNtk(pAbc); - int c; - // set defaults - Extra_UtilGetoptReset(); - while ( ( c = Extra_UtilGetopt( argc, argv, "dh" ) ) != EOF ) - { - switch ( c ) - { - case 'h': - goto usage; - default: - goto usage; - } - } - if ( !Abc_NtkRecIsRunning2() ) - { - Abc_Print( -1, "This command works only after calling \"rec_start2\".\n" ); - return 0; - } - Abc_NtkRecStop2(); - return 0; - -usage: - Abc_Print( -2, "usage: rec_stop2 [-h]\n" ); - Abc_Print( -2, "\t cleans the internal storage for AIG subgraphs\n" ); - Abc_Print( -2, "\t-h : print the command usage\n"); - return 1; -} - - -/**Function************************************************************* - - Synopsis [] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -int Abc_CommandRecPs2( Abc_Frame_t * pAbc, int argc, char ** argv ) -{ -// Abc_Ntk_t * pNtk = Abc_FrameReadNtk(pAbc); - int c, fPrintLib = 0; - // set defaults - Extra_UtilGetoptReset(); - while ( ( c = Extra_UtilGetopt( argc, argv, "ph" ) ) != EOF ) - { - switch ( c ) - { - case 'p': - fPrintLib ^= 1; - break; - case 'h': - goto usage; - default: - goto usage; - } - } - if ( !Abc_NtkRecIsRunning2() ) - { - Abc_Print( -1, "This command works for AIGs only after calling \"rec_start2\".\n" ); - return 0; - } - Abc_NtkRecPs2(fPrintLib); - return 0; - -usage: - Abc_Print( -2, "usage: rec_ps2 [-h]\n" ); - Abc_Print( -2, "\t prints statistics about the recorded AIG subgraphs\n" ); - Abc_Print( -2, "\t-h : print the command usage\n"); - return 1; -} - - -/**Function************************************************************* - - Synopsis [] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -int Abc_CommandRecAdd2( Abc_Frame_t * pAbc, int argc, char ** argv ) -{ - Abc_Ntk_t * pNtk = Abc_FrameReadNtk(pAbc); - int c; - int fUseSOPB = 0; - // set defaults - Extra_UtilGetoptReset(); - while ( ( c = Extra_UtilGetopt( argc, argv, "gh" ) ) != EOF ) - { - switch ( c ) - { - case 'g': - fUseSOPB = 1; - break; - case 'h': - goto usage; - default: - goto usage; - } - } - if ( !Abc_NtkIsStrash(pNtk) ) - { - Abc_Print( -1, "This command works for AIGs.\n" ); - return 0; - } - if ( !Abc_NtkRecIsRunning2() ) - { - Abc_Print( -1, "This command works for AIGs after calling \"rec_start2\".\n" ); - return 0; - } - Abc_NtkRecAdd2( pNtk, fUseSOPB); - return 0; - -usage: - Abc_Print( -2, "usage: rec_add2 [-h]\n" ); - Abc_Print( -2, "\t adds subgraphs from the current network to the set\n" ); - Abc_Print( -2, "\t-h : print the command usage\n"); - return 1; -} - - -/**Function************************************************************* - - Synopsis [] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -int Abc_CommandRecDump2( Abc_Frame_t * pAbc, int argc, char ** argv ) -{ - //Abc_Ntk_t * pNtk = Abc_FrameReadNtk(pAbc); - char * FileName; - char ** pArgvNew; - int nArgcNew; - Gia_Man_t * pGia; - int c; - - //pNtk = Abc_FrameReadNtk(pAbc); - // set defaults - Extra_UtilGetoptReset(); - while ( ( c = Extra_UtilGetopt( argc, argv, "h" ) ) != EOF ) - { - switch ( c ) - { - case 'h': - goto usage; - default: - goto usage; - } - } - - if ( !Abc_NtkRecIsRunning2() ) - { - Abc_Print( -1, "The AIG subgraph recording is not started.\n" ); - return 1; - } - pGia = Abc_NtkRecGetGia(); - pArgvNew = argv + globalUtilOptind; - nArgcNew = argc - globalUtilOptind; - if ( nArgcNew != 1 ) - { - Abc_Print( -1, "File name is not given on the command line.\n" ); - return 1; - } - else if(Gia_ManPoNum(pGia) == 0) - { - Abc_Print( 0, "No structure in the library.\n" ); - return 1; - } - else - { - // get the input file name - FileName = pArgvNew[0]; - Gia_AigerWrite( pGia, FileName, 0, 0 ); - } - return 0; - -usage: - Abc_Print( -2, "usage: rec_dump2 [-h] <file>\n" ); - Abc_Print( -2, "\t-h : print the command usage\n"); - return 1; -} - -/**Function************************************************************* - - Synopsis [] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -int Abc_CommandRecFilter2( Abc_Frame_t * pAbc, int argc, char ** argv ) -{ -// Abc_Ntk_t * pNtk = Abc_FrameReadNtk(pAbc); - int c, nLimit = 0; - // set defaults - Extra_UtilGetoptReset(); - while ( ( c = Extra_UtilGetopt( argc, argv, "Fh" ) ) != EOF ) - { - switch ( c ) - { - case 'F': - if ( globalUtilOptind >= argc ) - { - Abc_Print( -1, "Command line switch \"-F\" should be followed by an integer.\n" ); - goto usage; - } - nLimit = atoi(argv[globalUtilOptind]); - globalUtilOptind++; - if ( nLimit < 0 ) - goto usage; - break; - case 'h': - goto usage; - default: - goto usage; - } - } - if ( !Abc_NtkRecIsRunning2() ) - { - Abc_Print( -1, "This command works for AIGs only after calling \"rec_start2\".\n" ); - return 0; - } - if (!Abc_NtkRecIsInTrimMode2()) - Abc_Print( 0, "This command works fine only in trim mode. Please call \"rec_start2 -t\" first.\n" ); - - Abc_NtkRecFilter2(nLimit); - return 0; - -usage: - Abc_Print( -2, "usage: rec_filter2 [-h]\n" ); - Abc_Print( -2, "\t filter the library of the recorder\n" ); - Abc_Print( -2, "\t-F num : the limit number of function class [default = %d]\n", nLimit ); - Abc_Print( -2, "\t-h : print the command usage\n"); - return 1; -} - - -/**Function************************************************************* - - Synopsis [] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -int Abc_CommandRecMerge2( Abc_Frame_t * pAbc, int argc, char ** argv ) -{ - int c; - char * FileName, * pTemp; - char ** pArgvNew; - int nArgcNew; - FILE * pFile; - Gia_Man_t * pGia = NULL; - - // set defaults - Extra_UtilGetoptReset(); - while ( ( c = Extra_UtilGetopt( argc, argv, "dh" ) ) != EOF ) - { - switch ( c ) - { - case 'h': - goto usage; - default: - goto usage; - } - } - if ( !Abc_NtkRecIsRunning2() ) - { - Abc_Print( -1, "This command works for AIGs only after calling \"rec_start2\".\n" ); - return 0; - } - pArgvNew = argv + globalUtilOptind; - nArgcNew = argc - globalUtilOptind; - if ( nArgcNew != 1 ) - { - Abc_Print( -1, "File name is not given on the command line.\n" ); - return 1; - } - else - { - // get the input file name - FileName = pArgvNew[0]; - // fix the wrong symbol - for ( pTemp = FileName; *pTemp; pTemp++ ) - if ( *pTemp == '>' ) - *pTemp = '\\'; - if ( (pFile = fopen( FileName, "r" )) == NULL ) - { - Abc_Print( -1, "Cannot open input file \"%s\". ", FileName ); - if ( (FileName = Extra_FileGetSimilarName( FileName, ".aig", NULL, NULL, NULL, NULL )) ) - Abc_Print( 1, "Did you mean \"%s\"?", FileName ); - Abc_Print( 1, "\n" ); - return 1; - } - fclose( pFile ); - pGia = Gia_AigerRead( FileName, 0, 0 ); - if ( pGia == NULL ) - { - Abc_Print( -1, "Reading AIGER has failed.\n" ); - return 0; - } - } - Abc_NtkRecLibMerge2(pGia); - return 0; - -usage: - Abc_Print( -2, "usage: rec_merge2 [-h]\n" ); - Abc_Print( -2, "\t merge libraries\n" ); - Abc_Print( -2, "\t-h : print the command usage\n"); - return 1; -} - - - /**Function************************************************************* Synopsis [] @@ -15969,33 +15083,14 @@ int Abc_CommandIf( Abc_Frame_t * pAbc, int argc, char ** argv ) if ( pPars->fUserRecLib ) { - if ( Abc_NtkRecIsRunning() + Abc_NtkRecIsRunning2() + Abc_NtkRecIsRunning3() != 1 ) - { - printf( "Exactly one LMS manager should be running.\n" ); - return 0; - } - if ( Abc_NtkRecIsRunning3() && Abc_NtkRecInputNum3() != pPars->nLutSize ) + assert( Abc_NtkRecIsRunning3() ); + if ( Abc_NtkRecInputNum3() != pPars->nLutSize ) { printf( "The number of library inputs (%d) different from the K parameters (%d).\n", Abc_NtkRecInputNum3(), pPars->nLutSize ); return 0; } } -/* - // modify for LUT structures - if ( pPars->pLutStruct ) - { - if ( pPars->nLutSize == -1 ) - { - Abc_Print( -1, "Please specify the maximum cut size (-K <num>) when LUT structure is used.\n" ); - return 1; - } - pPars->fTruth = 1; - pPars->fExpRed = 0; - pPars->fUsePerm = 1; - pPars->pLutLib = NULL; - } -*/ // complain if truth tables are requested but the cut size is too large if ( pPars->fTruth && pPars->nLutSize > IF_MAX_FUNC_LUTSIZE ) { diff --git a/src/base/abci/abcIf.c b/src/base/abci/abcIf.c index dd2e4d9c..63fdfb15 100644 --- a/src/base/abci/abcIf.c +++ b/src/base/abci/abcIf.c @@ -482,16 +482,8 @@ Abc_Obj_t * Abc_NodeFromIf_rec( Abc_Ntk_t * pNtkNew, If_Man_t * pIfMan, If_Obj_t } else if ( pIfMan->pPars->fUserRecLib ) { - extern Hop_Obj_t * Abc_RecToHop( Hop_Man_t * pMan, If_Man_t * pIfMan, If_Cut_t * pCut, If_Obj_t * pIfObj ); - extern Hop_Obj_t * Abc_RecToHop2( Hop_Man_t * pMan, If_Man_t * pIfMan, If_Cut_t * pCut, If_Obj_t * pIfObj ); extern Hop_Obj_t * Abc_RecToHop3( Hop_Man_t * pMan, If_Man_t * pIfMan, If_Cut_t * pCut, If_Obj_t * pIfObj ); - if(Abc_NtkRecIsRunning3()) - pNodeNew->pData = Abc_RecToHop3( (Hop_Man_t *)pNtkNew->pManFunc, pIfMan, pCutBest, pIfObj); - else if(Abc_NtkRecIsRunning2()) - pNodeNew->pData = Abc_RecToHop2( (Hop_Man_t *)pNtkNew->pManFunc, pIfMan, pCutBest, pIfObj); - else - pNodeNew->pData = Abc_RecToHop( (Hop_Man_t *)pNtkNew->pManFunc, pIfMan, pCutBest, pIfObj); - + pNodeNew->pData = Abc_RecToHop3( (Hop_Man_t *)pNtkNew->pManFunc, pIfMan, pCutBest, pIfObj ); } else { diff --git a/src/base/abci/abcRec.c b/src/base/abci/abcRec.c deleted file mode 100644 index 40a05661..00000000 --- a/src/base/abci/abcRec.c +++ /dev/null @@ -1,3110 +0,0 @@ -/**CFile**************************************************************** - - FileName [abcRec.c] - - SystemName [ABC: Logic synthesis and verification system.] - - PackageName [Network and node package.] - - Synopsis [Record of semi-canonical AIG subgraphs.] - - Author [Allan Yang, Alan Mishchenko] - - Affiliation [Fudan University in Shanghai, UC Berkeley] - - Date [Ver. 1.0. Started - June 20, 2005.] - - Revision [$Id: abcRec.c,v 1.00 2005/06/20 00:00:00 alanmi Exp $] - -***********************************************************************/ - -#include "base/abc/abc.h" -#include "map/if/if.h" -#include "bool/kit/kit.h" - -ABC_NAMESPACE_IMPL_START - -//#define LibOut -//////////////////////////////////////////////////////////////////////// -/// DECLARATIONS /// -//////////////////////////////////////////////////////////////////////// - -typedef struct Abc_ManRec_t_ Abc_ManRec_t; -typedef struct Rec_Obj_t_ Rec_Obj_t; - -typedef enum { - REC_ERROR, //0: error - REC_SMALL, //1: smaller than - REC_EQUAL, //2: equal with - REC_BIG, //3: bigger than - REC_DOMINANCE, //4: dominance - REC_BEDOMINANCED //5: be dominated -} Abc_LookUpStatus_t; - -struct Rec_Obj_t_ -{ - Abc_Obj_t* obj; // the actual structure in the library - Rec_Obj_t* pNext; // link to the next structure of the same functional class - Rec_Obj_t* pCopy; // link to the next functional class in the same bucket - int Id; // structure's ID - int nFrequency; // appear times of this functional class among benchmarks - unsigned char cost; // structure's cost - char* pinToPinDelay; // structure's pin-to-pin delay -}; - - -struct Abc_ManRec_t_ -{ - Abc_Ntk_t * pNtk; // the record - Vec_Ptr_t * vTtElems; // the elementary truth tables - Vec_Ptr_t * vTtNodes; // the node truth tables - Mem_Fixed_t * pMmTruth; // memory manager for truth tables - Rec_Obj_t ** pBins; // hash table mapping truth tables into nodes - int nBins; // the number of allocated bins - int nVars; // the number of variables - int nVarsInit; // the number of variables requested initially - int nWords; // the number of TT words - int nCuts; // the max number of cuts to use - Mem_Fixed_t * pMemObj; // memory manager for Rec objects - int recObjSize; // size for one Rec object - int fTrim; // filter the library or not. - // temporaries - int * pBytes; // temporary storage for minterms - int * pMints; // temporary storage for minterm counters - unsigned * pTemp1; // temporary truth table - unsigned * pTemp2; // temporary truth table - unsigned * pTempTruth; // temporary truth table - char * pTempDepths; // temporary depths - int * pTempleaves; // temporary leaves - unsigned tempUsign; - unsigned tempNleaves; - unsigned currentCost; - int currentDelay; - Vec_Ptr_t * vNodes; // the temporary nodes - Vec_Ptr_t * vTtTemps; // the truth tables for the internal nodes of the cut - Vec_Ptr_t * vLabels; // temporary storage for AIG node labels - Vec_Str_t * vCosts; // temporary storage for costs - Vec_Int_t * vMemory; // temporary memory for truth tables - // statistics - int nTried; // the number of cuts tried - int nFilterSize; // the number of same structures - int nFilterRedund; // the number of same structures - int nFilterVolume; // the number of same structures - int nFilterTruth; // the number of same structures - int nFilterError; // the number of same structures - int nFilterSame; // the number of same structures - int nAdded; // the number of subgraphs added - int nAddedFuncs; // the number of functions added - int nIfMapTried; - int nIfMapError; - int nTrimed; // the number of structures filtered - // rewriting - int nFunsFound; // the found functions - int nFunsNotFound; // the missing functions - int nFunsTried; - int nFunsFilteredBysupport; // the function filtered when rewriting because not all supports are in use. - int nFunsDelayComput; // the times delay computed, just for statistics - int nNoBetter; // the number of functions found but no better than the current structures. - // rewriting runtime - abctime timeIfTotal; // time used on the whole process of rewriting a structure. - abctime timeIfComputDelay; // time used on the structure's delay computation. - abctime timeIfCanonicize; // time used on canonicize the function - abctime timeIfDerive; // time used on derive the final network; - abctime timeIfCopmutCur; // time used on compute the current structures info - abctime timeIfOther; // time used on other things - // record runtime - abctime timeTrim; // the runtime to filter the library - abctime timeCollect; // the runtime to collect the node of a structure. - abctime timeTruth; // the runtime to compute truth table. - abctime timeCanon; // the runtime to canonicize - abctime timeInsert; // the runtime to insert a structure. - abctime timeBuild; // the runtime to build a new structure in the library. - abctime timeMerge; // the runtime to merge libraries; - abctime timeReHash; // the runtime to resize the hash table. - abctime timeOther; // the runtime of other - abctime timeTotal; // the runtime to total. -}; - - -// the truth table is canonicized in such a way that for (00000) its value is 0 - -static Rec_Obj_t ** Abc_NtkRecTableLookup( Abc_ManRec_t* p, Rec_Obj_t ** pBins, int nBins, unsigned * pTruth, int nVars); -static int Abc_NtkRecComputeTruth( Abc_Obj_t * pObj, Vec_Ptr_t * vTtNodes, int nVars ); -static int Abc_NtkRecAddCutCheckCycle_rec( Abc_Obj_t * pRoot, Abc_Obj_t * pObj ); -static void Abc_NtkRecAddFromLib( Abc_Ntk_t* pNtk, Abc_Obj_t * pRoot, int nVars ); -static void Abc_NtkRecCurrentUnMark_rec(If_Obj_t * pObj); -static Abc_ManRec_t * s_pMan = NULL; - -static inline void Abc_ObjSetMax( Abc_Obj_t * pObj, int Value ) { assert( pObj->Level < 0xff ); pObj->Level = (Value << 8) | (pObj->Level & 0xff); } -static inline void Abc_ObjClearMax( Abc_Obj_t * pObj ) { pObj->Level = (pObj->Level & 0xff); } -static inline int Abc_ObjGetMax( Abc_Obj_t * pObj ) { return (pObj->Level >> 8) & 0xff; } - -static inline void Abc_NtkRecFrequencyInc(Rec_Obj_t* entry) -{ - // the hit number of this functional class increased - if (entry != NULL && entry->nFrequency < 0x7fffffff) - entry->nFrequency += 1; -} - -//////////////////////////////////////////////////////////////////////// -/// FUNCTION DEFINITIONS /// -//////////////////////////////////////////////////////////////////////// - -/**Function************************************************************* - - Synopsis [stretch the truthtable to have more input variables.] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -void If_CutTruthStretch(unsigned* pInOut, int nVarS, int nVarB) -{ - int w, i; - int step = Kit_TruthWordNum(nVarS); - int nWords = Kit_TruthWordNum(nVarB); - assert(step <= nWords); - if (step == nWords) - return; - for (w = 0; w <nWords; w += step) - for (i = 0; i < step; i++) - pInOut[w + i] = pInOut[i]; -} - -/**Function************************************************************* - - Synopsis [Alloc the Rec object from its manger.] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ - -Rec_Obj_t* Rec_ObjAlloc(Abc_ManRec_t* p, Abc_Obj_t* pObj, char* pinToPinDelay, char cost, int nVar) -{ - int i; - Rec_Obj_t * pRecObj; - pRecObj = (Rec_Obj_t *)Mem_FixedEntryFetch( p->pMemObj); - pRecObj->pinToPinDelay = (char*)(pRecObj + 1); - pRecObj->pNext = NULL; - pRecObj->pCopy = NULL; - pRecObj->obj = pObj; - pRecObj->Id = pObj->Id; - for (i = 0; i < nVar; i++) - pRecObj->pinToPinDelay[i] = pinToPinDelay[i]; - pRecObj->cost = cost; - pRecObj->nFrequency = 0; - return pRecObj; -} - -/**Function************************************************************* - - Synopsis [set the property of a Rec object.] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -void Rec_ObjSet(Abc_ManRec_t* p, Rec_Obj_t* pRecObj, Abc_Obj_t* pObj, char* newDelay, unsigned char cost, int nVar) -{ - int i; - pRecObj->obj = pObj; - pRecObj->Id = pObj->Id; - pRecObj->cost = cost; - for (i = 0; i < nVar; i++) - pRecObj->pinToPinDelay[i] = newDelay[i]; -} - -/**Function************************************************************* - - Synopsis [Compute the delay of the structure recursively.] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -/* int If_CutDelayRecComput_rec(Abc_Obj_t* pObj, Vec_Str_t* vCosts) - { - char Delay0, Delay1, Delay; - Abc_Obj_t *pFanin0, *pFanin1; - pObj = Abc_ObjRegular(pObj); - if (Abc_NodeIsTravIdCurrent(pObj) || pObj->Type == ABC_OBJ_PI) - return Vec_StrEntry(vCosts,pObj->Id); - Abc_NodeSetTravIdCurrent(pObj); - Delay0 = If_CutDelayRecComput_rec(Abc_ObjFanin0(pObj), vCosts); - Delay1 = If_CutDelayRecComput_rec(Abc_ObjFanin1(pObj), vCosts); - Delay = Abc_MaxInt(Delay0, Delay1) + 1; - Vec_StrWriteEntry(vCosts,pObj->Id,Delay); - return Delay; - }*/ - -/**Function************************************************************* - - Synopsis [Compute delay of the structure using pin-to-pin delay.] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -inline int If_CutComputDelay(If_Man_t* p, Rec_Obj_t* entry, If_Cut_t* pCut, char* pCanonPerm , int nVars) -{ - If_Obj_t* pLeaf; - int i, delayTemp, delayMax = -ABC_INFINITY; - for (i = 0; i < nVars; i++) - { - pLeaf = If_ManObj(p, (pCut)->pLeaves[(int)pCanonPerm[i]]); - pLeaf = If_Regular(pLeaf); - delayTemp = entry->pinToPinDelay[i] + If_ObjCutBest(pLeaf)->Delay; - if(delayTemp > delayMax) - delayMax = delayTemp; - } - // plus each pin's delay with its pin-to-output delay, the biggest one is the delay of the structure. - return delayMax; -} - -/**Function************************************************************* - - Synopsis [Compute pin-to-pin delay of the structure.] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -char If_CutDepthRecComput_rec(Abc_Obj_t* pObj, int iLeaf) -{ - char Depth0, Depth1, Depth; - pObj = Abc_ObjRegular(pObj); - if(pObj->Id == iLeaf) - return 0; - if(pObj->Type == ABC_OBJ_PI ) - return -IF_BIG_CHAR; - Depth0 = If_CutDepthRecComput_rec(Abc_ObjFanin0(pObj), iLeaf); - Depth1 = If_CutDepthRecComput_rec(Abc_ObjFanin1(pObj), iLeaf); - Depth = Abc_MaxInt(Depth0, Depth1); - Depth = (Depth == -IF_BIG_CHAR) ? -IF_BIG_CHAR : Depth + 1; -// assert(Depth <= 127); - return Depth; -} - -/**Function************************************************************* - - Synopsis [Compute area of the structure.] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -unsigned char Abc_NtkRecAreaAndMark_rec(Abc_Obj_t* pObj) -{ - unsigned char Area0, Area1, Area; - pObj = Abc_ObjRegular(pObj); - if(Abc_ObjIsCi(pObj) || pObj->fMarkA == 1) - return 0; - Area0 = Abc_NtkRecAreaAndMark_rec(Abc_ObjFanin0(pObj)); - Area1 = Abc_NtkRecAreaAndMark_rec(Abc_ObjFanin1(pObj)); - Area = Area1 + Area0 + 1; -// assert(Area <= 255); - pObj->fMarkA = 1; - return Area; -} - - -/**Function************************************************************* - - Synopsis [Compute area of the structure.] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -void Abc_NtkRecAreaUnMark_rec(Abc_Obj_t* pObj) -{ - pObj = Abc_ObjRegular(pObj); - if ( Abc_ObjIsCi(pObj) || pObj->fMarkA == 0 ) - return; - Abc_NtkRecAreaUnMark_rec( Abc_ObjFanin0(pObj) ); - Abc_NtkRecAreaUnMark_rec( Abc_ObjFanin1(pObj) ); - assert( pObj->fMarkA ); // loop detection - pObj->fMarkA = 0; -} - -/**Function************************************************************* - - Synopsis [Compute area of the structure.] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -unsigned char Abc_NtkRecArea(Abc_Obj_t* pObj) -{ - unsigned char area; - area = Abc_NtkRecAreaAndMark_rec(pObj); - Abc_NtkRecAreaUnMark_rec(pObj); - return area; -} - -/**Function************************************************************* - - Synopsis [Compare delay profile of two structures.] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ - -Abc_LookUpStatus_t ABC_NtkRecDelayCompare(char* delayFromStruct, char* delayFromTable, int nVar) -{ - int i, bigThan = 0, smallThan = 0, equal = 1, dominace = 1, beDominaced = 1; - for (i = 0; i < nVar; i++) - { - if(delayFromStruct[i] < delayFromTable[i]) - { - equal = 0; - beDominaced = 0; - if(bigThan == 0) - smallThan = 1; - } - else if (delayFromStruct[i] > delayFromTable[i]) - { - equal = 0; - dominace = 0; - if (smallThan == 0) - bigThan = 1; - } - } - if(equal) - return REC_EQUAL; - else if(dominace) - return REC_DOMINANCE; - else if(beDominaced) - return REC_BEDOMINANCED; - if(bigThan) - return REC_BIG; - else if(smallThan) - return REC_SMALL; - else - return REC_SMALL; -} - -/**Function************************************************************* - - Synopsis [link a useless PO to constant 0.] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -void Abc_NtkRecReplacePO(Abc_Obj_t* pObj ) -{ - Abc_Obj_t * pConst0, * pFaninNew; - Abc_Ntk_t * pNtk = pObj->pNtk; - if ( Abc_ObjFanin0(pObj) == Abc_AigConst1(pNtk) ) - { - if ( !Abc_ObjFaninC0(pObj) ) - Abc_ObjXorFaninC( pObj, 0 ); - return; - } - pConst0 = Abc_ObjNot( Abc_AigConst1(pNtk) ); - pFaninNew = Abc_ObjNotCond( pConst0, Abc_ObjFaninC0(pObj) ); - Abc_ObjPatchFanin( pObj, Abc_ObjFanin0(pObj), pFaninNew ); - assert( Abc_ObjChild0(pObj) == pConst0 ); - //Abc_AigCleanup( (Abc_Aig_t *)pNtk->pManFunc ); -} - -/**Function************************************************************* - - Synopsis [Delete a useless structure in the library.] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -void Abc_NtkRecDeleteSubGragh(Abc_ManRec_t* p, Abc_Obj_t* pObj) -{ - Abc_Obj_t* pFanOut; - int i, deleted = 0; - Abc_ObjForEachFanout(pObj, pFanOut, i) - { - if (Abc_ObjIsCo(pFanOut)) - { - Abc_NtkRecReplacePO(pFanOut); - deleted++; - p->nTrimed++; - } - } - assert(deleted == 1); -} - -/**Function************************************************************* - - Synopsis [Check if the structure is dominant or not.] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -int ABC_NtkRecIsDominant(char* delayFromStruct, char* delayFromTable, int nVar) -{ - int i; - for (i = 0; i < nVar; i++) - { - if(delayFromStruct[i] > delayFromTable[i]) - return 0; - } - return 1; -} - -/**Function************************************************************* - - Synopsis [Sweep the dominated structures.] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -void Abc_NtkRecSweepDominance(Abc_ManRec_t* p, Rec_Obj_t* previous, Rec_Obj_t* current, char * delayFromStruct, int nVars, int fTrim) -{ - Abc_Obj_t* pObj; - while(current != NULL) - { - if (ABC_NtkRecIsDominant(delayFromStruct, current->pinToPinDelay, nVars)) - { - pObj = current->obj; - previous->pNext = current->pNext; - current->pNext = NULL; - Mem_FixedEntryRecycle(p->pMemObj, (char *)current); - current = previous->pNext; - p->nAdded--; - // if filter the library is needed, then point the PO to a constant. - if (fTrim) - Abc_NtkRecDeleteSubGragh(p, pObj); - } - else - { - previous = current; - current = current->pNext; - } - } -} - - -/**Function************************************************************* - - Synopsis [Insert a structure into the look up table.] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -void Abc_NtkRecInsertToLookUpTable(Abc_ManRec_t* p, Rec_Obj_t** ppSpot, Abc_Obj_t* pObj, int nVars, int fTrim) -{ - char delayFromStruct[16] ; - int i; - Abc_Obj_t* pLeaf; - Rec_Obj_t* entry, *previous = NULL, *current = * ppSpot; - unsigned char costFromStruct = Abc_NtkRecArea(pObj); - Abc_LookUpStatus_t result; - for (i = 0; i < nVars; i++) - { - pLeaf = Abc_NtkPi( p->pNtk, i); - pLeaf =Abc_ObjRegular(pLeaf); - delayFromStruct[i] = If_CutDepthRecComput_rec(pObj, pLeaf->Id); - } - if(fTrim) - { - while(1) - { - if (current == NULL) - { - p->nAdded++; - entry = Rec_ObjAlloc(p, pObj, delayFromStruct, costFromStruct, nVars); - if(previous != NULL) - { - previous->pNext = entry; - } - else - { - // new functional class found - p->nAddedFuncs++; - *ppSpot = entry; - entry->nFrequency = 1; - } - break; - } - result = ABC_NtkRecDelayCompare(delayFromStruct, current->pinToPinDelay, nVars); - if(result == REC_EQUAL) - { - // when delay profile is equal, replace only if it has smaller cost. - if(costFromStruct < current->cost) - { - Abc_NtkRecDeleteSubGragh(p, current->obj); - Rec_ObjSet(p, current, pObj, delayFromStruct, costFromStruct, nVars); - } - else - Abc_NtkRecDeleteSubGragh(p, pObj); - break; - } - // when the new structure can dominate others, sweep them out of the library, delete them if required. - else if(result == REC_DOMINANCE) - { - Abc_NtkRecDeleteSubGragh(p, current->obj); - Rec_ObjSet(p, current, pObj, delayFromStruct, costFromStruct, nVars); - Abc_NtkRecSweepDominance(p,current,current->pNext,delayFromStruct, nVars, fTrim); - break; - } - // when the new structure is domianted by an existed one, don't store it. - else if (result == REC_BEDOMINANCED) - { - Abc_NtkRecDeleteSubGragh(p, pObj); - break; - } - // when the new structure's delay profile is big than the current, test the next one - else if (result == REC_BIG) - { - previous = current; - current = current->pNext; - } - // insert the new structure to the right position, sweep the ones it can dominate. - else if (result == REC_SMALL) - { - p->nAdded++; - entry = Rec_ObjAlloc(p, pObj, delayFromStruct, costFromStruct, nVars); - if(previous != NULL) - { - previous->pNext = entry; - entry->pNext = current; - } - else - { - entry->pNext = current; - entry->pCopy = (*ppSpot)->pCopy; - entry->nFrequency = (*ppSpot)->nFrequency; - (*ppSpot)->pCopy = NULL; - (*ppSpot)->nFrequency = 0; - *ppSpot = entry; - } - Abc_NtkRecSweepDominance(p,current,current->pNext,delayFromStruct, nVars, fTrim); - break; - } - else - assert(0); - } - } - else - { - if (current == NULL) - { - p->nAdded++; - entry = Rec_ObjAlloc(p, pObj, delayFromStruct, costFromStruct, nVars); - p->nAddedFuncs++; - *ppSpot = entry; - entry->nFrequency = 1; - } - else - { - p->nAdded++; - entry = Rec_ObjAlloc(p, pObj, delayFromStruct, costFromStruct, nVars); - entry->pNext = (*ppSpot)->pNext; - (*ppSpot)->pNext = entry; - } - } -} - -/**Function************************************************************* - - Synopsis [Build up the structure using library.] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ - Hop_Obj_t * Abc_NtkRecBuildUp_rec(Hop_Man_t* pMan, Abc_Obj_t* pObj, Vec_Ptr_t * vNodes) - { - Hop_Obj_t * pRes0, *pRes1, *pRes; - Abc_Obj_t *pRegular = Abc_ObjRegular(pObj); - if (Abc_NodeIsTravIdCurrent(pRegular) || pRegular->Type == ABC_OBJ_PI) - return (Hop_Obj_t *)Vec_PtrEntry(vNodes, pRegular->Id); - Abc_NodeSetTravIdCurrent(pRegular); - pRes0 = Abc_NtkRecBuildUp_rec(pMan, Abc_ObjFanin0(pRegular), vNodes); - pRes0 = Hop_NotCond(pRes0, pRegular->fCompl0); - pRes1 = Abc_NtkRecBuildUp_rec(pMan, Abc_ObjFanin1(pRegular), vNodes); - pRes1 = Hop_NotCond(pRes1, pRegular->fCompl1); - pRes = Hop_And(pMan, pRes0, pRes1); - Vec_PtrWriteEntry(vNodes,pRegular->Id,pRes); - return pRes; - } - - /**Function************************************************************* - - Synopsis [Build up the structure using library.] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ - Hop_Obj_t * Abc_NtkRecBuildUpFromCurrent_rec(Hop_Man_t* pMan, If_Obj_t* pObj, Vec_Ptr_t * vNodes) - { - Hop_Obj_t * pRes0, *pRes1, *pRes; - If_Obj_t *pRegular = If_Regular(pObj); - if (Vec_PtrEntry(vNodes, pRegular->Id) && pRegular->fMark == 1) - return (Hop_Obj_t *)Vec_PtrEntry(vNodes, pRegular->Id); - pRes0 = Abc_NtkRecBuildUpFromCurrent_rec(pMan, If_ObjFanin0(pRegular), vNodes); - pRes0 = Hop_NotCond(pRes0, pRegular->fCompl0); - pRes1 = Abc_NtkRecBuildUpFromCurrent_rec(pMan, If_ObjFanin1(pRegular), vNodes); - pRes1 = Hop_NotCond(pRes1, pRegular->fCompl1); - pRes = Hop_And(pMan, pRes0, pRes1); - Vec_PtrWriteEntry(vNodes,pRegular->Id,pRes); - assert(pRegular->fMark == 0); - pRegular->fMark = 1; - return pRes; - } - - /**Function************************************************************* - - Synopsis [Derive the final network from the library.] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ - Hop_Obj_t * Abc_RecFromCurrentToHop(Hop_Man_t * pMan, If_Man_t * pIfMan, If_Cut_t * pCut, If_Obj_t * pRoot) - { - int i; - If_Obj_t * pLeaf; - Hop_Obj_t* pHopObj; - Vec_PtrGrow(s_pMan->vLabels, pIfMan->vObjs->nSize); - s_pMan->vLabels->nSize = s_pMan->vLabels->nCap; - If_CutForEachLeaf(pIfMan, pCut, pLeaf, i) - { - pHopObj = Hop_IthVar(pMan, i); - Vec_PtrWriteEntry(s_pMan->vLabels, pLeaf->Id, pHopObj); - assert(pLeaf->fMark == 0); - pLeaf->fMark = 1; - } - pHopObj = Abc_NtkRecBuildUpFromCurrent_rec(pMan, pRoot, s_pMan->vLabels); - Abc_NtkRecCurrentUnMark_rec(pRoot); - return pHopObj; - - - } - - /**Function************************************************************* - - Synopsis [Look up the best strcuture in the library.] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ - int Abc_NtkRecLookUpEnum(If_Man_t * pIfMan,If_Cut_t * pCut, Rec_Obj_t ** ppSpot, Rec_Obj_t ** pCandMin, char * pCanonPerm) - { - int DelayMin = ABC_INFINITY , Delay = -ABC_INFINITY; - Rec_Obj_t *pCand; - int nLeaves = pCut->nLeaves; - assert( *ppSpot != NULL ); - for ( pCand = *ppSpot; pCand; pCand = pCand->pNext ) - { - s_pMan->nFunsDelayComput++; - Delay = If_CutComputDelay(pIfMan, pCand, pCut, pCanonPerm ,nLeaves); - if ( DelayMin > Delay ) - { - DelayMin = Delay; - *pCandMin = pCand; - } - else if(Delay == DelayMin) - { - if(pCand->cost < (*pCandMin)->cost) - *pCandMin = pCand; - } - } - assert( *pCandMin != NULL ); - return DelayMin; - } - - /**Function************************************************************* - - Synopsis [Look up the best strcuture in the library.] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ - Rec_Obj_t * Abc_NtkRecLookUpBest(If_Man_t * pIfMan,If_Cut_t * pCut, unsigned * pInOut, char * pCanonPerm, int * fCompl, int * delayBest) - { - Rec_Obj_t *pCandMin = NULL, *pCandMinCompl = NULL, **ppSpot; - int delay = ABC_INFINITY, delayCompl = ABC_INFINITY; - int nVars = s_pMan->nVars; - //int nLeaves = pCut->nLeaves; - ppSpot = Abc_NtkRecTableLookup(s_pMan, s_pMan->pBins, s_pMan->nBins, pInOut, nVars ); - if (*ppSpot != NULL) - delay = Abc_NtkRecLookUpEnum(pIfMan, pCut, ppSpot, &pCandMin, pCanonPerm); - Kit_TruthNot(pInOut, pInOut, nVars); - ppSpot = Abc_NtkRecTableLookup(s_pMan, s_pMan->pBins, s_pMan->nBins, pInOut, nVars ); - if (*ppSpot != NULL) - delayCompl = Abc_NtkRecLookUpEnum(pIfMan, pCut, ppSpot, &pCandMinCompl, pCanonPerm); - if (delayBest) - *delayBest = delay < delayCompl ? delay : delayCompl; - if (pCandMin == NULL && pCandMinCompl == NULL) - return NULL; - else if (pCandMin != NULL && pCandMinCompl != NULL) - { - if (delay > delayCompl || (delay == delayCompl && pCandMin->cost > pCandMinCompl->cost)) - { - if (fCompl) - *fCompl = 1; - return pCandMinCompl; - } - else - { - if (fCompl) - *fCompl = 0; - return pCandMin; - } - } - else if (pCandMin != NULL) - { - if (fCompl) - *fCompl = 0; - return pCandMin; - } - else - { - if (fCompl) - *fCompl = 1; - return pCandMinCompl; - } - } - -/**Function************************************************************* - - Synopsis [Derive the final network from the library.] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -Hop_Obj_t * Abc_RecToHop( Hop_Man_t * pMan, If_Man_t * pIfMan, If_Cut_t * pCut, If_Obj_t * pIfObj ) -{ - Rec_Obj_t *pCandMin; - Hop_Obj_t* pHopObj; - Abc_Obj_t* pAbcObj; - Abc_Ntk_t * pAig = s_pMan->pNtk; - int nLeaves, i;// DelayMin = ABC_INFINITY , Delay = -ABC_INFINITY - unsigned uCanonPhase; - int nVars = s_pMan->nVars; - char pCanonPerm[16]; - unsigned *pInOut = s_pMan->pTemp1; - unsigned *pTemp = s_pMan->pTemp2; - abctime time = Abc_Clock(); - int fCompl; - int * pCompl = &fCompl; - nLeaves = If_CutLeaveNum(pCut); -// if (nLeaves < 3) -// return Abc_NodeTruthToHop(pMan, pIfMan, pCut); - Kit_TruthCopy(pInOut, If_CutTruth(pIfMan, pCut), pCut->nLimit); - //special cases when cut-minimization return 2, that means there is only one leaf in the cut. - if ((Kit_TruthIsConst0(pInOut, nLeaves) && pCut->fCompl == 0) || (Kit_TruthIsConst1(pInOut, nLeaves) && pCut->fCompl == 1)) - return Hop_ManConst0(pMan); - if ((Kit_TruthIsConst0(pInOut, nLeaves) && pCut->fCompl == 1) || (Kit_TruthIsConst1(pInOut, nLeaves) && pCut->fCompl == 0)) - return Hop_ManConst1(pMan); - if (Kit_TruthSupport(pInOut, nLeaves) != Kit_BitMask(nLeaves)) - { - for (i = 0; i < nLeaves; i++) - if(Kit_TruthVarInSupport( pInOut, nLeaves, i )) - return Hop_NotCond(Hop_IthVar(pMan, i), (pCut->fCompl ^ ((*pInOut & 0x01) > 0))); - } - - for (i = 0; i < nLeaves; i++) - pCanonPerm[i] = i; - uCanonPhase = Kit_TruthSemiCanonicize(pInOut, pTemp, nLeaves, pCanonPerm); - If_CutTruthStretch(pInOut, nLeaves, nVars); - pCandMin = Abc_NtkRecLookUpBest(pIfMan, pCut, pInOut, pCanonPerm, pCompl,NULL); - Vec_PtrGrow(s_pMan->vLabels, Abc_NtkObjNumMax(pAig)); - s_pMan->vLabels->nSize = s_pMan->vLabels->nCap; - for (i = 0; i < nLeaves; i++) - { - pAbcObj = Abc_NtkPi( pAig, i ); - pHopObj = Hop_IthVar(pMan, pCanonPerm[i]); - pHopObj = Hop_NotCond(pHopObj, ((uCanonPhase & (1 << i)) > 0)); - Vec_PtrWriteEntry(s_pMan->vLabels, pAbcObj->Id, pHopObj); - } - Abc_NtkIncrementTravId(pAig); - //derive the best structure in the library. - pHopObj = Abc_NtkRecBuildUp_rec(pMan, pCandMin->obj, s_pMan->vLabels); - s_pMan->timeIfDerive += Abc_Clock() - time; - s_pMan->timeIfTotal += Abc_Clock() - time; - return Hop_NotCond(pHopObj, (pCut->fCompl)^(((uCanonPhase & (1 << nLeaves)) > 0)) ^ fCompl); -} - -/**Function************************************************************* - - Synopsis [Duplicates non-danglingn nodes and POs driven by constants.] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -void Abc_NtkDupWithoutDangling_rec( Abc_Ntk_t * pNtkNew, Abc_Obj_t * pObj ) -{ - if ( pObj->pCopy != NULL ) - return; - assert( Abc_ObjIsNode(pObj) ); - Abc_NtkDupWithoutDangling_rec( pNtkNew, Abc_ObjFanin0(pObj) ); - Abc_NtkDupWithoutDangling_rec( pNtkNew, Abc_ObjFanin1(pObj) ); - pObj->pCopy = Abc_AigAnd( (Abc_Aig_t *)pNtkNew->pManFunc, Abc_ObjChild0Copy(pObj), Abc_ObjChild1Copy(pObj) ); -} - -/**Function************************************************************* - - Synopsis [Duplicates non-danglingn nodes and POs driven by constants.] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -Abc_Ntk_t * Abc_NtkDupWithoutDangling( Abc_Ntk_t * pNtk ) -{ - Abc_Ntk_t * pNtkNew; - Abc_Obj_t * pObj; - int i; - assert( Abc_NtkIsStrash(pNtk) ); - // start the network - pNtkNew = Abc_NtkAlloc( pNtk->ntkType, pNtk->ntkFunc, 1 ); - // duplicate the name and the spec - pNtkNew->pName = Extra_UtilStrsav(pNtk->pName); - pNtkNew->pSpec = Extra_UtilStrsav(pNtk->pSpec); - // clean the node copy fields - Abc_NtkCleanCopy( pNtk ); - // map the constant nodes - Abc_AigConst1(pNtk)->pCopy = Abc_AigConst1(pNtkNew); - // clone PIs - Abc_NtkForEachPi( pNtk, pObj, i ) - Abc_NtkDupObj( pNtkNew, pObj, 0 ); - // recursively add non-dangling logic - Abc_NtkForEachPo( pNtk, pObj, i ) - if ( Abc_ObjFanin0(pObj) != Abc_AigConst1(pNtk) ) - Abc_NtkDupWithoutDangling_rec( pNtkNew, Abc_ObjFanin0(pObj) ); - // clone POs - Abc_NtkForEachPo( pNtk, pObj, i ) - if ( Abc_ObjFanin0(pObj) != Abc_AigConst1(pNtk) ) - { - Abc_NtkDupObj( pNtkNew, pObj, 0 ); - Abc_ObjAddFanin( pObj->pCopy, Abc_ObjFanin0(pObj)->pCopy ); - } - Abc_NtkAddDummyPiNames( pNtkNew ); - Abc_NtkAddDummyPoNames( pNtkNew ); - if ( !Abc_NtkCheck( pNtkNew ) ) - fprintf( stdout, "Abc_NtkDupWithoutDangling(): Network check has failed.\n" ); - pNtk->pCopy = pNtkNew; - return pNtkNew; -} - -/**Function************************************************************* - - Synopsis [Filter the library.] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -void Abc_RecUpdateHashTable() -{ - Abc_ManRec_t * p = s_pMan; - Rec_Obj_t * pEntry, * pTemp; - int i; - for ( i = 0; i < p->nBins; i++ ) - for ( pEntry = p->pBins[i]; pEntry; pEntry = pEntry->pCopy ) - for ( pTemp = pEntry; pTemp; pTemp = pTemp->pNext ) - pTemp->obj = pTemp->obj->pCopy; -} - -/**Function************************************************************* - - Synopsis [Filter the library.] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -void Abc_NtkRecFilter(int nLimit) -{ - Rec_Obj_t * previous = NULL, * entry = NULL, * pTemp; - int i; - Abc_Ntk_t * pNtk = s_pMan->pNtk; - abctime time = Abc_Clock(); - if (nLimit > 0) - { - for ( i = 0; i < s_pMan->nBins; i++ ) - { - previous = NULL; - for ( entry = s_pMan->pBins[i]; entry; entry = entry->pCopy) - { - assert(entry->nFrequency != 0); - // only filter the functional classed with frequency less than nLimit. - if(entry->nFrequency > nLimit) - { - previous = entry; - continue; - } - if(previous == NULL) - { - s_pMan->pBins[i] = entry->pCopy; - previous = NULL; - } - else - previous->pCopy = entry->pCopy; - - s_pMan->nAddedFuncs--; - //delete all the subgragh. - for ( pTemp = entry; pTemp; pTemp = pTemp->pNext ) - { - s_pMan->nAdded--; - Abc_NtkRecDeleteSubGragh(s_pMan, pTemp->obj); - Mem_FixedEntryRecycle(s_pMan->pMemObj, (char *)pTemp); - } - } - } - } - - // remove dangling nodes and POs driven by constants - s_pMan->pNtk = Abc_NtkDupWithoutDangling( pNtk ); - Abc_RecUpdateHashTable(); - Abc_NtkDelete( pNtk ); - - // collect runtime stats - s_pMan->timeTrim += Abc_Clock() - time; - s_pMan->timeTotal += Abc_Clock() - time; -} - - - -/**Function************************************************************* - - Synopsis [Test if the record is running.] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -int Abc_NtkRecIsRunning() -{ - return s_pMan != NULL; -} - -/**Function************************************************************* - - Synopsis [Test if the record is working in trim mode.] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -int Abc_NtkRecIsInTrimMode() -{ - return (s_pMan != NULL && s_pMan->fTrim); -} - -/**Function************************************************************* - - Synopsis [] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -int Abc_NtkRecVarNum() -{ - return (s_pMan != NULL)? s_pMan->nVars : -1; -} - -/**Function************************************************************* - - Synopsis [] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -Vec_Int_t * Abc_NtkRecMemory() -{ - return s_pMan->vMemory; -} - -/**Function************************************************************* - - Synopsis [Starts the record for the given network.] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -void Abc_NtkRecLibMerge(Abc_Ntk_t* pNtk) -{ - int i; - Abc_Obj_t * pObj; - Abc_ManRec_t * p = s_pMan; - abctime clk = Abc_Clock(); - if ( Abc_NtkPiNum(pNtk) > s_pMan->nVars ) - { - printf( "The library has more inputs than the record.\n"); - return; - } - Abc_NtkForEachPi( pNtk, pObj, i ) - Abc_ObjSetMax( pObj, i+1 ); - Abc_AigForEachAnd( pNtk, pObj, i ) - Abc_ObjSetMax( pObj, Abc_MaxInt( Abc_ObjGetMax(Abc_ObjFanin0(pObj)), Abc_ObjGetMax(Abc_ObjFanin1(pObj)) ) ); - - // insert the PO nodes into the table - Abc_NtkForEachPo( pNtk, pObj, i ) - { - p->nTried++; - //if the PO's input is a constant, skip it. - if (Abc_ObjChild0(pObj) == Abc_ObjNot( Abc_AigConst1(pNtk))) - { - p->nTrimed++; - continue; - } - pObj = Abc_ObjFanin0(pObj); - Abc_NtkRecAddFromLib(pNtk, pObj, Abc_ObjGetMax(pObj) ); - } - Abc_NtkForEachObj( pNtk, pObj, i ) - { - Abc_ObjClearMax( pObj ); - } - s_pMan->timeMerge += Abc_Clock() - clk; - s_pMan->timeTotal += Abc_Clock() - clk; -} - -/**Function************************************************************* - - Synopsis [Resize the hash table.] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -void Abc_NtkRecRezieHash(Abc_ManRec_t* p) -{ - Rec_Obj_t ** pBinsNew, **ppSpot; - Rec_Obj_t * pEntry, * pTemp; - int nBinsNew, Counter, i; - abctime clk = Abc_Clock(); - // get the new table size - nBinsNew = Cudd_Prime( 3 * p->nBins ); - printf("Hash table resize from %d to %d.\n", p->nBins, nBinsNew); - // allocate a new array - pBinsNew = ABC_ALLOC( Rec_Obj_t *, nBinsNew ); - memset( pBinsNew, 0, sizeof(Rec_Obj_t *) * nBinsNew ); - // rehash the entries from the old table - Counter = 0; - for ( i = 0; i < p->nBins; i++ ) - for ( pEntry = p->pBins[i]; pEntry;) - { - pTemp = pEntry->pCopy; - ppSpot = Abc_NtkRecTableLookup(p, pBinsNew, nBinsNew, (unsigned *)Vec_PtrEntry(p->vTtNodes, pEntry->Id), p->nVars); - assert(*ppSpot == NULL); - *ppSpot = pEntry; - pEntry->pCopy = NULL; - pEntry = pTemp; - Counter++; - } - assert( Counter == p->nAddedFuncs); - ABC_FREE( p->pBins ); - p->pBins = pBinsNew; - p->nBins = nBinsNew; - p->timeReHash += Abc_Clock() - clk; - p->timeTotal += Abc_Clock() - clk; - -} - - -/**Function************************************************************* - - Synopsis [Starts the record for the given network.] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -void Abc_NtkRecStart( Abc_Ntk_t * pNtk, int nVars, int nCuts, int fTrim ) -{ - Abc_ManRec_t * p; - Abc_Obj_t * pObj; - Rec_Obj_t** ppSpot; - char Buffer[10]; - unsigned * pTruth; - int i, RetValue; - abctime clkTotal = Abc_Clock(), clk, timeInsert; - //int testNum = 0; - - assert( s_pMan == NULL ); - if ( pNtk == NULL ) - { - assert( nVars > 2 && nVars <= 16 ); - pNtk = Abc_NtkAlloc( ABC_NTK_STRASH, ABC_FUNC_AIG, 1 ); - pNtk->pName = Extra_UtilStrsav( "record" ); - } - else - { - if ( Abc_NtkGetChoiceNum(pNtk) > 0 ) - { - printf( "The starting record should be a network without choice nodes.\n" ); - return; - } - if ( Abc_NtkPiNum(pNtk) > 16 ) - { - printf( "The starting record should be a network with no more than %d primary inputs.\n", 16 ); - return; - } - if ( Abc_NtkPiNum(pNtk) > nVars ) - printf( "The starting record has %d inputs (warning only).\n", Abc_NtkPiNum(pNtk) ); - pNtk = Abc_NtkDup( pNtk ); - } - // create the primary inputs - for ( i = Abc_NtkPiNum(pNtk); i < nVars; i++ ) - { - pObj = Abc_NtkCreatePi( pNtk ); - Buffer[0] = 'a' + i; - Buffer[1] = 0; - Abc_ObjAssignName( pObj, Buffer, NULL ); - } - Abc_NtkCleanCopy( pNtk ); - - // start the manager - p = ABC_ALLOC( Abc_ManRec_t, 1 ); - memset( p, 0, sizeof(Abc_ManRec_t) ); - p->pNtk = pNtk; - p->nVars = Abc_NtkPiNum(pNtk); - p->nWords = Kit_TruthWordNum( p->nVars ); - p->nCuts = nCuts; - p->nVarsInit = nVars; - p->recObjSize = sizeof(Rec_Obj_t) + sizeof(char) * p->nVars; - p->pMemObj = Mem_FixedStart(p->recObjSize); - p->fTrim = fTrim; - // create elementary truth tables - p->vTtElems = Vec_PtrAlloc( 0 ); assert( p->vTtElems->pArray == NULL ); - p->vTtElems->nSize = p->nVars; - p->vTtElems->nCap = p->nVars; - p->vTtElems->pArray = (void **)Extra_TruthElementary( p->nVars ); -/* - // allocate room for node truth tables - if ( Abc_NtkObjNum(pNtk) > (1<<14) ) - p->vTtNodes = Vec_PtrAllocSimInfo( 2 * Abc_NtkObjNum(pNtk), p->nWords ); - else - p->vTtNodes = Vec_PtrAllocSimInfo( 1<<14, p->nWords ); -*/ - p->vTtNodes = Vec_PtrAlloc( 1000 ); - p->pMmTruth = Mem_FixedStart( sizeof(unsigned)*p->nWords ); - for ( i = 0; i < Abc_NtkObjNumMax(pNtk); i++ ) -// Vec_PtrPush( p->vTtNodes, ABC_ALLOC(unsigned, p->nWords) ); - Vec_PtrPush( p->vTtNodes, Mem_FixedEntryFetch(p->pMmTruth) ); - - // create hash table - //p->nBins = 50011; - p->nBins =500011; - p->pBins = ABC_ALLOC( Rec_Obj_t *, p->nBins ); - memset( p->pBins, 0, sizeof(Rec_Obj_t *) * p->nBins ); - - // set elementary tables - Kit_TruthFill( (unsigned *)Vec_PtrEntry(p->vTtNodes, 0), p->nVars ); - Abc_NtkForEachPi( pNtk, pObj, i ) - Kit_TruthCopy( (unsigned *)Vec_PtrEntry(p->vTtNodes, pObj->Id), (unsigned *)Vec_PtrEntry(p->vTtElems, i), p->nVars ); - - // compute the tables -clk = Abc_Clock(); - - Abc_AigForEachAnd( pNtk, pObj, i ) - { - RetValue = Abc_NtkRecComputeTruth( pObj, p->vTtNodes, p->nVars ); - assert( RetValue ); - } -p->timeTruth += Abc_Clock() - clk; - - Abc_NtkForEachPi( pNtk, pObj, i ) - Abc_ObjSetMax( pObj, i+1 ); - Abc_AigForEachAnd( pNtk, pObj, i ) - Abc_ObjSetMax( pObj, Abc_MaxInt( Abc_ObjGetMax(Abc_ObjFanin0(pObj)), Abc_ObjGetMax(Abc_ObjFanin1(pObj)) ) ); - - // insert the PO nodes into the table - timeInsert = Abc_Clock(); - Abc_NtkForEachPo( pNtk, pObj, i ) - { - p->nTried++; - //if the PO's input is a constant, skip it. - if (Abc_ObjChild0(pObj) == Abc_ObjNot( Abc_AigConst1(pNtk))) - { - p->nTrimed++; - continue; - } - pObj = Abc_ObjFanin0(pObj); - pTruth = (unsigned *)Vec_PtrEntry( p->vTtNodes, pObj->Id ); - // add the resulting truth table to the hash table - if(p->nAddedFuncs > 2 * p->nBins) - Abc_NtkRecRezieHash(p); - ppSpot = Abc_NtkRecTableLookup(p, p->pBins, p->nBins, pTruth, p->nVars ); - Abc_NtkRecInsertToLookUpTable(p, ppSpot, pObj, Abc_ObjGetMax(pObj), p->fTrim); - } - p->timeInsert += Abc_Clock() - timeInsert; - Abc_NtkForEachObj( pNtk, pObj, i ) - { - Abc_ObjClearMax( pObj ); - } - // temporaries - p->pBytes = ABC_ALLOC( int, 4*p->nWords ); - p->pMints = ABC_ALLOC( int, 2*p->nVars ); - p->pTemp1 = ABC_ALLOC( unsigned, p->nWords ); - p->pTemp2 = ABC_ALLOC( unsigned, p->nWords ); - p->pTempTruth = ABC_ALLOC( unsigned, p->nWords ); - p->pTempDepths = ABC_ALLOC( char, p->nVars ); - p->pTempleaves = ABC_ALLOC( int, p->nVars ); - p->vNodes = Vec_PtrAlloc( 100 ); - p->vTtTemps = Vec_PtrAllocSimInfo( 1024, p->nWords ); - p->vMemory = Vec_IntAlloc( Abc_TruthWordNum(p->nVars) * 1000 ); - p->vLabels = Vec_PtrStart( 1000); - - // set the manager - s_pMan = p; - p->timeTotal += Abc_Clock() - clkTotal; -} - -/**Function************************************************************* - - Synopsis [Dump truth tables into a file.] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -/*void Abc_NtkRecDumpTruthTables( Abc_ManRec_t * p ) -{ - int nVars = 10; - FILE * pFile; - Rec_Obj_t * pObj; - unsigned * pTruth; - int i; - pFile = fopen( "tt10.txt", "wb" ); - for ( i = 0; i < p->nBins; i++ ) - for ( pObj = p->pBins[i]; pObj; pObj = pObj->pCopy ) - { - pTruth = Vec_PtrEntry(p->vTtNodes, pObj->Id); - if ( (int)Kit_TruthSupport(pTruth, nVars) != (1<<nVars)-1 ) - continue; - Extra_PrintHex( pFile, pTruth, nVars ); - fprintf( pFile, " " ); - Kit_DsdPrintFromTruth2( pFile, pTruth, nVars ); - fprintf( pFile, "\n" ); - } - fclose( pFile ); -}*/ - -/**Function************************************************************* - - Synopsis [Returns the given record.] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -void Abc_NtkRecStop() -{ - assert( s_pMan != NULL ); -// Abc_NtkRecDumpTruthTables( s_pMan ); - if ( s_pMan->pNtk ) - Abc_NtkDelete( s_pMan->pNtk ); -// Vec_PtrFreeFree( s_pMan->vTtNodes ); - Mem_FixedStop( s_pMan->pMmTruth, 0 ); - Vec_PtrFree( s_pMan->vTtNodes ); - Vec_PtrFree( s_pMan->vTtElems ); - ABC_FREE( s_pMan->pBins ); - - // temporaries - ABC_FREE( s_pMan->pBytes ); - ABC_FREE( s_pMan->pMints ); - ABC_FREE( s_pMan->pTemp1 ); - ABC_FREE( s_pMan->pTemp2 ); - ABC_FREE( s_pMan->pTempTruth ); - ABC_FREE( s_pMan->pTempDepths ); - Vec_PtrFree( s_pMan->vNodes ); - Vec_PtrFree( s_pMan->vTtTemps ); - if ( s_pMan->vLabels ) - Vec_PtrFree( s_pMan->vLabels ); - if ( s_pMan->vCosts ) - Vec_StrFree( s_pMan->vCosts ); - if(s_pMan->pMemObj) - Mem_FixedStop(s_pMan->pMemObj, 0); - Vec_IntFree( s_pMan->vMemory ); -// if(s_pMan->vFiltered) -// Vec_StrFree(s_pMan->vFiltered); - - ABC_FREE( s_pMan ); - s_pMan = NULL; -} - -/**Function************************************************************* - - Synopsis [Returns the given record.] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -Abc_Ntk_t * Abc_NtkRecUse() -{ - Abc_ManRec_t * p = s_pMan; - Abc_Ntk_t * pNtk = p->pNtk; - assert( p != NULL ); - Abc_NtkRecPs(0); - p->pNtk = NULL; - Abc_NtkRecStop(); - Abc_NtkCleanData(pNtk); - return pNtk; -} - - -/**Function************************************************************* - - Synopsis [Print statistics about the current record.] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -void Abc_NtkRecPs(int fPrintLib) -{ - int Counter, Counters[17] = {0}; - int CounterS, CountersS[17] = {0}; - Abc_ManRec_t * p = s_pMan; - Abc_Ntk_t * pNtk = p->pNtk; - Rec_Obj_t * pEntry, * pTemp; - Abc_Obj_t * pObj; - int i; - FILE * pFile; - unsigned* pTruth; - Rec_Obj_t* entry; - int j; - int nVars = s_pMan->nVars; - // set the max PI number - Abc_NtkForEachPi( pNtk, pObj, i ) - Abc_ObjSetMax( pObj, i+1 ); - Abc_AigForEachAnd( pNtk, pObj, i ) - Abc_ObjSetMax( pObj, Abc_MaxInt( Abc_ObjGetMax(Abc_ObjFanin0(pObj)), Abc_ObjGetMax(Abc_ObjFanin1(pObj)) ) ); -if(fPrintLib) -{ - pFile = fopen( "tt10.txt", "wb" ); -for ( i = 0; i < p->nBins; i++ ) - for ( entry = p->pBins[i]; entry; entry = entry->pCopy ) - { - int tmp = 0; - pTruth = (unsigned*)Vec_PtrEntry(p->vTtNodes, entry->Id); - /*if ( (int)Kit_TruthSupport(pTruth, nVars) != (1<<nVars)-1 ) - continue;*/ - Extra_PrintHex( pFile, pTruth, nVars ); - fprintf( pFile, " : nVars: %d, Frequency:%d, nBin:%d : ", Abc_ObjGetMax(entry->obj), entry->nFrequency, i); - Kit_DsdPrintFromTruth2( pFile, pTruth, Abc_ObjGetMax(entry->obj) ); - fprintf( pFile, "\n" ); - for ( pTemp = entry; pTemp; pTemp = pTemp->pNext ) - { - fprintf(pFile,"%d :", tmp); - for (j = 0; j <Abc_ObjGetMax(pTemp->obj); j++) - { - fprintf(pFile, " %d, ", pTemp->pinToPinDelay[j]); - } - fprintf(pFile, "cost = %d ID = %d\n", pTemp->cost, pTemp->Id); - tmp++; - } - fprintf( pFile, "\n"); - fprintf( pFile, "\n"); - } - fclose( pFile) ; -} - - // go through the table - Counter = CounterS = 0; - for ( i = 0; i < p->nBins; i++ ) - for ( pEntry = p->pBins[i]; pEntry; pEntry = pEntry->pCopy ) - { - assert(Abc_ObjGetMax(pEntry->obj) >= 2); - Counters[ Abc_ObjGetMax(pEntry->obj)]++; - Counter++; - for ( pTemp = pEntry; pTemp; pTemp = pTemp->pNext ) - { - assert( Abc_ObjGetMax(pTemp->obj) == Abc_ObjGetMax(pEntry->obj) ); - CountersS[ Abc_ObjGetMax(pTemp->obj) ]++; - CounterS++; - } - } - //printf( "Functions = %d. Expected = %d.\n", Counter, p->nAddedFuncs ); - //printf( "Subgraphs = %d. Expected = %d.\n", CounterS, p->nAdded ); - assert( Counter == p->nAddedFuncs ); - assert( CounterS == p->nAdded ); - // clean - Abc_NtkForEachObj( pNtk, pObj, i ) - { - Abc_ObjClearMax( pObj ); - } - printf( "The record with %d AND nodes in %d subgraphs for %d functions with %d inputs:\n", - Abc_NtkNodeNum(pNtk), Abc_NtkPoNum(pNtk), p->nAddedFuncs, Abc_NtkPiNum(pNtk) ); - for ( i = 0; i <= 16; i++ ) - { - if ( Counters[i] ) - printf( "Inputs = %2d. Funcs = %8d. Subgrs = %8d. Ratio = %6.2f.\n", i, Counters[i], CountersS[i], 1.0*CountersS[i]/Counters[i] ); - } - - printf( "Subgraphs tried = %10d. (%6.2f %%)\n", p->nTried, !p->nTried? 0 : 100.0*p->nTried/p->nTried ); - printf( "Subgraphs filtered by support size = %10d. (%6.2f %%)\n", p->nFilterSize, !p->nTried? 0 : 100.0*p->nFilterSize/p->nTried ); - printf( "Subgraphs filtered by structural redundancy = %10d. (%6.2f %%)\n", p->nFilterRedund, !p->nTried? 0 : 100.0*p->nFilterRedund/p->nTried ); - printf( "Subgraphs filtered by volume = %10d. (%6.2f %%)\n", p->nFilterVolume, !p->nTried? 0 : 100.0*p->nFilterVolume/p->nTried ); - printf( "Subgraphs filtered by TT redundancy = %10d. (%6.2f %%)\n", p->nFilterTruth, !p->nTried? 0 : 100.0*p->nFilterTruth/p->nTried ); - printf( "Subgraphs filtered by error = %10d. (%6.2f %%)\n", p->nFilterError, !p->nTried? 0 : 100.0*p->nFilterError/p->nTried ); - printf( "Subgraphs filtered by isomorphism = %10d. (%6.2f %%)\n", p->nFilterSame, !p->nTried? 0 : 100.0*p->nFilterSame/p->nTried ); - printf( "Subgraphs added = %10d. (%6.2f %%)\n", p->nAdded, !p->nTried? 0 : 100.0*p->nAdded/p->nTried ); - printf( "Functions added = %10d. (%6.2f %%)\n", p->nAddedFuncs, !p->nTried? 0 : 100.0*p->nAddedFuncs/p->nTried ); - if(s_pMan->fTrim) - printf( "Functions trimed = %10d. (%6.2f %%)\n", p->nTrimed, !p->nTried? 0 : 100.0*p->nTrimed/p->nTried ); - p->timeOther = p->timeTotal - p->timeCollect - p->timeTruth - p->timeCanon - p->timeInsert - p->timeBuild - p->timeTrim - p->timeMerge - p->timeReHash; - ABC_PRTP( "Collecting nodes ", p->timeCollect, p->timeTotal); - ABC_PRTP( "Computing truth ", p->timeTruth, p->timeTotal ); - ABC_PRTP( "Canonicizing ", p->timeCanon, p->timeTotal ); - ABC_PRTP( "Building ", p->timeBuild, p->timeTotal ); - ABC_PRTP( "ReHash ", p->timeReHash, p->timeTotal ); - ABC_PRTP( "Merge ", p->timeMerge, p->timeTotal ); - ABC_PRTP( "Insert ", p->timeInsert, p->timeTotal); - if(s_pMan->fTrim) - ABC_PRTP( "Filter ", p->timeTrim, p->timeTotal); - ABC_PRTP( "Other ", p->timeOther, p->timeTotal ); - ABC_PRTP( "TOTAL ", p->timeTotal, p->timeTotal ); - - if ( p->nFunsFound ) - { - printf("\n"); - printf( "During rewriting found = %d and not found = %d functions.\n", p->nFunsFound, p->nFunsNotFound ); - printf( "Functions tried = %10d. (%6.2f %%)\n", p->nFunsTried, !p->nFunsTried? 0 : 100.0*p->nFunsTried/p->nFunsTried ); - printf( "Functions filtered by support = %10d. (%6.2f %%)\n", p->nFunsFilteredBysupport, !p->nFunsFilteredBysupport? 0 : 100.0*p->nFunsFilteredBysupport/p->nFunsTried ); - printf( "Functions not found in lib = %10d. (%6.2f %%)\n", p->nFunsNotFound, !p->nFunsNotFound? 0 : 100.0*p->nFunsNotFound/p->nFunsTried ); - printf( "Functions founded = %10d. (%6.2f %%)\n", p->nFunsFound, !p->nFunsFound? 0 : 100.0*p->nFunsFound/p->nFunsTried ); - printf( "Functions delay computed = %10d. Ratio = %6.2f.\n", p->nFunsDelayComput, !p->nFunsDelayComput? 0 : 1.0*p->nFunsDelayComput/p->nFunsFound ); - p->timeIfOther = p->timeIfTotal - p->timeIfCanonicize - p->timeIfComputDelay -p->timeIfDerive; - ABC_PRTP( "Canonicize ", p->timeIfCanonicize, p->timeIfTotal ); - ABC_PRTP( "Compute Delay ", p->timeIfComputDelay, p->timeIfTotal ); - ABC_PRTP( "Derive ", p->timeIfDerive, p->timeIfTotal ); - ABC_PRTP( "Other ", p->timeIfOther, p->timeIfTotal ); - ABC_PRTP( "TOTAL ", p->timeIfTotal, p->timeIfTotal ); - } - -} - - -/**Function************************************************************* - - Synopsis [Returns the hash key.] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -static inline unsigned Abc_NtkRecTableHash( unsigned * pTruth, int nVars, int nBins, int * pPrimes ) -{ - int i, nWords = Kit_TruthWordNum( nVars ); - unsigned uHash = 0; - for ( i = 0; i < nWords; i++ ) - uHash ^= pTruth[i] * pPrimes[i & 0x7]; - return uHash % nBins; -} - -/**Function************************************************************* - - Synopsis [Returns the given record.] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -Rec_Obj_t ** Abc_NtkRecTableLookup(Abc_ManRec_t* p, Rec_Obj_t ** pBins, int nBins, unsigned * pTruth, int nVars ) -{ - static int s_Primes[10] = { 1291, 1699, 2357, 4177, 5147, 5647, 6343, 7103, 7873, 8147 }; - Rec_Obj_t ** ppSpot, * pEntry; - ppSpot = pBins + Abc_NtkRecTableHash( pTruth, nVars, nBins, s_Primes ); - for ( pEntry = *ppSpot; pEntry; ppSpot = &pEntry->pCopy, pEntry = pEntry->pCopy ) - if ( Kit_TruthIsEqualWithPhase((unsigned *)Vec_PtrEntry(p->vTtNodes, pEntry->Id), pTruth, nVars) ) - return ppSpot; - return ppSpot; -} - -/**Function************************************************************* - - Synopsis [Computes the truth table of the node.] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -int Abc_NtkRecComputeTruth( Abc_Obj_t * pObj, Vec_Ptr_t * vTtNodes, int nVars ) -{ - unsigned * pTruth, * pTruth0, * pTruth1; - int RetValue; - assert( Abc_ObjIsNode(pObj) ); - pTruth = (unsigned *)Vec_PtrEntry( vTtNodes, pObj->Id ); - pTruth0 = (unsigned *)Vec_PtrEntry( vTtNodes, Abc_ObjFaninId0(pObj) ); - pTruth1 = (unsigned *)Vec_PtrEntry( vTtNodes, Abc_ObjFaninId1(pObj) ); - Kit_TruthAndPhase( pTruth, pTruth0, pTruth1, nVars, Abc_ObjFaninC0(pObj), Abc_ObjFaninC1(pObj) ); - assert( (pTruth[0] & 1) == pObj->fPhase ); - RetValue = ((pTruth[0] & 1) == pObj->fPhase); - return RetValue; -} - -/**Function************************************************************* - - Synopsis [Performs renoding as technology mapping.] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -void Abc_NtkRecAdd( Abc_Ntk_t * pNtk, int fUseSOPB) -{ - extern Abc_Ntk_t * Abc_NtkIf( Abc_Ntk_t * pNtk, If_Par_t * pPars ); - extern int Abc_NtkRecAddCut( If_Man_t * pIfMan, If_Obj_t * pRoot, If_Cut_t * pCut ); - - If_Par_t Pars, * pPars = &Pars; - Abc_Ntk_t * pNtkNew; - abctime clk = Abc_Clock(); - - if ( Abc_NtkGetChoiceNum( pNtk ) ) - printf( "Performing renoding with choices.\n" ); - - // set defaults - memset( pPars, 0, sizeof(If_Par_t) ); - // user-controlable paramters - pPars->nLutSize = s_pMan->nVarsInit; - pPars->nCutsMax = s_pMan->nCuts; - pPars->nFlowIters = 0; - pPars->nAreaIters = 0; - pPars->DelayTarget = -1; - pPars->Epsilon = (float)0.005; - pPars->fPreprocess = 0; - pPars->fArea = 1; - pPars->fFancy = 0; - pPars->fExpRed = 0; - pPars->fLatchPaths = 0; - pPars->fSeqMap = 0; - pPars->fVerbose = 0; - //pPars->fCutMin = 1; - // internal parameters - if (fUseSOPB) - { - pPars->fTruth = 1; - pPars->fUsePerm = 1; - pPars->fDelayOpt = 1; - } - else - { - pPars->fTruth = 0; - pPars->fUsePerm = 0; - pPars->fDelayOpt = 0; - } - pPars->nLatchesCi = 0; - pPars->nLatchesCo = 0; - pPars->pLutLib = NULL; // Abc_FrameReadLibLut(); - pPars->pTimesArr = NULL; - pPars->pTimesArr = NULL; - pPars->fUseBdds = 0; - pPars->fUseSops = 0; - pPars->fUseCnfs = 0; - pPars->fUseMv = 0; - pPars->fSkipCutFilter = 1; - pPars->pFuncCost = NULL; - pPars->pFuncUser = Abc_NtkRecAddCut; - - // perform recording - pNtkNew = Abc_NtkIf( pNtk, pPars ); - Abc_NtkDelete( pNtkNew ); -s_pMan->timeTotal += Abc_Clock() - clk; - -// if ( !Abc_NtkCheck( s_pMan->pNtk ) ) -// printf( "Abc_NtkRecAdd: The network check has failed.\n" ); -} - -/**Function************************************************************* - - Synopsis [Adds the cut function to the internal storage.] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -void Abc_NtkRecCollectNodes_rec( If_Obj_t * pNode, Vec_Ptr_t * vNodes ) -{ - if ( pNode->fMark ) - return; - pNode->fMark = 1; - assert( If_ObjIsAnd(pNode) ); - Abc_NtkRecCollectNodes_rec( If_ObjFanin0(pNode), vNodes ); - Abc_NtkRecCollectNodes_rec( If_ObjFanin1(pNode), vNodes ); - Vec_PtrPush( vNodes, pNode ); -} - -/**Function************************************************************* - - Synopsis [Adds the cut function to the internal storage.] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -void Abc_NtkRecCollectNodesFromLib_rec( Abc_Obj_t * pNode, Vec_Ptr_t * vNodes ) -{ - if ( Abc_ObjIsPi(pNode)) - return; - Abc_NtkRecCollectNodesFromLib_rec( Abc_ObjFanin0(pNode), vNodes ); - Abc_NtkRecCollectNodesFromLib_rec( Abc_ObjFanin1(pNode), vNodes ); - Vec_PtrPush( vNodes, pNode ); -} - -/**Function************************************************************* - - Synopsis [Adds the cut function to the internal storage.] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -int Abc_NtkRecCollectNodes( If_Man_t * pIfMan, If_Obj_t * pRoot, If_Cut_t * pCut, Vec_Ptr_t * vNodes ) -{ - If_Obj_t * pLeaf; - int i, RetValue = 1; - - // collect the internal nodes of the cut - Vec_PtrClear( vNodes ); - If_CutForEachLeaf( pIfMan, pCut, pLeaf, i ) - { - Vec_PtrPush( vNodes, pLeaf ); - assert( pLeaf->fMark == 0 ); - pLeaf->fMark = 1; - } - - // collect other nodes - Abc_NtkRecCollectNodes_rec( pRoot, vNodes ); - - // check if there are leaves, such that both of their fanins are marked - // this indicates a redundant cut - If_CutForEachLeaf( pIfMan, pCut, pLeaf, i ) - { - if ( !If_ObjIsAnd(pLeaf) ) - continue; - if ( If_ObjFanin0(pLeaf)->fMark && If_ObjFanin1(pLeaf)->fMark ) - { - RetValue = 0; - break; - } - } - - // clean the mark - Vec_PtrForEachEntry( If_Obj_t *, vNodes, pLeaf, i ) - pLeaf->fMark = 0; -/* - if ( pRoot->Id == 2639 ) - { - // print the cut - Vec_PtrForEachEntry( If_Obj_t *, vNodes, pLeaf, i ) - { - if ( If_ObjIsAnd(pLeaf) ) - printf( "%4d = %c%4d & %c%4d\n", pLeaf->Id, - (If_ObjFaninC0(pLeaf)? '-':'+'), If_ObjFanin0(pLeaf)->Id, - (If_ObjFaninC1(pLeaf)? '-':'+'), If_ObjFanin1(pLeaf)->Id ); - else - printf( "%4d = pi\n", pLeaf->Id ); - } - printf( "\n" ); - } -*/ - return RetValue; -} - -/**Function************************************************************* - - Synopsis [Adds the cut function to the internal storage.] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -void Abc_NtkRecCollectNodesFromLib(Abc_Ntk_t* pNtk, Abc_Obj_t * pRoot, Vec_Ptr_t * vNodes , int nVars) -{ - int i; - // collect the internal nodes of the cut - Vec_PtrClear( vNodes ); - for ( i = 0; i < nVars; i++ ) - Vec_PtrPush( vNodes, Abc_NtkPi(pNtk, i)); - - - // collect other nodes - Abc_NtkRecCollectNodesFromLib_rec( pRoot, vNodes ); -} - -/**Function************************************************************* - - Synopsis [Computes truth tables of nodes in the cut.] - - Description [Returns 0 if the TT does not depend on some cut variables. - Or if the TT can be expressed simpler using other nodes.] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -int Abc_NtkRecCutTruth( Vec_Ptr_t * vNodes, int nLeaves, Vec_Ptr_t * vTtTemps, Vec_Ptr_t * vTtElems ) -{ - unsigned * pSims, * pSims0, * pSims1; - unsigned * pTemp = s_pMan->pTemp2; - unsigned uWord; - If_Obj_t * pObj, * pObj2, * pRoot; - int i, k, nLimit, nInputs = s_pMan->nVars; - - assert( Vec_PtrSize(vNodes) > nLeaves ); - - // set the elementary truth tables and compute the truth tables of the nodes - Vec_PtrForEachEntry( If_Obj_t *, vNodes, pObj, i ) - { - pObj->pCopy = Vec_PtrEntry(vTtTemps, i); - pSims = (unsigned *)pObj->pCopy; - if ( i < nLeaves ) - { - Kit_TruthCopy( pSims, (unsigned *)Vec_PtrEntry(vTtElems, i), nInputs ); - continue; - } - assert( If_ObjIsAnd(pObj) ); - // get hold of the simulation information - pSims0 = (unsigned *)If_ObjFanin0(pObj)->pCopy; - pSims1 = (unsigned *)If_ObjFanin1(pObj)->pCopy; - // simulate the node - Kit_TruthAndPhase( pSims, pSims0, pSims1, nInputs, If_ObjFaninC0(pObj), If_ObjFaninC1(pObj) ); - } - - // check the support size - pRoot = (If_Obj_t *)Vec_PtrEntryLast( vNodes ); - pSims = (unsigned *)pRoot->pCopy; - if ( Kit_TruthSupport(pSims, nInputs) != Kit_BitMask(nLeaves) ) - return 0; - - // make sure none of the nodes has the same simulation info as the output - // check pairwise comparisons - nLimit = Vec_PtrSize(vNodes) - 1; - Vec_PtrForEachEntryStop( If_Obj_t *, vNodes, pObj, i, nLimit ) - { - pSims0 = (unsigned *)pObj->pCopy; - if ( Kit_TruthIsEqualWithPhase(pSims, pSims0, nInputs) ) - return 0; - Vec_PtrForEachEntryStop( If_Obj_t *, vNodes, pObj2, k, i ) - { - if ( (If_ObjFanin0(pRoot) == pObj && If_ObjFanin1(pRoot) == pObj2) || - (If_ObjFanin1(pRoot) == pObj && If_ObjFanin0(pRoot) == pObj2) ) - continue; - pSims1 = (unsigned *)pObj2->pCopy; - - uWord = pSims0[0] & pSims1[0]; - if ( pSims[0] == uWord || pSims[0] == ~uWord ) - { - Kit_TruthAndPhase( pTemp, pSims0, pSims1, nInputs, 0, 0 ); - if ( Kit_TruthIsEqualWithPhase(pSims, pTemp, nInputs) ) - return 0; - } - - uWord = pSims0[0] & ~pSims1[0]; - if ( pSims[0] == uWord || pSims[0] == ~uWord ) - { - Kit_TruthAndPhase( pTemp, pSims0, pSims1, nInputs, 0, 1 ); - if ( Kit_TruthIsEqualWithPhase(pSims, pTemp, nInputs) ) - return 0; - } - - uWord = ~pSims0[0] & pSims1[0]; - if ( pSims[0] == uWord || pSims[0] == ~uWord ) - { - Kit_TruthAndPhase( pTemp, pSims0, pSims1, nInputs, 1, 0 ); - if ( Kit_TruthIsEqualWithPhase(pSims, pTemp, nInputs) ) - return 0; - } - - uWord = ~pSims0[0] & ~pSims1[0]; - if ( pSims[0] == uWord || pSims[0] == ~uWord ) - { - Kit_TruthAndPhase( pTemp, pSims0, pSims1, nInputs, 1, 1 ); - if ( Kit_TruthIsEqualWithPhase(pSims, pTemp, nInputs) ) - return 0; - } - } - } - return 1; -} - -/**Function************************************************************* - - Synopsis [Computes truth tables of nodes in the cut.] - - Description [Returns 0 if the TT does not depend on some cut variables. - Or if the TT can be expressed simpler using other nodes.] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -void Abc_NtkRecCutTruthFromLib( Vec_Ptr_t * vNodes, int nLeaves, Vec_Ptr_t * vTtTemps, Vec_Ptr_t * vTtElems ) -{ - unsigned * pSims, * pSims0, * pSims1; - //unsigned * pTemp = s_pMan->pTemp2; - Abc_Obj_t * pObj, * pRoot; - int i, nInputs = s_pMan->nVars; - - assert( Vec_PtrSize(vNodes) > nLeaves ); - - // set the elementary truth tables and compute the truth tables of the nodes - Vec_PtrForEachEntry( Abc_Obj_t *, vNodes, pObj, i ) - { - pObj->pTemp = Vec_PtrEntry(vTtTemps, i); - pSims = (unsigned *)pObj->pTemp; - if ( i < nLeaves ) - { - Kit_TruthCopy( pSims, (unsigned *)Vec_PtrEntry(vTtElems, i), nInputs ); - continue; - } - // get hold of the simulation information - pSims0 = (unsigned *)Abc_ObjFanin0(pObj)->pTemp; - pSims1 = (unsigned *)Abc_ObjFanin1(pObj)->pTemp; - // simulate the node - Kit_TruthAndPhase( pSims, pSims0, pSims1, nInputs, Abc_ObjFaninC0(pObj), Abc_ObjFaninC1(pObj) ); - } - - // check the support size - pRoot = (Abc_Obj_t *)Vec_PtrEntryLast( vNodes ); - pSims = (unsigned *)pRoot->pTemp; - assert ( Kit_TruthSupport(pSims, nInputs) == Kit_BitMask(nLeaves) ); -} - -/**Function************************************************************* - - Synopsis [Adds the cut function to the internal storage.] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -int Abc_NtkRecAddCutCheckCycle_rec( Abc_Obj_t * pRoot, Abc_Obj_t * pObj ) -{ - assert( pRoot->Level > 0 ); - if ( pObj->Level < pRoot->Level ) - return 1; - if ( pObj == pRoot ) - return 0; - if ( !Abc_NtkRecAddCutCheckCycle_rec(pRoot, Abc_ObjFanin0(pObj)) ) - return 0; - if ( !Abc_NtkRecAddCutCheckCycle_rec(pRoot, Abc_ObjFanin1(pObj)) ) - return 0; - return 1; -} - - -/**Function************************************************************* - - Synopsis [Building structures generated by SOPB.] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -void Abc_NtkRecAddSOPB( If_Man_t * pIfMan, If_Cut_t * pCut, unsigned* pInOut, char* pCanonPerm, unsigned uCanonPhase ) -{ - If_And_t Leaf; - int i, nNodes, RetValue, nNodesBeg, timeInsert; - Vec_Wrd_t * vAnds; - Abc_Ntk_t * pAig = s_pMan->pNtk; - Abc_Obj_t * pAbcObj, * pFanin0, * pFanin1, * pObj = NULL, * pObjPo; - static int s_MaxSize[16] = { 0 }; - int nLeaves = If_CutLeaveNum(pCut); - int nInputs = s_pMan->nVars; - word Entry; - If_And_t This; - Rec_Obj_t ** ppSpot; - char Buffer[40], Name[20], Truth[20]; - abctime timeBuild = Abc_Clock(); - unsigned * pTruth; - vAnds = If_CutDelaySopArray( pIfMan, pCut ); - if(Vec_WrdSize(vAnds) > nLeaves + 3*(nLeaves-1) + s_MaxSize[nLeaves]) - { - s_pMan->nFilterVolume++; - return; - } - Vec_PtrGrow(s_pMan->vLabels, Abc_NtkObjNumMax(pAig)); - s_pMan->vLabels->nSize = s_pMan->vLabels->nCap; - for (i = 0; i < nLeaves; i++) - { - pAbcObj = Abc_NtkPi( pAig, i ); - Leaf = If_WrdToAnd(Vec_WrdEntry(vAnds, pCanonPerm[i])); - pAbcObj = Abc_ObjNotCond(pAbcObj,Leaf.fCompl ^ ((uCanonPhase & (1 << i)) > 0)); - Vec_PtrWriteEntry(s_pMan->vLabels, Leaf.Id, pAbcObj); - } - nNodesBeg = Abc_NtkObjNumMax( pAig ); - Vec_WrdForEachEntryStart( vAnds, Entry, i, nLeaves ) - { - This = If_WrdToAnd( Entry ); - pFanin0 = Abc_ObjNotCond( (Abc_Obj_t *)Vec_PtrEntry(s_pMan->vLabels, This.iFan0), This.fCompl0 ); - pFanin1 = Abc_ObjNotCond( (Abc_Obj_t *)Vec_PtrEntry(s_pMan->vLabels, This.iFan1), This.fCompl1 ); - nNodes = Abc_NtkObjNumMax( pAig ); - pObj = Abc_AigAnd( (Abc_Aig_t *)pAig->pManFunc, pFanin0, pFanin1 ); - Vec_PtrWriteEntry(s_pMan->vLabels,This.Id,pObj); - assert( !Abc_ObjIsComplement(pObj) ); - - if ( pObj->Id == nNodes ) - { - // increase storage for truth tables - // if ( Vec_PtrSize(s_pMan->vTtNodes) <= pObj->Id ) - // Vec_PtrDoubleSimInfo(s_pMan->vTtNodes); - while ( Vec_PtrSize(s_pMan->vTtNodes) <= pObj->Id ) - // Vec_PtrPush( s_pMan->vTtNodes, ABC_ALLOC(unsigned, s_pMan->nWords) ); - Vec_PtrPush( s_pMan->vTtNodes, Mem_FixedEntryFetch(s_pMan->pMmTruth) ); - - // compute the truth table - RetValue = Abc_NtkRecComputeTruth( pObj, s_pMan->vTtNodes, nInputs ); - if ( RetValue == 0 ) - { - s_pMan->nFilterError++; - printf( "T" ); - return; - } - } - } - assert(pObj); - pTruth = (unsigned *)Vec_PtrEntry( s_pMan->vTtNodes, pObj->Id ); - if ( Kit_TruthSupport(pTruth, nInputs) != Kit_BitMask(nLeaves) ) - { - s_pMan->nFilterError++; - printf( "S" ); - return; - } - - // compare the truth tables - if ( !Kit_TruthIsEqualWithPhase( pTruth, pInOut, nInputs ) ) - { - s_pMan->nFilterError++; - printf( "F" ); - return; - } - s_pMan->timeBuild = Abc_Clock() - timeBuild; - // Extra_PrintBinary( stdout, pInOut, 8 ); printf( "\n" ); - - // look up in the hash table and increase the hit number of the functional class - if(s_pMan->nAddedFuncs > 2 * s_pMan->nBins) - Abc_NtkRecRezieHash(s_pMan); - ppSpot = Abc_NtkRecTableLookup(s_pMan, s_pMan->pBins,s_pMan->nBins , pTruth, nInputs ); - Abc_NtkRecFrequencyInc(*ppSpot); - // if not new nodes were added and the node has a CO fanout - - if ( nNodesBeg == Abc_NtkObjNumMax(pAig) && Abc_NodeFindCoFanout(pObj) != NULL ) - { - s_pMan->nFilterSame++; - //assert(*ppSpot != NULL); - return; - } - - // create PO for this node - pObjPo = Abc_NtkCreatePo(pAig); - Abc_ObjAddFanin( pObjPo, pObj ); - - // assign the name to this PO - sprintf( Name, "%d_%06d", nLeaves, Abc_NtkPoNum(pAig) ); - if ( (nInputs <= 6) && 0 ) - { - Extra_PrintHexadecimalString( Truth, pInOut, nInputs ); - sprintf( Buffer, "%s_%s", Name, Truth ); - } - else - { - sprintf( Buffer, "%s", Name ); - } - Abc_ObjAssignName( pObjPo, Buffer, NULL ); - - // add the resulting truth table to the hash table - timeInsert = Abc_Clock(); - ppSpot = Abc_NtkRecTableLookup(s_pMan, s_pMan->pBins, s_pMan->nBins, pTruth, s_pMan->nVars ); - Abc_NtkRecInsertToLookUpTable(s_pMan, ppSpot, pObj, nLeaves, s_pMan->fTrim); - s_pMan->timeInsert += Abc_Clock() - timeInsert; - s_pMan->timeTotal = Abc_Clock() - timeBuild; - return; - -} - -/**Function************************************************************* - - Synopsis [Adds the cut function to the internal storage.] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -int Abc_NtkRecAddCut( If_Man_t * pIfMan, If_Obj_t * pRoot, If_Cut_t * pCut ) -{ - static int s_MaxSize[16] = { 0 }; - char Buffer[40], Name[20], Truth[20]; - char pCanonPerm[16]; - Abc_Obj_t * pObj = NULL, * pFanin0, * pFanin1, * pObjPo; - Rec_Obj_t ** ppSpot; - Abc_Ntk_t * pAig = s_pMan->pNtk; - If_Obj_t * pIfObj; - Vec_Ptr_t * vNodes = s_pMan->vNodes; - unsigned * pInOut = s_pMan->pTemp1; - unsigned * pTemp = s_pMan->pTemp2; - unsigned * pTruth; - int i, RetValue, nNodes, nNodesBeg, nInputs = s_pMan->nVars, nLeaves = If_CutLeaveNum(pCut); - unsigned uCanonPhase; - abctime clk, timeInsert, timeBuild; - //int begin = Abc_Clock(); - assert( nInputs <= 16 ); - assert( nInputs == (int)pCut->nLimit ); - s_pMan->nTried++; - // skip small cuts - if ( nLeaves < 2 ) - { - s_pMan->nFilterSize++; - return 1; - } - - // collect internal nodes and skip redundant cuts -clk = Abc_Clock(); - RetValue = Abc_NtkRecCollectNodes( pIfMan, pRoot, pCut, vNodes ); - -s_pMan->timeCollect += Abc_Clock() - clk; - if ( !RetValue ) - { - s_pMan->nFilterRedund++; - return 1; - } - - // skip cuts with very large volume - if ( Vec_PtrSize(vNodes) > nLeaves + 3*(nLeaves-1) + s_MaxSize[nLeaves] ) - { - s_pMan->nFilterVolume++; - return 1; - } - - // compute truth table and skip the redundant structures -clk = Abc_Clock(); - RetValue = Abc_NtkRecCutTruth( vNodes, nLeaves, s_pMan->vTtTemps, s_pMan->vTtElems ); - s_pMan->timeTruth += Abc_Clock() - clk; - if ( !RetValue ) - { - //fprintf(file,"redundant structures\n"); - //fclose(file); - s_pMan->nFilterTruth++; - return 1; - } - - // copy the truth table - Kit_TruthCopy( pInOut, (unsigned *)pRoot->pCopy, nInputs ); - - // set permutation - for ( i = 0; i < nLeaves; i++ ) - pCanonPerm[i] = i; - - // semi-canonicize the truth table -clk = Abc_Clock(); - uCanonPhase = Kit_TruthSemiCanonicize( pInOut, pTemp, nLeaves, pCanonPerm ); - If_CutTruthStretch(pInOut, nLeaves, s_pMan->nVars); - s_pMan->timeCanon += Abc_Clock() - clk; - // pCanonPerm and uCanonPhase show what was the variable corresponding to each var in the current truth - - // go through the variables in the new truth table - timeBuild = Abc_Clock(); - for ( i = 0; i < nLeaves; i++ ) - { - // get hold of the corresponding leaf - pIfObj = If_ManObj( pIfMan, pCut->pLeaves[(int)pCanonPerm[i]] ); - // get hold of the corresponding new node - pObj = Abc_NtkPi( pAig, i ); - pObj = Abc_ObjNotCond( pObj, (uCanonPhase & (1 << i)) ); - // map them - pIfObj->pCopy = pObj; - } - - // build the node and compute its truth table - nNodesBeg = Abc_NtkObjNumMax( pAig ); - Vec_PtrForEachEntryStart( If_Obj_t *, vNodes, pIfObj, i, nLeaves ) - { - pFanin0 = Abc_ObjNotCond( (Abc_Obj_t *)If_ObjFanin0(pIfObj)->pCopy, If_ObjFaninC0(pIfObj) ); - pFanin1 = Abc_ObjNotCond( (Abc_Obj_t *)If_ObjFanin1(pIfObj)->pCopy, If_ObjFaninC1(pIfObj) ); - - nNodes = Abc_NtkObjNumMax( pAig ); - pObj = Abc_AigAnd( (Abc_Aig_t *)pAig->pManFunc, pFanin0, pFanin1 ); - assert( !Abc_ObjIsComplement(pObj) ); - pIfObj->pCopy = pObj; - - if ( pObj->Id == nNodes ) - { - // increase storage for truth tables -// if ( Vec_PtrSize(s_pMan->vTtNodes) <= pObj->Id ) -// Vec_PtrDoubleSimInfo(s_pMan->vTtNodes); - while ( Vec_PtrSize(s_pMan->vTtNodes) <= pObj->Id ) -// Vec_PtrPush( s_pMan->vTtNodes, ABC_ALLOC(unsigned, s_pMan->nWords) ); - Vec_PtrPush( s_pMan->vTtNodes, Mem_FixedEntryFetch(s_pMan->pMmTruth) ); - - // compute the truth table - RetValue = Abc_NtkRecComputeTruth( pObj, s_pMan->vTtNodes, nInputs ); - if ( RetValue == 0 ) - { - s_pMan->nFilterError++; - printf( "T" ); - return 1; - } - } - } - assert(pObj); - s_pMan->timeBuild += Abc_Clock() - timeBuild; - pTruth = (unsigned *)Vec_PtrEntry( s_pMan->vTtNodes, pObj->Id ); - if ( Kit_TruthSupport(pTruth, nInputs) != Kit_BitMask(nLeaves) ) - { - s_pMan->nFilterError++; - printf( "S" ); - return 1; - } - - // compare the truth tables - if ( !Kit_TruthIsEqualWithPhase( pTruth, pInOut, nInputs ) ) - { - s_pMan->nFilterError++; - printf( "F" ); - return 1; - } -// Extra_PrintBinary( stdout, pInOut, 8 ); printf( "\n" ); - - // look up in the hash table and increase the hit number of the functional class - if(s_pMan->nAddedFuncs > 2 * s_pMan->nBins) - Abc_NtkRecRezieHash(s_pMan); - ppSpot = Abc_NtkRecTableLookup(s_pMan, s_pMan->pBins,s_pMan->nBins , pTruth, nInputs ); - Abc_NtkRecFrequencyInc(*ppSpot); - // if not new nodes were added and the node has a CO fanout - - if ( nNodesBeg == Abc_NtkObjNumMax(pAig) && Abc_NodeFindCoFanout(pObj) != NULL ) - { - s_pMan->nFilterSame++; - //assert(*ppSpot != NULL); - return 1; - } - - // create PO for this node - pObjPo = Abc_NtkCreatePo(pAig); - Abc_ObjAddFanin( pObjPo, pObj ); - - // assign the name to this PO - sprintf( Name, "%d_%06d", nLeaves, Abc_NtkPoNum(pAig) ); - if ( (nInputs <= 6) && 0 ) - { - Extra_PrintHexadecimalString( Truth, pInOut, nInputs ); - sprintf( Buffer, "%s_%s", Name, Truth ); - } - else - { - sprintf( Buffer, "%s", Name ); - } - Abc_ObjAssignName( pObjPo, Buffer, NULL ); - - // add the resulting truth table to the hash table - timeInsert = Abc_Clock(); - Abc_NtkRecInsertToLookUpTable(s_pMan, ppSpot, pObj, nLeaves, s_pMan->fTrim); - s_pMan->timeInsert += Abc_Clock() - timeInsert; - if (pIfMan->pPars->fDelayOpt) - Abc_NtkRecAddSOPB(pIfMan, pCut, pTruth, pCanonPerm, uCanonPhase ); - return 1; -} - -/**Function************************************************************* - - Synopsis [Adds the cut function to the internal storage.] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -void Abc_NtkRecAddFromLib( Abc_Ntk_t* pNtk, Abc_Obj_t * pRoot, int nVars ) -{ - char Buffer[40], Name[20], Truth[20]; - Abc_Obj_t * pObj = NULL, * pFanin0, * pFanin1, * pObjPo; - Rec_Obj_t ** ppSpot; - Abc_Ntk_t * pAig = s_pMan->pNtk; - Abc_Obj_t * pAbcObj; - Vec_Ptr_t * vNodes = s_pMan->vNodes; - unsigned * pInOut = s_pMan->pTemp1; - //unsigned * pTemp = s_pMan->pTemp2; - unsigned * pTruth; - int i, RetValue, nNodes, nNodesBeg, nInputs = s_pMan->nVars, nLeaves = nVars; - assert( nInputs <= 16 ); - // collect internal nodes and skip redundant cuts - Abc_NtkRecCollectNodesFromLib(pNtk, pRoot, vNodes , nLeaves); - Abc_NtkRecCutTruthFromLib(vNodes, nLeaves, s_pMan->vTtTemps, s_pMan->vTtElems ); - // copy the truth table - Kit_TruthCopy( pInOut, (unsigned *)pRoot->pTemp, nInputs ); - // go through the variables in the new truth table - for ( i = 0; i < nLeaves; i++ ) - { - // get hold of the corresponding leaf - pAbcObj = Abc_NtkPi(pNtk, i); - // get hold of the corresponding new node - pObj = Abc_NtkPi( pAig, i ); - // map them - pAbcObj->pCopy = pObj; - } - - // build the node and compute its truth table - nNodesBeg = Abc_NtkObjNumMax( pAig ); - Vec_PtrForEachEntryStart( Abc_Obj_t *, vNodes, pAbcObj, i, nLeaves ) - { - pFanin0 = Abc_ObjNotCond( (Abc_Obj_t *)Abc_ObjFanin0(pAbcObj)->pCopy, Abc_ObjFaninC0(pAbcObj) ); - pFanin1 = Abc_ObjNotCond( (Abc_Obj_t *)Abc_ObjFanin1(pAbcObj)->pCopy, Abc_ObjFaninC1(pAbcObj) ); - - nNodes = Abc_NtkObjNumMax( pAig ); - pObj = Abc_AigAnd( (Abc_Aig_t *)pAig->pManFunc, pFanin0, pFanin1 ); - assert( !Abc_ObjIsComplement(pObj) ); - pAbcObj->pCopy = pObj; - - if ( pObj->Id == nNodes ) - { - // increase storage for truth tables -// if ( Vec_PtrSize(s_pMan->vTtNodes) <= pObj->Id ) -// Vec_PtrDoubleSimInfo(s_pMan->vTtNodes); - while ( Vec_PtrSize(s_pMan->vTtNodes) <= pObj->Id ) -// Vec_PtrPush( s_pMan->vTtNodes, ABC_ALLOC(unsigned, s_pMan->nWords) ); - Vec_PtrPush( s_pMan->vTtNodes, Mem_FixedEntryFetch(s_pMan->pMmTruth) ); - // compute the truth table - RetValue = Abc_NtkRecComputeTruth( pObj, s_pMan->vTtNodes, nInputs ); - if ( RetValue == 0 ) - { - s_pMan->nFilterError++; - printf( "T" ); - } - } - } - assert(pObj); - pTruth = (unsigned *)Vec_PtrEntry( s_pMan->vTtNodes, pObj->Id ); - assert ( Kit_TruthSupport(pTruth, nInputs) == Kit_BitMask(nLeaves) ); - // compare the truth tables - assert (Kit_TruthIsEqual( pTruth, pInOut, nInputs ) ); - -// Extra_PrintBinary( stdout, pInOut, 8 ); printf( "\n" ); - - // look up in the hash table and increase the hit number of the functional class - if(s_pMan->nAddedFuncs > 2 * s_pMan->nBins) - Abc_NtkRecRezieHash(s_pMan); - ppSpot = Abc_NtkRecTableLookup(s_pMan, s_pMan->pBins, s_pMan->nBins, pTruth, nInputs ); - - // if not new nodes were added and the node has a CO fanout - if ( nNodesBeg == Abc_NtkObjNumMax(pAig) && Abc_NodeFindCoFanout(pObj) != NULL ) - { - s_pMan->nFilterSame++; - //assert(*ppSpot != NULL); - return; - } - - // create PO for this node - pObjPo = Abc_NtkCreatePo(pAig); - Abc_ObjAddFanin( pObjPo, pObj ); - - // assign the name to this PO - sprintf( Name, "%d_%06d", nLeaves, Abc_NtkPoNum(pAig) ); - if ( (nInputs <= 6) && 0 ) - { - Extra_PrintHexadecimalString( Truth, pInOut, nInputs ); - sprintf( Buffer, "%s_%s", Name, Truth ); - } - else - { - sprintf( Buffer, "%s", Name ); - } - Abc_ObjAssignName( pObjPo, Buffer, NULL ); - - // add the resulting truth table to the hash table - Abc_NtkRecInsertToLookUpTable(s_pMan, ppSpot, pObj, nLeaves, s_pMan->fTrim); -} - -/**Function************************************************************* - - Synopsis [Prints one AIG sugraph recursively.] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -void Abc_RecPrint_rec( Abc_Obj_t * pObj ) -{ - if ( Abc_ObjIsPi(pObj) ) - { - printf( "%c", 'a' + pObj->Id - 1 ); - return; - } - assert( Abc_ObjIsNode(pObj) ); - printf( "(%s", Abc_ObjFaninC0(pObj)? "!" : "" ); - Abc_RecPrint_rec( Abc_ObjFanin0(pObj) ); - printf( "*%s", Abc_ObjFaninC1(pObj)? "!" : "" ); - Abc_RecPrint_rec( Abc_ObjFanin1(pObj) ); - printf( ")" ); -} - -/**Function************************************************************* - - Synopsis [back up the info of the cut.] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -void Abc_NtkRecBackUpCut(If_Cut_t* pCut) -{ - int i; - s_pMan->tempUsign = pCut->uSign; - s_pMan->tempNleaves = pCut->nLeaves; - for (i = 0; i < (int)pCut->nLeaves; i++) - s_pMan->pTempleaves[i] = pCut->pLeaves[i]; -// Kit_TruthCopy(s_pMan->pTempTruth, pCut->pTruth, s_pMan->nVars); -} - -/**Function************************************************************* - - Synopsis [restore the info of the cut.] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -void Abc_NtkRecRestoreCut(If_Cut_t* pCut) -{ - int i; - pCut->uSign = s_pMan->tempUsign; - pCut->nLeaves = s_pMan->tempNleaves; - for (i = 0; i < (int)pCut->nLeaves; i++) - pCut->pLeaves[i] = s_pMan->pTempleaves[i]; -// Kit_TruthCopy(pCut->pTruth ,s_pMan->pTempTruth, s_pMan->nVars); -} - -/**Function************************************************************* - - Synopsis [compute current cut's area.] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -void Abc_NtkRecCurrentUnMark_rec(If_Obj_t * pObj) -{ - pObj = If_Regular(pObj); - if(pObj->fMark == 0) - return; - if(pObj->pFanin0) - Abc_NtkRecCurrentUnMark_rec(If_ObjFanin0(pObj)); - if(pObj->pFanin1) - Abc_NtkRecCurrentUnMark_rec(If_ObjFanin1(pObj)); - pObj->fMark = 0; - return; -} - -/**Function************************************************************* - - Synopsis [compute current cut's area.] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -int Abc_NtkRecCurrentMarkAndCount_rec(If_Obj_t * pObj) -{ - int Area0, Area1, Area; - pObj = If_Regular(pObj); - if(pObj->fMark == 1) - return 0; - Area0 = Abc_NtkRecCurrentMarkAndCount_rec(If_ObjFanin0(pObj)); - Area1 = Abc_NtkRecCurrentMarkAndCount_rec(If_ObjFanin1(pObj)); - Area = Area1 + Area0 + 1; - pObj->fMark = 1; - return Area; -} - -/**Function************************************************************* - - Synopsis [compute current cut's area.] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -int Abc_NtkRecCurrentAera(If_Man_t* p, If_Cut_t* pCut, If_Obj_t * pRoot) -{ - int Area, i; - If_Obj_t * pLeaf; - Vec_PtrClear( s_pMan->vNodes ); - If_CutForEachLeaf( p, pCut, pLeaf, i ) - { - Vec_PtrPush( s_pMan->vNodes, pLeaf ); - assert( pLeaf->fMark == 0 ); - pLeaf->fMark = 1; - } - - // collect other nodes - Abc_NtkRecCollectNodes_rec( pRoot, s_pMan->vNodes ); - Vec_PtrForEachEntry( If_Obj_t *, s_pMan->vNodes, pLeaf, i ) - pLeaf->fMark = 0; - If_CutForEachLeaf(p, pCut, pLeaf, i) - pLeaf->fMark = 1; - Area = Abc_NtkRecCurrentMarkAndCount_rec(pRoot); - Abc_NtkRecCurrentUnMark_rec(pRoot); - return Area; -} - -/**Function************************************************************* - - Synopsis [compute current cut's delay.] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -char Abc_NtkRecCurrentDepth_rec(If_Obj_t * pObj, int iLeaf) -{ - char Depth0, Depth1, Depth; - pObj = If_Regular(pObj); - if(pObj->Id == iLeaf) - return 0; - if(pObj->fMark) - return -IF_BIG_CHAR; - Depth0 = Abc_NtkRecCurrentDepth_rec(If_ObjFanin0(pObj), iLeaf); - Depth1 = Abc_NtkRecCurrentDepth_rec(If_ObjFanin1(pObj), iLeaf); - Depth = Abc_MaxInt(Depth0, Depth1); - Depth = (Depth == -IF_BIG_CHAR) ? -IF_BIG_CHAR : Depth + 1; -// assert(Depth <= 127); - return Depth; -} - -/**Function************************************************************* - - Synopsis [compute current cut's delay.] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -void Abc_NtkRecCurrentDepth(If_Man_t* p, If_Cut_t* pCut, If_Obj_t * pRoot) -{ - int i; - If_Obj_t * pLeaf; - If_CutForEachLeaf(p, pCut, pLeaf, i) - pLeaf->fMark = 1; - If_CutForEachLeaf(p, pCut, pLeaf, i) - s_pMan->pTempDepths[i] = Abc_NtkRecCurrentDepth_rec(pRoot, pLeaf->Id); - If_CutForEachLeaf(p, pCut, pLeaf, i) - pLeaf->fMark = 0; -} - -/**Function************************************************************* - - Synopsis [compute current cut's delay.] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -int Abc_NtkRecCurrentDelay(If_Man_t* p, If_Cut_t* pCut, If_Obj_t * pRoot) -{ - If_Obj_t* pLeaf; - int i, delayTemp, delayMax = -ABC_INFINITY; - Abc_NtkRecCurrentDepth(p , pCut, pRoot); - If_CutForEachLeaf(p, pCut, pLeaf, i) - { - delayTemp = s_pMan->pTempDepths[i] + If_ObjCutBest(pLeaf)->Delay; - if(delayTemp > delayMax) - delayMax = delayTemp; - } - // plus each pin's delay with its pin-to-output delay, the biggest one is the delay of the structure. - return delayMax; -} - -/**Function************************************************************* - - Synopsis [compute current cut's delay and area.] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -void Abc_NtkRecComputCurrentStructure(If_Man_t* p, If_Cut_t* pCut, If_Obj_t * pRoot) -{ -// if (pRoot->Id == 78) -// { -// int a = 1; -// } - - s_pMan->currentCost = Abc_NtkRecCurrentAera(p, pCut, pRoot); - s_pMan->currentDelay = Abc_NtkRecCurrentDelay(p, pCut, pRoot); -} - -/**Function************************************************************* - - Synopsis [the cut not found in the library.] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -void SetUselessCut(If_Cut_t* pCut) -{ - int i; - pCut->fUseless = 1; - pCut->fUser = 1; - pCut->Cost = s_pMan->currentCost; - for (i = 0; i < (int)pCut->nLeaves; i++) - pCut->pPerm[i] = s_pMan->pTempDepths[i]; - return; -} - -/**Function************************************************************* - - Synopsis [the cut not found in the library.] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -void SetUseCut(If_Cut_t* pCut, Rec_Obj_t * pRecObj, char * pCanonPerm) -{ - int i; - pCut->fUseless = 0; - pCut->fUser = 1; - pCut->Cost = pRecObj->cost; - for (i = 0; i < (int)pCut->nLeaves; i++) - pCut->pPerm[(int)pCanonPerm[i]] = pRecObj->pinToPinDelay[i]; - return; - -} - -/**Function************************************************************* - - Synopsis [Computes the delay using library.] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -int If_CutDelayRecCost(If_Man_t* p, If_Cut_t* pCut, If_Obj_t * pObj) -{ - //int fVerbose = 0; - abctime timeDelayComput, timeTotal = Abc_Clock(), timeCanonicize; - int nLeaves, i, DelayMin = ABC_INFINITY , * pDelayBest = &DelayMin; - char pCanonPerm[16]; - unsigned uCanonPhase; - unsigned* pTruthRec; - Rec_Obj_t *pCandMin; - //Abc_Ntk_t *pAig = s_pMan->pNtk; - unsigned *pInOut = s_pMan->pTemp1; - unsigned *pTemp = s_pMan->pTemp2; - int nVars = s_pMan->nVars; - //int Counter; - assert( s_pMan != NULL ); - nLeaves = If_CutLeaveNum(pCut); - s_pMan->nFunsTried++; - assert( nLeaves >= 2 && nLeaves <= nVars ); - Kit_TruthCopy(pInOut, If_CutTruth(p, pCut), nLeaves); - //if not every variables are in the support, skip this cut. - if ( Kit_TruthSupport(pInOut, nLeaves) != Kit_BitMask(nLeaves) ) - { - DelayMin = 0; - //s_pMan->nFunsFilteredBysupport++; - pCut->fUser = 1; - pCut->fUseless = 0; - pCut->Cost = 1; - for (i = 0; i < nLeaves; i++) - { - if(Kit_TruthVarInSupport( pInOut, nLeaves, i )) - { - pCut->pPerm[i] = 0; - DelayMin = If_ObjCutBest(If_ManObj( p, pCut->pLeaves[i]))->Delay; - } - else - pCut->pPerm[i] = IF_BIG_CHAR; - } - - return DelayMin; - } - timeCanonicize = Abc_Clock(); - //canonicize - for (i = 0; i < nLeaves; i++) - pCanonPerm[i] = i; - uCanonPhase = Kit_TruthSemiCanonicize(pInOut, pTemp, nLeaves, pCanonPerm); - If_CutTruthStretch(pInOut, nLeaves, nVars); - s_pMan->timeIfCanonicize += Abc_Clock() - timeCanonicize; - timeDelayComput = Abc_Clock(); - pCandMin = Abc_NtkRecLookUpBest(p, pCut, pInOut, pCanonPerm, NULL,pDelayBest); - assert (!(pCandMin == NULL && nLeaves == 2)); - s_pMan->timeIfComputDelay += Abc_Clock() - timeDelayComput; - //functional class not found in the library. - if ( pCandMin == NULL ) - { - s_pMan->nFunsNotFound++; - pCut->Cost = IF_COST_MAX; - pCut->fUser = 1; - pCut->fUseless = 1; - return ABC_INFINITY; - } - s_pMan->nFunsFound++; - // make sure the truth table is the same - pTruthRec = (unsigned*)Vec_PtrEntry( s_pMan->vTtNodes, pCandMin->Id ); - if ( !Kit_TruthIsEqualWithPhase( pTruthRec, pInOut, nLeaves ) ) - { - assert( 0 ); - s_pMan->nIfMapError++; - return -1; - } - // mark as user cut. - pCut->fUser = 1; - - -// if ( fVerbose ) -// Kit_DsdPrintFromTruth( pInOut, nLeaves ), printf( " Subgraphs: " ); - - //find the best structure of the functional class. -// Counter = 0; -// for ( pCand = *ppSpot; pCand; pCand = pCand->pNext ) -// { -// Counter++; -// if ( fVerbose ) -// { -// printf( "%s(", Abc_ObjIsComplement(pCand->obj)? "!" : "" ); -// Abc_RecPrint_rec( Abc_ObjRegular(pCand->obj) ); -// printf( ") " ); -// } -// s_pMan->nFunsDelayComput++; -// Delay = If_CutComputDelay(p, pCand, pCut, pCanonPerm ,nLeaves); -// if ( DelayMin > Delay ) -// { -// // printf( "%d ", Cost ); -// DelayMin = Delay; -// pCandMin = pCand; -// } -// else if(Delay == DelayMin) -// { -// if(pCand->cost < pCandMin->cost) -// pCandMin = pCand; -// } -// } -// if ( fVerbose ) -// printf( "Printed %d subgraphs.\n", Counter ); - - //assert( pCandMin != NULL ); - for ( i = 0; i < nLeaves; i++ ) - { - pCut->pPerm[(int)pCanonPerm[i]] = pCandMin->pinToPinDelay[i]; - } - s_pMan->timeIfTotal += Abc_Clock() - timeTotal; - pCut->Cost = pCandMin->cost; - return DelayMin; - -} - -/**Function************************************************************* - - Synopsis [Labels the record AIG with the corresponding new AIG nodes.] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -/*Abc_Obj_t * Abc_NtkRecStrashNodeLabel_rec( Abc_Ntk_t * pNtkNew, Abc_Obj_t * pObj, int fBuild, Vec_Ptr_t * vLabels ) -{ - Abc_Obj_t * pFanin0New, * pFanin1New, * pLabel; - assert( !Abc_ObjIsComplement(pObj) ); - // if this node is already visited, skip - if ( Abc_NodeIsTravIdCurrent( pObj ) ) - return (Abc_Obj_t *)Vec_PtrEntry( vLabels, pObj->Id ); - assert( Abc_ObjIsNode(pObj) ); - // mark the node as visited - Abc_NodeSetTravIdCurrent( pObj ); - // label the fanins - pFanin0New = Abc_NtkRecStrashNodeLabel_rec( pNtkNew, Abc_ObjFanin0(pObj), fBuild, vLabels ); - pFanin1New = Abc_NtkRecStrashNodeLabel_rec( pNtkNew, Abc_ObjFanin1(pObj), fBuild, vLabels ); - // label the node if possible - pLabel = NULL; - if ( pFanin0New && pFanin1New ) - { - pFanin0New = Abc_ObjNotCond( pFanin0New, Abc_ObjFaninC0(pObj) ); - pFanin1New = Abc_ObjNotCond( pFanin1New, Abc_ObjFaninC1(pObj) ); - if ( fBuild ) - pLabel = Abc_AigAnd( (Abc_Aig_t *)pNtkNew->pManFunc, pFanin0New, pFanin1New ); - else - pLabel = Abc_AigAndLookup( (Abc_Aig_t *)pNtkNew->pManFunc, pFanin0New, pFanin1New ); - } - Vec_PtrWriteEntry( vLabels, pObj->Id, pLabel ); - return pLabel; -}*/ - -/**Function************************************************************* - - Synopsis [Counts the area of the given node.] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -/*int Abc_NtkRecStrashNodeCount_rec( Abc_Obj_t * pObj, Vec_Str_t * vCosts, Vec_Ptr_t * vLabels ) -{ - int Cost0, Cost1; - if ( Vec_PtrEntry( vLabels, pObj->Id ) ) - return 0; - assert( Abc_ObjIsNode(pObj) ); - // if this node is already visited, skip - if ( Abc_NodeIsTravIdCurrent( pObj ) ) - return Vec_StrEntry( vCosts, pObj->Id ); - // mark the node as visited - Abc_NodeSetTravIdCurrent( pObj ); - // count for the fanins - Cost0 = Abc_NtkRecStrashNodeCount_rec( Abc_ObjFanin0(pObj), vCosts, vLabels ); - Cost1 = Abc_NtkRecStrashNodeCount_rec( Abc_ObjFanin1(pObj), vCosts, vLabels ); - Vec_StrWriteEntry( vCosts, pObj->Id, (char)(Cost0 + Cost1 + 1) ); - return Cost0 + Cost1 + 1; -}*/ - -/**Function************************************************************* - - Synopsis [Strashes the given node using its local function.] - - Description [Assumes that the fanins are already strashed. - Returns 0 if the function is not found in the table.] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -/*int Abc_NtkRecStrashNode( Abc_Ntk_t * pNtkNew, Abc_Obj_t * pObj, unsigned * pTruth, int nVars ) -{ - char pCanonPerm[16]; - Abc_Ntk_t * pAig = s_pMan->pNtk; - unsigned * pInOut = s_pMan->pTemp1; - unsigned * pTemp = s_pMan->pTemp2; - unsigned * pTruthRec; - Abc_Obj_t * pCand, * pCandMin, * pLeaf, * pFanin, ** ppSpot; - unsigned uCanonPhase; - int i, nLeaves, CostMin, Cost, nOnes, fCompl; - - // check if the record works - nLeaves = Abc_ObjFaninNum(pObj); - assert( nLeaves >= 3 && nLeaves <= s_pMan->nVars ); - pFanin = Abc_ObjFanin0(pObj); - assert( Abc_ObjRegular(pFanin->pCopy)->pNtk == pNtkNew ); - assert( s_pMan != NULL ); - assert( nVars == s_pMan->nVars ); - - // copy the truth table - Kit_TruthCopy( pInOut, pTruth, nVars ); - - // set permutation - for ( i = 0; i < nVars; i++ ) - pCanonPerm[i] = i; - - // canonicize the truth table - uCanonPhase = Kit_TruthSemiCanonicize( pInOut, pTemp, nVars, pCanonPerm ); - - // get hold of the curresponding class - ppSpot = Abc_NtkRecTableLookup( s_pMan, pInOut, nVars ); - if ( *ppSpot == NULL ) - { - s_pMan->nFunsNotFound++; -// printf( "The class of a function with %d inputs is not found.\n", nLeaves ); - return 0; - } - s_pMan->nFunsFound++; - - // make sure the truth table is the same - pTruthRec = (unsigned *)Vec_PtrEntry( s_pMan->vTtNodes, (*ppSpot)->Id ); - if ( !Kit_TruthIsEqualWithPhase( pTruthRec, pInOut, nVars ) ) - { - assert( 0 ); - return 0; - } - - - // allocate storage for costs - if ( s_pMan->vLabels && Vec_PtrSize(s_pMan->vLabels) < Abc_NtkObjNumMax(pAig) ) - { - Vec_PtrFree( s_pMan->vLabels ); - s_pMan->vLabels = NULL; - } - if ( s_pMan->vLabels == NULL ) - s_pMan->vLabels = Vec_PtrStart( Abc_NtkObjNumMax(pAig) ); - - // go through the variables in the new truth table - Abc_NtkIncrementTravId( pAig ); - for ( i = 0; i < nLeaves; i++ ) - { - // get hold of the corresponding fanin - pFanin = Abc_ObjFanin( pObj, pCanonPerm[i] )->pCopy; - pFanin = Abc_ObjNotCond( pFanin, (uCanonPhase & (1 << i)) ); - // label the PI of the AIG subgraphs with this fanin - pLeaf = Abc_NtkPi( pAig, i ); - Vec_PtrWriteEntry( s_pMan->vLabels, pLeaf->Id, pFanin ); - Abc_NodeSetTravIdCurrent( pLeaf ); - } - - // go through the candidates - and recursively label them - for ( pCand = *ppSpot; pCand; pCand = (Abc_Obj_t *)pCand->pData ) - Abc_NtkRecStrashNodeLabel_rec( pNtkNew, pCand, 0, s_pMan->vLabels ); - - - // allocate storage for costs - if ( s_pMan->vCosts && Vec_StrSize(s_pMan->vCosts) < Abc_NtkObjNumMax(pAig) ) - { - Vec_StrFree( s_pMan->vCosts ); - s_pMan->vCosts = NULL; - } - if ( s_pMan->vCosts == NULL ) - s_pMan->vCosts = Vec_StrStart( Abc_NtkObjNumMax(pAig) ); - - // find the best subgraph - CostMin = ABC_INFINITY; - pCandMin = NULL; - for ( pCand = *ppSpot; pCand; pCand = (Abc_Obj_t *)pCand->pData ) - { - // label the leaves - Abc_NtkIncrementTravId( pAig ); - // count the number of non-labeled nodes - Cost = Abc_NtkRecStrashNodeCount_rec( pCand, s_pMan->vCosts, s_pMan->vLabels ); - if ( CostMin > Cost ) - { -// printf( "%d ", Cost ); - CostMin = Cost; - pCandMin = pCand; - } - } -// printf( "\n" ); - assert( pCandMin != NULL ); - if ( pCandMin == NULL ) - return 0; - - - // label the leaves - Abc_NtkIncrementTravId( pAig ); - for ( i = 0; i < nLeaves; i++ ) - Abc_NodeSetTravIdCurrent( Abc_NtkPi(pAig, i) ); - - // implement the subgraph - pObj->pCopy = Abc_NtkRecStrashNodeLabel_rec( pNtkNew, pCandMin, 1, s_pMan->vLabels ); - assert( Abc_ObjRegular(pObj->pCopy)->pNtk == pNtkNew ); - - // determine phase difference - nOnes = Kit_TruthCountOnes(pTruth, nVars); - fCompl = (nOnes > (1<< nVars)/2); -// assert( fCompl == ((uCanonPhase & (1 << nVars)) > 0) ); - - nOnes = Kit_TruthCountOnes(pTruthRec, nVars); - fCompl ^= (nOnes > (1<< nVars)/2); - // complement - pObj->pCopy = Abc_ObjNotCond( pObj->pCopy, fCompl ); - return 1; -}*/ - - - - - - -//////////////////////////////////////////////////////////////////////// -/// END OF FILE /// -//////////////////////////////////////////////////////////////////////// - - -ABC_NAMESPACE_IMPL_END - - diff --git a/src/base/abci/abcRec2.c b/src/base/abci/abcRec2.c deleted file mode 100644 index c62068c2..00000000 --- a/src/base/abci/abcRec2.c +++ /dev/null @@ -1,2442 +0,0 @@ -/**CFile**************************************************************** - - FileName [abcRec2.c] - - SystemName [ABC: Logic synthesis and verification system.] - - PackageName [Network and node package.] - - Synopsis [Record of semi-canonical AIG subgraphs.] - - Author [Allan Yang, Alan Mishchenko] - - Affiliation [Fudan University in Shanghai, UC Berkeley] - - Date [Ver. 1.0. Started - June 20, 2005.] - - Revision [$Id: abcRec.c,v 1.00 2005/06/20 00:00:00 alanmi Exp $] - -***********************************************************************/ - -#include "base/abc/abc.h" -#include "map/if/if.h" -#include "bool/kit/kit.h" -#include "aig/gia/giaAig.h" -#include "misc/vec/vecMem.h" -#include "bool/lucky/lucky.h" - -ABC_NAMESPACE_IMPL_START - -//#define LibOut - -//////////////////////////////////////////////////////////////////////// -/// DECLARATIONS /// -//////////////////////////////////////////////////////////////////////// - -#define REC_EMPTY_ID -1 - -typedef struct Abc_ManRec_t_2 Abc_ManRec_t2; -typedef struct Rec_Obj_t_2 Rec_Obj_t2; - -typedef enum { - REC_ERROR, //0: error - REC_SMALL, //1: smaller than - REC_EQUAL, //2: equal with - REC_BIG, //3: bigger than - REC_DOMINANCE, //4: dominance - REC_BEDOMINANCED //5: be dominated -} Abc_LookUpStatus_t2; - -struct Rec_Obj_t_2 -{ - int pNext; // link to the next structure of the same functional class - int pCopy; // link to the next functional class in the same bucket - int truthID; // structure's Truth ID - int nFrequency; // appear times of this functional class among benchmarks - unsigned char cost; // structure's cost - char pinToPinDelay[0]; // structure's pin-to-pin delay -}; - -struct Abc_ManRec_t_2 -{ - Gia_Man_t * pGia; // the record - Vec_Str_t * vInputs; // the input number of nodes - Vec_Ptr_t * vTtElems; // the elementary truth tables -// Vec_Ptr_t * vTtNodes; // the node truth tables -// Mem_Fixed_t * pMmTruth; // memory manager for truth tables - Vec_Mem_t * vTtMem; // memory for truth tables of primary outputs - int * pBins; // hash table mapping truth tables into nodes - int nBins; // the number of allocated bins - int nVars; // the number of variables - int nVarsInit; // the number of variables requested initially - int nWords; // the number of TT words - int nCuts; // the max number of cuts to use - //Mem_Fixed_t * pMemObj; // memory manager for Rec objects - int recObjSize; // size for one Rec object - int fTrim; // filter the library or not. - char * pRecObjs; - int nRecObjs; - int nRecObjsAlloc; - // temporaries - int * pBytes; // temporary storage for minterms - int * pMints; // temporary storage for minterm counters - unsigned * pTemp1; // temporary truth table - unsigned * pTemp2; // temporary truth table - Vec_Ptr_t * vNodes; // the temporary nodes - Vec_Ptr_t * vTtTemps; // the truth tables for the internal nodes of the cut - Vec_Ptr_t * vLabels; // temporary storage for AIG node labels - Vec_Int_t * vLabelsInt; // temporary storage for AIG node labels - Vec_Int_t * vUselessPos; - // statistics - int nTried; // the number of cuts tried - int nFilterSize; // the number of same structures - int nFilterRedund; // the number of same structures - int nFilterVolume; // the number of same structures - int nFilterTruth; // the number of same structures - int nFilterError; // the number of same structures - int nFilterSame; // the number of same structures - int nAdded; // the number of subgraphs added - int nAddedFuncs; // the number of functions added - int nIfMapError; - int nTrimed; // the number of structures filtered - // rewriting - int nFunsFound; // the found functions - int nFunsNotFound; // the missing functions - int nFunsTried; - int nFunsFilteredBysupport; // the function filtered when rewriting because not all supports are in use. - int nFunsDelayComput; // the times delay computed, just for statistics - int nNoBetter; // the number of functions found but no better than the current structures. - // rewriting runtime - int timeIfTotal; // time used on the whole process of rewriting a structure. - int timeIfComputDelay; // time used on the structure's delay computation. - int timeIfCanonicize; // time used on canonicize the function - int timeIfDerive; // time used on derive the final network; - int timeIfCopmutCur; // time used on compute the current structures info - int timeIfOther; // time used on other things - // record runtime - int timeTrim; // the runtime to filter the library - int timeCollect; // the runtime to collect the node of a structure. - int timeTruth; // the runtime to compute truth table. - int timeCanon; // the runtime to canonicize - int timeInsert; // the runtime to insert a structure. - int timeBuild; // the runtime to build a new structure in the library. - int timeMerge; // the runtime to merge libraries; - int timeReHash; // the runtime to resize the hash table. - int timeOther; // the runtime of other - int timeTotal; // the runtime to total. -}; - -static Abc_ManRec_t2 * s_pMan = NULL; - -static inline void Abc_ObjSetMax2( Vec_Str_t * p, Gia_Man_t * pGia, Gia_Obj_t * pObj, char Value ) { Vec_StrWriteEntry(p, Gia_ObjId(pGia, pObj), Value); } -//static inline void Abc_ObjClearMax( Gia_Obj_t * pObj ) { pObj->Value = (pObj->Value & 0xff); } -static inline int Abc_ObjGetMax2( Vec_Str_t * p, Gia_Man_t * pGia, Gia_Obj_t * pObj ) { return Vec_StrEntry(p, Gia_ObjId(pGia, pObj)); } -static inline int Rec_ObjID(Abc_ManRec_t2 *p, Rec_Obj_t2 * pRecObj) -{ char * pObj = (char *)pRecObj; - assert(p->pRecObjs <= pObj && pObj < p->pRecObjs + p->nRecObjs * p->recObjSize); - return (pObj - p->pRecObjs)/p->recObjSize; -} -static inline Rec_Obj_t2 * Rec_Obj(Abc_ManRec_t2 *p, int v) -{ - assert( v < p->nRecObjs ); - return (Rec_Obj_t2 *)(p->pRecObjs + v * p->recObjSize); -} - -static inline unsigned * Rec_MemReadEntry( Abc_ManRec_t2 * p, int i ) { return (unsigned *)Vec_MemReadEntry( p->vTtMem, i ); } -static inline void Rec_MemSetEntry( Abc_ManRec_t2 * p, int i, unsigned * pEntry ) { Vec_MemSetEntry( p->vTtMem, i, (word *)pEntry ); } - -/**Function************************************************************* - - Synopsis [Alloc the Rec object from its manger.] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -static inline int Rec_AppendObj( Abc_ManRec_t2 * p, Rec_Obj_t2 ** pObj ) -{ - //Rec_Obj_t2 * pObj; - int hasRealloced = 0; - if ( p->nRecObjs == p->nRecObjsAlloc ) - { - assert( p->nRecObjs > 0 ); - p->pRecObjs = ABC_REALLOC( char, p->pRecObjs, 2 * p->nRecObjsAlloc * p->recObjSize ); - memset( p->pRecObjs + p->nRecObjsAlloc * p->recObjSize, 0, p->recObjSize * p->nRecObjsAlloc ); - p->nRecObjsAlloc *= 2; - hasRealloced = 1; - } - *pObj = Rec_Obj( p, p->nRecObjs++ ); - (*pObj)->pCopy = REC_EMPTY_ID; - (*pObj)->pNext = REC_EMPTY_ID; - return hasRealloced; -} - - -/**Function************************************************************* - - Synopsis [set the property of a Rec object.] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -int Rec_ObjSet2(Abc_ManRec_t2* p, Rec_Obj_t2* pRecObj, char* newDelay, unsigned char cost, int nVar) -{ - int i; - //pRecObj->obj = pObj; - //pRecObj->Id = Gia_ObjId(p->pGia, pObj); - pRecObj->cost = cost; - for (i = 0; i < nVar; i++) - pRecObj->pinToPinDelay[i] = newDelay[i]; - return Rec_ObjID(p, pRecObj); -} - -/**Function************************************************************* - - Synopsis [Set input number for every structure.] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -void Abc_NtkRecMarkInputs(Abc_ManRec_t2 * p, Gia_Man_t * pGia) -{ - Gia_Obj_t * pObj; - int i; - Vec_Str_t * pStr = p->vInputs; - if (Vec_StrSize(pStr) < Gia_ManObjNum(pGia)) - Vec_StrFillExtra( pStr, Gia_ManObjNum(pGia), 0 ); - - - Gia_ManForEachPi( pGia, pObj, i ) - Abc_ObjSetMax2(pStr, pGia, pObj, (char)(i+1) ); - Gia_ManForEachAnd( pGia, pObj, i ) - Abc_ObjSetMax2(pStr, pGia, pObj, (char)Abc_MaxInt( Abc_ObjGetMax2(pStr, pGia, Gia_ObjFanin0(pObj)), Abc_ObjGetMax2(pStr, pGia, Gia_ObjFanin1(pObj)) ) ); -} - -/**Function************************************************************* - - Synopsis [Get the Gia_Obj_t.] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -Gia_Obj_t * Abc_NtkRecGetObj(int Rec_ID) -{ - Gia_Man_t * p = s_pMan->pGia; - Gia_Obj_t * pPO = Gia_ManPo(p, Rec_ID); - return Gia_ObjFanin0(pPO); -} - - -/**Function************************************************************* - - Synopsis [] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -int Abc_NtkRecIsRunning2() -{ - return s_pMan != NULL; -} - -/**Function************************************************************* - - Synopsis [] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -int Abc_NtkRecIsInTrimMode2() -{ - return (s_pMan != NULL && s_pMan->fTrim); -} - -/**Function************************************************************* - - Synopsis [] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -Gia_Man_t * Abc_NtkRecGetGia() -{ - return s_pMan->pGia; -} - -/**Function************************************************************* - - Synopsis [Set frequency.] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ - -static inline void Abc_NtkRecFrequencyInc(int entry) -{ - // the hit number of this functional class increased - if (entry != REC_EMPTY_ID && Rec_Obj(s_pMan, entry)->nFrequency < 0x7fffffff) - Rec_Obj(s_pMan, entry)->nFrequency += 1; -} - -/**Function************************************************************* - - Synopsis [stretch the truthtable to have more input variables.] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -static void If_CutTruthStretch(unsigned* pInOut, int nVarS, int nVarB) -{ - int w, i; - int step = Kit_TruthWordNum(nVarS); - int nWords = Kit_TruthWordNum(nVarB); - assert(step <= nWords); - if (step == nWords) - return; - for (w = 0; w <nWords; w += step) - for (i = 0; i < step; i++) - pInOut[w + i] = pInOut[i]; -} - -/**Function************************************************************* - - Synopsis [Compare delay profile of two structures.] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ - -static Abc_LookUpStatus_t2 ABC_NtkRecDelayCompare(char* delayFromStruct, char* delayFromTable, int nVar) -{ - int i, bigThan = 0, smallThan = 0, equal = 1, dominace = 1, beDominaced = 1; - for (i = 0; i < nVar; i++) - { - if(delayFromStruct[i] < delayFromTable[i]) - { - equal = 0; - beDominaced = 0; - if(bigThan == 0) - smallThan = 1; - } - else if (delayFromStruct[i] > delayFromTable[i]) - { - equal = 0; - dominace = 0; - if (smallThan == 0) - bigThan = 1; - } - } - if(equal) - return REC_EQUAL; - else if(dominace) - return REC_DOMINANCE; - else if(beDominaced) - return REC_BEDOMINANCED; - if(bigThan) - return REC_BIG; - else if(smallThan) - return REC_SMALL; - else - return REC_SMALL; -} - - - -/**Function************************************************************* - - Synopsis [Delete a useless structure in the library.] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -void Abc_NtkRecDeleteSubGragh2(Gia_Obj_t* pObj) -{ - //assert(pObj->fMark0 == 0); - //pObj->fMark0 = 1; - Vec_IntPush(s_pMan->vUselessPos, Gia_ObjId(s_pMan->pGia, pObj)); - s_pMan->nTrimed++; -} - - -/**Function************************************************************* - - Synopsis [Mark NonDangling nodes.] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -void Abc_NtkRecMarkNonDanglingNodes_Rec(Gia_Man_t * pGia, Gia_Obj_t * pRoot) -{ - Gia_Obj_t * pFanin0, * pFanin1; - //assert(pRoot->fMark0 == 0); - pRoot->fMark0 = 1; - pFanin0 = Gia_ObjFanin0(pRoot); - pFanin1 = Gia_ObjFanin1(pRoot); - if (pFanin0->fMark0 == 0) - { - if(Gia_ObjIsPi(pGia, pFanin0)) - pFanin0->fMark0 = 1; - else - Abc_NtkRecMarkNonDanglingNodes_Rec(pGia, pFanin0); - } - if (pFanin1->fMark0 == 0) - { - if(Gia_ObjIsPi(pGia, pFanin1)) - pFanin1->fMark0 = 1; - else - Abc_NtkRecMarkNonDanglingNodes_Rec(pGia, pFanin1); - } -} - -/**Function************************************************************* - - Synopsis [Mark Dangling nodes.] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -void Abc_NtkRecMarkCompl(Gia_Man_t * pGia) -{ - Gia_Obj_t * pObj; - int i; - Gia_ManForEachObj1(pGia, pObj,i) - pObj->fMark0 = !pObj->fMark0; -} - -/**Function************************************************************* - - Synopsis [Mark Dangling nodes.] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -void Abc_NtkRecMarkNonDanglingNodes(Gia_Man_t * pGia) -{ - Gia_Obj_t * pObj, * pFanin; - int i; - int Id; -// int counter = 0; - Gia_ManForEachObj(pGia, pObj, i) - { - if (pObj->fMark1 == 1) - { - pObj->fMark1 = 0; - } - if (pObj->fMark0 == 1) - { - pObj->fMark0 = 0; - } - } - - Vec_IntForEachEntry(s_pMan->vUselessPos, Id, i) - { - pObj = Gia_ManObj(pGia, Id); - pObj->fMark1 = 1; - } - Gia_ManForEachPo(pGia, pObj,i) - { - pFanin = Gia_ObjFanin0(pObj); - if (!pFanin->fMark1) - { - pObj->fMark0 = 1; - Abc_NtkRecMarkNonDanglingNodes_Rec(pGia, pFanin); - } - } - - Vec_IntClear(s_pMan->vUselessPos); - Abc_NtkRecMarkCompl(pGia); -} - -/**Function************************************************************* - - Synopsis [Duplicates non-dangling nodes and POs driven by constants.] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -Gia_Man_t * Abc_NtkDupWithoutDangling2( Gia_Man_t * pGia ) -{ - Gia_Man_t * pGiaNew; - Abc_NtkRecMarkNonDanglingNodes(pGia); - pGiaNew = Gia_ManDupMarked(pGia); - return pGiaNew; -} - - -/**Function************************************************************* - - Synopsis [Filter the library.] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -void Abc_NtkRecFilter2(int nLimit) -{ - int previous = REC_EMPTY_ID, entry = REC_EMPTY_ID, pTemp; - int i; - Gia_Man_t * pGia = s_pMan->pGia, *newPGia; - //int time = Abc_Clock(); - Abc_ManRec_t2 *p = s_pMan; -// Gia_Obj_t * pObj; - char fileName[256]; - if (nLimit > 0) - { - for ( i = 0; i < s_pMan->nBins; i++ ) - { - previous = REC_EMPTY_ID; - for ( entry = s_pMan->pBins[i]; entry != REC_EMPTY_ID; entry = Rec_Obj(p, entry)->pCopy) - { - assert(Rec_Obj(p, entry)->nFrequency != 0); - // only filter the functional classed with frequency less than nLimit. - if(Rec_Obj(p, entry)->nFrequency > nLimit) - { - previous = entry; - continue; - } - if(previous == REC_EMPTY_ID) - { - s_pMan->pBins[i] = Rec_Obj(p, entry)->pCopy; - previous = REC_EMPTY_ID; - } - else - Rec_Obj(p, previous)->pCopy = Rec_Obj(p, entry)->pCopy; - - s_pMan->nAddedFuncs--; - //delete all the subgragh. - for ( pTemp = entry; pTemp != REC_EMPTY_ID;) - { - s_pMan->nAdded--; - Abc_NtkRecDeleteSubGragh2(Abc_NtkRecGetObj(pTemp)); - pTemp = Rec_Obj(p, pTemp)->pNext; - //Mem_FixedEntryRecycle(s_pMan->pMemObj, (char *)pTemp); - //pTemp = pNextOne; - } - } - } - } - - // remove dangling nodes and POs driven by constants - newPGia = Abc_NtkDupWithoutDangling2(pGia); - sprintf( fileName, "RecLib%d_Filtered%d.aig", p->nVars, nLimit); - Gia_AigerWrite( newPGia, fileName, 0, 0 ); - Abc_Print(1, "Library %s was written.", fileName); - //Gia_ManHashStop(newPGia); - Gia_ManStop(newPGia); - Abc_NtkRecStop2(); - Abc_Print(1, "Record stopped."); - // collect runtime stats - //s_pMan->timeTrim += Abc_Clock() - time; - //s_pMan->timeTotal += Abc_Clock() - time; -} - - -/**Function************************************************************* - - Synopsis [Returns the hash key.] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -static inline unsigned Abc_NtkRecTableHash( unsigned * pTruth, int nVars, int nBins, int * pPrimes ) -{ - int i, nWords = Kit_TruthWordNum( nVars ); - unsigned uHash = 0; - for ( i = 0; i < nWords; i++ ) - uHash ^= pTruth[i] * pPrimes[i & 0x7]; - return uHash % nBins; -} - -/**Function************************************************************* - - Synopsis [Returns the given record.] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -static int * Abc_NtkRecTableLookup2(Abc_ManRec_t2* p, int * pBins, int nBins, unsigned * pTruth, int nVars ) -{ - static int s_Primes[10] = { 1291, 1699, 2357, 4177, 5147, 5647, 6343, 7103, 7873, 8147 }; - int * ppSpot, pEntry; - ppSpot = pBins + Abc_NtkRecTableHash( pTruth, nVars, nBins, s_Primes ); - for ( pEntry = *ppSpot; pEntry != REC_EMPTY_ID; ppSpot = &(Rec_Obj(p,pEntry)->pCopy), pEntry = Rec_Obj(p,pEntry)->pCopy ) -// if ( Kit_TruthIsEqualWithPhase((unsigned *)Vec_PtrEntry(p->vTtNodes, pEntry), pTruth, nVars) ) - if ( Kit_TruthIsEqualWithPhase( Rec_MemReadEntry(p, Rec_Obj(p, pEntry)->truthID), pTruth, nVars) ) - return ppSpot; - return ppSpot; -} - -/**Function************************************************************* - - Synopsis [Resize the hash table.] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -static void Abc_NtkRecResizeHash2(Abc_ManRec_t2* p) -{ - int * pBinsNew, *ppSpot; - int pEntry, pTemp; - int nBinsNew, Counter, i; - int clk = Abc_Clock(); - // get the new table size - nBinsNew = Cudd_Prime( 2 * p->nBins ); - printf("Hash table resize from %d to %d.\n", p->nBins, nBinsNew); - // allocate a new array - pBinsNew = ABC_ALLOC( int, nBinsNew ); - memset( pBinsNew, -1, sizeof(int) * nBinsNew ); - // rehash the entries from the old table - Counter = 0; - for ( i = 0; i < p->nBins; i++ ) - for ( pEntry = p->pBins[i]; pEntry != REC_EMPTY_ID;) - { - pTemp = Rec_Obj(p, pEntry)->pCopy; -// ppSpot = Abc_NtkRecTableLookup2(p, pBinsNew, nBinsNew, (unsigned *)Vec_PtrEntry(p->vTtNodes, pEntry), p->nVars); - ppSpot = Abc_NtkRecTableLookup2(p, pBinsNew, nBinsNew, Rec_MemReadEntry(p, Rec_Obj(p, pEntry)->truthID), p->nVars); - assert(*ppSpot == REC_EMPTY_ID); - *ppSpot = pEntry; - Rec_Obj(p, pEntry)->pCopy = REC_EMPTY_ID; - pEntry = pTemp; - Counter++; - } - assert( Counter == p->nAddedFuncs); - ABC_FREE( p->pBins ); - p->pBins = pBinsNew; - p->nBins = nBinsNew; - p->timeReHash += Abc_Clock() - clk; - p->timeTotal += Abc_Clock() - clk; - -} - -/**Function************************************************************* - - Synopsis [Compute area of the structure.] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -static unsigned char Abc_NtkRecAreaAndMark_rec(Gia_Obj_t* pObj) -{ - unsigned char Area0, Area1, Area; - pObj = Gia_Regular(pObj); - if(Gia_ObjIsCi(pObj) || pObj->fMark0 == 1) - return 0; - Area0 = Abc_NtkRecAreaAndMark_rec(Gia_ObjFanin0(pObj)); - Area1 = Abc_NtkRecAreaAndMark_rec(Gia_ObjFanin1(pObj)); - Area = Area1 + Area0 + 1; -// assert(Area <= 255); - pObj->fMark0 = 1; - return Area; -} - -/**Function************************************************************* - - Synopsis [Compute area of the structure.] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -static void Abc_NtkRecAreaUnMark_rec(Gia_Obj_t* pObj) -{ - pObj = Gia_Regular(pObj); - if ( Gia_ObjIsCi(pObj) || pObj->fMark0 == 0 ) - return; - Abc_NtkRecAreaUnMark_rec( Gia_ObjFanin0(pObj) ); - Abc_NtkRecAreaUnMark_rec( Gia_ObjFanin1(pObj) ); - assert( pObj->fMark0 ); // loop detection - pObj->fMark0 = 0; -} - -/**Function************************************************************* - - Synopsis [Compute area of the structure.] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -unsigned char Abc_NtkRecArea2(Gia_Obj_t* pObj) -{ - unsigned char area; - area = Abc_NtkRecAreaAndMark_rec(pObj); - Abc_NtkRecAreaUnMark_rec(pObj); - return area; -} - -/**Function************************************************************* - - Synopsis [Compute pin-to-pin delay of the structure.] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -char If_CutDepthRecComput_rec2(Gia_Obj_t* pObj, int iLeaf) -{ - char Depth0, Depth1, Depth; - pObj = Gia_Regular(pObj); - if(Gia_ObjId(s_pMan->pGia, pObj) == iLeaf) - return 0; - if(Gia_ObjIsCi(pObj)) - return -IF_BIG_CHAR; - Depth0 = If_CutDepthRecComput_rec2(Gia_ObjFanin0(pObj), iLeaf); - Depth1 = If_CutDepthRecComput_rec2(Gia_ObjFanin1(pObj), iLeaf); - Depth = Abc_MaxInt(Depth0, Depth1); - Depth = (Depth == -IF_BIG_CHAR) ? -IF_BIG_CHAR : Depth + 1; -// assert(Depth <= 127); - return Depth; -} - -/**Function************************************************************* - - Synopsis [Check if the structure is dominant or not.] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -static int ABC_NtkRecIsDominant(char* delayFromStruct, char* delayFromTable, int nVar) -{ - int i; - for (i = 0; i < nVar; i++) - { - if(delayFromStruct[i] > delayFromTable[i]) - return 0; - } - return 1; -} - -/**Function************************************************************* - - Synopsis [Sweep the dominated structures.] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -static void Abc_NtkRecSweepDominance(Abc_ManRec_t2* p, int previous, int current, char * delayFromStruct, int nVars) -{ - Gia_Obj_t* pObj; - while(current != REC_EMPTY_ID) - { - if (ABC_NtkRecIsDominant(delayFromStruct, Rec_Obj(p, current)->pinToPinDelay, nVars)) - { - pObj = Abc_NtkRecGetObj(current); - Rec_Obj(p, previous)->pNext = Rec_Obj(p, current)->pNext; - //current->pNext = NULL; - //Mem_FixedEntryRecycle(p->pMemObj, (char *)current); - current = Rec_Obj(p, previous)->pNext; - p->nAdded--; - // if filter the library is needed, then point the PO to a constant. - Abc_NtkRecDeleteSubGragh2(pObj); - } - else - { - previous = current; - current = Rec_Obj(p, current)->pNext; - } - } -} - -/**Function************************************************************* - - Synopsis [Insert a structure into the look up table.] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -void Abc_NtkRecReplaceCurrentEntry(int previous, int * current, int entry, int * ppSpot) -{ - Abc_ManRec_t2 * p = s_pMan; - Rec_Obj(p,entry)->pCopy = Rec_Obj(p, *current)->pCopy; - Rec_Obj(p,entry)->pNext = Rec_Obj(p, *current)->pNext; - if (previous == REC_EMPTY_ID) - { - *ppSpot = entry; - Rec_Obj(p,entry)->nFrequency = Rec_Obj(p, *current)->nFrequency; - } - else - { - Rec_Obj(p,previous)->pNext = entry; - } - *current = entry; - -} - -/**Function************************************************************* - - Synopsis [Insert a structure into the look up table.] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -void Abc_NtkRecInsertToLookUpTable2(Abc_ManRec_t2* p, int* ppSpot, Gia_Obj_t* pPO, int nVars, unsigned * pTruth, int fTrim) -{ - char delayFromStruct[16]; - int i, hasRealloced = 0; - Gia_Obj_t* pLeaf, *pObj = Gia_ObjFanin0(pPO); - int entry, previous = REC_EMPTY_ID, current = * ppSpot; - unsigned char costFromStruct = Abc_NtkRecArea2(pObj); - Abc_LookUpStatus_t2 result; - Rec_Obj_t2 * pRecObj; - assert( nVars > 0 ); - for (i = 0; i < nVars; i++) - { - pLeaf = Gia_ManPi( p->pGia, i); - pLeaf =Gia_Regular(pLeaf); - delayFromStruct[i] = If_CutDepthRecComput_rec2(pObj, Gia_ObjId(p->pGia, pLeaf)); - } - hasRealloced = Rec_AppendObj(p, &pRecObj); - if(hasRealloced) -// ppSpot = Abc_NtkRecTableLookup2(p, p->pBins, p->nBins, (unsigned *)Vec_PtrEntry( p->vTtNodes, Gia_ObjCioId(pPO)), p->nVars ); - ppSpot = Abc_NtkRecTableLookup2(p, p->pBins, p->nBins, pTruth, p->nVars ); - assert(Rec_ObjID(p, pRecObj) == Gia_ObjCioId(pPO)); - if (current == REC_EMPTY_ID) - { - pRecObj->truthID = p->nAddedFuncs; - Rec_MemSetEntry( p, pRecObj->truthID, pTruth); - } - else - pRecObj->truthID = Rec_Obj(p, current)->truthID; - - - if(fTrim) - { - while(1) - { - if (current == REC_EMPTY_ID) - { - p->nAdded++; - entry = Rec_ObjSet2(p, pRecObj, delayFromStruct, costFromStruct, nVars); - if(previous != REC_EMPTY_ID) - { - Rec_Obj(p, previous)->pNext = entry; - //previous->pNext = entry; - } - else - { - // new functional class found - p->nAddedFuncs++; - *ppSpot = entry; - Rec_Obj(p, entry)->nFrequency = 1; - } - break; - } - result = ABC_NtkRecDelayCompare(delayFromStruct, Rec_Obj(p, current)->pinToPinDelay, nVars); - if(result == REC_EQUAL) - { - // when delay profile is equal, replace only if it has smaller cost. - if(costFromStruct < (Rec_Obj(p, current)->cost)) - { - Abc_NtkRecDeleteSubGragh2(Abc_NtkRecGetObj(current)); - entry = Rec_ObjSet2(p, pRecObj, delayFromStruct, costFromStruct, nVars); - Abc_NtkRecReplaceCurrentEntry(previous, ¤t, entry, ppSpot); - - } - else - Abc_NtkRecDeleteSubGragh2(pObj); - break; - } - // when the new structure can dominate others, sweep them out of the library, delete them if required. - else if(result == REC_DOMINANCE) - { - Abc_NtkRecDeleteSubGragh2(Abc_NtkRecGetObj(current)); - entry = Rec_ObjSet2(p, pRecObj, delayFromStruct, costFromStruct, nVars); - Abc_NtkRecReplaceCurrentEntry(previous, ¤t, entry, ppSpot); - Abc_NtkRecSweepDominance(p,current,Rec_Obj(p, current)->pNext,delayFromStruct, nVars); - break; - } - // when the new structure is domianted by an existed one, don't store it. - else if (result == REC_BEDOMINANCED) - { - Abc_NtkRecDeleteSubGragh2(pObj); - break; - } - // when the new structure's delay profile is big than the current, test the next one - else if (result == REC_BIG) - { - previous = current; - current = Rec_Obj(p, current)->pNext; - } - // insert the new structure to the right position, sweep the ones it can dominate. - else if (result == REC_SMALL) - { - p->nAdded++; - entry = Rec_ObjSet2(p, pRecObj, delayFromStruct, costFromStruct, nVars); - if(previous != REC_EMPTY_ID) - { - Rec_Obj(p, previous)->pNext = entry; - Rec_Obj(p, entry)->pNext = current; - } - else - { - Rec_Obj(p, entry)->pNext = current; - Rec_Obj(p, entry)->pCopy = Rec_Obj(p, *ppSpot)->pCopy; - Rec_Obj(p, entry)->nFrequency = Rec_Obj(p, *ppSpot)->nFrequency; - Rec_Obj(p, *ppSpot)->pCopy = REC_EMPTY_ID; - Rec_Obj(p, *ppSpot)->nFrequency = 0; - *ppSpot = entry; - } - Abc_NtkRecSweepDominance(p,current,Rec_Obj(p, current)->pNext,delayFromStruct, nVars); - break; - } - else - assert(0); - } - } - else - { - entry = Rec_ObjSet2(p, pRecObj, delayFromStruct, costFromStruct, nVars); - if (current == REC_EMPTY_ID) - { - p->nAdded++; - p->nAddedFuncs++; - *ppSpot = entry; - Rec_Obj(p, entry)->nFrequency = 1; - } - else - { - p->nAdded++; - Rec_Obj(p, entry)->pNext = Rec_Obj(p, *ppSpot)->pNext; - Rec_Obj(p, *ppSpot)->pNext = entry; - } - } -} - - -/* -int Abc_NtkRecComputeTruth2( Gia_Obj_t * pObj, Vec_Ptr_t * vTtNodes, int nVars ) -{ - unsigned * pTruth, * pTruth0, * pTruth1; - //int RetValue; - Gia_Man_t *pGia = s_pMan->pGia; - Gia_Obj_t *pFanin0, *pFanin1; - pFanin0 = Gia_ObjFanin0(pObj); - pFanin1 = Gia_ObjFanin1(pObj); - assert( Gia_ObjIsAnd(pObj) ); - pTruth = (unsigned *)Vec_PtrEntry( vTtNodes, Gia_ObjId(pGia, pObj) ); - pTruth0 = (unsigned *)Vec_PtrEntry( vTtNodes, Gia_ObjId(pGia, pFanin0) ); - pTruth1 = (unsigned *)Vec_PtrEntry( vTtNodes, Gia_ObjId(pGia, pFanin1) ); - Kit_TruthAndPhase( pTruth, pTruth0, pTruth1, nVars, Gia_ObjFaninC0(pObj), Gia_ObjFaninC1(pObj) ); - //assert((pTruth[0] & 1) == pObj->fPhase ) - //RetValue = ((pTruth[0] & 1) == pObj->fPhase); - return 1; -} -*/ -void Abc_NtkRecStart2( Gia_Man_t * pGia, int nVars, int nCuts, int fTrim ) -{ - Abc_ManRec_t2 * p; - Gia_Obj_t * pObj, *pFanin; - int * ppSpot; - unsigned * pTruth; - int i;//, j = 0; - int clkTotal = Abc_Clock(), clk, timeInsert; - - assert( s_pMan == NULL ); - if ( pGia == NULL ) - { - assert( nVars > 2 && nVars <= 16 ); - pGia = Gia_ManStart( 1 << 16 ); - pGia->pName = Extra_UtilStrsav( "record" ); - - - } - else - { - if ( Gia_ManCountChoices(pGia) > 0 ) - { - printf( "The starting record should be a network without choice nodes.\n" ); - return; - } - if ( Gia_ManPiNum(pGia) > 16 ) - { - printf( "The starting record should be a network with no more than %d primary inputs.\n", 16 ); - return; - } - if ( Gia_ManPiNum(pGia) > nVars ) - printf( "The starting record has %d inputs (warning only).\n", Gia_ManPiNum(pGia) ); - } -// Gia_ManHashStart( pGia ); - // move this to rec_add2, because if the library is never used for adding new structures - // structural hashing is not needed - if ( pGia->pHTable != NULL ) - Gia_ManHashStop( pGia ); - - // create the primary inputs - for ( i = Gia_ManPiNum(pGia); i < nVars; i++ ) - Gia_ManAppendCi(pGia); - - p = ABC_CALLOC( Abc_ManRec_t2, 1 ); - s_pMan = p; -// memset( p, 0, sizeof(Abc_ManRec_t2) ); // no need for this if we use ABC_CALLOC - p->pGia = pGia; - p->nVars = Gia_ManPiNum(pGia); - p->nWords = Kit_TruthWordNum( p->nVars ); - p->nCuts = nCuts; - p->nVarsInit = nVars; - p->recObjSize = sizeof(Rec_Obj_t2) + sizeof(char) * p->nVars; - p->recObjSize = sizeof(void *) * ((p->recObjSize / sizeof(void *)) + ((p->recObjSize % sizeof(void *)) > 0)); - - p->nRecObjsAlloc = 1 << 16; - p->pRecObjs = (char *) calloc(p->nRecObjsAlloc, p->recObjSize); - - //p->pMemObj = Mem_FixedStart(p->recObjSize); - p->fTrim = fTrim; - // create elementary truth tables - p->vTtElems = Vec_PtrAlloc( 0 ); assert( p->vTtElems->pArray == NULL ); - p->vTtElems->nSize = p->nVars; - p->vTtElems->nCap = p->nVars; - p->vTtElems->pArray = (void **)Extra_TruthElementary( p->nVars ); - - p->vInputs = Vec_StrStart( 1 << 16 ); - p->vUselessPos = Vec_IntAlloc(1 << 16); -// p->vTtNodes = Vec_PtrAlloc( 1000 ); -// p->pMmTruth = Mem_FixedStart( sizeof(unsigned)*p->nWords ); -// for ( i = 0; i < Gia_ManPoNum(pGia); i++ ) -// Vec_PtrPush( p->vTtNodes, Mem_FixedEntryFetch(p->pMmTruth) ); - p->vTtMem = Vec_MemAlloc( p->nWords/2, 12 ); // 32 KB/page for 6-var functions - - // create hash table - p->nBins = 20011; - //p->nBins =500011; - p->pBins = ABC_ALLOC( int, p->nBins ); - memset( p->pBins, -1, sizeof(int) * p->nBins ); - -clk = Abc_Clock(); -// Gia_ManForEachPo( pGia, pObj, i ) -// { -// pTruthSrc = (unsigned *)Gia_ObjComputeTruthTable(pGia, pObj); -// // pTruthDst = (unsigned *)Vec_PtrEntry( p->vTtNodes, Gia_ObjCioId(pObj) ); -// // Kit_TruthCopy(pTruthDst, pTruthSrc, p->nVars); -// Rec_MemSetEntry( p, Gia_ObjCioId(pObj), pTruthSrc ); -// } -p->timeTruth += Abc_Clock() - clk; - - // insert the PO nodes into the table -timeInsert = Abc_Clock(); - Abc_NtkRecMarkInputs(p, pGia); - Gia_ManForEachPo( pGia, pObj, i ) - { - p->nTried++; - pFanin = Gia_ObjFanin0(pObj); - // mark the nodes with CO fanout. - assert(pFanin->fMark1 == 0); - pFanin->fMark1 = 1; -// pTruth = (unsigned *)Vec_PtrEntry( p->vTtNodes, Gia_ObjCioId(pObj) ); - pTruth = (unsigned *)Gia_ObjComputeTruthTable(pGia, pObj); - - //pTruth = Rec_MemReadEntry( p, Gia_ObjCioId(pObj) ); - // add the resulting truth table to the hash table - if(p->nAddedFuncs > 2 * p->nBins) - Abc_NtkRecResizeHash2(p); - ppSpot = Abc_NtkRecTableLookup2(p, p->pBins, p->nBins, pTruth, p->nVars ); - Abc_NtkRecInsertToLookUpTable2(p, ppSpot, pObj, Abc_ObjGetMax2(p->vInputs, pGia, pFanin), pTruth, p->fTrim); - } -p->timeInsert += Abc_Clock() - timeInsert; - - // temporaries - p->pBytes = ABC_ALLOC( int, 4*p->nWords ); - p->pMints = ABC_ALLOC( int, 2*p->nVars ); - p->pTemp1 = ABC_ALLOC( unsigned, p->nWords ); - p->pTemp2 = ABC_ALLOC( unsigned, p->nWords ); - p->vNodes = Vec_PtrAlloc( 100 ); - p->vTtTemps = Vec_PtrAllocSimInfo( 1024, p->nWords ); - p->vLabels = Vec_PtrStart( 1000 ); - p->vLabelsInt = Vec_IntStart( 1000 ); - - - p->timeTotal += Abc_Clock() - clkTotal; -} - -/**Function************************************************************* - - Synopsis [Print statistics about the current record.] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -void Abc_NtkRecPs2(int fPrintLib) -{ - int Counter, Counters[17] = {0}; - int CounterS, CountersS[17] = {0}; - Abc_ManRec_t2 * p = s_pMan; - Gia_Man_t * pGia = p->pGia; - int pEntry, pTemp; - //Gia_Obj_t * pObj; - int i; - FILE * pFile; - unsigned* pTruth; - int entry; - int j; - int nVars = s_pMan->nVars; - // set the max PI number - Abc_NtkRecMarkInputs(s_pMan, s_pMan->pGia); - -if(fPrintLib) -{ - pFile = fopen( "tt10.txt", "wb" ); -for ( i = 0; i < p->nBins; i++ ) - for ( entry = p->pBins[i]; entry != REC_EMPTY_ID; entry = Rec_Obj(p, entry)->pCopy ) - { - int tmp = 0; - - assert( 0 ); - // added the next line to silence the warning that 'pEntry' is not initialized - pEntry = -1; - -// pTruth = (unsigned*)Vec_PtrEntry(p->vTtNodes, entry); - pTruth = Rec_MemReadEntry( p, Rec_Obj(p, pEntry)->truthID ); - /*if ( (int)Kit_TruthSupport(pTruth, nVars) != (1<<nVars)-1 ) - continue;*/ - Extra_PrintHex( pFile, pTruth, nVars ); - fprintf( pFile, " : nVars: %d, Frequency:%d, nBin:%d : ", Abc_ObjGetMax2(s_pMan->vInputs, s_pMan->pGia, Abc_NtkRecGetObj(entry)), Rec_Obj(p, entry)->nFrequency, i); - Kit_DsdPrintFromTruth2( pFile, pTruth, Abc_ObjGetMax2(s_pMan->vInputs, s_pMan->pGia, Abc_NtkRecGetObj(entry)) ); - fprintf( pFile, "\n" ); - for ( pTemp = entry; pTemp != REC_EMPTY_ID; pTemp = Rec_Obj(p, pTemp)->pNext ) - { - fprintf(pFile,"%d :", tmp); - for (j = 0; j <Abc_ObjGetMax2(s_pMan->vInputs, s_pMan->pGia, Abc_NtkRecGetObj(pTemp)); j++) - { - fprintf(pFile, " %d, ", Rec_Obj(p, pTemp)->pinToPinDelay[j]); - } - fprintf(pFile, "cost = %d ID = %d\n", Rec_Obj(p, pTemp)->cost, pTemp); - tmp++; - } - fprintf( pFile, "\n"); - fprintf( pFile, "\n"); - } - fclose( pFile) ; -} - - // go through the table - Counter = CounterS = 0; - for ( i = 0; i < p->nBins; i++ ) - for ( pEntry = p->pBins[i]; pEntry != REC_EMPTY_ID; pEntry = Rec_Obj(p, pEntry)->pCopy ) - { - assert(Abc_ObjGetMax2(s_pMan->vInputs, s_pMan->pGia, Abc_NtkRecGetObj(pEntry)) >= 2); - Counters[ Abc_ObjGetMax2(s_pMan->vInputs, s_pMan->pGia, Abc_NtkRecGetObj(pEntry))]++; - Counter++; - for ( pTemp = pEntry; pTemp != REC_EMPTY_ID; pTemp = Rec_Obj(p, pTemp)->pNext ) - { - assert( Abc_ObjGetMax2(s_pMan->vInputs, s_pMan->pGia, Abc_NtkRecGetObj(pTemp)) == Abc_ObjGetMax2(s_pMan->vInputs, s_pMan->pGia, Abc_NtkRecGetObj(pEntry)) ); - CountersS[ Abc_ObjGetMax2(s_pMan->vInputs, s_pMan->pGia, Abc_NtkRecGetObj(pTemp)) ]++; - CounterS++; - } - } - //printf( "Functions = %d. Expected = %d.\n", Counter, p->nAddedFuncs ); - //printf( "Subgraphs = %d. Expected = %d.\n", CounterS, p->nAdded ); - assert( Counter == p->nAddedFuncs ); - assert( CounterS == p->nAdded ); - // clean - - printf( "The record with %d AND nodes in %d subgraphs for %d functions with %d inputs:\n", - Gia_ManAndNum(pGia), Gia_ManPoNum(pGia), p->nAddedFuncs, Gia_ManPiNum(pGia) ); - for ( i = 0; i <= 16; i++ ) - { - if ( Counters[i] ) - printf( "Inputs = %2d. Funcs = %8d. Subgrs = %8d. Ratio = %6.2f.\n", i, Counters[i], CountersS[i], 1.0*CountersS[i]/Counters[i] ); - } - - printf( "Subgraphs tried = %10d. (%6.2f %%)\n", p->nTried, !p->nTried? 0 : 100.0*p->nTried/p->nTried ); - printf( "Subgraphs filtered by support size = %10d. (%6.2f %%)\n", p->nFilterSize, !p->nTried? 0 : 100.0*p->nFilterSize/p->nTried ); - printf( "Subgraphs filtered by structural redundancy = %10d. (%6.2f %%)\n", p->nFilterRedund, !p->nTried? 0 : 100.0*p->nFilterRedund/p->nTried ); - printf( "Subgraphs filtered by volume = %10d. (%6.2f %%)\n", p->nFilterVolume, !p->nTried? 0 : 100.0*p->nFilterVolume/p->nTried ); - printf( "Subgraphs filtered by TT redundancy = %10d. (%6.2f %%)\n", p->nFilterTruth, !p->nTried? 0 : 100.0*p->nFilterTruth/p->nTried ); - printf( "Subgraphs filtered by error = %10d. (%6.2f %%)\n", p->nFilterError, !p->nTried? 0 : 100.0*p->nFilterError/p->nTried ); - printf( "Subgraphs filtered by isomorphism = %10d. (%6.2f %%)\n", p->nFilterSame, !p->nTried? 0 : 100.0*p->nFilterSame/p->nTried ); - printf( "Subgraphs added = %10d. (%6.2f %%)\n", p->nAdded, !p->nTried? 0 : 100.0*p->nAdded/p->nTried ); - printf( "Functions added = %10d. (%6.2f %%)\n", p->nAddedFuncs, !p->nTried? 0 : 100.0*p->nAddedFuncs/p->nTried ); - if(s_pMan->fTrim) - printf( "Functions trimed = %10d. (%6.2f %%)\n", p->nTrimed, !p->nTried? 0 : 100.0*p->nTrimed/p->nTried ); - p->timeOther = p->timeTotal - p->timeCollect - p->timeTruth - p->timeCanon - p->timeInsert - p->timeBuild - p->timeTrim - p->timeMerge - p->timeReHash; - ABC_PRTP( "Collecting nodes ", p->timeCollect, p->timeTotal); - ABC_PRTP( "Computing truth ", p->timeTruth, p->timeTotal ); - ABC_PRTP( "Canonicizing ", p->timeCanon, p->timeTotal ); - ABC_PRTP( "Building ", p->timeBuild, p->timeTotal ); - ABC_PRTP( "ReHash ", p->timeReHash, p->timeTotal ); - ABC_PRTP( "Merge ", p->timeMerge, p->timeTotal ); - ABC_PRTP( "Insert ", p->timeInsert, p->timeTotal); - if(s_pMan->fTrim) - ABC_PRTP( "Filter ", p->timeTrim, p->timeTotal); - ABC_PRTP( "Other ", p->timeOther, p->timeTotal ); - ABC_PRTP( "TOTAL ", p->timeTotal, p->timeTotal ); - - if ( p->nFunsFound ) - { - printf("\n"); - printf( "During rewriting found = %d and not found = %d functions.\n", p->nFunsFound, p->nFunsNotFound ); - printf( "Functions tried = %10d. (%6.2f %%)\n", p->nFunsTried, !p->nFunsTried? 0 : 100.0*p->nFunsTried/p->nFunsTried ); - printf( "Functions filtered by support = %10d. (%6.2f %%)\n", p->nFunsFilteredBysupport, !p->nFunsFilteredBysupport? 0 : 100.0*p->nFunsFilteredBysupport/p->nFunsTried ); - printf( "Functions not found in lib = %10d. (%6.2f %%)\n", p->nFunsNotFound, !p->nFunsNotFound? 0 : 100.0*p->nFunsNotFound/p->nFunsTried ); - printf( "Functions founded = %10d. (%6.2f %%)\n", p->nFunsFound, !p->nFunsFound? 0 : 100.0*p->nFunsFound/p->nFunsTried ); - printf( "Functions delay computed = %10d. Ratio = %6.2f.\n", p->nFunsDelayComput, !p->nFunsDelayComput? 0 : 1.0*p->nFunsDelayComput/p->nFunsFound ); - p->timeIfOther = p->timeIfTotal - p->timeIfCanonicize - p->timeIfComputDelay -p->timeIfDerive; - ABC_PRTP( "Canonicize ", p->timeIfCanonicize, p->timeIfTotal ); - ABC_PRTP( "Compute Delay ", p->timeIfComputDelay, p->timeIfTotal ); - ABC_PRTP( "Derive ", p->timeIfDerive, p->timeIfTotal ); - ABC_PRTP( "Other ", p->timeIfOther, p->timeIfTotal ); - ABC_PRTP( "TOTAL ", p->timeIfTotal, p->timeIfTotal ); - } - -} - -/**Function************************************************************* - - Synopsis [Adds the cut function to the internal storage.] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -static void Abc_NtkRecCollectNodes_rec( If_Obj_t * pNode, Vec_Ptr_t * vNodes ) -{ - if ( pNode->fMark ) - return; - pNode->fMark = 1; - assert( If_ObjIsAnd(pNode) ); - Abc_NtkRecCollectNodes_rec( If_ObjFanin0(pNode), vNodes ); - Abc_NtkRecCollectNodes_rec( If_ObjFanin1(pNode), vNodes ); - Vec_PtrPush( vNodes, pNode ); -} - -/**Function************************************************************* - - Synopsis [Adds the cut function to the internal storage.] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -static int Abc_NtkRecCollectNodes( If_Man_t * pIfMan, If_Obj_t * pRoot, If_Cut_t * pCut, Vec_Ptr_t * vNodes ) -{ - If_Obj_t * pLeaf; - int i, RetValue = 1; - - // collect the internal nodes of the cut - Vec_PtrClear( vNodes ); - If_CutForEachLeaf( pIfMan, pCut, pLeaf, i ) - { - Vec_PtrPush( vNodes, pLeaf ); - assert( pLeaf->fMark == 0 ); - pLeaf->fMark = 1; - } - - // collect other nodes - Abc_NtkRecCollectNodes_rec( pRoot, vNodes ); - - // check if there are leaves, such that both of their fanins are marked - // this indicates a redundant cut - If_CutForEachLeaf( pIfMan, pCut, pLeaf, i ) - { - if ( !If_ObjIsAnd(pLeaf) ) - continue; - if ( If_ObjFanin0(pLeaf)->fMark && If_ObjFanin1(pLeaf)->fMark ) - { - RetValue = 0; - break; - } - } - - // clean the mark - Vec_PtrForEachEntry( If_Obj_t *, vNodes, pLeaf, i ) - pLeaf->fMark = 0; - return RetValue; -} - -/**Function************************************************************* - - Synopsis [Computes truth tables of nodes in the cut.] - - Description [Returns 0 if the TT does not depend on some cut variables. - Or if the TT can be expressed simpler using other nodes.] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -static int Abc_NtkRecCutTruth( Vec_Ptr_t * vNodes, int nLeaves, Vec_Ptr_t * vTtTemps, Vec_Ptr_t * vTtElems ) -{ - unsigned * pSims, * pSims0, * pSims1; - unsigned * pTemp = s_pMan->pTemp2; - unsigned uWord; - If_Obj_t * pObj, * pObj2, * pRoot; - int i, k, nLimit, nInputs = s_pMan->nVars; - - assert( Vec_PtrSize(vNodes) > nLeaves ); - - // set the elementary truth tables and compute the truth tables of the nodes - Vec_PtrForEachEntry( If_Obj_t *, vNodes, pObj, i ) - { - pObj->pCopy = Vec_PtrEntry(vTtTemps, i); - pSims = (unsigned *)pObj->pCopy; - if ( i < nLeaves ) - { - Kit_TruthCopy( pSims, (unsigned *)Vec_PtrEntry(vTtElems, i), nInputs ); - continue; - } - assert( If_ObjIsAnd(pObj) ); - // get hold of the simulation information - pSims0 = (unsigned *)If_ObjFanin0(pObj)->pCopy; - pSims1 = (unsigned *)If_ObjFanin1(pObj)->pCopy; - // simulate the node - Kit_TruthAndPhase( pSims, pSims0, pSims1, nInputs, If_ObjFaninC0(pObj), If_ObjFaninC1(pObj) ); - } - - // check the support size - pRoot = (If_Obj_t *)Vec_PtrEntryLast( vNodes ); - pSims = (unsigned *)pRoot->pCopy; - if ( Kit_TruthSupport(pSims, nInputs) != Kit_BitMask(nLeaves) ) - return 0; - - // make sure none of the nodes has the same simulation info as the output - // check pairwise comparisons - nLimit = Vec_PtrSize(vNodes) - 1; - Vec_PtrForEachEntryStop( If_Obj_t *, vNodes, pObj, i, nLimit ) - { - pSims0 = (unsigned *)pObj->pCopy; - if ( Kit_TruthIsEqualWithPhase(pSims, pSims0, nInputs) ) - return 0; - Vec_PtrForEachEntryStop( If_Obj_t *, vNodes, pObj2, k, i ) - { - if ( (If_ObjFanin0(pRoot) == pObj && If_ObjFanin1(pRoot) == pObj2) || - (If_ObjFanin1(pRoot) == pObj && If_ObjFanin0(pRoot) == pObj2) ) - continue; - pSims1 = (unsigned *)pObj2->pCopy; - - uWord = pSims0[0] & pSims1[0]; - if ( pSims[0] == uWord || pSims[0] == ~uWord ) - { - Kit_TruthAndPhase( pTemp, pSims0, pSims1, nInputs, 0, 0 ); - if ( Kit_TruthIsEqualWithPhase(pSims, pTemp, nInputs) ) - return 0; - } - - uWord = pSims0[0] & ~pSims1[0]; - if ( pSims[0] == uWord || pSims[0] == ~uWord ) - { - Kit_TruthAndPhase( pTemp, pSims0, pSims1, nInputs, 0, 1 ); - if ( Kit_TruthIsEqualWithPhase(pSims, pTemp, nInputs) ) - return 0; - } - - uWord = ~pSims0[0] & pSims1[0]; - if ( pSims[0] == uWord || pSims[0] == ~uWord ) - { - Kit_TruthAndPhase( pTemp, pSims0, pSims1, nInputs, 1, 0 ); - if ( Kit_TruthIsEqualWithPhase(pSims, pTemp, nInputs) ) - return 0; - } - - uWord = ~pSims0[0] & ~pSims1[0]; - if ( pSims[0] == uWord || pSims[0] == ~uWord ) - { - Kit_TruthAndPhase( pTemp, pSims0, pSims1, nInputs, 1, 1 ); - if ( Kit_TruthIsEqualWithPhase(pSims, pTemp, nInputs) ) - return 0; - } - } - } - return 1; -} - - - -/**Function************************************************************* - - Synopsis [Adds the cut function to the internal storage.] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -int Abc_NtkRecAddCut2( If_Man_t * pIfMan, If_Obj_t * pRoot, If_Cut_t * pCut ) -{ - static int s_MaxSize[16] = { 0 }; - char pCanonPerm[16]; - Gia_Obj_t * pObj = NULL, *pPO; - int iFanin0, iFanin1, iRecObj = -1; - int * ppSpot, lit;//, test; - Gia_Man_t * pAig = s_pMan->pGia; - If_Obj_t * pIfObj; - Vec_Ptr_t * vNodes = s_pMan->vNodes; - unsigned * pInOut = s_pMan->pTemp1; - unsigned * pTemp = s_pMan->pTemp2; - unsigned *pTruth;//, *pTruthDst; - int objectID = 0; - int i, RetValue, nNodes, nNodesBeg, nInputs = s_pMan->nVars, nLeaves = If_CutLeaveNum(pCut); - unsigned uCanonPhase; - int clk, timeInsert, timeBuild; - //int begin = Abc_Clock(); - assert( nInputs <= 16 ); - assert( nInputs == (int)pCut->nLimit ); - s_pMan->nTried++; - // skip small cuts - if ( nLeaves < 2 ) - { - s_pMan->nFilterSize++; - return 1; - } - // collect internal nodes and skip redundant cuts -clk = Abc_Clock(); - RetValue = Abc_NtkRecCollectNodes( pIfMan, pRoot, pCut, vNodes ); - -s_pMan->timeCollect += Abc_Clock() - clk; - if ( !RetValue ) - { - s_pMan->nFilterRedund++; - return 1; - } - - // skip cuts with very large volume - if ( Vec_PtrSize(vNodes) > nLeaves + 3*(nLeaves-1) + s_MaxSize[nLeaves] ) - { - s_pMan->nFilterVolume++; - return 1; - } - - - // compute truth table and skip the redundant structures -clk = Abc_Clock(); - RetValue = Abc_NtkRecCutTruth( vNodes, nLeaves, s_pMan->vTtTemps, s_pMan->vTtElems ); - s_pMan->timeTruth += Abc_Clock() - clk; - if ( !RetValue ) - { - //fprintf(file,"redundant structures\n"); - //fclose(file); - s_pMan->nFilterTruth++; - return 1; - } - - // copy the truth table - Kit_TruthCopy( pInOut, (unsigned *)pRoot->pCopy, nInputs ); - - // set permutation - for ( i = 0; i < nLeaves; i++ ) - pCanonPerm[i] = i; - - // semi-canonicize the truth table -clk = Abc_Clock(); - //uCanonPhase = Kit_TruthSemiCanonicize( pInOut, pTemp, nLeaves, pCanonPerm ); - uCanonPhase = Kit_TruthSemiCanonicize_new( pInOut, pTemp, nLeaves, pCanonPerm ); - If_CutTruthStretch(pInOut, nLeaves, s_pMan->nVars); - s_pMan->timeCanon += Abc_Clock() - clk; - // pCanonPerm and uCanonPhase show what was the variable corresponding to each var in the current truth - - // go through the variables in the new truth table -timeBuild = Abc_Clock(); - for ( i = 0; i < nLeaves; i++ ) - { - // get hold of the corresponding leaf - pIfObj = If_ManObj( pIfMan, pCut->pLeaves[(int)pCanonPerm[i]] ); - // get hold of the corresponding new node - pObj = Gia_ManPi( pAig, i ); - lit = Gia_ObjId(pAig, pObj); - lit = Abc_Var2Lit( lit, ((uCanonPhase & (1 << i)) != 0) ); - // map them - pIfObj->iCopy = lit; - } - - // build the node and compute its truth table - assert( Vec_PtrSize(vNodes) > 0 ); - nNodesBeg = Gia_ManObjNum( pAig ); - Vec_PtrForEachEntryStart( If_Obj_t *, vNodes, pIfObj, i, nLeaves ) - { - iFanin0 = Abc_LitNotCond( If_ObjFanin0(pIfObj)->iCopy, If_ObjFaninC0(pIfObj) ); - iFanin1 = Abc_LitNotCond( If_ObjFanin1(pIfObj)->iCopy, If_ObjFaninC1(pIfObj) ); - - nNodes = Gia_ManObjNum( pAig ); - iRecObj = Gia_ManHashAnd(pAig, iFanin0, iFanin1 ); - //assert( !Gia_IsComplement(pObj) ); - //pObj = Gia_Regular(pObj); - pIfObj->iCopy = iRecObj; - - } - //assert(pObj); - pObj = Gia_ManObj(pAig, Abc_Lit2Var(iRecObj)); - pTruth = (unsigned *)Gia_ObjComputeTruthTable(pAig, pObj); -s_pMan->timeBuild += Abc_Clock() - timeBuild; - - if ( Kit_TruthSupport(pTruth, nInputs) != Kit_BitMask(nLeaves) ) - { - s_pMan->nFilterError++; - printf( "S" ); - return 1; - } - - // compare the truth tables - if ( !Kit_TruthIsEqualWithPhase( pTruth, pInOut, nInputs ) ) - { - s_pMan->nFilterError++; - printf( "F" ); - return 1; - } -// Extra_PrintBinary( stdout, pInOut, 8 ); printf( "\n" ); - - // look up in the hash table and increase the hit number of the functional class - if(s_pMan->nAddedFuncs > 2 * s_pMan->nBins) - Abc_NtkRecResizeHash2(s_pMan); - ppSpot = Abc_NtkRecTableLookup2(s_pMan, s_pMan->pBins,s_pMan->nBins , pTruth, nInputs ); - Abc_NtkRecFrequencyInc(*ppSpot); - // if not new nodes were added and the node has a CO fanout - - if ( nNodesBeg == Gia_ManObjNum(pAig) && pObj->fMark1 == 1 ) - { - s_pMan->nFilterSame++; - //assert(*ppSpot != NULL); - return 1; - } - - // create PO for this node - objectID = Gia_ObjId(pAig, pObj); - pPO = Gia_ManObj(pAig, Gia_ManAppendCo(pAig, Gia_ObjToLit(pAig, pObj)) >> 1); - pObj = Gia_ManObj(pAig, objectID); - assert(pObj->fMark1 == 0); - pObj->fMark1 = 1; - -// if ( Vec_PtrSize(s_pMan->vTtNodes) <= Gia_ManPoNum(pAig) ) -// { -// while ( Vec_PtrSize(s_pMan->vTtNodes) <= Gia_ObjCioId(pPO) ) -// Vec_PtrPush( s_pMan->vTtNodes, Mem_FixedEntryFetch(s_pMan->pMmTruth) ); -// } - -// pTruthDst = (unsigned *)Vec_PtrEntry( s_pMan->vTtNodes, Gia_ObjCioId(pPO)); -// Kit_TruthCopy(pTruthDst, pTruthSrc, s_pMan->nVars); - //Rec_MemSetEntry( s_pMan, Gia_ObjCioId(pPO), pTruthSrc ); - - // add the resulting truth table to the hash table - timeInsert = Abc_Clock(); - Abc_NtkRecInsertToLookUpTable2(s_pMan, ppSpot, pPO, nLeaves, pTruth, s_pMan->fTrim); - s_pMan->timeInsert += Abc_Clock() - timeInsert; -// if (pIfMan->pPars->fDelayOpt) -// Abc_NtkRecAddSOPB(pIfMan, pCut, pTruth, pCanonPerm, uCanonPhase ); - return 1; -} - -/**Function************************************************************* - - Synopsis [Performs renoding as technology mapping.] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -void Abc_NtkRecAdd2( Abc_Ntk_t * pNtk, int fUseSOPB) -{ - extern Abc_Ntk_t * Abc_NtkIf( Abc_Ntk_t * pNtk, If_Par_t * pPars ); - extern int Abc_NtkRecAddCut( If_Man_t * pIfMan, If_Obj_t * pRoot, If_Cut_t * pCut ); - - If_Par_t Pars, * pPars = &Pars; - Abc_Ntk_t * pNtkNew; - int clk = Abc_Clock(); - - if ( Abc_NtkGetChoiceNum( pNtk ) ) - printf( "Performing recoding structures with choices.\n" ); - - // create hash table if not available - if ( s_pMan->pGia->pHTable == NULL ) - Gia_ManHashStart( s_pMan->pGia ); - - // set defaults - memset( pPars, 0, sizeof(If_Par_t) ); - // user-controlable paramters - pPars->nLutSize = s_pMan->nVarsInit; - pPars->nCutsMax = s_pMan->nCuts; - pPars->nFlowIters = 0; - pPars->nAreaIters = 0; - pPars->DelayTarget = -1; - pPars->Epsilon = (float)0.005; - pPars->fPreprocess = 0; - pPars->fArea = 1; - pPars->fFancy = 0; - pPars->fExpRed = 0; - pPars->fLatchPaths = 0; - pPars->fSeqMap = 0; - pPars->fVerbose = 0; - //pPars->fCutMin = 1; - // internal parameters - if (fUseSOPB) - { - pPars->fTruth = 1; - pPars->fUsePerm = 1; - pPars->fDelayOpt = 1; - } - else - { - pPars->fTruth = 1; - pPars->fUsePerm = 0; - pPars->fDelayOpt = 0; - } - pPars->nLatchesCi = 0; - pPars->nLatchesCo = 0; - pPars->pLutLib = NULL; // Abc_FrameReadLibLut(); - pPars->pTimesArr = NULL; - pPars->pTimesArr = NULL; - pPars->fUseBdds = 0; - pPars->fUseSops = 0; - pPars->fUseCnfs = 0; - pPars->fUseMv = 0; - pPars->fSkipCutFilter = 1; - pPars->pFuncCost = NULL; - pPars->pFuncUser = Abc_NtkRecAddCut2; - - // perform recording - pNtkNew = Abc_NtkIf( pNtk, pPars ); - Abc_NtkDelete( pNtkNew ); -s_pMan->timeTotal += Abc_Clock() - clk; - -// if ( !Abc_NtkCheck( s_pMan->pNtk ) ) -// printf( "Abc_NtkRecAdd: The network check has failed.\n" ); -} - - -/**Function************************************************************* - - Synopsis [Compute delay of the structure using pin-to-pin delay.] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -static inline int If_CutComputDelay(If_Man_t* p, Rec_Obj_t2* entry, If_Cut_t* pCut, char* pCanonPerm , int nVars) -{ - If_Obj_t* pLeaf; - int i, delayTemp, delayMax = -ABC_INFINITY; - for (i = 0; i < nVars; i++) - { - pLeaf = If_ManObj(p, (pCut)->pLeaves[(int)pCanonPerm[i]]); - pLeaf = If_Regular(pLeaf); - delayTemp = entry->pinToPinDelay[i] + If_ObjCutBest(pLeaf)->Delay; - if(delayTemp > delayMax) - delayMax = delayTemp; - } - // plus each pin's delay with its pin-to-output delay, the biggest one is the delay of the structure. - return delayMax; -} - - /**Function************************************************************* - - Synopsis [Look up the best strcuture in the library.] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ - static int Abc_NtkRecLookUpEnum(If_Man_t * pIfMan,If_Cut_t * pCut, int * ppSpot, int * pCandMin, char * pCanonPerm) - { - int DelayMin = ABC_INFINITY , Delay = -ABC_INFINITY; - int pCand; - int nLeaves = pCut->nLeaves; - *pCandMin = -1; - assert( *ppSpot != -1 ); - for ( pCand = *ppSpot; pCand != -1 ; pCand = Rec_Obj(s_pMan,pCand)->pNext ) - { - s_pMan->nFunsDelayComput++; - Delay = If_CutComputDelay(pIfMan, Rec_Obj(s_pMan,pCand), pCut, pCanonPerm ,nLeaves); - if ( DelayMin > Delay ) - { - DelayMin = Delay; - *pCandMin = pCand; - } - else if(Delay == DelayMin) - { - if(Rec_Obj(s_pMan,pCand)->cost < Rec_Obj(s_pMan, *pCandMin)->cost) - *pCandMin = pCand; - } - } - assert( *pCandMin != -1 ); - return DelayMin; - } - - /**Function************************************************************* - - Synopsis [Look up the best strcuture in the library.] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ - static Rec_Obj_t2 * Abc_NtkRecLookUpBest(If_Man_t * pIfMan,If_Cut_t * pCut, unsigned * pInOut, char * pCanonPerm, int * fCompl, int * delayBest) - { - int pCandMin = REC_EMPTY_ID, pCandMinCompl = REC_EMPTY_ID, *ppSpot; - int delay = ABC_INFINITY, delayCompl = ABC_INFINITY; - int nVars = s_pMan->nVars; - //int nLeaves = pCut->nLeaves; - ppSpot = Abc_NtkRecTableLookup2(s_pMan, s_pMan->pBins, s_pMan->nBins, pInOut, nVars ); - if (*ppSpot != REC_EMPTY_ID) - delay = Abc_NtkRecLookUpEnum(pIfMan, pCut, ppSpot, &pCandMin, pCanonPerm); - Kit_TruthNot(pInOut, pInOut, nVars); - ppSpot = Abc_NtkRecTableLookup2(s_pMan, s_pMan->pBins, s_pMan->nBins, pInOut, nVars ); - if (*ppSpot != REC_EMPTY_ID) - delayCompl = Abc_NtkRecLookUpEnum(pIfMan, pCut, ppSpot, &pCandMinCompl, pCanonPerm); - if (delayBest) - *delayBest = delay < delayCompl ? delay : delayCompl; - if (pCandMin == REC_EMPTY_ID && pCandMinCompl == REC_EMPTY_ID) - return NULL; - else if (pCandMin != REC_EMPTY_ID && pCandMinCompl != REC_EMPTY_ID) - { - if (delay > delayCompl || (delay == delayCompl && Rec_Obj(s_pMan, pCandMin)->cost > Rec_Obj(s_pMan, pCandMinCompl)->cost)) - { - if (fCompl) - *fCompl = 1; - return Rec_Obj(s_pMan, pCandMinCompl); - } - else - { - if (fCompl) - *fCompl = 0; - return Rec_Obj(s_pMan, pCandMin); - } - } - else if (pCandMin != REC_EMPTY_ID) - { - if (fCompl) - *fCompl = 0; - return Rec_Obj(s_pMan, pCandMin); - } - else - { - if (fCompl) - *fCompl = 1; - return Rec_Obj(s_pMan, pCandMinCompl); - } - } - - /**Function************************************************************* - - Synopsis [Computes the delay using library.] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -int If_CutDelayRecCost2(If_Man_t* p, If_Cut_t* pCut, If_Obj_t * pObj) -{ - //int fVerbose = 0; - int timeDelayComput, timeTotal = Abc_Clock(), timeCanonicize; - int nLeaves, i, DelayMin = ABC_INFINITY , * pDelayBest = &DelayMin; - char pCanonPerm[16]; - unsigned uCanonPhase; - unsigned* pTruthRec; - Rec_Obj_t2 * pCandMin; - //Abc_Ntk_t *pAig = s_pMan->pNtk; - unsigned *pInOut = s_pMan->pTemp1; - unsigned *pTemp = s_pMan->pTemp2; - int nVars = s_pMan->nVars; - //int Counter; - assert( s_pMan != NULL ); - nLeaves = If_CutLeaveNum(pCut); - s_pMan->nFunsTried++; - assert( nLeaves >= 2 && nLeaves <= nVars ); - Kit_TruthCopy(pInOut, If_CutTruth(p, pCut), nLeaves); - //if not every variables are in the support, skip this cut. - if ( Kit_TruthSupport(pInOut, nLeaves) != Kit_BitMask(nLeaves) ) - { - DelayMin = 0; - //s_pMan->nFunsFilteredBysupport++; - pCut->fUser = 1; - pCut->fUseless = 0; - pCut->Cost = 1; - for (i = 0; i < nLeaves; i++) - { - if(Kit_TruthVarInSupport( pInOut, nLeaves, i )) - { - pCut->pPerm[i] = 0; - DelayMin = If_ObjCutBest(If_ManObj( p, pCut->pLeaves[i]))->Delay; - } - else - pCut->pPerm[i] = IF_BIG_CHAR; - } - - return DelayMin; - } - timeCanonicize = Abc_Clock(); - //canonicize - for (i = 0; i < nLeaves; i++) - pCanonPerm[i] = i; - uCanonPhase = Kit_TruthSemiCanonicize_new(pInOut, pTemp, nLeaves, pCanonPerm); - If_CutTruthStretch(pInOut, nLeaves, nVars); - s_pMan->timeIfCanonicize += Abc_Clock() - timeCanonicize; - timeDelayComput = Abc_Clock(); - pCandMin = Abc_NtkRecLookUpBest(p, pCut, pInOut, pCanonPerm, NULL,pDelayBest); - assert (!(pCandMin == NULL && nLeaves == 2)); - s_pMan->timeIfComputDelay += Abc_Clock() - timeDelayComput; - //functional class not found in the library. - if ( pCandMin == NULL ) - { - s_pMan->nFunsNotFound++; - pCut->Cost = IF_COST_MAX; - pCut->fUser = 1; - pCut->fUseless = 1; - return ABC_INFINITY; - } - s_pMan->nFunsFound++; - // make sure the truth table is the same -// pTruthRec = (unsigned*)Vec_PtrEntry( s_pMan->vTtNodes, Rec_ObjID(s_pMan, pCandMin) ); - pTruthRec = Rec_MemReadEntry( s_pMan, pCandMin->truthID ); - if ( !Kit_TruthIsEqualWithPhase( pTruthRec, pInOut, nLeaves ) ) - { - assert( 0 ); - s_pMan->nIfMapError++; - return -1; - } - // mark as user cut. - pCut->fUser = 1; - - //assert( pCandMin != NULL ); - for ( i = 0; i < nLeaves; i++ ) - { - pCut->pPerm[(int)pCanonPerm[i]] = pCandMin->pinToPinDelay[i]; - } - s_pMan->timeIfTotal += Abc_Clock() - timeTotal; - pCut->Cost = pCandMin->cost; - return DelayMin; - -} - - /**Function************************************************************* - - Synopsis [Build up the structure using library.] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -Hop_Obj_t * Abc_NtkRecBuildUp_rec2(Hop_Man_t* pMan, Gia_Obj_t* pObj, Vec_Ptr_t * vNodes) -{ - Hop_Obj_t * pRes0, *pRes1, *pRes; - Gia_Obj_t *pRegular = Gia_Regular(pObj); - if (Gia_ObjIsTravIdCurrent(s_pMan->pGia, pRegular) || Gia_ObjIsPi(s_pMan->pGia, pRegular)) - return (Hop_Obj_t *)Vec_PtrEntry(vNodes, Gia_ObjId(s_pMan->pGia, pRegular)); - Gia_ObjSetTravIdCurrent(s_pMan->pGia, pRegular); - pRes0 = Abc_NtkRecBuildUp_rec2(pMan, Gia_ObjFanin0(pRegular), vNodes); - pRes0 = Hop_NotCond(pRes0, pRegular->fCompl0); - pRes1 = Abc_NtkRecBuildUp_rec2(pMan, Gia_ObjFanin1(pRegular), vNodes); - pRes1 = Hop_NotCond(pRes1, pRegular->fCompl1); - pRes = Hop_And(pMan, pRes0, pRes1); - Vec_PtrWriteEntry(vNodes,Gia_ObjId(s_pMan->pGia, pRegular),pRes); - return pRes; -} - -/**Function************************************************************* - - Synopsis [Derive the final network from the library.] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -Hop_Obj_t * Abc_RecToHop2( Hop_Man_t * pMan, If_Man_t * pIfMan, If_Cut_t * pCut, If_Obj_t * pIfObj ) -{ - Rec_Obj_t2 * pCandMin; - Hop_Obj_t* pHopObj, * pFan0, * pFan1; - Gia_Obj_t* pGiaObj, *pGiaTemp; - Gia_Man_t * pAig = s_pMan->pGia; - int nLeaves, i;// DelayMin = ABC_INFINITY , Delay = -ABC_INFINITY - unsigned uCanonPhase; - int nVars = s_pMan->nVars; - char pCanonPerm[16]; - unsigned *pInOut = s_pMan->pTemp1; - unsigned *pTemp = s_pMan->pTemp2; - int time = Abc_Clock(); - int fCompl; - int * pCompl = &fCompl; - nLeaves = If_CutLeaveNum(pCut); -// if (nLeaves < 3) -// return Abc_NodeTruthToHop(pMan, pIfMan, pCut); - Kit_TruthCopy(pInOut, If_CutTruth(pIfMan, pCut), pCut->nLimit); - //special cases when cut-minimization return 2, that means there is only one leaf in the cut. - if ((Kit_TruthIsConst0(pInOut, nLeaves) && pCut->fCompl == 0) || (Kit_TruthIsConst1(pInOut, nLeaves) && pCut->fCompl == 1)) - return Hop_ManConst0(pMan); - if ((Kit_TruthIsConst0(pInOut, nLeaves) && pCut->fCompl == 1) || (Kit_TruthIsConst1(pInOut, nLeaves) && pCut->fCompl == 0)) - return Hop_ManConst1(pMan); - if (Kit_TruthSupport(pInOut, nLeaves) != Kit_BitMask(nLeaves)) - { - for (i = 0; i < nLeaves; i++) - if(Kit_TruthVarInSupport( pInOut, nLeaves, i )) - return Hop_NotCond(Hop_IthVar(pMan, i), (pCut->fCompl ^ ((*pInOut & 0x01) > 0))); - } - - for (i = 0; i < nLeaves; i++) - pCanonPerm[i] = i; - uCanonPhase = Kit_TruthSemiCanonicize_new(pInOut, pTemp, nLeaves, pCanonPerm); - If_CutTruthStretch(pInOut, nLeaves, nVars); - pCandMin = Abc_NtkRecLookUpBest(pIfMan, pCut, pInOut, pCanonPerm, pCompl,NULL); - -/* - Vec_PtrGrow(s_pMan->vLabels, Gia_ManObjNum(pAig)); - s_pMan->vLabels->nSize = s_pMan->vLabels->nCap; - for (i = 0; i < nLeaves; i++) - { - pGiaObj = Gia_ManPi( pAig, i ); - pHopObj = Hop_IthVar(pMan, pCanonPerm[i]); - pHopObj = Hop_NotCond(pHopObj, ((uCanonPhase & (1 << i)) > 0)); - Vec_PtrWriteEntry(s_pMan->vLabels, Gia_ObjId(pAig, pGiaObj), pHopObj); - } - //Abc_NtkIncrementTravId(pAig); - Gia_ManIncrementTravId(pAig); - //derive the best structure in the library. - pHopObj = Abc_NtkRecBuildUp_rec2(pMan, Abc_NtkRecGetObj(Rec_ObjID(s_pMan, pCandMin)), s_pMan->vLabels); -*/ - - // get the top-most GIA node - pGiaObj = Abc_NtkRecGetObj( Rec_ObjID(s_pMan, pCandMin) ); - assert( Gia_ObjIsAnd(pGiaObj) || Gia_ObjIsPi(pAig, pGiaObj) ); - // collect internal nodes into pAig->vTtNodes - if ( pAig->vTtNodes == NULL ) - pAig->vTtNodes = Vec_IntAlloc( 256 ); - Gia_ObjCollectInternal( pAig, pGiaObj ); - // collect HOP nodes for leaves - Vec_PtrClear( s_pMan->vLabels ); - for (i = 0; i < nLeaves; i++) - { - pHopObj = Hop_IthVar(pMan, pCanonPerm[i]); - pHopObj = Hop_NotCond(pHopObj, ((uCanonPhase & (1 << i)) > 0)); - Vec_PtrPush(s_pMan->vLabels, pHopObj); - } - // compute HOP nodes for internal nodes - Gia_ManForEachObjVec( pAig->vTtNodes, pAig, pGiaTemp, i ) - { - pGiaTemp->fMark0 = 0; // unmark node marked by Gia_ObjCollectInternal() - - if ( Gia_ObjIsAnd(Gia_ObjFanin0(pGiaTemp)) ) - pFan0 = (Hop_Obj_t *)Vec_PtrEntry(s_pMan->vLabels, Gia_ObjNum(pAig, Gia_ObjFanin0(pGiaTemp)) + nLeaves); - else - pFan0 = (Hop_Obj_t *)Vec_PtrEntry(s_pMan->vLabels, Gia_ObjCioId(Gia_ObjFanin0(pGiaTemp))); - pFan0 = Hop_NotCond(pFan0, Gia_ObjFaninC0(pGiaTemp)); - - if ( Gia_ObjIsAnd(Gia_ObjFanin1(pGiaTemp)) ) - pFan1 = (Hop_Obj_t *)Vec_PtrEntry(s_pMan->vLabels, Gia_ObjNum(pAig, Gia_ObjFanin1(pGiaTemp)) + nLeaves); - else - pFan1 = (Hop_Obj_t *)Vec_PtrEntry(s_pMan->vLabels, Gia_ObjCioId(Gia_ObjFanin1(pGiaTemp))); - pFan1 = Hop_NotCond(pFan1, Gia_ObjFaninC1(pGiaTemp)); - - pHopObj = Hop_And(pMan, pFan0, pFan1); - Vec_PtrPush(s_pMan->vLabels, pHopObj); - } - // get the final result - if ( Gia_ObjIsAnd(pGiaObj) ) - pHopObj = (Hop_Obj_t *)Vec_PtrEntry(s_pMan->vLabels, Gia_ObjNum(pAig, pGiaObj) + nLeaves); - else if ( Gia_ObjIsPi(pAig, pGiaObj) ) - pHopObj = (Hop_Obj_t *)Vec_PtrEntry(s_pMan->vLabels, Gia_ObjCioId(pGiaObj)); - else assert( 0 ); - - - s_pMan->timeIfDerive += Abc_Clock() - time; - s_pMan->timeIfTotal += Abc_Clock() - time; - // complement the result if needed - return Hop_NotCond(pHopObj, (pCut->fCompl)^(((uCanonPhase & (1 << nLeaves)) > 0)) ^ fCompl); -} - -/**Function************************************************************* - - Synopsis [Derive the final network from the library.] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -int Abc_RecToGia2( Gia_Man_t * pMan, If_Man_t * pIfMan, If_Cut_t * pCut, If_Obj_t * pIfObj, Vec_Int_t * vLeaves, int fHash ) -{ - Rec_Obj_t2 * pCandMin; - int pHopObj, pFan0, pFan1; - Gia_Obj_t* pGiaObj, *pGiaTemp; - Gia_Man_t * pAig = s_pMan->pGia; - int nLeaves, i;// DelayMin = ABC_INFINITY , Delay = -ABC_INFINITY - unsigned uCanonPhase; - int nVars = s_pMan->nVars; - char pCanonPerm[16]; - unsigned *pInOut = s_pMan->pTemp1; - unsigned *pTemp = s_pMan->pTemp2; - int time = Abc_Clock(); - int fCompl; - int * pCompl = &fCompl; - nLeaves = If_CutLeaveNum(pCut); -// if (nLeaves < 3) -// return Abc_NodeTruthToHop(pMan, pIfMan, pCut); - Kit_TruthCopy(pInOut, If_CutTruth(pIfMan, pCut), pCut->nLimit); - //special cases when cut-minimization return 2, that means there is only one leaf in the cut. - if ((Kit_TruthIsConst0(pInOut, nLeaves) && pCut->fCompl == 0) || (Kit_TruthIsConst1(pInOut, nLeaves) && pCut->fCompl == 1)) - return 0; - if ((Kit_TruthIsConst0(pInOut, nLeaves) && pCut->fCompl == 1) || (Kit_TruthIsConst1(pInOut, nLeaves) && pCut->fCompl == 0)) - return 1; - if (Kit_TruthSupport(pInOut, nLeaves) != Kit_BitMask(nLeaves)) - { - for (i = 0; i < nLeaves; i++) - if(Kit_TruthVarInSupport( pInOut, nLeaves, i )) - return Abc_LitNotCond( Vec_IntEntry(vLeaves, i), (pCut->fCompl ^ ((*pInOut & 0x01) > 0)) ); - } - - for (i = 0; i < nLeaves; i++) - pCanonPerm[i] = i; - uCanonPhase = Kit_TruthSemiCanonicize_new(pInOut, pTemp, nLeaves, pCanonPerm); - If_CutTruthStretch(pInOut, nLeaves, nVars); - pCandMin = Abc_NtkRecLookUpBest(pIfMan, pCut, pInOut, pCanonPerm, pCompl,NULL); - - // get the top-most GIA node - pGiaObj = Abc_NtkRecGetObj( Rec_ObjID(s_pMan, pCandMin) ); - assert( Gia_ObjIsAnd(pGiaObj) || Gia_ObjIsPi(pAig, pGiaObj) ); - // collect internal nodes into pAig->vTtNodes - if ( pAig->vTtNodes == NULL ) - pAig->vTtNodes = Vec_IntAlloc( 256 ); - Gia_ObjCollectInternal( pAig, pGiaObj ); - // collect HOP nodes for leaves - Vec_IntClear( s_pMan->vLabelsInt ); - for (i = 0; i < nLeaves; i++) - { - pHopObj = Vec_IntEntry(vLeaves, pCanonPerm[i]); - pHopObj = Abc_LitNotCond(pHopObj, ((uCanonPhase & (1 << i)) > 0)); - Vec_IntPush(s_pMan->vLabelsInt, pHopObj); - } - // compute HOP nodes for internal nodes - Gia_ManForEachObjVec( pAig->vTtNodes, pAig, pGiaTemp, i ) - { - pGiaTemp->fMark0 = 0; // unmark node marked by Gia_ObjCollectInternal() - - if ( Gia_ObjIsAnd(Gia_ObjFanin0(pGiaTemp)) ) - pFan0 = Vec_IntEntry(s_pMan->vLabelsInt, Gia_ObjNum(pAig, Gia_ObjFanin0(pGiaTemp)) + nLeaves); - else - pFan0 = Vec_IntEntry(s_pMan->vLabelsInt, Gia_ObjCioId(Gia_ObjFanin0(pGiaTemp))); - pFan0 = Abc_LitNotCond(pFan0, Gia_ObjFaninC0(pGiaTemp)); - - if ( Gia_ObjIsAnd(Gia_ObjFanin1(pGiaTemp)) ) - pFan1 = Vec_IntEntry(s_pMan->vLabelsInt, Gia_ObjNum(pAig, Gia_ObjFanin1(pGiaTemp)) + nLeaves); - else - pFan1 = Vec_IntEntry(s_pMan->vLabelsInt, Gia_ObjCioId(Gia_ObjFanin1(pGiaTemp))); - pFan1 = Abc_LitNotCond(pFan1, Gia_ObjFaninC1(pGiaTemp)); - - if ( fHash ) - pHopObj = Gia_ManHashAnd(pMan, pFan0, pFan1); - else - pHopObj = Gia_ManAppendAnd(pMan, pFan0, pFan1); - Vec_IntPush(s_pMan->vLabelsInt, pHopObj); - } - // get the final result - if ( Gia_ObjIsAnd(pGiaObj) ) - pHopObj = Vec_IntEntry(s_pMan->vLabelsInt, Gia_ObjNum(pAig, pGiaObj) + nLeaves); - else if ( Gia_ObjIsPi(pAig, pGiaObj) ) - pHopObj = Vec_IntEntry(s_pMan->vLabelsInt, Gia_ObjCioId(pGiaObj)); - else assert( 0 ); - - s_pMan->timeIfDerive += Abc_Clock() - time; - s_pMan->timeIfTotal += Abc_Clock() - time; - // complement the result if needed - return Abc_LitNotCond(pHopObj, (pCut->fCompl)^(((uCanonPhase & (1 << nLeaves)) > 0)) ^ fCompl); -} - -/**Function************************************************************* - - Synopsis [Returns the given record.] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -void Abc_NtkRecStop2() -{ - assert( s_pMan != NULL ); -// Abc_NtkRecDumpTruthTables( s_pMan ); - if ( s_pMan->pGia ) - Gia_ManStop(s_pMan->pGia); -// Vec_PtrFreeFree( s_pMan->vTtNodes ); - -// Mem_FixedStop( s_pMan->pMmTruth, 0 ); -// Vec_PtrFree( s_pMan->vTtNodes ); - Vec_MemFreeP( &s_pMan->vTtMem ); - - Vec_StrFree( s_pMan->vInputs ); - Vec_PtrFree( s_pMan->vTtElems ); - ABC_FREE( s_pMan->pBins ); - - // temporaries - ABC_FREE( s_pMan->pBytes ); - ABC_FREE( s_pMan->pMints ); - ABC_FREE( s_pMan->pTemp1 ); - ABC_FREE( s_pMan->pTemp2 ); - Vec_PtrFree( s_pMan->vNodes ); - Vec_PtrFree( s_pMan->vTtTemps ); - Vec_PtrFree( s_pMan->vLabels ); - Vec_IntFree( s_pMan->vLabelsInt ); - //if(s_pMan->pMemObj) - // Mem_FixedStop(s_pMan->pMemObj, 0); - Vec_IntFree( s_pMan->vUselessPos); - ABC_FREE(s_pMan->pRecObjs); -// if(s_pMan->vFiltered) -// Vec_StrFree(s_pMan->vFiltered); - - ABC_FREE( s_pMan ); - s_pMan = NULL; -} - -/**Function************************************************************* - - Synopsis [Adds the cut function to the internal storage.] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -void Abc_NtkRecCollectNodesFromLib_rec2(Gia_Man_t* pGia, Gia_Obj_t * pNode, Vec_Ptr_t * vNodes ) -{ - if ( Gia_ObjIsPi(pGia, pNode)) - return; - Abc_NtkRecCollectNodesFromLib_rec2(pGia, Gia_ObjFanin0(pNode), vNodes ); - Abc_NtkRecCollectNodesFromLib_rec2(pGia, Gia_ObjFanin1(pNode), vNodes ); - Vec_PtrPush( vNodes, pNode ); -} - -/**Function************************************************************* - - Synopsis [Adds the cut function to the internal storage.] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -void Abc_NtkRecCollectNodesFromLib2(Gia_Man_t* pGia, Gia_Obj_t * pRoot, Vec_Ptr_t * vNodes , int nVars) -{ - int i; - // collect the internal nodes of the cut - Vec_PtrClear( vNodes ); - for ( i = 0; i < nVars; i++ ) - Vec_PtrPush( vNodes, Gia_ManPi(pGia, i)); - - - // collect other nodes - Abc_NtkRecCollectNodesFromLib_rec2(pGia, pRoot, vNodes ); -} - -/**Function************************************************************* - - Synopsis [Computes truth tables of nodes in the cut.] - - Description [Returns 0 if the TT does not depend on some cut variables. - Or if the TT can be expressed simpler using other nodes.] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -void Abc_NtkRecCutTruthFromLib2( Gia_Man_t * pGia2, Vec_Ptr_t * vNodes, int nLeaves, Vec_Ptr_t * vTtTemps, Vec_Ptr_t * vTtElems ) -{ - unsigned * pSims, * pSims0, * pSims1; - //unsigned * pTemp = s_pMan->pTemp2; - Gia_Obj_t * pObj, * pRoot; - int i, nInputs = s_pMan->nVars; - - assert( Vec_PtrSize(vNodes) > nLeaves ); - Vec_PtrForEachEntry( Gia_Obj_t *, vNodes, pObj, i ) - { - Gia_ObjSetCopyF(pGia2, 0, pObj, i); - pSims = (unsigned *)Vec_PtrEntry(vTtTemps, i); - if ( i < nLeaves ) - { - Kit_TruthCopy( pSims, (unsigned *)Vec_PtrEntry(vTtElems, i), nInputs ); - continue; - } - // get hold of the simulation information - pSims0 = (unsigned *)Vec_PtrEntry(vTtTemps,Gia_ObjCopyF(pGia2, 0, Gia_ObjFanin0(pObj))); - pSims1 = (unsigned *)Vec_PtrEntry(vTtTemps,Gia_ObjCopyF(pGia2, 0, Gia_ObjFanin1(pObj))); - // simulate the node - Kit_TruthAndPhase( pSims, pSims0, pSims1, nInputs, Gia_ObjFaninC0(pObj), Gia_ObjFaninC1(pObj) ); - } - - // check the support size - pRoot = (Gia_Obj_t *)Vec_PtrEntryLast( vNodes ); - pSims = (unsigned *)Vec_PtrEntry(vTtTemps,Gia_ObjCopyF(pGia2, 0, pRoot)); - assert ( Kit_TruthSupport(pSims, nInputs) == Kit_BitMask(nLeaves) ); -} - -/**Function************************************************************* - - Synopsis [Adds the cut function to the internal storage.] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -void Abc_NtkRecAddFromLib2( Gia_Man_t * pGia2, Gia_Obj_t * pRoot, int nVars ) -{ - Gia_Obj_t * pObj = NULL, * pFanin0, * pFanin1, *pPO; - int* ppSpot; - Gia_Man_t * pGia = s_pMan->pGia; - Gia_Obj_t * pAbcObj; - Vec_Ptr_t * vNodes = s_pMan->vNodes; - unsigned * pInOut = s_pMan->pTemp1; - //unsigned * pTemp = s_pMan->pTemp2; - unsigned *pTruth;//, *pTruthDst; - int objectID; - int i, nNodes, nNodesBeg, nInputs = s_pMan->nVars, nLeaves = nVars; - assert( nInputs <= 16 ); - // collect internal nodes and skip redundant cuts - Abc_NtkRecCollectNodesFromLib2(pGia2, pRoot, vNodes , nLeaves); - Abc_NtkRecCutTruthFromLib2(pGia2, vNodes, nLeaves, s_pMan->vTtTemps, s_pMan->vTtElems ); - // copy the truth table - Kit_TruthCopy( pInOut, (unsigned *)Vec_PtrEntry(s_pMan->vTtTemps, Gia_ObjCopyF(pGia2, 0, pRoot)), nInputs ); - // go through the variables in the new truth table - for ( i = 0; i < nLeaves; i++ ) - { - // get hold of the corresponding leaf - pAbcObj = Gia_ManPi(pGia2, i); - // get hold of the corresponding new node - pObj = Gia_ManPi( pGia, i ); - // map them - Gia_ObjSetCopyF(pGia2, 0, pAbcObj, Gia_ObjId(pGia,pObj)); - } - - nNodesBeg = Gia_ManObjNum( pGia ); - Vec_PtrForEachEntryStart( Gia_Obj_t *, vNodes, pAbcObj, i, nLeaves ) - { - pFanin0 = Gia_NotCond(Gia_ManObj(pGia, Gia_ObjCopyF(pGia2, 0, Gia_ObjFanin0(pAbcObj))), Gia_ObjFaninC0(pAbcObj) ); - pFanin1 = Gia_NotCond(Gia_ManObj(pGia, Gia_ObjCopyF(pGia2, 0, Gia_ObjFanin1(pAbcObj))), Gia_ObjFaninC1(pAbcObj) ); - - nNodes = Gia_ManObjNum( pGia ); - pObj = Gia_ObjFromLit(pGia, Gia_ManHashAnd(pGia, Gia_ObjToLit(pGia,pFanin0), Gia_ObjToLit(pGia,pFanin1) )) ; - //assert( !Gia_IsComplement(pObj) ); - pObj = Gia_Regular(pObj); - Gia_ObjSetCopyF(pGia2, 0, pAbcObj, Gia_ObjId(pGia,pObj)); - } - assert(pObj); - pTruth = (unsigned *)Gia_ObjComputeTruthTable(pGia, pObj); - //pTruth = (unsigned *)Vec_PtrEntry( s_pMan->vTtNodes, Gia_ObjId(pGia, pObj) ); - assert ( Kit_TruthSupport(pTruth, nInputs) == Kit_BitMask(nLeaves) ); - // compare the truth tables - assert (Kit_TruthIsEqual( pTruth, pInOut, nInputs ) ); - - if(s_pMan->nAddedFuncs > 2 * s_pMan->nBins) - Abc_NtkRecResizeHash2(s_pMan); - ppSpot = Abc_NtkRecTableLookup2(s_pMan, s_pMan->pBins,s_pMan->nBins , pTruth, nInputs ); - // if not new nodes were added and the node has a CO fanout - - if ( nNodesBeg == Gia_ManObjNum(pGia) && pObj->fMark1 == 1 ) - { - s_pMan->nFilterSame++; - //assert(*ppSpot != NULL); - return; - } - - // create PO for this node - objectID = Gia_ObjId(pGia, pObj); - pPO = Gia_ManObj(pGia, Gia_ManAppendCo(pGia, Gia_ObjToLit(pGia, pObj)) >> 1); - pObj = Gia_ManObj(pGia, objectID); - assert(pObj->fMark1 == 0); - pObj->fMark1 = 1; - -// if ( Vec_PtrSize(s_pMan->vTtNodes) <= Gia_ManPoNum(pGia) ) -// { -// while ( Vec_PtrSize(s_pMan->vTtNodes) <= Gia_ObjCioId(pPO) ) -// Vec_PtrPush( s_pMan->vTtNodes, Mem_FixedEntryFetch(s_pMan->pMmTruth) ); -// } - -// pTruthDst = (unsigned *)Vec_PtrEntry( s_pMan->vTtNodes, Gia_ObjCioId(pPO)); -// Kit_TruthCopy(pTruthDst, pTruthSrc, s_pMan->nVars); - //Rec_MemSetEntry( s_pMan, Gia_ObjCioId(pPO), pTruthSrc ); - - // add the resulting truth table to the hash table - Abc_NtkRecInsertToLookUpTable2(s_pMan, ppSpot, pPO, nLeaves, pTruth, s_pMan->fTrim); - return; -} - -/**Function************************************************************* - - Synopsis [Starts the record for the given network.] - - Description [] - - SideEffects [] - - SeeAlso [] - -***********************************************************************/ -void Abc_NtkRecLibMerge2(Gia_Man_t* pGia2) -{ - int i; - Gia_Obj_t * pObj; - Abc_ManRec_t2 * p = s_pMan; - int clk = Abc_Clock(); - if ( Gia_ManPiNum(pGia2) > s_pMan->nVars ) - { - printf( "The library has more inputs than the record.\n"); - return; - } - pGia2->pCopies = ABC_FALLOC( int, Gia_ManObjNum(pGia2) ); - // create hash table if not available - if ( s_pMan->pGia->pHTable == NULL ) - Gia_ManHashStart( s_pMan->pGia ); - Abc_NtkRecMarkInputs(p, pGia2); - - // insert the PO nodes into the table - Gia_ManForEachPo( pGia2, pObj, i ) - { - p->nTried++; - //if the PO's input is a constant, skip it. - if (Gia_ObjChild0(pObj) == Gia_ManConst0(pGia2)) - { - p->nTrimed++; - continue; - } - pObj = Gia_ObjFanin0(pObj); - Abc_NtkRecAddFromLib2(pGia2, pObj, Abc_ObjGetMax2(s_pMan->vInputs, pGia2, pObj) ); - } - ABC_FREE(pGia2->pCopies); - - s_pMan->timeMerge += Abc_Clock() - clk; - s_pMan->timeTotal += Abc_Clock() - clk; -} - - - - -ABC_NAMESPACE_IMPL_END diff --git a/src/base/abci/module.make b/src/base/abci/module.make index 8d97c6cf..2f75a863 100644 --- a/src/base/abci/module.make +++ b/src/base/abci/module.make @@ -44,8 +44,6 @@ SRC += src/base/abci/abc.c \ src/base/abci/abcProve.c \ src/base/abci/abcQbf.c \ src/base/abci/abcQuant.c \ - src/base/abci/abcRec.c \ - src/base/abci/abcRec2.c \ src/base/abci/abcRec3.c \ src/base/abci/abcReconv.c \ src/base/abci/abcReach.c \ diff --git a/src/map/if/if.h b/src/map/if/if.h index a3e921cc..26d582db 100644 --- a/src/map/if/if.h +++ b/src/map/if/if.h @@ -590,18 +590,6 @@ extern int If_ManCountSpecialPos( If_Man_t * p ); extern void If_CutTraverse( If_Man_t * p, If_Obj_t * pRoot, If_Cut_t * pCut, Vec_Ptr_t * vNodes ); extern void If_ObjPrint( If_Obj_t * pObj ); -/*=== abcRec.c ============================================================*/ -/*=== abcRec2.c ============================================================*/ -/*=== abcRec3.c ============================================================*/ -extern int If_CutDelayRecCost(If_Man_t* p, If_Cut_t* pCut, If_Obj_t * pObj); -extern int If_CutDelayRecCost2(If_Man_t* p, If_Cut_t* pCut, If_Obj_t * pObj); -extern int If_CutDelayRecCost3(If_Man_t* p, If_Cut_t* pCut, If_Obj_t * pObj); -extern ABC_DLL int Abc_NtkRecIsRunning(); -extern ABC_DLL int Abc_NtkRecIsRunning2(); -extern ABC_DLL int Abc_NtkRecIsRunning3(); - -// othe packages -extern int Bat_ManCellFuncLookup( unsigned * pTruth, int nVars, int nLeaves ); ABC_NAMESPACE_HEADER_END diff --git a/src/map/if/ifMap.c b/src/map/if/ifMap.c index 58f0ad7b..d8f8785f 100644 --- a/src/map/if/ifMap.c +++ b/src/map/if/ifMap.c @@ -28,6 +28,7 @@ ABC_NAMESPACE_IMPL_START //////////////////////////////////////////////////////////////////////// extern char * Dau_DsdMerge( char * pDsd0i, int * pPerm0, char * pDsd1i, int * pPerm1, int fCompl0, int fCompl1, int nVars ); +extern int If_CutDelayRecCost3(If_Man_t* p, If_Cut_t* pCut, If_Obj_t * pObj); //////////////////////////////////////////////////////////////////////// /// FUNCTION DEFINITIONS /// @@ -164,15 +165,7 @@ void If_ObjPerformMappingAnd( If_Man_t * p, If_Obj_t * pObj, int Mode, int fPrep { // recompute the parameters of the best cut if ( p->pPars->fUserRecLib ) - { - assert( Abc_NtkRecIsRunning() + Abc_NtkRecIsRunning2() + Abc_NtkRecIsRunning3() == 1 ); - if ( Abc_NtkRecIsRunning3() ) - pCut->Delay = If_CutDelayRecCost3(p, pCut, pObj); - else if( Abc_NtkRecIsRunning2() ) - pCut->Delay = If_CutDelayRecCost2(p, pCut, pObj); - else - pCut->Delay = If_CutDelayRecCost(p, pCut, pObj); - } + pCut->Delay = If_CutDelayRecCost3(p, pCut, pObj); else if(p->pPars->fDelayOpt) pCut->Delay = If_CutDelaySopCost(p,pCut); else if(p->pPars->nGateSize > 0) @@ -301,15 +294,7 @@ void If_ObjPerformMappingAnd( If_Man_t * p, If_Obj_t * pObj, int Mode, int fPrep /// if ( p->pPars->pLutStruct ) /// pCut->Delay = If_CutDelayLutStruct( p, pCut, p->pPars->pLutStruct, p->pPars->WireDelay ); if ( p->pPars->fUserRecLib ) - { - assert( Abc_NtkRecIsRunning() + Abc_NtkRecIsRunning2() + Abc_NtkRecIsRunning3() == 1 ); - if ( Abc_NtkRecIsRunning3() ) - pCut->Delay = If_CutDelayRecCost3(p, pCut, pObj); - else if( Abc_NtkRecIsRunning2() ) - pCut->Delay = If_CutDelayRecCost2(p, pCut, pObj); - else - pCut->Delay = If_CutDelayRecCost(p, pCut, pObj); - } + pCut->Delay = If_CutDelayRecCost3(p, pCut, pObj); else if (p->pPars->fDelayOpt) pCut->Delay = If_CutDelaySopCost(p, pCut); else if(p->pPars->nGateSize > 0) |