用MATLAB的迭代法求解x^3-x-1=0在x0=1.5附近的一个根?
2个回答
2013-12-29
展开全部
%牛顿迭代法 解方程y=x.^3-x-1
x=1.5;
format long;
x1=x-func1_1(x)/func1_1_1(x);
if(abs(x1)<1.5)
delt=abs(x1-x);
else
delt=abs((x1-x)/x1);
end
while(delt>1e-6|abs(func1_1(x))>1e-6)
x=x1; x1=x-func1_1(x)/func1_1_1(x);
if(abs(x1)<1.5)
delt=abs(x1-x);
else
delt=abs((x1-x)/x1);
end
if func1_1(x1)==0
break
end
end
disp('解方程y=x.^3-x-1,牛顿迭代法结果')
x1
编辑函数
function y=func1_1(x)
y=x.^3-x-1;
function y=func1_1_1(x)
y=3*x.^2-1
% 对分法
delta=10e-5;
a=1;
b=2;
fa=func2_1(a);
fb=func2_1(b);
n=1;
while(1)
if(fa*fb>0)
break;
end
x=(a+b)/2;
fx=func2_1(x);
if(abs(fx)<delta)
break;
elseif(fa*fx<0)
b=x;fb=fx;
else
a=x;fa=fx;
end
if(b-a<eps)
break;
end
n=n+1;
end
disp('对分法结果');
x
% 调用roots函数求解结果并作图
x=linspace(-5,5);
y=x.^2-x-1;
plot(x,y)
p=[1 -1 -1];
disp('调用roots函数求解')
x=roots(p)
编辑函数
function y=func2_1(x)
y=x.^2-x-1;
function y=func2_1_1(x)
y=2*x-1
x=1.5;
format long;
x1=x-func1_1(x)/func1_1_1(x);
if(abs(x1)<1.5)
delt=abs(x1-x);
else
delt=abs((x1-x)/x1);
end
while(delt>1e-6|abs(func1_1(x))>1e-6)
x=x1; x1=x-func1_1(x)/func1_1_1(x);
if(abs(x1)<1.5)
delt=abs(x1-x);
else
delt=abs((x1-x)/x1);
end
if func1_1(x1)==0
break
end
end
disp('解方程y=x.^3-x-1,牛顿迭代法结果')
x1
编辑函数
function y=func1_1(x)
y=x.^3-x-1;
function y=func1_1_1(x)
y=3*x.^2-1
% 对分法
delta=10e-5;
a=1;
b=2;
fa=func2_1(a);
fb=func2_1(b);
n=1;
while(1)
if(fa*fb>0)
break;
end
x=(a+b)/2;
fx=func2_1(x);
if(abs(fx)<delta)
break;
elseif(fa*fx<0)
b=x;fb=fx;
else
a=x;fa=fx;
end
if(b-a<eps)
break;
end
n=n+1;
end
disp('对分法结果');
x
% 调用roots函数求解结果并作图
x=linspace(-5,5);
y=x.^2-x-1;
plot(x,y)
p=[1 -1 -1];
disp('调用roots函数求解')
x=roots(p)
编辑函数
function y=func2_1(x)
y=x.^2-x-1;
function y=func2_1_1(x)
y=2*x-1
Sievers分析仪
2024-10-13 广告
2024-10-13 广告
是的。传统上,对于符合要求的内毒素检测,最终用户必须从标准内毒素库存瓶中构建至少一式两份三点标准曲线;必须有重复的阴性控制;每个样品和PPC必须一式两份。有了Sievers Eclipse内毒素检测仪,这些步骤可以通过使用预嵌入的内毒素标准...
点击进入详情页
本回答由Sievers分析仪提供
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询
广告 您可能关注的内容 |