**文章编号:**1004-2474(2017)02-0176-04

# 基于 FPGA 的 MEMS 捷联惯性导航系统设计

张春熹<sup>1</sup>,李胜臣<sup>1</sup>,高 爽<sup>1</sup>,蔡晓雯<sup>1</sup>,陈光建<sup>2</sup>

(1.北京航空航天大学 惯性技术重点实验室,北京 100191;2.中国石油集团 测井有限公司装备与销售分公司,陕西 西安 710077)
 摘 要:针对石油、煤矿等特殊环境中对小型化捷联惯性导航系统的需求,设计并实现了基于现场可编程门阵列

(FPGA)单芯片控制的微机电系统-惯性测量单元(MEMS\_IMU)小型化捷联惯性导航系统。系统采用 ADI 公司的 MEMS\_IMU 作为惯性器件,主控芯片使用 Cyclone III 系列 FPGA,采用可编程片上系统(SOPC)工作模式,最终制成 尺寸 4 cm×11 cm 的捷联惯导系统。系统实现了数据采集、误差补偿、导航解算以及与上位机通信等功能。实验结果 表明,系统能满足在钻井等小尺寸测量环境中使用,连续姿态变换过程中姿态误差小于 2°,实现稳定工作。

**关键词:**微机电系统(MEMS);现场可编程门阵列(FPGA);可编程片上系统(SOPC);捷联惯导系统;小型化 中图分类号:TP368.2;V249.3 **文献标识码:**A

# Design of MEMS Strapdown Inertial Navigation System Based on FPGA

# ZHANG Chunxi<sup>1</sup>, LI Shengchen<sup>1</sup>, GAO Shuang<sup>1</sup>, CAI Xiaowen<sup>1</sup>, CHEN Guangjian<sup>2</sup>

(1. Key Lab. on Inertial Science and Technology, Beihang University, Beijing 100191, China;

2. China Petroleum Group Logging Co. Ltd. Equipment and Sales Branch, Xi'an 710077, China)

Abstract: In view of the requirement of the small size strapdown inertial navigation system in the special environments such as oil, coal mine and so on, a strapdown inertial navigation system based on FPGA single chip control and MEMS IMU is designed in this paper. The system uses ADI MEMS IMU as the inertial component, cyclone III series FPGA as the control chip, and the System on Programmable Chip (SOPC) operating mode to construct a strapdown inertial navigation system with the size of 4 cm×11 cm. The system realizes the functions of data acquisition, error compensation, navigation solution and communication with the host computer. The experimental results show that the system can meet the requirements of small size measurement environments such as drilling etc. The attitude error is less than  $2^{\circ}$  during the attitude changing process with steady operation.

**Key words**: microelectromechanical systems (MEMS); field-programmable gate array (FPGA); system on a programmable chip(SOPC); strapdown inertial navigation; miniaturization

0 引言

当前捷联惯性导航系统得到了越来越广泛的应用<sup>[1]</sup>。随着设备的更新换代和应用范围的扩大,对 其小型化的需要也越来越高。捷联惯导系统主要由 采集角速度和加速度的惯性器件和导航计算机两部 分组成。传统加速度计和陀螺仪如石英挠性加速度 计和光纤陀螺仪已逐渐不能满足捷联惯性导航系统 小型化的需求。随着微机电系统(MEMS)的发展, MEMS 传感器凭借其体积小,质量小,价格低,抗震 动冲击能力强及可靠性高等优点<sup>[2]</sup>,成为惯性器件 的一种新选择,且在中低精度的应用场合得到应用 推广<sup>[3]</sup>。目前广泛使用的数字信号处理与现场可编 程门阵列(DSP+FPGA)的导航计算机设计方案融 合了 FPGA 并行数据采集和 DSP 高速数据处理的 优点<sup>[4-5]</sup>,但却在小型化方面有所欠缺。Altera 公司 推出的 Cyclone III 系列 FPGA 具有 Nios II 软核处 理器系统,Nios II 软核处理器是一种 32 位 RISC 嵌 入式处理器,具有超过 200DMIP 的性能<sup>[6]</sup>,它作为 一种可配置的片上软核完全可以独立实现导航解算 的功能。本文针对目前应用需求,通过微机电系统-

收稿日期:2016-05-22

基金项目:国家重大仪器设备开发专项基金资助项目(2013YQ040877)

作者简介:李胜臣(1989-),男,山东人,硕士生,主要从事捷联惯性导航系统的研究。E-mail: luckylishengchen@163.com。通信作者:高爽 (1980-),女,讲师,硕士生导师,主要从事惯性组合测量,光纤陀螺测斜仪惯测等的研究。E-mail: shuanggao@126.com。 惯性测量单元(MEMS\_IMU)和 FPGA 芯片组合, 从硬件结构和软件算法上根据小型化导航系统要 求,设计出小型化捷联惯性导航系统。实验结果表 明,该设计不仅能满足小型化要求,且能实时稳定 工作。

1 系统总体方案设计

设计的捷联惯导系统包括惯性器件和导航计算 机两部分,传感器采用 MEMS 器件 IMU 采集加速 度和角速度,输出各自感应轴上的加速度和角速度 信息;导航计算机主控芯片采用 Altera 公司的 Cyclone III 系列 FPGA,芯片利用通用 I/O 口采集数 据到芯片内部,再由配置好的软核系统 Nios II 处理 器进行导航解算,解算完成的数据通过 RS-232 串 口通信协议传给上位机显示。图 1 为具体的导航系 统原理图。



图 1 导航系统原理

2 系统硬件设计

IMU 采用 ADI 公司的 MEMS 芯片 ADIS16445, 是一款六自由度惯性测量单元,内置一个三轴陀螺仪 和一个三轴加速度计<sup>[7]</sup>。ADIS16445 采用 SPI 数字 通信接口,实现外部指令输入、数据输出和编程功能。 三轴陀螺的测量范围在±62 (°)/s、±125 (°)/s和 ±250 (°)/s可选择,最低位对应分辨率为 0.002 5 (°)/s;三轴加速度计测量范围±5g (g = 9.8 m/s<sup>2</sup>),最低位对应分辨率为 0.25 mg;对外部 供电要求不高,内部具有高精度稳压电路。 ADIS16445 尺寸 24.1 mm× 37.7 mm×10.8 mm。

处理器是导航计算机的核心,处理器选用 Cyclone III 系列 FPGA 芯片 EP3C25F324C8,该芯片 具有 24 624 个逻辑单元、1 134 kbit Memory、4 个 锁相环,用户可用 I/O 数 215 个,可配置 Nios II 片 上软核处理器,能满足设计需求。

根据 FPGA 芯片配置需求和系统功能需求,设 计的系统硬件结构如图 2 所示。该系统结构主要完 成数据通信、数据处理、存储、高速浮点计算、导航解 算和信号输出等功能。



# 图 2 系统硬件结构

FPGA芯片的内核、锁相环和 I/O 口分别独立 供电,电源要求分别为 1.2 V、2.5 V 和 3.3 V, MEMS\_IMU 需要 3.3 V 供电; FLASH 存储用于 FPGA 芯片 配置 和导航 解算 程序存储,选用 EPCS16 闪存,具有 16 Mbit存储空间; SDRAM 选 择 Micron 公司的 MT48LC4M16,具有 16 Mbit 的 存储空间,在系统工作状态下运行片上软核导航解 算程序并存储解算过程中的数据;系统配置电路采 用 JTAG 和 AS 两种模式; MEMS\_IMU 的 SPI 数 据接口直接与 FPGA 通用 I/O 口连接,与上位机的 RS-232 通信选择 SP3232 收发器作为解决方案。

3 系统软件设计

## 3.1 FPGA 逻辑模块设计

FPGA 逻辑模块具备并行运算的能力,在信号 采集传输过程中具有独特的优势,需要完成的任务 包括:产生各个模块所需时钟信号,通过 SPI 协议采 集 IMU 数据并发送给片上软核,接收软核数据并 通过 RS-232 协议发送给上位机。FPGA 逻辑模块 设计包括时钟逻辑模块设计、SPI 逻辑模块设计和 RS-232 逻辑模块设计 3 部分。

3.1.1 时钟逻辑模块设计

时钟逻辑模块通过配置引脚接收晶振时钟信号,通过分频或移相产生如下时钟信号:

1) 锁相环倍频,产生 73.728 MHz 时钟信号提供给片上软核;分频产生 5 kHz 时钟信号提供给SPI 采数模块,用作 SPI 时钟。

2) 分频产生 5 kHz 时钟信号提供给 SPI 模块, 用作 SPI 采数信号。

3) 分频产生 115 200 Hz 信号提供给 RS-232 模块,用作 RS-232 协议波特率信号。

4) 对倍频产生的 73.728 MHz 的时钟信号进 行一70°移相,作为 SDRAM 的时钟信号。

3.1.2 SPI 逻辑模块设计

SPI 总线是一种同步串行通信总线,其数据采 集程序为主模式,分为地址发送和数据接收两部分, 在 MEMS\_IMU ADIS16445 的低速采集模式下,设 置同步时钟 500 kHz,采数频率 5 kHz。SPI 作为一 种双工通信协议,在片选信号拉低时发送 16 bit 地 址并接收 16 bit 数据,每次采集的数据对应上次发 送的地址,所以,在每次发送地址时产生一个伴随地 址的 8 bit 的标志信号,每次采集的数据根据当前标 志信号判断数据意义,共采集三轴陀螺、三轴加表和 温度 7 组数据,其时序如图 3 所示。数据与标志信 号以中断和总线形式同时发送给片上软核。



3.1.3 RS-232 逻辑模块设计

RS-232 模块负责系统与上位机的数据通信,将 原始的三轴陀螺和三轴加速度计数据及经片上软核 解算后的温度、横滚角、俯仰角、航向角、东北天向速 度、经度、纬度和高度 16 组 16 bit 数据发送给上位 机。该模块采用中断模式接收来自片上软核的数据, 中断产生时该模块接收的 16 bit 数据信号和 8 bit 标 志信号,根据标志信号区分数据意义,然后将数据分 类并拆分成 8 bit 放到各自寄存器,同时设置 8 bit 数 据帧头 0xab、帧尾 0xba(数据帧头、帧尾可由自己定 义),一帧数据共计 34 个 8 bit 数据。以 500 Hz 的发 数频率和 115 200 的通信波特率发送数据到上位机。

#### 3.2 Nios II 软核设计

Nios II 片上软核完成导航解算的任务,软核处 理器未固化到硅片,可利用软件对其进行配置<sup>[8]</sup>。 除添加软核自身所需模块 CPU、sysid、epcs、jtag、 sdram外,根据其按中断接收和发送数据的模式,采 用 PIO 内核方式添加数据输入中断、数据输入总 线、数据输入标志总线,数据输出中断、数据输出总 线和数据输出标志总线,其内部结构及外部接口如 图 4 所示。



图 4 Nios II 软核处理器结构和接口

#### 3.3 导航解算程序设计

本设计采用的 MEMS\_IMU 在±125°的转速下 初始灵敏度为 0.005 (°)/s/LSB(LSB 为最低有效 位),与地球转速在同 1 个数量级,初始对准较难,故 而采用固定初始姿态作为导航解算的初始条件,将 惯组放置在标准的转台上,写入初始姿态信息,进行 解算。

导航解算程序需要完成原始数据处理、误差补 偿和导航解算功能,求出载体的姿态、速度和位置信 息。一帧 MEMS\_IMU 原始数据包括三轴陀螺仪 数据、三轴加速度计数据和温度,根据数据手册说明 进行补码变换,然后进行补偿。采用四元数描述载 体姿态,用毕卡法更新四元数,得到实时的姿态信息 和捷联矩阵,然后根据捷联矩阵解算得出速度和位 置信息。解算流程图如图 5 所示。



图 5 导航解算流程

#### 4 实验及数据分析

将设计的小型化捷联惯导系统放置在标准的实验转台上,确定初始位置后开机,在已知初始位置的 条件下(方位角、俯仰角和横滚角均为 0°),静态测试 5 min,其姿态误差随时间变换如图 6 所示。



30

45

29.78

45.59

对系统进行姿态的连续测量,分别在 3 个轴向 上旋转 5°、10°、15°、20°、30°、45°,测量系统输出数 据,并与真值进行比较,结果如表 1 所示。

| · · · · · · · · · · · · · · · · · · · |       |         |       |         |       |
|---------------------------------------|-------|---------|-------|---------|-------|
| 俯仰角/(°)                               |       | 橫滚角/(°) |       | 方位角/(°) |       |
| 真值                                    | 测量    | 真值      | 测量    | 真值      | 测量    |
| 5                                     | 5.27  | 5       | 5.82  | 5       | 5.45  |
| 10                                    | 11.18 | 10      | 11.02 | 10      | 9.99  |
| 15                                    | 13.75 | 15      | 14.10 | 15      | 16.84 |
| 20                                    | 19.96 | 20      | 20.72 | 20      | 19.36 |
|                                       |       |         |       |         |       |

30.62

43.65

30

45

30.39

43 90

30

45

表1 连续测量姿态角

由实验数据(见表 1)可知,在静态条件下测试 5 min,系统姿态误差最大 1.8°;在姿态连续变换测 量实验中,俯仰角、横滚角和航向角误差变换范围在 2°内。从长时间的测量结果得知,系统在较短时间 内导航解算结果较好,长时间运行会产生严重的发 散误差,主要原因为:

1) 选用的 MEMS\_IMU 为低成本器件,精度 较低。

2) 捷联惯导系统为发散系统,存在误差积累效应<sup>[9]</sup>,误差会随着时间变大。

5 结束语

本文针对目前对小型化捷联惯导系统的需求, 设计了基于 MEMS 惯性组合测量单元和 FPGA 单 芯片导航解算的小型化捷联惯导系统,详细描述系 统的硬件实现方法,充分利用 FPGA 并行计算和 Nios II 软核可由用户配置的特点,用 FPGA 逻辑模 块实现 MEMS 数据采集和与上位机的 RS-232 通 信,设计了导航解算程序的算法流程,自定义 Nios II软核并在其内部实现导航解算程序。根据 设计对制成样机进行测试,在标准实验转台上的实 验数据验证了方案的可行性,为捷联惯导系统的小 型化提供了参考。

## 参考文献:

- [1] EIGIZAWY M L. Contunuous measurement-while-drilling surveying system utilizing MEMS inertial sensors[D]. Qttawa:Qttawa University of Cal-gary,2009.
- [2] 李荣冰,刘建业,曾庆化,等. 基于 MEMS 技术的微型 惯性导航系统的发展现状[J].中国惯性技术学报, 2004,12(6):526-529.

LI Rongbing, LIU Jianye, ZENG Qinghua, et al. Present development situation on micro inertial navigation system based on MEMS technology[J]. Journal of Chinese Inertial Technology, 2004, 12(6):526-529.

- [3] MONTORSI F, PANCALDI F, VITETTA G M. Design and implementation of an inertial navigation system for pedestrians based on a low-cost MEMS IMU
   [C]//S. l. ; Communications Workshops (ICC), 2013
   IEEE International Conference on, IEEE, 2015; 57-61.
- [4] 郭韶华, 吴秋平, 马让奎,等. 基于 DSP 和 FPGA 的 导航计算机设计[D]. 北京:清华大学,2011.
- [5] 杨春雷.无人机捷联惯性/全光自主组合导航系统研究 [J].四川兵工学报,2015(11):4-7.
- [6] 刘田豹. Cyclone Ⅲ系列 FPGA 器件的硬件设计[J]. 电 源技术应用,2010(10):16-19.
   LIU Tianbao. Hardware design of Cyclone series FP-GA devices [J]. Power Supply Technologies and Applications,2010(10):16-19.
- [7] 梁海波,司文杰,刘志华,等. 基于 SOPC 的 MEMS 组 合导航仪设计与实现[J]. 航天控制,2014,2(2):3-8.
  LIANG Haibo, SI Wenjie, LIU Zhihua, et al. Design and implementation of MEMS integrated navigation based on SOPC[J]. Aerospace Control,2014,2(2): 3-8.
- [8] 杨国林. 基于 Nios Ⅱ 处理器的 SOPC 应用平台的研究 与应用[D]. 济南:山东大学,2008.
- [9] OGAWA I. A quasi-optical system for converting TE mode out puts of a gyrotron into Gaussian beams[J]. Int Infrared Millim, 2002, 23:189-203.