Browse Source

Added check in Markov automaton parser to ensure the Markovian choice is the first one for each state. This way only the Markovian states need to be stored and by convention their first choice is the Markovian one.

Former-commit-id: 0cca1bb2c7
tempestpy_adaptions
dehnert 11 years ago
parent
commit
1c594d02f5
  1. 19
      src/parser/MarkovAutomatonSparseTransitionParser.cpp

19
src/parser/MarkovAutomatonSparseTransitionParser.cpp

@ -16,6 +16,7 @@ namespace storm {
int_fast64_t lastsource = -1; int_fast64_t lastsource = -1;
bool encounteredEOF = false; bool encounteredEOF = false;
bool stateHasMarkovianChoice = false; bool stateHasMarkovianChoice = false;
bool stateHasProbabilisticChoice = false;
while (buf[0] != '\0' && !encounteredEOF) { while (buf[0] != '\0' && !encounteredEOF) {
// At the current point, the next thing to read is the source state of the next choice to come. // At the current point, the next thing to read is the source state of the next choice to come.
source = checked_strtol(buf, &buf); source = checked_strtol(buf, &buf);
@ -33,9 +34,10 @@ namespace storm {
++result.numberOfChoices; ++result.numberOfChoices;
} }
// If we have moved to the next state, we need to clear the flag that stores whether or not the source has a Markovian choice.
// If we have moved to the next state, we need to clear the flag that stores whether or not the source has a Markovian or probabilistic choice.
if (source != lastsource) { if (source != lastsource) {
stateHasMarkovianChoice = false; stateHasMarkovianChoice = false;
stateHasProbabilisticChoice = false;
} }
// Record that the current source was the last source. // Record that the current source was the last source.
@ -65,9 +67,18 @@ namespace storm {
isMarkovianChoice = false; isMarkovianChoice = false;
} }
if (isMarkovianChoice && stateHasMarkovianChoice) {
LOG4CPLUS_ERROR(logger, "The state " << source << " has multiple Markovian choices.");
throw storm::exceptions::WrongFormatException() << "The state " << source << " has multiple Markovian choices.";
if (isMarkovianChoice) {
if (stateHasMarkovianChoice) {
LOG4CPLUS_ERROR(logger, "The state " << source << " has multiple Markovian choices.");
throw storm::exceptions::WrongFormatException() << "The state " << source << " has multiple Markovian choices.";
}
if (stateHasProbabilisticChoice) {
LOG4CPLUS_ERROR(logger, "The state " << source << " has a probabilistic choice preceding a Markovian choice. The Markovian choice must be the first choice listed.");
throw storm::exceptions::WrongFormatException() << "The state " << source << " has a probabilistic choice preceding a Markovian choice. The Markovian choice must be the first choice listed.";
}
stateHasMarkovianChoice = true;
} else {
stateHasProbabilisticChoice = true;
} }
buf = forwardToNextLine(buf, lineEndings); buf = forwardToNextLine(buf, lineEndings);

Loading…
Cancel
Save