1实验内容:设xn1,给出两个算法,求x1023,写出MATLAB程序,并统计计算法
n计算量。若要计算量不超过20flop,应如何设计算法? 算法一 算法: 令t1程序: n=1023; t=1+1/n; t0=t; for i=1:10 t=t^2; end t=t/t0; disp(t); n12481024,依次计算t,t,t,,t,最后用t1024/t。 n界面:
计算量:12flop 算法二 算法:
直接计算t的1023次方。 程序:
n=1023; t=1+1/n; x=t^1023; disp(x); 界面:
计算量:1024flop
若要计算量不超过20flop,采用第一种算法较合适。 作业二 3-5 实验目的:应用不同迭代法求解代数方程
实验内容:分别采用二分法、Newton法、Newton下山法、割线法求解方程
600x4550x3200x220x10
4在[0.1,1]中的根;精确到10。 二分法
算法:
f(x)600x4550x3200x220x1为连续函数,且由题意可知[0.1,1]为含根区间,
令a=0.1,b=1,取p=(a+b)/2。若f(p)=0则p是方程f(x)=0的解;若f(a)f(p)<0则根在(a,p)内,取a1=a,b1=p;否则根在区间(p,b)内,取a1=p,b1=b。重复上述过程直到达到精度要求为止。 程序:
function y=f_3_5(x) y=600*x^4-550*x^3+200*x^2-20*x-1; function [p,k]=lab3_5_Bisection(max,a,b,e) for k=1:max p=(b+a)/2; if f_3_5(p)==0 || (b-a)/2 Newton法 算法: 建立牛顿迭代格式 f(pn)600pn4550pn3200pn220pn1 pn1pnpn32f(pn)600*4*pn550*3*pn400pn20直到|pn1pn|小于精度要求时迭代结束,将pn1作为结果输出。 程序: function y=f2_3_5(x) y=600*4*x^3-550*3*x^2+400*x-20; function [p,k]=lab3_5_Newton(max,p0,e) for k=1:max p=p0-f_3_5(p0)/f2_3_5(p0); if abs(p-p0) 建立迭代格式 f(pn)600pn4550pn3200pn220pn1 pn1pnpn32f(pn)600*4*pn550*3*pn400pn20其中是下山因子,在每步迭代中依次取1,1/2,1/4,…直到满足精度要求。 程序: function [p,k]=lab3_5_Newton2(max,p0,tol,e) for k=1:max y=1; p=p0-y*f_3_5(p0)/f2_3_5(p0); while (abs(f_3_5(p))>=abs(f_3_5(p0)) & y>e) y=y/2; p=p0-y*f_3_5(p0)/f2_3_5(p0); end if abs(p-p0) 建立迭代格式 pn1pnpnpn1f(pn) f(pn)f(pn1)直到|pn1pn|小于精度要求时迭代结束,将pn1作为结果输出。 程序: function [p,k]=lab3_5_Secant(max,a,b,e) for k=1:max p=b-f_3_5(b)*(b-a)/(f_3_5(b)-f_3_5(a)); if abs(p-b) 实验内容:用MATLAB编程做Doolittle分解,求解方程组。 1.3x1x2x32.4x43.4x54.22.4xxx1.4x3.7x6.3123452x1x22x33.6x46.8x55.5 2.5xx4x3x6.6x3.6123451.5x1x2x35.3x42.8x56.2112.43.4111.43.7123.66.8进行Doolittle分解使得ALU,则线性方程组 1436.6115.32.8算法: 1.32.4对A22.51.5Lyb的求解。Doolittle分解过程为: Axb的求解问题就转化为对三角形方程组Uxy u1jaij,j1,2,,n li1ai1/u11,i2,3,,n uijaijlikukj,ij k1i1 lij(aijlikukj)/ujj,ij k1j1然后依次求解Lyb和Uxy: y1b1i1 ybly,i2,3,,niijjij1xnyn/unnn x(yux)/u,in1,n2,,1ijjiiiiji1function [L,U,x]=lab4_2(a,b) n=length(a); L=eye(n); U(1,:)=a(1,:); for k=2:n if U(k-1,k-1)==0 disp('·Ö½âʧ°Ü'); 程序: return; end L(k:n,k-1)=a(k:n,k-1)/U(k-1,k-1); U(k,k:n)=a(k,k:n)-L(k,1:k-1)*U(1:k-1,k:n); if k 10x1x2x36.2x1+10x22x38.5 2xx+5x3.2123算法: 对k1,2,,n1 (k1)(k1)mikaik/akk(k)(k1)(k1)aijaijmikakj,i,jk1,k2,,n (k)(k1)mikbk(k1)bibi 公式中aijaij,bi(0)(0)bi,i,j1,2,,n。 利用回代法求解得方程组的解为 (n1)(n1)xnbn/annn (k1)(k1)(k1)x(bax)/a,kn1,n2,,1kjjkkkkjk1 程序: function x=lab4_Gauss(b) n=size(b,1); for k=1:n-1 if(b(k,k)==0) disp('¸ß˹˳ÐòÏûÔª·¨Ê§°Ü'); return end for i=k+1:n m=b(i,k)/b(k,k); b(i,k:n+1)=b(i,k:n+1)-m*b(k,k:n+1); end end x=zeros(n,1); x(n)=b(n,n+1)/b(n,n); for i=n-1:-1:1 x(i)=(b(i,n+1)-b(i,i+1:n)*x(i+1:n))/b(i,i); end 界面: 作业五 编写Jacobi迭代法和Seidel迭代法求解上述方程组的程序,并计算出结果。 算法: Jacobi迭代格式为 (k)(k)x1(k1)0.1x20.1x30.62(k1)(k)(k)x20.1x10.2x30.85 (k1)(k)(k)x0.4x0.2x0.112 Seidel迭代格式为 (k)(k)x1(k1)0.1x20.1x30.62(k1)(k1)(k)x20.1x10.2x30.85 (k1)(k1)(k1)x0.4x0.2x0.121 程序: Jacobi迭代法 function [x,k]=lab5_Jacobi(a,b,x0,e,N) x=x0; n=length(x); k=1; while k<=N for i=1:n x(i)=(b(i)-a(i,:)*x0)/a(i,i)+x0(i); end if norm(x-x0) 因篇幅问题不能全部显示,请点此查看更多更全内容
Copyright © 2019- nryq.cn 版权所有 赣ICP备2024042798号-6
违法及侵权请联系:TEL:199 1889 7713 E-MAIL:2724546146@qq.com
本站由北京市万商天勤律师事务所王兴未律师提供法律服务