diff options
author | Alan Mishchenko <alanmi@berkeley.edu> | 2011-02-19 16:43:00 -0800 |
---|---|---|
committer | Alan Mishchenko <alanmi@berkeley.edu> | 2011-02-19 16:43:00 -0800 |
commit | 2619edf8c0347b78549c28083dd0565ed2589425 (patch) | |
tree | 739185b3e5cbd27e24e3c8320011d7ed013c1e51 /src | |
parent | 443cc01782ac3845183990ef86fdfe3d650341c5 (diff) | |
download | abc-2619edf8c0347b78549c28083dd0565ed2589425.tar.gz abc-2619edf8c0347b78549c28083dd0565ed2589425.tar.bz2 abc-2619edf8c0347b78549c28083dd0565ed2589425.zip |
Added two new APIs for reading/writing CEX from/into ABC.
Diffstat (limited to 'src')
-rw-r--r-- | src/base/abci/abc.c | 132 | ||||
-rw-r--r-- | src/misc/util/utilCex.c | 2 |
2 files changed, 122 insertions, 12 deletions
diff --git a/src/base/abci/abc.c b/src/base/abci/abc.c index 425b64f5..6778e6ee 100644 --- a/src/base/abci/abc.c +++ b/src/base/abci/abc.c @@ -354,6 +354,7 @@ static int Abc_CommandAbc9Sat ( Abc_Frame_t * pAbc, int argc, cha static int Abc_CommandAbc9Fraig ( Abc_Frame_t * pAbc, int argc, char ** argv ); static int Abc_CommandAbc9Srm ( Abc_Frame_t * pAbc, int argc, char ** argv ); static int Abc_CommandAbc9Reduce ( Abc_Frame_t * pAbc, int argc, char ** argv ); +static int Abc_CommandAbc9EquivMark ( Abc_Frame_t * pAbc, int argc, char ** argv ); static int Abc_CommandAbc9Cec ( Abc_Frame_t * pAbc, int argc, char ** argv ); static int Abc_CommandAbc9Force ( Abc_Frame_t * pAbc, int argc, char ** argv ); static int Abc_CommandAbc9Embed ( Abc_Frame_t * pAbc, int argc, char ** argv ); @@ -396,6 +397,42 @@ extern int Abc_CommandAbcLivenessToSafetyWithLTL( Abc_Frame_t * pAbc, int argc, SeeAlso [] ***********************************************************************/ +Abc_Cex_t * Abc_FrameReadCex( Abc_Frame_t * pAbc ) +{ + Abc_Cex_t * pCex; + pCex = pAbc->pCex; + pAbc->pCex = NULL; + return pCex; +} + +/**Function************************************************************* + + Synopsis [] + + Description [] + + SideEffects [] + + SeeAlso [] + +***********************************************************************/ +void Abc_FrameSetCex( Abc_Frame_t * pAbc, Abc_Cex_t * pCex ) +{ + ABC_FREE( pAbc->pCex ); + pAbc->pCex = pCex; +} + +/**Function************************************************************* + + Synopsis [] + + Description [] + + SideEffects [] + + SeeAlso [] + +***********************************************************************/ void Abc_FrameReplaceCex( Abc_Frame_t * pAbc, Abc_Cex_t ** ppCex ) { ABC_FREE( pAbc->pCex ); @@ -752,6 +789,7 @@ void Abc_Init( Abc_Frame_t * pAbc ) Cmd_CommandAdd( pAbc, "ABC9", "&fraig", Abc_CommandAbc9Fraig, 0 ); Cmd_CommandAdd( pAbc, "ABC9", "&srm", Abc_CommandAbc9Srm, 0 ); Cmd_CommandAdd( pAbc, "ABC9", "&reduce", Abc_CommandAbc9Reduce, 0 ); + Cmd_CommandAdd( pAbc, "ABC9", "&equiv_mark", Abc_CommandAbc9EquivMark, 0 ); Cmd_CommandAdd( pAbc, "ABC9", "&cec", Abc_CommandAbc9Cec, 0 ); Cmd_CommandAdd( pAbc, "ABC9", "&force", Abc_CommandAbc9Force, 0 ); Cmd_CommandAdd( pAbc, "ABC9", "&embed", Abc_CommandAbc9Embed, 0 ); @@ -25936,14 +25974,14 @@ usage: ***********************************************************************/ int Abc_CommandAbc9Srm( Abc_Frame_t * pAbc, int argc, char ** argv ) { - char * pFileName = "gsrm.aig"; - char * pFileName2 = "gsyn.aig"; + char pFileName[10], pFileName2[10]; Gia_Man_t * pTemp, * pAux; int c, fVerbose = 0; + int fSpeculate = 1; int fSynthesis = 0; int fDualOut = 0; Extra_UtilGetoptReset(); - while ( ( c = Extra_UtilGetopt( argc, argv, "dsvh" ) ) != EOF ) + while ( ( c = Extra_UtilGetopt( argc, argv, "dsrvh" ) ) != EOF ) { switch ( c ) { @@ -25951,6 +25989,9 @@ int Abc_CommandAbc9Srm( Abc_Frame_t * pAbc, int argc, char ** argv ) fDualOut ^= 1; break; case 's': + fSpeculate ^= 1; + break; + case 'r': fSynthesis ^= 1; break; case 'v': @@ -25967,12 +26008,16 @@ int Abc_CommandAbc9Srm( Abc_Frame_t * pAbc, int argc, char ** argv ) Abc_Print( -1, "Abc_CommandAbc9Srm(): There is no AIG.\n" ); return 1; } - pTemp = Gia_ManSpecReduce( pAbc->pGia, fDualOut, fSynthesis, fVerbose ); + sprintf( pFileName, "gsrm%s.aig", fSpeculate? "" : "s" ); + sprintf( pFileName2, "gsyn%s.aig", fSpeculate? "" : "s" ); + pTemp = Gia_ManSpecReduce( pAbc->pGia, fDualOut, fSynthesis, fSpeculate, fVerbose ); if ( pTemp ) { - pTemp = Gia_ManSeqStructSweep( pAux = pTemp, 1, 1, 0 ); - Gia_ManStop( pAux ); - + if ( fSpeculate ) + { + pTemp = Gia_ManSeqStructSweep( pAux = pTemp, 1, 1, 0 ); + Gia_ManStop( pAux ); + } Gia_WriteAiger( pTemp, pFileName, 0, 0 ); Abc_Print( 1, "Speculatively reduced model was written into file \"%s\".\n", pFileName ); Gia_ManPrintStatsShort( pTemp ); @@ -25995,10 +26040,11 @@ int Abc_CommandAbc9Srm( Abc_Frame_t * pAbc, int argc, char ** argv ) return 0; usage: - Abc_Print( -2, "usage: &srm [-dsvh]\n" ); + Abc_Print( -2, "usage: &srm [-dsrvh]\n" ); Abc_Print( -2, "\t writes speculatively reduced model into file \"%s\"\n", pFileName ); Abc_Print( -2, "\t-d : toggle creating dual output miter [default = %s]\n", fDualOut? "yes": "no" ); - Abc_Print( -2, "\t-s : toggle writing reduced network for synthesis [default = %s]\n", fSynthesis? "yes": "no" ); + Abc_Print( -2, "\t-s : toggle using speculation at the internal nodes [default = %s]\n", fSpeculate? "yes": "no" ); + Abc_Print( -2, "\t-r : toggle writing reduced network for synthesis [default = %s]\n", fSynthesis? "yes": "no" ); Abc_Print( -2, "\t-v : toggle printing verbose information [default = %s]\n", fVerbose? "yes": "no" ); Abc_Print( -2, "\t-h : print the command usage\n"); return 1; @@ -26046,13 +26092,15 @@ int Abc_CommandAbc9Reduce( Abc_Frame_t * pAbc, int argc, char ** argv ) Abc_Print( -1, "Abc_CommandAbc9Reduce(): There is no AIG.\n" ); return 1; } - pTemp = Gia_ManEquivReduce( pAbc->pGia, fUseAll, fDualOut, fVerbose ); - if ( pTemp != NULL ) + if ( fUseAll ) { + pTemp = Gia_ManEquivReduce( pAbc->pGia, fUseAll, fDualOut, fVerbose ); pTemp = Gia_ManSeqStructSweep( pTemp2 = pTemp, 1, 1, 0 ); Gia_ManStop( pTemp2 ); - Abc_CommandUpdate9( pAbc, pTemp ); } + else + pTemp = Gia_ManEquivReduceAndRemap( pAbc->pGia, 1, fDualOut ); + Abc_CommandUpdate9( pAbc, pTemp ); return 0; usage: @@ -26076,6 +26124,66 @@ usage: SeeAlso [] ***********************************************************************/ +int Abc_CommandAbc9EquivMark( Abc_Frame_t * pAbc, int argc, char ** argv ) +{ + extern void Gia_ManEquivMark( Gia_Man_t * p, char * pFileName, int fVerbose ); + char * pFileName; + int c, fVerbose = 0; + Extra_UtilGetoptReset(); + while ( ( c = Extra_UtilGetopt( argc, argv, "vh" ) ) != EOF ) + { + switch ( c ) + { + case 'v': + fVerbose ^= 1; + break; + case 'h': + goto usage; + default: + goto usage; + } + } + if ( pAbc->pGia == NULL ) + { + Abc_Print( -1, "Abc_CommandAbc9Reduce(): There is no AIG.\n" ); + return 1; + } + if ( argc != globalUtilOptind + 1 ) + goto usage; + // get the input file name + pFileName = argv[globalUtilOptind]; + // mark equivalences + Gia_ManEquivMark( pAbc->pGia, pFileName, fVerbose ); + return 0; + +usage: + Abc_Print( -2, "usage: &equiv_mark [-vh] <miter.aig>\n" ); + Abc_Print( -2, "\t marks equivalences using an external miter\n" ); + Abc_Print( -2, "\t-v : toggle printing verbose information [default = %s]\n", fVerbose? "yes": "no" ); + Abc_Print( -2, "\t-h : print the command usage\n"); + Abc_Print( -2, "\t<miter.aig> : file with the external miter to read\n"); + Abc_Print( -2, "\t \n" ); + Abc_Print( -2, "\t The external miter should be generated by &srm -m\n" ); + Abc_Print( -2, "\t and (partially) solved by any verification engine(s).\n" ); + Abc_Print( -2, "\t The external miter should have as many POs as\n" ); + Abc_Print( -2, "\t the number of POs in the current AIG plus\n" ); + Abc_Print( -2, "\t the number of equivalences in the current AIG.\n" ); + Abc_Print( -2, "\t If some POs are proved, the corresponding equivs\n" ); + Abc_Print( -2, "\t are marked as proved, to be reduced by &reduce.\n" ); + return 1; +} + +/**Function************************************************************* + + Synopsis [] + + Description [] + + SideEffects [] + + SeeAlso [] + +***********************************************************************/ int Abc_CommandAbc9Cec( Abc_Frame_t * pAbc, int argc, char ** argv ) { Cec_ParCec_t ParsCec, * pPars = &ParsCec; diff --git a/src/misc/util/utilCex.c b/src/misc/util/utilCex.c index 068e1768..a4cf5e33 100644 --- a/src/misc/util/utilCex.c +++ b/src/misc/util/utilCex.c @@ -139,6 +139,8 @@ Abc_Cex_t * Abc_CexDup( Abc_Cex_t * p, int nRegsNew ) { Abc_Cex_t * pCex; int i; + if ( nRegsNew == -1 ) + nRegsNew = p->nRegs; pCex = Abc_CexAlloc( nRegsNew, p->nPis, p->iFrame+1 ); pCex->iPo = p->iPo; pCex->iFrame = p->iFrame; |