File: test.tex

package info (click to toggle)
coq-iris 4.3.0-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 4,116 kB
  • sloc: python: 130; makefile: 61; sh: 28; sed: 2
file content (105 lines) | stat: -rw-r--r-- 4,718 bytes parent folder | download | duplicates (3)
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
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
\documentclass[10pt]{article}
\usepackage{lmodern}
\usepackage[T1]{fontenc}
\usepackage[utf8]{inputenc}

\input{setup}


\title{The Iris TeX Test Document}
\begin{document}
\maketitle

Here we put a bunch of uses of the macros in \texttt{iris.sty} that we can visually test to ensure they still work when those macros are changed.

\section{Logic notation, Hoare triples}

\begin{mathpar}
{  \hoare{P}{\expr}{Q} }

{  \ahoare{P}{\expr}{Q} }
\end{mathpar}

{
\newcommand{\mapstoDisk}{\mapsto_d}
\newcommand{\mapstoOp}{\mapsto_{\mathit{op}}}
\newcommand{\mapstoLftd}{\mapsto_d^{\mathrm{lftd}}}

\begin{align*}
  \hoareV{ \begin{aligned}
              &\dom(m) = \dom(m') * {} \\
  &\left( \Sep_{(a,o) \in m} a \mapstoLftd o \right) * %
  \left( \Sep_{(a,o') \in m'} a \mapstoOp o' \right)
            \end{aligned}} %
  {\mathit{op}.\texttt{Commit}()}%
  {\left( \Sep_{(a,o) \in m} a \mapstoDisk o \right) \lor
    \left( \Sep_{(a,o') \in m'} a \mapstoDisk o' \right) }
\end{align*}
\begin{align*}
  \ahoareV{ \begin{aligned}
              &\dom(m) = \dom(m') * {} \\
  &\left( \Sep_{(a,o) \in m} a \mapstoLftd o \right) * %
  \left( \Sep_{(a,o') \in m'} a \mapstoOp o' \right)
            \end{aligned}} %
  {\mathit{op}.\texttt{Commit}()}%
  {\left( \Sep_{(a,o) \in m} a \mapstoDisk o \right) \lor
    \left( \Sep_{(a,o') \in m'} a \mapstoDisk o' \right) }
\end{align*}
}

\section{Proof outlines}

\newcommand\oneshotm{\ensuremath{\textdom{OneShot}}}
\newcommand\ospending{\textlog{pending}}
\newcommand\osshot{\textlog{shot}}

\newcommand\newoneshot{\textlang{mk\_oneshot}}
\newcommand\OSset{\textlang{set}}
\newcommand\OScheck{\textlang{check}}

    \begin{proofoutline*}
       \CODE{\Let \lvar = \Alloc(\Inl(0)) in } \\
       \RES{\lvar \mapsto \Inl(0) * \ownGhost\gname{\ospending(1)}}[\top] \quad\COMMENT{(\textsc{hoare-alloc}, \textsc{ghost-alloc})} \\
       \RES{\lvar \mapsto \Inl(0) * \ownGhost\gname{\ospending(1/2)} * \ownGhost\gname{\ospending(1/2)}}[\top] \quad\COMMENT{(\textsc{ghost-op})} \\
       \RES{\knowInv\namesp{I} * \ownGhost\gname{\ospending(1/2)}}[\top] \quad\COMMENT{(\textsc{inv-alloc1})} \\
       \qquad\COMMENT{where $I\eqdef (\lvar \mapsto \Inl(0) * \ownGhost\gname{\ospending(1/2)}) \lor (\Exists n. \lvar \mapsto \Inr(n) * \ownGhost\gname{\osshot(n)})$} \\
       \COMMENT{Pick $T \eqdef \ownGhost\gname{\ospending(1/2)}$. We have to prove $T$ (easy) and two Hoare triples. (\textsc{hoare-ctx})} \\
       \\
       \CODE{\{~~ \OSset ={}\Lam \lvar n. }
         \IND
         \RES{\knowInv\namesp{I} * T}[\top] \IND
           \RES{I * T}[\top\setminus\namesp] \quad\COMMENT{(\textsc{hoare-inv-timeless})} \\
           \RES{\lvar \mapsto \Inl(0) * \ownGhost\gname{\ospending(1/2)} * \ownGhost\gname{\ospending(1/2)}}[\top\setminus\namesp] \quad\COMMENT{(\textsc{ghost-op}, \textsc{ghost-valid})} \\
           \CODE{\Let (\_, b) = \CmpXchg(\lvar, \Inl(0), \Inr(\lvar n)) in} \\
           \RES{\lvar \mapsto \Inr(n) * \ownGhost\gname{\osshot(n)} * b = \True}[\top\setminus\namesp] \quad\COMMENT{(\textsc{hoare-cmpx-suc}, \textsc{ghost-op}, \textsc{ghost-update})} \\
           \RES{I * b = \True}[\top\setminus\namesp] \UNIND
         \RES{\knowInv\namesp{I} * b = \True}[\top] \\
         \CODE{\Assert(b)} \quad\COMMENT{(\textsc{hoare-assert})} \\
         \RES{\TRUE}[\top]
         \UNIND
         \\
       \CODE{~~~ \OScheck ={} \Lam\any. }
         \IND
         \RES{\knowInv\namesp{I}}[\top] \IND
           \RES{I}[\top\setminus\namesp]
           \CODE{\Let \lvarB = \deref \lvar in}
           \RES{I * \prop}[\top\setminus\namesp] \quad\COMMENT{(\textsc{hoare-inv-timeless}, \textsc{hoare-load}, \textsc{ghost-op})} \\
           \qquad\COMMENT{where $\prop \eqdef y = \Inl(0) \lor (\Exists n. y = \Inr(n) * \ownGhost\gname{\osshot(n)})$} \UNIND
         \RES{\knowInv\namesp{I} * \prop}[\top]
           \IND
           \CODE{\Lam\any.} \\
           \RES{\knowInv\namesp{I} * \prop}[\top] \IND
             \RES{I * \prop}[\top\setminus\namesp] \quad\COMMENT{(\textsc{hoare-inv-timeless})} \\
             \CODE{\Let \lvarB' = \deref\lvar in} \quad\COMMENT{~~(\textsc{hoare-load})} \\
             \RES{I * \bigl( y = \Inl(0) \lor (\Exists n. \lvarB = \lvarB' = \Inr(n)) \bigr) }[\top\setminus\namesp] \quad\COMMENT{(\textsc{ghost-op}, \textsc{ghost-valid})} \UNIND
           \RES{\knowInv\namesp{I} * \bigl( y = \Inl(0) \lor (\Exists n. \lvarB = \lvarB' = \Inr(n)) \bigr)}[\top] \\
           \CODE{\MatchML \lvarB with
             \Inl(\any) => ()
           | \Inr(\any) => \Assert(\lvarB = \lvarB')  \quad\COMMENT{~~~~(\textsc{hoare-assert})} end {} }\\
           \RES{\TRUE}[\top]
         \UNIND
       \CODE{\}}
    \end{proofoutline*}


\end{document}