16template<
typename ReturnType>
18 if constexpr (std::is_same<ReturnType, typename CoefficientType<storm::RationalFunction>::type>::value) {
19 return function.evaluate(valuation);
21 return storm::utility::convertNumber<ReturnType>(function.evaluate(valuation));
27 return evaluateRationalFunction<double>(function, valuation);
30#if defined(STORM_HAVE_CLN)
33 return evaluateRationalFunction<ClnRationalNumber>(function, valuation);
37#if defined(STORM_HAVE_GMP)
40 return evaluateRationalFunction<GmpRationalNumber>(function, valuation);
47 return function.substitute(valuation);
53 function.gatherVariables(variableSet);
66 auto varInfos = function.nominator().getVarInfo<
false>();
67 for (
auto const& varInfo : varInfos) {
68 if (varInfo.second.maxDegree() > 1) {
void gatherOccurringVariables< storm::RationalFunction >(storm::RationalFunction const &function, std::set< typename VariableType< storm::RationalFunction >::type > &variableSet)
bool isMultiLinearPolynomial< storm::RationalFunction >(storm::RationalFunction const &function)
ReturnType evaluateRationalFunction(storm::RationalFunction const &function, Valuation< storm::RationalFunction > const &valuation)
std::map< typename VariableType< FunctionType >::type, typename CoefficientType< FunctionType >::type > Valuation
storm::RationalFunction substitute< storm::RationalFunction >(storm::RationalFunction const &function, Valuation< storm::RationalFunction > const &valuation)
bool isLinear< storm::RationalFunction >(storm::RationalFunction const &function)
double evaluate(storm::RationalFunction const &function, Valuation< storm::RationalFunction > const &valuation)
bool isConstant(ValueType const &)