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 + -
显示快捷键?