lehrkraefte:blc:informatik:glf22:turtle

Differences

This shows you the differences between two versions of the page.

Link to this comparison view

Both sides previous revision Previous revision
Next revision
Previous revision
lehrkraefte:blc:informatik:glf22:turtle [2023/01/12 09:35]
Ivo Blöchliger [Funktionen]
lehrkraefte:blc:informatik:glf22:turtle [2023/01/27 09:22] (current)
Ivo Blöchliger [Pythagorasbaum]
Line 63: Line 63:
  
 <hidden Lösungsvorschläge> <hidden Lösungsvorschläge>
-Das kriegen Sie jetzt aber selber hin!+<code python 12-eck.py> 
 +from kroete import Kroete 
 + 
 +t = Kroete() 
 + 
 +for i in range(12): 
 +    t.forward() 
 +    t.left(30) 
 + 
 +</code> 
 +<code python 5zack.py> 
 +from kroete import Kroete 
 + 
 +t = Kroete() 
 + 
 +for i in range(5): 
 +    t.forward(200) 
 +    t.left(144) 
 +</code> 
 +<code python n-eck.py> 
 +from kroete import Kroete 
 + 
 +n=7 
 + 
 +t = Kroete() 
 +for i in range(n): 
 +    t.forward() 
 +    t.left(360/n) 
 + 
 +</code> 
 +<code python n-zack.py> 
 +from kroete import Kroete 
 + 
 +n=11              # Anzahl Zacken 
 +m=4   # Wie viele Zacken vorwärts (darf kein Teiler von n sein!
 + 
 +t = Kroete() 
 +for i in range(n): 
 +    t.forward(200) 
 +    t.left(m*360/n) 
 +</code>
 </hidden> </hidden>
 </WRAP> </WRAP>
Line 100: Line 140:
 {{:lehrkraefte:blc:informatik:glf22:pasted:20230112-093411.png?200}} {{:lehrkraefte:blc:informatik:glf22:pasted:20230112-093411.png?200}}
 </WRAP> </WRAP>
 +
 +==== Kreis ====
 +Folgende Funktion zeichnet Kreise wobei der Mittelpunkt der aktuellen Position der Turtle entspricht:
 +<code python>
 +def kreis(schildi, r):
 +    schildi.save()  # Zustand speichern
 +    n = int(r)  # Anzahl Segmente
 +    w = 2*pi/ # Winkelschritt
 +    s = r*sqrt(sin(w)**2+(1-cos(w))**2)  # Segmentlänge
 +    schildi.move(r)
 +    schildi.left(90)
 +    for i in range(n):
 +        schildi.forward(s)
 +        schildi.left(360/n)
 +    schildi.restore()  # Zustand wieder herstellen
 +
 +</code>
 +
 +<WRAP todo>
 +  * Mathematisch gesprochen, was genau zeichnet die Funktion Kreis?
 +  * Was genau ist die Segmentlänge und woher kommt diese Formel? Begründen Sie mit einer guten Skizze (//Die Herleitung gäbe ein wunderbare Trigo-Prüfungsaufgabe//).
 +</WRAP>
 +
 +===== Rekursion =====
 +Rekursion nennt man etwas, das mit sich selbst definiert wird (plus noch etwas, um zu beginnen). In der Informatik heisst das meist, dass sich eine Funktion selbst wieder aufruft. Dabei muss natürlich peinlichst darauf geachtet werden, dass sich die Funktion nicht unendlich oft selbst wieder aufruft.
 +
 +==== Koch-Kurve ====
 +Die Koch-Kurve ist eine rekursiv definierte Kurve. 
 +  * Auf Stufe 0 ist die Kurve einfach eine Gerade
 +  * Auf Stufe 1 ist die Kurve aus 4 gleich langen Geradenstücken aufgebaut, mit entsprechenden Winkeln
 +  * Auf Stufe $n$ besteht die Kurve 4 Stücken der Stufe $n-1$, mit entsprechenden Winkeln dazwischen.
 +
 +{{:lehrkraefte:blc:informatik:glf22:pasted:20230112-102047.png}}
 +
 +<WRAP todo>
 +  * Schreiben und testen Sie eine Funktion ''koch0'', die eine Koch-Kurve der Stufe 0 zeichnet, also einfach eine Gerade. Als Argumente nimmt die Funktion eine Turtle und die Gesamtlänge entgegen.
 +  * Schreiben und testen Sie eine Funktion ''koch1'', die eine Koch-Kurve der Stufe 1 zeichnet und dabei die Funktion ''koch0'' aufruft. Als Argument nimmt die Funktion eine Turtle und die die Gesamtlänge entgegen. Die Länge einer ''koch0''-«Kurve» muss dann aus der Gesamtlänge berechnet werden.
 +  * Schreiben Sie dann eine Funktion ''koch2'', die eine Koch-Kurve der Stufe 2 zeichnet (und die natürlich die Funktion ''koch1'' benutzt). Ebenfalls gleiche Argumente.
 +  * Wie unterscheiden sich die Funktionen ''koch2'' und ''koch1''?
 +  * Anstatt jetzt noch eine Funktion ''koch3'' zu schreiben, schreiben Sie eine Funktion ''koch'', die einen zusätzlichen Parameter ''stufe'' entgegen nimmt. Ist die ''stufe'' Null, wird ein einzelner Strich gezeichnet und dann die Funktion mit ''return'' beendet. Ansonsten wird 4 mal die Funktion ''koch'' mit ''stufe-1'' aufgerufen und dazwischen entsprechend gedreht.
 +  * Zusatzaufgabe: Zeichnen Sie 3 Koch-Kurven auf einem gleichseitigen Dreieck, dass damit die «Kochschneeflocke» entsteht.
 +
 +{{:lehrkraefte:blc:informatik:glf22:pasted:20230112-103525.png}}
 +
 +</WRAP>
 +
 +
 +==== Pythagorasbaum ====
 +
 +{{:lehrkraefte:blc:informatik:glf22:pasted:20230112-105500.png}}
 +
 +<WRAP todo>
 +Um diesen Baum zu zeichnen, erstellen Sie erst eine Funktion ''element'', die folgendes Bild zeichnet:
 +
 +{{:lehrkraefte:blc:informatik:glf22:pasted:20230112-111635.png}}
 +
 +Die Funktion nimmt folgende Parameter entgegen:
 +  * Eine Turtle ''t''. Diese legt die Richtung und die Länge vom Quadrat als ''t.r'' fest.
 +  * Einen Winkel ''w'', der dem «linken» Winkel des rechtwinkligen Dreiecks entspricht.
 +  * Die Turtle startet bei «Start» und muss am Ende bei «Ende» sein. Die Schrittlänge ''t.r'' soll am Schluss unverändert sein.
 +  * Sie können dazu auch die Turtle-Methoden ''save'' und ''restore'' verwenden, um sich die Position und Zustand der Turtle zu merken.
 +
 +Hinweis: Sie können die Kathetenlängen mit trigonometrischen Funktionen aus ''w'' und ''t.r'' berechnen. 
 +
 +</WRAP>
 +
 +<WRAP todo>
 +Erweitern Sie Ihre Funktion so, dass ein zusätzlicher Parameter ''stufe'' entgegengenommen wird.
 +  * Ist die ''stufe'' Null, macht die Funktion immer noch das genau gleiche.
 +  * Sonst wird anstelle des Zeichnens der Katheten die Funktion selbst mit ''stufe-1'' aufgerufen, der Rest bleibt sich geich.
 +  * Probieren Sie verschiedene Winkel aus.
 +  * Anstatt die ''stufe'' als Abbruchkriterium zu verwenden, verwenden Sie ''t.r'', d.h. sobald die zu zeichnende Strecke z.B. kleiner als 3 ist, wird abgebrochen. So werden alle Äste bis zu einer sinnvollen Tiefe gezeichnet.
 +  * Man erhält einen interessanten Baum, wenn man statt einen konstanten Winkel ''w'' zu verwenden, zwischen ''w'' und ''90-w'' abwechselt, bzw. den je nach Stufe anpasst (z.B. als Schwingung ;-))
 +</WRAP>
 +
 +<hidden Lösungsvorschlag>
 +<code python>
 +from kroete import Kroete
 +from math import cos,sin,pi
 +
 +
 +
 +def baum(t, winkel, stufe):
 +    t.save()
 +    for i in range(4):
 +        t.forward()
 +        t.left(90)
 +    t.left(90)
 +    t.move()
 +    a = cos(winkel/180*pi)*t.r
 +    b = sin(winkel/180*pi)*t.r
 +    t.right(90-winkel)
 +    t.r = a
 +    if stufe==0 or (stufe<0 and t.r<3):
 +        t.forward()
 +    else:
 +        baum(t, winkel, stufe-1)
 +    t.right(90)
 +    t.r = b
 +    if stufe==0 or (stufe<0 and t.r<3):
 +        t.forward()
 +    else:
 +        baum(t, winkel, stufe-1)
 +    t.restore()
 +    t.move()
 +
 +
 +
 +t = Kroete()
 +t.y = -200
 +t.x = 50
 +t.r = 110
 +baum(t, 30, -1)
 +</code>
 +</hidden>
  • lehrkraefte/blc/informatik/glf22/turtle.1673512506.txt.gz
  • Last modified: 2023/01/12 09:35
  • by Ivo Blöchliger