python 探索分形世界|曼德布洛特|np.frompyfunc()

文章目录

  • 分形的重要特征
  • 曼德布洛特集合
    • 曼德布洛特集合有一个以证明的结论:
    • 图像展示
      • np.ogrid[]
      • np.frompyfunc()
      • 集合转图像
  • julia集合

无边的奇迹源自简单规则的无限重复 ---- 分形之父Benoit B.Mandelbrot

分形的重要特征

  • 自相似性
  • 无标度性
  • 非线性
    在这里插入图片描述

曼德布洛特集合

  • z 0 = 0 z_0 = 0 z0=0
  • z n + 1 = z n 2 + c z_{n+1} = z_{n}^2 + c zn+1=zn2+c

想要确定复数c是否属于曼德布洛特集合,只要将c代入上面公式,当n足够大时,如果序列没有发散,则说明c输入曼德布洛特集合。

def iter_m(c):z = cfor i in range(1, 10):z = z**2 + cprint(round(z, 3), end = '->')print('\n' + '*' * 20)
iter_m(-1)
iter_m(-0.5)
iter_m(0.5)# 输出
0->-1->0->-1->0->-1->0->-1->0->
********************
-0.25->-0.438->-0.309->-0.405->-0.336->-0.387->-0.35->-0.377->-0.358->
********************
0.75->1.062->1.629->3.153->10.444->109.567->12005.476->144131442.662->2.0773872763941816e+16->
********************
可以看到-1和0.5不收敛

从图像理解-0.5为什么收敛:
z n + 1 = z n 2 + c z_{n+1} = z_{n}^2 + c zn+1=zn2+c知道 z 1 = − 0.5 z_1 = -0.5 z1=0.5 z 1 z_1 z1要作下一步的横坐标,因此由 y = x y =x y=x找到横坐标为 z 1 z_1 z1的点,然后再在曼德布洛特的迭代函数中计算。(win11的计算器绘图不是方格,我稍微查了一下也没找到解决办法,如果有人知道怎么改,希望能留言,感谢)可以看到收敛于交点,至于-1和0.5也可以用同样的方法从图中看出来。

请添加图片描述

曼德布洛特集合有一个以证明的结论:

复平面上的曼德布洛特集合在一个半径为2的圆内

# 改进后的函数
def iter_m3(c):z = cfor i in range(0, 200):if abs(z) > 2: # 迭代200次后还没有发散则说明很有可能就属于曼德布洛特集合return Falsez = z**2 + creturn True

图像展示

现提出想要对一个复数区域内的点进行区分是否属于曼德布洛特集合该如何做呢?
先学习两个方法

np.ogrid[]

x, y = np.ogrid[0:1:5j, -1:1:5j] # 前列后行
# 切片第三个参数如果以j结尾则是将其等分划分
# 如果没有j,只是一个数,则是以该数为间隔划分
print('x:\n', x)
print('y:\n', y)
z = x + y * 1j
print('z:\n', z)# 输出
x:[[0.  ][0.25][0.5 ][0.75][1.  ]]
y:[[-1.  -0.5  0.   0.5  1. ]]
z:[[0.  -1.j  0.  -0.5j 0.  +0.j  0.  +0.5j 0.  +1.j ][0.25-1.j  0.25-0.5j 0.25+0.j  0.25+0.5j 0.25+1.j ][0.5 -1.j  0.5 -0.5j 0.5 +0.j  0.5 +0.5j 0.5 +1.j ][0.75-1.j  0.75-0.5j 0.75+0.j  0.75+0.5j 0.75+1.j ][1.  -1.j  1.  -0.5j 1.  +0.j  1.  +0.5j 1.  +1.j ]]

np.frompyfunc()

优点类似于map的功能,但不完全相同。对于上面的iter_m3()方法只能传入一个复数,如果传入一个包含复数的数组则不可以。为了解决这个问题,使用np.frompyfunc(func, nin, nout)
其中func是自定义函数,nin是传入参数的个数,nout是传出参数的个数。

mande = np.frompyfunc(iter_m3, 1, 1)
mande(z)# 输出
array([[True, True, True, True, True],[False, True, True, True, False],[False, False, False, False, False],[False, False, False, False, False],[False, False, False, False, False]], dtype=object)

同样也可以使用map达到该功能,但是复杂一些

result = np.array(list(map(lambda row: list(map(iter_m3, row)), z)))
# 注意:对于二维数组,一层map取的是一维数组
print(result)# 输出
[[ True  True  True  True  True][False  True  True  True False][False False False False False][False False False False False][False False False False False]]

集合转图像

import numpy as np
import matplotlib.pylab as plt
from matplotlib import cmdef iter_m3(c):z = cfor i in range(0, 200):if abs(z) > 2: # 迭代200次后还没有发散则说明很有可能就属于曼德布洛特集合return Falsez = z**2 + creturn Truedef draw_set(cx, cy, d, ufunc:np.ufunc):x0, x1, y0, y1 = cx - d, cx + d, cy - d, cy + dy, x = np.ogrid[y0:y1:400j, x0:x1:400j]z = x + y * 1jplt.imshow(ufunc(z).astype(float), cmap=cm.jet, extent=[x0, x1, y0, y1])mande = np.frompyfunc(iter_m3, 1, 1)
draw_set(-0.5, 0, 1.5, mande)

输出图像:
在这里插入图片描述

但是颜色不够鲜艳,希望每一个不同的发散点都能显示不同的颜色。

def iter_m4(c):z = cfor i in range(0, 200):if abs(z) > 2: # 迭代200次后还没有发散则说明很有可能就属于曼德布洛特集合breakz = z**2 + creturn i
mande = np.frompyfunc(iter_m4, 1, 1)
draw_set(-0.5, 0, 1.5, mande)

放大
对(0.273, 0.5921)处进行放大

x, y = 0.273, 0.5921
plt.subplot(2, 3, 1)
draw_set(-0.5, 0, 1.5, mande)
for i in range(2, 7):plt.subplot(2, 3, i)draw_set(x, y, 0.25**(i-1.5), mande)

输出:
在这里插入图片描述

julia集合

迭代公式与曼德布洛特唯一区别在于 z 0 z_0 z0不是0,而是输入数据,c给定一个值,因此曼德布洛特集合只有一个,而julia集合有无数个。

def iter_j(z):c = -0.4 + 0.6jfor i in range(0, 200):if abs(z) > 2: # 迭代200次后还没有发散则说明很有可能就属于曼德布洛特集合breakz = z**2 + creturn i
julia = np.frompyfunc(iter_j, 1, 1)
draw_set(0, 0, 1.5, julia)

输出:
在这里插入图片描述
放大

x, y = 0.5754, 0.2048
plt.subplot(2, 3, 1)
draw_set(0, 0, 1.5, julia)
for i in range(2, 7):plt.subplot(2, 3, i)draw_set(x, y, 0.25**(i-1), julia)

输出:
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/142201.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

8+单基因+细胞凋亡+WGCNA+单细胞+实验验证

今天给同学们分享一篇单基因细胞凋亡WGCNA实验验证的生信文章“RASGRP2 is a potential immune-related biomarker and regulates mitochondrial-dependent apoptosis in lung adenocarcinoma”,这篇文章于2023年2月3日发表在Front Immunol期刊上,影响因…

订阅《复现SCI文章系列教程》

写在前面 《小杜生信笔记》准备开启新的订阅专栏**《复现期刊文章系列教程》,本专栏小杜会寻找一些自己感兴趣的文章进行复现(不说百分之百的复现,但是也会百分之八十进行复现)。本期刊的教程代码会全部进行公开(通过订…

孙哥Spring源码第26集

第26集、AnnotationAwareAspectJAutoProxyCreator源码 【视频来源于:B站up主孙帅suns Spring源码视频】【微信号:suns45】 26.1、postProcessAfterInitialization分析 26.2、wrapIfNecessary分析 26.3、createProxy分析 26.4、getProxy 26.5、BeanPost…

Deep Span Representations for Named Entity Recognition

原文链接: https://aclanthology.org/2023.findings-acl.672.pdf ACL 2023 介绍 问题 作者认为,一个好的span表征对于NER任务是非常重要的,而之前的工作都是将第一个或最后一个的表征简单的进行组合后,没有进行充分的交互就送入到…

linux 查看CPU架构是AMD还是ARM

要查看 Linux 系统的 CPU 架构是 AMD 还是 ARM,可以使用以下命令: 使用 lscpu 命令并查找 Architecture 字段: lscpu | grep Architecture如果输出结果中包含 x86_64 或 i686,则表示系统的 CPU 架构是 AMD(或者是 x86…

android去掉 原生锁屏

1. /frameworks/base/core/java/com/android/internal/widget/LockPatternUtils.java 直接 return true 2./packages/apps/Settings/src/com/android/settings/password/ScreenLockType.java 都改成 none 类型

软件定义网络-OpenvSwitch

软件定义网络(SDN)。它主要有以下三个特点: 控制与转发分离:转发平面就是一个个虚拟或者物理的网络设备,就像小区里面的一条条路。控制平面就是统一的控制中心,就像小区物业的监控室。它们原来是一起的&…

xxl-job分布式调度框架

课程目标 1、 掌握xxl-job部署以及开发的方式 2、 掌握xxl-job特性以及架构设计 3、 掌握xxl-job运行原理 内容定位 适合已经掌握了Quartz的同学 quartz这节课是本节课的基础,这个要求大家一定掌握,因为xxl-job早期就是使用quartz改造的&#xff0…

基于微信小程序的高校就业招聘系统设计与实现(源码+lw+部署文档+讲解等)

前言 💗博主介绍:✌全网粉丝10W,CSDN特邀作者、博客专家、CSDN新星计划导师、全栈领域优质创作者,博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战✌💗 👇🏻…

【OLSR路由协议】链路状态路由(OLSR)协议中选择多点中继节点算法研究(Matlab代码实现)

💥💥💞💞欢迎来到本博客❤️❤️💥💥 🏆博主优势:🌞🌞🌞博客内容尽量做到思维缜密,逻辑清晰,为了方便读者。 ⛳️座右铭&a…

Simulink 封装

快捷键: Edit Mask:CtrlM Look Under Mask:CtrlU 封装之后的模型: Edit Mask界面: 双击模块后的提示界面: 封装的模块内部:

软件测试-测试用例

软件测试-测试用例 1.什么是测试用例 为了实施测试而向被测系统提供的一组集合。这组集合包括测试环境、操作步骤、测试数据、预期结果等要素。 举例:对一个垃圾桶设计测试用例 2.设计测试用例的万能公式 设计测试用例的万能公式:功能测试性能测试界…

国产手机芯片4G方案_紫光展锐安卓核心板虎贲4G智能模块方案定制

元器件清单即BOM物料清单,不同行业领域的BOM表侧重点不一样。安卓主板的BOM表则侧重点在于元器件物料的清单,也就是安卓电路板的PCBA清单,精密的安卓板有上千个物料,可以帮助我们估算物料成本,建立生产计划&#xff0c…

单日 5000 亿行 / 900G 数据接入,TDengine 3.0 在中国地震台网中心的大型应用

小T导读:为满足地震预警数据存储、检索和处理的建设与集成需求,以及响应国家国产软件自主可控的号召,中国地震台网中心决定选用国产数据库 TDengine 来存储和处理地震波形数据。本文将针对 TDengine 3.0 在地震领域的应用展开详细讲解。 关于…

Tensorflow Federated Framework 谷歌联邦学习框架

目录 Tensorflow Federated Framework 谷歌联邦学习框架 1、TensorFlow Federated Framework 数据为主 整体训练 新的语言 Federated Learning (FL) API 安装TFF库(conda) 2、数据类型 3、完整代码 Tensorflow Federated Framework 谷歌联邦学习…

系统架构设计师(第二版)学习笔记----软件工程

【原文链接】系统架构设计师(第二版)学习笔记----软件工程 文章目录 一、软件工程1.1 软件危机的表现1.2 软件工程的内容 二、软件过程模型2.1 软件的声明周期2.2 瀑布模型2.3 瀑布模型的缺点2.4 原型模型2.5 原型模型开发阶段2.6 开发原型的途径2.7 螺旋…

leetcodeTop100(21) 相交链表

给你两个单链表的头节点 headA 和 headB ,请你找出并返回两个单链表相交的起始节点。如果两个链表不存在相交节点,返回 null 。 题目数据 保证 整个链式结构中不存在环。 注意,函数返回结果后,链表必须 保持其原始结构 。 双链表…

SAP PO运维(一):系统概览异常处理

打开SAP PIPO Netweaver Administration界面,系统概览下显示异常: 参考SAP note: 2577844 - AS Java Monitoring and Logging parametrization best practice service/protectedwebmethods = SDEFAULT -GetVersionInfo -GetAccessPointList -ListLogFiles -ReadLogFile -Para…

基于微信小程序的宠物用品商城设计与实现(源码+lw+部署文档+讲解等)

文章目录 前言系统主要功能:具体实现截图论文参考详细视频演示为什么选择我自己的网站自己的小程序(小蔡coding)有保障的售后福利 代码参考源码获取 前言 💗博主介绍:✌全网粉丝10W,CSDN特邀作者、博客专家、CSDN新星计…

Jmeter配置性能监控插件

一、版本不兼容时,有报错 1、当jmeter版本比较高时,只需要从官网安装jmeter-plugins-manager-1.10.jar一个包 2、当jmeter版本较低时,安装JMeterPlugins-Extras-1.4.0.zip、JMeterPlugins-Standard-1.4.0.zip内两个jar包 3、服务器上传文件…