Main Content

参数化拟合

使用库模型进行参数化拟合

参数化拟合涉及为一个或多个要进行数据拟合的模型寻找系数(参数)。数据假定本质上是统计数据,分为两部分:

数据 = 确定性部分 + 随机部分

确定性部分由参数化模型给出,随机部分通常描述为与数据相关联的误差:

数据 = 参数化模型 + 误差

该模型是自(预测变量)变量和一个或多个系数的函数。误差表示数据中服从特定概率分布(通常为高斯分布)的随机变异。变异的来源可能众多,但在处理测量数据时始终处于某一水平。也可能存在系统性变异,但系统性变异可能导致拟合模型无法良好地表示数据。

模型系数通常具有物理意义。例如,假设您收集了与放射性核素的单一衰变模式对应的数据,并且要估计衰变的半衰期 (T1/2)。放射性衰变定律表明,放射性物质的活性随时间呈指数衰变。因此,拟合中使用的模型由下式给出:

y=y0eλt

其中 y0 是时间 t = 0 处的原子核数,λ 是衰变常量。数据可以描述为

data=y0eλt+error

y0 和 λ 均为由拟合估计的系数。由于 T1/2 = ln(2)/λ,通过衰变常量拟合值可得到拟合半衰期。然而,由于数据包含一些误差,无法从数据中精确地确定方程的确定性部分。因此,系数和半衰期计算会有一些不确定性。如果不确定性可接受,则您就完成了数据拟合。如果不确定性不可接受,则您可能需要采取措施来降低不确定性 - 或者通过收集更多数据,或者通过减少测量误差和收集新数据并重复模型拟合。

对于其他没有相关理论来确定适用模型的问题,您也可以通过添加或删除项来修改模型,或用完全不同的模型来代替。

以下各节描述了 Curve Fitting Toolbox™ 参数化库模型。

选择模型类型

以交互方式选择模型类型

通过在 MATLAB® 命令行中输入 curveFitter 打开曲线拟合器。或者,在 App 选项卡上的数学、统计和优化组中,点击曲线拟合器

在曲线拟合器中,转至曲线拟合器选项卡的拟合类型部分。您可以从拟合库中选择模型类型。点击箭头以打开该库。

Fit Type model gallery

下表描述可用于曲线和曲面拟合的模型。

拟合组拟合类型曲线曲面
回归模型多项式是(最高 9 次)是(最高 5 次)
指数
对数
傅里叶
高斯
有理数
正弦和
威布尔
S 形
插值插值

是,使用方法:

  • 最近邻点

  • 线性

  • 三次

  • 保形 (PCHIP)

是,使用方法:

  • 最近邻点

  • 线性

  • 自然邻点

  • 三次

  • 双调和(v4)

  • 薄板样条

平滑平滑样条
Lowess
自定义自定义方程
Custom Linear Fitting

结果窗格显示模型设定、系数值和拟合优度统计量。

提示

如果您的拟合有问题,则结果窗格中的消息会帮助您确定更好的设置。

曲线拟合器在拟合选项窗格中提供一系列拟合类型和设置以供选择,您可以更改这些类型和设置来尝试改进拟合效果。首先尝试默认值,然后用其他设置进行试验。有关如何使用可用拟合选项的更多详细信息,请参阅指定拟合选项和优化的起点

您可以为单个拟合尝试各种设置,也可以创建多个拟合进行比较。当您在曲线拟合器中创建多个拟合时,可以并排比较不同拟合类型和设置。有关详细信息,请参阅Create Multiple Fits in Curve Fitter App

以编程方式选择模型类型

当调用 fit 函数时,您可以将库模型名称指定为字符向量或字符串标量。例如,您可以指定一个二次 poly2 模型:

f = fit(x,y,"poly2")

要查看所有可用的库模型名称,请参阅曲线和曲面拟合的库模型列表

您还可以使用 fittype 函数为库模型构造一个 fittype 对象,并将 fittype 用作 fit 函数的输入。

使用 fitoptions 函数找出您可以设置的参数,例如:

fitoptions(poly2)

有关示例,请参阅以交互方式选择模型类型中的表中列出的每个模型类型的相关部分。有关创建和分析模型的所有函数的详细信息,请参阅Curve and Surface Fitting

中心化并缩放数据

曲线拟合器中的大多数拟合都在拟合选项窗格中提供中心化并缩放选项。选择此选项时,App 会使用经过中心化并缩放的数据重新拟合模型。在命令行中,使用 Normalize 选项设置为 'on'fitoptions 函数。

为了缓解因变量尺度不同产生的数值问题,请对输入数据(也称为预测变量数据)进行归一化。例如,假设曲面拟合输入是范围为 500-4500 r/min 的发动机转速和范围为 0-1 的发动机负荷百分比。在这种情况下,中心化并缩放通常会提高拟合度,因为两个输入之间的尺度差异很大。但是,如果您的输入使用相同的单位或相似的尺度(例如,地理数据的东距和北距),则中心化和缩放用处不大。使用此选项归一化输入时,与原始数据相比,拟合系数的值会发生变化。

如果要拟合曲线或曲面来估计系数,或系数具有物理意义,请清除中心化并缩放复选框。无论中心化并缩放状态如何,曲线拟合器中的图始终使用原始缩放。

在命令行中,要在拟合之前中心化并缩放数据,请使用 fitoptions 函数并将 options.Normal 指定为 'on' 来创建 options 结构体。然后,使用具有指定选项的 fit 函数。

options = fitoptions;
options.Normal = 'on';
options
options = 

  basefitoptions with properties:

    Normalize: 'on'
      Exclude: []
      Weights: []
       Method: 'None'

load census
f1 = fit(cdate,pop,"poly3",options)

指定拟合选项和优化的起点

曲线拟合器中的拟合选项

在曲线拟合器中,您可以在拟合选项窗格中以交互方式指定拟合选项。除了插值平滑样条Lowess 之外的所有拟合都有可配置的拟合选项。可用选项取决于您选择的拟合(即线性、非线性或非参数化拟合)。

  • 此处描述的选项适用于非线性模型。

  • 拟合选项窗格中,只有下限上限系数约束是可用于多项式拟合的拟合选项。

  • 非参数化拟合(即插值平滑样条Lowess 拟合)没有高级选项

此处显示单项指数拟合的拟合选项窗格。系数约束值适用于 census 数据。

Fit Options pane showing Advanced Options for exponential fit

 拟合方法和算法

 有限差分参数

 拟合收敛条件

 系数参数

有关这些拟合选项的详细信息,请参阅 lsqcurvefit (Optimization Toolbox) 函数。

优化的起点和默认约束

拟合类型窗格中拟合的默认系数起点和约束如下表中所示。如果起点经过优化,则它们是基于当前数据集通过启发式方法计算的。随机起点在区间 [0 1] 上定义,线性模型不需要起点。如果模型没有约束,则系数既没有下界也没有上界。您可以通过在拟合选项窗格中提供您自己的值来覆盖默认起点和约束。

拟合

起点

约束

线性拟合

不适用

自定义方程

随机

指数

已优化

对数

不适用

傅里叶

已优化

高斯

已优化

ci > 0

多项式

不适用

已优化

有理数

随机

正弦和

已优化

bi > 0

威布尔

随机

ab > 0

S 形

已优化

x/c>0

正弦和傅里叶拟合对起点特别敏感,优化值可能仅对相关联的方程中的几项是准确的。

在命令行中指定拟合选项

创建默认拟合 options 结构体,并将选项设置为在拟合前中心化并缩放数据:

options = fitoptions;
options.Normal = 'on';
options
options = 

  basefitoptions with properties:

    Normalize: 'on'
      Exclude: []
      Weights: []
       Method: 'None'

如果您要设置 NormalizeExcludeWeights 字段,然后使用相同的选项和不同拟合方法对数据进行拟合,则修改默认拟合 options 结构体非常有用。例如:

load census
f1 = fit(cdate,pop,"poly3",options);
f2 = fit(cdate,pop,"exp1",options);
f3 = fit(cdate,pop,"cubicsp",options);

数据相关拟合选项在 fit 函数的第三个输出参量中返回。例如,平滑样条的平滑参数是数据相关的:

[f,gof,out] = fit(cdate,pop,"smooth");
smoothparam = out.p
smoothparam =
    0.0089

使用拟合选项修改新拟合的默认平滑参数:

options = fitoptions("Method","Smooth","SmoothingParam",0.0098);
[f,gof,out] = fit(cdate,pop,"smooth",options);

有关使用拟合选项的更多详细信息,请参阅 fitoptions 函数。

另请参阅

App

函数

相关主题