How can I avoid using for loop in this functions

This is the function whose speed I want to improve. I know I should use more matrix operation and use less for loop. But I have no idea how to use if-else in matrices.
function y=Besselj_approx(n,z)
y=zeros(1,length(n));
for i=n
if i>0
y(i)=1./gamma(i+1).*(z/2).^i;
elseif i<0
y(i)=(-1).^(-i)./gamma(-i+1).*(z/2).^(-i);
else
y(i)=-z.^2/4+1;
end
end
Any help is appreciated!

4 comentarios

Rik
Rik el 26 de Mzo. de 2023
Have you tried logical indexing?
Dyuman Joshi
Dyuman Joshi el 26 de Mzo. de 2023
Editada: Dyuman Joshi el 26 de Mzo. de 2023
Loops are quite efficient if used properly and the usage above looks good. Although you can club the 1st two conditions together -
if i~=0
k=abs(i);
y(i)=sign(i).^(k)./gamma(k+1).*(z/2).^k;
else
y(i)=-z.^2/4+1;
end
If you are dealing with floating point numbers, I would suggest you to use a tolerance to compare rather than equality.
As Rik mentions, logical indexing is another good option. If you can attach your data, we can run and test the code.
祥宇 崔
祥宇 崔 el 26 de Mzo. de 2023
@Dyuman Joshi Thanks! Guess the for loop is alright.
祥宇 崔
祥宇 崔 el 26 de Mzo. de 2023
@Rik Thanks! I will give it a try.

Iniciar sesión para comentar.

 Respuesta aceptada

KSSV
KSSV el 26 de Mzo. de 2023
function y=Besselj_approx(n,z)
i = n ;
y=zeros(1,length(n));
y(1:end)=-z.^2/4+1;
y(i>0) = 1./gamma(i(i>0)+1).*(z/2).^i(i>0);
y(i<0)=(-1).^(-i(i<0))./gamma(-i(i<0)+1).*(z/2).^(-i(i<0));

Más respuestas (0)

Categorías

Más información sobre Loops and Conditional Statements en Centro de ayuda y File Exchange.

Productos

Versión

R2020b

Preguntada:

el 26 de Mzo. de 2023

Comentada:

el 11 de Abr. de 2023

Community Treasure Hunt

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

Start Hunting!

Translated by