1.3月19日学习进度2.第一次结对作业3月27日开发进度3.第一次结对作业4月11日开发进度4.4月18日冲刺记录5.4月19日学习进度6.4月19日冲刺记录7.4月20日学习进度8.4月20日冲刺记录9.4月21日冲刺记录10.第一次结对作业4月10日开发进度11.4月23日学习进度12.4月23日冲刺记录13.4月22日冲刺记录14.4月25日冲刺记录15.4月26日冲刺记录16.4月27日学习记录17.4月28日学习记录18.4月24日冲刺记录19.4月22日学习进度20.4月30日学习进度21.5月6日学习进度22.5月8日学习进度23.5月10日学习进度24.6月4日学习进度25.5月11日学习进度26.5月12日学习进度27.5月13日学习进度28.5月15日学习进度29.5月16日学习进度30.5月17日学习进度31.5月18日学习进度32.5月19日学习进度33.5月20日学习进度
34.5月21日学习进度
35.5月22日学习进度36.5月23日学习进度37.5月24日学习进度38.5月25日学习进度39.5月26日学习进度40.5月27日学习进度41.5月28日学习进度42.5月29日学习进度43.5月30日学习进度44.5月31日学习进度45.6月1日学习进度46.6月2日学习进度47.6月3日学习进度48.6月5日学习进度49.6月6日学习进度50.6月7日学习进度51.6月11日学习进度52.6月12日学习进度(个人总结)53.6月14日学习进度54.6月17日学习进度55.人月神话读后感156.人月神话读后感257.人月神话读后感3一.所花时间
0.5h
二.代码量
30行
三.博客量
1篇
四.了解到的知识点
实验二:最速下降法程序设计
一、实验目的
通过最速下降法的程序设计,为今后的约束优化方法的学习和编程奠定基础;掌握负梯度方向的定义和最速下降法的迭代公式 ;通过此次实验,进一步巩固最速下降法的基本原理和思想。
二、实验内容
(1)求解无约束优化问题: ;
(2)终止准则取 ;
(3)完成最速下降法(负梯度法)的MATLAB编程、调试;
(4)要求选取多个不同的初始点,并给出迭代次数,最优函数值等相关信息,有能力的同学尝试画出最优值随迭代次数变化的曲线图;
(5)按照模板撰写实验报告,要求规范整洁。
三、算法步骤、代码、及结果
1. 算法步骤
(1)给出初始点x 0,置iter=0,最大迭代次数max_iter=10000,精度e=1e-6,目标 函数f及其梯度grad
(2)若终止条件满足(| | f | | < e),则迭代停止
(3)计算d k = −grad
(4)在d k方向上利用一维精确线性搜索Amrijo搜索求步长ak
(5)x k + 1 = x k + α k d k , k = k + 1,转步骤2
2.代码
function f=fun(x)
f= (x(1)+10*x(2))^2+5*(x(3)-x(4))^2+(x(2)-2*x(3))^4+10*(x(1)-x(4))^4;
function gf=gfun(x)
gf = [2*(x(1)+10*x(2))+40*(x(1)-x(4))^3; 20*(10*x(2)+x(1))+4*(x(2)-2*x(3))^3; 10*(x(3)-x(4))-8*(x(2)-2*x(3))^3; -10*(x(3)-x(4))-40*(x(1)-x(4))^3];
function [k,x,val] = grad(fun,gfun,x0_list,epsilon)
%功能:用最速下降法求解无约束优化问题
%输入:funf,gfun分别是目标函数和梯度,x0是初始点,epsilon是容许误差
%输出:x,val分别是近似最优解和最优值,k是迭代次数
maxk=10000; %最大迭代次数
value = zeros(maxk, 1);
for i = 1:length(x0_list)-1
x0 = x0_list(:,i);
beta=0.5; sigma=0.4;
k=0;
fprintf('初始点 (%g; %g; %g; %g)\n', x0(1), x0(2), x0(3), x0(4));
while(k<maxk)
gk=feval(gfun,x0); %计算梯度
dk=-gk;
if(norm(gk)<epsilon), break; end %检验终止准则
m=0; mk=0;
%用Amrijo搜索技术确定步长
while(m<20) %最大迭代次数
if(feval(fun,x0+beta^m*dk)<=feval(fun,x0)+sigma*beta^m*gk'*dk)
mk=m; break;
end
m=m+1;
end
x0=x0+beta^mk*dk;
k=k+1;
value(k,1)=feval(fun,x0);
end
x=x0;
val=feval(fun,x0);
fprintf('迭代次数: %d\n', k);
fprintf('最优点: (%g; %g; %g; %g)\n', x(1), x(2), x(3), x(4));
fprintf('最优函数值: %g\n', val);
fprintf('\n');
% 迭代曲线图
figure;
plot(value);
title('迭代曲线');
xlabel('迭代次数');
ylabel('最优值');
end
% 命令行输入
% x0=[-1,-2,3; 1,7,10; 3,-4,5; 3,6,4];
% grad('fun','gfun',x0,1e-6);
3.结果
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 零经验选手,Compose 一天开发一款小游戏!
· 因为Apifox不支持离线,我果断选择了Apipost!
· 通过 API 将Deepseek响应流式内容输出到前端
2023-05-21 每日打卡-28