Info

이 질문은 마감되었습니다. 편집하거나 답변을 올리려면 질문을 다시 여십시오.

How to integrate a distribution function for a specific interval?

조회 수: 2 (최근 30일)
Nina
Nina 2017년 11월 6일
마감: Nina 2018년 4월 17일
I computed two distribution function:
[distribution_1,x]=ecdf(X); Distribution_2= f(distribution_1);
Now I want to integrate Distribution_2 over the interval [a,b] and tried to use q = integral(fun,xmin,xmax) but I have trouble creating the function handle "fun" in my specific case (since I cannot create the connection to x?)
Thankful for any advice!
  댓글 수: 5
Nina
Nina 2017년 11월 6일
Distribution_2 is also a CDF :-/
Nina
Nina 2017년 11월 6일
Concerning the distortion function f: Distribution_2=1-(1-distribution_1.^(1/(1+g))).^(1+h) eg. with g=0.1 and h=0.2

채택된 답변

Robert
Robert 2017년 11월 6일
To make your empirical CDF into a function that integral can use, you should interpolate distribution_2. Because of the way the CDF is defined, I recommend you interpolate based on the previous value. The first value of x is a duplicate of the second, but for use with interp1(..., 'previous') it should be a (finite) number less than any you plan to use. -realmax should do the trick.
x(1) = -realmax;
f_dist2 = @(new_x) interp1(x, distribution_2, new_x, 'previous', 'extrap');
integral(f_dist2, -1, 1)
  댓글 수: 3
Nina
Nina 2017년 11월 7일
Thank you very much! This was exactly what I needed =)
Nina
Nina 2017년 11월 7일
Another problem came up for the code when using integral(f_dist2,0,inf). Do I need to take into account anything extraordinary in this infinity case? Would be very pleased to receive another answer :)
Below the warning I get when running the code: Warning: Reached the limit on the maximum number of intervals in use. Approximate bound on error is 1.7e-04. The integral may not exist, or it may be difficult to approximate numerically to the requested accuracy.

추가 답변 (1개)

David Goodmanson
David Goodmanson 2017년 11월 6일
편집: David Goodmanson 2017년 11월 6일
Hi Nina,
If this is not a misinterpretation of the problem, then it seems to work. I am assuming that the function ecdf is already on the Matlab path.
g = .1; h = .2;
fun = @(x) 1-(1-ecdf(x).^(1/(1+g))).^(1+h)
integral(@(x) fun(x), 2,3)
function a = ecdf(x) % for demo purposes
a = sin(x);
end
I'm curious about the idea of integrating a cdf, could you perhaps comment on that?
  댓글 수: 1
Nina
Nina 2017년 11월 7일
Hi David, thanks for your answer, your code would work if X=x, but this is not the case here: Interpolation can solve this problem as described by Robert below :)

Community Treasure Hunt

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

Start Hunting!

Translated by