11namespace modelchecker {
12template<storm::dd::DdType Type,
typename ValueType>
15 : reachableStates(reachableStates), states(reachableStates), values(values) {
19template<storm::dd::DdType Type,
typename ValueType>
23 : reachableStates(reachableStates), states(states), values(values) {
27template<storm::dd::DdType Type,
typename ValueType>
29 : reachableStates(other.getReachableStates()), states(other.getStates()), values(other.getTruthValuesVector().template toAdd<ValueType>()) {
33template<storm::dd::DdType Type,
typename ValueType>
35 return std::make_unique<SymbolicQuantitativeCheckResult<Type, ValueType>>(this->reachableStates, this->states, this->values);
38template<storm::dd::DdType Type,
typename ValueType>
40 ValueType
const& bound)
const {
43 states &= values.less(bound);
45 states &= values.lessOrEqual(bound);
47 states &= values.greater(bound);
49 states &= values.greaterOrEqual(bound);
54template<storm::dd::DdType Type,
typename ValueType>
59template<storm::dd::DdType Type,
typename ValueType>
61 return states == reachableStates;
64template<storm::dd::DdType Type,
typename ValueType>
69template<storm::dd::DdType Type,
typename ValueType>
74template<storm::dd::DdType Type,
typename ValueType>
79template<storm::dd::DdType Type,
typename ValueType>
81 return reachableStates;
84template<
typename ValueType>
85void print(std::ostream& out, ValueType
const& value) {
86 if (value == storm::utility::infinity<ValueType>()) {
90 if (std::is_same<ValueType, storm::RationalNumber>::value) {
91 out <<
" (approx. " << storm::utility::convertNumber<double>(value) <<
")";
96template<
typename ValueType>
97void printRange(std::ostream& out, ValueType
const& min, ValueType
const& max) {
99 if (min == storm::utility::infinity<ValueType>()) {
105 if (max == storm::utility::infinity<ValueType>()) {
111 if (std::is_same<ValueType, storm::RationalNumber>::value) {
112 out <<
" (approx. [";
113 if (min == storm::utility::infinity<ValueType>()) {
116 out << storm::utility::convertNumber<double>(min);
119 if (max == storm::utility::infinity<ValueType>()) {
122 out << storm::utility::convertNumber<double>(max);
129template<storm::dd::DdType Type,
typename ValueType>
131 uint64_t totalNumberOfStates = states.getNonZeroCount();
132 bool minMaxSupported = std::is_same<ValueType, double>::value || std::is_same<ValueType, storm::RationalNumber>::value;
133 bool printAsRange =
false;
135 if (totalNumberOfStates == 1) {
136 print(out, this->values.sumAbstract(this->values.getContainedMetaVariables()).getValue());
137 }
else if (states.getNonZeroCount() >= 10 || !minMaxSupported) {
141 if (this->values.isZero()) {
145 for (
auto valuationValuePair : this->values) {
151 print(out, valuationValuePair.second);
153 if (states.getNonZeroCount() != this->values.getNonZeroCount()) {
161 printRange(out, this->getMin(), this->getMax());
166template<storm::dd::DdType Type,
typename ValueType>
168 STORM_LOG_THROW(filter.isSymbolicQualitativeCheckResult(), storm::exceptions::InvalidOperationException,
169 "Cannot filter symbolic check result with non-symbolic filter.");
170 this->states &= filter.asSymbolicQualitativeCheckResult<Type>().getTruthValuesVector();
171 this->values *= filter.asSymbolicQualitativeCheckResult<Type>().getTruthValuesVector().template toAdd<ValueType>();
174template<storm::dd::DdType Type,
typename ValueType>
178 return states.ite(this->values, states.getDdManager().getConstant(storm::utility::infinity<ValueType>())).getMin();
181template<storm::dd::DdType Type,
typename ValueType>
183 return this->values.getMax();
186template<storm::dd::DdType Type,
typename ValueType>
188 return this->sum() / storm::utility::convertNumber<ValueType>(this->states.getNonZeroCount());
191template<storm::dd::DdType Type,
typename ValueType>
193 return this->values.sumAbstract(this->values.getContainedMetaVariables()).getValue();
196template<storm::dd::DdType Type,
typename ValueType>
199 values = one - values;
virtual std::unique_ptr< CheckResult > clone() const override
virtual ValueType getMax() const override
storm::dd::Add< Type, ValueType > const & getValueVector() const
storm::dd::Bdd< Type > const & getStates() const
virtual void oneMinus() override
virtual ValueType getMin() const override
virtual void filter(QualitativeCheckResult const &filter) override
Filters the current result wrt.
virtual bool isSymbolicQuantitativeCheckResult() const override
virtual std::unique_ptr< CheckResult > compareAgainstBound(storm::logic::ComparisonType comparisonType, ValueType const &bound) const override
virtual bool isResultForAllStates() const override
virtual ValueType average() const override
virtual ValueType sum() const override
virtual std::ostream & writeToStream(std::ostream &out) const override
storm::dd::Bdd< Type > const & getReachableStates() const
SymbolicQuantitativeCheckResult()=default
virtual bool isSymbolic() const override
#define STORM_LOG_THROW(cond, exception, message)
void print(std::ostream &out, ValueType const &value)
void printRange(std::ostream &out, ValueType const &min, ValueType const &max)
ValueType max(ValueType const &first, ValueType const &second)
ValueType min(ValueType const &first, ValueType const &second)