mirror of https://github.com/YosysHQ/abc.git
Adding procedures to specify permutations with unused flops.
This commit is contained in:
parent
42f8082c59
commit
eec022ea64
|
|
@ -902,6 +902,7 @@ extern Gia_Man_t * Gia_ManDupCycled( Gia_Man_t * pAig, Abc_Cex_t * pCex,
|
|||
extern Gia_Man_t * Gia_ManDup( Gia_Man_t * p );
|
||||
extern Gia_Man_t * Gia_ManDupPerm( Gia_Man_t * p, Vec_Int_t * vPiPerm );
|
||||
extern Gia_Man_t * Gia_ManDupPermFlop( Gia_Man_t * p, Vec_Int_t * vFfPerm );
|
||||
extern Gia_Man_t * Gia_ManDupPermFlopGap( Gia_Man_t * p, Vec_Int_t * vFfPerm );
|
||||
extern void Gia_ManDupAppend( Gia_Man_t * p, Gia_Man_t * pTwo );
|
||||
extern void Gia_ManDupAppendShare( Gia_Man_t * p, Gia_Man_t * pTwo );
|
||||
extern Gia_Man_t * Gia_ManDupAppendNew( Gia_Man_t * pOne, Gia_Man_t * pTwo );
|
||||
|
|
|
|||
|
|
@ -615,6 +615,51 @@ Gia_Man_t * Gia_ManDupPermFlop( Gia_Man_t * p, Vec_Int_t * vFfPerm )
|
|||
Gia_ManSetRegNum( pNew, Gia_ManRegNum(p) );
|
||||
return pNew;
|
||||
}
|
||||
Gia_Man_t * Gia_ManDupSpreadFlop( Gia_Man_t * p, Vec_Int_t * vFfMask )
|
||||
{
|
||||
Gia_Man_t * pNew;
|
||||
Gia_Obj_t * pObj;
|
||||
int i, k, Entry;
|
||||
assert( Vec_IntSize(vFfMask) >= Gia_ManRegNum(p) );
|
||||
pNew = Gia_ManStart( Gia_ManObjNum(p) );
|
||||
pNew->pName = Abc_UtilStrsav( p->pName );
|
||||
pNew->pSpec = Abc_UtilStrsav( p->pSpec );
|
||||
Gia_ManConst0(p)->Value = 0;
|
||||
Gia_ManForEachPi( p, pObj, i )
|
||||
pObj->Value = Gia_ManAppendCi(pNew);
|
||||
k = 0;
|
||||
Vec_IntForEachEntry( vFfMask, Entry, i )
|
||||
if ( Entry == -1 )
|
||||
Gia_ManAppendCi(pNew);
|
||||
else
|
||||
Gia_ManRo(p, k++)->Value = Gia_ManAppendCi(pNew);
|
||||
assert( k == Gia_ManRegNum(p) );
|
||||
Gia_ManForEachAnd( p, pObj, i )
|
||||
pObj->Value = Gia_ManAppendAnd( pNew, Gia_ObjFanin0Copy(pObj), Gia_ObjFanin1Copy(pObj) );
|
||||
Gia_ManForEachPo( p, pObj, i )
|
||||
pObj->Value = Gia_ManAppendCo( pNew, Gia_ObjFanin0Copy(pObj) );
|
||||
k = 0;
|
||||
Vec_IntForEachEntry( vFfMask, Entry, i )
|
||||
if ( Entry == -1 )
|
||||
Gia_ManAppendCo( pNew, 0 );
|
||||
else
|
||||
{
|
||||
pObj = Gia_ManRi( p, k++ );
|
||||
pObj->Value = Gia_ManAppendCo( pNew, Gia_ObjFanin0Copy(pObj) );
|
||||
}
|
||||
assert( k == Gia_ManRegNum(p) );
|
||||
Gia_ManSetRegNum( pNew, Vec_IntSize(vFfMask) );
|
||||
return pNew;
|
||||
}
|
||||
Gia_Man_t * Gia_ManDupPermFlopGap( Gia_Man_t * p, Vec_Int_t * vFfMask )
|
||||
{
|
||||
Vec_Int_t * vPerm = Vec_IntCondense( vFfMask, -1 );
|
||||
Gia_Man_t * pPerm = Gia_ManDupPermFlop( p, vPerm );
|
||||
Gia_Man_t * pSpread = Gia_ManDupSpreadFlop( pPerm, vFfMask );
|
||||
Vec_IntFree( vPerm );
|
||||
Gia_ManStop( pPerm );
|
||||
return pSpread;
|
||||
}
|
||||
|
||||
/**Function*************************************************************
|
||||
|
||||
|
|
|
|||
|
|
@ -1043,6 +1043,27 @@ static inline Vec_Int_t * Vec_IntInvert( Vec_Int_t * p, int Fill )
|
|||
return vRes;
|
||||
}
|
||||
|
||||
/**Function*************************************************************
|
||||
|
||||
Synopsis []
|
||||
|
||||
Description []
|
||||
|
||||
SideEffects []
|
||||
|
||||
SeeAlso []
|
||||
|
||||
***********************************************************************/
|
||||
static inline Vec_Int_t * Vec_IntCondense( Vec_Int_t * p, int Fill )
|
||||
{
|
||||
int Entry, i;
|
||||
Vec_Int_t * vRes = Vec_IntAlloc( Vec_IntSize(p) );
|
||||
Vec_IntForEachEntry( p, Entry, i )
|
||||
if ( Entry != Fill )
|
||||
Vec_IntPush( vRes, Entry );
|
||||
return vRes;
|
||||
}
|
||||
|
||||
/**Function*************************************************************
|
||||
|
||||
Synopsis []
|
||||
|
|
|
|||
|
|
@ -1133,7 +1133,7 @@ finish:
|
|||
SeeAlso []
|
||||
|
||||
***********************************************************************/
|
||||
Vec_Int_t * Ssw_RarRandomPermFlop( int nFlops )
|
||||
Vec_Int_t * Ssw_RarRandomPermFlop( int nFlops, int nUnused )
|
||||
{
|
||||
Vec_Int_t * vPerm;
|
||||
int i, k, * pArray;
|
||||
|
|
@ -1146,6 +1146,15 @@ Vec_Int_t * Ssw_RarRandomPermFlop( int nFlops )
|
|||
k = rand() % nFlops;
|
||||
ABC_SWAP( int, pArray[i], pArray[k] );
|
||||
}
|
||||
printf( "Randomly adding %d unused flops.\n", nUnused );
|
||||
for ( i = 0; i < nUnused; i++ )
|
||||
{
|
||||
k = rand() % Vec_IntSize(vPerm);
|
||||
Vec_IntPush( vPerm, -1 );
|
||||
pArray = Vec_IntArray( vPerm );
|
||||
ABC_SWAP( int, pArray[Vec_IntSize(vPerm)-1], pArray[k] );
|
||||
}
|
||||
// Vec_IntPrint(vPerm);
|
||||
return vPerm;
|
||||
}
|
||||
|
||||
|
|
@ -1166,8 +1175,8 @@ int Ssw_RarSimulateGia( Gia_Man_t * p, Ssw_RarPars_t * pPars )
|
|||
int RetValue;
|
||||
if ( pPars->fUseFfGrouping )
|
||||
{
|
||||
Vec_Int_t * vPerm = Ssw_RarRandomPermFlop( Gia_ManRegNum(p) );
|
||||
Gia_Man_t * pTemp = Gia_ManDupPermFlop( p, vPerm );
|
||||
Vec_Int_t * vPerm = Ssw_RarRandomPermFlop( Gia_ManRegNum(p), 10 );
|
||||
Gia_Man_t * pTemp = Gia_ManDupPermFlopGap( p, vPerm );
|
||||
Vec_IntFree( vPerm );
|
||||
pAig = Gia_ManToAigSimple( pTemp );
|
||||
Gia_ManStop( pTemp );
|
||||
|
|
|
|||
Loading…
Reference in New Issue