updated
authorChristian Urban <christian dot urban at kcl dot ac dot uk>
Tue, 12 Jan 2016 02:49:26 +0000
changeset 396 4cd75c619e06
parent 395 e57d3d92b856
child 397 cf3ca219c727
updated
coursework/cw02.pdf
coursework/cw02.tex
Binary file coursework/cw02.pdf has changed
--- a/coursework/cw02.tex	Tue Jan 12 02:18:58 2016 +0000
+++ b/coursework/cw02.tex	Tue Jan 12 02:49:26 2016 +0000
@@ -69,7 +69,9 @@
 \item whitespaces are either \texttt{" "} (one or more) or \texttt{$\backslash$n}
 \item identifiers are letters followed by underscores \texttt{\_\!\_}, letters
 or digits
-\item numbers are \texttt{0}, \text{1}, \ldots
+\item numbers are \pcode{0}, \pcode{1}, \ldots and so on; give 
+a regular expression that can recognise \pcode{0}, but not numbers 
+with leading zeroes, such as \pcode{001}
 \end{enumerate}
 
 \noindent
@@ -91,8 +93,9 @@
 \end{tabular}
 \end{center}
 
-\noindent
-Try to design your regular expressions to be as small as possible.
+\noindent Try to design your regular expressions to be as
+small as possible. For example you should use character ranges
+for identifiers and numbers.
 
 \subsection*{Question 2 (marked with 3\%)}
 
@@ -117,11 +120,27 @@
 \end{center}
 
 \noindent where $inj$ takes three arguments: a regular
-expression, a character and a value. Also add the record
-regular expression from the lectures to your tokeniser and
-implement a function, say \pcode{env}, that returns all
-assignments from a value (such that you can extract easily the
-tokens from a value).\medskip 
+expression, a character and a value. Test your lexer code
+with at least the two small examples below:
+
+\begin{center}
+\begin{tabular}{ll}
+regex: & string:\smallskip\\
+$a^{\{3\}}$ & $aaa$\\
+$(a + \epsilon)^{\{3\}}$ & $aa$
+\end{tabular}
+\end{center}
+
+
+\noindent Both strings should be sucessfully lexed by the
+respective regular expression, that means the lexer returns 
+in both examples a value.
+
+
+Also add the record regular expression from the
+lectures to your tokeniser and implement a function, say
+\pcode{env}, that returns all assignments from a value (such
+that you can extract easily the tokens from a value).\medskip 
 
 \noindent
 Finally give the tokens for your regular expressions from Q1 and the