繁体   English   中英

如何在Matlab中找到对应的SNR的BLER

[英]How to find BLER for corresponding SNR in Matlab

我有100 SNR(信噪比),

    SNR=[32.48873121,21.11297791,15.04042054,15.03765931,14.9860986,14.70063992,14.0914781,12.63557416,11.90471529,10.66141951,10.61423996,8.872149307,7.489301489,7.409686903,5.356321373,4.42000844,4.137654873,3.884999624,3.784549782,3.348447225,3.285491969,3.197460245,2.848888812,2.160133333,1.915260409,1.563950453,1.329209884,1.191461459,0.790756594,0.611525663,0.575573311,0.140882111,-0.036497656,-0.111073002,-0.258210049,-0.848790033,-1.25026649,-1.446774222,-2.080726269,-2.359212956,-2.516335413,-2.595010771,-3.063688167,-3.257431493,-3.283558882,-3.351236489,
-3.466831795,-3.665976748,-3.821897741,-4.51332461,-4.564700129,-4.718940301,-4.79394587,-4.85247625,-5.000716016,-5.129179148,-5.393944029,-5.499661228,-5.550047619,-5.671860615]

对于这个特定的SNR,我通过使用以下代码发现了BLER(误块率):

SNR_L = [-8 -6 -4 -2];
L = [0.1231 0.0366 0.0082 0.0014]; 
logL=log10(L);
p=polyfit(SNR_L,logL,1);
semilogy(SNR_L,L,'k-s');
grid on;

for i=1:100
BLER(i)=p(1,2)+p(1,1)*SNR(i);
end

在这里,我正在使用从该代码semilogy(SNR_L,L,'k-s')找到的图semilogy(SNR_L,L,'k-s') 。由于我正在使用polyfit并且度数= 1,所以我找到了2个系数,例如y=a0+a1x 。找到BLER我正在使用此代码BLER(i)=p(1,2)+p(1,1)*SNR(i) 当我找到100 SNR时,这就是为什么我最终使用for循环为对应的SNR找到100 BLER的原因。

但是我无法获得正确的BLER以获得正SNR。 从我的角度来看,如果SNR高,那么我的BLER会很低,但我的BLER会很高。

问题可能是您正在混合plotsemilogy 如果执行以下操作,则曲线匹配:

plot(SNR_L,logL,'k-s');
hold on
plot(SNR,BLER);

请注意,y轴是BLER的log10,而不是BLER。 您可以使用BLER值标记轴

set(gca,'yticklabel', 10.^get(gca,'ytick'))

参见结果图。

在此处输入图片说明

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM