中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Python如何利用科赫曲線實現三維飄雪效果

發布時間:2022-03-03 15:07:57 來源:億速云 閱讀:187 作者:小新 欄目:開發技術

這篇文章主要介紹了Python如何利用科赫曲線實現三維飄雪效果,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

隨機雪花

如果隨機生成一些點,然后為每個點繪制一些枝杈,則可以畫出類似蒲公英這種結構,只是看上去不太好看而已

Python如何利用科赫曲線實現三維飄雪效果

import numpy as np
import matplotlib.pyplot as plt
from numpy.random import rand,randint
M,N = 10,100
x = rand(N)*100
y = rand(N)*100
plt.scatter(x,y,marker='.')
for i in range(N):
    M = randint(5,15)
    r = rand()*3
    for j in range(M):
        theta = np.pi*2/M*j
        plt.plot([x[i],x[i]+r*np.cos(theta)],
                 [y[i],y[i]+r*np.sin(theta)])
plt.axis('off')
plt.show()

當然也可以畫成三維圖,果然還是很丑。

Python如何利用科赫曲線實現三維飄雪效果

科赫雪花

所以,既然想飄雪,那就首先得有雪花。科赫曲線因為十分像雪花,所以又叫雪花曲線,生成方式十分簡單,總共分兩步

畫一個正三角形將正三角形的每個邊三等分,然后以中間的那份為邊,再畫出個三角形。重復第二步。

那么難點無非是三等分后如何新畫一個三角形,更進一步,新三角形的那個新頂點在哪里?

Python如何利用科赫曲線實現三維飄雪效果

從而得到

Python如何利用科赫曲線實現三維飄雪效果Python如何利用科赫曲線實現三維飄雪效果Python如何利用科赫曲線實現三維飄雪效果

代碼如下

import numpy as np
import matplotlib.pyplot as plt
from numpy.random import rand,randint
# n>=1,生成科赫雪花的方法
def Koch(L,n=1):
    if n<1 : return
    newL = []    #(x,y)的列表
    for i in range(len(L)-1):
       delta = (L[i+1]-L[i])/3
       x = (L[i][0]+L[i+1][0])/2-np.sqrt(3)/2*delta[1]
       y = (L[i][1]+L[i+1][1])/2+np.sqrt(3)/2*delta[0]
       newL += [L[i],L[i]+delta,np.array([x,y]),L[i]+delta*2]
    newL.append(L[-1])
        return newL if n==1 else Koch(newL,n-1)
L0 = [
    np.array([0,0]),
    np.array([0.5,np.sqrt(3)/2]),
    np.array([1,0]),
    np.array([0,0])
]
def plot_Koch(L):
    for i in range(len(L)-1):
        p = np.array(L[i:i+2]).T
        plt.plot(p[0],p[1],color='lightblue',lw = 1)
    plt.xlim(-0.25,1.25)
    plt.ylim(-0.5,1.25)
    plt.show()
if __name__ == "__main__":
    plot_Koch(Koch(L0,3))

如果多畫一些,那么就是這樣

Python如何利用科赫曲線實現三維飄雪效果

生成方法為

#n為雪花數量,low,high為最低和最高koch雪花階數
def RandKoch(n,low,high):
    randKochs = []
    rMax = np.sqrt(1/n)
    for _ in range(n):
        cx,cy,t0 = rand(3)
        r = rand()*rMax
        L0 = [np.array([np.cos(t),np.sin(t)])*r+[cx,cy]
            for t in (t0-np.arange(4)*np.pi*2/3)]
        randKochs.append(Koch(L0,randint(low,high)))
    return randKochs
def plot_Kochs(Ls):
    for L in Ls:
        for i in range(len(L)-1):
            p = np.array(L[i:i+2]).T
            plt.plot(p[0],p[1],color='lightblue',lw = 1)
    plt.xlim(-0.2,1.2)
    plt.ylim(-0.2,1.2)
    plt.show()

當然,如果用plt.fill(x,y),則可畫出實心的雪花

Python如何利用科赫曲線實現三維飄雪效果

def plot_Kochs(Ls):
    for L in Ls:
        x,y = np.array(L).T
        plt.fill(x, y, color = 'lightblue')
    plt.xlim(-0.2,1.2)
    plt.ylim(-0.2,1.2)
    plt.show()

三維

我們想要的是那種飄雪的感覺,所以至少得有個3D的圖,這很簡單,只要加個三維的坐標就可以了。

Python如何利用科赫曲線實現三維飄雪效果

#導入PolyCollection繪制實心的3D圖形
from mpl_toolkits.mplot3d.art3d import PolyCollection
def plot_Kochs_fill3d(Ls):
    fig = plt.figure()
    ax = fig.gca(projection='3d')
    p3d = PolyCollection(Ls,facecolors=np.repeat('lightblue',len(Ls)),alpha=0.7)
    ax.add_collection3d(p3d,zs=rand(len(Ls)),zdir='y')
    ax.set_xlim3d(0,1)
    ax.set_ylim3d(0,1)
    ax.set_zlim3d(0,1)
    plt.show()

感謝你能夠認真閱讀完這篇文章,希望小編分享的“Python如何利用科赫曲線實現三維飄雪效果”這篇文章對大家有幫助,同時也希望大家多多支持億速云,關注億速云行業資訊頻道,更多相關知識等著你來學習!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

轮台县| 炉霍县| 万州区| 旺苍县| 手机| 榆社县| 临高县| 兴业县| 元江| 阜新| 郴州市| 虹口区| 毕节市| 武清区| 巴南区| 富宁县| 深州市| 尉氏县| 榕江县| 独山县| 大荔县| 宣威市| 贡觉县| 朝阳县| 芦溪县| 图木舒克市| 长子县| 石家庄市| 天水市| 岳阳县| 三都| 汾阳市| 随州市| 棋牌| 宁强县| 石渠县| 达日县| 井研县| 龙江县| 安塞县| 祁阳县|