numpy.polynomial#
一个高效处理多项式的子包。
在此子包的文档中,“有限幂级数”,即多项式(也简称为“级数”),由多项式系数的一维 numpy 数组表示,从最低阶项到最高阶项排序。例如,数组 `[1,2,3]` 表示 P_0 + 2*P_1 + 3*P_2,其中 `P_n` 是适用于特定模块的 n 阶基多项式,例如 polynomial(它“包装”了“标准”基)或 chebyshev。为获得最佳性能,所有多项式操作,包括在参数上的求值,都实现了为系数上的操作。有关其他(特定于模块的)信息,请参阅相关模块的文档字符串。
此包为六种不同类型多项式提供了*便利类*
这些*便利类*为创建、操作和拟合不同基多项式数据提供了统一的接口。便利类是 polynomial 包的首选接口,并且可以从 numpy.polynomial 命名空间访问。这消除了导航到相应子模块的需要,例如 np.polynomial.Polynomial 或 np.polynomial.Chebyshev 而不是 np.polynomial.polynomial.Polynomial 或 np.polynomial.chebyshev.Chebyshev。与每个多项式类型在子模块中定义的特定于类型的函数相比,这些类提供了更一致且简洁的接口。例如,要使用度数为 1 的切比雪夫多项式拟合由数组 xdata 和 ydata 给出的数据,首选*类方法* fit
>>> from numpy.polynomial import Chebyshev
>>> xdata = [1, 2, 3, 4]
>>> ydata = [1, 4, 9, 16]
>>> c = Chebyshev.fit(xdata, ydata, deg=1)
而不是 np.polynomial.chebyshev 模块中的 chebyshev.chebfit 函数
>>> from numpy.polynomial.chebyshev import chebfit
>>> c = chebfit(xdata, ydata, deg=1)
有关更多详细信息,请参阅 使用便利类。
便利类#
以下列出了表示各种类型多项式的所有类的各种常量和方法。在下文中,术语 Poly 表示任何一个便利类(例如,Polynomial、Chebyshev、Hermite 等),而小写字母 p 表示多项式类的*实例*。
常量#
Poly.domain– 默认域Poly.window– 默认窗口Poly.basis_name– 用于表示基的字符串Poly.maxpower–p**n允许的最大值n
创建#
创建多项式实例的方法。
Poly.basis(degree)– 指定阶数的基多项式Poly.identity()–p,其中p(x) = x对于所有xPoly.fit(x, y, deg)– 度数为deg的p,其系数由对数据x,y的最小二乘拟合确定Poly.fromroots(roots)– 具有指定根的pp.copy()– 创建p的副本
转换#
将一种多项式实例转换为另一种类型的方法。
p.cast(Poly)– 将p转换为Poly类型的实例p.convert(Poly)– 将p转换为Poly类型的实例或在domain和window之间映射
微积分#
p.deriv()– 对p求导p.integ()– 对p积分
验证#
Poly.has_samecoef(p1, p2)– 检查系数是否匹配Poly.has_samedomain(p1, p2)– 检查域是否匹配Poly.has_sametype(p1, p2)– 检查类型是否匹配Poly.has_samewindow(p1, p2)– 检查窗口是否匹配
杂项#
p.linspace()– 在domain中等距点上返回x,p(x)p.mapparms()– 返回domain和window之间线性映射的参数。p.roots()– 返回p的根。p.trim()– 移除末尾的系数。p.cutdeg(degree)– 将p截断到指定的度数p.truncate(size)– 将p截断到指定的长度
配置#
设置多项式字符串表示的默认格式。 |