《重积分计算方法》word版

《重积分计算方法》word版

ID:29934244

大小:59.85 KB

页数:5页

时间:2018-12-25

《重积分计算方法》word版_第1页
《重积分计算方法》word版_第2页
《重积分计算方法》word版_第3页
《重积分计算方法》word版_第4页
《重积分计算方法》word版_第5页
资源描述:

《《重积分计算方法》word版》由会员上传分享,免费在线阅读,更多相关内容在应用文档-天天文库

1、这里讨论的计算方法指的是利用现有的MATLAB函数来求解,而不是根据具体的数值计算方法来编写相应程序。目前最新版的2009a有关于一般区域二重积分的计算函数quad2d(详细介绍见http://forum.simwe.com/viewthread.php?tid=873479),但没有一般区域三重积分的计算函数,而NIT工具箱似乎也没有一般区域三重积分的计算函数。本贴的目的是介绍一种在7.X版本MATLAB(不一定是2009a)里求解一般区域二重三重积分的思路方法。需要说明的是,上述链接里已经讨论了一种求解一般区域二重三重积分的思路方法,就是将被积函数“延拓”到矩形或者长方体区域,

2、但是这种方法不可避免引入很多乘0运算浪费时间。因此,新的思路将避免这些。由于是调用已有的MATLAB函数求解,在求一般区域二重积分时,效率和2009a的quad2d相比有一些差距,但是相对于"延拓"函数的做法,效率大大提高了。下面结合一些简单例子说明下计算方法。譬如二元函数f(x,y)=x*y,y从sin(x)积分到cos(x),x从1积分到2,这个积分可以很容易用符号积分算出结果1.symsxy2.int(int(x*y,y,sin(x),cos(x)),1,2)]3.结果是-1/2*cos(1)*sin(1)-1/4*cos(1)^2+cos(2)*sin(2)+1/4*cos

3、(2)^2=-0.635412702399943复制代码如果你用的是2009a,你可以用1.quad2d(@(x,y)x.*y,1,2,@(x)sin(x),@(x)cos(x),'AbsTol',1e-12)复制代码得到上述结果。如果用的不是2009a,那么你可以利用NIT工具箱里的quad2dggen函数。那么我们如果既没有NIT工具箱用的也不是2009a,怎么办呢?答案是我们可以利用两次quadl函数,注意到quadl函数要求积分表达式必须写成向量化形式,所以我们构造的函数必须能接受向量输入。见如下代码1.functionIntDemo2.functionf1=myfun1(

4、x)3.f1=zeros(size(x));4.fork=1:length(x)5.f1(k)=quadl(@(y)x(k)*y,sin(x(k)),cos(x(k)));6.end7.end8.y=quadl(@myfun1,1,2)9.end复制代码myfun1函数就是构造的原始被积函数对y积分后的函数,这时候是关于x的函数,要能接受向量形式的x输入,所以构造这个函数的时候考虑到x是向量的情况。利用arrayfun函数(7.X后的版本都有这个函数,不了解这个函数的朋友可以查看帮助文档,或者搜索本版)可以将IntDemo函数精简成一句代码:1.quadl(@(x)arrayfun

5、(@(xx)quadl(@(y)xx*y,sin(xx),cos(xx)),x),1,2)复制代码上面这行代码体现了用MATLAB7.X求一般区域二重积分的一般方法。可以这么理解这句代码:首先1.@(x)arrayfun(@(xx)quadl(@(y)xx*y,sin(xx),cos(xx)),x)复制代码定义了一个关于x的匿名函数,供quadl调用求最外重(x从1到2的)积分,这时候,x对于1.arrayfun(@(xx)quadl(@(y)xx*y,sin(xx),cos(xx)),x)复制代码就是已知的了。而1.@(xx)quadl(@(y)xx*y,sin(xx),cos(

6、xx))复制代码定义的是对于给定的xx,求xx*y关于y的积分函数,这就相当于数学上积完第一重y的积分后得到一个关于xx的函数而1.arrayfun(@(xx)quadl(@(y)xx*y,sin(xx),cos(xx)),x)复制代码只是对1.@(xx)quadl(@(y)xx*y,sin(xx),cos(xx))复制代码加了一个循环的壳,保证“积完第一重y的积分后得到一个关于xx的函数”能够接受向量化的xx的输入,从而能够被quadl调用。有了这个模板,我们可以方便求其他一般积分区域(上下限是函数)形式的二重积分,例如被积函数f=@(x,y)exp(sin(x))*ln(y),

7、y从5*x积分到x^2,x从10积分到20。用quad2d,上面介绍的方法,还有dblquad帮助文档里给的延拓函数的方法1.tic,y1=quad2d(@(x,y)exp(sin(x)).*log(y),10,20,@(x)5*x,@(x)x.^2),toc2.tic,y2=quadl(@(x)arrayfun(@(x)quadl(@(y)exp(sin(x)).*log(y),5*x,x.^2),x),10,20),toc3.tic,y3=dblquad(@(x,

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。