| /**CFile**************************************************************** |
| |
| FileName [intMan.c] |
| |
| SystemName [ABC: Logic synthesis and verification system.] |
| |
| PackageName [Interpolation engine.] |
| |
| Synopsis [Interpolation manager procedures.] |
| |
| Author [Alan Mishchenko] |
| |
| Affiliation [UC Berkeley] |
| |
| Date [Ver. 1.0. Started - June 24, 2008.] |
| |
| Revision [$Id: intMan.c,v 1.00 2005/06/20 00:00:00 alanmi Exp $] |
| |
| ***********************************************************************/ |
| |
| #include "intInt.h" |
| #include "aig/ioa/ioa.h" |
| |
| ABC_NAMESPACE_IMPL_START |
| |
| |
| //////////////////////////////////////////////////////////////////////// |
| /// DECLARATIONS /// |
| //////////////////////////////////////////////////////////////////////// |
| |
| //////////////////////////////////////////////////////////////////////// |
| /// FUNCTION DEFINITIONS /// |
| //////////////////////////////////////////////////////////////////////// |
| |
| /**Function************************************************************* |
| |
| Synopsis [Creates the interpolation manager.] |
| |
| Description [] |
| |
| SideEffects [] |
| |
| SeeAlso [] |
| |
| ***********************************************************************/ |
| Inter_Man_t * Inter_ManCreate( Aig_Man_t * pAig, Inter_ManParams_t * pPars ) |
| { |
| Inter_Man_t * p; |
| // create interpolation manager |
| p = ABC_ALLOC( Inter_Man_t, 1 ); |
| memset( p, 0, sizeof(Inter_Man_t) ); |
| p->vVarsAB = Vec_IntAlloc( Aig_ManRegNum(pAig) ); |
| p->nConfLimit = pPars->nBTLimit; |
| p->fVerbose = pPars->fVerbose; |
| p->pFileName = pPars->pFileName; |
| p->pAig = pAig; |
| if ( pPars->fDropInvar ) |
| p->vInters = Vec_PtrAlloc( 100 ); |
| return p; |
| } |
| |
| /**Function************************************************************* |
| |
| Synopsis [Cleans the interpolation manager.] |
| |
| Description [] |
| |
| SideEffects [] |
| |
| SeeAlso [] |
| |
| ***********************************************************************/ |
| void Inter_ManClean( Inter_Man_t * p ) |
| { |
| if ( p->vInters ) |
| { |
| Aig_Man_t * pMan; |
| int i; |
| Vec_PtrForEachEntry( Aig_Man_t *, p->vInters, pMan, i ) |
| Aig_ManStop( pMan ); |
| Vec_PtrClear( p->vInters ); |
| } |
| if ( p->pCnfInter ) |
| Cnf_DataFree( p->pCnfInter ); |
| if ( p->pCnfFrames ) |
| Cnf_DataFree( p->pCnfFrames ); |
| if ( p->pInter ) |
| Aig_ManStop( p->pInter ); |
| if ( p->pFrames ) |
| Aig_ManStop( p->pFrames ); |
| } |
| |
| /**Function************************************************************* |
| |
| Synopsis [Writes interpolant into a file.] |
| |
| Description [] |
| |
| SideEffects [] |
| |
| SeeAlso [] |
| |
| ***********************************************************************/ |
| void Inter_ManInterDump( Inter_Man_t * p, int fProved ) |
| { |
| char * pFileName = p->pFileName ? p->pFileName : (char *)"invar.aig"; |
| Aig_Man_t * pMan; |
| pMan = Aig_ManDupArray( p->vInters ); |
| Ioa_WriteAiger( pMan, pFileName, 0, 0 ); |
| Aig_ManStop( pMan ); |
| if ( fProved ) |
| printf( "Inductive invariant is dumped into file \"%s\".\n", pFileName ); |
| else |
| printf( "Interpolants are dumped into file \"%s\".\n", pFileName ); |
| } |
| |
| /**Function************************************************************* |
| |
| Synopsis [Frees the interpolation manager.] |
| |
| Description [] |
| |
| SideEffects [] |
| |
| SeeAlso [] |
| |
| ***********************************************************************/ |
| void Inter_ManStop( Inter_Man_t * p, int fProved ) |
| { |
| if ( p->fVerbose ) |
| { |
| p->timeOther = p->timeTotal-p->timeRwr-p->timeCnf-p->timeSat-p->timeInt-p->timeEqu; |
| printf( "Runtime statistics:\n" ); |
| ABC_PRTP( "Rewriting ", p->timeRwr, p->timeTotal ); |
| ABC_PRTP( "CNF mapping", p->timeCnf, p->timeTotal ); |
| ABC_PRTP( "SAT solving", p->timeSat, p->timeTotal ); |
| ABC_PRTP( "Interpol ", p->timeInt, p->timeTotal ); |
| ABC_PRTP( "Containment", p->timeEqu, p->timeTotal ); |
| ABC_PRTP( "Other ", p->timeOther, p->timeTotal ); |
| ABC_PRTP( "TOTAL ", p->timeTotal, p->timeTotal ); |
| } |
| |
| if ( p->vInters ) |
| Inter_ManInterDump( p, fProved ); |
| |
| if ( p->pCnfAig ) |
| Cnf_DataFree( p->pCnfAig ); |
| if ( p->pAigTrans ) |
| Aig_ManStop( p->pAigTrans ); |
| if ( p->pInterNew ) |
| Aig_ManStop( p->pInterNew ); |
| Inter_ManClean( p ); |
| Vec_PtrFreeP( &p->vInters ); |
| Vec_IntFreeP( &p->vVarsAB ); |
| ABC_FREE( p ); |
| } |
| |
| |
| //////////////////////////////////////////////////////////////////////// |
| /// END OF FILE /// |
| //////////////////////////////////////////////////////////////////////// |
| |
| |
| ABC_NAMESPACE_IMPL_END |
| |