summaryrefslogtreecommitdiffstats
path: root/src/opt
diff options
context:
space:
mode:
authorAlan Mishchenko <alanmi@berkeley.edu>2012-12-10 18:36:20 -0800
committerAlan Mishchenko <alanmi@berkeley.edu>2012-12-10 18:36:20 -0800
commitff62cd8349f14f6ff62cbe962c43c4b2739f0518 (patch)
treefe12b9dbecc28718df2fc21dda379756d661226d /src/opt
parentf35848ed970700faadd30dc8a247f2509c630b83 (diff)
downloadabc-ff62cd8349f14f6ff62cbe962c43c4b2739f0518.tar.gz
abc-ff62cd8349f14f6ff62cbe962c43c4b2739f0518.tar.bz2
abc-ff62cd8349f14f6ff62cbe962c43c4b2739f0518.zip
Improvements to DSD manager.
Diffstat (limited to 'src/opt')
-rw-r--r--src/opt/dau/dauTree.c40
1 files changed, 21 insertions, 19 deletions
diff --git a/src/opt/dau/dauTree.c b/src/opt/dau/dauTree.c
index cd6474c9..99381825 100644
--- a/src/opt/dau/dauTree.c
+++ b/src/opt/dau/dauTree.c
@@ -527,7 +527,7 @@ static inline void Dau_DsdMergeMatches( char * pDsd, int * pMatches )
}
assert( nNested == 0 );
}
-int Dss_NtkCreate_rec( char * pStr, char ** p, int * pMatches, Dss_Ntk_t * pNtk )
+int Dss_NtkCreate_rec( char * pStr, char ** p, int * pMatches, Dss_Ntk_t * pNtk, word * pTruth )
{
int fCompl = 0;
if ( **p == '!' )
@@ -564,9 +564,26 @@ int Dss_NtkCreate_rec( char * pStr, char ** p, int * pMatches, Dss_Ntk_t * pNtk
else assert( 0 );
assert( *q == **p + 1 + (**p != '(') );
for ( (*p)++; *p < q; (*p)++ )
- Vec_IntPush( vFaninLits, Dss_NtkCreate_rec(pStr, p, pMatches, pNtk) );
+ Vec_IntPush( vFaninLits, Dss_NtkCreate_rec(pStr, p, pMatches, pNtk, pTruth) );
assert( *p == q );
- pObj = Dss_ObjCreateNtk( pNtk, Type, vFaninLits );
+ if ( Type == DAU_DSD_PRIME )
+ {
+ Vec_Int_t * vFaninLitsNew;
+ word pTemp[DAU_MAX_WORD];
+ char pCanonPerm[DAU_MAX_VAR];
+ int i, uCanonPhase, nFanins = Vec_IntSize(vFaninLits);
+ Abc_TtCopy( pTemp, pTruth, Abc_TtWordNum(nFanins), 0 );
+ uCanonPhase = Abc_TtCanonicize( pTemp, nFanins, pCanonPerm );
+ fCompl = (uCanonPhase >> nFanins) & 1;
+ vFaninLitsNew = Vec_IntAlloc( nFanins );
+ for ( i = 0; i < nFanins; i++ )
+ Vec_IntPush( vFaninLitsNew, Abc_LitNotCond(Vec_IntEntry(vFaninLits, pCanonPerm[i]), (uCanonPhase>>i)&1) );
+ pObj = Dss_ObjCreateNtk( pNtk, DAU_DSD_PRIME, vFaninLitsNew );
+ Abc_TtCopy( Dss_ObjTruth(pObj), pTemp, Abc_TtWordNum(nFanins), 0 );
+ Vec_IntFree( vFaninLitsNew );
+ }
+ else
+ pObj = Dss_ObjCreateNtk( pNtk, Type, vFaninLits );
Vec_IntFree( vFaninLits );
return Abc_LitNotCond( Dss_Obj2Lit(pObj), fCompl );
}
@@ -587,23 +604,8 @@ Dss_Ntk_t * Dss_NtkCreate( char * pDsd, int nVars, word * pTruth )
{
int iLit, pMatches[DAU_MAX_STR];
Dau_DsdMergeMatches( pDsd, pMatches );
- iLit = Dss_NtkCreate_rec( pDsd, &pDsd, pMatches, pNtk );
+ iLit = Dss_NtkCreate_rec( pDsd, &pDsd, pMatches, pNtk, pTruth );
pNtk->pRoot = Dss_Lit2Obj( pNtk->vObjs, iLit );
- // assign the truth table
- if ( pTruth )
- {
- Dss_Obj_t * pObj;
- int k, Counter = 0;
- Dss_VecForEachNode( pNtk->vObjs, pObj, k )
- if ( pObj->Type == DAU_DSD_PRIME )
- {
-// Kit_DsdPrintFromTruth( (unsigned *)pTruth, nVars ); printf( "\n" );
-
- Abc_TtCopy( Dss_ObjTruth(pObj), pTruth, Abc_TtWordNum(pObj->nFans), 0 );
- Counter++;
- }
- assert( Counter < 2 );
- }
}
if ( fCompl )
pNtk->pRoot = Dss_Not(pNtk->pRoot);