|
|
@ -232,12 +232,21 @@ namespace storm { |
|
|
|
|
|
|
|
template<typename ValueType> |
|
|
|
DFT<ValueType> DFT<ValueType>::optimize() const { |
|
|
|
std::vector<std::vector<size_t>> rewriteIds = findModulesRewrite(); |
|
|
|
if (rewriteIds.empty()) { |
|
|
|
std::vector<size_t> modIdea = findModularisationRewrite(); |
|
|
|
std::cout << "Modularisation idea: " << std::endl; |
|
|
|
|
|
|
|
for( auto const& i : modIdea ) { |
|
|
|
std::cout << i << ", "; |
|
|
|
} |
|
|
|
|
|
|
|
if (modIdea.empty()) { |
|
|
|
// No rewrite needed
|
|
|
|
return *this; |
|
|
|
} |
|
|
|
|
|
|
|
std::vector<std::vector<size_t>> rewriteIds; |
|
|
|
rewriteIds.push_back(modIdea); |
|
|
|
|
|
|
|
DFTBuilder<ValueType> builder; |
|
|
|
|
|
|
|
// Accumulate elements which must be rewritten
|
|
|
@ -517,6 +526,41 @@ namespace storm { |
|
|
|
} |
|
|
|
return DFTIndependentSymmetries(res); |
|
|
|
} |
|
|
|
|
|
|
|
template<typename ValueType> |
|
|
|
std::vector<size_t> DFT<ValueType>::findModularisationRewrite() const { |
|
|
|
for(auto const& e : mElements) { |
|
|
|
if(e->isGate() && (e->type() == DFTElementType::AND || e->type() == DFTElementType::OR) ) { |
|
|
|
// suitable parent gate! - Lets check the independent submodules of the children
|
|
|
|
auto const& children = std::static_pointer_cast<DFTGate<ValueType>>(e)->children(); |
|
|
|
for(auto const& child : children) { |
|
|
|
//std::cout << "check idea for: " << child->id() << std::endl;;
|
|
|
|
auto ISD = std::static_pointer_cast<DFTGate<ValueType>>(child)->independentSubDft(true); |
|
|
|
// In the ISD, check for other children:
|
|
|
|
//std::cout << "** subdft = ";
|
|
|
|
for(auto const& isdelemid : ISD) { |
|
|
|
std::cout << isdelemid << " "; |
|
|
|
} |
|
|
|
std::cout << std::endl; |
|
|
|
|
|
|
|
std::vector<size_t> rewrite = {e->id(), child->id()}; |
|
|
|
for(size_t isdElemId : ISD) { |
|
|
|
if(isdElemId == child->id()) continue; |
|
|
|
if(std::find_if(children.begin(), children.end(), [&isdElemId](std::shared_ptr<DFTElement<ValueType>> const& e) { return e->id() == isdElemId; } ) != children.end()) { |
|
|
|
//std::cout << "** found child in subdft: " << isdElemId << std::endl;
|
|
|
|
rewrite.push_back(isdElemId); |
|
|
|
} |
|
|
|
} |
|
|
|
if(rewrite.size() > 2) { |
|
|
|
return rewrite; |
|
|
|
} |
|
|
|
|
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
return {}; |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
template<typename ValueType> |
|
|
|
std::pair<std::vector<size_t>, std::vector<size_t>> DFT<ValueType>::getSortedParentAndOutDepIds(size_t index) const { |
|
|
@ -530,14 +574,6 @@ namespace storm { |
|
|
|
return res; |
|
|
|
} |
|
|
|
|
|
|
|
template<typename ValueType> |
|
|
|
std::vector<std::vector<size_t>> DFT<ValueType>::findModulesRewrite() const { |
|
|
|
std::vector<std::vector<size_t>> modulesRewrite; |
|
|
|
// TODO write
|
|
|
|
return modulesRewrite; |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
// Explicitly instantiate the class.
|
|
|
|
template class DFT<double>; |
|
|
|
|
|
|
|