|
@ -108,13 +108,14 @@ namespace storm { |
|
|
|
|
|
|
|
|
#ifdef STORM_HAVE_CARL
|
|
|
#ifdef STORM_HAVE_CARL
|
|
|
template<> |
|
|
template<> |
|
|
|
|
|
template<> |
|
|
Add<DdType::Sylvan, storm::RationalFunction> DdManager<DdType::Sylvan>::getIdentity(storm::expressions::Variable const& variable) const { |
|
|
Add<DdType::Sylvan, storm::RationalFunction> DdManager<DdType::Sylvan>::getIdentity(storm::expressions::Variable const& variable) const { |
|
|
storm::dd::DdMetaVariable<DdType::Sylvan> const& metaVariable = this->getMetaVariable(variable); |
|
|
storm::dd::DdMetaVariable<DdType::Sylvan> const& metaVariable = this->getMetaVariable(variable); |
|
|
|
|
|
|
|
|
Add<DdType::Sylvan, storm::RationalFunction> result = this->getAddZero<storm::RationalFunction>(); |
|
|
Add<DdType::Sylvan, storm::RationalFunction> result = this->getAddZero<storm::RationalFunction>(); |
|
|
for (int_fast64_t value = metaVariable.getLow(); value <= metaVariable.getHigh(); ++value) { |
|
|
for (int_fast64_t value = metaVariable.getLow(); value <= metaVariable.getHigh(); ++value) { |
|
|
storm::RationalFunction constantFunction(value); |
|
|
storm::RationalFunction constantFunction(value); |
|
|
result += this->getEncoding(variable, value).template toAdd<ValueType>() * this->getConstant(constantFunction); |
|
|
|
|
|
|
|
|
result += this->getEncoding(variable, value).template toAdd<storm::RationalFunction>() * this->getConstant(constantFunction); |
|
|
} |
|
|
} |
|
|
return result; |
|
|
return result; |
|
|
} |
|
|
} |
|
|