Python绘制动态Julia集怎样做,方法及代码是什么
Admin 2022-06-20 群英技术资讯 837 次浏览
这篇文章主要介绍“Python绘制动态Julia集怎样做,方法及代码是什么”的相关知识,下面会通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Python绘制动态Julia集怎样做,方法及代码是什么”文章能帮助大家解决问题。特别地,当 c = z c=z c=z的初始值时,符合收敛条件的 z z z的便构成大名鼎鼎的Mandelbrot集

在上图中,颜色表示该点的发散速度,可以理解为开始发散时迭代的次数。其生成代码也非常简单,唯一需要注意的是,由于使用了大量的矩阵运算,故使用了cupy,如果电脑没装cuda,只需将所有的cp改为np即可。
# 这些代码会在后面的程序中反复调用,不再说明
import numpy as np
import time
import matplotlib.pyplot as plt
import cupy as cp
#生成z坐标 x0,y0 为起始点, nx,ny为点数, delta为点距
def genZ(x0, y0, nx, ny, delta):
real, img = cp.indices([nx,ny])*delta
real += x0
img += y0
return real.T+img.T*1j
#获取Julia集,n为迭代次数,m为判定发散点,大于1即可
def getJulia(z,c,n,m=2):
t = time.time()
z,out = z*1, cp.abs(z)
c = cp.zeros_like(z)+c
for i in range(n):
absz = cp.abs(z)
z[absz>m]=0 #对开始发散的点置零
c[absz>m]=0
out[absz>m]=i #记录发散点的发散速度
z = z*z + c
print("time:",time.time()-t)
return out
z1 = genZ(-2,-1.5,1000,1000,0.003)
mBrot = getJulia(z1,z1,50)
plt.imshow(mBrot.get(), cmap=plt.cm.jet)
plt.show()
如果对其生成过程感兴趣,那么可以观察一下随着迭代次数的增加,图像的变化情况

代码如下。
from matplotlib import animation
fig = plt.figure()
fig.subplots_adjust(top=1, bottom=0, left=0, right=1)
ax = plt.subplot()
def getJulias(z,c,n,m=2):
z,out = z*1, cp.abs(z)
c = cp.zeros_like(z)+c
J = []
for i in range(n):
z = z*z + c
absz = cp.abs(z)
z[absz>m]=0 #对开始发散的点置零
c[absz>m]=0
out[absz>m]=i #记录发散点的发散速度
im = ax.imshow(out.get(),cmap=plt.cm.jet, animated=True)
ax.set_axis_off()
J.append([im])
return J
N = 75 #迭代次数
z1 = genZ(-2,-1.5,1000,1000,0.003)
J = getJulias(z1,z1,N)
ani = animation.ArtistAnimation(fig, J, interval=50, blit=True,repeat_delay=1000)
plt.show()
ani.save('julias.gif',writer='imagemagick')
Mandelbrot集的分形特征意味着我们所生成的图片可以无限放大,但是受到栅格化尺寸的影响,手动的放大并不会更改其真实尺寸,
为了照顾观感,将缩放中心作为图像的中心,所以对genZ函数进行修改。如果选取(-0.75,-0.2)作为缩放中心,则其变化如下

代码为
from matplotlib import animation
# 生成z坐标 xy=np.array([xc,yc]) 为起始点,
# nxy=np.array([nx,ny])为点数, delta为点距
def genZbyCenter(xy,nxy,delta):
x0, y0 = xy-np.array(nxy)*delta/2
return genZ(x0,y0,*nxy,delta)
mBrots = []
xy = [-0.75,-0.2]
nxy = [1000,1000]
delta0 = 0.003 #初始宽度
fig = plt.figure()
fig.subplots_adjust(top=1, bottom=0, left=0, right=1)
ax = plt.subplot()
for n in range(50):
z1 = genZbyCenter(xy,nxy,1.1**(-n)*delta0)
out = getJulia(z1,z1,40)
im = ax.imshow(out.get(),cmap=plt.cm.jet, animated=True)
ax.set_axis_off()
mBrots.append([im])
ani = animation.ArtistAnimation(fig, mBrots, interval=50, blit=True)
plt.show()
ani.save('zoom.gif',writer='imagemagick')
如果更改c的值,那么就能得到一个变化着的Julia集,例如,下面选取一条直线
y = x y=x y=x
上面的Julia集,效果如图所示

代码为
z1 = genZ(-2,-1.5,1000,1000,0.003)
fig = plt.figure()
fig.subplots_adjust(top=1, bottom=0, left=0, right=1)
ax = plt.subplot()
mBrots = []
for x in np.arange(0.5,1,0.01):
c = x + x*1j
out = getJulia(z1,c,40)
im = ax.imshow(out.get(),cmap=plt.cm.jet, animated=True)
ax.set_axis_off()
mBrots.append([im])
ani = animation.ArtistAnimation(fig, mBrots, interval=50)
plt.show()
ani.save('julia.gif',writer='imagemagick')
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
这篇文章主要介绍了基于Python实现视频的分辨率转换的示例代码,文中的代码讲解详细,对学习Python有一定的帮助,感兴趣的小伙伴可以了解一下
在YOLOV5算法之中,针对不同的数据集,一般会预先设置固定的Anchor,下面这篇文章主要给大家介绍了关于yolov5中anchors设置的相关资料,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
缓存是一种优化技术,可以在应用程序中使用它来将最近或经常使用的数据保存在内存中,通过这种方式来访问数据的速度比直接读取磁盘文件的高很多
大家好啊!我用Tkinter写了一个天气预报小工具,支持34个省级行政区以及港澳台地区天气,覆盖全面。程序打包好放在了蓝奏云,与大家分享一下。
这篇文章主要为大家介绍了Python中常用的两个序列化模块:pickle序列化和json序列化。文中的示例代码讲解详细,感兴趣的小伙伴可以学习一下
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008