summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorAlan Mishchenko <alanmi@berkeley.edu>2014-03-23 11:00:26 -0700
committerAlan Mishchenko <alanmi@berkeley.edu>2014-03-23 11:00:26 -0700
commitc26f7cf331fb22dd8447109ba384358fb73ed148 (patch)
treebc598f534ae3a9fbe69b722cb027365527304f49 /src
parentb13e65882de94db9f28b9819d9e3a184ee507f07 (diff)
downloadabc-c26f7cf331fb22dd8447109ba384358fb73ed148.tar.gz
abc-c26f7cf331fb22dd8447109ba384358fb73ed148.tar.bz2
abc-c26f7cf331fb22dd8447109ba384358fb73ed148.zip
Experiments with mapping.
Diffstat (limited to 'src')
-rw-r--r--src/aig/gia/gia.h1
-rw-r--r--src/aig/gia/giaKf.c33
-rw-r--r--src/base/abci/abc.c28
3 files changed, 32 insertions, 30 deletions
diff --git a/src/aig/gia/gia.h b/src/aig/gia/gia.h
index 13bed64b..0fb41153 100644
--- a/src/aig/gia/gia.h
+++ b/src/aig/gia/gia.h
@@ -246,6 +246,7 @@ struct Jf_Par_t_
{
int nLutSize;
int nCutNum;
+ int nProcNum;
int nRounds;
int nVerbLimit;
int DelayTarget;
diff --git a/src/aig/gia/giaKf.c b/src/aig/gia/giaKf.c
index 34ee5eb7..f071bb72 100644
--- a/src/aig/gia/giaKf.c
+++ b/src/aig/gia/giaKf.c
@@ -38,11 +38,11 @@ ABC_NAMESPACE_IMPL_START
/// DECLARATIONS ///
////////////////////////////////////////////////////////////////////////
-#define KF_PROC_MAX 8
-#define KF_LEAF_MAX 8
+#define KF_LEAF_MAX 16
+#define KF_CUT_MAX 32
+#define KF_PROC_MAX 32
#define KF_WORD_MAX ((KF_LEAF_MAX > 6) ? 1 << (KF_LEAF_MAX-6) : 1)
#define KF_LOG_TABLE 8
-#define KF_NUM_MAX 16
#define KF_ADD_ON1 2 // offset in cut storage for each node (cut count; best cut)
#define KF_ADD_ON2 4 // offset in cut storage for each cut (leaf count; function, cut delay; cut area)
@@ -76,10 +76,10 @@ struct Kf_Set_t_
int pValue[1 << KF_LOG_TABLE];
int pPlace[KF_LEAF_MAX];
int pList [KF_LEAF_MAX+1];
- Kf_Cut_t pCuts0[KF_NUM_MAX];
- Kf_Cut_t pCuts1[KF_NUM_MAX];
- Kf_Cut_t pCutsR[KF_NUM_MAX*KF_NUM_MAX];
- Kf_Cut_t * ppCuts[KF_NUM_MAX];
+ Kf_Cut_t pCuts0[KF_CUT_MAX];
+ Kf_Cut_t pCuts1[KF_CUT_MAX];
+ Kf_Cut_t pCutsR[KF_CUT_MAX*KF_CUT_MAX];
+ Kf_Cut_t * ppCuts[KF_CUT_MAX];
Kf_Cut_t * pCutBest;
word CutCount[4]; // statistics
};
@@ -196,7 +196,7 @@ static inline void Kf_ManStoreAddUnit( Vec_Int_t * vTemp, int iObj, int Time, fl
static inline void Kf_ManSaveResults( Kf_Cut_t ** ppCuts, int nCuts, Kf_Cut_t * pCutBest, Vec_Int_t * vTemp )
{
int i, k;
- assert( nCuts > 0 && nCuts < KF_NUM_MAX );
+ assert( nCuts > 0 && nCuts < KF_CUT_MAX );
Kf_ManStoreStart( vTemp, nCuts );
for ( i = 0; i < nCuts; i++ )
{
@@ -823,7 +823,7 @@ void Kf_ManComputeCuts( Kf_Man_t * p )
Kf_ThData_t ThData[PAR_THR_MAX];
Vec_Int_t * vStack, * vFanins;
Gia_Obj_t * pObj;
- int nProcs = p->pPars->nProcNumMax;
+ int nProcs = p->pPars->nProcNum;
int i, k, iFan, status, nCountFanins, fRunning;
abctime clk, clkUsed = 0;
assert( nProcs <= PAR_THR_MAX );
@@ -964,7 +964,7 @@ void Kf_ManComputeMapping( Kf_Man_t * p )
assert( Vec_IntSize(p->vTemp) == 1 + KF_ADD_ON1 + KF_ADD_ON2 );
Kf_ObjSetCuts( p, i, p->vTemp );
}
- if ( p->pPars->nProcNumMax > 0 )
+ if ( p->pPars->nProcNum > 0 )
Kf_ManComputeCuts( p );
else
{
@@ -1037,9 +1037,9 @@ void Kf_ManSetInitRefs( Gia_Man_t * p, Vec_Flt_t * vRefs )
Kf_Man_t * Kf_ManAlloc( Gia_Man_t * pGia, Jf_Par_t * pPars )
{
Kf_Man_t * p; int i;
- assert( pPars->nLutSizeMax <= KF_LEAF_MAX );
- assert( pPars->nCutNumMax <= KF_NUM_MAX );
- assert( pPars->nProcNumMax <= KF_PROC_MAX );
+ assert( pPars->nLutSize <= KF_LEAF_MAX );
+ assert( pPars->nCutNum <= KF_CUT_MAX );
+ assert( pPars->nProcNum <= KF_PROC_MAX );
Vec_IntFreeP( &pGia->vMapping );
p = ABC_CALLOC( Kf_Man_t, 1 );
p->clkStart = Abc_Clock();
@@ -1053,7 +1053,7 @@ Kf_Man_t * Kf_ManAlloc( Gia_Man_t * pGia, Jf_Par_t * pPars )
p->vTemp = Vec_IntAlloc( 1000 );
pGia->pRefs = ABC_CALLOC( int, Gia_ManObjNum(pGia) );
// prepare cut sets
- for ( i = 0; i < Abc_MaxInt(1, pPars->nProcNumMax); i++ )
+ for ( i = 0; i < Abc_MaxInt(1, pPars->nProcNum); i++ )
{
(p->pSett + i)->pMan = p;
(p->pSett + i)->nLutSize = (unsigned short)pPars->nLutSize;
@@ -1114,6 +1114,7 @@ void Kf_ManSetDefaultPars( Jf_Par_t * pPars )
memset( pPars, 0, sizeof(Jf_Par_t) );
pPars->nLutSize = 6;
pPars->nCutNum = 8;
+ pPars->nProcNum = 0;
pPars->nRounds = 1;
pPars->nVerbLimit = 5;
pPars->DelayTarget = -1;
@@ -1128,8 +1129,8 @@ void Kf_ManSetDefaultPars( Jf_Par_t * pPars )
pPars->fVerbose = 0;
pPars->fVeryVerbose = 0;
pPars->nLutSizeMax = KF_LEAF_MAX;
- pPars->nCutNumMax = KF_NUM_MAX;
- pPars->nProcNumMax = 0;
+ pPars->nCutNumMax = KF_CUT_MAX;
+ pPars->nProcNumMax = KF_PROC_MAX;
}
Gia_Man_t * Kf_ManPerformMapping( Gia_Man_t * pGia, Jf_Par_t * pPars )
{
diff --git a/src/base/abci/abc.c b/src/base/abci/abc.c
index c01757b1..98bdb647 100644
--- a/src/base/abci/abc.c
+++ b/src/base/abci/abc.c
@@ -30369,7 +30369,7 @@ int Abc_CommandAbc9Kf( Abc_Frame_t * pAbc, int argc, char ** argv )
Gia_Man_t * pNew; int c;
Kf_ManSetDefaultPars( pPars );
Extra_UtilGetoptReset();
- while ( ( c = Extra_UtilGetopt( argc, argv, "KCRDWPaekmdcgtvwh" ) ) != EOF )
+ while ( ( c = Extra_UtilGetopt( argc, argv, "KCPRDWaekmdcgtvwh" ) ) != EOF )
{
switch ( c )
{
@@ -30401,6 +30401,17 @@ int Abc_CommandAbc9Kf( Abc_Frame_t * pAbc, int argc, char ** argv )
goto usage;
}
break;
+ case 'P':
+ if ( globalUtilOptind >= argc )
+ {
+ Abc_Print( -1, "Command line switch \"-P\" should be followed by a positive integer.\n" );
+ goto usage;
+ }
+ pPars->nProcNumMax = atoi(argv[globalUtilOptind]);
+ globalUtilOptind++;
+ if ( pPars->nProcNumMax < 0 )
+ goto usage;
+ break;
case 'R':
if ( globalUtilOptind >= argc )
{
@@ -30434,17 +30445,6 @@ int Abc_CommandAbc9Kf( Abc_Frame_t * pAbc, int argc, char ** argv )
if ( pPars->nVerbLimit < 0 )
goto usage;
break;
- case 'P':
- if ( globalUtilOptind >= argc )
- {
- Abc_Print( -1, "Command line switch \"-P\" should be followed by a positive integer.\n" );
- goto usage;
- }
- pPars->nProcNumMax = atoi(argv[globalUtilOptind]);
- globalUtilOptind++;
- if ( pPars->nProcNumMax < 0 )
- goto usage;
- break;
case 'a':
pPars->fAreaOnly ^= 1;
break;
@@ -30501,14 +30501,14 @@ usage:
sprintf(Buffer, "best possible" );
else
sprintf(Buffer, "%d", pPars->DelayTarget );
- Abc_Print( -2, "usage: &kf [-KCRDWP num] [-akmdcgtvwh]\n" );
+ Abc_Print( -2, "usage: &kf [-KCPRDW num] [-akmdcgtvwh]\n" );
Abc_Print( -2, "\t performs technology mapping of the network\n" );
Abc_Print( -2, "\t-K num : LUT size for the mapping (2 <= K <= %d) [default = %d]\n", pPars->nLutSizeMax, pPars->nLutSize );
Abc_Print( -2, "\t-C num : the max number of priority cuts (1 <= C <= %d) [default = %d]\n", pPars->nCutNumMax, pPars->nCutNum );
+ Abc_Print( -2, "\t-P num : the number of cut computation processes (0 <= P <= %d) [default = %d]\n", pPars->nProcNumMax, pPars->nProcNum );
Abc_Print( -2, "\t-R num : the number of mapping rounds [default = %d]\n", pPars->nRounds );
Abc_Print( -2, "\t-D num : sets the delay constraint for the mapping [default = %s]\n", Buffer );
Abc_Print( -2, "\t-W num : min frequency when printing functions with \"-w\" [default = %d]\n", pPars->nVerbLimit );
- Abc_Print( -2, "\t-P num : the number of cut computation processes [default = %d]\n", pPars->nProcNumMax );
Abc_Print( -2, "\t-a : toggles area-oriented mapping [default = %s]\n", pPars->fAreaOnly? "yes": "no" );
Abc_Print( -2, "\t-e : toggles edge vs node minimization [default = %s]\n", pPars->fOptEdge? "yes": "no" );
Abc_Print( -2, "\t-k : toggles coarsening the subject graph [default = %s]\n", pPars->fCoarsen? "yes": "no" );