GPS信号生成:C/A码序列生成【MATLAB实现】

GPS C/A码序列生成【MATLAB实现】

在本文中,将简要介绍GPS C/A码及其生成原理,并且用MATLAB代码实现。

GPS信号与C/A码

GPS的信号主要有三类:载波(carrier)、测距码(也可以说是伪随机噪声码,Pseudo Random Noise,PRN)和导航电文(Navigation message)。GPS卫星在实现定位时就使用以上三种信号进行相应的伪距(Pseudorange)测量或载波相位(Carrier phase)测量。
本文介绍实现伪距测量的一种信号:C/A码(Coarse/Acquisition Code)是用于进行粗略测距和捕获P码的粗码,也称捕获码。周期T为1毫秒,一个周期含有码元即码长N为2^10 - 1=1023,每个码元持续的时间即码元周期t=1 ms/1023=0.977517微秒,相应的码元宽度为293.05米。C/A码是一种公开的明码,可供全球用户免费使用。但C/A码在L1载波上,所以无法精确地消除电离层延迟,测距精度一般为±(2~3)米。C/A码和P码(Precise code)同属PRN码。但是C/A码为民用,P码通常为军用,所以我们在学习和实验时基本上使用的是C/A码。
C/A码有1023个元素(chips),这里面含有512个1与511个0,他们的排列是看起来仿佛随机的,但是却是完全可决定的,因此叫做伪随机噪声序列。

GPS C/A码序列生成原理

GPS C/A码的生成通常需要经过几个步骤:如下图,窄带宽基带信号(baseband signal)经 PRN 码调制后,基带信号的频谱明显变宽。也就是说,信号从narrow bandwidth变成了wide bandwidth。基带信号经过扩频处理后,使用二进制相移键控(BPSK)调制方法对扩频信号进行调制。最后,BPSK 扩频信号与 在L1频段1575.42 MHz 的载波信号一起传输。
GPS C/A码信号生成
GPS的L1频段的码率是50 bps(bit per second)。在这50 bps中,信号的频谱宽度是-50 Hz到50 Hz。另外,C/A码的码率是1.023 MHz,也就是1 ms内可以得到1023 chips的C/A码。
C/A码的生成遵循Gold code原理,这里我放了1967年的论文原文。在C/A码生成时,需要G1和G2两个线性反馈移位寄存器(Linear feedback shift register,LFSR)。每个寄存器都有10位,所以按照Gold code原理生成的序列长度是2^10-1=1023 chips。寄存器G1和G2按照异或(Exclusive or,XOR)的方式生成C/A码序列,如下图所示。一般来说,移位寄存器是一组一位存储单元(存储单元)。在时钟脉冲作用下,每个寄存器的内容将向右移动一位。输出是最后一个单元(最左边的单元或寄存器)的内容。
C/A码序列生成
需要注意的是,G1和G2分别有自己的反馈准则:
反馈准则
对于 G1,在每个时钟脉冲下,寄存器位置 3 和 10 的进行异或运算,并将结果移至寄存器位置 1。其他寄存器向右移动一个位置,最后寄存器位置 10 的内容成为 G1 的输出G1。对于 G2,每个时钟脉冲都会对寄存器位置 2、3、6、7、8、9、10 的进行异或运算,并将结果移至寄存器位置 1。同样,所有其他寄存器的内容也会向右移动一位。然后,选择两个selector,进行异或运算,再offset移位运算,成为G2i。最后,将两个寄存器的输出G1 和 G2i 进行异或,得到每个epoch脉冲上产生的 PRN 码位。
每个PRN对应的selector和offset的选择参考GPS Interface Specification IS-GPS-200 的表,如下图:
在这里插入图片描述
像这样重复运算1023次之后,我们就得到1 ms的C/A码序列。

MATLAB代码实现

附上生成C/A码序列的MATLAB代码,输入PRN号,得到相应的C/A码。

function code = CA_generation(prn)
% Generate the C/A code for a given PRN (1-32)
% Input:
%   prn - PRN number (1-32)
% Output:
%   code - 1023-length C/A code sequence

% Initial states for Linear feedback shift register (LFSR) of length G1 and G2
G1 = ones(1, 10); 
G2 = ones(1, 10);

% PRN taps (satellite-specific tap positions)
prn_taps_table = [
    2, 6;   % PRN1
    3, 7;   % PRN2
    4, 8;   % PRN3
    5, 9;   % PRN4
    1, 9;   % PRN5
    2, 10;  % PRN6
    1, 8;   % PRN7
    2, 9;   % PRN8
    3, 10;  % PRN9
    2, 3;   % PRN10
    3, 4;   % PRN11
    5, 6;   % PRN12
    6, 7;   % PRN13
    7, 8;   % PRN14
    8, 9;   % PRN15
    9, 10;  % PRN16
    1, 4;   % PRN17
    2, 5;   % PRN18
    3, 6;   % PRN19
    4, 7;   % PRN20
    5, 8;   % PRN21
    6, 9;   % PRN22
    1, 3;   % PRN23
    4, 6;   % PRN24
    5, 7;   % PRN25
    6, 8;   % PRN26
    7, 9;   % PRN27
    8, 10;  % PRN28
    1, 6;   % PRN29
    2, 7;   % PRN30
    3, 8;   % PRN31
    4, 9;   % PRN32
];

offset_table=[
    5;
    6;
    7;
    8;
    17;
    18;
    139;
    140;
    141;
    251;
    252;
    254;
    255;
    256;
    257;
    258;
    469;
    470;
    471;
    472;
    473;
    474;
    509;
    512;
    513;
    514;
    515;
    516;
    859;
    860;
    861;
    862;
];

% Validate PRN input
if prn < 1 || prn > 32
    error('PRN must be between 1 and 32.');
end

% Get the taps for the given PRN
selector = prn_taps_table(prn, :);
select1 = selector(1);
select2 = selector(2);

% Get the offset
offset=offset_table(prn,:);

% Generate the C/A code sequence
code = zeros(1, 1023);

for i = 1:1023
    % Generate the code bit (modulo-2 addition of selected G2 taps)
    G1_output = G1(10);
    G2_output = xor(G2(select1), G2(select2)); % Adjust G2 output by offset

    % Shift G1
    feedback1 = xor(G1(3), G1(10));
    G1 = [feedback1, G1(1:end-1)];
    
    % Shift G2
    feedback2 = xor(G2(2), xor(G2(3), xor(G2(6), xor(G2(8), xor(G2(9), G2(10))))));
    G2 = [feedback2, G2(1:end-1)];

    % Apply offset to G2
    G2_shifted = circshift(G2_output, [0, offset]);

    code(i) = xor(G1_output, G2_shifted); % Generate C/A code
end

% Convert 0 to -1 for numerical representation
code = 1 - 2 * code; % Change logic value 0 to +1 and 1 to -1
end

Github小项目在此,实现GPS信号的生成和获取,喜欢的朋友可以给个小星星。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/958737.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

redis离线安装部署详解(包括一键启动)

像上文一样 因为在学习的过程中没有查到一个详细的离线部署方案 所以在自己学习之后想要自己写一个文章 希望可以帮助后续学习redis离线部署的朋友少走一线弯路 首先就是下载安装包 可以自己在本地下载再传到机器上&#xff08;通过xftp或lrzsz都可&#xff09; http://d…

Hadoop•搭建完全分布式集群

听说这里是目录哦 一、安装Hadoop&#x1f955;二、配置Hadoop系统环境变量&#x1f96e;三、验证Hadoop系统环境变量是否配置成功&#x1f9c1;四、修改Hadoop配置文件&#x1f36d;五、分发Hadoop安装目录&#x1f9cb;六、分发系统环境变量文件&#x1f368;七、格式化HDFS文…

安卓动态设置Unity图形API

命令行方式 Unity图像api设置为自动,安卓动态设置Vulkan、OpenGLES Unity设置 安卓设置 创建自定义活动并将其设置为应用程序入口点。 在自定义活动中,覆盖字符串UnityPlayerActivity。updateunitycommandlineararguments (String cmdLine)方法。 在该方法中,将cmdLine…

Java春招面试指南前言

在当今竞争激烈的就业市场中&#xff0c;对于即将踏入职场的Java开发者而言&#xff0c;春招是一次宝贵的机会。本博客专栏旨在为大家提供一份全面且实用的Java春招面试指南&#xff0c;助力大家顺利通过面试&#xff0c;开启职业生涯的新篇章。 无论你是初出茅庐的应届生&…

记录一次k8s起不来的排查过程

我在k8s集群&#xff0c;重启了一个node宿主机&#xff0c;竟然发现kubelet起不来了&#xff01;报错如下 这个报错很模糊&#xff0c;怎么排查呢。这样&#xff0c;开两个界面&#xff0c;一个重启kubelet&#xff0c;一个看系统日志(/var/log/message:centos&#xff0c;/va…

利用Qt5.15.2编写Android程序时遇到的问题及解决方法

文章目录 背景1.文件读写 背景 目前我用的是Qt5.15.2来编写Qt程序&#xff0c;环境的配置看我这篇文章【Qt5.15.2配置Android开发环境】 项目中的一些配置的截图&#xff1a; 1.文件读写 假如直接用 QFileDialog::getExistingDirectory来获取路径的话&#xff0c;会得到类…

JVM深入学习(一)

目录 一.JVM概述 1.1 为什么要学jvm&#xff1f; 1.2 jvm的作用 1.3 jvm内部构造 二.JVM类加载 2.1类加载过程 2.2类加载器 2.3类加载器的分类 2.4双亲委派机制 三.运行时数据区 堆空间区域划分&#xff08;堆&#xff09; 为什么分区(代)&#xff1f;&#xff08…

o1 医学推理:基于推断时长扩展与旅程学习,仅用 500 条蒸馏示例,实现 6%~11% 性能提升

o1 医学推理&#xff1a;基于推断时长扩展与旅程学习&#xff0c;仅用 500 条蒸馏示例&#xff0c;实现 6%&#xff5e;11% 性能提升 论文大纲1. 提出背景是什么&#xff1f;2. 概念的性质是什么&#xff1f;是什么导致这个性质&#xff1f;3. 请举一个正例、一个反例&#xff…

微信小程序隐藏右侧胶囊按钮,分享和关闭即右侧三个点和小圆圈按钮

在微信小程序开发过程中&#xff0c;可能需要将右侧的胶囊按钮、即右侧的三个点和小圆圈按钮关闭掉。如图&#xff1a; 这时&#xff0c;我们只需在该页面的json文件中进行相关配置即可 {"navigationBarTitleText": "商品详情页","navigationStyle&q…

chrome小插件:长图片等分切割

前置条件&#xff1a; 安装有chrome谷歌浏览器的电脑 使用步骤&#xff1a; 1.打开chrome扩展插件 2.点击管理扩展程序 3.加载已解压的扩展程序 4.选择对应文件夹 5.成功后会出现一个扩展小程序 6.点击对应小程序 7.选择图片进行切割&#xff0c;切割完成后会自动保存 代码…

检测到联想鼠标自动调出运行窗口,鼠标自己作为键盘操作

联想鼠标会自动时不时的调用“运行”窗口 然后鼠标自己作为键盘输入 然后打开这个网页 &#xff08;不是点击了什么鼠标外加按键&#xff0c;这个鼠标除了左右和中间滚轮&#xff0c;没有其他按键了&#xff09;

深入MapReduce——计算模型设计

引入 通过引入篇&#xff0c;我们可以总结&#xff0c;MapReduce针对海量数据计算核心痛点的解法如下&#xff1a; 统一编程模型&#xff0c;降低用户使用门槛分而治之&#xff0c;利用了并行处理提高计算效率移动计算&#xff0c;减少硬件瓶颈的限制 优秀的设计&#xff0c…

【大数据】机器学习----------强化学习机器学习阶段尾声

一、强化学习的基本概念 注&#xff1a; 圈图与折线图引用知乎博主斜杠青年 1. 任务与奖赏 任务&#xff1a;强化学习的目标是让智能体&#xff08;agent&#xff09;在一个环境&#xff08;environment&#xff09;中采取一系列行动&#xff08;actions&#xff09;以完成一个…

Android中Service在新进程中的启动流程

目录 1、Service与AMS交互框架介绍 1.1、认识AMS代表IActivityManager 1.2、认识客户端代表IApplicationThread 2、Service启动流程概览 我们知道Android有四大组件&#xff0c;Activity、Service、ContentProvider、Broadcast&#xff0c;每个组件在系统运行中或者我们编写…

华为EC6110T-海思Hi3798MV310_安卓9.0_通刷-强刷固件包

华为EC6110T-海思Hi3798MV310_安卓9.0_通刷-强刷固件包 刷机教程说明&#xff1a; 适用机型&#xff1a;华为EC6110-T、华为EC6110-U、华为EC6110-M 破解总分为两个部分&#xff1a;拆机短接破解&#xff08;保留IPTV&#xff09;和OTT卡刷&#xff08;不保留IPTV&#xff09…

2025.1.20——二、buuctf BUU UPLOAD COURSE 1 1 文件上传

题目来源&#xff1a;buuctf BUU UPLOAD COURSE 1 1 目录 一、打开靶机&#xff0c;查看信息 二、解题思路 step 1&#xff1a;上传一句话木马.php文件康康回显 step 2&#xff1a;蚁剑连接 三、小结 一、打开靶机&#xff0c;查看信息 这里提示到了文件会被上传到./uplo…

移动端VR处理器和传统显卡的不同

骁龙 XR 系列芯片 更多地依赖 AI 技术 来优化渲染过程&#xff0c;而传统的 GPU 渲染 则倾向于在低画质下运行以减少负载。这种设计是为了在有限的硬件资源下&#xff08;如移动端 XR 设备&#xff09;实现高性能和低功耗的平衡。以下是具体的分析&#xff1a; 1. AI 驱动的渲染…

[java] java基础-字符串篇

目录 API String 创建字符串对象的两种方式&#xff1a; Java的内存模型 字符串常量池&#xff08;串池&#xff09;存放地址 两种构造方法的内存分析 String的常用方法 号比较的是什么 字符串比较&#xff08;比较字符串的数据值&#xff09; 遍历字符串 StringBui…

C# 多线程同步(Mutex | Semaphore)

Mutex: 用于保护临界区&#xff0c;确保同一时间只有一个线程能够访问共享资源&#xff1b; Semaphore: 允许同时有多个线程访问共享资源&#xff0c;但会限制并发访问的数量。 Mutex运行输出 Semaphore运行输出 namespace SyncThreadDemo {internal class Program{static stri…

易语言模拟真人鼠标轨迹算法 - 防止游戏检测

一.简介 鼠标轨迹算法是一种模拟人类鼠标操作的程序&#xff0c;它能够模拟出自然而真实的鼠标移动路径。 鼠标轨迹算法的底层实现采用C/C语言&#xff0c;原因在于C/C提供了高性能的执行能力和直接访问操作系统底层资源的能力。 鼠标轨迹算法具有以下优势&#xff1a; 模拟…