Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
A
abc
Overview
Overview
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
lvzhengyang
abc
Commits
48d867f7
Commit
48d867f7
authored
Apr 28, 2013
by
Alan Mishchenko
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Modified command 'eliminate' to perform traditional 'eliminate -1'.
parent
8db0b9c0
Expand all
Hide whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
257 additions
and
48 deletions
+257
-48
src/aig/hop/hop.h
+2
-0
src/aig/hop/hopDfs.c
+65
-0
src/base/abc/abcMinBase.c
+160
-28
src/base/abci/abc.c
+21
-11
src/base/abci/abcFxu.c
+9
-9
No files found.
src/aig/hop/hop.h
View file @
48d867f7
...
...
@@ -281,11 +281,13 @@ extern Vec_Ptr_t * Hop_ManDfsNode( Hop_Man_t * p, Hop_Obj_t * pNode );
extern
int
Hop_ManCountLevels
(
Hop_Man_t
*
p
);
extern
void
Hop_ManCreateRefs
(
Hop_Man_t
*
p
);
extern
int
Hop_DagSize
(
Hop_Obj_t
*
pObj
);
extern
int
Hop_ObjFanoutCount
(
Hop_Obj_t
*
pObj
,
Hop_Obj_t
*
pPivot
);
extern
void
Hop_ConeUnmark_rec
(
Hop_Obj_t
*
pObj
);
extern
Hop_Obj_t
*
Hop_Transfer
(
Hop_Man_t
*
pSour
,
Hop_Man_t
*
pDest
,
Hop_Obj_t
*
pObj
,
int
nVars
);
extern
Hop_Obj_t
*
Hop_Compose
(
Hop_Man_t
*
p
,
Hop_Obj_t
*
pRoot
,
Hop_Obj_t
*
pFunc
,
int
iVar
);
extern
Hop_Obj_t
*
Hop_Complement
(
Hop_Man_t
*
p
,
Hop_Obj_t
*
pRoot
,
int
iVar
);
extern
Hop_Obj_t
*
Hop_Remap
(
Hop_Man_t
*
p
,
Hop_Obj_t
*
pRoot
,
unsigned
uSupp
,
int
nVars
);
extern
Hop_Obj_t
*
Hop_Permute
(
Hop_Man_t
*
p
,
Hop_Obj_t
*
pRoot
,
int
nRootVars
,
int
*
pPermute
);
/*=== hopMan.c ==========================================================*/
extern
Hop_Man_t
*
Hop_ManStart
();
extern
Hop_Man_t
*
Hop_ManDup
(
Hop_Man_t
*
p
);
...
...
src/aig/hop/hopDfs.c
View file @
48d867f7
...
...
@@ -286,6 +286,38 @@ int Hop_DagSize( Hop_Obj_t * pObj )
/**Function*************************************************************
Synopsis [Counts how many fanout the given node has.]
Description []
SideEffects []
SeeAlso []
***********************************************************************/
int
Hop_ObjFanoutCount_rec
(
Hop_Obj_t
*
pObj
,
Hop_Obj_t
*
pPivot
)
{
int
Counter
;
assert
(
!
Hop_IsComplement
(
pObj
)
);
if
(
!
Hop_ObjIsNode
(
pObj
)
||
Hop_ObjIsMarkA
(
pObj
)
)
return
(
int
)(
pObj
==
pPivot
);
Counter
=
Hop_ObjFanoutCount_rec
(
Hop_ObjFanin0
(
pObj
),
pPivot
)
+
Hop_ObjFanoutCount_rec
(
Hop_ObjFanin1
(
pObj
),
pPivot
);
assert
(
!
Hop_ObjIsMarkA
(
pObj
)
);
// loop detection
Hop_ObjSetMarkA
(
pObj
);
return
Counter
;
}
int
Hop_ObjFanoutCount
(
Hop_Obj_t
*
pObj
,
Hop_Obj_t
*
pPivot
)
{
int
Counter
;
assert
(
!
Hop_IsComplement
(
pPivot
)
);
Counter
=
Hop_ObjFanoutCount_rec
(
Hop_Regular
(
pObj
),
pPivot
);
Hop_ConeUnmark_rec
(
Hop_Regular
(
pObj
)
);
return
Counter
;
}
/**Function*************************************************************
Synopsis [Transfers the AIG from one manager into another.]
Description []
...
...
@@ -517,6 +549,39 @@ Hop_Obj_t * Hop_Remap( Hop_Man_t * p, Hop_Obj_t * pRoot, unsigned uSupp, int nVa
return
Hop_NotCond
(
(
Hop_Obj_t
*
)
Hop_Regular
(
pRoot
)
->
pData
,
Hop_IsComplement
(
pRoot
)
);
}
/**Function*************************************************************
Synopsis [Permute the AIG according to the given permutation.]
Description []
SideEffects []
SeeAlso []
***********************************************************************/
Hop_Obj_t
*
Hop_Permute
(
Hop_Man_t
*
p
,
Hop_Obj_t
*
pRoot
,
int
nRootVars
,
int
*
pPermute
)
{
Hop_Obj_t
*
pObj
;
int
i
;
// return if constant
if
(
Hop_ObjIsConst1
(
Hop_Regular
(
pRoot
)
)
)
return
pRoot
;
// create mapping
Hop_ManForEachPi
(
p
,
pObj
,
i
)
{
if
(
i
==
nRootVars
)
break
;
assert
(
pPermute
[
i
]
>=
0
&&
pPermute
[
i
]
<
Hop_ManPiNum
(
p
)
);
pObj
->
pData
=
Hop_IthVar
(
p
,
pPermute
[
i
]
);
}
// recursively perform composition
Hop_Remap_rec
(
p
,
Hop_Regular
(
pRoot
)
);
// clear the markings
Hop_ConeUnmark_rec
(
Hop_Regular
(
pRoot
)
);
return
Hop_NotCond
(
(
Hop_Obj_t
*
)
Hop_Regular
(
pRoot
)
->
pData
,
Hop_IsComplement
(
pRoot
)
);
}
////////////////////////////////////////////////////////////////////////
/// END OF FILE ///
////////////////////////////////////////////////////////////////////////
...
...
src/base/abc/abcMinBase.c
View file @
48d867f7
This diff is collapsed.
Click to expand it.
src/base/abci/abc.c
View file @
48d867f7
...
...
@@ -3641,8 +3641,8 @@ usage:
Abc_Print
(
-
2
,
"
\t
performs unate fast extract on the current network
\n
"
);
Abc_Print
(
-
2
,
"
\t
-S <num> : max number of single-cube divisors to consider [default = %d]
\n
"
,
p
->
nSingleMax
);
Abc_Print
(
-
2
,
"
\t
-D <num> : max number of double-cube divisors to consider [default = %d]
\n
"
,
p
->
nPairsMax
);
Abc_Print
(
-
2
,
"
\t
-N <num> :
the maximum number of divisors to extract
[default = %d]
\n
"
,
p
->
nNodesExt
);
Abc_Print
(
-
2
,
"
\t
-W <num> : only extract divisors with weight more than this [default = %d]
\n
"
,
p
->
nSingle
Max
);
Abc_Print
(
-
2
,
"
\t
-N <num> :
max number of divisors to extract during this run
[default = %d]
\n
"
,
p
->
nNodesExt
);
Abc_Print
(
-
2
,
"
\t
-W <num> : only extract divisors with weight more than this [default = %d]
\n
"
,
p
->
Weight
Max
);
Abc_Print
(
-
2
,
"
\t
-s : use only single-cube divisors [default = %s]
\n
"
,
p
->
fOnlyS
?
"yes"
:
"no"
);
Abc_Print
(
-
2
,
"
\t
-d : use only double-cube divisors [default = %s]
\n
"
,
p
->
fOnlyD
?
"yes"
:
"no"
);
Abc_Print
(
-
2
,
"
\t
-z : use zero-weight divisors [default = %s]
\n
"
,
p
->
fUse0
?
"yes"
:
"no"
);
...
...
@@ -3668,17 +3668,20 @@ int Abc_CommandEliminate( Abc_Frame_t * pAbc, int argc, char ** argv )
{
Abc_Ntk_t
*
pNtk
=
Abc_FrameReadNtk
(
pAbc
);
int
nMaxSize
;
int
fGreedy
;
int
fReverse
;
int
fVerbose
;
int
c
;
extern
int
Abc_NtkEliminate
(
Abc_Ntk_t
*
pNtk
,
int
nMaxSize
,
int
fReverse
,
int
fVerbose
);
extern
int
Abc_NtkEliminate1
(
Abc_Ntk_t
*
pNtk
,
int
nMaxSize
,
int
fReverse
,
int
fVerbose
);
// set the defaults
nMaxSize
=
8
;
fReverse
=
0
;
fVerbose
=
0
;
nMaxSize
=
30
;
fGreedy
=
0
;
fReverse
=
0
;
fVerbose
=
0
;
Extra_UtilGetoptReset
();
while
(
(
c
=
Extra_UtilGetopt
(
argc
,
argv
,
"Nrvh"
))
!=
EOF
)
while
(
(
c
=
Extra_UtilGetopt
(
argc
,
argv
,
"N
g
rvh"
))
!=
EOF
)
{
switch
(
c
)
{
...
...
@@ -3693,6 +3696,9 @@ int Abc_CommandEliminate( Abc_Frame_t * pAbc, int argc, char ** argv )
if
(
nMaxSize
<=
0
)
goto
usage
;
break
;
case
'g'
:
fGreedy
^=
1
;
break
;
case
'r'
:
fReverse
^=
1
;
break
;
...
...
@@ -3725,14 +3731,18 @@ int Abc_CommandEliminate( Abc_Frame_t * pAbc, int argc, char ** argv )
return
1
;
}
// the nodes to be merged are linked into the special linked list
Abc_NtkEliminate
(
pNtk
,
nMaxSize
,
fReverse
,
fVerbose
);
if
(
fGreedy
)
Abc_NtkEliminate
(
pNtk
,
nMaxSize
,
fReverse
,
fVerbose
);
else
Abc_NtkEliminate1
(
pNtk
,
nMaxSize
,
fReverse
,
fVerbose
);
return
0
;
usage:
Abc_Print
(
-
2
,
"usage: eliminate [-N <num>] [-rvh]
\n
"
);
Abc_Print
(
-
2
,
"
\t
greedily eliminates nodes by collapsing them into fanouts
\n
"
);
Abc_Print
(
-
2
,
"
\t
-N <num> : the maximum support size after collapsing [default = %d]
\n
"
,
nMaxSize
);
Abc_Print
(
-
2
,
"usage: eliminate [-N <num>] [-grvh]
\n
"
);
Abc_Print
(
-
2
,
"
\t
traditional
\"
eliminate -1
\"
, which collapses the node into its fanout
\n
"
);
Abc_Print
(
-
2
,
"
\t
if the node's variable appears in the fanout's factored form only once
\n
"
);
Abc_Print
(
-
2
,
"
\t
-N <num> : the maximum node support after collapsing [default = %d]
\n
"
,
nMaxSize
);
Abc_Print
(
-
2
,
"
\t
-g : toggle using greedy eliminate (without
\"
value
\"
) [default = %s]
\n
"
,
fGreedy
?
"yes"
:
"no"
);
Abc_Print
(
-
2
,
"
\t
-r : use the reverse topological order [default = %s]
\n
"
,
fReverse
?
"yes"
:
"no"
);
Abc_Print
(
-
2
,
"
\t
-v : print verbose information [default = %s]
\n
"
,
fVerbose
?
"yes"
:
"no"
);
Abc_Print
(
-
2
,
"
\t
-h : print the command usage
\n
"
);
...
...
src/base/abci/abcFxu.c
View file @
48d867f7
...
...
@@ -52,15 +52,15 @@ extern int Fxu_FastExtract( Fxu_Data_t * pData );
void
Abc_NtkSetDefaultParams
(
Fxu_Data_t
*
p
)
{
memset
(
p
,
0
,
sizeof
(
Fxu_Data_t
)
);
p
->
nSingleMax
=
20000
;
p
->
nPairsMax
=
30000
;
p
->
nNodesExt
=
10000
;
p
->
WeightMax
=
0
;
p
->
fOnlyS
=
0
;
p
->
fOnlyD
=
0
;
p
->
fUse0
=
0
;
p
->
fUseCompl
=
1
;
p
->
fVerbose
=
0
;
p
->
nSingleMax
=
20000
;
p
->
nPairsMax
=
30000
;
p
->
nNodesExt
=
10000
0
;
p
->
WeightMax
=
0
;
p
->
fOnlyS
=
0
;
p
->
fOnlyD
=
0
;
p
->
fUse0
=
0
;
p
->
fUseCompl
=
1
;
p
->
fVerbose
=
0
;
}
/**Function*************************************************************
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment