blob: 09271a164f801091d382d9ffb9fbf1546238bf24 (
plain) (
blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
|
% vim:set spelllang=nl:
\section{Smurf in structurele operationele semantiek}
\label{sec:sos}
We willen ook nog graag laten zien hoe de definities van Smurf eruit zien als
je de structurele operationele semantiek gebruikt. In principe maakt het voor
de analyse van Smurf niet uit of je natuurlijke semantiek gebruikt of
structurele operationele semantiek. Omdat natuurlijke semantiek en structurele
operationele semantiek equivalent zijn wanneer de regels goed gedefinieerd
zijn. Wij hadden een voorkeur om natuurlijke semantiek te gebruiken omdat we
hier meer bekend mee zijn. Echter willen we ook nog graag laten zien hoe het
eruit zou zien als je structurele operationele semantiek zou gebruiken.
We gebruiken hier in plaats van de lambdaregel twee compositieregels om hiervan
ook het verschil aan te geven.
De twee compositieregels zijn als volgt:
$$
\begin{prooftree}
\sostrans
{\stm}{\ip}{\op}{(\stk, \str)}
{\pgm'}{\ip'}{\op'}{(\stk', \str')}
\justifies
\sostrans
{\stm:\pgm}{\ip}{\op}{(\stk,\str)}
{\pgm'}{\ip'}{\op'}{(\stk',\str')}
\using{\rcompeensos}
\qquad
\end{prooftree}
$$
\medskip
$$
\begin{prooftree}
\sostranseind
{\stm}{\ip}{\op}{(\stk, \str)}
{\ip'}{\op'}{(\stk', \str')}
\justifies
\sostrans
{\stm:\pgm}{\ip}{\op}{(\stk,\str)}
{\pgm}{\ip'}{\op'}{(\stk',\str')}
\using{\rcomptweesos}
\qquad
\end{prooftree}
$$
\bigskip
De regel voor $\StmTail$ zou in de structurele operationele semantiek als volgt
zijn:
$$
\begin{prooftree}
\axjustifies
\sostranseind
{\StmTail}{\ip}{\op}{(\stk,\str)}
{\ip}{\op}{(\push{s}{\stk'}, \str)}
\using{\rtailsos}
\qquad
\text{met $\pop{\stk} = (c~s,\stk')$.}
\end{prooftree}
$$
|