Browse Source

Set dont care for children if parent gate fails

Former-commit-id: c70852b7e8
tempestpy_adaptions
Mavo 9 years ago
parent
commit
7bcbbe75fa
  1. 26
      src/storage/dft/DFTElements.cpp
  2. 2
      src/storage/dft/DFTElements.h

26
src/storage/dft/DFTElements.cpp

@ -7,18 +7,24 @@ namespace storm {
template<typename ValueType> template<typename ValueType>
bool DFTElement<ValueType>::checkDontCareAnymore(storm::storage::DFTState<ValueType>& state, DFTStateSpaceGenerationQueues<ValueType>& queues) const { bool DFTElement<ValueType>::checkDontCareAnymore(storm::storage::DFTState<ValueType>& state, DFTStateSpaceGenerationQueues<ValueType>& queues) const {
if(!state.dontCare(mId) && !hasOutgoingDependencies())
{
for(DFTGatePointer const& parent : mParents) {
if(state.isOperational(parent->id())) {
return false;
}
if (state.dontCare(mId)) {
return false;
}
// Check that no outgoing dependencies can be triggered anymore
for (DFTDependencyPointer dependency : mOutgoingDependencies) {
if (state.isOperational(dependency->dependentEvent()->id()) && state.isOperational(dependency->triggerEvent()->id())) {
return false;
} }
state.setDontCare(mId);
return true;
} }
return false;
// Check that no parent can fail anymore
for(DFTGatePointer const& parent : mParents) {
if(state.isOperational(parent->id())) {
return false;
}
}
state.setDontCare(mId);
return true;
} }
template<typename ValueType> template<typename ValueType>

2
src/storage/dft/DFTElements.h

@ -350,6 +350,7 @@ namespace storm {
} }
} }
state.setFailed(this->mId); state.setFailed(this->mId);
this->childrenDontCare(state, queues);
} }
void failsafe(DFTState<ValueType>& state, DFTStateSpaceGenerationQueues<ValueType>& queues) const { void failsafe(DFTState<ValueType>& state, DFTStateSpaceGenerationQueues<ValueType>& queues) const {
@ -359,6 +360,7 @@ namespace storm {
} }
} }
state.setFailsafe(this->mId); state.setFailsafe(this->mId);
this->childrenDontCare(state, queues);
} }
void childrenDontCare(DFTState<ValueType>& state, DFTStateSpaceGenerationQueues<ValueType>& queues) const { void childrenDontCare(DFTState<ValueType>& state, DFTStateSpaceGenerationQueues<ValueType>& queues) const {

Loading…
Cancel
Save