#! /usr/bin/python2.7 """ turtle-example-suite: tdemo_fractalCurves.py This program draws two fractal-curve-designs: (1) A hilbert curve (in a box) (2) A combination of Koch-curves. The CurvesTurtle class and the fractal-curve- methods are taken from the PythonCard example scripts for turtle-graphics. """ from turtle import * from time import sleep, clock class CurvesTurtle(Pen): # example derived from # Turtle Geometry: The Computer as a Medium for Exploring Mathematics # by Harold Abelson and Andrea diSessa # p. 96-98 def hilbert(self, size, level, parity): if level == 0: return # rotate and draw first subcurve with opposite parity to big curve self.left(parity * 90) self.hilbert(size, level - 1, -parity) # interface to and draw second subcurve with same parity as big curve self.forward(size) self.right(parity * 90) self.hilbert(size, level - 1, parity) # third subcurve self.forward(size) self.hilbert(size, level - 1, parity) # fourth subcurve self.right(parity * 90) self.forward(size) self.hilbert(size, level - 1, -parity) # a final turn is needed to make the turtle # end up facing outward from the large square self.left(parity * 90) # Visual Modeling with Logo: A Structural Approach to Seeing # by James Clayson # Koch curve, after Helge von Koch who introduced this geometric figure in 1904 # p. 146 def fractalgon(self, n, rad, lev, dir): import math # if dir = 1 turn outward # if dir = -1 turn inward edge = 2 * rad * math.sin(math.pi / n) self.pu() self.fd(rad) self.pd() self.rt(180 - (90 * (n - 2) / n)) for i in range(n): self.fractal(edge, lev, dir) self.rt(360 / n) self.lt(180 - (90 * (n - 2) / n)) self.pu() self.bk(rad) self.pd() # p. 146 def fractal(self, dist, depth, dir): if depth < 1: self.fd(dist) return self.fractal(dist / 3, depth - 1, dir) self.lt(60 * dir) self.fractal(dist / 3, depth - 1, dir) self.rt(120 * dir) self.fractal(dist / 3, depth - 1, dir) self.lt(60 * dir) self.fractal(dist / 3, depth - 1, dir) def main(): ft = CurvesTurtle() ft.reset() ft.speed(0) ft.ht() ft.tracer(1,0) ft.pu() size = 6 ft.setpos(-33*size, -32*size) ft.pd() ta=clock() ft.fillcolor("red") ft.fill(True) ft.fd(size) ft.hilbert(size, 6, 1) # frame ft.fd(size) for i in range(3): ft.lt(90) ft.fd(size*(64+i%2)) ft.pu() for i in range(2): ft.fd(size) ft.rt(90) ft.pd() for i in range(4): ft.fd(size*(66+i%2)) ft.rt(90) ft.fill(False) tb=clock() res = "Hilbert: %.2fsec. " % (tb-ta) sleep(3) ft.reset() ft.speed(0) ft.ht() ft.tracer(1,0) ta=clock() ft.color("black", "blue") ft.fill(True) ft.fractalgon(3, 250, 4, 1) ft.fill(True) ft.color("red") ft.fractalgon(3, 200, 4, -1) ft.fill(False) tb=clock() res += "Koch: %.2fsec." % (tb-ta) return res if __name__ == '__main__': msg = main() print msg mainloop()
Name | Type | Size | Permission | Actions |
---|---|---|---|---|
about_turtle.txt | File | 3.44 KB | 0644 |
|
about_turtledemo.txt | File | 302 B | 0644 |
|
demohelp.txt | File | 2.96 KB | 0644 |
|
tdemo_I_dontlike_tiltdemo.py | File | 1.05 KB | 0755 |
|
tdemo_I_dontlike_tiltdemo.pyc | File | 1.62 KB | 0644 |
|
tdemo_I_dontlike_tiltdemo.pyo | File | 1.62 KB | 0644 |
|
tdemo_bytedesign.py | File | 4.12 KB | 0755 |
|
tdemo_bytedesign.pyc | File | 5.19 KB | 0644 |
|
tdemo_bytedesign.pyo | File | 5.19 KB | 0644 |
|
tdemo_chaos.py | File | 951 B | 0644 |
|
tdemo_chaos.pyc | File | 2.24 KB | 0644 |
|
tdemo_chaos.pyo | File | 2.24 KB | 0644 |
|
tdemo_clock.py | File | 3.14 KB | 0755 |
|
tdemo_clock.pyc | File | 4.43 KB | 0644 |
|
tdemo_clock.pyo | File | 4.43 KB | 0644 |
|
tdemo_colormixer.py | File | 1.31 KB | 0644 |
|
tdemo_colormixer.pyc | File | 2.31 KB | 0644 |
|
tdemo_colormixer.pyo | File | 2.31 KB | 0644 |
|
tdemo_fractalcurves.py | File | 3.33 KB | 0755 |
|
tdemo_fractalcurves.pyc | File | 3.44 KB | 0644 |
|
tdemo_fractalcurves.pyo | File | 3.44 KB | 0644 |
|
tdemo_lindenmayer_indian.py | File | 2.38 KB | 0755 |
|
tdemo_lindenmayer_indian.pyc | File | 3.52 KB | 0644 |
|
tdemo_lindenmayer_indian.pyo | File | 3.52 KB | 0644 |
|
tdemo_minimal_hanoi.py | File | 2 KB | 0755 |
|
tdemo_minimal_hanoi.pyc | File | 3.54 KB | 0644 |
|
tdemo_minimal_hanoi.pyo | File | 3.54 KB | 0644 |
|
tdemo_nim.py | File | 6.36 KB | 0644 |
|
tdemo_nim.pyc | File | 9.16 KB | 0644 |
|
tdemo_nim.pyo | File | 9.16 KB | 0644 |
|
tdemo_paint.py | File | 1.26 KB | 0755 |
|
tdemo_paint.pyc | File | 1.86 KB | 0644 |
|
tdemo_paint.pyo | File | 1.86 KB | 0644 |
|
tdemo_peace.py | File | 1.04 KB | 0755 |
|
tdemo_peace.pyc | File | 1.36 KB | 0644 |
|
tdemo_peace.pyo | File | 1.36 KB | 0644 |
|
tdemo_penrose.py | File | 3.45 KB | 0755 |
|
tdemo_penrose.pyc | File | 5.86 KB | 0644 |
|
tdemo_penrose.pyo | File | 5.86 KB | 0644 |
|
tdemo_planet_and_moon.py | File | 2.76 KB | 0755 |
|
tdemo_planet_and_moon.pyc | File | 4.43 KB | 0644 |
|
tdemo_planet_and_moon.pyo | File | 4.43 KB | 0644 |
|
tdemo_tree.py | File | 1.38 KB | 0755 |
|
tdemo_tree.pyc | File | 2.07 KB | 0644 |
|
tdemo_tree.pyo | File | 2.07 KB | 0644 |
|
tdemo_two_canvases.py | File | 1.09 KB | 0644 |
|
tdemo_two_canvases.pyc | File | 1.6 KB | 0644 |
|
tdemo_two_canvases.pyo | File | 1.6 KB | 0644 |
|
tdemo_wikipedia.py | File | 1.32 KB | 0644 |
|
tdemo_wikipedia.pyc | File | 1.91 KB | 0644 |
|
tdemo_wikipedia.pyo | File | 1.91 KB | 0644 |
|
tdemo_yinyang.py | File | 807 B | 0755 |
|
tdemo_yinyang.pyc | File | 1.29 KB | 0644 |
|
tdemo_yinyang.pyo | File | 1.29 KB | 0644 |
|
turtle.cfg | File | 160 B | 0644 |
|
turtleDemo.py | File | 9.85 KB | 0755 |
|
turtleDemo.pyc | File | 10.69 KB | 0644 |
|
turtleDemo.pyo | File | 10.69 KB | 0644 |
|