Browse Source

second hald of documentation. I guess that's it :-)

tempestpy_adaptions
gereon 12 years ago
parent
commit
9a73a2740a
  1. 20
      src/formula/InstantaneousReward.h
  2. 18
      src/formula/Next.h
  3. 18
      src/formula/NoBoundOperator.h
  4. 18
      src/formula/Not.h
  5. 18
      src/formula/Or.h
  6. 19
      src/formula/PrctlFormulaChecker.h
  7. 2
      src/formula/ProbabilisticBoundOperator.h
  8. 2
      src/formula/ProbabilisticNoBoundOperator.h
  9. 20
      src/formula/ReachabilityReward.h
  10. 2
      src/formula/RewardBoundOperator.h
  11. 2
      src/formula/RewardNoBoundOperator.h
  12. 19
      src/formula/Until.h

20
src/formula/InstantaneousReward.h

@ -20,9 +20,21 @@ namespace formula {
template <class T> class InstantaneousReward; template <class T> class InstantaneousReward;
/*!
* @brief Interface class for model checkers that support InstantaneousReward.
*
* All model checkers that support the formula class InstantaneousReward must inherit
* this pure virtual class.
*/
template <class T> template <class T>
class IInstantaneousRewardModelChecker { class IInstantaneousRewardModelChecker {
public: public:
/*!
* @brief Evaluates InstantaneousReward formula within a model checker.
*
* @param obj Formula object with subformulas.
* @return Result of the formula for every node.
*/
virtual std::vector<T>* checkInstantaneousReward(const InstantaneousReward<T>& obj) const = 0; virtual std::vector<T>* checkInstantaneousReward(const InstantaneousReward<T>& obj) const = 0;
}; };
@ -113,6 +125,14 @@ public:
return modelChecker.template as<IInstantaneousRewardModelChecker>()->checkInstantaneousReward(*this); return modelChecker.template as<IInstantaneousRewardModelChecker>()->checkInstantaneousReward(*this);
} }
/*!
* @brief Checks if all subtrees conform to some logic.
*
* As InstantaneousReward formulas have no subformulas, we return true here.
*
* @param checker Formula checker object.
* @return true
*/
virtual bool conforms(const AbstractFormulaChecker<T>& checker) const { virtual bool conforms(const AbstractFormulaChecker<T>& checker) const {
return true; return true;
} }

18
src/formula/Next.h

@ -18,9 +18,21 @@ namespace formula {
template <class T> class Next; template <class T> class Next;
/*!
* @brief Interface class for model checkers that support Next.
*
* All model checkers that support the formula class Next must inherit
* this pure virtual class.
*/
template <class T> template <class T>
class INextModelChecker { class INextModelChecker {
public: public:
/*!
* @brief Evaluates Next formula within a model checker.
*
* @param obj Formula object with subformulas.
* @return Result of the formula for every node.
*/
virtual std::vector<T>* checkNext(const Next<T>& obj) const = 0; virtual std::vector<T>* checkNext(const Next<T>& obj) const = 0;
}; };
@ -125,6 +137,12 @@ public:
return modelChecker.template as<INextModelChecker>()->checkNext(*this); return modelChecker.template as<INextModelChecker>()->checkNext(*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 { virtual bool conforms(const AbstractFormulaChecker<T>& checker) const {
return checker.conforms(this->child); return checker.conforms(this->child);
} }

18
src/formula/NoBoundOperator.h

@ -18,9 +18,21 @@ namespace formula {
template <class T> class NoBoundOperator; template <class T> class NoBoundOperator;
/*!
* @brief Interface class for model checkers that support NoBoundOperator.
*
* All model checkers that support the formula class NoBoundOperator must inherit
* this pure virtual class.
*/
template <class T> template <class T>
class INoBoundOperatorModelChecker { class INoBoundOperatorModelChecker {
public: public:
/*!
* @brief Evaluates NoBoundOperator formula within a model checker.
*
* @param obj Formula object with subformulas.
* @return Result of the formula for every node.
*/
virtual std::vector<T>* checkNoBoundOperator(const NoBoundOperator<T>& obj) const = 0; virtual std::vector<T>* checkNoBoundOperator(const NoBoundOperator<T>& obj) const = 0;
}; };
@ -118,6 +130,12 @@ public:
*/ */
virtual std::string toString() const = 0; virtual std::string toString() const = 0;
/*!
* @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 { virtual bool conforms(const AbstractFormulaChecker<T>& checker) const {
return checker.conforms(this->pathFormula); return checker.conforms(this->pathFormula);
} }

18
src/formula/Not.h

@ -18,9 +18,21 @@ namespace formula {
template <class T> class Not; template <class T> class Not;
/*!
* @brief Interface class for model checkers that support Not.
*
* All model checkers that support the formula class Not must inherit
* this pure virtual class.
*/
template <class T> template <class T>
class INotModelChecker { class INotModelChecker {
public: public:
/*!
* @brief Evaluates Not formula within a model checker.
*
* @param obj Formula object with subformulas.
* @return Result of the formula for every node.
*/
virtual storm::storage::BitVector* checkNot(const Not<T>& obj) const = 0; virtual storm::storage::BitVector* checkNot(const Not<T>& obj) const = 0;
}; };
@ -119,6 +131,12 @@ public:
return modelChecker.template as<INotModelChecker>()->checkNot(*this); return modelChecker.template as<INotModelChecker>()->checkNot(*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 { virtual bool conforms(const AbstractFormulaChecker<T>& checker) const {
return checker.conforms(this->child); return checker.conforms(this->child);
} }

18
src/formula/Or.h

@ -16,9 +16,21 @@ namespace formula {
template <class T> class Or; template <class T> class Or;
/*!
* @brief Interface class for model checkers that support Or.
*
* All model checkers that support the formula class Or must inherit
* this pure virtual class.
*/
template <class T> template <class T>
class IOrModelChecker { class IOrModelChecker {
public: public:
/*!
* @brief Evaluates Or formula within a model checker.
*
* @param obj Formula object with subformulas.
* @return Result of the formula for every node.
*/
virtual storm::storage::BitVector* checkOr(const Or<T>& obj) const = 0; virtual storm::storage::BitVector* checkOr(const Or<T>& obj) const = 0;
}; };
@ -152,6 +164,12 @@ public:
return modelChecker.template as<IOrModelChecker>()->checkOr(*this); return modelChecker.template as<IOrModelChecker>()->checkOr(*this);
} }
/*!
* @brief Checks if all subtrees conform to some logic.
*
* @param checker Formula checker object.
* @return true iff all subtrees conform to some logic.
*/
virtual bool conforms(const AbstractFormulaChecker<T>& checker) const { virtual bool conforms(const AbstractFormulaChecker<T>& checker) const {
return checker.conforms(this->left) && checker.conforms(this->right); return checker.conforms(this->left) && checker.conforms(this->right);
} }

19
src/formula/PrctlFormulaChecker.h

@ -9,9 +9,22 @@
namespace storm { namespace storm {
namespace formula { namespace formula {
/*!
* @brief Checks formulas if they are within PRCTL.
*
* This class implements AbstractFormulaChecker to check if a given formula
* is part of PRCTL logic.
*/
template <class T> template <class T>
class PrctlFormulaChecker : public AbstractFormulaChecker<T> { class PrctlFormulaChecker : public AbstractFormulaChecker<T> {
public: public:
/*!
* Implementation of AbstractFormulaChecker::conforms() using code
* looking exactly like the sample code given there.
*
* We currently allow And, Ap, Eventually, Not, Or,
* ProbabilisticNoBoundOperator.
*/
virtual bool conforms(const AbstractFormula<T>* formula) const { virtual bool conforms(const AbstractFormula<T>* formula) const {
if ( if (
dynamic_cast<const And<T>*>(formula) || dynamic_cast<const And<T>*>(formula) ||
@ -25,11 +38,9 @@ class PrctlFormulaChecker : public AbstractFormulaChecker<T> {
} }
return false; return false;
} }
private:
}; };
}
}
} // namespace formula
} // namespace storm
#endif #endif

2
src/formula/ProbabilisticBoundOperator.h

@ -14,7 +14,6 @@
#include "utility/ConstTemplates.h" #include "utility/ConstTemplates.h"
namespace storm { namespace storm {
namespace formula { namespace formula {
/*! /*!
@ -92,7 +91,6 @@ public:
}; };
} //namespace formula } //namespace formula
} //namespace storm } //namespace storm
#endif /* STORM_FORMULA_PROBABILISTICBOUNDOPERATOR_H_ */ #endif /* STORM_FORMULA_PROBABILISTICBOUNDOPERATOR_H_ */

2
src/formula/ProbabilisticNoBoundOperator.h

@ -13,7 +13,6 @@
#include "NoBoundOperator.h" #include "NoBoundOperator.h"
namespace storm { namespace storm {
namespace formula { namespace formula {
/*! /*!
@ -77,7 +76,6 @@ public:
}; };
} /* namespace formula */ } /* namespace formula */
} /* namespace storm */ } /* namespace storm */
#endif /* STORM_FORMULA_PROBABILISTICNOBOUNDOPERATOR_H_ */ #endif /* STORM_FORMULA_PROBABILISTICNOBOUNDOPERATOR_H_ */

20
src/formula/ReachabilityReward.h

@ -14,14 +14,25 @@
#include "src/modelChecker/AbstractModelChecker.h" #include "src/modelChecker/AbstractModelChecker.h"
namespace storm { namespace storm {
namespace formula { namespace formula {
template <class T> class ReachabilityReward; template <class T> class ReachabilityReward;
/*!
* @brief Interface class for model checkers that support ReachabilityReward.
*
* All model checkers that support the formula class ReachabilityReward must inherit
* this pure virtual class.
*/
template <class T> template <class T>
class IReachabilityRewardModelChecker { class IReachabilityRewardModelChecker {
public: public:
/*!
* @brief Evaluates ReachabilityReward formula within a model checker.
*
* @param obj Formula object with subformulas.
* @return Result of the formula for every node.
*/
virtual std::vector<T>* checkReachabilityReward(const ReachabilityReward<T>& obj) const = 0; virtual std::vector<T>* checkReachabilityReward(const ReachabilityReward<T>& obj) const = 0;
}; };
@ -121,6 +132,12 @@ public:
return modelChecker.template as<IReachabilityRewardModelChecker>()->checkReachabilityReward(*this); return modelChecker.template as<IReachabilityRewardModelChecker>()->checkReachabilityReward(*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 { virtual bool conforms(const AbstractFormulaChecker<T>& checker) const {
return checker.conforms(this->child); return checker.conforms(this->child);
} }
@ -130,7 +147,6 @@ private:
}; };
} //namespace formula } //namespace formula
} //namespace storm } //namespace storm
#endif /* STORM_FORMULA_REACHABILITYREWARD_H_ */ #endif /* STORM_FORMULA_REACHABILITYREWARD_H_ */

2
src/formula/RewardBoundOperator.h

@ -14,7 +14,6 @@
#include "utility/ConstTemplates.h" #include "utility/ConstTemplates.h"
namespace storm { namespace storm {
namespace formula { namespace formula {
/*! /*!
@ -90,7 +89,6 @@ public:
}; };
} //namespace formula } //namespace formula
} //namespace storm } //namespace storm
#endif /* STORM_FORMULA_REWARDBOUNDOPERATOR_H_ */ #endif /* STORM_FORMULA_REWARDBOUNDOPERATOR_H_ */

2
src/formula/RewardNoBoundOperator.h

@ -13,7 +13,6 @@
#include "NoBoundOperator.h" #include "NoBoundOperator.h"
namespace storm { namespace storm {
namespace formula { namespace formula {
/*! /*!
@ -77,7 +76,6 @@ public:
}; };
} /* namespace formula */ } /* namespace formula */
} /* namespace storm */ } /* namespace storm */
#endif /* STORM_FORMULA_REWARDNOBOUNDOPERATOR_H_ */ #endif /* STORM_FORMULA_REWARDNOBOUNDOPERATOR_H_ */

19
src/formula/Until.h

@ -13,14 +13,25 @@
#include "src/formula/AbstractFormulaChecker.h" #include "src/formula/AbstractFormulaChecker.h"
namespace storm { namespace storm {
namespace formula { namespace formula {
template <class T> class Until; template <class T> class Until;
/*!
* @brief Interface class for model checkers that support Until.
*
* All model checkers that support the formula class Until must inherit
* this pure virtual class.
*/
template <class T> template <class T>
class IUntilModelChecker { class IUntilModelChecker {
public: public:
/*!
* @brief Evaluates Until formula within a model checker.
*
* @param obj Formula object with subformulas.
* @return Result of the formula for every node.
*/
virtual std::vector<T>* checkUntil(const Until<T>& obj) const = 0; virtual std::vector<T>* checkUntil(const Until<T>& obj) const = 0;
}; };
@ -153,6 +164,12 @@ public:
return modelChecker.template as<IUntilModelChecker>()->checkUntil(*this); return modelChecker.template as<IUntilModelChecker>()->checkUntil(*this);
} }
/*!
* @brief Checks if all subtrees conform to some logic.
*
* @param checker Formula checker object.
* @return true iff all subtrees conform to some logic.
*/
virtual bool conforms(const AbstractFormulaChecker<T>& checker) const { virtual bool conforms(const AbstractFormulaChecker<T>& checker) const {
return checker.conforms(this->left) && checker.conforms(this->right); return checker.conforms(this->left) && checker.conforms(this->right);
} }

Loading…
Cancel
Save