Calculating integral but weird result :S

5 ビュー (過去 30 日間)
Serhat
Serhat 2013 年 1 月 30 日
Hi,
I am trying to calculate this integral.
sigmaZ= -0.1464*eye(4);
f = @(x)(arrayfun(@(x)(1./(det(sigmaZ./sin(x).^2 + eye(4)))),x))
out = (1/pi)*quad(f,0,pi)
but it gives this result 3e+10. It must not have been that high. Is my integral wrong?
Thanks:)

採用された回答

Teja Muppirala
Teja Muppirala 2013 年 1 月 30 日
When sigmaZ is negative, the integrand blows up around x = 0.3 and x = 2.7 and you have a singularity which you cannot integrate.
For example, just plot it:
sigmaZ= -0.1464*eye(4);
f = @(x)(arrayfun(@(x)(1./(det(sigmaZ./sin(x).^2 + eye(4)))),x))
ezplot(f)
When sigmaZ is positive, the integrand is always finite for x in [0 pi] and so you don't get any problem.
  1 件のコメント
Serhat
Serhat 2013 年 1 月 30 日
Hımm, Isee. Then the problem is sigmaZ. Thanks for help:)

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

その他の回答 (1 件)

Jan
Jan 2013 年 1 月 30 日
Is there any chance that we can guess what you want to calculate?
  1 件のコメント
Jan
Jan 2013 年 1 月 30 日
編集済み: Jan 2013 年 1 月 30 日
@Serhat: All you have shown us is the code and you explain, that it could be wrong. But we cannot suggest an improvement, when you do not explain, which equation this code should solve. And if this is still not clear, a simplified version:
I have c = a + b, where a is 2 and b is 3. I get the result 5, but I want 6. Where is the error?
Without a magic crystal ball it is impossible to find an answer.

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

カテゴリ

Help Center および File ExchangeCommunications Toolbox についてさらに検索

Community Treasure Hunt

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

Start Hunting!

Translated by