我哪里做错了?问题在于: R = sqrt(bsxfun(@minus,XX,(XX)').^2+bsxfun(@minus,YY,(YY)').^2);
EO = 8.8541e-12; %eps0
A2 = 1.0e-2; %2a
N = 100; %num of subareas in a plate
M = sqrt(N); %num of subareas in one axis
DX = A2/M; % 2b
DY = DX; %2b
DL = DX; %2b
% SECOND, CALCULATE THE ELEMENS OF THE COEFFICIENT MATRIX A
% Write all the subareas centers coordinates to X and Y
% SECOND, CALCULATE THE ELEMENS OF THE COEFFICIENT MATRIX A
% Write all the subareas centers coordinates to X and Y
x = linspace(DL*0.5,DL*(M-0.5),M);
y = x;
[XX,YY]=meshgrid(x,y);
%%L = NaN(N,N);
**R = sqrt(bsxfun(@minus,XX,(XX)').^2+bsxfun(@minus,YY,(YY)').^2);**
idx_diagL = find(eye(N)~=0);
idx_not_diagL = find(eye(N)==0);
L(idx_not_diagL) = DL^2./(4.*pi*EO*R(mod(idx_not_diagL,10),floor(idx_not_diagL/N)));
L(idx_diagL) = DL*0.8814/(pi*EO); %ln(1+sqrt(2)= 0.8814
问题不在于你说它在哪里,而在于以下行:
L(idx_not_diagL) = DL^2./(4.*pi*EO*R(mod(idx_not_diagL,10),floor(idx_not_diagL/N)));
简而言之,您的问题是您为矩阵R
指定了零索引,但在 MATLAB 中零索引是非法的(它们从 1 开始,而不是 0!
现在,你从哪里得到零指数?使用以下行和列下标索引到R(..., ...)
:
mod(idx_not_diagL, 10)
和
floor(idx_not_diagL / N))
两者都偶尔得到零值。
作为修复,我建议对行索引使用以下方法:
mod(idx_not_diagL, 10) + 1
至于列索引,还有另一个问题。floor(...)
表达式的范围为 0 到 99。一旦你修复了它(我不确定你想实现什么),它就会起作用。