news 2026/2/26 18:53:55

共轭梯度法无约束最优化程序 共轭梯度法、梯度下降法求解无约束最优化问题的MATLAB程序

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
共轭梯度法无约束最优化程序 共轭梯度法、梯度下降法求解无约束最优化问题的MATLAB程序

共轭梯度法无约束最优化程序 共轭梯度法、梯度下降法求解无约束最优化问题的MATLAB程序,买家可通过修改程序中的fun1目标函数和gfun1目标函数的梯度函数求解自己的无约束最优化问题。

最近在折腾无约束优化问题的时候顺手写了套MATLAB工具,今天拿出来和大家唠唠。这玩意儿特别适合手头有数学公式但懒得从头造轮子的朋友,咱们重点聊聊怎么用梯度下降和共轭梯度法快速实现优化。

先甩个梯度下降法的核心代码镇楼:

function [x,val,k] = grad_descent(fun,gfun,x0) maxk = 5000; rho = 0.5; sigma = 0.4; k = 0; epsilon = 1e-5; while(k < maxk) g = feval(gfun,x0); d = -g; if(norm(d) < epsilon), break; end % 步长搜索 m = 0; while(m < 20) if(feval(fun,x0 + rho^m*d) < feval(fun,x0) + sigma*rho^m*g'*d) break; end m = m + 1; end x0 = x0 + rho^m*d; k = k + 1; end x = x0; val = feval(fun,x); end

这个实现有几个骚操作值得注意:1)用了Armijo非精确线搜索控制步长,避免算不动点;2)设置双重循环防止死磕;3)变量名故意用x0而不是x,提醒自己这是就地更新。不过梯度下降大家都懂,就像下楼梯总得一步步蹭,遇到山谷地形就扭成麻花了。

重点看看共轭梯度法的升级版:

function [x,val,k] = conj_gradient(fun,gfun,x0) maxk = 5000; n = length(x0); epsilon = 1e-5; k = 0; g0 = feval(gfun,x0); d = -g0; while(k < maxk) % 精确线搜索 alpha = golden_section(fun,x0,d); x1 = x0 + alpha*d; g1 = feval(gfun,x1); if(norm(g1) < epsilon), break; end % 共轭方向更新 if mod(k,n) == 0 beta = 0; else beta = (g1'*g1)/(g0'*g0); % FR公式 end d = -g1 + beta*d; g0 = g1; x0 = x1; k = k + 1; end x = x1; val = feval(fun,x); end

这里有几个关键点:1)用了黄金分割法做精确线搜索(需要自己实现);2)每n步重置搜索方向,防止累积误差;3)beta计算采用Fletcher-Reeves公式。特别是方向更新那句d = -g1 + beta*d,这行代码堪称魔法——把梯度方向和前一步方向做线性组合,强行制造共轭性,相当于给优化路径加了惯性导航。

共轭梯度法无约束最优化程序 共轭梯度法、梯度下降法求解无约束最优化问题的MATLAB程序,买家可通过修改程序中的fun1目标函数和gfun1目标函数的梯度函数求解自己的无约束最优化问题。

举个栗子,对于目标函数f = @(x) x(1)^2 + 2x(2)^2,梯度函数g = @(x) [2x(1);4*x(2)],初始点取[10,10]时:

梯度下降需要迭代23次达到精度1e-5,而共轭梯度法仅需2次(二维二次函数理论上应该两步收敛)。实际跑起来能看到梯度下降的路径像喝醉似的走之字形,共轭梯度则直插目标点。

改用自己的目标函数时要注意:

  1. fun1必须返回标量值
  2. gfun1的梯度维度必须与x一致
  3. 非凸函数可能需要调大maxk
  4. 强烈建议先数值验证梯度正确性(可以用central difference)

最后给个调试小技巧:在循环里加个fprintf('k=%d, x=[%.4f,%.4f], fval=%.6f\n',k,x0(1),x0(2),feval(fun,x0));,看着数值怎么跳动的,比干瞪眼强多了。优化嘛,本质就是让函数值在参数空间里跳广场舞,咱们的任务就是帮它找最短路径。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/2/26 10:47:41

Redmi AX6 TTL 救砖记录

仅做一次记录,可能会有不理解和错误的地方 背景 刷过不死Uboot ImmortalWrt, 想刷回原厂固件,试图刷原厂分区因操作分区表不当成普砖.砖度判断:引用恩山 一台刷砖的AX6&#xff0c;先判定是普通砖还是深度砖&#xff0c;普通砖TTL可救&#xff0c;深度砖编程器才能救&#xff…

作者头像 李华
网站建设 2026/2/13 21:39:23

2026年,“配置工程师“终于死绝了

昨晚看 GitHub Trending&#xff0c;有个项目让我心里咯噔一下。 不是什么惊天动地的 AI 模型&#xff0c;而是一个叫做 Zero-Config-World 的脚手架。简介只有一行字&#xff1a;“For those who want to build products, not pipelines.” &#xff08;献给那些想做产品&…

作者头像 李华
网站建设 2026/2/24 1:31:47

机器学习中的熵

摘要&#xff1a;本文探讨了熵在机器学习中的应用&#xff0c;重点介绍了其在决策树算法中的作用。熵用于衡量数据集的纯度或随机性&#xff0c;通过香农熵公式计算。决策树利用熵选择最优分割点&#xff0c;以生成同质性更强的子集。文章还提供了Python实现示例&#xff0c;使…

作者头像 李华
网站建设 2026/2/26 10:05:46

ELISpot Plus:Mouse IL-4 (ALP)--简洁高效,节省时间

在免疫学研究中&#xff0c;细胞因子的检测对于理解免疫应答机制、评估疫苗效果以及探索疾病机制至关重要。其中&#xff0c;IL-4作为一种重要的Th2型细胞因子&#xff0c;在过敏反应、自身免疫性疾病和抗寄生虫免疫中扮演着关键角色。为了更准确地检测小鼠体内的IL-4水平&…

作者头像 李华