diff options
Diffstat (limited to 'src')
| -rw-r--r-- | src/aig/gia/giaTtopt.cpp | 232 | 
1 files changed, 98 insertions, 134 deletions
| diff --git a/src/aig/gia/giaTtopt.cpp b/src/aig/gia/giaTtopt.cpp index e5dff231..8939a87b 100644 --- a/src/aig/gia/giaTtopt.cpp +++ b/src/aig/gia/giaTtopt.cpp @@ -1,42 +1,20 @@  // Author : Yukio Miyasaka -#if 0 - -#include <iostream> -#include <fstream> -#include <string>  #include <vector> -#include <list>  #include <algorithm> -#include <numeric> -#include <random>  #include <cassert> -#include <map>  #include <bitset> -#include <unordered_map> - -#endif  #include "gia.h" +#include "misc/vec/vecHash.h"  ABC_NAMESPACE_IMPL_START -#if 0 -  namespace Ttopt { -struct PairHasher { -  std::size_t operator()(const std::pair<int, int> & k) const { -    std::hash<int> hasher; -    std::size_t seed = hasher(k.first) + 0x9e3779b9; -    seed = hasher(k.second) + 0x9e3779b9 + (seed << 6) + (seed >> 2); -    return seed; -  } -}; -  class TruthTable {  public: -  const int ww = 64; // word width -  const int lww = 6; // log word width +  static const int ww; // word width +  static const int lww; // log word width    typedef std::bitset<64> bsw;    int nInputs; @@ -54,11 +32,11 @@ public:    std::vector<std::vector<std::vector<int> > > vvRedundantIndicesSaved;    std::vector<std::vector<int> > vLevelsSaved; -  std::mt19937 rng;    static const word ones[];    static const word swapmask[];    TruthTable(int nInputs, int nOutputs): nInputs(nInputs), nOutputs(nOutputs) { +    srand(0xABC);      if(nInputs >= lww) {        nSize = 1 << (nInputs - lww);        nTotalSize = nSize * nOutputs; @@ -69,45 +47,12 @@ public:        t.resize(nTotalSize);      }      vLevels.resize(nInputs); -    std::iota(vLevels.begin(), vLevels.end(), 0); -  } - -  std::string BinaryToString(int bin, int size) { -    std::string str; -    for(int i = 0; i < size; i++) { -      str += (bin & 1) + '0'; -      bin = bin >> 1; -    } -    return str; -  } -  void GeneratePla(std::string filename) { -    std::ofstream f(filename); -    f << ".i " << nInputs << std::endl; -    f << ".o " << nOutputs << std::endl; -    if(nSize) { -      for(int index = 0; index < nSize; index++) { -        for(int pos = 0; pos < ww; pos++) { -          int pat = (index << lww) + pos; -          f << BinaryToString(pat, nInputs) << " "; -          for(int i = 0; i < nOutputs; i++) { -            f << ((t[nSize * i + index] >> pos) & 1); -          } -          f << std::endl; -        } -      } -    } else { -      for(int pos = 0; pos < (1 << nInputs); pos++) { -        f << BinaryToString(pos, nInputs) << " "; -        for(int i = 0; i < nOutputs; i++) { -          int padding = i * (1 << nInputs); -          f << ((t[padding / ww] >> (pos + padding % ww)) & 1); -        } -        f << std::endl; -      } +    for(int i = 0; i < nInputs; i++) { +      vLevels[i] = i;      }    } -  virtual void Save(uint i) { +  virtual void Save(unsigned i) {      if(savedt.size() < i + 1) {        savedt.resize(i + 1);        vLevelsSaved.resize(i + 1); @@ -116,13 +61,13 @@ public:      vLevelsSaved[i] = vLevels;    } -  virtual void Load(uint i) { +  virtual void Load(unsigned i) {      assert(i < savedt.size());      t = savedt[i];      vLevels = vLevelsSaved[i];    } -  virtual void SaveIndices(uint i) { +  virtual void SaveIndices(unsigned i) {      if(vvIndicesSaved.size() < i + 1) {        vvIndicesSaved.resize(i + 1);        vvRedundantIndicesSaved.resize(i + 1); @@ -131,7 +76,7 @@ public:      vvRedundantIndicesSaved[i] = vvRedundantIndices;    } -  virtual void LoadIndices(uint i) { +  virtual void LoadIndices(unsigned i) {      vvIndices = vvIndicesSaved[i];      vvRedundantIndices = vvRedundantIndicesSaved[i];    } @@ -206,7 +151,7 @@ public:        if(fZero || fOne) {          return -2 ^ fOne;        } -      for(uint j = 0; j < vvIndices[lev].size(); j++) { +      for(unsigned j = 0; j < vvIndices[lev].size(); j++) {          int index2 = vvIndices[lev][j];          bool fEq = true;          bool fCompl = true; @@ -226,7 +171,7 @@ public:        if(!(value ^ ones[logwidth])) {          return -1;        } -      for(uint j = 0; j < vvIndices[lev].size(); j++) { +      for(unsigned j = 0; j < vvIndices[lev].size(); j++) {          int index2 = vvIndices[lev][j];          word value2 = value ^ GetValue(index2, lev);          if(!(value2)) { @@ -260,7 +205,8 @@ public:    }    virtual void BDDBuildLevel(int lev) { -    for(int index: vvIndices[lev-1]) { +    for(unsigned i = 0; i < vvIndices[lev-1].size(); i++) { +      int index = vvIndices[lev-1][i];        int cof0 = BDDBuildOne(index << 1, lev);        int cof1 = BDDBuildOne((index << 1) ^ 1, lev);        if(cof0 == cof1) { @@ -292,7 +238,8 @@ public:      }      if(lev < nInputs - 2) {        vvRedundantIndices[lev+1].clear(); -      for(int index: vvIndices[lev+1]) { +      for(unsigned i = 0; i < vvIndices[lev+1].size(); i++) { +        int index = vvIndices[lev+1][i];          if(IsEq(index << 1, (index << 1) ^ 1, lev + 2)) {            vvRedundantIndices[lev+1].push_back(index);          } @@ -303,8 +250,8 @@ public:    virtual void Swap(int lev) {      assert(lev < nInputs - 1); -    auto it0 = std::find(vLevels.begin(), vLevels.end(), lev); -    auto it1 = std::find(vLevels.begin(), vLevels.end(), lev + 1); +    std::vector<int>::iterator it0 = std::find(vLevels.begin(), vLevels.end(), lev); +    std::vector<int>::iterator it1 = std::find(vLevels.begin(), vLevels.end(), lev + 1);      std::swap(*it0, *it1);      if(nInputs - lev - 1 > lww) {        int nScopeSize = 1 << (nInputs - lev - 2 - lww); @@ -341,7 +288,7 @@ public:    virtual int BDDSwap(int lev) {      Swap(lev);      for(int i = lev + 2; i < nInputs; i++) { -      for(uint j = 0; j < vvIndices[i].size(); j++) { +      for(unsigned j = 0; j < vvIndices[i].size(); j++) {          SwapIndex(vvIndices[i][j], i - (lev + 2));        }      } @@ -354,10 +301,23 @@ public:      Save(0);      SaveIndices(0);      std::vector<int> vars(nInputs); -    std::iota(vars.begin(), vars.end(), 0); -    std::sort(vars.begin(), vars.end(), [&](int i1, int i2) {return BDDNodeCountLevel(vLevels[i1]) > BDDNodeCountLevel(vLevels[i2]);}); +    for(int i = 0; i < nInputs; i++) { +      vars[i] = i; +    } +    std::vector<unsigned> vCounts(nInputs); +    for(int i = 0; i < nInputs; i++) { +      vCounts[i] = BDDNodeCountLevel(vLevels[i]); +    } +    for(int i = 1; i < nInputs; i++) { +      int j = i; +      while(j > 0 && vCounts[vars[j-1]] < vCounts[vars[j]]) { +        std::swap(vars[j], vars[j-1]); +        j--; +      } +    }      bool turn = true; -    for(int var: vars) { +    for(unsigned j = 0; j < vars.size(); j++) { +      int var = vars[j];        bool updated = false;        int lev = vLevels[var];        for(int i = lev; i < nInputs - 1; i++) { @@ -411,8 +371,13 @@ public:      Save(2);      for(int i = 0; i < nRound; i++) {        std::vector<int> vLevelsNew(nInputs); -      std::iota(vLevelsNew.begin(), vLevelsNew.end(), 0); -      std::shuffle(vLevelsNew.begin(), vLevelsNew.end(), rng); +      for(int j = 0; j < nInputs; j++) { +        vLevelsNew[j] = j; +      } +      for(int j = nInputs - 1; j > 0; j--) { +        int d = rand() % j; +        std::swap(vLevelsNew[j], vLevelsNew[d]); +      }        Reo(vLevelsNew);        int r = SiftReo();        if(best > r) { @@ -465,6 +430,9 @@ public:    }  }; +const int TruthTable::ww = 64; +const int TruthTable::lww = 6; +  const word TruthTable::ones[7] = {ABC_CONST(0x0000000000000001),                                    ABC_CONST(0x0000000000000003),                                    ABC_CONST(0x000000000000000f), @@ -481,25 +449,27 @@ const word TruthTable::swapmask[5] = {ABC_CONST(0x2222222222222222),  class TruthTableReo : public TruthTable {  public: -  bool fBuilt = false; +  bool fBuilt;    std::vector<std::vector<int> > vvChildren;    std::vector<std::vector<std::vector<int> > > vvChildrenSaved; -  TruthTableReo(int nInputs, int nOutputs): TruthTable(nInputs, nOutputs) {} +  TruthTableReo(int nInputs, int nOutputs): TruthTable(nInputs, nOutputs) { +    fBuilt = false; +  } -  void Save(uint i) override { +  void Save(unsigned i) {      if(vLevelsSaved.size() < i + 1) {        vLevelsSaved.resize(i + 1);      }      vLevelsSaved[i] = vLevels;    } -  void Load(uint i) override { +  void Load(unsigned i) {      assert(i < vLevelsSaved.size());      vLevels = vLevelsSaved[i];    } -  void SaveIndices(uint i) override { +  void SaveIndices(unsigned i) {      TruthTable::SaveIndices(i);      if(vvChildrenSaved.size() < i + 1) {        vvChildrenSaved.resize(i + 1); @@ -507,19 +477,20 @@ public:      vvChildrenSaved[i] = vvChildren;    } -  void LoadIndices(uint i) override { +  void LoadIndices(unsigned i) {      TruthTable::LoadIndices(i);      vvChildren = vvChildrenSaved[i];    } -  void BDDBuildStartup() override { +  void BDDBuildStartup() {      vvChildren.clear();      vvChildren.resize(nInputs);      TruthTable::BDDBuildStartup();    } -  void BDDBuildLevel(int lev) override { -    for(int index: vvIndices[lev-1]) { +  void BDDBuildLevel(int lev) { +    for(unsigned i = 0; i < vvIndices[lev-1].size(); i++) { +      int index = vvIndices[lev-1][i];        int cof0 = BDDBuildOne(index << 1, lev);        int cof1 = BDDBuildOne((index << 1) ^ 1, lev);        vvChildren[lev-1].push_back(cof0); @@ -530,7 +501,7 @@ public:      }    } -  int BDDBuild() override { +  int BDDBuild() {      if(fBuilt) {        return BDDNodeCount();      } @@ -542,7 +513,7 @@ public:      return BDDNodeCount();    } -  int BDDRebuildOne(int index, int cof0, int cof1, int lev, std::unordered_map<std::pair<int, int>, int, PairHasher> &unique, std::vector<int> &vChildrenLow) { +  int BDDRebuildOne(int index, int cof0, int cof1, int lev, Hash_IntMan_t *unique, std::vector<int> &vChildrenLow) {      if(cof0 < 0 && cof0 == cof1) {        return cof0;      } @@ -551,11 +522,12 @@ public:        cof0 ^= 1;        cof1 ^= 1;      } -    if(unique.count({cof0, cof1})) { -      return (unique[{cof0, cof1}] << 1) ^ fCompl; +    int *place = Hash_Int2ManLookup(unique, cof0, cof1); +    if(*place) { +      return (Hash_IntObjData2(unique, *place) << 1) ^ fCompl;      }      vvIndices[lev].push_back(index); -    unique[{cof0, cof1}] = vvIndices[lev].size() - 1; +    Hash_Int2ManInsert(unique, cof0, cof1, vvIndices[lev].size() - 1);      vChildrenLow.push_back(cof0);      vChildrenLow.push_back(cof1);      if(cof0 == cof1) { @@ -564,15 +536,14 @@ public:      return ((vvIndices[lev].size() - 1) << 1) ^ fCompl;    } -  int BDDRebuild(int lev) override { +  int BDDRebuild(int lev) {      vvRedundantIndices[lev].clear();      vvRedundantIndices[lev+1].clear();      std::vector<int> vChildrenHigh;      std::vector<int> vChildrenLow; -    std::unordered_map<std::pair<int, int>, int, PairHasher> unique; -    unique.reserve(2 * vvIndices[lev+1].size()); +    Hash_IntMan_t *unique = Hash_IntManStart(2 * vvIndices[lev+1].size());      vvIndices[lev+1].clear(); -    for(uint i = 0; i < vvIndices[lev].size(); i++) { +    for(unsigned i = 0; i < vvIndices[lev].size(); i++) {        int index = vvIndices[lev][i];        int cof0index = vvChildren[lev][i+i] >> 1;        int cof1index = vvChildren[lev][i+i+1] >> 1; @@ -601,25 +572,26 @@ public:          vvRedundantIndices[lev].push_back(index);        }      } +    Hash_IntManStop(unique);      vvChildren[lev] = vChildrenHigh;      vvChildren[lev+1] = vChildrenLow;      return BDDNodeCount();    } -  void Swap(int lev) override { +  void Swap(int lev) {      assert(lev < nInputs - 1); -    auto it0 = std::find(vLevels.begin(), vLevels.end(), lev); -    auto it1 = std::find(vLevels.begin(), vLevels.end(), lev + 1); +    std::vector<int>::iterator it0 = std::find(vLevels.begin(), vLevels.end(), lev); +    std::vector<int>::iterator it1 = std::find(vLevels.begin(), vLevels.end(), lev + 1);      std::swap(*it0, *it1);      BDDRebuild(lev);    } -  int BDDSwap(int lev) override { +  int BDDSwap(int lev) {      Swap(lev);      return BDDNodeCount();    } -  virtual void BDDGenerateAig(Gia_Man_t *pNew, Vec_Int_t *vSupp) override { +  virtual void BDDGenerateAig(Gia_Man_t *pNew, Vec_Int_t *vSupp) {      abort();    }  }; @@ -712,7 +684,7 @@ public:      }    } -  void Save(uint i) override { +  void Save(unsigned i) {      TruthTable::Save(i);      if(savedcare.size() < i + 1) {        savedcare.resize(i + 1); @@ -720,12 +692,12 @@ public:      savedcare[i] = care;    } -  void Load(uint i) override { +  void Load(unsigned i) {      TruthTable::Load(i);      care = savedcare[i];    } -  void SaveIndices(uint i) override { +  void SaveIndices(unsigned i) {      TruthTable::SaveIndices(i);      if(vvMergedIndicesSaved.size() < i + 1) {        vvMergedIndicesSaved.resize(i + 1); @@ -733,12 +705,12 @@ public:      vvMergedIndicesSaved[i] = vvMergedIndices;    } -  void LoadIndices(uint i) override { +  void LoadIndices(unsigned i) {      TruthTable::LoadIndices(i);      vvMergedIndices = vvMergedIndicesSaved[i];    } -  void Swap(int lev) override { +  void Swap(int lev) {      TruthTable::Swap(lev);      if(nInputs - lev - 1 > lww) {        int nScopeSize = 1 << (nInputs - lev - 2 - lww); @@ -899,10 +871,10 @@ public:    void Merge(int index1, int index2, int lev, bool fCompl) {      MergeCare(index1, index2, lev); -    vvMergedIndices[lev].push_back({(index1 << 1) ^ fCompl, index2}); +    vvMergedIndices[lev].push_back(std::make_pair((index1 << 1) ^ fCompl, index2));    } -  int BDDBuildOne(int index, int lev) override { +  int BDDBuildOne(int index, int lev) {      int r = BDDFind(index, lev);      if(r >= -2) {        if(r >= 0) { @@ -916,13 +888,13 @@ public:    void CompleteMerge() {      for(int i = nInputs - 1; i >= 0; i--) { -      for(auto it = vvMergedIndices[i].rbegin(); it != vvMergedIndices[i].rend(); it++) { +      for(std::vector<std::pair<int, int> >::reverse_iterator it = vvMergedIndices[i].rbegin(); it != vvMergedIndices[i].rend(); it++) {          CopyFunc((*it).second, (*it).first >> 1, i, (*it).first & 1);        }      }    } -  void BDDBuildStartup() override { +  void BDDBuildStartup() {      RestoreCare();      vvIndices.clear();      vvIndices.resize(nInputs); @@ -938,12 +910,13 @@ public:    }    virtual void BDDRebuildByMerge(int lev) { -    for(auto &p: vvMergedIndices[lev]) { +    for(unsigned i = 0; i < vvMergedIndices[lev].size(); i++) { +      std::pair<int, int> &p = vvMergedIndices[lev][i];        MergeCare(p.first >> 1, p.second, lev);      }    } -  int BDDRebuild(int lev) override { +  int BDDRebuild(int lev) {      RestoreCare();      for(int i = lev; i < nInputs; i++) {        vvIndices[i].clear(); @@ -969,7 +942,7 @@ public:      return BDDNodeCount();    } -  int BDDSwap(int lev) override { +  int BDDSwap(int lev) {      Swap(lev);      return BDDRebuild(lev);    } @@ -993,7 +966,8 @@ public:    virtual void Optimize() {      OptimizationStartup();      for(int i = 1; i < nInputs; i++) { -      for(int index: vvIndices[i-1]) { +      for(unsigned j = 0; j < vvIndices[i-1].size(); j++) { +        int index = vvIndices[i-1][j];          BDDBuildOne(index << 1, i);          BDDBuildOne((index << 1) ^ 1, i);        } @@ -1021,7 +995,8 @@ public:        if(fZero || fOne) {          return -2 ^ fOne;        } -      for(int index2: vvIndices[lev]) { +      for(unsigned j = 0; j < vvIndices[lev].size(); j++) { +        int index2 = vvIndices[lev][j];          bool fEq = true;          bool fCompl = true;          for(int i = 0; i < nScopeSize && (fEq || fCompl); i++) { @@ -1044,7 +1019,8 @@ public:        if(!((value ^ one) & cvalue)) {          return -1;        } -      for(int index2: vvIndices[lev]) { +      for(unsigned j = 0; j < vvIndices[lev].size(); j++) { +        int index2 = vvIndices[lev][j];          word value2 = value ^ GetValue(index2, lev);          word cvalue2 = cvalue & GetCare(index2, lev);          if(!(value2 & cvalue2)) { @@ -1058,14 +1034,14 @@ public:      return -3;    } -  int BDDBuildOne(int index, int lev) override { +  int BDDBuildOne(int index, int lev) {      int r = BDDFindTSM(index, lev);      if(r >= -2) {        if(r >= 0) {          CopyFuncMasked(r >> 1, index, lev, r & 1);          Merge(r >> 1, index, lev, r & 1);        } else { -        vvMergedIndices[lev].push_back({r, index}); +        vvMergedIndices[lev].push_back(std::make_pair(r, index));        }        return r;      } @@ -1073,15 +1049,16 @@ public:      return index << 1;    } -  int BDDBuild() override { +  int BDDBuild() {      TruthTable::Save(3);      int r = TruthTable::BDDBuild();      TruthTable::Load(3);      return r;    } -  void BDDRebuildByMerge(int lev) override { -    for(auto &p: vvMergedIndices[lev]) { +  void BDDRebuildByMerge(int lev) { +    for(unsigned i = 0; i < vvMergedIndices[lev].size(); i++) { +      std::pair<int, int> &p = vvMergedIndices[lev][i];        if(p.first >= 0) {          CopyFuncMasked(p.first >> 1, p.second, lev, p.first & 1);          MergeCare(p.first >> 1, p.second, lev); @@ -1089,7 +1066,7 @@ public:      }    } -  int BDDRebuild(int lev) override { +  int BDDRebuild(int lev) {      TruthTable::Save(3);      int r = TruthTableCare::BDDRebuild(lev);      TruthTable::Load(3); @@ -1209,19 +1186,6 @@ Gia_Man_t * Gia_ManTtoptCare( Gia_Man_t * p, int nIns, int nOuts, int nRounds, c      Vec_WrdFreeP( &vSimI );      return pNew;  } -#endif - -extern "C" -Gia_Man_t * Gia_ManTtopt( Gia_Man_t * p, int nIns, int nOuts, int nRounds ) -{ -    return NULL; -} - -extern "C" -Gia_Man_t * Gia_ManTtoptCare( Gia_Man_t * p, int nIns, int nOuts, int nRounds, char * pFileName, int nRarity ) -{ -    return NULL; -}  ABC_NAMESPACE_IMPL_END | 
