当N = 2时,我正在尝试使用zeroforcing编写quadrature phase-shift keying(QPSK)的代码,我收到了错误。
以下是代码:
Modulation = 'QPSK'
Decode_Method = 'ZeroForcing'
switch Modulation
case {'QPSK'}
Symbols = [ 1+j 1-j -1+j -1-j ]';
end
Symbols = Symbols.';
nSymbols = length(Symbols);
SNR_Array = [0.3 0.7 1.2 2.5 5 6.2 10 15.4 22 45 75.7 100.0];
nSNR = length(SNR_Array);
Ntest = 20;
N = 2;
for iSNR = 1 : nSNR
SNR = SNR_Array(iSNR);
Nerror = 0;
for i = 1:Ntest
H = randn(N,N) + j*randn(N,N);
X = Symbols( ceil( nSymbols*rand(N,1) ) )';
Noise = (randn(N,1) + j*randn(N,1))/sqrt(2)/sqrt(SNR);
Y = H*X + Noise;
switch Decode_Method
case {'ZeroForcing'}
X_Decode = Zero_Forcing(Y,H,Symbols);
end
end
Nerror = Nerror + length( find( X ~= X_Decode) );
end
Symbol_Error_Rate(iSNR) = Nerror/Ntest/N;
figure(1)
loglog(SNR_Array, Symbol_Error_Rate,'b')
hold on
xlabel('SNR')
ylabel('Symbol Error Ratio')
title('Symbol Error Ratio for NxN MIMO System')
错误是:
???未定义的函数或方法'Zero_Forcing'用于'double'类型的输入参数。
==>中的错误无题2在33
X_Decode = Zero_Forcing(Y,H,符号);
如何解决此错误?
答案 0 :(得分:1)
该错误表示MATLAB无法找到函数Zero_Forcing
。如果你有这个名字的功能,你应该确保它在MATLAB路径上,也就是MATLAB知道的目录。否则,您应该编写该函数。这似乎很重要。
另外,你可能不想调用你的函数'Untitled2',但给它一个更有意义的名字。