#ifndef STORM_LOGIC_BINARYSTATEFORMULA_H_ #define STORM_LOGIC_BINARYSTATEFORMULA_H_ #include "src/logic/StateFormula.h" namespace storm { namespace logic { class BinaryStateFormula : public StateFormula { public: BinaryStateFormula(std::shared_ptr const& leftSubformula, std::shared_ptr const& rightSubformula); virtual ~BinaryStateFormula() { // Intentionally left empty. } virtual bool isBinaryStateFormula() const override; virtual bool isPctlStateFormula() const override; virtual bool isLtlFormula() const override; virtual bool containsBoundedUntilFormula() const override; virtual bool containsNextFormula() const override; virtual bool containsProbabilityOperator() const override; virtual bool containsNestedProbabilityOperators() const override; virtual bool containsRewardOperator() const override; virtual bool containsNestedRewardOperators() const override; Formula const& getLeftSubformula() const; Formula const& getRightSubformula() const; virtual void gatherAtomicExpressionFormulas(std::vector>& atomicExpressionFormulas) const override; virtual void gatherAtomicLabelFormulas(std::vector>& atomicLabelFormulas) const override; private: std::shared_ptr leftSubformula; std::shared_ptr rightSubformula; }; } } #endif /* STORM_LOGIC_BINARYSTATEFORMULA_H_ */