Browse Source

adding needed methods for more formula classes

tempestpy_adaptions
gereon 12 years ago
parent
commit
8077952331
  1. 7
      src/formula/And.h
  2. 5
      src/formula/BoundOperator.h
  3. 5
      src/formula/BoundedEventually.h
  4. 5
      src/formula/CumulativeReward.h
  5. 5
      src/formula/Globally.h
  6. 5
      src/formula/InstantaneousReward.h
  7. 5
      src/formula/Next.h
  8. 7
      src/formula/Or.h
  9. 2
      src/formula/ProbabilisticBoundOperator.h
  10. 1
      src/formula/RewardBoundOperator.h

7
src/formula/And.h

@ -9,6 +9,7 @@
#define STORM_FORMULA_AND_H_ #define STORM_FORMULA_AND_H_
#include "src/formula/AbstractStateFormula.h" #include "src/formula/AbstractStateFormula.h"
#include "src/formula/AbstractFormulaChecker.h"
#include "src/modelChecker/AbstractModelChecker.h" #include "src/modelChecker/AbstractModelChecker.h"
#include <string> #include <string>
@ -149,10 +150,14 @@ 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) {
virtual storm::storage::BitVector* check(const storm::modelChecker::AbstractModelChecker<T>& modelChecker) const {
return modelChecker.template as<IAndModelChecker>()->checkAnd(*this); return modelChecker.template as<IAndModelChecker>()->checkAnd(*this);
} }
virtual bool conforms(const AbstractFormulaChecker<T>& checker) const {
return checker.conforms(this->left) && checker.conforms(this->right);
}
private: private:
AbstractStateFormula<T>* left; AbstractStateFormula<T>* left;
AbstractStateFormula<T>* right; AbstractStateFormula<T>* right;

5
src/formula/BoundOperator.h

@ -10,6 +10,7 @@
#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/modelChecker/AbstractModelChecker.h" #include "src/modelChecker/AbstractModelChecker.h"
#include "src/utility/ConstTemplates.h" #include "src/utility/ConstTemplates.h"
@ -158,6 +159,10 @@ public:
return modelChecker.template as<IBoundUntilModelChecker>()->checkBoundOperator(*this); return modelChecker.template as<IBoundUntilModelChecker>()->checkBoundOperator(*this);
} }
virtual bool conforms(const AbstractFormulaChecker<T>& checker) const {
return checker.conforms(this->pathFormula);
}
private: private:
ComparisonType comparisonOperator; ComparisonType comparisonOperator;
T bound; T bound;

5
src/formula/BoundedEventually.h

@ -10,6 +10,7 @@
#include "AbstractPathFormula.h" #include "AbstractPathFormula.h"
#include "AbstractStateFormula.h" #include "AbstractStateFormula.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"
@ -148,6 +149,10 @@ public:
return modelChecker.template as<IBoundedEventuallyModelChecker>()->checkBoundedEventually(*this); return modelChecker.template as<IBoundedEventuallyModelChecker>()->checkBoundedEventually(*this);
} }
virtual bool conforms(const AbstractFormulaChecker<T>& checker) const {
return checker.conforms(this->child);
}
private: private:
AbstractStateFormula<T>* child; AbstractStateFormula<T>* child;
uint_fast64_t bound; uint_fast64_t bound;

5
src/formula/CumulativeReward.h

@ -10,6 +10,7 @@
#include "AbstractPathFormula.h" #include "AbstractPathFormula.h"
#include "AbstractStateFormula.h" #include "AbstractStateFormula.h"
#include "src/formula/AbstractFormulaChecker.h"
#include "boost/integer/integer_mask.hpp" #include "boost/integer/integer_mask.hpp"
#include <string> #include <string>
@ -112,6 +113,10 @@ public:
return modelChecker.template as<ICumulativeRewardModelChecker>()->checkCumulativeReward(*this); return modelChecker.template as<ICumulativeRewardModelChecker>()->checkCumulativeReward(*this);
} }
virtual bool conforms(const AbstractFormulaChecker<T>& checker) const {
return true;
}
private: private:
uint_fast64_t bound; uint_fast64_t bound;
}; };

5
src/formula/Globally.h

@ -10,6 +10,7 @@
#include "AbstractPathFormula.h" #include "AbstractPathFormula.h"
#include "AbstractStateFormula.h" #include "AbstractStateFormula.h"
#include "src/formula/AbstractFormulaChecker.h"
namespace storm { namespace storm {
@ -122,6 +123,10 @@ public:
return modelChecker.template as<IGloballyModelChecker>()->checkGlobally(*this); return modelChecker.template as<IGloballyModelChecker>()->checkGlobally(*this);
} }
virtual bool conforms(const AbstractFormulaChecker<T>& checker) const {
return checker.conforms(this->child);
}
private: private:
AbstractStateFormula<T>* child; AbstractStateFormula<T>* child;
}; };

5
src/formula/InstantaneousReward.h

@ -10,6 +10,7 @@
#include "AbstractPathFormula.h" #include "AbstractPathFormula.h"
#include "AbstractStateFormula.h" #include "AbstractStateFormula.h"
#include "src/formula/AbstractFormulaChecker.h"
#include "boost/integer/integer_mask.hpp" #include "boost/integer/integer_mask.hpp"
#include <string> #include <string>
@ -112,6 +113,10 @@ public:
return modelChecker.template as<IInstantaneousRewardModelChecker>()->checkInstantaneousReward(*this); return modelChecker.template as<IInstantaneousRewardModelChecker>()->checkInstantaneousReward(*this);
} }
virtual bool conforms(const AbstractFormulaChecker<T>& checker) const {
return true;
}
private: private:
uint_fast64_t bound; uint_fast64_t bound;
}; };

5
src/formula/Next.h

@ -10,6 +10,7 @@
#include "AbstractPathFormula.h" #include "AbstractPathFormula.h"
#include "AbstractStateFormula.h" #include "AbstractStateFormula.h"
#include "src/formula/AbstractFormulaChecker.h"
namespace storm { namespace storm {
@ -124,6 +125,10 @@ public:
return modelChecker.template as<INextModelChecker>()->checkNext(*this); return modelChecker.template as<INextModelChecker>()->checkNext(*this);
} }
virtual bool conforms(const AbstractFormulaChecker<T>& checker) const {
return checker.conforms(this->child);
}
private: private:
AbstractStateFormula<T>* child; AbstractStateFormula<T>* child;
}; };

7
src/formula/Or.h

@ -8,7 +8,8 @@
#ifndef STORM_FORMULA_OR_H_ #ifndef STORM_FORMULA_OR_H_
#define STORM_FORMULA_OR_H_ #define STORM_FORMULA_OR_H_
#include "AbstractStateFormula.h"
#include "src/formula/AbstractStateFormula.h"
#include "src/formula/AbstractFormulaChecker.h"
namespace storm { namespace storm {
namespace formula { namespace formula {
@ -151,6 +152,10 @@ public:
return modelChecker.template as<IOrModelChecker>()->checkOr(*this); return modelChecker.template as<IOrModelChecker>()->checkOr(*this);
} }
virtual bool conforms(const AbstractFormulaChecker<T>& checker) const {
return checker.conforms(this->left) && checker.conforms(this->right);
}
private: private:
AbstractStateFormula<T>* left; AbstractStateFormula<T>* left;
AbstractStateFormula<T>* right; AbstractStateFormula<T>* right;

2
src/formula/ProbabilisticBoundOperator.h

@ -45,10 +45,12 @@ public:
/*! /*!
* Empty constructor * Empty constructor
*/ */
//! TODO: this constructor should give a comparisontype as first argument
ProbabilisticBoundOperator() : BoundOperator<T>(storm::utility::constGetZero<T>(), storm::utility::constGetZero<T>(), nullptr) { ProbabilisticBoundOperator() : BoundOperator<T>(storm::utility::constGetZero<T>(), storm::utility::constGetZero<T>(), nullptr) {
// Intentionally left empty // Intentionally left empty
} }
/*! /*!
* Constructor * Constructor
* *

1
src/formula/RewardBoundOperator.h

@ -44,6 +44,7 @@ public:
/*! /*!
* Empty constructor * Empty constructor
*/ */
//! TODO: this constructor should give a comparisontype as first argument
RewardBoundOperator() : BoundOperator<T>(storm::utility::constGetZero<T>(), storm::utility::constGetZero<T>(), nullptr) { RewardBoundOperator() : BoundOperator<T>(storm::utility::constGetZero<T>(), storm::utility::constGetZero<T>(), nullptr) {
// Intentionally left empty // Intentionally left empty
} }

Loading…
Cancel
Save