Browse Source

fixed bug in concatenating results of subformulas

Former-commit-id: 73b773480a
main
dehnert 11 years ago
parent
commit
b9cc6c2708
  1. 14
      src/modelchecker/results/ExplicitQualitativeCheckResult.cpp
  2. 2
      src/modelchecker/results/ExplicitQualitativeCheckResult.h

14
src/modelchecker/results/ExplicitQualitativeCheckResult.cpp

@ -29,13 +29,19 @@ namespace storm {
// Intentionally left empty. // Intentionally left empty.
} }
void ExplicitQualitativeCheckResult::performLogicalOperation(ExplicitQualitativeCheckResult& first, QualitativeCheckResult const& second, std::function<bool (bool, bool)> const& function) {
void ExplicitQualitativeCheckResult::performLogicalOperation(ExplicitQualitativeCheckResult& first, QualitativeCheckResult const& second, bool logicalAnd) {
STORM_LOG_THROW(second.isExplicitQualitativeCheckResult(), storm::exceptions::InvalidOperationException, "Cannot perform logical 'and' on check results of incompatible type."); STORM_LOG_THROW(second.isExplicitQualitativeCheckResult(), storm::exceptions::InvalidOperationException, "Cannot perform logical 'and' on check results of incompatible type.");
STORM_LOG_THROW(first.isResultForAllStates() == second.isResultForAllStates(), storm::exceptions::InvalidOperationException, "Cannot perform logical 'and' on check results of incompatible type."); STORM_LOG_THROW(first.isResultForAllStates() == second.isResultForAllStates(), storm::exceptions::InvalidOperationException, "Cannot perform logical 'and' on check results of incompatible type.");
ExplicitQualitativeCheckResult const& secondCheckResult = static_cast<ExplicitQualitativeCheckResult const&>(second); ExplicitQualitativeCheckResult const& secondCheckResult = static_cast<ExplicitQualitativeCheckResult const&>(second);
if (first.isResultForAllStates()) { if (first.isResultForAllStates()) {
boost::get<vector_type>(first.truthValues) &= boost::get<vector_type>(secondCheckResult.truthValues);
if (logicalAnd) {
boost::get<vector_type>(first.truthValues) &= boost::get<vector_type>(secondCheckResult.truthValues);
} else {
boost::get<vector_type>(first.truthValues) |= boost::get<vector_type>(secondCheckResult.truthValues);
}
} else { } else {
std::function<bool (bool, bool)> function = logicalAnd ? [] (bool a, bool b) { return a && b; } : [] (bool a, bool b) { return a || b; };
map_type& map1 = boost::get<map_type>(first.truthValues); map_type& map1 = boost::get<map_type>(first.truthValues);
map_type const& map2 = boost::get<map_type>(secondCheckResult.truthValues); map_type const& map2 = boost::get<map_type>(secondCheckResult.truthValues);
for (auto& element1 : map1) { for (auto& element1 : map1) {
@ -53,12 +59,12 @@ namespace storm {
} }
QualitativeCheckResult& ExplicitQualitativeCheckResult::operator&=(QualitativeCheckResult const& other) { QualitativeCheckResult& ExplicitQualitativeCheckResult::operator&=(QualitativeCheckResult const& other) {
performLogicalOperation(*this, other, [] (bool a, bool b) { return a && b; });
performLogicalOperation(*this, other, true);
return *this; return *this;
} }
QualitativeCheckResult& ExplicitQualitativeCheckResult::operator|=(QualitativeCheckResult const& other) { QualitativeCheckResult& ExplicitQualitativeCheckResult::operator|=(QualitativeCheckResult const& other) {
performLogicalOperation(*this, other, [] (bool a, bool b) { return a || b; });
performLogicalOperation(*this, other, false);
return *this; return *this;
} }

2
src/modelchecker/results/ExplicitQualitativeCheckResult.h

@ -51,7 +51,7 @@ namespace storm {
virtual void filter(QualitativeCheckResult const& filter) override; virtual void filter(QualitativeCheckResult const& filter) override;
private: private:
static void performLogicalOperation(ExplicitQualitativeCheckResult& first, QualitativeCheckResult const& second, std::function<bool (bool, bool)> const& function);
static void performLogicalOperation(ExplicitQualitativeCheckResult& first, QualitativeCheckResult const& second, bool logicalAnd);
// The values of the quantitative check result. // The values of the quantitative check result.
boost::variant<vector_type, map_type> truthValues; boost::variant<vector_type, map_type> truthValues;

Loading…
Cancel
Save