フィルターのクリア

How to fastly compute a double integral of a self-defined function?

1 回表示 (過去 30 日間)
Tmat
Tmat 2020 年 2 月 26 日
コメント済み: Tmat 2020 年 2 月 27 日
Hi everyone,
I need to compute , where is my self-defined function, M is infinity and in actual calculation I set it to be a large number and is the probability density function of standard bivariate normal. My code for a simple example looks as follows (here ):
clear;
tic
step=0.01;
grid=-100:step:100; lg=length(grid);
x=repmat(grid',1,lg);
y=repmat(grid,lg,1);
tempz=[x(:) y(:)];
z=tempz(:,1).*tempz(:,2);
fz=mvnpdf(tempz);
t=sum(z.*fz);
toc
This simple example already takes me 30 seconds on a computing node of our university. In the real application is much more complex and defined by a separate function file. I'm wondering if there are any more efficient ways of doing this?

採用された回答

Steven Lord
Steven Lord 2020 年 2 月 26 日
Use the integral2 function.
  5 件のコメント
Steven Lord
Steven Lord 2020 年 2 月 26 日
fh = @(x, y) reshape(mvnpdf([x(:), y(:)]), size(x));
integral2(fh, -Inf, Inf, -Inf, Inf)
fh combines the two coordinate vectors integral2 will pass into it into the coordinate matrix mvnpdf requires, evaluates the PDF, and uses reshape to make the PDF values vector the same shape as the input.
Tmat
Tmat 2020 年 2 月 27 日
Thanks a lot, Steven. This worked!

サインインしてコメントする。

その他の回答 (0 件)

カテゴリ

Help Center および File ExchangeNumerical Integration and Differentiation についてさらに検索

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by