2
0
Fork 0
mirror of https://github.com/MartinThoma/LaTeX-examples.git synced 2025-04-24 22:08:04 +02:00

Abschnitt: lambda-Kalkül hinzugefügt

This commit is contained in:
Martin Thoma 2014-03-02 18:02:13 +01:00
parent 42ac8356e1
commit c181e1f412
6 changed files with 109 additions and 0 deletions

View file

@ -162,6 +162,17 @@ Ein paar Beispiele zur Typinferenz:
\label{fig:haskell-type-hierarchy}
\end{figure}
\subsection{type}
Mit \texttt{type} können Typsynonyme erstellt werden:
\inputminted[linenos, numbersep=5pt, tabsize=4]{haskell}{scripts/haskell/alt-types.hs}
\subsection{data}
Mit dem Schlüsselwort \texttt{data} können algebraische Datentypen\xindex{Datentyp!algebraischer}
erzeugt werden:
\section{Lazy Evaluation}\xindex{Lazy Evaluation}
Haskell wertet Ausdrücke nur aus, wenn es nötig ist.

View file

@ -93,6 +93,7 @@
\input{Programmiersprachen}
\input{Programmiertechniken}
\input{Logik}
\input{lambda}
\input{Haskell}
\input{Prolog}
\input{Scala}

View file

@ -0,0 +1,87 @@
%!TEX root = Programmierparadigmen.tex
\chapter{$\lambda$-Kalkül}
Der Lambda-Kalkül ist eine formale Sprache.
In diesem Kalkül gibt es drei Arten von Termen $T$:
\begin{itemize}
\item Variablen: $x$
\item Applikationen: $(T T)$
\item Lambda: $\lambda x. T$
\end{itemize}
Es ist zu beachten, dass Funktionsapplikation linksassoziativ ist. Es gilt also:
\[a~b~c~d = ((a~b)~c)~d\]
\begin{definition}[Freie Variable]
TODO
\end{definition}
\begin{definition}[Gebundene Variable]
Eine Variable heißt gebunden, wenn sie nicht frei ist.
\end{definition}
\section{Reduktionen}
\begin{definition}[$\alpha$-Äquivalenz]
Zwei Terme $T_1, T_2$ heißen $\alpha$-Äquivalent, wenn $T_1$ durch
konsistente Umbenennung in $T_2$ überführt werden kann.
Man schreibt dann: $T_1 \overset{\alpha}{=} T_2$.
\end{definition}
\begin{beispiel}[$\alpha$-Äquivalenz]
\begin{align*}
\lambda x.x &\overset{\alpha}{=} \lambda y. y\\
\lambda x. x x &\overset{\alpha}{=} \lambda y. y y\\
\lambda x. (\lambda y. z (\lambda x. z y) y) &\overset{\alpha}{=}
\lambda a. (\lambda x. z (\lambda c. z x) x)
\end{align*}
\end{beispiel}
\begin{definition}[$\beta$-Äquivalenz]
TODO
\end{definition}
\begin{beispiel}[$\beta$-Äquivalenz]
TODO
\end{beispiel}
\begin{definition}[$\eta$-Äquivalenz]
Zwei Terme $\lambda x. f~x$ und $f$ heißen $\eta$-Äquivalent, wenn
$x$ nicht freie Variable von $f$ ist.
\end{definition}
\begin{beispiel}[$\eta$-Äquivalenz]
TODO
\end{beispiel}
\section{Auswertungsstrategien}
\begin{definition}[Normalenreihenfolge]\xindex{Normalenreihenfolge}%
In der Normalenreihenfolge-Auswertungsstrategie wird der linkeste äußerste
Redex ausgewertet.
\end{definition}
\begin{definition}[Call-By-Name]\xindex{Call-By-Name}%
In der Call-By-Name Auswertungsreihenfolge wird der linkeste äußerste Redex
reduziert, der nicht von einem $\lambda$ umgeben ist.
\end{definition}
Die Call-By-Name Auswertung wird in Funktionen verwendet.
\begin{definition}[Call-By-Value]\xindex{Call-By-Value}%
In der Call-By-Value Auswertung wird der linkeste Redex reduziert, der
nicht von einem $\lambda$ umgeben ist und dessen Argument ein Wert ist.
\end{definition}
Die Call-By-Value Auswertungsreihenfolge wird in C und Java verwendet.
Auch in Haskell werden arithmetische Ausdrücke in der Call-By-Name Auswertungsreihenfolge
reduziert.
\section{Church-Zahlen}
TODO
\section{Weiteres}
\begin{satz}[Satz von Curch-Rosser]
Wenn zwei unterschiedliche Terme $a$ und $b$ äquivalent sind, d.h. mit Reduktionsschritten beliebiger Richtung ineinander transformiert werden können, dann gibt es einen weiteren Term $c$, zu dem sowohl $a$ als auch $b$ reduziert werden können.
\end{satz}

View file

@ -0,0 +1,6 @@
data People = Person String Int
jogi :: People
jogi = Person "Joachim Löw" 50
isAdult :: People -> Bool
isAdult (Person name age) = (age >= 18)

View file

@ -0,0 +1,4 @@
type Prename = String
type Age = Double
type Person = (Prename, Age)
type Friends = [Person]