elimone.m
来自「经典通信系统仿真书籍《通信系统与 MATLAB (Proakis)》源代码」· M 代码 · 共 37 行
M
37 行
function [x, xmask] = elimone(x, xmask, h, w, n, maxbin)
%ELIMONE Eliminates a variable.(Utility function used by DFILDEMO).
% Eliminates a variable and places it in the discrete set of
% variables that are not free to vary.
xold = x;
Fbest = -1e16;
Fix = xmask(1);
ceilflag = 0;
for i = xmask
x = xold;
x(i) = ceil(x(i));
ht=abs(freqz(x(1:n), x(n+1:2*n), w));
F = max(abs(h-ht));
if F > Fbest & roots(x(n+1:2*n)) < 1
Fix = i;
Fbest = F;
ceilflag =1;
end
x = xold;
x(i) = floor(x(i));
ht=abs(freqz(x(1:n), x(n+1:2*n), w));
F = max(abs(h-ht));
if F < Fbest & roots(x(n+1:2*n)) < 1
Fix = i;
Fbest = F;
ceilflag = 0;
end
end
x = xold;
if ceilflag
x(Fix) = ceil(x(Fix));
else
x(Fix) = floor(x(Fix));
end
xmask(find(xmask == Fix)) = [];
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?