[2.1] Idempotence, symmetry and associativity for each of □ and ⊓. Below illustrated for □:
P□PP□QP□(Q□R)=P=Q□P=(P□Q)□R□-idem□-sym□-assoc
Distributivity over ⊓: any F(⋅) is distributive if it uses at most one copy of its argument. F(P⊓Q)F(⊓S)=F(P)⊓F(Q)=⊓{F(P)∣P∈S}F-distF-Dist
- True for all operators but recursion.
- Distributivity of ⊓ over □. P⊓(Q□R)=(P⊓Q)□(P⊓R)⊓-□-dist
Step laws show first step actions.
(?x:A→P)□(?x:B→Q)=?x:A∪B→((P⊓Q)<∣x∈A∩B∣>(P<∣x∈A∣>Q))STOP=?x:{}→P□-stepSTOP-step
STOP is a unit of □. STOP□P=P□-unit
Conditional choice is idempotent and distributive over ⊓, and
P<∣true∣>QP<∣false∣>Q=P=Q<∣true∣>-id<∣false∣>-id
Law of recursion μp.P=P[μp.P/p]μ-unwind
Some laws are not present in some models, including □-idem and ⊓-□-dist. Denoted by * in the book/slides.