#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 class SMTMinimalCommandSetGenerator; template class MILPMinimalLabelSetGenerator; } namespace modelchecker { template class SparseMdpPrctlModelChecker : public SparsePropositionalModelChecker { public: typedef typename SparseMdpModelType::ValueType ValueType; typedef typename SparseMdpModelType::RewardModelType RewardModelType; friend class storm::counterexamples::SMTMinimalCommandSetGenerator; friend class storm::counterexamples::MILPMinimalLabelSetGenerator; explicit SparseMdpPrctlModelChecker(SparseMdpModelType const& model); explicit SparseMdpPrctlModelChecker(SparseMdpModelType const& model, std::unique_ptr>&& MinMaxLinearEquationSolverFactory); // The implemented methods of the AbstractModelChecker interface. virtual bool canHandle(storm::logic::Formula const& formula) const override; virtual std::unique_ptr computeBoundedUntilProbabilities(storm::logic::BoundedUntilFormula const& pathFormula, CheckSettings const& checkSettings) override; virtual std::unique_ptr computeNextProbabilities(storm::logic::NextFormula const& pathFormula, CheckSettings const& checkSettings) override; virtual std::unique_ptr computeUntilProbabilities(storm::logic::UntilFormula const& pathFormula, CheckSettings const& checkSettings) override; virtual std::unique_ptr computeGloballyProbabilities(storm::logic::GloballyFormula const& pathFormula, CheckSettings const& checkSettings) override; virtual std::unique_ptr computeConditionalProbabilities(storm::logic::ConditionalPathFormula const& pathFormula, CheckSettings const& checkSettings) override; virtual std::unique_ptr computeUntilProbabilitiesForInitialStates(storm::logic::UntilFormula const& pathFormula, CheckSettings const& checkSettings, boost::optional> const& bound =boost::optional>()); virtual std::unique_ptr computeCumulativeRewards(storm::logic::CumulativeRewardFormula const& rewardPathFormula, CheckSettings const& checkSettings) override; virtual std::unique_ptr computeInstantaneousRewards(storm::logic::InstantaneousRewardFormula const& rewardPathFormula, CheckSettings const& checkSettings) override; virtual std::unique_ptr computeReachabilityRewards(storm::logic::ReachabilityRewardFormula const& rewardPathFormula, CheckSettings const& checkSettings) override; virtual std::unique_ptr computeLongRunAverageProbabilities(storm::logic::StateFormula const& stateFormula, CheckSettings 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> minMaxLinearEquationSolverFactory; }; } // namespace modelchecker } // namespace storm #endif /* STORM_MODELCHECKER_SPARSEMDPPRCTLMODELCHECKER_H_ */