使用python 的matplotlib 画轨道实例
Python  /  管理员 发布于 7年前   198
如下所示:
import numpy as np import matplotlib.pyplot as pltimport matplotlib.patches as mpatchesfrom scipy import stats fig = plt.figure()ax = fig.add_subplot(111, xlim=(0, 10), ylim=(-4, 4))sx=0;sy=0;r=1.5 ; circle = mpatches.Circle((sx,sy),r,ec='b',fc = 'b',alpha=0.6)ax.add_patch(circle)n = 5alpha = np.linspace(-np.pi/2,np.pi/2,100)for i in range(1,n+1): a = (i+1)*2 b = (i+1) plt.plot(a*np.cos(alpha),b*np.sin(alpha)) if i <= 3: ax.text(a+1,0,'layer.%d'%(i-1),ha='center',va='center')rate = 3Jnum = 100for i in range(Jnum): data = stats.poisson.rvs(mu = rate, loc = 0 , size = 1) while data == 0: data = stats.poisson.rvs(mu = rate, loc = 0 , size = 1) data = data[0] r = np.random.random() beta = (np.random.random()-0.5)*np.pi print beta data += r a = (data+1)*2*np.cos(beta) b = (data+1)*np.sin(beta) ax.scatter(a,b, c='y',edgecolors = 'y')xx = [3.5 , 6.8,6.8]yy = [-1.8,0.9,3.1]pp = [1.00,0.85,0.75]rota = [-45,0,0]for i in range(3): plt.plot((1.5,xx[i]) , (0,yy[i]) , 'r') ax.scatter(xx[i],yy[i], c='y',edgecolors = 'b') ax.text(xx[i] , yy[i] , 'probability %lf'%pp[i] , ha = 'center' )tx = np.linspace(0,10,10)ty = np.linspace(-4,-4,10)ax.set_xticks(tx)ax.set_xticklabels((''))ax.set_yticks(ty)ax.set_yticklabels((''))#plt.axis('off')plt.show()
以上这篇使用python 的matplotlib 画轨道实例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
122 在
学历:一种延缓就业设计,生活需求下的权衡之选中评论 工作几年后,报名考研了,到现在还没认真学习备考,迷茫中。作为一名北漂互联网打工人..123 在
Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..原梓番博客 在
在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..博主 在
佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..1111 在
佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..
Copyright·© 2019 侯体宗版权所有·
粤ICP备20027696号