SILENT KILLERPanel

Current Path: > > > lib64 > python3.8 > turtledemo >


Operation   : Linux premium131.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
Software     : Apache
Server IP    : 162.0.232.56 | Your IP: 216.73.216.111
Domains      : 1034 Domain(s)
Permission   : [ 0755 ]

Files and Folders in: ///lib64/python3.8/turtledemo/

NameTypeSizeLast ModifiedActions
__pycache__ Directory - -
__init__.py File 314 bytes June 06 2023 13:32:21.
__main__.py File 14241 bytes October 17 2023 18:12:57.
bytedesign.py File 4247 bytes June 06 2023 13:32:21.
chaos.py File 951 bytes June 06 2023 13:32:21.
clock.py File 3200 bytes June 06 2023 13:32:21.
colormixer.py File 1339 bytes June 06 2023 13:32:21.
forest.py File 2965 bytes June 06 2023 13:32:21.
fractalcurves.py File 3472 bytes June 06 2023 13:32:21.
lindenmayer.py File 2433 bytes June 06 2023 13:32:21.
minimal_hanoi.py File 2050 bytes June 06 2023 13:32:21.
nim.py File 6513 bytes June 06 2023 13:32:21.
paint.py File 1290 bytes June 06 2023 13:32:21.
peace.py File 1065 bytes June 06 2023 13:32:21.
penrose.py File 3379 bytes June 06 2023 13:32:21.
planet_and_moon.py File 2824 bytes June 06 2023 13:32:21.
rosette.py File 1361 bytes June 06 2023 13:32:21.
round_dance.py File 1804 bytes June 06 2023 13:32:21.
sorting_animate.py File 5029 bytes October 17 2023 18:12:57.
tree.py File 1400 bytes June 06 2023 13:32:21.
turtle.cfg File 160 bytes June 06 2023 13:32:21.
two_canvases.py File 1119 bytes June 06 2023 13:32:21.
yinyang.py File 820 bytes June 06 2023 13:32:21.

Reading File: ///lib64/python3.8/turtledemo//fractalcurves.py

#! /usr/bin/python3.8
"""      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, perf_counter as 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.getscreen().tracer(1,0)
    ft.pu()

    size = 6
    ft.setpos(-33*size, -32*size)
    ft.pd()

    ta=clock()
    ft.fillcolor("red")
    ft.begin_fill()
    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.end_fill()
    tb=clock()
    res =  "Hilbert: %.2fsec. " % (tb-ta)

    sleep(3)

    ft.reset()
    ft.speed(0)
    ft.ht()
    ft.getscreen().tracer(1,0)

    ta=clock()
    ft.color("black", "blue")
    ft.begin_fill()
    ft.fractalgon(3, 250, 4, 1)
    ft.end_fill()
    ft.begin_fill()
    ft.color("red")
    ft.fractalgon(3, 200, 4, -1)
    ft.end_fill()
    tb=clock()
    res +=  "Koch: %.2fsec." % (tb-ta)
    return res

if __name__  == '__main__':
    msg = main()
    print(msg)
    mainloop()

SILENT KILLER Tool