首页 > 其他分享 >matlab实验3

matlab实验3

时间:2024-06-19 22:00:10浏览次数:12  
标签:迭代 val 梯度 实验 matlab x0 共轭

一、实验目的

掌握共轭梯度法的基本思想及其迭代步骤;学会运用MATLAB编程实现常用优化算法;能够正确处理实验数据和分析实验结果及调试程序。

二、实验内容

 (1)求解无约束优化问题:min f(x)=100(x1^2-x2)^2+(x1-1)^2,x∈R;

(2)终止准则取||f(x^k)||<=10^-5,搜索方法采用非精确搜索Armijo;

(3)完成FR共轭梯度法的MATLAB编程、调试;

(4)选取几个与实验二实验三中相同的初始点,并给出相关实验结果的对比及分析(从最优解、最优值、收敛速度(迭代次数)等方面进行比较);

function[x,val,k]=frcg(fun,gfun,x0)
%功能:用FR共轭梯度法求解无约束问题:minf(x)
%输入:x0是初始点,fun,gfun分别是目标函数和梯度
%输出:x,val分别是近似最优点和最优值,k是迭代次数.
maxk=5000;
%最大迭代次数
rho=0.6;sigma=0.4;
k=0;
epsilon=1e-4;
n=length(x0);
while(k<maxk)
    g=feval(gfun,x0);
    %计算梯度
    itern=k-(n+1)*floor(k/(n+1));
    itern=itern+1;
    %计算搜索方向
    if(itern==1)
        d=-g;
    else
        beta=(g'*g)/(g0'*g0);
        d=-g+beta*d0;
        gd=g'*d;
        if(gd>=0.0)
            d=-g;
        end
    end
    if(norm(g)<epsilon),break;end
    %检验终止条件
    m=0;mk=0;
    while(m<20)
        %Armijo搜索
        if(feval(fun,x0+rho^m*d)<feval(fun,x0)+sigma*rho^m*g'*d)
            mk=m;break;
        end
        m=m+1;
    end
    x0=x0+rho^mk*d;
    val=feval(fun,x0);
    g0=g;
    d0=d;
    k=k+1;
end
x=x0;
val=feval(fun,x);

结果

>> Untitled14
x =
    0.9999
    0.9999
val =
   2.9396e-09
k =
    44

标签:迭代,val,梯度,实验,matlab,x0,共轭
From: https://www.cnblogs.com/bdsz/p/18257520

相关文章

  • matlab实验4
    一、实验目的掌握共轭梯度法的基本思想及其迭代步骤;学会运用MATLAB编程实现常用优化算法;能够正确处理实验数据和分析实验结果及调试程序。二、实验内容 (1)求解无约束优化问题:minf(x)=100(x1^2-x2)^2+(x1-1)^2,x∈R;(2)终止准则取||f(x^k)||<=10^-5,搜索方法采用非精确搜索Armijo;......
  • 基于Python+Django的高校实验室管理系统设计与实现(源码+数据库+讲解)
    文章目录前言详细视频演示项目运行截图技术框架后端采用Django框架前端框架Vue可行性分析系统测试系统测试的目的系统功能测试数据库表设计代码参考数据库脚本为什么选择我?获取源码前言......
  • 实验7
    task4#include<stdio.h>intmain(){inti=0;charch;FILE*fp;fp=fopen("data4.txt","r");if(fp==NULL){printf("failtoopenfile\n");return0;}while((ch=fgetc(f......
  • 数据库实验2
    一、实验目的:掌握使用SQL语言进行各种查询的操作和视图的操纵方法。二、实验要求:在现有的数据库上进行各种查询操作,对视图的创建、使用等操作。三、实验步骤:1、开始→程序→MicrosoftSQLServer→SQLServerManagementStudio。2、在“连接到服务器”对话框中,选择“Wi......
  • matlab实验
    一、实验目的掌握Hesse矩阵的计算方法和Newton法的基本思想及其迭代步骤;学会运用MATLAB编程实现常用优化算法;正确处理实验数据和分析实验结果及调试程序。二、实验内容(1)求解无约束优化问题(3)完成Newton法(牛顿法)的MATLAB编程、调试;(4)选取几个与实验二中相同的初始点,并给出相关实......
  • matlab最优化工具箱
    一、实验目的(一)通过一个农业生产计划优化安排的实例求解,培养学生解决实际线性规划问题的初步能力;熟悉线性规划的建模过程;掌握Matlab优化工具箱中线性规划函数的调用。二、实验内容(一)某村计划在100公顷的土地上种植a、b、c三种农作物。可以提供的劳力、粪肥和化肥等资源的数量,种......
  • web实验3
    三、实验步骤1)   打开MySQL,新建一个数据库。2)   新建一个数据库表。3)   在表中增加若干记录,作为初始数据。4)   打开Eclipse软件,新建一个名为Lab04的Web项目,并设置其部署程序为Tomcat。5)   在Lab04中添加文件,编写代码。6)   DBBean.java文件代......
  • 数据库实验1
    掌握使用SQL语言进行各种查询的操作和视图的操纵方法。二、实验要求:在现有的数据库上进行各种查询操作,对视图的创建、使用等操作。三、实验步骤:1、开始→程序→MicrosoftSQLServer→SQLServerManagementStudio。2、在“连接到服务器”对话框中,选择“Windows身份验......
  • 区间预测 | Matlab实现的集成双向长短期记忆网络自适应带宽核密度BiLSTM-Adaboost-ABK
    %设置参数numLSTM=3;%LSTM模型数量numBoost=5;%Adaboost迭代次数%加载数据load(‘data.mat’);%替换为您的数据文件%数据预处理%…%初始化LSTM模型lstmModels=cell(numLSTM,1);fori=1:numLSTMlstmModels{i}=trainLSTMModel(data);%使用......
  • web实验1
    1)编写index.jsp文件,展示某一类物品或知识的介绍,可以是歌曲、人物、名胜古迹等。要求至少有三个条目,用户登录后才能浏览这三个条目的内容。如果用户尚未登录,需要显示用户为“游客”,否则显示用户名。页面下端设置超链接,指向login.jsp。如果用户尚未登录,单击了某一条目的内容,则系统......