updated
authorChristian Urban <christian.urban@kcl.ac.uk>
Thu, 26 Oct 2023 14:30:20 +0100
changeset 945 5070392a1bd7
parent 944 f5d2453c5640
child 946 bee7c57c18c3
updated
progs/lexer/lexer.sc
slides/slides03.pdf
slides/slides05.pdf
slides/slides05.tex
--- a/progs/lexer/lexer.sc	Wed Oct 25 13:54:11 2023 +0100
+++ b/progs/lexer/lexer.sc	Thu Oct 26 14:30:20 2023 +0100
@@ -59,9 +59,6 @@
 
 
 
-val r : Rexp = ("a" | "b").% 
-println(r) 
-
 def nullable(r: Rexp) : Boolean = r match {
   case ZERO => false
   case ONE => true
@@ -84,8 +81,6 @@
   case RECD(_, r1) => der(c, r1)
 }
 
-println(der('a', ALT(STAR("a"), "b")))
-
 // extracts a string from a value
 def flatten(v: Val) : String = v match {
   case Empty => ""
@@ -338,7 +333,8 @@
 //
 // which has been removed in Scala 3.
 //
-// for escaping strings in Scala 3
+// for escaping strings in Scala 3 use this equivalent code
+
 import scala.quoted._
 
 def escapeImpl(raw: Expr[String])(using Quotes): Expr[String] = {
Binary file slides/slides03.pdf has changed
Binary file slides/slides05.pdf has changed
--- a/slides/slides05.tex	Wed Oct 25 13:54:11 2023 +0100
+++ b/slides/slides05.tex	Thu Oct 26 14:30:20 2023 +0100
@@ -80,7 +80,30 @@
 %  can stay unchanged. Use \texttt{ders} for CW2, not \texttt{ders2}!
 %  \end{frame}
 %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
-    
+
+{
+\setbeamercolor{background canvas}{bg=cream}
+\begin{frame}<1-10>[c]
+\end{frame}
+
+
+%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
+\begin{frame}[c]
+  \frametitle{Coursework 1: Submissions}
+  
+  \begin{itemize}
+  \item Scala (162)
+  \item Ocaml (1)
+  \item Java (1)  \ldots uses new features of Java 21  
+  \item Rust (6)
+  \end{itemize}\bigskip\bigskip  
+  
+
+\end{frame}
+%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
+}
+
+
 %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
 \begin{frame}[t]
 \frametitle{Parser}
@@ -154,6 +177,36 @@
 \end{frame}
 %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%   
 
+%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
+{
+\setbeamercolor{background canvas}{bg=cream}
+\begin{frame}[c]
+
+\begin{center}
+\begin{tikzpicture}[scale=1.5,>=stealth',very thick,
+                    every state/.style={minimum size=0pt,
+                    draw=blue!50,very thick,fill=blue!20}]
+  \node[state,initial]   (q0) at (0,2) {$q_0$};
+  \node[state,accepting] (q1) at (2,2) {$q_1$};
+  \node[state]           (q2) at (0,0) {$q_2$};
+  \node[state]           (q3) at (2,0) {$q_3$};
+
+  \path[->] (q0) edge[bend left] node[above] {\alert{$a$}} (q1)
+            (q1) edge[bend left] node[above] {\alert{$a$}} (q0)
+            (q2) edge[bend left] node[above] {\alert{$a$}} (q3)
+            (q3) edge[bend left] node[above] {\alert{$a$}} (q2)
+            (q0) edge[bend left] node[right] {\alert{$b$}} (q2)
+            (q2) edge[bend left] node[left]  {\alert{$b$}} (q0)
+            (q1) edge[bend left] node[right] {\alert{$b$}} (q3)
+            (q3) edge[bend left] node[left]  {\alert{$b$}} (q1);
+\end{tikzpicture}
+\end{center}
+
+\hfill{}Which language?
+
+\end{frame}
+}
+%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
 
 
 %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
@@ -638,6 +691,24 @@
 \end{frame}
 
 
+\begin{frame}[t]
+\begin{minipage}{1.2\textwidth}  
+  \begin{mybox3}{}\small
+    \textbf{Questions regarding CFL CW1}
+
+Dear Dr Urban    
+    
+ Regarding CW1, I am stuck on finding the nullable and derivative rules for some important regexes.\smallskip
+
+The NOT Regex nullable rule: I am not sure how to approach this, I am inclined to simply put this as the negation of the nullable function on the input regex (e.g !nullable(r)). However I have found instances where negating a nullable does not make it un-nullable. For example the negation of r* can still match regex ab (which is not nullable). So I would like some actual clarification, pointers and help in this area.\smallskip
+
+The NOT Regex derivation rule: again I am dumbfounded here, I am inclined to think that I should derive the regex and then negate that derivation. But none of this ever works. Please provide some helpful information so I can solve this.
+\end{mybox3}
+\end{minipage}
+\end{frame}
+
+
+
 \end{document}
 
 %%% Local Variables: