ABC: A System for Sequential Synthesis and Verification
 
Loading...
Searching...
No Matches
absOldSim.c File Reference
#include "abs.h"
Include dependency graph for absOldSim.c:

Go to the source code of this file.

Macros

#define SAIG_ZER   1
 DECLARATIONS ///.
 
#define SAIG_ONE   2
 
#define SAIG_UND   3
 
#define SAIG_ZER_NEW   0
 
#define SAIG_ONE_NEW   1
 
#define SAIG_ZER_OLD   2
 
#define SAIG_ONE_OLD   3
 

Functions

int Saig_ManExtendOneEval (Vec_Ptr_t *vSimInfo, Aig_Obj_t *pObj, int iFrame)
 FUNCTION DEFINITIONS ///.
 
int Saig_ManSimDataInit (Aig_Man_t *p, Abc_Cex_t *pCex, Vec_Ptr_t *vSimInfo, Vec_Int_t *vRes)
 
int Saig_ManExtendOneEval2 (Vec_Ptr_t *vSimInfo, Aig_Obj_t *pObj, int iFrame)
 
int Saig_ManSimDataInit2 (Aig_Man_t *p, Abc_Cex_t *pCex, Vec_Ptr_t *vSimInfo)
 
void Saig_ManSetAndDriveImplications_rec (Aig_Man_t *p, Aig_Obj_t *pObj, int f, int fMax, Vec_Ptr_t *vSimInfo)
 
void Saig_ManExplorePaths_rec (Aig_Man_t *p, Aig_Obj_t *pObj, int f, int fMax, Vec_Ptr_t *vSimInfo)
 
Vec_Int_tSaig_ManProcessCex (Aig_Man_t *p, int iFirstFlopPi, Abc_Cex_t *pCex, Vec_Ptr_t *vSimInfo, int fVerbose)
 
Vec_Int_tSaig_ManExtendCounterExampleTest2 (Aig_Man_t *p, int iFirstFlopPi, Abc_Cex_t *pCex, int fVerbose)
 

Macro Definition Documentation

◆ SAIG_ONE

#define SAIG_ONE   2

Definition at line 31 of file absOldSim.c.

◆ SAIG_ONE_NEW

#define SAIG_ONE_NEW   1

Definition at line 69 of file absOldSim.c.

◆ SAIG_ONE_OLD

#define SAIG_ONE_OLD   3

Definition at line 71 of file absOldSim.c.

◆ SAIG_UND

#define SAIG_UND   3

Definition at line 32 of file absOldSim.c.

◆ SAIG_ZER

#define SAIG_ZER   1

DECLARATIONS ///.

CFile****************************************************************

FileName [saigSimExt2.c]

SystemName [ABC: Logic synthesis and verification system.]

PackageName [Sequential AIG package.]

Synopsis [Extending simulation trace to contain ternary values.]

Author [Alan Mishchenko]

Affiliation [UC Berkeley]

Date [Ver. 1.0. Started - June 20, 2005.]

Revision [

Id
saigSimExt2.c,v 1.00 2005/06/20 00:00:00 alanmi Exp

]

Definition at line 30 of file absOldSim.c.

◆ SAIG_ZER_NEW

#define SAIG_ZER_NEW   0

Definition at line 68 of file absOldSim.c.

◆ SAIG_ZER_OLD

#define SAIG_ZER_OLD   2

Definition at line 70 of file absOldSim.c.

Function Documentation

◆ Saig_ManExplorePaths_rec()

void Saig_ManExplorePaths_rec ( Aig_Man_t * p,
Aig_Obj_t * pObj,
int f,
int fMax,
Vec_Ptr_t * vSimInfo )

Function*************************************************************

Synopsis [Performs recursive sensetization analysis.]

Description []

SideEffects []

SeeAlso []

Definition at line 333 of file absOldSim.c.

334{
335 int Value = Saig_ManSimInfo2Get( vSimInfo, pObj, f );
336 if ( Saig_ManSimInfo2IsOld( Value ) )
337 return;
338 Saig_ManSetAndDriveImplications_rec( p, pObj, f, fMax, vSimInfo );
339 assert( !Aig_ObjIsConst1(pObj) );
340 if ( Saig_ObjIsLo(p, pObj) && f == 0 )
341 return;
342 if ( Saig_ObjIsPi(p, pObj) )
343 {
344 // propagate implications of this assignment
345 int i, iPiNum = Aig_ObjCioId(pObj);
346 for ( i = fMax; i >= 0; i-- )
347 if ( i != f )
348 Saig_ManSetAndDriveImplications_rec( p, Aig_ManCi(p, iPiNum), i, fMax, vSimInfo );
349 return;
350 }
351 if ( Saig_ObjIsLo( p, pObj ) )
352 {
353 assert( f > 0 );
354 Saig_ManExplorePaths_rec( p, Saig_ObjLoToLi(p, pObj), f-1, fMax, vSimInfo );
355 return;
356 }
357 if ( Aig_ObjIsCo(pObj) )
358 {
359 Saig_ManExplorePaths_rec( p, Aig_ObjFanin0(pObj), f, fMax, vSimInfo );
360 return;
361 }
362 assert( Aig_ObjIsNode(pObj) );
363 if ( Value == SAIG_ZER_OLD )
364 {
365// if ( (Aig_ObjId(pObj) & 1) == 0 )
366 Saig_ManExplorePaths_rec( p, Aig_ObjFanin0(pObj), f, fMax, vSimInfo );
367// else
368// Saig_ManExplorePaths_rec( p, Aig_ObjFanin1(pObj), f, fMax, vSimInfo );
369 }
370 else
371 {
372 Saig_ManExplorePaths_rec( p, Aig_ObjFanin0(pObj), f, fMax, vSimInfo );
373 Saig_ManExplorePaths_rec( p, Aig_ObjFanin1(pObj), f, fMax, vSimInfo );
374 }
375}
void Saig_ManSetAndDriveImplications_rec(Aig_Man_t *p, Aig_Obj_t *pObj, int f, int fMax, Vec_Ptr_t *vSimInfo)
Definition absOldSim.c:280
void Saig_ManExplorePaths_rec(Aig_Man_t *p, Aig_Obj_t *pObj, int f, int fMax, Vec_Ptr_t *vSimInfo)
Definition absOldSim.c:333
#define SAIG_ZER_OLD
Definition absOldSim.c:70
Cube * p
Definition exorList.c:222
#define assert(ex)
Definition util_old.h:213
Here is the call graph for this function:
Here is the caller graph for this function:

◆ Saig_ManExtendCounterExampleTest2()

Vec_Int_t * Saig_ManExtendCounterExampleTest2 ( Aig_Man_t * p,
int iFirstFlopPi,
Abc_Cex_t * pCex,
int fVerbose )

Function*************************************************************

Synopsis [Returns the array of PIs for flops that should not be absracted.]

Description []

SideEffects []

SeeAlso []

Definition at line 443 of file absOldSim.c.

444{
445 Vec_Int_t * vRes;
446 Vec_Ptr_t * vSimInfo;
447 abctime clk;
448 if ( Saig_ManPiNum(p) != pCex->nPis )
449 {
450 printf( "Saig_ManExtendCounterExampleTest2(): The PI count of AIG (%d) does not match that of cex (%d).\n",
451 Aig_ManCiNum(p), pCex->nPis );
452 return NULL;
453 }
455 vSimInfo = Vec_PtrAllocSimInfo( Aig_ManObjNumMax(p), Abc_BitWordNum(2*(pCex->iFrame+1)) );
456 Vec_PtrCleanSimInfo( vSimInfo, 0, Abc_BitWordNum(2*(pCex->iFrame+1)) );
457
458clk = Abc_Clock();
459 vRes = Saig_ManProcessCex( p, iFirstFlopPi, pCex, vSimInfo, fVerbose );
460 if ( fVerbose )
461 {
462 printf( "Total new PIs = %3d. Non-removable PIs = %3d. ", Saig_ManPiNum(p)-iFirstFlopPi, Vec_IntSize(vRes) );
463ABC_PRT( "Time", Abc_Clock() - clk );
464 }
465 Vec_PtrFree( vSimInfo );
467 return vRes;
468}
ABC_INT64_T abctime
Definition abc_global.h:332
#define ABC_PRT(a, t)
Definition abc_global.h:255
Vec_Int_t * Saig_ManProcessCex(Aig_Man_t *p, int iFirstFlopPi, Abc_Cex_t *pCex, Vec_Ptr_t *vSimInfo, int fVerbose)
Definition absOldSim.c:388
void Aig_ManFanoutStart(Aig_Man_t *p)
FUNCTION DEFINITIONS ///.
Definition aigFanout.c:56
void Aig_ManFanoutStop(Aig_Man_t *p)
Definition aigFanout.c:89
typedefABC_NAMESPACE_IMPL_START struct Vec_Int_t_ Vec_Int_t
DECLARATIONS ///.
Definition bblif.c:37
typedefABC_NAMESPACE_HEADER_START struct Vec_Ptr_t_ Vec_Ptr_t
INCLUDES ///.
Definition vecPtr.h:42
Here is the call graph for this function:
Here is the caller graph for this function:

◆ Saig_ManExtendOneEval()

int Saig_ManExtendOneEval ( Vec_Ptr_t * vSimInfo,
Aig_Obj_t * pObj,
int iFrame )

FUNCTION DEFINITIONS ///.

Function*************************************************************

Synopsis [Performs ternary simulation for one node.]

Description []

SideEffects []

SeeAlso []

Definition at line 143 of file absOldSim.c.

144{
145 int Value0, Value1, Value;
146 Value0 = Saig_ManSimInfoGet( vSimInfo, Aig_ObjFanin0(pObj), iFrame );
147 if ( Aig_ObjFaninC0(pObj) )
148 Value0 = Saig_ManSimInfoNot( Value0 );
149 if ( Aig_ObjIsCo(pObj) )
150 {
151 Saig_ManSimInfoSet( vSimInfo, pObj, iFrame, Value0 );
152 return Value0;
153 }
154 assert( Aig_ObjIsNode(pObj) );
155 Value1 = Saig_ManSimInfoGet( vSimInfo, Aig_ObjFanin1(pObj), iFrame );
156 if ( Aig_ObjFaninC1(pObj) )
157 Value1 = Saig_ManSimInfoNot( Value1 );
158 Value = Saig_ManSimInfoAnd( Value0, Value1 );
159 Saig_ManSimInfoSet( vSimInfo, pObj, iFrame, Value );
160 return Value;
161}
Here is the caller graph for this function:

◆ Saig_ManExtendOneEval2()

int Saig_ManExtendOneEval2 ( Vec_Ptr_t * vSimInfo,
Aig_Obj_t * pObj,
int iFrame )

Function*************************************************************

Synopsis [Performs ternary simulation for one node.]

Description []

SideEffects []

SeeAlso []

Definition at line 213 of file absOldSim.c.

214{
215 int Value0, Value1, Value;
216 Value0 = Saig_ManSimInfo2Get( vSimInfo, Aig_ObjFanin0(pObj), iFrame );
217 if ( Aig_ObjFaninC0(pObj) )
218 Value0 = Saig_ManSimInfo2Not( Value0 );
219 if ( Aig_ObjIsCo(pObj) )
220 {
221 Saig_ManSimInfo2Set( vSimInfo, pObj, iFrame, Value0 );
222 return Value0;
223 }
224 assert( Aig_ObjIsNode(pObj) );
225 Value1 = Saig_ManSimInfo2Get( vSimInfo, Aig_ObjFanin1(pObj), iFrame );
226 if ( Aig_ObjFaninC1(pObj) )
227 Value1 = Saig_ManSimInfo2Not( Value1 );
228 Value = Saig_ManSimInfo2And( Value0, Value1 );
229 Saig_ManSimInfo2Set( vSimInfo, pObj, iFrame, Value );
230 return Value;
231}
Here is the caller graph for this function:

◆ Saig_ManProcessCex()

Vec_Int_t * Saig_ManProcessCex ( Aig_Man_t * p,
int iFirstFlopPi,
Abc_Cex_t * pCex,
Vec_Ptr_t * vSimInfo,
int fVerbose )

Function*************************************************************

Synopsis [Returns the array of PIs for flops that should not be absracted.]

Description []

SideEffects []

SeeAlso []

Definition at line 388 of file absOldSim.c.

389{
390 Aig_Obj_t * pObj;
391 Vec_Int_t * vRes, * vResInv;
392 int i, f, Value;
393// assert( Aig_ManRegNum(p) > 0 );
394 assert( (unsigned *)Vec_PtrEntry(vSimInfo,1) - (unsigned *)Vec_PtrEntry(vSimInfo,0) >= Abc_BitWordNum(2*(pCex->iFrame+1)) );
395 // start simulation data
396 Value = Saig_ManSimDataInit2( p, pCex, vSimInfo );
397 assert( Value == SAIG_ONE_NEW );
398 // derive implications of constants and primary inputs
399 Saig_ManForEachLo( p, pObj, i )
400 Saig_ManSetAndDriveImplications_rec( p, pObj, 0, pCex->iFrame, vSimInfo );
401 for ( f = pCex->iFrame; f >= 0; f-- )
402 {
403 Saig_ManSetAndDriveImplications_rec( p, Aig_ManConst1(p), f, pCex->iFrame, vSimInfo );
404 for ( i = 0; i < iFirstFlopPi; i++ )
405 Saig_ManSetAndDriveImplications_rec( p, Aig_ManCi(p, i), f, pCex->iFrame, vSimInfo );
406 }
407 // recursively compute justification
408 Saig_ManExplorePaths_rec( p, Aig_ManCo(p, pCex->iPo), pCex->iFrame, pCex->iFrame, vSimInfo );
409 // select the result
410 vRes = Vec_IntAlloc( 1000 );
411 vResInv = Vec_IntAlloc( 1000 );
412 for ( i = iFirstFlopPi; i < Saig_ManPiNum(p); i++ )
413 {
414 for ( f = pCex->iFrame; f >= 0; f-- )
415 {
416 Value = Saig_ManSimInfo2Get( vSimInfo, Aig_ManCi(p, i), f );
417 if ( Saig_ManSimInfo2IsOld( Value ) )
418 break;
419 }
420 if ( f >= 0 )
421 Vec_IntPush( vRes, i );
422 else
423 Vec_IntPush( vResInv, i );
424 }
425 // resimulate to make sure it is valid
426 Value = Saig_ManSimDataInit( p, pCex, vSimInfo, vResInv );
427 assert( Value == SAIG_ONE );
428 Vec_IntFree( vResInv );
429 return vRes;
430}
int Saig_ManSimDataInit2(Aig_Man_t *p, Abc_Cex_t *pCex, Vec_Ptr_t *vSimInfo)
Definition absOldSim.c:244
#define SAIG_ONE
Definition absOldSim.c:31
#define SAIG_ONE_NEW
Definition absOldSim.c:69
int Saig_ManSimDataInit(Aig_Man_t *p, Abc_Cex_t *pCex, Vec_Ptr_t *vSimInfo, Vec_Int_t *vRes)
Definition absOldSim.c:174
struct Aig_Obj_t_ Aig_Obj_t
Definition aig.h:51
#define Saig_ManForEachLo(p, pObj, i)
Definition saig.h:96
Here is the call graph for this function:
Here is the caller graph for this function:

◆ Saig_ManSetAndDriveImplications_rec()

void Saig_ManSetAndDriveImplications_rec ( Aig_Man_t * p,
Aig_Obj_t * pObj,
int f,
int fMax,
Vec_Ptr_t * vSimInfo )

Function*************************************************************

Synopsis [Drive implications of the given node towards primary outputs.]

Description []

SideEffects []

SeeAlso []

Definition at line 280 of file absOldSim.c.

281{
282 Aig_Obj_t * pFanout;
283 int k, iFanout = -1, Value0, Value1;
284 int Value = Saig_ManSimInfo2Get( vSimInfo, pObj, f );
285 assert( !Saig_ManSimInfo2IsOld( Value ) );
286 Saig_ManSimInfo2Set( vSimInfo, pObj, f, Saig_ManSimInfo2SetOld(Value) );
287 if ( (Aig_ObjIsCo(pObj) && f == fMax) || Saig_ObjIsPo(p, pObj) )
288 return;
289 if ( Saig_ObjIsLi( p, pObj ) )
290 {
291 assert( f < fMax );
292 pFanout = Saig_ObjLiToLo(p, pObj);
293 Value = Saig_ManSimInfo2Get( vSimInfo, pFanout, f+1 );
294 if ( !Saig_ManSimInfo2IsOld( Value ) )
295 Saig_ManSetAndDriveImplications_rec( p, pFanout, f+1, fMax, vSimInfo );
296 return;
297 }
298 assert( Aig_ObjIsCi(pObj) || Aig_ObjIsNode(pObj) || Aig_ObjIsConst1(pObj) );
299 Aig_ObjForEachFanout( p, pObj, pFanout, iFanout, k )
300 {
301 Value = Saig_ManSimInfo2Get( vSimInfo, pFanout, f );
302 if ( Saig_ManSimInfo2IsOld( Value ) )
303 continue;
304 if ( Aig_ObjIsCo(pFanout) )
305 {
306 Saig_ManSetAndDriveImplications_rec( p, pFanout, f, fMax, vSimInfo );
307 continue;
308 }
309 assert( Aig_ObjIsNode(pFanout) );
310 Value0 = Saig_ManSimInfo2Get( vSimInfo, Aig_ObjFanin0(pFanout), f );
311 Value1 = Saig_ManSimInfo2Get( vSimInfo, Aig_ObjFanin1(pFanout), f );
312 if ( Aig_ObjFaninC0(pFanout) )
313 Value0 = Saig_ManSimInfo2Not( Value0 );
314 if ( Aig_ObjFaninC1(pFanout) )
315 Value1 = Saig_ManSimInfo2Not( Value1 );
316 if ( Value0 == SAIG_ZER_OLD || Value1 == SAIG_ZER_OLD ||
317 (Value0 == SAIG_ONE_OLD && Value1 == SAIG_ONE_OLD) )
318 Saig_ManSetAndDriveImplications_rec( p, pFanout, f, fMax, vSimInfo );
319 }
320}
#define SAIG_ONE_OLD
Definition absOldSim.c:71
#define Aig_ObjForEachFanout(p, pObj, pFanout, iFan, i)
Definition aig.h:427
Here is the call graph for this function:
Here is the caller graph for this function:

◆ Saig_ManSimDataInit()

int Saig_ManSimDataInit ( Aig_Man_t * p,
Abc_Cex_t * pCex,
Vec_Ptr_t * vSimInfo,
Vec_Int_t * vRes )

Function*************************************************************

Synopsis [Performs ternary simulation for one design.]

Description []

SideEffects []

SeeAlso []

Definition at line 174 of file absOldSim.c.

175{
176 Aig_Obj_t * pObj, * pObjLi, * pObjLo;
177 int i, f, Entry, iBit = 0;
178 Saig_ManForEachLo( p, pObj, i )
179 Saig_ManSimInfoSet( vSimInfo, pObj, 0, Abc_InfoHasBit(pCex->pData, iBit++)?SAIG_ONE:SAIG_ZER );
180 for ( f = 0; f <= pCex->iFrame; f++ )
181 {
182 Saig_ManSimInfoSet( vSimInfo, Aig_ManConst1(p), f, SAIG_ONE );
183 Saig_ManForEachPi( p, pObj, i )
184 Saig_ManSimInfoSet( vSimInfo, pObj, f, Abc_InfoHasBit(pCex->pData, iBit++)?SAIG_ONE:SAIG_ZER );
185 if ( vRes )
186 Vec_IntForEachEntry( vRes, Entry, i )
187 Saig_ManSimInfoSet( vSimInfo, Aig_ManCi(p, Entry), f, SAIG_UND );
188 Aig_ManForEachNode( p, pObj, i )
189 Saig_ManExtendOneEval( vSimInfo, pObj, f );
190 Aig_ManForEachCo( p, pObj, i )
191 Saig_ManExtendOneEval( vSimInfo, pObj, f );
192 if ( f == pCex->iFrame )
193 break;
194 Saig_ManForEachLiLo( p, pObjLi, pObjLo, i )
195 Saig_ManSimInfoSet( vSimInfo, pObjLo, f+1, Saig_ManSimInfoGet(vSimInfo, pObjLi, f) );
196 }
197 // make sure the output of the property failed
198 pObj = Aig_ManCo( p, pCex->iPo );
199 return Saig_ManSimInfoGet( vSimInfo, pObj, pCex->iFrame );
200}
int Saig_ManExtendOneEval(Vec_Ptr_t *vSimInfo, Aig_Obj_t *pObj, int iFrame)
FUNCTION DEFINITIONS ///.
Definition absOldSim.c:143
#define SAIG_ZER
DECLARATIONS ///.
Definition absOldSim.c:30
#define SAIG_UND
Definition absOldSim.c:32
#define Aig_ManForEachNode(p, pObj, i)
Definition aig.h:413
#define Aig_ManForEachCo(p, pObj, i)
Definition aig.h:398
#define Saig_ManForEachLiLo(p, pObjLi, pObjLo, i)
Definition saig.h:101
#define Saig_ManForEachPi(p, pObj, i)
Definition saig.h:91
#define Vec_IntForEachEntry(vVec, Entry, i)
MACRO DEFINITIONS ///.
Definition vecInt.h:54
Here is the call graph for this function:
Here is the caller graph for this function:

◆ Saig_ManSimDataInit2()

int Saig_ManSimDataInit2 ( Aig_Man_t * p,
Abc_Cex_t * pCex,
Vec_Ptr_t * vSimInfo )

Function*************************************************************

Synopsis [Performs sensitization analysis for one design.]

Description []

SideEffects []

SeeAlso []

Definition at line 244 of file absOldSim.c.

245{
246 Aig_Obj_t * pObj, * pObjLi, * pObjLo;
247 int i, f, iBit = 0;
248 Saig_ManForEachLo( p, pObj, i )
249 Saig_ManSimInfo2Set( vSimInfo, pObj, 0, Abc_InfoHasBit(pCex->pData, iBit++)?SAIG_ONE_NEW:SAIG_ZER_NEW );
250 for ( f = 0; f <= pCex->iFrame; f++ )
251 {
252 Saig_ManSimInfo2Set( vSimInfo, Aig_ManConst1(p), f, SAIG_ONE_NEW );
253 Saig_ManForEachPi( p, pObj, i )
254 Saig_ManSimInfo2Set( vSimInfo, pObj, f, Abc_InfoHasBit(pCex->pData, iBit++)?SAIG_ONE_NEW:SAIG_ZER_NEW );
255 Aig_ManForEachNode( p, pObj, i )
256 Saig_ManExtendOneEval2( vSimInfo, pObj, f );
257 Aig_ManForEachCo( p, pObj, i )
258 Saig_ManExtendOneEval2( vSimInfo, pObj, f );
259 if ( f == pCex->iFrame )
260 break;
261 Saig_ManForEachLiLo( p, pObjLi, pObjLo, i )
262 Saig_ManSimInfo2Set( vSimInfo, pObjLo, f+1, Saig_ManSimInfo2Get(vSimInfo, pObjLi, f) );
263 }
264 // make sure the output of the property failed
265 pObj = Aig_ManCo( p, pCex->iPo );
266 return Saig_ManSimInfo2Get( vSimInfo, pObj, pCex->iFrame );
267}
#define SAIG_ZER_NEW
Definition absOldSim.c:68
int Saig_ManExtendOneEval2(Vec_Ptr_t *vSimInfo, Aig_Obj_t *pObj, int iFrame)
Definition absOldSim.c:213
Here is the call graph for this function:
Here is the caller graph for this function: