matlab实现最速下降法(梯度)程序

上传人:第*** 文档编号:38805919 上传时间:2018-05-08 格式:DOC 页数:2 大小:30KB
返回 下载 相关 举报
matlab实现最速下降法(梯度)程序_第1页
第1页 / 共2页
matlab实现最速下降法(梯度)程序_第2页
第2页 / 共2页
亲,该文档总共2页,全部预览完了,如果喜欢就下载吧!
资源描述

《matlab实现最速下降法(梯度)程序》由会员分享,可在线阅读,更多相关《matlab实现最速下降法(梯度)程序(2页珍藏版)》请在金锄头文库上搜索。

1、matlabmatlab 最速下降法最速下降法 2010-08-18 17:13 function x=fsxsteep(f,e,a,b) % fsxsteep 函数 最速下降法 % x=fsxsteep(f,e,a,b)为输入函数 f 为函数 e 为允许误差 (a,b) 为初始点;% fsx TJPU 2008.6.15x1=a;x2=b; Q=fsxhesse(f,x1,x2); x0=x1 x2; fx1=diff(f,x1); %对 x1 求偏导数 fx2=diff(f,x2); %对 x2 求偏导数 g=fx1 fx2; %梯度 g1=subs(g); %把符号变量转为数值 d=-g

2、1; while (abs(norm(g1)=e) t=(-d)*d/(-d)*Q*d);t=(-d)*d/(-d)*Q*d); %求搜索方向 x0=x0-t*g1; %搜索到的点 v=x0; a=1 0*x0; b=0 1*x0; x1=a; x2=b; g1=subs(g); d=-g1; end; x=v;function x=fsxhesse(f,a,b) % fsxhesse 函数 求函数的 hesse 矩阵; % 本程序仅是简单的求二次函数的 hesse 矩阵!; % x=fsxhesse(f)为输入函数 f 为二次函数 x1,x2 为自变量;% fsx TJPU 2008.6.1

3、5x1=a;x2=b; fx=diff(f,x1); %求 f 对 x1 偏导数 fy=diff(f,x2); %求 f 对 x2 偏导数 fxx=diff(fx,x1); %求二阶偏导数 对 x1 再对 x1 fxy=diff(fx,x2); %求二阶偏导数 对 x1 再对 x2 fyx=diff(fy,x1); %求二阶偏导数 对 x2 再对 x1 fyy=diff(fy,x2); %求二阶偏导数 对 x2 再对 x2 fxx=subs(fxx); %将符号变量转化为数值 fxy=subs(fxy); fyx=subs(fyx); fyy=subs(fyy); x=fxx,fxy;fyx,fyy; %求 hesse 矩阵syms x1 x2; X=x1,x2; fx=X(1)2+2*X(2)2; z=fsxsteep(fx,0.001,1,1)

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 中学教育 > 教学课件 > 初中课件

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号