Browse Source

adjusted scheduler dontCare

tempestpy_adaptions
hannah 3 years ago
committed by Stefan Pranger
parent
commit
093b01f0c5
  1. 28
      src/storm/storage/Scheduler.cpp
  2. 10
      src/storm/storage/Scheduler.h

28
src/storm/storage/Scheduler.cpp

@ -90,23 +90,35 @@ namespace storm {
void Scheduler<ValueType>::setDontCare(uint_fast64_t modelState, uint_fast64_t memoryState) { void Scheduler<ValueType>::setDontCare(uint_fast64_t modelState, uint_fast64_t memoryState) {
STORM_LOG_ASSERT(memoryState < getNumberOfMemoryStates(), "Illegal memory state index"); STORM_LOG_ASSERT(memoryState < getNumberOfMemoryStates(), "Illegal memory state index");
STORM_LOG_ASSERT(modelState < schedulerChoices[memoryState].size(), "Illegal model state index"); STORM_LOG_ASSERT(modelState < schedulerChoices[memoryState].size(), "Illegal model state index");
auto& schedulerChoice = schedulerChoices[memoryState][modelState];
if (!dontCareStates[memoryState].get(modelState)) { if (!dontCareStates[memoryState].get(modelState)) {
auto& schedulerChoice = schedulerChoices[memoryState][modelState];
if (!schedulerChoice.isDefined()) {
// Set an arbitrary choice
this->setChoice(0, modelState, memoryState);
}
dontCareStates[memoryState].set(modelState, true); dontCareStates[memoryState].set(modelState, true);
++numOfDontCareStates; ++numOfDontCareStates;
}
}
template <typename ValueType>
void Scheduler<ValueType>::unSetDontCare(uint_fast64_t modelState, uint_fast64_t memoryState) {
STORM_LOG_ASSERT(memoryState < getNumberOfMemoryStates(), "Illegal memory state index");
STORM_LOG_ASSERT(modelState < schedulerChoices[memoryState].size(), "Illegal model state index");
// Choices for dontCare states are not considered undefined or deterministic
if (dontCareStates[memoryState].get(modelState)) {
auto& schedulerChoice = schedulerChoices[memoryState][modelState];
if (!schedulerChoice.isDefined()) { if (!schedulerChoice.isDefined()) {
--numOfUndefinedChoices;
} else if (schedulerChoice.isDeterministic()) {
--numOfDeterministicChoices;
++numOfUndefinedChoices;
} }
dontCareStates[memoryState].set(modelState, false);
--numOfDontCareStates;
// Set an arbitrary choice
schedulerChoices[memoryState][modelState] = SchedulerChoice<ValueType>(0);
} }
} }
template <typename ValueType> template <typename ValueType>
bool Scheduler<ValueType>::isDontCare(uint_fast64_t modelState, uint64_t memoryState) const { bool Scheduler<ValueType>::isDontCare(uint_fast64_t modelState, uint64_t memoryState) const {
return dontCareStates[memoryState].get(modelState); return dontCareStates[memoryState].get(modelState);
@ -137,7 +149,7 @@ namespace storm {
template <typename ValueType> template <typename ValueType>
bool Scheduler<ValueType>::isDeterministicScheduler() const { bool Scheduler<ValueType>::isDeterministicScheduler() const {
return numOfDeterministicChoices == (schedulerChoices.size() * schedulerChoices.begin()->size()) - numOfUndefinedChoices - numOfDontCareStates;
return numOfDeterministicChoices == (schedulerChoices.size() * schedulerChoices.begin()->size()) - numOfUndefinedChoices;
} }
template <typename ValueType> template <typename ValueType>

10
src/storm/storage/Scheduler.h

@ -62,13 +62,21 @@ namespace storm {
/*! /*!
* Set the combination of model state and memoryStructure state to dontCare. * Set the combination of model state and memoryStructure state to dontCare.
* This means the corresponding choices are neither considered undefined nor deterministic.
* Set an arbitrary choice an arbitrary choice if no choice exists.
* *
* @param modelState The state of the model. * @param modelState The state of the model.
* @param memoryState The state of the memoryStructure. * @param memoryState The state of the memoryStructure.
*/ */
void setDontCare(uint_fast64_t modelState, uint_fast64_t memoryState = 0); void setDontCare(uint_fast64_t modelState, uint_fast64_t memoryState = 0);
/*!
* Unset the combination of model state and memoryStructure state to dontCare.
*
* @param modelState The state of the model.
* @param memoryState The state of the memoryStructure.
*/
void unSetDontCare(uint_fast64_t modelState, uint_fast64_t memoryState = 0);
/*! /*!
* Is the combination of model state and memoryStructure state to reachable? * Is the combination of model state and memoryStructure state to reachable?
*/ */

Loading…
Cancel
Save