使用numpy.polyfit进行数据拟合的技巧

一、简介

Numpy是一个功能强大的Python科学计算库,其中包含了很多常用的数学函数和方法。其中numpy.polyfit函数就是一个非常常用的函数,它可以用于多项式拟合。多项式拟合是指将一组数据用一个n阶多项式进行拟合,得到一个多项式函数,从而实现对数据的拟合和预测的目的。其中n阶多项式的系数就是拟合函数的参数。

二、numpy.polyfit函数使用方法

numpy.polyfit(x, y, deg, rcond=None, full=False, w=None, cov=False)

1. 参数说明

  • x:1-D或2-D数组表示的x坐标系的数据。
  • y:1-D数组,表示y坐标系的数据,与x的维度也应该一致。
  • deg:拟合多项式的阶数,即多项式的次数。
  • rcond:用于确定奇异值的容差。也就是说,如果最小奇异值已经小于这个容差值,那么将放弃行列式的计算。默认值是len(x)*eps,其中eps是浮点数的机器精度。
  • full:如果为True,则返回拟合函数的一些附加信息,包括拟合残差、排名、奇异值和秩的值。默认值是False。
  • w:与y具有相同长度的1-D数组或None,用于指定相应的y值的权重。默认是None。
  • cov:如果为True,返回拟合确信度的协方差矩阵。默认值是False。

2. 返回值

拟合函数的参数。在多项式拟合中,返回值是一个1-D数组,其中第一个元素是最高阶项(x^deg)的系数,最后一个元素是常数项系数。注意:返回值是p[::-1]。

3. 代码实现

import numpy as np

# 利用numpy.polyfit函数进行一阶多项式拟合,得到函数f
x = np.array([1, 2, 3, 4, 5])
y = np.array([2, 4, 6, 8, 10])
f = np.polyfit(x, y, 1)

# 绘制拟合后的曲线
import matplotlib.pyplot as plt
plt.plot(x, y, 'o', label='Original data', markersize=10)
plt.plot(x, np.polyval(f, x), 'r', label='Fitted line')
plt.legend()
plt.show()

三、numpy.polyfit函数在多项式拟合中的应用

1. 用一阶多项式拟合数据

一阶多项式指的是y = kx + b,即直线函数。利用numpy.polyfit函数可以方便地进行直线拟合,代码实现如下:

import numpy as np
import matplotlib.pyplot as plt

# 原始数据
x = np.array([1, 2, 3, 4, 5])
y = np.array([2, 4, 6, 8, 10])

# 拟合函数
f = np.polyfit(x, y, 1)

# 绘制拟合结果
plt.plot(x, y, 'o', label='Original data', markersize=10)
plt.plot(x, np.polyval(f, x), 'r', label='Fitted line')
plt.legend()
plt.show()

2. 用高阶多项式拟合数据

除了一阶多项式外,还可以用高阶多项式(例如二次函数、三次函数等)进行数据拟合。

import numpy as np
import matplotlib.pyplot as plt

# 原始数据
x = np.array([1, 2, 3, 4, 5])
y = np.array([2, 6, 9, 10, 11])

# 二次函数拟合
f = np.polyfit(x, y, 2)

# 绘制拟合结果
plt.plot(x, y, 'o', label='Original data', markersize=10)
plt.plot(x, np.polyval(f, x), 'r', label='Fitted line')
plt.legend()
plt.show()

3. 用numpy.polyfit对非线性数据进行拟合

除了对线性数据的拟合外,还可以利用numpy.polyfit函数对非线性数据进行拟合,例如下图所示的非线性函数拟合:

import numpy as np
import matplotlib.pyplot as plt

# 原始数据
x = np.array([1, 2, 3, 4, 5])
y = np.array([10, 17, 25, 37, 50])

# 拟合函数(使用3阶多项式)
f = np.polyfit(x, y, 3)

# 绘制拟合结果
xp = np.linspace(0, 6, 100)
plt.plot(x, y, 'o', label='data', markersize=10)
plt.plot(xp, np.polyval(f, xp), 'r', lw=2.5, label='fit')
plt.legend()
plt.show()

四、综合实例:用numpy.polyfit进行黄金分割数拟合

黄金分割数是指将一条线段分割为两部分,较大部分与整条线段之比等于较小部分与较大部分之比,其值约为1.6180339887。利用numpy.polyfit函数,可以方便地对黄金分割数进行拟合,从而得到它的近似值。

import numpy as np
import matplotlib.pyplot as plt

# 生成黄金分割数列
x = np.arange(1, 50)
y = x[:-1] / x[1:]

# 拟合函数
f = np.polyfit(x[:-1], y, len(x)-2)

# 绘制拟合结果
plt.plot(x, y, 'ro', label='Golden ratio', markersize=7)
plt.plot(x[:-1], np.polyval(f, x[:-1]), 'b', label='Fitted curve')
plt.legend()
plt.show()

五、总结

本文通过介绍numpy.polyfit函数的参数、返回值以及应用实例,详细阐述了如何使用该函数进行多项式拟合,以及如何将其应用于非线性数据拟合和特定场景中的实际问题,从而使读者能够更加深入地理解和使用Python中的numpy库。

原创文章,作者:小蓝,如若转载,请注明出处:https://www.506064.com/n/186719.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
小蓝小蓝
上一篇 2024-11-27 05:48
下一篇 2024-11-27 05:48

相关推荐

  • 使用vscode建立UML图的实践和技巧

    本文将重点介绍在使用vscode在软件开发中如何建立UML图,并且给出操作交互和技巧的指导。 一、概述 在软件开发中,UML图是必不可少的重要工具之一。它为软件架构和各种设计模式的…

    编程 2025-04-29
  • Python读取CSV数据画散点图

    本文将从以下方面详细阐述Python读取CSV文件并画出散点图的方法: 一、CSV文件介绍 CSV(Comma-Separated Values)即逗号分隔值,是一种存储表格数据的…

    编程 2025-04-29
  • Python中读入csv文件数据的方法用法介绍

    csv是一种常见的数据格式,通常用于存储小型数据集。Python作为一种广泛流行的编程语言,内置了许多操作csv文件的库。本文将从多个方面详细介绍Python读入csv文件的方法。…

    编程 2025-04-29
  • 如何用Python统计列表中各数据的方差和标准差

    本文将从多个方面阐述如何使用Python统计列表中各数据的方差和标准差, 并给出详细的代码示例。 一、什么是方差和标准差 方差是衡量数据变异程度的统计指标,它是每个数据值和该数据值…

    编程 2025-04-29
  • Python多线程读取数据

    本文将详细介绍多线程读取数据在Python中的实现方法以及相关知识点。 一、线程和多线程 线程是操作系统调度的最小单位。单线程程序只有一个线程,按照程序从上到下的顺序逐行执行。而多…

    编程 2025-04-29
  • Python爬取公交数据

    本文将从以下几个方面详细阐述python爬取公交数据的方法: 一、准备工作 1、安装相关库 import requests from bs4 import BeautifulSou…

    编程 2025-04-29
  • Python两张表数据匹配

    本篇文章将详细阐述如何使用Python将两张表格中的数据匹配。以下是具体的解决方法。 一、数据匹配的概念 在生活和工作中,我们常常需要对多组数据进行比对和匹配。在数据量较小的情况下…

    编程 2025-04-29
  • Python数据标准差标准化

    本文将为大家详细讲述Python中的数据标准差标准化,以及涉及到的相关知识。 一、什么是数据标准差标准化 数据标准差标准化是数据处理中的一种方法,通过对数据进行标准差标准化可以将不…

    编程 2025-04-29
  • 如何使用Python读取CSV数据

    在数据分析、数据挖掘和机器学习等领域,CSV文件是一种非常常见的文件格式。Python作为一种广泛使用的编程语言,也提供了方便易用的CSV读取库。本文将介绍如何使用Python读取…

    编程 2025-04-29
  • Python根据表格数据生成折线图

    本文将介绍如何使用Python根据表格数据生成折线图。折线图是一种常见的数据可视化图表形式,可以用来展示数据的趋势和变化。Python是一种流行的编程语言,其强大的数据分析和可视化…

    编程 2025-04-29

发表回复

登录后才能评论