bsc-leon-vatthauer/slides/sections/00_intro.tex
2024-01-22 17:57:12 +01:00

106 lines
No EOL
3.1 KiB
TeX
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

\section{Partiality in Type Theory}
\begin{frame}[t, fragile]{Partiality in Haskell}{}
In Haskell we are able to define arbitrary partial functions
\begin{itemize}
\item<1-> Some can be spotted easily by their definition:
\vskip 0.5cm
\begin{minted}{haskell}
head :: [a] -> a
head (x:xs) = x
\end{minted}
\mycallout<2->{22.5, 1.5}{
ghci> head []\\
Exception: code-examples/example.hs:2:1-14: Non-exhaustive patterns in function head
}
\item<3->
others might be more subtle:
\vskip 0.5cm
\begin{minted}{haskell}
reverse :: [a] -> [a]
reverse l = revAcc l []
where
revAcc [] a = a
revAcc (x:xs) a = revAcc xs (x:a)
\end{minted}
\mycallout<4->{22.5, 2}{
ghci> ones = 1 : ones\\
ghci> reverse ones\\
...
}
\end{itemize}
\end{frame}
\begin{frame}[t, fragile]{Partiality in Agda}{The Maybe Monad}
\begin{itemize}[<+->]
\item In Agda every function has to be total and terminating, so how do we model partial functions?
\item Simple errors can be modelled with the maybe monad
\begin{multicols}{2}
\begin{minted}{agda}
data Maybe (A : Set) : Set where
just : A → Maybe A
nothing : Maybe A
\end{minted}
\columnbreak
\begin{minted}{agda}
head : ∀ A → List A → Maybe A
head nil = nothing
head (cons x xs) = just x
\end{minted}
\end{multicols}
\item What about \mintinline{agda}|reverse| for (possibly) infinite lists:
\begin{minted}{agda}
data Colist (A : Set) : Set where
[] : Colist A
__ : A → ∞ (Colist A) → Colist A
\end{minted}
\end{itemize}
\end{frame}
\begin{frame}[t, fragile]{Partiality in Agda}{Capretta's Delay Monad}
\begin{itemize}[<+->]
\item Capretta's Delay Monad is a \textbf{coinductive} data type whose inhabitants can be viewed as suspended computations.
\vskip 0.5cm
\begin{minted}{agda}
data Delay (A : Set) : Set where
now : A → Delay A
later : ∞ (Delay A) → Delay A
\end{minted}
\vskip 0.5cm
\item The delay datatype contains a constant for non-termination:
\vskip 0.5cm
\begin{minted}{agda}
never : Delay A
never = later (♯ never)
\end{minted}
\vskip 0.5cm
\item and we can define a function for \textit{running} a computation (for some amount of steps):
\vskip 0.5cm
\begin{minted}{agda}
run_for_steps : Delay A → → Delay A
run now x for n steps = now x
run later x for zero steps = later x
run later x for suc n steps = run ♭ x for n steps
\end{minted}
\end{itemize}
\end{frame}
\begin{frame}[t, fragile]{Partiality in Agda}{Capretta's Delay Monad}
\begin{itemize}
\item Now we can define a reverse function for possibly infinite lists:
\begin{minted}{agda}
reverse : ∀ {A : Set} → Colist A → Delay (Colist A)
reverse {A} l = revAcc l []
where
revAcc : Colist A → Colist A → Delay (Colist A)
revAcc [] a = now a
revAcc (x ∷ xs) a = later (♯ revAcc (♭ xs) (x ∷ (♯ a)))
\end{minted}
\end{itemize}
\end{frame}