summaryrefslogtreecommitdiffstats
path: root/src/sat/bsat/vecRec.h
diff options
context:
space:
mode:
Diffstat (limited to 'src/sat/bsat/vecRec.h')
-rw-r--r--src/sat/bsat/vecRec.h306
1 files changed, 306 insertions, 0 deletions
diff --git a/src/sat/bsat/vecRec.h b/src/sat/bsat/vecRec.h
new file mode 100644
index 00000000..d81cc631
--- /dev/null
+++ b/src/sat/bsat/vecRec.h
@@ -0,0 +1,306 @@
+/**CFile****************************************************************
+
+ FileName [vecRec.h]
+
+ SystemName [ABC: Logic synthesis and verification system.]
+
+ PackageName [Resizable arrays.]
+
+ Synopsis [Array of records.]
+
+ Author [Alan Mishchenko]
+
+ Affiliation [UC Berkeley]
+
+ Date [Ver. 1.0. Started - June 20, 2005.]
+
+ Revision [$Id: vecRec.h,v 1.00 2005/06/20 00:00:00 alanmi Exp $]
+
+***********************************************************************/
+
+#ifndef __VEC_REC_H__
+#define __VEC_REC_H__
+
+
+////////////////////////////////////////////////////////////////////////
+/// INCLUDES ///
+////////////////////////////////////////////////////////////////////////
+
+#include <stdio.h>
+
+ABC_NAMESPACE_HEADER_START
+
+
+////////////////////////////////////////////////////////////////////////
+/// PARAMETERS ///
+////////////////////////////////////////////////////////////////////////
+
+////////////////////////////////////////////////////////////////////////
+/// BASIC TYPES ///
+////////////////////////////////////////////////////////////////////////
+
+// data-structure for logging entries
+// memory is allocated in 2^(p->LogSize+2) byte chunks
+// the first 'int' of each entry cannot be 0
+typedef struct Vec_Rec_t_ Vec_Rec_t;
+struct Vec_Rec_t_
+{
+ int LogSize; // the log size of one chunk in 'int'
+ int Mask; // mask for the log size
+ int hCurrent; // current position
+ int nEntries; // total number of entries
+ int nChunks; // total number of chunks
+ int nChunksAlloc; // the number of allocated chunks
+ int ** pChunks; // the chunks
+};
+
+////////////////////////////////////////////////////////////////////////
+/// MACRO DEFINITIONS ///
+////////////////////////////////////////////////////////////////////////
+
+// p is vector of records
+// Size is given by the user
+// Handle is returned to the user
+// c (chunk) and s (shift) are variables used here
+#define Vec_RecForEachEntry( p, Size, Handle, c, s ) \
+ for ( c = 1; c <= p->nChunks; c++ ) \
+ for ( s = 0; p->pChunks[c][s] && ((Handle) = (((c)<<16)|(s))); s += Size, assert(s < p->Mask) )
+
+
+////////////////////////////////////////////////////////////////////////
+/// FUNCTION DEFINITIONS ///
+////////////////////////////////////////////////////////////////////////
+
+/**Function*************************************************************
+
+ Synopsis []
+
+ Description []
+
+ SideEffects []
+
+ SeeAlso []
+
+***********************************************************************/
+static inline Vec_Rec_t * Vec_RecAlloc()
+{
+ Vec_Rec_t * p;
+ p = ABC_CALLOC( Vec_Rec_t, 1 );
+ p->LogSize = 15; // chunk size = 2^15 ints = 128 Kb
+ p->Mask = (1 << p->LogSize) - 1;
+ p->hCurrent = (1 << 16);
+ p->nChunks = 1;
+ p->nChunksAlloc = 16;
+ p->pChunks = ABC_CALLOC( int *, p->nChunksAlloc );
+ p->pChunks[0] = NULL;
+ p->pChunks[1] = ABC_ALLOC( int, (1 << 16) );
+ p->pChunks[1][0] = 0;
+ return p;
+}
+
+/**Function*************************************************************
+
+ Synopsis []
+
+ Description []
+
+ SideEffects []
+
+ SeeAlso []
+
+***********************************************************************/
+static inline int Vec_RecEntryNum( Vec_Rec_t * p )
+{
+ return p->nEntries;
+}
+
+/**Function*************************************************************
+
+ Synopsis []
+
+ Description []
+
+ SideEffects []
+
+ SeeAlso []
+
+***********************************************************************/
+static inline int Vec_RecChunk( int i )
+{
+ return i>>16;
+}
+
+/**Function*************************************************************
+
+ Synopsis []
+
+ Description []
+
+ SideEffects []
+
+ SeeAlso []
+
+***********************************************************************/
+static inline int Vec_RecShift( int i )
+{
+ return i&0xFFFF;
+}
+
+/**Function*************************************************************
+
+ Synopsis []
+
+ Description []
+
+ SideEffects []
+
+ SeeAlso []
+
+***********************************************************************/
+static inline int Vec_RecEntry( Vec_Rec_t * p, int i )
+{
+ assert( i <= p->hCurrent );
+ return p->pChunks[Vec_RecChunk(i)][Vec_RecShift(i)];
+}
+
+/**Function*************************************************************
+
+ Synopsis []
+
+ Description []
+
+ SideEffects []
+
+ SeeAlso []
+
+***********************************************************************/
+static inline int * Vec_RecEntryP( Vec_Rec_t * p, int i )
+{
+ assert( i <= p->hCurrent );
+ return p->pChunks[Vec_RecChunk(i)] + Vec_RecShift(i);
+}
+
+/**Function*************************************************************
+
+ Synopsis []
+
+ Description []
+
+ SideEffects []
+
+ SeeAlso []
+
+***********************************************************************/
+static inline void Vec_RecRestart( Vec_Rec_t * p )
+{
+ p->hCurrent = (1 << 16);
+ p->nChunks = 1;
+ p->nEntries = 0;
+ p->pChunks[1][0] = 0;
+}
+
+/**Function*************************************************************
+
+ Synopsis []
+
+ Description []
+
+ SideEffects []
+
+ SeeAlso []
+
+***********************************************************************/
+static inline void Vec_RecShrink( Vec_Rec_t * p, int h )
+{
+ int i;
+ assert( Vec_RecEntry(p, h) == 0 );
+ for ( i = Vec_RecChunk(h)+1; i < p->nChunksAlloc; i++ )
+ ABC_FREE( p->pChunks[i] );
+ p->nChunks = Vec_RecChunk(h);
+ p->hCurrent = h;
+}
+
+/**Function*************************************************************
+
+ Synopsis []
+
+ Description []
+
+ SideEffects []
+
+ SeeAlso []
+
+***********************************************************************/
+static inline void Vec_RecFree( Vec_Rec_t * p )
+{
+ int i;
+ for ( i = 0; i < p->nChunksAlloc; i++ )
+ ABC_FREE( p->pChunks[i] );
+ ABC_FREE( p->pChunks );
+ ABC_FREE( p );
+}
+
+/**Function*************************************************************
+
+ Synopsis []
+
+ Description []
+
+ SideEffects []
+
+ SeeAlso []
+
+***********************************************************************/
+static inline int Vec_RecAppend( Vec_Rec_t * p, int nSize )
+{
+ int RetValue;
+ assert( nSize <= p->Mask );
+ assert( Vec_RecEntry(p, p->hCurrent) == 0 );
+ assert( Vec_RecChunk(p->hCurrent) == p->nChunks );
+ if ( Vec_RecShift(p->hCurrent) + nSize >= p->Mask )
+ {
+ if ( ++p->nChunks == p->nChunksAlloc )
+ {
+ p->pChunks = ABC_REALLOC( int *, p->pChunks, p->nChunksAlloc * 2 );
+ memset( p->pChunks + p->nChunksAlloc, 0, sizeof(int *) * p->nChunksAlloc );
+ p->nChunksAlloc *= 2;
+ }
+ if ( p->pChunks[p->nChunks] == NULL )
+ p->pChunks[p->nChunks] = ABC_ALLOC( int, (1 << p->LogSize) );
+ p->pChunks[p->nChunks][0] = 0;
+ p->hCurrent = p->nChunks << 16;
+ }
+ RetValue = p->hCurrent;
+ p->hCurrent += nSize;
+ *Vec_RecEntryP(p, p->hCurrent) = 0;
+ p->nEntries++;
+ return RetValue;
+}
+
+/**Function*************************************************************
+
+ Synopsis []
+
+ Description []
+
+ SideEffects []
+
+ SeeAlso []
+
+***********************************************************************/
+static inline int Vec_RecPush( Vec_Rec_t * p, int * pArray, int nSize )
+{
+ int Handle = Vec_RecAppend( p, nSize );
+ memmove( Vec_RecEntryP(p, Handle), pArray, sizeof(int) * nSize );
+ return Handle;
+}
+
+
+ABC_NAMESPACE_HEADER_END
+
+#endif
+
+////////////////////////////////////////////////////////////////////////
+/// END OF FILE ///
+////////////////////////////////////////////////////////////////////////
+