matlab中用0.618法求minf(x)=e^(-x)+x^2在区间(0,1)上的极小值,精确到0.03.

帐号已注销
2021-10-22 · TA获得超过77万个赞
知道小有建树答主
回答量:4168
采纳率:93%
帮助的人:159万
展开全部

clc

clear all;

k=1;

a(k)=0;

b(k)=1;

%f1=(r(k)).^2-r(k);

f1 = exp(-r(k))+r(k).^2;

f2 = exp(-u(k))+u(k).^2;

%f2=(u(k)).^2-u(k);

a(k+1)=a(k);

b(k+1)=u(k);

u(k+1)=r(k);

r(k+1)=b(k+1)-tao*(b(k+1)-a(k+1));

x=(b(k+1)+a(k+1))/2;

end

k=k+1;

end

结果:

x = 0.3501

y = 0.8272

验证:

>> x1=0:0.001:1;

>> y1=exp(-x1)+x1.^2;

>> min(y1)

ans =

0.8272

>>

MATLAB

和Mathematica、Maple并称为三大数学软件。它在数学类科技应用软件中在数值计算方面首屈一指。行矩阵运算、绘制函数和数据、实现算法、创建用户界面、连接其他编程语言的程序等。MATLAB的基本数据单位是矩阵,它的指令表达式与数学、工程中常用的形式十分相似,故用MATLAB来解算问题要比用C,FORTRAN等语言完成相同的事情简捷得多。

jimtien
2011-05-16 · TA获得超过7652个赞
知道大有可为答主
回答量:2146
采纳率:88%
帮助的人:1090万
展开全部
clc
clear all;
elp=0.03;
tao=0.618;

N=fix(log(elp)/log(tao))+1;
k=1;
a(k)=0;
b(k)=1;
r(1)=b(k)-tao*(b(k)-a(k));
u(1)=a(k)+tao*(b(k)-a(k));
for i=1:N
%f1=(r(k)).^2-r(k);
f1 = exp(-r(k))+r(k).^2;
f2 = exp(-u(k))+u(k).^2;
%f2=(u(k)).^2-u(k);
if(f1>f2)
a(k+1)=r(k);
b(k+1)=b(k);
r(k+1)=u(k);
u(k+1)=a(k+1)+tao*(b(k+1)-a(k+1));
x=(b(k+1)+a(k+1))/2;
else
a(k+1)=a(k);
b(k+1)=u(k);
u(k+1)=r(k);
r(k+1)=b(k+1)-tao*(b(k+1)-a(k+1));
x=(b(k+1)+a(k+1))/2;
end
k=k+1;
end
x
y=exp(-x)+x.^2;
y
结果:
x = 0.3501
y = 0.8272

验证:
>> x1=0:0.001:1;
>> y1=exp(-x1)+x1.^2;
>> min(y1)
ans =
0.8272

>>
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式