|
@ -5,11 +5,11 @@ |
|
|
|
|
|
|
|
|
namespace storm { |
|
|
namespace storm { |
|
|
namespace dd { |
|
|
namespace dd { |
|
|
DdForwardIterator<DdType::CUDD>::DdForwardIterator() : ddManager(), generator(), cube(), value(), isAtEnd(), metaVariables(), cubeCounter(), relevantDontCareDdVariables(), currentValuation() { |
|
|
|
|
|
|
|
|
DdForwardIterator<DdType::CUDD>::DdForwardIterator() : ddManager(), generator(), cube(), value(), isAtEnd(), metaVariables(), enumerateDontCareMetaVariables(), cubeCounter(), relevantDontCareDdVariables(), currentValuation() { |
|
|
// Intentionally left empty.
|
|
|
// Intentionally left empty.
|
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
DdForwardIterator<DdType::CUDD>::DdForwardIterator(std::shared_ptr<DdManager<DdType::CUDD>> ddManager, DdGen* generator, int* cube, double value, bool isAtEnd, std::set<std::string> const* metaVariables) : ddManager(ddManager), generator(generator), cube(cube), value(value), isAtEnd(isAtEnd), metaVariables(metaVariables), cubeCounter(), relevantDontCareDdVariables(), currentValuation() { |
|
|
|
|
|
|
|
|
DdForwardIterator<DdType::CUDD>::DdForwardIterator(std::shared_ptr<DdManager<DdType::CUDD>> ddManager, DdGen* generator, int* cube, double value, bool isAtEnd, std::set<std::string> const* metaVariables, bool enumerateDontCareMetaVariables) : ddManager(ddManager), generator(generator), cube(cube), value(value), isAtEnd(isAtEnd), metaVariables(metaVariables), enumerateDontCareMetaVariables(enumerateDontCareMetaVariables), cubeCounter(), relevantDontCareDdVariables(), currentValuation() { |
|
|
// If the given generator is not yet at its end, we need to create the current valuation from the cube from
|
|
|
// If the given generator is not yet at its end, we need to create the current valuation from the cube from
|
|
|
// scratch.
|
|
|
// scratch.
|
|
|
if (!this->isAtEnd) { |
|
|
if (!this->isAtEnd) { |
|
@ -113,32 +113,63 @@ namespace storm { |
|
|
// don't cares. In the latter case, we add them to a special list, so we can iterate over their concrete
|
|
|
// don't cares. In the latter case, we add them to a special list, so we can iterate over their concrete
|
|
|
// valuations later.
|
|
|
// valuations later.
|
|
|
for (auto const& metaVariableName : *this->metaVariables) { |
|
|
for (auto const& metaVariableName : *this->metaVariables) { |
|
|
|
|
|
bool metaVariableAppearsInCube = false; |
|
|
|
|
|
std::vector<std::tuple<ADD, std::string, uint_fast64_t>> localRelenvantDontCareDdVariables; |
|
|
auto const& metaVariable = this->ddManager->getMetaVariable(metaVariableName); |
|
|
auto const& metaVariable = this->ddManager->getMetaVariable(metaVariableName); |
|
|
if (metaVariable.getType() == DdMetaVariable<DdType::CUDD>::MetaVariableType::Bool) { |
|
|
if (metaVariable.getType() == DdMetaVariable<DdType::CUDD>::MetaVariableType::Bool) { |
|
|
if (this->cube[metaVariable.getDdVariables()[0].getCuddAdd().NodeReadIndex()] == 0) { |
|
|
if (this->cube[metaVariable.getDdVariables()[0].getCuddAdd().NodeReadIndex()] == 0) { |
|
|
|
|
|
metaVariableAppearsInCube = true; |
|
|
|
|
|
if (!currentValuation.containsBooleanIdentifier(metaVariableName)) { |
|
|
|
|
|
currentValuation.addBooleanIdentifier(metaVariableName, false); |
|
|
|
|
|
} else { |
|
|
currentValuation.setBooleanValue(metaVariableName, false); |
|
|
currentValuation.setBooleanValue(metaVariableName, false); |
|
|
|
|
|
} |
|
|
} else if (this->cube[metaVariable.getDdVariables()[0].getCuddAdd().NodeReadIndex()] == 1) { |
|
|
} else if (this->cube[metaVariable.getDdVariables()[0].getCuddAdd().NodeReadIndex()] == 1) { |
|
|
|
|
|
metaVariableAppearsInCube = true; |
|
|
|
|
|
if (!currentValuation.containsBooleanIdentifier(metaVariableName)) { |
|
|
|
|
|
currentValuation.addBooleanIdentifier(metaVariableName, true); |
|
|
|
|
|
} else { |
|
|
currentValuation.setBooleanValue(metaVariableName, true); |
|
|
currentValuation.setBooleanValue(metaVariableName, true); |
|
|
|
|
|
} |
|
|
} else { |
|
|
} else { |
|
|
relevantDontCareDdVariables.push_back(std::make_tuple(metaVariable.getDdVariables()[0].getCuddAdd(), metaVariableName, 0)); |
|
|
|
|
|
|
|
|
localRelenvantDontCareDdVariables.push_back(std::make_tuple(metaVariable.getDdVariables()[0].getCuddAdd(), metaVariableName, 0)); |
|
|
} |
|
|
} |
|
|
} else { |
|
|
} else { |
|
|
int_fast64_t intValue = 0; |
|
|
int_fast64_t intValue = 0; |
|
|
for (uint_fast64_t bitIndex = 0; bitIndex < metaVariable.getNumberOfDdVariables(); ++bitIndex) { |
|
|
for (uint_fast64_t bitIndex = 0; bitIndex < metaVariable.getNumberOfDdVariables(); ++bitIndex) { |
|
|
if (cube[metaVariable.getDdVariables()[bitIndex].getCuddAdd().NodeReadIndex()] == 0) { |
|
|
if (cube[metaVariable.getDdVariables()[bitIndex].getCuddAdd().NodeReadIndex()] == 0) { |
|
|
// Leave bit unset.
|
|
|
// Leave bit unset.
|
|
|
|
|
|
metaVariableAppearsInCube = true; |
|
|
} else if (cube[metaVariable.getDdVariables()[bitIndex].getCuddAdd().NodeReadIndex()] == 1) { |
|
|
} else if (cube[metaVariable.getDdVariables()[bitIndex].getCuddAdd().NodeReadIndex()] == 1) { |
|
|
intValue |= 1ull << (metaVariable.getNumberOfDdVariables() - bitIndex - 1); |
|
|
intValue |= 1ull << (metaVariable.getNumberOfDdVariables() - bitIndex - 1); |
|
|
|
|
|
metaVariableAppearsInCube = true; |
|
|
} else { |
|
|
} else { |
|
|
// Temporarily leave bit unset so we can iterate trough the other option later.
|
|
|
// Temporarily leave bit unset so we can iterate trough the other option later.
|
|
|
// Add the bit to the relevant don't care bits.
|
|
|
// Add the bit to the relevant don't care bits.
|
|
|
this->relevantDontCareDdVariables.push_back(std::make_tuple(metaVariable.getDdVariables()[bitIndex].getCuddAdd(), metaVariableName, metaVariable.getNumberOfDdVariables() - bitIndex - 1)); |
|
|
|
|
|
|
|
|
localRelenvantDontCareDdVariables.push_back(std::make_tuple(metaVariable.getDdVariables()[bitIndex].getCuddAdd(), metaVariableName, metaVariable.getNumberOfDdVariables() - bitIndex - 1)); |
|
|
|
|
|
} |
|
|
} |
|
|
} |
|
|
|
|
|
if (this->enumerateDontCareMetaVariables || metaVariableAppearsInCube) { |
|
|
|
|
|
if (!currentValuation.containsIntegerIdentifier(metaVariableName)) { |
|
|
|
|
|
currentValuation.addIntegerIdentifier(metaVariableName); |
|
|
} |
|
|
} |
|
|
currentValuation.setIntegerValue(metaVariableName, intValue + metaVariable.getLow()); |
|
|
currentValuation.setIntegerValue(metaVariableName, intValue + metaVariable.getLow()); |
|
|
} |
|
|
} |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
// If all meta variables are to be enumerated or the meta variable appeared in the cube, we register the
|
|
|
|
|
|
// missing bits to later enumerate all possible valuations.
|
|
|
|
|
|
if (this->enumerateDontCareMetaVariables || metaVariableAppearsInCube) { |
|
|
|
|
|
relevantDontCareDdVariables.insert(relevantDontCareDdVariables.end(), localRelenvantDontCareDdVariables.begin(), localRelenvantDontCareDdVariables.end()); |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
// If the meta variable does not appear in the cube and we're not supposed to enumerate such meta variables
|
|
|
|
|
|
// we remove the meta variable from the valuation.
|
|
|
|
|
|
if (!this->enumerateDontCareMetaVariables && !metaVariableAppearsInCube) { |
|
|
|
|
|
currentValuation.removeIdentifier(metaVariableName); |
|
|
|
|
|
} |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
// Finally, reset the cube counter.
|
|
|
// Finally, reset the cube counter.
|
|
|
this->cubeCounter = 0; |
|
|
this->cubeCounter = 0; |
|
|
} |
|
|
} |
|
|