圆月山庄资源网 Design By www.vgjia.com
今天发现sympy依赖的库mpmath里也有很多数学函数,其中也有在复平面绘制二维图的函数cplot,具体例子如下
from mpmath import * def f1(z): return z def f2(z): return z**3 def f3(z): return (z**4-1)**(1/4) def f4(z): return 1/z def f5(z): return atan(z) def f6(z): return sqrt(z) cplot(f1) cplot(f2) cplot(f3) cplot(f4) cplot(f5) cplot(f6)
参照matlab绘制复变函数的例子,使用python实现绘制复变函数图像,网上还没搜到相关的文章,在这里分享出来供大家学习。
''' 参照matlab绘制复变函数的例子,创建函数cplxgrid,cplxmap,cplxroot ''' # 1.导入相关库 import numpy as np import matplotlib.pyplot as plt from mpl_toolkits.mplot3d import * # 2.创建函数 def cplxgrid(m): '''Return polar coordinate complex grid. Parameters ---------- m: int Returns ---------- z: ndarray,with shape (m+1)-by-(2*(m+1)) ''' m = m r = np.arange(0,m).reshape(m,1) / m theta = np.pi * np.arange(-m,m) / m z = r * np.exp(1j * theta) return z def cplxroot(n=3,m=20): ''' cplxroot(n): renders the Riemann surface for the n-th root cplxroot(): renders the Riemann surface for the cube root. cplxroot(n,m): uses an m-by-m grid. Default m = 20. Use polar coordinates, (r,theta). Use polar coordinates, (r,theta). Parameters ---------- n: n-th root m: int Returns ---------- None: Plot the Riemann surface ''' m = m+1 r = np.arange(0,m).reshape(m,1) / m theta = np.pi * np.arange(-n * m, n * m) / m z = r * np.exp(1j * theta) s = r * (1/n) * np.exp(1j * theta / n) fig = plt.figure() ax = fig.add_subplot(111,projection='3d') # ax.plot_surface(np.real(z),np.imag(z),np.real(s),color = np.imag(s)) ax.plot_surface(np.real(z),np.imag(z),np.real(s),cmap = plt.cm.hsv) ax.set_xlim((-1,1)) ax.set_ylim((-1,1)) ax.set_xlabel('Real') ax.set_ylabel('Imag') ax.set_xticks([]) ax.set_yticks([]) ax.set_zticks([]) ax.set_autoscalez_on(True)#z轴自动缩放 ax.grid('on') plt.show() def cplxmap(z,cfun): ''' Plot a function of a complex variable. Parameters ---------- z: complex plane cfun: complex function to plot Returns ---------- None: Plot the surface of complex function ''' blue = 0.2 x = np.real(z) y = np.imag(z) u = np.real(cfun) v = np.imag(cfun) M = np.max(np.max(u))#复变函数实部最大值 m = np.min(np.min(u))#复变函数实部最大值 s = np.ones(z.shape) fig = plt.figure() ax = fig.add_subplot(111,projection='3d') # 投影部分用线框图 surf1 = ax.plot_wireframe(x,y,m*s,cmap=plt.cm.hsv) surf2 = ax.plot_surface(x,y,u,cmap=plt.cm.hsv) #绘制复变函数1/z时会出错,ValueError: Axis limits cannot be NaN or Inf # ax.set_zlim(m, M) ax.set_xlim((-1,1)) ax.set_ylim((-1,1)) ax.set_xlabel('Real') ax.set_ylabel('Imag') ax.set_xticks([]) ax.set_yticks([]) ax.set_zticks([]) ax.set_autoscalez_on(True)#z轴自动缩放 ax.grid('on') plt.show() def _test_cplxmap(): '''测试cplxmap函数''' z = cplxgrid(30) w1 = z w2 = z**3 w3 = (z**4-1)**(1/4) w4 = 1/z w5 = np.arctan(2*z) w6 = np.sqrt(z) w = [w1,w2,w3,w4,w5,w6] for i in w: cplxmap(z,i) def _test_cplxroot(): '''测试cplxroot函数''' cplxroot(n=2) cplxroot(n=3) cplxroot(n=4) cplxroot(n=5) if __name__ == '__main__': _test_cplxmap() _test_cplxroot()
以上这篇python/Matplotlib绘制复变函数图像教程就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
圆月山庄资源网 Design By www.vgjia.com
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
圆月山庄资源网 Design By www.vgjia.com
暂无评论...
稳了!魔兽国服回归的3条重磅消息!官宣时间再确认!
昨天有一位朋友在大神群里分享,自己亚服账号被封号之后居然弹出了国服的封号信息对话框。
这里面让他访问的是一个国服的战网网址,com.cn和后面的zh都非常明白地表明这就是国服战网。
而他在复制这个网址并且进行登录之后,确实是网易的网址,也就是我们熟悉的停服之后国服发布的暴雪游戏产品运营到期开放退款的说明。这是一件比较奇怪的事情,因为以前都没有出现这样的情况,现在突然提示跳转到国服战网的网址,是不是说明了简体中文客户端已经开始进行更新了呢?
更新日志
2024年11月05日
2024年11月05日
- 雨林唱片《赏》新曲+精选集SACD版[ISO][2.3G]
- 罗大佑与OK男女合唱团.1995-再会吧!素兰【音乐工厂】【WAV+CUE】
- 草蜢.1993-宝贝对不起(国)【宝丽金】【WAV+CUE】
- 杨培安.2009-抒·情(EP)【擎天娱乐】【WAV+CUE】
- 周慧敏《EndlessDream》[WAV+CUE]
- 彭芳《纯色角3》2007[WAV+CUE]
- 江志丰2008-今生为你[豪记][WAV+CUE]
- 罗大佑1994《恋曲2000》音乐工厂[WAV+CUE][1G]
- 群星《一首歌一个故事》赵英俊某些作品重唱企划[FLAC分轨][1G]
- 群星《网易云英文歌曲播放量TOP100》[MP3][1G]
- 方大同.2024-梦想家TheDreamer【赋音乐】【FLAC分轨】
- 李慧珍.2007-爱死了【华谊兄弟】【WAV+CUE】
- 王大文.2019-国际太空站【环球】【FLAC分轨】
- 群星《2022超好听的十倍音质网络歌曲(163)》U盘音乐[WAV分轨][1.1G]
- 童丽《啼笑姻缘》头版限量编号24K金碟[低速原抓WAV+CUE][1.1G]