📄 lscma.m
字号:
function SINR=lscma()
%
%2005.12.7
%加载数据
load goldseq;
load bs;
%gold码归一化
goldseq = 1/sqrt(31)*goldseq;
%期望用户扩频序列
s1=goldseq(1,:)';
s2=goldseq(2,:)';
s3=goldseq(3,:)';
s4=goldseq(4,:)';
s5=goldseq(5,:)';
s6=goldseq(6,:)';
A2=10;
A3=10;
A4=10;
A5=10;
A6=10;
L=200;
N=length(s1);
z=zeros(N,1);
z(1,1)=1;
B=eye(N)-s1*s1';
w=s1+B*z;
w=s1;
w=randn(N,1);
r1=goldseq(1,:)'*b(1,:);
r2=goldseq(2,:)'*b(2,:);
r3=goldseq(3,:)'*b(3,:);
r4=goldseq(4,:)'*b(4,:);
r5=goldseq(5,:)'*b(5,:);
r6=goldseq(6,:)'*b(6,:);
r=r1+A2*r2+A3*r3+A4*r4+A5*r5+A6*r6;
%r=r1+r2+r3+r4+r5+r6;
SNR=20;
r=awgn(r,SNR);
for i=1:500
X=r(:,i:i+L-1);
y=w'*X;
M=diag(y.^2);
z=z/2+(1/2)*((X*M*X')^-1)*X*y'-s1/2;
w=s1+B*z;
%n=w'*s2+w'*s3+w'*s4+w'*s5+w'*s6+0.1*norm(w);
n=(A2*w'*s2)^2+(A3*w'*s3)^2+(A4*w'*s4)^2+(A5*w'*s5)^2+(A6*w'*s6)^2+w'*0.01*w;
%n=(w'*s2)^2+(w'*s3)^2+(w'*s4)^2+(w'*s5)^2+(w'*s6)^2+0.1*norm(w);
SINR(i)=((w'*s1)^2)/n;
%SINR(i)=((w'*s1)^2)/(var(w'*X));
end
i=1:500;
plot(i,10*log10(SINR));
xlabel('迭代次数');
ylabel('信号干扰噪声比SINR(dB)');
title('LSCMA多用户检测');
grid on
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -