GRAYBYTE WORDPRESS FILE MANAGER4586

Server IP : 198.54.121.189 / Your IP : 216.73.216.140
System : Linux premium69.web-hosting.com 4.18.0-553.44.1.lve.el8.x86_64 #1 SMP Thu Mar 13 14:29:12 UTC 2025 x86_64
PHP Version : 7.4.33
Disable Function : NONE
cURL : ON | WGET : ON | Sudo : OFF | Pkexec : OFF
Directory : /lib64/python2.7/Demo/turtle/
Upload Files :
Current_dir [ Not Writeable ] Document_root [ Writeable ]

Command :


Current File : /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()

[ Back ]
Name
Size
Last Modified
Owner / Group
Permissions
Options
..
--
June 15 2024 08:34:37
root / root
0755
about_turtle.txt
3.442 KB
April 19 2020 21:13:39
root / root
0644
about_turtledemo.txt
0.295 KB
April 19 2020 21:13:39
root / root
0644
demohelp.txt
2.963 KB
April 19 2020 21:13:39
root / root
0644
tdemo_I_dontlike_tiltdemo.py
1.048 KB
April 10 2024 04:57:37
root / root
0755
tdemo_I_dontlike_tiltdemo.pyc
1.621 KB
April 10 2024 04:58:47
root / root
0644
tdemo_I_dontlike_tiltdemo.pyo
1.621 KB
April 10 2024 04:58:47
root / root
0644
tdemo_bytedesign.py
4.119 KB
April 10 2024 04:57:37
root / root
0755
tdemo_bytedesign.pyc
5.188 KB
April 10 2024 04:58:47
root / root
0644
tdemo_bytedesign.pyo
5.188 KB
April 10 2024 04:58:47
root / root
0644
tdemo_chaos.py
0.929 KB
April 19 2020 21:13:39
root / root
0644
tdemo_chaos.pyc
2.242 KB
April 10 2024 04:58:47
root / root
0644
tdemo_chaos.pyo
2.242 KB
April 10 2024 04:58:47
root / root
0644
tdemo_clock.py
3.144 KB
April 10 2024 04:57:37
root / root
0755
tdemo_clock.pyc
4.429 KB
April 10 2024 04:58:47
root / root
0644
tdemo_clock.pyo
4.429 KB
April 10 2024 04:58:47
root / root
0644
tdemo_colormixer.py
1.307 KB
April 19 2020 21:13:39
root / root
0644
tdemo_colormixer.pyc
2.31 KB
April 10 2024 04:58:47
root / root
0644
tdemo_colormixer.pyo
2.31 KB
April 10 2024 04:58:47
root / root
0644
tdemo_fractalcurves.py
3.329 KB
April 10 2024 04:57:37
root / root
0755
tdemo_fractalcurves.pyc
3.441 KB
April 10 2024 04:58:47
root / root
0644
tdemo_fractalcurves.pyo
3.441 KB
April 10 2024 04:58:47
root / root
0644
tdemo_lindenmayer_indian.py
2.375 KB
April 10 2024 04:57:37
root / root
0755
tdemo_lindenmayer_indian.pyc
3.518 KB
April 10 2024 04:58:47
root / root
0644
tdemo_lindenmayer_indian.pyo
3.518 KB
April 10 2024 04:58:47
root / root
0644
tdemo_minimal_hanoi.py
2.001 KB
April 10 2024 04:57:37
root / root
0755
tdemo_minimal_hanoi.pyc
3.538 KB
April 10 2024 04:58:47
root / root
0644
tdemo_minimal_hanoi.pyo
3.538 KB
April 10 2024 04:58:47
root / root
0644
tdemo_nim.py
6.361 KB
April 19 2020 21:13:39
root / root
0644
tdemo_nim.pyc
9.164 KB
April 10 2024 04:58:47
root / root
0644
tdemo_nim.pyo
9.164 KB
April 10 2024 04:58:47
root / root
0644
tdemo_paint.py
1.259 KB
April 10 2024 04:57:37
root / root
0755
tdemo_paint.pyc
1.856 KB
April 10 2024 04:58:47
root / root
0644
tdemo_paint.pyo
1.856 KB
April 10 2024 04:58:47
root / root
0644
tdemo_peace.py
1.04 KB
April 10 2024 04:57:37
root / root
0755
tdemo_peace.pyc
1.355 KB
April 10 2024 04:58:47
root / root
0644
tdemo_peace.pyo
1.355 KB
April 10 2024 04:58:47
root / root
0644
tdemo_penrose.py
3.452 KB
April 10 2024 04:57:37
root / root
0755
tdemo_penrose.pyc
5.864 KB
April 10 2024 04:58:47
root / root
0644
tdemo_penrose.pyo
5.864 KB
April 10 2024 04:58:47
root / root
0644
tdemo_planet_and_moon.py
2.757 KB
April 10 2024 04:57:37
root / root
0755
tdemo_planet_and_moon.pyc
4.429 KB
April 10 2024 04:58:47
root / root
0644
tdemo_planet_and_moon.pyo
4.429 KB
April 10 2024 04:58:47
root / root
0644
tdemo_tree.py
1.377 KB
April 10 2024 04:57:37
root / root
0755
tdemo_tree.pyc
2.073 KB
April 10 2024 04:58:47
root / root
0644
tdemo_tree.pyo
2.073 KB
April 10 2024 04:58:47
root / root
0644
tdemo_two_canvases.py
1.094 KB
April 19 2020 21:13:39
root / root
0644
tdemo_two_canvases.pyc
1.597 KB
April 10 2024 04:58:47
root / root
0644
tdemo_two_canvases.pyo
1.597 KB
April 10 2024 04:58:47
root / root
0644
tdemo_wikipedia.py
1.315 KB
April 19 2020 21:13:39
root / root
0644
tdemo_wikipedia.pyc
1.909 KB
April 10 2024 04:58:47
root / root
0644
tdemo_wikipedia.pyo
1.909 KB
April 10 2024 04:58:47
root / root
0644
tdemo_yinyang.py
0.788 KB
April 10 2024 04:57:37
root / root
0755
tdemo_yinyang.pyc
1.289 KB
April 10 2024 04:58:47
root / root
0644
tdemo_yinyang.pyo
1.289 KB
April 10 2024 04:58:47
root / root
0644
turtle.cfg
0.156 KB
April 19 2020 21:13:39
root / root
0644
turtleDemo.py
9.854 KB
April 10 2024 04:57:37
root / root
0755
turtleDemo.pyc
10.691 KB
April 10 2024 04:58:47
root / root
0644
turtleDemo.pyo
10.691 KB
April 10 2024 04:58:47
root / root
0644

GRAYBYTE WORDPRESS FILE MANAGER @ 2025
CONTACT ME
Static GIF