1

我哪里做错了?问题出在: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
4

1 回答 1

4

问题在于您所说的位置,而在于以下行:

L(idx_not_diagL) = DL^2./(4.*pi*EO*R(mod(idx_not_diagL,10),floor(idx_not_diagL/N)));

简而言之,您的问题是您为 matrix 指定了零索引R,但在 MATLAB 中,零索引是非法的(它们从 1 开始,而不是 0!)。

现在,你从哪里得到零索引?您可以R(..., ...)使用以下行和列下标进行索引:

mod(idx_not_diagL, 10)

floor(idx_not_diagL / N))

两者偶尔都会得到零值。

作为修复,我建议对行索引使用以下内容:

mod(idx_not_diagL, 10) + 1

至于列索引,还有另一个问题。表达式的floor(...)范围从 0 到 99。一旦你修复它(我不确定你想要达到什么目的),它就会起作用。

于 2012-12-09T15:15:23.913 回答