|
|
@ -570,27 +570,22 @@ public class ProbModelChecker extends NonProbModelChecker |
|
|
*/ |
|
|
*/ |
|
|
protected StateValues checkProbPathFormulaSimple(Model model, Expression expr, MinMax minMax, BitSet statesOfInterest) throws PrismException |
|
|
protected StateValues checkProbPathFormulaSimple(Model model, Expression expr, MinMax minMax, BitSet statesOfInterest) throws PrismException |
|
|
{ |
|
|
{ |
|
|
|
|
|
boolean negated = false; |
|
|
StateValues probs = null; |
|
|
StateValues probs = null; |
|
|
|
|
|
|
|
|
// Negation/parentheses |
|
|
|
|
|
if (expr instanceof ExpressionUnaryOp) { |
|
|
|
|
|
ExpressionUnaryOp exprUnary = (ExpressionUnaryOp) expr; |
|
|
|
|
|
// Parentheses |
|
|
|
|
|
if (exprUnary.getOperator() == ExpressionUnaryOp.PARENTH) { |
|
|
|
|
|
// Recurse |
|
|
|
|
|
probs = checkProbPathFormulaSimple(model, exprUnary.getOperand(), minMax, statesOfInterest); |
|
|
|
|
|
} |
|
|
|
|
|
// Negation |
|
|
|
|
|
else if (exprUnary.getOperator() == ExpressionUnaryOp.NOT) { |
|
|
|
|
|
// Compute, then subtract from 1 |
|
|
|
|
|
probs = checkProbPathFormulaSimple(model, exprUnary.getOperand(), minMax.negate(), statesOfInterest); |
|
|
|
|
|
probs.timesConstant(-1.0); |
|
|
|
|
|
probs.plusConstant(1.0); |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
expr = Expression.convertSimplePathFormulaToCanonicalForm(expr); |
|
|
|
|
|
|
|
|
|
|
|
// Negation |
|
|
|
|
|
if (expr instanceof ExpressionUnaryOp && |
|
|
|
|
|
((ExpressionUnaryOp)expr).getOperator() == ExpressionUnaryOp.NOT) { |
|
|
|
|
|
negated = true; |
|
|
|
|
|
minMax = minMax.negate(); |
|
|
|
|
|
expr = ((ExpressionUnaryOp)expr).getOperand(); |
|
|
} |
|
|
} |
|
|
// Temporal operators |
|
|
|
|
|
else if (expr instanceof ExpressionTemporal) { |
|
|
|
|
|
ExpressionTemporal exprTemp = (ExpressionTemporal) expr; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (expr instanceof ExpressionTemporal) { |
|
|
|
|
|
ExpressionTemporal exprTemp = (ExpressionTemporal) expr; |
|
|
|
|
|
|
|
|
// Next |
|
|
// Next |
|
|
if (exprTemp.getOperator() == ExpressionTemporal.P_X) { |
|
|
if (exprTemp.getOperator() == ExpressionTemporal.P_X) { |
|
|
probs = checkProbNext(model, exprTemp, minMax, statesOfInterest); |
|
|
probs = checkProbNext(model, exprTemp, minMax, statesOfInterest); |
|
|
@ -603,15 +598,17 @@ public class ProbModelChecker extends NonProbModelChecker |
|
|
probs = checkProbUntil(model, exprTemp, minMax, statesOfInterest); |
|
|
probs = checkProbUntil(model, exprTemp, minMax, statesOfInterest); |
|
|
} |
|
|
} |
|
|
} |
|
|
} |
|
|
// Anything else - convert to until and recurse |
|
|
|
|
|
else { |
|
|
|
|
|
probs = checkProbPathFormulaSimple(model, exprTemp.convertToUntilForm(), minMax, statesOfInterest); |
|
|
|
|
|
} |
|
|
|
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
if (probs == null) |
|
|
if (probs == null) |
|
|
throw new PrismException("Unrecognised path operator in P operator"); |
|
|
throw new PrismException("Unrecognised path operator in P operator"); |
|
|
|
|
|
|
|
|
|
|
|
if (negated) { |
|
|
|
|
|
// Subtract from 1 for negation |
|
|
|
|
|
probs.timesConstant(-1.0); |
|
|
|
|
|
probs.plusConstant(1.0); |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
return probs; |
|
|
return probs; |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
|