ruby_abc 0.0.3 → 0.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +5 -5
- data/.yardopts +7 -0
- data/LICENSE +51 -52
- data/README.md +96 -37
- data/bin/ruby_abc +103 -0
- data/ext/ruby_abc/extconf.rb +58 -0
- data/ext/{ruby_abc.c → ruby_abc/ruby_abc.c} +45 -72
- data/ext/ruby_abc/ruby_abc.map +6 -0
- data/ext/{ruby_abc_wrapper.c → ruby_abc/ruby_abc_wrapper.c} +0 -0
- data/ext/ruby_abc/ruby_abc_wrapper.h +39 -0
- data/lib/ruby_abc/version.rb +4 -0
- data/lib/ruby_abc.rb +247 -225
- data/share/bash_completion/ruby_abc.bash-completion.sh +24 -0
- data/share/osu018.genlib +66 -0
- data/share/simple.genlib +25 -0
- data/test/test_ruby_abc.rb +1 -1
- metadata +19 -1727
- data/Rakefile +0 -83
- data/bin/rubyabc_synthesis +0 -71
- data/ext/abc/CMakeLists.txt +0 -103
- data/ext/abc/Makefile +0 -213
- data/ext/abc/abc.rc +0 -146
- data/ext/abc/abcexe.dsp +0 -103
- data/ext/abc/abclib.dsp +0 -5948
- data/ext/abc/abcspace.dsw +0 -44
- data/ext/abc/arch_flags.c +0 -17
- data/ext/abc/copyright.txt +0 -23
- data/ext/abc/depends.sh +0 -13
- data/ext/abc/i10.aig +0 -752
- data/ext/abc/lib/pthread.h +0 -1369
- data/ext/abc/lib/sched.h +0 -178
- data/ext/abc/lib/semaphore.h +0 -166
- data/ext/abc/lib/x64/pthreadVC2.dll +0 -0
- data/ext/abc/lib/x64/pthreadVC2.lib +0 -0
- data/ext/abc/lib/x86/pthreadVC2.dll +0 -0
- data/ext/abc/lib/x86/pthreadVC2.lib +0 -0
- data/ext/abc/readme.md +0 -111
- data/ext/abc/readmeaig +0 -47
- data/ext/abc/src/aig/aig/aig.h +0 -713
- data/ext/abc/src/aig/aig/aigCanon.c +0 -701
- data/ext/abc/src/aig/aig/aigCheck.c +0 -168
- data/ext/abc/src/aig/aig/aigCuts.c +0 -673
- data/ext/abc/src/aig/aig/aigDfs.c +0 -1136
- data/ext/abc/src/aig/aig/aigDoms.c +0 -1154
- data/ext/abc/src/aig/aig/aigDup.c +0 -1335
- data/ext/abc/src/aig/aig/aigFact.c +0 -734
- data/ext/abc/src/aig/aig/aigFanout.c +0 -194
- data/ext/abc/src/aig/aig/aigFrames.c +0 -140
- data/ext/abc/src/aig/aig/aigInter.c +0 -301
- data/ext/abc/src/aig/aig/aigJust.c +0 -316
- data/ext/abc/src/aig/aig/aigMan.c +0 -486
- data/ext/abc/src/aig/aig/aigMem.c +0 -610
- data/ext/abc/src/aig/aig/aigMffc.c +0 -316
- data/ext/abc/src/aig/aig/aigObj.c +0 -536
- data/ext/abc/src/aig/aig/aigOper.c +0 -606
- data/ext/abc/src/aig/aig/aigOrder.c +0 -176
- data/ext/abc/src/aig/aig/aigPack.c +0 -404
- data/ext/abc/src/aig/aig/aigPart.c +0 -1613
- data/ext/abc/src/aig/aig/aigPartReg.c +0 -629
- data/ext/abc/src/aig/aig/aigPartSat.c +0 -618
- data/ext/abc/src/aig/aig/aigRepar.c +0 -403
- data/ext/abc/src/aig/aig/aigRepr.c +0 -559
- data/ext/abc/src/aig/aig/aigRet.c +0 -975
- data/ext/abc/src/aig/aig/aigRetF.c +0 -214
- data/ext/abc/src/aig/aig/aigScl.c +0 -708
- data/ext/abc/src/aig/aig/aigShow.c +0 -368
- data/ext/abc/src/aig/aig/aigSplit.c +0 -330
- data/ext/abc/src/aig/aig/aigTable.c +0 -277
- data/ext/abc/src/aig/aig/aigTest.c +0 -39
- data/ext/abc/src/aig/aig/aigTiming.c +0 -356
- data/ext/abc/src/aig/aig/aigTruth.c +0 -103
- data/ext/abc/src/aig/aig/aigTsim.c +0 -526
- data/ext/abc/src/aig/aig/aigUtil.c +0 -1575
- data/ext/abc/src/aig/aig/aigWin.c +0 -189
- data/ext/abc/src/aig/aig/aig_.c +0 -53
- data/ext/abc/src/aig/aig/module.make +0 -31
- data/ext/abc/src/aig/gia/gia.c +0 -52
- data/ext/abc/src/aig/gia/gia.h +0 -1667
- data/ext/abc/src/aig/gia/giaAgi.c +0 -238
- data/ext/abc/src/aig/gia/giaAig.c +0 -676
- data/ext/abc/src/aig/gia/giaAig.h +0 -78
- data/ext/abc/src/aig/gia/giaAiger.c +0 -1479
- data/ext/abc/src/aig/gia/giaAigerExt.c +0 -326
- data/ext/abc/src/aig/gia/giaBalAig.c +0 -1095
- data/ext/abc/src/aig/gia/giaBalLut.c +0 -982
- data/ext/abc/src/aig/gia/giaBalMap.c +0 -326
- data/ext/abc/src/aig/gia/giaBidec.c +0 -305
- data/ext/abc/src/aig/gia/giaCCof.c +0 -349
- data/ext/abc/src/aig/gia/giaCSat.c +0 -1105
- data/ext/abc/src/aig/gia/giaCSatOld.c +0 -804
- data/ext/abc/src/aig/gia/giaCTas.c +0 -1790
- data/ext/abc/src/aig/gia/giaCTas2.c +0 -208
- data/ext/abc/src/aig/gia/giaCex.c +0 -392
- data/ext/abc/src/aig/gia/giaClp.c +0 -422
- data/ext/abc/src/aig/gia/giaCof.c +0 -1002
- data/ext/abc/src/aig/gia/giaCone.c +0 -590
- data/ext/abc/src/aig/gia/giaConstr.c +0 -52
- data/ext/abc/src/aig/gia/giaCut.c +0 -646
- data/ext/abc/src/aig/gia/giaDfs.c +0 -582
- data/ext/abc/src/aig/gia/giaDup.c +0 -4791
- data/ext/abc/src/aig/gia/giaEdge.c +0 -1000
- data/ext/abc/src/aig/gia/giaEmbed.c +0 -1876
- data/ext/abc/src/aig/gia/giaEnable.c +0 -650
- data/ext/abc/src/aig/gia/giaEquiv.c +0 -2416
- data/ext/abc/src/aig/gia/giaEra.c +0 -602
- data/ext/abc/src/aig/gia/giaEra2.c +0 -1963
- data/ext/abc/src/aig/gia/giaEsop.c +0 -541
- data/ext/abc/src/aig/gia/giaFalse.c +0 -552
- data/ext/abc/src/aig/gia/giaFanout.c +0 -338
- data/ext/abc/src/aig/gia/giaForce.c +0 -1106
- data/ext/abc/src/aig/gia/giaFrames.c +0 -996
- data/ext/abc/src/aig/gia/giaFront.c +0 -295
- data/ext/abc/src/aig/gia/giaFx.c +0 -487
- data/ext/abc/src/aig/gia/giaGiarf.c +0 -1079
- data/ext/abc/src/aig/gia/giaGig.c +0 -506
- data/ext/abc/src/aig/gia/giaGlitch.c +0 -786
- data/ext/abc/src/aig/gia/giaHash.c +0 -816
- data/ext/abc/src/aig/gia/giaHcd.c +0 -689
- data/ext/abc/src/aig/gia/giaIf.c +0 -2536
- data/ext/abc/src/aig/gia/giaIff.c +0 -444
- data/ext/abc/src/aig/gia/giaIiff.c +0 -62
- data/ext/abc/src/aig/gia/giaIiff.h +0 -54
- data/ext/abc/src/aig/gia/giaIso.c +0 -1331
- data/ext/abc/src/aig/gia/giaIso2.c +0 -776
- data/ext/abc/src/aig/gia/giaIso3.c +0 -167
- data/ext/abc/src/aig/gia/giaJf.c +0 -1805
- data/ext/abc/src/aig/gia/giaKf.c +0 -1341
- data/ext/abc/src/aig/gia/giaLf.c +0 -2301
- data/ext/abc/src/aig/gia/giaMan.c +0 -1126
- data/ext/abc/src/aig/gia/giaMem.c +0 -598
- data/ext/abc/src/aig/gia/giaMf.c +0 -1741
- data/ext/abc/src/aig/gia/giaMffc.c +0 -313
- data/ext/abc/src/aig/gia/giaMfs.c +0 -477
- data/ext/abc/src/aig/gia/giaMini.c +0 -574
- data/ext/abc/src/aig/gia/giaMuxes.c +0 -915
- data/ext/abc/src/aig/gia/giaNf.c +0 -2420
- data/ext/abc/src/aig/gia/giaOf.c +0 -1866
- data/ext/abc/src/aig/gia/giaPack.c +0 -207
- data/ext/abc/src/aig/gia/giaPat.c +0 -135
- data/ext/abc/src/aig/gia/giaPf.c +0 -1354
- data/ext/abc/src/aig/gia/giaProp.c +0 -176
- data/ext/abc/src/aig/gia/giaQbf.c +0 -701
- data/ext/abc/src/aig/gia/giaResub.c +0 -292
- data/ext/abc/src/aig/gia/giaRetime.c +0 -304
- data/ext/abc/src/aig/gia/giaRex.c +0 -545
- data/ext/abc/src/aig/gia/giaSat.c +0 -427
- data/ext/abc/src/aig/gia/giaSat3.c +0 -136
- data/ext/abc/src/aig/gia/giaSatEdge.c +0 -537
- data/ext/abc/src/aig/gia/giaSatLE.c +0 -1083
- data/ext/abc/src/aig/gia/giaSatLut.c +0 -1225
- data/ext/abc/src/aig/gia/giaSatMap.c +0 -554
- data/ext/abc/src/aig/gia/giaSatoko.c +0 -274
- data/ext/abc/src/aig/gia/giaScl.c +0 -300
- data/ext/abc/src/aig/gia/giaScript.c +0 -783
- data/ext/abc/src/aig/gia/giaShow.c +0 -1164
- data/ext/abc/src/aig/gia/giaShrink.c +0 -154
- data/ext/abc/src/aig/gia/giaShrink6.c +0 -492
- data/ext/abc/src/aig/gia/giaShrink7.c +0 -373
- data/ext/abc/src/aig/gia/giaSim.c +0 -905
- data/ext/abc/src/aig/gia/giaSim2.c +0 -706
- data/ext/abc/src/aig/gia/giaSort.c +0 -273
- data/ext/abc/src/aig/gia/giaSpeedup.c +0 -805
- data/ext/abc/src/aig/gia/giaSplit.c +0 -578
- data/ext/abc/src/aig/gia/giaStg.c +0 -528
- data/ext/abc/src/aig/gia/giaStr.c +0 -1865
- data/ext/abc/src/aig/gia/giaSupMin.c +0 -165
- data/ext/abc/src/aig/gia/giaSupp.c +0 -886
- data/ext/abc/src/aig/gia/giaSweep.c +0 -777
- data/ext/abc/src/aig/gia/giaSweeper.c +0 -1185
- data/ext/abc/src/aig/gia/giaSwitch.c +0 -829
- data/ext/abc/src/aig/gia/giaTim.c +0 -1017
- data/ext/abc/src/aig/gia/giaTis.c +0 -213
- data/ext/abc/src/aig/gia/giaTruth.c +0 -639
- data/ext/abc/src/aig/gia/giaTsim.c +0 -757
- data/ext/abc/src/aig/gia/giaUnate.c +0 -255
- data/ext/abc/src/aig/gia/giaUtil.c +0 -2136
- data/ext/abc/src/aig/gia/module.make +0 -89
- data/ext/abc/src/aig/hop/cudd2.c +0 -360
- data/ext/abc/src/aig/hop/cudd2.h +0 -86
- data/ext/abc/src/aig/hop/hop.h +0 -356
- data/ext/abc/src/aig/hop/hopBalance.c +0 -401
- data/ext/abc/src/aig/hop/hopCheck.c +0 -115
- data/ext/abc/src/aig/hop/hopDfs.c +0 -591
- data/ext/abc/src/aig/hop/hopMan.c +0 -169
- data/ext/abc/src/aig/hop/hopMem.c +0 -120
- data/ext/abc/src/aig/hop/hopObj.c +0 -277
- data/ext/abc/src/aig/hop/hopOper.c +0 -378
- data/ext/abc/src/aig/hop/hopTable.c +0 -232
- data/ext/abc/src/aig/hop/hopTruth.c +0 -274
- data/ext/abc/src/aig/hop/hopUtil.c +0 -578
- data/ext/abc/src/aig/hop/hop_.c +0 -53
- data/ext/abc/src/aig/hop/module.make +0 -10
- data/ext/abc/src/aig/ioa/ioa.h +0 -87
- data/ext/abc/src/aig/ioa/ioaReadAig.c +0 -465
- data/ext/abc/src/aig/ioa/ioaUtil.c +0 -146
- data/ext/abc/src/aig/ioa/ioaWriteAig.c +0 -599
- data/ext/abc/src/aig/ioa/module.make +0 -3
- data/ext/abc/src/aig/ivy/attr.h +0 -418
- data/ext/abc/src/aig/ivy/ivy.h +0 -562
- data/ext/abc/src/aig/ivy/ivyBalance.c +0 -414
- data/ext/abc/src/aig/ivy/ivyCanon.c +0 -149
- data/ext/abc/src/aig/ivy/ivyCheck.c +0 -278
- data/ext/abc/src/aig/ivy/ivyCut.c +0 -995
- data/ext/abc/src/aig/ivy/ivyCutTrav.c +0 -478
- data/ext/abc/src/aig/ivy/ivyDfs.c +0 -498
- data/ext/abc/src/aig/ivy/ivyDsd.c +0 -831
- data/ext/abc/src/aig/ivy/ivyFanout.c +0 -314
- data/ext/abc/src/aig/ivy/ivyFastMap.c +0 -1569
- data/ext/abc/src/aig/ivy/ivyFraig.c +0 -2972
- data/ext/abc/src/aig/ivy/ivyHaig.c +0 -535
- data/ext/abc/src/aig/ivy/ivyMan.c +0 -552
- data/ext/abc/src/aig/ivy/ivyMem.c +0 -121
- data/ext/abc/src/aig/ivy/ivyMulti.c +0 -312
- data/ext/abc/src/aig/ivy/ivyMulti8.c +0 -432
- data/ext/abc/src/aig/ivy/ivyObj.c +0 -481
- data/ext/abc/src/aig/ivy/ivyOper.c +0 -298
- data/ext/abc/src/aig/ivy/ivyResyn.c +0 -201
- data/ext/abc/src/aig/ivy/ivyRwr.c +0 -618
- data/ext/abc/src/aig/ivy/ivyRwrAlg.c +0 -413
- data/ext/abc/src/aig/ivy/ivySeq.c +0 -1142
- data/ext/abc/src/aig/ivy/ivyShow.c +0 -343
- data/ext/abc/src/aig/ivy/ivyTable.c +0 -272
- data/ext/abc/src/aig/ivy/ivyUtil.c +0 -824
- data/ext/abc/src/aig/ivy/ivy_.c +0 -53
- data/ext/abc/src/aig/ivy/module.make +0 -22
- data/ext/abc/src/aig/miniaig/abcOper.h +0 -249
- data/ext/abc/src/aig/miniaig/miniaig.h +0 -346
- data/ext/abc/src/aig/miniaig/minilut.h +0 -288
- data/ext/abc/src/aig/miniaig/module.make +0 -1
- data/ext/abc/src/aig/miniaig/ndr.h +0 -521
- data/ext/abc/src/aig/saig/module.make +0 -26
- data/ext/abc/src/aig/saig/saig.h +0 -200
- data/ext/abc/src/aig/saig/saigCone.c +0 -181
- data/ext/abc/src/aig/saig/saigConstr.c +0 -484
- data/ext/abc/src/aig/saig/saigConstr2.c +0 -1013
- data/ext/abc/src/aig/saig/saigDual.c +0 -240
- data/ext/abc/src/aig/saig/saigDup.c +0 -600
- data/ext/abc/src/aig/saig/saigGlaCba.c +0 -840
- data/ext/abc/src/aig/saig/saigGlaPba.c +0 -589
- data/ext/abc/src/aig/saig/saigGlaPba2.c +0 -558
- data/ext/abc/src/aig/saig/saigInd.c +0 -409
- data/ext/abc/src/aig/saig/saigIoa.c +0 -405
- data/ext/abc/src/aig/saig/saigIso.c +0 -628
- data/ext/abc/src/aig/saig/saigIsoFast.c +0 -353
- data/ext/abc/src/aig/saig/saigIsoSlow.c +0 -1224
- data/ext/abc/src/aig/saig/saigMiter.c +0 -1317
- data/ext/abc/src/aig/saig/saigOutDec.c +0 -205
- data/ext/abc/src/aig/saig/saigPhase.c +0 -1081
- data/ext/abc/src/aig/saig/saigRefSat.c +0 -986
- data/ext/abc/src/aig/saig/saigRetFwd.c +0 -248
- data/ext/abc/src/aig/saig/saigRetMin.c +0 -705
- data/ext/abc/src/aig/saig/saigRetStep.c +0 -236
- data/ext/abc/src/aig/saig/saigScl.c +0 -115
- data/ext/abc/src/aig/saig/saigSimFast.c +0 -451
- data/ext/abc/src/aig/saig/saigSimMv.c +0 -956
- data/ext/abc/src/aig/saig/saigSimSeq.c +0 -518
- data/ext/abc/src/aig/saig/saigStrSim.c +0 -976
- data/ext/abc/src/aig/saig/saigSwitch.c +0 -573
- data/ext/abc/src/aig/saig/saigSynch.c +0 -665
- data/ext/abc/src/aig/saig/saigTempor.c +0 -256
- data/ext/abc/src/aig/saig/saigTrans.c +0 -428
- data/ext/abc/src/aig/saig/saigUnfold2.c +0 -497
- data/ext/abc/src/aig/saig/saigWnd.c +0 -816
- data/ext/abc/src/aig/saig/saig_.c +0 -52
- data/ext/abc/src/base/abc/abc.h +0 -1064
- data/ext/abc/src/base/abc/abcAig.c +0 -1505
- data/ext/abc/src/base/abc/abcBarBuf.c +0 -513
- data/ext/abc/src/base/abc/abcBlifMv.c +0 -1167
- data/ext/abc/src/base/abc/abcCheck.c +0 -953
- data/ext/abc/src/base/abc/abcDfs.c +0 -1910
- data/ext/abc/src/base/abc/abcFanOrder.c +0 -652
- data/ext/abc/src/base/abc/abcFanio.c +0 -366
- data/ext/abc/src/base/abc/abcFunc.c +0 -1273
- data/ext/abc/src/base/abc/abcHie.c +0 -843
- data/ext/abc/src/base/abc/abcHieCec.c +0 -764
- data/ext/abc/src/base/abc/abcHieGia.c +0 -582
- data/ext/abc/src/base/abc/abcHieNew.c +0 -1635
- data/ext/abc/src/base/abc/abcInt.h +0 -60
- data/ext/abc/src/base/abc/abcLatch.c +0 -778
- data/ext/abc/src/base/abc/abcLib.c +0 -400
- data/ext/abc/src/base/abc/abcMinBase.c +0 -841
- data/ext/abc/src/base/abc/abcNames.c +0 -802
- data/ext/abc/src/base/abc/abcNetlist.c +0 -511
- data/ext/abc/src/base/abc/abcNtk.c +0 -2298
- data/ext/abc/src/base/abc/abcObj.c +0 -1075
- data/ext/abc/src/base/abc/abcRefs.c +0 -457
- data/ext/abc/src/base/abc/abcShow.c +0 -458
- data/ext/abc/src/base/abc/abcSop.c +0 -1356
- data/ext/abc/src/base/abc/abcUtil.c +0 -3269
- data/ext/abc/src/base/abc/abc_.c +0 -52
- data/ext/abc/src/base/abc/module.make +0 -23
- data/ext/abc/src/base/abci/abc.c +0 -44490
- data/ext/abc/src/base/abci/abcAttach.c +0 -409
- data/ext/abc/src/base/abci/abcAuto.c +0 -256
- data/ext/abc/src/base/abci/abcBalance.c +0 -629
- data/ext/abc/src/base/abci/abcBidec.c +0 -156
- data/ext/abc/src/base/abci/abcBm.c +0 -2050
- data/ext/abc/src/base/abci/abcBmc.c +0 -122
- data/ext/abc/src/base/abci/abcCas.c +0 -128
- data/ext/abc/src/base/abci/abcCascade.c +0 -1062
- data/ext/abc/src/base/abci/abcCollapse.c +0 -957
- data/ext/abc/src/base/abci/abcCut.c +0 -700
- data/ext/abc/src/base/abci/abcDar.c +0 -4807
- data/ext/abc/src/base/abci/abcDarUnfold2.c +0 -69
- data/ext/abc/src/base/abci/abcDebug.c +0 -213
- data/ext/abc/src/base/abci/abcDec.c +0 -666
- data/ext/abc/src/base/abci/abcDetect.c +0 -1264
- data/ext/abc/src/base/abci/abcDress.c +0 -214
- data/ext/abc/src/base/abci/abcDress2.c +0 -500
- data/ext/abc/src/base/abci/abcDress3.c +0 -320
- data/ext/abc/src/base/abci/abcDsd.c +0 -710
- data/ext/abc/src/base/abci/abcEco.c +0 -58
- data/ext/abc/src/base/abci/abcEspresso.c +0 -255
- data/ext/abc/src/base/abci/abcExact.c +0 -3024
- data/ext/abc/src/base/abci/abcExtract.c +0 -752
- data/ext/abc/src/base/abci/abcFlop.c +0 -40
- data/ext/abc/src/base/abci/abcFpga.c +0 -288
- data/ext/abc/src/base/abci/abcFpgaFast.c +0 -195
- data/ext/abc/src/base/abci/abcFraig.c +0 -816
- data/ext/abc/src/base/abci/abcFx.c +0 -1207
- data/ext/abc/src/base/abci/abcFxu.c +0 -292
- data/ext/abc/src/base/abci/abcGen.c +0 -830
- data/ext/abc/src/base/abci/abcHaig.c +0 -557
- data/ext/abc/src/base/abci/abcIf.c +0 -830
- data/ext/abc/src/base/abci/abcIfMux.c +0 -422
- data/ext/abc/src/base/abci/abcIfif.c +0 -349
- data/ext/abc/src/base/abci/abcIvy.c +0 -1149
- data/ext/abc/src/base/abci/abcLog.c +0 -242
- data/ext/abc/src/base/abci/abcLut.c +0 -793
- data/ext/abc/src/base/abci/abcLutmin.c +0 -785
- data/ext/abc/src/base/abci/abcMap.c +0 -1064
- data/ext/abc/src/base/abci/abcMeasure.c +0 -483
- data/ext/abc/src/base/abci/abcMerge.c +0 -358
- data/ext/abc/src/base/abci/abcMffc.c +0 -1252
- data/ext/abc/src/base/abci/abcMfs.c +0 -469
- data/ext/abc/src/base/abci/abcMini.c +0 -237
- data/ext/abc/src/base/abci/abcMiter.c +0 -1196
- data/ext/abc/src/base/abci/abcMulti.c +0 -660
- data/ext/abc/src/base/abci/abcMv.c +0 -381
- data/ext/abc/src/base/abci/abcNpn.c +0 -392
- data/ext/abc/src/base/abci/abcNpnSave.c +0 -740
- data/ext/abc/src/base/abci/abcNtbdd.c +0 -619
- data/ext/abc/src/base/abci/abcOdc.c +0 -1132
- data/ext/abc/src/base/abci/abcOrder.c +0 -136
- data/ext/abc/src/base/abci/abcPart.c +0 -1206
- data/ext/abc/src/base/abci/abcPlace.c +0 -260
- data/ext/abc/src/base/abci/abcPrint.c +0 -2008
- data/ext/abc/src/base/abci/abcProve.c +0 -354
- data/ext/abc/src/base/abci/abcQbf.c +0 -319
- data/ext/abc/src/base/abci/abcQuant.c +0 -436
- data/ext/abc/src/base/abci/abcReach.c +0 -327
- data/ext/abc/src/base/abci/abcRec3.c +0 -1433
- data/ext/abc/src/base/abci/abcReconv.c +0 -776
- data/ext/abc/src/base/abci/abcRefactor.c +0 -418
- data/ext/abc/src/base/abci/abcRenode.c +0 -326
- data/ext/abc/src/base/abci/abcReorder.c +0 -117
- data/ext/abc/src/base/abci/abcRestruct.c +0 -1511
- data/ext/abc/src/base/abci/abcResub.c +0 -1957
- data/ext/abc/src/base/abci/abcRewrite.c +0 -420
- data/ext/abc/src/base/abci/abcRpo.c +0 -442
- data/ext/abc/src/base/abci/abcRr.c +0 -1005
- data/ext/abc/src/base/abci/abcSat.c +0 -1020
- data/ext/abc/src/base/abci/abcSaucy.c +0 -3346
- data/ext/abc/src/base/abci/abcScorr.c +0 -454
- data/ext/abc/src/base/abci/abcSense.c +0 -216
- data/ext/abc/src/base/abci/abcSpeedup.c +0 -965
- data/ext/abc/src/base/abci/abcStrash.c +0 -848
- data/ext/abc/src/base/abci/abcSweep.c +0 -1030
- data/ext/abc/src/base/abci/abcSymm.c +0 -246
- data/ext/abc/src/base/abci/abcTim.c +0 -637
- data/ext/abc/src/base/abci/abcTiming.c +0 -1398
- data/ext/abc/src/base/abci/abcUnate.c +0 -178
- data/ext/abc/src/base/abci/abcUnreach.c +0 -366
- data/ext/abc/src/base/abci/abcVerify.c +0 -1109
- data/ext/abc/src/base/abci/abcXsim.c +0 -231
- data/ext/abc/src/base/abci/abciUnfold2.c +0 -186
- data/ext/abc/src/base/abci/fahout_cut.c +0 -358
- data/ext/abc/src/base/abci/module.make +0 -75
- data/ext/abc/src/base/acb/acb.c +0 -52
- data/ext/abc/src/base/acb/acb.h +0 -1038
- data/ext/abc/src/base/acb/acbAbc.c +0 -302
- data/ext/abc/src/base/acb/acbAig.c +0 -52
- data/ext/abc/src/base/acb/acbCom.c +0 -735
- data/ext/abc/src/base/acb/acbFunc.c +0 -56
- data/ext/abc/src/base/acb/acbMfs.c +0 -1644
- data/ext/abc/src/base/acb/acbPar.h +0 -70
- data/ext/abc/src/base/acb/acbPush.c +0 -372
- data/ext/abc/src/base/acb/acbSets.c +0 -54
- data/ext/abc/src/base/acb/acbSets.h +0 -61
- data/ext/abc/src/base/acb/acbUtil.c +0 -479
- data/ext/abc/src/base/acb/module.make +0 -8
- data/ext/abc/src/base/bac/bac.c +0 -52
- data/ext/abc/src/base/bac/bac.h +0 -1017
- data/ext/abc/src/base/bac/bacBac.c +0 -298
- data/ext/abc/src/base/bac/bacBlast.c +0 -587
- data/ext/abc/src/base/bac/bacCom.c +0 -728
- data/ext/abc/src/base/bac/bacLib.c +0 -52
- data/ext/abc/src/base/bac/bacNtk.c +0 -603
- data/ext/abc/src/base/bac/bacOper.c +0 -365
- data/ext/abc/src/base/bac/bacPrs.h +0 -363
- data/ext/abc/src/base/bac/bacPrsBuild.c +0 -356
- data/ext/abc/src/base/bac/bacPrsTrans.c +0 -211
- data/ext/abc/src/base/bac/bacPtr.c +0 -470
- data/ext/abc/src/base/bac/bacPtrAbc.c +0 -486
- data/ext/abc/src/base/bac/bacReadBlif.c +0 -453
- data/ext/abc/src/base/bac/bacReadSmt.c +0 -42
- data/ext/abc/src/base/bac/bacReadVer.c +0 -875
- data/ext/abc/src/base/bac/bacWriteBlif.c +0 -236
- data/ext/abc/src/base/bac/bacWriteSmt.c +0 -52
- data/ext/abc/src/base/bac/bacWriteVer.c +0 -703
- data/ext/abc/src/base/bac/module.make +0 -15
- data/ext/abc/src/base/cba/cba.c +0 -52
- data/ext/abc/src/base/cba/cba.h +0 -1024
- data/ext/abc/src/base/cba/cbaBlast.c +0 -1069
- data/ext/abc/src/base/cba/cbaCba.c +0 -58
- data/ext/abc/src/base/cba/cbaCom.c +0 -731
- data/ext/abc/src/base/cba/cbaNtk.c +0 -1183
- data/ext/abc/src/base/cba/cbaPrs.h +0 -520
- data/ext/abc/src/base/cba/cbaReadBlif.c +0 -646
- data/ext/abc/src/base/cba/cbaReadVer.c +0 -2182
- data/ext/abc/src/base/cba/cbaTypes.h +0 -169
- data/ext/abc/src/base/cba/cbaWriteBlif.c +0 -218
- data/ext/abc/src/base/cba/cbaWriteVer.c +0 -1016
- data/ext/abc/src/base/cba/module.make +0 -8
- data/ext/abc/src/base/cmd/cmd.c +0 -2611
- data/ext/abc/src/base/cmd/cmd.h +0 -81
- data/ext/abc/src/base/cmd/cmdAlias.c +0 -126
- data/ext/abc/src/base/cmd/cmdApi.c +0 -127
- data/ext/abc/src/base/cmd/cmdAuto.c +0 -684
- data/ext/abc/src/base/cmd/cmdFlag.c +0 -110
- data/ext/abc/src/base/cmd/cmdHist.c +0 -180
- data/ext/abc/src/base/cmd/cmdInt.h +0 -92
- data/ext/abc/src/base/cmd/cmdLoad.c +0 -209
- data/ext/abc/src/base/cmd/cmdPlugin.c +0 -773
- data/ext/abc/src/base/cmd/cmdStarter.c +0 -259
- data/ext/abc/src/base/cmd/cmdUtils.c +0 -756
- data/ext/abc/src/base/cmd/module.make +0 -10
- data/ext/abc/src/base/exor/exor.c +0 -958
- data/ext/abc/src/base/exor/exor.h +0 -189
- data/ext/abc/src/base/exor/exorBits.c +0 -425
- data/ext/abc/src/base/exor/exorCubes.c +0 -190
- data/ext/abc/src/base/exor/exorLink.c +0 -749
- data/ext/abc/src/base/exor/exorList.c +0 -1156
- data/ext/abc/src/base/exor/exorUtil.c +0 -228
- data/ext/abc/src/base/exor/module.make +0 -6
- data/ext/abc/src/base/io/io.c +0 -3157
- data/ext/abc/src/base/io/ioAbc.h +0 -172
- data/ext/abc/src/base/io/ioInt.h +0 -57
- data/ext/abc/src/base/io/ioJson.c +0 -270
- data/ext/abc/src/base/io/ioReadAiger.c +0 -599
- data/ext/abc/src/base/io/ioReadBaf.c +0 -177
- data/ext/abc/src/base/io/ioReadBblif.c +0 -348
- data/ext/abc/src/base/io/ioReadBench.c +0 -391
- data/ext/abc/src/base/io/ioReadBlif.c +0 -1707
- data/ext/abc/src/base/io/ioReadBlifAig.c +0 -1019
- data/ext/abc/src/base/io/ioReadBlifMv.c +0 -2363
- data/ext/abc/src/base/io/ioReadDsd.c +0 -313
- data/ext/abc/src/base/io/ioReadEdif.c +0 -240
- data/ext/abc/src/base/io/ioReadEqn.c +0 -244
- data/ext/abc/src/base/io/ioReadPla.c +0 -600
- data/ext/abc/src/base/io/ioReadPlaMo.c +0 -813
- data/ext/abc/src/base/io/ioReadVerilog.c +0 -102
- data/ext/abc/src/base/io/ioUtil.c +0 -871
- data/ext/abc/src/base/io/ioWriteAiger.c +0 -956
- data/ext/abc/src/base/io/ioWriteBaf.c +0 -173
- data/ext/abc/src/base/io/ioWriteBblif.c +0 -116
- data/ext/abc/src/base/io/ioWriteBench.c +0 -340
- data/ext/abc/src/base/io/ioWriteBlif.c +0 -1410
- data/ext/abc/src/base/io/ioWriteBlifMv.c +0 -476
- data/ext/abc/src/base/io/ioWriteBook.c +0 -998
- data/ext/abc/src/base/io/ioWriteCnf.c +0 -120
- data/ext/abc/src/base/io/ioWriteDot.c +0 -854
- data/ext/abc/src/base/io/ioWriteEqn.c +0 -257
- data/ext/abc/src/base/io/ioWriteGml.c +0 -121
- data/ext/abc/src/base/io/ioWriteList.c +0 -293
- data/ext/abc/src/base/io/ioWritePla.c +0 -460
- data/ext/abc/src/base/io/ioWriteSmv.c +0 -265
- data/ext/abc/src/base/io/ioWriteVerilog.c +0 -662
- data/ext/abc/src/base/io/module.make +0 -31
- data/ext/abc/src/base/main/abcapis.h +0 -106
- data/ext/abc/src/base/main/abcapis_old.h +0 -84
- data/ext/abc/src/base/main/libSupport.c +0 -211
- data/ext/abc/src/base/main/main.c +0 -12
- data/ext/abc/src/base/main/main.h +0 -171
- data/ext/abc/src/base/main/mainFrame.c +0 -742
- data/ext/abc/src/base/main/mainInit.c +0 -168
- data/ext/abc/src/base/main/mainInt.h +0 -207
- data/ext/abc/src/base/main/mainLib.c +0 -93
- data/ext/abc/src/base/main/mainMC.c +0 -203
- data/ext/abc/src/base/main/mainReal.c +0 -386
- data/ext/abc/src/base/main/mainUtils.c +0 -294
- data/ext/abc/src/base/main/module.make +0 -7
- data/ext/abc/src/base/pla/module.make +0 -7
- data/ext/abc/src/base/pla/pla.c +0 -52
- data/ext/abc/src/base/pla/pla.h +0 -297
- data/ext/abc/src/base/pla/plaCom.c +0 -507
- data/ext/abc/src/base/pla/plaFxch.c +0 -854
- data/ext/abc/src/base/pla/plaHash.c +0 -347
- data/ext/abc/src/base/pla/plaMan.c +0 -300
- data/ext/abc/src/base/pla/plaMerge.c +0 -55
- data/ext/abc/src/base/pla/plaRead.c +0 -224
- data/ext/abc/src/base/pla/plaSimple.c +0 -339
- data/ext/abc/src/base/pla/plaWrite.c +0 -112
- data/ext/abc/src/base/test/module.make +0 -1
- data/ext/abc/src/base/test/test.c +0 -70
- data/ext/abc/src/base/ver/module.make +0 -4
- data/ext/abc/src/base/ver/ver.h +0 -122
- data/ext/abc/src/base/ver/verCore.c +0 -3037
- data/ext/abc/src/base/ver/verFormula.c +0 -479
- data/ext/abc/src/base/ver/verParse.c +0 -131
- data/ext/abc/src/base/ver/verStream.c +0 -450
- data/ext/abc/src/base/ver/verWords.c +0 -53
- data/ext/abc/src/base/ver/ver_.c +0 -53
- data/ext/abc/src/base/wlc/module.make +0 -17
- data/ext/abc/src/base/wlc/wlc.c +0 -274
- data/ext/abc/src/base/wlc/wlc.h +0 -392
- data/ext/abc/src/base/wlc/wlcAbc.c +0 -275
- data/ext/abc/src/base/wlc/wlcAbs.c +0 -1912
- data/ext/abc/src/base/wlc/wlcAbs2.c +0 -410
- data/ext/abc/src/base/wlc/wlcBlast.c +0 -1692
- data/ext/abc/src/base/wlc/wlcCom.c +0 -1559
- data/ext/abc/src/base/wlc/wlcGraft.c +0 -573
- data/ext/abc/src/base/wlc/wlcJson.c +0 -54
- data/ext/abc/src/base/wlc/wlcNtk.c +0 -1268
- data/ext/abc/src/base/wlc/wlcPth.c +0 -173
- data/ext/abc/src/base/wlc/wlcReadSmt.c +0 -1784
- data/ext/abc/src/base/wlc/wlcReadVer.c +0 -1308
- data/ext/abc/src/base/wlc/wlcShow.c +0 -337
- data/ext/abc/src/base/wlc/wlcSim.c +0 -251
- data/ext/abc/src/base/wlc/wlcStdin.c +0 -255
- data/ext/abc/src/base/wlc/wlcUif.c +0 -290
- data/ext/abc/src/base/wlc/wlcWin.c +0 -166
- data/ext/abc/src/base/wlc/wlcWriteVer.c +0 -450
- data/ext/abc/src/bdd/bbr/bbr.h +0 -93
- data/ext/abc/src/bdd/bbr/bbrCex.c +0 -172
- data/ext/abc/src/bdd/bbr/bbrImage.c +0 -1327
- data/ext/abc/src/bdd/bbr/bbrNtbdd.c +0 -218
- data/ext/abc/src/bdd/bbr/bbrReach.c +0 -615
- data/ext/abc/src/bdd/bbr/bbr_.c +0 -52
- data/ext/abc/src/bdd/bbr/module.make +0 -4
- data/ext/abc/src/bdd/cas/cas.h +0 -66
- data/ext/abc/src/bdd/cas/casCore.c +0 -1265
- data/ext/abc/src/bdd/cas/casDec.c +0 -512
- data/ext/abc/src/bdd/cas/module.make +0 -3
- data/ext/abc/src/bdd/cudd/Makefile +0 -124
- data/ext/abc/src/bdd/cudd/cuBdd.make +0 -41
- data/ext/abc/src/bdd/cudd/cudd.h +0 -1054
- data/ext/abc/src/bdd/cudd/cudd.make +0 -42
- data/ext/abc/src/bdd/cudd/cuddAPI.c +0 -4444
- data/ext/abc/src/bdd/cudd/cuddAddAbs.c +0 -588
- data/ext/abc/src/bdd/cudd/cuddAddApply.c +0 -949
- data/ext/abc/src/bdd/cudd/cuddAddFind.c +0 -316
- data/ext/abc/src/bdd/cudd/cuddAddInv.c +0 -209
- data/ext/abc/src/bdd/cudd/cuddAddIte.c +0 -647
- data/ext/abc/src/bdd/cudd/cuddAddNeg.c +0 -296
- data/ext/abc/src/bdd/cudd/cuddAddWalsh.c +0 -399
- data/ext/abc/src/bdd/cudd/cuddAndAbs.c +0 -384
- data/ext/abc/src/bdd/cudd/cuddAnneal.c +0 -822
- data/ext/abc/src/bdd/cudd/cuddApa.c +0 -979
- data/ext/abc/src/bdd/cudd/cuddApprox.c +0 -2213
- data/ext/abc/src/bdd/cudd/cuddBddAbs.c +0 -725
- data/ext/abc/src/bdd/cudd/cuddBddCorr.c +0 -515
- data/ext/abc/src/bdd/cudd/cuddBddIte.c +0 -1328
- data/ext/abc/src/bdd/cudd/cuddBridge.c +0 -1021
- data/ext/abc/src/bdd/cudd/cuddCache.c +0 -1100
- data/ext/abc/src/bdd/cudd/cuddCheck.c +0 -887
- data/ext/abc/src/bdd/cudd/cuddClip.c +0 -566
- data/ext/abc/src/bdd/cudd/cuddCof.c +0 -335
- data/ext/abc/src/bdd/cudd/cuddCompose.c +0 -1760
- data/ext/abc/src/bdd/cudd/cuddDecomp.c +0 -2185
- data/ext/abc/src/bdd/cudd/cuddEssent.c +0 -1475
- data/ext/abc/src/bdd/cudd/cuddExact.c +0 -1028
- data/ext/abc/src/bdd/cudd/cuddExport.c +0 -1384
- data/ext/abc/src/bdd/cudd/cuddGenCof.c +0 -2175
- data/ext/abc/src/bdd/cudd/cuddGenetic.c +0 -957
- data/ext/abc/src/bdd/cudd/cuddGroup.c +0 -2173
- data/ext/abc/src/bdd/cudd/cuddHarwell.c +0 -576
- data/ext/abc/src/bdd/cudd/cuddInit.c +0 -319
- data/ext/abc/src/bdd/cudd/cuddInt.h +0 -1232
- data/ext/abc/src/bdd/cudd/cuddInteract.c +0 -437
- data/ext/abc/src/bdd/cudd/cuddLCache.c +0 -1465
- data/ext/abc/src/bdd/cudd/cuddLevelQ.c +0 -569
- data/ext/abc/src/bdd/cudd/cuddLinear.c +0 -1373
- data/ext/abc/src/bdd/cudd/cuddLiteral.c +0 -272
- data/ext/abc/src/bdd/cudd/cuddMatMult.c +0 -715
- data/ext/abc/src/bdd/cudd/cuddPriority.c +0 -2035
- data/ext/abc/src/bdd/cudd/cuddRead.c +0 -525
- data/ext/abc/src/bdd/cudd/cuddRef.c +0 -816
- data/ext/abc/src/bdd/cudd/cuddReorder.c +0 -2143
- data/ext/abc/src/bdd/cudd/cuddSat.c +0 -1338
- data/ext/abc/src/bdd/cudd/cuddSign.c +0 -326
- data/ext/abc/src/bdd/cudd/cuddSolve.c +0 -374
- data/ext/abc/src/bdd/cudd/cuddSplit.c +0 -694
- data/ext/abc/src/bdd/cudd/cuddSubsetHB.c +0 -1337
- data/ext/abc/src/bdd/cudd/cuddSubsetSP.c +0 -1657
- data/ext/abc/src/bdd/cudd/cuddSymmetry.c +0 -1706
- data/ext/abc/src/bdd/cudd/cuddTable.c +0 -3179
- data/ext/abc/src/bdd/cudd/cuddUtil.c +0 -3929
- data/ext/abc/src/bdd/cudd/cuddWindow.c +0 -1031
- data/ext/abc/src/bdd/cudd/cuddZddCount.c +0 -357
- data/ext/abc/src/bdd/cudd/cuddZddFuncs.c +0 -1638
- data/ext/abc/src/bdd/cudd/cuddZddGroup.c +0 -1344
- data/ext/abc/src/bdd/cudd/cuddZddIsop.c +0 -919
- data/ext/abc/src/bdd/cudd/cuddZddLin.c +0 -975
- data/ext/abc/src/bdd/cudd/cuddZddMisc.c +0 -286
- data/ext/abc/src/bdd/cudd/cuddZddPort.c +0 -389
- data/ext/abc/src/bdd/cudd/cuddZddReord.c +0 -1668
- data/ext/abc/src/bdd/cudd/cuddZddSetop.c +0 -1166
- data/ext/abc/src/bdd/cudd/cuddZddSymm.c +0 -1707
- data/ext/abc/src/bdd/cudd/cuddZddUtil.c +0 -1071
- data/ext/abc/src/bdd/cudd/license +0 -32
- data/ext/abc/src/bdd/cudd/module.make +0 -61
- data/ext/abc/src/bdd/cudd/r7x8.1.mat +0 -53
- data/ext/abc/src/bdd/cudd/r7x8.1.out +0 -377
- data/ext/abc/src/bdd/cudd/testcudd.c +0 -1073
- data/ext/abc/src/bdd/dsd/dsd.h +0 -134
- data/ext/abc/src/bdd/dsd/dsdApi.c +0 -102
- data/ext/abc/src/bdd/dsd/dsdCheck.c +0 -319
- data/ext/abc/src/bdd/dsd/dsdInt.h +0 -99
- data/ext/abc/src/bdd/dsd/dsdLocal.c +0 -342
- data/ext/abc/src/bdd/dsd/dsdMan.c +0 -119
- data/ext/abc/src/bdd/dsd/dsdProc.c +0 -1613
- data/ext/abc/src/bdd/dsd/dsdTree.c +0 -1181
- data/ext/abc/src/bdd/dsd/module.make +0 -6
- data/ext/abc/src/bdd/epd/epd.c +0 -1347
- data/ext/abc/src/bdd/epd/epd.h +0 -196
- data/ext/abc/src/bdd/epd/module.make +0 -1
- data/ext/abc/src/bdd/extrab/extraBdd.h +0 -317
- data/ext/abc/src/bdd/extrab/extraBddAuto.c +0 -1563
- data/ext/abc/src/bdd/extrab/extraBddCas.c +0 -1235
- data/ext/abc/src/bdd/extrab/extraBddImage.c +0 -1162
- data/ext/abc/src/bdd/extrab/extraBddKmap.c +0 -876
- data/ext/abc/src/bdd/extrab/extraBddMisc.c +0 -2591
- data/ext/abc/src/bdd/extrab/extraBddSymm.c +0 -1474
- data/ext/abc/src/bdd/extrab/extraBddThresh.c +0 -693
- data/ext/abc/src/bdd/extrab/extraBddTime.c +0 -660
- data/ext/abc/src/bdd/extrab/extraBddUnate.c +0 -646
- data/ext/abc/src/bdd/extrab/module.make +0 -9
- data/ext/abc/src/bdd/llb/llb.c +0 -52
- data/ext/abc/src/bdd/llb/llb.h +0 -96
- data/ext/abc/src/bdd/llb/llb1Cluster.c +0 -356
- data/ext/abc/src/bdd/llb/llb1Constr.c +0 -313
- data/ext/abc/src/bdd/llb/llb1Core.c +0 -222
- data/ext/abc/src/bdd/llb/llb1Group.c +0 -474
- data/ext/abc/src/bdd/llb/llb1Hint.c +0 -226
- data/ext/abc/src/bdd/llb/llb1Man.c +0 -218
- data/ext/abc/src/bdd/llb/llb1Matrix.c +0 -430
- data/ext/abc/src/bdd/llb/llb1Pivot.c +0 -254
- data/ext/abc/src/bdd/llb/llb1Reach.c +0 -904
- data/ext/abc/src/bdd/llb/llb1Sched.c +0 -257
- data/ext/abc/src/bdd/llb/llb2Bad.c +0 -138
- data/ext/abc/src/bdd/llb/llb2Core.c +0 -777
- data/ext/abc/src/bdd/llb/llb2Driver.c +0 -222
- data/ext/abc/src/bdd/llb/llb2Dump.c +0 -104
- data/ext/abc/src/bdd/llb/llb2Flow.c +0 -1376
- data/ext/abc/src/bdd/llb/llb2Image.c +0 -482
- data/ext/abc/src/bdd/llb/llb3Image.c +0 -1095
- data/ext/abc/src/bdd/llb/llb3Nonlin.c +0 -872
- data/ext/abc/src/bdd/llb/llb4Cex.c +0 -320
- data/ext/abc/src/bdd/llb/llb4Cluster.c +0 -452
- data/ext/abc/src/bdd/llb/llb4Image.c +0 -863
- data/ext/abc/src/bdd/llb/llb4Map.c +0 -123
- data/ext/abc/src/bdd/llb/llb4Nonlin.c +0 -1185
- data/ext/abc/src/bdd/llb/llb4Sweep.c +0 -589
- data/ext/abc/src/bdd/llb/llbInt.h +0 -212
- data/ext/abc/src/bdd/llb/module.make +0 -22
- data/ext/abc/src/bdd/mtr/module.make +0 -2
- data/ext/abc/src/bdd/mtr/mtr.h +0 -187
- data/ext/abc/src/bdd/mtr/mtrBasic.c +0 -453
- data/ext/abc/src/bdd/mtr/mtrGroup.c +0 -734
- data/ext/abc/src/bdd/mtr/mtrInt.h +0 -94
- data/ext/abc/src/bdd/reo/module.make +0 -8
- data/ext/abc/src/bdd/reo/reo.h +0 -234
- data/ext/abc/src/bdd/reo/reoApi.c +0 -294
- data/ext/abc/src/bdd/reo/reoCore.c +0 -441
- data/ext/abc/src/bdd/reo/reoProfile.c +0 -370
- data/ext/abc/src/bdd/reo/reoShuffle.c +0 -230
- data/ext/abc/src/bdd/reo/reoSift.c +0 -346
- data/ext/abc/src/bdd/reo/reoSwap.c +0 -905
- data/ext/abc/src/bdd/reo/reoTest.c +0 -256
- data/ext/abc/src/bdd/reo/reoTransfer.c +0 -206
- data/ext/abc/src/bdd/reo/reoUnits.c +0 -190
- data/ext/abc/src/bool/bdc/bdc.h +0 -98
- data/ext/abc/src/bool/bdc/bdcCore.c +0 -374
- data/ext/abc/src/bool/bdc/bdcDec.c +0 -751
- data/ext/abc/src/bool/bdc/bdcInt.h +0 -165
- data/ext/abc/src/bool/bdc/bdcSpfd.c +0 -1184
- data/ext/abc/src/bool/bdc/bdcTable.c +0 -134
- data/ext/abc/src/bool/bdc/bdc_.c +0 -54
- data/ext/abc/src/bool/bdc/module.make +0 -5
- data/ext/abc/src/bool/dec/dec.h +0 -725
- data/ext/abc/src/bool/dec/decAbc.c +0 -358
- data/ext/abc/src/bool/dec/decFactor.c +0 -403
- data/ext/abc/src/bool/dec/decMan.c +0 -88
- data/ext/abc/src/bool/dec/decPrint.c +0 -289
- data/ext/abc/src/bool/dec/decUtil.c +0 -148
- data/ext/abc/src/bool/dec/module.make +0 -5
- data/ext/abc/src/bool/deco/deco.h +0 -714
- data/ext/abc/src/bool/deco/module.make +0 -1
- data/ext/abc/src/bool/kit/cloud.c +0 -993
- data/ext/abc/src/bool/kit/cloud.h +0 -254
- data/ext/abc/src/bool/kit/kit.h +0 -655
- data/ext/abc/src/bool/kit/kitAig.c +0 -126
- data/ext/abc/src/bool/kit/kitBdd.c +0 -243
- data/ext/abc/src/bool/kit/kitCloud.c +0 -378
- data/ext/abc/src/bool/kit/kitDec.c +0 -343
- data/ext/abc/src/bool/kit/kitDsd.c +0 -3285
- data/ext/abc/src/bool/kit/kitFactor.c +0 -344
- data/ext/abc/src/bool/kit/kitGraph.c +0 -402
- data/ext/abc/src/bool/kit/kitHop.c +0 -200
- data/ext/abc/src/bool/kit/kitIsop.c +0 -365
- data/ext/abc/src/bool/kit/kitPerm.c +0 -357
- data/ext/abc/src/bool/kit/kitPla.c +0 -535
- data/ext/abc/src/bool/kit/kitSop.c +0 -579
- data/ext/abc/src/bool/kit/kitTruth.c +0 -2224
- data/ext/abc/src/bool/kit/kit_.c +0 -53
- data/ext/abc/src/bool/kit/module.make +0 -11
- data/ext/abc/src/bool/lucky/lucky.c +0 -705
- data/ext/abc/src/bool/lucky/lucky.h +0 -44
- data/ext/abc/src/bool/lucky/luckyFast16.c +0 -872
- data/ext/abc/src/bool/lucky/luckyFast6.c +0 -285
- data/ext/abc/src/bool/lucky/luckyInt.h +0 -136
- data/ext/abc/src/bool/lucky/luckyRead.c +0 -333
- data/ext/abc/src/bool/lucky/luckySimple.c +0 -307
- data/ext/abc/src/bool/lucky/luckySwap.c +0 -402
- data/ext/abc/src/bool/lucky/luckySwapIJ.c +0 -102
- data/ext/abc/src/bool/lucky/module.make +0 -7
- data/ext/abc/src/bool/rpo/literal.h +0 -297
- data/ext/abc/src/bool/rpo/module.make +0 -1
- data/ext/abc/src/bool/rpo/rpo.c +0 -383
- data/ext/abc/src/bool/rpo/rpo.h +0 -61
- data/ext/abc/src/bool/rsb/module.make +0 -2
- data/ext/abc/src/bool/rsb/rsb.h +0 -65
- data/ext/abc/src/bool/rsb/rsbDec6.c +0 -770
- data/ext/abc/src/bool/rsb/rsbInt.h +0 -84
- data/ext/abc/src/bool/rsb/rsbMan.c +0 -99
- data/ext/abc/src/demo.c +0 -181
- data/ext/abc/src/generic.c +0 -52
- data/ext/abc/src/generic.h +0 -63
- data/ext/abc/src/map/amap/amap.h +0 -97
- data/ext/abc/src/map/amap/amapCore.c +0 -110
- data/ext/abc/src/map/amap/amapGraph.c +0 -399
- data/ext/abc/src/map/amap/amapInt.h +0 -376
- data/ext/abc/src/map/amap/amapLib.c +0 -374
- data/ext/abc/src/map/amap/amapLiberty.c +0 -1103
- data/ext/abc/src/map/amap/amapMan.c +0 -104
- data/ext/abc/src/map/amap/amapMatch.c +0 -622
- data/ext/abc/src/map/amap/amapMerge.c +0 -541
- data/ext/abc/src/map/amap/amapOutput.c +0 -186
- data/ext/abc/src/map/amap/amapParse.c +0 -480
- data/ext/abc/src/map/amap/amapPerm.c +0 -380
- data/ext/abc/src/map/amap/amapRead.c +0 -494
- data/ext/abc/src/map/amap/amapRule.c +0 -462
- data/ext/abc/src/map/amap/amapUniq.c +0 -317
- data/ext/abc/src/map/amap/module.make +0 -13
- data/ext/abc/src/map/cov/cov.h +0 -109
- data/ext/abc/src/map/cov/covBuild.c +0 -544
- data/ext/abc/src/map/cov/covCore.c +0 -1030
- data/ext/abc/src/map/cov/covInt.h +0 -654
- data/ext/abc/src/map/cov/covMan.c +0 -149
- data/ext/abc/src/map/cov/covMinEsop.c +0 -304
- data/ext/abc/src/map/cov/covMinMan.c +0 -118
- data/ext/abc/src/map/cov/covMinSop.c +0 -620
- data/ext/abc/src/map/cov/covMinUtil.c +0 -343
- data/ext/abc/src/map/cov/covTest.c +0 -422
- data/ext/abc/src/map/cov/module.make +0 -7
- data/ext/abc/src/map/fpga/fpga.c +0 -288
- data/ext/abc/src/map/fpga/fpga.h +0 -175
- data/ext/abc/src/map/fpga/fpgaCore.c +0 -194
- data/ext/abc/src/map/fpga/fpgaCreate.c +0 -584
- data/ext/abc/src/map/fpga/fpgaCut.c +0 -1186
- data/ext/abc/src/map/fpga/fpgaCutUtils.c +0 -476
- data/ext/abc/src/map/fpga/fpgaFanout.c +0 -146
- data/ext/abc/src/map/fpga/fpgaGENERIC.c +0 -51
- data/ext/abc/src/map/fpga/fpgaInt.h +0 -389
- data/ext/abc/src/map/fpga/fpgaLib.c +0 -255
- data/ext/abc/src/map/fpga/fpgaMatch.c +0 -800
- data/ext/abc/src/map/fpga/fpgaSwitch.c +0 -156
- data/ext/abc/src/map/fpga/fpgaTime.c +0 -267
- data/ext/abc/src/map/fpga/fpgaTruth.c +0 -171
- data/ext/abc/src/map/fpga/fpgaUtils.c +0 -990
- data/ext/abc/src/map/fpga/fpgaVec.c +0 -413
- data/ext/abc/src/map/fpga/module.make +0 -13
- data/ext/abc/src/map/if/if.h +0 -689
- data/ext/abc/src/map/if/ifCache.c +0 -100
- data/ext/abc/src/map/if/ifCheck.c +0 -204
- data/ext/abc/src/map/if/ifCom.c +0 -372
- data/ext/abc/src/map/if/ifCore.c +0 -200
- data/ext/abc/src/map/if/ifCount.h +0 -521
- data/ext/abc/src/map/if/ifCut.c +0 -1479
- data/ext/abc/src/map/if/ifData2.c +0 -52
- data/ext/abc/src/map/if/ifDec07.c +0 -1125
- data/ext/abc/src/map/if/ifDec08.c +0 -507
- data/ext/abc/src/map/if/ifDec10.c +0 -506
- data/ext/abc/src/map/if/ifDec16.c +0 -2374
- data/ext/abc/src/map/if/ifDec75.c +0 -341
- data/ext/abc/src/map/if/ifDelay.c +0 -447
- data/ext/abc/src/map/if/ifDsd.c +0 -2838
- data/ext/abc/src/map/if/ifLibBox.c +0 -401
- data/ext/abc/src/map/if/ifLibLut.c +0 -505
- data/ext/abc/src/map/if/ifMan.c +0 -720
- data/ext/abc/src/map/if/ifMap.c +0 -680
- data/ext/abc/src/map/if/ifMatch2.c +0 -62
- data/ext/abc/src/map/if/ifReduce.c +0 -466
- data/ext/abc/src/map/if/ifSat.c +0 -548
- data/ext/abc/src/map/if/ifSelect.c +0 -601
- data/ext/abc/src/map/if/ifSeq.c +0 -397
- data/ext/abc/src/map/if/ifTest.c +0 -352
- data/ext/abc/src/map/if/ifTime.c +0 -525
- data/ext/abc/src/map/if/ifTruth.c +0 -339
- data/ext/abc/src/map/if/ifTune.c +0 -1452
- data/ext/abc/src/map/if/ifUtil.c +0 -632
- data/ext/abc/src/map/if/if_.c +0 -52
- data/ext/abc/src/map/if/module.make +0 -26
- data/ext/abc/src/map/mapper/mapper.c +0 -185
- data/ext/abc/src/map/mapper/mapper.h +0 -201
- data/ext/abc/src/map/mapper/mapperCanon.c +0 -277
- data/ext/abc/src/map/mapper/mapperCore.c +0 -231
- data/ext/abc/src/map/mapper/mapperCreate.c +0 -587
- data/ext/abc/src/map/mapper/mapperCut.c +0 -1178
- data/ext/abc/src/map/mapper/mapperCutUtils.c +0 -279
- data/ext/abc/src/map/mapper/mapperFanout.c +0 -146
- data/ext/abc/src/map/mapper/mapperInt.h +0 -469
- data/ext/abc/src/map/mapper/mapperLib.c +0 -258
- data/ext/abc/src/map/mapper/mapperMatch.c +0 -664
- data/ext/abc/src/map/mapper/mapperRefs.c +0 -540
- data/ext/abc/src/map/mapper/mapperSuper.c +0 -456
- data/ext/abc/src/map/mapper/mapperSwitch.c +0 -229
- data/ext/abc/src/map/mapper/mapperTable.c +0 -407
- data/ext/abc/src/map/mapper/mapperTime.c +0 -459
- data/ext/abc/src/map/mapper/mapperTree.c +0 -1042
- data/ext/abc/src/map/mapper/mapperTruth.c +0 -315
- data/ext/abc/src/map/mapper/mapperUtils.c +0 -898
- data/ext/abc/src/map/mapper/mapperVec.c +0 -344
- data/ext/abc/src/map/mapper/module.make +0 -17
- data/ext/abc/src/map/mio/exp.h +0 -343
- data/ext/abc/src/map/mio/mio.c +0 -728
- data/ext/abc/src/map/mio/mio.h +0 -242
- data/ext/abc/src/map/mio/mioApi.c +0 -254
- data/ext/abc/src/map/mio/mioForm.c +0 -307
- data/ext/abc/src/map/mio/mioFunc.c +0 -327
- data/ext/abc/src/map/mio/mioInt.h +0 -160
- data/ext/abc/src/map/mio/mioParse.c +0 -504
- data/ext/abc/src/map/mio/mioRead.c +0 -780
- data/ext/abc/src/map/mio/mioSop.c +0 -333
- data/ext/abc/src/map/mio/mioUtils.c +0 -1752
- data/ext/abc/src/map/mio/module.make +0 -7
- data/ext/abc/src/map/mpm/module.make +0 -11
- data/ext/abc/src/map/mpm/mpm.c +0 -55
- data/ext/abc/src/map/mpm/mpm.h +0 -98
- data/ext/abc/src/map/mpm/mpmAbc.c +0 -350
- data/ext/abc/src/map/mpm/mpmCore.c +0 -115
- data/ext/abc/src/map/mpm/mpmDsd.c +0 -1055
- data/ext/abc/src/map/mpm/mpmGates.c +0 -307
- data/ext/abc/src/map/mpm/mpmInt.h +0 -265
- data/ext/abc/src/map/mpm/mpmLib.c +0 -74
- data/ext/abc/src/map/mpm/mpmMan.c +0 -207
- data/ext/abc/src/map/mpm/mpmMap.c +0 -872
- data/ext/abc/src/map/mpm/mpmMig.c +0 -204
- data/ext/abc/src/map/mpm/mpmMig.h +0 -358
- data/ext/abc/src/map/mpm/mpmPre.c +0 -1029
- data/ext/abc/src/map/mpm/mpmTruth.c +0 -239
- data/ext/abc/src/map/mpm/mpmUtil.c +0 -52
- data/ext/abc/src/map/scl/module.make +0 -11
- data/ext/abc/src/map/scl/scl.c +0 -2042
- data/ext/abc/src/map/scl/scl.h +0 -58
- data/ext/abc/src/map/scl/sclBufSize.c +0 -518
- data/ext/abc/src/map/scl/sclBuffer.c +0 -1010
- data/ext/abc/src/map/scl/sclCon.h +0 -293
- data/ext/abc/src/map/scl/sclDnsize.c +0 -378
- data/ext/abc/src/map/scl/sclLib.h +0 -770
- data/ext/abc/src/map/scl/sclLibScl.c +0 -848
- data/ext/abc/src/map/scl/sclLibUtil.c +0 -1078
- data/ext/abc/src/map/scl/sclLiberty.c +0 -1697
- data/ext/abc/src/map/scl/sclLoad.c +0 -238
- data/ext/abc/src/map/scl/sclSize.c +0 -915
- data/ext/abc/src/map/scl/sclSize.h +0 -594
- data/ext/abc/src/map/scl/sclTime.h +0 -234
- data/ext/abc/src/map/scl/sclUpsize.c +0 -1045
- data/ext/abc/src/map/scl/sclUtil.c +0 -320
- data/ext/abc/src/map/super/module.make +0 -3
- data/ext/abc/src/map/super/super.c +0 -333
- data/ext/abc/src/map/super/super.h +0 -62
- data/ext/abc/src/map/super/superAnd.c +0 -701
- data/ext/abc/src/map/super/superGENERIC.c +0 -51
- data/ext/abc/src/map/super/superGate.c +0 -1473
- data/ext/abc/src/map/super/superInt.h +0 -64
- data/ext/abc/src/map/super/superWrite.c +0 -81
- data/ext/abc/src/misc/avl/avl.c +0 -621
- data/ext/abc/src/misc/avl/avl.doc +0 -166
- data/ext/abc/src/misc/avl/avl.h +0 -91
- data/ext/abc/src/misc/bar/bar.c +0 -193
- data/ext/abc/src/misc/bar/bar.h +0 -78
- data/ext/abc/src/misc/bar/module.make +0 -1
- data/ext/abc/src/misc/bbl/bblif.c +0 -1518
- data/ext/abc/src/misc/bbl/bblif.h +0 -285
- data/ext/abc/src/misc/bbl/module.make +0 -1
- data/ext/abc/src/misc/bzlib/CHANGES +0 -319
- data/ext/abc/src/misc/bzlib/LICENSE +0 -42
- data/ext/abc/src/misc/bzlib/blocksort.c +0 -1098
- data/ext/abc/src/misc/bzlib/bzip2.txt +0 -391
- data/ext/abc/src/misc/bzlib/bzlib.c +0 -1588
- data/ext/abc/src/misc/bzlib/bzlib.h +0 -287
- data/ext/abc/src/misc/bzlib/bzlib_private.h +0 -513
- data/ext/abc/src/misc/bzlib/compress.c +0 -677
- data/ext/abc/src/misc/bzlib/crctable.c +0 -109
- data/ext/abc/src/misc/bzlib/decompress.c +0 -631
- data/ext/abc/src/misc/bzlib/huffman.c +0 -210
- data/ext/abc/src/misc/bzlib/link.txt +0 -2
- data/ext/abc/src/misc/bzlib/manual.html +0 -2540
- data/ext/abc/src/misc/bzlib/module.make +0 -7
- data/ext/abc/src/misc/bzlib/randtable.c +0 -89
- data/ext/abc/src/misc/espresso/cofactor.c +0 -389
- data/ext/abc/src/misc/espresso/cols.c +0 -319
- data/ext/abc/src/misc/espresso/compl.c +0 -685
- data/ext/abc/src/misc/espresso/contain.c +0 -450
- data/ext/abc/src/misc/espresso/cubehack.c +0 -143
- data/ext/abc/src/misc/espresso/cubestr.c +0 -157
- data/ext/abc/src/misc/espresso/cvrin.c +0 -816
- data/ext/abc/src/misc/espresso/cvrm.c +0 -544
- data/ext/abc/src/misc/espresso/cvrmisc.c +0 -147
- data/ext/abc/src/misc/espresso/cvrout.c +0 -614
- data/ext/abc/src/misc/espresso/dominate.c +0 -103
- data/ext/abc/src/misc/espresso/equiv.c +0 -99
- data/ext/abc/src/misc/espresso/espresso.c +0 -144
- data/ext/abc/src/misc/espresso/espresso.h +0 -786
- data/ext/abc/src/misc/espresso/essen.c +0 -184
- data/ext/abc/src/misc/espresso/exact.c +0 -186
- data/ext/abc/src/misc/espresso/expand.c +0 -700
- data/ext/abc/src/misc/espresso/gasp.c +0 -233
- data/ext/abc/src/misc/espresso/gimpel.c +0 -112
- data/ext/abc/src/misc/espresso/globals.c +0 -81
- data/ext/abc/src/misc/espresso/hack.c +0 -646
- data/ext/abc/src/misc/espresso/indep.c +0 -139
- data/ext/abc/src/misc/espresso/irred.c +0 -445
- data/ext/abc/src/misc/espresso/main.c +0 -751
- data/ext/abc/src/misc/espresso/main.h +0 -122
- data/ext/abc/src/misc/espresso/map.c +0 -122
- data/ext/abc/src/misc/espresso/matrix.c +0 -579
- data/ext/abc/src/misc/espresso/mincov.c +0 -383
- data/ext/abc/src/misc/espresso/mincov.h +0 -11
- data/ext/abc/src/misc/espresso/mincov_int.h +0 -55
- data/ext/abc/src/misc/espresso/module.make +0 -39
- data/ext/abc/src/misc/espresso/opo.c +0 -629
- data/ext/abc/src/misc/espresso/pair.c +0 -685
- data/ext/abc/src/misc/espresso/part.c +0 -127
- data/ext/abc/src/misc/espresso/primes.c +0 -175
- data/ext/abc/src/misc/espresso/reduce.c +0 -263
- data/ext/abc/src/misc/espresso/rows.c +0 -319
- data/ext/abc/src/misc/espresso/set.c +0 -825
- data/ext/abc/src/misc/espresso/setc.c +0 -488
- data/ext/abc/src/misc/espresso/sharp.c +0 -252
- data/ext/abc/src/misc/espresso/sminterf.c +0 -49
- data/ext/abc/src/misc/espresso/solution.c +0 -119
- data/ext/abc/src/misc/espresso/sparse.c +0 -151
- data/ext/abc/src/misc/espresso/sparse.h +0 -143
- data/ext/abc/src/misc/espresso/sparse_int.h +0 -121
- data/ext/abc/src/misc/espresso/unate.c +0 -446
- data/ext/abc/src/misc/espresso/util_old.h +0 -309
- data/ext/abc/src/misc/espresso/verify.c +0 -198
- data/ext/abc/src/misc/extra/extra.h +0 -417
- data/ext/abc/src/misc/extra/extraUtilBitMatrix.c +0 -420
- data/ext/abc/src/misc/extra/extraUtilCanon.c +0 -691
- data/ext/abc/src/misc/extra/extraUtilCube.c +0 -279
- data/ext/abc/src/misc/extra/extraUtilDsd.c +0 -1271
- data/ext/abc/src/misc/extra/extraUtilEnum.c +0 -680
- data/ext/abc/src/misc/extra/extraUtilFile.c +0 -887
- data/ext/abc/src/misc/extra/extraUtilMemory.c +0 -628
- data/ext/abc/src/misc/extra/extraUtilMisc.c +0 -2580
- data/ext/abc/src/misc/extra/extraUtilPerm.c +0 -933
- data/ext/abc/src/misc/extra/extraUtilPrime.c +0 -602
- data/ext/abc/src/misc/extra/extraUtilProgress.c +0 -185
- data/ext/abc/src/misc/extra/extraUtilReader.c +0 -390
- data/ext/abc/src/misc/extra/extraUtilSupp.c +0 -532
- data/ext/abc/src/misc/extra/extraUtilTruth.c +0 -1153
- data/ext/abc/src/misc/extra/extraUtilUtil.c +0 -421
- data/ext/abc/src/misc/extra/extraZddTrunc.c +0 -338
- data/ext/abc/src/misc/extra/module.make +0 -14
- data/ext/abc/src/misc/hash/hash.h +0 -70
- data/ext/abc/src/misc/hash/hashFlt.h +0 -339
- data/ext/abc/src/misc/hash/hashGen.h +0 -367
- data/ext/abc/src/misc/hash/hashInt.h +0 -302
- data/ext/abc/src/misc/hash/hashPtr.h +0 -339
- data/ext/abc/src/misc/hash/module.make +0 -1
- data/ext/abc/src/misc/mem/mem.c +0 -605
- data/ext/abc/src/misc/mem/mem.h +0 -75
- data/ext/abc/src/misc/mem/mem2.h +0 -271
- data/ext/abc/src/misc/mem/module.make +0 -1
- data/ext/abc/src/misc/mvc/module.make +0 -15
- data/ext/abc/src/misc/mvc/mvc.c +0 -51
- data/ext/abc/src/misc/mvc/mvc.h +0 -739
- data/ext/abc/src/misc/mvc/mvcApi.c +0 -238
- data/ext/abc/src/misc/mvc/mvcCompare.c +0 -374
- data/ext/abc/src/misc/mvc/mvcContain.c +0 -178
- data/ext/abc/src/misc/mvc/mvcCover.c +0 -256
- data/ext/abc/src/misc/mvc/mvcCube.c +0 -180
- data/ext/abc/src/misc/mvc/mvcDivide.c +0 -442
- data/ext/abc/src/misc/mvc/mvcDivisor.c +0 -95
- data/ext/abc/src/misc/mvc/mvcList.c +0 -367
- data/ext/abc/src/misc/mvc/mvcLits.c +0 -350
- data/ext/abc/src/misc/mvc/mvcMan.c +0 -82
- data/ext/abc/src/misc/mvc/mvcOpAlg.c +0 -168
- data/ext/abc/src/misc/mvc/mvcOpBool.c +0 -156
- data/ext/abc/src/misc/mvc/mvcPrint.c +0 -225
- data/ext/abc/src/misc/mvc/mvcSort.c +0 -146
- data/ext/abc/src/misc/mvc/mvcUtils.c +0 -873
- data/ext/abc/src/misc/nm/module.make +0 -2
- data/ext/abc/src/misc/nm/nm.h +0 -96
- data/ext/abc/src/misc/nm/nmApi.c +0 -278
- data/ext/abc/src/misc/nm/nmInt.h +0 -94
- data/ext/abc/src/misc/nm/nmTable.c +0 -310
- data/ext/abc/src/misc/parse/module.make +0 -2
- data/ext/abc/src/misc/parse/parse.h +0 -62
- data/ext/abc/src/misc/parse/parseCore.c +0 -536
- data/ext/abc/src/misc/parse/parseEqn.c +0 -362
- data/ext/abc/src/misc/parse/parseInt.h +0 -77
- data/ext/abc/src/misc/parse/parseStack.c +0 -248
- data/ext/abc/src/misc/st/module.make +0 -2
- data/ext/abc/src/misc/st/st.c +0 -561
- data/ext/abc/src/misc/st/st.h +0 -121
- data/ext/abc/src/misc/st/stmm.c +0 -627
- data/ext/abc/src/misc/st/stmm.h +0 -147
- data/ext/abc/src/misc/tim/module.make +0 -5
- data/ext/abc/src/misc/tim/tim.c +0 -39
- data/ext/abc/src/misc/tim/tim.h +0 -184
- data/ext/abc/src/misc/tim/timBox.c +0 -326
- data/ext/abc/src/misc/tim/timDump.c +0 -201
- data/ext/abc/src/misc/tim/timInt.h +0 -148
- data/ext/abc/src/misc/tim/timMan.c +0 -807
- data/ext/abc/src/misc/tim/timTime.c +0 -267
- data/ext/abc/src/misc/tim/timTrav.c +0 -185
- data/ext/abc/src/misc/util/abc_global.h +0 -416
- data/ext/abc/src/misc/util/abc_namespaces.h +0 -58
- data/ext/abc/src/misc/util/module.make +0 -8
- data/ext/abc/src/misc/util/utilBridge.c +0 -564
- data/ext/abc/src/misc/util/utilCex.c +0 -574
- data/ext/abc/src/misc/util/utilCex.h +0 -84
- data/ext/abc/src/misc/util/utilColor.c +0 -124
- data/ext/abc/src/misc/util/utilDouble.h +0 -222
- data/ext/abc/src/misc/util/utilFile.c +0 -221
- data/ext/abc/src/misc/util/utilFloat.h +0 -226
- data/ext/abc/src/misc/util/utilIsop.c +0 -1139
- data/ext/abc/src/misc/util/utilMem.c +0 -341
- data/ext/abc/src/misc/util/utilMem.h +0 -73
- data/ext/abc/src/misc/util/utilNam.c +0 -622
- data/ext/abc/src/misc/util/utilNam.h +0 -80
- data/ext/abc/src/misc/util/utilSignal.c +0 -68
- data/ext/abc/src/misc/util/utilSignal.h +0 -58
- data/ext/abc/src/misc/util/utilSort.c +0 -789
- data/ext/abc/src/misc/util/utilTruth.h +0 -3076
- data/ext/abc/src/misc/util/util_hack.h +0 -46
- data/ext/abc/src/misc/vec/module.make +0 -1
- data/ext/abc/src/misc/vec/vec.h +0 -74
- data/ext/abc/src/misc/vec/vecAtt.h +0 -298
- data/ext/abc/src/misc/vec/vecBit.h +0 -636
- data/ext/abc/src/misc/vec/vecFlt.h +0 -826
- data/ext/abc/src/misc/vec/vecHash.h +0 -280
- data/ext/abc/src/misc/vec/vecHsh.h +0 -590
- data/ext/abc/src/misc/vec/vecInt.h +0 -2078
- data/ext/abc/src/misc/vec/vecMem.h +0 -431
- data/ext/abc/src/misc/vec/vecPtr.h +0 -1160
- data/ext/abc/src/misc/vec/vecQue.h +0 -374
- data/ext/abc/src/misc/vec/vecSet.h +0 -299
- data/ext/abc/src/misc/vec/vecStr.h +0 -1072
- data/ext/abc/src/misc/vec/vecVec.h +0 -646
- data/ext/abc/src/misc/vec/vecWec.h +0 -738
- data/ext/abc/src/misc/vec/vecWrd.h +0 -1205
- data/ext/abc/src/misc/zlib/README +0 -115
- data/ext/abc/src/misc/zlib/adler32.c +0 -168
- data/ext/abc/src/misc/zlib/algorithm.txt +0 -209
- data/ext/abc/src/misc/zlib/compress_.c +0 -76
- data/ext/abc/src/misc/zlib/crc32.c +0 -433
- data/ext/abc/src/misc/zlib/crc32.h +0 -445
- data/ext/abc/src/misc/zlib/deflate.c +0 -1784
- data/ext/abc/src/misc/zlib/deflate.h +0 -346
- data/ext/abc/src/misc/zlib/gzclose.c +0 -33
- data/ext/abc/src/misc/zlib/gzguts.h +0 -147
- data/ext/abc/src/misc/zlib/gzlib.c +0 -517
- data/ext/abc/src/misc/zlib/gzread.c +0 -641
- data/ext/abc/src/misc/zlib/gzwrite.c +0 -520
- data/ext/abc/src/misc/zlib/infback.c +0 -631
- data/ext/abc/src/misc/zlib/inffast.c +0 -351
- data/ext/abc/src/misc/zlib/inffast.h +0 -15
- data/ext/abc/src/misc/zlib/inffixed.h +0 -98
- data/ext/abc/src/misc/zlib/inflate.c +0 -1457
- data/ext/abc/src/misc/zlib/inflate.h +0 -126
- data/ext/abc/src/misc/zlib/inftrees.c +0 -337
- data/ext/abc/src/misc/zlib/inftrees.h +0 -66
- data/ext/abc/src/misc/zlib/license +0 -31
- data/ext/abc/src/misc/zlib/link.txt +0 -1
- data/ext/abc/src/misc/zlib/module.make +0 -15
- data/ext/abc/src/misc/zlib/trees.c +0 -1216
- data/ext/abc/src/misc/zlib/trees.h +0 -132
- data/ext/abc/src/misc/zlib/uncompr.c +0 -67
- data/ext/abc/src/misc/zlib/zconf.h +0 -432
- data/ext/abc/src/misc/zlib/zlib.h +0 -1619
- data/ext/abc/src/misc/zlib/zutil.c +0 -318
- data/ext/abc/src/misc/zlib/zutil.h +0 -288
- data/ext/abc/src/opt/cgt/cgt.h +0 -87
- data/ext/abc/src/opt/cgt/cgtAig.c +0 -601
- data/ext/abc/src/opt/cgt/cgtCore.c +0 -328
- data/ext/abc/src/opt/cgt/cgtDecide.c +0 -300
- data/ext/abc/src/opt/cgt/cgtInt.h +0 -123
- data/ext/abc/src/opt/cgt/cgtMan.c +0 -179
- data/ext/abc/src/opt/cgt/cgtSat.c +0 -98
- data/ext/abc/src/opt/cgt/module.make +0 -5
- data/ext/abc/src/opt/csw/csw.h +0 -69
- data/ext/abc/src/opt/csw/cswCore.c +0 -100
- data/ext/abc/src/opt/csw/cswCut.c +0 -608
- data/ext/abc/src/opt/csw/cswInt.h +0 -160
- data/ext/abc/src/opt/csw/cswMan.c +0 -130
- data/ext/abc/src/opt/csw/cswTable.c +0 -166
- data/ext/abc/src/opt/csw/csw_.c +0 -53
- data/ext/abc/src/opt/csw/module.make +0 -4
- data/ext/abc/src/opt/cut/abcCut.c +0 -498
- data/ext/abc/src/opt/cut/cut.h +0 -172
- data/ext/abc/src/opt/cut/cutApi.c +0 -202
- data/ext/abc/src/opt/cut/cutCut.c +0 -364
- data/ext/abc/src/opt/cut/cutExpand.c +0 -189
- data/ext/abc/src/opt/cut/cutInt.h +0 -165
- data/ext/abc/src/opt/cut/cutList.h +0 -215
- data/ext/abc/src/opt/cut/cutMan.c +0 -320
- data/ext/abc/src/opt/cut/cutMerge.c +0 -662
- data/ext/abc/src/opt/cut/cutNode.c +0 -1004
- data/ext/abc/src/opt/cut/cutOracle.c +0 -424
- data/ext/abc/src/opt/cut/cutPre22.c +0 -994
- data/ext/abc/src/opt/cut/cutSeq.c +0 -232
- data/ext/abc/src/opt/cut/cutTruth.c +0 -232
- data/ext/abc/src/opt/cut/module.make +0 -9
- data/ext/abc/src/opt/dar/dar.h +0 -116
- data/ext/abc/src/opt/dar/darBalance.c +0 -761
- data/ext/abc/src/opt/dar/darCore.c +0 -348
- data/ext/abc/src/opt/dar/darCut.c +0 -837
- data/ext/abc/src/opt/dar/darData.c +0 -11294
- data/ext/abc/src/opt/dar/darInt.h +0 -169
- data/ext/abc/src/opt/dar/darLib.c +0 -1341
- data/ext/abc/src/opt/dar/darMan.c +0 -174
- data/ext/abc/src/opt/dar/darPrec.c +0 -394
- data/ext/abc/src/opt/dar/darRefact.c +0 -639
- data/ext/abc/src/opt/dar/darResub.c +0 -53
- data/ext/abc/src/opt/dar/darScript.c +0 -911
- data/ext/abc/src/opt/dar/dar_.c +0 -53
- data/ext/abc/src/opt/dar/module.make +0 -9
- data/ext/abc/src/opt/dau/dau.c +0 -53
- data/ext/abc/src/opt/dau/dau.h +0 -125
- data/ext/abc/src/opt/dau/dauArray.c +0 -257
- data/ext/abc/src/opt/dau/dauCanon.c +0 -1202
- data/ext/abc/src/opt/dau/dauCore.c +0 -112
- data/ext/abc/src/opt/dau/dauDivs.c +0 -111
- data/ext/abc/src/opt/dau/dauDsd.c +0 -2098
- data/ext/abc/src/opt/dau/dauDsd2.c +0 -660
- data/ext/abc/src/opt/dau/dauEnum.c +0 -253
- data/ext/abc/src/opt/dau/dauGia.c +0 -573
- data/ext/abc/src/opt/dau/dauInt.h +0 -70
- data/ext/abc/src/opt/dau/dauMerge.c +0 -824
- data/ext/abc/src/opt/dau/dauNonDsd.c +0 -903
- data/ext/abc/src/opt/dau/dauTree.c +0 -2022
- data/ext/abc/src/opt/dau/module.make +0 -9
- data/ext/abc/src/opt/dsc/dsc.c +0 -525
- data/ext/abc/src/opt/dsc/dsc.h +0 -91
- data/ext/abc/src/opt/dsc/module.make +0 -1
- data/ext/abc/src/opt/fret/fretFlow.c +0 -700
- data/ext/abc/src/opt/fret/fretInit.c +0 -1343
- data/ext/abc/src/opt/fret/fretMain.c +0 -1383
- data/ext/abc/src/opt/fret/fretTime.c +0 -766
- data/ext/abc/src/opt/fret/fretime.h +0 -212
- data/ext/abc/src/opt/fret/module.make +0 -5
- data/ext/abc/src/opt/fsim/fsim.h +0 -101
- data/ext/abc/src/opt/fsim/fsimCore.c +0 -88
- data/ext/abc/src/opt/fsim/fsimFront.c +0 -369
- data/ext/abc/src/opt/fsim/fsimInt.h +0 -138
- data/ext/abc/src/opt/fsim/fsimMan.c +0 -212
- data/ext/abc/src/opt/fsim/fsimSim.c +0 -569
- data/ext/abc/src/opt/fsim/fsimSwitch.c +0 -40
- data/ext/abc/src/opt/fsim/fsimTsim.c +0 -416
- data/ext/abc/src/opt/fsim/module.make +0 -6
- data/ext/abc/src/opt/fxch/Fxch.c +0 -266
- data/ext/abc/src/opt/fxch/Fxch.h +0 -229
- data/ext/abc/src/opt/fxch/FxchDiv.c +0 -485
- data/ext/abc/src/opt/fxch/FxchMan.c +0 -785
- data/ext/abc/src/opt/fxch/FxchSCHashTable.c +0 -382
- data/ext/abc/src/opt/fxch/module.make +0 -4
- data/ext/abc/src/opt/fxu/fxu.c +0 -260
- data/ext/abc/src/opt/fxu/fxu.h +0 -97
- data/ext/abc/src/opt/fxu/fxuCreate.c +0 -447
- data/ext/abc/src/opt/fxu/fxuHeapD.c +0 -450
- data/ext/abc/src/opt/fxu/fxuHeapS.c +0 -449
- data/ext/abc/src/opt/fxu/fxuInt.h +0 -545
- data/ext/abc/src/opt/fxu/fxuList.c +0 -527
- data/ext/abc/src/opt/fxu/fxuMatrix.c +0 -377
- data/ext/abc/src/opt/fxu/fxuPair.c +0 -560
- data/ext/abc/src/opt/fxu/fxuPrint.c +0 -202
- data/ext/abc/src/opt/fxu/fxuReduce.c +0 -213
- data/ext/abc/src/opt/fxu/fxuSelect.c +0 -608
- data/ext/abc/src/opt/fxu/fxuSingle.c +0 -289
- data/ext/abc/src/opt/fxu/fxuUpdate.c +0 -811
- data/ext/abc/src/opt/fxu/module.make +0 -12
- data/ext/abc/src/opt/lpk/lpk.h +0 -88
- data/ext/abc/src/opt/lpk/lpkAbcDec.c +0 -294
- data/ext/abc/src/opt/lpk/lpkAbcDsd.c +0 -617
- data/ext/abc/src/opt/lpk/lpkAbcMux.c +0 -240
- data/ext/abc/src/opt/lpk/lpkAbcUtil.c +0 -249
- data/ext/abc/src/opt/lpk/lpkCore.c +0 -694
- data/ext/abc/src/opt/lpk/lpkCut.c +0 -689
- data/ext/abc/src/opt/lpk/lpkInt.h +0 -250
- data/ext/abc/src/opt/lpk/lpkMan.c +0 -127
- data/ext/abc/src/opt/lpk/lpkMap.c +0 -210
- data/ext/abc/src/opt/lpk/lpkMulti.c +0 -513
- data/ext/abc/src/opt/lpk/lpkMux.c +0 -252
- data/ext/abc/src/opt/lpk/lpkSets.c +0 -445
- data/ext/abc/src/opt/lpk/lpk_.c +0 -53
- data/ext/abc/src/opt/lpk/module.make +0 -11
- data/ext/abc/src/opt/mfs/mfs.h +0 -89
- data/ext/abc/src/opt/mfs/mfsCore.c +0 -596
- data/ext/abc/src/opt/mfs/mfsCore_.c +0 -394
- data/ext/abc/src/opt/mfs/mfsDiv.c +0 -309
- data/ext/abc/src/opt/mfs/mfsGia.c +0 -301
- data/ext/abc/src/opt/mfs/mfsInt.h +0 -192
- data/ext/abc/src/opt/mfs/mfsInter.c +0 -398
- data/ext/abc/src/opt/mfs/mfsMan.c +0 -202
- data/ext/abc/src/opt/mfs/mfsResub.c +0 -622
- data/ext/abc/src/opt/mfs/mfsResub_.c +0 -567
- data/ext/abc/src/opt/mfs/mfsSat.c +0 -182
- data/ext/abc/src/opt/mfs/mfsStrash.c +0 -406
- data/ext/abc/src/opt/mfs/mfsWin.c +0 -117
- data/ext/abc/src/opt/mfs/mfs_.c +0 -52
- data/ext/abc/src/opt/mfs/module.make +0 -8
- data/ext/abc/src/opt/nwk/module.make +0 -14
- data/ext/abc/src/opt/nwk/ntlnwk.h +0 -113
- data/ext/abc/src/opt/nwk/nwk.h +0 -307
- data/ext/abc/src/opt/nwk/nwkAig.c +0 -299
- data/ext/abc/src/opt/nwk/nwkBidec.c +0 -177
- data/ext/abc/src/opt/nwk/nwkCheck.c +0 -76
- data/ext/abc/src/opt/nwk/nwkDfs.c +0 -664
- data/ext/abc/src/opt/nwk/nwkFanio.c +0 -320
- data/ext/abc/src/opt/nwk/nwkFlow.c +0 -606
- data/ext/abc/src/opt/nwk/nwkFlow_depth.c +0 -631
- data/ext/abc/src/opt/nwk/nwkMan.c +0 -278
- data/ext/abc/src/opt/nwk/nwkMap.c +0 -396
- data/ext/abc/src/opt/nwk/nwkMerge.c +0 -1046
- data/ext/abc/src/opt/nwk/nwkMerge.h +0 -153
- data/ext/abc/src/opt/nwk/nwkObj.c +0 -204
- data/ext/abc/src/opt/nwk/nwkSpeedup.c +0 -382
- data/ext/abc/src/opt/nwk/nwkStrash.c +0 -149
- data/ext/abc/src/opt/nwk/nwkTiming.c +0 -894
- data/ext/abc/src/opt/nwk/nwkUtil.c +0 -644
- data/ext/abc/src/opt/nwk/nwk_.c +0 -52
- data/ext/abc/src/opt/res/module.make +0 -7
- data/ext/abc/src/opt/res/res.h +0 -79
- data/ext/abc/src/opt/res/resCore.c +0 -427
- data/ext/abc/src/opt/res/resDivs.c +0 -290
- data/ext/abc/src/opt/res/resFilter.c +0 -439
- data/ext/abc/src/opt/res/resInt.h +0 -141
- data/ext/abc/src/opt/res/resSat.c +0 -414
- data/ext/abc/src/opt/res/resSim.c +0 -795
- data/ext/abc/src/opt/res/resSim_old.c +0 -526
- data/ext/abc/src/opt/res/resStrash.c +0 -122
- data/ext/abc/src/opt/res/resWin.c +0 -490
- data/ext/abc/src/opt/res/res_.c +0 -55
- data/ext/abc/src/opt/ret/module.make +0 -8
- data/ext/abc/src/opt/ret/retArea.c +0 -554
- data/ext/abc/src/opt/ret/retCore.c +0 -138
- data/ext/abc/src/opt/ret/retDelay.c +0 -315
- data/ext/abc/src/opt/ret/retFlow.c +0 -789
- data/ext/abc/src/opt/ret/retIncrem.c +0 -480
- data/ext/abc/src/opt/ret/retInit.c +0 -355
- data/ext/abc/src/opt/ret/retInt.h +0 -88
- data/ext/abc/src/opt/ret/retLvalue.c +0 -402
- data/ext/abc/src/opt/ret/ret_.c +0 -53
- data/ext/abc/src/opt/rwr/module.make +0 -7
- data/ext/abc/src/opt/rwr/rwr.h +0 -173
- data/ext/abc/src/opt/rwr/rwrDec.c +0 -155
- data/ext/abc/src/opt/rwr/rwrEva.c +0 -599
- data/ext/abc/src/opt/rwr/rwrExp.c +0 -336
- data/ext/abc/src/opt/rwr/rwrLib.c +0 -367
- data/ext/abc/src/opt/rwr/rwrMan.c +0 -323
- data/ext/abc/src/opt/rwr/rwrPrint.c +0 -271
- data/ext/abc/src/opt/rwr/rwrTemp.c +0 -126
- data/ext/abc/src/opt/rwr/rwrUtil.c +0 -661
- data/ext/abc/src/opt/rwt/module.make +0 -3
- data/ext/abc/src/opt/rwt/rwt.h +0 -165
- data/ext/abc/src/opt/rwt/rwtDec.c +0 -155
- data/ext/abc/src/opt/rwt/rwtMan.c +0 -363
- data/ext/abc/src/opt/rwt/rwtUtil.c +0 -663
- data/ext/abc/src/opt/sbd/module.make +0 -9
- data/ext/abc/src/opt/sbd/sbd.c +0 -122
- data/ext/abc/src/opt/sbd/sbd.h +0 -82
- data/ext/abc/src/opt/sbd/sbdCnf.c +0 -147
- data/ext/abc/src/opt/sbd/sbdCore.c +0 -2229
- data/ext/abc/src/opt/sbd/sbdCut.c +0 -872
- data/ext/abc/src/opt/sbd/sbdCut2.c +0 -431
- data/ext/abc/src/opt/sbd/sbdInt.h +0 -125
- data/ext/abc/src/opt/sbd/sbdLut.c +0 -311
- data/ext/abc/src/opt/sbd/sbdPath.c +0 -197
- data/ext/abc/src/opt/sbd/sbdSat.c +0 -793
- data/ext/abc/src/opt/sbd/sbdSim.c +0 -310
- data/ext/abc/src/opt/sbd/sbdWin.c +0 -464
- data/ext/abc/src/opt/sfm/module.make +0 -10
- data/ext/abc/src/opt/sfm/sfm.h +0 -107
- data/ext/abc/src/opt/sfm/sfmArea.c +0 -380
- data/ext/abc/src/opt/sfm/sfmCnf.c +0 -179
- data/ext/abc/src/opt/sfm/sfmCore.c +0 -306
- data/ext/abc/src/opt/sfm/sfmDec.c +0 -2168
- data/ext/abc/src/opt/sfm/sfmInt.h +0 -254
- data/ext/abc/src/opt/sfm/sfmLib.c +0 -766
- data/ext/abc/src/opt/sfm/sfmMit.c +0 -73
- data/ext/abc/src/opt/sfm/sfmNtk.c +0 -381
- data/ext/abc/src/opt/sfm/sfmSat.c +0 -273
- data/ext/abc/src/opt/sfm/sfmTim.c +0 -458
- data/ext/abc/src/opt/sfm/sfmWin.c +0 -481
- data/ext/abc/src/opt/sim/module.make +0 -9
- data/ext/abc/src/opt/sim/sim.h +0 -237
- data/ext/abc/src/opt/sim/simMan.c +0 -293
- data/ext/abc/src/opt/sim/simSat.c +0 -53
- data/ext/abc/src/opt/sim/simSeq.c +0 -176
- data/ext/abc/src/opt/sim/simSupp.c +0 -603
- data/ext/abc/src/opt/sim/simSwitch.c +0 -112
- data/ext/abc/src/opt/sim/simSym.c +0 -148
- data/ext/abc/src/opt/sim/simSymSat.c +0 -205
- data/ext/abc/src/opt/sim/simSymSim.c +0 -178
- data/ext/abc/src/opt/sim/simSymStr.c +0 -493
- data/ext/abc/src/opt/sim/simUtils.c +0 -718
- data/ext/abc/src/phys/place/Makefile +0 -30
- data/ext/abc/src/phys/place/README +0 -50
- data/ext/abc/src/phys/place/hpwl +0 -57
- data/ext/abc/src/phys/place/libhmetis.h +0 -39
- data/ext/abc/src/phys/place/module.make +0 -10
- data/ext/abc/src/phys/place/place_base.c +0 -350
- data/ext/abc/src/phys/place/place_base.h +0 -145
- data/ext/abc/src/phys/place/place_bin.c +0 -282
- data/ext/abc/src/phys/place/place_genqp.c +0 -314
- data/ext/abc/src/phys/place/place_gordian.c +0 -165
- data/ext/abc/src/phys/place/place_gordian.h +0 -86
- data/ext/abc/src/phys/place/place_inc.c +0 -111
- data/ext/abc/src/phys/place/place_io.c +0 -99
- data/ext/abc/src/phys/place/place_legalize.c +0 -28
- data/ext/abc/src/phys/place/place_pads.c +0 -146
- data/ext/abc/src/phys/place/place_partition.c +0 -1140
- data/ext/abc/src/phys/place/place_qpsolver.c +0 -1275
- data/ext/abc/src/phys/place/place_qpsolver.h +0 -139
- data/ext/abc/src/phys/place/place_test.c +0 -365
- data/ext/abc/src/proof/abs/abs.c +0 -52
- data/ext/abc/src/proof/abs/abs.h +0 -177
- data/ext/abc/src/proof/abs/absDup.c +0 -445
- data/ext/abc/src/proof/abs/absGla.c +0 -1901
- data/ext/abc/src/proof/abs/absGlaOld.c +0 -1956
- data/ext/abc/src/proof/abs/absIter.c +0 -148
- data/ext/abc/src/proof/abs/absOldCex.c +0 -873
- data/ext/abc/src/proof/abs/absOldRef.c +0 -474
- data/ext/abc/src/proof/abs/absOldSat.c +0 -986
- data/ext/abc/src/proof/abs/absOldSim.c +0 -477
- data/ext/abc/src/proof/abs/absOut.c +0 -458
- data/ext/abc/src/proof/abs/absPth.c +0 -205
- data/ext/abc/src/proof/abs/absRef.c +0 -751
- data/ext/abc/src/proof/abs/absRef.h +0 -129
- data/ext/abc/src/proof/abs/absRefJ.c +0 -916
- data/ext/abc/src/proof/abs/absRefJ.h +0 -67
- data/ext/abc/src/proof/abs/absRefSelect.c +0 -309
- data/ext/abc/src/proof/abs/absRpm.c +0 -874
- data/ext/abc/src/proof/abs/absRpmOld.c +0 -201
- data/ext/abc/src/proof/abs/absUtil.c +0 -257
- data/ext/abc/src/proof/abs/absVta.c +0 -1764
- data/ext/abc/src/proof/abs/module.make +0 -16
- data/ext/abc/src/proof/acec/acec.c +0 -52
- data/ext/abc/src/proof/acec/acec.h +0 -98
- data/ext/abc/src/proof/acec/acec2Mult.c +0 -1211
- data/ext/abc/src/proof/acec/acecBo.c +0 -216
- data/ext/abc/src/proof/acec/acecCl.c +0 -445
- data/ext/abc/src/proof/acec/acecCo.c +0 -429
- data/ext/abc/src/proof/acec/acecCore.c +0 -553
- data/ext/abc/src/proof/acec/acecCover.c +0 -263
- data/ext/abc/src/proof/acec/acecFadds.c +0 -1247
- data/ext/abc/src/proof/acec/acecInt.h +0 -105
- data/ext/abc/src/proof/acec/acecMult.c +0 -623
- data/ext/abc/src/proof/acec/acecNorm.c +0 -226
- data/ext/abc/src/proof/acec/acecOrder.c +0 -254
- data/ext/abc/src/proof/acec/acecPa.c +0 -277
- data/ext/abc/src/proof/acec/acecPo.c +0 -655
- data/ext/abc/src/proof/acec/acecPolyn.c +0 -445
- data/ext/abc/src/proof/acec/acecPool.c +0 -428
- data/ext/abc/src/proof/acec/acecRe.c +0 -602
- data/ext/abc/src/proof/acec/acecSt.c +0 -422
- data/ext/abc/src/proof/acec/acecStruct.c +0 -271
- data/ext/abc/src/proof/acec/acecTree.c +0 -783
- data/ext/abc/src/proof/acec/acecUtil.c +0 -122
- data/ext/abc/src/proof/acec/acecXor.c +0 -434
- data/ext/abc/src/proof/acec/module.make +0 -19
- data/ext/abc/src/proof/cec/cec.c +0 -53
- data/ext/abc/src/proof/cec/cec.h +0 -240
- data/ext/abc/src/proof/cec/cecCec.c +0 -580
- data/ext/abc/src/proof/cec/cecChoice.c +0 -410
- data/ext/abc/src/proof/cec/cecClass.c +0 -931
- data/ext/abc/src/proof/cec/cecCore.c +0 -554
- data/ext/abc/src/proof/cec/cecCorr.c +0 -1229
- data/ext/abc/src/proof/cec/cecInt.h +0 -227
- data/ext/abc/src/proof/cec/cecIso.c +0 -375
- data/ext/abc/src/proof/cec/cecMan.c +0 -297
- data/ext/abc/src/proof/cec/cecPat.c +0 -578
- data/ext/abc/src/proof/cec/cecSat.c +0 -1040
- data/ext/abc/src/proof/cec/cecSatG.c +0 -1048
- data/ext/abc/src/proof/cec/cecSeq.c +0 -449
- data/ext/abc/src/proof/cec/cecSim.c +0 -53
- data/ext/abc/src/proof/cec/cecSimBack.c +0 -194
- data/ext/abc/src/proof/cec/cecSolve.c +0 -1107
- data/ext/abc/src/proof/cec/cecSplit.c +0 -849
- data/ext/abc/src/proof/cec/cecSweep.c +0 -301
- data/ext/abc/src/proof/cec/cecSynth.c +0 -433
- data/ext/abc/src/proof/cec/module.make +0 -15
- data/ext/abc/src/proof/dch/dch.h +0 -91
- data/ext/abc/src/proof/dch/dchAig.c +0 -119
- data/ext/abc/src/proof/dch/dchChoice.c +0 -552
- data/ext/abc/src/proof/dch/dchClass.c +0 -611
- data/ext/abc/src/proof/dch/dchCnf.c +0 -334
- data/ext/abc/src/proof/dch/dchCore.c +0 -161
- data/ext/abc/src/proof/dch/dchInt.h +0 -170
- data/ext/abc/src/proof/dch/dchMan.c +0 -191
- data/ext/abc/src/proof/dch/dchSat.c +0 -167
- data/ext/abc/src/proof/dch/dchSim.c +0 -297
- data/ext/abc/src/proof/dch/dchSimSat.c +0 -260
- data/ext/abc/src/proof/dch/dchSweep.c +0 -146
- data/ext/abc/src/proof/dch/module.make +0 -10
- data/ext/abc/src/proof/fra/fra.h +0 -389
- data/ext/abc/src/proof/fra/fraBmc.c +0 -453
- data/ext/abc/src/proof/fra/fraCec.c +0 -574
- data/ext/abc/src/proof/fra/fraClass.c +0 -862
- data/ext/abc/src/proof/fra/fraClau.c +0 -745
- data/ext/abc/src/proof/fra/fraClaus.c +0 -1877
- data/ext/abc/src/proof/fra/fraCnf.c +0 -289
- data/ext/abc/src/proof/fra/fraCore.c +0 -490
- data/ext/abc/src/proof/fra/fraHot.c +0 -476
- data/ext/abc/src/proof/fra/fraImp.c +0 -732
- data/ext/abc/src/proof/fra/fraInd.c +0 -712
- data/ext/abc/src/proof/fra/fraIndVer.c +0 -166
- data/ext/abc/src/proof/fra/fraLcr.c +0 -708
- data/ext/abc/src/proof/fra/fraMan.c +0 -314
- data/ext/abc/src/proof/fra/fraPart.c +0 -269
- data/ext/abc/src/proof/fra/fraSat.c +0 -571
- data/ext/abc/src/proof/fra/fraSec.c +0 -693
- data/ext/abc/src/proof/fra/fraSim.c +0 -1173
- data/ext/abc/src/proof/fra/fra_.c +0 -53
- data/ext/abc/src/proof/fra/module.make +0 -17
- data/ext/abc/src/proof/fraig/fraig.h +0 -257
- data/ext/abc/src/proof/fraig/fraigApi.c +0 -299
- data/ext/abc/src/proof/fraig/fraigCanon.c +0 -223
- data/ext/abc/src/proof/fraig/fraigChoice.c +0 -246
- data/ext/abc/src/proof/fraig/fraigFanout.c +0 -180
- data/ext/abc/src/proof/fraig/fraigFeed.c +0 -914
- data/ext/abc/src/proof/fraig/fraigInt.h +0 -436
- data/ext/abc/src/proof/fraig/fraigMan.c +0 -546
- data/ext/abc/src/proof/fraig/fraigMem.c +0 -251
- data/ext/abc/src/proof/fraig/fraigNode.c +0 -319
- data/ext/abc/src/proof/fraig/fraigPrime.c +0 -113
- data/ext/abc/src/proof/fraig/fraigSat.c +0 -1463
- data/ext/abc/src/proof/fraig/fraigTable.c +0 -664
- data/ext/abc/src/proof/fraig/fraigUtil.c +0 -1039
- data/ext/abc/src/proof/fraig/fraigVec.c +0 -550
- data/ext/abc/src/proof/fraig/module.make +0 -12
- data/ext/abc/src/proof/int/int.h +0 -96
- data/ext/abc/src/proof/int/intCheck.c +0 -305
- data/ext/abc/src/proof/int/intContain.c +0 -341
- data/ext/abc/src/proof/int/intCore.c +0 -412
- data/ext/abc/src/proof/int/intCtrex.c +0 -168
- data/ext/abc/src/proof/int/intDup.c +0 -184
- data/ext/abc/src/proof/int/intFrames.c +0 -124
- data/ext/abc/src/proof/int/intInt.h +0 -143
- data/ext/abc/src/proof/int/intInter.c +0 -145
- data/ext/abc/src/proof/int/intM114.c +0 -323
- data/ext/abc/src/proof/int/intM114p.c +0 -443
- data/ext/abc/src/proof/int/intMan.c +0 -165
- data/ext/abc/src/proof/int/intUtil.c +0 -108
- data/ext/abc/src/proof/int/module.make +0 -10
- data/ext/abc/src/proof/int2/int2.h +0 -90
- data/ext/abc/src/proof/int2/int2Bmc.c +0 -355
- data/ext/abc/src/proof/int2/int2Core.c +0 -335
- data/ext/abc/src/proof/int2/int2Int.h +0 -164
- data/ext/abc/src/proof/int2/int2Refine.c +0 -154
- data/ext/abc/src/proof/int2/int2Util.c +0 -152
- data/ext/abc/src/proof/int2/module.make +0 -4
- data/ext/abc/src/proof/live/arenaViolation.c +0 -549
- data/ext/abc/src/proof/live/combination.c +0 -463
- data/ext/abc/src/proof/live/disjunctiveMonotone.c +0 -757
- data/ext/abc/src/proof/live/kLiveConstraints.c +0 -177
- data/ext/abc/src/proof/live/kliveness.c +0 -816
- data/ext/abc/src/proof/live/liveness.c +0 -2575
- data/ext/abc/src/proof/live/liveness_sim.c +0 -849
- data/ext/abc/src/proof/live/ltl_parser.c +0 -839
- data/ext/abc/src/proof/live/module.make +0 -9
- data/ext/abc/src/proof/live/monotone.c +0 -507
- data/ext/abc/src/proof/pdr/module.make +0 -10
- data/ext/abc/src/proof/pdr/pdr.c +0 -53
- data/ext/abc/src/proof/pdr/pdr.h +0 -109
- data/ext/abc/src/proof/pdr/pdrClass.c +0 -223
- data/ext/abc/src/proof/pdr/pdrCnf.c +0 -455
- data/ext/abc/src/proof/pdr/pdrCore.c +0 -1451
- data/ext/abc/src/proof/pdr/pdrIncr.c +0 -1046
- data/ext/abc/src/proof/pdr/pdrInt.h +0 -275
- data/ext/abc/src/proof/pdr/pdrInv.c +0 -985
- data/ext/abc/src/proof/pdr/pdrMan.c +0 -549
- data/ext/abc/src/proof/pdr/pdrSat.c +0 -395
- data/ext/abc/src/proof/pdr/pdrTsim.c +0 -502
- data/ext/abc/src/proof/pdr/pdrTsim2.c +0 -550
- data/ext/abc/src/proof/pdr/pdrTsim3.c +0 -361
- data/ext/abc/src/proof/pdr/pdrUtil.c +0 -800
- data/ext/abc/src/proof/ssc/module.make +0 -5
- data/ext/abc/src/proof/ssc/ssc.h +0 -78
- data/ext/abc/src/proof/ssc/sscClass.c +0 -326
- data/ext/abc/src/proof/ssc/sscCore.c +0 -469
- data/ext/abc/src/proof/ssc/sscInt.h +0 -135
- data/ext/abc/src/proof/ssc/sscSat.c +0 -430
- data/ext/abc/src/proof/ssc/sscSim.c +0 -364
- data/ext/abc/src/proof/ssc/sscUtil.c +0 -173
- data/ext/abc/src/proof/ssw/module.make +0 -20
- data/ext/abc/src/proof/ssw/ssw.h +0 -170
- data/ext/abc/src/proof/ssw/sswAig.c +0 -258
- data/ext/abc/src/proof/ssw/sswBmc.c +0 -224
- data/ext/abc/src/proof/ssw/sswClass.c +0 -1170
- data/ext/abc/src/proof/ssw/sswCnf.c +0 -427
- data/ext/abc/src/proof/ssw/sswConstr.c +0 -718
- data/ext/abc/src/proof/ssw/sswCore.c +0 -539
- data/ext/abc/src/proof/ssw/sswDyn.c +0 -491
- data/ext/abc/src/proof/ssw/sswFilter.c +0 -493
- data/ext/abc/src/proof/ssw/sswInt.h +0 -302
- data/ext/abc/src/proof/ssw/sswIslands.c +0 -598
- data/ext/abc/src/proof/ssw/sswLcorr.c +0 -337
- data/ext/abc/src/proof/ssw/sswMan.c +0 -217
- data/ext/abc/src/proof/ssw/sswPairs.c +0 -480
- data/ext/abc/src/proof/ssw/sswPart.c +0 -140
- data/ext/abc/src/proof/ssw/sswRarity.c +0 -1385
- data/ext/abc/src/proof/ssw/sswRarity2.c +0 -518
- data/ext/abc/src/proof/ssw/sswSat.c +0 -307
- data/ext/abc/src/proof/ssw/sswSemi.c +0 -323
- data/ext/abc/src/proof/ssw/sswSim.c +0 -1406
- data/ext/abc/src/proof/ssw/sswSimSat.c +0 -124
- data/ext/abc/src/proof/ssw/sswSweep.c +0 -440
- data/ext/abc/src/proof/ssw/sswUnique.c +0 -196
- data/ext/abc/src/sat/bmc/bmc.c +0 -52
- data/ext/abc/src/sat/bmc/bmc.h +0 -205
- data/ext/abc/src/sat/bmc/bmcBCore.c +0 -273
- data/ext/abc/src/sat/bmc/bmcBmc.c +0 -377
- data/ext/abc/src/sat/bmc/bmcBmc2.c +0 -944
- data/ext/abc/src/sat/bmc/bmcBmc3.c +0 -1893
- data/ext/abc/src/sat/bmc/bmcBmcAnd.c +0 -1100
- data/ext/abc/src/sat/bmc/bmcBmcG.c +0 -455
- data/ext/abc/src/sat/bmc/bmcBmcS.c +0 -940
- data/ext/abc/src/sat/bmc/bmcBmci.c +0 -344
- data/ext/abc/src/sat/bmc/bmcCexCare.c +0 -476
- data/ext/abc/src/sat/bmc/bmcCexCut.c +0 -537
- data/ext/abc/src/sat/bmc/bmcCexDepth.c +0 -373
- data/ext/abc/src/sat/bmc/bmcCexMin1.c +0 -578
- data/ext/abc/src/sat/bmc/bmcCexMin2.c +0 -363
- data/ext/abc/src/sat/bmc/bmcCexTools.c +0 -852
- data/ext/abc/src/sat/bmc/bmcChain.c +0 -396
- data/ext/abc/src/sat/bmc/bmcClp.c +0 -1548
- data/ext/abc/src/sat/bmc/bmcEco.c +0 -312
- data/ext/abc/src/sat/bmc/bmcEnum.c +0 -223
- data/ext/abc/src/sat/bmc/bmcExpand.c +0 -172
- data/ext/abc/src/sat/bmc/bmcFault.c +0 -1710
- data/ext/abc/src/sat/bmc/bmcFx.c +0 -725
- data/ext/abc/src/sat/bmc/bmcGen.c +0 -193
- data/ext/abc/src/sat/bmc/bmcICheck.c +0 -540
- data/ext/abc/src/sat/bmc/bmcInse.c +0 -345
- data/ext/abc/src/sat/bmc/bmcLoad.c +0 -212
- data/ext/abc/src/sat/bmc/bmcMaj.c +0 -745
- data/ext/abc/src/sat/bmc/bmcMaj2.c +0 -852
- data/ext/abc/src/sat/bmc/bmcMaxi.c +0 -282
- data/ext/abc/src/sat/bmc/bmcMesh.c +0 -433
- data/ext/abc/src/sat/bmc/bmcMesh2.c +0 -449
- data/ext/abc/src/sat/bmc/bmcMulti.c +0 -296
- data/ext/abc/src/sat/bmc/bmcUnroll.c +0 -505
- data/ext/abc/src/sat/bmc/module.make +0 -31
- data/ext/abc/src/sat/bsat/license +0 -21
- data/ext/abc/src/sat/bsat/module.make +0 -14
- data/ext/abc/src/sat/bsat/satChecker.c +0 -193
- data/ext/abc/src/sat/bsat/satClause.h +0 -476
- data/ext/abc/src/sat/bsat/satInter.c +0 -1077
- data/ext/abc/src/sat/bsat/satInterA.c +0 -1090
- data/ext/abc/src/sat/bsat/satInterB.c +0 -1115
- data/ext/abc/src/sat/bsat/satInterP.c +0 -1096
- data/ext/abc/src/sat/bsat/satMem.c +0 -583
- data/ext/abc/src/sat/bsat/satMem.h +0 -85
- data/ext/abc/src/sat/bsat/satProof.c +0 -934
- data/ext/abc/src/sat/bsat/satProof2.h +0 -327
- data/ext/abc/src/sat/bsat/satSolver.c +0 -2417
- data/ext/abc/src/sat/bsat/satSolver.h +0 -639
- data/ext/abc/src/sat/bsat/satSolver2.c +0 -1998
- data/ext/abc/src/sat/bsat/satSolver2.h +0 -377
- data/ext/abc/src/sat/bsat/satSolver2i.c +0 -242
- data/ext/abc/src/sat/bsat/satSolver3.c +0 -2299
- data/ext/abc/src/sat/bsat/satSolver3.h +0 -622
- data/ext/abc/src/sat/bsat/satStore.c +0 -469
- data/ext/abc/src/sat/bsat/satStore.h +0 -158
- data/ext/abc/src/sat/bsat/satTrace.c +0 -112
- data/ext/abc/src/sat/bsat/satTruth.c +0 -299
- data/ext/abc/src/sat/bsat/satTruth.h +0 -89
- data/ext/abc/src/sat/bsat/satUtil.c +0 -358
- data/ext/abc/src/sat/bsat/satVec.h +0 -161
- data/ext/abc/src/sat/bsat2/AbcApi.cpp +0 -59
- data/ext/abc/src/sat/bsat2/Alg.h +0 -84
- data/ext/abc/src/sat/bsat2/Alloc.h +0 -131
- data/ext/abc/src/sat/bsat2/Dimacs.h +0 -89
- data/ext/abc/src/sat/bsat2/Heap.h +0 -149
- data/ext/abc/src/sat/bsat2/IntTypes.h +0 -47
- data/ext/abc/src/sat/bsat2/LICENSE +0 -21
- data/ext/abc/src/sat/bsat2/MainSat.cpp +0 -197
- data/ext/abc/src/sat/bsat2/MainSimp.cpp +0 -206
- data/ext/abc/src/sat/bsat2/Map.h +0 -193
- data/ext/abc/src/sat/bsat2/Options.cpp +0 -93
- data/ext/abc/src/sat/bsat2/Options.h +0 -387
- data/ext/abc/src/sat/bsat2/ParseUtils.h +0 -122
- data/ext/abc/src/sat/bsat2/Queue.h +0 -69
- data/ext/abc/src/sat/bsat2/README +0 -24
- data/ext/abc/src/sat/bsat2/ReleaseNotes-2.2.0.txt +0 -79
- data/ext/abc/src/sat/bsat2/SimpSolver.cpp +0 -720
- data/ext/abc/src/sat/bsat2/SimpSolver.h +0 -197
- data/ext/abc/src/sat/bsat2/Solver.cpp +0 -924
- data/ext/abc/src/sat/bsat2/Solver.h +0 -373
- data/ext/abc/src/sat/bsat2/SolverTypes.h +0 -407
- data/ext/abc/src/sat/bsat2/Sort.h +0 -98
- data/ext/abc/src/sat/bsat2/System.cpp +0 -95
- data/ext/abc/src/sat/bsat2/System.h +0 -60
- data/ext/abc/src/sat/bsat2/Vec.h +0 -130
- data/ext/abc/src/sat/bsat2/XAlloc.h +0 -45
- data/ext/abc/src/sat/bsat2/module.make +0 -7
- data/ext/abc/src/sat/bsat2/pstdint.h +0 -813
- data/ext/abc/src/sat/cnf/cnf.h +0 -202
- data/ext/abc/src/sat/cnf/cnfCore.c +0 -290
- data/ext/abc/src/sat/cnf/cnfCut.c +0 -376
- data/ext/abc/src/sat/cnf/cnfData.c +0 -4789
- data/ext/abc/src/sat/cnf/cnfFast.c +0 -697
- data/ext/abc/src/sat/cnf/cnfMan.c +0 -726
- data/ext/abc/src/sat/cnf/cnfMap.c +0 -362
- data/ext/abc/src/sat/cnf/cnfPost.c +0 -238
- data/ext/abc/src/sat/cnf/cnfUtil.c +0 -479
- data/ext/abc/src/sat/cnf/cnfWrite.c +0 -806
- data/ext/abc/src/sat/cnf/cnf_.c +0 -53
- data/ext/abc/src/sat/cnf/module.make +0 -9
- data/ext/abc/src/sat/csat/csat_apis.c +0 -778
- data/ext/abc/src/sat/csat/csat_apis.h +0 -226
- data/ext/abc/src/sat/csat/module.make +0 -1
- data/ext/abc/src/sat/glucose/AbcGlucose.cpp +0 -1372
- data/ext/abc/src/sat/glucose/AbcGlucose.h +0 -110
- data/ext/abc/src/sat/glucose/AbcGlucoseCmd.cpp +0 -144
- data/ext/abc/src/sat/glucose/Alg.h +0 -84
- data/ext/abc/src/sat/glucose/Alloc.h +0 -132
- data/ext/abc/src/sat/glucose/BoundedQueue.h +0 -110
- data/ext/abc/src/sat/glucose/Constants.h +0 -33
- data/ext/abc/src/sat/glucose/Dimacs.h +0 -89
- data/ext/abc/src/sat/glucose/Glucose.cpp +0 -1493
- data/ext/abc/src/sat/glucose/Heap.h +0 -150
- data/ext/abc/src/sat/glucose/IntTypes.h +0 -47
- data/ext/abc/src/sat/glucose/Map.h +0 -193
- data/ext/abc/src/sat/glucose/Options.cpp +0 -92
- data/ext/abc/src/sat/glucose/Options.h +0 -388
- data/ext/abc/src/sat/glucose/ParseUtils.h +0 -151
- data/ext/abc/src/sat/glucose/Queue.h +0 -69
- data/ext/abc/src/sat/glucose/SimpSolver.cpp +0 -774
- data/ext/abc/src/sat/glucose/SimpSolver.h +0 -204
- data/ext/abc/src/sat/glucose/Solver.h +0 -491
- data/ext/abc/src/sat/glucose/SolverTypes.h +0 -434
- data/ext/abc/src/sat/glucose/Sort.h +0 -98
- data/ext/abc/src/sat/glucose/System.cpp +0 -95
- data/ext/abc/src/sat/glucose/System.h +0 -60
- data/ext/abc/src/sat/glucose/Vec.h +0 -130
- data/ext/abc/src/sat/glucose/XAlloc.h +0 -47
- data/ext/abc/src/sat/glucose/module.make +0 -6
- data/ext/abc/src/sat/glucose/pstdint.h +0 -919
- data/ext/abc/src/sat/glucose/stdint.h +0 -1628
- data/ext/abc/src/sat/lsat/solver.h +0 -132
- data/ext/abc/src/sat/msat/module.make +0 -13
- data/ext/abc/src/sat/msat/msat.h +0 -168
- data/ext/abc/src/sat/msat/msatActivity.c +0 -165
- data/ext/abc/src/sat/msat/msatClause.c +0 -537
- data/ext/abc/src/sat/msat/msatClauseVec.c +0 -237
- data/ext/abc/src/sat/msat/msatInt.h +0 -295
- data/ext/abc/src/sat/msat/msatMem.c +0 -534
- data/ext/abc/src/sat/msat/msatOrderH.c +0 -415
- data/ext/abc/src/sat/msat/msatOrderJ.c +0 -477
- data/ext/abc/src/sat/msat/msatQueue.c +0 -162
- data/ext/abc/src/sat/msat/msatRead.c +0 -274
- data/ext/abc/src/sat/msat/msatSolverApi.c +0 -505
- data/ext/abc/src/sat/msat/msatSolverCore.c +0 -215
- data/ext/abc/src/sat/msat/msatSolverIo.c +0 -182
- data/ext/abc/src/sat/msat/msatSolverSearch.c +0 -634
- data/ext/abc/src/sat/msat/msatSort.c +0 -178
- data/ext/abc/src/sat/msat/msatVec.c +0 -500
- data/ext/abc/src/sat/proof/pr.c +0 -1264
- data/ext/abc/src/sat/proof/pr.h +0 -69
- data/ext/abc/src/sat/proof/stats.txt +0 -66
- data/ext/abc/src/sat/psat/m114p.h +0 -47
- data/ext/abc/src/sat/psat/m114p_types.h +0 -13
- data/ext/abc/src/sat/psat/module.make +0 -1
- data/ext/abc/src/sat/satoko/LICENSE +0 -22
- data/ext/abc/src/sat/satoko/act_clause.h +0 -43
- data/ext/abc/src/sat/satoko/act_var.h +0 -53
- data/ext/abc/src/sat/satoko/cdb.h +0 -106
- data/ext/abc/src/sat/satoko/clause.h +0 -77
- data/ext/abc/src/sat/satoko/cnf_reader.c +0 -157
- data/ext/abc/src/sat/satoko/module.make +0 -3
- data/ext/abc/src/sat/satoko/satoko.h +0 -147
- data/ext/abc/src/sat/satoko/solver.c +0 -771
- data/ext/abc/src/sat/satoko/solver.h +0 -260
- data/ext/abc/src/sat/satoko/solver_api.c +0 -669
- data/ext/abc/src/sat/satoko/types.h +0 -39
- data/ext/abc/src/sat/satoko/utils/b_queue.h +0 -81
- data/ext/abc/src/sat/satoko/utils/heap.h +0 -178
- data/ext/abc/src/sat/satoko/utils/mem.h +0 -23
- data/ext/abc/src/sat/satoko/utils/misc.h +0 -35
- data/ext/abc/src/sat/satoko/utils/sdbl.h +0 -133
- data/ext/abc/src/sat/satoko/utils/sort.h +0 -65
- data/ext/abc/src/sat/satoko/utils/vec/vec_char.h +0 -260
- data/ext/abc/src/sat/satoko/utils/vec/vec_flt.h +0 -246
- data/ext/abc/src/sat/satoko/utils/vec/vec_int.h +0 -240
- data/ext/abc/src/sat/satoko/utils/vec/vec_sdbl.h +0 -253
- data/ext/abc/src/sat/satoko/utils/vec/vec_uint.h +0 -268
- data/ext/abc/src/sat/satoko/watch_list.h +0 -203
- data/ext/abc/src/sat/xsat/license +0 -39
- data/ext/abc/src/sat/xsat/module.make +0 -3
- data/ext/abc/src/sat/xsat/xsat.h +0 -59
- data/ext/abc/src/sat/xsat/xsatBQueue.h +0 -190
- data/ext/abc/src/sat/xsat/xsatClause.h +0 -109
- data/ext/abc/src/sat/xsat/xsatCnfReader.c +0 -236
- data/ext/abc/src/sat/xsat/xsatHeap.h +0 -330
- data/ext/abc/src/sat/xsat/xsatMemory.h +0 -222
- data/ext/abc/src/sat/xsat/xsatSolver.c +0 -1003
- data/ext/abc/src/sat/xsat/xsatSolver.h +0 -248
- data/ext/abc/src/sat/xsat/xsatSolverAPI.c +0 -346
- data/ext/abc/src/sat/xsat/xsatUtils.h +0 -106
- data/ext/abc/src/sat/xsat/xsatWatchList.h +0 -269
- data/ext/abc/src/starter.c +0 -190
- data/ext/abc/src/template.c +0 -111
- data/ext/extconf.rb +0 -14
- data/ext/ruby_abc_wrapper.h +0 -13
@@ -1,1613 +0,0 @@
|
|
1
|
-
/**CFile****************************************************************
|
2
|
-
|
3
|
-
FileName [dsdProc.c]
|
4
|
-
|
5
|
-
PackageName [DSD: Disjoint-support decomposition package.]
|
6
|
-
|
7
|
-
Synopsis [The core procedures of the package.]
|
8
|
-
|
9
|
-
Author [Alan Mishchenko]
|
10
|
-
|
11
|
-
Affiliation [UC Berkeley]
|
12
|
-
|
13
|
-
Date [Ver. 8.0. Started - September 22, 2003.]
|
14
|
-
|
15
|
-
Revision [$Id: dsdProc.c,v 1.0 2002/22/09 00:00:00 alanmi Exp $]
|
16
|
-
|
17
|
-
***********************************************************************/
|
18
|
-
|
19
|
-
#include "dsdInt.h"
|
20
|
-
|
21
|
-
ABC_NAMESPACE_IMPL_START
|
22
|
-
|
23
|
-
|
24
|
-
|
25
|
-
////////////////////////////////////////////////////////////////////////
|
26
|
-
/// FUNCTION DECLARATIONS ///
|
27
|
-
////////////////////////////////////////////////////////////////////////
|
28
|
-
|
29
|
-
// the most important procedures
|
30
|
-
void dsdKernelDecompose( Dsd_Manager_t * pDsdMan, DdNode ** pbFuncs, int nFuncs );
|
31
|
-
static Dsd_Node_t * dsdKernelDecompose_rec( Dsd_Manager_t * pDsdMan, DdNode * F );
|
32
|
-
|
33
|
-
// additional procedures
|
34
|
-
static Dsd_Node_t * dsdKernelFindContainingComponent( Dsd_Manager_t * pDsdMan, Dsd_Node_t * pWhere, DdNode * Var, int * fPolarity );
|
35
|
-
static int dsdKernelFindCommonComponents( Dsd_Manager_t * pDsdMan, Dsd_Node_t * pL, Dsd_Node_t * pH, Dsd_Node_t *** pCommon, Dsd_Node_t ** pLastDiffL, Dsd_Node_t ** pLastDiffH );
|
36
|
-
static void dsdKernelComputeSumOfComponents( Dsd_Manager_t * pDsdMan, Dsd_Node_t ** pCommon, int nCommon, DdNode ** pCompF, DdNode ** pCompS, int fExor );
|
37
|
-
static int dsdKernelCheckContainment( Dsd_Manager_t * pDsdMan, Dsd_Node_t * pL, Dsd_Node_t * pH, Dsd_Node_t ** pLarge, Dsd_Node_t ** pSmall );
|
38
|
-
|
39
|
-
// list copying
|
40
|
-
static void dsdKernelCopyListPlusOne( Dsd_Node_t * p, Dsd_Node_t * First, Dsd_Node_t ** ppList, int nListSize );
|
41
|
-
static void dsdKernelCopyListPlusOneMinusOne( Dsd_Node_t * p, Dsd_Node_t * First, Dsd_Node_t ** ppList, int nListSize, int Skipped );
|
42
|
-
|
43
|
-
// debugging procedures
|
44
|
-
static int dsdKernelVerifyDecomposition( Dsd_Manager_t * pDsdMan, Dsd_Node_t * pDE );
|
45
|
-
|
46
|
-
////////////////////////////////////////////////////////////////////////
|
47
|
-
/// STATIC VARIABLES ///
|
48
|
-
////////////////////////////////////////////////////////////////////////
|
49
|
-
|
50
|
-
// the counter of marks
|
51
|
-
static int s_Mark;
|
52
|
-
|
53
|
-
// debugging flag
|
54
|
-
//static int s_Show = 0;
|
55
|
-
// temporary var used for debugging
|
56
|
-
static int Depth = 0;
|
57
|
-
|
58
|
-
static int s_Loops1;
|
59
|
-
static int s_Loops2;
|
60
|
-
static int s_Loops3;
|
61
|
-
static int s_Common;
|
62
|
-
static int s_CommonNo;
|
63
|
-
|
64
|
-
static int s_Case4Calls;
|
65
|
-
static int s_Case4CallsSpecial;
|
66
|
-
|
67
|
-
//static int s_Case5;
|
68
|
-
//static int s_Loops2Useless;
|
69
|
-
|
70
|
-
// statistical variables
|
71
|
-
static int s_nDecBlocks;
|
72
|
-
static int s_nLiterals;
|
73
|
-
static int s_nExorGates;
|
74
|
-
static int s_nReusedBlocks;
|
75
|
-
static int s_nCascades;
|
76
|
-
static int s_nPrimeBlocks;
|
77
|
-
|
78
|
-
static int HashSuccess = 0;
|
79
|
-
static int HashFailure = 0;
|
80
|
-
|
81
|
-
static int s_CacheEntries;
|
82
|
-
|
83
|
-
|
84
|
-
////////////////////////////////////////////////////////////////////////
|
85
|
-
/// DECOMPOSITION FUNCTIONS ///
|
86
|
-
////////////////////////////////////////////////////////////////////////
|
87
|
-
|
88
|
-
/**Function*************************************************************
|
89
|
-
|
90
|
-
Synopsis [Performs DSD for the array of functions represented by BDDs.]
|
91
|
-
|
92
|
-
Description [This function takes the DSD manager, which should be
|
93
|
-
previously allocated by the call to Dsd_ManagerStart(). The resulting
|
94
|
-
DSD tree is stored in the DSD manager (pDsdMan->pRoots, pDsdMan->nRoots).
|
95
|
-
Access to the tree is through the APIs of the manager. The resulting
|
96
|
-
tree is a shared DSD DAG for the functions given in the array. For one
|
97
|
-
function the resulting DAG is always a tree. The root node pointers can
|
98
|
-
be complemented, as discussed in the literature referred to in "dsd.h".
|
99
|
-
This procedure can be called repeatedly for different functions. There is
|
100
|
-
no need to remove the decomposition tree after it is returned, because
|
101
|
-
the next call to the DSD manager will "recycle" the tree. The user should
|
102
|
-
not modify or dereference any data associated with the nodes of the
|
103
|
-
DSD trees (the user can only change the contents of a temporary
|
104
|
-
mark associated with each node by the calling to Dsd_NodeSetMark()).
|
105
|
-
All the decomposition trees and intermediate nodes will be removed when
|
106
|
-
the DSD manager is deallocated at the end by calling Dsd_ManagerStop().]
|
107
|
-
|
108
|
-
SideEffects []
|
109
|
-
|
110
|
-
SeeAlso []
|
111
|
-
|
112
|
-
***********************************************************************/
|
113
|
-
void Dsd_Decompose( Dsd_Manager_t * pDsdMan, DdNode ** pbFuncs, int nFuncs )
|
114
|
-
{
|
115
|
-
DdManager * dd = pDsdMan->dd;
|
116
|
-
int i;
|
117
|
-
abctime clk;
|
118
|
-
Dsd_Node_t * pTemp;
|
119
|
-
int SumMaxGateSize = 0;
|
120
|
-
int nDecOutputs = 0;
|
121
|
-
int nCBFOutputs = 0;
|
122
|
-
/*
|
123
|
-
s_Loops1 = 0;
|
124
|
-
s_Loops2 = 0;
|
125
|
-
s_Loops3 = 0;
|
126
|
-
s_Case4Calls = 0;
|
127
|
-
s_Case4CallsSpecial = 0;
|
128
|
-
s_Case5 = 0;
|
129
|
-
s_Loops2Useless = 0;
|
130
|
-
*/
|
131
|
-
// resize the number of roots in the manager
|
132
|
-
if ( pDsdMan->nRootsAlloc < nFuncs )
|
133
|
-
{
|
134
|
-
if ( pDsdMan->nRootsAlloc > 0 )
|
135
|
-
ABC_FREE( pDsdMan->pRoots );
|
136
|
-
pDsdMan->nRootsAlloc = nFuncs;
|
137
|
-
pDsdMan->pRoots = (Dsd_Node_t **) ABC_ALLOC( char, pDsdMan->nRootsAlloc * sizeof(Dsd_Node_t *) );
|
138
|
-
}
|
139
|
-
|
140
|
-
if ( pDsdMan->fVerbose )
|
141
|
-
printf( "\nDecomposability statistics for individual outputs:\n" );
|
142
|
-
|
143
|
-
// set the counter of decomposition nodes
|
144
|
-
s_nDecBlocks = 0;
|
145
|
-
|
146
|
-
// perform decomposition for all outputs
|
147
|
-
clk = Abc_Clock();
|
148
|
-
pDsdMan->nRoots = 0;
|
149
|
-
s_nCascades = 0;
|
150
|
-
for ( i = 0; i < nFuncs; i++ )
|
151
|
-
{
|
152
|
-
int nLiteralsPrev;
|
153
|
-
int nDecBlocksPrev;
|
154
|
-
int nExorGatesPrev;
|
155
|
-
int nReusedBlocksPres;
|
156
|
-
int nCascades;
|
157
|
-
int MaxBlock;
|
158
|
-
int nPrimeBlocks;
|
159
|
-
abctime clk;
|
160
|
-
|
161
|
-
clk = Abc_Clock();
|
162
|
-
nLiteralsPrev = s_nLiterals;
|
163
|
-
nDecBlocksPrev = s_nDecBlocks;
|
164
|
-
nExorGatesPrev = s_nExorGates;
|
165
|
-
nReusedBlocksPres = s_nReusedBlocks;
|
166
|
-
nPrimeBlocks = s_nPrimeBlocks;
|
167
|
-
|
168
|
-
pDsdMan->pRoots[ pDsdMan->nRoots++ ] = dsdKernelDecompose_rec( pDsdMan, pbFuncs[i] );
|
169
|
-
|
170
|
-
Dsd_TreeNodeGetInfoOne( pDsdMan->pRoots[i], &nCascades, &MaxBlock );
|
171
|
-
s_nCascades = ddMax( s_nCascades, nCascades );
|
172
|
-
pTemp = Dsd_Regular(pDsdMan->pRoots[i]);
|
173
|
-
if ( pTemp->Type != DSD_NODE_PRIME || pTemp->nDecs != Extra_bddSuppSize(dd,pTemp->S) )
|
174
|
-
nDecOutputs++;
|
175
|
-
if ( MaxBlock < 3 )
|
176
|
-
nCBFOutputs++;
|
177
|
-
SumMaxGateSize += MaxBlock;
|
178
|
-
|
179
|
-
if ( pDsdMan->fVerbose )
|
180
|
-
{
|
181
|
-
printf("#%02d: ", i );
|
182
|
-
printf("Ins=%2d. ", Cudd_SupportSize(dd,pbFuncs[i]) );
|
183
|
-
printf("Gts=%3d. ", Dsd_TreeCountNonTerminalNodesOne( pDsdMan->pRoots[i] ) );
|
184
|
-
printf("Pri=%3d. ", Dsd_TreeCountPrimeNodesOne( pDsdMan->pRoots[i] ) );
|
185
|
-
printf("Max=%3d. ", MaxBlock );
|
186
|
-
printf("Reuse=%2d. ", s_nReusedBlocks-nReusedBlocksPres );
|
187
|
-
printf("Csc=%2d. ", nCascades );
|
188
|
-
printf("T= %.2f s. ", (float)(Abc_Clock()-clk)/(float)(CLOCKS_PER_SEC) ) ;
|
189
|
-
printf("Bdd=%2d. ", Cudd_DagSize(pbFuncs[i]) );
|
190
|
-
printf("\n");
|
191
|
-
fflush( stdout );
|
192
|
-
}
|
193
|
-
}
|
194
|
-
assert( pDsdMan->nRoots == nFuncs );
|
195
|
-
|
196
|
-
if ( pDsdMan->fVerbose )
|
197
|
-
{
|
198
|
-
printf( "\n" );
|
199
|
-
printf( "The cumulative decomposability statistics:\n" );
|
200
|
-
printf( " Total outputs = %5d\n", nFuncs );
|
201
|
-
printf( " Decomposable outputs = %5d\n", nDecOutputs );
|
202
|
-
printf( " Completely decomposable outputs = %5d\n", nCBFOutputs );
|
203
|
-
printf( " The sum of max gate sizes = %5d\n", SumMaxGateSize );
|
204
|
-
printf( " Shared BDD size = %5d\n", Cudd_SharingSize( pbFuncs, nFuncs ) );
|
205
|
-
printf( " Decomposition entries = %5d\n", st__count( pDsdMan->Table ) );
|
206
|
-
printf( " Pure decomposition time = %.2f sec\n", (float)(Abc_Clock() - clk)/(float)(CLOCKS_PER_SEC) );
|
207
|
-
}
|
208
|
-
/*
|
209
|
-
printf( "s_Loops1 = %d.\n", s_Loops1 );
|
210
|
-
printf( "s_Loops2 = %d.\n", s_Loops2 );
|
211
|
-
printf( "s_Loops3 = %d.\n", s_Loops3 );
|
212
|
-
printf( "s_Case4Calls = %d.\n", s_Case4Calls );
|
213
|
-
printf( "s_Case4CallsSpecial = %d.\n", s_Case4CallsSpecial );
|
214
|
-
printf( "s_Case5 = %d.\n", s_Case5 );
|
215
|
-
printf( "s_Loops2Useless = %d.\n", s_Loops2Useless );
|
216
|
-
*/
|
217
|
-
}
|
218
|
-
|
219
|
-
/**Function*************************************************************
|
220
|
-
|
221
|
-
Synopsis [Performs decomposition for one function.]
|
222
|
-
|
223
|
-
Description []
|
224
|
-
|
225
|
-
SideEffects []
|
226
|
-
|
227
|
-
SeeAlso []
|
228
|
-
|
229
|
-
***********************************************************************/
|
230
|
-
Dsd_Node_t * Dsd_DecomposeOne( Dsd_Manager_t * pDsdMan, DdNode * bFunc )
|
231
|
-
{
|
232
|
-
return dsdKernelDecompose_rec( pDsdMan, bFunc );
|
233
|
-
}
|
234
|
-
|
235
|
-
/**Function*************************************************************
|
236
|
-
|
237
|
-
Synopsis [The main function of this module. Recursive implementation of DSD.]
|
238
|
-
|
239
|
-
Description []
|
240
|
-
|
241
|
-
SideEffects []
|
242
|
-
|
243
|
-
SeeAlso []
|
244
|
-
|
245
|
-
***********************************************************************/
|
246
|
-
Dsd_Node_t * dsdKernelDecompose_rec( Dsd_Manager_t * pDsdMan, DdNode * bFunc0 )
|
247
|
-
{
|
248
|
-
DdManager * dd = pDsdMan->dd;
|
249
|
-
DdNode * bLow;
|
250
|
-
DdNode * bLowR;
|
251
|
-
DdNode * bHigh;
|
252
|
-
|
253
|
-
int VarInt;
|
254
|
-
DdNode * bVarCur;
|
255
|
-
Dsd_Node_t * pVarCurDE;
|
256
|
-
// works only if var indices start from 0!!!
|
257
|
-
DdNode * bSuppNew = NULL, * bTemp;
|
258
|
-
|
259
|
-
int fContained;
|
260
|
-
int nSuppLH;
|
261
|
-
int nSuppL;
|
262
|
-
int nSuppH;
|
263
|
-
|
264
|
-
|
265
|
-
|
266
|
-
// various decomposition nodes
|
267
|
-
Dsd_Node_t * pThis, * pL, * pH, * pLR, * pHR;
|
268
|
-
|
269
|
-
Dsd_Node_t * pSmallR, * pLargeR;
|
270
|
-
Dsd_Node_t * pTableEntry;
|
271
|
-
|
272
|
-
|
273
|
-
// treat the complemented case
|
274
|
-
DdNode * bF = Cudd_Regular(bFunc0);
|
275
|
-
int fCompF = (int)(bF != bFunc0);
|
276
|
-
|
277
|
-
// check cache
|
278
|
-
if ( st__lookup( pDsdMan->Table, (char*)bF, (char**)&pTableEntry ) )
|
279
|
-
{ // the entry is present
|
280
|
-
HashSuccess++;
|
281
|
-
return Dsd_NotCond( pTableEntry, fCompF );
|
282
|
-
}
|
283
|
-
HashFailure++;
|
284
|
-
Depth++;
|
285
|
-
|
286
|
-
// proceed to consider "four cases"
|
287
|
-
//////////////////////////////////////////////////////////////////////
|
288
|
-
// TERMINAL CASES - CASES 1 and 2
|
289
|
-
//////////////////////////////////////////////////////////////////////
|
290
|
-
bLow = cuddE(bF);
|
291
|
-
bLowR = Cudd_Regular(bLow);
|
292
|
-
bHigh = cuddT(bF);
|
293
|
-
VarInt = bF->index;
|
294
|
-
bVarCur = dd->vars[VarInt];
|
295
|
-
pVarCurDE = pDsdMan->pInputs[VarInt];
|
296
|
-
// works only if var indices start from 0!!!
|
297
|
-
bSuppNew = NULL;
|
298
|
-
|
299
|
-
if ( bLowR->index == CUDD_CONST_INDEX || bHigh->index == CUDD_CONST_INDEX )
|
300
|
-
{ // one of the cofactors in the constant
|
301
|
-
if ( bHigh == b1 ) // bHigh cannot be equal to b0, because then it will be complemented
|
302
|
-
if ( bLow == b0 ) // bLow cannot be equal to b1, because then the node will have bLow == bHigh
|
303
|
-
/////////////////////////////////////////////////////////////////
|
304
|
-
// bLow == 0, bHigh == 1, F = x'&0 + x&1 = x
|
305
|
-
/////////////////////////////////////////////////////////////////
|
306
|
-
{ // create the elementary variable node
|
307
|
-
assert(0); // should be already in the hash table
|
308
|
-
pThis = Dsd_TreeNodeCreate( DSD_NODE_BUF, 1, s_nDecBlocks++ );
|
309
|
-
pThis->pDecs[0] = NULL;
|
310
|
-
}
|
311
|
-
else // if ( bLow != constant )
|
312
|
-
/////////////////////////////////////////////////////////////////
|
313
|
-
// bLow != const, bHigh == 1, F = x'&bLow + x&1 = bLow + x --- DSD_NODE_OR(x,bLow)
|
314
|
-
/////////////////////////////////////////////////////////////////
|
315
|
-
{
|
316
|
-
pL = dsdKernelDecompose_rec( pDsdMan, bLow );
|
317
|
-
pLR = Dsd_Regular( pL );
|
318
|
-
bSuppNew = Cudd_bddAnd( dd, bVarCur, pLR->S ); Cudd_Ref(bSuppNew);
|
319
|
-
if ( pLR->Type == DSD_NODE_OR && pL == pLR ) // OR and no complement
|
320
|
-
{ // add to the components
|
321
|
-
pThis = Dsd_TreeNodeCreate( DSD_NODE_OR, pL->nDecs+1, s_nDecBlocks++ );
|
322
|
-
dsdKernelCopyListPlusOne( pThis, pVarCurDE, pL->pDecs, pL->nDecs );
|
323
|
-
}
|
324
|
-
else // all other cases
|
325
|
-
{ // create a new 2-input OR-gate
|
326
|
-
pThis = Dsd_TreeNodeCreate( DSD_NODE_OR, 2, s_nDecBlocks++ );
|
327
|
-
dsdKernelCopyListPlusOne( pThis, pVarCurDE, &pL, 1 );
|
328
|
-
}
|
329
|
-
}
|
330
|
-
else // if ( bHigh != const ) // meaning that bLow should be a constant
|
331
|
-
{
|
332
|
-
pH = dsdKernelDecompose_rec( pDsdMan, bHigh );
|
333
|
-
pHR = Dsd_Regular( pH );
|
334
|
-
bSuppNew = Cudd_bddAnd( dd, bVarCur, pHR->S ); Cudd_Ref(bSuppNew);
|
335
|
-
if ( bLow == b0 )
|
336
|
-
/////////////////////////////////////////////////////////////////
|
337
|
-
// Low == 0, High != 1, F = x'&0+x&High = (x'+High')'--- NOR(x',High')
|
338
|
-
/////////////////////////////////////////////////////////////////
|
339
|
-
if ( pHR->Type == DSD_NODE_OR && pH != pHR ) // DSD_NODE_OR and complement
|
340
|
-
{ // add to the components
|
341
|
-
pThis = Dsd_TreeNodeCreate( DSD_NODE_OR, pHR->nDecs+1, s_nDecBlocks++ );
|
342
|
-
dsdKernelCopyListPlusOne( pThis, Dsd_Not(pVarCurDE), pHR->pDecs, pHR->nDecs );
|
343
|
-
pThis = Dsd_Not(pThis);
|
344
|
-
}
|
345
|
-
else // all other cases
|
346
|
-
{ // create a new 2-input NOR gate
|
347
|
-
pThis = Dsd_TreeNodeCreate( DSD_NODE_OR, 2, s_nDecBlocks++ );
|
348
|
-
pH = Dsd_Not(pH);
|
349
|
-
dsdKernelCopyListPlusOne( pThis, Dsd_Not(pVarCurDE), &pH, 1 );
|
350
|
-
pThis = Dsd_Not(pThis);
|
351
|
-
}
|
352
|
-
else // if ( bLow == b1 )
|
353
|
-
/////////////////////////////////////////////////////////////////
|
354
|
-
// Low == 1, High != 1, F = x'&1 + x&High = x' + High --- DSD_NODE_OR(x',High)
|
355
|
-
/////////////////////////////////////////////////////////////////
|
356
|
-
if ( pHR->Type == DSD_NODE_OR && pH == pHR ) // OR and no complement
|
357
|
-
{ // add to the components
|
358
|
-
pThis = Dsd_TreeNodeCreate( DSD_NODE_OR, pH->nDecs+1, s_nDecBlocks++ );
|
359
|
-
dsdKernelCopyListPlusOne( pThis, Dsd_Not(pVarCurDE), pH->pDecs, pH->nDecs );
|
360
|
-
}
|
361
|
-
else // all other cases
|
362
|
-
{ // create a new 2-input OR-gate
|
363
|
-
pThis = Dsd_TreeNodeCreate( DSD_NODE_OR, 2, s_nDecBlocks++ );
|
364
|
-
dsdKernelCopyListPlusOne( pThis, Dsd_Not(pVarCurDE), &pH, 1 );
|
365
|
-
}
|
366
|
-
}
|
367
|
-
goto EXIT;
|
368
|
-
}
|
369
|
-
// else if ( bLow != const && bHigh != const )
|
370
|
-
|
371
|
-
// the case of equal cofactors (up to complementation)
|
372
|
-
if ( bLowR == bHigh )
|
373
|
-
/////////////////////////////////////////////////////////////////
|
374
|
-
// Low == G, High == G', F = x'&G + x&G' = (x(+)G) --- EXOR(x,Low)
|
375
|
-
/////////////////////////////////////////////////////////////////
|
376
|
-
{
|
377
|
-
pL = dsdKernelDecompose_rec( pDsdMan, bLow );
|
378
|
-
pLR = Dsd_Regular( pL );
|
379
|
-
bSuppNew = Cudd_bddAnd( dd, bVarCur, pLR->S ); Cudd_Ref(bSuppNew);
|
380
|
-
if ( pLR->Type == DSD_NODE_EXOR ) // complemented or not - does not matter!
|
381
|
-
{ // add to the components
|
382
|
-
pThis = Dsd_TreeNodeCreate( DSD_NODE_EXOR, pLR->nDecs+1, s_nDecBlocks++ );
|
383
|
-
dsdKernelCopyListPlusOne( pThis, pVarCurDE, pLR->pDecs, pLR->nDecs );
|
384
|
-
if ( pL != pLR )
|
385
|
-
pThis = Dsd_Not( pThis );
|
386
|
-
}
|
387
|
-
else // all other cases
|
388
|
-
{ // create a new 2-input EXOR-gate
|
389
|
-
pThis = Dsd_TreeNodeCreate( DSD_NODE_EXOR, 2, s_nDecBlocks++ );
|
390
|
-
if ( pL != pLR ) // complemented
|
391
|
-
{
|
392
|
-
dsdKernelCopyListPlusOne( pThis, pVarCurDE, &pLR, 1 );
|
393
|
-
pThis = Dsd_Not( pThis );
|
394
|
-
}
|
395
|
-
else // non-complemented
|
396
|
-
dsdKernelCopyListPlusOne( pThis, pVarCurDE, &pL, 1 );
|
397
|
-
}
|
398
|
-
goto EXIT;
|
399
|
-
}
|
400
|
-
|
401
|
-
//////////////////////////////////////////////////////////////////////
|
402
|
-
// solve subproblems
|
403
|
-
//////////////////////////////////////////////////////////////////////
|
404
|
-
pL = dsdKernelDecompose_rec( pDsdMan, bLow );
|
405
|
-
pH = dsdKernelDecompose_rec( pDsdMan, bHigh );
|
406
|
-
pLR = Dsd_Regular( pL );
|
407
|
-
pHR = Dsd_Regular( pH );
|
408
|
-
|
409
|
-
assert( pLR->Type == DSD_NODE_BUF || pLR->Type == DSD_NODE_OR || pLR->Type == DSD_NODE_EXOR || pLR->Type == DSD_NODE_PRIME );
|
410
|
-
assert( pHR->Type == DSD_NODE_BUF || pHR->Type == DSD_NODE_OR || pHR->Type == DSD_NODE_EXOR || pHR->Type == DSD_NODE_PRIME );
|
411
|
-
|
412
|
-
/*
|
413
|
-
if ( Depth == 1 )
|
414
|
-
{
|
415
|
-
// PRK(bLow,pDecTreeTotal->nInputs);
|
416
|
-
// PRK(bHigh,pDecTreeTotal->nInputs);
|
417
|
-
if ( s_Show )
|
418
|
-
{
|
419
|
-
PRD( pL );
|
420
|
-
PRD( pH );
|
421
|
-
}
|
422
|
-
}
|
423
|
-
*/
|
424
|
-
// compute the new support
|
425
|
-
bTemp = Cudd_bddAnd( dd, pLR->S, pHR->S ); Cudd_Ref( bTemp );
|
426
|
-
nSuppL = Extra_bddSuppSize( dd, pLR->S );
|
427
|
-
nSuppH = Extra_bddSuppSize( dd, pHR->S );
|
428
|
-
nSuppLH = Extra_bddSuppSize( dd, bTemp );
|
429
|
-
bSuppNew = Cudd_bddAnd( dd, bTemp, bVarCur ); Cudd_Ref( bSuppNew );
|
430
|
-
Cudd_RecursiveDeref( dd, bTemp );
|
431
|
-
|
432
|
-
|
433
|
-
// several possibilities are possible
|
434
|
-
// (1) support of one component contains another
|
435
|
-
// (2) none of the supports is contained in another
|
436
|
-
fContained = dsdKernelCheckContainment( pDsdMan, pLR, pHR, &pLargeR, &pSmallR );
|
437
|
-
|
438
|
-
//////////////////////////////////////////////////////////////////////
|
439
|
-
// CASE 3.b One of the cofactors in a constant (OR and EXOR)
|
440
|
-
//////////////////////////////////////////////////////////////////////
|
441
|
-
// the support of the larger component should contain the support of the smaller
|
442
|
-
// it is possible to have PRIME function in this role
|
443
|
-
// for example: F = ITE( a+b, c(+)d, e+f ), F0 = ITE( b, c(+)d, e+f ), F1 = c(+)d
|
444
|
-
if ( fContained )
|
445
|
-
{
|
446
|
-
Dsd_Node_t * pSmall, * pLarge;
|
447
|
-
int c, iCompLarge = -1; // the number of the component is Large is equal to the whole of Small; suppress "might be used uninitialized"
|
448
|
-
int fLowIsLarge;
|
449
|
-
|
450
|
-
DdNode * bFTemp; // the changed input function
|
451
|
-
Dsd_Node_t * pDETemp, * pDENew;
|
452
|
-
|
453
|
-
Dsd_Node_t * pComp = NULL;
|
454
|
-
int nComp = -1; // Suppress "might be used uninitialized"
|
455
|
-
|
456
|
-
if ( pSmallR == pLR )
|
457
|
-
{ // Low is Small => High is Large
|
458
|
-
pSmall = pL;
|
459
|
-
pLarge = pH;
|
460
|
-
fLowIsLarge = 0;
|
461
|
-
}
|
462
|
-
else
|
463
|
-
{ // vice versa
|
464
|
-
pSmall = pH;
|
465
|
-
pLarge = pL;
|
466
|
-
fLowIsLarge = 1;
|
467
|
-
}
|
468
|
-
|
469
|
-
// treat the situation when the larger is PRIME
|
470
|
-
if ( pLargeR->Type == DSD_NODE_PRIME ) //&& pLargeR->nDecs != pSmallR->nDecs )
|
471
|
-
{
|
472
|
-
// QUESTION: Is it possible for pLargeR->nDecs > 3
|
473
|
-
// and pSmall contained as one of input in pLarge?
|
474
|
-
// Yes, for example F = a'c + a & MUX(b,c',d) = a'c + abc' + ab'd is non-decomposable
|
475
|
-
// Consider the function H(a->xy) = F( xy, b, c, d )
|
476
|
-
// H0 = H(x=0) = F(0,b,c,d) = c
|
477
|
-
// H1 = F(x=1) = F(y,b,c,d) - non-decomposable
|
478
|
-
//
|
479
|
-
// QUESTION: Is it possible that pLarge is PRIME(3) and pSmall is OR(2),
|
480
|
-
// which is not contained in PRIME as one input?
|
481
|
-
// Yes, for example F = abcd + b'c'd' + a'c'd' = PRIME(ab, c, d)
|
482
|
-
// F(a=0) = c'd' = NOT(OR(a,d)) F(a=1) = bcd + b'c'd' = PRIME(b,c,d)
|
483
|
-
// To find decomposition, we have to prove that F(a=1)|b=0 = F(a=0)
|
484
|
-
|
485
|
-
// Is it possible that (pLargeR->nDecs == pSmallR->nDecs) and yet this case holds?
|
486
|
-
// Yes, consider the function such that F(a=0) = PRIME(a,b+c,d,e) and F(a=1) = OR(b,c,d,e)
|
487
|
-
// They have the same number of inputs and it is possible that they will be the cofactors
|
488
|
-
// as discribed in the previous example.
|
489
|
-
|
490
|
-
// find the component, which when substituted for 0 or 1, produces the desired result
|
491
|
-
int g, fFoundComp = -1; // {0,1} depending on whether setting cofactor to 0 or 1 worked out; suppress "might be used uninitialized"
|
492
|
-
|
493
|
-
DdNode * bLarge, * bSmall;
|
494
|
-
if ( fLowIsLarge )
|
495
|
-
{
|
496
|
-
bLarge = bLow;
|
497
|
-
bSmall = bHigh;
|
498
|
-
}
|
499
|
-
else
|
500
|
-
{
|
501
|
-
bLarge = bHigh;
|
502
|
-
bSmall = bLow;
|
503
|
-
}
|
504
|
-
|
505
|
-
for ( g = 0; g < pLargeR->nDecs; g++ )
|
506
|
-
// if ( g != c )
|
507
|
-
{
|
508
|
-
pDETemp = pLargeR->pDecs[g]; // cannot be complemented
|
509
|
-
if ( Dsd_CheckRootFunctionIdentity( dd, bLarge, bSmall, pDETemp->G, b1 ) )
|
510
|
-
{
|
511
|
-
fFoundComp = 1;
|
512
|
-
break;
|
513
|
-
}
|
514
|
-
|
515
|
-
s_Loops1++;
|
516
|
-
|
517
|
-
if ( Dsd_CheckRootFunctionIdentity( dd, bLarge, bSmall, Cudd_Not(pDETemp->G), b1 ) )
|
518
|
-
{
|
519
|
-
fFoundComp = 0;
|
520
|
-
break;
|
521
|
-
}
|
522
|
-
|
523
|
-
s_Loops1++;
|
524
|
-
}
|
525
|
-
|
526
|
-
if ( g != pLargeR->nDecs )
|
527
|
-
{ // decomposition is found
|
528
|
-
if ( fFoundComp )
|
529
|
-
if ( fLowIsLarge )
|
530
|
-
bFTemp = Cudd_bddOr( dd, bVarCur, pLargeR->pDecs[g]->G );
|
531
|
-
else
|
532
|
-
bFTemp = Cudd_bddOr( dd, Cudd_Not(bVarCur), pLargeR->pDecs[g]->G );
|
533
|
-
else
|
534
|
-
if ( fLowIsLarge )
|
535
|
-
bFTemp = Cudd_bddAnd( dd, Cudd_Not(bVarCur), pLargeR->pDecs[g]->G );
|
536
|
-
else
|
537
|
-
bFTemp = Cudd_bddAnd( dd, bVarCur, pLargeR->pDecs[g]->G );
|
538
|
-
Cudd_Ref( bFTemp );
|
539
|
-
|
540
|
-
pDENew = dsdKernelDecompose_rec( pDsdMan, bFTemp );
|
541
|
-
pDENew = Dsd_Regular( pDENew );
|
542
|
-
Cudd_RecursiveDeref( dd, bFTemp );
|
543
|
-
|
544
|
-
// get the new gate
|
545
|
-
pThis = Dsd_TreeNodeCreate( DSD_NODE_PRIME, pLargeR->nDecs, s_nDecBlocks++ );
|
546
|
-
dsdKernelCopyListPlusOneMinusOne( pThis, pDENew, pLargeR->pDecs, pLargeR->nDecs, g );
|
547
|
-
goto EXIT;
|
548
|
-
}
|
549
|
-
}
|
550
|
-
|
551
|
-
// try to find one component in the pLarger that is equal to the whole of pSmaller
|
552
|
-
for ( c = 0; c < pLargeR->nDecs; c++ )
|
553
|
-
if ( pLargeR->pDecs[c] == pSmall || pLargeR->pDecs[c] == Dsd_Not(pSmall) )
|
554
|
-
{
|
555
|
-
iCompLarge = c;
|
556
|
-
break;
|
557
|
-
}
|
558
|
-
|
559
|
-
// assign the equal component
|
560
|
-
if ( c != pLargeR->nDecs ) // the decomposition is possible!
|
561
|
-
{
|
562
|
-
pComp = pLargeR->pDecs[iCompLarge];
|
563
|
-
nComp = 1;
|
564
|
-
}
|
565
|
-
else // the decomposition is still possible
|
566
|
-
{ // for example F = OR(ab,c,d), F(a=0) = OR(c,d), F(a=1) = OR(b,c,d)
|
567
|
-
// supp(F0) is contained in supp(F1), Polarity(F(a=0)) == Polarity(F(a=1))
|
568
|
-
|
569
|
-
// try to find a group of common components
|
570
|
-
if ( pLargeR->Type == pSmallR->Type &&
|
571
|
-
(pLargeR->Type == DSD_NODE_EXOR || (pSmallR->Type == DSD_NODE_OR && ((pLarge==pLargeR) == (pSmall==pSmallR)))) )
|
572
|
-
{
|
573
|
-
Dsd_Node_t ** pCommon, * pLastDiffL = NULL, * pLastDiffH = NULL;
|
574
|
-
int nCommon = dsdKernelFindCommonComponents( pDsdMan, pLargeR, pSmallR, &pCommon, &pLastDiffL, &pLastDiffH );
|
575
|
-
// if all the components of pSmall are contained in pLarge,
|
576
|
-
// then the decomposition exists
|
577
|
-
if ( nCommon == pSmallR->nDecs )
|
578
|
-
{
|
579
|
-
pComp = pSmallR;
|
580
|
-
nComp = pSmallR->nDecs;
|
581
|
-
}
|
582
|
-
}
|
583
|
-
}
|
584
|
-
|
585
|
-
if ( pComp ) // the decomposition is possible!
|
586
|
-
{
|
587
|
-
// Dsd_Node_t * pComp = pLargeR->pDecs[iCompLarge];
|
588
|
-
Dsd_Node_t * pCompR = Dsd_Regular( pComp );
|
589
|
-
int fComp1 = (int)( pLarge != pLargeR );
|
590
|
-
int fComp2 = (int)( pComp != pCompR );
|
591
|
-
int fComp3 = (int)( pSmall != pSmallR );
|
592
|
-
|
593
|
-
DdNode * bFuncComp; // the function of the given component
|
594
|
-
DdNode * bFuncNew; // the function of the input component
|
595
|
-
|
596
|
-
if ( pLargeR->Type == DSD_NODE_OR ) // Figure 4 of Matsunaga's paper
|
597
|
-
{
|
598
|
-
// the decomposition exists only if the polarity assignment
|
599
|
-
// along the paths is the same
|
600
|
-
if ( (fComp1 ^ fComp2) == fComp3 )
|
601
|
-
{ // decomposition exists = consider 4 cases
|
602
|
-
// consideration of cases leads to the following conclusion
|
603
|
-
// fComp1 gives the polarity of the resulting DSD_NODE_OR gate
|
604
|
-
// fComp2 gives the polarity of the common component feeding into the DSD_NODE_OR gate
|
605
|
-
//
|
606
|
-
// | fComp1 pL/ |pS
|
607
|
-
// <> .........<=>....... <> |
|
608
|
-
// | / |
|
609
|
-
// [OR] [OR] | fComp3
|
610
|
-
// / \ fComp2 / | \ |
|
611
|
-
// <> <> .......<=>... /..|..<> |
|
612
|
-
// / \ / | \|
|
613
|
-
// [OR] [C] S1 S2 C
|
614
|
-
// / \ .
|
615
|
-
// <> \ .
|
616
|
-
// / \ .
|
617
|
-
// [OR] [x] .
|
618
|
-
// / \ .
|
619
|
-
// S1 S2 .
|
620
|
-
//
|
621
|
-
|
622
|
-
|
623
|
-
// at this point we have the function F (bFTemp) and the common component C (bFuncComp)
|
624
|
-
// to get the remainder, R, in the relationship F = R + C, supp(R) & supp(C) = 0
|
625
|
-
// we compute the following R = Exist( F - C, supp(C) )
|
626
|
-
bFTemp = (fComp1)? Cudd_Not( bF ): bF;
|
627
|
-
bFuncComp = (fComp2)? Cudd_Not( pCompR->G ): pCompR->G;
|
628
|
-
bFuncNew = Cudd_bddAndAbstract( dd, bFTemp, Cudd_Not(bFuncComp), pCompR->S ); Cudd_Ref( bFuncNew );
|
629
|
-
|
630
|
-
// there is no need to copy the dec entry list first, because pComp is a component
|
631
|
-
// which will not be destroyed by the recursive call to decomposition
|
632
|
-
pDENew = dsdKernelDecompose_rec( pDsdMan, bFuncNew );
|
633
|
-
assert( Dsd_IsComplement(pDENew) ); // follows from the consideration of cases
|
634
|
-
Cudd_RecursiveDeref( dd, bFuncNew );
|
635
|
-
|
636
|
-
// get the new gate
|
637
|
-
if ( nComp == 1 )
|
638
|
-
{
|
639
|
-
pThis = Dsd_TreeNodeCreate( DSD_NODE_OR, 2, s_nDecBlocks++ );
|
640
|
-
pThis->pDecs[0] = pDENew;
|
641
|
-
pThis->pDecs[1] = pComp; // takes the complement
|
642
|
-
}
|
643
|
-
else
|
644
|
-
{ // pComp is not complemented
|
645
|
-
pThis = Dsd_TreeNodeCreate( DSD_NODE_OR, nComp+1, s_nDecBlocks++ );
|
646
|
-
dsdKernelCopyListPlusOne( pThis, pDENew, pComp->pDecs, nComp );
|
647
|
-
}
|
648
|
-
|
649
|
-
if ( fComp1 )
|
650
|
-
pThis = Dsd_Not( pThis );
|
651
|
-
goto EXIT;
|
652
|
-
}
|
653
|
-
}
|
654
|
-
else if ( pLargeR->Type == DSD_NODE_EXOR ) // Figure 5 of Matsunaga's paper (with correction)
|
655
|
-
{ // decomposition always exists = consider 4 cases
|
656
|
-
|
657
|
-
// consideration of cases leads to the following conclusion
|
658
|
-
// fComp3 gives the COMPLEMENT of the polarity of the resulting EXOR gate
|
659
|
-
// (if fComp3 is 0, the EXOR gate is complemented, and vice versa)
|
660
|
-
//
|
661
|
-
// | fComp1 pL/ |pS
|
662
|
-
// <> .........<=>....... /....| fComp3
|
663
|
-
// | / |
|
664
|
-
// [XOR] [XOR] |
|
665
|
-
// / \ fComp2==0 / | \ |
|
666
|
-
// / \ / | \ |
|
667
|
-
// / \ / | \|
|
668
|
-
// [OR] [C] S1 S2 C
|
669
|
-
// / \ .
|
670
|
-
// <> \ .
|
671
|
-
// / \ .
|
672
|
-
// [XOR] [x] .
|
673
|
-
// / \ .
|
674
|
-
// S1 S2 .
|
675
|
-
//
|
676
|
-
|
677
|
-
assert( fComp2 == 0 );
|
678
|
-
// find the functionality of the lower gates
|
679
|
-
bFTemp = (fComp3)? bF: Cudd_Not( bF );
|
680
|
-
bFuncNew = Cudd_bddXor( dd, bFTemp, pComp->G ); Cudd_Ref( bFuncNew );
|
681
|
-
|
682
|
-
pDENew = dsdKernelDecompose_rec( pDsdMan, bFuncNew );
|
683
|
-
assert( !Dsd_IsComplement(pDENew) ); // follows from the consideration of cases
|
684
|
-
Cudd_RecursiveDeref( dd, bFuncNew );
|
685
|
-
|
686
|
-
// get the new gate
|
687
|
-
if ( nComp == 1 )
|
688
|
-
{
|
689
|
-
pThis = Dsd_TreeNodeCreate( DSD_NODE_EXOR, 2, s_nDecBlocks++ );
|
690
|
-
pThis->pDecs[0] = pDENew;
|
691
|
-
pThis->pDecs[1] = pComp;
|
692
|
-
}
|
693
|
-
else
|
694
|
-
{ // pComp is not complemented
|
695
|
-
pThis = Dsd_TreeNodeCreate( DSD_NODE_EXOR, nComp+1, s_nDecBlocks++ );
|
696
|
-
dsdKernelCopyListPlusOne( pThis, pDENew, pComp->pDecs, nComp );
|
697
|
-
}
|
698
|
-
|
699
|
-
if ( !fComp3 )
|
700
|
-
pThis = Dsd_Not( pThis );
|
701
|
-
goto EXIT;
|
702
|
-
}
|
703
|
-
}
|
704
|
-
}
|
705
|
-
|
706
|
-
// this case was added to fix the trivial bug found November 4, 2002 in Japan
|
707
|
-
// by running the example provided by T. Sasao
|
708
|
-
if ( nSuppLH == nSuppL + nSuppH ) // the supports of the components are disjoint
|
709
|
-
{
|
710
|
-
// create a new component of the type ITE( a, pH, pL )
|
711
|
-
pThis = Dsd_TreeNodeCreate( DSD_NODE_PRIME, 3, s_nDecBlocks++ );
|
712
|
-
if ( dd->perm[pLR->S->index] < dd->perm[pHR->S->index] ) // pLR is higher in the varible order
|
713
|
-
{
|
714
|
-
pThis->pDecs[1] = pLR;
|
715
|
-
pThis->pDecs[2] = pHR;
|
716
|
-
}
|
717
|
-
else // pHR is higher in the varible order
|
718
|
-
{
|
719
|
-
pThis->pDecs[1] = pHR;
|
720
|
-
pThis->pDecs[2] = pLR;
|
721
|
-
}
|
722
|
-
// add the first component
|
723
|
-
pThis->pDecs[0] = pVarCurDE;
|
724
|
-
goto EXIT;
|
725
|
-
}
|
726
|
-
|
727
|
-
|
728
|
-
//////////////////////////////////////////////////////////////////////
|
729
|
-
// CASE 3.a Neither of the cofactors is a constant (OR, EXOR, PRIME)
|
730
|
-
//////////////////////////////////////////////////////////////////////
|
731
|
-
// the component types are identical
|
732
|
-
// and if they are OR, they are either both complemented or both not complemented
|
733
|
-
// and if they are PRIME, their dec numbers should be the same
|
734
|
-
if ( pLR->Type == pHR->Type &&
|
735
|
-
pLR->Type != DSD_NODE_BUF &&
|
736
|
-
(pLR->Type != DSD_NODE_OR || ( (pL == pLR && pH == pHR) || (pL != pLR && pH != pHR) ) ) &&
|
737
|
-
(pLR->Type != DSD_NODE_PRIME || pLR->nDecs == pHR->nDecs) )
|
738
|
-
{
|
739
|
-
// array to store common comps in pL and pH
|
740
|
-
Dsd_Node_t ** pCommon, * pLastDiffL = NULL, * pLastDiffH = NULL;
|
741
|
-
int nCommon = dsdKernelFindCommonComponents( pDsdMan, pLR, pHR, &pCommon, &pLastDiffL, &pLastDiffH );
|
742
|
-
if ( nCommon )
|
743
|
-
{
|
744
|
-
if ( pLR->Type == DSD_NODE_OR ) // Figure 2 of Matsunaga's paper
|
745
|
-
{ // at this point we have the function F and the group of common components C
|
746
|
-
// to get the remainder, R, in the relationship F = R + C, supp(R) & supp(C) = 0
|
747
|
-
// we compute the following R = Exist( F - C, supp(C) )
|
748
|
-
|
749
|
-
// compute the sum total of the common components and the union of their supports
|
750
|
-
DdNode * bCommF, * bCommS, * bFTemp, * bFuncNew;
|
751
|
-
Dsd_Node_t * pDENew;
|
752
|
-
|
753
|
-
dsdKernelComputeSumOfComponents( pDsdMan, pCommon, nCommon, &bCommF, &bCommS, 0 );
|
754
|
-
Cudd_Ref( bCommF );
|
755
|
-
Cudd_Ref( bCommS );
|
756
|
-
bFTemp = ( pL != pLR )? Cudd_Not(bF): bF;
|
757
|
-
|
758
|
-
bFuncNew = Cudd_bddAndAbstract( dd, bFTemp, Cudd_Not(bCommF), bCommS ); Cudd_Ref( bFuncNew );
|
759
|
-
Cudd_RecursiveDeref( dd, bCommF );
|
760
|
-
Cudd_RecursiveDeref( dd, bCommS );
|
761
|
-
|
762
|
-
// get the new gate
|
763
|
-
|
764
|
-
// copy the components first, then call the decomposition
|
765
|
-
// because decomposition will distroy the list used for copying
|
766
|
-
pThis = Dsd_TreeNodeCreate( DSD_NODE_OR, nCommon + 1, s_nDecBlocks++ );
|
767
|
-
dsdKernelCopyListPlusOne( pThis, NULL, pCommon, nCommon );
|
768
|
-
|
769
|
-
// call the decomposition recursively
|
770
|
-
pDENew = dsdKernelDecompose_rec( pDsdMan, bFuncNew );
|
771
|
-
// assert( !Dsd_IsComplement(pDENew) ); // follows from the consideration of cases
|
772
|
-
Cudd_RecursiveDeref( dd, bFuncNew );
|
773
|
-
|
774
|
-
// add the first component
|
775
|
-
pThis->pDecs[0] = pDENew;
|
776
|
-
|
777
|
-
if ( pL != pLR )
|
778
|
-
pThis = Dsd_Not( pThis );
|
779
|
-
goto EXIT;
|
780
|
-
}
|
781
|
-
else
|
782
|
-
if ( pLR->Type == DSD_NODE_EXOR ) // Figure 3 of Matsunaga's paper
|
783
|
-
{
|
784
|
-
// compute the sum total of the common components and the union of their supports
|
785
|
-
DdNode * bCommF, * bFuncNew;
|
786
|
-
Dsd_Node_t * pDENew;
|
787
|
-
int fCompExor;
|
788
|
-
|
789
|
-
dsdKernelComputeSumOfComponents( pDsdMan, pCommon, nCommon, &bCommF, NULL, 1 );
|
790
|
-
Cudd_Ref( bCommF );
|
791
|
-
|
792
|
-
bFuncNew = Cudd_bddXor( dd, bF, bCommF ); Cudd_Ref( bFuncNew );
|
793
|
-
Cudd_RecursiveDeref( dd, bCommF );
|
794
|
-
|
795
|
-
// get the new gate
|
796
|
-
|
797
|
-
// copy the components first, then call the decomposition
|
798
|
-
// because decomposition will distroy the list used for copying
|
799
|
-
pThis = Dsd_TreeNodeCreate( DSD_NODE_EXOR, nCommon + 1, s_nDecBlocks++ );
|
800
|
-
dsdKernelCopyListPlusOne( pThis, NULL, pCommon, nCommon );
|
801
|
-
|
802
|
-
// call the decomposition recursively
|
803
|
-
pDENew = dsdKernelDecompose_rec( pDsdMan, bFuncNew );
|
804
|
-
Cudd_RecursiveDeref( dd, bFuncNew );
|
805
|
-
|
806
|
-
// remember the fact that it was complemented
|
807
|
-
fCompExor = Dsd_IsComplement(pDENew);
|
808
|
-
pDENew = Dsd_Regular(pDENew);
|
809
|
-
|
810
|
-
// add the first component
|
811
|
-
pThis->pDecs[0] = pDENew;
|
812
|
-
|
813
|
-
|
814
|
-
if ( fCompExor )
|
815
|
-
pThis = Dsd_Not( pThis );
|
816
|
-
goto EXIT;
|
817
|
-
}
|
818
|
-
else
|
819
|
-
if ( pLR->Type == DSD_NODE_PRIME && (nCommon == pLR->nDecs-1 || nCommon == pLR->nDecs) )
|
820
|
-
{
|
821
|
-
// for example the function F(a,b,c,d) = ITE(b,c,a(+)d) produces
|
822
|
-
// two cofactors F(a=0) = PRIME(b,c,d) and F(a=1) = PRIME(b,c,d)
|
823
|
-
// with exactly the same list of common components
|
824
|
-
|
825
|
-
Dsd_Node_t * pDENew;
|
826
|
-
DdNode * bFuncNew;
|
827
|
-
int fCompComp = 0; // this flag can be {0,1,2}
|
828
|
-
// if it is 0 there is no identity
|
829
|
-
// if it is 1/2, the cofactored functions are equal in the direct/complemented polarity
|
830
|
-
|
831
|
-
if ( nCommon == pLR->nDecs )
|
832
|
-
{ // all the components are the same
|
833
|
-
// find the formal input, in which pLow and pHigh differ (if such input exists)
|
834
|
-
int m;
|
835
|
-
Dsd_Node_t * pTempL, * pTempH;
|
836
|
-
|
837
|
-
s_Common++;
|
838
|
-
for ( m = 0; m < pLR->nDecs; m++ )
|
839
|
-
{
|
840
|
-
pTempL = pLR->pDecs[m]; // cannot be complemented
|
841
|
-
pTempH = pHR->pDecs[m]; // cannot be complemented
|
842
|
-
|
843
|
-
if ( Dsd_CheckRootFunctionIdentity( dd, bLow, bHigh, pTempL->G, Cudd_Not(pTempH->G) ) &&
|
844
|
-
Dsd_CheckRootFunctionIdentity( dd, bLow, bHigh, Cudd_Not(pTempL->G), pTempH->G ) )
|
845
|
-
{
|
846
|
-
pLastDiffL = pTempL;
|
847
|
-
pLastDiffH = pTempH;
|
848
|
-
assert( pLastDiffL == pLastDiffH );
|
849
|
-
fCompComp = 2;
|
850
|
-
break;
|
851
|
-
}
|
852
|
-
|
853
|
-
s_Loops2++;
|
854
|
-
s_Loops2++;
|
855
|
-
/*
|
856
|
-
if ( s_Loops2 % 10000 == 0 )
|
857
|
-
{
|
858
|
-
int i;
|
859
|
-
for ( i = 0; i < pLR->nDecs; i++ )
|
860
|
-
printf( " %d(s=%d)", pLR->pDecs[i]->Type,
|
861
|
-
Extra_bddSuppSize(dd, pLR->pDecs[i]->S) );
|
862
|
-
printf( "\n" );
|
863
|
-
}
|
864
|
-
*/
|
865
|
-
|
866
|
-
}
|
867
|
-
// if ( pLR->nDecs == Extra_bddSuppSize(dd, pLR->S) )
|
868
|
-
// s_Loops2Useless += pLR->nDecs * 2;
|
869
|
-
|
870
|
-
if ( fCompComp )
|
871
|
-
{ // put the equal components into pCommon, so that they could be copied into the new dec entry
|
872
|
-
nCommon = 0;
|
873
|
-
for ( m = 0; m < pLR->nDecs; m++ )
|
874
|
-
if ( pLR->pDecs[m] != pLastDiffL )
|
875
|
-
pCommon[nCommon++] = pLR->pDecs[m];
|
876
|
-
assert( nCommon = pLR->nDecs-1 );
|
877
|
-
}
|
878
|
-
}
|
879
|
-
else
|
880
|
-
{ // the differing components are known - check that they have compatible PRIME function
|
881
|
-
|
882
|
-
s_CommonNo++;
|
883
|
-
|
884
|
-
// find the numbers of different components
|
885
|
-
assert( pLastDiffL );
|
886
|
-
assert( pLastDiffH );
|
887
|
-
// also, they cannot be complemented, because the decomposition type is PRIME
|
888
|
-
|
889
|
-
if ( Dsd_CheckRootFunctionIdentity( dd, bLow, bHigh, Cudd_Not(pLastDiffL->G), Cudd_Not(pLastDiffH->G) ) &&
|
890
|
-
Dsd_CheckRootFunctionIdentity( dd, bLow, bHigh, pLastDiffL->G, pLastDiffH->G ) )
|
891
|
-
fCompComp = 1;
|
892
|
-
else if ( Dsd_CheckRootFunctionIdentity( dd, bLow, bHigh, pLastDiffL->G, Cudd_Not(pLastDiffH->G) ) &&
|
893
|
-
Dsd_CheckRootFunctionIdentity( dd, bLow, bHigh, Cudd_Not(pLastDiffL->G), pLastDiffH->G ) )
|
894
|
-
fCompComp = 2;
|
895
|
-
|
896
|
-
s_Loops3 += 4;
|
897
|
-
}
|
898
|
-
|
899
|
-
if ( fCompComp )
|
900
|
-
{
|
901
|
-
if ( fCompComp == 1 ) // it is true that bLow(G=0) == bHigh(H=0) && bLow(G=1) == bHigh(H=1)
|
902
|
-
bFuncNew = Cudd_bddIte( dd, bVarCur, pLastDiffH->G, pLastDiffL->G );
|
903
|
-
else // it is true that bLow(G=0) == bHigh(H=1) && bLow(G=1) == bHigh(H=0)
|
904
|
-
bFuncNew = Cudd_bddIte( dd, bVarCur, Cudd_Not(pLastDiffH->G), pLastDiffL->G );
|
905
|
-
Cudd_Ref( bFuncNew );
|
906
|
-
|
907
|
-
// get the new gate
|
908
|
-
|
909
|
-
// copy the components first, then call the decomposition
|
910
|
-
// because decomposition will distroy the list used for copying
|
911
|
-
pThis = Dsd_TreeNodeCreate( DSD_NODE_PRIME, pLR->nDecs, s_nDecBlocks++ );
|
912
|
-
dsdKernelCopyListPlusOne( pThis, NULL, pCommon, nCommon );
|
913
|
-
|
914
|
-
// create a new component
|
915
|
-
pDENew = dsdKernelDecompose_rec( pDsdMan, bFuncNew );
|
916
|
-
Cudd_RecursiveDeref( dd, bFuncNew );
|
917
|
-
// the BDD of the argument function in PRIME decomposition, should be regular
|
918
|
-
pDENew = Dsd_Regular(pDENew);
|
919
|
-
|
920
|
-
// add the first component
|
921
|
-
pThis->pDecs[0] = pDENew;
|
922
|
-
goto EXIT;
|
923
|
-
}
|
924
|
-
} // end of PRIME type
|
925
|
-
} // end of existing common components
|
926
|
-
} // end of CASE 3.a
|
927
|
-
|
928
|
-
// if ( Depth != 1)
|
929
|
-
// {
|
930
|
-
|
931
|
-
//CASE4:
|
932
|
-
//////////////////////////////////////////////////////////////////////
|
933
|
-
// CASE 4
|
934
|
-
//////////////////////////////////////////////////////////////////////
|
935
|
-
{
|
936
|
-
// estimate the number of entries in the list
|
937
|
-
int nEntriesMax = pDsdMan->nInputs - dd->perm[VarInt];
|
938
|
-
|
939
|
-
// create the new decomposition entry
|
940
|
-
int nEntries = 0;
|
941
|
-
|
942
|
-
DdNode * SuppL, * SuppH, * SuppL_init, * SuppH_init;
|
943
|
-
Dsd_Node_t *pHigher = NULL; // Suppress "might be used uninitialized"
|
944
|
-
Dsd_Node_t *pLower, * pTemp, * pDENew;
|
945
|
-
|
946
|
-
|
947
|
-
int levTopSuppL;
|
948
|
-
int levTopSuppH;
|
949
|
-
int levTop;
|
950
|
-
|
951
|
-
pThis = Dsd_TreeNodeCreate( DSD_NODE_PRIME, nEntriesMax, s_nDecBlocks++ );
|
952
|
-
pThis->pDecs[ nEntries++ ] = pVarCurDE;
|
953
|
-
// other entries will be added to this list one-by-one during analysis
|
954
|
-
|
955
|
-
// count how many times does it happen that the decomposition entries are
|
956
|
-
s_Case4Calls++;
|
957
|
-
|
958
|
-
// consider the simplest case: when the supports are equal
|
959
|
-
// and at least one of the components
|
960
|
-
// is the PRIME without decompositions, or
|
961
|
-
// when both of them are without decomposition
|
962
|
-
if ( (((pLR->Type == DSD_NODE_PRIME && nSuppL == pLR->nDecs) || (pHR->Type == DSD_NODE_PRIME && nSuppH == pHR->nDecs)) && pLR->S == pHR->S) ||
|
963
|
-
((pLR->Type == DSD_NODE_PRIME && nSuppL == pLR->nDecs) && (pHR->Type == DSD_NODE_PRIME && nSuppH == pHR->nDecs)) )
|
964
|
-
{
|
965
|
-
|
966
|
-
s_Case4CallsSpecial++;
|
967
|
-
// walk through both supports and create the decomposition list composed of simple entries
|
968
|
-
SuppL = pLR->S;
|
969
|
-
SuppH = pHR->S;
|
970
|
-
do
|
971
|
-
{
|
972
|
-
// determine levels
|
973
|
-
levTopSuppL = cuddI(dd,SuppL->index);
|
974
|
-
levTopSuppH = cuddI(dd,SuppH->index);
|
975
|
-
|
976
|
-
// skip the topmost variable in both supports
|
977
|
-
if ( levTopSuppL <= levTopSuppH )
|
978
|
-
{
|
979
|
-
levTop = levTopSuppL;
|
980
|
-
SuppL = cuddT(SuppL);
|
981
|
-
}
|
982
|
-
else
|
983
|
-
levTop = levTopSuppH;
|
984
|
-
|
985
|
-
if ( levTopSuppH <= levTopSuppL )
|
986
|
-
SuppH = cuddT(SuppH);
|
987
|
-
|
988
|
-
// set the new decomposition entry
|
989
|
-
pThis->pDecs[ nEntries++ ] = pDsdMan->pInputs[ dd->invperm[levTop] ];
|
990
|
-
}
|
991
|
-
while ( SuppL != b1 || SuppH != b1 );
|
992
|
-
}
|
993
|
-
else
|
994
|
-
{
|
995
|
-
|
996
|
-
// compare two different decomposition lists
|
997
|
-
SuppL_init = pLR->S;
|
998
|
-
SuppH_init = pHR->S;
|
999
|
-
// start references (because these supports will change)
|
1000
|
-
SuppL = pLR->S; Cudd_Ref( SuppL );
|
1001
|
-
SuppH = pHR->S; Cudd_Ref( SuppH );
|
1002
|
-
while ( SuppL != b1 || SuppH != b1 )
|
1003
|
-
{
|
1004
|
-
// determine the top level in cofactors and
|
1005
|
-
// whether they have the same top level
|
1006
|
-
int TopLevL = cuddI(dd,SuppL->index);
|
1007
|
-
int TopLevH = cuddI(dd,SuppH->index);
|
1008
|
-
int TopLevel = TopLevH;
|
1009
|
-
int fEqualLevel = 0;
|
1010
|
-
|
1011
|
-
DdNode * bVarTop;
|
1012
|
-
DdNode * bSuppSubract;
|
1013
|
-
|
1014
|
-
|
1015
|
-
if ( TopLevL < TopLevH )
|
1016
|
-
{
|
1017
|
-
pHigher = pLR;
|
1018
|
-
pLower = pHR;
|
1019
|
-
TopLevel = TopLevL;
|
1020
|
-
}
|
1021
|
-
else if ( TopLevL > TopLevH )
|
1022
|
-
{
|
1023
|
-
pHigher = pHR;
|
1024
|
-
pLower = pLR;
|
1025
|
-
}
|
1026
|
-
else
|
1027
|
-
fEqualLevel = 1;
|
1028
|
-
assert( TopLevel != CUDD_CONST_INDEX );
|
1029
|
-
|
1030
|
-
|
1031
|
-
// find the currently top variable in the decomposition lists
|
1032
|
-
bVarTop = dd->vars[dd->invperm[TopLevel]];
|
1033
|
-
|
1034
|
-
if ( !fEqualLevel )
|
1035
|
-
{
|
1036
|
-
// find the lower support
|
1037
|
-
DdNode * bSuppLower = (TopLevL < TopLevH)? SuppH_init: SuppL_init;
|
1038
|
-
|
1039
|
-
// find the first component in pHigher
|
1040
|
-
// whose support does not overlap with supp(Lower)
|
1041
|
-
// and remember the previous component
|
1042
|
-
int fPolarity;
|
1043
|
-
Dsd_Node_t * pPrev = NULL; // the pointer to the component proceeding pCur
|
1044
|
-
Dsd_Node_t * pCur = pHigher; // the first component not contained in supp(Lower)
|
1045
|
-
while ( Extra_bddSuppOverlapping( dd, pCur->S, bSuppLower ) )
|
1046
|
-
{ // get the next component
|
1047
|
-
pPrev = pCur;
|
1048
|
-
pCur = dsdKernelFindContainingComponent( pDsdMan, pCur, bVarTop, &fPolarity );
|
1049
|
-
};
|
1050
|
-
|
1051
|
-
// look for the possibility to subtract more than one component
|
1052
|
-
if ( pPrev == NULL || pPrev->Type == DSD_NODE_PRIME )
|
1053
|
-
{ // if there is no previous component, or if the previous component is PRIME
|
1054
|
-
// there is no way to subtract more than one component
|
1055
|
-
|
1056
|
-
// add the new decomposition entry (it is already regular)
|
1057
|
-
pThis->pDecs[ nEntries++ ] = pCur;
|
1058
|
-
// assign the support to be subtracted from both components
|
1059
|
-
bSuppSubract = pCur->S;
|
1060
|
-
}
|
1061
|
-
else // all other types
|
1062
|
-
{
|
1063
|
-
// go through the decomposition list of pPrev and find components
|
1064
|
-
// whose support does not overlap with supp(Lower)
|
1065
|
-
|
1066
|
-
static Dsd_Node_t * pNonOverlap[MAXINPUTS];
|
1067
|
-
int i, nNonOverlap = 0;
|
1068
|
-
for ( i = 0; i < pPrev->nDecs; i++ )
|
1069
|
-
{
|
1070
|
-
pTemp = Dsd_Regular( pPrev->pDecs[i] );
|
1071
|
-
if ( !Extra_bddSuppOverlapping( dd, pTemp->S, bSuppLower ) )
|
1072
|
-
pNonOverlap[ nNonOverlap++ ] = pPrev->pDecs[i];
|
1073
|
-
}
|
1074
|
-
assert( nNonOverlap > 0 );
|
1075
|
-
|
1076
|
-
if ( nNonOverlap == 1 )
|
1077
|
-
{ // one one component was found, which is the original one
|
1078
|
-
assert( Dsd_Regular(pNonOverlap[0]) == pCur);
|
1079
|
-
// add the new decomposition entry
|
1080
|
-
pThis->pDecs[ nEntries++ ] = pCur;
|
1081
|
-
// assign the support to be subtracted from both components
|
1082
|
-
bSuppSubract = pCur->S;
|
1083
|
-
}
|
1084
|
-
else // more than one components was found
|
1085
|
-
{
|
1086
|
-
// find the OR (EXOR) of the non-overlapping components
|
1087
|
-
DdNode * bCommF;
|
1088
|
-
dsdKernelComputeSumOfComponents( pDsdMan, pNonOverlap, nNonOverlap, &bCommF, NULL, (int)(pPrev->Type==DSD_NODE_EXOR) );
|
1089
|
-
Cudd_Ref( bCommF );
|
1090
|
-
|
1091
|
-
// create a new gated
|
1092
|
-
pDENew = dsdKernelDecompose_rec( pDsdMan, bCommF );
|
1093
|
-
Cudd_RecursiveDeref(dd, bCommF);
|
1094
|
-
// make it regular... it must be regular already
|
1095
|
-
assert( !Dsd_IsComplement(pDENew) );
|
1096
|
-
|
1097
|
-
// add the new decomposition entry
|
1098
|
-
pThis->pDecs[ nEntries++ ] = pDENew;
|
1099
|
-
// assign the support to be subtracted from both components
|
1100
|
-
bSuppSubract = pDENew->S;
|
1101
|
-
}
|
1102
|
-
}
|
1103
|
-
|
1104
|
-
// subtract its support from the support of upper component
|
1105
|
-
if ( TopLevL < TopLevH )
|
1106
|
-
{
|
1107
|
-
SuppL = Cudd_bddExistAbstract( dd, bTemp = SuppL, bSuppSubract ); Cudd_Ref( SuppL );
|
1108
|
-
Cudd_RecursiveDeref(dd, bTemp);
|
1109
|
-
}
|
1110
|
-
else
|
1111
|
-
{
|
1112
|
-
SuppH = Cudd_bddExistAbstract( dd, bTemp = SuppH, bSuppSubract ); Cudd_Ref( SuppH );
|
1113
|
-
Cudd_RecursiveDeref(dd, bTemp);
|
1114
|
-
}
|
1115
|
-
} // end of if ( !fEqualLevel )
|
1116
|
-
else // if ( fEqualLevel ) -- they have the same top level var
|
1117
|
-
{
|
1118
|
-
static Dsd_Node_t * pMarkedLeft[MAXINPUTS]; // the pointers to the marked blocks
|
1119
|
-
static char pMarkedPols[MAXINPUTS]; // polarities of the marked blocks
|
1120
|
-
int nMarkedLeft = 0;
|
1121
|
-
|
1122
|
-
int fPolarity = 0;
|
1123
|
-
Dsd_Node_t * pTempL = pLR;
|
1124
|
-
|
1125
|
-
int fPolarityCurH = 0;
|
1126
|
-
Dsd_Node_t * pPrevH = NULL, * pCurH = pHR;
|
1127
|
-
|
1128
|
-
int fPolarityCurL = 0;
|
1129
|
-
Dsd_Node_t * pPrevL = NULL, * pCurL = pLR; // = pMarkedLeft[0];
|
1130
|
-
int index = 1;
|
1131
|
-
|
1132
|
-
// set the new mark
|
1133
|
-
s_Mark++;
|
1134
|
-
|
1135
|
-
// go over the dec list of pL, mark all components that contain the given variable
|
1136
|
-
assert( Extra_bddSuppContainVar( dd, pLR->S, bVarTop ) );
|
1137
|
-
assert( Extra_bddSuppContainVar( dd, pHR->S, bVarTop ) );
|
1138
|
-
do {
|
1139
|
-
pTempL->Mark = s_Mark;
|
1140
|
-
pMarkedLeft[ nMarkedLeft ] = pTempL;
|
1141
|
-
pMarkedPols[ nMarkedLeft ] = fPolarity;
|
1142
|
-
nMarkedLeft++;
|
1143
|
-
} while ( (pTempL = dsdKernelFindContainingComponent( pDsdMan, pTempL, bVarTop, &fPolarity )) );
|
1144
|
-
|
1145
|
-
// go over the dec list of pH, and find the component that is marked and the previos one
|
1146
|
-
// (such component always exists, because they have common variables)
|
1147
|
-
while ( pCurH->Mark != s_Mark )
|
1148
|
-
{
|
1149
|
-
pPrevH = pCurH;
|
1150
|
-
pCurH = dsdKernelFindContainingComponent( pDsdMan, pCurH, bVarTop, &fPolarityCurH );
|
1151
|
-
assert( pCurH );
|
1152
|
-
}
|
1153
|
-
|
1154
|
-
// go through the first list once again and find
|
1155
|
-
// the component proceeding the one marked found in the second list
|
1156
|
-
while ( pCurL != pCurH )
|
1157
|
-
{
|
1158
|
-
pPrevL = pCurL;
|
1159
|
-
pCurL = pMarkedLeft[index];
|
1160
|
-
fPolarityCurL = pMarkedPols[index];
|
1161
|
-
index++;
|
1162
|
-
}
|
1163
|
-
|
1164
|
-
// look for the possibility to subtract more than one component
|
1165
|
-
if ( !pPrevL || !pPrevH || pPrevL->Type != pPrevH->Type || pPrevL->Type == DSD_NODE_PRIME || fPolarityCurL != fPolarityCurH )
|
1166
|
-
{ // there is no way to extract more than one
|
1167
|
-
pThis->pDecs[ nEntries++ ] = pCurH;
|
1168
|
-
// assign the support to be subtracted from both components
|
1169
|
-
bSuppSubract = pCurH->S;
|
1170
|
-
}
|
1171
|
-
else
|
1172
|
-
{
|
1173
|
-
// find the equal components in two decomposition lists
|
1174
|
-
Dsd_Node_t ** pCommon, * pLastDiffL = NULL, * pLastDiffH = NULL;
|
1175
|
-
int nCommon = dsdKernelFindCommonComponents( pDsdMan, pPrevL, pPrevH, &pCommon, &pLastDiffL, &pLastDiffH );
|
1176
|
-
|
1177
|
-
if ( nCommon == 0 || nCommon == 1 )
|
1178
|
-
{ // one one component was found, which is the original one
|
1179
|
-
// assert( Dsd_Regular(pCommon[0]) == pCurL);
|
1180
|
-
// add the new decomposition entry
|
1181
|
-
pThis->pDecs[ nEntries++ ] = pCurL;
|
1182
|
-
// assign the support to be subtracted from both components
|
1183
|
-
bSuppSubract = pCurL->S;
|
1184
|
-
}
|
1185
|
-
else // more than one components was found
|
1186
|
-
{
|
1187
|
-
// find the OR (EXOR) of the non-overlapping components
|
1188
|
-
DdNode * bCommF;
|
1189
|
-
dsdKernelComputeSumOfComponents( pDsdMan, pCommon, nCommon, &bCommF, NULL, (int)(pPrevL->Type==DSD_NODE_EXOR) );
|
1190
|
-
Cudd_Ref( bCommF );
|
1191
|
-
|
1192
|
-
pDENew = dsdKernelDecompose_rec( pDsdMan, bCommF );
|
1193
|
-
assert( !Dsd_IsComplement(pDENew) ); // cannot be complemented because of construction
|
1194
|
-
Cudd_RecursiveDeref( dd, bCommF );
|
1195
|
-
|
1196
|
-
// add the new decomposition entry
|
1197
|
-
pThis->pDecs[ nEntries++ ] = pDENew;
|
1198
|
-
|
1199
|
-
// assign the support to be subtracted from both components
|
1200
|
-
bSuppSubract = pDENew->S;
|
1201
|
-
}
|
1202
|
-
}
|
1203
|
-
|
1204
|
-
SuppL = Cudd_bddExistAbstract( dd, bTemp = SuppL, bSuppSubract ), Cudd_Ref( SuppL );
|
1205
|
-
Cudd_RecursiveDeref(dd, bTemp);
|
1206
|
-
|
1207
|
-
SuppH = Cudd_bddExistAbstract( dd, bTemp = SuppH, bSuppSubract ), Cudd_Ref( SuppH );
|
1208
|
-
Cudd_RecursiveDeref(dd, bTemp);
|
1209
|
-
|
1210
|
-
} // end of if ( fEqualLevel )
|
1211
|
-
|
1212
|
-
} // end of decomposition list comparison
|
1213
|
-
Cudd_RecursiveDeref( dd, SuppL );
|
1214
|
-
Cudd_RecursiveDeref( dd, SuppH );
|
1215
|
-
|
1216
|
-
}
|
1217
|
-
|
1218
|
-
// check that the estimation of the number of entries was okay
|
1219
|
-
assert( nEntries <= nEntriesMax );
|
1220
|
-
|
1221
|
-
// if ( nEntries != Extra_bddSuppSize(dd, bSuppNew) )
|
1222
|
-
// s_Case5++;
|
1223
|
-
|
1224
|
-
// update the number of entries in the new decomposition list
|
1225
|
-
pThis->nDecs = nEntries;
|
1226
|
-
}
|
1227
|
-
//}
|
1228
|
-
EXIT:
|
1229
|
-
|
1230
|
-
{
|
1231
|
-
// if the component created is complemented, it represents a function without complement
|
1232
|
-
// therefore, as it is, without complement, it should recieve the complemented function
|
1233
|
-
Dsd_Node_t * pThisR = Dsd_Regular( pThis );
|
1234
|
-
assert( pThisR->G == NULL );
|
1235
|
-
assert( pThisR->S == NULL );
|
1236
|
-
|
1237
|
-
if ( pThisR == pThis ) // set regular function
|
1238
|
-
pThisR->G = bF;
|
1239
|
-
else // set complemented function
|
1240
|
-
pThisR->G = Cudd_Not(bF);
|
1241
|
-
Cudd_Ref(bF); // reference the function in the component
|
1242
|
-
|
1243
|
-
assert( bSuppNew );
|
1244
|
-
pThisR->S = bSuppNew; // takes the reference from the new support
|
1245
|
-
if ( st__insert( pDsdMan->Table, (char*)bF, (char*)pThis ) )
|
1246
|
-
{
|
1247
|
-
assert( 0 );
|
1248
|
-
}
|
1249
|
-
s_CacheEntries++;
|
1250
|
-
|
1251
|
-
|
1252
|
-
/*
|
1253
|
-
if ( dsdKernelVerifyDecomposition(dd, pThis) == 0 )
|
1254
|
-
{
|
1255
|
-
// write the function, for which verification does not work
|
1256
|
-
cout << endl << "Internal verification failed!"" );
|
1257
|
-
|
1258
|
-
// create the variable mask
|
1259
|
-
static int s_pVarMask[MAXINPUTS];
|
1260
|
-
int nInputCounter = 0;
|
1261
|
-
|
1262
|
-
Cudd_SupportArray( dd, bF, s_pVarMask );
|
1263
|
-
int k;
|
1264
|
-
for ( k = 0; k < dd->size; k++ )
|
1265
|
-
if ( s_pVarMask[k] )
|
1266
|
-
nInputCounter++;
|
1267
|
-
|
1268
|
-
cout << endl << "The problem function is "" );
|
1269
|
-
|
1270
|
-
DdNode * zNewFunc = Cudd_zddIsopCover( dd, bF, bF ); Cudd_Ref( zNewFunc );
|
1271
|
-
cuddWriteFunctionSop( stdout, dd, zNewFunc, -1, dd->size, "1", s_pVarMask );
|
1272
|
-
Cudd_RecursiveDerefZdd( dd, zNewFunc );
|
1273
|
-
}
|
1274
|
-
*/
|
1275
|
-
|
1276
|
-
}
|
1277
|
-
|
1278
|
-
Depth--;
|
1279
|
-
return Dsd_NotCond( pThis, fCompF );
|
1280
|
-
}
|
1281
|
-
|
1282
|
-
|
1283
|
-
////////////////////////////////////////////////////////////////////////
|
1284
|
-
/// OTHER FUNCTIONS ///
|
1285
|
-
////////////////////////////////////////////////////////////////////////
|
1286
|
-
|
1287
|
-
/**Function*************************************************************
|
1288
|
-
|
1289
|
-
Synopsis [Finds the corresponding decomposition entry.]
|
1290
|
-
|
1291
|
-
Description [This function returns the non-complemented pointer to the
|
1292
|
-
DecEntry of that component which contains the given variable in its
|
1293
|
-
support, or NULL if no such component exists]
|
1294
|
-
|
1295
|
-
SideEffects []
|
1296
|
-
|
1297
|
-
SeeAlso []
|
1298
|
-
|
1299
|
-
***********************************************************************/
|
1300
|
-
Dsd_Node_t * dsdKernelFindContainingComponent( Dsd_Manager_t * pDsdMan, Dsd_Node_t * pWhere, DdNode * Var, int * fPolarity )
|
1301
|
-
|
1302
|
-
{
|
1303
|
-
Dsd_Node_t * pTemp;
|
1304
|
-
int i;
|
1305
|
-
|
1306
|
-
// assert( !Dsd_IsComplement( pWhere ) );
|
1307
|
-
// assert( Extra_bddSuppContainVar( pDsdMan->dd, pWhere->S, Var ) );
|
1308
|
-
|
1309
|
-
if ( pWhere->nDecs == 1 )
|
1310
|
-
return NULL;
|
1311
|
-
|
1312
|
-
for( i = 0; i < pWhere->nDecs; i++ )
|
1313
|
-
{
|
1314
|
-
pTemp = Dsd_Regular( pWhere->pDecs[i] );
|
1315
|
-
if ( Extra_bddSuppContainVar( pDsdMan->dd, pTemp->S, Var ) )
|
1316
|
-
{
|
1317
|
-
*fPolarity = (int)( pTemp != pWhere->pDecs[i] );
|
1318
|
-
return pTemp;
|
1319
|
-
}
|
1320
|
-
}
|
1321
|
-
assert( 0 );
|
1322
|
-
return NULL;
|
1323
|
-
}
|
1324
|
-
|
1325
|
-
/**Function*************************************************************
|
1326
|
-
|
1327
|
-
Synopsis [Find the common decomposition components.]
|
1328
|
-
|
1329
|
-
Description [This function determines the common components. It counts
|
1330
|
-
the number of common components in the decomposition lists of pL and pH
|
1331
|
-
and returns their number and the lists of common components. It assumes
|
1332
|
-
that pL and pH are regular pointers. It retuns also the pointers to the
|
1333
|
-
last different components encountered in pL and pH.]
|
1334
|
-
|
1335
|
-
SideEffects []
|
1336
|
-
|
1337
|
-
SeeAlso []
|
1338
|
-
|
1339
|
-
***********************************************************************/
|
1340
|
-
int dsdKernelFindCommonComponents( Dsd_Manager_t * pDsdMan, Dsd_Node_t * pL, Dsd_Node_t * pH, Dsd_Node_t *** pCommon, Dsd_Node_t ** pLastDiffL, Dsd_Node_t ** pLastDiffH )
|
1341
|
-
{
|
1342
|
-
static Dsd_Node_t * Common[MAXINPUTS];
|
1343
|
-
int nCommon = 0;
|
1344
|
-
|
1345
|
-
// pointers to the current decomposition entries
|
1346
|
-
Dsd_Node_t * pLcur;
|
1347
|
-
Dsd_Node_t * pHcur;
|
1348
|
-
|
1349
|
-
// the pointers to their supports
|
1350
|
-
DdNode * bSLcur;
|
1351
|
-
DdNode * bSHcur;
|
1352
|
-
|
1353
|
-
// the top variable in the supports
|
1354
|
-
int TopVar;
|
1355
|
-
|
1356
|
-
// the indices running through the components
|
1357
|
-
int iCurL = 0;
|
1358
|
-
int iCurH = 0;
|
1359
|
-
while ( iCurL < pL->nDecs && iCurH < pH->nDecs )
|
1360
|
-
{ // both did not run out
|
1361
|
-
|
1362
|
-
pLcur = Dsd_Regular(pL->pDecs[iCurL]);
|
1363
|
-
pHcur = Dsd_Regular(pH->pDecs[iCurH]);
|
1364
|
-
|
1365
|
-
bSLcur = pLcur->S;
|
1366
|
-
bSHcur = pHcur->S;
|
1367
|
-
|
1368
|
-
// find out what component is higher in the BDD
|
1369
|
-
if ( pDsdMan->dd->perm[bSLcur->index] < pDsdMan->dd->perm[bSHcur->index] )
|
1370
|
-
TopVar = bSLcur->index;
|
1371
|
-
else
|
1372
|
-
TopVar = bSHcur->index;
|
1373
|
-
|
1374
|
-
if ( TopVar == bSLcur->index && TopVar == bSHcur->index )
|
1375
|
-
{
|
1376
|
-
// the components may be equal - should match exactly!
|
1377
|
-
if ( pL->pDecs[iCurL] == pH->pDecs[iCurH] )
|
1378
|
-
Common[nCommon++] = pL->pDecs[iCurL];
|
1379
|
-
else
|
1380
|
-
{
|
1381
|
-
*pLastDiffL = pL->pDecs[iCurL];
|
1382
|
-
*pLastDiffH = pH->pDecs[iCurH];
|
1383
|
-
}
|
1384
|
-
|
1385
|
-
// skip both
|
1386
|
-
iCurL++;
|
1387
|
-
iCurH++;
|
1388
|
-
}
|
1389
|
-
else if ( TopVar == bSLcur->index )
|
1390
|
-
{ // the components cannot be equal
|
1391
|
-
// skip the top-most one
|
1392
|
-
*pLastDiffL = pL->pDecs[iCurL++];
|
1393
|
-
}
|
1394
|
-
else // if ( TopVar == bSHcur->index )
|
1395
|
-
{ // the components cannot be equal
|
1396
|
-
// skip the top-most one
|
1397
|
-
*pLastDiffH = pH->pDecs[iCurH++];
|
1398
|
-
}
|
1399
|
-
}
|
1400
|
-
|
1401
|
-
// if one of the lists still has components, write the first one down
|
1402
|
-
if ( iCurL < pL->nDecs )
|
1403
|
-
*pLastDiffL = pL->pDecs[iCurL];
|
1404
|
-
|
1405
|
-
if ( iCurH < pH->nDecs )
|
1406
|
-
*pLastDiffH = pH->pDecs[iCurH];
|
1407
|
-
|
1408
|
-
// return the pointer to the array
|
1409
|
-
*pCommon = Common;
|
1410
|
-
// return the number of common components
|
1411
|
-
return nCommon;
|
1412
|
-
}
|
1413
|
-
|
1414
|
-
/**Function*************************************************************
|
1415
|
-
|
1416
|
-
Synopsis [Computes the sum (OR or EXOR) of the functions of the components.]
|
1417
|
-
|
1418
|
-
Description []
|
1419
|
-
|
1420
|
-
SideEffects []
|
1421
|
-
|
1422
|
-
SeeAlso []
|
1423
|
-
|
1424
|
-
***********************************************************************/
|
1425
|
-
void dsdKernelComputeSumOfComponents( Dsd_Manager_t * pDsdMan, Dsd_Node_t ** pCommon, int nCommon, DdNode ** pCompF, DdNode ** pCompS, int fExor )
|
1426
|
-
{
|
1427
|
-
DdManager * dd = pDsdMan->dd;
|
1428
|
-
DdNode * bF, * bFadd, * bTemp;
|
1429
|
-
DdNode * bS = NULL; // Suppress "might be used uninitialized"
|
1430
|
-
Dsd_Node_t * pDE, * pDER;
|
1431
|
-
int i;
|
1432
|
-
|
1433
|
-
// start the function
|
1434
|
-
bF = b0; Cudd_Ref( bF );
|
1435
|
-
// start the support
|
1436
|
-
if ( pCompS )
|
1437
|
-
bS = b1, Cudd_Ref( bS );
|
1438
|
-
|
1439
|
-
assert( nCommon > 0 );
|
1440
|
-
for ( i = 0; i < nCommon; i++ )
|
1441
|
-
{
|
1442
|
-
pDE = pCommon[i];
|
1443
|
-
pDER = Dsd_Regular( pDE );
|
1444
|
-
bFadd = (pDE != pDER)? Cudd_Not(pDER->G): pDER->G;
|
1445
|
-
// add to the function
|
1446
|
-
if ( fExor )
|
1447
|
-
bF = Cudd_bddXor( dd, bTemp = bF, bFadd );
|
1448
|
-
else
|
1449
|
-
bF = Cudd_bddOr( dd, bTemp = bF, bFadd );
|
1450
|
-
Cudd_Ref( bF );
|
1451
|
-
Cudd_RecursiveDeref( dd, bTemp );
|
1452
|
-
if ( pCompS )
|
1453
|
-
{
|
1454
|
-
// add to the support
|
1455
|
-
bS = Cudd_bddAnd( dd, bTemp = bS, pDER->S ); Cudd_Ref( bS );
|
1456
|
-
Cudd_RecursiveDeref( dd, bTemp );
|
1457
|
-
}
|
1458
|
-
}
|
1459
|
-
// return the function
|
1460
|
-
Cudd_Deref( bF );
|
1461
|
-
*pCompF = bF;
|
1462
|
-
|
1463
|
-
// return the support
|
1464
|
-
if ( pCompS )
|
1465
|
-
Cudd_Deref( bS ), *pCompS = bS;
|
1466
|
-
}
|
1467
|
-
|
1468
|
-
/**Function*************************************************************
|
1469
|
-
|
1470
|
-
Synopsis [Checks support containment of the decomposition components.]
|
1471
|
-
|
1472
|
-
Description [This function returns 1 if support of one component is contained
|
1473
|
-
in that of another. In this case, pLarge (pSmall) is assigned to point to the
|
1474
|
-
larger (smaller) support. If the supports are identical return 0, and does not
|
1475
|
-
assign the components.]
|
1476
|
-
]
|
1477
|
-
|
1478
|
-
SideEffects []
|
1479
|
-
|
1480
|
-
SeeAlso []
|
1481
|
-
|
1482
|
-
***********************************************************************/
|
1483
|
-
int dsdKernelCheckContainment( Dsd_Manager_t * pDsdMan, Dsd_Node_t * pL, Dsd_Node_t * pH, Dsd_Node_t ** pLarge, Dsd_Node_t ** pSmall )
|
1484
|
-
{
|
1485
|
-
DdManager * dd = pDsdMan->dd;
|
1486
|
-
DdNode * bSuppLarge, * bSuppSmall;
|
1487
|
-
int RetValue;
|
1488
|
-
|
1489
|
-
RetValue = Extra_bddSuppCheckContainment( dd, pL->S, pH->S, &bSuppLarge, &bSuppSmall );
|
1490
|
-
|
1491
|
-
if ( RetValue == 0 )
|
1492
|
-
return 0;
|
1493
|
-
|
1494
|
-
if ( pH->S == bSuppLarge )
|
1495
|
-
{
|
1496
|
-
*pLarge = pH;
|
1497
|
-
*pSmall = pL;
|
1498
|
-
}
|
1499
|
-
else // if ( pL->S == bSuppLarge )
|
1500
|
-
{
|
1501
|
-
*pLarge = pL;
|
1502
|
-
*pSmall = pH;
|
1503
|
-
}
|
1504
|
-
return 1;
|
1505
|
-
}
|
1506
|
-
|
1507
|
-
/**Function*************************************************************
|
1508
|
-
|
1509
|
-
Synopsis [Copies the list of components plus one.]
|
1510
|
-
|
1511
|
-
Description []
|
1512
|
-
|
1513
|
-
SideEffects []
|
1514
|
-
|
1515
|
-
SeeAlso []
|
1516
|
-
|
1517
|
-
***********************************************************************/
|
1518
|
-
void dsdKernelCopyListPlusOne( Dsd_Node_t * p, Dsd_Node_t * First, Dsd_Node_t ** ppList, int nListSize )
|
1519
|
-
{
|
1520
|
-
int i;
|
1521
|
-
assert( nListSize+1 == p->nDecs );
|
1522
|
-
p->pDecs[0] = First;
|
1523
|
-
for( i = 0; i < nListSize; i++ )
|
1524
|
-
p->pDecs[i+1] = ppList[i];
|
1525
|
-
}
|
1526
|
-
|
1527
|
-
/**Function*************************************************************
|
1528
|
-
|
1529
|
-
Synopsis [Copies the list of components plus one, and skips one.]
|
1530
|
-
|
1531
|
-
Description []
|
1532
|
-
|
1533
|
-
SideEffects []
|
1534
|
-
|
1535
|
-
SeeAlso []
|
1536
|
-
|
1537
|
-
***********************************************************************/
|
1538
|
-
void dsdKernelCopyListPlusOneMinusOne( Dsd_Node_t * p, Dsd_Node_t * First, Dsd_Node_t ** ppList, int nListSize, int iSkipped )
|
1539
|
-
{
|
1540
|
-
int i, Counter;
|
1541
|
-
assert( nListSize == p->nDecs );
|
1542
|
-
p->pDecs[0] = First;
|
1543
|
-
for( i = 0, Counter = 1; i < nListSize; i++ )
|
1544
|
-
if ( i != iSkipped )
|
1545
|
-
p->pDecs[Counter++] = ppList[i];
|
1546
|
-
}
|
1547
|
-
|
1548
|
-
/**Function*************************************************************
|
1549
|
-
|
1550
|
-
Synopsis [Debugging procedure to compute the functionality of the decomposed structure.]
|
1551
|
-
|
1552
|
-
Description []
|
1553
|
-
|
1554
|
-
SideEffects []
|
1555
|
-
|
1556
|
-
SeeAlso []
|
1557
|
-
|
1558
|
-
***********************************************************************/
|
1559
|
-
int dsdKernelVerifyDecomposition( Dsd_Manager_t * pDsdMan, Dsd_Node_t * pDE )
|
1560
|
-
{
|
1561
|
-
DdManager * dd = pDsdMan->dd;
|
1562
|
-
Dsd_Node_t * pR = Dsd_Regular(pDE);
|
1563
|
-
int RetValue;
|
1564
|
-
|
1565
|
-
DdNode * bRes;
|
1566
|
-
if ( pR->Type == DSD_NODE_CONST1 )
|
1567
|
-
bRes = b1;
|
1568
|
-
else if ( pR->Type == DSD_NODE_BUF )
|
1569
|
-
bRes = pR->G;
|
1570
|
-
else if ( pR->Type == DSD_NODE_OR || pR->Type == DSD_NODE_EXOR )
|
1571
|
-
dsdKernelComputeSumOfComponents( pDsdMan, pR->pDecs, pR->nDecs, &bRes, NULL, (int)(pR->Type == DSD_NODE_EXOR) );
|
1572
|
-
else if ( pR->Type == DSD_NODE_PRIME )
|
1573
|
-
{
|
1574
|
-
int i;
|
1575
|
-
static DdNode * bGVars[MAXINPUTS];
|
1576
|
-
// transform the function of this block, so that it depended on inputs
|
1577
|
-
// corresponding to the formal inputs
|
1578
|
-
DdNode * bNewFunc = Dsd_TreeGetPrimeFunctionOld( dd, pR, 1 ); Cudd_Ref( bNewFunc );
|
1579
|
-
|
1580
|
-
// compose this function with the inputs
|
1581
|
-
// create the elementary permutation
|
1582
|
-
for ( i = 0; i < dd->size; i++ )
|
1583
|
-
bGVars[i] = dd->vars[i];
|
1584
|
-
|
1585
|
-
// assign functions to be composed
|
1586
|
-
for ( i = 0; i < pR->nDecs; i++ )
|
1587
|
-
bGVars[dd->invperm[i]] = pR->pDecs[i]->G;
|
1588
|
-
|
1589
|
-
// perform the composition
|
1590
|
-
bRes = Cudd_bddVectorCompose( dd, bNewFunc, bGVars ); Cudd_Ref( bRes );
|
1591
|
-
Cudd_RecursiveDeref( dd, bNewFunc );
|
1592
|
-
|
1593
|
-
/////////////////////////////////////////////////////////
|
1594
|
-
RetValue = (int)( bRes == pR->G );//|| bRes == Cudd_Not(pR->G) );
|
1595
|
-
/////////////////////////////////////////////////////////
|
1596
|
-
Cudd_Deref( bRes );
|
1597
|
-
}
|
1598
|
-
else
|
1599
|
-
{
|
1600
|
-
assert(0);
|
1601
|
-
}
|
1602
|
-
|
1603
|
-
Cudd_Ref( bRes );
|
1604
|
-
RetValue = (int)( bRes == pR->G );//|| bRes == Cudd_Not(pR->G) );
|
1605
|
-
Cudd_RecursiveDeref( dd, bRes );
|
1606
|
-
return RetValue;
|
1607
|
-
}
|
1608
|
-
|
1609
|
-
////////////////////////////////////////////////////////////////////////
|
1610
|
-
/// END OF FILE ///
|
1611
|
-
////////////////////////////////////////////////////////////////////////
|
1612
|
-
ABC_NAMESPACE_IMPL_END
|
1613
|
-
|