diff --git a/src/storage/dd/CuddDd.cpp b/src/storage/dd/CuddDd.cpp index bbce93902..72abb87bf 100644 --- a/src/storage/dd/CuddDd.cpp +++ b/src/storage/dd/CuddDd.cpp @@ -184,6 +184,23 @@ namespace storm { this->cuddAdd = this->cuddAdd.OrAbstract(cubeDd.getCuddAdd()); } + void Dd::universalAbstract(std::set const& metaVariableNames) { + Dd cubeDd(this->getDdManager()->getOne()); + + for (auto const& metaVariableName : metaVariableNames) { + // First check whether the DD contains the meta variable and erase it, if this is the case. + if (!this->containsMetaVariable(metaVariableName)) { + throw storm::exceptions::InvalidArgumentException() << "Cannot abstract from meta variable that is not present in the DD."; + } + this->getContainedMetaVariableNames().erase(metaVariableName); + + DdMetaVariable const& metaVariable = this->getDdManager()->getMetaVariable(metaVariableName); + cubeDd *= metaVariable.getCube(); + } + + this->cuddAdd = this->cuddAdd.UnivAbstract(cubeDd.getCuddAdd()); + } + void Dd::sumAbstract(std::set const& metaVariableNames) { Dd cubeDd(this->getDdManager()->getOne()); diff --git a/src/storage/dd/CuddDd.h b/src/storage/dd/CuddDd.h index 6c7bffd6a..f345c28a2 100644 --- a/src/storage/dd/CuddDd.h +++ b/src/storage/dd/CuddDd.h @@ -233,6 +233,13 @@ namespace storm { */ void existsAbstract(std::set const& metaVariableNames); + /*! + * Universally abstracts from the given meta variables. + * + * @param metaVariableNames The names of all meta variables from which to abstract. + */ + void universalAbstract(std::set const& metaVariableNames); + /*! * Sum-abstracts from the given meta variables. *