diff options
author | Alan Mishchenko <alanmi@berkeley.edu> | 2012-07-20 08:48:14 -0700 |
---|---|---|
committer | Alan Mishchenko <alanmi@berkeley.edu> | 2012-07-20 08:48:14 -0700 |
commit | e53ffc640827d1c9d44f8fb24518d9bb87660f4a (patch) | |
tree | 15f5e3a5b64600d96312bd6369e103991238cc04 /src | |
parent | febe2c6ae0f2fcd41e0a1fc25352c02d973ee8c9 (diff) | |
download | abc-e53ffc640827d1c9d44f8fb24518d9bb87660f4a.tar.gz abc-e53ffc640827d1c9d44f8fb24518d9bb87660f4a.tar.bz2 abc-e53ffc640827d1c9d44f8fb24518d9bb87660f4a.zip |
New procedures to generate NPN-classes for a library of 6-input functions.
Diffstat (limited to 'src')
-rw-r--r-- | src/misc/extra/extraUtilMisc.c | 24 |
1 files changed, 16 insertions, 8 deletions
diff --git a/src/misc/extra/extraUtilMisc.c b/src/misc/extra/extraUtilMisc.c index d440c79c..c490b14a 100644 --- a/src/misc/extra/extraUtilMisc.c +++ b/src/misc/extra/extraUtilMisc.c @@ -2330,12 +2330,14 @@ word * Extra_NpnRead( char * pFileName, int nFuncs ) pFuncs = ABC_CALLOC( word, nFuncs ); pFile = fopen( pFileName, "rb" ); while ( fgets( pBuffer, 100, pFile ) ) - Extra_ReadHex( (unsigned *)(pFuncs + i++), pBuffer+2, 16 ); -// Extra_ReadHex( (unsigned *)(pFuncs + i++), pBuffer, 16 ); + Extra_ReadHex( (unsigned *)(pFuncs + i++), (pBuffer[1] == 'x' ? pBuffer+2 : pBuffer), 16 ); fclose( pFile ); assert( i == nFuncs ); - for ( i = 0; i < Abc_MinInt(nFuncs, 20); i++ ) + for ( i = 0; i < Abc_MinInt(nFuncs, 10); i++ ) + { + printf( "Line %d : ", i ); Extra_PrintHex( stdout, (unsigned *)(pFuncs + i), 6 ), printf( "\n" ); + } return pFuncs; } @@ -2394,13 +2396,14 @@ void Extra_NpnTest2() } void Extra_NpnTest() { - int nFuncs = 5687661; +// int nFuncs = 5687661; // int nFuncs = 400777; -// int nFuncs = 10; + int nFuncs = 10; clock_t clk = clock(); word * pFuncs; int * pComp, * pPerm; int i, k, nUnique = 0; +/* // read functions pFuncs = Extra_NpnRead( "C:\\_projects\\abc\\_TEST\\allan\\lib6var5M.txt", nFuncs ); // pFuncs = Extra_NpnRead( "C:\\_projects\\abc\\_TEST\\allan\\lib6var5M_out_Total_minimal.txt", nFuncs ); @@ -2413,9 +2416,9 @@ void Extra_NpnTest() pFuncs[k++] = pFuncs[i]; nFuncs = k; printf( "Total number of unique functions = %d\n", nFuncs ); - +*/ // pFuncs = Extra_NpnRead( "C:\\_projects\\abc\\_TEST\\allan\\lib6var5M_out_Total_minimal.txt", nFuncs ); -// pFuncs = Extra_NpnRead( "C:\\_projects\\abc\\_TEST\\allan\\test.txt", nFuncs ); + pFuncs = Extra_NpnRead( "C:\\_projects\\abc\\_TEST\\allan\\test.txt", nFuncs ); pComp = Extra_GreyCodeSchedule( 6 ); pPerm = Extra_PermSchedule( 6 ); // compute minimum forms @@ -2426,6 +2429,7 @@ void Extra_NpnTest() printf( "%d\n", i ); } printf( "Finished deriving minimum form\n" ); +/* // sort them by value qsort( (void *)pFuncs, nFuncs, sizeof(word), (int(*)(const void *,const void *))CompareWords ); // count unique @@ -2434,8 +2438,12 @@ void Extra_NpnTest() if ( pFuncs[i] == pFuncs[i-1] ) nUnique--; printf( "Total number of unique ones = %d\n", nUnique ); - for ( i = 0; i < Abc_MinInt(nFuncs, 20); i++ ) +*/ + for ( i = 0; i < Abc_MinInt(nFuncs, 10); i++ ) + { + printf( "Line %d : ", i ); Extra_PrintHex( stdout, (unsigned *)(pFuncs + i), 6 ), printf( "\n" ); + } ABC_FREE( pPerm ); ABC_FREE( pComp ); ABC_FREE( pFuncs ); |