⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 hypot.m

📁 抛物线法求解 方程的构造方法:给出[0,1]区间上的随机数(服从均匀分布)作为方程的根p*. 设你的班级数为a3,学号的后两位数分别为a2与a1,从而得到你的三次方程 例如:你的31班的1
💻 M
字号:
syms ii 
for ii=1:20;
clear x y s e Y X w c p t;
r=vpa(rand(1,1),16)
syms x y s e Y X w c p t;
a3=10;a2=1;a1=9;a0=-a3*r^3-10*(a2+1)*r^2-a1*r;
f1=a3*x^3+10*(a2+1)*x^2+a1*x+a0;
f2=a3*y^3+10*(a2+1)*y^2+a1*y+a0;
hypoth=x-f1*(x-y)/(f1-f2);
s(1)=0,s(2)=1 ;
for n=2:20;
    s(n)=vpa(s(n),16)
    s(n+1)=subs(hypoth,{x,y},{s(n),s(n-1)});
    a=vpa((abs(s(n+1)-s(n))),16)
    e(n-1)=vpa((s(n)-r),16);
    e(n)=vpa((s(n+1)-r),16);
 
    if (subs(abs(e(n)))<10^(-16))
      break
    end;
    
    X(n-1)=log(abs(e(n-1)));
    Y(n-1)=log(abs(e(n)));
    
    w(n-1)=(n-1)^2;
    v00(n-1)=w(n-1);
    v10(n-1)=w(n-1)*X(n-1);
    v11(n-1)=w(n-1)*(X(n-1)^2);
    v02(n-1)=w(n-1)*Y(n-1);
    v12(n-1)=w(n-1)*X(n-1)*Y(n-1);
   
    if (subs(a)<10^(-16))
        
        break
    end;
end
    d00=sum(v00);
    d10=sum(v10);
    d11=sum(v11);
    d02=sum(v02);
    d12=sum(v12);
    q1=d00*c+d10*p-d02;
    q2=d10*c+d11*p-d12;
    S=solve(q1,q2,c,p);
    S.c;
    S.p;
    t=S.p;
T(ii)=t

end
sum(T)/20

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -