slides/src/slides.tex
author Eugen Sawin <sawine@me73.com>
Fri, 22 Jul 2011 20:49:15 +0200
changeset 71 e7c58603ff08
parent 70 ab0b7643228a
child 72 722ec2a3cabe
permissions -rw-r--r--
Reactive program graph.
sawine@55
     1
\documentclass[9pt]{beamer}
sawine@55
     2
\usetheme{Boadilla}
sawine@58
     3
\usecolortheme{dove}
sawine@58
     4
\usecolortheme{orchid}
sawine@58
     5
\usecolortheme{dolphin}
sawine@58
     6
%\usecolortheme{seagull}
sawine@58
     7
sawine@60
     8
\usepackage{amsmath, amsthm, amssymb, amsfonts, verbatim}
sawine@62
     9
\usepackage{pifont}
sawine@61
    10
\usepackage{xcolor}
sawine@58
    11
\usepackage{ulem}
sawine@66
    12
\usepackage{graphics}
sawine@58
    13
\usepackage{tikz}
sawine@58
    14
\usetikzlibrary{automata}
sawine@58
    15
\usepackage{subfigure}
sawine@55
    16
sawine@61
    17
\renewcommand{\emph}{\textit}
sawine@66
    18
\renewcommand{\em}{\it}
sawine@62
    19
sawine@62
    20
\newcommand{\cross}{\ding{55}}
sawine@55
    21
\newcommand{\M}{\mathcal{M}}
sawine@55
    22
\newcommand{\N}{\mathbb{N}_0}
sawine@55
    23
\newcommand{\F}{\mathcal{F}}
sawine@57
    24
\newcommand{\Fs}{\mathbb{F}}
sawine@55
    25
\newcommand{\Prop}{\mathcal{P}}
sawine@55
    26
\newcommand{\A}{\mathcal{A}}
sawine@55
    27
\newcommand{\X}{\mathcal{X}}
sawine@55
    28
\newcommand{\U}{\mathcal{U}}
sawine@55
    29
\newcommand{\V}{\mathcal{V}}
sawine@55
    30
\newcommand{\dnf}{\mathsf{dnf}}
sawine@55
    31
\newcommand{\consq}{\mathsf{consq}}
sawine@55
    32
sawine@55
    33
\theoremstyle{definition} %plain, definition, remark, proof, corollary
sawine@55
    34
\newtheorem*{def:finite words}{Finite words}
sawine@55
    35
\newtheorem*{def:infinite words}{Infinite words}
sawine@55
    36
\newtheorem*{def:regular languages}{Regular languages}
sawine@55
    37
\newtheorem*{def:regular languages closure}{Regular closure}
sawine@55
    38
\newtheorem*{def:omega regular languages}{$\omega$-regular languages}
sawine@55
    39
\newtheorem*{def:omega regular languages closure}{$\omega$-regular closure}
sawine@55
    40
\newtheorem*{def:buechi automata}{Automaton}
sawine@56
    41
\newtheorem*{def:automata runs}{Run}
sawine@56
    42
\newtheorem*{def:inf}{Infinite occurrences}
sawine@55
    43
\newtheorem*{def:automata acceptance}{Acceptance}
sawine@56
    44
\newtheorem*{def:automata language}{Recognised language}
sawine@57
    45
\newtheorem*{def:general automata}{Generalised automaton}
sawine@55
    46
\newtheorem*{def:general acceptance}{Acceptance}
sawine@61
    47
\newtheorem*{def:syntax}{Syntax}
sawine@61
    48
sawine@61
    49
sawine@55
    50
\newtheorem*{def:vocabulary}{Vocabulary}
sawine@62
    51
\newtheorem*{def:frames}{Frame}
sawine@62
    52
\newtheorem*{def:models}{Model}
sawine@55
    53
\newtheorem*{def:satisfiability}{Satisfiability}
sawine@55
    54
\newtheorem*{def:fs closure}{Closure}
sawine@55
    55
\newtheorem*{def:atoms}{Atoms}
sawine@55
    56
\newtheorem*{def:rep function}{Representation function}
sawine@55
    57
\newtheorem*{def:next}{Next function}
sawine@55
    58
\newtheorem*{def:dnf}{Disjunctive normal form}
sawine@55
    59
\newtheorem*{def:positive formulae}{Positive formulae}
sawine@55
    60
\newtheorem*{def:consq}{Logical consequences}
sawine@55
    61
\newtheorem*{def:partial automata}{Partial automata}
sawine@55
    62
sawine@55
    63
\theoremstyle{plain}
sawine@55
    64
\newtheorem{prop:vocabulary sat}{Proposition}[section]
sawine@55
    65
\newtheorem{prop:general equiv}{Proposition}[section]
sawine@55
    66
\newtheorem{prop:computation set=language}{Proposition}[section]
sawine@55
    67
sawine@55
    68
\theoremstyle{plain}
sawine@55
    69
\newtheorem{thm:model language}{Theorem}[section]
sawine@55
    70
\newtheorem{cor:mod=model language}{Corollary}[thm:model language]
sawine@55
    71
\newtheorem{cor:mod=program language}[cor:mod=model language]{Corollary}
sawine@55
    72
\newtheorem{thm:model checking}{Theorem}[section]
sawine@55
    73
\newtheorem{lem:dnf}{Lemma}[section]
sawine@55
    74
\newtheorem{lem:consq}[lem:dnf]{Lemma}
sawine@55
    75
sawine@55
    76
\title[Algorithmic Verification]{Algorithmic Verification of Reactive Systems}
sawine@55
    77
\author{Eugen Sawin}
sawine@55
    78
\institute[University of Freiburg]
sawine@55
    79
{ 
sawine@55
    80
  Research Group for Foundations in Artificial Intelligence\\
sawine@55
    81
  Computer Science Department\\
sawine@55
    82
  University of Freiburg
sawine@55
    83
}
sawine@55
    84
\date[SS 2011]{Seminar: Automata Constructions in Model Checking}
sawine@55
    85
\subject{Model Checking}
sawine@55
    86
sawine@55
    87
\begin{document}
sawine@55
    88
\frame{\titlepage}
sawine@66
    89
sawine@55
    90
\begin{frame}
sawine@55
    91
\frametitle{Motivation}
sawine@67
    92
\framesubtitle{Model Checking 1/2}
sawine@66
    93
\begin{center}
sawine@66
    94
%\only<1>{\colorbox{black}{\makebox(35,10){\color{white} $\M \models \varphi$}}}
sawine@67
    95
\[\M \models \varphi\]
sawine@66
    96
\end{center}
sawine@66
    97
\end{frame}
sawine@66
    98
sawine@66
    99
\begin{frame}
sawine@66
   100
\frametitle{Motivation}
sawine@67
   101
\framesubtitle{Model Checking 2/2}
sawine@67
   102
\begin{center}
sawine@67
   103
Given a program $P$ and specification $\varphi$:\\
sawine@67
   104
\colorbox{black}{\makebox(150,10){\color{white} does every run of $P$ satisfy $\varphi$?}}
sawine@67
   105
\end{center}
sawine@67
   106
\end{frame}
sawine@67
   107
sawine@67
   108
\begin{frame}
sawine@67
   109
\frametitle{Motivation}
sawine@67
   110
\framesubtitle{Industry}
sawine@66
   111
\begin{figure}
sawine@66
   112
\centering
sawine@67
   113
\subfigure{\includegraphics[width=70pt,height=50pt]{images/intel.jpg}}
sawine@67
   114
\subfigure{\includegraphics[width=70pt,height=50pt]{images/airbag.jpg}}
sawine@67
   115
\subfigure{\includegraphics[width=70pt,height=50pt]{images/atc.jpg}}
sawine@66
   116
\end{figure}
sawine@55
   117
\end{frame}
sawine@55
   118
sawine@67
   119
{
sawine@67
   120
\setbeamercolor{normal text}{bg=black, fg=white}
sawine@67
   121
\setbeamercolor{frametitle}{fg=white!30!black}
sawine@67
   122
\usebeamercolor*{normal text} 
sawine@67
   123
\usebeamercolor*{frametitle} 
sawine@67
   124
\begin{frame}
sawine@67
   125
\frametitle{Linear Temporal Logic}
sawine@70
   126
\framesubtitle{Natural language 1/2}
sawine@67
   127
\begin{center}
sawine@67
   128
``It is dark.''\\
sawine@67
   129
\visible<2->{``It is \emph{always} dark.''\\}
sawine@67
   130
\visible<3->{``It is \emph{currently} dark.''\\}
sawine@69
   131
\visible<4->{``It will \emph{necessarily} be dark.''\\}
sawine@67
   132
\visible<5->{``It is dark \emph{until} someone puts the light on.''}
sawine@67
   133
\end{center}
sawine@67
   134
\end{frame}
sawine@67
   135
}
sawine@67
   136
sawine@67
   137
\begin{frame}
sawine@67
   138
\frametitle{Linear Temporal Logic}
sawine@70
   139
\framesubtitle{Natural language 2/2}
sawine@67
   140
\begin{center}
sawine@67
   141
\only<1->{
sawine@67
   142
\color{white}
sawine@67
   143
\colorbox{black}{\makebox(50,10){It is dark}} \colorbox{orange}{\makebox(30,10){until}} \colorbox{black!30}{\makebox(50,10){there is light}}\\
sawine@67
   144
\visible<2->{
sawine@67
   145
\colorbox{black}{\makebox(50,10){$p_0$}} \colorbox{orange}{\makebox(30,10){$\U$}} \colorbox{black!30}{\makebox(50,10){$p_1$}}}
sawine@67
   146
}
sawine@67
   147
\end{center}
sawine@67
   148
\end{frame}
sawine@67
   149
sawine@67
   150
\begin{frame}
sawine@67
   151
\frametitle{Linear Temporal Logic}
sawine@67
   152
\framesubtitle{Syntax}
sawine@67
   153
\begin{def:syntax}
sawine@67
   154
Let $\Prop$ be the countable set of \emph{atomic propositions}, LTL-formulae $\varphi$ are defined using following productions:
sawine@67
   155
\[\varphi ::= p \in \Prop \,|\, \neg \varphi \,|\, \varphi \lor \varphi \,|\, \X \varphi \,|\, \varphi \U \varphi\]
sawine@67
   156
\begin{itemize}
sawine@67
   157
\item $\neg, \lor$ corresponds to the Boolean \emph{negation} and \emph{disjunction}.
sawine@67
   158
\item $\X$ reads \emph{next}.
sawine@67
   159
\item $\U$ reads \emph{until}.
sawine@67
   160
\end{itemize}
sawine@67
   161
\end{def:syntax}
sawine@67
   162
\end{frame}
sawine@67
   163
sawine@67
   164
\begin{frame}
sawine@67
   165
\frametitle{Linear Temporal Logic}
sawine@67
   166
\framesubtitle{Semantics}
sawine@67
   167
\begin{def:frames}
sawine@67
   168
An LTL-\emph{frame} is a tuple $\F = (S, R)$:
sawine@67
   169
\begin{itemize}
sawine@67
   170
\item $S = \{s_i \mid i \in \N\}$ is the set of states.
sawine@67
   171
\item $R = \{(s_i, s_{i+1}) \mid i \in \N\}$ is the accessibility relation.
sawine@67
   172
\end{itemize} 
sawine@67
   173
\end{def:frames}
sawine@67
   174
sawine@67
   175
\begin{def:models}
sawine@67
   176
An LTL-\emph{model} is a tuple $\M = (\F, V)$:
sawine@67
   177
\begin{itemize}
sawine@67
   178
\item $\F$ is a \emph{frame}.
sawine@67
   179
\item $V: S \to 2^\Prop$ is a \emph{valuation function}.
sawine@67
   180
\item Intuitively we say $p \in \Prop$ is \emph{true} at time instant $i$ iff $p \in V(i)$. 
sawine@67
   181
\end{itemize}
sawine@67
   182
\end{def:models}
sawine@67
   183
\end{frame}
sawine@67
   184
sawine@67
   185
\begin{frame}
sawine@67
   186
\frametitle{Linear Temporal Logic}
sawine@67
   187
\framesubtitle{Model Example}
sawine@67
   188
\begin{figure}
sawine@67
   189
\centering
sawine@67
   190
\begin{tikzpicture}[shorten >=1pt, node distance=2.5cm, auto, semithick, >=stealth   
sawine@67
   191
    ,accepting/.style={fill, gray!50!black, text=white}]
sawine@67
   192
\node[state, initial, initial text=] (s_0) {$\{p_0\}$};
sawine@67
   193
\path (s_0) [late options={label=below:$s_0$}];
sawine@67
   194
\node[state] (s_1) [right of= s_0] {$\{p_0, p_2\}$};
sawine@67
   195
\path (s_1) [late options={label=below:$s_1$}];
sawine@67
   196
\node[state] (s_2) [right of= s_1] {$\{p_1\}$};
sawine@67
   197
\path (s_2) [late options={label=below:$s_2$}];
sawine@67
   198
\node[state] (s_i) [right of= s_2] {$\{p_1\}$};
sawine@67
   199
\path (s_i) [late options={label=below:$s_i$}];
sawine@67
   200
\path[->] 
sawine@67
   201
(s_0) edge node {$R$} (s_1) 
sawine@67
   202
(s_1) edge node {$R$} (s_2);
sawine@67
   203
\path[dashed,->] 
sawine@67
   204
(s_2) edge node {$R$} (s_i); 
sawine@67
   205
\end{tikzpicture}
sawine@67
   206
\end{figure}
sawine@67
   207
\end{frame}
sawine@67
   208
sawine@67
   209
\begin{frame}
sawine@67
   210
\frametitle{Linear Temporal Logic}
sawine@67
   211
\framesubtitle{Satisfiability}
sawine@67
   212
\begin{def:satisfiability}
sawine@67
   213
A model $\M = (\F, V)$ \emph{satisfies} a formula $\varphi$ at time instant $i$ is denoted by $\M,i \models \varphi$:
sawine@67
   214
\begin{itemize}
sawine@67
   215
\item $\M,i \models p$ for $p \in \Prop \iff p \in V(i)$
sawine@67
   216
\item $\M,i \models \neg \varphi \iff$ not $\M,i \models \varphi$
sawine@67
   217
\item $\M,i \models \varphi \lor \psi \iff \M,i \models \varphi$ or $\M,i \models \psi$
sawine@67
   218
\item $\M,i \models \X \varphi \iff \M,i+1 \models \varphi$
sawine@67
   219
\item $\M,i \models \varphi \U \psi \iff \exists{k \geq i}: \M,k \models \psi$ and $\forall{i \leq j < k}: \M,j \models\varphi$
sawine@67
   220
\end{itemize}
sawine@67
   221
\end{def:satisfiability}
sawine@67
   222
\end{frame}
sawine@67
   223
sawine@55
   224
\begin{frame}
sawine@70
   225
\frametitle{Reactive Systems}
sawine@70
   226
\framesubtitle{Infinite inputs}
sawine@71
   227
\begin{center}
sawine@66
   228
\begin{figure}
sawine@71
   229
\setcounter{subfigure}{0} 
sawine@71
   230
\subfigure[Terminating program]{
sawine@70
   231
\begin{tikzpicture}[shorten >=1pt, node distance=1.5cm, semithick, >=stealth   
sawine@70
   232
    ,accepting/.style={fill, gray!50!black, text=white}]
sawine@71
   233
\node[state, initial, initial text=$input$] (p) {$P$};
sawine@71
   234
\coordinate (b) at (1,0);
sawine@70
   235
        %\coordinate (b) at ($(a)+1/2*(3,3)$);
sawine@71
   236
\draw (p) edge[->] node[right] {$\hspace{8pt}output$} (b);
sawine@70
   237
%\draw[->] (p) -- (b);
sawine@70
   238
\end{tikzpicture}
sawine@70
   239
}
sawine@71
   240
\hspace{10pt}
sawine@71
   241
\visible<2>{\subfigure[Reactive program]{
sawine@66
   242
\begin{tikzpicture}[shorten >=1pt, node distance=1.5cm, semithick, >=stealth   
sawine@66
   243
    ,accepting/.style={fill, gray!50!black, text=white}]
sawine@71
   244
\node[state, initial, initial text=$event$] (p) {$RP$};
sawine@71
   245
\coordinate (b) at (1.1,0);
sawine@71
   246
        %\coordinate (b) at ($(a)+1/2*(3,3)$);
sawine@71
   247
\path[->]
sawine@71
   248
(p) edge [loop right] node {$action$} ();
sawine@66
   249
\end{tikzpicture}
sawine@71
   250
}}
sawine@66
   251
\end{figure}
sawine@71
   252
\end{center}
sawine@55
   253
\end{frame}
sawine@55
   254
sawine@55
   255
\begin{frame}
sawine@56
   256
\frametitle{Automata}
sawine@59
   257
\framesubtitle{Example 1/2}
sawine@58
   258
\begin{figure}
sawine@58
   259
\centering
sawine@60
   260
\only<-3>{
sawine@58
   261
\begin{tikzpicture}[shorten >=1pt, node distance=2cm, auto, semithick, >=stealth
sawine@58
   262
    %every state/.style={fill, draw=none, gray, text=white},
sawine@58
   263
    ,accepting/.style={fill, gray!50!black, text=white}
sawine@58
   264
    %initial/.style ={gray, text=white}]%,  thick]
sawine@58
   265
    ]
sawine@58
   266
\node[state,initial, initial text=] (q_0) {$q_0$};
sawine@58
   267
\node[state] (q_1) [above right of= q_0] {$q_1$};
sawine@58
   268
\node[state,accepting](q_2) [below right of= q_1] {$q_2$};
sawine@58
   269
\path[->] 
sawine@58
   270
(q_0) edge node {$a$} (q_1)
sawine@58
   271
  edge [loop above] node {$b$} ()
sawine@58
   272
(q_1) edge node {$b$} (q_2)
sawine@58
   273
  edge [loop above] node {$a$} ()
sawine@58
   274
(q_2) %edge node {$a$} (q_1)
sawine@58
   275
  edge node {$b$} (q_0);
sawine@58
   276
\draw[->] (q_2) .. controls +(up:1cm) and +(right:1cm) .. node[above] {$a$} (q_1);
sawine@60
   277
\end{tikzpicture}\\
sawine@60
   278
\vspace{10pt}
sawine@60
   279
\visible<2-3>{$w_1 = \overline{bbaa} \implies \rho_1 = q_0q_0\overline{q_0q_1q_1q_2}$}\\
sawine@60
   280
\visible<3>{$w_2 = bb\overline{ab} \implies \rho_2 = q_0q_0\overline{q_1q_2}$}\\
sawine@60
   281
\vspace{10pt}
sawine@60
   282
\visible<4>{Accepts all inputs with infinite occurrences of $ab$.}
sawine@58
   283
}
sawine@58
   284
sawine@60
   285
\only<4>{
sawine@58
   286
\begin{tikzpicture}[shorten >=1pt, node distance=2cm, auto, semithick, >=stealth
sawine@58
   287
    %every state/.style={fill, draw=none, gray, text=white},
sawine@58
   288
    ,accepting/.style={fill, gray!50!black, text=white}
sawine@58
   289
    %initial/.style ={gray, text=white}]%,  thick]
sawine@58
   290
    ]
sawine@58
   291
\node[state,initial, initial text=] (q_0) {$q_0$};
sawine@58
   292
\node[state] (q_1) [above right of= q_0] {$q_1$};
sawine@58
   293
\node[state,accepting](q_2) [below right of= q_1] {$q_2$};
sawine@58
   294
\path[->] 
sawine@58
   295
(q_0) 
sawine@58
   296
  edge [loop above] node {$b$} ()
sawine@58
   297
(q_1) 
sawine@58
   298
  edge [loop above] node {$a$} ()
sawine@58
   299
(q_2) %edge node {$a$} (q_1)
sawine@58
   300
  edge node {$b$} (q_0);
sawine@58
   301
\color{green}
sawine@58
   302
\path[->] 
sawine@58
   303
(q_0) edge node {$a$} (q_1) 
sawine@58
   304
(q_1) edge node {$b$} (q_2);
sawine@58
   305
\draw[->] (q_2) .. controls +(up:1cm) and +(right:1cm) .. node[above] {$a$} (q_1);
sawine@59
   306
\end{tikzpicture}\\
sawine@58
   307
\color{black}
sawine@60
   308
\vspace{10pt}
sawine@60
   309
\visible<2->{$w_1 = \overline{\textcolor{green}{b}ba\textcolor{green}{a}} \implies \rho_1 = q_0q_0\overline{q_0q_1q_1\textcolor{green}{q_2}}$}\\
sawine@60
   310
\visible<3->{$w_2 = bb\overline{\textcolor{green}{ab}} \implies \rho_2 = q_0q_0\overline{q_1\textcolor{green}{q_2}}$}\\
sawine@60
   311
\vspace{10pt}
sawine@60
   312
\visible<4>{Accepts all inputs with infinite occurrences of $ab$.}
sawine@58
   313
}
sawine@58
   314
%Automaton $\A_1$
sawine@58
   315
\end{figure}
sawine@58
   316
\end{frame}
sawine@58
   317
sawine@58
   318
\begin{frame}
sawine@58
   319
\frametitle{Automata}
sawine@59
   320
\framesubtitle{Example 2/2 (Complement)}
sawine@58
   321
\begin{figure}
sawine@58
   322
\centering
sawine@60
   323
\only<1>{
sawine@58
   324
  \subfigure
sawine@58
   325
            {
sawine@58
   326
              \begin{tikzpicture}[shorten >=1pt, node distance=2cm, auto, semithick, >=stealth
sawine@58
   327
                  %every state/.style={fill, draw=none, gray, text=white},
sawine@58
   328
                  ,accepting/.style={fill, gray!50!black, text=white}
sawine@58
   329
                  %initial/.style ={gray, text=white}]%,  thick]
sawine@58
   330
                ]
sawine@58
   331
                \node[state,initial, initial text=, accepting] (q_0) {$q_0$};
sawine@58
   332
                \node[state, accepting] (q_1) [above right of= q_0] {$q_1$};
sawine@58
   333
                \node[state](q_2) [below right of= q_1] {$q_2$};
sawine@58
   334
                \path[->] 
sawine@58
   335
                (q_0) edge node {$a$} (q_1)
sawine@58
   336
                edge [loop above] node {$b$} ()
sawine@58
   337
                (q_1) edge node {$b$} (q_2)
sawine@58
   338
                edge [loop above] node {$a$} ()
sawine@58
   339
                (q_2) %edge node {$a$} (q_1)
sawine@58
   340
                edge node {$b$} (q_0);
sawine@58
   341
                \draw[->] (q_2) .. controls +(up:1cm) and +(right:1cm) .. node[above] {$a$} (q_1);
sawine@58
   342
              \end{tikzpicture}
sawine@58
   343
            }
sawine@58
   344
}
sawine@58
   345
\only<2>{ 
sawine@58
   346
  \subfigure
sawine@58
   347
            {
sawine@58
   348
              \begin{tikzpicture}[shorten >=1pt, node distance=2cm, auto, semithick, >=stealth
sawine@58
   349
                  %every state/.style={fill, draw=none, gray, text=white},
sawine@58
   350
                  ,accepting/.style={fill, gray!50!black, text=white}
sawine@58
   351
                  %initial/.style ={gray, text=white}]%,  thick]
sawine@58
   352
                ]
sawine@58
   353
                \node[state,initial, initial text=, accepting] (q_0) {$q_0$};
sawine@58
   354
                \node[state, accepting] (q_1) [above right of= q_0] {$q_1$};
sawine@58
   355
                \node[state](q_2) [below right of= q_1] {$q_2$};
sawine@58
   356
                \path[->] 
sawine@58
   357
                (q_0) 
sawine@58
   358
                edge [loop above] node {$b$} ()
sawine@58
   359
                (q_1) 
sawine@58
   360
                edge [loop above] node {$a$} ();                
sawine@58
   361
                \color{red}  
sawine@58
   362
                \path[->] 
sawine@58
   363
                (q_0) edge node {$a$} (q_1)
sawine@58
   364
                (q_1) edge node {$b$} (q_2)
sawine@58
   365
                (q_2) edge node {$b$} (q_0);  
sawine@58
   366
                \draw[->] (q_2) .. controls +(up:1cm) and +(right:1cm) .. node[above] {$a$} (q_1);              
sawine@58
   367
              \end{tikzpicture}  \color{red}  
sawine@58
   368
            }
sawine@58
   369
 \color{black}
sawine@58
   370
}
sawine@58
   371
\only<3->{ \setcounter{subfigure}{0} 
sawine@62
   372
  \subfigure[Complement automaton \cross]
sawine@58
   373
            {
sawine@58
   374
              \begin{tikzpicture}[shorten >=1pt, node distance=2cm, auto, semithick, >=stealth
sawine@58
   375
                  %every state/.style={fill, draw=none, gray, text=white},
sawine@58
   376
                  ,accepting/.style={fill, gray!50!black, text=white}
sawine@58
   377
                  %initial/.style ={gray, text=white}]%,  thick]
sawine@58
   378
                ]
sawine@58
   379
                \node[state,initial, initial text=, accepting] (q_0) {$q_0$};
sawine@58
   380
                \node[state, accepting] (q_1) [above right of= q_0] {$q_1$};
sawine@58
   381
                \node[state](q_2) [below right of= q_1] {$q_2$};
sawine@58
   382
                \path[->] 
sawine@58
   383
                (q_0) 
sawine@58
   384
                edge [loop above] node {$b$} ()
sawine@58
   385
                (q_1) 
sawine@58
   386
                edge [loop above] node {$a$} ();                
sawine@58
   387
                \path[->] 
sawine@58
   388
                (q_0) edge node {$a$} (q_1)
sawine@58
   389
                (q_1) edge node {$b$} (q_2)
sawine@58
   390
                (q_2) edge node {$b$} (q_0);  
sawine@58
   391
                \draw[->] (q_2) .. controls +(up:1cm) and +(right:1cm) .. node[above] {$a$} (q_1);              
sawine@58
   392
              \end{tikzpicture}  \color{red}  
sawine@58
   393
            }
sawine@58
   394
 \color{black}
sawine@58
   395
}
sawine@60
   396
%\hspace{10pt}
sawine@58
   397
\visible<3->{
sawine@62
   398
  \subfigure[Complement automaton \checkmark]
sawine@58
   399
            {
sawine@58
   400
              \label{fig:complement automaton}
sawine@58
   401
              \begin{tikzpicture}[shorten >=1pt, node distance=2cm, auto, semithick, >=stealth   
sawine@58
   402
                  ,accepting/.style={fill, gray!50!black, text=white}]
sawine@58
   403
                \node[state, initial, initial text=] (q_0) {$q_0$};
sawine@58
   404
                \node[state, accepting] (q_1) [above right of= q_0] {$q_1$};
sawine@58
   405
                \node[state, accepting](q_2) [below right of= q_1] {$q_2$};
sawine@58
   406
                \path[->] 
sawine@58
   407
                (q_0) edge node {$a$} (q_1)
sawine@58
   408
                edge node {$b$} (q_2)
sawine@58
   409
                edge [loop above] node {$a, b$} ()
sawine@58
   410
                (q_1) edge [loop above] node {$a$} ()
sawine@58
   411
                (q_2) 
sawine@58
   412
                edge [loop above] node {$b$} ();
sawine@58
   413
              \end{tikzpicture}\color{green}  
sawine@59
   414
            }\\
sawine@58
   415
\color{black}  
sawine@59
   416
\vspace{20pt}
sawine@66
   417
Accepts all inputs with finite many $ab$.
sawine@58
   418
}
sawine@58
   419
%\caption{Automata from Example \ref{ex:automaton}}
sawine@58
   420
\end{figure}
sawine@58
   421
\end{frame}
sawine@61
   422
\color{black}  
sawine@58
   423
sawine@58
   424
\begin{frame}
sawine@58
   425
\frametitle{Automata}
sawine@56
   426
\framesubtitle{Definition}
sawine@55
   427
\begin{def:buechi automata}
sawine@56
   428
A non-deterministic B\"uchi automaton is a tuple $\A = (\Sigma, S, S_0, \Delta, F)$ with:
sawine@55
   429
\begin{itemize}
sawine@57
   430
\item $\Sigma$ is a finite \emph{alphabet}.
sawine@57
   431
\item $S$ is a finite set of \emph{states}.
sawine@57
   432
\item $S_0 \subseteq S$ is the set of \emph{initial states}.
sawine@57
   433
\item $\Delta: S \times \Sigma \times S$ is a \emph{transition relation}.
sawine@57
   434
\item $F \subseteq S$ is the set of \emph{accepting states}.
sawine@55
   435
\end{itemize}
sawine@55
   436
\end{def:buechi automata}
sawine@55
   437
\end{frame}
sawine@55
   438
sawine@55
   439
\begin{frame}
sawine@56
   440
\frametitle{Automata}
sawine@56
   441
\framesubtitle{Runs}
sawine@56
   442
\begin{def:automata runs}
sawine@56
   443
Let $\A = (\Sigma, S, S_0, \Delta, F)$ be an automaton:
sawine@56
   444
\begin{itemize}
sawine@56
   445
\item A run $\rho$ of $\A$ on an infinite word $w = a_0,a_1,...$ is a sequence $\rho = s_0,s_1,...$:
sawine@56
   446
\begin{itemize}
sawine@57
   447
\item $s_0 \in S_0$.
sawine@57
   448
\item $(s_i, a_i, s_{i+1}) \in \Delta$, for all $i \geq 0$.
sawine@56
   449
\end{itemize}
sawine@57
   450
\item Alternative view of a run $\rho$ as a function $\rho : \N \to S$, with $\rho(i) = s_i$.
sawine@56
   451
\end{itemize}
sawine@56
   452
\end{def:automata runs}
sawine@66
   453
\visible<2->{\[w_1 = \overline{\textcolor{green}{b}ba\textcolor{green}{a}} \implies \rho_1 = q_0q_0\overline{q_0q_1q_1\textcolor{green}{q_2}}\]
sawine@66
   454
\[w_2 = bb\overline{\textcolor{green}{ab}} \implies \rho_2 = q_0q_0\overline{q_1\textcolor{green}{q_2}}\]}
sawine@56
   455
\end{frame}
sawine@56
   456
sawine@56
   457
\begin{frame}
sawine@56
   458
\frametitle{Automata}
sawine@56
   459
\framesubtitle{Acceptance}
sawine@56
   460
\begin{def:inf}
sawine@56
   461
Let $\A = (\Sigma, S, S_0, \Delta, F)$ be an automaton and let $\rho$ be a run of $\A$:
sawine@56
   462
\begin{itemize}
sawine@59
   463
\item $\exists^\omega$ denotes the existential quantifier for \emph{infinitely} many occurrences.
sawine@57
   464
\item $inf(\rho) = \{s \in S \mid \exists^\omega{n \in \N}: \rho(n) = s\}$.
sawine@56
   465
\end{itemize}
sawine@56
   466
\end{def:inf}
sawine@56
   467
sawine@56
   468
\begin{def:automata acceptance}
sawine@56
   469
Let $\A = (\Sigma, S, S_0, \Delta, F)$ be an automaton and let $\rho$ be a run of $\A$:
sawine@56
   470
\begin{itemize}
sawine@56
   471
\item $\rho$ is \emph{accepting} iff $inf(\rho) \cap F \neq \emptyset$.
sawine@59
   472
\item $\A$ \emph{accepts} an input word $w$ iff there exists a run $\rho$ of $\A$ on $w$, such that $\rho$ is accepting. 
sawine@56
   473
\end{itemize}
sawine@56
   474
\end{def:automata acceptance}
sawine@56
   475
\end{frame}
sawine@56
   476
sawine@56
   477
\begin{frame}
sawine@56
   478
\frametitle{Automata}
sawine@56
   479
\framesubtitle{Language}
sawine@56
   480
\begin{def:automata language}
sawine@56
   481
Let $\A = (\Sigma, S, S_0, \Delta, F)$ be an automaton:
sawine@56
   482
\begin{itemize}
sawine@57
   483
\item $L_\omega(\A) = \{w \in \Sigma^\omega \mid \A \text{ accepts } w\}$, we say $\A$ recognises language $L_\omega(\A)$.
sawine@57
   484
\item Language $L$ is \emph{B\"uchi-recognisable} iff there is an automaton $\A$ with $L = L_\omega(\A)$.
sawine@56
   485
\end{itemize}
sawine@56
   486
\end{def:automata language}
sawine@56
   487
\end{frame}
sawine@56
   488
sawine@56
   489
\begin{frame}
sawine@57
   490
\frametitle{Generalised Automata}
sawine@57
   491
\begin{def:general automata}
sawine@65
   492
A \emph{generalised B\"uchi automaton} is a tuple $\A_G = (\Sigma, S, S_0, \Delta, \{F_i\}_{i<k})$:
sawine@57
   493
\begin{itemize}
sawine@57
   494
\item $\{F_i\}$ is a finite set of sets for a given $k$.
sawine@57
   495
\item Each $F_i \subseteq S$ is a finite set of accepting states.
sawine@57
   496
\end{itemize}
sawine@57
   497
\end{def:general automata}
sawine@57
   498
sawine@57
   499
\begin{def:general acceptance}
sawine@65
   500
Let $\A_G = (\Sigma, S, S_0, \Delta, \{F_i\}_{i<k})$ be a generalised automaton and let $\rho$ be a run of $\A_G$:
sawine@57
   501
\begin{itemize}
sawine@57
   502
\item $\rho$ is \emph{accepting} iff $\forall{i < k}: inf(\rho) \cap F_i \neq \emptyset$.
sawine@65
   503
\item $\A_G$ \emph{accepts} an input word $w$ iff there exists a run $\rho$ of $\A_G$ on $w$, such that $\rho$ is accepting. 
sawine@57
   504
\end{itemize} 
sawine@57
   505
\end{def:general acceptance}
sawine@57
   506
sawine@57
   507
\begin{prop:general equiv}
sawine@65
   508
Let $\A_G = (\Sigma, S, S_0, \Delta, \{F_i\}_{i < k})$ be a generalised automaton and let $\A_i = (\Sigma, S, S_0, \Delta, F_i)$ be non-deterministic automata:
sawine@65
   509
\[L_\omega(\A_G) = \bigcap_{i < k} L_\omega(\A_i)\]
sawine@57
   510
\end{prop:general equiv}
sawine@57
   511
\end{frame}
sawine@57
   512
sawine@65
   513
\begin{frame}
sawine@68
   514
\frametitle{Automata Construction}
sawine@68
   515
\framesubtitle{Formula automata}
sawine@68
   516
\begin{center}
sawine@68
   517
Model $\M_\varphi$ for formula $\varphi$\\
sawine@68
   518
$\Downarrow$\\
sawine@68
   519
Closure $CL(\varphi)$ of $\varphi$\\
sawine@68
   520
$\Downarrow$\\
sawine@68
   521
Automaton $\A_\varphi$ for $\varphi$\\
sawine@68
   522
\vspace{20pt}
sawine@68
   523
\textcolor{red}{On-the-fly methods} \`a la Gerth et al.
sawine@68
   524
\end{center}
sawine@68
   525
\end{frame}
sawine@68
   526
sawine@68
   527
\begin{frame}
sawine@68
   528
\frametitle{Automata Construction}
sawine@68
   529
\framesubtitle{System automata}
sawine@68
   530
\begin{center}
sawine@68
   531
Model $\M_\varphi$ for formula $\varphi$\\
sawine@68
   532
$\Downarrow$\\
sawine@68
   533
Closure $CL(\varphi)$ of $\varphi$\\
sawine@68
   534
$\Downarrow$\\
sawine@68
   535
Automaton $\A_\varphi$ for $\varphi$
sawine@68
   536
\end{center}
sawine@68
   537
\end{frame}
sawine@68
   538
sawine@68
   539
\begin{frame}
sawine@55
   540
\frametitle{Model Checking}
sawine@67
   541
\framesubtitle{Definition}
sawine@66
   542
\begin{thm:model checking}
sawine@66
   543
\label{thm:model checking}
sawine@66
   544
Let $\A_P$ be the automaton for program $P$ and let $\A_\varphi$ be the automaton for formula $\varphi$.\\
sawine@66
   545
P satisfies $\varphi$ iff:
sawine@66
   546
\begin{itemize}
sawine@66
   547
\item $L_\omega(\A_P) \subseteq L_\omega(\A_\varphi)$.
sawine@66
   548
\item $L_\omega(\A_P) \cap L_\omega(\A_{\neg \varphi}) = \emptyset$.
sawine@66
   549
\end{itemize}
sawine@66
   550
\end{thm:model checking}
sawine@55
   551
\end{frame}
sawine@55
   552
sawine@55
   553
\begin{frame}[allowframebreaks]
sawine@55
   554
\frametitle<presentation>{Literature}    
sawine@55
   555
\begin{thebibliography}{10}    
sawine@55
   556
sawine@55
   557
\beamertemplatearticlebibitems
sawine@55
   558
\bibitem{ref:ltl&büchi}
sawine@55
   559
Madhavan Mukund.
sawine@55
   560
\newblock {\em Linear-Time Temporal Logic and B\"uchi Automata}.
sawine@55
   561
\newblock Winter School on Logic and Computer Science, Indian Statistical Institute, Calcutta, 1997.
sawine@55
   562
  
sawine@55
   563
\beamertemplatearticlebibitems
sawine@55
   564
\bibitem{ref:alternating verification}
sawine@55
   565
Moshe Y. Vardi.
sawine@55
   566
\newblock {\em Alternating Automata and Program Verification}.
sawine@55
   567
\newblock Computer Science Today, Volume 1000 of Lecture Notes in Computer Science, Springer-Verlag, Berlin, 1995.
sawine@55
   568
sawine@55
   569
\beamertemplatebookbibitems
sawine@55
   570
\bibitem{ref:handbook}
sawine@55
   571
Patrick Blackburn and Frank Wolter and Johan van Benthem.
sawine@55
   572
\newblock {\em Handbook of Modal Logic}.
sawine@55
   573
\newblock 3rd Edition, Elsevier, Amsterdam, Chapter 11 P. 655-720 and Chapter 17 P. 975-989, 2007.
sawine@55
   574
sawine@55
   575
\end{thebibliography}
sawine@55
   576
\end{frame}
sawine@55
   577
sawine@55
   578
\end{document}