【matlab】一维搜索Fibonacci法和黄金分割法

一维搜索 Fibonacci法和黄金分割法

Fibonacci法

// Fibonacci
function [k,x,result]=fibonacci(f,interval,delta)   %k为迭代次数
a=interval(1);
b=interval(2);
F=[1 1];      %斐波那契数列数列的第一项和第二项
n=3;
while F(end)<(b-a)/delta    %产生斐波那契数列
    F(n)=F(n-1)+F(n-2);    
    n=n+1;
end
n=n-1;  %产生斐波那契数列的时候末尾多加了一个1,此处要减去一个1
x1=a+(F(n-2)/F(n))*(b-a);
x2=a+(F(n-1)/F(n))*(b-a);
f1=f(x1);
f2=f(x2);
k=0;
while n>3 
     k=k+1;
     n=n-1;
    if f1>f2
        a=x1;
        x1=x2;
        f1=f2;
        x2=a+(F(n-1)/F(n))*(b-a);
        f2=f(x2);
    elseif f1==f2
        a=x1;
        b=x2;
        x1=a+(F(n-2)/F(n))*(b-a);
        x2=a+(F(n-1)/F(n))*(b-a);
    else
        b=x2;
        x2=x1;
        f2=f1;
        x1=a+(F(n-2)/F(n))*(b-a);
        f1=f(x1);
    end
end
x=(a+b)/2;     %取最终区间的中点为极小值点
result=f(x);
end

黄金分割法

// 黄金分割法
function [k,x,result]=golden(f,interval,delta)
%k为迭代次数
%x为极小值的近似解,result为极值的近似解
%给定函数f,区间interval,误差delta
a=interval(1);
b=interval(2);
x1=a+0.382*(b-a);   
x2=a+0.618*(b-a);
f1=f(x1);
f2=f(x2);
k=0; %迭代初值
%迭代,分三种情况
while (b-a)>delta    %迭代条件
    k=k+1;
    if f1>f2
        a=x1;
        x1=x2;
        x2=a+0.618*(b-a);
        f1=f2;
        f2=f(x2);
    elseif f1==f2
        a=x1;
        b=x2;
        x1=a+0.382*(b-a);
        x2=a+0.618*(b-a);
        f1=f(x1);
        f2=f(x2);
    else
        b=x2;
        x2=x1;
        x1=a+0.382*(b-a);
        f2=f1;
        f1=f(x1);
    end
end
x=(b+a)/2;
result=f(x);
end
// 运行程序
clc
clear
f=@(x) x.^2-x+2;  %定义一个匿名函数
f1=@(x) 2*x-1;   %定义一个匿名函数,为f的导函数
x1=vpa(solve(f1),5); %求极值点
[k,x,result]=golden(f,[-1 3],1e-9)
tol=x-double(x1(1))   %求误差
  • 4
    点赞
  • 45
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值