python绘制动态曲线教程
更新时间:2020年02月24日 08:21:37 作者:淮南草
今天小编就为大家分享一篇python绘制动态曲线教程,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
从txt种获取数据 并且通过动态曲线显示
import numpy as np import matplotlib.pyplot as plt import matplotlib.animation as animation import time # Fixing random state for reproducibility np.random.seed(196) path = "feed.txt" file = open(path, 'r') data = [] for line in file.readlines(): lineArr = line.strip().split() data.append(int(lineArr[0])) xdata = np.arange(0,len(data)) #初始数据绘图 dis = np.zeros(40) dis2 = dis fig, ax = plt.subplots() line, = ax.plot(dis) ax.set_ylim(0, 100) plt.grid(True) ax.set_ylabel("distance: m") ax.set_xlabel("time") def update(frame): global dis global dis2 global line #读入模拟 a = frame time.sleep(np.random.rand()/10) #绘图数据生成 dis[0:-1] = dis2[1:] dis[-1] = a dis2 = dis #绘图 line.set_ydata(dis) #颜色设置 plt.setp(line, 'color', 'b', 'linewidth', 2.0) return line ani = animation.FuncAnimation(fig, update,frames=data, interval=10) plt.show()
输出:
补充拓展:Python绘制mes曲线实例
mes曲线:累计误差曲线。一般用于测试生成的关键点与标定的关键点间的差异情况,差异一般是指两点间的欧氏距离。
标记点坐标 p_g(x,y)
预测点坐标 p_t(x,y)
dist(p_g,p_t)可以计算两点间的欧氏距离。
def dist(point1,point2): return ((point1[0] - point2[0]) ** 2 + (point1[1] - point2[1]) ** 2) ** 0.5
在人脸的关键点检测中,dist()计算的距离/双眼间距离 进行归一化。将归一化后的值append到MSE,调用drawCDFSingle(MSE)即可看到累计误差曲线。
def drawCDFSingle(MSE): plotDataset = [[], []] plt.grid() plt.xlabel("pixel error") plt.ylabel("Fraction of number of landmarks") plt.title('CDF') for i in range(len(MSE[0])): sumnum = 0 mse_point = [x[i] for x in MSE] mse_point.sort() plotDataset[0]=[] plotDataset[1]=[] for t in range(len(mse_point)): plotDataset[0].append(float(t+1)/len(mse_point)) # sumnum=sumnum+float(mse_point[t]) plotDataset[1].append(float(mse_point[t])) plt.plot(plotDataset[1],plotDataset[0] , color[i%len(color)]+linestyle[i%len(linestyle)], linewidth=2, label=i) plt.legend() # make legend plt.show()
以上这篇python绘制动态曲线教程就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持脚本之家。
相关文章
TensorFlow中tf.batch_matmul()的用法
这篇文章主要介绍了TensorFlow中tf.batch_matmul()的用法,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教2021-06-06python框架Django实战商城项目之工程搭建过程图文详解
这篇文章主要介绍了python框架Django实战商城项目之工程搭建过程,这个项目很像京东商城,项目开发采用前后端不分离的模式,本文通过图文并茂的形式给大家介绍的非常详细,需要的朋友可以参考下2020-03-03pycharm激活码免费分享适用最新pycharm2020.2.3永久激活
免费为大家分享Pycharm激活码,适用最新版pycharm2020.2.3永久激活,pycharm2018,pycharm2019也可永久激活,可成功激活到2089年2020-11-11
最新评论