You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
54 lines
3.9 KiB
54 lines
3.9 KiB
#ifndef STORM_MODELCHECKER_SPARSEMDPPRCTLMODELCHECKER_H_
|
|
#define STORM_MODELCHECKER_SPARSEMDPPRCTLMODELCHECKER_H_
|
|
|
|
#include "src/modelchecker/propositional/SparsePropositionalModelChecker.h"
|
|
#include "src/models/sparse/Mdp.h"
|
|
#include "src/utility/solver.h"
|
|
#include "src/logic/BoundInfo.h"
|
|
#include "src/solver/MinMaxLinearEquationSolver.h"
|
|
|
|
namespace storm {
|
|
namespace counterexamples {
|
|
template<typename ValueType>
|
|
class SMTMinimalCommandSetGenerator;
|
|
|
|
template<typename ValueType>
|
|
class MILPMinimalLabelSetGenerator;
|
|
}
|
|
|
|
|
|
|
|
namespace modelchecker {
|
|
template<class SparseMdpModelType>
|
|
class SparseMdpPrctlModelChecker : public SparsePropositionalModelChecker<SparseMdpModelType> {
|
|
public:
|
|
typedef typename SparseMdpModelType::ValueType ValueType;
|
|
typedef typename SparseMdpModelType::RewardModelType RewardModelType;
|
|
|
|
friend class storm::counterexamples::SMTMinimalCommandSetGenerator<ValueType>;
|
|
friend class storm::counterexamples::MILPMinimalLabelSetGenerator<ValueType>;
|
|
|
|
explicit SparseMdpPrctlModelChecker(SparseMdpModelType const& model);
|
|
explicit SparseMdpPrctlModelChecker(SparseMdpModelType const& model, std::unique_ptr<storm::utility::solver::MinMaxLinearEquationSolverFactory<ValueType>>&& MinMaxLinearEquationSolverFactory);
|
|
|
|
// The implemented methods of the AbstractModelChecker interface.
|
|
virtual bool canHandle(storm::logic::Formula const& formula) const override;
|
|
virtual std::unique_ptr<CheckResult> computeBoundedUntilProbabilities(storm::logic::BoundedUntilFormula const& pathFormula, CheckSettings<double> const& checkSettings) override;
|
|
virtual std::unique_ptr<CheckResult> computeNextProbabilities(storm::logic::NextFormula const& pathFormula, CheckSettings<double> const& checkSettings) override;
|
|
virtual std::unique_ptr<CheckResult> computeUntilProbabilities(storm::logic::UntilFormula const& pathFormula, CheckSettings<double> const& checkSettings) override;
|
|
virtual std::unique_ptr<CheckResult> computeGloballyProbabilities(storm::logic::GloballyFormula const& pathFormula, CheckSettings<double> const& checkSettings) override;
|
|
virtual std::unique_ptr<CheckResult> computeConditionalProbabilities(storm::logic::ConditionalPathFormula const& pathFormula, CheckSettings<double> const& checkSettings) override;
|
|
virtual std::unique_ptr<CheckResult> computeUntilProbabilitiesForInitialStates(storm::logic::UntilFormula const& pathFormula, CheckSettings<double> const& checkSettings, boost::optional<storm::logic::BoundInfo<ValueType>> const& bound =boost::optional<storm::logic::BoundInfo<ValueType>>());
|
|
virtual std::unique_ptr<CheckResult> computeCumulativeRewards(storm::logic::CumulativeRewardFormula const& rewardPathFormula, CheckSettings<double> const& checkSettings) override;
|
|
virtual std::unique_ptr<CheckResult> computeInstantaneousRewards(storm::logic::InstantaneousRewardFormula const& rewardPathFormula, CheckSettings<double> const& checkSettings) override;
|
|
virtual std::unique_ptr<CheckResult> computeReachabilityRewards(storm::logic::ReachabilityRewardFormula const& rewardPathFormula, CheckSettings<double> const& checkSettings) override;
|
|
virtual std::unique_ptr<CheckResult> computeLongRunAverageProbabilities(storm::logic::StateFormula const& stateFormula, CheckSettings<double> const& checkSettings) override;
|
|
|
|
private:
|
|
// An object that is used for retrieving solvers for systems of linear equations that are the result of nondeterministic choices.
|
|
std::unique_ptr<storm::utility::solver::MinMaxLinearEquationSolverFactory<ValueType>> minMaxLinearEquationSolverFactory;
|
|
};
|
|
} // namespace modelchecker
|
|
} // namespace storm
|
|
|
|
#endif /* STORM_MODELCHECKER_SPARSEMDPPRCTLMODELCHECKER_H_ */
|