$49 GRAYBYTE WORDPRESS FILE MANAGER $22

SERVER : vnpttt-amd7f72-h1.vietnix.vn #1 SMP Fri May 24 12:42:50 UTC 2024
SERVER IP : 103.200.23.149 | ADMIN IP 216.73.216.22
OPTIONS : CRL = ON | WGT = ON | SDO = OFF | PKEX = OFF
DEACTIVATED : NONE

/usr/lib64/python2.7/Demo/turtle/

HOME
Current File : /usr/lib64/python2.7/Demo/turtle//tdemo_fractalcurves.py
#! /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()

Current_dir [ NOT WRITEABLE ] Document_root [ WRITEABLE ]


[ Back ]
NAME
SIZE
LAST TOUCH
USER
CAN-I?
FUNCTIONS
..
--
14 Aug 2025 9.26 PM
root / root
0755
about_turtle.txt
3.442 KB
20 Apr 2020 4.13 AM
root / root
0644
about_turtledemo.txt
0.295 KB
20 Apr 2020 4.13 AM
root / root
0644
demohelp.txt
2.963 KB
20 Apr 2020 4.13 AM
root / root
0644
tdemo_I_dontlike_tiltdemo.py
1.048 KB
10 Apr 2024 11.57 AM
root / root
0755
tdemo_I_dontlike_tiltdemo.pyc
1.621 KB
10 Apr 2024 11.58 AM
root / root
0644
tdemo_I_dontlike_tiltdemo.pyo
1.621 KB
10 Apr 2024 11.58 AM
root / root
0644
tdemo_bytedesign.py
4.119 KB
10 Apr 2024 11.57 AM
root / root
0755
tdemo_bytedesign.pyc
5.188 KB
10 Apr 2024 11.58 AM
root / root
0644
tdemo_bytedesign.pyo
5.188 KB
10 Apr 2024 11.58 AM
root / root
0644
tdemo_chaos.py
0.929 KB
20 Apr 2020 4.13 AM
root / root
0644
tdemo_chaos.pyc
2.242 KB
10 Apr 2024 11.58 AM
root / root
0644
tdemo_chaos.pyo
2.242 KB
10 Apr 2024 11.58 AM
root / root
0644
tdemo_clock.py
3.144 KB
10 Apr 2024 11.57 AM
root / root
0755
tdemo_clock.pyc
4.429 KB
10 Apr 2024 11.58 AM
root / root
0644
tdemo_clock.pyo
4.429 KB
10 Apr 2024 11.58 AM
root / root
0644
tdemo_colormixer.py
1.307 KB
20 Apr 2020 4.13 AM
root / root
0644
tdemo_colormixer.pyc
2.31 KB
10 Apr 2024 11.58 AM
root / root
0644
tdemo_colormixer.pyo
2.31 KB
10 Apr 2024 11.58 AM
root / root
0644
tdemo_fractalcurves.py
3.329 KB
10 Apr 2024 11.57 AM
root / root
0755
tdemo_fractalcurves.pyc
3.441 KB
10 Apr 2024 11.58 AM
root / root
0644
tdemo_fractalcurves.pyo
3.441 KB
10 Apr 2024 11.58 AM
root / root
0644
tdemo_lindenmayer_indian.py
2.375 KB
10 Apr 2024 11.57 AM
root / root
0755
tdemo_lindenmayer_indian.pyc
3.518 KB
10 Apr 2024 11.58 AM
root / root
0644
tdemo_lindenmayer_indian.pyo
3.518 KB
10 Apr 2024 11.58 AM
root / root
0644
tdemo_minimal_hanoi.py
2.001 KB
10 Apr 2024 11.57 AM
root / root
0755
tdemo_minimal_hanoi.pyc
3.538 KB
10 Apr 2024 11.58 AM
root / root
0644
tdemo_minimal_hanoi.pyo
3.538 KB
10 Apr 2024 11.58 AM
root / root
0644
tdemo_nim.py
6.361 KB
20 Apr 2020 4.13 AM
root / root
0644
tdemo_nim.pyc
9.164 KB
10 Apr 2024 11.58 AM
root / root
0644
tdemo_nim.pyo
9.164 KB
10 Apr 2024 11.58 AM
root / root
0644
tdemo_paint.py
1.259 KB
10 Apr 2024 11.57 AM
root / root
0755
tdemo_paint.pyc
1.856 KB
10 Apr 2024 11.58 AM
root / root
0644
tdemo_paint.pyo
1.856 KB
10 Apr 2024 11.58 AM
root / root
0644
tdemo_peace.py
1.04 KB
10 Apr 2024 11.57 AM
root / root
0755
tdemo_peace.pyc
1.355 KB
10 Apr 2024 11.58 AM
root / root
0644
tdemo_peace.pyo
1.355 KB
10 Apr 2024 11.58 AM
root / root
0644
tdemo_penrose.py
3.452 KB
10 Apr 2024 11.57 AM
root / root
0755
tdemo_penrose.pyc
5.864 KB
10 Apr 2024 11.58 AM
root / root
0644
tdemo_penrose.pyo
5.864 KB
10 Apr 2024 11.58 AM
root / root
0644
tdemo_planet_and_moon.py
2.757 KB
10 Apr 2024 11.57 AM
root / root
0755
tdemo_planet_and_moon.pyc
4.429 KB
10 Apr 2024 11.58 AM
root / root
0644
tdemo_planet_and_moon.pyo
4.429 KB
10 Apr 2024 11.58 AM
root / root
0644
tdemo_tree.py
1.377 KB
10 Apr 2024 11.57 AM
root / root
0755
tdemo_tree.pyc
2.073 KB
10 Apr 2024 11.58 AM
root / root
0644
tdemo_tree.pyo
2.073 KB
10 Apr 2024 11.58 AM
root / root
0644
tdemo_two_canvases.py
1.094 KB
20 Apr 2020 4.13 AM
root / root
0644
tdemo_two_canvases.pyc
1.597 KB
10 Apr 2024 11.58 AM
root / root
0644
tdemo_two_canvases.pyo
1.597 KB
10 Apr 2024 11.58 AM
root / root
0644
tdemo_wikipedia.py
1.315 KB
20 Apr 2020 4.13 AM
root / root
0644
tdemo_wikipedia.pyc
1.909 KB
10 Apr 2024 11.58 AM
root / root
0644
tdemo_wikipedia.pyo
1.909 KB
10 Apr 2024 11.58 AM
root / root
0644
tdemo_yinyang.py
0.788 KB
10 Apr 2024 11.57 AM
root / root
0755
tdemo_yinyang.pyc
1.289 KB
10 Apr 2024 11.58 AM
root / root
0644
tdemo_yinyang.pyo
1.289 KB
10 Apr 2024 11.58 AM
root / root
0644
turtle.cfg
0.156 KB
20 Apr 2020 4.13 AM
root / root
0644
turtleDemo.py
9.854 KB
10 Apr 2024 11.57 AM
root / root
0755
turtleDemo.pyc
10.691 KB
10 Apr 2024 11.58 AM
root / root
0644
turtleDemo.pyo
10.691 KB
10 Apr 2024 11.58 AM
root / root
0644

GRAYBYTE WORDPRESS FILE MANAGER @ 2026 CONTACT ME
Static GIF