电赛一等奖!基于TMS320F2812的简易数字频率计

电赛一等奖!简易数字频率计设计(原理图、PCB、源码、分析报告)

        这份文件是关于合肥工业大学电气与自动化工程学院的一个项目报告,题目为“基于TMS320F2812的简易数字频率计”。项目由方敏、侯其立、李苗、张巧云四位本科生完成,指导教师为徐科军教授。以下是该项目报告的核心内容概述:

项目背景与目的:

  • 频率测量在多个领域非常重要,因此高精度、宽量程的数字频率计成为了关键的测量工具。
  • 项目设计采用了多周期测量原理,通过标准频率信号填充被测信号的整数个周期,以消除计数误差,提高测量精度。

系统设计与实现:

  • 选用了TMS320F2812型号的DSP芯片作为核心处理单元,利用其高精度时钟和快速运算能力。
  • 结合DSP芯片的事件管理器,如捕获单元、定时/计数单元、比较单元和脉宽调制电路PWM,实现了高精度的频率测量及脉宽和占空比的测量。

系统指标与性能:

  • 系统设计满足了高精度测量的要求,具体性能指标包括幅度范围、频率范围、最大相对误差等。
  • 系统在保证最大相对误差的前提下,尽可能扩大了测量范围。

测量方法及理论误差分析:

  • 详细介绍了频率测量、脉宽和占空比测量以及幅值测量的方法和理论误差分析。
  • 讨论了量化误差、测量原理误差和标准频率误差对测量结果的影响。

摘要

        频率测量用途非常广泛,高精度、宽量程的数字频率计因而成为重要的测量仪器。本设
计采用多周期测量原理,即用标准频率信号填充整数个周期的被测信号,从而消除了被测信
号+1 的计数误差,其测量精度仅与门控时间和标准频率有关,克服传统的直接测频或者直
接测周法均不能全面满足高精度要求的缺陷。选用 TMS320F2812 型号的 DSP 芯片作为核心处
理单元,结合其高精时钟和快速运算的优点,充分利用其内部的事件管理器:捕获单元,定
时/计数单元,比较单元,脉宽调制电路 PWM,实现高精度的频率测量,并且实现了脉宽和
占空比的测量。
关键词:
高精度频率测量;脉宽和占空比测量;多周期测量原理;DSP ;
系统组成
系统主要是由电源管理模块,输入调理模块,信号处理模块,通讯模块和 D 触发器组
成,如图 所示
信号处理部分
本设计中采用的 DSP 芯片型号为 TMS320F2812,它是到目前为止 C2000 系列中性能最强
大的一代产品。系统中,F2812 协调整个系统各模块的有序工作,并且承担着信号处理的任
务。
系统软件设计
系统软件设计采取模块化设计方案,将完成特定功能或者类似功能的子程序组合成功能
模块,主要功能模块有:初始化模块、中断模块、频率测量模块、脉宽测量模块、SCI 通信
模块以及看门狗模块等,由主监控程序统一调用,协调各个部分正常有序工作。软件系统功
能框图如图所示。
关键程序:
EV 配置程序:
void InitEv(void)
{
EvaRegs.GPTCONA.all = 0;
EvbRegs.GPTCONB.all = 0;
EvaRegs.EXTCONA.bit.INDCOE=1;//
EvaRegs.GPTCONA.bit.T1CTRIPE = 1;//使能定时器 1 输出切断功能
EvaRegs.GPTCONA.bit.T1CMPOE = 1;//使能 T1 比较输出,允许独立使能禁止
//将通用定时器 1 的比较输出设置成低电平有效
EvaRegs.GPTCONA.bit.T1PIN = 1;
// 将定时器 1 设置成连续增计数模式外部时钟,使能 T1 比较
EvaRegs.T1CON.all = 0x101a;
EvaRegs.T1PR=0xffff;
EvaRegs.T1CMPR=1;
// 将定时器 2 设置成连续增计数模式 4 分频,内部时钟
EvaRegs.T2CON.all = 0x1288;
EvaRegs.T2PR = 0xffff;
EvbRegs.T3PR = 0xffff;
EvbRegs.T3CMPR =30000;//T3CMPR 设置为 10000 预置时间
EvbRegs.T4PR=0xffff;
EvbRegs.T4CON.all=0x1000; //T4 使用内部时钟
EvaRegs.CAPCONA.all= 0x04E4; //CAP3 时基为 T1,检测上边沿, CAP1 时基为 T2 ,检
测两个边沿
EvbRegs.CAPCONB.all=0x0064; //CAP4 上升沿 cap5 下降沿,时基 T4
}
主循环程序:
while(1)
{
//***开始测量频率
EvaRegs.CAPCONA.bit.CAP12EN = 1;//使能捕获 1
//实验发现,使能捕获 1 后 CAP1FIFO 会变成 2,故重新复位
EvaRegs.CAPFIFOA.bit.CAP1FIFO=0;
EvaRegs.CAPFIFOA.bit.CAP3FIFO=0;
EvaRegs.T1CON.bit.TENABLE=1;//使能 T1、T2
while(EvaRegs.EVAIFRA.bit.T1CINT!=1)KickDog();//等待 T1 发生比较匹配
t1cint_isr();
while(EvbRegs.EVBIFRA.bit.T3CINT!=1);//等待 T3 发生比较匹配
t3cint_isr();
while(EvaRegs.EVAIFRA.bit.PDPINTA != 1 )KickDog();//等待 PDPINTA 置位
pdpinta_isr();
//***频率测量结束,禁止定时器和捕获
EvaRegs.T1CON.bit.TENABLE=0;//禁止 T1、T2
EvaRegs.CAPCONA.bit.CAP12EN=0;//禁止捕获 1
EvaRegs.CAPCONA.bit.CAP3EN=0;//禁止捕获 3
//***计算频率周期
Freaa[n_celiang]=150000000.0*(65536.0*t1ofcount+t1_2-1)/((4.0*2)*(t2_2+t2ofcoun
t*65536.0-t2_1));
Taa[n_celiang]=1.0/Freaa[n_celiang];
GpioDataRegs.GPASET.bit.GPIOA0 = 1;//写 1 给 GPIOA0 口
//***开始测量脉宽
EvbRegs.CAPFIFOB.bit.CAP4FIFO=1;//置 CAP4FIFO 为 1
EvbRegs.T4CON.bit.TENABLE=1;// 使能 T4
EvbRegs.CAPCONB.bit.CAP45EN = 1;//使能 CAP45
while(EvbRegs.EVBIFRC.bit.CAP4INT!=1)KickDog();//等待 CAP4 中断标志位职
capint4_isr();
//***脉宽测量结束,禁止定时器和捕获,复位中断标志位
资源下载
电赛一等奖!简易数字频率计设计(原理图、PCB、源码、分析报告)icon-default.png?t=N7T8https://download.csdn.net/download/xcltapestry/89356209?spm=1001.2014.3001.5503

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

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

相关文章

Redis 哨兵机制的工作原理——Java全栈知识(22)

Redis 哨兵机制的工作原理 在之前的文章我们讲到了 Redis 的三种集群架构:跳转文章:Redis集群模式 接下来我们详细讲哨兵机制的作用以及实现原理 以下是 Redis 哨兵的结构图 1、Redis 哨兵的作用 哨兵的作用如下: 1、监控,2、…

【ArcGIS微课1000例】0111:谷歌地球Google Earth下载安装与使用教程

一、谷歌地球安装 双击安装包,默认点击完成即可。 二、谷歌地球使用 打开快捷方式,开始使用谷歌地球。欢迎界面: 软件主界面: 三、谷歌地球下载 软件安装包位于《ArcGIS微课实验1000例(附数据)专栏配套完数据包中的0111.rar中…

企业如何防止数据泄密?大型企业必备的文件加密软件

随着信息化建设的大步推进,越来越多的企业资料以电子文件的形式保存,企业内部和企业之间的信息交流也主要依靠电子文件。近年来的泄密事件层出不穷,比如东软泄密案、HTC窃密案、力拓案等,给企业带来灾难性的经济损失及信誉重创。如…

出题123

题目时限空间说明 无特殊均默认 1 s , 256 M B 1s,256MB 1s,256MB Problem a 最大化 在最大化目标值的基础上选择的操作越多越好,且输出操作应当按照顺序执行,即你的输出顺序就是你的执行顺序,当有多个执行顺序可以最大化目标值时&#xff0…

python中的条件语句

python中语句的执行顺序 默认情况下,python代码的执行顺序,是从上到下依次执行的,这个顺序是不会变的, python中的条件语句 电脑的CPU芯片是能够进行算术运算也能进行逻辑判断的。 条件语句能够表达“如果...否则...” 这样的语…

基于51单片机的数字频率计(电路图+pcb+论文+仿真+源码)

于51单片机的数字频率计 设计的频率计范围能够达到1HZ-1MHZ(实际上51单片机达不到这个范围,不要在实验环境下进行),这个是课设来着,用Proteus仿真实现的,给有需要的同学参考一下 仿真原理图如下(proteus仿真工程文件可…

面试八股之JVM篇3.6——垃圾回收——强引用、弱引用、虚引用、软引用

🌈hello,你好鸭,我是Ethan,一名不断学习的码农,很高兴你能来阅读。 ✔️目前博客主要更新Java系列、项目案例、计算机必学四件套等。 🏃人生之义,在于追求,不在成败,勤通…

Javascript特效之鼠标悬停特效【css】

先看一看效果&#xff0c;是不是很炫酷啊&#xff1f;&#xff1f; HTML代码&#xff1a; <!DOCTYPE html> <html><head><meta charset""UTF-8"" /><title>CSS特效&#xff1a;鼠标悬停效果</title><link rel&q…

SQL分类——DDL(数据定义语言)

一、DDL&#xff08;数据定义语言&#xff09; &#xff08;1&#xff09;DDL——数据库——操作的相关语法&#xff1a; 查询 可以一次性查询当前数据库服务器中所有的数据库&#xff1a; SHOW DATABASES; 查询当前所处的数据库&#xff1a; SELECT DATABASE(); 创建 一般最简…

Python | Leetcode Python题解之第101题对称二叉树

题目&#xff1a; 题解&#xff1a; class Solution:# 在【100. 相同的树】的基础上稍加改动def isSameTree(self, p: Optional[TreeNode], q: Optional[TreeNode]) -> bool:if p is None or q is None:return p is qreturn p.val q.val and self.isSameTree(p.left, q.ri…

Transformer详解(1)-结构解读

Transormer块主要由四个部分组成&#xff0c;注意力层、位置感知前馈神经网络、残差连接和层归一化。 1、注意力层(Multi-Head Attention) 使用多头注意力机制整合上下文语义&#xff0c;它使得序列中任意两个单词之间的依赖关系可以直接被建模而不基于传统的循环结构&#…

基于.net开发的博客系统

基于.net开发可以批量上传md文件生成文章的博客系统 .NET 个人博客 基于.net开发的博客系统 个人博客系统&#xff0c;采用.net core微服务技术搭建&#xff0c;采用传统的MVC模式&#xff0c;使用EF core来对mysql数据库(sqlite数据库)进行CRUD操作项目 为什么要自己开发博客…

clion读取文件设置为读取当前目录下的文件

1.问题 使用vs读取文件时一切正常 但是同样的代码在clion中无法正常执行 原因 原因&#xff1a;clion的源文件找不到input.txt文件的位置 需要设置工作目录&#xff0c;例如此时input.txt在当前目录下&#xff0c;那么就设置 设置当前文件的工作目录为$FileDir$即可&am…

Ubuntu 如何根据NVIDIA显卡型号确定对应的显卡驱动版本并安装

目录 一、查询推荐安装的驱动版本 二、安装推荐版本的驱动 1. 通过终端安装&#xff0c;只安装 nvidia 驱动&#xff08;亲测可用&#xff01;&#xff09; 2. 通过 software & Updates 安装&#xff0c;安装 nvidia 驱动。 三、查询能安装的最新的显卡驱动版本 1. 方…

C++—— set、map、multiset、multimap的介绍及使用

目录 关联式容器 关联式容器的特点和使用场景 树形结构与哈希结构 树形结构 哈希结构 键值对 set set的介绍 set的定义方式 set的使用 multiset map map的介绍 map的定义方式 map的使用 multimap 关联式容器 C标准模板库&#xff08;STL&#xff09;中的关联…

AI必然趋势下,产品经理未来何在?路怎么走?

AI已经普遍运用到产品经理的日常工作中了。让它写个需求分析、做个PRD不在话下… 因为AI&#xff0c;也能经常听到有人在谈论&#xff1a;产品经理未来是否会被取代&#xff1f; 未来&#xff0c;产品经理的路该往哪走、怎么走&#xff1f; 未来&#xff0c;产品经理职业规划…

瑞芯微RV1126——ffmpeg环境搭建

本篇文章来介绍一下&#xff0c;在ubuntu上搭建一个比较完整的ffmpeg环境需要的步骤以及流程。为后期将我们开发的应用程序移植到RV1126开发板上做准备。 在安装ffmpeg之前&#xff0c;为了方便后续的操作&#xff0c;我们可以先搭建好samba服务器。所以本节将分为两个部分&am…

AI多模态「六边形战士」,原创音乐、1分钟百页PPT、抖音爆款……

2024年AI行业最大的看点是什么&#xff1f; 那一定是多模态AI应用。 大模型发展到今天这个阶段&#xff0c;文本处理已经是各家大模型的必备技能了&#xff0c;对音频、视觉等多模态的理解和应用才是下一个阶段大模型比拼的赛道。 3.5研究测试&#xff1a;hujiaoai.cn 4研究测…

Golang单元测试

文章目录 传统测试方法基本介绍主要缺点 单元测试基本介绍测试函数基准测试示例函数 传统测试方法 基本介绍 基本介绍 代码测试是软件开发中的一项重要实践&#xff0c;用于验证代码的正确性、可靠性和预期行为。通过代码测试&#xff0c;开发者可以发现和修复潜在的错误、确保…

Python实现数据可视化效果图总结

一、JSON格式 JSON是一种轻量级的数据交互格式。可以按照JSON指定的格式去组织和封装数据。 JSON本质上是一个带有特定格式的字符串 Json格式 JSON数据格式在Python中可以是字典、又可以是列表中嵌套着字典的格式。 Pyhton数据和Json数据相互转化 二、pyecharts模块 如果想…