Python如何利用科赫曲线实现三维飘雪效果
Python如何利用科赫曲线实现三维飘雪效果
这篇文章主要介绍了Python如何利用科赫曲线实现三维飘雪效果,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。
随机雪花
如果随机生成一些点,然后为每个点绘制一些枝杈,则可以画出类似蒲公英这种结构,只是看上去不太好看而已
importnumpyasnpimportmatplotlib.pyplotaspltfromnumpy.randomimportrand,randintM,N=10,100x=rand(N)*100y=rand(N)*100plt.scatter(x,y,marker='.')foriinrange(N):M=randint(5,15)r=rand()*3forjinrange(M):theta=np.pi*2/M*jplt.plot([x[i],x[i]+r*np.cos(theta)],[y[i],y[i]+r*np.sin(theta)])plt.axis('off')plt.show()
当然也可以画成三维图,果然还是很丑。
科赫雪花
所以,既然想飘雪,那就首先得有雪花。科赫曲线因为十分像雪花,所以又叫雪花曲线,生成方式十分简单,总共分两步
画一个正三角形将正三角形的每个边三等分,然后以中间的那份为边,再画出个三角形。重复第二步。
那么难点无非是三等分后如何新画一个三角形,更进一步,新三角形的那个新顶点在哪里?
从而得到
代码如下
importnumpyasnpimportmatplotlib.pyplotaspltfromnumpy.randomimportrand,randint#n>=1,生成科赫雪花的方法defKoch(L,n=1):ifn<1:returnnewL=[]#(x,y)的列表foriinrange(len(L)-1):delta=(L[i+1]-L[i])/3x=(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])returnnewLifn==1elseKoch(newL,n-1)L0=[np.array([0,0]),np.array([0.5,np.sqrt(3)/2]),np.array([1,0]),np.array([0,0])]defplot_Koch(L):foriinrange(len(L)-1):p=np.array(L[i:i+2]).Tplt.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))
如果多画一些,那么就是这样
生成方法为
#n为雪花数量,low,high为最低和最高koch雪花阶数defRandKoch(n,low,high):randKochs=[]rMax=np.sqrt(1/n)for_inrange(n):cx,cy,t0=rand(3)r=rand()*rMaxL0=[np.array([np.cos(t),np.sin(t)])*r+[cx,cy]fortin(t0-np.arange(4)*np.pi*2/3)]randKochs.append(Koch(L0,randint(low,high)))returnrandKochsdefplot_Kochs(Ls):forLinLs:foriinrange(len(L)-1):p=np.array(L[i:i+2]).Tplt.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)
,则可画出实心的雪花
defplot_Kochs(Ls):forLinLs:x,y=np.array(L).Tplt.fill(x,y,color='lightblue')plt.xlim(-0.2,1.2)plt.ylim(-0.2,1.2)plt.show()
三维
我们想要的是那种飘雪的感觉,所以至少得有个3D的图,这很简单,只要加个三维的坐标就可以了。
#导入PolyCollection绘制实心的3D图形frommpl_toolkits.mplot3d.art3dimportPolyCollectiondefplot_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如何利用科赫曲线实现三维飘雪效果”这篇文章对大家有帮助,同时也希望大家多多支持恰卡编程网,关注恰卡编程网行业资讯频道,更多相关知识等着你来学习!
推荐阅读
-
python多行注释符号怎么表示
python多行注释符号怎么表示这篇文章主要介绍“python多行...
-
python支持的操作系统是什么
python支持的操作系统是什么这篇文章主要介绍“python支持...
-
python如何判断列表为空
python如何判断列表为空这篇文章主要介绍“python如何判断...
-
Python如何利用D3Blocks绘制可动态交互的图表
-
2021年度编程语言揭晓
-
PPython:PHP 拥抱 Python 的利器
-
哪种Python IDE最适合你?这里有一份优缺点列表
-
Python分隔字符串函数用法split
aaa,bbb=str.split(‘&&’,2)第一个参数为分隔符第二个参数是要完成的最大拆分数...
-
php安全编程——python测试实例编写
-
神奇的Python模块:pdfkit,将Python抓取的网址内容保存pdf文件