• m低信噪比下GPS信号的捕获算法研究,使用matlab算法进行仿真


    目录

    1.算法概述

    2.仿真效果预览

    3.MATLAB部分代码预览

    4.完整MATLAB程序


    1.算法概述


           GPS系统的星座部分是由21颗工作卫星和3颗在轨备用卫星组成,其高度为20183km,这24颗卫星均匀分布在6个等间隔的、相对轨道面倾角为55º的近圆轨道上。

           GPS卫星的轨道周期为半个恒星日,即11小时58分钟。从地球质心到卫星的额定距离为26600km,即轨道半径。每颗GPS工作卫星都发射用于导航定位的信号,然后GPS用户利用这些信号来进行工作的。这样的空间布局,可以保证在地球上的任意点、任意时刻均可同时观测到至少4颗卫星,最多时可以见到11颗,从而为全球用户提供24小时的导航定位功能。

          GPS卫星发送的信号一般由3个分量组成:载波信号、伪码和导航电文。其中伪码和导航电文采用BPSK技术去调制载波。每个卫星数据代码中使用模2加法叠加在C/A和P码上,再调制到L1、L2载波上。正如已经提到的,载波信号涵盖L1载波和L2载波,所以测距码信号包括叠加在L2载波上的P码和L1载波上的P码、C/A。所有信号都是通过同一个基本频率的控制下产生的,如图3所示。

      

           从图3可知,L1载波调制有P码、C/A码和数据码。而在L2载波上当前只有数据码和调制P码。拟议中的L5载波(第二民用频率)将会选择同时加载P码和C/A码,预计它的频率将会达到f5=115*f0=1175.45MHz,波长为=25.48cm。无论数据码还是测距码,是通过相位调制高频载波。也就是说,当代码值(调制信号)从1到0,或从0到1,会使载波相位变化180度。调制以后的卫星信号向用户播放是通过卫星发射天线。接收机的主要工作是重建载波来提取导航电文。信号解调中常用的2种方法:平方解调技术和复制代码相关技术。

           GPS卫星所发播的信号包括载波信号(L1和L2)、测距信号(包括C/A码和P码)和导航信号(或称D码元)。其中测距信号是一种伪随机噪声码(PRN) 。

           GPS使用的两个L波段两种载频:   

    选择L波段的好处是:

    (1)减少拥挤,防止“撞车“现象发生。目前L波段的频率占用率要低于其他波段,对全球性的导航定位测量非常有利。

    (2)自适应扩频,传输宽带信号。卫星扩频传输卫星导航电文,高频率约为20兆赫兹,在占用率较低的带宽。

     (3)大气衰减较小,对研制用户设备有利。GPS卫星采用的是L波段,避免了大气的谐振吸收,衰减较小,而且电离层延迟的影响小,有利于接收设备测量GPS信号。

          而在接收端,其结构如图1所示,它是利用前段射频硬件的采集模板将 GPS信号采集转化成中频数字信号再进行后续信号处理,从而得到信号定位等相关信息。软件接收机的实现由前段射频模块的质量和性能去决定。

     

            软件接收机主要是由两个模块组成:信号数据处理软件模块和前端信号采集硬件电路模块。软件模块细分为捕获与跟踪,星历解码与PVT估计。软件接收机系统的主线是GPS数据流的处理过程,前端以数据采集为主,在后端的设计集中于信号处理的软件编程与实现,因此,在可以采集准确的GPS数据的前提下,后端设计为软件接收机给予了很大的灵活性,为新算法的验证评估和测试提供一个有效的、便捷的服务平台。硬件模块细分则为天线,A/D转换模块,降频模块,数据采集存贮模块和串并行模块。

            通常情况下,由于输入信号的C/A码的起始位置是未知的,所以在进行捕获之前,波形实现产生一个伪随机码,这里假设将接收到的模拟信号数字化为5000个点,然后与输入的信号在数字域进行相乘,将相乘得到的结果进行快速傅里叶变换,从而得到其频率。通过上一节的讨论,FFT之后的频率分量为前半部分的2500个频率分量,将输出的频率分量的幅度与设置的门限值进行比较,如果幅度值大于门限值,那么该频率分量就是所需要的期望值。通过这种算法,就能够得到之前所说的起始点位置。

    2.仿真效果预览

    matlab2022a仿真

     

    3.MATLAB部分代码预览

    1. .........................................................................
    2. %% step2:CA码的产生
    3. load gold1.mat;
    4. code=double(code(1,:));
    5. figure;
    6. plot(code,'r-*');
    7. axis([0,length(code),-1.2*max(code),1.2*max(code)]);
    8. title('采样化后的 CA 码');
    9. %相关性
    10. Xcor_code = xcorr(code,code);
    11. figure
    12. plot(Xcor_code,'b-o');
    13. axis([0,length(Xcor_code),0,1.2*max(Xcor_code)]);
    14. %% step3:GPS中频信号
    15. load data.mat
    16. x=double(data');
    17. figure;
    18. plot(x,'r-*');
    19. axis([0,length(x),-1.2*max(x),1.2*max(x)]);
    20. x2 = [x x x x x x x x x x];
    21. %发送四段连续的信号;
    22. LENS = length(x2);
    23. s=0:LENS-1;
    24. y=x2.*exp(j*2*pi*(fc+fdelta)/fs*s);
    25. y=awgn(y,snr);
    26. %% step4:GPS信号的捕获 分成4段捕获
    27. CA_fre = conj(fft(code));
    28. L2 = length(y)/N;
    29. y1 = y(1:11999);
    30. y2 = y(12000:23998);
    31. y3 = y(23999:35997);
    32. y4 = y(35998:47996);
    33. y5 = y(47997:59995);
    34. y6 = y(59996:71994);
    35. y7 = y(71995:83993);
    36. y8 = y(83994:95992);
    37. y9 = y(95993:107991);
    38. y10= y(107992:119990);
    39. ys1 = y1+y2+y3+y4;
    40. % ys2 = y1+y2+y3+y4+y5+y6+y7+y8+y9-y10;
    41. % ys3 = y1+y2+y3+y4+y5+y6+y7+y8-y9-y10;
    42. % ys4 = y1+y2+y3+y4+y5+y6+y7-y8-y9-y10;
    43. % ys5 = y1+y2+y3+y4+y5+y6-y7-y8-y9-y10;
    44. % ys6 = y1+y2+y3+y4+y5-y6-y7-y8-y9-y10;
    45. % ys7 = y1+y2+y3+y4-y5-y6-y7-y8-y9-y10;
    46. % ys8 = y1+y2+y3-y4-y5-y6-y7-y8-y9-y10;
    47. % ys9 = y1+y2-y3-y4-y5-y6-y7-y8-y9-y10;
    48. % ys10= y1-y2-y3-y4-y5-y6-y7-y8-y9-y10;
    49. for i=1:2*Nstep+1
    50. fc(i) = 0.0005e6*(i-Nstep-1); %搜索频率
    51. expfreq = exp(j*2*pi*fc(i)*ts*nn);
    52. Data_sin = imag(expfreq);
    53. Data_cos = real(expfreq);
    54. I = Data_sin.*ys1;
    55. Q = Data_cos.*ys1;
    56. IQfreq = fft(I+j*Q);
    57. convIQ = IQfreq .* CA_fre;
    58. peaks(i,:) = abs(ifft(convIQ)).^2;
    59. end
    60. [value_peak codephases]=max(max(peaks));
    61. [value_peak frequencys]=max(max(peaks'));
    62. frequency = fc(frequencys);%中心频率;
    63. codephaseChips = round(1023 - (codephases/11999)*1023);%CA码相位
    64. frequency
    65. codephaseChips
    66. close all;
    67. figure
    68. plot(peaks(frequencys,:),'r-*');
    69. grid on
    70. xlabel('频率');
    71. ylabel('幅度');
    72. %% step5:三围搜索结构
    73. gold_rate = 1.023e6;
    74. ts=1/fs;
    75. tc=1/gold_rate;
    76. b=[1:n];
    77. c=ceil((ts*b)/tc);
    78. 01_036_m

    4.完整MATLAB程序

    matlab源码说明_我爱C编程的博客-CSDN博客

    V

  • 相关阅读:
    执行npm的时候报权限问题的解决方案
    python封印魔法球小游戏
    Sha1,Sha256 哈希(摘要)处理
    时间戳转换为正常时间
    抖音店铺列表接口h5
    [基础服务] [ELK] CentOS7.x安装ELFK / (ElasticSearch + Kibana + Logstash+Filebeat)
    项目实战总结
    Java 进阶IO流(二)
    爬虫工具篇-ProxyBroker-代理IP管理
    王道22数据结构课后习题(第二章2.2.3)
  • 原文地址:https://blog.csdn.net/hlayumi1234567/article/details/127949687