- 1、本文档共34页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
基于_FPGA_的卡尔曼滤波器的设计与实现[毕业论文]
基于 FPGA 的卡尔曼滤波器的设计与实现 姓名:杨秋月 学号:2010202120081 基于FPGA的卡尔曼滤波器的设计与实现 背景知识简介 1.卡尔曼和卡尔曼滤波 2.卡尔曼滤波原理 3.卡尔曼滤波器的实现方法及比较 卡尔曼和卡尔曼滤波 卡尔曼 (Rudolf Emil Kalman) 匈牙利数学家,1930年出生于匈牙利首都布达佩斯。1953,1954年于麻省理工学院分别获得电机工程学士及硕士学位。1957年于哥伦比亚大学获得博士学位。我们现在要学习的卡尔曼滤波器,正是源于他的博士论文和1960年发表的论文《A New Approach to Linear Filtering and Prediction Problems》(线性滤波与预测问题的新方法)。 卡尔曼滤波(Kalman filtering) 当输入由白噪声产生的随机信号时,使期望输出和实际输出之间的均方根误差达到最小的线性系统。 卡尔曼滤波采用状态空间法在时域内设计滤波器,是一种最优估计算法。自从被提出以来,获得了广泛的实际应用,其应用领域包括控制、通讯、信号处理、石油地震勘探、故障诊断、图像处理等。 卡尔曼滤波原理 卡尔曼滤波,是一种线性最小方差估计,特点是考虑了系统的模型误差和测量噪声的统计特性。 设随机线形离散系统的状态方程为: 观测方程为: 式中 为系统的状态向量, 为系统的观测序列, 为系统的过程噪声序列, 为观测噪声序列, 为系统控制输入, 为状态转移矩阵, 为系数矩阵, 为观测矩阵。 卡尔曼滤波原理 因为控制规律 是有规律的信号,可以先不考虑,假设 =0。设k时刻的状态估计值为: 卡尔曼滤波的递推步骤如下所示: 状态一步预测值: 预测误差方差: 滤波增益: 最佳滤波值: 滤波误差方差: 卡尔曼滤波器的实现方法及比较 用DSP处理器实现 在应用中,卡尔曼滤波器通常由DSP处理器来实现。使用DSP处理器具有设计简单灵活,可直接采用C语言矩阵运算的优点,但由于卡尔曼算法在运算中有大量的矩阵加减乘除运算且DSP处理器采用程序顺序执行的CPU架构,在要求较高的场合, 不能满足系统高速、实时的需要。 用FPGA实现 采用的是硬件并行算法,能很好的解决速度和实时性的问题,并且具有灵活的可配置特性和优良的抗干扰能力,使得FPGA构成的数字信号处理系统非常易于修改、测试及硬件升级。 1.FPGA设计简介 一般地,数字滤波器的FPGA实现是用VHDL或Verilog HDL等硬件描述语言通过编写底层代码实现。这种编程方式效率低,难度大。利用 Altera 公司 FPGA 的 DSP 开发工具 DSP Builder 设计卡尔曼滤波器,比基于硬件描述语言的设计周期更短,设计更容易。 设计选用的FPGA是Altera公司CycloneⅡEP2C20Q240C8N , FPGA中I/O端口可自由定义,电路设计方便,编程灵活,不易受外部干扰。系统编译环境采用QuartusⅡ,顶层设计为图形化方式,易实现模块化。FPGA的主要任务是控制AD转换芯片进行数据转换,并从AD芯片中读取转换输出数据,进行卡尔曼滤波处理并输出。 设计思路 本实验以基于现场可编程逻辑门阵列FPGA器件和模数转换器设计的数据采集系统为硬件平台,进行算法设计。基于模块化设计思想,设计了时钟分频模块,AD 转换芯片的 FPGA控制模块和卡尔曼滤波模块。卡尔曼滤波模块采用DSP Builder设计,转换成硬件描述语言VHDL 后,应用软件 Modelsim、QuartusII 进行仿真并完成硬件验证。 基于FPGA的卡尔曼滤波器各功能模块设计 单元功能模块设计 *分频模块 分频模块是将外部时钟进行分频设定,得到系统内部AD控制模块和卡尔曼滤波模块所需要的时钟,并为AD芯片提供时钟信号基准。此模块采用VHDL语言编程实现。这里给出10分频时序仿真图,其中分频模块的外部时钟输入频率为50MHz,产生的时钟频率为5MHz。 * AD 控制模块 ADS8364 的简介与工作原理 采用ADS8364芯片对输入信号数据采样。ADS8364是TI公司的一款高速、低功耗、6路模拟输入、16位并行输出的模数转换器。六路模拟输入分为三组(A,B和C),每个输入端都有一个保持信号来实现所有通道的同时采样与转换功能,适合于多路采集系统的需要。ADS8364的时钟信号由外部提供,转换时间为20个时钟周期,最
文档评论(0)