Browse Source
a bit more work toward CheckSettings objects
a bit more work toward CheckSettings objects
Former-commit-id: e8026b85e1
tempestpy_adaptions
dehnert
9 years ago
4 changed files with 180 additions and 7 deletions
-
2src/modelchecker/AbstractModelChecker.cpp
-
4src/modelchecker/AbstractModelChecker.h
-
103src/modelchecker/CheckSettings.cpp
-
78src/modelchecker/CheckSettings.h
@ -1,9 +1,108 @@ |
|||||
#include "src/modelchecker/CheckSettings.h"
|
#include "src/modelchecker/CheckSettings.h"
|
||||
|
|
||||
|
#include "src/logic/Formulas.h"
|
||||
|
|
||||
|
#include "src/utility/constants.h"
|
||||
|
|
||||
namespace storm { |
namespace storm { |
||||
namespace modelchecker { |
namespace modelchecker { |
||||
class CheckSettings { |
|
||||
|
|
||||
}; |
|
||||
|
template<typename ValueType> |
||||
|
CheckSettings<ValueType>::CheckSettings() : CheckSettings(boost::none, false, boost::none, false, false) { |
||||
|
// Intentionally left empty.
|
||||
|
} |
||||
|
|
||||
|
template<typename ValueType> |
||||
|
CheckSettings<ValueType>::CheckSettings(boost::optional<storm::OptimizationDirection> const& optimizationDirection, bool onlyInitialStatesRelevant, boost::optional<std::pair<storm::logic::ComparisonType, ValueType>> const& initialStatesBound, bool qualitative, bool produceStrategies) : optimizationDirection(optimizationDirection), onlyInitialStatesRelevant(onlyInitialStatesRelevant), initialStatesBound(initialStatesBound), qualitative(qualitative), produceStrategies(produceStrategies) { |
||||
|
// Intentionally left empty.
|
||||
|
} |
||||
|
|
||||
|
template<typename ValueType> |
||||
|
CheckSettings<ValueType> CheckSettings<ValueType>::fromToplevelFormula(storm::logic::Formula const& formula) { |
||||
|
return fromFormula(formula, true); |
||||
|
} |
||||
|
|
||||
|
template<typename ValueType> |
||||
|
CheckSettings<ValueType> CheckSettings<ValueType>::fromNestedFormula(storm::logic::Formula const& formula) { |
||||
|
return fromFormula(formula, false); |
||||
|
} |
||||
|
|
||||
|
template<typename ValueType> |
||||
|
CheckSettings<ValueType> CheckSettings<ValueType>::fromFormula(storm::logic::Formula const& formula, bool toplevel) { |
||||
|
boost::optional<storm::OptimizationDirection> optimizationDirection; |
||||
|
boost::optional<std::pair<storm::logic::ComparisonType, ValueType>> initialStatesBound; |
||||
|
bool qualitative = false; |
||||
|
bool onlyInitialStatesRelevant = !toplevel; |
||||
|
bool produceStrategies = false; |
||||
|
|
||||
|
if (formula.isProbabilityOperatorFormula()) { |
||||
|
storm::logic::ProbabilityOperatorFormula const& probabilityOperatorFormula = formula.asProbabilityOperatorFormula(); |
||||
|
if (probabilityOperatorFormula.hasOptimalityType()) { |
||||
|
optimizationDirection = probabilityOperatorFormula.getOptimalityType(); |
||||
|
} |
||||
|
|
||||
|
if (probabilityOperatorFormula.hasBound()) { |
||||
|
if (onlyInitialStatesRelevant) { |
||||
|
initialStatesBound = std::make_pair(probabilityOperatorFormula.getComparisonType(), static_cast<ValueType>(probabilityOperatorFormula.getBound())); |
||||
|
} |
||||
|
if (probabilityOperatorFormula.getBound() == storm::utility::zero<ValueType>() || probabilityOperatorFormula.getBound() == storm::utility::one<ValueType>()) { |
||||
|
qualitative = true; |
||||
|
} |
||||
|
} |
||||
|
} else if (formula.isRewardOperatorFormula()) { |
||||
|
storm::logic::RewardOperatorFormula const& rewardOperatorFormula = formula.asRewardOperatorFormula(); |
||||
|
if (rewardOperatorFormula.hasOptimalityType()) { |
||||
|
optimizationDirection = rewardOperatorFormula.getOptimalityType(); |
||||
|
} |
||||
|
|
||||
|
if (rewardOperatorFormula.hasBound()) { |
||||
|
if (onlyInitialStatesRelevant) { |
||||
|
initialStatesBound = std::make_pair(rewardOperatorFormula.getComparisonType(), static_cast<ValueType>(rewardOperatorFormula.getBound())); |
||||
|
} |
||||
|
if (rewardOperatorFormula.getBound() == storm::utility::zero<ValueType>()) { |
||||
|
qualitative = true; |
||||
|
} |
||||
|
} |
||||
|
} |
||||
|
return CheckSettings<ValueType>(optimizationDirection, onlyInitialStatesRelevant, initialStatesBound, qualitative, produceStrategies); |
||||
|
} |
||||
|
|
||||
|
template<typename ValueType> |
||||
|
bool CheckSettings<ValueType>::isOptimizationDirectionSet() const { |
||||
|
return static_cast<bool>(optimizationDirection); |
||||
|
} |
||||
|
|
||||
|
template<typename ValueType> |
||||
|
storm::OptimizationDirection const& CheckSettings<ValueType>::getOptimizationDirection() const { |
||||
|
return optimizationDirection.get(); |
||||
|
} |
||||
|
|
||||
|
template<typename ValueType> |
||||
|
bool CheckSettings<ValueType>::isOnlyInitialStatesRelevantSet() const { |
||||
|
return onlyInitialStatesRelevant; |
||||
|
} |
||||
|
|
||||
|
template<typename ValueType> |
||||
|
bool CheckSettings<ValueType>::isInitialStatesBoundSet() const { |
||||
|
return static_cast<bool>(initialStatesBound); |
||||
|
} |
||||
|
|
||||
|
template<typename ValueType> |
||||
|
std::pair<storm::logic::ComparisonType, ValueType> const& CheckSettings<ValueType>::getInitialStatesBound() const { |
||||
|
return initialStatesBound.get(); |
||||
|
} |
||||
|
|
||||
|
template<typename ValueType> |
||||
|
bool CheckSettings<ValueType>::isQualitativeSet() const { |
||||
|
return qualitative; |
||||
|
} |
||||
|
|
||||
|
template<typename ValueType> |
||||
|
bool CheckSettings<ValueType>::isProduceStrategiesSet() const { |
||||
|
return produceStrategies; |
||||
|
} |
||||
|
|
||||
|
template class CheckSettings<double>; |
||||
|
|
||||
} |
} |
||||
} |
} |
Write
Preview
Loading…
Cancel
Save
Reference in new issue