matlab课后习题答案第四篇.doc

  1. 1、本文档共23页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
数值运算 习题 4 及解答 根据题给的模拟实际测量数据的一组和 试用数值差分diff或数值梯度gradient指令计算,然后把和曲线绘制在同一张图上,观察数值求导的后果。(模拟数据从prob_data401.mat获得) 〖目的〗 强调:要非常慎用数值导数计算。 练习mat数据文件中数据的获取。 实验数据求导的后果 把两条曲线绘制在同一图上的一种方法。 〖解答〗 (1)从数据文件获得数据的指令 假如prob_data401.mat文件在当前目录或搜索路径上 clear load prob_data401.mat (2)用diff求导的指令 dt=t(2)-t(1); yc=diff(y)/dt; %注意yc的长度将比y短1 plot(t,y,b,t(2:end),yc,r) grid on (3)用gradent求导的指令(图形与上相似) dt=t(2)-t(1); yc=gradient(y)/dt; plot(t,y,b,t,yc,r) grid on 〖说明〗 不到万不得已,不要进行数值求导。 假若一定要计算数值导数,自变量增量dt 要取得比原有数据相对误差高1、2个量级以上。 求导会使数据中原有的噪声放大。 采用数值计算方法,画出在区间曲线,并计算。 〖提示〗 指定区间内的积分函数可用cumtrapz指令给出。 在计算要求不太高的地方可用find指令算得。 〖目的〗 指定区间内的积分函数的数值计算法和cumtrapz指令。 find指令的应用。 〖解答〗 dt=1e-4; t=0:dt:10; t=t+(t==0)*eps; f=sin(t)./t; s=cumtrapz(f)*dt; plot(t,s,LineWidth,3) ii=find(t==4.5); s45=s(ii) s45 = 1.6541 求函数的数值积分,并请采用符号计算尝试复算。 〖提示〗 数值积分均可尝试。 符号积分的局限性。 〖目的〗 符号积分的局限性。 〖解答〗 dx=pi/2000; x=0:dx:pi; s=trapz(exp(sin(x).^3))*dx s = 5.1370 符号复算的尝试 syms x f=exp(sin(x)^3); ss=int(f,x,0,pi) Warning: Explicit integral could not be found. In sym.int at 58 ss = int(exp(sin(x)^3),x = 0 .. pi) 用quad求取的数值积分,并保证积分的绝对精度为。 〖目的〗 quadl,精度可控,计算较快。 近似积分指令trapz获得高精度积分的内存和时间代价较高。 〖解答〗 %精度可控的数值积分 fx=@(x)exp(-abs(x)).*abs(sin(x)); format long sq=quadl(fx,-10*pi,1.7*pi,1e-7) sq = 1.08784993815498 %近似积分算法 x=linspace(-10*pi,1.7*pi,1e7); dx=x(2)-x(1); st=trapz(exp(-abs(x)).*abs(sin(x)))*dx st = 1.08784949973430 %符号积分算法 y=exp(-abs(x))*abs(sin(x)) si=vpa(int(y,-10*pi,1.7*pi),16) y = exp(-abs(x))*abs(sin(x)) si = 1.087849499412911 求函数在区间中的最小值点。 〖目的〗 理解极值概念的邻域性。 如何求最小值。 学习运用作图法求极值或最小值。 感受符号法的局限性。 〖解答〗 (1)采用fminbnd找极小值点 在指令窗中多次运行以下指令,观察在不同数目子区间分割下,进行的极小值搜索。然后从一系列极小值点中,确定最小值点。 clear ft=@(t)sin(5*t).^2.*exp(0.06*t.*t)+1.8*abs(t+0.5)-1.5*t.*cos(2*t); disp(计算中,把[ -5,5] 分成若干搜索子区间。) N=input( 请输入子区间数 N,注意使N=1 ?);%该指令只能在指令窗中运行 tt=linspace(-5,5,N+1); for k=1:N [tmin(k),fobj(k)]=fminbnd(ft,tt(k),tt(k+1)); end [fobj,ii]=sort(fobj); %将目标值由小到大排列 tmin=tmin(ii); %使极小值点做与目标值相应的重新排列 fobj,tmin (2)最

文档评论(0)

xuefei111 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档