INTEGARTION OF BESSELH function
Mostra commenti meno recenti
Hi
i make a code where i integrate the hankel function besselh(0, 2)
function z = Escat(r,phi)
[f,N,ra,k0,Z0] =parameter();
[Is]=currentMoM()
Phim=zeros(N+1);
FINAL=0;
for jj=1:N
%Phi0(jj)=(jj-1).*(pi./N);
Phi0(jj)=(jj-1).*(2.*pi./N);
FINAL=FINAL-(k0.*Z0./4).*Is(jj).*ra.*integral(@(xx)besselh(0,2,k0.*sqrt(ra.^2+r.^2-2.*r.*ra.*(phi-xx))),Phi0(jj),2*pi/N+Phi0(jj));
end
z=FINAL;
end
when i plot the function in the range φ=0 : 2π with r=const the valus of Escat are extremely big value ...
clear all
clc
[f,N,ra,k0,Z0] = parameter();
%ph_i=pi/2;
rho=10.*ra ;
phi=0:pi/180:2*pi;
Es=zeros(length(phi));
%phi=0:pi/200:pi/3
for jj=1:length(phi)
Es(jj)=abs(Escat(rho,phi(jj)));
end
plot(phi*(180./pi),Es,'b--')
hold on
%plot(phi*(180./pi),abs(integ),'b--')
plot(phi,abs(Escattheory_new(rho,phi)),'r-')
xlabel('$\phi$','Interpreter','latex')
ylabel('$|E_{s}|$','Interpreter','latex' )
%legend('MoM', 'Theory')
hold off
can i check if the the integration is ok ?
the parameter fucntion is
function [f,N,ra,k0,Z0] = parameter()
%UNTITLED Summary of this function goes here
c0=3e8;
Z0=120.*pi;
ra=1;
N=80;
f=300e6;
lambda=c0./f;
k0=2*pi./lambda;
end
thank you
6 Commenti
Steven Lord
il 19 Nov 2024
You haven't provided two of the functions used by your code: currentMoM and Escattheory_new.
You wrote "the valus of Escat are extremely bih value ..." -- I assume that's a typo and you meant to say "big value". How big is "extremely big" and how big were you expecting the values to be? Why did you expect the values to be so different from the values you actually received?
george veropoulos
il 20 Nov 2024
Modificato: Walter Roberson
il 22 Nov 2024
george veropoulos
il 20 Nov 2024
Modificato: Walter Roberson
il 22 Nov 2024
george veropoulos
il 20 Nov 2024
Modificato: Walter Roberson
il 22 Nov 2024
Steven Lord
il 20 Nov 2024
If you're adding information, please put it as a comment rather than a separate answer. Leave the answer for posts that may be a solution to the problem, to make them easier to distinguish from commentary.
Walter Roberson
il 22 Nov 2024
Note that function e_n leaves y undefined in the case where k is NaN.
If k cannot be NaN then there is no point in using elseif -- just use else
Risposta accettata
Più risposte (0)
Categorie
Scopri di più su Mathematics in Centro assistenza e File Exchange
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!