From f910288aeaab991b9157f19603fa6b554a72b47e Mon Sep 17 00:00:00 2001 From: Sebastian Junges Date: Fri, 21 May 2021 21:23:02 -0700 Subject: [PATCH] global command indices may not be from 0 to N, so we have to check for highest command index explicitly --- src/storm/storage/prism/Program.cpp | 15 +++++++++++++-- src/storm/storage/prism/Program.h | 2 ++ 2 files changed, 15 insertions(+), 2 deletions(-) diff --git a/src/storm/storage/prism/Program.cpp b/src/storm/storage/prism/Program.cpp index 617479343..033ef304a 100644 --- a/src/storm/storage/prism/Program.cpp +++ b/src/storm/storage/prism/Program.cpp @@ -163,7 +163,8 @@ namespace storm { } } - possiblySynchronizingCommands = storage::BitVector(this->getNumberOfCommands()); + uint64_t highestGlobalIndex = this->getHighestCommandIndex(); + possiblySynchronizingCommands = storage::BitVector(highestGlobalIndex + 1); std::set possiblySynchronizingActionIndices; for(uint64_t syncAction : synchronizingActionIndices) { if (getModuleIndicesByActionIndex(syncAction).size() > 1) { @@ -173,7 +174,7 @@ namespace storm { for (auto const& module : getModules()) { for (auto const& command : module.getCommands()) { if (command.isLabeled()) { - if (possiblySynchronizingActionIndices.count(command.getActionIndex())) { + if (possiblySynchronizingActionIndices.count(command.getActionIndex()) > 0) { possiblySynchronizingCommands.set(command.getGlobalIndex()); } } @@ -2100,6 +2101,16 @@ namespace storm { return std::make_pair(janiModel, newProperties); } + uint64_t Program::getHighestCommandIndex() const { + uint64_t highest = 0; + for (auto const& m : getModules()) { + for (auto const& c : m.getCommands()) { + highest = std::max(highest, c.getGlobalIndex()); + } + } + return highest; + } + storm::expressions::ExpressionManager& Program::getManager() const { return *this->manager; } diff --git a/src/storm/storage/prism/Program.h b/src/storm/storage/prism/Program.h index 3b2240e0c..363ee9375 100644 --- a/src/storm/storage/prism/Program.h +++ b/src/storm/storage/prism/Program.h @@ -765,6 +765,8 @@ namespace storm { // Creates the internal mappings. void createMappings(); + uint64_t getHighestCommandIndex() const; + // The type of the model. ModelType modelType;