diff --git a/Lectures/Figures/Maze2.pdf b/Lectures/Figures/Maze2.pdf new file mode 100644 index 0000000000000000000000000000000000000000..de66cd7b8e0181efb3287cca142ec2d1a8d74d51 Binary files /dev/null and b/Lectures/Figures/Maze2.pdf differ diff --git a/Lectures/L12_OOD/OOD.pdf b/Lectures/L12_OOD/OOD.pdf index cd3279e7119b1c3519c57e4c46e369bd8bc798a3..5da333d62a53c65b4710451c4730abd0472b190b 100644 Binary files a/Lectures/L12_OOD/OOD.pdf and b/Lectures/L12_OOD/OOD.pdf differ diff --git a/Lectures/L12_OOD/OOD.tex b/Lectures/L12_OOD/OOD.tex index 2ad827b2539d336d0536919cb6a79171b36936d2..ab7e5aadd96299bf401cbd3d4ef66e124c799b20 100755 --- a/Lectures/L12_OOD/OOD.tex +++ b/Lectures/L12_OOD/OOD.tex @@ -223,10 +223,10 @@ tp\_get & ~ & T & ~\\ \begin{itemize} \item B inherits from A \item Conversely, A generalizes B -\end{itemize} \item A is a superclass of B \item B is a subclass of A \end{itemize} +\end{itemize} ~\\ \structure<1>{In Python, what class do all classes inherit?}\\ %object ~\\ diff --git a/Lectures/L18_ModulesWithExternalInteraction/ModulesWithExternalInteraction.pdf b/Lectures/L18_ModulesWithExternalInteraction/ModulesWithExternalInteraction.pdf index d3dcdb8aca353560d80ac4478990e7d28005f7b9..298b352619b2e7520ddcb1903139f6e33ab328e6 100644 Binary files a/Lectures/L18_ModulesWithExternalInteraction/ModulesWithExternalInteraction.pdf and b/Lectures/L18_ModulesWithExternalInteraction/ModulesWithExternalInteraction.pdf differ diff --git a/Lectures/L18_ModulesWithExternalInteraction/ModulesWithExternalInteraction.tex b/Lectures/L18_ModulesWithExternalInteraction/ModulesWithExternalInteraction.tex index af6af8789e04b8fb5668e1d819350ede73eb010a..25c050370f9e4fdd730e07e6e8b41cab36c1f6ca 100755 --- a/Lectures/L18_ModulesWithExternalInteraction/ModulesWithExternalInteraction.tex +++ b/Lectures/L18_ModulesWithExternalInteraction/ModulesWithExternalInteraction.tex @@ -24,7 +24,7 @@ \input{../def-beamer} \Draftfalse -\newcommand{\topicTitle}{19 Modules with External Interaction (H\&S Section 7.4)} +\newcommand{\topicTitle}{18 Modules with External Interaction (H\&S Section 7.4)} \ifDraft \newcommand{\topic}{\topicTitle~DRAFT} \else diff --git a/Lectures/L19_MazeTracingRobot/MazeTracingRobot.pdf b/Lectures/L19_MazeTracingRobot/MazeTracingRobot.pdf index c3fece5b6cf4f0035edf0c490f2d47d08b32d45c..9c4d40027c9010ca355513066931d5c171cb7a90 100644 Binary files a/Lectures/L19_MazeTracingRobot/MazeTracingRobot.pdf and b/Lectures/L19_MazeTracingRobot/MazeTracingRobot.pdf differ diff --git a/Lectures/L19_MazeTracingRobot/MazeTracingRobot.tex b/Lectures/L19_MazeTracingRobot/MazeTracingRobot.tex index f28871d62281ccc11e480578b03cfe8b4b9b9189..2ed9d4d5f15f39c665b33bb4240dae79969be0f5 100755 --- a/Lectures/L19_MazeTracingRobot/MazeTracingRobot.tex +++ b/Lectures/L19_MazeTracingRobot/MazeTracingRobot.tex @@ -22,9 +22,9 @@ \mode<presentation>{} \input{../def-beamer} -\Drafttrue +\Draftfalse -\newcommand{\topicTitle}{18 Maze Tracing Robot Example} +\newcommand{\topicTitle}{19 Maze Tracing Robot Example} \ifDraft \newcommand{\topic}{\topicTitle~DRAFT} \else @@ -44,8 +44,13 @@ \begin{itemize} \item Administrative details -\item Solar water heating tank example -\item Dr.\ v.\ Mohrenschildt's maze tracing robot (\href{https://gitlab.cas.mcmaster.ca/smiths/se2aa4_cs2me3/blob/master/ReferenceMaterial/ExampleMaze_FormalSpec.pdf}{see GitLab}) +\item Dr.\ v.\ Mohrenschildt's maze tracing robot +\bi +\item + \href{https://gitlab.cas.mcmaster.ca/smiths/se2aa4_cs2me3/blob/master/ReferenceMaterial/vMohrenshildtAndPeters1998.pdf} + {see GitLab} +\item Content section on Avenue +\ei \item MIS for maze\_storage \end{itemize} @@ -61,25 +66,18 @@ TBD \else { \begin{itemize} - \item Assignment 2 \begin{itemize} -\item {Files due by 11:59 pm Feb 19} -\item {File automatically sent to partners on Feb 20} -\item Lab report due by 11:59 pm Feb 27 -\item {When returning an object, you can either create a new object or - return a reference} -\item \structure{Remember: Deque is an Abstract Object, not an ADT} +\item Part 1: February 20, 2018 +\item Partner Files: February 26, 2018 +\item Part 2: March 2, 2018 \end{itemize} \item Midterm exam \begin{itemize} -\item March 1, 7:00 pm, TSH/120 +\item Wednesday, February 28, 7:00 pm \item 90 minute duration -\item Multiple choice - 30--40 questions? -\item Open book (any paper) \end{itemize} - \end{itemize} } \fi @@ -89,149 +87,23 @@ TBD %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% \begin{frame} -\frametitle{Solar Water Heating System Example} - -\bi -\item \href{https://github.com/smiths/swhs}{https://github.com/smiths/swhs} -\item Solve ODEs for temperature of water and PCM -\item Solve for energy in water and PCM -\item Generate plots -\ei +\frametitle{Dr.\ v.\ Mohrenschildt's Maze Tracing Robot Example} \begin{figure} -{ -\includegraphics[width=0.5\textwidth]{Tank.pdf} -} +\includegraphics[scale=0.42]{ExampleMaze.pdf} \end{figure} - -\end{frame} - -%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% - -\begin{frame} -\frametitle{Anticipated Changes} - -\bi -\item The specific hardware on which the software is to run -\item The format of the initial input data -\item The format of the input parameters -\item The constraints on the input parameters -\item The format of the output data -\item The constraints on the output results -\item How the governing ODEs are defined using the input parameters -\item How the energy equations are defined using the input parameters -\item How the overall control of the calculations is orchestrated -\item The implementation of the sequence data structure -\item The algorithm used for the ODE solver -\item The implementation of plotting data -\ei - -\end{frame} - -%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% - -\begin{frame} -\frametitle{Module Hierarchy by Secrets} -\begin{table}[h!] -\centering -\begin{tabular}{p{0.3\textwidth} p{0.6\textwidth}} -\toprule -\textbf{Level 1} & \textbf{Level 2}\\ -\midrule - -{Hardware-Hiding Module} & ~ \\ -\midrule - -\multirow{6}{0.3\textwidth}{Behaviour-Hiding Module} & Input Format Module\\ -& Input Parameters Module\\ -& Output Format Module\\ -& Temperature ODEs Module\\ -& Energy Equations Module\\ -& Control Module\\ -\midrule - -\multirow{3}{0.3\textwidth}{Software Decision Module} & {Sequence Data Structure Module}\\ -& ODE Solver Module\\ -& Plotting Module\\ -\bottomrule - -\end{tabular} -\caption{Module Hierarchy} -\label{TblMH} -\end{table} -\end{frame} - -%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% - -\begin{frame} -\frametitle{Example Modules from SWHS} - -\textbf{Hardware Hiding Modules} - -\begin{description} -\item[Secrets:]The data structure and algorithm used to implement the virtual - hardware. -\item[Services:]Serves as a virtual hardware used by the rest of the - system. This module provides the interface between the hardware and the - software. So, the system can use it to display outputs or to accept inputs. -\item[Implemented By:] OS -\end{description} - -\end{frame} - -%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% - -\begin{frame} -\frametitle{Example Modules from SWHS} - -\textbf{Input Verification Module} - -\begin{description} -\item[Secrets:] The rules for the physical and software constraints. -\item[Services:] Verifies that the input parameters comply with physical and - software constraints. Throws an exception if a parameter violates a physical - constraint. Throws a warning if a parameter violates a software constraint. -\item[Implemented By:] SWHS -\end{description} - \end{frame} %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% \begin{frame} -\frametitle{Example Modules from SWHS} +\frametitle{Likely Changes?} -\textbf{ODE Solver Module} - -\begin{description} -\item[Secrets:] The algorithm to solve a system of first order ODEs. -\item[Services:] Provides solvers that take the governing equation, initial - conditions, and numerical parameters, and solve them. -\item[Implemented By:] Matlab -\end{description} - -\end{frame} - -%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% - -\begin{frame}[plain, fragile] - -\frametitle{SWHS Uses Hierarchy} - -\begin{center} -\includegraphics[scale=0.55]{UsesHierarchy.pdf} -\end{center} - -\end{frame} - -%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% - -\begin{frame} -\frametitle{Dr.\ v.\ Mohrenschildt's Maze Tracing Robot Example} +\begin{itemize} +\item \structure<1>{What is the first step in the design process?} +\item \uncover<2->{\structure<2>{What are some potential likely changes?}} +\end{itemize} -\begin{figure} -\includegraphics[scale=0.42]{ExampleMaze.pdf} -\end{figure} \end{frame} %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% @@ -242,9 +114,11 @@ TBD \begin{itemize} \item Changes to the geometry of the robot such that the mapping from a position to the robot inputs is different -\item Changes to the interface to the robot -\item Changes to the format of the maze +\item Changes to the hardware interface to the robot +\item Changes to the input format of the maze \item Changes to any constant values +\item Changes to the data structure to store the maze +\item Changes to the path finding algorithm \end{itemize} \end{frame} @@ -332,18 +206,36 @@ TBD %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% +\begin{frame} +\frametitle{Understanding Maze Storage} + +\begin{center} +\includegraphics[scale=0.5]{../Figures/Maze2.pdf} +\end{center} + +\structure{Path length is measured by the number of grid blocks. What length + are these paths?}\\ +\medskip +C$_1$, C$_2$, C$_{10}$, C$_{11}$ \\ %12 +C$_1$, C$_2$, C$_4$, C$_8$, C$_{10}$, C$_{11}$ \\ %12 +%C$_1$, C$_7$, C$_8$, C$_{10}$, C$_{11}$ \\ %12 + +\end{frame} + +%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% + \begin{frame} \frametitle{maze\_storage MIS} \textbf{Module}\\ ~\newline maze\_storage\\ -~\newline +\medskip \textbf{Uses}\\ ~\newline types\_constants \#\textit{provides NUM\_X\_CELLS, NUM\_Y\_CELLS}\\ -~\newline +\medskip \textbf{Exported Access Programs}\\ ~\newline @@ -353,12 +245,15 @@ types\_constants \#\textit{provides NUM\_X\_CELLS, NUM\_Y\_CELLS}\\ \hline ... & ... & ... & ...\\ \hline -%any thoughts from the class on the design of the interface? \end{tabular} +~\newline + +\structure{What are some potential access programs?} \end{frame} %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% + \begin{frame} \frametitle{maze\_storage Exported Access Programs} @@ -376,7 +271,7 @@ ms\_get\_maze\_start & ~ & cell & ms\_not\_initialized\\ \hline ms\_get\_maze\_end & ~ & cell & ms\_not\_initialized\\ \hline -ms\_set\_wall & cell, cell & ~ & ms\_not\_initialized, ms\_not\_valid\_wall\\ +ms\_set\_wall & cell, cell & ~ & ms\_not\_initialized, ms\_not\_valid\_wall, etc.\\ \hline ms\_is\_connected & cell, cell & boolean & ms\_not\_initialized, ms\_cell\_out\_of\_range\\ \hline @@ -390,7 +285,7 @@ cell = tuple of (x: integer, y: integer) \begin{frame} \frametitle{maze\_storage Semantics} -\textbf{State Variables}\\ +\textbf{State Variables} \uncover<1>{\structure<1>{-- Ideas?}}\\ ~\newline \uncover<2->{\structure<2>{$\mathit{maze}$: set of tuple of ( cell, cell )}}\\ \uncover<2->{\structure<2>{$\mathit{start}: \mbox{cell} $}}\\ @@ -460,8 +355,8 @@ the corresponding set routines have been called. \noindent ms\_set\_wall(c1, c2): \begin{itemize} -\item transition: \uncover<2->{\structure<2>{$\mathit{maze} := \mathit{maze} \cup \{ < c1, c2 > \}$}} -\item exception: \uncover<3->{\structure<3>{$exc := (\neg \mathit{is\_init} \Rightarrow \mbox{ms\_not\_initialized } | +\item transition: \uncover<-1>{\structure<-1>{?}}\uncover<2->{\structure<2>{$\mathit{maze} := \mathit{maze} \cup \{ < c1, c2 > \}$}} +\item exception: \uncover<-2>{\structure<-2>{?}}\uncover<3->{\structure<3>{$exc := (\neg \mathit{is\_init} \Rightarrow \mbox{ms\_not\_initialized } | \mbox{ wall\_is\_point}(c1, c2) \vee \mbox{wall\_is\_diagonal}(c1, c2) \vee \mbox{wall\_is\_out\_of\_range}(c1, c2) \Rightarrow \mbox{ms\_not\_valid\_wall})$}} \end{itemize} @@ -483,8 +378,9 @@ the corresponding set routines have been called. \mbox{ } \neg \mbox{cell\_in\_range}(c2) \Rightarrow \mbox{ms\_cell\_out\_of\_range} )$}} \end{itemize} -\# \textit{Assumes that all intermediate points are in the input. Could - rephrase to be more intelligent about it.} +\# \textit{Assume that all intermediate segments are in the set of maze walls. + Could rephrase to allow to cover a portion of a segment. The more general + case is covered on 2017 Midterm} \end{frame} @@ -548,5 +444,16 @@ How would you specify the length of a path?\\ %%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% +\begin{frame} +\frametitle{Midterm Questions} + +The +\href{https://gitlab.cas.mcmaster.ca/smiths/se2aa4_cs2me3/blob/master/MidtermExam/PreviousYears/2017/midterm1-ver1-ANS.pdf} +{Midterm 2017} has several questions related to mazes + +\end{frame} + +%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%% + \end{document} diff --git a/Tutorials/T04-A2Example/slides/T4.pdf b/Tutorials/T04-A2Example/slides/T4.pdf index a9d4f895e275dc71be37773cc2a20377412d174f..290f041c4529d7262a1c8bb1580e3f3e4ae0d86e 100644 Binary files a/Tutorials/T04-A2Example/slides/T4.pdf and b/Tutorials/T04-A2Example/slides/T4.pdf differ diff --git a/Tutorials/T04-A2Example/slides/T4.tex b/Tutorials/T04-A2Example/slides/T4.tex index 51a9b84a5fb5820c34023b365b13654f66f16c05..6cc967be55a70b82a8bd7a2d671232a3bd975df9 100644 --- a/Tutorials/T04-A2Example/slides/T4.tex +++ b/Tutorials/T04-A2Example/slides/T4.tex @@ -442,9 +442,9 @@ new TriangleT($a, b, c$): \noindent inequality\_theorem(): \begin{itemize} \item output: -$out := ((self.sides[0] + self.slide[1]) > self.sides[2]$ - $\wedge (self.sides[1] + self.slide[2]) > self.sides[0]$ -$\wedge (self.sides[0] + self.slide[2]) > self.sides[1]$) +$out := ((self.sides[0] + self.sides[1]) > self.sides[2]$ + $\wedge (self.sides[1] + self.sides[2]) > self.sides[0]$ +$\wedge (self.sides[0] + self.sides[2]) > self.sides[1]$) \item exception: \\ $ex := ((p1.xcoord()==p2.xcoord() ==p3.xcoord()$ $\vee$ \\ $p1.ycoord()==p2.ycoord() ==p3.ycoord())$ $\Rightarrow \mbox{LINE})$