-
Notifications
You must be signed in to change notification settings - Fork 1
/
koch_island.py
52 lines (42 loc) · 1.01 KB
/
koch_island.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
########################################
# koch_curve.py
# lsystem representation of a koch curve
# author: stphndemos
########################################
import sys
import lsys
import turtle
segment_length = 5
angle = 90
def draw_segment():
turtle.forward(segment_length)
def draw_blank_segment():
turtle.up()
draw_segment()
turtle.down()
def turn_left():
turtle.left(angle)
def turn_right():
turtle.right(angle)
def init_turtle():
turtle.ht()
turtle.up()
turtle.speed(0)
turtle.setpos(-500, 0)
turtle.down()
alphabet = { 'F' : draw_segment,
'f' : draw_blank_segment,
'+' : turn_left,
'-' : turn_right,
}
axiom = 'F-F-F-F'
rules = { 'F' : 'F-F+F+FF-F-F+F' }
def main():
init_turtle()
koch_curve = lsys.lsystem(alphabet, axiom, rules)
tree = koch_curve.apply_rules(int(sys.argv[1]))
koch_curve.perform_actions(tree)
print 'click to exit'
turtle.exitonclick()
if __name__ == '__main__':
main()