我的编程空间,编程开发者的网络收藏夹
学习永远不晚

python如何绘制超炫酷动态Julia集

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

python如何绘制超炫酷动态Julia集

这期内容当中小编将会给大家带来有关python如何绘制超炫酷动态Julia集,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。

前言

此Julia非彼Julia,指的是对于某复数                              c                          c               c,使得迭代式                              f                      (                      z                      )                      =                               z                         2                              +                      c                          f(z)=z^2+c               f(z)=z2+c收敛的复数                              z                          z               z的集合。例如,当                              c                      =                      0                          c=0               c=0时,那么其收敛区间为                                       z                         2                              <                      1                          z^2<1               z2<1的单位圆,对应的                              c                          c               c的Julia集便是                              cos                      ⁡                      θ                      +                      i                      sin                      ⁡                      θ                          \cos\theta+i\sin\theta               cosθ+isinθ。

Mandelbrot集

特别地,当                              c                      =                      z                          c=z               c=z的初始值时,符合收敛条件的                              z                          z               z的便构成大名鼎鼎的Mandelbrot集

python如何绘制超炫酷动态Julia集

在上图中,颜色表示该点的发散速度,可以理解为开始发散时迭代的次数。其生成代码也非常简单,唯一需要注意的是,由于使用了大量的矩阵运算,故使用了cupy,如果电脑没装cuda,只需将所有的cp改为np即可。

# 这些代码会在后面的程序中反复调用,不再说明import numpy as npimport timeimport matplotlib.pyplot as pltimport 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 outz1 = genZ(-2,-1.5,1000,1000,0.003)mBrot = getJulia(z1,z1,50)plt.imshow(mBrot.get(), cmap=plt.cm.jet)plt.show()

如果对其生成过程感兴趣,那么可以观察一下随着迭代次数的增加,图像的变化情况

python如何绘制超炫酷动态Julia集

代码如下。

from matplotlib import animationfig = 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 JN = 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)作为缩放中心,则其变化如下

python如何绘制超炫酷动态Julia集

代码为

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')

Julia集

如果更改c的值,那么就能得到一个变化着的Julia集,例如,下面选取一条直线

y                         =                         x                              y=x                  y=x

上面的Julia集,效果如图所示

python如何绘制超炫酷动态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')

上述就是小编为大家分享的python如何绘制超炫酷动态Julia集了,如果刚好有类似的疑惑,不妨参照上述分析进行理解。如果想知道更多相关知识,欢迎关注编程网行业资讯频道。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

python如何绘制超炫酷动态Julia集

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

python如何绘制超炫酷动态Julia集

这期内容当中小编将会给大家带来有关python如何绘制超炫酷动态Julia集,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。前言此Julia非彼Julia,指的是对于某复数
2023-06-22

Python如何实现炫酷的动态图

这篇文章主要为大家展示了“Python如何实现炫酷的动态图”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“Python如何实现炫酷的动态图”这篇文章吧。启动如果你还没安装 Plotly,只需在你的
2023-06-28

如何用Python绘制可视化动态图表

这篇文章主要介绍“如何用Python绘制可视化动态图表”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“如何用Python绘制可视化动态图表”文章能帮助大家解决问题。对数据科学家来说,讲故事是一个至关重
2023-06-30

如何用Python绘制动态可视化图表

本篇内容主要讲解“如何用Python绘制动态可视化图表”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“如何用Python绘制动态可视化图表”吧!安装模块如果你还没安装 Plotly,只需在你的终端
2023-06-30

Python如何利用D3Blocks绘制可动态交互的图表

本篇内容主要讲解“Python如何利用D3Blocks绘制可动态交互的图表”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Python如何利用D3Blocks绘制可动态交互的图表”吧!热力图热力图
2023-07-05

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录