liujia1067 发表于 2008-6-15 22:16

频率调制FSK的伪随机码,相关峰不是应该很窄吗?

这个程序是这样的,先产生伪随机码,之后把码调制在两个频率的信号上,没考虑相位的连续性。按道理伪随机码应该相关峰很窄啊,可是从图中看却不是这样,这是怎么回事?
另外,我也用这个伪随机码,用相位调制单频信号,则能得到很窄的相关峰。
请帮忙看看,是不是程序中频率调制那段(蓝色)是不是错了?谢谢!


%-- mseq 为输出01二进制码 ---%
fbconnection = ; n = length(fbconnection) ; N = 2^n - 1 ;% n级码 码数N
register = ; %定义移位寄存器的初始状态
mseq(1) = register(n) ; newregister = zeros(1,n);
for i = 2:N, newregister(1) = mod(sum(fbconnection.*register),2);
    for k = 2 :n, newregister(k) = register(k - 1) ; end
    register = newregister ; mseq(i) = register(n) ;
end
aa = xcorr(mseq); figure,plot(aa);
%--- 0 -> -1 ---%
for n=1:length(mseq)
   if mseq(n)==0, mseq(n)=-1; end
end
%--- 载波信号 ---%
f01 =500; f02 =1000; delta_f=20;% 带宽
Ts=1/delta_f;%码元宽度
T_sig = N*Ts; fs = 10*max(f01,f02); t = /fs;
y1 = sin(2*pi*f01*t); y2 = sin(2*pi*f02*t);
%--- 频率调制 ---%
N_Ts=Ts*fs;% 单个码元宽度具有的离散点数
a=ones(1,round(N_Ts));
for n=0:N-1
    pn(n*round(N_Ts)+1:(n+1)*round(N_Ts))=a*mseq(n+1);% 小蓝脸那是个冒号
end
for n = 1:length(pn)
    if pn(n)==1, output(n) = y1(n); end
    if pn(n)==-1, output(n) = y2(n); end
end
%--- 显示 ---%
figure,subplot(2,1,1); plot(t,output);
N_fft = fs; f_axis = *fs/N_fft;
subplot(212); plot(f_axis,abs(fft(output,N_fft)));
= xcorr(output); figure(4),plot(lags/fs,xg);title('自相关');

[ 本帖最后由 ChaChing 于 2010-1-12 10:11 编辑 ]
页: [1]
查看完整版本: 频率调制FSK的伪随机码,相关峰不是应该很窄吗?