summaryrefslogtreecommitdiffstats
path: root/src/sat/bmc
diff options
context:
space:
mode:
authorAlan Mishchenko <alanmi@berkeley.edu>2019-07-18 10:51:05 +0200
committerAlan Mishchenko <alanmi@berkeley.edu>2019-07-18 10:51:05 +0200
commit2de35735c550cd70f707aea7418edc78f68bda50 (patch)
tree54ab9baa8ec39177b7c71addbc1edfc5e9574576 /src/sat/bmc
parent6b9ed7a08d7edb794d046e47770e73638efc71ba (diff)
downloadabc-2de35735c550cd70f707aea7418edc78f68bda50.tar.gz
abc-2de35735c550cd70f707aea7418edc78f68bda50.tar.bz2
abc-2de35735c550cd70f707aea7418edc78f68bda50.zip
Representing formula used in &fftest as a BLIF file.
Diffstat (limited to 'src/sat/bmc')
-rw-r--r--src/sat/bmc/bmcFault.c56
1 files changed, 56 insertions, 0 deletions
diff --git a/src/sat/bmc/bmcFault.c b/src/sat/bmc/bmcFault.c
index 93728660..1b54dc73 100644
--- a/src/sat/bmc/bmcFault.c
+++ b/src/sat/bmc/bmcFault.c
@@ -49,6 +49,62 @@ ABC_NAMESPACE_IMPL_START
SeeAlso []
***********************************************************************/
+void Gia_DeriveFormula_rec( Gia_Man_t * pGia, char ** ppNamesIn, Vec_Str_t * vStr, int iLit )
+{
+ Gia_Obj_t * pObj = Gia_ManObj( pGia, Abc_Lit2Var(iLit) );
+ int fCompl = Abc_LitIsCompl(iLit);
+ if ( Gia_ObjIsAnd(pObj) )
+ {
+ Vec_StrPush( vStr, '(' );
+ if ( Gia_ObjIsMux(pGia, pObj) )
+ {
+ Gia_DeriveFormula_rec( pGia, ppNamesIn, vStr, Gia_ObjFaninLit0p(pGia, pObj) );
+ Vec_StrPush( vStr, '?' );
+ Gia_DeriveFormula_rec( pGia, ppNamesIn, vStr, Abc_LitNotCond( Gia_ObjFaninLit1p(pGia, pObj), fCompl ) );
+ Vec_StrPush( vStr, ':' );
+ Gia_DeriveFormula_rec( pGia, ppNamesIn, vStr, Abc_LitNotCond( Gia_ObjFaninLit2p(pGia, pObj), fCompl ) );
+ }
+ else
+ {
+ Gia_DeriveFormula_rec( pGia, ppNamesIn, vStr, Abc_LitNotCond( Gia_ObjFaninLit0p(pGia, pObj), fCompl ) );
+ Vec_StrPush( vStr, (char)(Gia_ObjIsXor(pObj) ? '^' : (char)(fCompl ? '|' : '&')) );
+ Gia_DeriveFormula_rec( pGia, ppNamesIn, vStr, Abc_LitNotCond( Gia_ObjFaninLit1p(pGia, pObj), fCompl ) );
+ }
+ Vec_StrPush( vStr, ')' );
+ }
+ else
+ {
+ if ( fCompl ) Vec_StrPush( vStr, '~' );
+ Vec_StrPrintF( vStr, "%s", ppNamesIn[Gia_ObjCioId(pObj)] );
+ }
+}
+char * Gia_DeriveFormula( Gia_Man_t * pGia, char ** ppNamesIn )
+{
+ char * pResult;
+ Vec_Str_t * vStr = Vec_StrAlloc( 1000 );
+ Gia_Man_t * pMuxes = Gia_ManDupMuxes( pGia, 2 );
+ Gia_Obj_t * pObj = Gia_ManCo( pGia, 0 );
+ Vec_StrPush( vStr, '(' );
+ Gia_DeriveFormula_rec( pGia, ppNamesIn, vStr, Gia_ObjFaninLit0p(pGia, pObj) );
+ Vec_StrPush( vStr, ')' );
+ Vec_StrPush( vStr, '\0' );
+ Gia_ManStop( pMuxes );
+ pResult = Vec_StrReleaseArray( vStr );
+ Vec_StrFree( vStr );
+ return pResult;
+}
+
+/**Function*************************************************************
+
+ Synopsis [This procedure sets default parameters.]
+
+ Description []
+
+ SideEffects []
+
+ SeeAlso []
+
+***********************************************************************/
void Gia_ParFfSetDefault( Bmc_ParFf_t * p )
{
memset( p, 0, sizeof(Bmc_ParFf_t) );