summaryrefslogtreecommitdiffstats
path: root/src/base/exor
diff options
context:
space:
mode:
authorHeinz Riener <heinz.riener@gmail.com>2018-05-25 13:44:34 +0200
committerHeinz Riener <heinz.riener@gmail.com>2018-05-25 13:44:34 +0200
commit88185a02e2e3cfb23891f14a59bb58d452da1935 (patch)
treeee1a87266cf3ca3bddca3c01bd7bc810caf0407b /src/base/exor
parent6df13962739353022cc365b6b4c6a72014e05a35 (diff)
downloadabc-88185a02e2e3cfb23891f14a59bb58d452da1935.tar.gz
abc-88185a02e2e3cfb23891f14a59bb58d452da1935.tar.bz2
abc-88185a02e2e3cfb23891f14a59bb58d452da1935.zip
&exorcism: read ESOP-PLA from file.
Diffstat (limited to 'src/base/exor')
-rw-r--r--src/base/exor/exor.c64
1 files changed, 64 insertions, 0 deletions
diff --git a/src/base/exor/exor.c b/src/base/exor/exor.c
index 2310de5f..75cd9e3f 100644
--- a/src/base/exor/exor.c
+++ b/src/base/exor/exor.c
@@ -46,6 +46,7 @@
////////////////////////////////////////////////////////////////////////
#include "exor.h"
+#include "base/abc/abc.h"
ABC_NAMESPACE_IMPL_START
@@ -947,6 +948,69 @@ int Abc_ExorcismMain( Vec_Wec_t * vEsop, int nIns, int nOuts, char * pFileNameOu
return 1;
}
+Vec_Wec_t * Abc_ExorcismNtk2Esop( Abc_Ntk_t * pNtk )
+{
+ Vec_Wec_t * vEsop = NULL;
+ Abc_Obj_t * pNode, * pFanin, * pDriver;
+ char * pCube;
+ int nIns, nOuts, nProducts, nFanins, i, k;
+
+ nIns = Abc_NtkCiNum( pNtk );
+ nOuts = Abc_NtkCoNum( pNtk );
+
+ nProducts = 0;
+ Abc_NtkForEachCo( pNtk, pNode, i )
+ {
+ pDriver = Abc_ObjFanin0Ntk( Abc_ObjFanin0(pNode) );
+ if ( !Abc_ObjIsNode(pDriver) )
+ {
+ nProducts++;
+ continue;
+ }
+ if ( Abc_NodeIsConst(pDriver) )
+ {
+ if ( Abc_NodeIsConst1(pDriver) )
+ nProducts++;
+ continue;
+ }
+ nProducts += Abc_SopGetCubeNum((char *)pDriver->pData);
+ }
+
+ Abc_NtkForEachCi( pNtk, pNode, i )
+ pNode->pCopy = (Abc_Obj_t *)(ABC_PTRUINT_T)i;
+
+ vEsop = Vec_WecAlloc( nProducts+1 );
+
+ Abc_NtkForEachCo( pNtk, pNode, i )
+ {
+ pDriver = Abc_ObjFanin0Ntk( Abc_ObjFanin0(pNode) );
+ if ( Abc_NodeIsConst(pDriver) ) continue;
+
+ nFanins = Abc_ObjFaninNum(pDriver);
+ Abc_SopForEachCube( (char *)pDriver->pData, nFanins, pCube )
+ {
+ Vec_Int_t *vCubeIn = Vec_WecPushLevel( vEsop );
+ Vec_IntGrow( vCubeIn, nIns+2 );
+
+ Abc_ObjForEachFanin( pDriver, pFanin, k )
+ {
+ pFanin = Abc_ObjFanin0Ntk(pFanin);
+ assert( (int)(ABC_PTRUINT_T)pFanin->pCopy < nIns );
+ if ( pCube[k] == '0' )
+ {
+ Vec_IntPush( vCubeIn, 2*k + 1 );
+ }
+ else if ( pCube[k] == '1' )
+ {
+ Vec_IntPush( vCubeIn, 2*k );
+ }
+ }
+ Vec_IntPush( vCubeIn, -1 );
+ }
+ }
+
+ return vEsop;
+}
///////////////////////////////////////////////////////////////////