summaryrefslogtreecommitdiffstats
path: root/src/base
diff options
context:
space:
mode:
authorAlan Mishchenko <alanmi@berkeley.edu>2015-03-31 11:34:24 +0700
committerAlan Mishchenko <alanmi@berkeley.edu>2015-03-31 11:34:24 +0700
commitd00cbdb52ff656823b1b32f3123823bd04a5ab85 (patch)
treeda89d2f0a8d04f12a4e6d6cae486559dbc68e98f /src/base
parentac3817caa7dfc8a3e41d563184d4db308ded656c (diff)
downloadabc-d00cbdb52ff656823b1b32f3123823bd04a5ab85.tar.gz
abc-d00cbdb52ff656823b1b32f3123823bd04a5ab85.tar.bz2
abc-d00cbdb52ff656823b1b32f3123823bd04a5ab85.zip
Changed in comparing user timing.
Diffstat (limited to 'src/base')
-rw-r--r--src/base/abci/abcTiming.c24
1 files changed, 16 insertions, 8 deletions
diff --git a/src/base/abci/abcTiming.c b/src/base/abci/abcTiming.c
index a40f625e..7b13a83c 100644
--- a/src/base/abci/abcTiming.c
+++ b/src/base/abci/abcTiming.c
@@ -18,6 +18,8 @@
***********************************************************************/
+#include <math.h>
+
#include "base/abc/abc.h"
#include "base/main/main.h"
#include "map/mio/mio.h"
@@ -41,6 +43,10 @@ struct Abc_ManTime_t_
Abc_Time_t * tOutLoad;
};
+#define TOLERANCE 0.001
+
+static inline int Abc_FloatEqual( float x, float y ) { return fabs(x-y) < TOLERANCE; }
+
// static functions
static Abc_ManTime_t * Abc_ManTimeStart( Abc_Ntk_t * pNtk );
static void Abc_ManTimeExpand( Abc_ManTime_t * p, int nSize, int fProgressive );
@@ -341,7 +347,7 @@ void Abc_NtkTimeInitialize( Abc_Ntk_t * pNtk, Abc_Ntk_t * pNtkOld )
Abc_NtkForEachCi( pNtk, pObj, i )
{
pTime = ppTimes[pObj->Id];
- if ( Abc_MaxFloat(pTime->Fall, pTime->Rise) != -ABC_INFINITY )
+ if ( !Abc_FloatEqual( Abc_MaxFloat(pTime->Fall, pTime->Rise), 0 ) )
continue;
*pTime = pNtkOld ? *Abc_NodeReadArrival(Abc_NtkCi(pNtkOld, i)) : pNtk->pManTime->tArrDef;
}
@@ -350,7 +356,7 @@ void Abc_NtkTimeInitialize( Abc_Ntk_t * pNtk, Abc_Ntk_t * pNtkOld )
Abc_NtkForEachCo( pNtk, pObj, i )
{
pTime = ppTimes[pObj->Id];
- if ( Abc_MaxFloat(pTime->Fall, pTime->Rise) != ABC_INFINITY )
+ if ( !Abc_FloatEqual( Abc_MaxFloat(pTime->Fall, pTime->Rise), ABC_INFINITY ) )
continue;
*pTime = pNtkOld ? *Abc_NodeReadRequired(Abc_NtkCo(pNtkOld, i)) : pNtk->pManTime->tReqDef;
}
@@ -385,16 +391,18 @@ void Abc_NtkTimeScale( Abc_Ntk_t * pNtk, float Scale )
pNtk->pManTime->tArrDef.Fall *= Scale;
pNtk->pManTime->tArrDef.Rise *= Scale;
// departure
- if ( pNtk->pManTime->tReqDef.Fall != ABC_INFINITY )
- pNtk->pManTime->tReqDef.Fall *= Scale;
- if ( pNtk->pManTime->tReqDef.Rise != ABC_INFINITY )
- pNtk->pManTime->tReqDef.Rise *= Scale;
+ pTime = &pNtk->pManTime->tReqDef;
+ if ( !Abc_FloatEqual( Abc_MaxFloat(pTime->Fall, pTime->Rise), ABC_INFINITY ) )
+ {
+ pTime->Fall *= Scale;
+ pTime->Rise *= Scale;
+ }
// set the default timing
ppTimes = (Abc_Time_t **)pNtk->pManTime->vArrs->pArray;
Abc_NtkForEachCi( pNtk, pObj, i )
{
pTime = ppTimes[pObj->Id];
- if ( Abc_MaxFloat(pTime->Fall, pTime->Rise) != -ABC_INFINITY )
+ if ( !Abc_FloatEqual( Abc_MaxFloat(pTime->Fall, pTime->Rise), 0 ) )
continue;
pTime->Fall *= Scale;
pTime->Rise *= Scale;
@@ -404,7 +412,7 @@ void Abc_NtkTimeScale( Abc_Ntk_t * pNtk, float Scale )
Abc_NtkForEachCo( pNtk, pObj, i )
{
pTime = ppTimes[pObj->Id];
- if ( Abc_MaxFloat(pTime->Fall, pTime->Rise) != ABC_INFINITY )
+ if ( !Abc_FloatEqual( Abc_MaxFloat(pTime->Fall, pTime->Rise), ABC_INFINITY ) )
continue;
pTime->Fall *= Scale;
pTime->Rise *= Scale;