00001
00019 #include <limits.h>
00020 #include "fraigInt.h"
00021
00025
00029
00049 Fraig_Node_t * Fraig_NodeAndCanon( Fraig_Man_t * pMan, Fraig_Node_t * p1, Fraig_Node_t * p2 )
00050 {
00051 Fraig_Node_t * pNodeNew, * pNodeOld, * pNodeRepr;
00052 int fUseSatCheck;
00053
00054
00055
00056 if ( p1 == p2 )
00057 return p1;
00058 if ( p1 == Fraig_Not(p2) )
00059 return Fraig_Not(pMan->pConst1);
00060 if ( Fraig_NodeIsConst(p1) )
00061 {
00062 if ( p1 == pMan->pConst1 )
00063 return p2;
00064 return Fraig_Not(pMan->pConst1);
00065 }
00066 if ( Fraig_NodeIsConst(p2) )
00067 {
00068 if ( p2 == pMan->pConst1 )
00069 return p1;
00070 return Fraig_Not(pMan->pConst1);
00071 }
00072
00073
00074
00075
00076
00077
00078
00079
00080
00081
00082
00083
00084
00085
00086
00087
00088
00089
00090
00091
00092
00093
00094
00095
00096
00097
00098
00099
00100
00101
00102
00103
00104
00105
00106
00107
00108
00109
00110
00111
00112
00113
00114
00115
00116
00117
00118
00119
00120
00121
00122
00123
00124
00125
00126
00127
00128
00129
00130
00131 if ( Fraig_HashTableLookupS( pMan, p1, p2, &pNodeNew ) )
00132 {
00133
00134
00135
00136
00137 pNodeRepr = Fraig_Regular(pNodeNew)->pRepr;
00138 if ( pMan->fFuncRed && pNodeRepr )
00139 return Fraig_NotCond( pNodeRepr, Fraig_IsComplement(pNodeNew) ^ Fraig_NodeComparePhase(Fraig_Regular(pNodeNew), pNodeRepr) );
00140
00141 return pNodeNew;
00142 }
00143
00144
00145
00146 if ( !pMan->fFuncRed )
00147 return pNodeNew;
00148
00149
00150 if ( pNodeNew->nOnes == 0 || pNodeNew->nOnes == (unsigned)pMan->nWordsRand * 32 )
00151 {
00152 pMan->nSatZeros++;
00153 if ( !pMan->fDoSparse )
00154 return pNodeNew;
00155
00156 pNodeOld = Fraig_HashTableLookupF0( pMan, pNodeNew );
00157 if ( pNodeOld == NULL )
00158 return pNodeNew;
00159 }
00160 else
00161 {
00162
00163 pNodeOld = Fraig_HashTableLookupF( pMan, pNodeNew );
00164 if ( pNodeOld == NULL )
00165 return pNodeNew;
00166 }
00167 assert( pNodeOld->pRepr == 0 );
00168
00169
00170
00171 fUseSatCheck = (pMan->nInspLimit == 0 || Fraig_ManReadInspects(pMan) < pMan->nInspLimit);
00172 if ( fUseSatCheck && Fraig_NodeIsEquivalent( pMan, pNodeOld, pNodeNew, pMan->nBTLimit, 1000000 ) )
00173 {
00174
00175
00176
00177
00178
00179
00180
00181 if ( pMan->fChoicing && !Fraig_CheckTfi( pMan, pNodeOld, pNodeNew ) )
00182 {
00183
00184
00185 pNodeNew->pNextE = pNodeOld->pNextE;
00186 pNodeOld->pNextE = pNodeNew;
00187 }
00188
00189 pNodeNew->pRepr = pNodeOld;
00190
00191 return Fraig_NotCond( pNodeOld, Fraig_NodeComparePhase(pNodeOld, pNodeNew) );
00192 }
00193
00194
00195 if ( pNodeNew->nOnes == 0 || pNodeNew->nOnes == (unsigned)pMan->nWordsRand * 32 )
00196 {
00197 Fraig_Node_t * pNodeTemp;
00198 assert( pMan->fDoSparse );
00199 pNodeTemp = Fraig_HashTableLookupF0( pMan, pNodeNew );
00200
00201
00202 }
00203 else
00204 {
00205 pNodeNew->pNextD = pNodeOld->pNextD;
00206 pNodeOld->pNextD = pNodeNew;
00207 }
00208
00209 assert( pNodeNew->pRepr == 0 );
00210 return pNodeNew;
00211 }
00212
00213
00217
00218