当前位置:   article > 正文

【学习】Python对于数据进行曲线拟合计算多项式方程_python拟合曲线求方程

python拟合曲线求方程

 说得直观一点,就是将平面上的一些散点拟合为一条最为接近的曲线,获得曲线方程,从而可以通过输入其他x坐标的值实现对结果值的预测。

 如图,这是简单的一元线性回归模型,训练数据包含X和Y两组,其中X中的数据表示学生在作业上投入的时间,Y中的数据表示学生的作业成绩,X和Y中的数据是一一对应的。笔者使用最小二乘回归拟合训练数据中X与Y的关系。

最小二乘

其通过最小化误差的平方和寻找数据的最佳匹配函数。使用该方法可以实现预测未知的数据,并使得这些求得的数据与实际数据之间误差的平方和最小。

python类库

NumPy

Numeric Python。由多维数组对象和用于处理数组的例程集合组成的库,支持大量维度数组与矩阵运算,也针对数组运算提供大量的数学函数库。

Matplotlib

绘图库。可与NumPy一起使用,提供了一种有效的MatLab开源替代方案。

  1. import matplotlib.pyplot as plt
  2. import numpy as np
  3. x = np.array([0.50, 0.75, 1.00, 1.25, 1.50, 1.85, 2.00, 2.25, 2.50, 2.75, 3.25, 3.50, 4.25, 5.00, 5.50])
  4. y = np.array([10, 20, 22, 33, 40, 52, 48, 55, 55, 62, 73, 74, 82, 90, 93]) # 将(x,y)坐标点输入
  5. z1 = np.polyfit(x, y, 2)
  6. #使用polyfit方法进行拟合,选择二次方程式
  7. p1 = np.poly1d(z1)
  8. # 打印拟合多项式
  9. print(p1)
  10. # 求对应的各项拟合函数值
  11. fx = p1(x)
  12. # 绘制图像
  13. plot1 = plt.plot(x, y, '*', label='study time')
  14. plot2 = plt.plot(x, fx, 'r', label='score')
  15. plt.xlabel('X')
  16. plt.ylabel('Y')
  17. plt.legend(loc=4)
  18. plt.title('score')
  19. plt.show()
  20. plt.savefig('score.png')

文章参考:张一鸣

处于初步学习阶段,如有不妥或问题敬请指出。

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/知新_RL/article/detail/683744
推荐阅读
相关标签
  

闽ICP备14008679号