bc_error.m

来自「利用电磁场的源激发方法来计算光子晶体波导例如光子晶体光纤」· M 代码 · 共 24 行

M
24
字号
function err = bc_error(mZ, mBNegate, vSolution, varargin)
if ~isempty(varargin)
        G = varargin{1};
        bPlot = 1;
else
        bPlot = 0;
end

vSolution = vSolution(:);
abs_err = mZ*vSolution;
% calculate average on the interface
L = length(vSolution);
mZ(mBNegate) = -mZ(mBNegate);
vAvg = mZ*vSolution;
M = rms(vAvg);
%M = max(abs(mZ*vAvg));
err = rms(abs_err)/M;
if bPlot
        hold off
        plot(abs(abs_err),'r')
        hold on
        plot(abs(vAvg),'g')
        hold off
end

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?