|  | @ -35,13 +35,12 @@ namespace storm { | 
		
	
		
			
				|  |  |             using DFTDependencyPointer = std::shared_ptr<DFTDependency<ValueType>>; |  |  |             using DFTDependencyPointer = std::shared_ptr<DFTDependency<ValueType>>; | 
		
	
		
			
				|  |  |             using DFTDependencyVector = std::vector<DFTDependencyPointer>; |  |  |             using DFTDependencyVector = std::vector<DFTDependencyPointer>; | 
		
	
		
			
				|  |  | 
 |  |  | 
 | 
		
	
		
			
				|  |  | 
 |  |  |  | 
		
	
		
			
				|  |  |         protected: |  |  |         protected: | 
		
	
		
			
				|  |  |             size_t mId; |  |  |             size_t mId; | 
		
	
		
			
				|  |  |             std::string mName; |  |  |             std::string mName; | 
		
	
		
			
				|  |  |             size_t mRank = -1; |  |  |             size_t mRank = -1; | 
		
	
		
			
				|  |  |             DFTGateVector mParents; |  |  |             DFTGateVector mParents; | 
		
	
		
			
				|  |  |             DFTDependencyVector dependencies; |  |  |  | 
		
	
		
			
				|  |  |  |  |  |             DFTDependencyVector mOutgoingDependencies; | 
		
	
		
			
				|  |  | 
 |  |  | 
 | 
		
	
		
			
				|  |  |         public: |  |  |         public: | 
		
	
		
			
				|  |  |             DFTElement(size_t id, std::string const& name) : |  |  |             DFTElement(size_t id, std::string const& name) : | 
		
	
	
		
			
				|  | @ -139,27 +138,28 @@ namespace storm { | 
		
	
		
			
				|  |  |                 return res; |  |  |                 return res; | 
		
	
		
			
				|  |  |             } |  |  |             } | 
		
	
		
			
				|  |  |              |  |  |              | 
		
	
		
			
				|  |  |             bool addDependency(DFTDependencyPointer const& e) { |  |  |  | 
		
	
		
			
				|  |  |                 if(std::find(dependencies.begin(), dependencies.end(), e) != dependencies.end()) { |  |  |  | 
		
	
		
			
				|  |  |  |  |  |             bool addOutgoingDependency(DFTDependencyPointer const& e) { | 
		
	
		
			
				|  |  |  |  |  |                 assert(e->triggerEvent()->id() == this->id()); | 
		
	
		
			
				|  |  |  |  |  |                 if(std::find(mOutgoingDependencies.begin(), mOutgoingDependencies.end(), e) != mOutgoingDependencies.end()) { | 
		
	
		
			
				|  |  |                     return false; |  |  |                     return false; | 
		
	
		
			
				|  |  |                 } |  |  |                 } | 
		
	
		
			
				|  |  |                 else |  |  |                 else | 
		
	
		
			
				|  |  |                 { |  |  |                 { | 
		
	
		
			
				|  |  |                     dependencies.push_back(e); |  |  |  | 
		
	
		
			
				|  |  |  |  |  |                     mOutgoingDependencies.push_back(e); | 
		
	
		
			
				|  |  |                     return true; |  |  |                     return true; | 
		
	
		
			
				|  |  |                 } |  |  |                 } | 
		
	
		
			
				|  |  |             } |  |  |             } | 
		
	
		
			
				|  |  |              |  |  |              | 
		
	
		
			
				|  |  |             bool hasDependencies() const { |  |  |  | 
		
	
		
			
				|  |  |                 return !dependencies.empty(); |  |  |  | 
		
	
		
			
				|  |  |  |  |  |             bool hasOutgoingDependencies() const { | 
		
	
		
			
				|  |  |  |  |  |                 return !mOutgoingDependencies.empty(); | 
		
	
		
			
				|  |  |             } |  |  |             } | 
		
	
		
			
				|  |  |              |  |  |              | 
		
	
		
			
				|  |  |             size_t nrDependencies() const { |  |  |  | 
		
	
		
			
				|  |  |                 return dependencies.size(); |  |  |  | 
		
	
		
			
				|  |  |  |  |  |             size_t nrOutgoingDependencies() const { | 
		
	
		
			
				|  |  |  |  |  |                 return mOutgoingDependencies.size(); | 
		
	
		
			
				|  |  |             } |  |  |             } | 
		
	
		
			
				|  |  |              |  |  |              | 
		
	
		
			
				|  |  |             DFTDependencyVector const& getDependencies() const { |  |  |  | 
		
	
		
			
				|  |  |                 return dependencies; |  |  |  | 
		
	
		
			
				|  |  |  |  |  |             DFTDependencyVector const& getOutgoingDependencies() const { | 
		
	
		
			
				|  |  |  |  |  |                 return mOutgoingDependencies; | 
		
	
		
			
				|  |  |             } |  |  |             } | 
		
	
		
			
				|  |  |              |  |  |              | 
		
	
		
			
				|  |  |             virtual void extendSpareModule(std::set<size_t>& elementsInModule) const; |  |  |             virtual void extendSpareModule(std::set<size_t>& elementsInModule) const; | 
		
	
	
		
			
				|  | @ -376,8 +376,13 @@ namespace storm { | 
		
	
		
			
				|  |  |         template<typename ValueType> |  |  |         template<typename ValueType> | 
		
	
		
			
				|  |  |         class DFTBE : public DFTElement<ValueType> { |  |  |         class DFTBE : public DFTElement<ValueType> { | 
		
	
		
			
				|  |  |              |  |  |              | 
		
	
		
			
				|  |  |  |  |  |             using DFTDependencyPointer = std::shared_ptr<DFTDependency<ValueType>>; | 
		
	
		
			
				|  |  |  |  |  |             using DFTDependencyVector = std::vector<DFTDependencyPointer>; | 
		
	
		
			
				|  |  |  |  |  | 
 | 
		
	
		
			
				|  |  |  |  |  |         protected: | 
		
	
		
			
				|  |  |             ValueType mActiveFailureRate; |  |  |             ValueType mActiveFailureRate; | 
		
	
		
			
				|  |  |             ValueType mPassiveFailureRate; |  |  |             ValueType mPassiveFailureRate; | 
		
	
		
			
				|  |  |  |  |  |             DFTDependencyVector mIngoingDependencies; | 
		
	
		
			
				|  |  | 
 |  |  | 
 | 
		
	
		
			
				|  |  |         public: |  |  |         public: | 
		
	
		
			
				|  |  |             DFTBE(size_t id, std::string const& name, ValueType failureRate, ValueType dormancyFactor) : |  |  |             DFTBE(size_t id, std::string const& name, ValueType failureRate, ValueType dormancyFactor) : | 
		
	
	
		
			
				|  | @ -400,6 +405,30 @@ namespace storm { | 
		
	
		
			
				|  |  |                 return mPassiveFailureRate; |  |  |                 return mPassiveFailureRate; | 
		
	
		
			
				|  |  |             } |  |  |             } | 
		
	
		
			
				|  |  |              |  |  |              | 
		
	
		
			
				|  |  |  |  |  |             bool addIngoingDependency(DFTDependencyPointer const& e) { | 
		
	
		
			
				|  |  |  |  |  |                 assert(e->dependentEvent()->id() == this->id()); | 
		
	
		
			
				|  |  |  |  |  |                 if(std::find(mIngoingDependencies.begin(), mIngoingDependencies.end(), e) != mIngoingDependencies.end()) { | 
		
	
		
			
				|  |  |  |  |  |                     return false; | 
		
	
		
			
				|  |  |  |  |  |                 } | 
		
	
		
			
				|  |  |  |  |  |                 else | 
		
	
		
			
				|  |  |  |  |  |                 { | 
		
	
		
			
				|  |  |  |  |  |                     mIngoingDependencies.push_back(e); | 
		
	
		
			
				|  |  |  |  |  |                     return true; | 
		
	
		
			
				|  |  |  |  |  |                 } | 
		
	
		
			
				|  |  |  |  |  |             } | 
		
	
		
			
				|  |  |  |  |  |              | 
		
	
		
			
				|  |  |  |  |  |             bool hasIngoingDependencies() const { | 
		
	
		
			
				|  |  |  |  |  |                 return !mIngoingDependencies.empty(); | 
		
	
		
			
				|  |  |  |  |  |             } | 
		
	
		
			
				|  |  |  |  |  |              | 
		
	
		
			
				|  |  |  |  |  |             size_t nrIngoingDependencies() const { | 
		
	
		
			
				|  |  |  |  |  |                 return mIngoingDependencies.size(); | 
		
	
		
			
				|  |  |  |  |  |             } | 
		
	
		
			
				|  |  |  |  |  |              | 
		
	
		
			
				|  |  |  |  |  |             DFTDependencyVector const& getIngoingDependencies() const { | 
		
	
		
			
				|  |  |  |  |  |                 return mIngoingDependencies; | 
		
	
		
			
				|  |  |  |  |  |             } | 
		
	
		
			
				|  |  |  |  |  |          | 
		
	
		
			
				|  |  |             std::string toString() const override { |  |  |             std::string toString() const override { | 
		
	
		
			
				|  |  |                 std::stringstream stream; |  |  |                 std::stringstream stream; | 
		
	
		
			
				|  |  |                 stream << *this; |  |  |                 stream << *this; | 
		
	
	
		
			
				|  | 
 |