[学习] RTKLib详解:qzslex.c、rcvraw.c与solution.c

RTKLib详解:qzslex.crcvraw.csolution.c


本文是 RTKLlib详解 系列文章的一篇,目前该系列文章还在持续总结写作中,以发表的如下,有兴趣的可以翻阅。

[学习] RTKlib详解:功能、工具与源码结构解析
[学习]RTKLib详解:pntpos.c与postpos.c
[学习]RTKLib详解:rtkcmn.c与rtkpos.c
[学习]RTKLib详解:ppp.c与ppp_ar.c
[学习]RTKLib详解:ephemeris.c与rinex.c
[学习]RTKLib详解:sbas.c与rtcm.c
[学习]RTKLib详解:rtksvr.c与streamsvr.c
[学习]RTKLib详解:convkml.c、convrnx.c与geoid.c
[学习]RTKLib详解:datum.c、download.c与lambda.c
[学习]RTKLib详解:ionex.c、options.c与preceph.c
[学习] RTKLib详解:qzslex.c、rcvraw.c与solution.c
[学习] RTKLib详解:rtcm2.c、rtcm3.c、rtcm3e与rtcmn.c


文章目录

  • RTKLib详解:`qzslex.c`、`rcvraw.c`与`solution.c`
    • Part A: qzslex.c 文件解析
      • 一、文件整体说明
      • 二、执行流程与函数调用关系
      • 三、主要函数说明
        • 3.1 `lex_init`
        • 3.2 `lex_read_frame`
        • 3.3 `lex_check_crc`
        • 3.4 `lex_decode_frame`
      • 四、关键算法数学原理与推导
        • LEX 信号电文结构
    • Part B: rcvraw.c 文件解析
      • 一、文件整体说明
      • 二、执行流程与函数调用关系
      • 三、主要函数说明
        • 3.1 `raw_init`
        • 3.2 `raw_read`
        • 3.3 `raw_parse`
        • 3.4 `raw_output`
      • 四、关键算法数学原理与推导
        • 观测值时间戳同步
    • Part C: solution.c 文件解析
      • 一、文件整体说明
      • 二、执行流程与函数调用关系
      • 三、主要函数说明
        • 3.1 `sol_init`
        • 3.2 `sol_load_obs`
        • 3.3 `sol_update`
        • 3.4 `sol_output`
      • 四、关键算法数学原理与推导
        • 卡尔曼滤波观测方程


Part A: qzslex.c 文件解析

一、文件整体说明

qzslex.c 是 RTKLIB 中用于解析 QZSS(Quasi-Zenith Satellite System)LEX(L-band EXperimental)信号的模块。该文件实现了从原始信号数据中提取导航电文、星历信息和时钟校正参数的功能,支持日本准天顶卫星系统(QZSS)的高精度定位。

主要功能:

  • 解析 QZSS LEX 信号电文。
  • 提取星历参数、时钟偏差和电离层校正信息。
  • 支持 LEX 数据 CRC 校验与帧同步。

主要特色:

  • 支持 QZSS 多频段信号(L1/L2/L5/LEX)。
  • 高效的位操作与电文解码算法。
  • 可扩展至未来新型 GNSS 信号。

二、执行流程与函数调用关系

程序执行流程如下:

  1. 初始化 LEX 信号解析器。
  2. 逐帧读取原始信号数据。
  3. 执行 CRC 校验与帧同步。
  4. 解码电文内容并提取参数。

函数调用关系如下:

main
lex_init
lex_read_frame
lex_check_crc
lex_decode_frame
lex_output_data

三、主要函数说明

3.1 lex_init
int lex_init(lex_t *lex)

功能:
初始化 LEX 信号解析器,设置默认参数。

输入参数:

  • lex: LEX 数据结构体指针。

返回值:

  • 成功返回 1,失败返回 0。

3.2 lex_read_frame
int lex_read_frame(FILE *fp, unsigned char *buff, int *len)

功能:
从文件或流中读取 LEX 信号帧数据。

输入参数:

  • fp: 文件指针。
  • buff: 缓冲区。
  • len: 输出读取长度。

返回值:

  • 成功返回字节数,失败返回负值。

3.3 lex_check_crc
int lex_check_crc(const unsigned char *buff, int len)

功能:
验证 LEX 帧的 CRC 校验码。

输入参数:

  • buff: 数据缓冲区。
  • len: 数据长度。

返回值:

  • 校验成功返回 1,失败返回 0。

3.4 lex_decode_frame
int lex_decode_frame(const unsigned char *buff, lex_data_t *data)

功能:
解码 LEX 帧电文,提取星历、时钟等参数。

输入参数:

  • buff: 解析后的帧数据。
  • data: 输出参数存储结构体。

返回值:

  • 成功返回 1,失败返回 0。

四、关键算法数学原理与推导

LEX 信号电文结构

LEX 信号采用前向纠错编码(FEC)和交织技术,电文结构包含:

  • 帧头(8 bit): 标识帧起始。
  • 数据域(N bit): 星历参数、时钟校正等。
  • CRC 校验(24 bit): 使用多项式 x 24 + x 23 + x 18 + x 17 + x 14 + x 11 + x 10 + x 6 + x 5 + x 4 + x 3 + x + 1 x^{24} + x^{23} + x^{18} + x^{17} + x^{14} + x^{11} + x^{10} + x^6 + x^5 + x^4 + x^3 + x + 1 x24+x23+x18+x17+x14+x11+x10+x6+x5+x4+x3+x+1

CRC 校验公式为:

CRC ( D ) = ( D ⋅ x 24 ) m o d G ( x ) \text{CRC}(D) = \left(D \cdot x^{24}\right) \mod G(x) CRC(D)=(Dx24)modG(x)

其中 G ( x ) G(x) G(x) 为上述多项式。


Part B: rcvraw.c 文件解析

一、文件整体说明

rcvraw.c 是 RTKLIB 中用于解析接收机原始观测数据的核心模块。它支持多种接收机格式(如 UBX、RTCM、BINEX),将原始二进制数据转换为内部观测结构,为后续处理提供基础。

主要功能:

  • 解析接收机原始数据流。
  • 支持多频段、多系统观测值提取。
  • 提供时间戳同步与数据校验。

主要特色:

  • 自动探测输入数据格式。
  • 支持实时流与文件模式。
  • 高效的数据缓存与解析机制。

二、执行流程与函数调用关系

程序执行流程如下:

  1. 读取原始数据流并识别格式。
  2. 解析观测值、星历和校正信息。
  3. 将数据转换为 RTKLIB 内部结构。
  4. 输出观测数据与状态信息。

函数调用关系如下:

main
raw_init
raw_read
raw_parse
raw_output

三、主要函数说明

3.1 raw_init
int raw_init(raw_t *raw, int format)

功能:
初始化接收机原始数据解析器,指定数据格式。

输入参数:

  • raw: 原始数据结构体。
  • format: 数据格式(如 FORMAT_UBX)。

返回值:

  • 成功返回 1,失败返回 0。

3.2 raw_read
int raw_read(FILE *fp, unsigned char *buff, int nmax)

功能:
从文件或流中读取原始数据。

输入参数:

  • fp: 文件指针。
  • buff: 缓冲区。
  • nmax: 最大读取长度。

返回值:

  • 成功返回字节数,失败返回负值。

3.3 raw_parse
int raw_parse(raw_t *raw, int type, const unsigned char *buff, int len)

功能:
解析原始数据,识别消息类型并填充结构体。

输入参数:

  • raw: 解析器结构体。
  • type: 消息类型(如 MSG_NAV_PVT)。
  • buff: 数据缓冲区。
  • len: 数据长度。

返回值:

  • 成功返回 1,失败返回 0。

3.4 raw_output
int raw_output(raw_t *raw, FILE *fp)

功能:
将解析后的观测数据写入输出文件或流。

输入参数:

  • raw: 解析器结构体。
  • fp: 输出文件指针。

返回值:

  • 成功返回 1,失败返回 0。

四、关键算法数学原理与推导

观测值时间戳同步

接收机时间戳 t r e c v t_{recv} trecv 与 GPS 时间 t G P S t_{GPS} tGPS 的关系为:

t G P S = t r e c v + Δ t u t c t_{GPS} = t_{recv} + \Delta t_{utc} tGPS=trecv+Δtutc

其中 Δ t u t c \Delta t_{utc} Δtutc 是 UTC 与 GPS 时间的闰秒修正值,需通过星历或头文件获取。


Part C: solution.c 文件解析

一、文件整体说明

solution.c 是 RTKLIB 中用于 GNSS 定位解算的核心模块。它实现了从观测数据到最终位置、速度、时间(PVT)的求解过程,支持单点定位(SPP)、差分定位(DGPS)和实时动态定位(RTK)等多种模式。

主要功能:

  • 计算卫星位置与钟差。
  • 实现观测方程与参数估计。
  • 支持多种解算模式(SPP/DGPS/RTK)。

主要特色:

  • 支持多频段、多系统联合解算。
  • 高精度卡尔曼滤波器实现。
  • 可视化解算状态与质量指标。

二、执行流程与函数调用关系

程序执行流程如下:

  1. 初始化解算器与状态向量。
  2. 加载观测数据与星历信息。
  3. 构建观测方程并更新卡尔曼滤波器。
  4. 输出解算结果与协方差矩阵。

函数调用关系如下:

main
sol_init
sol_load_obs
sol_update
sol_output

三、主要函数说明

3.1 sol_init
int sol_init(sol_t *sol, int mode)

功能:
初始化解算器,设置解算模式(SPP/RTK)。

输入参数:

  • sol: 解算器结构体。
  • mode: 解算模式(如 SOL_MODE_RTK)。

返回值:

  • 成功返回 1,失败返回 0。

3.2 sol_load_obs
int sol_load_obs(const obs_t *obs, const nav_t *nav, sol_t *sol)

功能:
加载观测数据与导航数据到解算器。

输入参数:

  • obs, nav: 观测与导航数据。
  • sol: 解算器结构体。

返回值:

  • 成功返回 1,失败返回 0。

3.3 sol_update
int sol_update(sol_t *sol)

功能:
执行一次解算迭代,更新状态向量与协方差矩阵。

输入参数:

  • sol: 解算器结构体。

返回值:

  • 成功返回 1,失败返回 0。

3.4 sol_output
int sol_output(const sol_t *sol, FILE *fp)

功能:
将解算结果(位置、速度、状态)写入文件。

输入参数:

  • sol: 解算器结构体。
  • fp: 输出文件指针。

返回值:

  • 成功返回 1,失败返回 0。

四、关键算法数学原理与推导

卡尔曼滤波观测方程

观测方程为:

y = H x + v \mathbf{y} = \mathbf{H} \mathbf{x} + \mathbf{v} y=Hx+v

其中:

  • y \mathbf{y} y: 观测向量(伪距、载波相位等)。
  • H \mathbf{H} H: 设计矩阵(几何距离对状态变量的偏导数)。
  • x \mathbf{x} x: 状态向量(位置、速度、模糊度等)。
  • v \mathbf{v} v: 观测噪声。

卡尔曼增益更新公式为:

K = P H T ( H P H T + R ) − 1 \mathbf{K} = \mathbf{P} \mathbf{H}^T \left( \mathbf{H} \mathbf{P} \mathbf{H}^T + \mathbf{R} \right)^{-1} K=PHT(HPHT+R)1

其中 P \mathbf{P} P 为状态协方差矩阵, R \mathbf{R} R 为观测噪声协方差矩阵。


研究学习不易,点赞易。
工作生活不易,收藏易,点收藏不迷茫 :)


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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

移植RTOS,发现任务栈溢出怎么办?

目录 1、硬件检测方法 2、软件检测方法 3、预防堆栈溢出 4、处理堆栈溢出 在嵌入式系统中,RTOS通过管理多个任务来满足严格的时序要求。任务堆栈管理是RTOS开发中的关键环节,尤其是在将RTOS移植到新硬件平台时。堆栈溢出是嵌入式开发中常见的错误&am…

window 显示驱动开发-使用有保证的协定 DMA 缓冲区模型

Windows Vista 的显示驱动程序模型保证呈现设备的 DMA 缓冲区和修补程序位置列表的大小。 修补程序位置列表包含 DMA 缓冲区中命令引用的资源的物理内存地址。 在有保证的协定模式下,用户模式显示驱动程序知道 DMA 缓冲区和修补程序位置列表的确切大小,…

SD-HOST Controller design-----SD CLK 设计

hclk的分频电路,得到的分频时钟作为sd卡时钟。 该模块最终输出两个时钟:一个为fifo_sd_clk,另一个为out_sd_clk_dft。当不分频时,fifo_sd_clk等于hclk;当分频时候,div_counter开始计数,记到相应分频的时候…

完全背包问题中「排列数」与「组合数」的核心区别

🎯 一句话理解 求组合数(不计顺序) → 外层遍历物品,内层遍历背包容量 求排列数(计顺序) → 外层遍历背包容量,内层遍历物品 🎲 举例说明 假设有硬币 [1, 2, 3],目标金…

NHANES指标推荐:MDS

文章题目:The association between magnesium depletion score (MDS) and overactive bladder (OAB) among the U.S. population DOI:10.1186/s41043-025-00846-x 中文标题:美国人群镁耗竭评分 (MDS) 与膀胱过度活动症…

C++:字符串操作函数

strcpy() 功能&#xff1a;把一个字符串复制到另一个字符串。 #include <iostream> #include <cstring> using namespace std;int main() {char src[] "Hello";char dest[10];strcpy(dest, src);cout << "Copied string: " << …

1基·2台·3空间·6主体——蓝象智联解码可信数据空间的“数智密码”

近日&#xff0c;由全国数据标准化技术委员会编制的《可信数据空间 技术架构》技术文件正式发布&#xff0c;标志着我国数据要素流通体系向标准化、规范化迈出关键一步。该文件从技术功能、业务流程、安全要求三大维度对可信数据空间进行系统性规范&#xff0c;为地方、行业及企…

基于TI AM6442+FPGA解决方案,支持6网口,4路CAN,8个串口

TI AM6442FPGA解决方案具有以下技术优势及适用领域&#xff1a; 一、技术优势 ‌异构多核架构‌&#xff1a;AM6442处理器集成7个内核&#xff08;2xCortex-A534xCortex-R5F1xCortex-M4F&#xff09;&#xff0c;可实现应用处理、实时控制和独立任务分核协同&#xff0c;满足…

android vlc播放rtsp

最近在做IOT开发&#xff0c;需要把IOT设备的RTSP流在手机端播放&#xff0c;VLC是个不错的选择&#xff0c;使用起来简单方便。 1、在AndroidManifest.xml 中添加网络权限 <uses-permission android:name"android.permission.INTERNET"/> <uses-permissi…

前端面经 9 JS中的继承

借用Class实现继承 实现继承 extends super extends 继承父类 super调用父类的构造函数 子类中存在方法采取就近原则 &#xff0c;子类构造函数需要使用super()调用父类的构造函数 JS 静态属性和私有属性 寄生组合式继承

jQuery知识框架

一、jQuery 基础 核心概念 $ 或 jQuery&#xff1a;全局函数&#xff0c;用于选择元素或创建DOM对象。 链式调用&#xff1a;多数方法返回jQuery对象&#xff0c;支持连续操作。 文档就绪事件&#xff1a; $(document).ready(function() { /* 代码 */ }); // 简写 $(function…

【HCIA】BFD

前言 前面我们介绍了浮动路由以及出口路由器的默认路由配置&#xff0c;可如此配置会存在隐患&#xff0c;就是出口路由器直连的网络设备并不是运营商的路由器&#xff0c;而是交换机。此时我们就需要感知路由器的存活状态&#xff0c;这就需要用到 BFD&#xff08;Bidirectio…

前端流行框架Vue3教程:18. _组件数据传递

透传 Attributes 透传attribute指的是传递给一个组件&#xff0c;却没有被该组件声明为props或emits的attribute或者v-on事件监听器。最常见的例子就是class、style和id 当一个组件以单个元素为根作渲染时&#xff0c;透传的attribute会自动被添加到根元素上 透传 Attributes …

卓力达电铸镍网:精密制造与跨领域应用的创新典范

目录 引言 一、电铸镍网的技术原理与核心特性 二、电铸镍网的跨领域应用 三、南通卓力达电铸镍网的核心优势 四、未来技术展望 引言 电铸镍网作为一种兼具高精度与高性能的金属网状材料&#xff0c;通过电化学沉积工艺实现复杂结构的精密成型&#xff0c;已成为航空航天、电…

1.2.3.2 数据安全发展历程-大数据安全产品领域

从电商到物流&#xff1a;中国大数据安全产品如何进化&#xff1f; 在数字化时代&#xff0c;我们的一举一动都可能被记录——购物记录、聊天信息、位置轨迹……这些数据不仅关系到个人隐私&#xff0c;更涉及企业运营和国家安全的命脉。近年来&#xff0c;随着数据的爆发式增长…

服务器性能参数分析基础:磁盘-CPU-内存

在Linux系统中&#xff0c;"挂载"&#xff08;Mount&#xff09;是指将物理存储设备&#xff08;如磁盘分区&#xff09;或逻辑存储卷&#xff08;如LVM、网络存储&#xff09;关联到文件系统目录树的特定路径节点&#xff08;即挂载点&#xff09;&#xff0c;使得该…

密码学刷题小记录

base 64 打开后发现是一串字符串&#xff0c;&#xff0c;我们直接进行base64解密即可 Caesar 根据标题分析&#xff0c;我们知道这是凯撒解密&#xff0c;拖进去经过尝试在偏移量为12时直接得解&#xff08;这道题就是找偏移量比较麻烦&#xff09; Morse 这道题打开后&am…

Spring框架(三)

目录 一、JDBC模板技术概述 1.1 什么是JDBC模板 二、JdbcTemplate使用实战 2.1 基础使用&#xff08;手动创建对象&#xff09; 2.2 使用Spring管理模板类 2.3 使用开源连接池&#xff08;Druid&#xff09; 三、模拟转账开发 3.1 基础实现 3.1.1 Service层 3.1.2 Da…

[计算机网络]网络层

文章目录 408考研大纲IPV4数据报格式协议: IPv4 地址DHCP协议IP组播 408考研大纲 IPV4数据报格式 协议: 1:ICMP 6:TCP 17:UDP IPv4 地址 特殊IP 网络号全1又称直接广播地址&#xff0c;32位全1又称受限广播地址 因为255.255.255.255只能在本网络内广播&#xff0c;路由器不…

影楼精修-肤色统一算法解析

注意&#xff1a;本文样例图片为了避免侵权&#xff0c;均使用AIGC生成&#xff1b; 本文介绍影楼精修中肤色统一算法的实现方案&#xff0c;并以像素蛋糕为例&#xff0c;进行分析说明。 肤色统一就是将人像照片中皮肤区域的颜色进行统一&#xff0c;看起来颜色均匀一致&…