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.
// 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.");
throwstorm::exceptions::WrongFormatException()<<"The state "<<source<<" has multiple Markovian choices.";
if(isMarkovianChoice){
if(stateHasMarkovianChoice){
LOG4CPLUS_ERROR(logger,"The state "<<source<<" has multiple Markovian choices.");
throwstorm::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.");
throwstorm::exceptions::WrongFormatException()<<"The state "<<source<<" has a probabilistic choice preceding a Markovian choice. The Markovian choice must be the first choice listed.";