二元信号探测的误检概率推导与其matlab验证

本文探讨了在高斯白噪声背景下,如何区分两种不同信号的问题,并详细推导了误检概率的公式。通过MATLAB验证了理论结果。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

假设传输两个信号:s0[n]s_0[n]s0[n]s1[n]s_1[n]s1[n],传输过程中叠加了高斯白噪声w[n]w[n]w[n]w[n]∼N(0,σ2)w[n]\sim N(0,\sigma^2)w[n]N(0,σ2)。在接收端,我们需要判断接收到的x[n]x[n]x[n]到底是哪个信号,就有了如下两个假设:
H0:x[n]=s0[n]+w[n]H1:x[n]=s1[n]+w[n] H_0:x[n]=s_0[n]+w[n]\\ H_1:x[n]=s_1[n]+w[n] H0:x[n]=s0[n]+w[n]H1:x[n]=s1[n]+w[n]
假设发出两种信号的概率相等,当
Pr⁡(x⃗∣H1)Pr⁡(x⃗∣H0)>γ=Pr⁡(H0)Pr⁡(H1)=1 \frac{\Pr(\vec{x}|H_1)}{\Pr(\vec{x}|H_0)}>\gamma=\frac{\Pr(H_0)}{\Pr(H_1)}=1 Pr(xH0)Pr(xH1)>γ=Pr(H1)Pr(H0)=1
时,拒绝H0H_0H0,认为我们接收到了s1s_1s1信号。

为了进一步探讨该问题,将Pr⁡(x⃗∣Hi)\Pr(\vec{x}|H_i)Pr(xHi)展开,因为接收到的信号x[n]x[n]x[n]每一位都满足x[n]∼N(si[n],σ2)x[n]\sim N(s_i[n],\sigma^2)x[n]N(si[n],σ2),故整个信号x⃗\vec{x}x
Pr⁡(x⃗∣Hi)=1(2πσ2)N2exp⁡[−12σ2∑n=0N−1(x[n]−si[n])2] \Pr(\vec{x}|H_i)=\frac{1}{(2\pi\sigma^2)^{\frac{N}{2}}}\exp[-\frac{1}{2\sigma^2}\sum_{n=0}^{N-1}(x[n]-s_i[n])^2] Pr(xHi)=(2πσ2)2N1exp[2σ21n=0N1(x[n]si[n])2]
注意到对于两个假设H0H_0H0H1H_1H1Pr⁡(x⃗∣Hi)\Pr(\vec{x}|H_i)Pr(xHi)的区别在于∑n=0N−1(x[n]−si[n])2\sum_{n=0}^{N-1}(x[n]-s_i[n])^2n=0N1(x[n]si[n])2,故设
Di2=∑n=0N−1(x[n]−si[n])2=∣∣x⃗−si⃗∣∣2 D_i^2=\sum_{n=0}^{N-1}(x[n]-s_i[n])^2=||\vec{x}-\vec{s_i}||^2 Di2=n=0N1(x[n]si[n])2=xsi2
不难看出,我们做出判断的依据就在于接收信号构成的向量x⃗\vec{x}x与两已知信号向量si⃗\vec{s_i}si之差的模长的平方。

再展开Di2D_i^2Di2,得
Di2=∑n=0N−1x2[n]−2∑n=0N−1x[n]si[n]+∑n=0N−1si2[n] D_i^2=\sum_{n=0}^{N-1}x^2[n]-2\sum_{n=0}^{N-1}x[n]s_i[n]+\sum_{n=0}^{N-1}s_i^2[n] Di2=n=0N1x2[n]2n=0N1x[n]si[n]+n=0N1si2[n]
发现D12D_1^2D12D22D_2^2D22之间的差别在于−2∑n=0N−1x[n]si[n]+∑n=0N−1si2[n]-2\sum_{n=0}^{N-1}x[n]s_i[n]+\sum_{n=0}^{N-1}s_i^2[n]2n=0N1x[n]si[n]+n=0N1si2[n],故定义
Ti(x)=∑n=0N−1x[n]si[n]−12∑n=0N−1si2[n] T_i(x)=\sum_{n=0}^{N-1}x[n]s_i[n]-\frac{1}{2}\sum_{n=0}^{N-1}s_i^2[n] Ti(x)=n=0N1x[n]si[n]21n=0N1si2[n]
其中,∑n=0N−1si2[n]\sum_{n=0}^{N-1}s_i^2[n]n=0N1si2[n]为信号sis_isi的能量,故TiT_iTi又可写为
Ti(x)=∑n=0N−1x[n]si[n]−12εi T_i(x)=\sum_{n=0}^{N-1}x[n]s_i[n]-\frac{1}{2}\varepsilon_i Ti(x)=n=0N1x[n]si[n]21εi
可得出误检概率PeP_ePe的表达式为
Pe=Pr⁡(H1∣H0)Pr⁡(H0)+Pr⁡(H0∣H1)Pr⁡(H1)=12[Pr⁡(H1∣H0)+Pr⁡(H0∣H1)]=12[Pr⁡(T1(x⃗)−T0(x⃗)>0∣H0)+Pr⁡(T0(x⃗)−T1(x⃗)>0∣H1)] \begin{aligned} P_e&=\Pr(H_1|H_0)\Pr(H_0)+\Pr(H_0|H_1)\Pr(H_1)\\ &=\frac{1}{2}[\Pr(H_1|H_0)+\Pr(H_0|H_1)]\\ &=\frac{1}{2}[\Pr(T_1(\vec{x})-T_0(\vec{x})>0|H_0)+\Pr(T_0(\vec{x})-T_1(\vec{x})>0|H_1)] \end{aligned} Pe=Pr(H1H0)Pr(H0)+Pr(H0H1)Pr(H1)=21[Pr(H1H0)+Pr(H0H1)]=21[Pr(T1(x)T0(x)>0H0)+Pr(T0(x)T1(x)>0H1)]
故定义检验T(x⃗)=T1(x⃗)−T0(x⃗)T(\vec{x})=T_1(\vec{x})-T_0(\vec{x})T(x)=T1(x)T0(x),即
T(x⃗)=∑n=0N−1x[n](s1[n]−s0[n])−12(ε1−ε0) T(\vec{x})=\sum_{n=0}^{N-1}x[n](s_1[n]-s_0[n])-\frac{1}{2}(\varepsilon_1-\varepsilon_0) T(x)=n=0N1x[n](s1[n]s0[n])21(ε1ε0)
通过计算可得TTT的期望与方差:
E(T∣H0)=∑n=0N−1s0[n](s1[n]−s0[n])−12(ε1−ε0)=−12∣∣s1⃗−s0⃗∣∣2E(T∣H1)=12∣∣s1⃗−s0⃗∣∣2Var(T∣H0)=Var(∑n=0N−1x[n](s1[n]−s0[n])∣H0)=σ2∣∣s1⃗−s0⃗∣∣2Var(T∣H1)=σ2∣∣s1⃗−s0⃗∣∣2 \begin{aligned} &E(T|H_0)=\sum_{n=0}^{N-1}s_0[n](s_1[n]-s_0[n])-\frac{1}{2}(\varepsilon_1-\varepsilon_0)=-\frac{1}{2}||\vec{s_1}-\vec{s_0}||^2\\ &E(T|H_1)=\frac{1}{2}||\vec{s_1}-\vec{s_0}||^2\\ &Var(T|H_0)=Var(\sum_{n=0}^{N-1}x[n](s_1[n]-s_0[n])|H_0)=\sigma^2||\vec{s_1}-\vec{s_0}||^2\\ &Var(T|H_1)=\sigma^2||\vec{s_1}-\vec{s_0}||^2 \end{aligned} E(TH0)=n=0N1s0[n](s1[n]s0[n])21(ε1ε0)=21s1s02E(TH1)=21s1s02Var(TH0)=Var(n=0N1x[n](s1[n]s0[n])H0)=σ2s1s02Var(TH1)=σ2s1s02
所以,(T∣H0)(T|H_0)(TH0)(T∣H1)(T|H_1)(TH1)均满足正态分布,且
(T∣H0)∼N(−12∣∣s1⃗−s0⃗∣∣2,σ2∣∣s1⃗−s0⃗∣∣2)(T∣H1)∼N(12∣∣s1⃗−s0⃗∣∣2,σ2∣∣s1⃗−s0⃗∣∣2) (T|H_0)\sim N(-\frac{1}{2}||\vec{s_1}-\vec{s_0}||^2,\sigma^2||\vec{s_1}-\vec{s_0}||^2)\\ (T|H_1)\sim N(\frac{1}{2}||\vec{s_1}-\vec{s_0}||^2,\sigma^2||\vec{s_1}-\vec{s_0}||^2) (TH0)N(21s1s02,σ2s1s02)(TH1)N(21s1s02,σ2s1s02)
故误检概率可写为
Pe=Pr⁡(T>0∣H0)Pr⁡(H0)+Pr⁡(T<0∣H1)Pr⁡(H1)=12[Pr⁡(T>0∣H0)+Pr⁡(T<0∣H1)]=Φ(−12∣∣s1⃗−s0⃗∣∣2σ2∣∣s1⃗−s0⃗∣∣2)=Φ(−12∣∣s1⃗−s0⃗∣∣2σ2) \begin{aligned} P_e&=\Pr(T>0|H_0)\Pr(H_0)+\Pr(T<0|H_1)\Pr(H_1)\\ &=\frac{1}{2}[\Pr(T>0|H_0)+\Pr(T<0|H_1)]\\ &=\Phi(-\frac{\frac{1}{2}||\vec{s_1}-\vec{s_0}||^2}{\sqrt{\sigma^2||\vec{s_1}-\vec{s_0}||^2}})\\ &=\Phi(-\frac{1}{2}\sqrt{\frac{||\vec{s_1}-\vec{s_0}||^2}{\sigma^2}}) \end{aligned} Pe=Pr(T>0H0)Pr(H0)+Pr(T<0H1)Pr(H1)=21[Pr(T>0H0)+Pr(T<0H1)]=Φ(σ2s1s0221s1s02)=Φ(21σ2s1s02)
可以看出,误检概率与两信号向量之差的模长成正比,与噪音的标准差成反比。

我们可以用matlab验证该推导结果,每次检验均生成两个随机信号s1,s2s_1,s_2s1,s2,分别叠加噪音计算TTT值,判断是否误检。

在这里只生成了长度为2的信号,一是因为长度太长每次检验的速度会增加,程序的总运行时间暴增;其次若信号长度太长,很难随机生成∣∣s1⃗−s0⃗∣∣2||\vec{s_1}-\vec{s_0}||^2s1s02较小的信号,使统计不准。
test.m

function res=test(sigma)
N=2;
s0=2*rand(1,N)-1;
s1=2*rand(1,N)-1;
w0=s0+sigma*randn(1,N);
w1=s1+sigma*randn(1,N);
T0=0;
T1=0;
E0=0;
E1=0;
for i=1:1:N
   E0=E0+s0(i)^2;
   E1=E1+s1(i)^2;
   T0=T0+w0(i)*(s1(i)-s0(i));
   T1=T1+w1(i)*(s1(i)-s0(i));
end
T0=T0-(E1-E0)/2;
T1=T1-(E1-E0)/2;
p=(s1-s0)*(s1-s0)';
%p=2*s1*s0'/(s1*s1'+s0*s0');
res=[p,(T0>0)+(T1<0)];

之后,统计两向量之差的模长与误检次数的关系,与推导结果比对,可得
在这里插入图片描述
∣∣s1⃗−s0⃗∣∣2||\vec{s_1}-\vec{s_0}||^2s1s02偏大的部分,统计很不准确,这是因为对于随机生成的长度为2的信号,∣∣s1⃗−s0⃗∣∣2||\vec{s_1}-\vec{s_0}||^2s1s02那么大的样本很少,统计结果就会非常不准确。可以考虑使用蒙特卡洛法消除部分偏差。

统计及生成gif代码:
statistic.m

clc;clear;
cnt=1;
for sigma=0.2:0.01:0.6
str='σ=';
N=10000000;
d=1000;
y=zeros(1,d);
tot=zeros(1,d);
data=zeros(N,2);
hb=0;
lb=400;
for i=1:1:N
    a=test(sigma);
    data(i,1)=a(1);
    data(i,2)=a(2);
    hb=max(hb,a(1));
    lb=min(lb,a(1));
end
hb=hb+0.01;
sep=(hb-lb)/d;
x=lb+sep/2:sep:hb-sep/2;
for i=1:1:N
    idx=floor((data(i,1)-lb)/sep)+1;
    y(idx)=y(idx)+data(i,2);
    tot(idx)=tot(idx)+2;
end
y=y./tot;
figure
plot(x,y,"linewidth",2);
hold on;
pd=makedist("Normal","mu",0,"sigma",1);
y1=cdf(pd,trans(x,sigma));
plot(x,y1,"linewidth",2);
xlabel("$||s_1-s_0||^2$","interpreter","latex","fontsize",16);
ylabel("prE","fontsize",16);
str1=[str num2str(sigma)];
title(str1,"fontsize",18);
print(1,'-dbmp',sprintf('img/%d',cnt));
cnt=cnt+1;
close;
end
%xlim([0.1 0.7]);
%ylim([-0.0025 0.03]);
%依次读取生成的所有图片
for j=1:41
    %获取当前图片
    A=imread(sprintf('img/%d.bmp',j));
    [I,map]=rgb2ind(A,256);
    %生成gif,并保存
    if(j==1)
        imwrite(I,map,'movefig.gif','DelayTime',0.1,'LoopCount',Inf)
    else
        imwrite(I,map,'movefig.gif','WriteMode','append','DelayTime',0.1)    
    end
end

trans.m

function re=trans(x,sigma)
re=-sqrt(x/sigma^2)/2;
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

ShadyPi

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值