How to make integral of Hankel function at infinite?
Mostrar comentarios más antiguos
Hi guys,
I have a question on numerical integral of Hankel functions, need help from all you. Thank you in advance
How do we treat with integral of a function contains Hankel function from 0 to infinite? for example, function=x.besselh(1,0,x)?
statement "quad" not allow at infinite.
Respuestas (2)
Mike Hosea
el 25 de Sept. de 2012
0 votos
Use INTEGRAL. If you don't have R2012a or later, use QUADGK. If you don't have QUADGK, it's time to upgrade.
2 comentarios
tran
el 26 de Sept. de 2012
Mike Hosea
el 26 de Sept. de 2012
I didn't even think about the function you were integrating. I assumed it was integrable. I'm not saying QUADGK can handle any integrable problem, because there are some that it can't, but if you're going to try to integrate a function that oscillates with increasing amplitude as x increases, I don't think it matters what method you use.
Matt Fig
el 25 de Sept. de 2012
This one is easy. Because:
besselh(1,0,x) % Zero for all x.
we know the integral from 0 to inf is 0.
8 comentarios
tran
el 26 de Sept. de 2012
Walter Roberson
el 26 de Sept. de 2012
By converting to the equivalent BesselJ and BesselK functions and evaluating those, you get 1 + 0i
This is a difficult integral to evaluate numerically, as Mike noted. What you can do is approximate it because you know it converges. This takes a while to run, so be warned. For greater precision you will need to adjust the conditional on the WHILE loop:
f = @(x) besselh(0,1,x);
I = 0;
A = 1;
ii = 1;
while abs(A)>1e-3
A = quadgk(f,(ii-1)*20,ii*20); % integrate intervals and sum
I = I + A;
ii = ii + 1;
end
I end up with: I = 0.9991 - 0.0001i Which tends to confirm Walter's solution. You could also break the besselh into besselj and bessely then run two loops. This might be actually faster.
tran
el 26 de Sept. de 2012
Matt Fig
el 26 de Sept. de 2012
tran, I understand that the approach I showed above is limited. Are you listening to Mike's and my advice about the difficulty of integrating this particular function? Just because you can write something down does not mean that it is easy to calculate! I have offered a way to get something towards a solution of your problem. I assume something is better than nothing, which is what quadgk(f,0,inf) gives...
If you want to evaluate this integral numerically, feel free to find another approach. I don't know if another approach will work faster and/or be more accurate. If you find one, please let us know how you did it!
tran
el 27 de Sept. de 2012
Walter Roberson
el 27 de Sept. de 2012
Looks to me like the two component parts of besselh both oscillate infinitely often towards x=infinity, and it appears that although the oscillations decay that they do so much more slowly than x increases; this leads to the indeterminate (infinity times 0) + I * (infinity times 0) as the limit at infinity, which is undefined.
Categorías
Más información sobre Loops and Conditional Statements en Centro de ayuda y File Exchange.
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!