Here you can ask questions and find or give answers to organizational, academic and other questions about studying computer science.

1.1k questions

1.3k answers

1.7k comments

556 users

0 votes

I have 2 questions regarding the following Kripke structure and 2 formulas:

vars a,b,c;

init 4,5;

labels 0:; 1:a; 2:a,b; 3:c; 4:a,c; 5:a,c; 6:;

transitions 0->4; 1->6; 3->4; 3->5; 4->2; 4->4; 4->6; 5->3; 6->0; 6->1; 6->3;

1) nu x. (a & <>x)

2) mu x. (!a | []x)

Both formulas result for inital state s4 in paths that I don't quite understand how the result is determined. Both basically boil down to:

1) true & (false | loop)

2) false | (true & loop)

Where the loop just goes back to the same equation. To me it seems like both either loop forever or end in a false:

1) true & (false | loop) = (false | loop) = loop

2) false | (true & loop) = (true & loop) = loop

However, the first loop is evaluated as true, while the second is evaluated as false. How exactly is this determined?

Finally, I also noticed in the same examples that <>x without successors is evaluated as false, while []x without successors is evaluated as true. What is the intuition behind this? And how would <:>x and [:]x be evaluated if they don't have any predecessors?

in * TF "Emb. Sys. and Rob." by (280 points)

1 Answer

0 votes
 
Best answer

For the same reason, we start with the full state set when doing global model checking on nu, and the empty set when doing so on mu. Mu is the least, nu is the greatest fixpoint.

When we reach a loop, that means “this state is in the fixpoint if it has been in the fixpoint”. Therefore, a loop on the nu-operation is satisfied while a loop on the mu operation is not satisfied. We called this subroutine “LoopTest” on slide 103 in the chapter on mu-calculus https://es.cs.uni-kl.de/teaching/vrs/slides/VRS-05-MuCalculus-1.pdf

by (25.6k points)
selected by
Imprint | Privacy Policy
...