author | Chengsong |
Wed, 23 Aug 2023 03:02:31 +0100 | |
changeset 668 | 3831621d7b14 |
parent 663 | 0d1e68268d0f |
permissions | -rwxr-xr-x |
532 | 1 |
% Chapter Template |
2 |
||
668
3831621d7b14
added technical Overview section, almost done introduction
Chengsong
parents:
663
diff
changeset
|
3 |
\chapter{A Formal Proof That $\textit{Blexer}\_\textit{simp}$ will not Grow Unbounded} % Main chapter title |
532 | 4 |
|
5 |
\label{Finite} |
|
6 |
% In Chapter 4 \ref{Chapter4} we give the second guarantee |
|
7 |
%of our bitcoded algorithm, that is a finite bound on the size of any |
|
8 |
%regex's derivatives. |
|
660
eddc4eaba7c4
addresses Gerog "N_r meaning and relation with backtracking?" comment
Chengsong
parents:
659
diff
changeset
|
9 |
%(this is cahpter 5 now) |
618 | 10 |
|
668
3831621d7b14
added technical Overview section, almost done introduction
Chengsong
parents:
663
diff
changeset
|
11 |
In this chapter we prove a bound in terms of the size of |
624 | 12 |
the calculated derivatives: |
668
3831621d7b14
added technical Overview section, almost done introduction
Chengsong
parents:
663
diff
changeset
|
13 |
given an annotated regular expression $a$, there exists |
3831621d7b14
added technical Overview section, almost done introduction
Chengsong
parents:
663
diff
changeset
|
14 |
a constant integer $N$, such that for any string $s$ |
624 | 15 |
our algorithm $\blexersimp$'s derivatives |
668
3831621d7b14
added technical Overview section, almost done introduction
Chengsong
parents:
663
diff
changeset
|
16 |
are bounded |
3831621d7b14
added technical Overview section, almost done introduction
Chengsong
parents:
663
diff
changeset
|
17 |
by $N$. %a constant that only depends on $a$. |
3831621d7b14
added technical Overview section, almost done introduction
Chengsong
parents:
663
diff
changeset
|
18 |
Formally this can be expresssed |
3831621d7b14
added technical Overview section, almost done introduction
Chengsong
parents:
663
diff
changeset
|
19 |
as |
3831621d7b14
added technical Overview section, almost done introduction
Chengsong
parents:
663
diff
changeset
|
20 |
%we show that there exists a constant integer $N_a$ such that |
576 | 21 |
\begin{center} |
668
3831621d7b14
added technical Overview section, almost done introduction
Chengsong
parents:
663
diff
changeset
|
22 |
$\llbracket \bderssimp{a}{s} \rrbracket \leq N$ |
576 | 23 |
\end{center} |
24 |
\noindent |
|
618 | 25 |
where the size ($\llbracket \_ \rrbracket$) of |
26 |
an annotated regular expression is defined |
|
27 |
in terms of the number of nodes in its |
|
640
bd1354127574
more proofreading done, last version before submission
Chengsong
parents:
639
diff
changeset
|
28 |
tree structure (its recursive definition is given in the next page). |
613 | 29 |
We believe this size bound |
640
bd1354127574
more proofreading done, last version before submission
Chengsong
parents:
639
diff
changeset
|
30 |
is important in the context of POSIX lexing because |
660
eddc4eaba7c4
addresses Gerog "N_r meaning and relation with backtracking?" comment
Chengsong
parents:
659
diff
changeset
|
31 |
\marginpar{Addressing Gerog comment: "how does this relate to backtracking?"} |
590 | 32 |
\begin{itemize} |
33 |
\item |
|
618 | 34 |
It is a stepping stone towards the goal |
35 |
of eliminating ``catastrophic backtracking''. |
|
660
eddc4eaba7c4
addresses Gerog "N_r meaning and relation with backtracking?" comment
Chengsong
parents:
659
diff
changeset
|
36 |
The derivative-based lexing algorithm avoids backtracking |
eddc4eaba7c4
addresses Gerog "N_r meaning and relation with backtracking?" comment
Chengsong
parents:
659
diff
changeset
|
37 |
by a trade-off between space and time. |
eddc4eaba7c4
addresses Gerog "N_r meaning and relation with backtracking?" comment
Chengsong
parents:
659
diff
changeset
|
38 |
Backtracking algorithms |
eddc4eaba7c4
addresses Gerog "N_r meaning and relation with backtracking?" comment
Chengsong
parents:
659
diff
changeset
|
39 |
save other possibilities on a stack when exploring one possible |
eddc4eaba7c4
addresses Gerog "N_r meaning and relation with backtracking?" comment
Chengsong
parents:
659
diff
changeset
|
40 |
path of matching. Catastrophic backtracking typically occurs |
eddc4eaba7c4
addresses Gerog "N_r meaning and relation with backtracking?" comment
Chengsong
parents:
659
diff
changeset
|
41 |
when the number of steps increase exponentially with respect |
668
3831621d7b14
added technical Overview section, almost done introduction
Chengsong
parents:
663
diff
changeset
|
42 |
to input. In other words, the complexity is $O((c_r)^n)$ of the input |
660
eddc4eaba7c4
addresses Gerog "N_r meaning and relation with backtracking?" comment
Chengsong
parents:
659
diff
changeset
|
43 |
string length $n$, where the base of the exponent is determined by the |
eddc4eaba7c4
addresses Gerog "N_r meaning and relation with backtracking?" comment
Chengsong
parents:
659
diff
changeset
|
44 |
regular expression $r$. |
eddc4eaba7c4
addresses Gerog "N_r meaning and relation with backtracking?" comment
Chengsong
parents:
659
diff
changeset
|
45 |
%so that they |
eddc4eaba7c4
addresses Gerog "N_r meaning and relation with backtracking?" comment
Chengsong
parents:
659
diff
changeset
|
46 |
%can be traversed in the future in a DFS manner, |
eddc4eaba7c4
addresses Gerog "N_r meaning and relation with backtracking?" comment
Chengsong
parents:
659
diff
changeset
|
47 |
%different matchings are stored as sub-expressions |
eddc4eaba7c4
addresses Gerog "N_r meaning and relation with backtracking?" comment
Chengsong
parents:
659
diff
changeset
|
48 |
%in a regular expression derivative. |
eddc4eaba7c4
addresses Gerog "N_r meaning and relation with backtracking?" comment
Chengsong
parents:
659
diff
changeset
|
49 |
Derivatives saves these possibilities as sub-expressions |
eddc4eaba7c4
addresses Gerog "N_r meaning and relation with backtracking?" comment
Chengsong
parents:
659
diff
changeset
|
50 |
and traverse those during future derivatives. If we denote the size |
eddc4eaba7c4
addresses Gerog "N_r meaning and relation with backtracking?" comment
Chengsong
parents:
659
diff
changeset
|
51 |
of intermediate derivatives as $S_{r,n}$ (where the subscripts |
eddc4eaba7c4
addresses Gerog "N_r meaning and relation with backtracking?" comment
Chengsong
parents:
659
diff
changeset
|
52 |
$r,n$ indicate that $S$ depends on them), then the runtime of |
eddc4eaba7c4
addresses Gerog "N_r meaning and relation with backtracking?" comment
Chengsong
parents:
659
diff
changeset
|
53 |
derivative-based approaches would be $O(S_{r,n} * n)$. |
eddc4eaba7c4
addresses Gerog "N_r meaning and relation with backtracking?" comment
Chengsong
parents:
659
diff
changeset
|
54 |
We observe that if $S_{r,n}$ continously grows with $n$ (for example |
eddc4eaba7c4
addresses Gerog "N_r meaning and relation with backtracking?" comment
Chengsong
parents:
659
diff
changeset
|
55 |
growing exponentially fast), then this |
eddc4eaba7c4
addresses Gerog "N_r meaning and relation with backtracking?" comment
Chengsong
parents:
659
diff
changeset
|
56 |
is equally bad as catastrophic backtracking. |
661
71502e4d8691
overview of finiteness proof Gerog comment "not helpful", adding more intuitions of "closed forms"
Chengsong
parents:
660
diff
changeset
|
57 |
Our finiteness bound seeks to find a constant integer |
71502e4d8691
overview of finiteness proof Gerog comment "not helpful", adding more intuitions of "closed forms"
Chengsong
parents:
660
diff
changeset
|
58 |
upper bound $C$ (which in our case is $N_a$ where $a = r^\uparrow$) of $\S_{r,n}$, |
660
eddc4eaba7c4
addresses Gerog "N_r meaning and relation with backtracking?" comment
Chengsong
parents:
659
diff
changeset
|
59 |
so that the complexity of the algorithm can be seen as linear ($O(C * n)$). |
eddc4eaba7c4
addresses Gerog "N_r meaning and relation with backtracking?" comment
Chengsong
parents:
659
diff
changeset
|
60 |
Even if $C$ is still large in our current work, it is still a constant |
eddc4eaba7c4
addresses Gerog "N_r meaning and relation with backtracking?" comment
Chengsong
parents:
659
diff
changeset
|
61 |
rather than ever-increasing number with respect to input length $n$. |
eddc4eaba7c4
addresses Gerog "N_r meaning and relation with backtracking?" comment
Chengsong
parents:
659
diff
changeset
|
62 |
More importantly this $C$ constant can potentially |
eddc4eaba7c4
addresses Gerog "N_r meaning and relation with backtracking?" comment
Chengsong
parents:
659
diff
changeset
|
63 |
be shrunken as we optimize our simplification procedure. |
eddc4eaba7c4
addresses Gerog "N_r meaning and relation with backtracking?" comment
Chengsong
parents:
659
diff
changeset
|
64 |
%and showing the potential |
eddc4eaba7c4
addresses Gerog "N_r meaning and relation with backtracking?" comment
Chengsong
parents:
659
diff
changeset
|
65 |
%improvements can be by the notion of partial derivatives. |
eddc4eaba7c4
addresses Gerog "N_r meaning and relation with backtracking?" comment
Chengsong
parents:
659
diff
changeset
|
66 |
|
eddc4eaba7c4
addresses Gerog "N_r meaning and relation with backtracking?" comment
Chengsong
parents:
659
diff
changeset
|
67 |
%If the internal data structures used by our algorithm |
eddc4eaba7c4
addresses Gerog "N_r meaning and relation with backtracking?" comment
Chengsong
parents:
659
diff
changeset
|
68 |
%grows beyond a finite bound, then clearly |
eddc4eaba7c4
addresses Gerog "N_r meaning and relation with backtracking?" comment
Chengsong
parents:
659
diff
changeset
|
69 |
%the algorithm (which traverses these structures) will |
eddc4eaba7c4
addresses Gerog "N_r meaning and relation with backtracking?" comment
Chengsong
parents:
659
diff
changeset
|
70 |
%be slow. |
eddc4eaba7c4
addresses Gerog "N_r meaning and relation with backtracking?" comment
Chengsong
parents:
659
diff
changeset
|
71 |
%The next step is to refine the bound $N_a$ so that it |
eddc4eaba7c4
addresses Gerog "N_r meaning and relation with backtracking?" comment
Chengsong
parents:
659
diff
changeset
|
72 |
%is not just finite but polynomial in $\llbracket a\rrbracket$. |
590 | 73 |
\item |
618 | 74 |
Having the finite bound formalised |
640
bd1354127574
more proofreading done, last version before submission
Chengsong
parents:
639
diff
changeset
|
75 |
gives us higher confidence that |
bd1354127574
more proofreading done, last version before submission
Chengsong
parents:
639
diff
changeset
|
76 |
our simplification algorithm $\simp$ does not ``misbehave'' |
639 | 77 |
like $\textit{simpSL}$ does. |
618 | 78 |
The bound is universal for a given regular expression, |
79 |
which is an advantage over work which |
|
624 | 80 |
only gives empirical evidence on |
639 | 81 |
some test cases (see for example Verbatim work \cite{Verbatimpp}). |
590 | 82 |
\end{itemize} |
625 | 83 |
\noindent |
84 |
We then extend our $\blexersimp$ |
|
85 |
to support bounded repetitions ($r^{\{n\}}$). |
|
86 |
We update our formalisation of |
|
87 |
the correctness and finiteness properties to |
|
88 |
include this new construct. |
|
639 | 89 |
We show that we can out-compete other verified lexers such as |
625 | 90 |
Verbatim++ on bounded regular expressions. |
91 |
||
618 | 92 |
In the next section we describe in more detail |
93 |
what the finite bound means in our algorithm |
|
94 |
and why the size of the internal data structures of |
|
95 |
a typical derivative-based lexer such as |
|
639 | 96 |
Sulzmann and Lu's needs formal treatment. |
618 | 97 |
|
625 | 98 |
|
99 |
||
100 |
||
639 | 101 |
\section{Formalising Size Bound of Derivatives} |
577 | 102 |
\noindent |
613 | 103 |
In our lexer ($\blexersimp$), |
104 |
we take an annotated regular expression as input, |
|
618 | 105 |
and repeately take derivative of and simplify it. |
106 |
\begin{figure} |
|
107 |
\begin{center} |
|
108 |
\begin{tabular}{lcl} |
|
109 |
$\llbracket _{bs}\ONE \rrbracket$ & $\dn$ & $1$\\ |
|
110 |
$\llbracket \ZERO \rrbracket$ & $\dn$ & $1$ \\ |
|
111 |
$\llbracket _{bs} r_1 \cdot r_2 \rrbracket$ & $\dn$ & $\llbracket r_1 \rrbracket + \llbracket r_2 \rrbracket + 1$\\ |
|
112 |
$\llbracket _{bs}\mathbf{c} \rrbracket $ & $\dn$ & $1$\\ |
|
668
3831621d7b14
added technical Overview section, almost done introduction
Chengsong
parents:
663
diff
changeset
|
113 |
$\llbracket _{bs}\sum as \rrbracket $ & $\dn$ & $(\textit{sum}\; (\map \; (\llbracket \_ \rrbracket)\; as) ) + 1$\\ |
618 | 114 |
$\llbracket _{bs} a^* \rrbracket $ & $\dn$ & $\llbracket a \rrbracket + 1$. |
115 |
\end{tabular} |
|
116 |
\end{center} |
|
117 |
\caption{The size function of bitcoded regular expressions}\label{brexpSize} |
|
118 |
\end{figure} |
|
119 |
||
120 |
\begin{figure} |
|
593 | 121 |
\begin{tikzpicture}[scale=2, |
122 |
every node/.style={minimum size=11mm}, |
|
123 |
->,>=stealth',shorten >=1pt,auto,thick |
|
124 |
] |
|
125 |
\node (r0) [rectangle, draw=black, thick, minimum size = 5mm, draw=blue] {$a$}; |
|
126 |
\node (r1) [rectangle, draw=black, thick, right=of r0, minimum size = 7mm]{$a_1$}; |
|
127 |
\draw[->,line width=0.2mm](r0)--(r1) node[above,midway] {$\backslash c_1$}; |
|
590 | 128 |
|
593 | 129 |
\node (r1s) [rectangle, draw=blue, thick, right=of r1, minimum size=6mm]{$a_{1s}$}; |
130 |
\draw[->, line width=0.2mm](r1)--(r1s) node[above, midway] {$\simp$}; |
|
590 | 131 |
|
593 | 132 |
\node (r2) [rectangle, draw=black, thick, right=of r1s, minimum size = 12mm]{$a_2$}; |
133 |
\draw[->,line width=0.2mm](r1s)--(r2) node[above,midway] {$\backslash c_2$}; |
|
590 | 134 |
|
593 | 135 |
\node (r2s) [rectangle, draw = blue, thick, right=of r2,minimum size=6mm]{$a_{2s}$}; |
136 |
\draw[->,line width=0.2mm](r2)--(r2s) node[above,midway] {$\simp$}; |
|
590 | 137 |
|
593 | 138 |
\node (rns) [rectangle, draw = blue, thick, right=of r2s,minimum size=6mm]{$a_{ns}$}; |
139 |
\draw[->,line width=0.2mm, dashed](r2s)--(rns) node[above,midway] {$\backslash \ldots$}; |
|
590 | 140 |
|
593 | 141 |
\node (v) [circle, thick, draw, right=of rns, minimum size=6mm, right=1.7cm]{$v$}; |
142 |
\draw[->, line width=0.2mm](rns)--(v) node[above, midway] {\bmkeps} node [below, midway] {\decode}; |
|
143 |
\end{tikzpicture} |
|
144 |
\caption{Regular expression size change during our $\blexersimp$ algorithm}\label{simpShrinks} |
|
590 | 145 |
\end{figure} |
618 | 146 |
|
576 | 147 |
\noindent |
590 | 148 |
Each time |
613 | 149 |
a derivative is taken, the regular expression might grow. |
639 | 150 |
However, the simplification that is immediately afterwards will often shrink it so that |
151 |
the overall size of the derivatives stays relatively small. |
|
577 | 152 |
This intuition is depicted by the relative size |
590 | 153 |
change between the black and blue nodes: |
639 | 154 |
After $\simp$ the node shrinks. |
618 | 155 |
Our proof states that all the blue nodes |
613 | 156 |
stay below a size bound $N_a$ determined by the input $a$. |
576 | 157 |
|
640
bd1354127574
more proofreading done, last version before submission
Chengsong
parents:
639
diff
changeset
|
158 |
Sulzmann and Lu's assumed a similar picture of their algorithm, |
668
3831621d7b14
added technical Overview section, almost done introduction
Chengsong
parents:
663
diff
changeset
|
159 |
even though it did not work as they expected. |
3831621d7b14
added technical Overview section, almost done introduction
Chengsong
parents:
663
diff
changeset
|
160 |
%though in fact their algorithm's size might be better depicted by the following graph: |
3831621d7b14
added technical Overview section, almost done introduction
Chengsong
parents:
663
diff
changeset
|
161 |
%\begin{figure}[H] |
3831621d7b14
added technical Overview section, almost done introduction
Chengsong
parents:
663
diff
changeset
|
162 |
% \begin{tikzpicture}[scale=2, |
3831621d7b14
added technical Overview section, almost done introduction
Chengsong
parents:
663
diff
changeset
|
163 |
% every node/.style={minimum size=11mm}, |
3831621d7b14
added technical Overview section, almost done introduction
Chengsong
parents:
663
diff
changeset
|
164 |
% ->,>=stealth',shorten >=1pt,auto,thick |
3831621d7b14
added technical Overview section, almost done introduction
Chengsong
parents:
663
diff
changeset
|
165 |
% ] |
3831621d7b14
added technical Overview section, almost done introduction
Chengsong
parents:
663
diff
changeset
|
166 |
% \node (r0) [rectangle, draw=black, thick, minimum size = 5mm, draw=blue] {$a$}; |
3831621d7b14
added technical Overview section, almost done introduction
Chengsong
parents:
663
diff
changeset
|
167 |
% \node (r1) [rectangle, draw=black, thick, right=of r0, minimum size = 7mm]{$a_1$}; |
3831621d7b14
added technical Overview section, almost done introduction
Chengsong
parents:
663
diff
changeset
|
168 |
% \draw[->,line width=0.2mm](r0)--(r1) node[above,midway] {$\backslash c_1$}; |
3831621d7b14
added technical Overview section, almost done introduction
Chengsong
parents:
663
diff
changeset
|
169 |
% |
3831621d7b14
added technical Overview section, almost done introduction
Chengsong
parents:
663
diff
changeset
|
170 |
% \node (r1s) [rectangle, draw=blue, thick, right=of r1, minimum size=7mm]{$a_{1s}$}; |
3831621d7b14
added technical Overview section, almost done introduction
Chengsong
parents:
663
diff
changeset
|
171 |
% \draw[->, line width=0.2mm](r1)--(r1s) node[above, midway] {$\simp'$}; |
3831621d7b14
added technical Overview section, almost done introduction
Chengsong
parents:
663
diff
changeset
|
172 |
% |
3831621d7b14
added technical Overview section, almost done introduction
Chengsong
parents:
663
diff
changeset
|
173 |
% \node (r2) [rectangle, draw=black, thick, right=of r1s, minimum size = 17mm]{$a_2$}; |
3831621d7b14
added technical Overview section, almost done introduction
Chengsong
parents:
663
diff
changeset
|
174 |
% \draw[->,line width=0.2mm](r1s)--(r2) node[above,midway] {$\backslash c_2$}; |
3831621d7b14
added technical Overview section, almost done introduction
Chengsong
parents:
663
diff
changeset
|
175 |
% |
3831621d7b14
added technical Overview section, almost done introduction
Chengsong
parents:
663
diff
changeset
|
176 |
% \node (r2s) [rectangle, draw = blue, thick, right=of r2,minimum size=14mm]{$a_{2s}$}; |
3831621d7b14
added technical Overview section, almost done introduction
Chengsong
parents:
663
diff
changeset
|
177 |
% \draw[->,line width=0.2mm](r2)--(r2s) node[above,midway] {$\simp'$}; |
3831621d7b14
added technical Overview section, almost done introduction
Chengsong
parents:
663
diff
changeset
|
178 |
% |
3831621d7b14
added technical Overview section, almost done introduction
Chengsong
parents:
663
diff
changeset
|
179 |
% \node (r3) [rectangle, draw = black, thick, right= of r2s, minimum size = 22mm]{$a_3$}; |
3831621d7b14
added technical Overview section, almost done introduction
Chengsong
parents:
663
diff
changeset
|
180 |
% \draw[->,line width=0.2mm](r2s)--(r3) node[above,midway] {$\backslash c_3$}; |
3831621d7b14
added technical Overview section, almost done introduction
Chengsong
parents:
663
diff
changeset
|
181 |
% |
3831621d7b14
added technical Overview section, almost done introduction
Chengsong
parents:
663
diff
changeset
|
182 |
% \node (rns) [right = of r3, draw=blue, minimum size = 20mm]{$a_{3s}$}; |
3831621d7b14
added technical Overview section, almost done introduction
Chengsong
parents:
663
diff
changeset
|
183 |
% \draw[->,line width=0.2mm] (r3)--(rns) node [above, midway] {$\simp'$}; |
3831621d7b14
added technical Overview section, almost done introduction
Chengsong
parents:
663
diff
changeset
|
184 |
% |
3831621d7b14
added technical Overview section, almost done introduction
Chengsong
parents:
663
diff
changeset
|
185 |
% \node (rnn) [right = of rns, minimum size = 1mm]{}; |
3831621d7b14
added technical Overview section, almost done introduction
Chengsong
parents:
663
diff
changeset
|
186 |
% \draw[->, dashed] (rns)--(rnn) node [above, midway] {$\ldots$}; |
3831621d7b14
added technical Overview section, almost done introduction
Chengsong
parents:
663
diff
changeset
|
187 |
% |
3831621d7b14
added technical Overview section, almost done introduction
Chengsong
parents:
663
diff
changeset
|
188 |
% \end{tikzpicture} |
3831621d7b14
added technical Overview section, almost done introduction
Chengsong
parents:
663
diff
changeset
|
189 |
% \caption{Regular expression size change during our $\blexersimp$ algorithm}\label{sulzShrinks} |
3831621d7b14
added technical Overview section, almost done introduction
Chengsong
parents:
663
diff
changeset
|
190 |
%\end{figure} |
3831621d7b14
added technical Overview section, almost done introduction
Chengsong
parents:
663
diff
changeset
|
191 |
%\noindent |
639 | 192 |
The picture means that in some cases their lexer (where they use $\simpsulz$ |
613 | 193 |
as the simplification function) |
618 | 194 |
will have a size explosion, causing the running time |
613 | 195 |
of each derivative step to grow continuously (for example |
590 | 196 |
in \ref{SulzmannLuLexerTime}). |
613 | 197 |
They tested out the run time of their |
590 | 198 |
lexer on particular examples such as $(a+b+ab)^*$ |
613 | 199 |
and claimed that their algorithm is linear w.r.t to the input. |
640
bd1354127574
more proofreading done, last version before submission
Chengsong
parents:
639
diff
changeset
|
200 |
With our mechanised proof, we avoid this type of unintentional |
639 | 201 |
generalisation. |
613 | 202 |
|
640
bd1354127574
more proofreading done, last version before submission
Chengsong
parents:
639
diff
changeset
|
203 |
Before delving into the details of the formalisation, |
bd1354127574
more proofreading done, last version before submission
Chengsong
parents:
639
diff
changeset
|
204 |
we are going to provide an overview of it in the following subsection. |
613 | 205 |
|
590 | 206 |
|
577 | 207 |
\subsection{Overview of the Proof} |
661
71502e4d8691
overview of finiteness proof Gerog comment "not helpful", adding more intuitions of "closed forms"
Chengsong
parents:
660
diff
changeset
|
208 |
\marginpar{trying to make it more intuitive |
71502e4d8691
overview of finiteness proof Gerog comment "not helpful", adding more intuitions of "closed forms"
Chengsong
parents:
660
diff
changeset
|
209 |
and provide more insights into proof} |
663
0d1e68268d0f
more explanation for the name "closed form" and their intuition
Chengsong
parents:
662
diff
changeset
|
210 |
The most important idea in this chapter %intuition |
0d1e68268d0f
more explanation for the name "closed form" and their intuition
Chengsong
parents:
662
diff
changeset
|
211 |
is what we call the "closed forms" of |
661
71502e4d8691
overview of finiteness proof Gerog comment "not helpful", adding more intuitions of "closed forms"
Chengsong
parents:
660
diff
changeset
|
212 |
regular expression derivatives with respect to strings. |
663
0d1e68268d0f
more explanation for the name "closed form" and their intuition
Chengsong
parents:
662
diff
changeset
|
213 |
In short it allows us to express $r \backslash_{rsimps} s$ |
0d1e68268d0f
more explanation for the name "closed form" and their intuition
Chengsong
parents:
662
diff
changeset
|
214 |
as a different recursive function so induction on the size bound can go through. |
0d1e68268d0f
more explanation for the name "closed form" and their intuition
Chengsong
parents:
662
diff
changeset
|
215 |
A simple induction on $s$ or $r$ fails for $r\backslash_{rsimps} s$, but |
0d1e68268d0f
more explanation for the name "closed form" and their intuition
Chengsong
parents:
662
diff
changeset
|
216 |
works for $\textit{ClosedForm}(r,s)$. |
0d1e68268d0f
more explanation for the name "closed form" and their intuition
Chengsong
parents:
662
diff
changeset
|
217 |
|
0d1e68268d0f
more explanation for the name "closed form" and their intuition
Chengsong
parents:
662
diff
changeset
|
218 |
|
0d1e68268d0f
more explanation for the name "closed form" and their intuition
Chengsong
parents:
662
diff
changeset
|
219 |
|
661
71502e4d8691
overview of finiteness proof Gerog comment "not helpful", adding more intuitions of "closed forms"
Chengsong
parents:
660
diff
changeset
|
220 |
Assume we have a regular expression $r$, be it an alternative, |
71502e4d8691
overview of finiteness proof Gerog comment "not helpful", adding more intuitions of "closed forms"
Chengsong
parents:
660
diff
changeset
|
221 |
a sequence or a star, the idea is if we try to take several derivatives |
71502e4d8691
overview of finiteness proof Gerog comment "not helpful", adding more intuitions of "closed forms"
Chengsong
parents:
660
diff
changeset
|
222 |
of it on paper, we end up getting a list of subexpressions, |
71502e4d8691
overview of finiteness proof Gerog comment "not helpful", adding more intuitions of "closed forms"
Chengsong
parents:
660
diff
changeset
|
223 |
something like |
71502e4d8691
overview of finiteness proof Gerog comment "not helpful", adding more intuitions of "closed forms"
Chengsong
parents:
660
diff
changeset
|
224 |
%omitting certain |
71502e4d8691
overview of finiteness proof Gerog comment "not helpful", adding more intuitions of "closed forms"
Chengsong
parents:
660
diff
changeset
|
225 |
%nested structures of those expressions: |
71502e4d8691
overview of finiteness proof Gerog comment "not helpful", adding more intuitions of "closed forms"
Chengsong
parents:
660
diff
changeset
|
226 |
\[ |
71502e4d8691
overview of finiteness proof Gerog comment "not helpful", adding more intuitions of "closed forms"
Chengsong
parents:
660
diff
changeset
|
227 |
r\backslash s = r_1 + r_2 + r_3 + \ldots + r_n, |
71502e4d8691
overview of finiteness proof Gerog comment "not helpful", adding more intuitions of "closed forms"
Chengsong
parents:
660
diff
changeset
|
228 |
\] |
71502e4d8691
overview of finiteness proof Gerog comment "not helpful", adding more intuitions of "closed forms"
Chengsong
parents:
660
diff
changeset
|
229 |
if we omit the way these regular expressions need to be nested. |
71502e4d8691
overview of finiteness proof Gerog comment "not helpful", adding more intuitions of "closed forms"
Chengsong
parents:
660
diff
changeset
|
230 |
where each $r_i$ ($i \in \{1, \ldots, n\}$) is related to some fragments |
71502e4d8691
overview of finiteness proof Gerog comment "not helpful", adding more intuitions of "closed forms"
Chengsong
parents:
660
diff
changeset
|
231 |
of $r$ and $s$. |
71502e4d8691
overview of finiteness proof Gerog comment "not helpful", adding more intuitions of "closed forms"
Chengsong
parents:
660
diff
changeset
|
232 |
The second important observation is that the list %of regular expressions |
71502e4d8691
overview of finiteness proof Gerog comment "not helpful", adding more intuitions of "closed forms"
Chengsong
parents:
660
diff
changeset
|
233 |
$[r_1, \ldots, r_n]$ %is not |
71502e4d8691
overview of finiteness proof Gerog comment "not helpful", adding more intuitions of "closed forms"
Chengsong
parents:
660
diff
changeset
|
234 |
cannot grow indefinitely because they all come from $r$, and derivatives |
71502e4d8691
overview of finiteness proof Gerog comment "not helpful", adding more intuitions of "closed forms"
Chengsong
parents:
660
diff
changeset
|
235 |
of the same regular expression are finite up to some isomorphisms. |
71502e4d8691
overview of finiteness proof Gerog comment "not helpful", adding more intuitions of "closed forms"
Chengsong
parents:
660
diff
changeset
|
236 |
We prove that the simplifications of $\blexersimp$ %make use of |
71502e4d8691
overview of finiteness proof Gerog comment "not helpful", adding more intuitions of "closed forms"
Chengsong
parents:
660
diff
changeset
|
237 |
is powerful enough to counteract the effect of nested structure of alternatives |
71502e4d8691
overview of finiteness proof Gerog comment "not helpful", adding more intuitions of "closed forms"
Chengsong
parents:
660
diff
changeset
|
238 |
and eliminate duplicates |
71502e4d8691
overview of finiteness proof Gerog comment "not helpful", adding more intuitions of "closed forms"
Chengsong
parents:
660
diff
changeset
|
239 |
such that indeed the list in $a\backslash s$ does not grow unbounded. |
663
0d1e68268d0f
more explanation for the name "closed form" and their intuition
Chengsong
parents:
662
diff
changeset
|
240 |
We call the precise formalisation for the shape of |
0d1e68268d0f
more explanation for the name "closed form" and their intuition
Chengsong
parents:
662
diff
changeset
|
241 |
\[ |
0d1e68268d0f
more explanation for the name "closed form" and their intuition
Chengsong
parents:
662
diff
changeset
|
242 |
r_1 + r_2 + r_3 + \ldots + r_n |
0d1e68268d0f
more explanation for the name "closed form" and their intuition
Chengsong
parents:
662
diff
changeset
|
243 |
\] |
0d1e68268d0f
more explanation for the name "closed form" and their intuition
Chengsong
parents:
662
diff
changeset
|
244 |
"closed form". |
0d1e68268d0f
more explanation for the name "closed form" and their intuition
Chengsong
parents:
662
diff
changeset
|
245 |
The name was chosen because turning the recursive relation |
0d1e68268d0f
more explanation for the name "closed form" and their intuition
Chengsong
parents:
662
diff
changeset
|
246 |
\[ |
0d1e68268d0f
more explanation for the name "closed form" and their intuition
Chengsong
parents:
662
diff
changeset
|
247 |
a \backslash_{bsimps} (c\!::\!s) \dn (\textit{bsimp} \; (a\backslash c)) \backslash_{bsimps} s |
0d1e68268d0f
more explanation for the name "closed form" and their intuition
Chengsong
parents:
662
diff
changeset
|
248 |
\] |
0d1e68268d0f
more explanation for the name "closed form" and their intuition
Chengsong
parents:
662
diff
changeset
|
249 |
into some easier-to-estimate forms |
0d1e68268d0f
more explanation for the name "closed form" and their intuition
Chengsong
parents:
662
diff
changeset
|
250 |
like |
0d1e68268d0f
more explanation for the name "closed form" and their intuition
Chengsong
parents:
662
diff
changeset
|
251 |
\[ |
0d1e68268d0f
more explanation for the name "closed form" and their intuition
Chengsong
parents:
662
diff
changeset
|
252 |
\sum (a_1\backslash s \cdot a_2) :: (\map \; (a_2\backslash\_) \; |
0d1e68268d0f
more explanation for the name "closed form" and their intuition
Chengsong
parents:
662
diff
changeset
|
253 |
(\textit{Suffix} \; s \; a_1)) |
0d1e68268d0f
more explanation for the name "closed form" and their intuition
Chengsong
parents:
662
diff
changeset
|
254 |
%\backslash_{bsimp |
0d1e68268d0f
more explanation for the name "closed form" and their intuition
Chengsong
parents:
662
diff
changeset
|
255 |
\] |
0d1e68268d0f
more explanation for the name "closed form" and their intuition
Chengsong
parents:
662
diff
changeset
|
256 |
was reminiscent of |
0d1e68268d0f
more explanation for the name "closed form" and their intuition
Chengsong
parents:
662
diff
changeset
|
257 |
%similar to t |
0d1e68268d0f
more explanation for the name "closed form" and their intuition
Chengsong
parents:
662
diff
changeset
|
258 |
solving recurrence relations like |
0d1e68268d0f
more explanation for the name "closed form" and their intuition
Chengsong
parents:
662
diff
changeset
|
259 |
$T \; n = 2 (T \frac{1}{2} n) + n$ to obtain |
0d1e68268d0f
more explanation for the name "closed form" and their intuition
Chengsong
parents:
662
diff
changeset
|
260 |
their closed forms. |
0d1e68268d0f
more explanation for the name "closed form" and their intuition
Chengsong
parents:
662
diff
changeset
|
261 |
%$T \; n = n \ln n + (s \; n)$ ($s \; n$ is |
0d1e68268d0f
more explanation for the name "closed form" and their intuition
Chengsong
parents:
662
diff
changeset
|
262 |
%some higher-order terms). |
0d1e68268d0f
more explanation for the name "closed form" and their intuition
Chengsong
parents:
662
diff
changeset
|
263 |
%(for example we know $T$ is $\Theta (n \ln n)$). |
0d1e68268d0f
more explanation for the name "closed form" and their intuition
Chengsong
parents:
662
diff
changeset
|
264 |
Just like a closed form of a recursive definition makes estimating |
0d1e68268d0f
more explanation for the name "closed form" and their intuition
Chengsong
parents:
662
diff
changeset
|
265 |
their growth possible, the closed |
0d1e68268d0f
more explanation for the name "closed form" and their intuition
Chengsong
parents:
662
diff
changeset
|
266 |
form of $a \backslash_{bsimps} s$ |
0d1e68268d0f
more explanation for the name "closed form" and their intuition
Chengsong
parents:
662
diff
changeset
|
267 |
allows us to prove the existence of a size bound. |
0d1e68268d0f
more explanation for the name "closed form" and their intuition
Chengsong
parents:
662
diff
changeset
|
268 |
Note that \ref{eq:approx} is only an approximate |
0d1e68268d0f
more explanation for the name "closed form" and their intuition
Chengsong
parents:
662
diff
changeset
|
269 |
term to show our point. |
0d1e68268d0f
more explanation for the name "closed form" and their intuition
Chengsong
parents:
662
diff
changeset
|
270 |
The precise formalised formula (\ref{seqClosedForm}) |
0d1e68268d0f
more explanation for the name "closed form" and their intuition
Chengsong
parents:
662
diff
changeset
|
271 |
needs to wait until all $\textit{rrexp}$-related |
0d1e68268d0f
more explanation for the name "closed form" and their intuition
Chengsong
parents:
662
diff
changeset
|
272 |
definitions are given, |
0d1e68268d0f
more explanation for the name "closed form" and their intuition
Chengsong
parents:
662
diff
changeset
|
273 |
%but for now we can think of the above as "the sequence |
0d1e68268d0f
more explanation for the name "closed form" and their intuition
Chengsong
parents:
662
diff
changeset
|
274 |
%regular expression $a_1 \cdot a_2$ after derivatives and simplifications |
0d1e68268d0f
more explanation for the name "closed form" and their intuition
Chengsong
parents:
662
diff
changeset
|
275 |
%w.r.t string $s$ looks like |
0d1e68268d0f
more explanation for the name "closed form" and their intuition
Chengsong
parents:
662
diff
changeset
|
276 |
%an alternative of giant list of sub-expressions, where each |
0d1e68268d0f
more explanation for the name "closed form" and their intuition
Chengsong
parents:
662
diff
changeset
|
277 |
|
0d1e68268d0f
more explanation for the name "closed form" and their intuition
Chengsong
parents:
662
diff
changeset
|
278 |
|
661
71502e4d8691
overview of finiteness proof Gerog comment "not helpful", adding more intuitions of "closed forms"
Chengsong
parents:
660
diff
changeset
|
279 |
|
618 | 280 |
A high-level overview of the main components of the finiteness proof |
281 |
is as follows: |
|
593 | 282 |
\begin{figure}[H] |
283 |
\begin{tikzpicture}[scale=1,font=\bf, |
|
284 |
node/.style={ |
|
285 |
rectangle,rounded corners=3mm, |
|
286 |
ultra thick,draw=black!50,minimum height=18mm, |
|
287 |
minimum width=20mm, |
|
288 |
top color=white,bottom color=black!20}] |
|
543 | 289 |
|
290 |
||
593 | 291 |
\node (0) at (-5,0) |
292 |
[node, text width=1.8cm, text centered] |
|
293 |
{$\llbracket \bderssimp{a}{s} \rrbracket$}; |
|
294 |
\node (A) at (0,0) |
|
295 |
[node,text width=1.6cm, text centered] |
|
296 |
{$\llbracket \rderssimp{r}{s} \rrbracket_r$}; |
|
297 |
\node (B) at (3,0) |
|
298 |
[node,text width=3.0cm, anchor=west, minimum width = 40mm] |
|
299 |
{$\llbracket \textit{ClosedForm}(r, s)\rrbracket_r$}; |
|
300 |
\node (C) at (9.5,0) [node, minimum width=10mm] {$N_r$}; |
|
301 |
||
302 |
\draw [->,line width=0.5mm] (0) -- |
|
303 |
node [above,pos=0.45] {=} (A) node [below, pos = 0.45] {$(r = a \downarrow_r)$} (A); |
|
304 |
\draw [->,line width=0.5mm] (A) -- |
|
305 |
node [above,pos=0.35] {$\quad =\ldots=$} (B); |
|
306 |
\draw [->,line width=0.5mm] (B) -- |
|
307 |
node [above,pos=0.35] {$\quad \leq \ldots \leq$} (C); |
|
308 |
\end{tikzpicture} |
|
309 |
%\caption{ |
|
310 |
\end{figure} |
|
576 | 311 |
\noindent |
577 | 312 |
We explain the steps one by one: |
532 | 313 |
\begin{itemize} |
590 | 314 |
\item |
315 |
We first introduce the operations such as |
|
316 |
derivatives, simplification, size calculation, etc. |
|
618 | 317 |
associated with $\rrexp$s, which we have introduced |
659
2e05f04ed6b3
Addressed Gerog "can't understand 'erase messes with structure'" comment
Chengsong
parents:
640
diff
changeset
|
318 |
in chapter \ref{Bitcoded2}. As promised we will discuss |
2e05f04ed6b3
Addressed Gerog "can't understand 'erase messes with structure'" comment
Chengsong
parents:
640
diff
changeset
|
319 |
why they are needed in \ref{whyRerase}. |
593 | 320 |
The operations on $\rrexp$s are identical to those on |
618 | 321 |
annotated regular expressions except that they dispense with |
322 |
bitcodes. This means that all proofs about size of $\rrexp$s will apply to |
|
323 |
annotated regular expressions, because the size of a regular |
|
324 |
expression is independent of the bitcodes. |
|
590 | 325 |
\item |
593 | 326 |
We prove that $\rderssimp{r}{s} = \textit{ClosedForm}(r, s)$, |
327 |
where $\textit{ClosedForm}(r, s)$ is entirely |
|
618 | 328 |
given as the derivatives of their children regular |
593 | 329 |
expressions. |
330 |
We call the right-hand-side the \emph{Closed Form} |
|
331 |
of the derivative $\rderssimp{r}{s}$. |
|
590 | 332 |
\item |
618 | 333 |
Formally we give an estimate of |
334 |
$\llbracket \textit{ClosedForm}(r, s) \rrbracket_r$. |
|
593 | 335 |
The key observation is that $\distinctBy$'s output is |
336 |
a list with a constant length bound. |
|
532 | 337 |
\end{itemize} |
594 | 338 |
We will expand on these steps in the next sections.\\ |
532 | 339 |
|
613 | 340 |
\section{The $\textit{Rrexp}$ Datatype} |
594 | 341 |
The first step is to define |
342 |
$\textit{rrexp}$s. |
|
618 | 343 |
They are annotated regular expressions without bitcodes, |
639 | 344 |
allowing a more convenient size bound proof. |
618 | 345 |
%Of course, the bits which encode the lexing information |
346 |
%would grow linearly with respect |
|
640
bd1354127574
more proofreading done, last version before submission
Chengsong
parents:
639
diff
changeset
|
347 |
%to the input, which should be taken into accounte when we wish to tackle the runtime complexity. |
618 | 348 |
%But for the sake of the structural size |
349 |
%we can safely ignore them.\\ |
|
350 |
The datatype |
|
594 | 351 |
definition of the $\rrexp$, called |
593 | 352 |
\emph{r-regular expressions}, |
594 | 353 |
was initially defined in \ref{rrexpDef}. |
354 |
The reason for the prefix $r$ is |
|
593 | 355 |
to make a distinction |
594 | 356 |
with basic regular expressions. |
639 | 357 |
We give here again the definition of $\rrexp$. |
576 | 358 |
\[ \rrexp ::= \RZERO \mid \RONE |
593 | 359 |
\mid \RCHAR{c} |
360 |
\mid \RSEQ{r_1}{r_2} |
|
361 |
\mid \RALTS{rs} |
|
362 |
\mid \RSTAR{r} |
|
576 | 363 |
\] |
593 | 364 |
The size of an r-regular expression is |
365 |
written $\llbracket r\rrbracket_r$, |
|
366 |
whose definition mirrors that of an annotated regular expression. |
|
576 | 367 |
\begin{center} |
618 | 368 |
\begin{tabular}{lcl} |
593 | 369 |
$\llbracket _{bs}\ONE \rrbracket_r$ & $\dn$ & $1$\\ |
370 |
$\llbracket \ZERO \rrbracket_r$ & $\dn$ & $1$ \\ |
|
371 |
$\llbracket _{bs} r_1 \cdot r_2 \rrbracket_r$ & $\dn$ & $\llbracket r_1 \rrbracket_r + \llbracket r_2 \rrbracket_r + 1$\\ |
|
372 |
$\llbracket _{bs}\mathbf{c} \rrbracket_r $ & $\dn$ & $1$\\ |
|
373 |
$\llbracket _{bs}\sum as \rrbracket_r $ & $\dn$ & $\map \; (\llbracket \_ \rrbracket_r)\; as + 1$\\ |
|
374 |
$\llbracket _{bs} a^* \rrbracket_r $ & $\dn$ & $\llbracket a \rrbracket_r + 1$. |
|
375 |
\end{tabular} |
|
576 | 376 |
\end{center} |
377 |
\noindent |
|
593 | 378 |
The $r$ in the subscript of $\llbracket \rrbracket_r$ is to |
379 |
differentiate with the same operation for annotated regular expressions. |
|
640
bd1354127574
more proofreading done, last version before submission
Chengsong
parents:
639
diff
changeset
|
380 |
Similar subscripts will be added for operations like $\rerase{}$: |
593 | 381 |
\begin{center} |
382 |
\begin{tabular}{lcl} |
|
383 |
$\rerase{\ZERO}$ & $\dn$ & $\RZERO$\\ |
|
384 |
$\rerase{_{bs}\ONE}$ & $\dn$ & $\RONE$\\ |
|
385 |
$\rerase{_{bs}\mathbf{c}}$ & $\dn$ & $\RCHAR{c}$\\ |
|
386 |
$\rerase{_{bs}r_1\cdot r_2}$ & $\dn$ & $\RSEQ{\rerase{r_1}}{\rerase{r_2}}$\\ |
|
387 |
$\rerase{_{bs}\sum as}$ & $\dn$ & $\RALTS{\map \; \rerase{\_} \; as}$\\ |
|
388 |
$\rerase{_{bs} a ^*}$ & $\dn$ & $\rerase{a} ^*$ |
|
389 |
\end{tabular} |
|
390 |
\end{center} |
|
594 | 391 |
|
659
2e05f04ed6b3
Addressed Gerog "can't understand 'erase messes with structure'" comment
Chengsong
parents:
640
diff
changeset
|
392 |
\subsection{Why a New Datatype?}\label{whyRerase} |
2e05f04ed6b3
Addressed Gerog "can't understand 'erase messes with structure'" comment
Chengsong
parents:
640
diff
changeset
|
393 |
\marginpar{\em added label so this section can be referenced by other parts of the thesis |
2e05f04ed6b3
Addressed Gerog "can't understand 'erase messes with structure'" comment
Chengsong
parents:
640
diff
changeset
|
394 |
so that interested readers can jump to/be reassured that there will explanations.} |
2e05f04ed6b3
Addressed Gerog "can't understand 'erase messes with structure'" comment
Chengsong
parents:
640
diff
changeset
|
395 |
Originally the erase operation $(\_)_\downarrow$ was |
2e05f04ed6b3
Addressed Gerog "can't understand 'erase messes with structure'" comment
Chengsong
parents:
640
diff
changeset
|
396 |
used by Ausaf et al. in their proofs related to $\blexer$. |
2e05f04ed6b3
Addressed Gerog "can't understand 'erase messes with structure'" comment
Chengsong
parents:
640
diff
changeset
|
397 |
This function was not part of the lexing algorithm, and the sole purpose was to |
2e05f04ed6b3
Addressed Gerog "can't understand 'erase messes with structure'" comment
Chengsong
parents:
640
diff
changeset
|
398 |
bridge the gap between the $r$ |
2e05f04ed6b3
Addressed Gerog "can't understand 'erase messes with structure'" comment
Chengsong
parents:
640
diff
changeset
|
399 |
%$\textit{rexp}$ |
2e05f04ed6b3
Addressed Gerog "can't understand 'erase messes with structure'" comment
Chengsong
parents:
640
diff
changeset
|
400 |
(un-annotated) and $\textit{arexp}$ (annotated) |
2e05f04ed6b3
Addressed Gerog "can't understand 'erase messes with structure'" comment
Chengsong
parents:
640
diff
changeset
|
401 |
regular expression datatypes so as to leverage the correctness |
2e05f04ed6b3
Addressed Gerog "can't understand 'erase messes with structure'" comment
Chengsong
parents:
640
diff
changeset
|
402 |
theorem of $\lexer$.%to establish the correctness of $\blexer$. |
2e05f04ed6b3
Addressed Gerog "can't understand 'erase messes with structure'" comment
Chengsong
parents:
640
diff
changeset
|
403 |
For example, lemma \ref{retrieveStepwise} %and \ref{bmkepsRetrieve} |
2e05f04ed6b3
Addressed Gerog "can't understand 'erase messes with structure'" comment
Chengsong
parents:
640
diff
changeset
|
404 |
uses $\erase$ to convert an annotated regular expression $a$ into |
2e05f04ed6b3
Addressed Gerog "can't understand 'erase messes with structure'" comment
Chengsong
parents:
640
diff
changeset
|
405 |
a plain one so that it can be used by $\inj$ to create the desired value |
2e05f04ed6b3
Addressed Gerog "can't understand 'erase messes with structure'" comment
Chengsong
parents:
640
diff
changeset
|
406 |
$\inj\; (a)_\downarrow \; c \; v$. |
2e05f04ed6b3
Addressed Gerog "can't understand 'erase messes with structure'" comment
Chengsong
parents:
640
diff
changeset
|
407 |
|
2e05f04ed6b3
Addressed Gerog "can't understand 'erase messes with structure'" comment
Chengsong
parents:
640
diff
changeset
|
408 |
Ideally $\erase$ should only remove the auxiliary information not related to the |
2e05f04ed6b3
Addressed Gerog "can't understand 'erase messes with structure'" comment
Chengsong
parents:
640
diff
changeset
|
409 |
structure--the |
2e05f04ed6b3
Addressed Gerog "can't understand 'erase messes with structure'" comment
Chengsong
parents:
640
diff
changeset
|
410 |
bitcodes. However there exists a complication |
2e05f04ed6b3
Addressed Gerog "can't understand 'erase messes with structure'" comment
Chengsong
parents:
640
diff
changeset
|
411 |
where the alternative constructors have different arity for $\textit{arexp}$ |
2e05f04ed6b3
Addressed Gerog "can't understand 'erase messes with structure'" comment
Chengsong
parents:
640
diff
changeset
|
412 |
and $\textit{r}$: |
576 | 413 |
\begin{center} |
618 | 414 |
\begin{tabular}{lcl} |
659
2e05f04ed6b3
Addressed Gerog "can't understand 'erase messes with structure'" comment
Chengsong
parents:
640
diff
changeset
|
415 |
$\textit{r}$ & $::=$ & $\ldots \;|\; (\_ + \_) \; ::\; "\textit{r} \Rightarrow \textit{r} \Rightarrow \textit{r}" | \ldots$\\ |
2e05f04ed6b3
Addressed Gerog "can't understand 'erase messes with structure'" comment
Chengsong
parents:
640
diff
changeset
|
416 |
$\textit{arexp}$ & $::=$ & $\ldots\; |\; (\Sigma \_ ) \; ::\; "\textit{arexp} \; list \Rightarrow \textit{arexp}" | \ldots$ |
594 | 417 |
\end{tabular} |
576 | 418 |
\end{center} |
594 | 419 |
\noindent |
659
2e05f04ed6b3
Addressed Gerog "can't understand 'erase messes with structure'" comment
Chengsong
parents:
640
diff
changeset
|
420 |
To convert between the two |
2e05f04ed6b3
Addressed Gerog "can't understand 'erase messes with structure'" comment
Chengsong
parents:
640
diff
changeset
|
421 |
$\erase$ has to recursively disassemble a list into nested binary applications of the |
2e05f04ed6b3
Addressed Gerog "can't understand 'erase messes with structure'" comment
Chengsong
parents:
640
diff
changeset
|
422 |
$(\_ + \_)$ operator, |
2e05f04ed6b3
Addressed Gerog "can't understand 'erase messes with structure'" comment
Chengsong
parents:
640
diff
changeset
|
423 |
handling corner cases like empty or |
2e05f04ed6b3
Addressed Gerog "can't understand 'erase messes with structure'" comment
Chengsong
parents:
640
diff
changeset
|
424 |
singleton alternative lists: |
2e05f04ed6b3
Addressed Gerog "can't understand 'erase messes with structure'" comment
Chengsong
parents:
640
diff
changeset
|
425 |
%becomes $r$ during the |
2e05f04ed6b3
Addressed Gerog "can't understand 'erase messes with structure'" comment
Chengsong
parents:
640
diff
changeset
|
426 |
%$\erase$ function. |
2e05f04ed6b3
Addressed Gerog "can't understand 'erase messes with structure'" comment
Chengsong
parents:
640
diff
changeset
|
427 |
%The annotated regular expression $\sum[a, b, c]$ would turn into |
2e05f04ed6b3
Addressed Gerog "can't understand 'erase messes with structure'" comment
Chengsong
parents:
640
diff
changeset
|
428 |
%$(a+(b+c))$. |
2e05f04ed6b3
Addressed Gerog "can't understand 'erase messes with structure'" comment
Chengsong
parents:
640
diff
changeset
|
429 |
\begin{center} |
2e05f04ed6b3
Addressed Gerog "can't understand 'erase messes with structure'" comment
Chengsong
parents:
640
diff
changeset
|
430 |
\begin{tabular}{lcl} |
2e05f04ed6b3
Addressed Gerog "can't understand 'erase messes with structure'" comment
Chengsong
parents:
640
diff
changeset
|
431 |
$ (_{bs}\sum [])_\downarrow $ & $\dn$ & $\ZERO$\\ |
2e05f04ed6b3
Addressed Gerog "can't understand 'erase messes with structure'" comment
Chengsong
parents:
640
diff
changeset
|
432 |
$ (_{bs}\sum [a])_\downarrow$ & $\dn$ & $a$\\ |
2e05f04ed6b3
Addressed Gerog "can't understand 'erase messes with structure'" comment
Chengsong
parents:
640
diff
changeset
|
433 |
$ (_{bs}\sum a_1 :: a_2)_\downarrow$ & $\dn$ & $(a_1)_\downarrow + (a_2)_\downarrow)$\\ |
2e05f04ed6b3
Addressed Gerog "can't understand 'erase messes with structure'" comment
Chengsong
parents:
640
diff
changeset
|
434 |
$ (_{bs}\sum a :: as)_\downarrow$ & $\dn$ & $a_\downarrow + (\erase \; _{[]} \sum as)$ |
2e05f04ed6b3
Addressed Gerog "can't understand 'erase messes with structure'" comment
Chengsong
parents:
640
diff
changeset
|
435 |
\end{tabular} |
2e05f04ed6b3
Addressed Gerog "can't understand 'erase messes with structure'" comment
Chengsong
parents:
640
diff
changeset
|
436 |
\end{center} |
2e05f04ed6b3
Addressed Gerog "can't understand 'erase messes with structure'" comment
Chengsong
parents:
640
diff
changeset
|
437 |
\noindent |
2e05f04ed6b3
Addressed Gerog "can't understand 'erase messes with structure'" comment
Chengsong
parents:
640
diff
changeset
|
438 |
These operations inevitably change the structure and size of |
2e05f04ed6b3
Addressed Gerog "can't understand 'erase messes with structure'" comment
Chengsong
parents:
640
diff
changeset
|
439 |
an annotated regular expression. For example, |
2e05f04ed6b3
Addressed Gerog "can't understand 'erase messes with structure'" comment
Chengsong
parents:
640
diff
changeset
|
440 |
$a_1 = \sum _{Z}[x]$ has size 2, but $(a_1)_\downarrow = x$ |
2e05f04ed6b3
Addressed Gerog "can't understand 'erase messes with structure'" comment
Chengsong
parents:
640
diff
changeset
|
441 |
only has size 1. |
2e05f04ed6b3
Addressed Gerog "can't understand 'erase messes with structure'" comment
Chengsong
parents:
640
diff
changeset
|
442 |
%adding unnecessary |
2e05f04ed6b3
Addressed Gerog "can't understand 'erase messes with structure'" comment
Chengsong
parents:
640
diff
changeset
|
443 |
%complexities to the size bound proof. |
2e05f04ed6b3
Addressed Gerog "can't understand 'erase messes with structure'" comment
Chengsong
parents:
640
diff
changeset
|
444 |
%The reason we |
2e05f04ed6b3
Addressed Gerog "can't understand 'erase messes with structure'" comment
Chengsong
parents:
640
diff
changeset
|
445 |
%define a new datatype is that |
2e05f04ed6b3
Addressed Gerog "can't understand 'erase messes with structure'" comment
Chengsong
parents:
640
diff
changeset
|
446 |
%the $\erase$ function |
2e05f04ed6b3
Addressed Gerog "can't understand 'erase messes with structure'" comment
Chengsong
parents:
640
diff
changeset
|
447 |
%does not preserve the structure of annotated |
2e05f04ed6b3
Addressed Gerog "can't understand 'erase messes with structure'" comment
Chengsong
parents:
640
diff
changeset
|
448 |
%regular expressions. |
2e05f04ed6b3
Addressed Gerog "can't understand 'erase messes with structure'" comment
Chengsong
parents:
640
diff
changeset
|
449 |
%We initially started by using |
2e05f04ed6b3
Addressed Gerog "can't understand 'erase messes with structure'" comment
Chengsong
parents:
640
diff
changeset
|
450 |
%plain regular expressions and tried to prove |
2e05f04ed6b3
Addressed Gerog "can't understand 'erase messes with structure'" comment
Chengsong
parents:
640
diff
changeset
|
451 |
%lemma \ref{rsizeAsize}, |
2e05f04ed6b3
Addressed Gerog "can't understand 'erase messes with structure'" comment
Chengsong
parents:
640
diff
changeset
|
452 |
%however the $\erase$ function messes with the structure of the |
2e05f04ed6b3
Addressed Gerog "can't understand 'erase messes with structure'" comment
Chengsong
parents:
640
diff
changeset
|
453 |
%annotated regular expression. |
2e05f04ed6b3
Addressed Gerog "can't understand 'erase messes with structure'" comment
Chengsong
parents:
640
diff
changeset
|
454 |
%The $+$ constructor |
2e05f04ed6b3
Addressed Gerog "can't understand 'erase messes with structure'" comment
Chengsong
parents:
640
diff
changeset
|
455 |
%of basic regular expressions is only binary, whereas $\sum$ |
2e05f04ed6b3
Addressed Gerog "can't understand 'erase messes with structure'" comment
Chengsong
parents:
640
diff
changeset
|
456 |
%takes a list. Therefore we need to convert between |
2e05f04ed6b3
Addressed Gerog "can't understand 'erase messes with structure'" comment
Chengsong
parents:
640
diff
changeset
|
457 |
%annotated and normal regular expressions as follows: |
613 | 458 |
For example, if we define the size of a basic plain regular expression |
594 | 459 |
in the usual way, |
543 | 460 |
\begin{center} |
618 | 461 |
\begin{tabular}{lcl} |
593 | 462 |
$\llbracket \ONE \rrbracket_p$ & $\dn$ & $1$\\ |
463 |
$\llbracket \ZERO \rrbracket_p$ & $\dn$ & $1$ \\ |
|
659
2e05f04ed6b3
Addressed Gerog "can't understand 'erase messes with structure'" comment
Chengsong
parents:
640
diff
changeset
|
464 |
$\llbracket r_1 + r_2 \rrbracket_p$ & $\dn$ & $\llbracket r_1 \rrbracket_p + \llbracket r_2 \rrbracket_p + 1$\\ |
593 | 465 |
$\llbracket \mathbf{c} \rrbracket_p $ & $\dn$ & $1$\\ |
466 |
$\llbracket r_1 \cdot r_2 \rrbracket_p $ & $\dn$ & $\llbracket r_1 \rrbracket_p \; + \llbracket r_2 \rrbracket_p + 1$\\ |
|
467 |
$\llbracket a^* \rrbracket_p $ & $\dn$ & $\llbracket a \rrbracket_p + 1$ |
|
468 |
\end{tabular} |
|
532 | 469 |
\end{center} |
543 | 470 |
\noindent |
594 | 471 |
Then the property |
532 | 472 |
\begin{center} |
613 | 473 |
$\llbracket a \rrbracket \stackrel{?}{=} \llbracket a_\downarrow \rrbracket_p$ |
532 | 474 |
\end{center} |
594 | 475 |
does not hold. |
659
2e05f04ed6b3
Addressed Gerog "can't understand 'erase messes with structure'" comment
Chengsong
parents:
640
diff
changeset
|
476 |
%With $\textit{rerase}$, however, |
2e05f04ed6b3
Addressed Gerog "can't understand 'erase messes with structure'" comment
Chengsong
parents:
640
diff
changeset
|
477 |
%only the bitcodes are thrown away. |
2e05f04ed6b3
Addressed Gerog "can't understand 'erase messes with structure'" comment
Chengsong
parents:
640
diff
changeset
|
478 |
That leads to us defining the new regular expression datatype without |
2e05f04ed6b3
Addressed Gerog "can't understand 'erase messes with structure'" comment
Chengsong
parents:
640
diff
changeset
|
479 |
bitcodes but with a list alternative constructor, and defining a new erase function |
2e05f04ed6b3
Addressed Gerog "can't understand 'erase messes with structure'" comment
Chengsong
parents:
640
diff
changeset
|
480 |
in a strictly structure-preserving manner: |
2e05f04ed6b3
Addressed Gerog "can't understand 'erase messes with structure'" comment
Chengsong
parents:
640
diff
changeset
|
481 |
\begin{center} |
2e05f04ed6b3
Addressed Gerog "can't understand 'erase messes with structure'" comment
Chengsong
parents:
640
diff
changeset
|
482 |
\begin{tabular}{lcl} |
2e05f04ed6b3
Addressed Gerog "can't understand 'erase messes with structure'" comment
Chengsong
parents:
640
diff
changeset
|
483 |
$\textit{rrexp}$ & $::=$ & $\ldots\; |\; (\sum \_ ) \; ::\; "\textit{rrexp} \; list \Rightarrow \textit{rrexp}" | \ldots$\\ |
2e05f04ed6b3
Addressed Gerog "can't understand 'erase messes with structure'" comment
Chengsong
parents:
640
diff
changeset
|
484 |
$\rerase{_{bs}\sum as}$ & $\dn$ & $\RALTS{\map \; \rerase{\_} \; as}$\\ |
2e05f04ed6b3
Addressed Gerog "can't understand 'erase messes with structure'" comment
Chengsong
parents:
640
diff
changeset
|
485 |
\end{tabular} |
2e05f04ed6b3
Addressed Gerog "can't understand 'erase messes with structure'" comment
Chengsong
parents:
640
diff
changeset
|
486 |
\end{center} |
2e05f04ed6b3
Addressed Gerog "can't understand 'erase messes with structure'" comment
Chengsong
parents:
640
diff
changeset
|
487 |
\noindent |
2e05f04ed6b3
Addressed Gerog "can't understand 'erase messes with structure'" comment
Chengsong
parents:
640
diff
changeset
|
488 |
%But |
2e05f04ed6b3
Addressed Gerog "can't understand 'erase messes with structure'" comment
Chengsong
parents:
640
diff
changeset
|
489 |
%Everything about the structure remains intact. |
2e05f04ed6b3
Addressed Gerog "can't understand 'erase messes with structure'" comment
Chengsong
parents:
640
diff
changeset
|
490 |
%Therefore it does not change the size |
2e05f04ed6b3
Addressed Gerog "can't understand 'erase messes with structure'" comment
Chengsong
parents:
640
diff
changeset
|
491 |
%of an annotated regular expression and we have: |
613 | 492 |
\noindent |
594 | 493 |
One might be able to prove an inequality such as |
494 |
$\llbracket a \rrbracket \leq \llbracket a_\downarrow \rrbracket_p $ |
|
495 |
and then estimate $\llbracket a_\downarrow \rrbracket_p$, |
|
496 |
but we found our approach more straightforward.\\ |
|
532 | 497 |
|
613 | 498 |
\subsection{Functions for R-regular Expressions} |
639 | 499 |
The downside of our approach is that we need to redefine |
500 |
several functions for $\rrexp$. |
|
618 | 501 |
In this section we shall define the r-regular expression version |
639 | 502 |
of $\bder$, and $\textit{bsimp}$ related functions. |
613 | 503 |
We use $r$ as the prefix or subscript to differentiate |
504 |
with the bitcoded version. |
|
618 | 505 |
%For example,$\backslash_r$, $\rdistincts$, and $\rsimp$ |
506 |
%as opposed to $\backslash$, $\distinctBy$, and $\bsimp$. |
|
507 |
%As promised, they are much simpler than their bitcoded counterparts. |
|
613 | 508 |
%The operations on r-regular expressions are |
509 |
%almost identical to those of the annotated regular expressions, |
|
510 |
%except that no bitcodes are used. For example, |
|
618 | 511 |
The derivative operation for an r-regular expression is\\ |
543 | 512 |
\begin{center} |
593 | 513 |
\begin{tabular}{@{}lcl@{}} |
514 |
$(\ZERO)\,\backslash_r c$ & $\dn$ & $\ZERO$\\ |
|
515 |
$(\ONE)\,\backslash_r c$ & $\dn$ & |
|
516 |
$\textit{if}\;c=d\; \;\textit{then}\; |
|
517 |
\ONE\;\textit{else}\;\ZERO$\\ |
|
518 |
$(\sum \;\textit{rs})\,\backslash_r c$ & $\dn$ & |
|
519 |
$\sum\;(\textit{map} \; (\_\backslash_r c) \; rs )$\\ |
|
520 |
$(r_1\cdot r_2)\,\backslash_r c$ & $\dn$ & |
|
594 | 521 |
$\textit{if}\;(\textit{rnullable}\,r_1)$\\ |
593 | 522 |
& &$\textit{then}\;\sum\,[(r_1\,\backslash_r c)\cdot\,r_2,$\\ |
523 |
& &$\phantom{\textit{then},\;\sum\,}((r_2\,\backslash_r c))]$\\ |
|
524 |
& &$\textit{else}\;\,(r_1\,\backslash_r c)\cdot r_2$\\ |
|
525 |
$(r^*)\,\backslash_r c$ & $\dn$ & |
|
526 |
$( r\,\backslash_r c)\cdot |
|
527 |
(_{[]}r^*))$ |
|
528 |
\end{tabular} |
|
543 | 529 |
\end{center} |
530 |
\noindent |
|
618 | 531 |
where we omit the definition of $\textit{rnullable}$. |
639 | 532 |
The generalisation from the derivatives w.r.t a character to |
533 |
derivatives w.r.t strings is given as |
|
620 | 534 |
\begin{center} |
535 |
\begin{tabular}{lcl} |
|
536 |
$r \backslash_{rs} []$ & $\dn$ & $r$\\ |
|
537 |
$r \backslash_{rs} c::s$ & $\dn$ & $(r\backslash_r c) \backslash_{rs} s$ |
|
538 |
\end{tabular} |
|
539 |
\end{center} |
|
618 | 540 |
|
541 |
The function $\distinctBy$ for r-regular expressions does not need |
|
594 | 542 |
a function checking equivalence because |
618 | 543 |
there are no bit annotations. |
544 |
Therefore we have |
|
532 | 545 |
\begin{center} |
593 | 546 |
\begin{tabular}{lcl} |
547 |
$\rdistinct{[]}{rset} $ & $\dn$ & $[]$\\ |
|
594 | 548 |
$\rdistinct{r :: rs}{rset}$ & $\dn$ & |
549 |
$\textit{if}(r \in \textit{rset}) \; \textit{then} \; \rdistinct{rs}{rset}$\\ |
|
550 |
& & $\textit{else}\; \; |
|
551 |
r::\rdistinct{rs}{(rset \cup \{r\})}$ |
|
593 | 552 |
\end{tabular} |
532 | 553 |
\end{center} |
554 |
%TODO: definition of rsimp (maybe only the alternative clause) |
|
543 | 555 |
\noindent |
618 | 556 |
%We would like to make clear |
557 |
%a difference between our $\rdistincts$ and |
|
558 |
%the Isabelle $\textit {distinct}$ predicate. |
|
559 |
%In Isabelle $\textit{distinct}$ is a function that returns a boolean |
|
560 |
%rather than a list. |
|
561 |
%It tests if all the elements of a list are unique.\\ |
|
562 |
With $\textit{rdistinct}$ in place, |
|
563 |
the flatten function for $\rrexp$ is as follows: |
|
595 | 564 |
\begin{center} |
565 |
\begin{tabular}{@{}lcl@{}} |
|
596 | 566 |
$\textit{rflts} \; (\sum \textit{as}) :: \textit{as'}$ & $\dn$ & $as \; @ \; \textit{rflts} \; as' $ \\ |
595 | 567 |
$\textit{rflts} \; \ZERO :: as'$ & $\dn$ & $ \textit{rflts} \; \textit{as'} $ \\ |
568 |
$\textit{rflts} \; a :: as'$ & $\dn$ & $a :: \textit{rflts} \; \textit{as'}$ \quad(otherwise) |
|
569 |
\end{tabular} |
|
570 |
\end{center} |
|
571 |
\noindent |
|
618 | 572 |
The function |
573 |
$\rsimpalts$ corresponds to $\textit{bsimp}_{ALTS}$: |
|
596 | 574 |
\begin{center} |
575 |
\begin{tabular}{@{}lcl@{}} |
|
576 |
$\rsimpalts \;\; nil$ & $\dn$ & $\RZERO$\\ |
|
577 |
$\rsimpalts \;\; r::nil$ & $\dn$ & $r$\\ |
|
578 |
$\rsimpalts \;\; rs$ & $\dn$ & $\sum rs$\\ |
|
579 |
\end{tabular} |
|
580 |
\end{center} |
|
581 |
\noindent |
|
618 | 582 |
Similarly, we have $\rsimpseq$ which corresponds to $\textit{bsimp}_{SEQ}$: |
596 | 583 |
\begin{center} |
584 |
\begin{tabular}{@{}lcl@{}} |
|
585 |
$\rsimpseq \;\; \RZERO \; \_ $ & $=$ & $\RZERO$\\ |
|
586 |
$\rsimpseq \;\; \_ \; \RZERO $ & $=$ & $\RZERO$\\ |
|
587 |
$\rsimpseq \;\; \RONE \cdot r_2$ & $\dn$ & $r_2$\\ |
|
588 |
$\rsimpseq \;\; r_1 r_2$ & $\dn$ & $r_1 \cdot r_2$\\ |
|
589 |
\end{tabular} |
|
590 |
\end{center} |
|
591 |
and get $\textit{rsimp}$ and $\rderssimp{\_}{\_}$: |
|
595 | 592 |
\begin{center} |
593 |
\begin{tabular}{@{}lcl@{}} |
|
594 |
||
596 | 595 |
$\textit{rsimp} \; (r_1\cdot r_2)$ & $\dn$ & $ \textit{rsimp}_{SEQ} \; bs \;(\textit{rsimp} \; r_1) \; (\textit{rsimp} \; r_2) $ \\ |
596 |
$\textit{rsimp} \; (_{bs}\sum \textit{rs})$ & $\dn$ & $\textit{rsimp}_{ALTS} \; \textit{bs} \; (\textit{rdistinct} \; ( \textit{rflts} ( \textit{map} \; rsimp \; rs)) \; \rerases \; \varnothing) $ \\ |
|
597 |
$\textit{rsimp} \; r$ & $\dn$ & $\textit{r} \qquad \textit{otherwise}$ |
|
595 | 598 |
\end{tabular} |
599 |
\end{center} |
|
596 | 600 |
\begin{center} |
601 |
\begin{tabular}{@{}lcl@{}} |
|
602 |
$r\backslash_{rsimp} \, c$ & $\dn$ & $\rsimp \; (r\backslash_r \, c)$ |
|
603 |
\end{tabular} |
|
604 |
\end{center} |
|
605 |
||
606 |
\begin{center} |
|
607 |
\begin{tabular}{@{}lcl@{}} |
|
601 | 608 |
$r \backslash_{rsimps} \; \; c\!::\!s $ & $\dn$ & $(r \backslash_{rsimp}\, c) \backslash_{rsimps}\, s$ \\ |
596 | 609 |
$r \backslash_{rsimps} [\,] $ & $\dn$ & $r$ |
610 |
\end{tabular} |
|
611 |
\end{center} |
|
612 |
\noindent |
|
601 | 613 |
We do not define an r-regular expression version of $\blexersimp$, |
618 | 614 |
as our proof does not depend on it. |
613 | 615 |
Now we are ready to introduce how r-regular expressions allow |
616 |
us to prove the size bound on bitcoded regular expressions. |
|
617 |
||
618 |
\subsection{Using R-regular Expressions to Bound Bit-coded Regular Expressions} |
|
619 |
Everything about the size of annotated regular expressions after the application |
|
620 |
of function $\bsimp$ and $\backslash_{simps}$ |
|
621 |
can be calculated via the size of r-regular expressions after the application |
|
622 |
of $\rsimp$ and $\backslash_{rsimps}$: |
|
564 | 623 |
\begin{lemma}\label{sizeRelations} |
659
2e05f04ed6b3
Addressed Gerog "can't understand 'erase messes with structure'" comment
Chengsong
parents:
640
diff
changeset
|
624 |
The following equalities hold: |
543 | 625 |
\begin{itemize} |
626 |
\item |
|
659
2e05f04ed6b3
Addressed Gerog "can't understand 'erase messes with structure'" comment
Chengsong
parents:
640
diff
changeset
|
627 |
$\rsize{\rerase a} = \asize a$ |
2e05f04ed6b3
Addressed Gerog "can't understand 'erase messes with structure'" comment
Chengsong
parents:
640
diff
changeset
|
628 |
\item |
601 | 629 |
$\asize{\bsimps \; a} = \rsize{\rsimp{ \rerase{a}}}$ |
554 | 630 |
\item |
596 | 631 |
$\asize{\bderssimp{a}{s}} = \rsize{\rderssimp{\rerase{a}}{s}}$ |
554 | 632 |
\end{itemize} |
532 | 633 |
\end{lemma} |
601 | 634 |
\begin{proof} |
659
2e05f04ed6b3
Addressed Gerog "can't understand 'erase messes with structure'" comment
Chengsong
parents:
640
diff
changeset
|
635 |
First part follows from the definition of $(\_)_{\downarrow_r}$. |
2e05f04ed6b3
Addressed Gerog "can't understand 'erase messes with structure'" comment
Chengsong
parents:
640
diff
changeset
|
636 |
The second part is by induction on the inductive cases |
601 | 637 |
of $\textit{bsimp}$. |
659
2e05f04ed6b3
Addressed Gerog "can't understand 'erase messes with structure'" comment
Chengsong
parents:
640
diff
changeset
|
638 |
The third part is by induction on the string $s$, |
601 | 639 |
where the inductive step follows from part one. |
640 |
\end{proof} |
|
543 | 641 |
\noindent |
596 | 642 |
With lemma \ref{sizeRelations}, |
601 | 643 |
we will be able to focus on |
644 |
estimating only |
|
645 |
$\rsize{\rderssimp{\rerase{a}}{s}}$ |
|
646 |
in later parts because |
|
647 |
\begin{center} |
|
648 |
$\rsize{\rderssimp{\rerase{a}}{s}} \leq N_r \quad$ |
|
649 |
implies |
|
650 |
$\quad \llbracket a \backslash_{bsimps} s \rrbracket \leq N_r$. |
|
651 |
\end{center} |
|
618 | 652 |
%From now on we |
653 |
%Unless stated otherwise in the rest of this |
|
654 |
%chapter all regular expressions without |
|
655 |
%bitcodes are seen as r-regular expressions ($\rrexp$s). |
|
656 |
%For the binary alternative r-regular expression $\RALTS{[r_1, r_2]}$, |
|
657 |
%we use the notation $r_1 + r_2$ |
|
658 |
%for brevity. |
|
532 | 659 |
|
660 |
||
661 |
%----------------------------------- |
|
596 | 662 |
% SUB SECTION ROADMAP RREXP BOUND |
532 | 663 |
%----------------------------------- |
553 | 664 |
|
596 | 665 |
%\subsection{Roadmap to a Bound for $\textit{Rrexp}$} |
553 | 666 |
|
596 | 667 |
%The way we obtain the bound for $\rrexp$s is by two steps: |
668 |
%\begin{itemize} |
|
669 |
% \item |
|
670 |
% First, we rewrite $r\backslash s$ into something else that is easier |
|
640
bd1354127574
more proofreading done, last version before submission
Chengsong
parents:
639
diff
changeset
|
671 |
% to bound. This step is crucial for the inductive case |
596 | 672 |
% $r_1 \cdot r_2$ and $r^*$, where the derivative can grow and bloat in a wild way, |
640
bd1354127574
more proofreading done, last version before submission
Chengsong
parents:
639
diff
changeset
|
673 |
% but after simplification, they will always be equal or smaller to a form consisting of an alternative |
596 | 674 |
% list of regular expressions $f \; (g\; (\sum rs))$ with some functions applied to it, where each element will be distinct after the function application. |
675 |
% \item |
|
676 |
% Then, for such a sum list of regular expressions $f\; (g\; (\sum rs))$, we can control its size |
|
677 |
% by estimation, since $\distinctBy$ and $\flts$ are well-behaved and working together would only |
|
678 |
% reduce the size of a regular expression, not adding to it. |
|
679 |
%\end{itemize} |
|
680 |
% |
|
681 |
%\section{Step One: Closed Forms} |
|
682 |
%We transform the function application $\rderssimp{r}{s}$ |
|
683 |
%into an equivalent |
|
684 |
%form $f\; (g \; (\sum rs))$. |
|
685 |
%The functions $f$ and $g$ can be anything from $\flts$, $\distinctBy$ and other helper functions from $\bsimp{\_}$. |
|
686 |
%This way we get a different but equivalent way of expressing : $r\backslash s = f \; (g\; (\sum rs))$, we call the |
|
687 |
%right hand side the "closed form" of $r\backslash s$. |
|
688 |
% |
|
689 |
%\begin{quote}\it |
|
690 |
% Claim: For regular expressions $r_1 \cdot r_2$, we claim that |
|
691 |
%\end{quote} |
|
692 |
%\noindent |
|
693 |
%We explain in detail how we reached those claims. |
|
601 | 694 |
If we attempt to prove |
695 |
\begin{center} |
|
609 | 696 |
$\forall r. \; \exists N_r.\;\; s.t. \llbracket r\backslash_{rsimps} s \rrbracket_r \leq N_r$ |
601 | 697 |
\end{center} |
698 |
using a naive induction on the structure of $r$, |
|
699 |
then we are stuck at the inductive cases such as |
|
700 |
$r_1\cdot r_2$. |
|
701 |
The inductive hypotheses are: |
|
702 |
\begin{center} |
|
703 |
1: $\text{for } r_1, \text{there exists } N_{r_1}.\;\; s.t. |
|
609 | 704 |
\;\;\forall s. \llbracket r_1 \backslash_{rsimps} s \rrbracket_r \leq N_{r_1}. $\\ |
601 | 705 |
2: $\text{for } r_2, \text{there exists } N_{r_2}.\;\; s.t. |
609 | 706 |
\;\; \forall s. \llbracket r_2 \backslash_{rsimps} s \rrbracket_r \leq N_{r_2}. $ |
601 | 707 |
\end{center} |
708 |
The inductive step to prove would be |
|
709 |
\begin{center} |
|
710 |
$\text{there exists } N_{r_1\cdot r_2}. \;\; s.t. \forall s. |
|
609 | 711 |
\llbracket (r_1 \cdot r_2) \backslash_{rsimps} s \rrbracket_r \leq N_{r_1\cdot r_2}.$ |
601 | 712 |
\end{center} |
713 |
The problem is that it is not clear what |
|
609 | 714 |
$(r_1\cdot r_2) \backslash_{rsimps} s$ looks like, |
601 | 715 |
and therefore $N_{r_1}$ and $N_{r_2}$ in the |
716 |
inductive hypotheses cannot be directly used. |
|
618 | 717 |
%We have already seen that $(r_1 \cdot r_2)\backslash s$ |
718 |
%and $(r^*)\backslash s$ can grow in a wild way. |
|
613 | 719 |
|
618 | 720 |
The point however, is that they will be equivalent to a list of |
609 | 721 |
terms $\sum rs$, where each term in $rs$ will |
722 |
be made of $r_1 \backslash s' $, $r_2\backslash s'$, |
|
618 | 723 |
and $r \backslash s'$ with $s' \in \textit{SubString} \; s$ (which stands |
724 |
for the set of substrings of $s$). |
|
609 | 725 |
The list $\sum rs$ will then be de-duplicated by $\textit{rdistinct}$ |
618 | 726 |
in the simplification, which prevents the $rs$ from growing indefinitely. |
609 | 727 |
|
613 | 728 |
Based on this idea, we develop a proof in two steps. |
640
bd1354127574
more proofreading done, last version before submission
Chengsong
parents:
639
diff
changeset
|
729 |
First, we show the below equality (where |
609 | 730 |
$f$ and $g$ are functions that do not increase the size of the input) |
731 |
\begin{center} |
|
613 | 732 |
$r\backslash_{rsimps} s = f\; (\textit{rdistinct} \; (g\; \sum rs))$, |
609 | 733 |
\end{center} |
613 | 734 |
where $r = r_1 \cdot r_2$ or $r = r_0^*$ and so on. |
735 |
For example, for $r_1 \cdot r_2$ we have the equality as |
|
736 |
\begin{center} |
|
737 |
$ \rderssimp{r_1 \cdot r_2}{s} = |
|
639 | 738 |
\rsimp{(\sum (r_1 \backslash s \cdot r_2 ) \; :: \;(\map \; \rderssimp{r_2}{\_} \;(\vsuf{s}{r_1})))}$ |
613 | 739 |
\end{center} |
609 | 740 |
We call the right-hand-side the |
741 |
\emph{Closed Form} of $(r_1 \cdot r_2)\backslash_{rsimps} s$. |
|
613 | 742 |
Second, we will bound the closed form of r-regular expressions |
743 |
using some estimation techniques |
|
618 | 744 |
and then apply |
745 |
lemma \ref{sizeRelations} to show that the bitcoded regular expressions |
|
613 | 746 |
in our $\blexersimp$ are finitely bounded. |
609 | 747 |
|
618 | 748 |
We will describe in detail the first step of the proof |
749 |
in the next section. |
|
613 | 750 |
|
751 |
\section{Closed Forms} |
|
609 | 752 |
In this section we introduce in detail |
640
bd1354127574
more proofreading done, last version before submission
Chengsong
parents:
639
diff
changeset
|
753 |
how to express the string derivatives |
618 | 754 |
of regular expressions (i.e. $r \backslash_r s$ where $s$ is a string |
755 |
rather than a single character) in a different way than |
|
756 |
our previous definition. |
|
757 |
In previous chapters, the derivative of a |
|
758 |
regular expression $r$ w.r.t a string $s$ |
|
759 |
was recursively defined on the string: |
|
760 |
\begin{center} |
|
761 |
$r \backslash_s (c::s) \dn (r \backslash c) \backslash_s s$ |
|
762 |
\end{center} |
|
763 |
The problem is that |
|
764 |
this definition does not provide much information |
|
765 |
on what $r \backslash_s s$ looks like. |
|
766 |
If we are interested in the size of a derivative like |
|
767 |
$(r_1 \cdot r_2)\backslash s$, |
|
768 |
we have to somehow get a more concrete form to begin. |
|
769 |
We call such more concrete representations the ``closed forms'' of |
|
770 |
string derivatives as opposed to their original definitions. |
|
668
3831621d7b14
added technical Overview section, almost done introduction
Chengsong
parents:
663
diff
changeset
|
771 |
The name ``closed from'' was inspired by closed forms in math, |
3831621d7b14
added technical Overview section, almost done introduction
Chengsong
parents:
663
diff
changeset
|
772 |
and the similarity with closed forms here is that they make |
3831621d7b14
added technical Overview section, almost done introduction
Chengsong
parents:
663
diff
changeset
|
773 |
estimating the same term easier. |
3831621d7b14
added technical Overview section, almost done introduction
Chengsong
parents:
663
diff
changeset
|
774 |
%The terminology ``closed form'' is borrowed from mathematics, |
3831621d7b14
added technical Overview section, almost done introduction
Chengsong
parents:
663
diff
changeset
|
775 |
%which usually describe expressions that are solely comprised of finitely many |
3831621d7b14
added technical Overview section, almost done introduction
Chengsong
parents:
663
diff
changeset
|
776 |
%well-known and easy-to-compute operations such as |
3831621d7b14
added technical Overview section, almost done introduction
Chengsong
parents:
663
diff
changeset
|
777 |
%additions, multiplications, and exponential functions. |
618 | 778 |
|
613 | 779 |
We start by proving some basic identities |
609 | 780 |
involving the simplification functions for r-regular expressions. |
613 | 781 |
After that we introduce the rewrite relations |
782 |
$\rightsquigarrow_h$, $\rightsquigarrow^*_{scf}$ |
|
783 |
$\rightsquigarrow_f$ and $\rightsquigarrow_g$. |
|
640
bd1354127574
more proofreading done, last version before submission
Chengsong
parents:
639
diff
changeset
|
784 |
These relations involve similar techniques as in chapter \ref{Bitcoded2} |
618 | 785 |
for annotated regular expressions. |
613 | 786 |
Finally, we use these identities to establish the |
787 |
closed forms of the alternative regular expression, |
|
788 |
the sequence regular expression, and the star regular expression. |
|
609 | 789 |
%$r_1\cdot r_2$, $r^*$ and $\sum rs$. |
601 | 790 |
|
791 |
||
609 | 792 |
|
613 | 793 |
\subsection{Some Basic Identities} |
609 | 794 |
|
618 | 795 |
In what follows we will often convert between lists |
796 |
and sets. |
|
640
bd1354127574
more proofreading done, last version before submission
Chengsong
parents:
639
diff
changeset
|
797 |
We use Isabelle's $set$ to refer to the |
611 | 798 |
function that converts a list $rs$ to the set |
799 |
containing all the elements in $rs$. |
|
800 |
\subsubsection{$\textit{rdistinct}$'s Does the Job of De-duplication} |
|
543 | 801 |
The $\textit{rdistinct}$ function, as its name suggests, will |
613 | 802 |
de-duplicate an r-regular expression list. |
803 |
It will also remove any elements that |
|
640
bd1354127574
more proofreading done, last version before submission
Chengsong
parents:
639
diff
changeset
|
804 |
are already in the accumulator set. |
555 | 805 |
\begin{lemma}\label{rdistinctDoesTheJob} |
609 | 806 |
%The function $\textit{rdistinct}$ satisfies the following |
807 |
%properties: |
|
808 |
Assume we have the predicate $\textit{isDistinct}$\footnote{We omit its |
|
618 | 809 |
recursive definition here. Its Isabelle counterpart would be $\textit{distinct}$.} |
609 | 810 |
for testing |
613 | 811 |
whether a list's elements are unique. Then the following |
609 | 812 |
properties about $\textit{rdistinct}$ hold: |
543 | 813 |
\begin{itemize} |
814 |
\item |
|
815 |
If $a \in acc$ then $a \notin (\rdistinct{rs}{acc})$. |
|
816 |
\item |
|
609 | 817 |
%If list $rs'$ is the result of $\rdistinct{rs}{acc}$, |
818 |
$\textit{isDistinct} \;\;\; (\rdistinct{rs}{acc})$. |
|
555 | 819 |
\item |
609 | 820 |
$\textit{set} \; (\rdistinct{rs}{acc}) |
639 | 821 |
= (\textit{set} \; rs) - acc$ |
543 | 822 |
\end{itemize} |
823 |
\end{lemma} |
|
555 | 824 |
\noindent |
543 | 825 |
\begin{proof} |
826 |
The first part is by an induction on $rs$. |
|
640
bd1354127574
more proofreading done, last version before submission
Chengsong
parents:
639
diff
changeset
|
827 |
The second and third parts can be proven by using the |
609 | 828 |
inductive cases of $\textit{rdistinct}$. |
593 | 829 |
|
543 | 830 |
\end{proof} |
831 |
||
832 |
\noindent |
|
613 | 833 |
%$\textit{rdistinct}$ will out all regular expression terms |
834 |
%that are in the accumulator, therefore |
|
835 |
Concatenating a list $rs_a$ at the front of another |
|
836 |
list $rs$ whose elements are all from the accumulator, and then calling $\textit{rdistinct}$ |
|
837 |
on the merged list, the output will be as if we had called $\textit{rdistinct}$ |
|
543 | 838 |
without the prepending of $rs$: |
609 | 839 |
\begin{lemma}\label{rdistinctConcat} |
554 | 840 |
The elements appearing in the accumulator will always be removed. |
841 |
More precisely, |
|
842 |
\begin{itemize} |
|
843 |
\item |
|
844 |
If $rs \subseteq rset$, then |
|
845 |
$\rdistinct{rs@rsa }{acc} = \rdistinct{rsa }{acc}$. |
|
846 |
\item |
|
609 | 847 |
More generally, if $a \in rset$ and $\rdistinct{rs}{\{a\}} = []$, |
554 | 848 |
then $\rdistinct{(rs @ rs')}{rset} = \rdistinct{rs'}{rset}$ |
849 |
\end{itemize} |
|
543 | 850 |
\end{lemma} |
554 | 851 |
|
543 | 852 |
\begin{proof} |
609 | 853 |
By induction on $rs$ and using \ref{rdistinctDoesTheJob}. |
543 | 854 |
\end{proof} |
855 |
\noindent |
|
856 |
On the other hand, if an element $r$ does not appear in the input list waiting to be deduplicated, |
|
857 |
then expanding the accumulator to include that element will not cause the output list to change: |
|
611 | 858 |
\begin{lemma}\label{rdistinctOnDistinct} |
543 | 859 |
The accumulator can be augmented to include elements not appearing in the input list, |
860 |
and the output will not change. |
|
861 |
\begin{itemize} |
|
862 |
\item |
|
611 | 863 |
If $r \notin rs$, then $\rdistinct{rs}{acc} = \rdistinct{rs}{(\{r\} \cup acc)}$. |
543 | 864 |
\item |
611 | 865 |
Particularly, if $\;\;\textit{isDistinct} \; rs$, then we have\\ |
543 | 866 |
\[ \rdistinct{rs}{\varnothing} = rs \] |
867 |
\end{itemize} |
|
868 |
\end{lemma} |
|
869 |
\begin{proof} |
|
870 |
The first half is by induction on $rs$. The second half is a corollary of the first. |
|
871 |
\end{proof} |
|
872 |
\noindent |
|
611 | 873 |
The function $\textit{rdistinct}$ removes duplicates from anywhere in a list. |
874 |
Despite being seemingly obvious, |
|
875 |
the induction technique is not as straightforward. |
|
554 | 876 |
\begin{lemma}\label{distinctRemovesMiddle} |
877 |
The two properties hold if $r \in rs$: |
|
878 |
\begin{itemize} |
|
879 |
\item |
|
555 | 880 |
$\rdistinct{rs}{rset} = \rdistinct{(rs @ [r])}{rset}$\\ |
881 |
and\\ |
|
554 | 882 |
$\rdistinct{(ab :: rs @ [ab])}{rset'} = \rdistinct{(ab :: rs)}{rset'}$ |
883 |
\item |
|
555 | 884 |
$\rdistinct{ (rs @ rs') }{rset} = \rdistinct{rs @ [r] @ rs'}{rset}$\\ |
885 |
and\\ |
|
554 | 886 |
$\rdistinct{(ab :: rs @ [ab] @ rs'')}{rset'} = |
593 | 887 |
\rdistinct{(ab :: rs @ rs'')}{rset'}$ |
554 | 888 |
\end{itemize} |
889 |
\end{lemma} |
|
890 |
\noindent |
|
891 |
\begin{proof} |
|
593 | 892 |
By induction on $rs$. All other variables are allowed to be arbitrary. |
611 | 893 |
The second part of the lemma requires the first. |
618 | 894 |
Note that for each part, the two sub-propositions need to be proven |
895 |
at the same time, |
|
593 | 896 |
so that the induction goes through. |
554 | 897 |
\end{proof} |
555 | 898 |
\noindent |
611 | 899 |
This allows us to prove a few more equivalence relations involving |
618 | 900 |
$\textit{rdistinct}$ (they will be useful later): |
555 | 901 |
\begin{lemma}\label{rdistinctConcatGeneral} |
611 | 902 |
\mbox{} |
555 | 903 |
\begin{itemize} |
904 |
\item |
|
905 |
$\rdistinct{(rs @ rs')}{\varnothing} = \rdistinct{((\rdistinct{rs}{\varnothing})@ rs')}{\varnothing}$ |
|
906 |
\item |
|
907 |
$\rdistinct{(rs @ rs')}{\varnothing} = \rdistinct{(\rdistinct{rs}{\varnothing} @ rs')}{\varnothing}$ |
|
908 |
\item |
|
909 |
If $rset' \subseteq rset$, then $\rdistinct{rs}{rset} = |
|
910 |
\rdistinct{(\rdistinct{rs}{rset'})}{rset}$. As a corollary |
|
911 |
of this, |
|
912 |
\item |
|
913 |
$\rdistinct{(rs @ rs')}{rset} = \rdistinct{ |
|
914 |
(\rdistinct{rs}{\varnothing}) @ rs')}{rset}$. This |
|
915 |
gives another corollary use later: |
|
916 |
\item |
|
917 |
If $a \in rset$, then $\rdistinct{(rs @ rs')}{rset} = \rdistinct{ |
|
918 |
(\rdistinct{(a :: rs)}{\varnothing} @ rs')}{rset} $, |
|
919 |
||
920 |
\end{itemize} |
|
921 |
\end{lemma} |
|
922 |
\begin{proof} |
|
923 |
By \ref{rdistinctDoesTheJob} and \ref{distinctRemovesMiddle}. |
|
924 |
\end{proof} |
|
611 | 925 |
\noindent |
639 | 926 |
The next lemma is a more general form of \ref{rdistinctConcat}; |
927 |
It says that |
|
611 | 928 |
$\textit{rdistinct}$ is composable w.r.t list concatenation: |
929 |
\begin{lemma}\label{distinctRdistinctAppend} |
|
930 |
If $\;\; \textit{isDistinct} \; rs_1$, |
|
931 |
and $(set \; rs_1) \cap acc = \varnothing$, |
|
932 |
then applying $\textit{rdistinct}$ on $rs_1 @ rs_a$ does not |
|
933 |
have an effect on $rs_1$: |
|
934 |
\[\textit{rdistinct}\; (rs_1 @ rsa)\;\, acc |
|
935 |
= rs_1@(\textit{rdistinct} rsa \; (acc \cup rs_1))\] |
|
936 |
\end{lemma} |
|
937 |
\begin{proof} |
|
938 |
By an induction on |
|
939 |
$rs_1$, where $rsa$ and $acc$ are allowed to be arbitrary. |
|
940 |
\end{proof} |
|
941 |
\noindent |
|
942 |
$\textit{rdistinct}$ needs to be applied only once, and |
|
618 | 943 |
applying it multiple times does not make any difference: |
611 | 944 |
\begin{corollary}\label{distinctOnceEnough} |
639 | 945 |
$\textit{rdistinct} \; (rs @ rsa) {} = \textit{rdistinct} \; ( (rdistinct \; |
946 |
rs \; \{ \}) @ (\textit{rdistinct} \; rs_a \; (set \; rs)))$ |
|
611 | 947 |
\end{corollary} |
948 |
\begin{proof} |
|
949 |
By lemma \ref{distinctRdistinctAppend}. |
|
950 |
\end{proof} |
|
555 | 951 |
|
611 | 952 |
\subsubsection{The Properties of $\textit{Rflts}$} |
953 |
We give in this subsection some properties |
|
620 | 954 |
involving $\backslash_r$, $\backslash_{rsimps}$, $\textit{rflts}$ and |
611 | 955 |
$\textit{rsimp}_{ALTS} $, together with any non-trivial lemmas that lead to them. |
640
bd1354127574
more proofreading done, last version before submission
Chengsong
parents:
639
diff
changeset
|
956 |
These will be helpful in later closed-form proofs, when |
611 | 957 |
we want to transform derivative terms which have |
958 |
%the ways in which multiple functions involving |
|
959 |
%those are composed together |
|
640
bd1354127574
more proofreading done, last version before submission
Chengsong
parents:
639
diff
changeset
|
960 |
interleaving derivatives and simplifications applied to them. |
543 | 961 |
|
611 | 962 |
\noindent |
963 |
%When the function $\textit{Rflts}$ |
|
640
bd1354127574
more proofreading done, last version before submission
Chengsong
parents:
639
diff
changeset
|
964 |
%is applied to the concatenation of two lists; the output can be calculated by first applying the |
bd1354127574
more proofreading done, last version before submission
Chengsong
parents:
639
diff
changeset
|
965 |
%functions on two lists separately and then concatenating them together. |
611 | 966 |
$\textit{Rflts}$ is composable in terms of concatenation: |
554 | 967 |
\begin{lemma}\label{rfltsProps} |
618 | 968 |
The function $\rflts$ has the properties below:\\ |
543 | 969 |
\begin{itemize} |
970 |
\item |
|
554 | 971 |
$\rflts \; (rs_1 @ rs_2) = \rflts \; rs_1 @ \rflts \; rs_2$ |
972 |
\item |
|
973 |
If $r \neq \RZERO$ and $\nexists rs_1. r = \RALTS{rs}_1$, then $\rflts \; (r::rs) = r :: \rflts \; rs$ |
|
974 |
\item |
|
975 |
$\rflts \; (rs @ [\RZERO]) = \rflts \; rs$ |
|
976 |
\item |
|
977 |
$\rflts \; (rs' @ [\RALTS{rs}]) = \rflts \; rs'@rs$ |
|
978 |
\item |
|
979 |
$\rflts \; (rs @ [\RONE]) = \rflts \; rs @ [\RONE]$ |
|
980 |
\item |
|
981 |
If $r \neq \RZERO$ and $\nexists rs'. r = \RALTS{rs'}$ then $\rflts \; (rs @ [r]) |
|
982 |
= (\rflts \; rs) @ [r]$ |
|
555 | 983 |
\item |
984 |
If $r = \RALTS{rs}$ and $r \in rs'$ then for all $r_1 \in rs. |
|
985 |
r_1 \in \rflts \; rs'$. |
|
986 |
\item |
|
987 |
$\rflts \; (rs_a @ \RZERO :: rs_b) = \rflts \; (rs_a @ rs_b)$ |
|
543 | 988 |
\end{itemize} |
989 |
\end{lemma} |
|
990 |
\noindent |
|
991 |
\begin{proof} |
|
555 | 992 |
By induction on $rs_1$ in the first sub-lemma, and induction on $r$ in the second part, |
993 |
and induction on $rs$, $rs'$, $rs$, $rs'$, $rs_a$ in the third, fourth, fifth, sixth and |
|
994 |
last sub-lemma. |
|
543 | 995 |
\end{proof} |
611 | 996 |
\noindent |
997 |
Now we introduce the property that the operations |
|
998 |
derivative and $\rsimpalts$ |
|
639 | 999 |
commute, this will be used later on when deriving the closed form for |
611 | 1000 |
the alternative regular expression: |
1001 |
\begin{lemma}\label{rderRsimpAltsCommute} |
|
1002 |
$\rder{x}{(\rsimpalts \; rs)} = \rsimpalts \; (\map \; (\rder{x}{\_}) \; rs)$ |
|
1003 |
\end{lemma} |
|
618 | 1004 |
\begin{proof} |
1005 |
By induction on $rs$. |
|
1006 |
\end{proof} |
|
611 | 1007 |
\noindent |
614 | 1008 |
|
639 | 1009 |
\subsubsection{The $RL$ Function: Language Interpretation for $\textit{Rrexp}$s} |
618 | 1010 |
Much like the definition of $L$ on plain regular expressions, one can also |
639 | 1011 |
define the language interpretation for $\rrexp$s. |
614 | 1012 |
\begin{center} |
1013 |
\begin{tabular}{lcl} |
|
639 | 1014 |
$RL \; (\ZERO_r)$ & $\dn$ & $\phi$\\ |
1015 |
$RL \; (\ONE_r)$ & $\dn$ & $\{[]\}$\\ |
|
614 | 1016 |
$RL \; (c)$ & $\dn$ & $\{[c]\}$\\ |
1017 |
$RL \; \sum rs$ & $\dn$ & $ \bigcup_{r \in rs} (RL \; r)$\\ |
|
1018 |
$RL \; (r_1 \cdot r_2)$ & $\dn$ & $ RL \; (r_1) @ RL \; (r_2)$\\ |
|
1019 |
$RL \; (r^*)$ & $\dn$ & $ (RL(r))^*$ |
|
1020 |
\end{tabular} |
|
1021 |
\end{center} |
|
1022 |
\noindent |
|
1023 |
The main use of $RL$ is to establish some connections between $\rsimp{}$ |
|
1024 |
and $\rnullable{}$: |
|
1025 |
\begin{lemma} |
|
1026 |
The following properties hold: |
|
1027 |
\begin{itemize} |
|
1028 |
\item |
|
1029 |
If $\rnullable{r}$, then $\rsimp{r} \neq \RZERO$. |
|
1030 |
\item |
|
1031 |
$\rnullable{r \backslash s} \quad $ if and only if $\quad \rnullable{\rderssimp{r}{s}}$. |
|
1032 |
\end{itemize} |
|
1033 |
\end{lemma} |
|
1034 |
\begin{proof} |
|
1035 |
The first part is by induction on $r$. |
|
1036 |
The second part is true because property |
|
1037 |
\[ RL \; r = RL \; (\rsimp{r})\] holds. |
|
1038 |
\end{proof} |
|
1039 |
||
1040 |
\subsubsection{Simplified $\textit{Rrexp}$s are Good} |
|
1041 |
We formalise the notion of ``good" regular expressions, |
|
1042 |
which means regular expressions that |
|
618 | 1043 |
are fully simplified in terms of our $\textit{rsimp}$ function. |
1044 |
For alternative regular expressions that means they |
|
1045 |
do not contain any nested alternatives, un-eliminated $\RZERO$s |
|
1046 |
or duplicate elements (for example, |
|
1047 |
$r_1 + (r_2 + r_3)$, $\RZERO + r$ and $ \sum [r, r, \ldots]$). |
|
1048 |
The clauses for $\good$ are: |
|
614 | 1049 |
\begin{center} |
1050 |
\begin{tabular}{@{}lcl@{}} |
|
1051 |
$\good\; \RZERO$ & $\dn$ & $\textit{false}$\\ |
|
1052 |
$\good\; \RONE$ & $\dn$ & $\textit{true}$\\ |
|
1053 |
$\good\; \RCHAR{c}$ & $\dn$ & $\btrue$\\ |
|
1054 |
$\good\; \RALTS{[]}$ & $\dn$ & $\bfalse$\\ |
|
1055 |
$\good\; \RALTS{[r]}$ & $\dn$ & $\bfalse$\\ |
|
1056 |
$\good\; \RALTS{r_1 :: r_2 :: rs}$ & $\dn$ & |
|
1057 |
$\textit{isDistinct} \; (r_1 :: r_2 :: rs) \;$\\ |
|
618 | 1058 |
& & $\land \; (\forall r' \in (r_1 :: r_2 :: rs).\; \good \; r'\; \, \land \; \, \textit{nonAlt}\; r')$\\ |
614 | 1059 |
$\good \; \RSEQ{\RZERO}{r}$ & $\dn$ & $\bfalse$\\ |
1060 |
$\good \; \RSEQ{\RONE}{r}$ & $\dn$ & $\bfalse$\\ |
|
1061 |
$\good \; \RSEQ{r}{\RZERO}$ & $\dn$ & $\bfalse$\\ |
|
1062 |
$\good \; \RSEQ{r_1}{r_2}$ & $\dn$ & $\good \; r_1 \;\, \textit{and} \;\, \good \; r_2$\\ |
|
1063 |
$\good \; \RSTAR{r}$ & $\dn$ & $\btrue$\\ |
|
1064 |
\end{tabular} |
|
1065 |
\end{center} |
|
1066 |
\noindent |
|
618 | 1067 |
We omit the recursive definition of the predicate $\textit{nonAlt}$, |
1068 |
which evaluates to true when the regular expression is not an |
|
614 | 1069 |
alternative, and false otherwise. |
1070 |
The $\good$ property is preserved under $\rsimp_{ALTS}$, provided that |
|
640
bd1354127574
more proofreading done, last version before submission
Chengsong
parents:
639
diff
changeset
|
1071 |
its non-empty argument list of expressions are all good themselves, and $\textit{nonAlt}$, |
614 | 1072 |
and unique: |
1073 |
\begin{lemma}\label{rsimpaltsGood} |
|
640
bd1354127574
more proofreading done, last version before submission
Chengsong
parents:
639
diff
changeset
|
1074 |
If $rs \neq []$ and for all $r \in rs. \textit{nonAlt} \; r$ and $\textit{isDistinct} \; rs$, |
614 | 1075 |
then $\good \; (\rsimpalts \; rs)$ if and only if forall $r \in rs. \; \good \; r$. |
1076 |
\end{lemma} |
|
1077 |
\noindent |
|
1078 |
We also note that |
|
1079 |
if a regular expression $r$ is good, then $\rflts$ on the singleton |
|
1080 |
list $[r]$ will not break goodness: |
|
1081 |
\begin{lemma}\label{flts2} |
|
1082 |
If $\good \; r$, then forall $r' \in \rflts \; [r]. \; \good \; r'$ and $\textit{nonAlt} \; r'$. |
|
1083 |
\end{lemma} |
|
1084 |
\begin{proof} |
|
1085 |
By an induction on $r$. |
|
1086 |
\end{proof} |
|
1087 |
\noindent |
|
1088 |
The other observation we make about $\rsimp{r}$ is that it never |
|
1089 |
comes with nested alternatives, which we describe as the $\nonnested$ |
|
1090 |
property: |
|
1091 |
\begin{center} |
|
1092 |
\begin{tabular}{lcl} |
|
1093 |
$\nonnested \; \, \sum []$ & $\dn$ & $\btrue$\\ |
|
1094 |
$\nonnested \; \, \sum ((\sum rs_1) :: rs_2)$ & $\dn$ & $\bfalse$\\ |
|
1095 |
$\nonnested \; \, \sum (r :: rs)$ & $\dn$ & $\nonnested (\sum rs)$\\ |
|
1096 |
$\nonnested \; \, r $ & $\dn$ & $\btrue$ |
|
1097 |
\end{tabular} |
|
1098 |
\end{center} |
|
1099 |
\noindent |
|
1100 |
The $\rflts$ function |
|
1101 |
always opens up nested alternatives, |
|
1102 |
which enables $\rsimp$ to be non-nested: |
|
1103 |
||
1104 |
\begin{lemma}\label{nonnestedRsimp} |
|
618 | 1105 |
It is always the case that |
1106 |
\begin{center} |
|
1107 |
$\nonnested \; (\rsimp{r})$ |
|
1108 |
\end{center} |
|
614 | 1109 |
\end{lemma} |
1110 |
\begin{proof} |
|
618 | 1111 |
By induction on $r$. |
614 | 1112 |
\end{proof} |
1113 |
\noindent |
|
640
bd1354127574
more proofreading done, last version before submission
Chengsong
parents:
639
diff
changeset
|
1114 |
With this we can prove that a regular expression |
614 | 1115 |
after simplification and flattening and de-duplication, |
1116 |
will not contain any alternative regular expression directly: |
|
1117 |
\begin{lemma}\label{nonaltFltsRd} |
|
1118 |
If $x \in \rdistinct{\rflts\; (\map \; \rsimp{} \; rs)}{\varnothing}$ |
|
1119 |
then $\textit{nonAlt} \; x$. |
|
1120 |
\end{lemma} |
|
1121 |
\begin{proof} |
|
1122 |
By \ref{nonnestedRsimp}. |
|
1123 |
\end{proof} |
|
1124 |
\noindent |
|
618 | 1125 |
The other fact we know is that once $\rsimp{}$ has finished |
614 | 1126 |
processing an alternative regular expression, it will not |
618 | 1127 |
contain any $\RZERO$s. This is because all the recursive |
614 | 1128 |
calls to the simplification on the children regular expressions |
618 | 1129 |
make the children good, and $\rflts$ will not delete |
614 | 1130 |
any $\RZERO$s out of a good regular expression list, |
618 | 1131 |
and $\rdistinct{}$ will not ``mess'' with the result. |
614 | 1132 |
\begin{lemma}\label{flts3Obv} |
1133 |
The following are true: |
|
1134 |
\begin{itemize} |
|
1135 |
\item |
|
1136 |
If for all $r \in rs. \, \good \; r $ or $r = \RZERO$, |
|
1137 |
then for all $r \in \rflts\; rs. \, \good \; r$. |
|
1138 |
\item |
|
1139 |
If $x \in \rdistinct{\rflts\; (\map \; rsimp{}\; rs)}{\varnothing}$ |
|
1140 |
and for all $y$ such that $\llbracket y \rrbracket_r$ less than |
|
1141 |
$\llbracket rs \rrbracket_r + 1$, either |
|
1142 |
$\good \; (\rsimp{y})$ or $\rsimp{y} = \RZERO$, |
|
1143 |
then $\good \; x$. |
|
1144 |
\end{itemize} |
|
1145 |
\end{lemma} |
|
1146 |
\begin{proof} |
|
640
bd1354127574
more proofreading done, last version before submission
Chengsong
parents:
639
diff
changeset
|
1147 |
The first part is by induction, where the inductive cases |
bd1354127574
more proofreading done, last version before submission
Chengsong
parents:
639
diff
changeset
|
1148 |
are the inductive cases of $\rflts$. |
614 | 1149 |
The second part is a corollary from the first part. |
1150 |
\end{proof} |
|
1151 |
||
639 | 1152 |
This leads to good structural property of $\rsimp{}$, |
614 | 1153 |
that after simplification, a regular expression is |
1154 |
either good or $\RZERO$: |
|
1155 |
\begin{lemma}\label{good1} |
|
1156 |
For any r-regular expression $r$, $\good \; \rsimp{r}$ or $\rsimp{r} = \RZERO$. |
|
1157 |
\end{lemma} |
|
1158 |
\begin{proof} |
|
1159 |
By an induction on $r$. The inductive measure is the size $\llbracket \rrbracket_r$. |
|
618 | 1160 |
Lemma \ref{rsimpMono} says that |
614 | 1161 |
$\llbracket \rsimp{r}\rrbracket_r$ is smaller than or equal to |
1162 |
$\llbracket r \rrbracket_r$. |
|
1163 |
Therefore, in the $r_1 \cdot r_2$ and $\sum rs$ case, |
|
640
bd1354127574
more proofreading done, last version before submission
Chengsong
parents:
639
diff
changeset
|
1164 |
The inductive hypothesis applies to the children regular expressions |
614 | 1165 |
$r_1$, $r_2$, etc. The lemma \ref{flts3Obv}'s precondition is satisfied |
1166 |
by that as well. |
|
1167 |
The lemmas \ref{nonnestedRsimp} and \ref{nonaltFltsRd} are used |
|
1168 |
to ensure that goodness is preserved at the topmost level. |
|
1169 |
\end{proof} |
|
1170 |
We shall prove that any good regular expression is |
|
639 | 1171 |
a fixed-point for $\textit{rsimp}$. |
614 | 1172 |
First we prove an auxiliary lemma: |
1173 |
\begin{lemma}\label{goodaltsNonalt} |
|
1174 |
If $\good \; \sum rs$, then $\rflts\; rs = rs$. |
|
1175 |
\end{lemma} |
|
1176 |
\begin{proof} |
|
1177 |
By an induction on $\sum rs$. The inductive rules are the cases |
|
1178 |
for $\good$. |
|
1179 |
\end{proof} |
|
1180 |
\noindent |
|
1181 |
Now we are ready to prove that good regular expressions are invariant |
|
618 | 1182 |
with respect to $\rsimp{}$: |
614 | 1183 |
\begin{lemma}\label{test} |
1184 |
If $\good \;r$ then $\rsimp{r} = r$. |
|
1185 |
\end{lemma} |
|
1186 |
\begin{proof} |
|
1187 |
By an induction on the inductive cases of $\good$, using lemmas |
|
1188 |
\ref{goodaltsNonalt} and \ref{rdistinctOnDistinct}. |
|
1189 |
The lemma \ref{goodaltsNonalt} is used in the alternative |
|
1190 |
case where 2 or more elements are present in the list. |
|
1191 |
\end{proof} |
|
1192 |
\noindent |
|
639 | 1193 |
Below we show a property involving $\rflts$, $\textit{rdistinct}$, |
618 | 1194 |
$\rsimp{}$ and $\rsimp_{ALTS}$, |
1195 |
which requires $\ref{good1}$ to go through smoothly: |
|
614 | 1196 |
\begin{lemma}\label{flattenRsimpalts} |
618 | 1197 |
An application of $\rsimp_{ALTS}$ can be ``absorbed'', |
1198 |
if its output is concatenated with a list and then applied to $\rflts$. |
|
1199 |
\begin{center} |
|
614 | 1200 |
$\rflts \; ( (\rsimp_{ALTS} \; |
1201 |
(\rdistinct{(\rflts \; (\map \; \rsimp{}\; rs))}{\varnothing})) :: |
|
1202 |
\map \; \rsimp{} \; rs' ) = |
|
1203 |
\rflts \; ( (\rdistinct{(\rflts \; (\map \; \rsimp{}\; rs))}{\varnothing}) @ ( |
|
1204 |
\map \; \rsimp{rs'}))$ |
|
618 | 1205 |
\end{center} |
614 | 1206 |
|
1207 |
||
1208 |
\end{lemma} |
|
1209 |
\begin{proof} |
|
1210 |
By \ref{good1}. |
|
1211 |
\end{proof} |
|
1212 |
\noindent |
|
1213 |
||
1214 |
||
1215 |
||
1216 |
||
1217 |
||
1218 |
We are also ready to prove that $\textit{rsimp}$ is idempotent. |
|
1219 |
\subsubsection{$\rsimp$ is Idempotent} |
|
1220 |
The idempotency of $\rsimp$ is very useful in |
|
1221 |
manipulating regular expression terms into desired |
|
1222 |
forms so that key steps allowing further rewriting to closed forms |
|
1223 |
are possible. |
|
1224 |
\begin{lemma}\label{rsimpIdem} |
|
618 | 1225 |
$\rsimp{r} = \rsimp{(\rsimp{r})}$ |
614 | 1226 |
\end{lemma} |
1227 |
||
1228 |
\begin{proof} |
|
1229 |
By \ref{test} and \ref{good1}. |
|
1230 |
\end{proof} |
|
1231 |
\noindent |
|
1232 |
This property means we do not have to repeatedly |
|
1233 |
apply simplification in each step, which justifies |
|
1234 |
our definition of $\blexersimp$. |
|
639 | 1235 |
This is in contrast to the work of Sulzmann and Lu where |
1236 |
the simplification is applied in a fixpoint manner. |
|
614 | 1237 |
|
1238 |
||
618 | 1239 |
On the other hand, we can repeat the same $\rsimp{}$ applications |
614 | 1240 |
on regular expressions as many times as we want, if we have at least |
639 | 1241 |
one simplification applied to it, and apply it wherever we need to: |
614 | 1242 |
\begin{corollary}\label{headOneMoreSimp} |
1243 |
The following properties hold, directly from \ref{rsimpIdem}: |
|
1244 |
||
1245 |
\begin{itemize} |
|
1246 |
\item |
|
1247 |
$\map \; \rsimp{(r :: rs)} = \map \; \rsimp{} \; (\rsimp{r} :: rs)$ |
|
1248 |
\item |
|
1249 |
$\rsimp{(\RALTS{rs})} = \rsimp{(\RALTS{\map \; \rsimp{} \; rs})}$ |
|
1250 |
\end{itemize} |
|
1251 |
\end{corollary} |
|
1252 |
\noindent |
|
640
bd1354127574
more proofreading done, last version before submission
Chengsong
parents:
639
diff
changeset
|
1253 |
This will be useful in the later closed-form proof's rewriting steps. |
618 | 1254 |
Similarly, we state the following useful facts below: |
614 | 1255 |
\begin{lemma} |
1256 |
The following equalities hold if $r = \rsimp{r'}$ for some $r'$: |
|
1257 |
\begin{itemize} |
|
1258 |
\item |
|
1259 |
If $r = \sum rs$ then $\rsimpalts \; rs = \sum rs$. |
|
1260 |
\item |
|
1261 |
If $r = \sum rs$ then $\rdistinct{rs}{\varnothing} = rs$. |
|
1262 |
\item |
|
1263 |
$\rsimpalts \; (\rdistinct{\rflts \; [r]}{\varnothing}) = r$. |
|
1264 |
\end{itemize} |
|
1265 |
\end{lemma} |
|
1266 |
\begin{proof} |
|
1267 |
By application of lemmas \ref{rsimpIdem} and \ref{good1}. |
|
1268 |
\end{proof} |
|
1269 |
||
1270 |
\noindent |
|
639 | 1271 |
With the idempotency of $\textit{rsimp}$ and its corollaries, |
614 | 1272 |
we can start proving some key equalities leading to the |
1273 |
closed forms. |
|
639 | 1274 |
Next we present a few equivalent terms under $\textit{rsimp}$. |
618 | 1275 |
To make the notation more concise |
639 | 1276 |
We use $r_1 \sequal r_2 $ to denote that $\rsimp{r_1} = \rsimp{r_2}$. |
1277 |
%\begin{center} |
|
1278 |
%\begin{tabular}{lcl} |
|
1279 |
% $a \sequal b$ & $ \dn$ & $ \textit{rsimp} \; a = \textit{rsimp} \; b$ |
|
1280 |
%\end{tabular} |
|
1281 |
%\end{center} |
|
1282 |
%\noindent |
|
618 | 1283 |
%\vspace{0em} |
614 | 1284 |
\begin{lemma} |
618 | 1285 |
The following equivalence hold: |
614 | 1286 |
\begin{itemize} |
1287 |
\item |
|
1288 |
$\rsimpalts \; (\RZERO :: rs) \sequal \rsimpalts\; rs$ |
|
1289 |
\item |
|
1290 |
$\rsimpalts \; rs \sequal \rsimpalts (\map \; \rsimp{} \; rs)$ |
|
1291 |
\item |
|
1292 |
$\RALTS{\RALTS{rs}} \sequal \RALTS{rs}$ |
|
1293 |
\item |
|
1294 |
$\sum ((\sum rs_a) :: rs_b) \sequal \sum rs_a @ rs_b$ |
|
1295 |
\item |
|
639 | 1296 |
$\RALTS{rs} \sequal \RALTS{\map \; \rsimp{} \; rs}$ |
614 | 1297 |
\end{itemize} |
1298 |
\end{lemma} |
|
1299 |
\begin{proof} |
|
1300 |
By induction on the lists involved. |
|
1301 |
\end{proof} |
|
1302 |
\noindent |
|
1303 |
The above allows us to prove |
|
1304 |
two similar equalities (which are a bit more involved). |
|
618 | 1305 |
It says that we could flatten the elements |
614 | 1306 |
before simplification and still get the same result. |
1307 |
\begin{lemma}\label{simpFlatten3} |
|
1308 |
One can flatten the inside $\sum$ of a $\sum$ if it is being |
|
1309 |
simplified. Concretely, |
|
1310 |
\begin{itemize} |
|
1311 |
\item |
|
1312 |
If for all $r \in rs, rs', rs''$, we have $\good \; r $ |
|
1313 |
or $r = \RZERO$, then $\sum (rs' @ rs @ rs'') \sequal |
|
1314 |
\sum (rs' @ [\sum rs] @ rs'')$ holds. As a corollary, |
|
1315 |
\item |
|
1316 |
$\sum (rs' @ [\sum rs] @ rs'') \sequal \sum (rs' @ rs @ rs'')$ |
|
1317 |
\end{itemize} |
|
1318 |
\end{lemma} |
|
1319 |
\begin{proof} |
|
1320 |
By rewriting steps involving the use of \ref{test} and \ref{rdistinctConcatGeneral}. |
|
1321 |
The second sub-lemma is a corollary of the previous. |
|
1322 |
\end{proof} |
|
1323 |
%Rewriting steps not put in--too long and complicated------------------------------- |
|
1324 |
\begin{comment} |
|
1325 |
\begin{center} |
|
1326 |
$\rsimp{\sum (rs' @ rs @ rs'')} \stackrel{def of bsimp}{=}$ \\ |
|
1327 |
$\rsimpalts \; (\rdistinct{\rflts \; ((\map \; \rsimp{}\; rs') @ (\map \; \rsimp{} \; rs ) @ (\map \; \rsimp{} \; rs''))}{\varnothing})$ \\ |
|
1328 |
$\stackrel{by \ref{test}}{=} |
|
1329 |
\rsimpalts \; (\rdistinct{(\rflts \; rs' @ \rflts \; rs @ \rflts \; rs'')}{ |
|
1330 |
\varnothing})$\\ |
|
1331 |
$\stackrel{by \ref{rdistinctConcatGeneral}}{=} |
|
1332 |
\rsimpalts \; (\rdistinct{\rflts \; rs'}{\varnothing} @ \rdistinct{( |
|
1333 |
\rflts\; rs @ \rflts \; rs'')}{\rflts \; rs'})$\\ |
|
1334 |
||
1335 |
\end{center} |
|
1336 |
\end{comment} |
|
1337 |
%Rewriting steps not put in--too long and complicated------------------------------- |
|
1338 |
\noindent |
|
1339 |
||
1340 |
||
618 | 1341 |
We need more equalities like the above to enable a closed form lemma, |
613 | 1342 |
for which we need to introduce a few rewrite relations |
1343 |
to help |
|
1344 |
us obtain them. |
|
554 | 1345 |
|
610 | 1346 |
\subsection{The rewrite relation $\hrewrite$ , $\scfrewrites$ , $\frewrite$ and $\grewrite$} |
613 | 1347 |
Inspired by the success we had in the correctness proof |
1348 |
in \ref{Bitcoded2}, |
|
1349 |
we follow suit here, defining atomic simplification |
|
1350 |
steps as ``small-step'' rewriting steps. This allows capturing |
|
555 | 1351 |
similarities between terms that would be otherwise |
1352 |
hard to express. |
|
1353 |
||
557 | 1354 |
We use $\hrewrite$ for one-step atomic rewrite of |
1355 |
regular expression simplification, |
|
555 | 1356 |
$\frewrite$ for rewrite of list of regular expressions that |
1357 |
include all operations carried out in $\rflts$, and $\grewrite$ for |
|
613 | 1358 |
rewriting a list of regular expressions possible in both $\rflts$ and $\textit{rdistinct}$. |
555 | 1359 |
Their reflexive transitive closures are used to denote zero or many steps, |
1360 |
as was the case in the previous chapter. |
|
613 | 1361 |
As we have already |
1362 |
done something similar, the presentation about |
|
1363 |
these rewriting rules will be more concise than that in \ref{Bitcoded2}. |
|
554 | 1364 |
To differentiate between the rewriting steps for annotated regular expressions |
1365 |
and $\rrexp$s, we add characters $h$ and $g$ below the squig arrow symbol |
|
1366 |
to mean atomic simplification transitions |
|
1367 |
of $\rrexp$s and $\rrexp$ lists, respectively. |
|
1368 |
||
555 | 1369 |
|
1370 |
||
1371 |
||
613 | 1372 |
\begin{figure}[H] |
554 | 1373 |
\begin{center} |
593 | 1374 |
\begin{mathpar} |
1375 |
\inferrule[RSEQ0L]{}{\RZERO \cdot r_2 \hrewrite \RZERO\\} |
|
555 | 1376 |
|
593 | 1377 |
\inferrule[RSEQ0R]{}{r_1 \cdot \RZERO \hrewrite \RZERO\\} |
555 | 1378 |
|
593 | 1379 |
\inferrule[RSEQ1]{}{(\RONE \cdot r) \hrewrite r\\}\\ |
555 | 1380 |
|
593 | 1381 |
\inferrule[RSEQL]{ r_1 \hrewrite r_2}{r_1 \cdot r_3 \hrewrite r_2 \cdot r_3\\} |
1382 |
||
1383 |
\inferrule[RSEQR]{ r_3 \hrewrite r_4}{r_1 \cdot r_3 \hrewrite r_1 \cdot r_4\\}\\ |
|
555 | 1384 |
|
593 | 1385 |
\inferrule[RALTSChild]{r \hrewrite r'}{\sum (rs_1 @ [r] @ rs_2) \hrewrite \sum (rs_1 @ [r'] @ rs_2)\\} |
555 | 1386 |
|
593 | 1387 |
\inferrule[RALTS0]{}{\sum (rs_a @ [\RZERO] @ rs_b) \hrewrite \sum (rs_a @ rs_b)} |
555 | 1388 |
|
593 | 1389 |
\inferrule[RALTSNested]{}{\sum (rs_a @ [\sum rs_1] @ rs_b) \hrewrite \sum (rs_a @ rs_1 @ rs_b)} |
555 | 1390 |
|
593 | 1391 |
\inferrule[RALTSNil]{}{ \sum [] \hrewrite \RZERO\\} |
555 | 1392 |
|
593 | 1393 |
\inferrule[RALTSSingle]{}{ \sum [r] \hrewrite r\\} |
555 | 1394 |
|
593 | 1395 |
\inferrule[RALTSDelete]{\\ r_1 = r_2}{\sum rs_a @ [r_1] @ rs_b @ [r_2] @ rsc \hrewrite \sum rs_a @ [r_1] @ rs_b @ rs_c} |
555 | 1396 |
|
593 | 1397 |
\end{mathpar} |
555 | 1398 |
\end{center} |
613 | 1399 |
\caption{List of one-step rewrite rules for r-regular expressions ($\hrewrite$)}\label{hRewrite} |
1400 |
\end{figure} |
|
554 | 1401 |
|
557 | 1402 |
|
613 | 1403 |
Like $\rightsquigarrow_s$, it is |
1404 |
convenient to define rewrite rules for a list of regular expressions, |
|
593 | 1405 |
where each element can rewrite in many steps to the other (scf stands for |
1406 |
li\emph{s}t \emph{c}losed \emph{f}orm). This relation is similar to the |
|
1407 |
$\stackrel{s*}{\rightsquigarrow}$ for annotated regular expressions. |
|
557 | 1408 |
|
613 | 1409 |
\begin{figure}[H] |
557 | 1410 |
\begin{center} |
593 | 1411 |
\begin{mathpar} |
1412 |
\inferrule{}{[] \scfrewrites [] } |
|
613 | 1413 |
|
593 | 1414 |
\inferrule{r \hrewrites r' \\ rs \scfrewrites rs'}{r :: rs \scfrewrites r' :: rs'} |
1415 |
\end{mathpar} |
|
557 | 1416 |
\end{center} |
613 | 1417 |
\caption{List of one-step rewrite rules for a list of r-regular expressions}\label{scfRewrite} |
1418 |
\end{figure} |
|
555 | 1419 |
%frewrite |
593 | 1420 |
List of one-step rewrite rules for flattening |
1421 |
a list of regular expressions($\frewrite$): |
|
613 | 1422 |
\begin{figure}[H] |
555 | 1423 |
\begin{center} |
593 | 1424 |
\begin{mathpar} |
1425 |
\inferrule{}{\RZERO :: rs \frewrite rs \\} |
|
555 | 1426 |
|
593 | 1427 |
\inferrule{}{(\sum rs) :: rs_a \frewrite rs @ rs_a \\} |
555 | 1428 |
|
593 | 1429 |
\inferrule{rs_1 \frewrite rs_2}{r :: rs_1 \frewrite r :: rs_2} |
1430 |
\end{mathpar} |
|
555 | 1431 |
\end{center} |
613 | 1432 |
\caption{List of one-step rewrite rules characterising the $\rflts$ operation on a list}\label{fRewrites} |
1433 |
\end{figure} |
|
555 | 1434 |
|
593 | 1435 |
Lists of one-step rewrite rules for flattening and de-duplicating |
1436 |
a list of regular expressions ($\grewrite$): |
|
613 | 1437 |
\begin{figure}[H] |
555 | 1438 |
\begin{center} |
593 | 1439 |
\begin{mathpar} |
1440 |
\inferrule{}{\RZERO :: rs \grewrite rs \\} |
|
532 | 1441 |
|
593 | 1442 |
\inferrule{}{(\sum rs) :: rs_a \grewrite rs @ rs_a \\} |
555 | 1443 |
|
593 | 1444 |
\inferrule{rs_1 \grewrite rs_2}{r :: rs_1 \grewrite r :: rs_2} |
555 | 1445 |
|
593 | 1446 |
\inferrule[dB]{}{rs_a @ [a] @ rs_b @[a] @ rs_c \grewrite rs_a @ [a] @ rsb @ rsc} |
1447 |
\end{mathpar} |
|
555 | 1448 |
\end{center} |
613 | 1449 |
\caption{List of one-step rewrite rules characterising the $\rflts$ and $\textit{rdistinct}$ |
1450 |
operations}\label{gRewrite} |
|
1451 |
\end{figure} |
|
555 | 1452 |
\noindent |
618 | 1453 |
We define |
613 | 1454 |
two separate list rewriting relations $\frewrite$ and $\grewrite$. |
611 | 1455 |
The rewriting steps that take place during |
639 | 1456 |
flattening are characterised by $\frewrite$. |
618 | 1457 |
The rewrite relation $\grewrite$ characterises both flattening and de-duplicating. |
557 | 1458 |
Sometimes $\grewrites$ is slightly too powerful |
613 | 1459 |
so we would rather use $\frewrites$ to prove |
1460 |
%because we only |
|
1461 |
equalities related to $\rflts$. |
|
1462 |
%certain equivalence under the rewriting steps of $\frewrites$. |
|
556 | 1463 |
For example, when proving the closed-form for the alternative regular expression, |
613 | 1464 |
one of the equalities needed is: |
1465 |
\begin{center} |
|
557 | 1466 |
$\sum (\rDistinct \;\; (\map \; (\_ \backslash x) \; (\rflts \; rs)) \;\; \varnothing) \sequal |
593 | 1467 |
\sum (\rDistinct \;\; (\rflts \; (\map \; (\_ \backslash x) \; rs)) \;\; \varnothing) |
1468 |
$ |
|
613 | 1469 |
\end{center} |
556 | 1470 |
\noindent |
1471 |
Proving this is by first showing |
|
557 | 1472 |
\begin{lemma}\label{earlyLaterDerFrewrites} |
556 | 1473 |
$\map \; (\_ \backslash x) \; (\rflts \; rs) \frewrites |
557 | 1474 |
\rflts \; (\map \; (\_ \backslash x) \; rs)$ |
556 | 1475 |
\end{lemma} |
1476 |
\noindent |
|
613 | 1477 |
and then the equivalence between two terms |
618 | 1478 |
that can reduce in many steps to each other: |
556 | 1479 |
\begin{lemma}\label{frewritesSimpeq} |
1480 |
If $rs_1 \frewrites rs_2 $, then $\sum (\rDistinct \; rs_1 \; \varnothing) \sequal |
|
557 | 1481 |
\sum (\rDistinct \; rs_2 \; \varnothing)$. |
556 | 1482 |
\end{lemma} |
557 | 1483 |
\noindent |
618 | 1484 |
These two lemmas can both be proven using a straightforward induction (and |
1485 |
the proofs for them are therefore omitted). |
|
613 | 1486 |
|
639 | 1487 |
Now the above equalities can be derived with ease: |
613 | 1488 |
\begin{corollary} |
1489 |
$\sum (\rDistinct \;\; (\map \; (\_ \backslash x) \; (\rflts \; rs)) \;\; \varnothing) \sequal |
|
1490 |
\sum (\rDistinct \;\; (\rflts \; (\map \; (\_ \backslash x) \; rs)) \;\; \varnothing) |
|
1491 |
$ |
|
1492 |
\end{corollary} |
|
618 | 1493 |
\begin{proof} |
1494 |
By lemmas \ref{earlyLaterDerFrewrites} and \ref{frewritesSimpeq}. |
|
1495 |
\end{proof} |
|
557 | 1496 |
But this trick will not work for $\grewrites$. |
1497 |
For example, a rewriting step in proving |
|
1498 |
closed forms is: |
|
1499 |
\begin{center} |
|
593 | 1500 |
$\rsimp{(\rsimpalts \; (\map \; (\_ \backslash x) \; (\rdistinct{(\rflts \; (\map \; (\rsimp{} \; \circ \; (\lambda r. \rderssimp{r}{xs}))))}{\varnothing})))}$\\ |
1501 |
$=$ \\ |
|
1502 |
$\rsimp{(\rsimpalts \; (\rdistinct{(\map \; (\_ \backslash x) \; (\rflts \; (\map \; (\rsimp{} \; \circ \; (\lambda r. \rderssimp{r}{xs})))) ) }{\varnothing}))} $ |
|
1503 |
\noindent |
|
557 | 1504 |
\end{center} |
618 | 1505 |
For this, one would hope to have a rewriting relation between the two lists involved, |
557 | 1506 |
similar to \ref{earlyLaterDerFrewrites}. However, it turns out that |
556 | 1507 |
\begin{center} |
593 | 1508 |
$\map \; (\_ \backslash x) \; (\rDistinct \; rs \; rset) \grewrites \rDistinct \; (\map \; |
1509 |
(\_ \backslash x) \; rs) \; ( rset \backslash x)$ |
|
556 | 1510 |
\end{center} |
1511 |
\noindent |
|
557 | 1512 |
does $\mathbf{not}$ hold in general. |
1513 |
For this rewriting step we will introduce some slightly more cumbersome |
|
618 | 1514 |
proof technique later. |
557 | 1515 |
The point is that $\frewrite$ |
613 | 1516 |
allows us to prove equivalence in a straightforward way that is |
1517 |
not possible for $\grewrite$. |
|
555 | 1518 |
|
556 | 1519 |
|
557 | 1520 |
\subsubsection{Terms That Can Be Rewritten Using $\hrewrites$, $\grewrites$, and $\frewrites$} |
613 | 1521 |
In this part, we present lemmas stating |
618 | 1522 |
pairs of r-regular expressions and r-regular expression lists |
639 | 1523 |
where one can rewrite from one in many steps to the other. |
613 | 1524 |
Most of the proofs to these lemmas are straightforward, using |
618 | 1525 |
an induction on the corresponding rewriting relations. |
613 | 1526 |
These proofs will therefore be omitted when this is the case. |
618 | 1527 |
We present in the following lemma a few pairs of terms that are rewritable via |
557 | 1528 |
$\grewrites$: |
1529 |
\begin{lemma}\label{gstarRdistinctGeneral} |
|
613 | 1530 |
\mbox{} |
557 | 1531 |
\begin{itemize} |
1532 |
\item |
|
1533 |
$rs_1 @ rs \grewrites rs_1 @ (\rDistinct \; rs \; rs_1)$ |
|
1534 |
\item |
|
1535 |
$rs \grewrites \rDistinct \; rs \; \varnothing$ |
|
1536 |
\item |
|
1537 |
$rs_a @ (\rDistinct \; rs \; rs_a) \grewrites rs_a @ (\rDistinct \; |
|
1538 |
rs \; (\{\RZERO\} \cup rs_a))$ |
|
1539 |
\item |
|
1540 |
$rs \;\; @ \;\; \rDistinct \; rs_a \; rset \grewrites rs @ \rDistinct \; rs_a \; |
|
1541 |
(rest \cup rs)$ |
|
1542 |
||
1543 |
\end{itemize} |
|
1544 |
\end{lemma} |
|
1545 |
\noindent |
|
1546 |
If a pair of terms $rs_1, rs_2$ are rewritable via $\grewrites$ to each other, |
|
1547 |
then they are equivalent under $\rsimp{}$: |
|
1548 |
\begin{lemma}\label{grewritesSimpalts} |
|
618 | 1549 |
\mbox{} |
557 | 1550 |
If $rs_1 \grewrites rs_2$, then |
613 | 1551 |
we have the following equivalence: |
557 | 1552 |
\begin{itemize} |
1553 |
\item |
|
1554 |
$\sum rs_1 \sequal \sum rs_2$ |
|
1555 |
\item |
|
1556 |
$\rsimpalts \; rs_1 \sequal \rsimpalts \; rs_2$ |
|
1557 |
\end{itemize} |
|
1558 |
\end{lemma} |
|
1559 |
\noindent |
|
1560 |
Here are a few connecting lemmas showing that |
|
1561 |
if a list of regular expressions can be rewritten using $\grewrites$ or $\frewrites $ or |
|
1562 |
$\scfrewrites$, |
|
1563 |
then an alternative constructor taking the list can also be rewritten using $\hrewrites$: |
|
1564 |
\begin{lemma} |
|
1565 |
\begin{itemize} |
|
1566 |
\item |
|
1567 |
If $rs \grewrites rs'$ then $\sum rs \hrewrites \sum rs'$. |
|
1568 |
\item |
|
1569 |
If $rs \grewrites rs'$ then $\sum rs \hrewrites \rsimpalts \; rs'$ |
|
1570 |
\item |
|
1571 |
If $rs_1 \scfrewrites rs_2$ then $\sum (rs @ rs_1) \hrewrites \sum (rs @ rs_2)$ |
|
1572 |
\item |
|
1573 |
If $rs_1 \scfrewrites rs_2$ then $\sum rs_1 \hrewrites \sum rs_2$ |
|
1574 |
||
1575 |
\end{itemize} |
|
1576 |
\end{lemma} |
|
1577 |
\noindent |
|
618 | 1578 |
Now comes the core of the proof, |
557 | 1579 |
which says that once two lists are rewritable to each other, |
639 | 1580 |
then they are equivalent under $\textit{rsimp}$: |
557 | 1581 |
\begin{lemma} |
1582 |
If $r_1 \hrewrites r_2$ then $r_1 \sequal r_2$. |
|
1583 |
\end{lemma} |
|
1584 |
||
1585 |
\noindent |
|
639 | 1586 |
Similar to what we did in chapter \ref{Bitcoded2}, |
618 | 1587 |
we prove that if one can rewrite from one r-regular expression ($r$) |
639 | 1588 |
to the other ($r'$), after taking derivatives one can still rewrite |
618 | 1589 |
the first ($r\backslash c$) to the other ($r'\backslash c$). |
557 | 1590 |
\begin{lemma}\label{interleave} |
1591 |
If $r \hrewrites r' $ then $\rder{c}{r} \hrewrites \rder{c}{r'}$ |
|
1592 |
\end{lemma} |
|
1593 |
\noindent |
|
640
bd1354127574
more proofreading done, last version before submission
Chengsong
parents:
639
diff
changeset
|
1594 |
This allows us to prove more $\mathbf{rsimp}$-equivalent terms, involving $\backslash_r$. |
557 | 1595 |
\begin{lemma}\label{insideSimpRemoval} |
618 | 1596 |
$\rsimp{(\rder{c}{(\rsimp{r})})} = \rsimp{(\rder{c}{r})} $ |
557 | 1597 |
\end{lemma} |
1598 |
\noindent |
|
1599 |
\begin{proof} |
|
1600 |
By \ref{interleave} and \ref{rsimpIdem}. |
|
1601 |
\end{proof} |
|
1602 |
\noindent |
|
1603 |
And this unlocks more equivalent terms: |
|
1604 |
\begin{lemma}\label{Simpders} |
|
1605 |
As corollaries of \ref{insideSimpRemoval}, we have |
|
1606 |
\begin{itemize} |
|
1607 |
\item |
|
620 | 1608 |
If $s \neq []$ then $\rderssimp{r}{s} = \rsimp{( r \backslash_{rs} s)}$. |
557 | 1609 |
\item |
1610 |
$\rsimpalts \; (\map \; (\_ \backslash_r x) \; |
|
593 | 1611 |
(\rdistinct{rs}{\varnothing})) \sequal |
1612 |
\rsimpalts \; (\rDistinct \; |
|
1613 |
(\map \; (\_ \backslash_r x) rs) \;\varnothing )$ |
|
1614 |
\end{itemize} |
|
1615 |
\end{lemma} |
|
611 | 1616 |
\begin{proof} |
1617 |
Part 1 is by lemma \ref{insideSimpRemoval}, |
|
613 | 1618 |
part 2 is by lemma \ref{insideSimpRemoval} .%and \ref{distinctDer}. |
611 | 1619 |
\end{proof} |
557 | 1620 |
\noindent |
613 | 1621 |
|
1622 |
\subsection{Closed Forms for $\sum rs$, $r_1\cdot r_2$ and $r^*$} |
|
618 | 1623 |
Lemma \ref{Simpders} leads to our first closed form, |
1624 |
which is for the alternative regular expression: |
|
1625 |
\begin{theorem}\label{altsClosedForm} |
|
1626 |
\mbox{} |
|
593 | 1627 |
\begin{center} |
1628 |
$\rderssimp{(\sum rs)}{s} \sequal |
|
1629 |
\sum \; (\map \; (\rderssimp{\_}{s}) \; rs)$ |
|
1630 |
\end{center} |
|
618 | 1631 |
\end{theorem} |
556 | 1632 |
\noindent |
557 | 1633 |
\begin{proof} |
1634 |
By a reverse induction on the string $s$. |
|
1635 |
One rewriting step, as we mentioned earlier, |
|
1636 |
involves |
|
1637 |
\begin{center} |
|
1638 |
$\rsimpalts \; (\map \; (\_ \backslash x) \; |
|
1639 |
(\rdistinct{(\rflts \; (\map \; (\rsimp{} \; \circ \; |
|
1640 |
(\lambda r. \rderssimp{r}{xs}))))}{\varnothing})) |
|
1641 |
\sequal |
|
1642 |
\rsimpalts \; (\rdistinct{(\map \; (\_ \backslash x) \; |
|
593 | 1643 |
(\rflts \; (\map \; (\rsimp{} \; \circ \; |
557 | 1644 |
(\lambda r. \rderssimp{r}{xs})))) ) }{\varnothing}) $. |
1645 |
\end{center} |
|
1646 |
This can be proven by a combination of |
|
1647 |
\ref{grewritesSimpalts}, \ref{gstarRdistinctGeneral}, \ref{rderRsimpAltsCommute}, and |
|
1648 |
\ref{insideSimpRemoval}. |
|
1649 |
\end{proof} |
|
1650 |
\noindent |
|
1651 |
This closed form has a variant which can be more convenient in later proofs: |
|
618 | 1652 |
\begin{corollary}\label{altsClosedForm1} |
557 | 1653 |
If $s \neq []$ then |
1654 |
$\rderssimp \; (\sum \; rs) \; s = |
|
1655 |
\rsimp{(\sum \; (\map \; \rderssimp{\_}{s} \; rs))}$. |
|
1656 |
\end{corollary} |
|
1657 |
\noindent |
|
1658 |
The harder closed forms are the sequence and star ones. |
|
613 | 1659 |
Before we obtain them, some preliminary definitions |
557 | 1660 |
are needed to make proof statements concise. |
556 | 1661 |
|
609 | 1662 |
|
1663 |
\subsubsection{Closed Form for Sequence Regular Expressions} |
|
618 | 1664 |
For the sequence regular expression, |
1665 |
let's first look at a series of derivative steps on it |
|
1666 |
(assuming that each time when a derivative is taken, |
|
1667 |
the head of the sequence is always nullable): |
|
557 | 1668 |
\begin{center} |
618 | 1669 |
\begin{tabular}{llll} |
1670 |
$r_1 \cdot r_2$ & |
|
1671 |
$\longrightarrow_{\backslash c}$ & |
|
1672 |
$r_1\backslash c \cdot r_2 + r_2 \backslash c$ & |
|
1673 |
$ \longrightarrow_{\backslash c'} $ \\ |
|
1674 |
\\ |
|
1675 |
$(r_1 \backslash cc' \cdot r_2 + r_2 \backslash c') + r_2 \backslash cc'$ & |
|
1676 |
$\longrightarrow_{\backslash c''} $ & |
|
1677 |
$((r_1 \backslash cc'c'' \cdot r_2 + r_2 \backslash c'') + r_2 \backslash c'c'') |
|
1678 |
+ r_2 \backslash cc'c''$ & |
|
1679 |
$ \longrightarrow_{\backslash c''} \quad \ldots$\\ |
|
1680 |
\end{tabular} |
|
557 | 1681 |
\end{center} |
640
bd1354127574
more proofreading done, last version before submission
Chengsong
parents:
639
diff
changeset
|
1682 |
Roughly speaking $r_1 \cdot r_2 \backslash s$ can be expressed as |
558 | 1683 |
a giant alternative taking a list of terms |
1684 |
$[r_1 \backslash_r s \cdot r_2, r_2 \backslash_r s'', r_2 \backslash_r s_1'', \ldots]$, |
|
1685 |
where the head of the list is always the term |
|
1686 |
representing a match involving only $r_1$, and the tail of the list consisting of |
|
1687 |
terms of the shape $r_2 \backslash_r s''$, $s''$ being a suffix of $s$. |
|
618 | 1688 |
This intuition is also echoed by Murugesan and Sundaram \cite{Murugesan2014}, |
1689 |
where they gave |
|
557 | 1690 |
a pencil-and-paper derivation of $(r_1 \cdot r_2)\backslash s$: |
532 | 1691 |
\begin{center} |
618 | 1692 |
\begin{tabular}{lc} |
1693 |
$L \; [ (r_1 \cdot r_2) \backslash_r (c_1 :: c_2 :: \ldots c_n) ]$ & $ =$\\ |
|
1694 |
\\ |
|
1695 |
\rule{0pt}{3ex} $L \; [ ((r_1 \backslash_r c_1) \cdot r_2 + |
|
1696 |
(\delta\; (\nullable \; r_1) \; (r_2 \backslash_r c_1) )) \backslash_r |
|
1697 |
(c_2 :: \ldots c_n) ]$ & |
|
1698 |
$=$\\ |
|
1699 |
\\ |
|
1700 |
\rule{0pt}{3ex} $L \; [ ((r_1 \backslash_r c_1c_2 \cdot r_2 + |
|
1701 |
(\delta \; (\nullable \; r_1) \; (r_2 \backslash_r c_1c_2))) |
|
1702 |
$ & \\ |
|
1703 |
\\ |
|
1704 |
$\quad + (\delta \ (\nullable \; r_1 \backslash_r c)\; (r_2 \backslash_r c_2) )) |
|
1705 |
\backslash_r (c_3 \ldots c_n) ]$ & $\ldots$ \\ |
|
558 | 1706 |
\end{tabular} |
557 | 1707 |
\end{center} |
1708 |
\noindent |
|
618 | 1709 |
The $\delta$ function |
1710 |
returns $r$ when the boolean condition |
|
1711 |
$b$ evaluates to true and |
|
639 | 1712 |
$\ZERO_r$ otherwise: |
618 | 1713 |
\begin{center} |
1714 |
\begin{tabular}{lcl} |
|
1715 |
$\delta \; b\; r$ & $\dn$ & $r \quad \textit{if} \; b \; is \;\textit{true}$\\ |
|
639 | 1716 |
& $\dn$ & $\ZERO_r \quad otherwise$ |
618 | 1717 |
\end{tabular} |
1718 |
\end{center} |
|
1719 |
\noindent |
|
1720 |
Note that the term |
|
1721 |
\begin{center} |
|
1722 |
\begin{tabular}{lc} |
|
1723 |
\rule{0pt}{3ex} $((r_1 \backslash_r c_1c_2 \cdot r_2 + |
|
1724 |
(\delta \; (\nullable \; r_1) \; (r_2 \backslash_r c_1c_2))) |
|
1725 |
$ & \\ |
|
1726 |
\\ |
|
1727 |
$\quad + (\delta \ (\nullable \; r_1 \backslash_r c)\; (r_2 \backslash_r c_2) )) |
|
1728 |
\backslash_r (c_3 \ldots c_n)$ &\\ |
|
1729 |
\end{tabular} |
|
1730 |
\end{center} |
|
1731 |
\noindent |
|
558 | 1732 |
does not faithfully |
1733 |
represent what the intermediate derivatives would actually look like |
|
1734 |
when one or more intermediate results $r_1 \backslash s' \cdot r_2$ are not |
|
1735 |
nullable in the head of the sequence. |
|
1736 |
For example, when $r_1$ and $r_1 \backslash_r c_1$ are not nullable, |
|
1737 |
the regular expression would not look like |
|
1738 |
\[ |
|
618 | 1739 |
r_1 \backslash_r c_1c_2 |
558 | 1740 |
\] |
618 | 1741 |
instead of |
1742 |
\[ |
|
639 | 1743 |
(r_1 \backslash_r c_1c_2 + \ZERO_r ) + \ZERO_r. |
618 | 1744 |
\] |
639 | 1745 |
The redundant $\ZERO_r$s will not be created in the |
558 | 1746 |
first place. |
618 | 1747 |
In a closed-form one needs to take into account this (because |
1748 |
closed forms require exact equality rather than language equivalence) |
|
1749 |
and only generate the |
|
1750 |
$r_2 \backslash_r s''$ terms satisfying the property |
|
1751 |
\begin{center} |
|
640
bd1354127574
more proofreading done, last version before submission
Chengsong
parents:
639
diff
changeset
|
1752 |
$\exists s'. such \; that \; s'@s'' = s \;\; \land \;\; |
618 | 1753 |
r_1 \backslash s' \; is \; nullable$. |
1754 |
\end{center} |
|
1755 |
Given the arguments $s$ and $r_1$, we denote the list of strings |
|
1756 |
$s''$ satisfying the above property as $\vsuf{s}{r_1}$. |
|
1757 |
The function $\vsuf{\_}{\_}$ is defined recursively on the structure of the string\footnote{ |
|
640
bd1354127574
more proofreading done, last version before submission
Chengsong
parents:
639
diff
changeset
|
1758 |
Perhaps a better name for it would be ``NullablePrefixSuffix'' |
618 | 1759 |
to differentiate with the list of \emph{all} prefixes of $s$, but |
1760 |
that is a bit too long for a function name and we are yet to find |
|
1761 |
a more concise and easy-to-understand name.} |
|
558 | 1762 |
\begin{center} |
593 | 1763 |
\begin{tabular}{lcl} |
1764 |
$\vsuf{[]}{\_} $ & $=$ & $[]$\\ |
|
618 | 1765 |
$\vsuf{c::cs}{r_1}$ & $ =$ & $ \textit{if} \; (\rnullable{r_1}) \; \textit{then} \; (\vsuf{cs}{(\rder{c}{r_1})}) @ [c :: cs]$\\ |
593 | 1766 |
&& $\textit{else} \; (\vsuf{cs}{(\rder{c}{r_1}) }) $ |
1767 |
\end{tabular} |
|
558 | 1768 |
\end{center} |
1769 |
\noindent |
|
618 | 1770 |
The list starts with shorter suffixes |
1771 |
and ends with longer ones (in other words, the string elements $s''$ |
|
1772 |
in the list $\vsuf{s}{r_1}$ are sorted |
|
1773 |
in the same order as that of the terms $r_2\backslash s''$ |
|
1774 |
appearing in $(r_1\cdot r_2)\backslash s$). |
|
558 | 1775 |
In essence, $\vsuf{\_}{\_}$ is doing a |
1776 |
"virtual derivative" of $r_1 \cdot r_2$, but instead of producing |
|
1777 |
the entire result $(r_1 \cdot r_2) \backslash s$, |
|
618 | 1778 |
it only stores strings, |
1779 |
with each string $s''$ representing a term such that $r_2 \backslash s''$ |
|
1780 |
is occurring in $(r_1\cdot r_2)\backslash s$. |
|
558 | 1781 |
|
618 | 1782 |
With $\textit{Suffix}$ we are ready to express the |
1783 |
sequence regular expression's closed form, |
|
1784 |
but before doing so |
|
639 | 1785 |
more definitions are needed. |
618 | 1786 |
The first thing is the flattening function $\sflat{\_}$, |
1787 |
which takes an alternative regular expression and produces a flattened version |
|
1788 |
of that alternative regular expression. |
|
1789 |
It is needed to convert |
|
557 | 1790 |
a left-associative nested sequence of alternatives into |
1791 |
a flattened list: |
|
558 | 1792 |
\[ |
618 | 1793 |
\sum(\ldots ((r_1 + r_2) + r_3) + \ldots) |
1794 |
\stackrel{\sflat{\_}}{\rightarrow} |
|
1795 |
\sum[r_1, r_2, r_3, \ldots] |
|
558 | 1796 |
\] |
1797 |
\noindent |
|
618 | 1798 |
The definitions of $\sflat{\_}$ and helper functions |
1799 |
$\sflataux{\_}$ and $\llparenthesis \_ \rrparenthesis''$ are given below. |
|
593 | 1800 |
\begin{center} |
618 | 1801 |
\begin{tabular}{lcl} |
1802 |
$\sflataux{\sum r :: rs}$ & $\dn$ & $\sflataux{r} @ rs$\\ |
|
1803 |
$\sflataux{\sum []}$ & $ \dn $ & $ []$\\ |
|
1804 |
$\sflataux r$ & $\dn$ & $ [r]$ |
|
593 | 1805 |
\end{tabular} |
532 | 1806 |
\end{center} |
1807 |
||
593 | 1808 |
\begin{center} |
618 | 1809 |
\begin{tabular}{lcl} |
1810 |
$\sflat{(\sum r :: rs)}$ & $\dn$ & $\sum (\sflataux{r} @ rs)$\\ |
|
1811 |
$\sflat{\sum []}$ & $ \dn $ & $ \sum []$\\ |
|
1812 |
$\sflat r$ & $\dn$ & $ r$ |
|
1813 |
\end{tabular} |
|
1814 |
\end{center} |
|
1815 |
||
1816 |
\begin{center} |
|
1817 |
\begin{tabular}{lcl} |
|
1818 |
$\sflataux{[]}'$ & $ \dn $ & $ []$\\ |
|
1819 |
$\sflataux{ (r_1 + r_2) :: rs }'$ & $\dn$ & $r_1 :: r_2 :: rs$\\ |
|
639 | 1820 |
$\sflataux{r :: rs}'$ & $\dn$ & $ r::rs$ |
593 | 1821 |
\end{tabular} |
557 | 1822 |
\end{center} |
558 | 1823 |
\noindent |
576 | 1824 |
$\sflataux{\_}$ breaks up nested alternative regular expressions |
557 | 1825 |
of the $(\ldots((r_1 + r_2) + r_3) + \ldots )$(left-associated) shape |
558 | 1826 |
into a "balanced" list: $\AALTS{\_}{[r_1,\, r_2 ,\, r_3, \ldots]}$. |
557 | 1827 |
It will return the singleton list $[r]$ otherwise. |
1828 |
$\sflat{\_}$ works the same as $\sflataux{\_}$, except that it keeps |
|
1829 |
the output type a regular expression, not a list. |
|
558 | 1830 |
$\sflataux{\_}$ and $\sflat{\_}$ are only recursive on the |
1831 |
first element of the list. |
|
618 | 1832 |
$\sflataux{\_}'$ takes a list of regular expressions as input, and outputs |
1833 |
a list of regular expressions. |
|
1834 |
The use of $\sflataux{\_}$ and $\sflataux{\_}'$ is clear once we have |
|
1835 |
$\textit{createdBySequence}$ defined: |
|
1836 |
\begin{center} |
|
1837 |
\begin{mathpar} |
|
1838 |
\inferrule{\mbox{}}{\textit{createdBySequence}\; (r_1 \cdot r_2)} |
|
558 | 1839 |
|
618 | 1840 |
\inferrule{\textit{createdBySequence} \; r_1}{\textit{createdBySequence} \; |
1841 |
(r_1 + r_2)} |
|
1842 |
\end{mathpar} |
|
1843 |
\end{center} |
|
1844 |
\noindent |
|
1845 |
The predicate $\textit{createdBySequence}$ is used to describe the shape of |
|
1846 |
the derivative regular expressions $(r_1\cdot r_2) \backslash s$: |
|
1847 |
\begin{lemma}\label{recursivelyDerseq} |
|
1848 |
It is always the case that |
|
1849 |
\begin{center} |
|
1850 |
$\textit{createdBySequence} \; ( (r_1\cdot r_2) \backslash_r s) $ |
|
1851 |
\end{center} |
|
1852 |
holds. |
|
1853 |
\end{lemma} |
|
1854 |
\begin{proof} |
|
1855 |
By a reverse induction on the string $s$, where the inductive cases are $[]$ |
|
1856 |
and $xs @ [x]$. |
|
1857 |
\end{proof} |
|
1858 |
\noindent |
|
639 | 1859 |
If we have a regular expression $r$ whose shape |
618 | 1860 |
fits into those described by $\textit{createdBySequence}$, |
639 | 1861 |
then we can convert between |
618 | 1862 |
$r \backslash_r c$ and $(\sflataux{r}) \backslash_r c$ with |
1863 |
$\sflataux{\_}'$: |
|
1864 |
\begin{lemma}\label{sfauIdemDer} |
|
1865 |
If $\textit{createdBySequence} \; r$, then |
|
1866 |
\begin{center} |
|
1867 |
$\sflataux{ r \backslash_r c} = |
|
1868 |
\llparenthesis (\map \; (\_ \backslash_r c) \; (\sflataux{r}) ) \rrparenthesis''$ |
|
1869 |
\end{center} |
|
1870 |
holds. |
|
1871 |
\end{lemma} |
|
1872 |
\begin{proof} |
|
1873 |
By a simple induction on the inductive cases of $\textit{createdBySequence}. |
|
1874 |
$ |
|
1875 |
\end{proof} |
|
1876 |
||
1877 |
Now we are ready to express |
|
1878 |
the shape of $r_1 \cdot r_2 \backslash s$ |
|
558 | 1879 |
\begin{lemma}\label{seqSfau0} |
618 | 1880 |
$\sflataux{(r_1 \cdot r_2) \backslash_r s} = (r_1 \backslash_r s) \cdot r_2 |
639 | 1881 |
:: (\map \; (r_2 \backslash_r \_) \; (\textit{Suffix} \; s \; r_1))$ |
558 | 1882 |
\end{lemma} |
1883 |
\begin{proof} |
|
618 | 1884 |
By a reverse induction on the string $s$, where the inductive cases |
1885 |
are $[]$ and $xs @ [x]$. |
|
1886 |
For the inductive case, we know that $\textit{createdBySequence} \; ((r_1 \cdot r_2) |
|
1887 |
\backslash_r xs)$ holds from lemma \ref{recursivelyDerseq}, |
|
1888 |
which can be used to prove |
|
558 | 1889 |
\[ |
1890 |
\map \; (r_2 \backslash_r \_) \; (\vsuf{[x]}{(r_1 \backslash_r xs)}) \;\; @ \;\; |
|
1891 |
\map \; (\_ \backslash_r x) \; (\map \; (r_2 \backslash \_) \; (\vsuf{xs}{r_1})) |
|
1892 |
\] |
|
593 | 1893 |
= |
558 | 1894 |
\[ |
1895 |
\map \; (r_2 \backslash_r \_) \; (\vsuf{xs @ [x]}{r_1}) |
|
1896 |
\] |
|
618 | 1897 |
using lemma \ref{sfauIdemDer}. |
1898 |
This equality enables the inductive case to go through. |
|
558 | 1899 |
\end{proof} |
1900 |
\noindent |
|
618 | 1901 |
This lemma says that $(r_1\cdot r_2)\backslash s$ |
1902 |
can be flattened into a list whose head and tail meet the description |
|
1903 |
we gave earlier. |
|
1904 |
%Note that this lemma does $\mathbf{not}$ depend on any |
|
1905 |
%specific definitions we used, |
|
1906 |
%allowing people investigating derivatives to get an alternative |
|
1907 |
%view of what $r_1 \cdot r_2$ is. |
|
532 | 1908 |
|
618 | 1909 |
We now use $\textit{createdBySequence}$ and |
1910 |
$\sflataux{\_}$ to describe an intuition |
|
639 | 1911 |
behind the sequence closed form. |
618 | 1912 |
If two regular expressions only differ in the way their |
1913 |
alternatives are nested, then we should be able to get the same result |
|
1914 |
once we apply simplification to both of them: |
|
1915 |
\begin{lemma}\label{sflatRsimpeq} |
|
1916 |
If $r$ is created from a sequence through |
|
1917 |
a series of derivatives |
|
1918 |
(i.e. if $\textit{createdBySequence} \; r$ holds), |
|
1919 |
and that $\sflataux{r} = rs$, |
|
1920 |
then we have |
|
1921 |
that |
|
1922 |
\begin{center} |
|
1923 |
$\textit{rsimp} \; r = \textit{rsimp} \; (\sum \; rs)$ |
|
1924 |
\end{center} |
|
1925 |
holds. |
|
1926 |
\end{lemma} |
|
1927 |
\begin{proof} |
|
1928 |
By an induction on the inductive cases of $\textit{createdBySequence}$. |
|
1929 |
\end{proof} |
|
1930 |
||
1931 |
Now we are ready for the closed form |
|
1932 |
for the sequence regular expressions (without the inner applications |
|
1933 |
of simplifications): |
|
1934 |
\begin{lemma}\label{seqClosedFormGeneral} |
|
558 | 1935 |
$\rsimp{\sflat{(r_1 \cdot r_2) \backslash s} } |
1936 |
=\rsimp{(\sum ( (r_1 \backslash s) \cdot r_2 :: |
|
593 | 1937 |
\map\; (r_2 \backslash \_) \; (\vsuf{s}{r_1})))}$ |
558 | 1938 |
\end{lemma} |
1939 |
\begin{proof} |
|
618 | 1940 |
We know that |
1941 |
$\sflataux{(r_1 \cdot r_2) \backslash_r s} = (r_1 \backslash_r s) \cdot r_2 |
|
639 | 1942 |
:: (\map \; (r_2 \backslash_r \_) \; (\textit{Suffix} \; s \; r_1))$ |
618 | 1943 |
holds |
1944 |
by lemma \ref{seqSfau0}. |
|
1945 |
This allows the theorem to go through because of lemma \ref{sflatRsimpeq}. |
|
558 | 1946 |
\end{proof} |
618 | 1947 |
Together with the idempotency property of $\rsimp{}$ (lemma \ref{rsimpIdem}), |
1948 |
it is possible to convert the above lemma to obtain the |
|
1949 |
proper closed form for $\backslash_{rsimps}$ rather than $\backslash_r$: |
|
1950 |
for derivatives nested with simplification: |
|
1951 |
\begin{theorem}\label{seqClosedForm} |
|
1952 |
$\rderssimp{(r_1 \cdot r_2)}{s} = \rsimp{(\sum ((r_1 \backslash s) \cdot r_2 ) |
|
1953 |
:: (\map \; (r_2 \backslash \_) (\vsuf{s}{r_1})))}$ |
|
1954 |
\end{theorem} |
|
1955 |
\begin{proof} |
|
1956 |
By a case analysis of the string $s$. |
|
1957 |
When $s$ is an empty list, the rewrite is straightforward. |
|
1958 |
When $s$ is a non-empty list, the |
|
1959 |
lemmas \ref{seqClosedFormGeneral} and \ref{Simpders} apply, |
|
1960 |
making the proof go through. |
|
1961 |
\end{proof} |
|
609 | 1962 |
\subsubsection{Closed Forms for Star Regular Expressions} |
618 | 1963 |
The closed form for the star regular expression involves similar tricks |
1964 |
for the sequence regular expression. |
|
1965 |
The $\textit{Suffix}$ function is now replaced by something |
|
1966 |
slightly more complex, because the growth pattern of star |
|
1967 |
regular expressions' derivatives is a bit different: |
|
564 | 1968 |
\begin{center} |
618 | 1969 |
\begin{tabular}{lclc} |
1970 |
$r^* $ & $\longrightarrow_{\backslash c}$ & |
|
1971 |
$(r\backslash c) \cdot r^*$ & $\longrightarrow_{\backslash c'}$\\ |
|
1972 |
\\ |
|
1973 |
$r \backslash cc' \cdot r^* + r \backslash c' \cdot r^*$ & |
|
1974 |
$\longrightarrow_{\backslash c''}$ & |
|
1975 |
$(r_1 \backslash cc'c'' \cdot r^* + r \backslash c'') + |
|
1976 |
(r \backslash c'c'' \cdot r^* + r \backslash c'' \cdot r^*)$ & |
|
1977 |
$\longrightarrow_{\backslash c'''}$ \\ |
|
1978 |
\\ |
|
1979 |
$\ldots$\\ |
|
1980 |
\end{tabular} |
|
564 | 1981 |
\end{center} |
1982 |
When we have a string $s = c :: c' :: c'' \ldots$ such that $r \backslash c$, $r \backslash cc'$, $r \backslash c'$, |
|
1983 |
$r \backslash cc'c''$, $r \backslash c'c''$, $r\backslash c''$ etc. are all nullable, |
|
618 | 1984 |
the number of terms in $r^* \backslash s$ will grow exponentially rather than linearly |
1985 |
in the sequence case. |
|
1986 |
The good news is that the function $\textit{rsimp}$ will again |
|
640
bd1354127574
more proofreading done, last version before submission
Chengsong
parents:
639
diff
changeset
|
1987 |
ignore the difference between different nesting patterns of alternatives, |
618 | 1988 |
and the exponentially growing star derivative like |
1989 |
\begin{center} |
|
1990 |
$(r_1 \backslash cc'c'' \cdot r^* + r \backslash c'') + |
|
1991 |
(r \backslash c'c'' \cdot r^* + r \backslash c'' \cdot r^*) $ |
|
1992 |
\end{center} |
|
1993 |
can be treated as |
|
1994 |
\begin{center} |
|
1995 |
$\RALTS{[r_1 \backslash cc'c'' \cdot r^*, r \backslash c'', |
|
1996 |
r \backslash c'c'' \cdot r^*, r \backslash c'' \cdot r^*]}$ |
|
1997 |
\end{center} |
|
1998 |
which can be de-duplicated by $\rDistinct$ |
|
1999 |
and therefore bounded finitely. |
|
564 | 2000 |
|
639 | 2001 |
%and then de-duplicate terms of the form ($s'$ being a substring of $s$). |
2002 |
%This allows us to use a similar technique as $r_1 \cdot r_2$ case, |
|
618 | 2003 |
|
2004 |
Now the crux of this section is finding a suitable description |
|
2005 |
for $rs$ where |
|
2006 |
\begin{center} |
|
2007 |
$\rderssimp{r^*}{s} = \rsimp{\sum rs}$. |
|
2008 |
\end{center} |
|
2009 |
holds. |
|
2010 |
In addition, the list $rs$ |
|
2011 |
shall be in the form of |
|
2012 |
$\map \; (\lambda s'. r\backslash s' \cdot r^*) \; Ss$. |
|
2013 |
The $Ss$ is a list of strings, and for example in the sequence |
|
2014 |
closed form it is specified as $\textit{Suffix} \; s \; r_1$. |
|
2015 |
To get $Ss$ for the star regular expression, |
|
2016 |
we need to introduce $\starupdate$ and $\starupdates$: |
|
558 | 2017 |
\begin{center} |
2018 |
\begin{tabular}{lcl} |
|
2019 |
$\starupdate \; c \; r \; [] $ & $\dn$ & $[]$\\ |
|
2020 |
$\starupdate \; c \; r \; (s :: Ss)$ & $\dn$ & \\ |
|
2021 |
& & $\textit{if} \; |
|
620 | 2022 |
(\rnullable \; (r \backslash_{rs} s))$ \\ |
558 | 2023 |
& & $\textit{then} \;\; (s @ [c]) :: [c] :: ( |
2024 |
\starupdate \; c \; r \; Ss)$ \\ |
|
2025 |
& & $\textit{else} \;\; (s @ [c]) :: ( |
|
2026 |
\starupdate \; c \; r \; Ss)$ |
|
2027 |
\end{tabular} |
|
2028 |
\end{center} |
|
2029 |
\begin{center} |
|
2030 |
\begin{tabular}{lcl} |
|
2031 |
$\starupdates \; [] \; r \; Ss$ & $=$ & $Ss$\\ |
|
2032 |
$\starupdates \; (c :: cs) \; r \; Ss$ & $=$ & $\starupdates \; cs \; r \; ( |
|
2033 |
\starupdate \; c \; r \; Ss)$ |
|
2034 |
\end{tabular} |
|
2035 |
\end{center} |
|
2036 |
\noindent |
|
618 | 2037 |
Assuming we have that |
2038 |
\begin{center} |
|
2039 |
$\rderssimp{r^*}{s} = \rsimp{(\sum \map \; (\lambda s'. r\backslash s' \cdot r^*) \; Ss)}$. |
|
2040 |
\end{center} |
|
2041 |
holds. |
|
2042 |
The idea of $\starupdate$ and $\starupdates$ |
|
2043 |
is to update $Ss$ when another |
|
2044 |
derivative is taken on $\rderssimp{r^*}{s}$ |
|
2045 |
w.r.t a character $c$ and a string $s'$ |
|
2046 |
respectively. |
|
2047 |
Both $\starupdate$ and $\starupdates$ take three arguments as input: |
|
2048 |
the new character $c$ or string $s$ to take derivative with, |
|
2049 |
the regular expression |
|
2050 |
$r$ under the star $r^*$, and the |
|
2051 |
list of strings $Ss$ for the derivative $r^* \backslash s$ |
|
2052 |
up until this point |
|
2053 |
such that |
|
2054 |
\begin{center} |
|
2055 |
$(r^*) \backslash s = \sum_{s' \in sSet} (r\backslash s') \cdot r^*$ |
|
2056 |
\end{center} |
|
2057 |
is satisfied. |
|
2058 |
||
2059 |
Functions $\starupdate$ and $\starupdates$ characterise what the |
|
2060 |
star derivatives will look like once ``straightened out'' into lists. |
|
2061 |
The helper functions for such operations will be similar to |
|
2062 |
$\sflat{\_}$, $\sflataux{\_}$ and $\sflataux{\_}$, which we defined for sequence. |
|
2063 |
We use similar symbols to denote them, with a $*$ subscript to mark the difference. |
|
558 | 2064 |
\begin{center} |
2065 |
\begin{tabular}{lcl} |
|
2066 |
$\hflataux{r_1 + r_2}$ & $\dn$ & $\hflataux{r_1} @ \hflataux{r_2}$\\ |
|
2067 |
$\hflataux{r}$ & $\dn$ & $[r]$ |
|
2068 |
\end{tabular} |
|
2069 |
\end{center} |
|
557 | 2070 |
|
2071 |
\begin{center} |
|
558 | 2072 |
\begin{tabular}{lcl} |
2073 |
$\hflat{r_1 + r_2}$ & $\dn$ & $\sum (\hflataux {r_1} @ \hflataux {r_2}) $\\ |
|
2074 |
$\hflat{r}$ & $\dn$ & $r$ |
|
2075 |
\end{tabular} |
|
2076 |
\end{center} |
|
2077 |
\noindent |
|
618 | 2078 |
These definitions are tailor-made for dealing with alternatives that have |
2079 |
originated from a star's derivatives. |
|
2080 |
A typical star derivative always has the structure of a balanced binary tree: |
|
564 | 2081 |
\begin{center} |
618 | 2082 |
$(r_1 \backslash cc'c'' \cdot r^* + r \backslash c'') + |
2083 |
(r \backslash c'c'' \cdot r^* + r \backslash c'' \cdot r^*) $ |
|
593 | 2084 |
\end{center} |
618 | 2085 |
All of the nested structures of alternatives |
2086 |
generated from derivatives are binary, and therefore |
|
2087 |
$\hflat{\_}$ and $\hflataux{\_}$ only deal with binary alternatives. |
|
2088 |
$\hflat{\_}$ ``untangles'' like the following: |
|
2089 |
\[ |
|
2090 |
\sum ((r_1 + r_2) + (r_3 + r_4)) + \ldots \; |
|
2091 |
\stackrel{\hflat{\_}}{\longrightarrow} \; |
|
2092 |
\RALTS{[r_1, r_2, \ldots, r_n]} |
|
2093 |
\] |
|
2094 |
Here is a lemma stating the recursive property of $\starupdate$ and $\starupdates$, |
|
2095 |
with the helpers $\hflat{\_}$ and $\hflataux{\_}$\footnote{The function $\textit{concat}$ takes a list of lists |
|
2096 |
and merges each of the element lists to form a flattened list.}: |
|
2097 |
\begin{lemma}\label{stupdateInduct1} |
|
2098 |
\mbox |
|
2099 |
For a list of strings $Ss$, the following hold. |
|
2100 |
\begin{itemize} |
|
2101 |
\item |
|
2102 |
If we do a derivative on the terms |
|
2103 |
$r\backslash_r s \cdot r^*$ (where $s$ is taken from the list $Ss$), |
|
2104 |
the result will be the same as if we apply $\starupdate$ to $Ss$. |
|
2105 |
\begin{center} |
|
2106 |
\begin{tabular}{c} |
|
2107 |
$\textit{concat} \; (\map \; (\hflataux{\_} \circ ( (\_\backslash_r x) |
|
2108 |
\circ (\lambda s.\;\; (r \backslash_r s) \cdot r^*)))\; Ss )\; |
|
2109 |
$\\ |
|
2110 |
\\ |
|
2111 |
$=$ \\ |
|
2112 |
\\ |
|
2113 |
$\map \; (\lambda s. (r \backslash_r s) \cdot (r^*)) \; |
|
2114 |
(\starupdate \; x \; r \; Ss)$ |
|
2115 |
\end{tabular} |
|
2116 |
\end{center} |
|
2117 |
\item |
|
2118 |
$\starupdates$ is ``composable'' w.r.t a derivative. |
|
2119 |
It piggybacks the character $x$ to the tail of the string |
|
2120 |
$xs$. |
|
2121 |
\begin{center} |
|
2122 |
\begin{tabular}{c} |
|
2123 |
$\textit{concat} \; (\map \; \hflataux{\_} \; |
|
2124 |
(\map \; (\_\backslash_r x) \; |
|
2125 |
(\map \; (\lambda s.\;\; (r \backslash_r s) \cdot |
|
2126 |
(r^*) ) \; (\starupdates \; xs \; r \; Ss))))$\\ |
|
2127 |
\\ |
|
2128 |
$=$\\ |
|
2129 |
\\ |
|
2130 |
$\map \; (\lambda s.\;\; (r\backslash_r s) \cdot (r^*)) \; |
|
2131 |
(\starupdates \; (xs @ [x]) \; r \; Ss)$ |
|
2132 |
\end{tabular} |
|
2133 |
\end{center} |
|
2134 |
\end{itemize} |
|
2135 |
\end{lemma} |
|
2136 |
||
2137 |
\begin{proof} |
|
2138 |
Part 1 is by induction on $Ss$. |
|
2139 |
Part 2 is by induction on $xs$, where $Ss$ is left to take arbitrary values. |
|
2140 |
\end{proof} |
|
2141 |
||
593 | 2142 |
|
618 | 2143 |
Like $\textit{createdBySequence}$, we need |
2144 |
a predicate for ``star-created'' regular expressions: |
|
593 | 2145 |
\begin{center} |
618 | 2146 |
\begin{mathpar} |
2147 |
\inferrule{\mbox{}}{ \textit{createdByStar}\; \RSEQ{ra}{\RSTAR{rb}} } |
|
2148 |
||
2149 |
\inferrule{ \textit{createdByStar} \; r_1\; \land \; \textit{createdByStar} \; r_2 }{\textit{createdByStar} \; (r_1 + r_2) } |
|
2150 |
\end{mathpar} |
|
593 | 2151 |
\end{center} |
618 | 2152 |
\noindent |
2153 |
All regular expressions created by taking derivatives of |
|
2154 |
$r_1 \cdot (r_2)^*$ satisfy the $\textit{createdByStar}$ predicate: |
|
2155 |
\begin{lemma}\label{starDersCbs} |
|
2156 |
$\textit{createdByStar} \; ((r_1 \cdot r_2^*) \backslash_r s) $ holds. |
|
2157 |
\end{lemma} |
|
2158 |
\begin{proof} |
|
2159 |
By a reverse induction on $s$. |
|
2160 |
\end{proof} |
|
2161 |
If a regular expression conforms to the shape of a star's derivative, |
|
2162 |
then we can push an application of $\hflataux{\_}$ inside a derivative of it: |
|
2163 |
\begin{lemma}\label{hfauPushin} |
|
2164 |
If $\textit{createdByStar} \; r$ holds, then |
|
2165 |
\begin{center} |
|
2166 |
$\hflataux{r \backslash_r c} = \textit{concat} \; ( |
|
2167 |
\map \; \hflataux{\_} (\map \; (\_\backslash_r c) \;(\hflataux{r})))$ |
|
2168 |
\end{center} |
|
2169 |
holds. |
|
2170 |
\end{lemma} |
|
2171 |
\begin{proof} |
|
640
bd1354127574
more proofreading done, last version before submission
Chengsong
parents:
639
diff
changeset
|
2172 |
By an induction on the inductive cases of $\textit{createdByStar}$. |
618 | 2173 |
\end{proof} |
2174 |
%This is not entirely true for annotated regular expressions: |
|
2175 |
%%TODO: bsimp bders \neq bderssimp |
|
2176 |
%\begin{center} |
|
2177 |
% $(1+ (c\cdot \ASEQ{bs}{c^*}{c} ))$ |
|
2178 |
%\end{center} |
|
2179 |
%For bit-codes, the order in which simplification is applied |
|
2180 |
%might cause a difference in the location they are placed. |
|
2181 |
%If we want something like |
|
2182 |
%\begin{center} |
|
2183 |
% $\bderssimp{r}{s} \myequiv \bsimp{\bders{r}{s}}$ |
|
2184 |
%\end{center} |
|
2185 |
%Some "canonicalization" procedure is required, |
|
2186 |
%which either pushes all the common bitcodes to nodes |
|
2187 |
%as senior as possible: |
|
2188 |
%\begin{center} |
|
2189 |
% $_{bs}(_{bs_1 @ bs'}r_1 + _{bs_1 @ bs''}r_2) \rightarrow _{bs @ bs_1}(_{bs'}r_1 + _{bs''}r_2) $ |
|
2190 |
%\end{center} |
|
2191 |
%or does the reverse. However bitcodes are not of interest if we are talking about |
|
2192 |
%the $\llbracket r \rrbracket$ size of a regex. |
|
2193 |
%Therefore for the ease and simplicity of producing a |
|
2194 |
%proof for a size bound, we are happy to restrict ourselves to |
|
2195 |
%unannotated regular expressions, and obtain such equalities as |
|
2196 |
%TODO: rsimp sflat |
|
2197 |
% The simplification of a flattened out regular expression, provided it comes |
|
2198 |
%from the derivative of a star, is the same as the one nested. |
|
2199 |
||
2200 |
||
2201 |
||
2202 |
Now we introduce an inductive property |
|
2203 |
for $\starupdate$ and $\hflataux{\_}$. |
|
2204 |
\begin{lemma}\label{starHfauInduct} |
|
2205 |
If we do derivatives of $r^*$ |
|
2206 |
with a string that starts with $c$, |
|
2207 |
then flatten it out, |
|
2208 |
we obtain a list |
|
2209 |
of the shape $\sum_{s' \in sS} (r\backslash_r s') \cdot r^*$, |
|
2210 |
where $sS = \starupdates \; s \; r \; [[c]]$. Namely, |
|
2211 |
\begin{center} |
|
620 | 2212 |
$\hflataux{(( (\rder{c}{r_0})\cdot(r_0^*))\backslash_{rs} s)} = |
618 | 2213 |
\map \; (\lambda s_1. (r_0 \backslash_r s_1) \cdot (r_0^*)) \; |
2214 |
(\starupdates \; s \; r_0 \; [[c]])$ |
|
2215 |
\end{center} |
|
2216 |
holds. |
|
2217 |
\end{lemma} |
|
2218 |
\begin{proof} |
|
2219 |
By an induction on $s$, the inductive cases |
|
2220 |
being $[]$ and $s@[c]$. The lemmas \ref{hfauPushin} and \ref{starDersCbs} are used. |
|
2221 |
\end{proof} |
|
2222 |
\noindent |
|
2223 |
||
639 | 2224 |
The function $\hflataux{\_}$ has a similar effect as $\textit{flatten}$: |
618 | 2225 |
\begin{lemma}\label{hflatauxGrewrites} |
2226 |
$a :: rs \grewrites \hflataux{a} @ rs$ |
|
2227 |
\end{lemma} |
|
2228 |
\begin{proof} |
|
2229 |
By induction on $a$. $rs$ is set to take arbitrary values. |
|
2230 |
\end{proof} |
|
638 | 2231 |
It is also not surprising that |
2232 |
two regular expressions differing only in terms |
|
2233 |
of the |
|
2234 |
nesting of parentheses are equivalent w.r.t. $\textit{rsimp}$: |
|
618 | 2235 |
\begin{lemma}\label{cbsHfauRsimpeq1} |
2236 |
$\rsimp{(r_1 + r_2)} = \rsimp{(\RALTS{\hflataux{r_1} @ \hflataux{r_2}})}$ |
|
593 | 2237 |
\end{lemma} |
2238 |
||
2239 |
\begin{proof} |
|
2240 |
By using the rewriting relation $\rightsquigarrow$ |
|
2241 |
\end{proof} |
|
640
bd1354127574
more proofreading done, last version before submission
Chengsong
parents:
639
diff
changeset
|
2242 |
And from this we obtain the following fact: a |
639 | 2243 |
regular expression created by star |
2244 |
is the same as its flattened version, up to equivalence under $\textit{bsimp}$. |
|
593 | 2245 |
For example, |
618 | 2246 |
\begin{lemma}\label{hfauRsimpeq2} |
639 | 2247 |
$\textit{createdByStar} \; r \implies \rsimp{r} = \rsimp{\RALTS{\hflataux{r}}}$ |
593 | 2248 |
\end{lemma} |
2249 |
\begin{proof} |
|
618 | 2250 |
By structural induction on $r$, where the induction rules |
2251 |
are these of $\createdByStar{\_}$. |
|
2252 |
Lemma \ref{cbsHfauRsimpeq1} is used in the inductive case. |
|
593 | 2253 |
\end{proof} |
564 | 2254 |
|
2255 |
||
618 | 2256 |
%Here is a corollary that states the lemma in |
2257 |
%a more intuitive way: |
|
2258 |
%\begin{corollary} |
|
2259 |
% $\hflataux{r^* \backslash_r (c::xs)} = \map \; (\lambda s. (r \backslash_r s) \cdot |
|
2260 |
% (r^*))\; (\starupdates \; c\; r\; [[c]])$ |
|
2261 |
%\end{corollary} |
|
2262 |
%\noindent |
|
2263 |
%Note that this is also agnostic of the simplification |
|
2264 |
%function we defined, and is therefore of more general interest. |
|
2265 |
||
2266 |
Together with the rewriting relation |
|
2267 |
\begin{lemma}\label{starClosedForm6Hrewrites} |
|
2268 |
We have the following set of rewriting relations or equalities: |
|
2269 |
\begin{itemize} |
|
2270 |
\item |
|
2271 |
$\textit{rsimp} \; (r^* \backslash_r (c::s)) |
|
2272 |
\sequal |
|
2273 |
\sum \; ( ( \sum (\lambda s. (r\backslash_r s) \cdot r^*) \; ( |
|
2274 |
\starupdates \; s \; r \; [ c::[]] ) ) )$ |
|
2275 |
\item |
|
620 | 2276 |
$r \backslash_{rsimps} (c::s) = \textit{rsimp} \; ( ( |
618 | 2277 |
\sum ( (\map \; (\lambda s_1. (r\backslash s_1) \; r^*) \; |
2278 |
(\starupdates \;s \; r \; [ c::[] ])))))$ |
|
2279 |
\item |
|
2280 |
$\sum ( (\map \; (\lambda s. (r\backslash s) \; r^*) \; Ss)) |
|
2281 |
\sequal |
|
2282 |
\sum ( (\map \; (\lambda s. \textit{rsimp} \; (r\backslash s) \; |
|
2283 |
r^*) \; Ss) )$ |
|
2284 |
\item |
|
2285 |
$\map \; (\lambda s. (\rsimp{r \backslash_r s}) \cdot (r^*)) \; Ss |
|
2286 |
\scfrewrites |
|
2287 |
\map \; (\lambda s. (\rsimp{r \backslash_r s}) \cdot (r^*)) \; Ss$ |
|
2288 |
\item |
|
2289 |
$( ( \sum ( ( \map \ (\lambda s. \;\; |
|
2290 |
(\textit{rsimp} \; (r \backslash_r s)) \cdot r^*) \; (\starupdates \; |
|
2291 |
s \; r \; [ c::[] ])))))$\\ |
|
2292 |
$\sequal$\\ |
|
2293 |
$( ( \sum ( ( \map \ (\lambda s. \;\; |
|
620 | 2294 |
( r \backslash_{rsimps} s)) \cdot r^*) \; (\starupdates \; |
618 | 2295 |
s \; r \; [ c::[] ]))))$\\ |
2296 |
\end{itemize} |
|
558 | 2297 |
\end{lemma} |
2298 |
\begin{proof} |
|
618 | 2299 |
Part 1 leads to part 2. |
2300 |
The rest of them are routine. |
|
558 | 2301 |
\end{proof} |
2302 |
\noindent |
|
618 | 2303 |
Next the closed form for star regular expressions can be derived: |
2304 |
\begin{theorem}\label{starClosedForm} |
|
558 | 2305 |
$\rderssimp{r^*}{c::s} = |
2306 |
\rsimp{ |
|
2307 |
(\sum (\map \; (\lambda s. (\rderssimp{r}{s})\cdot r^*) \; |
|
593 | 2308 |
(\starupdates \; s\; r \; [[c]]) |
558 | 2309 |
) |
593 | 2310 |
) |
2311 |
} |
|
558 | 2312 |
$ |
618 | 2313 |
\end{theorem} |
558 | 2314 |
\begin{proof} |
2315 |
By an induction on $s$. |
|
618 | 2316 |
The lemmas \ref{rsimpIdem}, \ref{starHfauInduct}, \ref{starClosedForm6Hrewrites} |
2317 |
and \ref{hfauRsimpeq2} |
|
558 | 2318 |
are used. |
618 | 2319 |
In \ref{starClosedForm6Hrewrites}, the equalities are |
2320 |
used to link the LHS and RHS. |
|
558 | 2321 |
\end{proof} |
609 | 2322 |
|
2323 |
||
2324 |
||
2325 |
||
2326 |
||
2327 |
||
613 | 2328 |
%---------------------------------------------------------------------------------------- |
2329 |
% SECTION ?? |
|
2330 |
%---------------------------------------------------------------------------------------- |
|
2331 |
||
2332 |
%----------------------------------- |
|
2333 |
% SECTION syntactic equivalence under simp |
|
2334 |
%----------------------------------- |
|
2335 |
||
2336 |
||
2337 |
%---------------------------------------------------------------------------------------- |
|
2338 |
% SECTION ALTS CLOSED FORM |
|
2339 |
%---------------------------------------------------------------------------------------- |
|
2340 |
%\section{A Closed Form for \textit{ALTS}} |
|
2341 |
%Now we prove that $rsimp (rders\_simp (RALTS rs) s) = rsimp (RALTS (map (\lambda r. rders\_simp r s) rs))$. |
|
2342 |
% |
|
2343 |
% |
|
2344 |
%There are a few key steps, one of these steps is |
|
2345 |
% |
|
2346 |
% |
|
2347 |
% |
|
2348 |
%One might want to prove this by something a simple statement like: |
|
2349 |
% |
|
2350 |
%For this to hold we want the $\textit{distinct}$ function to pick up |
|
2351 |
%the elements before and after derivatives correctly: |
|
2352 |
%$r \in rset \equiv (rder x r) \in (rder x rset)$. |
|
2353 |
%which essentially requires that the function $\backslash$ is an injective mapping. |
|
2354 |
% |
|
2355 |
%Unfortunately the function $\backslash c$ is not an injective mapping. |
|
2356 |
% |
|
2357 |
%\subsection{function $\backslash c$ is not injective (1-to-1)} |
|
2358 |
%\begin{center} |
|
2359 |
% The derivative $w.r.t$ character $c$ is not one-to-one. |
|
2360 |
% Formally, |
|
2361 |
% $\exists r_1 \;r_2. r_1 \neq r_2 \mathit{and} r_1 \backslash c = r_2 \backslash c$ |
|
2362 |
%\end{center} |
|
2363 |
%This property is trivially true for the |
|
2364 |
%character regex example: |
|
2365 |
%\begin{center} |
|
2366 |
% $r_1 = e; \; r_2 = d;\; r_1 \backslash c = \ZERO = r_2 \backslash c$ |
|
2367 |
%\end{center} |
|
2368 |
%But apart from the cases where the derivative |
|
2369 |
%output is $\ZERO$, are there non-trivial results |
|
2370 |
%of derivatives which contain strings? |
|
2371 |
%The answer is yes. |
|
2372 |
%For example, |
|
2373 |
%\begin{center} |
|
2374 |
% Let $r_1 = a^*b\;\quad r_2 = (a\cdot a^*)\cdot b + b$.\\ |
|
2375 |
% where $a$ is not nullable.\\ |
|
2376 |
% $r_1 \backslash c = ((a \backslash c)\cdot a^*)\cdot c + b \backslash c$\\ |
|
2377 |
% $r_2 \backslash c = ((a \backslash c)\cdot a^*)\cdot c + b \backslash c$ |
|
2378 |
%\end{center} |
|
2379 |
%We start with two syntactically different regular expressions, |
|
2380 |
%and end up with the same derivative result. |
|
2381 |
%This is not surprising as we have such |
|
2382 |
%equality as below in the style of Arden's lemma:\\ |
|
2383 |
%\begin{center} |
|
2384 |
% $L(A^*B) = L(A\cdot A^* \cdot B + B)$ |
|
2385 |
%\end{center} |
|
2386 |
\section{Bounding Closed Forms} |
|
2387 |
||
2388 |
In this section, we introduce how we formalised the bound |
|
2389 |
on closed forms. |
|
640
bd1354127574
more proofreading done, last version before submission
Chengsong
parents:
639
diff
changeset
|
2390 |
We first show that in general the number of regular expressions up to a certain |
bd1354127574
more proofreading done, last version before submission
Chengsong
parents:
639
diff
changeset
|
2391 |
size is finite. |
618 | 2392 |
Then we prove that functions such as $\rflts$ |
613 | 2393 |
will not cause the size of r-regular expressions to grow. |
2394 |
Putting this together with a general bound |
|
2395 |
on the finiteness of distinct regular expressions |
|
640
bd1354127574
more proofreading done, last version before submission
Chengsong
parents:
639
diff
changeset
|
2396 |
up to a specific size, we obtain a bound on |
613 | 2397 |
the closed forms. |
2398 |
||
618 | 2399 |
\subsection{Finiteness of Distinct Regular Expressions} |
640
bd1354127574
more proofreading done, last version before submission
Chengsong
parents:
639
diff
changeset
|
2400 |
We define the set of regular expressions whose size is no more than |
618 | 2401 |
a certain size $N$ as $\textit{sizeNregex} \; N$: |
2402 |
\[ |
|
2403 |
\textit{sizeNregex} \; N \dn \{r\; \mid \; \llbracket r \rrbracket_r \leq N \} |
|
2404 |
\] |
|
2405 |
We have that $\textit{sizeNregex} \; N$ is always a finite set: |
|
2406 |
\begin{lemma}\label{finiteSizeN} |
|
2407 |
$\textit{finite} \; (\textit{sizeNregex} \; N)$ holds. |
|
2408 |
\end{lemma} |
|
2409 |
\begin{proof} |
|
2410 |
By splitting the set $\textit{sizeNregex} \; (N + 1)$ into |
|
2411 |
subsets by their categories: |
|
639 | 2412 |
$\{\ZERO_r, \ONE_r, c\}$, $\{r^* \mid r \in \textit{sizeNregex} \; N\}$, |
640
bd1354127574
more proofreading done, last version before submission
Chengsong
parents:
639
diff
changeset
|
2413 |
and so on. Each of these subsets is finitely bounded. |
618 | 2414 |
\end{proof} |
2415 |
\noindent |
|
2416 |
From this we get a corollary that |
|
2417 |
if forall $r \in rs$, $\rsize{r} \leq N$, then the output of |
|
2418 |
$\rdistinct{rs}{\varnothing}$ is a list of regular |
|
2419 |
expressions of finite size depending on $N$ only. |
|
2420 |
\begin{corollary}\label{finiteSizeNCorollary} |
|
2421 |
$\rsize{\rdistinct{rs}{\varnothing}} \leq c_N * N$ holds, |
|
2422 |
where the constant $c_N$ is equal to $\textit{card} \; (\textit{sizeNregex} \; |
|
2423 |
N)$. |
|
2424 |
\end{corollary} |
|
2425 |
\begin{proof} |
|
2426 |
For all $r$ in |
|
2427 |
$\textit{set} \; (\rdistinct{rs}{\varnothing})$, |
|
2428 |
it is always the case that $\rsize{r} \leq N$. |
|
2429 |
In addition, the list length is bounded by |
|
2430 |
$c_N$, yielding the desired bound. |
|
2431 |
\end{proof} |
|
2432 |
\noindent |
|
2433 |
This fact will be handy in estimating the closed form sizes. |
|
2434 |
%We have proven that the size of the |
|
2435 |
%output of $\textit{rdistinct} \; rs' \; \varnothing$ |
|
2436 |
%is bounded by a constant $N * c_N$ depending only on $N$, |
|
2437 |
%provided that each of $rs'$'s element |
|
2438 |
%is bounded by $N$. |
|
2439 |
||
639 | 2440 |
\subsection{$\textit{rsimp}$ Does Not Increase the Size} |
613 | 2441 |
Although it seems evident, we need a series |
2442 |
of non-trivial lemmas to establish that functions such as $\rflts$ |
|
2443 |
do not cause the regular expressions to grow. |
|
2444 |
\begin{lemma}\label{rsimpMonoLemmas} |
|
2445 |
\mbox{} |
|
2446 |
\begin{itemize} |
|
2447 |
\item |
|
2448 |
\[ |
|
2449 |
\llbracket \rsimpalts \; rs \rrbracket_r \leq |
|
2450 |
\llbracket \sum \; rs \rrbracket_r |
|
2451 |
\] |
|
2452 |
\item |
|
2453 |
\[ |
|
2454 |
\llbracket \rsimpseq \; r_1 \; r_2 \rrbracket_r \leq |
|
2455 |
\llbracket r_1 \cdot r_2 \rrbracket_r |
|
2456 |
\] |
|
2457 |
\item |
|
2458 |
\[ |
|
2459 |
\llbracket \rflts \; rs \rrbracket_r \leq |
|
2460 |
\llbracket rs \rrbracket_r |
|
2461 |
\] |
|
2462 |
\item |
|
2463 |
\[ |
|
2464 |
\llbracket \rDistinct \; rs \; ss \rrbracket_r \leq |
|
2465 |
\llbracket rs \rrbracket_r |
|
2466 |
\] |
|
2467 |
\item |
|
2468 |
If all elements $a$ in the set $as$ satisfy the property |
|
2469 |
that $\llbracket \textit{rsimp} \; a \rrbracket_r \leq |
|
2470 |
\llbracket a \rrbracket_r$, then we have |
|
2471 |
\[ |
|
2472 |
\llbracket \; \rsimpalts \; (\textit{rdistinct} \; |
|
2473 |
(\textit{rflts} \; (\textit{map}\;\textit{rsimp} as)) \{\}) |
|
2474 |
\rrbracket \leq |
|
2475 |
\llbracket \; \sum \; (\rDistinct \; (\rflts \;(\map \; |
|
2476 |
\textit{rsimp} \; x))\; \{ \} ) \rrbracket_r |
|
2477 |
\] |
|
2478 |
\end{itemize} |
|
2479 |
\end{lemma} |
|
2480 |
\begin{proof} |
|
640
bd1354127574
more proofreading done, last version before submission
Chengsong
parents:
639
diff
changeset
|
2481 |
Points 1, 3, and 4 can be proven by an induction on $rs$. |
613 | 2482 |
Point 2 is by case analysis on $r_1$ and $r_2$. |
2483 |
The last part is a corollary of the previous ones. |
|
2484 |
\end{proof} |
|
2485 |
\noindent |
|
2486 |
With the lemmas for each inductive case in place, we are ready to get |
|
2487 |
the non-increasing property as a corollary: |
|
2488 |
\begin{corollary}\label{rsimpMono} |
|
2489 |
$\llbracket \textit{rsimp} \; r \rrbracket_r \leq \llbracket r \rrbracket_r$ |
|
2490 |
\end{corollary} |
|
2491 |
\begin{proof} |
|
2492 |
By \ref{rsimpMonoLemmas}. |
|
2493 |
\end{proof} |
|
2494 |
||
609 | 2495 |
\subsection{Estimating the Closed Forms' sizes} |
618 | 2496 |
We recap the closed forms we obtained |
639 | 2497 |
earlier: |
558 | 2498 |
\begin{itemize} |
2499 |
\item |
|
593 | 2500 |
$\rderssimp{(\sum rs)}{s} \sequal |
2501 |
\sum \; (\map \; (\rderssimp{\_}{s}) \; rs)$ |
|
558 | 2502 |
\item |
593 | 2503 |
$\rderssimp{(r_1 \cdot r_2)}{s} \sequal \sum ((r_1 \backslash s) \cdot r_2 ) |
2504 |
:: (\map \; (r_2 \backslash \_) (\vsuf{s}{r_1}))$ |
|
558 | 2505 |
\item |
2506 |
||
593 | 2507 |
$\rderssimp{r^*}{c::s} = |
2508 |
\rsimp{ |
|
2509 |
(\sum (\map \; (\lambda s. (\rderssimp{r}{s})\cdot r^*) \; |
|
558 | 2510 |
(\starupdates \; s\; r \; [[c]]) |
593 | 2511 |
) |
2512 |
) |
|
2513 |
} |
|
2514 |
$ |
|
558 | 2515 |
\end{itemize} |
2516 |
\noindent |
|
2517 |
The closed forms on the left-hand-side |
|
2518 |
are all of the same shape: $\rsimp{ (\sum rs)} $. |
|
2519 |
Such regular expression will be bounded by the size of $\sum rs'$, |
|
2520 |
where every element in $rs'$ is distinct, and each element |
|
2521 |
can be described by some inductive sub-structures |
|
2522 |
(for example when $r = r_1 \cdot r_2$ then $rs'$ |
|
2523 |
will be solely comprised of $r_1 \backslash s'$ |
|
2524 |
and $r_2 \backslash s''$, $s'$ and $s''$ being |
|
2525 |
sub-strings of $s$). |
|
640
bd1354127574
more proofreading done, last version before submission
Chengsong
parents:
639
diff
changeset
|
2526 |
which will each have a size upper bound |
bd1354127574
more proofreading done, last version before submission
Chengsong
parents:
639
diff
changeset
|
2527 |
according to the inductive hypothesis, which controls $r \backslash s$. |
557 | 2528 |
|
558 | 2529 |
We elaborate the above reasoning by a series of lemmas |
2530 |
below, where straightforward proofs are omitted. |
|
639 | 2531 |
%We want to apply it to our setting $\rsize{\rsimp{\sum rs}}$. |
2532 |
We show that $\textit{rdistinct}$ and $\rflts$ |
|
609 | 2533 |
working together is at least as |
639 | 2534 |
good as $\textit{rdistinct}$ alone, which can be written as |
609 | 2535 |
\begin{center} |
2536 |
$\llbracket \rdistinct{(\rflts \; \textit{rs})}{\varnothing} \rrbracket_r |
|
2537 |
\leq |
|
2538 |
\llbracket \rdistinct{rs}{\varnothing} \rrbracket_r $. |
|
2539 |
\end{center} |
|
2540 |
We need this so that we know the outcome of our real |
|
2541 |
simplification is better than or equal to a rough estimate, |
|
2542 |
and therefore can be bounded by that estimate. |
|
640
bd1354127574
more proofreading done, last version before submission
Chengsong
parents:
639
diff
changeset
|
2543 |
This is a bit harder to establish compared to proving |
609 | 2544 |
$\textit{flts}$ does not make a list larger (which can |
2545 |
be proven using routine induction): |
|
2546 |
\begin{center} |
|
2547 |
$\llbracket \textit{rflts}\; rs \rrbracket_r \leq |
|
2548 |
\llbracket \textit{rs} \rrbracket_r$ |
|
2549 |
\end{center} |
|
2550 |
We cannot simply prove how each helper function |
|
2551 |
reduces the size and then put them together: |
|
2552 |
From |
|
2553 |
\begin{center} |
|
2554 |
$\llbracket \textit{rflts}\; rs \rrbracket_r \leq |
|
618 | 2555 |
\llbracket \textit{rs} \rrbracket_r$ |
609 | 2556 |
\end{center} |
2557 |
and |
|
2558 |
\begin{center} |
|
2559 |
$\llbracket \textit{rdistinct} \; rs \; \varnothing \leq |
|
2560 |
\llbracket rs \rrbracket_r$ |
|
2561 |
\end{center} |
|
618 | 2562 |
one cannot infer |
609 | 2563 |
\begin{center} |
558 | 2564 |
$\llbracket \rdistinct{(\rflts \; \textit{rs})}{\varnothing} \rrbracket_r |
2565 |
\leq |
|
2566 |
\llbracket \rdistinct{rs}{\varnothing} \rrbracket_r $. |
|
609 | 2567 |
\end{center} |
618 | 2568 |
What we can infer is that |
609 | 2569 |
\begin{center} |
2570 |
$\llbracket \rdistinct{(\rflts \; \textit{rs})}{\varnothing} \rrbracket_r |
|
2571 |
\leq |
|
2572 |
\llbracket rs \rrbracket_r$ |
|
2573 |
\end{center} |
|
2574 |
but this estimate is too rough and $\llbracket rs \rrbracket_r$ is unbounded. |
|
2575 |
The way we |
|
618 | 2576 |
get around this is by first proving a more general lemma |
609 | 2577 |
(so that the inductive case goes through): |
2578 |
\begin{lemma}\label{fltsSizeReductionAlts} |
|
2579 |
If we have three accumulator sets: |
|
2580 |
$noalts\_set$, $alts\_set$ and $corr\_set$, |
|
2581 |
satisfying: |
|
2582 |
\begin{itemize} |
|
2583 |
\item |
|
2584 |
$\forall r \in noalts\_set. \; \nexists xs.\; r = \sum xs$ |
|
2585 |
\item |
|
2586 |
$\forall r \in alts\_set. \; \exists xs. \; r = \sum xs |
|
2587 |
\; \textit{and} \; set \; xs \subseteq corr\_set$ |
|
2588 |
\end{itemize} |
|
2589 |
then we have that |
|
2590 |
\begin{center} |
|
2591 |
\begin{tabular}{lcl} |
|
2592 |
$\llbracket (\textit{rdistinct} \; (\textit{rflts} \; as) \; |
|
2593 |
(noalts\_set \cup corr\_set)) \rrbracket_r$ & $\leq$ &\\ |
|
2594 |
$\llbracket (\textit{rdistinct} \; as \; (noalts\_set \cup alts\_set \cup |
|
639 | 2595 |
\{ \ZERO_r \} )) \rrbracket_r$ & & \\ |
609 | 2596 |
\end{tabular} |
2597 |
\end{center} |
|
2598 |
holds. |
|
532 | 2599 |
\end{lemma} |
558 | 2600 |
\noindent |
618 | 2601 |
We split the accumulator into two parts: the part |
609 | 2602 |
which contains alternative regular expressions ($alts\_set$), and |
2603 |
the part without any of them($noalts\_set$). |
|
618 | 2604 |
This is because $\rflts$ opens up the alternatives in $as$, |
2605 |
causing the accumulators on both sides of the inequality |
|
2606 |
to diverge slightly. |
|
2607 |
If we want to compare the accumulators that are not |
|
2608 |
perfectly in sync, we need to consider the alternatives and non-alternatives |
|
2609 |
separately. |
|
609 | 2610 |
The set $corr\_set$ is the corresponding set |
618 | 2611 |
of $alts\_set$ with all elements under the alternative constructor |
609 | 2612 |
spilled out. |
2613 |
\begin{proof} |
|
2614 |
By induction on the list $as$. We make use of lemma \ref{rdistinctConcat}. |
|
2615 |
\end{proof} |
|
2616 |
By setting all three sets to the empty set, one gets the desired size estimate: |
|
2617 |
\begin{corollary}\label{interactionFltsDB} |
|
2618 |
$\llbracket \rdistinct{(\rflts \; \textit{rs})}{\varnothing} \rrbracket_r |
|
2619 |
\leq |
|
2620 |
\llbracket \rdistinct{rs}{\varnothing} \rrbracket_r $. |
|
2621 |
\end{corollary} |
|
2622 |
\begin{proof} |
|
2623 |
By using the lemma \ref{fltsSizeReductionAlts}. |
|
2624 |
\end{proof} |
|
2625 |
\noindent |
|
618 | 2626 |
The intuition for why this is true |
2627 |
is that if we remove duplicates from the $\textit{LHS}$, at least the same amount of |
|
558 | 2628 |
duplicates will be removed from the list $\textit{rs}$ in the $\textit{RHS}$. |
2629 |
||
2630 |
Now this $\rsimp{\sum rs}$ can be estimated using $\rdistinct{rs}{\varnothing}$: |
|
2631 |
\begin{lemma}\label{altsSimpControl} |
|
2632 |
$\rsize{\rsimp{\sum rs}} \leq \rsize{\rdistinct{rs}{\varnothing}}+ 1$ |
|
532 | 2633 |
\end{lemma} |
558 | 2634 |
\begin{proof} |
618 | 2635 |
By using corollary \ref{interactionFltsDB}. |
558 | 2636 |
\end{proof} |
2637 |
\noindent |
|
640
bd1354127574
more proofreading done, last version before submission
Chengsong
parents:
639
diff
changeset
|
2638 |
This is a key lemma in establishing the bounds of all the |
609 | 2639 |
closed forms. |
2640 |
With this we are now ready to control the sizes of |
|
618 | 2641 |
$(r_1 \cdot r_2 )\backslash s$ and $r^* \backslash s$. |
2642 |
\begin{theorem}\label{rBound} |
|
593 | 2643 |
For any regex $r$, $\exists N_r. \forall s. \; \rsize{\rderssimp{r}{s}} \leq N_r$ |
558 | 2644 |
\end{theorem} |
2645 |
\noindent |
|
2646 |
\begin{proof} |
|
593 | 2647 |
We prove this by induction on $r$. The base cases for $\RZERO$, |
2648 |
$\RONE $ and $\RCHAR{c}$ are straightforward. |
|
2649 |
In the sequence $r_1 \cdot r_2$ case, |
|
2650 |
the inductive hypotheses state |
|
2651 |
$\exists N_1. \forall s. \; \llbracket \rderssimp{r}{s} \rrbracket \leq N_1$ and |
|
2652 |
$\exists N_2. \forall s. \; \llbracket \rderssimp{r_2}{s} \rrbracket \leq N_2$. |
|
562 | 2653 |
|
593 | 2654 |
When the string $s$ is not empty, we can reason as follows |
2655 |
% |
|
2656 |
\begin{center} |
|
2657 |
\begin{tabular}{lcll} |
|
558 | 2658 |
& & $ \llbracket \rderssimp{r_1\cdot r_2 }{s} \rrbracket_r $\\ |
620 | 2659 |
& $ = $ & $\llbracket \rsimp{(\sum(r_1 \backslash_{rsimps} s \cdot r_2 \; \; :: \; \; |
2660 |
\map \; (r_2\backslash_{rsimps} \_)\; (\vsuf{s}{r})))} \rrbracket_r $ & (1) \\ |
|
2661 |
& $\leq$ & $\llbracket \rdistinct{(r_1 \backslash_{rsimps} s \cdot r_2 \; \; :: \; \; |
|
2662 |
\map \; (r_2\backslash_{rsimps} \_)\; (\vsuf{s}{r}))}{\varnothing} \rrbracket_r + 1$ & (2) \\ |
|
593 | 2663 |
& $\leq$ & $2 + N_1 + \rsize{r_2} + (N_2 * (card\;(\sizeNregex \; N_2)))$ & (3)\\ |
558 | 2664 |
\end{tabular} |
2665 |
\end{center} |
|
561 | 2666 |
\noindent |
618 | 2667 |
(1) is by theorem \ref{seqClosedForm}. |
561 | 2668 |
(2) is by \ref{altsSimpControl}. |
2669 |
(3) is by \ref{finiteSizeNCorollary}. |
|
562 | 2670 |
|
2671 |
||
2672 |
Combining the cases when $s = []$ and $s \neq []$, we get (4): |
|
2673 |
\begin{center} |
|
2674 |
\begin{tabular}{lcll} |
|
2675 |
$\rsize{(r_1 \cdot r_2) \backslash_r s}$ & $\leq$ & |
|
2676 |
$max \; (2 + N_1 + |
|
2677 |
\llbracket r_2 \rrbracket_r + |
|
2678 |
N_2 * (card\; (\sizeNregex \; N_2))) \; \rsize{r_1\cdot r_2}$ & (4) |
|
2679 |
\end{tabular} |
|
2680 |
\end{center} |
|
558 | 2681 |
|
562 | 2682 |
We reason similarly for $\STAR$. |
2683 |
The inductive hypothesis is |
|
2684 |
$\exists N. \forall s. \; \llbracket \rderssimp{r}{s} \rrbracket \leq N$. |
|
564 | 2685 |
Let $n_r = \llbracket r^* \rrbracket_r$. |
562 | 2686 |
When $s = c :: cs$ is not empty, |
2687 |
\begin{center} |
|
593 | 2688 |
\begin{tabular}{lcll} |
562 | 2689 |
& & $ \llbracket \rderssimp{r^* }{c::cs} \rrbracket_r $\\ |
620 | 2690 |
& $ = $ & $\llbracket \rsimp{(\sum (\map \; (\lambda s. (r \backslash_{rsimps} s) \cdot r^*) \; (\starupdates\; |
593 | 2691 |
cs \; r \; [[c]] )) )} \rrbracket_r $ & (5) \\ |
2692 |
& $\leq$ & $\llbracket |
|
2693 |
\rdistinct{ |
|
2694 |
(\map \; |
|
620 | 2695 |
(\lambda s. (r \backslash_{rsimps} s) \cdot r^*) \; |
593 | 2696 |
(\starupdates\; cs \; r \; [[c]] ) |
2697 |
)} |
|
562 | 2698 |
{\varnothing} \rrbracket_r + 1$ & (6) \\ |
2699 |
& $\leq$ & $1 + (\textit{card} (\sizeNregex \; (N + n_r))) |
|
2700 |
* (1 + (N + n_r)) $ & (7)\\ |
|
2701 |
\end{tabular} |
|
2702 |
\end{center} |
|
2703 |
\noindent |
|
618 | 2704 |
(5) is by theorem \ref{starClosedForm}. |
562 | 2705 |
(6) is by \ref{altsSimpControl}. |
618 | 2706 |
(7) is by corollary \ref{finiteSizeNCorollary}. |
639 | 2707 |
Combining with the case when $s = []$, one obtains |
562 | 2708 |
\begin{center} |
593 | 2709 |
\begin{tabular}{lcll} |
2710 |
$\rsize{r^* \backslash_r s}$ & $\leq$ & $max \; n_r \; 1 + (\textit{card} (\sizeNregex \; (N + n_r))) |
|
2711 |
* (1 + (N + n_r)) $ & (8)\\ |
|
2712 |
\end{tabular} |
|
562 | 2713 |
\end{center} |
2714 |
\noindent |
|
2715 |
||
2716 |
The alternative case is slightly less involved. |
|
2717 |
The inductive hypothesis |
|
2718 |
is equivalent to $\exists N. \forall r \in (\map \; (\_ \backslash_r s) \; rs). \rsize{r} \leq N$. |
|
2719 |
In the case when $s = c::cs$, we have |
|
2720 |
\begin{center} |
|
593 | 2721 |
\begin{tabular}{lcll} |
562 | 2722 |
& & $ \llbracket \rderssimp{\sum rs }{c::cs} \rrbracket_r $\\ |
620 | 2723 |
& $ = $ & $\llbracket \rsimp{(\sum (\map \; (\_ \backslash_{rsimps} s) \; rs) )} \rrbracket_r $ & (9) \\ |
2724 |
& $\leq$ & $\llbracket (\sum (\map \; (\_ \backslash_{rsimps} s) \; rs) ) \rrbracket_r $ & (10) \\ |
|
562 | 2725 |
& $\leq$ & $1 + N * (length \; rs) $ & (11)\\ |
593 | 2726 |
\end{tabular} |
562 | 2727 |
\end{center} |
2728 |
\noindent |
|
618 | 2729 |
(9) is by theorem \ref{altsClosedForm}, (10) by lemma \ref{rsimpMono} and (11) by inductive hypothesis. |
562 | 2730 |
|
639 | 2731 |
Combining with the case when $s = []$, we obtain |
562 | 2732 |
\begin{center} |
593 | 2733 |
\begin{tabular}{lcll} |
2734 |
$\rsize{\sum rs \backslash_r s}$ & $\leq$ & $max \; \rsize{\sum rs} \; 1+N*(length \; rs)$ |
|
2735 |
& (12)\\ |
|
2736 |
\end{tabular} |
|
562 | 2737 |
\end{center} |
618 | 2738 |
We have all the inductive cases proven. |
558 | 2739 |
\end{proof} |
2740 |
||
618 | 2741 |
This leads to our main result on the size bound: |
564 | 2742 |
\begin{corollary} |
618 | 2743 |
For any annotated regular expression $a$, $\exists N_r. \forall s. \; \rsize{\bderssimp{a}{s}} \leq N_r$ |
564 | 2744 |
\end{corollary} |
2745 |
\begin{proof} |
|
618 | 2746 |
By lemma \ref{sizeRelations} and theorem \ref{rBound}. |
564 | 2747 |
\end{proof} |
558 | 2748 |
\noindent |
2749 |
||
609 | 2750 |
|
2751 |
||
2752 |
||
2753 |
||
558 | 2754 |
%----------------------------------- |
2755 |
% SECTION 2 |
|
2756 |
%----------------------------------- |
|
2757 |
||
625 | 2758 |
\section{Bounded Repetitions} |
2759 |
We have promised in chapter \ref{Introduction} |
|
2760 |
that our lexing algorithm can potentially be extended |
|
2761 |
to handle bounded repetitions |
|
2762 |
in natural and elegant ways. |
|
2763 |
Now we fulfill our promise by adding support for |
|
2764 |
the ``exactly-$n$-times'' bounded regular expression $r^{\{n\}}$. |
|
2765 |
We add clauses in our derivatives-based lexing algorithms (with simplifications) |
|
2766 |
introduced in chapter \ref{Bitcoded2}. |
|
2767 |
||
2768 |
\subsection{Augmented Definitions} |
|
2769 |
There are a number of definitions that need to be augmented. |
|
2770 |
The most notable one would be the POSIX rules for $r^{\{n\}}$: |
|
2771 |
\begin{center} |
|
2772 |
\begin{mathpar} |
|
2773 |
\inferrule{\forall v \in vs_1. \vdash v:r \land |
|
2774 |
|v| \neq []\\ \forall v \in vs_2. \vdash v:r \land |v| = []\\ |
|
2775 |
\textit{length} \; (vs_1 @ vs_2) = n}{\textit{Stars} \; |
|
2776 |
(vs_1 @ vs_2) : r^{\{n\}} } |
|
2777 |
\end{mathpar} |
|
2778 |
\end{center} |
|
2779 |
As Ausaf had pointed out \cite{Ausaf}, |
|
2780 |
sometimes empty iterations have to be taken to get |
|
2781 |
a match with exactly $n$ repetitions, |
|
2782 |
and hence the $vs_2$ part. |
|
2783 |
||
2784 |
Another important definition would be the size: |
|
2785 |
\begin{center} |
|
2786 |
\begin{tabular}{lcl} |
|
2787 |
$\llbracket r^{\{n\}} \rrbracket_r$ & $\dn$ & |
|
2788 |
$\llbracket r \rrbracket_r + n$\\ |
|
2789 |
\end{tabular} |
|
2790 |
\end{center} |
|
2791 |
\noindent |
|
2792 |
Arguably we should use $\log \; n$ for the size because |
|
640
bd1354127574
more proofreading done, last version before submission
Chengsong
parents:
639
diff
changeset
|
2793 |
the number of digits increases logarithmically w.r.t $n$. |
625 | 2794 |
For simplicity we choose to add the counter directly to the size. |
2795 |
||
2796 |
The derivative w.r.t a bounded regular expression |
|
2797 |
is given as |
|
2798 |
\begin{center} |
|
2799 |
\begin{tabular}{lcl} |
|
2800 |
$r^{\{n\}} \backslash_r c$ & $\dn$ & |
|
2801 |
$r\backslash_r c \cdot r^{\{n-1\}} \;\; \textit{if} \; n \geq 1$\\ |
|
2802 |
& & $\RZERO \;\quad \quad\quad \quad |
|
2803 |
\textit{otherwise}$\\ |
|
2804 |
\end{tabular} |
|
2805 |
\end{center} |
|
2806 |
\noindent |
|
2807 |
For brevity, we sometimes use NTIMES to refer to bounded |
|
2808 |
regular expressions. |
|
2809 |
The $\mkeps$ function clause for NTIMES would be |
|
2810 |
\begin{center} |
|
2811 |
\begin{tabular}{lcl} |
|
2812 |
$\mkeps \; r^{\{n\}} $ & $\dn$ & $\Stars \; |
|
2813 |
(\textit{replicate} \; n\; (\mkeps \; r))$ |
|
2814 |
\end{tabular} |
|
2815 |
\end{center} |
|
2816 |
\noindent |
|
2817 |
The injection looks like |
|
2818 |
\begin{center} |
|
2819 |
\begin{tabular}{lcl} |
|
2820 |
$\inj \; r^{\{n\}} \; c\; (\Seq \;v \; (\Stars \; vs)) $ & |
|
2821 |
$\dn$ & $\Stars \; |
|
2822 |
((\inj \; r \;c \;v ) :: vs)$ |
|
2823 |
\end{tabular} |
|
2824 |
\end{center} |
|
2825 |
\noindent |
|
2826 |
||
2827 |
||
2828 |
\subsection{Proofs for the Augmented Lexing Algorithm} |
|
2829 |
We need to maintain two proofs with the additional $r^{\{n\}}$ |
|
2830 |
construct: the |
|
2831 |
correctness proof in chapter \ref{Bitcoded2}, |
|
2832 |
and the finiteness proof in chapter \ref{Finite}. |
|
2833 |
||
2834 |
\subsubsection{Correctness Proof Augmentation} |
|
2835 |
The correctness of $\textit{lexer}$ and $\textit{blexer}$ with bounded repetitions |
|
2836 |
have been proven by Ausaf and Urban\cite{AusafDyckhoffUrban2016}. |
|
2837 |
As they have commented, once the definitions are in place, |
|
2838 |
the proofs given for the basic regular expressions will extend to |
|
2839 |
bounded regular expressions, and there are no ``surprises''. |
|
2840 |
We confirm this point because the correctness theorem would also |
|
2841 |
extend without surprise to $\blexersimp$. |
|
2842 |
The rewrite rules such as $\rightsquigarrow$, $\stackrel{s}{\rightsquigarrow}$ and so on |
|
2843 |
do not need to be changed, |
|
2844 |
and only a few lemmas such as lemma \ref{fltsPreserves} need to be adjusted to |
|
640
bd1354127574
more proofreading done, last version before submission
Chengsong
parents:
639
diff
changeset
|
2845 |
add one more line which can be solved by the Sledgehammer tool |
625 | 2846 |
to solve the $r^{\{n\}}$ inductive case. |
2847 |
||
2848 |
||
2849 |
\subsubsection{Finiteness Proof Augmentation} |
|
2850 |
The bounded repetitions are |
|
2851 |
very similar to stars, and therefore the treatment |
|
2852 |
is similar, with minor changes to handle some slight complications |
|
2853 |
when the counter reaches 0. |
|
2854 |
The exponential growth is similar: |
|
2855 |
\begin{center} |
|
2856 |
\begin{tabular}{ll} |
|
2857 |
$r^{\{n\}} $ & $\longrightarrow_{\backslash c}$\\ |
|
2858 |
$(r\backslash c) \cdot |
|
2859 |
r^{\{n - 1\}}*$ & $\longrightarrow_{\backslash c'}$\\ |
|
2860 |
\\ |
|
2861 |
$r \backslash cc' \cdot r^{\{n - 2\}}* + |
|
2862 |
r \backslash c' \cdot r^{\{n - 1\}}*$ & |
|
2863 |
$\longrightarrow_{\backslash c''}$\\ |
|
2864 |
\\ |
|
2865 |
$(r_1 \backslash cc'c'' \cdot r^{\{n-3\}}* + |
|
2866 |
r \backslash c''\cdot r^{\{n-1\}}) + |
|
2867 |
(r \backslash c'c'' \cdot r^{\{n-2\}}* + |
|
2868 |
r \backslash c'' \cdot r^{\{n-1\}}*)$ & |
|
2869 |
$\longrightarrow_{\backslash c'''}$ \\ |
|
2870 |
\\ |
|
2871 |
$\ldots$\\ |
|
2872 |
\end{tabular} |
|
2873 |
\end{center} |
|
2874 |
Again, we assume that $r\backslash c$, $r \backslash cc'$ and so on |
|
2875 |
are all nullable. |
|
2876 |
The flattened list of terms for $r^{\{n\}} \backslash_{rs} s$ |
|
2877 |
\begin{center} |
|
2878 |
$[r_1 \backslash cc'c'' \cdot r^{\{n-3\}}*,\; |
|
2879 |
r \backslash c''\cdot r^{\{n-1\}}, \; |
|
2880 |
r \backslash c'c'' \cdot r^{\{n-2\}}*, \; |
|
2881 |
r \backslash c'' \cdot r^{\{n-1\}}*,\; \ldots ]$ |
|
2882 |
\end{center} |
|
2883 |
that comes from |
|
2884 |
\begin{center} |
|
2885 |
$(r_1 \backslash cc'c'' \cdot r^{\{n-3\}}* + |
|
2886 |
r \backslash c''\cdot r^{\{n-1\}}) + |
|
2887 |
(r \backslash c'c'' \cdot r^{\{n-2\}}* + |
|
2888 |
r \backslash c'' \cdot r^{\{n-1\}}*)+ \ldots$ |
|
2889 |
\end{center} |
|
2890 |
are made of sequences with different tails, where the counters |
|
2891 |
might differ. |
|
2892 |
The observation for maintaining the bound is that |
|
2893 |
these counters never exceed $n$, the original |
|
2894 |
counter. With the number of counters staying finite, |
|
2895 |
$\rDistinct$ will deduplicate and keep the list finite. |
|
2896 |
We introduce this idea as a lemma once we describe all |
|
2897 |
the necessary helper functions. |
|
2898 |
||
2899 |
Similar to the star case, we want |
|
2900 |
\begin{center} |
|
2901 |
$\rderssimp{r^{\{n\}}}{s} = \rsimp{\sum rs}$. |
|
2902 |
\end{center} |
|
2903 |
where $rs$ |
|
2904 |
shall be in the form of |
|
2905 |
$\map \; f \; Ss$, where $f$ is a function and |
|
2906 |
$Ss$ a list of objects to act on. |
|
2907 |
For star, the object's datatype is string. |
|
2908 |
The list of strings $Ss$ |
|
2909 |
is generated using functions |
|
2910 |
$\starupdate$ and $\starupdates$. |
|
2911 |
The function that takes a string and returns a regular expression |
|
2912 |
is the anonymous function $ |
|
2913 |
(\lambda s'. \; r\backslash s' \cdot r^{\{m\}})$. |
|
2914 |
In the NTIMES setting, |
|
2915 |
the $\starupdate$ and $\starupdates$ functions are replaced by |
|
2916 |
$\textit{nupdate}$ and $\textit{nupdates}$: |
|
2917 |
\begin{center} |
|
2918 |
\begin{tabular}{lcl} |
|
2919 |
$\nupdate \; c \; r \; [] $ & $\dn$ & $[]$\\ |
|
2920 |
$\nupdate \; c \; r \; |
|
2921 |
(\Some \; (s, \; n + 1) \; :: \; Ss)$ & $\dn$ & %\\ |
|
2922 |
$\textit{if} \; |
|
2923 |
(\rnullable \; (r \backslash_{rs} s))$ \\ |
|
2924 |
& & $\;\;\textit{then} |
|
2925 |
\;\; \Some \; (s @ [c], n + 1) :: \Some \; ([c], n) :: ( |
|
2926 |
\nupdate \; c \; r \; Ss)$ \\ |
|
2927 |
& & $\textit{else} \;\; \Some \; (s @ [c], n+1) :: ( |
|
2928 |
\nupdate \; c \; r \; Ss)$\\ |
|
2929 |
$\nupdate \; c \; r \; (\textit{None} :: Ss)$ & $\dn$ & |
|
2930 |
$(\None :: \nupdate \; c \; r \; Ss)$\\ |
|
2931 |
& & \\ |
|
2932 |
%\end{tabular} |
|
2933 |
%\end{center} |
|
2934 |
%\begin{center} |
|
2935 |
%\begin{tabular}{lcl} |
|
2936 |
$\nupdates \; [] \; r \; Ss$ & $\dn$ & $Ss$\\ |
|
2937 |
$\nupdates \; (c :: cs) \; r \; Ss$ & $\dn$ & $\nupdates \; cs \; r \; ( |
|
2938 |
\nupdate \; c \; r \; Ss)$ |
|
2939 |
\end{tabular} |
|
2940 |
\end{center} |
|
2941 |
\noindent |
|
2942 |
which take into account when a subterm |
|
2943 |
\begin{center} |
|
2944 |
$r \backslash_s s \cdot r^{\{n\}}$ |
|
2945 |
\end{center} |
|
2946 |
counter $n$ |
|
2947 |
is 0, and therefore expands to |
|
2948 |
\begin{center} |
|
2949 |
$r \backslash_s (s@[c]) \cdot r^{\{n\}} \;+ |
|
2950 |
\; \ZERO$ |
|
2951 |
\end{center} |
|
2952 |
after taking a derivative. |
|
2953 |
The object now has type |
|
2954 |
\begin{center} |
|
2955 |
$\textit{option} \;(\textit{string}, \textit{nat})$ |
|
2956 |
\end{center} |
|
2957 |
and therefore the function for converting such an option into |
|
2958 |
a regular expression term is called $\opterm$: |
|
2959 |
||
2960 |
\begin{center} |
|
2961 |
\begin{tabular}{lcl} |
|
2962 |
$\opterm \; r \; SN$ & $\dn$ & $\textit{case} \; SN\; of$\\ |
|
2963 |
& & $\;\;\Some \; (s, n) \Rightarrow |
|
2964 |
(r\backslash_{rs} s)\cdot r^{\{n\}}$\\ |
|
2965 |
& & $\;\;\None \Rightarrow |
|
2966 |
\ZERO$\\ |
|
2967 |
\end{tabular} |
|
2968 |
\end{center} |
|
2969 |
\noindent |
|
2970 |
Put together, the list $\map \; f \; Ss$ is instantiated as |
|
2971 |
\begin{center} |
|
2972 |
$\map \; (\opterm \; r) \; (\nupdates \; s \; r \; |
|
2973 |
[\Some \; ([c], n)])$. |
|
2974 |
\end{center} |
|
2975 |
For the closed form to be bounded, we would like |
|
2976 |
simplification to be applied to each term in the list. |
|
2977 |
Therefore we introduce some variants of $\opterm$, |
|
2978 |
which help conveniently express the rewriting steps |
|
2979 |
needed in the closed form proof. |
|
639 | 2980 |
We have $\optermOsimp$, $\optermosimp$ and $\optermsimp$ |
2981 |
with slightly different spellings because they help the proof to go through: |
|
625 | 2982 |
\begin{center} |
2983 |
\begin{tabular}{lcl} |
|
2984 |
$\optermOsimp \; r \; SN$ & $\dn$ & $\textit{case} \; SN\; of$\\ |
|
2985 |
& & $\;\;\Some \; (s, n) \Rightarrow |
|
2986 |
\textit{rsimp} \; ((r\backslash_{rs} s)\cdot r^{\{n\}})$\\ |
|
2987 |
& & $\;\;\None \Rightarrow |
|
2988 |
\ZERO$\\ |
|
2989 |
\\ |
|
2990 |
$\optermosimp \; r \; SN$ & $\dn$ & $\textit{case} \; SN\; of$\\ |
|
2991 |
& & $\;\;\Some \; (s, n) \Rightarrow |
|
2992 |
(\textit{rsimp} \; (r\backslash_{rs} s)) |
|
2993 |
\cdot r^{\{n\}}$\\ |
|
2994 |
& & $\;\;\None \Rightarrow |
|
2995 |
\ZERO$\\ |
|
2996 |
\\ |
|
2997 |
$\optermsimp \; r \; SN$ & $\dn$ & $\textit{case} \; SN\; of$\\ |
|
2998 |
& & $\;\;\Some \; (s, n) \Rightarrow |
|
2999 |
(r\backslash_{rsimps} s)\cdot r^{\{n\}}$\\ |
|
3000 |
& & $\;\;\None \Rightarrow |
|
3001 |
\ZERO$\\ |
|
3002 |
\end{tabular} |
|
3003 |
\end{center} |
|
3004 |
||
3005 |
||
3006 |
For a list of |
|
3007 |
$\textit{option} \;(\textit{string}, \textit{nat})$ elements, |
|
3008 |
we define the highest power for it recursively: |
|
3009 |
\begin{center} |
|
3010 |
\begin{tabular}{lcl} |
|
3011 |
$\hpa \; [] \; n $ & $\dn$ & $n$\\ |
|
3012 |
$\hpa \; (\None :: os) \; n $ & $\dn$ & $\hpa \; os \; n$\\ |
|
3013 |
$\hpa \; (\Some \; (s, n) :: os) \; m$ & $\dn$ & |
|
3014 |
$\hpa \;os \; (\textit{max} \; n\; m)$\\ |
|
3015 |
\\ |
|
3016 |
$\hpower \; rs $ & $\dn$ & $\hpa \; rs \; 0$\\ |
|
3017 |
\end{tabular} |
|
3018 |
\end{center} |
|
3019 |
||
3020 |
Now the intuition that an NTIMES regular expression's power |
|
3021 |
does not increase can be easily expressed as |
|
3022 |
\begin{lemma}\label{nupdatesMono2} |
|
3023 |
$\hpower \; (\nupdates \;s \; r \; [\Some \; ([c], n)]) \leq n$ |
|
3024 |
\end{lemma} |
|
3025 |
\begin{proof} |
|
3026 |
Note that the power is non-increasing after a $\nupdate$ application: |
|
3027 |
\begin{center} |
|
3028 |
$\hpa \;\; (\nupdate \; c \; r \; Ss)\;\; m \leq |
|
3029 |
\hpa\; \; Ss \; m$. |
|
3030 |
\end{center} |
|
3031 |
This is also the case for $\nupdates$: |
|
3032 |
\begin{center} |
|
3033 |
$\hpa \;\; (\nupdates \; s \; r \; Ss)\;\; m \leq |
|
3034 |
\hpa\; \; Ss \; m$. |
|
3035 |
\end{center} |
|
3036 |
Therefore we have that |
|
3037 |
\begin{center} |
|
3038 |
$\hpower \;\; (\nupdates \; s \; r \; Ss) \leq |
|
3039 |
\hpower \;\; Ss$ |
|
3040 |
\end{center} |
|
3041 |
which leads to the lemma being proven. |
|
3042 |
||
3043 |
\end{proof} |
|
3044 |
||
3045 |
||
3046 |
We also define the inductive rules for |
|
3047 |
the shape of derivatives of the NTIMES regular expressions:\\[-3em] |
|
3048 |
\begin{center} |
|
3049 |
\begin{mathpar} |
|
3050 |
\inferrule{\mbox{}}{\cbn \;\ZERO} |
|
3051 |
||
3052 |
\inferrule{\mbox{}}{\cbn \; \; r_a \cdot (r^{\{n\}})} |
|
3053 |
||
3054 |
\inferrule{\cbn \; r_1 \;\; \; \cbn \; r_2}{\cbn \; r_1 + r_2} |
|
3055 |
||
3056 |
\inferrule{\cbn \; r}{\cbn \; r + \ZERO} |
|
3057 |
\end{mathpar} |
|
3058 |
\end{center} |
|
3059 |
\noindent |
|
3060 |
A derivative of NTIMES fits into the shape described by $\cbn$: |
|
3061 |
\begin{lemma}\label{ntimesDersCbn} |
|
3062 |
$\cbn \; ((r' \cdot r^{\{n\}}) \backslash_{rs} s)$ holds. |
|
3063 |
\end{lemma} |
|
3064 |
\begin{proof} |
|
3065 |
By a reverse induction on $s$. |
|
3066 |
For the inductive case, note that if $\cbn \; r$ holds, |
|
3067 |
then $\cbn \; (r\backslash_r c)$ holds. |
|
3068 |
\end{proof} |
|
3069 |
\noindent |
|
640
bd1354127574
more proofreading done, last version before submission
Chengsong
parents:
639
diff
changeset
|
3070 |
In addition, for $\cbn$-shaped regular expressions, one can flatten |
625 | 3071 |
them: |
3072 |
\begin{lemma}\label{ntimesHfauPushin} |
|
3073 |
If $\cbn \; r$ holds, then $\hflataux{r \backslash_r c} = |
|
3074 |
\textit{concat} \; (\map \; \hflataux{\map \; (\_\backslash_r c) \; |
|
3075 |
(\hflataux{r})})$ |
|
3076 |
\end{lemma} |
|
3077 |
\begin{proof} |
|
3078 |
By an induction on the inductive cases of $\cbn$. |
|
3079 |
\end{proof} |
|
3080 |
\noindent |
|
3081 |
This time we do not need to define the flattening functions for NTIMES only, |
|
3082 |
because $\hflat{\_}$ and $\hflataux{\_}$ work on NTIMES already. |
|
3083 |
\begin{lemma}\label{ntimesHfauInduct} |
|
3084 |
$\hflataux{( (r\backslash_r c) \cdot r^{\{n\}}) \backslash_{rsimps} s} = |
|
3085 |
\map \; (\opterm \; r) \; (\nupdates \; s \; r \; [\Some \; ([c], n)])$ |
|
3086 |
\end{lemma} |
|
3087 |
\begin{proof} |
|
3088 |
By a reverse induction on $s$. |
|
3089 |
The lemmas \ref{ntimesHfauPushin} and \ref{ntimesDersCbn} are used. |
|
3090 |
\end{proof} |
|
3091 |
\noindent |
|
3092 |
We have a recursive property for NTIMES with $\nupdate$ |
|
3093 |
similar to that for STAR, |
|
3094 |
and one for $\nupdates $ as well: |
|
3095 |
\begin{lemma}\label{nupdateInduct1} |
|
3096 |
\mbox{} |
|
3097 |
\begin{itemize} |
|
3098 |
\item |
|
3099 |
\begin{center} |
|
3100 |
$\textit{concat} \; (\map \; (\hflataux{\_} \circ ( |
|
3101 |
\opterm \; r)) \; Ss) = \map \; (\opterm \; r) \; (\nupdate \; |
|
3102 |
c \; r \; Ss)$\\ |
|
3103 |
\end{center} |
|
3104 |
holds. |
|
3105 |
\item |
|
3106 |
\begin{center} |
|
3107 |
$\textit{concat} \; (\map \; \hflataux{\_}\; |
|
3108 |
\map \; (\_\backslash_r x) \; |
|
3109 |
(\map \; (\opterm \; r) \; (\nupdates \; xs \; r \; Ss)))$\\ |
|
3110 |
$=$\\ |
|
3111 |
$\map \; (\opterm \; r) \; (\nupdates \;(xs@[x]) \; r\;Ss)$ |
|
3112 |
\end{center} |
|
3113 |
holds. |
|
3114 |
\end{itemize} |
|
3115 |
\end{lemma} |
|
3116 |
\begin{proof} |
|
3117 |
(i) is by an induction on $Ss$. |
|
3118 |
(ii) is by an induction on $xs$. |
|
3119 |
\end{proof} |
|
3120 |
\noindent |
|
3121 |
The $\nString$ predicate is defined for conveniently |
|
3122 |
expressing that there are no empty strings in the |
|
3123 |
$\Some \;(s, n)$ elements generated by $\nupdate$: |
|
3124 |
\begin{center} |
|
3125 |
\begin{tabular}{lcl} |
|
3126 |
$\nString \; \None$ & $\dn$ & $ \textit{true}$\\ |
|
3127 |
$\nString \; (\Some \; ([], n))$ & $\dn$ & $ \textit{false}$\\ |
|
3128 |
$\nString \; (\Some \; (c::s, n))$ & $\dn$ & $ \textit{true}$\\ |
|
3129 |
\end{tabular} |
|
3130 |
\end{center} |
|
3131 |
\begin{lemma}\label{nupdatesNonempty} |
|
3132 |
If for all elements $o \in \textit{set} \; Ss$, |
|
640
bd1354127574
more proofreading done, last version before submission
Chengsong
parents:
639
diff
changeset
|
3133 |
$\nString \; o$ holds, then we have that |
625 | 3134 |
for all elements $o' \in \textit{set} \; (\nupdates \; s \; r \; Ss)$, |
3135 |
$\nString \; o'$ holds. |
|
3136 |
\end{lemma} |
|
3137 |
\begin{proof} |
|
3138 |
By an induction on $s$, where $Ss$ is set to vary over all possible values. |
|
3139 |
\end{proof} |
|
3140 |
||
3141 |
\noindent |
|
3142 |
||
3143 |
\begin{lemma}\label{ntimesClosedFormsSteps} |
|
3144 |
The following list of equalities or rewriting relations hold:\\ |
|
3145 |
(i) $r^{\{n+1\}} \backslash_{rsimps} (c::s) = |
|
3146 |
\textit{rsimp} \; (\sum (\map \; (\opterm \;r \;\_) \; (\nupdates \; |
|
3147 |
s \; r \; [\Some \; ([c], n)])))$\\ |
|
3148 |
(ii) |
|
3149 |
\begin{center} |
|
3150 |
$\sum (\map \; (\opterm \; r) \; (\nupdates \; s \; r \; [ |
|
3151 |
\Some \; ([c], n)]))$ \\ $ \sequal$\\ |
|
3152 |
$\sum (\map \; (\textit{rsimp} \circ (\opterm \; r))\; (\nupdates \; |
|
3153 |
s\;r \; [\Some \; ([c], n)]))$\\ |
|
3154 |
\end{center} |
|
3155 |
(iii) |
|
3156 |
\begin{center} |
|
3157 |
$\sum \;(\map \; (\optermosimp \; r) \; (\nupdates \; s \; r\; [\Some \; |
|
3158 |
([c], n)]))$\\ |
|
3159 |
$\sequal$\\ |
|
3160 |
$\sum \;(\map \; (\optermsimp r) \; (\nupdates \; s \; r \; [\Some \; |
|
3161 |
([c], n)])) $\\ |
|
3162 |
\end{center} |
|
3163 |
(iv) |
|
3164 |
\begin{center} |
|
3165 |
$\sum \;(\map \; (\optermosimp \; r) \; (\nupdates \; s \; r\; [\Some \; |
|
3166 |
([c], n)])) $ \\ $\sequal$\\ |
|
3167 |
$\sum \;(\map \; (\optermOsimp r) \; (\nupdates \; s \; r \; [\Some \; |
|
3168 |
([c], n)])) $\\ |
|
3169 |
\end{center} |
|
3170 |
(v) |
|
3171 |
\begin{center} |
|
3172 |
$\sum \;(\map \; (\optermOsimp r) \; (\nupdates \; s \; r \; [\Some \; |
|
3173 |
([c], n)])) $ \\ $\sequal$\\ |
|
3174 |
$\sum \; (\map \; (\textit{rsimp} \circ (\opterm \; r)) \; |
|
3175 |
(\nupdates \; s \; r \; [\Some \; ([c], n)]))$ |
|
3176 |
\end{center} |
|
3177 |
\end{lemma} |
|
3178 |
\begin{proof} |
|
3179 |
Routine. |
|
3180 |
(iii) and (iv) make use of the fact that all the strings $s$ |
|
3181 |
inside $\Some \; (s, m)$ which are elements of the list |
|
3182 |
$\nupdates \; s\;r\;[\Some\; ([c], n)]$ are non-empty, |
|
3183 |
which is from lemma \ref{nupdatesNonempty}. |
|
3184 |
Once the string in $o = \Some \; (s, n)$ is |
|
3185 |
nonempty, $\optermsimp \; r \;o$, |
|
3186 |
$\optermosimp \; r \; o$ and $\optermosimp \; \; o$ are guaranteed |
|
3187 |
to be equal. |
|
3188 |
(v) uses \ref{nupdateInduct1}. |
|
3189 |
\end{proof} |
|
3190 |
\noindent |
|
3191 |
Now we are ready to present the closed form for NTIMES: |
|
3192 |
\begin{theorem}\label{ntimesClosedForm} |
|
3193 |
The derivative of $r^{\{n+1\}}$ can be described as an alternative |
|
3194 |
containing a list |
|
3195 |
of terms:\\ |
|
3196 |
$r^{\{n+1\}} \backslash_{rsimps} (c::s) = \textit{rsimp} \; ( |
|
3197 |
\sum (\map \; (\optermsimp \; r) \; (\nupdates \; s \; r \; |
|
3198 |
[\Some \; ([c], n)])))$ |
|
3199 |
\end{theorem} |
|
3200 |
\begin{proof} |
|
3201 |
By the rewriting steps described in lemma \ref{ntimesClosedFormsSteps}. |
|
3202 |
\end{proof} |
|
3203 |
\noindent |
|
3204 |
The key observation for bounding this closed form |
|
3205 |
is that the counter on $r^{\{n\}}$ will |
|
3206 |
only decrement during derivatives: |
|
3207 |
\begin{lemma}\label{nupdatesNLeqN} |
|
3208 |
For an element $o$ in $\textit{set} \; (\nupdates \; s \; r \; |
|
3209 |
[\Some \; ([c], n)])$, either $o = \None$, or $o = \Some |
|
3210 |
\; (s', m)$ for some string $s'$ and number $m \leq n$. |
|
3211 |
\end{lemma} |
|
3212 |
\noindent |
|
3213 |
The proof is routine and therefore omitted. |
|
3214 |
This allows us to say what kind of terms |
|
3215 |
are in the list $\textit{set} \; (\map \; (\optermsimp \; r) \; ( |
|
3216 |
\nupdates \; s \; r \; [\Some \; ([c], n)]))$: |
|
3217 |
only $\ZERO_r$s or a sequence with the tail an $r^{\{m\}}$ |
|
3218 |
with a small $m$: |
|
3219 |
\begin{lemma}\label{ntimesClosedFormListElemShape} |
|
3220 |
For any element $r'$ in $\textit{set} \; (\map \; (\optermsimp \; r) \; ( |
|
3221 |
\nupdates \; s \; r \; [\Some \; ([c], n)]))$, |
|
3222 |
we have that $r'$ is either $\ZERO$ or $r \backslash_{rsimps} s' \cdot |
|
3223 |
r^{\{m\}}$ for some string $s'$ and number $m \leq n$. |
|
3224 |
\end{lemma} |
|
3225 |
\begin{proof} |
|
3226 |
Using lemma \ref{nupdatesNLeqN}. |
|
3227 |
\end{proof} |
|
3228 |
||
3229 |
\begin{theorem}\label{ntimesClosedFormBounded} |
|
3230 |
Assuming that for any string $s$, $\llbracket r \backslash_{rsimps} s |
|
3231 |
\rrbracket_r \leq N$ holds, then we have that\\ |
|
3232 |
$\llbracket r^{\{n+1\}} \backslash_{rsimps} s \rrbracket_r \leq |
|
3233 |
\textit{max} \; (c_N+1)* (N + \llbracket r^{\{n\}} \rrbracket+1)$, |
|
3234 |
where $c_N = \textit{card} \; (\textit{sizeNregex} \; ( |
|
3235 |
N + \llbracket r^{\{n\}} \rrbracket_r+1))$. |
|
3236 |
\end{theorem} |
|
3237 |
\begin{proof} |
|
639 | 3238 |
We have that for all regular expressions $r'$ in |
3239 |
\begin{center} |
|
3240 |
$\textit{set} \; (\map \; (\optermsimp \; r) \; ( |
|
625 | 3241 |
\nupdates \; s \; r \; [\Some \; ([c], n)]))$, |
639 | 3242 |
\end{center} |
625 | 3243 |
$r'$'s size is less than or equal to $N + \llbracket r^{\{n\}} |
3244 |
\rrbracket_r + 1$ |
|
3245 |
because $r'$ can only be either a $\ZERO$ or $r \backslash_{rsimps} s' \cdot |
|
3246 |
r^{\{m\}}$ for some string $s'$ and number |
|
3247 |
$m \leq n$ (lemma \ref{ntimesClosedFormListElemShape}). |
|
3248 |
In addition, we know that the list |
|
3249 |
$\map \; (\optermsimp \; r) \; ( |
|
3250 |
\nupdates \; s \; r \; [\Some \; ([c], n)])$'s size is at most |
|
3251 |
$c_N = \textit{card} \; |
|
3252 |
(\sizeNregex \; ((N + \llbracket r^{\{n\}} \rrbracket) + 1))$. |
|
3253 |
This gives us $\llbracket r \backslash_{rsimps} \;s \rrbracket_r |
|
3254 |
\leq N * c_N$. |
|
3255 |
\end{proof} |
|
3256 |
||
3257 |
We aim to formalise the correctness and size bound |
|
3258 |
for constructs like $r^{\{\ldots n\}}$, $r^{\{n \ldots\}}$ |
|
3259 |
and so on, which is still work in progress. |
|
3260 |
They should more or less follow the same recipe described in this section. |
|
640
bd1354127574
more proofreading done, last version before submission
Chengsong
parents:
639
diff
changeset
|
3261 |
Once we know how to deal with them recursively using suitable auxiliary |
bd1354127574
more proofreading done, last version before submission
Chengsong
parents:
639
diff
changeset
|
3262 |
definitions, we can routinely establish the proofs. |
625 | 3263 |
|
532 | 3264 |
|
557 | 3265 |
%---------------------------------------------------------------------------------------- |
3266 |
% SECTION 3 |
|
3267 |
%---------------------------------------------------------------------------------------- |
|
3268 |
||
532 | 3269 |
|
618 | 3270 |
\section{Comments and Future Improvements} |
3271 |
\subsection{Some Experimental Results} |
|
532 | 3272 |
What guarantee does this bound give us? |
639 | 3273 |
It states that whatever the regex is, it will not grow indefinitely. |
532 | 3274 |
Take our previous example $(a + aa)^*$ as an example: |
3275 |
\begin{center} |
|
593 | 3276 |
\begin{tabular}{@{}c@{\hspace{0mm}}c@{\hspace{0mm}}c@{}} |
3277 |
\begin{tikzpicture} |
|
3278 |
\begin{axis}[ |
|
3279 |
xlabel={number of $a$'s}, |
|
3280 |
x label style={at={(1.05,-0.05)}}, |
|
3281 |
ylabel={regex size}, |
|
3282 |
enlargelimits=false, |
|
3283 |
xtick={0,5,...,30}, |
|
3284 |
xmax=33, |
|
3285 |
ymax= 40, |
|
3286 |
ytick={0,10,...,40}, |
|
3287 |
scaled ticks=false, |
|
3288 |
axis lines=left, |
|
3289 |
width=5cm, |
|
3290 |
height=4cm, |
|
3291 |
legend entries={$(a + aa)^*$}, |
|
618 | 3292 |
legend pos=south east, |
593 | 3293 |
legend cell align=left] |
3294 |
\addplot[red,mark=*, mark options={fill=white}] table {a_aa_star.data}; |
|
3295 |
\end{axis} |
|
3296 |
\end{tikzpicture} |
|
3297 |
\end{tabular} |
|
532 | 3298 |
\end{center} |
3299 |
We are able to limit the size of the regex $(a + aa)^*$'s derivatives |
|
593 | 3300 |
with our simplification |
532 | 3301 |
rules very effectively. |
3302 |
||
3303 |
||
3304 |
In our proof for the inductive case $r_1 \cdot r_2$, the dominant term in the bound |
|
3305 |
is $l_{N_2} * N_2$, where $N_2$ is the bound we have for $\llbracket \bderssimp{r_2}{s} \rrbracket$. |
|
3306 |
Given that $l_{N_2}$ is roughly the size $4^{N_2}$, the size bound $\llbracket \bderssimp{r_1 \cdot r_2}{s} \rrbracket$ |
|
3307 |
inflates the size bound of $\llbracket \bderssimp{r_2}{s} \rrbracket$ with the function |
|
3308 |
$f(x) = x * 2^x$. |
|
3309 |
This means the bound we have will surge up at least |
|
3310 |
tower-exponentially with a linear increase of the depth. |
|
3311 |
||
640
bd1354127574
more proofreading done, last version before submission
Chengsong
parents:
639
diff
changeset
|
3312 |
One might be pretty skepticafl about what this non-elementary |
618 | 3313 |
bound can bring us. |
3314 |
It turns out that the giant bounds are far from being hit. |
|
3315 |
Here we have some test data from randomly generated regular expressions: |
|
3316 |
\begin{figure}[H] |
|
3317 |
\begin{tabular}{@{}c@{\hspace{2mm}}c@{\hspace{0mm}}c@{}} |
|
593 | 3318 |
\begin{tikzpicture} |
3319 |
\begin{axis}[ |
|
618 | 3320 |
xlabel={$n$}, |
593 | 3321 |
x label style={at={(1.05,-0.05)}}, |
3322 |
ylabel={regex size}, |
|
3323 |
enlargelimits=false, |
|
3324 |
xtick={0,5,...,30}, |
|
3325 |
xmax=33, |
|
611 | 3326 |
%ymax=1000, |
3327 |
%ytick={0,100,...,1000}, |
|
593 | 3328 |
scaled ticks=false, |
3329 |
axis lines=left, |
|
618 | 3330 |
width=4.75cm, |
3331 |
height=3.8cm, |
|
593 | 3332 |
legend entries={regex1}, |
618 | 3333 |
legend pos=north east, |
593 | 3334 |
legend cell align=left] |
3335 |
\addplot[red,mark=*, mark options={fill=white}] table {regex1_size_change.data}; |
|
3336 |
\end{axis} |
|
3337 |
\end{tikzpicture} |
|
618 | 3338 |
& |
593 | 3339 |
\begin{tikzpicture} |
3340 |
\begin{axis}[ |
|
3341 |
xlabel={$n$}, |
|
3342 |
x label style={at={(1.05,-0.05)}}, |
|
3343 |
%ylabel={time in secs}, |
|
3344 |
enlargelimits=false, |
|
3345 |
xtick={0,5,...,30}, |
|
3346 |
xmax=33, |
|
611 | 3347 |
%ymax=1000, |
3348 |
%ytick={0,100,...,1000}, |
|
593 | 3349 |
scaled ticks=false, |
3350 |
axis lines=left, |
|
618 | 3351 |
width=4.75cm, |
3352 |
height=3.8cm, |
|
593 | 3353 |
legend entries={regex2}, |
618 | 3354 |
legend pos=south east, |
593 | 3355 |
legend cell align=left] |
3356 |
\addplot[blue,mark=*, mark options={fill=white}] table {regex2_size_change.data}; |
|
3357 |
\end{axis} |
|
3358 |
\end{tikzpicture} |
|
618 | 3359 |
& |
593 | 3360 |
\begin{tikzpicture} |
3361 |
\begin{axis}[ |
|
3362 |
xlabel={$n$}, |
|
3363 |
x label style={at={(1.05,-0.05)}}, |
|
3364 |
%ylabel={time in secs}, |
|
3365 |
enlargelimits=false, |
|
3366 |
xtick={0,5,...,30}, |
|
3367 |
xmax=33, |
|
611 | 3368 |
%ymax=1000, |
3369 |
%ytick={0,100,...,1000}, |
|
593 | 3370 |
scaled ticks=false, |
3371 |
axis lines=left, |
|
618 | 3372 |
width=4.75cm, |
3373 |
height=3.8cm, |
|
593 | 3374 |
legend entries={regex3}, |
618 | 3375 |
legend pos=south east, |
593 | 3376 |
legend cell align=left] |
3377 |
\addplot[cyan,mark=*, mark options={fill=white}] table {regex3_size_change.data}; |
|
3378 |
\end{axis} |
|
3379 |
\end{tikzpicture}\\ |
|
618 | 3380 |
\multicolumn{3}{c}{} |
593 | 3381 |
\end{tabular} |
618 | 3382 |
\caption{Graphs: size change of 3 randomly generated |
3383 |
regular expressions $w.r.t.$ input string length. |
|
640
bd1354127574
more proofreading done, last version before submission
Chengsong
parents:
639
diff
changeset
|
3384 |
The x-axis represents the length of the input.} |
611 | 3385 |
\end{figure} |
532 | 3386 |
\noindent |
3387 |
Most of the regex's sizes seem to stay within a polynomial bound $w.r.t$ the |
|
3388 |
original size. |
|
591 | 3389 |
We will discuss improvements to this bound in the next chapter. |
532 | 3390 |
|
3391 |
||
3392 |
||
618 | 3393 |
\subsection{Possible Further Improvements} |
639 | 3394 |
There are two problems with this finiteness result, though:\\ |
618 | 3395 |
(i) |
3396 |
First, it is not yet a direct formalisation of our lexer's complexity, |
|
593 | 3397 |
as a complexity proof would require looking into |
3398 |
the time it takes to execute {\bf all} the operations |
|
618 | 3399 |
involved in the lexer (simp, collect, decode), not just the derivative.\\ |
3400 |
(ii) |
|
593 | 3401 |
Second, the bound is not yet tight, and we seek to improve $N_a$ so that |
618 | 3402 |
it is polynomial on $\llbracket a \rrbracket$.\\ |
3403 |
Still, we believe this contribution is useful, |
|
590 | 3404 |
because |
3405 |
\begin{itemize} |
|
3406 |
\item |
|
3407 |
||
618 | 3408 |
The size proof can serve as a starting point for a complexity |
590 | 3409 |
formalisation. |
3410 |
Derivatives are the most important phases of our lexer algorithm. |
|
640
bd1354127574
more proofreading done, last version before submission
Chengsong
parents:
639
diff
changeset
|
3411 |
Size properties about derivatives cover the majority of the algorithm |
bd1354127574
more proofreading done, last version before submission
Chengsong
parents:
639
diff
changeset
|
3412 |
and is therefore a good indication of the complexity of the entire program. |
590 | 3413 |
\item |
3414 |
The bound is already a strong indication that catastrophic |
|
3415 |
backtracking is much less likely to occur in our $\blexersimp$ |
|
3416 |
algorithm. |
|
3417 |
We refine $\blexersimp$ with $\blexerStrong$ in the next chapter |
|
639 | 3418 |
so that we conjecture the bound becomes polynomial. |
590 | 3419 |
\end{itemize} |
593 | 3420 |
|
532 | 3421 |
%---------------------------------------------------------------------------------------- |
3422 |
% SECTION 4 |
|
3423 |
%---------------------------------------------------------------------------------------- |
|
593 | 3424 |
|
3425 |
||
3426 |
||
3427 |
||
3428 |
||
3429 |
||
3430 |
||
3431 |
||
640
bd1354127574
more proofreading done, last version before submission
Chengsong
parents:
639
diff
changeset
|
3432 |
One might wonder about the actual bound rather than the loose bound we gave |
bd1354127574
more proofreading done, last version before submission
Chengsong
parents:
639
diff
changeset
|
3433 |
for the convenience of a more straightforward proof. |
532 | 3434 |
How much can the regex $r^* \backslash s$ grow? |
3435 |
As earlier graphs have shown, |
|
3436 |
%TODO: reference that graph where size grows quickly |
|
593 | 3437 |
they can grow at a maximum speed |
3438 |
exponential $w.r.t$ the number of characters, |
|
532 | 3439 |
but will eventually level off when the string $s$ is long enough. |
3440 |
If they grow to a size exponential $w.r.t$ the original regex, our algorithm |
|
3441 |
would still be slow. |
|
3442 |
And unfortunately, we have concrete examples |
|
576 | 3443 |
where such regular expressions grew exponentially large before levelling off: |
618 | 3444 |
\begin{center} |
532 | 3445 |
$(a ^ * + (aa) ^ * + (aaa) ^ * + \ldots + |
618 | 3446 |
(\underbrace{a \ldots a}_{\text{n a's}})^*)^*$ |
3447 |
\end{center} |
|
3448 |
will already have a maximum |
|
593 | 3449 |
size that is exponential on the number $n$ |
532 | 3450 |
under our current simplification rules: |
3451 |
%TODO: graph of a regex whose size increases exponentially. |
|
3452 |
\begin{center} |
|
593 | 3453 |
\begin{tikzpicture} |
3454 |
\begin{axis}[ |
|
3455 |
height=0.5\textwidth, |
|
3456 |
width=\textwidth, |
|
3457 |
xlabel=number of a's, |
|
3458 |
xtick={0,...,9}, |
|
3459 |
ylabel=maximum size, |
|
3460 |
ymode=log, |
|
3461 |
log basis y={2} |
|
3462 |
] |
|
3463 |
\addplot[mark=*,blue] table {re-chengsong.data}; |
|
3464 |
\end{axis} |
|
3465 |
\end{tikzpicture} |
|
532 | 3466 |
\end{center} |
3467 |
||
618 | 3468 |
For convenience we use $(\sum_{i=1}^{n} (\underbrace{a \ldots a}_{\text{i a's}})^*)^*$ |
532 | 3469 |
to express $(a ^ * + (aa) ^ * + (aaa) ^ * + \ldots + |
3470 |
(\underbrace{a \ldots a}_{\text{n a's}})^*$ in the below discussion. |
|
3471 |
The exponential size is triggered by that the regex |
|
618 | 3472 |
$\sum_{i=1}^{n} (\underbrace{a \ldots a}_{\text{i a's}})^*$ |
532 | 3473 |
inside the $(\ldots) ^*$ having exponentially many |
640
bd1354127574
more proofreading done, last version before submission
Chengsong
parents:
639
diff
changeset
|
3474 |
different derivatives, despite those differences being minor. |
618 | 3475 |
$(\sum_{i=1}^{n} (\underbrace{a \ldots a}_{\text{i a's}})^*)^*\backslash \underbrace{a \ldots a}_{\text{m a's}}$ |
532 | 3476 |
will therefore contain the following terms (after flattening out all nested |
3477 |
alternatives): |
|
3478 |
\begin{center} |
|
618 | 3479 |
$(\sum_{i = 1}^{n} (\underbrace{a \ldots a}_{\text{((i - (m' \% i))\%i) a's}})\cdot (\underbrace{a \ldots a}_{\text{i a's}})^* )\cdot (\sum_{i=1}^{n} (\underbrace{a \ldots a}_{\text{i a's}})^*)$\\ |
3480 |
[1mm] |
|
593 | 3481 |
$(1 \leq m' \leq m )$ |
532 | 3482 |
\end{center} |
639 | 3483 |
There are at least exponentially |
618 | 3484 |
many such terms.\footnote{To be exact, these terms are |
3485 |
distinct for $m' \leq L.C.M.(1, \ldots, n)$, the details are omitted, |
|
3486 |
but the point is that the number is exponential. |
|
3487 |
} |
|
593 | 3488 |
With each new input character taking the derivative against the intermediate result, more and more such distinct |
618 | 3489 |
terms will accumulate. |
3490 |
The function $\textit{distinctBy}$ will not be able to de-duplicate any two of these terms |
|
3491 |
\begin{center} |
|
3492 |
$(\sum_{i = 1}^{n} |
|
3493 |
(\underbrace{a \ldots a}_{\text{((i - (m' \% i))\%i) a's}})\cdot |
|
3494 |
(\underbrace{a \ldots a}_{\text{i a's}})^* )\cdot |
|
3495 |
(\sum_{i=1}^{n} (\underbrace{a \ldots a}_{\text{i a's}})^*)^*$\\ |
|
3496 |
$(\sum_{i = 1}^{n} (\underbrace{a \ldots a}_{\text{((i - (m'' \% i))\%i) a's}})\cdot |
|
3497 |
(\underbrace{a \ldots a}_{\text{i a's}})^* )\cdot |
|
3498 |
(\sum_{i=1}^{n} (\underbrace{a \ldots a}_{\text{i a's}})^*)^*$ |
|
3499 |
\end{center} |
|
3500 |
\noindent |
|
3501 |
where $m' \neq m''$ |
|
593 | 3502 |
as they are slightly different. |
3503 |
This means that with our current simplification methods, |
|
3504 |
we will not be able to control the derivative so that |
|
618 | 3505 |
$\llbracket \bderssimp{r}{s} \rrbracket$ stays polynomial. %\leq O((\llbracket r\rrbacket)^c)$ |
593 | 3506 |
These terms are similar in the sense that the head of those terms |
3507 |
are all consisted of sub-terms of the form: |
|
3508 |
$(\underbrace{a \ldots a}_{\text{j a's}})\cdot (\underbrace{a \ldots a}_{\text{i a's}})^* $. |
|
618 | 3509 |
For $\sum_{i=1}^{n} (\underbrace{a \ldots a}_{\text{i a's}})^*$, there will be at most |
593 | 3510 |
$n * (n + 1) / 2$ such terms. |
3511 |
For example, $(a^* + (aa)^* + (aaa)^*) ^*$'s derivatives |
|
3512 |
can be described by 6 terms: |
|
3513 |
$a^*$, $a\cdot (aa)^*$, $ (aa)^*$, |
|
3514 |
$aa \cdot (aaa)^*$, $a \cdot (aaa)^*$, and $(aaa)^*$. |
|
532 | 3515 |
The total number of different "head terms", $n * (n + 1) / 2$, |
593 | 3516 |
is proportional to the number of characters in the regex |
618 | 3517 |
$(\sum_{i=1}^{n} (\underbrace{a \ldots a}_{\text{i a's}})^*)^*$. |
3518 |
If we can improve our deduplication process so that it becomes smarter |
|
3519 |
and only keep track of these $n * (n+1) /2$ terms, then we can keep |
|
3520 |
the size growth polynomial again. |
|
3521 |
This example also suggests a slightly different notion of size, which we call the |
|
532 | 3522 |
alphabetic width: |
618 | 3523 |
\begin{center} |
3524 |
\begin{tabular}{lcl} |
|
3525 |
$\textit{awidth} \; \ZERO$ & $\dn$ & $0$\\ |
|
3526 |
$\textit{awidth} \; \ONE$ & $\dn$ & $0$\\ |
|
3527 |
$\textit{awidth} \; c$ & $\dn$ & $1$\\ |
|
3528 |
$\textit{awidth} \; r_1 + r_2$ & $\dn$ & $\textit{awidth} \; |
|
3529 |
r_1 + \textit{awidth} \; r_2$\\ |
|
3530 |
$\textit{awidth} \; r_1 \cdot r_2$ & $\dn$ & $\textit{awidth} \; |
|
3531 |
r_1 + \textit{awidth} \; r_2$\\ |
|
3532 |
$\textit{awidth} \; r^*$ & $\dn$ & $\textit{awidth} \; r$\\ |
|
3533 |
\end{tabular} |
|
3534 |
\end{center} |
|
3535 |
||
532 | 3536 |
|
593 | 3537 |
|
532 | 3538 |
Antimirov\parencite{Antimirov95} has proven that |
618 | 3539 |
$\textit{PDER}_{UNIV}(r) \leq \textit{awidth}(r)$, |
532 | 3540 |
where $\textit{PDER}_{UNIV}(r)$ is a set of all possible subterms |
3541 |
created by doing derivatives of $r$ against all possible strings. |
|
3542 |
If we can make sure that at any moment in our lexing algorithm our |
|
3543 |
intermediate result hold at most one copy of each of the |
|
3544 |
subterms then we can get the same bound as Antimirov's. |
|
3545 |
This leads to the algorithm in the next chapter. |
|
3546 |
||
3547 |
||
3548 |
||
3549 |
||
3550 |
||
3551 |
%---------------------------------------------------------------------------------------- |
|
3552 |
% SECTION 1 |
|
3553 |
%---------------------------------------------------------------------------------------- |
|
3554 |
||
3555 |
||
3556 |
%----------------------------------- |
|
3557 |
% SUBSECTION 1 |
|
3558 |
%----------------------------------- |
|
618 | 3559 |
%\subsection{Syntactic Equivalence Under $\simp$} |
640
bd1354127574
more proofreading done, last version before submission
Chengsong
parents:
639
diff
changeset
|
3560 |
%We prove that minor differences can be annihilated |
618 | 3561 |
%by $\simp$. |
3562 |
%For example, |
|
3563 |
%\begin{center} |
|
3564 |
% $\simp \;(\simpALTs\; (\map \;(\_\backslash \; x)\; (\distinct \; \mathit{rs}\; \phi))) = |
|
3565 |
% \simp \;(\simpALTs \;(\distinct \;(\map \;(\_ \backslash\; x) \; \mathit{rs}) \; \phi))$ |
|
3566 |
%\end{center} |
|
532 | 3567 |