[关闭]
@wuqi0616 2017-05-24T14:30:44.000000Z 字数 4073 阅读 3229

非线性最小二乘法的理论

三轴运动平台


1、 背景

非线性最小二乘算法的应用大约于上世纪80年代初,非线性最小二乘法除可直接用于估计静态非线性模型的参数外,在时间序列建模、连续动态模型的参数估计中,也往往遇到求解非线性最小二乘问题。其算法主要有两类:一类是搜索算法,另一类是迭代算法
搜索算法的思路是:按一定的规则选择若干组参数值,分别计算它们的目标函数值并比较大小;选出使目标函数值最小的参数值,同时舍弃其他的参数值;然后按规则补充新的参数值,再与原来留下的参数值进行比较,选出使目标函数达到最小的参数值。如此继续进行,直到选不出更好的参数值为止。以不同的规则选择参数值,即可构成不同的搜索算法。常用的方法有单纯形搜索法、复合形搜索法、随机搜索法等。
迭代算法是从参数的某一初始猜测值出发,然后产生一系列的参数点,如果这个参数序列收敛到使目标函数极小的参数点娈,那么对充分大的就可用作为娈。迭代算法的一般步骤是:
1、给出初始猜测值,并置迭代步数
2、确定一个向量作为第步的迭代方向
3、用寻优的方法决定一个标量步长
4、检查停机规则是否满足,如果不满足,则将加1再从2开始重复;如果满足,则取为值

典型的迭代算法有:

2、 算法核心

一般非线性最小二乘法及其典型迭代算法:
提出问题:---量测关系式


其中,可以是量测量,物理量测量,数学量测量
是待估时常参数,可以是单变量,也可以是多变量
可以是时间变量,也可以是其他已知函数,可以是单变量,也可以是多变量
是对量测的测量误差,可以是偏倚误差,也可以是随机误差,可以是平稳随机过程,也可以是非平稳随机过程;
的非线性函数。
一般非线性最小二乘问题是:给定量测与关系式,要求确定参数,使:

该式是一个无条件极值问题,根据微积分学教程的方法,可以求:

的n个方程的解,找出平衡值(为极值存在的必要条件),再来验证是极大值还是极小值。
由上式可以看出:一般非线性最小二乘问题的解,是转化为非线性方程组的求解问题。而非线性方程组并无解析解的一般方法,为此发展了一系列的数值解法[1]
1、高斯-牛顿迭代法
选给定的初始近似值,记录真值与初始之差(未知)为

由下面联立方程组给出:

其中:

值较大时,可令当前的值代替原来的近似值,重复计算并求解联立方程得到新的,直至值小到可以忽略不计为止。

2、麦夸脱(Levenberg-Marquardt)迭代法
该法与高斯-牛顿法不同,在于确定方程组的不同,此处取联立方程组为:


上式中,则退化为高斯-牛顿迭代法,的选取方法为:
1)算出初始值所对应的残差,指定一个常数,例如),并给出的一个初始值(例如:当时,令)。

2)进行下一步迭代时,令


其中值尽可能取得小些,但需要保证由上面方程组解出的(进而是)相应的残差平方和小于,即:

先令,若上式成立,则此次迭代完成;否则令d=c^{(0)} d^{(0)}直至上式成立。

3)以的当前值代替,重复第2)步,做下次迭代,直至可以忽略。

3、平台应用

此处输入图片的描述
建立速度输入()速度输出()的数学模型:


因此,需要的辨识的模型可以为:

得到的仍为高阶系统模型,在系统速度处于1/20 ~ 1/5额定转速时机电一体化伺服系统可以近似用二阶模型近似:
此处输入图片的描述
因此可以建立输入输出降阶模型为:

记录输入量(给定目标速度)、输出量(实际瞬间转速,实际电机位置),可以通过辨识实际输出转速(物理量)与输入量(数字量)之间的输入输出模型进而获得实际输出电机位置(物理量)与输入量(数字量)之间的输入输出模型,即:


这里的为伺服器反馈信息时间差。

N 参考文献


1 Lawson C. L.,Hanson R. J. Solving Least Squares
Problems[M]. Prentice-Hall Inc,1974.
2 刘钦圣. 最小二乘问题计算方法[M]. 北京:北京工业
大学出版社,1989
[3]王新洲、非线性模型参数估计理论与应用.武汉大学出版社,2002


[1] 王梓坤. 常用数学公式大全[M]. 重庆:重庆出版社,1991
添加新批注
在作者公开此批注前,只有你和作者可见。
回复批注