Python原野中的科赫雪花

2024-09-27 00:19:56 发布

您现在位置:Python中文网/ 问答频道 /正文

我对这个Python程序有问题。它应该用n次迭代绘制一个科赫雪花。代码确实可以编译,但它不会画出雪花,我找不到我的错误。在

如果有人能帮我解决这个问题,我会非常感激的!在

from math import sqrt
from matplotlib import pyplot as plt

class vector:
    def __init__(self,one,two):
        self.x = one
        self.y = two

    def printV(self):
        s = "(" + str(self.x) + "," + str(self.y) + ")"
        print s

    def __len__(self):
        l = sqrt(self.x**2 + self.y**2)
        return l

def kochSnowflakeImpl(p1,p2):
    u = vector(p1.x + p2.x - p1.x, p1.y + p2.y - p1.y)
    array = []

    #calculate n1
    n1 = vector(p1.x + 1.0/3.0 * u.x, p1.y + (1.0/3.0) * u.y)

    #calculate n2
    n2 = vector(p1.x + 2.0/3.0 * u.x,p1.y + 2.0/3.0 * u.y)

    v = vector(n1.y + n2.y - n1.y, -(n1.x + n2.x - n1.x)) #is an  orthogonal vector to u

    #calculate n3
    n3 = vector(n1.x + 0.5*u.x + sqrt(3.0)/2.0 * v.x, p1.y + 0.5*u.y + sqrt(3.0)/2.0* v.y)

    array.append([n1.x,n1.y])
    array.append([n2.x,n2.y])
    array.append([n3.x,n3.y])
    return n1,n2,n3,array

def kochSnowflake(level):
    p1 = vector(0,0) #format: p = (x,y)
    p2 = vector(1,0)
    p3 = vector(0.5,sqrt(3)/2)
    array = [[p1.x,p1.y],[p2.x,p2.y],[p3.x,p3.y],[p1.x,p1.y]]

    while level > 0:
        if level == 1:
            n1,n2,n3,array1 = kochSnowflakeImpl(p1,p2)
            n4,n5,n6,array2 = kochSnowflakeImpl(p2,p3)
            n7,n8,n9,array3 = kochSnowflakeImpl(p3,p2)
            for i in array1:
                array.append(i)
            for j in array2:
                array.append(j)
            for k in array3:
                array.append(k)
        else:
            n1,n2,n3,array1 = kochSnowflakeImpl(p1,p2)
            n11,n21,n31,array11 = kochSnowflakeImpl(n1,n3)
            n12,n22,n32,array12 = kochSnowflakeImpl(n3,n2)

            n4,n5,n6,array2 = kochSnowflakeImpl(p2,p3)
            n41,n52,n61,array21 = kochSnowflakeImpl(n4,n6)
            n42,n52,n62,array22 = kochSnowflakeImpl(n6,n5)

            n7,n8,n9,array3 = kochSnowflakeImpl(p1,p3)
            n71,n81,n91,array31 = kochSnowflakeImpl(n7,n9)
            n72,n82,n92,array32 = kochSnowflakeImpl(n9,n8)

            for i in array1:
                array.append(i)
            for i in array11:
                array.append(i)
            for i in array12:
                array.append(i)
            for j in array2:
                array.append(j)
            for j in array21:
                array.append(j)
            for j in array22:
                array.append(j)
            for k in array3:
                array.append(k)
            for k in array31:
                array.append(k)
            for k in array32:
                array.append(k)
        level -= 1
    return array

if __name__=='__main__':
    points = kochSnowflake(5)
    x,y = zip(*points)
    plt.plot(x, y)
    plt.show()

Tags: inselffordefsqrtarrayvectorp2
1条回答
网友
1楼 · 发布于 2024-09-27 00:19:56

我决定是时候把这段代码的输出从70年代的一段糟糕的弦乐艺术作品中转换成科赫雪花。

一个问题是OP向kochSnowflakeImpl()中的数组添加了新的点,但是忘记了添加原始的起点和终点。下一个问题是n3计算,因为求和使每个坐标的两个项都来自同一个坐标,而一项应该来自另一个坐标。并且kochSnowflake()中的电平逻辑是无望的。

为了简化代码,我放弃了OP的vector类(这是合理的),并替换了Python turtle中更完整的Vec2D类:

from turtle import Vec2D
from matplotlib import pyplot as plt

SQRT_3 = 3.0 ** 0.5

def kochSnowflakeImpl(p1, p2):
    u = p2 - p1
    v = Vec2D(-u[1], u[0])

    n1 = p1 + u * (1.0 / 3.0)
    n2 = n1 + u * (1.0 / 6.0) + v * (SQRT_3 / 6.0)
    n3 = p1 + u * (2.0 / 3.0)

    return [p1, n1, n2, n3, p2]

def kochSnowflake(level):
    p1 = Vec2D(0.0, 0.0)
    p2 = Vec2D(0.5, SQRT_3 / 2.0)
    p3 = Vec2D(1.0, 0.0)

    array = [p1, p2, p3, p1]

    for _ in range(level):
        new_array = []

        for (p1, p2) in zip(array, array[1:]):
            new_array.extend(kochSnowflakeImpl(p1, p2))

        array = new_array

    return array

if __name__ == '__main__':
    points = kochSnowflake(4)
    x, y = zip(*points)
    plt.plot(x, y)
    plt.show()

我不认为这段代码是非常正确的,因为雪花看起来有点低沉,但我相信它达到了原始代码的目标,并且足够干净,可以在上面进行构建。

enter image description here

相关问题 更多 >

    热门问题