Browse Source

Improve currying slides

Julian Ospald 4 years ago
parent
commit
686f4fc438
No account linked to committer's email address

+ 1
- 1
VL2/VL2_document_structure.tex View File

@@ -54,10 +54,10 @@
54 54
 
55 55
 \subsection{\ifger{Schlussfolgerung}{Conclusion}}
56 56
 \slide{./content/VL2_currying5.tex}
57
+\slide{./content/VL2_currying5.1.tex}[ (cnt.)]
57 58
 
58 59
 \subsection{Partial application}
59 60
 \slide{./content/VL2_currying6.tex}
60
-\slide{./content/VL2_currying6.2.tex}
61 61
 
62 62
 \subsection{Curry \ifger{und}{and} Uncurry}
63 63
 \slide{./content/VL2_currying7.tex}

+ 10
- 0
VL2/content/VL2_currying5.1.tex View File

@@ -0,0 +1,10 @@
1
+\ifger{Also, wenn wir in Haskell scheinbar mehrere Argumente einer Funktion übergeben, steckt immer Currying dahinter. Es erzeugt eine Reihe von Zwischenfunktionen (oder anonyme Funktionen) mit jeweils einem Argument und evaluiert diese dann schrittweise.}{So, if we seemingly pass multiple arguments into a function, then there is always currying behind it. It creates those intermediate/anonymous functions, all with one argument only, and then evaluates them stepwise.}
2
+
3
+\begin{haskellcode}
4
+-- this is more or less just syntax sugar...
5
+f x y z = x + y + z
6
+-- ...for this
7
+f = \x -> (\y -> (\z -> x + y + z)) -- right-associative
8
+\end{haskellcode}
9
+
10
+\ifger{Frage: was passiert, wenn wir nur $x = 3$ übergeben?}{Question: what happens if we just pass $x = 3$?}

+ 2
- 4
VL2/content/VL2_currying5.tex View File

@@ -1,5 +1,6 @@
1 1
 \ifger{D.h. mathematisch gesehen können wir schreiben:}{So in mathematical terms you can say:}\\
2 2
 $f : A_1 \times ... \times A_n \mapsto B$
3
+\vspace{\baselineskip}
3 4
 \\
4 5
 \ifger{wird zu}{gets modified into:}\\
5 6
 \pause
@@ -15,7 +16,4 @@ f :: Int -> (Int -> Int)
15 16
 -- but this is NOT the same
16 17
 f :: (Int -> Int) -> Int
17 18
 \end{haskellcode}
18
-\ifger{Auf der anderen Seite ist Funktionsanwendung \emph{links}-assoziativ, d.h.}{On the other hand function application is \emph{left}-associative, so} \hinline{f 3 2} \ifger{ist nur die Kurzform für}{is just a shorthand of} \hinline{(f 3) 2}.
19
-\vspace{\baselineskip}
20
-\\
21
-\ifger{Also, wenn wir in Haskell scheinbar mehrere Argumente einer Funktion übergeben, steckt immer Currying dahinter. Es erzeugt eine Reihe von (Zwischen-)Funktionen mit jeweils einem Argument und evaluiert diese dann schrittweise.}{So, if we seemingly pass multiple arguments into a function, then that's always currying in disguise. It create those (intermediate) functions, all with one argument only, and then evaluates them stepwise.}
19
+\ifger{Auf der anderen Seite ist Funktionsanwendung \emph{links}-assoziativ, d.h.}{On the other hand function application is \emph{left}-associative, so} \hinline{f 3 2} \ifger{ist nur die Kurzform für}{is just a shorthand of} \hinline{(f 3) 2}.

+ 0
- 14
VL2/content/VL2_currying6.2.tex View File

@@ -1,15 +0,0 @@
1
-\ifger{Wer es unbedingt wissen will, der Grund warum wir \hinline{x} auslassen können ist, dass}{The reason we can omit the \hinline{x} here is that}
2
-\begin{haskellcode}
3
-f x y z = ...
4
-\end{haskellcode}
5
-\ifger{mehr oder weniger nur syntax sugar ist für}{is more or less just syntax sugar for}
6
-\begin{haskellcode}
7
-f = \x -> (\y -> (\z -> ... )) -- right-associative, ofc
8
-\end{haskellcode}
9
-\ifger{D.h. wir hätten auch folgendes schreiben können:}{That means we could have said:}
10
-\begin{haskellcode}
11
-addTwo :: Int -> Int
12
-addTwo = \x -> (addInt 2) x
13
-addTwo x = (addInt 2) x
14
-\end{haskellcode}

+ 6
- 2
VL2/content/VL2_currying6.tex View File

@@ -3,12 +3,16 @@
3 3
 \begin{haskellcode}
4 4
 addInt :: Int -> Int -> Int
5 5
 addInt x y = x + y
6
+-- which is equivalent to this as we already know
7
+addInt = \x -> (\y -> x + y)
6 8
 
7 9
 addTwo :: Int -> Int
8 10
 addTwo = addInt 2
11
+-- equivalent to
12
+addTwo = \y -> addInt 2 y
9 13
 \end{haskellcode}
10
-\ifger{Warum haben wir nicht \hinline{addTwo x = ...} geschrieben? Wieso sollten wir? Wir haben \hinline{addInt} ein Argument übergeben, also ist die Arität (im Beispiel vorher Dimension) einer weniger und damit ist noch ein Argument notwendig um den endgültigen Wert zu bekommen.
14
+\ifger{Wir haben \hinline{addInt} ein Argument übergeben, also ist die Arität (im Beispiel vorher Dimension) einer weniger und damit ist noch ein Argument notwendig um den endgültigen Wert zu bekommen.
11 15
 \vspace{\baselineskip}\\
12
-Oder in anderen Worten: wir haben der Zwischenfunktion, die Currying für uns erstellt hat, lediglich den Namen \hinline{addTwo} gegeben.}{You probably noticed that we did not write \hinline{addTwo x = ...}, but why would we? We gave \hinline{addInt} one argument, so the arity (we called it dimension in the gemoetrical example) is one less, but there is still one parameter left we can pass in.
16
+Oder in anderen Worten: wir haben der Zwischenfunktion, die Currying für uns erstellt hat, lediglich den Namen \hinline{addTwo} gegeben.}{We gave \hinline{addInt} one argument, so the arity (we called it dimension in the gemoetrical example) is one less, but there is still one argument left we can pass in.
13 17
 \vspace{\baselineskip}\\
14 18
 Or in other words: we just gave the intermediate function that currying created for us the name \hinline{addTwo}. That's it.}\vspace{\baselineskip}\\