proof.tex
author Christian Urban <urbanc@in.tum.de>
Fri, 05 Oct 2012 00:40:52 +0100
changeset 20 32af6d4de262
child 21 4e5092ab450a
permissions -rw-r--r--
added
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
20
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
     1
\documentclass{article}
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
     2
\usepackage{charter}
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
     3
\usepackage{hyperref}
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
     4
\usepackage{amssymb}
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
     5
\usepackage{amsmath}
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
     6
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
     7
\newcommand{\dn}{\stackrel{\mbox{\scriptsize def}}{=}}% for definitions
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
     8
\begin{document}
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
     9
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    10
\section*{Proof}
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    11
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    12
Recall the definitions for regular expressions and the language associated with a regular expression:
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    13
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    14
\begin{center}
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    15
\begin{tabular}{c}
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    16
\begin{tabular}[t]{rcl}
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    17
  $r$ & $::=$  & $\varnothing$  \\
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    18
         & $\mid$ & $\epsilon$       \\
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    19
         & $\mid$ & $c$                         \\
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    20
         & $\mid$ & $r_1 \cdot r_2$ \\
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    21
         & $\mid$ & $r_1 + r_2$  \\
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    22
         & $\mid$ & $r^*$                 \\
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    23
  \end{tabular}\hspace{10mm}
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    24
\begin{tabular}[t]{r@{\hspace{1mm}}c@{\hspace{1mm}}l}
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    25
$L(\varnothing)$ & $\dn$ & $\varnothing$ \\
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    26
$L(\epsilon)$       & $\dn$ & $\{\texttt{""}\}$       \\
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    27
$L(c)$                   & $\dn$ & $\{\texttt{"}c\texttt{"}\}$                         \\
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    28
$L(r_1 \cdot r_2)$   & $\dn$ & $L(r_1) \,@\, L(r_2)$ \\
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    29
$L(r_1 + r_2)$         & $\dn$ & $L(r_1) \cup L(r_2)$  \\
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    30
 $L(r^*)$        & $\dn$ & $\bigcup_{n\ge 0} L(r)^n$                 \\
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    31
  \end{tabular}
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    32
\end{tabular}
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    33
\end{center}
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    34
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    35
\noindent
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    36
We also defined the notion of a derivative of a regular expression (the derivative with respect to a character):
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    37
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    38
\begin{center}
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    39
\begin{tabular}{lcl}
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    40
  $der\, c\, (\varnothing)$    & $\dn$ & $\varnothing$  \\
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    41
  $der\, c\, (\epsilon)$          & $\dn$ & $\varnothing$ \\
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    42
  $der\, c\, (d)$                      & $\dn$ & if $c = d$ then $\epsilon$ else $\varnothing$\\
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    43
  $der\, c\, (r_1 + r_2)$        & $\dn$ & $(der\, c\, r_1) + (der\, c\, r_2)$ \\
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    44
  $der\, c\, (r_1 \cdot r_2)$ & $\dn$  & if $nullable(r_1)$\\
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    45
       & & then $((der\, c\, r_1) \cdot r_2) + (der\, c\, r_2)$\\ 
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    46
       & & else $(der\, c\, r_1) \cdot r_2$\\
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    47
  $der\, c\, (r^*)$                   & $\dn$ & $(der\, c\, r) \cdot (r^*)$\\
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    48
  \end{tabular}
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    49
\end{center}
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    50
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    51
\noindent
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    52
With our definition of regular expressions comes an induction principle. Given a property $P$ over 
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    53
regular expressions. We can establish that $\forall r.\; P(r)$ holds, provided we can show the following:
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    54
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    55
\begin{enumerate}
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    56
\item $P(\varnothing)$, $P(\epsilon)$ and $P(c)$ all hold,
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    57
\item $P(r_1 + r_2)$ holds under the induction hypotheses that 
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    58
$P(r_1)$ and $P(r_2)$ hold,
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    59
\item $P(r_1 \cdot r_2)$ holds under the induction hypotheses that 
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    60
$P(r_1)$ and $P(r_2)$ hold, and
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    61
\item $P(r^*)$ holds under the induction hypothesis that $P(r)$ holds.
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    62
\end{enumerate}
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    63
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    64
\noindent
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    65
Let us try out an induction proof. Recall the definition
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    66
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    67
\begin{center}
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    68
$Der\, c\, A \dn \{ s\;\mid\; c\!::\!s \in A\}$
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    69
\end{center}
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    70
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    71
\noindent
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    72
whereby $A$ is a set of strings. We like to prove
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    73
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    74
\begin{center}
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    75
\begin{tabular}{l}
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    76
$P(r) \dn $ \hspace{4mm} $L(der\,c\,r) = Der\,c\,(L(r))$
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    77
\end{tabular}
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    78
\end{center}
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    79
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    80
\noindent
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    81
by induction over the regular expression $r$.
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    82
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    83
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    84
\newpage
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    85
\noindent
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    86
{\bf Proof}
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    87
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    88
\noindent
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    89
According to 1.~above we need to prove $P(\varnothing)$, $P(\epsilon)$ and $P(d)$. Lets do this in turn.
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    90
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    91
\begin{itemize}
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    92
\item First Case: $P(\varnothing)$ is $L(der\,c\,\varnothing) = Der\,c\,(L(\varnothing))$ (a). We have $der\,c\,\varnothing = \varnothing$ 
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    93
and $L(\varnothing) = \varnothing$. We also have $Der\,c\,\varnothing = \varnothing$. Hence we have $\varnothing = \varnothing$ in (a). 
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    94
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    95
\item Second  Case: $P(\epsilon)$ is $L(der\,c\,\epsilon) = Der\,c\,(L(\epsilon))$ (b). We have $der\,c\,\epsilon = \varnothing$,
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    96
$L(\varnothing) = \varnothing$ and $L(\epsilon) = \{\texttt{""}\}$. We also have $Der\,c\,\{\texttt{""}\} = \varnothing$. Hence we have 
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    97
$\varnothing = \varnothing$ in (b). 
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    98
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    99
\item Third  Case: $P(d)$ is $L(der\,c\,d) = Der\,c\,(L(d))$ (c). We need to treat the cases $d = c$ and $d \not= c$. 
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   100
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   101
$d = c$: We have $der\,c\,c = \epsilon$ and $L(\epsilon) = \{\texttt{""}\}$. 
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   102
We also have $L(c) = \{\texttt{"}c\texttt{"}\}$ and $Der\,c\,\{\texttt{"}c\texttt{"}\} = \{\texttt{""}\}$. Hence we have 
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   103
$\{\texttt{""}\} = \{\texttt{""}\}$ in (c). 
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   104
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   105
$d \not=c$: We have $der\,c\,d = \varnothing$.
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   106
We also have $Der\,c\,\{\texttt{"}d\texttt{"}\} = \varnothing$. Hence we have 
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   107
$\varnothing = \varnothing$  in (c). 
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   108
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   109
\item Fourth Case: $P(r_1 + r_2)$ is $L(der\,c\,(r_1 + r_2)) = Der\,c\,(L(r_1 + r_2))$ (d). This is what we have to show.
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   110
We can assume already:
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   111
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   112
\begin{center}
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   113
\begin{tabular}{ll}
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   114
$P(r_1)$: & $L(der\,c\,r_1) = Der\,c\,(L(r_1))$ (I)\\
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   115
$P(r_2)$: & $L(der\,c\,r_2) = Der\,c\,(L(r_2))$ (II)
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   116
\end{tabular}
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   117
\end{center}
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   118
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   119
We have that $der\,c\,(r_1 + r_2) = (der\,c\,r_1) + (der\,c\,r_2)$ and also $L((der\,c\,r_1) + (der\,c\,r_2)) = L(der\,c\,r_1) \cup L(der\,c\,r_2)$.
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   120
By (I) and (II) we know that the left-hand side is $Der\,c\,(L(r_1)) \cup Der\,c\,(L(r_2))$.  You need to ponder a bit, but you should see
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   121
that 
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   122
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   123
\begin{center}
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   124
$Der\,c(A \cup B) = (Der\,c\,A) \cup (Der\,c\,B)$
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   125
\end{center}
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   126
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   127
holds for every set of strings $A$ and $B$. That means the right-hand side of (d) is also $Der\,c\,(L(r_1)) \cup Der\,c\,(L(r_2))$,
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   128
because $L(r_1 + r_2) = L(r_1) \cup L(r_2)$. And we are done with the fourth case.
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   129
 
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   130
\item Fifth Case:
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   131
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   132
\item Sixth Case:
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   133
\end{itemize}
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   134
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   135
\end{document}
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   136
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   137
%%% Local Variables: 
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   138
%%% mode: latex
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   139
%%% TeX-master: t
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   140
%%% End: