2013-11-07 13:19:20 +01:00
|
|
|
#lang racket
|
|
|
|
|
|
|
|
#|
|
|
|
|
SE 3 Funktional Blatt 2
|
|
|
|
Abgebende: Jim 2martens, Britta 2noack, Jan-Simon 0giesel
|
|
|
|
|#
|
|
|
|
|
|
|
|
; 1) Definitionen
|
|
|
|
(define miau 'Katze)
|
|
|
|
(define plueschi miau)
|
|
|
|
(define peter 'miau)
|
|
|
|
(define (welcherNameGiltWo PersonA PersonB)
|
|
|
|
(let ((PersonA 'Sam)
|
|
|
|
(PersonC PersonA))
|
|
|
|
PersonC))
|
|
|
|
(define xs1 '(0 1 2 miau plueschi))
|
|
|
|
(define xs3 (list miau plueschi))
|
|
|
|
(define xs2 (cons plueschi miau))
|
|
|
|
|
|
|
|
#| 1. zu 'Katze, da miau als 'Katze definiert wurde
|
|
|
|
2. zu 'Katze, da plueschi als miau definiert wurde,
|
|
|
|
welches als 'Katze definiert wurde
|
|
|
|
bei der Ausführung werden Symbole so lange ausgewertet, bis ein ' auftaucht
|
|
|
|
oder eine Zahl/ein String
|
|
|
|
3. zu 'miau, da peter als 'miau definiert wurde und ' die Auswertung von miau verhindert
|
|
|
|
4. zu 'plueschi, da die Funktion quote das Symbol selbst ohne Auswertung zurückgibt
|
|
|
|
5. zu 'Katze, da eval den Inhalt von peter auswertet, welcher das Symbol miau ist
|
|
|
|
6. wirft Fehler, da kein Symbol Katze definiert wurde, eben dieses aber in miau als Inhalt steht
|
|
|
|
durch eval wird nun versucht den Inhalt von miau auszuwerten, also den Inhalt von Katze zu finden
|
|
|
|
das geschieht, weil vor Ausführung von eval bereits plueschi zu 'Katze ausgewertet wird
|
|
|
|
7. zu 'Katze, da nun das Symbol plueschi selbst ausgewertet wird durch eval, was miau und damit 'Katze ergibt
|
|
|
|
8. zu 'Ich, da das Symbol Ich den Wert 'Sam zugewiesen bekommt und PersonC den Wert 'Ich
|
|
|
|
bei der anschließenden Rückgabe von PersonC wird daher 'Ich zurückgegeben
|
|
|
|
9. zu '(miau plueschi), da die ersten drei Listenglieder durch cdddr entfernt werden
|
|
|
|
und nur die verbleibende Liste zurückgegeben wird
|
|
|
|
10. zu 'Katze, da (cons plueschi miau) ein Paar mit den Werten 'Katze und 'Katze erzeugt
|
|
|
|
cdr gibt nun das zweite Element zurück
|
|
|
|
11. zu '(Katze), da (list plueschi miau) eine Liste '('Katze 'Katze) erzeugt
|
|
|
|
cdr schneidet das erste Element ab und gibt die verbleibende Liste zurück
|
|
|
|
12. zu 0.1411200080598672, da zunächst der Sinus von 3 berechnet wird
|
|
|
|
und eval einer Zahl eben diese zurückgibt
|
|
|
|
13. zu 'peter, da der Aufruf von welcherNameGiltWo 'peter zurückgibt
|
|
|
|
eval wird also mit ''peter aufgerufen; die Auswertung durch eval ergibt daher 'peter
|
|
|
|
14. zu 'miau, da der Aufruf von welcherNameGiltWo 'peter zurückgibt
|
|
|
|
eval wird also mit 'peter aufgerufen; eval wertet damit das Symbol peter aus, welches den Wert 'miau hat
|
|
|
|
|#
|
|
|
|
|
|
|
|
; 2.1
|
|
|
|
(define (fakultaet n)
|
|
|
|
(letrec (
|
|
|
|
; rekursive Hilfsfunktion
|
|
|
|
(helper (λ (x)
|
2013-11-10 10:27:25 +01:00
|
|
|
; 0! ergibt 1
|
2013-11-07 13:19:20 +01:00
|
|
|
(cond ([= 0 x] 1)
|
2013-11-10 10:27:25 +01:00
|
|
|
; ansonsten ergibt sich x! aus x*(x-1)!
|
2013-11-07 13:19:20 +01:00
|
|
|
(else (* x (helper (- x 1)))
|
|
|
|
)
|
|
|
|
)
|
|
|
|
)
|
|
|
|
)
|
|
|
|
)
|
2013-11-10 10:27:25 +01:00
|
|
|
; aufrufen der rekursiven Hilfsfunktion
|
2013-11-07 13:19:20 +01:00
|
|
|
(helper n)
|
|
|
|
)
|
|
|
|
)
|
|
|
|
|
|
|
|
; 2.2
|
|
|
|
(define (power r n)
|
|
|
|
(letrec (
|
|
|
|
; rekursive Hilfsfunktion
|
|
|
|
(helper (λ (x y)
|
2013-11-10 10:27:25 +01:00
|
|
|
; r⁰ ergibt immer 1
|
2013-11-07 13:19:20 +01:00
|
|
|
(cond ([= 0 y] 1)
|
2013-11-10 10:27:25 +01:00
|
|
|
; wenn y gerade ist, dann rechne (x^(y/2))²
|
2013-11-07 13:19:20 +01:00
|
|
|
([even? y]
|
|
|
|
(sqr (expt x (/ y 2)))
|
|
|
|
)
|
2013-11-10 10:27:25 +01:00
|
|
|
; ansonsten rechne x*x^(y-1)
|
2013-11-07 13:19:20 +01:00
|
|
|
(else
|
|
|
|
(* (expt x (- y 1)) x)
|
|
|
|
)
|
|
|
|
)
|
|
|
|
)
|
|
|
|
)
|
|
|
|
)
|
2013-11-10 10:27:25 +01:00
|
|
|
; aufrufen der rekursiven Hilfsfunktion
|
2013-11-07 13:19:20 +01:00
|
|
|
(helper r n)
|
|
|
|
)
|
|
|
|
)
|
|
|
|
|
|
|
|
; 2.3
|
2013-11-10 10:27:25 +01:00
|
|
|
; berechnen des Limits hier aus Gründen der Optimierung
|
|
|
|
(define limit (power 10 1000))
|
2013-11-07 13:19:20 +01:00
|
|
|
(define e
|
|
|
|
(letrec (
|
|
|
|
; rekursive Hilfsfunktion
|
|
|
|
(helper (λ (x y)
|
2013-11-10 10:27:25 +01:00
|
|
|
; wenn x kleiner als 1/(10^1000) ist, breche ab
|
|
|
|
(cond ([< x (/ 1 limit)] 0)
|
|
|
|
; ansonsten addiere x mit dem Ergebnis aus einem weiteren Aufruf
|
|
|
|
; der Hilfsfunktion
|
2013-11-07 13:19:20 +01:00
|
|
|
(else
|
|
|
|
(+ x (helper (/ 1 (fakultaet (+ y 1))) (+ y 1) ))
|
|
|
|
)
|
|
|
|
)
|
|
|
|
)
|
|
|
|
)
|
|
|
|
)
|
2013-11-10 10:27:25 +01:00
|
|
|
; aufrufen der Hilfsfunktion und multiplizieren des Ergebnisses mit
|
|
|
|
; 10^1001
|
|
|
|
(* (helper 1 0) 10 limit)
|
2013-11-07 13:19:20 +01:00
|
|
|
)
|
|
|
|
)
|
|
|
|
|
|
|
|
; 2.4
|
|
|
|
(define my-pi
|
|
|
|
(letrec (
|
|
|
|
; rekursive Hilfsfunktion
|
|
|
|
(helper (λ (x plus?)
|
2013-11-10 10:27:25 +01:00
|
|
|
; wenn x größer ist als 22000, breche ab
|
2013-11-07 13:19:20 +01:00
|
|
|
(cond ([> x 22000] 0)
|
2013-11-10 10:27:25 +01:00
|
|
|
; andernfalls fahre fort
|
2013-11-07 13:19:20 +01:00
|
|
|
(else
|
2013-11-10 10:27:25 +01:00
|
|
|
; und addiere 1/x
|
2013-11-07 13:19:20 +01:00
|
|
|
(cond (plus?
|
|
|
|
(+ (/ 1 x) (helper (+ x 2) #f))
|
|
|
|
)
|
2013-11-10 10:27:25 +01:00
|
|
|
; oder -1/x mit dem Ergebnis eines weiteren Aufrufs der Hilfsfunktion
|
2013-11-07 13:19:20 +01:00
|
|
|
(else
|
|
|
|
(+ (* -1 (/ 1 x)) (helper (+ x 2) #t))
|
|
|
|
)
|
|
|
|
)
|
|
|
|
)
|
|
|
|
)
|
|
|
|
)
|
|
|
|
))
|
2013-11-10 10:27:25 +01:00
|
|
|
; aufrufen der Hilfsfunktion und anschließendes Multiplizieren mit
|
|
|
|
; 4 und 10^1000
|
|
|
|
(* (* (helper 1 #t) 4) limit)
|
2013-11-07 13:19:20 +01:00
|
|
|
)
|
|
|
|
)
|
|
|
|
|
|
|
|
; 3
|
2013-11-10 10:27:25 +01:00
|
|
|
; Typbestimmung
|
2013-11-07 13:19:20 +01:00
|
|
|
(define (type-of input)
|
|
|
|
(cond ([boolean? input] 'boolean)
|
|
|
|
([list? input] 'list)
|
2013-11-10 10:08:41 +01:00
|
|
|
([pair? input] 'pair)
|
2013-11-07 13:19:20 +01:00
|
|
|
([symbol? input] 'symbol)
|
|
|
|
([number? input] 'number)
|
|
|
|
([char? input] 'char)
|
|
|
|
([string? input] 'string)
|
|
|
|
([vector? input] 'vector)
|
|
|
|
([procedure? input] 'procedure)
|
2013-11-10 10:08:41 +01:00
|
|
|
(else 'noneOfThem)
|
2013-11-07 13:19:20 +01:00
|
|
|
)
|
|
|
|
)
|
|
|
|
|
|
|
|
; Ausgaben
|
|
|
|
(display "(type-of (+ 3 7)): ")
|
|
|
|
(type-of (+ 3 7))
|
2013-11-10 10:08:41 +01:00
|
|
|
; zu 'number, da (+ 3 7) zunächst zu 10 und damit einer number ausgewertet wird
|
2013-11-07 13:19:20 +01:00
|
|
|
(display "(type-of type-of): ")
|
|
|
|
(type-of type-of)
|
2013-11-10 10:08:41 +01:00
|
|
|
; zu 'procedure, da type-of eine Funktion ist
|
2013-11-07 13:19:20 +01:00
|
|
|
(display "(type-of (type-of type-of)): ")
|
|
|
|
(type-of (type-of type-of))
|
2013-11-10 10:08:41 +01:00
|
|
|
; zu 'symbol, da (type-of type-of) 'procedure zurückgibt und dies ein Symbol ist
|
2013-11-07 13:19:20 +01:00
|
|
|
(display "(type-of (string-ref \"Schneewitchen_und_die_7_Zwerge\" 2)): ")
|
|
|
|
(type-of (string-ref "Schneewitchen_und_die_7_Zwerge" 2))
|
2013-11-10 10:08:41 +01:00
|
|
|
; zu 'char, da string-ref den char an der Position 2 zurückgibt
|
2013-11-07 13:19:20 +01:00
|
|
|
(display "(type-of (lambda (x) x)): ")
|
|
|
|
(type-of (lambda (x) x))
|
2013-11-10 10:08:41 +01:00
|
|
|
; zu 'procedure, da lambda eine Funktion erstellt
|
2013-11-07 13:19:20 +01:00
|
|
|
(define (id z) z)
|
|
|
|
(display "(type-of (id cos)): ")
|
|
|
|
(type-of (id cos))
|
2013-11-10 10:08:41 +01:00
|
|
|
; zu 'procedure, da id den Parameter zurückgibt, welcher eine Funktion ist
|
2013-11-07 13:19:20 +01:00
|
|
|
(display "(type-of '(1 2 3)): ")
|
|
|
|
(type-of '(1 2 3))
|
2013-11-10 10:08:41 +01:00
|
|
|
; zu 'list, da '(1 2 3) eine Liste ist
|
2013-11-07 13:19:20 +01:00
|
|
|
(display "(type-of '()): ")
|
|
|
|
(type-of '())
|
2013-11-10 10:08:41 +01:00
|
|
|
; zu 'list, da '() eine leere Liste ist
|