debugging 错误:A和B必须是浮点标量

laximzn5  于 2023-01-17  发布在  其他
关注(0)|答案(1)|浏览(151)

我试图整合两点之间的函数,但我不能这样做,因为我得到以下错误:

Error using integral (line 85)
A and B must be floating-point scalars.

Error in integrantK_sup (line 6)
I=integral(F1,double(ALPHA*R_int_ind),double(ALPHA*R_ext_ind)); % équation (70), p.2834

Error in Script_A_MH_L (line 228)
    integ=integrantK_sup(ALPHA);

使用的代码为:

nb_pt_v=200;  pas_v=Ep_plaque/nb_pt_v;
nb_pt_h=200;  pas_h=3*R_ext_ind/nb_pt_h;
ik=1:nb_pt_h+1;
il=1:nb_pt_v+1;
r=  0    + (ik-1).*pas_h;        
z=  0    - (il-1).*pas_v;        [r,z]=meshgrid(r,z);
A=zeros(nb_pt_v+1,nb_pt_h+1);

pas_alpha=10;
nb_pas_al=1500;
for ALPHA=0.1:pas_alpha:nb_pas_al
    integ=integrantK_sup(ALPHA);
    A=integ.*pas_alpha+A;
end

积分函数integratingK_sup定义如下:

function integ=integrantK_sup(ALPHA)
% équation (74), p.2835
global   r z R_int_ind R_ext_ind Ep_plaque Ep_ind Airgap w mur sigma_plaque  
F1=@(x)x.*besselj(1,x);
I=integral(F1,double(ALPHA*R_int_ind),double(ALPHA*R_ext_ind)); % équation (70), p.2834
Alpha_1=sqrt(ALPHA^2+1j*w*mur*sigma_plaque);

aa=I.*besselj(1,ALPHA.*r).*(exp(-ALPHA*Airgap)-exp(-ALPHA*(Airgap+Ep_ind)));
bb=(ALPHA*Alpha_1*exp(2*Alpha_1*Ep_plaque).*exp(Alpha_1.*z));
cc=ALPHA*Alpha_1.*exp(-Alpha_1.*z);
dd=((ALPHA-Alpha_1)*Alpha_1+Alpha_1*(ALPHA+Alpha_1)*exp(2*Alpha_1*Ep_plaque));

integ=((1/(ALPHA^3)).*aa).*((bb+cc)/dd);

end

要执行,必须首先初始化参数:

Ep_plaque = 5e-3;
R_plaque = 20e-2;    
R_int_ind   = 5e-2;
R_ext_ind   = 15e-2;
Ep_ind      = 2e-3;
Airgap      = 2e-3;     
R_air = 5*R_plaque;
H_air = 100*Ep_plaque;
mu0=4*pi*1e-7;          %% Perméabilité magnétique du vide 
nu0=1/mu0;              %% Réluctivité magnétique du vide
mur=1e5;                %% Perméabilité magnétique relative 
nur=1.0/mur;            %% Perméabilité magnétique du circuit magnétique
Js=5e6;                 %% Densité de courant source
Is = Js *((R_ext_ind-R_int_ind)*Ep_ind); %% courant source 
ADirichlet=0;           %% Valeurs Dirichlet du potentiel vecteur magnétique 
sigma_plaque=1e6;       %% Conductivité électrique du circuit magnétique
fr=50000;               %% Fréquence de travail
w = 2*pi*fr ;           %% Pulsation

问题在于两点ALPHA * R_int_indALPHA * R_ext_ind之间函数F1的积分。

dluptydi

dluptydi1#

根据我们在评论中的对话,我能够重现您看到的错误,即在初始化时没有使R_int_indR_ext_ind全局化。下面是修复了该错误的代码的简化版本:

% Script_A_MH_L
global R_int_ind R_ext_ind % <-- Global declaration added here.
R_int_ind   = 5e-2;
R_ext_ind   = 15e-2;

pas_alpha=10;
nb_pas_al=1500;
I=[];
for ALPHA=0.1:pas_alpha:nb_pas_al;
    I(end+1)=integrantK_sup(ALPHA);
end
% integrantK_sup
function I = integrantK_sup(ALPHA)
global R_int_ind R_ext_ind
F1=@(x)x.*besselj(1,x);
I=integral(F1,double(ALPHA*R_int_ind),double(ALPHA*R_ext_ind)); % équation (70), p.2834
end

全局变量是出了名的容易引起混淆,你最好把常量打包成一个结构体,然后把它们传递给需要它们的函数。
一个二个一个一个

相关问题