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
9206e6ff
Commit
9206e6ff
authored
Oct 08, 2012
by
Alan Mishchenko
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Improvements to gate sizing.
parent
2cb69e45
Expand all
Show whitespace changes
Inline
Side-by-side
Showing
12 changed files
with
635 additions
and
79 deletions
+635
-79
abclib.dsp
+8
-0
src/map/scl/module.make
+1
-0
src/map/scl/scl.c
+40
-9
src/map/scl/sclGsize.c
+54
-0
src/map/scl/sclInt.h
+9
-7
src/map/scl/sclLoad.c
+54
-28
src/map/scl/sclMan.h
+73
-8
src/map/scl/sclSize.c
+7
-6
src/map/scl/sclTime.c
+28
-21
src/map/scl/sclUpsize.c
+0
-0
src/map/scl/sclUtil.c
+1
-0
src/misc/vec/vecQue.h
+360
-0
No files found.
abclib.dsp
View file @
9206e6ff
...
...
@@ -2391,6 +2391,10 @@ SOURCE=.\src\map\scl\sclFile.c
# End Source File
# Begin Source File
SOURCE=.\src\map\scl\sclGsize.c
# End Source File
# Begin Source File
SOURCE=.\src\map\scl\sclInt.h
# End Source File
# Begin Source File
...
...
@@ -2627,6 +2631,10 @@ SOURCE=.\src\misc\vec\vecPtr.h
# End Source File
# Begin Source File
SOURCE=.\src\misc\vec\vecQue.h
# End Source File
# Begin Source File
SOURCE=.\src\misc\vec\vecSet.h
# End Source File
# Begin Source File
...
...
src/map/scl/module.make
View file @
9206e6ff
SRC
+=
src/map/scl/scl.c
\
src/map/scl/sclBuff.c
\
src/map/scl/sclFile.c
\
src/map/scl/sclGsize.c
\
src/map/scl/sclLoad.c
\
src/map/scl/sclSize.c
\
src/map/scl/sclTime.c
\
...
...
src/map/scl/scl.c
View file @
9206e6ff
...
...
@@ -644,15 +644,29 @@ usage:
int
Scl_CommandUpsize
(
Abc_Frame_t
*
pAbc
,
int
argc
,
char
**
argv
)
{
Abc_Ntk_t
*
pNtk
=
Abc_FrameReadNtk
(
pAbc
);
int
nIters
=
300
;
int
Window
=
2
;
int
Ratio
=
10
;
int
nIters
=
100
;
int
Notches
=
10
;
int
TimeOut
=
0
;
int
c
,
fVerbose
=
0
;
int
fVeryVerbose
=
0
;
Extra_UtilGetoptReset
();
while
(
(
c
=
Extra_UtilGetopt
(
argc
,
argv
,
"
WRIv
h"
)
)
!=
EOF
)
while
(
(
c
=
Extra_UtilGetopt
(
argc
,
argv
,
"
IWRNTvw
h"
)
)
!=
EOF
)
{
switch
(
c
)
{
case
'I'
:
if
(
globalUtilOptind
>=
argc
)
{
Abc_Print
(
-
1
,
"Command line switch
\"
-I
\"
should be followed by a positive integer.
\n
"
);
goto
usage
;
}
nIters
=
atoi
(
argv
[
globalUtilOptind
]);
globalUtilOptind
++
;
if
(
nIters
<
0
)
goto
usage
;
break
;
case
'W'
:
if
(
globalUtilOptind
>=
argc
)
{
...
...
@@ -675,20 +689,34 @@ int Scl_CommandUpsize( Abc_Frame_t * pAbc, int argc, char **argv )
if
(
Ratio
<
0
)
goto
usage
;
break
;
case
'
I
'
:
case
'
N
'
:
if
(
globalUtilOptind
>=
argc
)
{
Abc_Print
(
-
1
,
"Command line switch
\"
-
I
\"
should be followed by a positive integer.
\n
"
);
Abc_Print
(
-
1
,
"Command line switch
\"
-
N
\"
should be followed by a positive integer.
\n
"
);
goto
usage
;
}
nIter
s
=
atoi
(
argv
[
globalUtilOptind
]);
Notche
s
=
atoi
(
argv
[
globalUtilOptind
]);
globalUtilOptind
++
;
if
(
nIters
<
0
)
if
(
Notches
<
0
)
goto
usage
;
break
;
case
'T'
:
if
(
globalUtilOptind
>=
argc
)
{
Abc_Print
(
-
1
,
"Command line switch
\"
-T
\"
should be followed by a positive integer.
\n
"
);
goto
usage
;
}
TimeOut
=
atoi
(
argv
[
globalUtilOptind
]);
globalUtilOptind
++
;
if
(
TimeOut
<
0
)
goto
usage
;
break
;
case
'v'
:
fVerbose
^=
1
;
break
;
case
'w'
:
fVeryVerbose
^=
1
;
break
;
case
'h'
:
goto
usage
;
default:
...
...
@@ -717,16 +745,19 @@ int Scl_CommandUpsize( Abc_Frame_t * pAbc, int argc, char **argv )
return
1
;
}
Abc_SclUpsizePerform
(
(
SC_Lib
*
)
pAbc
->
pLibScl
,
pNtk
,
Window
,
Ratio
,
nIters
,
f
Verbose
);
Abc_SclUpsizePerform
(
(
SC_Lib
*
)
pAbc
->
pLibScl
,
pNtk
,
nIters
,
Window
,
Ratio
,
Notches
,
TimeOut
,
fVerbose
,
fVery
Verbose
);
return
0
;
usage:
fprintf
(
pAbc
->
Err
,
"usage: upsize [-
WRI num] [-v
h]
\n
"
);
fprintf
(
pAbc
->
Err
,
"usage: upsize [-
IWRNT num] [-vw
h]
\n
"
);
fprintf
(
pAbc
->
Err
,
"
\t
selectively increases gate sizes in timing-critical regions
\n
"
);
fprintf
(
pAbc
->
Err
,
"
\t
-I <num> : the number of upsizing iterations to perform [default = %d]
\n
"
,
nIters
);
fprintf
(
pAbc
->
Err
,
"
\t
-W <num> : delay window (in percents) of near-critical COs [default = %d]
\n
"
,
Window
);
fprintf
(
pAbc
->
Err
,
"
\t
-R <num> : ratio of critical nodes (in percents) to update [default = %d]
\n
"
,
Ratio
);
fprintf
(
pAbc
->
Err
,
"
\t
-I <num> : the number of upsizing iterations to perform [default = %d]
\n
"
,
nIters
);
fprintf
(
pAbc
->
Err
,
"
\t
-N <num> : limit on discrete upsizing steps at a node [default = %d]
\n
"
,
Notches
);
fprintf
(
pAbc
->
Err
,
"
\t
-T <num> : approximate timeout in seconds [default = %d]
\n
"
,
TimeOut
);
fprintf
(
pAbc
->
Err
,
"
\t
-v : toggle printing verbose information [default = %s]
\n
"
,
fVerbose
?
"yes"
:
"no"
);
fprintf
(
pAbc
->
Err
,
"
\t
-w : toggle printing more verbose information [default = %s]
\n
"
,
fVeryVerbose
?
"yes"
:
"no"
);
fprintf
(
pAbc
->
Err
,
"
\t
-h : print the command usage
\n
"
);
return
1
;
}
...
...
src/map/scl/sclGsize.c
0 → 100644
View file @
9206e6ff
/**CFile****************************************************************
FileName [sclGsize.c]
SystemName [ABC: Logic synthesis and verification system.]
PackageName [Standard-cell library representation.]
Synopsis [Selective increase of gate sizes.]
Author [Alan Mishchenko, Niklas Een]
Affiliation [UC Berkeley]
Date [Ver. 1.0. Started - August 24, 2012.]
Revision [$Id: sclGsize.c,v 1.0 2012/08/24 00:00:00 alanmi Exp $]
***********************************************************************/
#include "sclInt.h"
#include "sclMan.h"
ABC_NAMESPACE_IMPL_START
////////////////////////////////////////////////////////////////////////
/// DECLARATIONS ///
////////////////////////////////////////////////////////////////////////
////////////////////////////////////////////////////////////////////////
/// FUNCTION DEFINITIONS ///
////////////////////////////////////////////////////////////////////////
/**Function*************************************************************
Synopsis []
Description []
SideEffects []
SeeAlso []
***********************************************************************/
////////////////////////////////////////////////////////////////////////
/// END OF FILE ///
////////////////////////////////////////////////////////////////////////
ABC_NAMESPACE_IMPL_END
src/map/scl/sclInt.h
View file @
9206e6ff
...
...
@@ -423,22 +423,24 @@ static inline void Abc_SclLibFree( SC_Lib * p )
}
/*=== sclBuff.c =============================================================*/
/*=== sclBuff.c =============================================================
==
*/
extern
int
Abc_SclCheckNtk
(
Abc_Ntk_t
*
p
,
int
fVerbose
);
extern
Abc_Ntk_t
*
Abc_SclPerformBuffering
(
Abc_Ntk_t
*
p
,
int
Degree
,
int
fVerbose
);
/*=== sclFile.c =============================================================*/
/*=== sclFile.c =============================================================
==
*/
extern
SC_Lib
*
Abc_SclRead
(
char
*
pFileName
);
extern
void
Abc_SclWrite
(
char
*
pFileName
,
SC_Lib
*
p
);
extern
void
Abc_SclWriteText
(
char
*
pFileName
,
SC_Lib
*
p
);
extern
void
Abc_SclLoad
(
char
*
pFileName
,
SC_Lib
**
ppScl
);
extern
void
Abc_SclSave
(
char
*
pFileName
,
SC_Lib
*
pScl
);
/*=== sclTime.c =============================================================*/
/*=== sclLoad.c ===============================================================*/
extern
SC_WireLoad
*
Abc_SclFindWireLoadModel
(
SC_Lib
*
p
,
float
Area
);
/*=== sclTime.c ===============================================================*/
extern
void
Abc_SclTimePerform
(
SC_Lib
*
pLib
,
Abc_Ntk_t
*
pNtk
,
int
fUseWireLoads
,
int
fShowAll
,
int
fShort
);
/*=== sclSize.c =============================================================*/
/*=== sclSize.c =============================================================
==
*/
extern
void
Abc_SclSizingPerform
(
SC_Lib
*
pLib
,
Abc_Ntk_t
*
pNtk
,
SC_SizePars
*
p
);
/*=== sclUpsize.c =============================================================*/
extern
void
Abc_SclUpsizePerform
(
SC_Lib
*
pLib
,
Abc_Ntk_t
*
pNtk
,
int
Window
,
int
Ratio
,
int
nIters
,
int
f
Verbose
);
/*=== sclUtil.c =============================================================*/
/*=== sclUpsize.c =============================================================
==
*/
extern
void
Abc_SclUpsizePerform
(
SC_Lib
*
pLib
,
Abc_Ntk_t
*
pNtk
,
int
nIters
,
int
Window
,
int
Ratio
,
int
Notches
,
int
TimeOut
,
int
fVerbose
,
int
fVery
Verbose
);
/*=== sclUtil.c =============================================================
==
*/
extern
void
Abc_SclHashCells
(
SC_Lib
*
p
);
extern
int
Abc_SclCellFind
(
SC_Lib
*
p
,
char
*
pName
);
extern
void
Abc_SclLinkCells
(
SC_Lib
*
p
);
...
...
src/map/scl/sclLoad.c
View file @
9206e6ff
...
...
@@ -34,7 +34,7 @@ ABC_NAMESPACE_IMPL_START
/**Function*************************************************************
Synopsis [Returns
estimated wire capacitances for each fanout count
.]
Synopsis [Returns
the wireload model for the given area
.]
Description []
...
...
@@ -43,52 +43,69 @@ ABC_NAMESPACE_IMPL_START
SeeAlso []
***********************************************************************/
Vec_Flt_t
*
Abc_SclFindWireCaps
(
SC_Man
*
p
)
SC_WireLoad
*
Abc_SclFindWireLoadModel
(
SC_Lib
*
p
,
float
Area
)
{
Vec_Flt_t
*
vCaps
=
NULL
;
SC_WireLoad
*
pWL
=
NULL
;
int
i
,
Entry
,
EntryMax
;
float
EntryPrev
,
EntryCur
;
p
->
pWLoadUsed
=
NULL
;
if
(
p
->
pLib
->
default_wire_load_sel
&&
strlen
(
p
->
pLib
->
default_wire_load_sel
)
)
char
*
pWLoadUsed
=
NULL
;
int
i
;
if
(
p
->
default_wire_load_sel
&&
strlen
(
p
->
default_wire_load_sel
)
)
{
float
Area
;
SC_WireLoadSel
*
pWLS
=
NULL
;
SC_LibForEachWireLoadSel
(
p
->
pLib
,
pWLS
,
i
)
if
(
!
strcmp
(
pWLS
->
pName
,
p
->
pLib
->
default_wire_load_sel
)
)
SC_LibForEachWireLoadSel
(
p
,
pWLS
,
i
)
if
(
!
strcmp
(
pWLS
->
pName
,
p
->
default_wire_load_sel
)
)
break
;
if
(
i
==
Vec_PtrSize
(
p
->
pLib
->
vWireLoadSels
)
)
if
(
i
==
Vec_PtrSize
(
p
->
vWireLoadSels
)
)
{
Abc_Print
(
-
1
,
"Cannot find wire load selection model
\"
%s
\"
.
\n
"
,
p
->
pLib
->
default_wire_load_sel
);
Abc_Print
(
-
1
,
"Cannot find wire load selection model
\"
%s
\"
.
\n
"
,
p
->
default_wire_load_sel
);
exit
(
1
);
}
Area
=
(
float
)
Abc_SclGetTotalArea
(
p
);
for
(
i
=
0
;
i
<
Vec_FltSize
(
pWLS
->
vAreaFrom
);
i
++
)
if
(
Area
>=
Vec_FltEntry
(
pWLS
->
vAreaFrom
,
i
)
&&
Area
<
Vec_FltEntry
(
pWLS
->
vAreaTo
,
i
)
)
{
p
->
p
WLoadUsed
=
(
char
*
)
Vec_PtrEntry
(
pWLS
->
vWireLoadModel
,
i
);
pWLoadUsed
=
(
char
*
)
Vec_PtrEntry
(
pWLS
->
vWireLoadModel
,
i
);
break
;
}
if
(
i
==
Vec_FltSize
(
pWLS
->
vAreaFrom
)
)
p
->
p
WLoadUsed
=
(
char
*
)
Vec_PtrEntryLast
(
pWLS
->
vWireLoadModel
);
pWLoadUsed
=
(
char
*
)
Vec_PtrEntryLast
(
pWLS
->
vWireLoadModel
);
}
else
if
(
p
->
pLib
->
default_wire_load
&&
strlen
(
p
->
pLib
->
default_wire_load
)
)
p
->
pWLoadUsed
=
p
->
pLib
->
default_wire_load
;
else
if
(
p
->
default_wire_load
&&
strlen
(
p
->
default_wire_load
)
)
p
WLoadUsed
=
p
->
default_wire_load
;
else
{
Abc_Print
(
0
,
"No wire model given.
\n
"
);
return
NULL
;
}
// Get the actual table and reformat it for 'wire_cap' output:
assert
(
p
->
p
WLoadUsed
!=
NULL
);
SC_LibForEachWireLoad
(
p
->
pLib
,
pWL
,
i
)
if
(
!
strcmp
(
pWL
->
pName
,
p
->
p
WLoadUsed
)
)
assert
(
pWLoadUsed
!=
NULL
);
SC_LibForEachWireLoad
(
p
,
pWL
,
i
)
if
(
!
strcmp
(
pWL
->
pName
,
pWLoadUsed
)
)
break
;
if
(
i
==
Vec_PtrSize
(
p
->
pLib
->
vWireLoads
)
)
if
(
i
==
Vec_PtrSize
(
p
->
vWireLoads
)
)
{
Abc_Print
(
-
1
,
"Cannot find wire load model
\"
%s
\"
.
\n
"
,
p
->
p
WLoadUsed
);
Abc_Print
(
-
1
,
"Cannot find wire load model
\"
%s
\"
.
\n
"
,
pWLoadUsed
);
exit
(
1
);
}
// printf( "Using wireload model \"%s\".\n", pWL->pName );
return
pWL
;
}
/**Function*************************************************************
Synopsis [Returns estimated wire capacitances for each fanout count.]
Description []
SideEffects []
SeeAlso []
***********************************************************************/
Vec_Flt_t
*
Abc_SclFindWireCaps
(
SC_Man
*
p
,
SC_WireLoad
*
pWL
)
{
Vec_Flt_t
*
vCaps
=
NULL
;
float
EntryPrev
,
EntryCur
;
int
i
,
Entry
,
EntryMax
;
assert
(
pWL
!=
NULL
);
// find the biggest fanout
EntryMax
=
0
;
Vec_IntForEachEntry
(
pWL
->
vFanout
,
Entry
,
i
)
...
...
@@ -111,7 +128,7 @@ Vec_Flt_t * Abc_SclFindWireCaps( SC_Man * p )
/**Function*************************************************************
Synopsis [Computes
/updates
load for all nodes in the network.]
Synopsis [Computes load for all nodes in the network.]
Description []
...
...
@@ -143,12 +160,10 @@ void Abc_SclComputeLoad( SC_Man * p )
pLoad
->
fall
+=
pPin
->
fall_cap
;
}
}
if
(
!
p
->
fUseWireLoads
)
if
(
p
->
pWLoadUsed
==
NULL
)
return
;
// add wire load
vWireCaps
=
Abc_SclFindWireCaps
(
p
);
if
(
vWireCaps
)
{
vWireCaps
=
Abc_SclFindWireCaps
(
p
,
p
->
pWLoadUsed
);
Abc_NtkForEachNode1
(
p
->
pNtk
,
pObj
,
i
)
{
SC_Pair
*
pLoad
=
Abc_SclObjLoad
(
p
,
pObj
);
...
...
@@ -157,8 +172,19 @@ void Abc_SclComputeLoad( SC_Man * p )
pLoad
->
fall
+=
Vec_FltEntry
(
vWireCaps
,
k
);
}
Vec_FltFree
(
vWireCaps
);
}
}
/**Function*************************************************************
Synopsis [Updates load of the node's fanins.]
Description []
SideEffects []
SeeAlso []
***********************************************************************/
void
Abc_SclUpdateLoad
(
SC_Man
*
p
,
Abc_Obj_t
*
pObj
,
SC_Cell
*
pOld
,
SC_Cell
*
pNew
)
{
Abc_Obj_t
*
pFanin
;
...
...
src/map/scl/sclMan.h
View file @
9206e6ff
...
...
@@ -26,6 +26,8 @@
/// INCLUDES ///
////////////////////////////////////////////////////////////////////////
#include "misc/vec/vecQue.h"
ABC_NAMESPACE_HEADER_START
////////////////////////////////////////////////////////////////////////
...
...
@@ -49,21 +51,33 @@ struct SC_Man_
{
SC_Lib
*
pLib
;
// library
Abc_Ntk_t
*
pNtk
;
// network
int
fUseWireLoads
;
// set to 1 if wireloads are used
int
nObjs
;
// allocated size
// get assignment
Vec_Int_t
*
vGates
;
// mapping of objId into gateId
Vec_Int_t
*
vGatesBest
;
// best gate sizes found so far
Vec_Int_t
*
vUpdates
;
// sizing updates in this round
// timing information
SC_Pair
*
pLoads
;
// loads for each gate
SC_Pair
*
pLoads2
;
// loads for each gate
SC_Pair
*
pDepts
;
// departures for each gate
SC_Pair
*
pTimes
;
// arrivals for each gate
SC_Pair
*
pSlews
;
// slews for each gate
SC_Pair
*
pTimes2
;
// arrivals for each gate
SC_Pair
*
pSlews2
;
// slews for each gate
char
*
pWLoadUsed
;
// name of the used WireLoad model
clock_t
clkStart
;
// starting time
Vec_Flt_t
*
vTimesOut
;
// output arrival times
Vec_Que_t
*
vQue
;
// outputs by their time
SC_WireLoad
*
pWLoadUsed
;
// name of the used WireLoad model
float
SumArea
;
// total area
float
MaxDelay
;
// max delay
float
SumArea0
;
// total area at the begining
float
MaxDelay0
;
// max delay at the begining
float
BestDelay
;
// best delay in the middle
// runtime statistics
clock_t
timeTotal
;
// starting/total time
clock_t
timeCone
;
// critical path selection
clock_t
timeSize
;
// incremental sizing
clock_t
timeTime
;
// timing update
clock_t
timeOther
;
// everything else
};
////////////////////////////////////////////////////////////////////////
...
...
@@ -78,6 +92,7 @@ static inline SC_Cell * Abc_SclObjCell( SC_Man * p, Abc_Obj_t * pObj )
static
inline
void
Abc_SclObjSetCell
(
SC_Man
*
p
,
Abc_Obj_t
*
pObj
,
SC_Cell
*
pCell
)
{
Vec_IntWriteEntry
(
p
->
vGates
,
Abc_ObjId
(
pObj
),
pCell
->
Id
);
}
static
inline
SC_Pair
*
Abc_SclObjLoad
(
SC_Man
*
p
,
Abc_Obj_t
*
pObj
)
{
return
p
->
pLoads
+
Abc_ObjId
(
pObj
);
}
static
inline
SC_Pair
*
Abc_SclObjLoad2
(
SC_Man
*
p
,
Abc_Obj_t
*
pObj
)
{
return
p
->
pLoads2
+
Abc_ObjId
(
pObj
);
}
static
inline
SC_Pair
*
Abc_SclObjDept
(
SC_Man
*
p
,
Abc_Obj_t
*
pObj
)
{
return
p
->
pDepts
+
Abc_ObjId
(
pObj
);
}
static
inline
SC_Pair
*
Abc_SclObjTime
(
SC_Man
*
p
,
Abc_Obj_t
*
pObj
)
{
return
p
->
pTimes
+
Abc_ObjId
(
pObj
);
}
static
inline
SC_Pair
*
Abc_SclObjSlew
(
SC_Man
*
p
,
Abc_Obj_t
*
pObj
)
{
return
p
->
pSlews
+
Abc_ObjId
(
pObj
);
}
...
...
@@ -113,24 +128,38 @@ static inline double Abc_SclObjSlewPs( SC_Man * p, Abc_Obj_t * pObj, int fRis
static
inline
SC_Man
*
Abc_SclManAlloc
(
SC_Lib
*
pLib
,
Abc_Ntk_t
*
pNtk
)
{
SC_Man
*
p
;
int
i
;
assert
(
Abc_NtkHasMapping
(
pNtk
)
);
p
=
ABC_CALLOC
(
SC_Man
,
1
);
p
->
pLib
=
pLib
;
p
->
pNtk
=
pNtk
;
p
->
nObjs
=
Abc_NtkObjNumMax
(
pNtk
);
p
->
pLoads
=
ABC_CALLOC
(
SC_Pair
,
p
->
nObjs
);
p
->
pLoads2
=
ABC_CALLOC
(
SC_Pair
,
p
->
nObjs
);
p
->
pDepts
=
ABC_CALLOC
(
SC_Pair
,
p
->
nObjs
);
p
->
pTimes
=
ABC_CALLOC
(
SC_Pair
,
p
->
nObjs
);
p
->
pSlews
=
ABC_CALLOC
(
SC_Pair
,
p
->
nObjs
);
p
->
pTimes2
=
ABC_CALLOC
(
SC_Pair
,
p
->
nObjs
);
p
->
pSlews2
=
ABC_CALLOC
(
SC_Pair
,
p
->
nObjs
);
p
->
clkStart
=
clock
();
p
->
vTimesOut
=
Vec_FltStart
(
Abc_NtkCoNum
(
pNtk
)
);
p
->
vQue
=
Vec_QueAlloc
(
Abc_NtkCoNum
(
pNtk
)
);
Vec_QueSetCosts
(
p
->
vQue
,
Vec_FltArray
(
p
->
vTimesOut
)
);
for
(
i
=
0
;
i
<
Abc_NtkCoNum
(
pNtk
);
i
++
)
Vec_QuePush
(
p
->
vQue
,
i
);
p
->
vUpdates
=
Vec_IntAlloc
(
1000
);
return
p
;
}
static
inline
void
Abc_SclManFree
(
SC_Man
*
p
)
{
Vec_IntFreeP
(
&
p
->
vUpdates
);
Vec_IntFreeP
(
&
p
->
vGatesBest
);
// Vec_QuePrint( p->vQue );
Vec_QueCheck
(
p
->
vQue
);
Vec_QueFreeP
(
&
p
->
vQue
);
Vec_FltFreeP
(
&
p
->
vTimesOut
);
Vec_IntFreeP
(
&
p
->
vGates
);
ABC_FREE
(
p
->
pLoads
);
ABC_FREE
(
p
->
pLoads2
);
ABC_FREE
(
p
->
pDepts
);
ABC_FREE
(
p
->
pTimes
);
ABC_FREE
(
p
->
pSlews
);
...
...
@@ -159,13 +188,12 @@ static inline void Abc_SclManCleanTime( SC_Man * p )
***********************************************************************/
static
inline
void
Abc_SclConeStore
(
SC_Man
*
p
,
Vec_Int_t
*
vCone
)
{
SC_Pair
Zero
=
{
0
.
0
,
0
.
0
};
Abc_Obj_t
*
pObj
;
int
i
;
Abc_NtkForEachObjVec
(
vCone
,
p
->
pNtk
,
pObj
,
i
)
{
*
Abc_SclObjTime2
(
p
,
pObj
)
=
*
Abc_SclObjTime
(
p
,
pObj
);
*
Abc_SclObjTime
(
p
,
pObj
)
=
Zero
;
*
Abc_SclObjSlew2
(
p
,
pObj
)
=
*
Abc_SclObjSlew
(
p
,
pObj
);
*
Abc_SclObjSlew
(
p
,
pObj
)
=
Zero
;
*
Abc_SclObjTime2
(
p
,
pObj
)
=
*
Abc_SclObjTime
(
p
,
pObj
);
*
Abc_SclObjSlew2
(
p
,
pObj
)
=
*
Abc_SclObjSlew
(
p
,
pObj
);
}
}
static
inline
void
Abc_SclConeRestore
(
SC_Man
*
p
,
Vec_Int_t
*
vCone
)
...
...
@@ -178,6 +206,43 @@ static inline void Abc_SclConeRestore( SC_Man * p, Vec_Int_t * vCone )
*
Abc_SclObjSlew
(
p
,
pObj
)
=
*
Abc_SclObjSlew2
(
p
,
pObj
);
}
}
static
inline
void
Abc_SclConeClear
(
SC_Man
*
p
,
Vec_Int_t
*
vCone
)
{
SC_Pair
Zero
=
{
0
.
0
,
0
.
0
};
Abc_Obj_t
*
pObj
;
int
i
;
Abc_NtkForEachObjVec
(
vCone
,
p
->
pNtk
,
pObj
,
i
)
{
*
Abc_SclObjTime
(
p
,
pObj
)
=
Zero
;
*
Abc_SclObjSlew
(
p
,
pObj
)
=
Zero
;
}
}
/**Function*************************************************************
Synopsis [Stores/retrivies load information.]
Description []
SideEffects []
SeeAlso []
***********************************************************************/
static
inline
void
Abc_SclLoadStore
(
SC_Man
*
p
,
Abc_Obj_t
*
pObj
)
{
Abc_Obj_t
*
pFanin
;
int
i
;
Abc_ObjForEachFanin
(
pObj
,
pFanin
,
i
)
*
Abc_SclObjLoad2
(
p
,
pFanin
)
=
*
Abc_SclObjLoad
(
p
,
pFanin
);
}
static
inline
void
Abc_SclLoadRestore
(
SC_Man
*
p
,
Abc_Obj_t
*
pObj
)
{
Abc_Obj_t
*
pFanin
;
int
i
;
Abc_ObjForEachFanin
(
pObj
,
pFanin
,
i
)
*
Abc_SclObjLoad
(
p
,
pFanin
)
=
*
Abc_SclObjLoad2
(
p
,
pFanin
);
}
/**Function*************************************************************
...
...
@@ -246,7 +311,7 @@ extern Abc_Obj_t * Abc_SclFindMostCriticalFanin( SC_Man * p, int * pfRise, Abc_O
extern
void
Abc_SclTimeNtkPrint
(
SC_Man
*
p
,
int
fShowAll
,
int
fShort
);
extern
SC_Man
*
Abc_SclManStart
(
SC_Lib
*
pLib
,
Abc_Ntk_t
*
pNtk
,
int
fUseWireLoads
);
extern
void
Abc_SclTimeCone
(
SC_Man
*
p
,
Vec_Int_t
*
vCone
);
extern
void
Abc_SclTimeNtkRecompute
(
SC_Man
*
p
,
float
*
pArea
,
float
*
pDelay
);
extern
void
Abc_SclTimeNtkRecompute
(
SC_Man
*
p
,
float
*
pArea
,
float
*
pDelay
,
int
fReverse
);
/*=== sclTime.c =============================================================*/
extern
void
Abc_SclComputeLoad
(
SC_Man
*
p
);
extern
void
Abc_SclUpdateLoad
(
SC_Man
*
p
,
Abc_Obj_t
*
pObj
,
SC_Cell
*
pOld
,
SC_Cell
*
pNew
);
...
...
src/map/scl/sclSize.c
View file @
9206e6ff
...
...
@@ -336,12 +336,12 @@ void Abc_SclUpdateNetwork( SC_Man * p, Abc_Obj_t * pObj, int nCone, int fUpsize,
printf
(
"d =%8.2f ps "
,
SC_LibTimePs
(
p
->
pLib
,
Abc_SclGetMaxDelay
(
p
))
);
printf
(
"a =%10.2f "
,
p
->
SumArea
);
printf
(
"n =%5d "
,
nCone
);
// Abc_PrintTime( 1, "Time", clock() - p->
clkStart
);
// ABC_PRTr( "Time", clock() - p->
clkStart
);
// Abc_PrintTime( 1, "Time", clock() - p->
timeTotal
);
// ABC_PRTr( "Time", clock() - p->
timeTotal
);
if
(
fVeryVerbose
)
ABC_PRT
(
"Time"
,
clock
()
-
p
->
clkStart
);
ABC_PRT
(
"Time"
,
clock
()
-
p
->
timeTotal
);
else
ABC_PRTr
(
"Time"
,
clock
()
-
p
->
clkStart
);
ABC_PRTr
(
"Time"
,
clock
()
-
p
->
timeTotal
);
}
}
...
...
@@ -366,6 +366,7 @@ void Abc_SclSizingPerform( SC_Lib * pLib, Abc_Ntk_t * pNtk, SC_SizePars * pPars
clock_t
nRuntimeLimit
=
pPars
->
nTimeOut
?
pPars
->
nTimeOut
*
CLOCKS_PER_SEC
+
clock
()
:
0
;
int
r
,
i
,
nNodes
,
nCones
=
0
,
nDownSize
=
0
;
p
=
Abc_SclManStart
(
pLib
,
pNtk
,
pPars
->
fUseWireLoads
);
p
->
timeTotal
=
clock
();
if
(
pPars
->
fPrintCP
)
Abc_SclTimeNtkPrint
(
p
,
0
,
0
);
if
(
pPars
->
fVerbose
)
...
...
@@ -377,7 +378,7 @@ void Abc_SclSizingPerform( SC_Lib * pLib, Abc_Ntk_t * pNtk, SC_SizePars * pPars
printf
(
"d =%8.2f ps "
,
SC_LibTimePs
(
p
->
pLib
,
Abc_SclGetMaxDelay
(
p
))
);
printf
(
"a =%10.2f "
,
p
->
SumArea
);
printf
(
" "
);
Abc_PrintTime
(
1
,
"Time"
,
clock
()
-
p
->
clkStart
);
Abc_PrintTime
(
1
,
"Time"
,
clock
()
-
p
->
timeTotal
);
}
for
(
r
=
i
=
0
;
r
<
nIters
;
r
++
)
{
...
...
@@ -471,7 +472,7 @@ void Abc_SclSizingPerform( SC_Lib * pLib, Abc_Ntk_t * pNtk, SC_SizePars * pPars
printf
(
"Area: "
);
printf
(
"%.2f -> %.2f "
,
p
->
SumArea0
,
p
->
SumArea
);
printf
(
"(%+.1f %%). "
,
100
.
0
*
(
p
->
SumArea
-
p
->
SumArea0
)
/
p
->
SumArea0
);
Abc_PrintTime
(
1
,
"Time"
,
clock
()
-
p
->
clkStart
);
Abc_PrintTime
(
1
,
"Time"
,
clock
()
-
p
->
timeTotal
);
// save the result and quit
Abc_SclManSetGates
(
pLib
,
pNtk
,
p
->
vGates
);
// updates gate pointers
Abc_SclManFree
(
p
);
...
...
src/map/scl/sclTime.c
View file @
9206e6ff
...
...
@@ -82,7 +82,7 @@ Abc_Obj_t * Abc_SclFindMostCriticalFanin( SC_Man * p, int * pfRise, Abc_Obj_t *
SeeAlso []
***********************************************************************/
static
inline
void
Abc_SclTime
Gat
ePrint
(
SC_Man
*
p
,
Abc_Obj_t
*
pObj
,
int
fRise
,
int
Length
,
float
maxDelay
)
static
inline
void
Abc_SclTime
Nod
ePrint
(
SC_Man
*
p
,
Abc_Obj_t
*
pObj
,
int
fRise
,
int
Length
,
float
maxDelay
)
{
printf
(
"%7d : "
,
Abc_ObjId
(
pObj
)
);
printf
(
"%d "
,
Abc_ObjFaninNum
(
pObj
)
);
...
...
@@ -90,8 +90,8 @@ static inline void Abc_SclTimeGatePrint( SC_Man * p, Abc_Obj_t * pObj, int fRise
if
(
fRise
>=
0
)
printf
(
"(%s) "
,
fRise
?
"rise"
:
"fall"
);
printf
(
"delay = ("
);
printf
(
"%
7.1
f ps "
,
Abc_SclObjTimePs
(
p
,
pObj
,
1
)
);
printf
(
"%
7.1
f ps ) "
,
Abc_SclObjTimePs
(
p
,
pObj
,
0
)
);
printf
(
"%
8.2
f ps "
,
Abc_SclObjTimePs
(
p
,
pObj
,
1
)
);
printf
(
"%
8.2
f ps ) "
,
Abc_SclObjTimePs
(
p
,
pObj
,
0
)
);
printf
(
"load =%6.2f ff "
,
Abc_SclObjLoadFf
(
p
,
pObj
,
fRise
>=
0
?
fRise
:
0
)
);
printf
(
"slew =%6.1f ps "
,
Abc_SclObjSlewPs
(
p
,
pObj
,
fRise
>=
0
?
fRise
:
0
)
);
printf
(
"slack =%6.1f ps"
,
Abc_SclObjSlack
(
p
,
pObj
,
maxDelay
)
);
...
...
@@ -103,10 +103,10 @@ void Abc_SclTimeNtkPrint( SC_Man * p, int fShowAll, int fShort )
Abc_Obj_t
*
pObj
,
*
pPivot
=
Abc_SclFindCriticalCo
(
p
,
&
fRise
);
float
maxDelay
=
Abc_SclObjTimePs
(
p
,
pPivot
,
fRise
);
printf
(
"WireLoad model =
\"
%s
\"
. "
,
p
->
pWLoadUsed
?
p
->
pWLoadUsed
:
"none"
);
printf
(
"WireLoad model =
\"
%s
\"
. "
,
p
->
pWLoadUsed
?
p
->
pWLoadUsed
->
pName
:
"none"
);
printf
(
"Gates = %d. "
,
Abc_NtkNodeNum
(
p
->
pNtk
)
);
printf
(
"Area = %.2f. "
,
Abc_SclGetTotalArea
(
p
)
);
printf
(
"Critical delay = %.
1
f ps
\n
"
,
maxDelay
);
printf
(
"Critical delay = %.
2
f ps
\n
"
,
maxDelay
);
if
(
fShort
)
return
;
...
...
@@ -120,7 +120,7 @@ void Abc_SclTimeNtkPrint( SC_Man * p, int fShowAll, int fShort )
// print timing
Abc_NtkForEachNodeReverse
(
p
->
pNtk
,
pObj
,
i
)
if
(
Abc_ObjFaninNum
(
pObj
)
>
0
)
Abc_SclTime
Gat
ePrint
(
p
,
pObj
,
-
1
,
nLength
,
maxDelay
);
Abc_SclTime
Nod
ePrint
(
p
,
pObj
,
-
1
,
nLength
,
maxDelay
);
}
else
{
...
...
@@ -137,7 +137,7 @@ void Abc_SclTimeNtkPrint( SC_Man * p, int fShowAll, int fShort )
while
(
pObj
&&
Abc_ObjIsNode
(
pObj
)
)
{
printf
(
"Critical path -- "
);
Abc_SclTime
Gat
ePrint
(
p
,
pObj
,
fRise
,
nLength
,
maxDelay
);
Abc_SclTime
Nod
ePrint
(
p
,
pObj
,
fRise
,
nLength
,
maxDelay
);
pObj
=
Abc_SclFindMostCriticalFanin
(
p
,
&
fRise
,
pObj
);
}
}
...
...
@@ -185,7 +185,7 @@ static inline float Abc_SclLookup( SC_Surface * p, float slew, float load )
return
p0
+
sfrac
*
(
p1
-
p0
);
// <<== multiply result with K factor here
}
void
Abc_SclTime
P
in
(
SC_Man
*
p
,
SC_Timing
*
pTime
,
Abc_Obj_t
*
pObj
,
Abc_Obj_t
*
pFanin
)
void
Abc_SclTime
Fan
in
(
SC_Man
*
p
,
SC_Timing
*
pTime
,
Abc_Obj_t
*
pObj
,
Abc_Obj_t
*
pFanin
)
{
SC_Pair
*
pArrIn
=
Abc_SclObjTime
(
p
,
pFanin
);
SC_Pair
*
pSlewIn
=
Abc_SclObjSlew
(
p
,
pFanin
);
...
...
@@ -208,7 +208,7 @@ void Abc_SclTimePin( SC_Man * p, SC_Timing * pTime, Abc_Obj_t * pObj, Abc_Obj_t
pSlewOut
->
fall
=
Abc_MaxFloat
(
pSlewOut
->
fall
,
Abc_SclLookup
(
pTime
->
pFallTrans
,
pSlewIn
->
rise
,
pLoad
->
fall
)
);
}
}
void
Abc_SclDept
P
in
(
SC_Man
*
p
,
SC_Timing
*
pTime
,
Abc_Obj_t
*
pObj
,
Abc_Obj_t
*
pFanin
)
void
Abc_SclDept
Fan
in
(
SC_Man
*
p
,
SC_Timing
*
pTime
,
Abc_Obj_t
*
pObj
,
Abc_Obj_t
*
pFanin
)
{
SC_Pair
*
pDepIn
=
Abc_SclObjDept
(
p
,
pFanin
);
// modified
SC_Pair
*
pSlewIn
=
Abc_SclObjSlew
(
p
,
pFanin
);
...
...
@@ -226,7 +226,7 @@ void Abc_SclDeptPin( SC_Man * p, SC_Timing * pTime, Abc_Obj_t * pObj, Abc_Obj_t
pDepIn
->
rise
=
Abc_MaxFloat
(
pDepIn
->
rise
,
pDepOut
->
fall
+
Abc_SclLookup
(
pTime
->
pCellFall
,
pSlewIn
->
rise
,
pLoad
->
fall
)
);
}
}
void
Abc_SclTime
Gat
e
(
SC_Man
*
p
,
Abc_Obj_t
*
pObj
,
int
fDept
)
void
Abc_SclTime
Nod
e
(
SC_Man
*
p
,
Abc_Obj_t
*
pObj
,
int
fDept
)
{
SC_Timings
*
pRTime
;
SC_Timing
*
pTime
;
...
...
@@ -252,9 +252,9 @@ void Abc_SclTimeGate( SC_Man * p, Abc_Obj_t * pObj, int fDept )
assert
(
Vec_PtrSize
(
pRTime
->
vTimings
)
==
1
);
pTime
=
(
SC_Timing
*
)
Vec_PtrEntry
(
pRTime
->
vTimings
,
0
);
if
(
fDept
)
Abc_SclDept
P
in
(
p
,
pTime
,
pObj
,
Abc_ObjFanin
(
pObj
,
k
)
);
Abc_SclDept
Fan
in
(
p
,
pTime
,
pObj
,
Abc_ObjFanin
(
pObj
,
k
)
);
else
Abc_SclTime
P
in
(
p
,
pTime
,
pObj
,
Abc_ObjFanin
(
pObj
,
k
)
);
Abc_SclTime
Fan
in
(
p
,
pTime
,
pObj
,
Abc_ObjFanin
(
pObj
,
k
)
);
}
}
void
Abc_SclTimeCone
(
SC_Man
*
p
,
Vec_Int_t
*
vCone
)
...
...
@@ -262,32 +262,38 @@ void Abc_SclTimeCone( SC_Man * p, Vec_Int_t * vCone )
int
fVerbose
=
0
;
Abc_Obj_t
*
pObj
;
int
i
;
Abc_SclConeClear
(
p
,
vCone
);
Abc_NtkForEachObjVec
(
vCone
,
p
->
pNtk
,
pObj
,
i
)
{
if
(
fVerbose
&&
Abc_ObjIsNode
(
pObj
)
)
printf
(
" Updating node %d with gate %s
\n
"
,
Abc_ObjId
(
pObj
),
Abc_SclObjCell
(
p
,
pObj
)
->
pName
);
if
(
fVerbose
&&
Abc_ObjIsNode
(
pObj
)
)
printf
(
" before (%6.1f ps %6.1f ps) "
,
Abc_SclObjTimePs
(
p
,
pObj
,
1
),
Abc_SclObjTimePs
(
p
,
pObj
,
0
)
);
Abc_SclTimeGate
(
p
,
pObj
,
0
);
Abc_SclTimeNode
(
p
,
pObj
,
0
);
if
(
fVerbose
&&
Abc_ObjIsNode
(
pObj
)
)
printf
(
"after (%6.1f ps %6.1f ps)
\n
"
,
Abc_SclObjTimePs
(
p
,
pObj
,
1
),
Abc_SclObjTimePs
(
p
,
pObj
,
0
)
);
}
}
void
Abc_SclTimeNtkRecompute
(
SC_Man
*
p
,
float
*
pArea
,
float
*
pDelay
)
void
Abc_SclTimeNtkRecompute
(
SC_Man
*
p
,
float
*
pArea
,
float
*
pDelay
,
int
fReverse
)
{
Abc_Obj_t
*
pObj
;
int
i
;
Abc_SclComputeLoad
(
p
);
Abc_SclManCleanTime
(
p
);
Abc_NtkForEachNode1
(
p
->
pNtk
,
pObj
,
i
)
Abc_SclTimeGate
(
p
,
pObj
,
0
);
Abc_SclTimeNode
(
p
,
pObj
,
0
);
if
(
fReverse
)
Abc_NtkForEachNodeReverse1
(
p
->
pNtk
,
pObj
,
i
)
Abc_SclTimeGat
e
(
p
,
pObj
,
1
);
Abc_SclTimeNod
e
(
p
,
pObj
,
1
);
Abc_NtkForEachCo
(
p
->
pNtk
,
pObj
,
i
)
{
Abc_SclObjDupFanin
(
p
,
pObj
);
Vec_FltWriteEntry
(
p
->
vTimesOut
,
i
,
Abc_SclObjTimeMax
(
p
,
pObj
)
);
Vec_QueUpdate
(
p
->
vQue
,
i
);
}
// Vec_FltClear( p->vTimesOut );
// Abc_NtkForEachCo( p->pNtk, pObj, i )
// Vec_FltPush( p->vTimesOut, Abc_SclObjTimeMax(p, pObj) );
if
(
pArea
)
*
pArea
=
Abc_SclGetTotalArea
(
p
);
if
(
pDelay
)
...
...
@@ -308,10 +314,11 @@ void Abc_SclTimeNtkRecompute( SC_Man * p, float * pArea, float * pDelay )
SC_Man
*
Abc_SclManStart
(
SC_Lib
*
pLib
,
Abc_Ntk_t
*
pNtk
,
int
fUseWireLoads
)
{
SC_Man
*
p
=
Abc_SclManAlloc
(
pLib
,
pNtk
);
p
->
fUseWireLoads
=
fUseWireLoads
;
assert
(
p
->
vGates
==
NULL
);
p
->
vGates
=
Abc_SclManFindGates
(
pLib
,
pNtk
);
Abc_SclTimeNtkRecompute
(
p
,
&
p
->
SumArea0
,
&
p
->
MaxDelay0
);
if
(
fUseWireLoads
)
p
->
pWLoadUsed
=
Abc_SclFindWireLoadModel
(
pLib
,
Abc_SclGetTotalArea
(
p
)
);
Abc_SclTimeNtkRecompute
(
p
,
&
p
->
SumArea0
,
&
p
->
MaxDelay0
,
0
);
p
->
SumArea
=
p
->
SumArea0
;
return
p
;
}
...
...
src/map/scl/sclUpsize.c
View file @
9206e6ff
This diff is collapsed.
Click to expand it.
src/map/scl/sclUtil.c
View file @
9206e6ff
...
...
@@ -233,6 +233,7 @@ void Abc_SclManSetGates( SC_Lib * pLib, Abc_Ntk_t * p, Vec_Int_t * vGates )
SC_Cell
*
pCell
=
SC_LibCell
(
pLib
,
Vec_IntEntry
(
vGates
,
Abc_ObjId
(
pObj
))
);
assert
(
pCell
->
n_inputs
==
Abc_ObjFaninNum
(
pObj
)
);
pObj
->
pData
=
Mio_LibraryReadGateByName
(
(
Mio_Library_t
*
)
p
->
pManFunc
,
pCell
->
pName
,
NULL
);
assert
(
pObj
->
fMarkA
==
0
&&
pObj
->
fMarkB
==
0
);
//printf( "Found gate %s\n", pCell->name );
}
}
...
...
src/misc/vec/vecQue.h
0 → 100644
View file @
9206e6ff
/**CFile****************************************************************
FileName [vecQue.h]
SystemName [ABC: Logic synthesis and verification system.]
PackageName [Resizable arrays.]
Synopsis [Priority queue.]
Author [Alan Mishchenko]
Affiliation [UC Berkeley]
Date [Ver. 1.0. Started - June 20, 2005.]
Revision [$Id: vecQue.h,v 1.00 2005/06/20 00:00:00 alanmi Exp $]
***********************************************************************/
#ifndef ABC__misc__vec__Queue_h
#define ABC__misc__vec__Queue_h
////////////////////////////////////////////////////////////////////////
/// INCLUDES ///
////////////////////////////////////////////////////////////////////////
#include <stdio.h>
ABC_NAMESPACE_HEADER_START
////////////////////////////////////////////////////////////////////////
/// PARAMETERS ///
////////////////////////////////////////////////////////////////////////
////////////////////////////////////////////////////////////////////////
/// BASIC TYPES ///
////////////////////////////////////////////////////////////////////////
typedef
struct
Vec_Que_t_
Vec_Que_t
;
struct
Vec_Que_t_
{
int
nCap
;
int
nSize
;
int
*
pHeap
;
int
*
pOrder
;
float
*
pCostsFlt
;
// owned by the caller
};
static
inline
float
Vec_QueCost
(
Vec_Que_t
*
p
,
int
v
)
{
return
p
->
pCostsFlt
?
p
->
pCostsFlt
[
v
]
:
v
;
}
////////////////////////////////////////////////////////////////////////
/// MACRO DEFINITIONS ///
////////////////////////////////////////////////////////////////////////
////////////////////////////////////////////////////////////////////////
/// FUNCTION DEFINITIONS ///
////////////////////////////////////////////////////////////////////////
/**Function*************************************************************
Synopsis []
Description []
SideEffects []
SeeAlso []
***********************************************************************/
static
inline
Vec_Que_t
*
Vec_QueAlloc
(
int
nCap
)
{
Vec_Que_t
*
p
;
p
=
ABC_CALLOC
(
Vec_Que_t
,
1
);
if
(
nCap
<
16
)
nCap
=
16
;
p
->
nSize
=
1
;
p
->
nCap
=
nCap
+
1
;
p
->
pHeap
=
ABC_FALLOC
(
int
,
p
->
nCap
);
p
->
pOrder
=
ABC_FALLOC
(
int
,
p
->
nCap
);
return
p
;
}
static
inline
void
Vec_QueFree
(
Vec_Que_t
*
p
)
{
ABC_FREE
(
p
->
pOrder
);
ABC_FREE
(
p
->
pHeap
);
ABC_FREE
(
p
);
}
static
inline
void
Vec_QueFreeP
(
Vec_Que_t
**
p
)
{
if
(
*
p
)
Vec_QueFree
(
*
p
);
*
p
=
NULL
;
}
static
inline
void
Vec_QueSetCosts
(
Vec_Que_t
*
p
,
float
*
pCosts
)
{
assert
(
p
->
pCostsFlt
==
NULL
);
p
->
pCostsFlt
=
pCosts
;
}
static
inline
void
Vec_QueGrow
(
Vec_Que_t
*
p
,
int
nCapMin
)
{
if
(
p
->
nCap
>=
nCapMin
)
return
;
p
->
pHeap
=
ABC_REALLOC
(
int
,
p
->
pHeap
,
nCapMin
);
p
->
pOrder
=
ABC_REALLOC
(
int
,
p
->
pOrder
,
nCapMin
);
memset
(
p
->
pHeap
+
p
->
nCap
,
0xff
,
(
nCapMin
-
p
->
nCap
)
*
sizeof
(
int
)
);
memset
(
p
->
pOrder
+
p
->
nCap
,
0xff
,
(
nCapMin
-
p
->
nCap
)
*
sizeof
(
int
)
);
p
->
nCap
=
nCapMin
;
}
static
inline
void
Vec_QueClear
(
Vec_Que_t
*
p
)
{
int
i
;
assert
(
p
->
pHeap
[
0
]
==
-
1
);
for
(
i
=
1
;
i
<
p
->
nSize
;
i
++
)
{
assert
(
p
->
pHeap
[
i
]
>=
0
&&
p
->
pOrder
[
p
->
pHeap
[
i
]]
==
i
);
p
->
pOrder
[
p
->
pHeap
[
i
]]
=
-
1
;
p
->
pHeap
[
i
]
=
-
1
;
}
p
->
nSize
=
1
;
}
/**Function*************************************************************
Synopsis []
Description []
SideEffects []
SeeAlso []
***********************************************************************/
static
inline
int
Vec_QueSize
(
Vec_Que_t
*
p
)
{
assert
(
p
->
nSize
>
0
);
return
p
->
nSize
-
1
;
}
static
inline
int
Vec_QueTop
(
Vec_Que_t
*
p
)
{
return
Vec_QueSize
(
p
)
>
0
?
p
->
pHeap
[
1
]
:
-
1
;
}
/**Function*************************************************************
Synopsis []
Description []
SideEffects []
SeeAlso []
***********************************************************************/
static
inline
int
Vec_QueMoveUp
(
Vec_Que_t
*
p
,
int
v
)
{
float
Cost
=
Vec_QueCost
(
p
,
v
);
int
i
=
p
->
pOrder
[
v
];
int
parent
=
i
>>
1
;
int
fMoved
=
0
;
assert
(
p
->
pOrder
[
v
]
!=
-
1
);
assert
(
p
->
pHeap
[
i
]
==
v
);
while
(
i
>
1
&&
Cost
>
Vec_QueCost
(
p
,
p
->
pHeap
[
parent
])
)
{
p
->
pHeap
[
i
]
=
p
->
pHeap
[
parent
];
p
->
pOrder
[
p
->
pHeap
[
i
]]
=
i
;
i
=
parent
;
parent
=
i
>>
1
;
fMoved
=
1
;
}
p
->
pHeap
[
i
]
=
v
;
p
->
pOrder
[
v
]
=
i
;
return
fMoved
;
}
static
inline
void
Vec_QueMoveDown
(
Vec_Que_t
*
p
,
int
v
)
{
float
Cost
=
Vec_QueCost
(
p
,
v
);
int
i
=
p
->
pOrder
[
v
];
int
child
=
i
<<
1
;
while
(
child
<
p
->
nSize
)
{
if
(
child
+
1
<
p
->
nSize
&&
Vec_QueCost
(
p
,
p
->
pHeap
[
child
])
<
Vec_QueCost
(
p
,
p
->
pHeap
[
child
+
1
])
)
child
++
;
assert
(
child
<
p
->
nSize
);
if
(
Cost
>=
Vec_QueCost
(
p
,
p
->
pHeap
[
child
]))
break
;
p
->
pHeap
[
i
]
=
p
->
pHeap
[
child
];
p
->
pOrder
[
p
->
pHeap
[
i
]]
=
i
;
i
=
child
;
child
=
child
<<
1
;
}
p
->
pHeap
[
i
]
=
v
;
p
->
pOrder
[
v
]
=
i
;
}
static
inline
void
Vec_QueUpdate
(
Vec_Que_t
*
p
,
int
v
)
{
if
(
!
Vec_QueMoveUp
(
p
,
v
)
)
Vec_QueMoveDown
(
p
,
v
);
}
/**Function*************************************************************
Synopsis []
Description []
SideEffects []
SeeAlso []
***********************************************************************/
static
inline
void
Vec_QuePush
(
Vec_Que_t
*
p
,
int
v
)
{
if
(
p
->
nSize
==
p
->
nCap
)
Vec_QueGrow
(
p
,
2
*
p
->
nCap
);
assert
(
p
->
nSize
<
p
->
nCap
);
assert
(
p
->
pOrder
[
v
]
==
-
1
);
assert
(
p
->
pHeap
[
p
->
nSize
]
==
-
1
);
p
->
pOrder
[
v
]
=
p
->
nSize
;
p
->
pHeap
[
p
->
nSize
++
]
=
v
;
Vec_QueMoveUp
(
p
,
v
);
}
static
inline
int
Vec_QuePop
(
Vec_Que_t
*
p
)
{
int
v
,
Res
;
assert
(
p
->
nSize
>
1
);
Res
=
p
->
pHeap
[
1
];
p
->
pOrder
[
Res
]
=
-
1
;
if
(
--
p
->
nSize
==
1
)
return
Res
;
v
=
p
->
pHeap
[
p
->
nSize
];
p
->
pHeap
[
p
->
nSize
]
=
-
1
;
p
->
pHeap
[
1
]
=
v
;
p
->
pOrder
[
v
]
=
1
;
Vec_QueMoveDown
(
p
,
v
);
return
Res
;
}
/**Function*************************************************************
Synopsis []
Description []
SideEffects []
SeeAlso []
***********************************************************************/
static
inline
void
Vec_QuePrint
(
Vec_Que_t
*
p
)
{
int
i
,
k
,
m
;
for
(
i
=
k
=
1
;
i
<
p
->
nSize
;
i
+=
k
,
k
*=
2
)
{
for
(
m
=
0
;
m
<
k
;
m
++
)
if
(
i
+
m
<
p
->
nSize
)
printf
(
"%-5d"
,
p
->
pHeap
[
i
+
m
]
);
printf
(
"
\n
"
);
for
(
m
=
0
;
m
<
k
;
m
++
)
if
(
i
+
m
<
p
->
nSize
)
printf
(
"%-5.0f"
,
Vec_QueCost
(
p
,
p
->
pHeap
[
i
+
m
])
);
printf
(
"
\n
"
);
printf
(
"
\n
"
);
}
}
/**Function*************************************************************
Synopsis []
Description []
SideEffects []
SeeAlso []
***********************************************************************/
static
inline
void
Vec_QueCheck
(
Vec_Que_t
*
p
)
{
int
i
,
child
;
assert
(
p
->
nSize
>
0
);
assert
(
p
->
nSize
<=
p
->
nCap
);
// check mapping
for
(
i
=
0
;
i
<
p
->
nSize
-
1
;
i
++
)
assert
(
p
->
pOrder
[
i
]
>
0
);
for
(
;
i
<
p
->
nCap
;
i
++
)
assert
(
p
->
pOrder
[
i
]
==
-
1
);
// check heap
assert
(
p
->
pHeap
[
0
]
==
-
1
);
for
(
i
=
0
;
i
<
p
->
nSize
-
1
;
i
++
)
assert
(
p
->
pHeap
[
p
->
pOrder
[
i
]]
==
i
);
for
(
i
++
;
i
<
p
->
nCap
;
i
++
)
assert
(
p
->
pHeap
[
i
]
==
-
1
);
// check heap property
for
(
i
=
1
;
i
<
p
->
nSize
;
i
++
)
{
child
=
i
<<
1
;
if
(
child
<
p
->
nSize
)
assert
(
Vec_QueCost
(
p
,
p
->
pHeap
[
i
])
>=
Vec_QueCost
(
p
,
p
->
pHeap
[
child
])
);
child
++
;
if
(
child
<
p
->
nSize
)
assert
(
Vec_QueCost
(
p
,
p
->
pHeap
[
i
])
>=
Vec_QueCost
(
p
,
p
->
pHeap
[
child
])
);
}
}
/**Function*************************************************************
Synopsis []
Description []
SideEffects []
SeeAlso []
***********************************************************************/
static
inline
void
Vec_QueTest
(
Vec_Flt_t
*
vCosts
)
{
Vec_Int_t
*
vTop
;
Vec_Que_t
*
p
;
int
i
,
Entry
;
// start the queue
p
=
Vec_QueAlloc
(
Vec_FltSize
(
vCosts
)
);
Vec_QueSetCosts
(
p
,
Vec_FltArray
(
vCosts
)
);
for
(
i
=
0
;
i
<
Vec_FltSize
(
vCosts
);
i
++
)
Vec_QuePush
(
p
,
i
);
// Vec_QuePrint( p );
Vec_QueCheck
(
p
);
// find the topmost 10%
vTop
=
Vec_IntAlloc
(
Vec_FltSize
(
vCosts
)
/
10
);
while
(
Vec_IntSize
(
vTop
)
<
Vec_FltSize
(
vCosts
)
/
10
)
Vec_IntPush
(
vTop
,
Vec_QuePop
(
p
)
);
// Vec_IntPrint( vTop );
// Vec_QueCheck( p ); // queque is not ready at this point!!!
// put them back
Vec_IntForEachEntry
(
vTop
,
Entry
,
i
)
Vec_QuePush
(
p
,
Entry
);
Vec_IntFree
(
vTop
);
Vec_QueCheck
(
p
);
Vec_QueFree
(
p
);
}
/*
{
extern void Vec_QueTest( Vec_Flt_t * p );
Vec_QueTest( p->vTimesOut );
}
*/
////////////////////////////////////////////////////////////////////////
/// END OF FILE ///
////////////////////////////////////////////////////////////////////////
ABC_NAMESPACE_HEADER_END
#endif
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