Commit 8eb651c3 by Alan Mishchenko

Adding command to check resub problem solution.

parent ae0f03f4
...@@ -119,7 +119,7 @@ Res6_Man_t * Res6_ManRead( char * pFileName ) ...@@ -119,7 +119,7 @@ Res6_Man_t * Res6_ManRead( char * pFileName )
printf( "Cannot open input file \"%s\".\n", pFileName ); printf( "Cannot open input file \"%s\".\n", pFileName );
else else
{ {
int i, k, nIns, nNodes, nOuts, nPats, iLit = 0; int i, k, nIns, nNodes, nOuts, nPats;
char Temp[100], Buffer[100]; char Temp[100], Buffer[100];
char * pLine = fgets( Buffer, 100, pFile ); char * pLine = fgets( Buffer, 100, pFile );
if ( pLine == NULL ) if ( pLine == NULL )
...@@ -279,11 +279,57 @@ static inline void Res6_LitPrint( int iLit, int nDivs ) ...@@ -279,11 +279,57 @@ static inline void Res6_LitPrint( int iLit, int nDivs )
printf( "%d", Abc_Lit2Var(iLit) ); printf( "%d", Abc_Lit2Var(iLit) );
} }
} }
Vec_Int_t * Res6_FindSupport( Vec_Int_t * vSol, int nDivs )
{
int i, iLit;
Vec_Int_t * vSupp = Vec_IntAlloc( 10 );
Vec_IntForEachEntry( vSol, iLit, i )
if ( iLit >= 2 && iLit < 2*nDivs )
Vec_IntPushUnique( vSupp, Abc_Lit2Var(iLit) );
return vSupp;
}
void Res6_PrintSuppSims( Vec_Int_t * vSol, word ** ppLits, int nWords, int nDivs )
{
Vec_Int_t * vSupp = Res6_FindSupport( vSol, nDivs );
int i, k, iObj;
Vec_IntForEachEntry( vSupp, iObj, i )
{
for ( k = 0; k < 64*nWords; k++ )
if ( Abc_TtGetBit(ppLits[2*iObj+1], k) )
printf( "0" );
else if ( Abc_TtGetBit(ppLits[2*iObj], k) )
printf( "1" );
else
printf( "-" );
printf( "\n" );
}
for ( k = 0; k < 64*nWords; k++ )
{
Vec_IntForEachEntry( vSupp, iObj, i )
if ( Abc_TtGetBit(ppLits[2*iObj+1], k) )
printf( "0" );
else if ( Abc_TtGetBit(ppLits[2*iObj+0], k) )
printf( "1" );
else
printf( "-" );
printf( "\n" );
if ( k == 9 )
break;
}
Vec_IntFree( vSupp );
}
int Res6_FindSupportSize( Vec_Int_t * vSol, int nDivs )
{
Vec_Int_t * vSupp = Res6_FindSupport( vSol, nDivs );
int Res = Vec_IntSize(vSupp);
Vec_IntFree( vSupp );
return Res;
}
void Res6_PrintSolution( Vec_Int_t * vSol, int nDivs ) void Res6_PrintSolution( Vec_Int_t * vSol, int nDivs )
{ {
int iNode, nNodes = Vec_IntSize(vSol)/2-1; int iNode, nNodes = Vec_IntSize(vSol)/2-1;
assert( Vec_IntSize(vSol) % 2 == 0 ); assert( Vec_IntSize(vSol) % 2 == 0 );
printf( "Solution: In+Div = %d Node = %d Out = %d\n", nDivs-1, nNodes, 1 ); printf( "Solution: In = %d Div = %d Node = %d Out = %d\n", Res6_FindSupportSize(vSol, nDivs), nDivs-1, nNodes, 1 );
for ( iNode = 0; iNode <= nNodes; iNode++ ) for ( iNode = 0; iNode <= nNodes; iNode++ )
{ {
int * pLits = Vec_IntEntryP( vSol, 2*iNode ); int * pLits = Vec_IntEntryP( vSol, 2*iNode );
...@@ -386,6 +432,8 @@ void Res6_ManResubCheck( char * pFileNameRes, char * pFileNameSol, int fVerbose ...@@ -386,6 +432,8 @@ void Res6_ManResubCheck( char * pFileNameRes, char * pFileNameSol, int fVerbose
Res6_ManPrintProblem( p, 0 ); Res6_ManPrintProblem( p, 0 );
if ( fVerbose ) if ( fVerbose )
Res6_PrintSolution( vSol, p->nDivs ); Res6_PrintSolution( vSol, p->nDivs );
//if ( fVerbose )
// Res6_PrintSuppSims( vSol, p->ppLits, p->nWords, p->nDivs );
Res6_ManResubVerify( p, vSol ); Res6_ManResubVerify( p, vSol );
Vec_IntFree( vSol ); Vec_IntFree( vSol );
Res6_ManStop( p ); Res6_ManStop( p );
......
...@@ -46,6 +46,7 @@ struct Supp_Man_t_ ...@@ -46,6 +46,7 @@ struct Supp_Man_t_
Gia_Man_t * pGia; // used for object names Gia_Man_t * pGia; // used for object names
// computed data // computed data
Vec_Wrd_t * vDivs[2]; // simulation values Vec_Wrd_t * vDivs[2]; // simulation values
Vec_Wrd_t * vDivsC[2]; // simulation values
Vec_Wrd_t * vPats[2]; // simulation values Vec_Wrd_t * vPats[2]; // simulation values
Vec_Ptr_t * vMatrix; // simulation values Vec_Ptr_t * vMatrix; // simulation values
Vec_Wrd_t * vMask; // simulation values Vec_Wrd_t * vMask; // simulation values
...@@ -143,9 +144,10 @@ int Supp_DeriveLines( Supp_Man_t * p ) ...@@ -143,9 +144,10 @@ int Supp_DeriveLines( Supp_Man_t * p )
{ {
p->vDivs[n] = Vec_WrdStart( 64*nWords*nDivWords ); p->vDivs[n] = Vec_WrdStart( 64*nWords*nDivWords );
p->vPats[n] = Vec_WrdStart( 64*nWords*nDivWords ); p->vPats[n] = Vec_WrdStart( 64*nWords*nDivWords );
//p->vDivsC[n] = Vec_WrdStart( 64*nWords*nDivWords );
if ( p->vSimsC ) if ( p->vSimsC )
Vec_IntForEachEntry( p->vCands, iObj, i ) Vec_IntForEachEntry( p->vCands, iObj, i )
Abc_TtAndSharp( Vec_WrdEntryP(p->vDivs[n], i*nWords), Vec_WrdEntryP(p->vSimsC, iObj*nWords), Vec_WrdEntryP(p->vSims, iObj*nWords), nWords, !n ); Abc_TtAndSharp( Vec_WrdEntryP(p->vDivsC[n], i*nWords), Vec_WrdEntryP(p->vSimsC, iObj*nWords), Vec_WrdEntryP(p->vSims, iObj*nWords), nWords, !n );
else else
Vec_IntForEachEntry( p->vCands, iObj, i ) Vec_IntForEachEntry( p->vCands, iObj, i )
Abc_TtCopy( Vec_WrdEntryP(p->vDivs[n], i*nWords), Vec_WrdEntryP(p->vSims, iObj*nWords), nWords, !n ); Abc_TtCopy( Vec_WrdEntryP(p->vDivs[n], i*nWords), Vec_WrdEntryP(p->vSims, iObj*nWords), nWords, !n );
...@@ -195,6 +197,8 @@ void Supp_ManDelete( Supp_Man_t * p ) ...@@ -195,6 +197,8 @@ void Supp_ManDelete( Supp_Man_t * p )
Supp_ManCleanMatrix( p ); Supp_ManCleanMatrix( p );
Vec_WrdFreeP( &p->vDivs[0] ); Vec_WrdFreeP( &p->vDivs[0] );
Vec_WrdFreeP( &p->vDivs[1] ); Vec_WrdFreeP( &p->vDivs[1] );
Vec_WrdFreeP( &p->vDivsC[0] );
Vec_WrdFreeP( &p->vDivsC[1] );
Vec_WrdFreeP( &p->vPats[0] ); Vec_WrdFreeP( &p->vPats[0] );
Vec_WrdFreeP( &p->vPats[1] ); Vec_WrdFreeP( &p->vPats[1] );
Vec_PtrFreeP( &p->vMatrix ); Vec_PtrFreeP( &p->vMatrix );
...@@ -682,10 +686,27 @@ void Supp_DeriveDumpSims( FILE * pFile, Vec_Wrd_t * vDivs, int nWords ) ...@@ -682,10 +686,27 @@ void Supp_DeriveDumpSims( FILE * pFile, Vec_Wrd_t * vDivs, int nWords )
fprintf( pFile, "\n" ); fprintf( pFile, "\n" );
} }
} }
void Supp_DeriveDumpSimsC( FILE * pFile, Vec_Wrd_t * vDivs[2], int nWords )
{
int i, k, nDivs = Vec_WrdSize(vDivs[0])/nWords;
for ( i = 0; i < nDivs; i++ )
{
word * pSim0 = Vec_WrdEntryP(vDivs[0], i*nWords);
word * pSim1 = Vec_WrdEntryP(vDivs[1], i*nWords);
for ( k = 0; k < 64*nWords; k++ )
if ( Abc_TtGetBit(pSim0, k) )
fprintf( pFile, "0" );
else if ( Abc_TtGetBit(pSim1, k) )
fprintf( pFile, "1" );
else
fprintf( pFile, "-" );
fprintf( pFile, "\n" );
}
}
void Supp_DeriveDumpProb( Vec_Wrd_t * vIsfs, Vec_Wrd_t * vDivs, int nWords ) void Supp_DeriveDumpProb( Vec_Wrd_t * vIsfs, Vec_Wrd_t * vDivs, int nWords )
{ {
char Buffer[100]; int nDivs = Vec_WrdSize(vDivs)/nWords; char Buffer[100]; int nDivs = Vec_WrdSize(vDivs)/nWords;
int RetValue = sprintf( Buffer, "case01_%02d.resub", s_Counter ); int RetValue = sprintf( Buffer, "%02d.resub", s_Counter );
FILE * pFile = fopen( Buffer, "wb" ); FILE * pFile = fopen( Buffer, "wb" );
if ( pFile == NULL ) if ( pFile == NULL )
printf( "Cannot open output file.\n" ); printf( "Cannot open output file.\n" );
...@@ -696,10 +717,24 @@ void Supp_DeriveDumpProb( Vec_Wrd_t * vIsfs, Vec_Wrd_t * vDivs, int nWords ) ...@@ -696,10 +717,24 @@ void Supp_DeriveDumpProb( Vec_Wrd_t * vIsfs, Vec_Wrd_t * vDivs, int nWords )
fclose ( pFile ); fclose ( pFile );
RetValue = 0; RetValue = 0;
} }
void Supp_DeriveDumpProbC( Vec_Wrd_t * vIsfs, Vec_Wrd_t * vDivs[2], int nWords )
{
char Buffer[100]; int nDivs = Vec_WrdSize(vDivs[0])/nWords;
int RetValue = sprintf( Buffer, "%02d.resub", s_Counter );
FILE * pFile = fopen( Buffer, "wb" );
if ( pFile == NULL )
printf( "Cannot open output file.\n" );
fprintf( pFile, "resyn %d %d %d %d\n", 0, nDivs, 1, 64*nWords );
//fprintf( pFile, "%d %d %d %d\n", 0, nDivs, 1, 64*nWords );
Supp_DeriveDumpSimsC( pFile, vDivs, nWords );
Supp_DeriveDumpSims( pFile, vIsfs, nWords );
fclose ( pFile );
RetValue = 0;
}
void Supp_DeriveDumpSol( Vec_Int_t * vSet, Vec_Int_t * vRes, int nDivs ) void Supp_DeriveDumpSol( Vec_Int_t * vSet, Vec_Int_t * vRes, int nDivs )
{ {
char Buffer[100]; char Buffer[100];
int RetValue = sprintf( Buffer, "case01_%02d.sol", s_Counter ); int RetValue = sprintf( Buffer, "%02d.sol", s_Counter );
int i, iLit, iLitRes = -1, nSupp = Vec_IntSize(vSet); int i, iLit, iLitRes = -1, nSupp = Vec_IntSize(vSet);
FILE * pFile = fopen( Buffer, "wb" ); FILE * pFile = fopen( Buffer, "wb" );
if ( pFile == NULL ) if ( pFile == NULL )
...@@ -779,7 +814,10 @@ Vec_Int_t * Supp_ManFindBestSolution( Supp_Man_t * p, Vec_Wec_t * vSols, int fVe ...@@ -779,7 +814,10 @@ Vec_Int_t * Supp_ManFindBestSolution( Supp_Man_t * p, Vec_Wec_t * vSols, int fVe
Vec_IntForEachEntry( vSet, iObj, i ) Vec_IntForEachEntry( vSet, iObj, i )
Vec_IntPush( *pvDivs, Vec_IntEntry(p->vCands, iObj) ); Vec_IntPush( *pvDivs, Vec_IntEntry(p->vCands, iObj) );
} }
//Supp_DeriveDumpProbC( p->vIsfs, p->vDivsC, p->nWords );
//Supp_DeriveDumpProb( p->vIsfs, p->vDivs[1], p->nWords );
//Supp_DeriveDumpSol( vSet, vRes, Vec_WrdSize(p->vDivs[1])/p->nWords ); //Supp_DeriveDumpSol( vSet, vRes, Vec_WrdSize(p->vDivs[1])/p->nWords );
//s_Counter++;
} }
return vRes; return vRes;
} }
...@@ -877,8 +915,6 @@ Vec_Int_t * Supp_ManCompute( Vec_Wrd_t * vIsfs, Vec_Int_t * vCands, Vec_Int_t * ...@@ -877,8 +915,6 @@ Vec_Int_t * Supp_ManCompute( Vec_Wrd_t * vIsfs, Vec_Int_t * vCands, Vec_Int_t *
Supp_PrintOne( p, iBest ); Supp_PrintOne( p, iBest );
} }
vRes = Supp_ManFindBestSolution( p, p->vSolutions, fVerbose, pvDivs ); vRes = Supp_ManFindBestSolution( p, p->vSolutions, fVerbose, pvDivs );
//Supp_DeriveDumpProb( vIsfs, p->vDivs[1], p->nWords );
s_Counter++;
//Vec_IntPrint( vRes ); //Vec_IntPrint( vRes );
Supp_ManDelete( p ); Supp_ManDelete( p );
// if ( vRes && Vec_IntSize(vRes) == 0 ) // if ( vRes && Vec_IntSize(vRes) == 0 )
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment