我正在尝试在numpy中转换一个matlab代码来计算误码率一段代码对我来说是个问题这是我想转换的matlab代码
SNR=6:22;
display(SNR)
display(length(SNR))
BER=zeros(1,length(SNR));
display(BER)
display(length(BER))
Es=10;
for ii=1:length(SNR)
variance=Es*10^(-SNR(ii)/10);
std_dev=sqrt(variance/2);
noise=(randn(1,length(S))+sqrt(-1)*randn(1,length(S)))*std_dev;
S_noisy=S+noise;
end
display(variance)
python代码SNR=arange(6,23,1)
BER=zeros(len(SNR))
print(BER)
Es=10
for ii in arange(0,len(SNR)):
variance=Es*10**(-SNR[ii]/10)
std_dev=cmath.sqrt(variance/2)
noise=(np.random.randn(len(S))+cmath.sqrt(-1)*np.random.randn(len(S))) *std_dev
S_noisy=S+noise
print(variance)
在 python 中方差的答案应该是 0.063 bt 它提供 0.01 plzz 帮助