时间:2021-05-23
输入各种特征值聚堆与分散时的矩阵,并应用共轭梯度法,观察迭代次数与聚堆情况的关系。
因为对角矩阵的对角线元素为其特征值,则用对角矩阵讨论较为方便
代码
矩阵1,前5个元素聚堆且都为相同元素
矩阵2,特征值分散
矩阵3,前5个特征值聚堆,但是最大差为0.4 ,而cg法精度为1e-6
矩阵4,前5个特征值聚堆,且相差最大小于1e-6
矩阵5,三聚堆
输出:
分析:
以上就是python共轭梯度法特征值迭代次数讨论的详细内容,更多关于python共轭梯度法迭代的资料请关注其它相关文章!
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
在一般问题的优化中,最速下降法和共轭梯度法都是非常有用的经典方法,但最速下降法往往以”之”字形下降,速度较慢,不能很快的达到最优值,共轭梯度法则优于最速下降法,
对于一个多元函数用牛顿法求其极小值的迭代格式为其中为函数的梯度向量,为函数的Hesse(Hessian)矩阵。上述牛顿法不是全局收敛的。为此可以引入阻尼牛顿法(
#检查数据中是否有缺失值np.isnan(train).any()Flase:表示对应特征的特征值中无缺失值True:表示有缺失值通常情况下删除行,使用参数ax
共轭梯度法是介于最速下降法与牛顿法之间的一个方法,它仅需利用一阶导数信息,但克服了最速下降法收敛慢的缺点,又避免了牛顿法需要存储和计算Hesse矩阵并求逆的缺点
下面代码中利用了两种比对的方法,一对图片矩阵(mxm)求解特征值,通过比较特征值是否在一定的范围内,判断图片是否相同。二对图片矩阵(mxm)中1求和,通过比较s