Browse Source

renamed BoundOperator to PathBoundOperator (StateBoundOperator is coming soon...)

renamed modelChecker to modelchecker
tempestpy_adaptions
gereon 12 years ago
parent
commit
47cb1aa4d9
  1. 2
      src/formula/AbstractFormula.h
  2. 2
      src/formula/AbstractPathFormula.h
  3. 4
      src/formula/AbstractStateFormula.h
  4. 2
      src/formula/And.h
  5. 2
      src/formula/Ap.h
  6. 6
      src/formula/BoundedEventually.h
  7. 9
      src/formula/BoundedNaryUntil.h
  8. 2
      src/formula/BoundedUntil.h
  9. 6
      src/formula/Eventually.h
  10. 4
      src/formula/Formulas.h
  11. 6
      src/formula/NoBoundOperator.h
  12. 2
      src/formula/Not.h
  13. 28
      src/formula/PathBoundOperator.h
  14. 14
      src/formula/ProbabilisticBoundOperator.h
  15. 2
      src/formula/ReachabilityReward.h
  16. 12
      src/formula/RewardBoundOperator.h
  17. 197
      src/formula/StateBoundOperator.h
  18. 161
      src/formula/SteadyStateOperator.h
  19. 0
      src/modelchecker/AbstractModelChecker.h
  20. 4
      src/modelchecker/DtmcPrctlModelChecker.h
  21. 2
      src/modelchecker/EigenDtmcPrctlModelChecker.h
  22. 0
      src/modelchecker/ForwardDeclarations.h
  23. 2
      src/modelchecker/GmmxxDtmcPrctlModelChecker.h
  24. 16
      src/parser/PrctlParser.cpp
  25. 4
      src/storm.cpp
  26. 4
      test/parser/PrctlParserTest.cpp
  27. 35
      test/parser/output.dot
  28. 2
      test/storm-tests.cpp

2
src/formula/AbstractFormula.h

@ -14,7 +14,7 @@ namespace storm { namespace formula {
template <class T> class AbstractFormula; template <class T> class AbstractFormula;
}} }}
#include "src/modelChecker/AbstractModelChecker.h"
#include "src/modelchecker/AbstractModelChecker.h"
#include "src/formula/AbstractFormulaChecker.h" #include "src/formula/AbstractFormulaChecker.h"
namespace storm { namespace storm {

2
src/formula/AbstractPathFormula.h

@ -13,8 +13,8 @@ template <class T> class AbstractPathFormula;
}} }}
#include "src/formula/AbstractFormula.h" #include "src/formula/AbstractFormula.h"
#include "src/modelchecker/AbstractModelChecker.h"
#include "modelChecker/AbstractModelChecker.h"
#include <vector> #include <vector>
#include <iostream> #include <iostream>
#include <typeinfo> #include <typeinfo>

4
src/formula/AbstractStateFormula.h

@ -12,9 +12,9 @@ namespace storm { namespace formula {
template <class T> class AbstractStateFormula; template <class T> class AbstractStateFormula;
}} }}
#include "AbstractFormula.h"
#include "src/formula/AbstractFormula.h"
#include "src/storage/BitVector.h" #include "src/storage/BitVector.h"
#include "src/modelChecker/AbstractModelChecker.h"
#include "src/modelchecker/AbstractModelChecker.h"
namespace storm { namespace storm {
namespace formula { namespace formula {

2
src/formula/And.h

@ -10,7 +10,7 @@
#include "src/formula/AbstractStateFormula.h" #include "src/formula/AbstractStateFormula.h"
#include "src/formula/AbstractFormulaChecker.h" #include "src/formula/AbstractFormulaChecker.h"
#include "src/modelChecker/AbstractModelChecker.h"
#include "src/modelchecker/AbstractModelChecker.h"
#include <string> #include <string>
namespace storm { namespace storm {

2
src/formula/Ap.h

@ -10,7 +10,7 @@
#include "src/formula/AbstractStateFormula.h" #include "src/formula/AbstractStateFormula.h"
#include "src/formula/AbstractFormulaChecker.h" #include "src/formula/AbstractFormulaChecker.h"
#include "src/modelChecker/AbstractModelChecker.h"
#include "src/modelchecker/AbstractModelChecker.h"
namespace storm { namespace storm {
namespace formula { namespace formula {

6
src/formula/BoundedEventually.h

@ -8,12 +8,12 @@
#ifndef STORM_FORMULA_BOUNDEDEVENTUALLY_H_ #ifndef STORM_FORMULA_BOUNDEDEVENTUALLY_H_
#define STORM_FORMULA_BOUNDEDEVENTUALLY_H_ #define STORM_FORMULA_BOUNDEDEVENTUALLY_H_
#include "AbstractPathFormula.h"
#include "AbstractStateFormula.h"
#include "src/formula/AbstractPathFormula.h"
#include "src/formula/AbstractStateFormula.h"
#include "src/formula/AbstractFormulaChecker.h" #include "src/formula/AbstractFormulaChecker.h"
#include "boost/integer/integer_mask.hpp" #include "boost/integer/integer_mask.hpp"
#include <string> #include <string>
#include "src/modelChecker/AbstractModelChecker.h"
#include "src/modelchecker/AbstractModelChecker.h"
namespace storm { namespace storm {

9
src/formula/BoundedNaryUntil.h

@ -10,7 +10,7 @@
#include "src/formula/AbstractPathFormula.h" #include "src/formula/AbstractPathFormula.h"
#include "src/formula/AbstractStateFormula.h" #include "src/formula/AbstractStateFormula.h"
#include "src/modelChecker/AbstractModelChecker.h"
#include "src/modelchecker/AbstractModelChecker.h"
#include "boost/integer/integer_mask.hpp" #include "boost/integer/integer_mask.hpp"
#include <string> #include <string>
#include <vector> #include <vector>
@ -68,7 +68,7 @@ public:
* Empty constructor * Empty constructor
*/ */
BoundedNaryUntil() { BoundedNaryUntil() {
this->left = NULL;
this->left = nullptr;
this->right = new std::vector<std::tuple<AbstractStateFormula<T>*,T,T>>(); this->right = new std::vector<std::tuple<AbstractStateFormula<T>*,T,T>>();
} }
@ -91,10 +91,10 @@ public:
* (this behaviour can be prevented by setting the subtrees to NULL before deletion) * (this behaviour can be prevented by setting the subtrees to NULL before deletion)
*/ */
virtual ~BoundedNaryUntil() { virtual ~BoundedNaryUntil() {
if (left != NULL) {
if (left != nullptr) {
delete left; delete left;
} }
if (right != NULL) {
if (right != nullptr) {
delete right; delete right;
} }
} }
@ -205,7 +205,6 @@ private:
}; };
} //namespace formula } //namespace formula
} //namespace storm } //namespace storm
#endif /* STORM_FORMULA_BOUNDEDNARYUNTIL_H_ */ #endif /* STORM_FORMULA_BOUNDEDNARYUNTIL_H_ */

2
src/formula/BoundedUntil.h

@ -10,7 +10,7 @@
#include "src/formula/AbstractPathFormula.h" #include "src/formula/AbstractPathFormula.h"
#include "src/formula/AbstractStateFormula.h" #include "src/formula/AbstractStateFormula.h"
#include "src/modelChecker/AbstractModelChecker.h"
#include "src/modelchecker/AbstractModelChecker.h"
#include "boost/integer/integer_mask.hpp" #include "boost/integer/integer_mask.hpp"
#include <string> #include <string>
#include "src/formula/AbstractFormulaChecker.h" #include "src/formula/AbstractFormulaChecker.h"

6
src/formula/Eventually.h

@ -8,9 +8,9 @@
#ifndef STORM_FORMULA_EVENTUALLY_H_ #ifndef STORM_FORMULA_EVENTUALLY_H_
#define STORM_FORMULA_EVENTUALLY_H_ #define STORM_FORMULA_EVENTUALLY_H_
#include "AbstractPathFormula.h"
#include "AbstractStateFormula.h"
#include "src/modelChecker/AbstractModelChecker.h"
#include "src/formula/AbstractPathFormula.h"
#include "src/formula/AbstractStateFormula.h"
#include "src/modelchecker/AbstractModelChecker.h"
namespace storm { namespace storm {

4
src/formula/Formulas.h

@ -8,7 +8,7 @@
#ifndef STORM_FORMULA_FORMULAS_H_ #ifndef STORM_FORMULA_FORMULAS_H_
#define STORM_FORMULA_FORMULAS_H_ #define STORM_FORMULA_FORMULAS_H_
#include "modelChecker/ForwardDeclarations.h"
#include "modelchecker/ForwardDeclarations.h"
#include "AbstractFormula.h" #include "AbstractFormula.h"
#include "AbstractPathFormula.h" #include "AbstractPathFormula.h"
@ -35,6 +35,6 @@
#include "RewardBoundOperator.h" #include "RewardBoundOperator.h"
#include "RewardNoBoundOperator.h" #include "RewardNoBoundOperator.h"
#include "modelChecker/DtmcPrctlModelChecker.h"
#include "modelchecker/DtmcPrctlModelChecker.h"
#endif /* STORM_FORMULA_FORMULAS_H_ */ #endif /* STORM_FORMULA_FORMULAS_H_ */

6
src/formula/NoBoundOperator.h

@ -8,11 +8,11 @@
#ifndef STORM_FORMULA_NOBOUNDOPERATOR_H_ #ifndef STORM_FORMULA_NOBOUNDOPERATOR_H_
#define STORM_FORMULA_NOBOUNDOPERATOR_H_ #define STORM_FORMULA_NOBOUNDOPERATOR_H_
#include "AbstractFormula.h"
#include "AbstractPathFormula.h"
#include "src/formula/AbstractFormula.h"
#include "src/formula/AbstractPathFormula.h"
#include "src/formula/AbstractFormulaChecker.h" #include "src/formula/AbstractFormulaChecker.h"
#include "modelChecker/ForwardDeclarations.h"
#include "src/modelchecker/ForwardDeclarations.h"
namespace storm { namespace storm {

2
src/formula/Not.h

@ -10,7 +10,7 @@
#include "AbstractStateFormula.h" #include "AbstractStateFormula.h"
#include "src/formula/AbstractFormulaChecker.h" #include "src/formula/AbstractFormulaChecker.h"
#include "src/modelChecker/AbstractModelChecker.h"
#include "src/modelchecker/AbstractModelChecker.h"
namespace storm { namespace storm {

28
src/formula/BoundOperator.h → src/formula/PathBoundOperator.h

@ -1,35 +1,35 @@
/* /*
* BoundOperator.h
* PathBoundOperator.h
* *
* Created on: 27.12.2012 * Created on: 27.12.2012
* Author: Christian Dehnert * Author: Christian Dehnert
*/ */
#ifndef STORM_FORMULA_BOUNDOPERATOR_H_
#define STORM_FORMULA_BOUNDOPERATOR_H_
#ifndef STORM_FORMULA_PATHBOUNDOPERATOR_H_
#define STORM_FORMULA_PATHBOUNDOPERATOR_H_
#include "src/formula/AbstractStateFormula.h" #include "src/formula/AbstractStateFormula.h"
#include "src/formula/AbstractPathFormula.h" #include "src/formula/AbstractPathFormula.h"
#include "src/formula/AbstractFormulaChecker.h" #include "src/formula/AbstractFormulaChecker.h"
#include "src/modelChecker/AbstractModelChecker.h"
#include "src/modelchecker/AbstractModelChecker.h"
#include "src/utility/ConstTemplates.h" #include "src/utility/ConstTemplates.h"
namespace storm { namespace storm {
namespace formula { namespace formula {
template <class T> class BoundOperator;
template <class T> class PathBoundOperator;
/*! /*!
* @brief Interface class for model checkers that support BoundOperator.
* @brief Interface class for model checkers that support PathBoundOperator.
* *
* All model checkers that support the formula class BoundOperator must inherit
* All model checkers that support the formula class PathBoundOperator must inherit
* this pure virtual class. * this pure virtual class.
*/ */
template <class T> template <class T>
class IBoundOperatorModelChecker {
class IPathBoundOperatorModelChecker {
public: public:
virtual storm::storage::BitVector* checkBoundOperator(const BoundOperator<T>& obj) const = 0;
virtual storm::storage::BitVector* checkPathBoundOperator(const PathBoundOperator<T>& obj) const = 0;
}; };
/*! /*!
@ -54,7 +54,7 @@ class IBoundOperatorModelChecker {
* @see AbstractFormula * @see AbstractFormula
*/ */
template<class T> template<class T>
class BoundOperator : public AbstractStateFormula<T> {
class PathBoundOperator : public AbstractStateFormula<T> {
public: public:
enum ComparisonType { LESS, LESS_EQUAL, GREATER, GREATER_EQUAL }; enum ComparisonType { LESS, LESS_EQUAL, GREATER, GREATER_EQUAL };
@ -66,7 +66,7 @@ public:
* @param bound The bound for the probability * @param bound The bound for the probability
* @param pathFormula The child node * @param pathFormula The child node
*/ */
BoundOperator(ComparisonType comparisonOperator, T bound, AbstractPathFormula<T>* pathFormula)
PathBoundOperator(ComparisonType comparisonOperator, T bound, AbstractPathFormula<T>* pathFormula)
: comparisonOperator(comparisonOperator), bound(bound), pathFormula(pathFormula) { : comparisonOperator(comparisonOperator), bound(bound), pathFormula(pathFormula) {
// Intentionally left empty // Intentionally left empty
} }
@ -77,7 +77,7 @@ public:
* The subtree is deleted with the object * The subtree is deleted with the object
* (this behavior can be prevented by setting them to NULL before deletion) * (this behavior can be prevented by setting them to NULL before deletion)
*/ */
virtual ~BoundOperator() {
virtual ~PathBoundOperator() {
if (pathFormula != nullptr) { if (pathFormula != nullptr) {
delete pathFormula; delete pathFormula;
} }
@ -173,7 +173,7 @@ public:
* @returns A bit vector indicating all states that satisfy the formula represented by the called object. * @returns A bit vector indicating all states that satisfy the formula represented by the called object.
*/ */
virtual storm::storage::BitVector *check(const storm::modelChecker::AbstractModelChecker<T>& modelChecker) const { virtual storm::storage::BitVector *check(const storm::modelChecker::AbstractModelChecker<T>& modelChecker) const {
return modelChecker.template as<IBoundOperatorModelChecker>()->checkBoundOperator(*this);
return modelChecker.template as<IPathBoundOperatorModelChecker>()->checkPathBoundOperator(*this);
} }
/*! /*!
@ -196,4 +196,4 @@ private:
} //namespace storm } //namespace storm
#endif /* STORM_FORMULA_BOUNDOPERATOR_H_ */
#endif /* STORM_FORMULA_PATHBOUNDOPERATOR_H_ */

14
src/formula/ProbabilisticBoundOperator.h

@ -10,7 +10,7 @@
#include "AbstractStateFormula.h" #include "AbstractStateFormula.h"
#include "AbstractPathFormula.h" #include "AbstractPathFormula.h"
#include "BoundOperator.h"
#include "src/formula/PathBoundOperator.h"
#include "utility/ConstTemplates.h" #include "utility/ConstTemplates.h"
namespace storm { namespace storm {
@ -38,14 +38,14 @@ namespace formula {
* @see AbstractFormula * @see AbstractFormula
*/ */
template<class T> template<class T>
class ProbabilisticBoundOperator : public BoundOperator<T> {
class ProbabilisticBoundOperator : public PathBoundOperator<T> {
public: public:
/*! /*!
* Empty constructor * Empty constructor
*/ */
ProbabilisticBoundOperator() : BoundOperator<T>
(BoundOperator<T>::LESS_EQUAL, storm::utility::constGetZero<T>(), nullptr) {
ProbabilisticBoundOperator() : PathBoundOperator<T>
(PathBoundOperator<T>::LESS_EQUAL, storm::utility::constGetZero<T>(), nullptr) {
// Intentionally left empty // Intentionally left empty
} }
@ -58,8 +58,8 @@ public:
* @param pathFormula The child node * @param pathFormula The child node
*/ */
ProbabilisticBoundOperator( ProbabilisticBoundOperator(
typename BoundOperator<T>::ComparisonType comparisonRelation, T bound, AbstractPathFormula<T>* pathFormula) :
BoundOperator<T>(comparisonRelation, bound, pathFormula) {
typename PathBoundOperator<T>::ComparisonType comparisonRelation, T bound, AbstractPathFormula<T>* pathFormula) :
PathBoundOperator<T>(comparisonRelation, bound, pathFormula) {
// Intentionally left empty // Intentionally left empty
} }
@ -68,7 +68,7 @@ public:
*/ */
virtual std::string toString() const { virtual std::string toString() const {
std::string result = "P "; std::string result = "P ";
result += BoundOperator<T>::toString();
result += PathBoundOperator<T>::toString();
return result; return result;
} }

2
src/formula/ReachabilityReward.h

@ -11,7 +11,7 @@
#include "src/formula/AbstractPathFormula.h" #include "src/formula/AbstractPathFormula.h"
#include "src/formula/AbstractStateFormula.h" #include "src/formula/AbstractStateFormula.h"
#include "src/formula/AbstractFormulaChecker.h" #include "src/formula/AbstractFormulaChecker.h"
#include "src/modelChecker/AbstractModelChecker.h"
#include "src/modelchecker/AbstractModelChecker.h"
namespace storm { namespace storm {
namespace formula { namespace formula {

12
src/formula/RewardBoundOperator.h

@ -10,7 +10,7 @@
#include "AbstractStateFormula.h" #include "AbstractStateFormula.h"
#include "AbstractPathFormula.h" #include "AbstractPathFormula.h"
#include "BoundOperator.h"
#include "PathBoundOperator.h"
#include "utility/ConstTemplates.h" #include "utility/ConstTemplates.h"
namespace storm { namespace storm {
@ -37,13 +37,13 @@ namespace formula {
* @see AbstractFormula * @see AbstractFormula
*/ */
template<class T> template<class T>
class RewardBoundOperator : public BoundOperator<T> {
class RewardBoundOperator : public PathBoundOperator<T> {
public: public:
/*! /*!
* Empty constructor * Empty constructor
*/ */
RewardBoundOperator() : BoundOperator<T>(BoundOperator<T>::LESS_EQUAL, storm::utility::constGetZero<T>(), nullptr) {
RewardBoundOperator() : PathBoundOperator<T>(PathBoundOperator<T>::LESS_EQUAL, storm::utility::constGetZero<T>(), nullptr) {
// Intentionally left empty // Intentionally left empty
} }
@ -55,8 +55,8 @@ public:
* @param pathFormula The child node * @param pathFormula The child node
*/ */
RewardBoundOperator( RewardBoundOperator(
typename BoundOperator<T>::ComparisonType comparisonRelation, T bound, AbstractPathFormula<T>* pathFormula) :
BoundOperator<T>(comparisonRelation, bound, pathFormula) {
typename PathBoundOperator<T>::ComparisonType comparisonRelation, T bound, AbstractPathFormula<T>* pathFormula) :
PathBoundOperator<T>(comparisonRelation, bound, pathFormula) {
// Intentionally left empty // Intentionally left empty
} }
@ -65,7 +65,7 @@ public:
*/ */
virtual std::string toString() const { virtual std::string toString() const {
std::string result = "R "; std::string result = "R ";
result += BoundOperator<T>::toString();
result += PathBoundOperator<T>::toString();
return result; return result;
} }

197
src/formula/StateBoundOperator.h

@ -0,0 +1,197 @@
/*
* BoundOperator.h
*
* Created on: 27.12.2012
* Author: Christian Dehnert
*/
#ifndef STORM_FORMULA_STATEBOUNDOPERATOR_H_
#define STORM_FORMULA_STATEBOUNDOPERATOR_H_
#include "src/formula/AbstractStateFormula.h"
#include "src/formula/AbstractPathFormula.h"
#include "src/formula/AbstractFormulaChecker.h"
#include "src/modelChecker/AbstractModelChecker.h"
#include "src/utility/ConstTemplates.h"
namespace storm {
namespace formula {
template <class T> class StateBoundOperator;
/*!
* @brief Interface class for model checkers that support StateBoundOperator.
*
* All model checkers that support the formula class StateBoundOperator must inherit
* this pure virtual class.
*/
template <class T>
class IStateBoundOperatorModelChecker {
public:
virtual storm::storage::BitVector* checkStateBoundOperator(const StateBoundOperator<T>& obj) const = 0;
};
/*!
* @brief
* Class for a Abstract formula tree with a P (probablistic) operator node over a probability interval
* as root.
*
* Has one Abstract state formula as sub formula/tree.
*
* @par Semantics
* The formula holds iff the probability that the state formula holds is inside the bounds
* specified in this operator
*
* The subtree is seen as part of the object and deleted with it
* (this behavior can be prevented by setting them to NULL before deletion)
*
*
* @see AbstractStateFormula
* @see AbstractPathFormula
* @see ProbabilisticOperator
* @see ProbabilisticNoBoundsOperator
* @see AbstractFormula
*/
template<class T>
class StateBoundOperator : public AbstractStateFormula<T> {
public:
enum ComparisonType { LESS, LESS_EQUAL, GREATER, GREATER_EQUAL };
/*!
* Constructor
*
* @param comparisonOperator The relation for the bound.
* @param bound The bound for the probability
* @param stateFormula The child node
*/
StateBoundOperator(ComparisonType comparisonOperator, T bound, AbstractStateFormula<T>* stateFormula)
: comparisonOperator(comparisonOperator), bound(bound), stateFormula(stateFormula) {
// Intentionally left empty
}
/*!
* Destructor
*
* The subtree is deleted with the object
* (this behavior can be prevented by setting them to NULL before deletion)
*/
virtual ~StateBoundOperator() {
if (stateFormula != nullptr) {
delete stateFormula;
}
}
/*!
* @returns the child node (representation of a Abstract state formula)
*/
const AbstractStateFormula<T>& getStateFormula () const {
return *stateFormula;
}
/*!
* Sets the child node
*
* @param stateFormula the state formula that becomes the new child node
*/
void setStateFormula(AbstractStateFormula<T>* stateFormula) {
this->stateFormula = stateFormula;
}
/*!
* @returns the comparison relation
*/
const ComparisonType getComparisonOperator() const {
return comparisonOperator;
}
void setComparisonOperator(ComparisonType comparisonOperator) {
this->comparisonOperator = comparisonOperator;
}
/*!
* @returns the bound for the measure
*/
const T& getBound() const {
return bound;
}
/*!
* Sets the interval in which the probability that the path formula holds may lie in.
*
* @param bound The bound for the measure
*/
void setBound(T bound) {
this->bound = bound;
}
/*!
* @returns a string representation of the formula
*/
virtual std::string toString() const {
std::string result = "";
switch (comparisonOperator) {
case LESS: result += "< "; break;
case LESS_EQUAL: result += "<= "; break;
case GREATER: result += "> "; break;
case GREATER_EQUAL: result += ">= "; break;
}
result += std::to_string(bound);
result += " [";
result += stateFormula->toString();
result += "]";
return result;
}
bool meetsBound(T value) const {
switch (comparisonOperator) {
case LESS: return value < bound; break;
case LESS_EQUAL: return value <= bound; break;
case GREATER: return value > bound; break;
case GREATER_EQUAL: return value >= bound; break;
default: return false;
}
}
/*!
* Clones the called object.
*
* Performs a "deep copy", i.e. the subtrees of the new object are clones of the original ones
*
* @returns a new AND-object that is identical the called object.
*/
virtual AbstractStateFormula<T>* clone() const = 0;
/*!
* Calls the model checker to check this formula.
* Needed to infer the correct type of formula class.
*
* @note This function should only be called in a generic check function of a model checker class. For other uses,
* the methods of the model checker should be used.
*
* @returns A bit vector indicating all states that satisfy the formula represented by the called object.
*/
virtual storm::storage::BitVector *check(const storm::modelChecker::AbstractModelChecker<T>& modelChecker) const {
return modelChecker.template as<IStateBoundOperatorModelChecker>()->checkStateBoundOperator(*this);
}
/*!
* @brief Checks if the subtree conforms to some logic.
*
* @param checker Formula checker object.
* @return true iff the subtree conforms to some logic.
*/
virtual bool conforms(const AbstractFormulaChecker<T>& checker) const {
return checker.conforms(this->stateFormula);
}
private:
ComparisonType comparisonOperator;
T bound;
AbstractStateFormula<T>* stateFormula;
};
} //namespace formula
} //namespace storm
#endif /* STORM_FORMULA_STATEBOUNDOPERATOR_H_ */

161
src/formula/SteadyStateOperator.h

@ -0,0 +1,161 @@
/*
* SteadyState.h
*
* Created on: 19.10.2012
* Author: Thomas Heinemann
*/
#ifndef STORM_FORMULA_STEADYSTATEOPERATOR_H_
#define STORM_FORMULA_STEADYSTATEOPERATOR_H_
#include "AbstractPathFormula.h"
#include "AbstractStateFormula.h"
#include "BoundOperator.h"
#include "src/formula/AbstractFormulaChecker.h"
namespace storm {
namespace formula {
template <class T> class SteadyStateOperator;
/*!
* @brief Interface class for model checkers that support SteadyStateOperator.
*
* All model checkers that support the formula class SteadyStateOperator must inherit
* this pure virtual class.
*/
template <class T>
class ISteadyStateOperatorModelChecker {
public:
/*!
* @brief Evaluates SteadyStateOperator formula within a model checker.
*
* @param obj Formula object with subformulas.
* @return Result of the formula for every node.
*/
virtual storm::storage::BitVector* checkSteadyStateOperator(const SteadyStateOperator<T>& obj) const = 0;
};
/*!
* @brief
* Class for a Abstract (path) formula tree with a SteadyStateOperator node as root.
*
* Has two Abstract state formulas as sub formulas/trees.
*
* @par Semantics
* The formula holds iff \e child holds SteadyStateOperator step, \e child holds
*
* The subtree is seen as part of the object and deleted with the object
* (this behavior can be prevented by setting them to NULL before deletion)
*
* @see AbstractPathFormula
* @see AbstractFormula
*/
template <class T>
class SteadyStateOperator : public BoundOperator<T> {
public:
/*!
* Empty constructor
*/
SteadyStateOperator() : BoundOperator<T>
(BoundOperator<T>::LESS_EQUAL, storm::utility::constGetZero<T>(), nullptr) {
// Intentionally left empty
}
/*!
* Constructor
*
* @param child The child node
*/
SteadyStateOperator(
BoundOperator<T>::ComparisonType comparisonRelation, T bound, AbstractStateFormula<T>* child) {
this->child = child;
}
/*!
* Constructor.
*
* Also deletes the subtree.
* (this behaviour can be prevented by setting the subtrees to NULL before deletion)
*/
virtual ~SteadyStateOperator() {
if (child != NULL) {
delete child;
}
}
/*!
* @returns the child node
*/
const AbstractStateFormula<T>& getChild() const {
return *child;
}
/*!
* Sets the subtree
* @param child the new child node
*/
void setChild(AbstractStateFormula<T>* child) {
this->child = child;
}
/*!
* @returns a string representation of the formula
*/
virtual std::string toString() const {
std::string result = "(";
result += " S ";
result += child->toString();
result += ")";
return result;
}
/*!
* Clones the called object.
*
* Performs a "deep copy", i.e. the subtrees of the new object are clones of the original ones
*
* @returns a new BoundedUntil-object that is identical the called object.
*/
virtual AbstractPathFormula<T>* clone() const {
SteadyStateOperator<T>* result = new SteadyStateOperator<T>();
if (child != NULL) {
result->setChild(child);
}
return result;
}
/*!
* Calls the model checker to check this formula.
* Needed to infer the correct type of formula class.
*
* @note This function should only be called in a generic check function of a model checker class. For other uses,
* the methods of the model checker should be used.
*
* @returns A vector indicating the probability that the formula holds for each state.
*/
virtual storm::storage::BitVector* check(const storm::modelChecker::AbstractModelChecker<T>& modelChecker) const {
return modelChecker.template as<ISteadyStateOperatorModelChecker>()->checkSteadyStateOperator(*this);
}
/*!
* @brief Checks if the subtree conforms to some logic.
*
* @param checker Formula checker object.
* @return true iff the subtree conforms to some logic.
*/
virtual bool conforms(const AbstractFormulaChecker<T>& checker) const {
return checker.conforms(this->child);
}
private:
AbstractStateFormula<T>* child;
};
} //namespace formula
} //namespace storm
#endif /* STORM_FORMULA_STEADYSTATEOPERATOR_H_ */

0
src/modelChecker/AbstractModelChecker.h → src/modelchecker/AbstractModelChecker.h

4
src/modelChecker/DtmcPrctlModelChecker.h → src/modelchecker/DtmcPrctlModelChecker.h

@ -16,7 +16,7 @@
#include "src/storage/BitVector.h" #include "src/storage/BitVector.h"
#include "src/exceptions/InvalidPropertyException.h" #include "src/exceptions/InvalidPropertyException.h"
#include "src/utility/Vector.h" #include "src/utility/Vector.h"
#include "src/modelChecker/AbstractModelChecker.h"
#include "src/modelchecker/AbstractModelChecker.h"
#include <vector> #include <vector>
#include "log4cplus/logger.h" #include "log4cplus/logger.h"
@ -222,7 +222,7 @@ public:
* @param formula The state formula to check * @param formula The state formula to check
* @returns The set of states satisfying the formula, represented by a bit vector * @returns The set of states satisfying the formula, represented by a bit vector
*/ */
storm::storage::BitVector* checkBoundOperator(const storm::formula::BoundOperator<Type>& formula) const {
storm::storage::BitVector* checkPathBoundOperator(const storm::formula::PathBoundOperator<Type>& formula) const {
// First, we need to compute the probability for satisfying the path formula for each state. // First, we need to compute the probability for satisfying the path formula for each state.
std::vector<Type>* quantitativeResult = this->checkPathFormula(formula.getPathFormula()); std::vector<Type>* quantitativeResult = this->checkPathFormula(formula.getPathFormula());

2
src/modelChecker/EigenDtmcPrctlModelChecker.h → src/modelchecker/EigenDtmcPrctlModelChecker.h

@ -11,7 +11,7 @@
#include "src/utility/Vector.h" #include "src/utility/Vector.h"
#include "src/models/Dtmc.h" #include "src/models/Dtmc.h"
#include "src/modelChecker/DtmcPrctlModelChecker.h"
#include "src/modelchecker/DtmcPrctlModelChecker.h"
#include "src/solver/GraphAnalyzer.h" #include "src/solver/GraphAnalyzer.h"
#include "src/utility/ConstTemplates.h" #include "src/utility/ConstTemplates.h"
#include "src/exceptions/NoConvergenceException.h" #include "src/exceptions/NoConvergenceException.h"

0
src/modelChecker/ForwardDeclarations.h → src/modelchecker/ForwardDeclarations.h

2
src/modelChecker/GmmxxDtmcPrctlModelChecker.h → src/modelchecker/GmmxxDtmcPrctlModelChecker.h

@ -11,7 +11,7 @@
#include <cmath> #include <cmath>
#include "src/models/Dtmc.h" #include "src/models/Dtmc.h"
#include "src/modelChecker/DtmcPrctlModelChecker.h"
#include "src/modelchecker/DtmcPrctlModelChecker.h"
#include "src/solver/GraphAnalyzer.h" #include "src/solver/GraphAnalyzer.h"
#include "src/utility/Vector.h" #include "src/utility/Vector.h"
#include "src/utility/ConstTemplates.h" #include "src/utility/ConstTemplates.h"

16
src/parser/PrctlParser.cpp

@ -51,23 +51,23 @@ struct PrctlParser::PrctlGrammar : qi::grammar<Iterator, storm::formula::Abstrac
phoenix::new_<storm::formula::Ap<double>>(qi::_1)]; phoenix::new_<storm::formula::Ap<double>>(qi::_1)];
probabilisticBoundOperator = ( probabilisticBoundOperator = (
(qi::lit("P") >> qi::lit(">") >> qi::double_ >> qi::lit("[") >> pathFormula >> qi::lit("]"))[qi::_val = (qi::lit("P") >> qi::lit(">") >> qi::double_ >> qi::lit("[") >> pathFormula >> qi::lit("]"))[qi::_val =
phoenix::new_<storm::formula::ProbabilisticBoundOperator<double> >(storm::formula::BoundOperator<double>::GREATER, qi::_1, qi::_2)] |
phoenix::new_<storm::formula::ProbabilisticBoundOperator<double> >(storm::formula::PathBoundOperator<double>::GREATER, qi::_1, qi::_2)] |
(qi::lit("P") >> qi::lit(">=") >> qi::double_ >> qi::lit("[") >> pathFormula >> qi::lit("]"))[qi::_val = (qi::lit("P") >> qi::lit(">=") >> qi::double_ >> qi::lit("[") >> pathFormula >> qi::lit("]"))[qi::_val =
phoenix::new_<storm::formula::ProbabilisticBoundOperator<double> >(storm::formula::BoundOperator<double>::GREATER_EQUAL, qi::_1, qi::_2)] |
phoenix::new_<storm::formula::ProbabilisticBoundOperator<double> >(storm::formula::PathBoundOperator<double>::GREATER_EQUAL, qi::_1, qi::_2)] |
(qi::lit("P") >> qi::lit("<") >> qi::double_ >> qi::lit("[") >> pathFormula >> qi::lit("]"))[qi::_val = (qi::lit("P") >> qi::lit("<") >> qi::double_ >> qi::lit("[") >> pathFormula >> qi::lit("]"))[qi::_val =
phoenix::new_<storm::formula::ProbabilisticBoundOperator<double> >(storm::formula::BoundOperator<double>::LESS, qi::_1, qi::_2)] |
phoenix::new_<storm::formula::ProbabilisticBoundOperator<double> >(storm::formula::PathBoundOperator<double>::LESS, qi::_1, qi::_2)] |
(qi::lit("P") >> qi::lit("<=") >> qi::double_ >> qi::lit("[") >> pathFormula >> qi::lit("]"))[qi::_val = (qi::lit("P") >> qi::lit("<=") >> qi::double_ >> qi::lit("[") >> pathFormula >> qi::lit("]"))[qi::_val =
phoenix::new_<storm::formula::ProbabilisticBoundOperator<double> >(storm::formula::BoundOperator<double>::LESS_EQUAL, qi::_1, qi::_2)]
phoenix::new_<storm::formula::ProbabilisticBoundOperator<double> >(storm::formula::PathBoundOperator<double>::LESS_EQUAL, qi::_1, qi::_2)]
); );
rewardBoundOperator = ( rewardBoundOperator = (
(qi::lit("R") >> qi::lit(">") >> qi::double_ >> qi::lit("[") >> pathFormula >> qi::lit("]"))[qi::_val = (qi::lit("R") >> qi::lit(">") >> qi::double_ >> qi::lit("[") >> pathFormula >> qi::lit("]"))[qi::_val =
phoenix::new_<storm::formula::RewardBoundOperator<double> >(storm::formula::BoundOperator<double>::GREATER, qi::_1, qi::_2)] |
phoenix::new_<storm::formula::RewardBoundOperator<double> >(storm::formula::PathBoundOperator<double>::GREATER, qi::_1, qi::_2)] |
(qi::lit("R") >> qi::lit(">=") >> qi::double_ >> qi::lit("[") >> pathFormula >> qi::lit("]"))[qi::_val = (qi::lit("R") >> qi::lit(">=") >> qi::double_ >> qi::lit("[") >> pathFormula >> qi::lit("]"))[qi::_val =
phoenix::new_<storm::formula::RewardBoundOperator<double> >(storm::formula::BoundOperator<double>::GREATER_EQUAL, qi::_1, qi::_2)] |
phoenix::new_<storm::formula::RewardBoundOperator<double> >(storm::formula::PathBoundOperator<double>::GREATER_EQUAL, qi::_1, qi::_2)] |
(qi::lit("R") >> qi::lit("<") >> qi::double_ >> qi::lit("[") >> pathFormula >> qi::lit("]"))[qi::_val = (qi::lit("R") >> qi::lit("<") >> qi::double_ >> qi::lit("[") >> pathFormula >> qi::lit("]"))[qi::_val =
phoenix::new_<storm::formula::RewardBoundOperator<double> >(storm::formula::BoundOperator<double>::LESS, qi::_1, qi::_2)] |
phoenix::new_<storm::formula::RewardBoundOperator<double> >(storm::formula::PathBoundOperator<double>::LESS, qi::_1, qi::_2)] |
(qi::lit("R") >> qi::lit("<=")>> qi::double_ >> qi::lit("[") >> pathFormula >> qi::lit("]"))[qi::_val = (qi::lit("R") >> qi::lit("<=")>> qi::double_ >> qi::lit("[") >> pathFormula >> qi::lit("]"))[qi::_val =
phoenix::new_<storm::formula::RewardBoundOperator<double> >(storm::formula::BoundOperator<double>::LESS_EQUAL, qi::_1, qi::_2)]
phoenix::new_<storm::formula::RewardBoundOperator<double> >(storm::formula::PathBoundOperator<double>::LESS_EQUAL, qi::_1, qi::_2)]
); );
//This block defines rules for parsing formulas with noBoundOperators //This block defines rules for parsing formulas with noBoundOperators

4
src/storm.cpp

@ -22,8 +22,8 @@
#include "src/models/Dtmc.h" #include "src/models/Dtmc.h"
#include "src/storage/SparseMatrix.h" #include "src/storage/SparseMatrix.h"
#include "src/models/AtomicPropositionsLabeling.h" #include "src/models/AtomicPropositionsLabeling.h"
#include "src/modelChecker/EigenDtmcPrctlModelChecker.h"
#include "src/modelChecker/GmmxxDtmcPrctlModelChecker.h"
#include "src/modelchecker/EigenDtmcPrctlModelChecker.h"
#include "src/modelchecker/GmmxxDtmcPrctlModelChecker.h"
#include "src/parser/AutoParser.h" #include "src/parser/AutoParser.h"
#include "src/parser/PrctlParser.h" #include "src/parser/PrctlParser.h"
#include "src/solver/GraphAnalyzer.h" #include "src/solver/GraphAnalyzer.h"

4
test/parser/PrctlParserTest.cpp

@ -53,7 +53,7 @@ TEST(PrctlParserTest, parseProbabilisticFormulaTest) {
storm::formula::ProbabilisticBoundOperator<double>* op = static_cast<storm::formula::ProbabilisticBoundOperator<double>*>(prctlFileParser->getFormula()); storm::formula::ProbabilisticBoundOperator<double>* op = static_cast<storm::formula::ProbabilisticBoundOperator<double>*>(prctlFileParser->getFormula());
ASSERT_EQ(storm::formula::BoundOperator<double>::GREATER, op->getComparisonOperator());
ASSERT_EQ(storm::formula::PathBoundOperator<double>::GREATER, op->getComparisonOperator());
ASSERT_EQ(0.5, op->getBound()); ASSERT_EQ(0.5, op->getBound());
ASSERT_EQ(prctlFileParser->getFormula()->toString(), "P > 0.500000 [F a]"); ASSERT_EQ(prctlFileParser->getFormula()->toString(), "P > 0.500000 [F a]");
@ -73,7 +73,7 @@ TEST(PrctlParserTest, parseRewardFormulaTest) {
storm::formula::RewardBoundOperator<double>* op = static_cast<storm::formula::RewardBoundOperator<double>*>(prctlFileParser->getFormula()); storm::formula::RewardBoundOperator<double>* op = static_cast<storm::formula::RewardBoundOperator<double>*>(prctlFileParser->getFormula());
ASSERT_EQ(storm::formula::BoundOperator<double>::GREATER_EQUAL, op->getComparisonOperator());
ASSERT_EQ(storm::formula::PathBoundOperator<double>::GREATER_EQUAL, op->getComparisonOperator());
ASSERT_EQ(15.0, op->getBound()); ASSERT_EQ(15.0, op->getBound());
ASSERT_EQ(prctlFileParser->getFormula()->toString(), "R >= 15.000000 [(a U !b)]"); ASSERT_EQ(prctlFileParser->getFormula()->toString(), "R >= 15.000000 [(a U !b)]");

35
test/parser/output.dot

@ -0,0 +1,35 @@
digraph dtmc {
1[label="1\n{ phi }"];
2[label="2\n{ phi }"];
3[label="3\n{ phi }"];
4[label="4\n{ smth }"];
5[label="5\n{ phi,smth }"];
6[label="6\n{ psi }"];
7[label="7\n{ phi,psi }"];
8[label="8\n{ phi,psi }"];
9[label="9\n{ phi }"];
10[label="10\n{ phi }"];
11[label="11\n{ phi }"];
0 -> 0 [label=1]
1 -> 3 [label=0.5]
1 -> 4 [label=0.5]
2 -> 1 [label=0.3]
2 -> 7 [label=0.7]
3 -> 2 [label=0.05]
3 -> 3 [label=0.7]
3 -> 6 [label=0.05]
3 -> 8 [label=0.2]
4 -> 1 [label=0.3]
4 -> 5 [label=0.3]
4 -> 6 [label=0.4]
5 -> 4 [label=1]
6 -> 7 [label=1]
7 -> 2 [label=0.2]
7 -> 6 [label=0.8]
8 -> 9 [label=1]
9 -> 8 [label=0.3]
9 -> 9 [label=0.7]
10 -> 4 [label=1]
11 -> 5 [label=0.7]
11 -> 9 [label=0.3]
}

2
test/storm-tests.cpp

@ -7,7 +7,7 @@
#include "log4cplus/fileappender.h" #include "log4cplus/fileappender.h"
#include "src/utility/Settings.h" #include "src/utility/Settings.h"
#include "src/modelChecker/GmmxxDtmcPrctlModelChecker.h"
#include "src/modelchecker/GmmxxDtmcPrctlModelChecker.h"
log4cplus::Logger logger; log4cplus::Logger logger;

Loading…
Cancel
Save