### GPS接收机软件开发手册知识点概述
#### 一、FPGA程序开发
##### 1.1 总体构成
FPGA(Field Programmable Gate Array,现场可编程门阵列)是GPS接收机软件开发中的核心组件之一,负责信号处理的关键部分。在GPS接收机软件开发手册中提到的“总体构成”,主要是指FPGA内部各模块的设计布局和它们之间的相互作用。如图1-1所示,整个基带处理FPGA的结构设计包括多个关键模块,例如AD数据采样模块、NCO产生模块、数字下变频模块等,这些模块共同构成了一个完整的信号处理链路。
##### 1.2 基带AD数据采样
基带信号是指未经调制的原始信号,在GPS接收机中,这部分通常指的是从天线接收到的经过放大和滤波后的信号。AD数据采样模块负责将这些模拟信号转换成数字信号,以便后续处理。该模块通常采用高速ADC(模数转换器)来实现,确保能够准确无误地捕捉到信号中的所有细节。
##### 1.3 载波NCO产生模块
NCO(Numerically Controlled Oscillator,数字控制振荡器)用于产生精确的载波频率,这对于信号解调至关重要。载波NCO产生模块通过数字方式生成所需的正弦波或余弦波信号,用于与接收到的信号进行混频操作,从而实现载波恢复的目的。
##### 1.4 码NCO产生模块
除了载波恢复之外,GPS接收机还需要恢复接收信号中的P码(粗码)或C/A码(民用码),这同样需要一个NCO模块来生成相应的参考码序列。码NCO产生模块就是用来生成这种特定的码序列的,它对于实现信号的同步和解码至关重要。
##### 1.5 复相位旋转数字下变频模块
在GPS接收机中,信号需要从高频载波降低到基带频率,这一过程称为下变频。复相位旋转数字下变频模块使用I/Q(In-phase/Quadrature,同相/正交)信号表示方法,通过复数乘法将信号从高频降到基带,同时保留了信号的所有相位信息。
##### 1.6 本地扩频码产生模块
为了从接收到的信号中提取有用的信息,GPS接收机需要与接收到的信号同步,并且需要一个本地扩频码产生模块来生成与卫星发送的扩频码相同的本地码。这个模块产生的码序列用于与接收到的信号进行相关性分析,从而实现信号的解调。
##### 1.7 相关器模块
相关器模块是GPS接收机的核心组件之一,它的作用是对信号进行匹配滤波,通过比较本地码序列与接收到的信号,检测是否存在匹配的部分。当接收到的信号与本地产生的扩频码匹配时,表示已经成功捕获到了目标卫星的信号。
##### 1.8 时基产生模块
时基产生模块用于提供整个系统的时钟基准,这对于确保各个模块之间的时间同步至关重要。在GPS接收机中,时钟的准确性直接影响到信号处理的性能和最终的定位精度。
##### 1.9 GPS帧同步产生模块
GPS信号是由一系列帧组成的,每个帧包含了重要的导航数据。GPS帧同步产生模块的任务是在接收到的信号中识别出帧的边界,这是解码导航数据的基础。
##### 1.10 串口收发模块
串口收发模块负责GPS接收机与外部设备之间的数据交换,如向计算机发送定位结果或从计算机接收配置指令等。
##### 1.11 射频频综SPI配置模块
射频频综SPI配置模块负责配置射频前端的参数,如增益、滤波器设置等,通过SPI(Serial Peripheral Interface,串行外设接口)与射频芯片进行通信。
##### 1.12 FPGA与DSP总线通讯接口
由于FPGA与DSP(Digital Signal Processor,数字信号处理器)通常是GPS接收机系统中的两个重要组成部分,因此它们之间需要有一个高效的通信接口。本手册中提到的总线通讯接口定义了FPGA与DSP之间数据交换的具体机制,包括系统级寄存器定义和GPS通道寄存器寄存器定义等。
#### 二、DSP程序开发
##### 2.1 DSP Bootloader
Bootloader是DSP启动阶段执行的第一段代码,负责初始化硬件环境、加载操作系统或应用程序等任务。本手册中提到了几个关键步骤:
- **备份原始项目文件**:在进行任何更改之前,都需要备份原始的DSP项目工程文件,以防万一出现问题可以恢复。
- **生成Flash烧写数据文件**:将DSP程序编译生成的数据文件烧录到Flash存储器中,确保DSP启动时能够正确加载程序。
- **烧写工程**:通过特定工具将编译好的数据文件写入DSP的Flash存储器。
##### 2.2 DSP软件程序框架设计
- **与硬件接口设计**:定义了DSP与硬件设备交互的接口,包括读取传感器数据、控制外设等。
- **时钟中断**:用于定时触发某些任务或事件,如周期性的数据采集、状态检查等。
- **串口通信**:定义了DSP与外部设备之间通过串口进行数据交换的方式。
- **DSP访问FPGA程序**:描述了DSP如何通过特定接口与FPGA进行数据交换,如读取FPGA处理的结果、向FPGA发送控制指令等。
##### 2.3 DSP软件函数功能
手册中详细列举了多个文件及其包含的函数,这些函数覆盖了从初始化、基本处理到复杂算法的各种功能,具体包括但不限于:
- **GPSystem.c**:主程序文件,包含了初始化和主循环等核心逻辑。
- **Globle_InitFunc.h**:定义了各种初始化函数,如硬件初始化、变量初始化等。
- **Globle_BaseFunc.h**:提供了基本的函数库,如数学运算、数组操作等。
- **Globle_MainFunc.h**:定义了主要的处理函数,如信号解调、数据解析等。
- **GNSS_BaseBandCtrl.h**:处理基带信号相关的函数,如滤波、解调等。
- **COMPort.h**:管理串口通信的函数库。
##### 2.4 定位解算
- **GPS卫星位置计算**:基于GPS卫星星历数据计算卫星的位置,包括位置和速度计算。
- **最小二乘计算接收机位置速度**:利用最小二乘法估算接收机的位置和速度。
- **伪距修正**:对测量得到的伪距进行修正,以提高定位精度,包括钟差修正、电离层时延修正、对流层折射时延修正等。
- **获取导航电文**:从接收到的信号中提取导航电文数据,用于后续的定位计算。
通过以上分析可以看出,《GPS接收机软件开发手册》涵盖了GPS接收机软件开发的各个方面,从硬件接口设计到软件算法实现,提供了全面的技术指导和支持。这对于从事GPS接收机开发的专业人员来说是一份非常有价值的参考资料。