Python编程使用matplotlib绘制动态圆锥曲线示例
更新时间:2021年10月19日 16:00 点击:2330
作为让高中生心脏骤停的四个字,对于高考之后的人来说可谓刻骨铭心,所以定义不再赘述,直接撸图,其标准方程分别为
在Python中,绘制动图需要用到matplotlib
中的animation
包,其调用方法以及接下来要用到的参数为
ani = animation.FuncAnimation(fig, func, frames, interval)
其中fig
为绘图窗口,func
为绘图函数,其返回值为图像,frames
为迭代参数,如果为整型的话,其迭代参数则为range(frames)
。
椭圆
为了绘图方便,椭圆的参数方程为
代码为:
# 这三个包在后面的程序中不再复述 import numpy as np import matplotlib.pyplot as plt import matplotlib.animation as animation a,b,c = 5,3,4 fig = plt.figure(figsize=(12,9)) ax = fig.add_subplot(autoscale_on=False, xlim=(-a,a),ylim=(-b,b)) ax.grid() line, = ax.plot([],[],'o-',lw=2) trace, = ax.plot([],[],'-', lw=1) theta_text = ax.text(0.02,0.85,'',transform=ax.transAxes) textTemplate = '''theta = %.1f°\n lenL = %.1f, lenR = %.1f\n lenL+lenR = %.1f''' xs,ys = [], [] def animate(i): if(i==0): xs.clear() ys.clear() theta = i*0.04 x = a*np.cos(theta) y = b*np.sin(theta) xs.append(x) ys.append(y) line.set_data([-c,x,c], [0,y,0]) trace.set_data(xs,ys) lenL = np.sqrt((x+c)**2+y**2) lenR = np.sqrt((x-c)**2+y**2) theta_text.set_text(textTemplate % (180*theta/np.pi, lenL, lenR, lenL+lenR)) return line, trace, theta_text ani = animation.FuncAnimation(fig, animate, 157, interval=5, blit=True) ani.save("ellipse.gif") plt.show()
双曲线
双曲线的参数方程为
设 a = 4 , b = 3 , c = 5 则代码如下
a,b,c = 4,3,5 fig = plt.figure(figsize=(12,9)) ax = fig.add_subplot(autoscale_on=False, xlim=(-c,16),ylim=(-12,12)) ax.grid() line, = ax.plot([],[],'o-',lw=2) trace, = ax.plot([],[],'-', lw=1) theta_text = ax.text(0.01,0.85,'', transform=ax.transAxes) textTemplate = '''t = %.1f\n lenL = %.1f, lenR = %.1f\n lenL-lenR = %.1f''' xs,ys = [],[] def animate(t): if(t==-3): xs.clear() ys.clear() x = a*np.cosh(t) y = b*np.sinh(t) xs.append(x) ys.append(y) line.set_data([-c,x,c], [0,y,0]) trace.set_data(xs,ys) lenL = np.sqrt((x+c)**2+y**2) lenR = np.sqrt((x-c)**2+y**2) theta_text.set_text(textTemplate % (t, lenL, lenL, lenL-lenR)) return line, trace, theta_text frames = np.arange(-3,3,0.05) ani = animation.FuncAnimation(fig, animate, frames, interval=5, blit=True) ani.save("hyperbola.gif") plt.show()
抛物线
import numpy as np import matplotlib.pyplot as plt import matplotlib.animation as animation a,b,c = 4,3,5 p = 1 fig = plt.figure(figsize=(12,9)) ax = fig.add_subplot(autoscale_on=False, xlim=(-0.6,4.5),ylim=(-3,3)) ax.grid() ax.plot([-p/2,-p/2],[-5,5],'-',lw=2) line, = ax.plot([],[],'o-',lw=2) trace, = ax.plot([],[],'-', lw=1) theta_text = ax.text(0.05,0.85,'', transform=ax.transAxes) textTemplate = '''y = %.1f\n lenL = %.1f, lenF = %.1f\n lenL-lenF = %.1f''' xs,ys = [],[] def animate(y): if(y==-3): xs.clear() ys.clear() x = y**2/p/2 xs.append(x) ys.append(y) line.set_data([-p,x,p/2], [y,y,0]) trace.set_data(xs,ys) lenL = x+p/2 lenF = np.sqrt((x-p/2)**2+y**2) theta_text.set_text(textTemplate % (y, lenL, lenF, lenL-lenF)) return line, trace, theta_text frames = np.arange(-3,3,0.1) ani = animation.FuncAnimation(fig, animate, frames, interval=5, blit=True) ani.save("parabola.gif") plt.show()
极坐标方程
圆锥曲线在极坐标系下有相同的表达式,即
在matplotlib
中,极坐标图像需要通过projection='polar'
来标识,其代码为
p = 2 fig = plt.figure(figsize=(12,9)) ax = fig.add_subplot(autoscale_on=False, projection='polar') ax.set_rlim(0,8) trace, = ax.plot([],[],'-', lw=1) theta_text = ax.text(0.05,0.95,'',transform=ax.transAxes) textTemplate = 'e = %.1f\n' theta = np.arange(-3.1,3.2,0.1) def animate(e): rho = p/(1-e*np.cos(theta)) trace.set_data(theta,rho) theta_text.set_text(textTemplate % e) return trace, theta_text frames = np.arange(-2,2,0.1) ani = animation.FuncAnimation(fig, animate, frames, interval=100, blit=True) ani.save("polar.gif") plt.show()
以上就是Python使用matplotlib绘制动态的圆锥曲线示例的详细内容,更多关于matplotlib绘制动态圆锥曲线的资料请关注猪先飞其它相关文章!
上一篇: Python 注解方式实现缓存数据详解
下一篇: 一篇文章带你入门Python正则表达式
相关文章
- ps动态环绕动画效果是现在很多人都非常喜欢的,大多数人还不知道ps动态环绕动画效果怎么制作下面文章就给大家介绍下ps怎么制作科技感十足的动态环绕动画效果,一起来看看...2017-07-06
- 这篇文章主要介绍了matplotlib绘制正余弦曲线图的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2021-02-22
- 这篇文章主要介绍了matplotlib bar()实现百分比堆积柱状图,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2021-02-24
- 这篇文章主要介绍了vue 实现动态路由的方法,文中示例代码非常详细,帮助大家更好的理解和学习,感兴趣的朋友可以了解下...2020-07-06
python Matplotlib基础--如何添加文本和标注
这篇文章主要介绍了python Matplotlib基础--如何添加文本和标注,帮助大家更好的利用Matplotlib绘制图表,感兴趣的朋友可以了解下...2021-01-26matplotlib之pyplot模块之标题(title()和suptitle())
这篇文章主要介绍了matplotlib之pyplot模块之标题(title()和suptitle()),文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2021-02-23- 今天我们来给大家介绍下在Vue开发中我们经常会碰到的一种需求场景,本文主要介绍了Vue动态查询规则生成组件,需要的朋友们下面随着小编来一起学习学习吧...2021-05-27
- 这篇文章介绍了c#动态调用Webservice的两种方法实例,有需要的朋友可以参考一下...2020-06-25
- 本文详细讲解了SQLServer中执行动态SQL的方法,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下...2022-05-19
- 想在网页中动态地显示当前系统的时间,找了好多,不过都是一些停在那里不动的。。。不过皇天不负有心人,终于让我找到了...2020-06-25
- 下面小编就为大家带来一篇jQuery为动态生成的select元素添加事件的方法。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧...2016-09-01
- 这篇文章主要介绍了matplotlib grid()设置网格线外观的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2021-02-23
matplotlib之pyplot模块坐标轴标签设置使用(xlabel()、ylabel())
这篇文章主要介绍了matplotlib之pyplot模块坐标轴标签设置使用(xlabel()、ylabel()),文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2021-02-23- 这篇文章主要介绍了PyQt5结合matplotlib绘图的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2020-09-15
- 下面小编就为大家带来一篇用C++面向对象的方式动态加载so的方法。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧...2020-04-25
- 这篇文章主要介绍了C#实现动态显示及动态移除图片方法,对于C#的初学者了解图像操作有一定的帮助,需要的朋友可以参考下...2020-06-25
- 这篇文章主要介绍了将matplotlib绘图嵌入pyqt的方法示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2020-04-27
- 这篇文章主要介绍了Springboot使用thymeleaf动态模板实现刷新,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下...2020-08-31
- 本篇文章主要介绍了vue2 中如何实现动态表单增删改查实例,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧 ...2017-06-15
- 最近由于项目的需要,需要动态的添加和删除table中的tr,感觉用JS可以实现,但是在网上找了一下,单纯的自己写JS,感觉太麻烦,而且也不好维护。于是想到了最近学的jQuery。这篇文章给大家用实例介绍了jQuery动态添加与删除tr行的方法,有需要的朋友们可以参考借鉴。...2016-10-20