#ifndef STORM_LOGIC_CONDITIONALFORMULA_H_ #define STORM_LOGIC_CONDITIONALFORMULA_H_ #include "storm/logic/BinaryPathFormula.h" #include "storm/logic/FormulaContext.h" namespace storm { namespace logic { class ConditionalFormula : public Formula { public: ConditionalFormula(std::shared_ptr const& subformula, std::shared_ptr const& conditionFormula, FormulaContext context = FormulaContext::Probability); virtual ~ConditionalFormula() { // Intentionally left empty. } Formula const& getSubformula() const; Formula const& getConditionFormula() const; FormulaContext const& getContext() const; virtual bool isConditionalProbabilityFormula() const override; virtual bool isConditionalRewardFormula() const override; virtual boost::any accept(FormulaVisitor const& visitor, boost::any const& data) const override; virtual std::ostream& writeToStream(std::ostream& out, bool allowParentheses = false) const override; virtual void gatherAtomicExpressionFormulas(std::vector>& atomicExpressionFormulas) const override; virtual void gatherAtomicLabelFormulas(std::vector>& atomicLabelFormulas) const override; virtual void gatherReferencedRewardModels(std::set& referencedRewardModels) const override; virtual void gatherUsedVariables(std::set& usedVariables) const override; virtual bool hasQualitativeResult() const override; virtual bool hasQuantitativeResult() const override; private: std::shared_ptr subformula; std::shared_ptr conditionFormula; FormulaContext context; }; } } #endif /* STORM_LOGIC_CONDITIONALFORMULA_H_ */