利用python實現(xiàn)蝴蝶曲線
導(dǎo)言:
接上期,我們在極坐標(biāo)下用python畫了圓,心形線,玫瑰線,阿基米德螺線和雙紐線5大常規(guī)曲線外,后來發(fā)現(xiàn)還漏了好一些漂亮且有意思的的曲線,今天就來講一講蝴蝶曲線。
一、什么是蝴蝶曲線?
蝴蝶曲線是平面上一類代數(shù)曲線,最初由美國南密西西比大學(xué)特普爾·費伊(Temple H·Fay)發(fā)現(xiàn),因其形狀宛如一只翩翩起舞的蝴蝶,故為其取美日“蝴蝶曲線”。
極坐標(biāo)系下蝴蝶曲線方程為:

使用參數(shù)方程描述為:

二、畫一個最簡單的蝴蝶曲線
有了蝴蝶曲線在極坐標(biāo)下的曲線方程之后,我們就可以進(jìn)行描點法畫出其圖形,先從最簡單的蝴蝶曲線入手。
import matplotlib.pyplot as plt
import math
thetas =[] #用來存放極角
rhos = [] #用來存放極徑
for i in range(-181, 181):
? ? theta = i*math.pi/180 #角度轉(zhuǎn)弧度
? ? rho = math.exp(math.cos(theta)) - 2*math.cos(4*theta)+math.pow(math.sin(theta/12), 5) #極徑
? ? thetas.append(theta)
? ? rhos.append(rho)
fig = plt.figure() #新建畫布
plt.polar(thetas, rhos, color = "red") #極坐標(biāo)畫圖
plt.title("butterfly")
plt.show()
圖1 蝴蝶曲線效果圖
三、畫一個優(yōu)美的蝴蝶曲線
在上一部分我們畫出了最簡單的蝴蝶曲線,從效果圖只能看到大致呈現(xiàn)蝴蝶形狀,
通過改變這個方程中的變量θ,可以得到不同形狀與方向的蝴蝶曲線。如果再施以復(fù)雜的組合和變換,我們看到的就完全稱得上是一幅藝術(shù)品了。
import matplotlib.pyplot as plt
import numpy as np
import math
X = []?
Y = []?
theta =0
for theta in np.linspace(0, math.pi*20, 10001):
? ? x = math.cos(theta)*(math.exp(math.cos(theta)) - 2*math.cos(4*theta) + math.pow(math.sin(theta/12),5))
? ? y = math.sin(theta)*(math.exp(math.cos(theta)) - 2*math.cos(4*theta) + math.pow(math.sin(theta/12),5))
? ? X.append(x)
? ? Y.append(y)
fig = plt.figure() #新建畫布
plt.plot(Y, X, color = "red", linewidth = 0.2) #極坐標(biāo)畫圖
plt.title("butterfly")
plt.show()圖2 優(yōu)美蝴蝶曲線效果圖

結(jié)論:
自然界的很多現(xiàn)象都可以適當(dāng)?shù)暮喕么鷶?shù)曲線和超越曲線來表達(dá),蝴蝶曲線只是其中一種,后續(xù)我們會探索更多有趣有意義的曲線圖形。
到此這篇關(guān)于利用python實現(xiàn)蝴蝶曲線的文章就介紹到這了,更多相關(guān)python實現(xiàn)蝴蝶曲線內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
python實現(xiàn)大戰(zhàn)外星人小游戲?qū)嵗a
這篇文章主要介紹了python實現(xiàn)大戰(zhàn)外星人小游戲,本文通過實例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價值,需要的朋友可以參考下2019-12-12
如何使用pytorch實現(xiàn)LocallyConnected1D
由于LocallyConnected1D是Keras中的函數(shù),為了用pytorch實現(xiàn)LocallyConnected1D并在960×33的數(shù)據(jù)集上進(jìn)行訓(xùn)練和驗證,本文分步驟給大家介紹如何使用pytorch實現(xiàn)LocallyConnected1D,感興趣的朋友一起看看吧2023-09-09
使用Python編寫一個粘貼python源代碼就能運行的工具
以下是一個使用wxPython模塊創(chuàng)建帶有Memo(文本輸入框)和保存按鈕的GUI程序示例,點擊保存按鈕后將Memo內(nèi)容保存到指定路徑下的文件,并提供運行按鈕以執(zhí)行指定的Python腳本,需要的朋友可以參考下2025-04-04
python 和c++實現(xiàn)旋轉(zhuǎn)矩陣到歐拉角的變換方式
今天小編就為大家分享一篇python 和c++實現(xiàn)旋轉(zhuǎn)矩陣到歐拉角的變換方式,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-12-12
Python數(shù)據(jù)可視化之matplotlib.pyplot繪圖的基本參數(shù)詳解
matplotlib.pyplot模塊是一個功能強大的畫圖模塊,可以對畫圖的多個參數(shù)進(jìn)行調(diào)整,下面這篇文章主要給大家介紹了關(guān)于Python數(shù)據(jù)可視化之matplotlib.pyplot繪圖基本參數(shù)的相關(guān)資料,需要的朋友可以參考下2022-04-04
在Apache服務(wù)器上同時運行多個Django程序的方法
這篇文章主要介紹了在Apache服務(wù)器上同時運行多個Django程序的方法,Django是Python各色高人氣web框架中最為著名的一個,需要的朋友可以參考下2015-07-07
淺析python 內(nèi)置字符串處理函數(shù)的使用方法
這篇文章主要介紹了python 內(nèi)置字符串處理函數(shù)的使用方法,需要的朋友可以參考下2014-06-06

