2021年A题-信号失真度测量装置 - 嘉立创EDA开源硬件平台

编辑器版本 ×
标准版 Standard

1、简单易用,可快速上手

2、流畅支持300个器件或1000个焊盘以下的设计规模

3、支持简单的电路仿真

4、面向学生、老师、创客

专业版 professional

1、全新的交互和界面

2、流畅支持超过3w器件或10w焊盘的设计规模,支持面板和外壳设计

3、更严谨的设计约束,更规范的流程

4、面向企业、更专业的用户

标准版 2021年A题-信号失真度测量装置

简介:小国二一枚,完成题目所有指标并有所拓展,MCU选的是MSP432E401Y,谨以此纪念小队本科期间最后一届电赛。

开源协议: GPL 3.0

(未经作者授权,禁止转载)

创建时间: 2021-12-09 00:10:34
更新时间: 2023-12-29 11:09:13
描述
### 2021年电赛国赛A题:信号失真度测量装置 ## **目录** **1.前言** **2.团队介绍** **3.项目简介** **4.题目及功能指标** **5.理论分析与计算** **6.本题所用模块清单表及总体方案描述** **7.各原理图电路分析** **8.电路pcb设计** **9.程序设计** **10.实物图展示** **11.总结** **12.演示视频** - - - ### 前言       团队一直都很乐于参加立创的活动,因为自己和队友通过立创认识了很多有趣的小电路,跟着复现了一些小型电路DIY,现在也正拿着立创推荐的开源课题,给大一大二的学弟们做培训,工具也使用的立创EDA(真的太亲民了),平常为电赛准备的一些电路板也都是在立创这边开板,真的帮了我们学生党很多。然后这次立创的国赛作品征集令,也是收到消息第一时间就来参加了,希望多少也能回馈一些,对队伍来说也是一种回忆了。      当初因为要考研,差点放弃参赛,但是想到这辈子只有这一次参加国赛的机会,最终还是毅然决定参加比赛,不留遗憾。尽管身边充斥着同学的质疑:“马上考研了你还去参加比赛,你不考研了?”,“你都这么久没没弄了,去了也不一定获奖,还不如老老实实考研”…但是回想起在实验室的点点滴滴,无数次的熬夜,以及与队友并肩作战的快乐,我选择参加比赛,不管结果如何,也算是给自己和队友一个交代。       这是我第一次在立创开源项目,没有什么经验,有不足的希望大家多多指教,互相学习。 - - - ### 团队介绍      团队里三个人都是学校电子信息工程学院电赛实验室的成员,主要是仪器仪表方向,本科期间除了上课,其余绝大部分精力都投入到实验室里,现在三个人都是大四老狗了,有读研的也有工作的。参加这次电赛主要是因为情怀,给学弟学妹们留下传承,也圆一圆自己的电赛国奖梦。
团队专业相关竞赛获奖经历: 2021年“TI杯”全国大学生电子设计竞赛国家二等奖 2020年“TI杯”湖北省大学生电子设计竞赛省级一等奖 第十二届蓝桥杯嵌入式andEDA设计与开发国家二等奖
另外团队也经常在自己的CSDN中总结分享立创EDA使用,电赛训练等专业相关内容的经验,队伍个人CSDN链接: 队友的: 学工科的皮皮志:[https://blog.csdn.net/qq_45138815](https://blog.csdn.net/qq_45138815) 俺的: 遗忘丶:[https://blog.csdn.net/h568630659?spm=1010.2135.3001.5343](https://blog.csdn.net/h568630659?spm=1010.2135.3001.5343) 本题B站演示视频:[https://www.bilibili.com/video/BV1Fi4y1d7Ro/](https://www.bilibili.com/video/BV1Fi4y1d7Ro/) - - - ### 项目简介      本系统以TI公司的MSP432系列MCU为控制核心,通过硬件调理电路、MCU ADC采样、数字信号处理等手段,测量信号源产生的任意波的总谐波失真近似值(THD)。输入信号经自动增益控制放大器,再通过直流偏置加法器把幅度调整到ADC采样范围,进而采样为数字信号,通过快速傅立叶变换(FFT)分析计算出信号的THD,得到频域与时域波形,并将所测结果通过本地彩色触摸屏显示和通过WiFi实时传输至手机APP显示。测试结果表明,本装置电路设计条理清晰,人机交互界面友好,功能性能完备,并且频率、幅度、精度的测量范围均超过题目要求,能在1s内完成各项指标的测量,新增频率指标和语音播报创新功能,THD测量最大误差不超过1%,圆满完成了题目的所有要求并有所拓展。 - - - ### 题目及功能指标 ![image.png](//image.lceda.cn/pullimage/9nQyrNQvZNwTK0aNQ0o7ABYlTh0j41WSBiBjIJeo.png) ![image.png](//image.lceda.cn/pullimage/j29jqcRsatcE51tXkmx0QNDvNcm7rbIidfnhz90U.png)    | | | | --- | --- | | 题目要求 | 完成情况 | | (1)输入信号峰峰值30mV~600mV | 完成,拓展至170μV~6V | | (2)输入信号基频范围1kHz~100kHz | 完成,拓展至600Hz~100kHz | | (3)输入信号失真度范围5%~50% | 完成,拓展至0%~100% | | (4)失真度测量与显示用时不超过10s | 完成,拓展至不超过1s | | (5)测量输出信号总谐波失真近似值THD | 完成,最大误差不超过1% | | (6)测量并显示输入信号一个周期波形 | 完成 | | (7)显示基波与谐波归一化幅值 | 完成 | | (8)手机上显示测量结果 | 完成 | | (9)其它 | (1) 频率测量显示

(2) 语音提示功能

(3) 离散频谱可视化

(4)交互友好、显示清晰

(5)连续、单次测量模式 | ### 本题模块清单表 | | | | | --- | --- | --- | | 模块 | 型号 | 备注 | | 主控模块MCU | MSP432E401Y | | | 自动增益控制放大模块AGC | AGC模块(AD603) | 淘宝链接:[https://m.tb.cn/h.fiGzQkD?sm=9124c2](https://m.tb.cn/h.fiGzQkD?sm=9124c2) | | WiFi模块 | ESP8266(正点原子) | 淘宝链接:[https://m.tb.cn/h.f7zSYlr?sm=472fbb](https://m.tb.cn/h.f7zSYlr?sm=472fbb) | | 显示屏(大彩屏) | 7寸800*480 8P接口串口屏 | 淘宝链接:[https://m.tb.cn/h.fRyreFA?sm=ad58ad](https://m.tb.cn/h.fRyreFA?sm=ad58ad) | ### 总体方案描述      外接任意波信号发生器作为信号源,输入信号接入自动增益控制放大器进行放大以适应宽输入幅度范围,再叠加偏置将输出信号调理至ADC采样幅度范围,单片机将采样得到的结果进行FFT运算,从而得到总谐波失真近似值和时域、频域的波形信息,并将所测结果通过彩色触摸屏显示和通过WiFi实时传输至手机APP显示,系统总体方案框图如图所示。 ![image.png](//image.lceda.cn/pullimage/Q9A4iBgXI5pJitxrCNw7IUldZIDuWxUtWDZt5uTF.png) - - - ### 理论分析与计算 **1.放大电路设计**      在本系统中,由于测控信号的范围比较宽,为保证必要的测量精度,对于输入的模拟信号需要加前置放大器,以使输出电压适合于模数转换器的电压范围。      针对题目输入信号的峰峰值范围30mV~600mV,本系统设计的放大器不仅要满足最低输入幅度的信号能被AD准确采集,也要保证最高输入幅度的信号经放大后不会超过单片机ADC的输入幅度限制0~3.3V,同时,考虑到输入信号基频最大为100kHz,则其五次谐波频率为500kHz,故应选用带宽不小于5MHz的运放,此处选用程控放大器AD603实现,AD603采用特有的内插技术,可保证增益变化是线性的,且增益稳定性强,受外界温度及电源波动影响较小。      信号源产生的任意波通过自动增益放大电路,其作用是当输入信号较强时,使放大器增益自动降低,而当信号较弱时,又使其增益自动增高,从而保证在AGC作用范围内输出电压比较均匀。使得后级处理电路对于输入信号具有良好的处理特性。 **2.直流偏置加法电路设计**      偏置部分选用经典加法器电路,其中比例电阻均取10kΩ。具体偏置大小采用定值电阻与电位器分压的方式,考虑到MCU ADC要求采集信号幅度在0~3.3V,取放大后的正弦波峰峰值最大可放大到3Vpp,则: ![image.png](//image.lceda.cn/pullimage/1ebrUC8iMkCVSIyvGvFILgOgd6ZmzcIWabunCFwS.png)      故取1K电位器与3.3K定值电阻分压。 **3.FFT测量设计**      快速傅里叶变换FFT可以将一个时域信号变换到频域,也可以将一个信号的频谱提取出来,先对一个信号在时域上按照采样频率F进行采集,采集N个点然后对这N个点进行FFT运算,就可以得到这个信号的频谱特性。FFT之后结果就是一个N个点的复数,每一个点对应一个模值为实部与虚部平方和的频率点,每个频率点的模值(第一个点直流分量除外)为原始信号峰值A的N/2倍,第一个点直流分量为A的N倍。第n个点对应的信号频率为: ![image.png](//image.lceda.cn/pullimage/sVWD4hNdGF8X0VUnbDQT5DDt9SD8Xjipw5jdSE4k.png) - - - ### 原理图电路分析 **1.自动增益控制放大电路**      AGC电路本质上是一个反馈控制电路,将输出电压平均值通过检测电路变换为合适的直流电平,并反馈至压控增益放大器的增益控制端,其结构如下图。 ![image.png](//image.lceda.cn/pullimage/oO7ggRsT0aW9JfoxeuRkxuDwiqXqKKr2Yg6ZUiTP.png)                                                压控增益放大器决定了AGC的最大增益和增益变换范围,电路的频率特性,噪声指标等主要指标也取决于这个放大器。由于反馈环反馈准直流信号,所以对于整个放大器的频率特性基本没有影响。      本系统中的自动增益控制放大电路,是由两个AD603构成可变增益放大器,每个AD603的电压增益可以从0dB变化到+42dB,两个放大器构成的级联放大器增加AGC的控制范围。      AD603依靠控制电压控制放大倍数;比较器AD8561比较的是第二级AD603输出信号(比较器的同相端)和设置电压(比较器的反相端),使用二极管和RC对比较器输出信号进行检波;检波的值的范围0~3.3V,电路设置为固定电压值1.4V,这样就可以保证调整电压在AD603的控制电压范围内,使AD603能正常放大,具有自动调节的能力,如图所示。 ![image.png](//image.lceda.cn/pullimage/TYP0O4uQkPurWH9OAZATrE0PfV5AwJYE0qVfjipa.png)   **2.直流偏置加法电路**      在本系统中,由于前级放大电路中的AD603存在内部失调电压,导致放大后的信号在进入加法器前存在较大的直流偏置,故加入截止频率为1.59Hz的高通滤波器隔直,这里取电容C=0.1μF,R=1MΩ的一阶无源高通滤波器。      同时,为防止分压电路电阻对加法器比例电阻的影响,与比例电阻对高通滤波器截止频率的影响,在分压电路和高通滤波器后各加入一级跟随器进行隔离再输入进加法器,实际电路如图所示。 ![image.png](//image.lceda.cn/pullimage/S73u48A3T468i16K3jMPJ1jptUbIdDpPdDD4aY76.png)
### PCB电路分析 **1.自动增益控制放大电路**      这个用的是备赛期间准备的AGC自动增益控制放大模块,所以就不贴PCB图了,放一个淘宝链接: [https://m.tb.cn/h.fiGzQkD?sm=9124c2](https://m.tb.cn/h.fiGzQkD?sm=9124c2)  AGC模块 AD603 自动增益控制 手动、程控调节输出幅值 带宽10M ![image.png](//image.lceda.cn/pullimage/V6LB5UhdHNFBaAqJ4rXn6twZxBHtCUPeBK7Oh0Uo.png) **2.直流偏置与高通隔直电路**      因为是比赛的时候制作的,实验室做双面板很麻烦,选用单面板,然后之所以放两个供电接口,主要是因为只放一个的话很难布通。然后规格接近5X5cm,不大不小,和其他电路模块大小一致,看上去也比较美观。
![image.png](//image.lceda.cn/pullimage/1iDiOHlpokXqXNkAkWWSVjzNoTvK59kYsr6M2w4I.png) **3.加法电路** **这也是个基本的加法电路,注意电源退耦,然后电路板规格也是尽量做成5*5cm,与前后电路模块大小保持一致。** **![image.png](//image.lceda.cn/pullimage/EZohW0Jq7f7DwHbm5ggA439YGDWSy53gUMiaZZQm.png)** - - - ### 程序设计      本装置以MSP432E401Y单片机为核心,使用串口屏进行人机交互,一键启动后,通过单片机片上12位ADC对放大后的输入信号进行多次采样,选取最佳采样率下的数据进行FFT运算,得到信号的频域波形,在频域中提取基波及各次谐波的峰峰值、相位等信息并进行IFFT运算,从而得到还原后的一个周期时域波形,最终测试结果通过串口屏显示和通过WiFi实时传输至手机APP显示,如图所示。 ![image.png](//image.lceda.cn/pullimage/GxXXdFIWmSAib9AVg13l4f6oqt5W6FOhEuuxrZVB.png)      首先先来介绍一下上位机。我们上位机软件是用QT来写的,因为QT是跨平台的,同样一套代码可以在windows上面跑,也可以在linux上面跑,也可以在安卓手机上面跑。而且不需要修改任何东西,编译器会自动给你生成好,并且可以非常地快速实现界面设计,非常地友好,这就非常的方便。既然可以在手机上面跑,那么我把串口改成WiFi不就是一个WiFi_APP了吗?说干就干,网上关于QT开发蓝牙的已经有相关的资料了,那么一样的道理,WiFi或蓝牙差不多的,于是乎就综合各方面资料,整合了一个WiFi_APP。 做这个app不需要任何的Java的知识,你只要会QT最基本的C++基础就可以了。只有你手头有WIFI模块(ESP8266)和安卓手机就可以实现WIFI_APP的功能。
**软硬件平台** **硬件平台:**      ESP8266,(淘宝上有卖),它的接口就是跟串口一样,用到了TX,RX,GND,VCC四个引脚。跟下位机或者用CH340,TTL转USB模块接到PC机上,WIFI的工作模式可以通过AT指令调节。有AP模式,STA模式,AP+STA混合模式......简单的来说就是:      AP:可以将ESP8266作为热点,可以让其他的设备连接上它;      STA:可以连接上当前环境下的WIFI热点。      最重要的是开启透传模式。透传就是指不需要关心wifi协议是如何实现的。所需要做的就是A通过串口发数据,B通过串口收数据,整个过程中A串口和B串口就像是用导线直接连接起来了一样。则对于开发人员来看,就是完全透明的。我们用的是STA模式(需连接热点),然后开启透传。 ATK-ESP8266(正点原子)模块,接线方式如下: ![image.png](//image.lceda.cn/pullimage/QFc6IEGazm1IRlHo4vjxIWY8rpNvcYwue6TvmLQS.png) 这六个引脚只需要4个就行了:RXD、TXD、GND、VCC,分别和单片机的TXD、RXD、GND、VCC相连接就行了。 ![EW9.jpg](//image.lceda.cn/pullimage/TdGDjvEyArBrNQTo4wRHyEDOvUBgDyOS2SzRf716.jpeg) **安卓手机:**      我这里用的是一台安卓手机,OPPO手机,安卓版本10 **软件平台:**     本项目Qt版本是5.12.4,系统是Windows 10 x64     注意:需要搭建Qt for Android 环境     视频链接:[Qt的安装和安卓环境搭建](https://www.bilibili.com/video/BV1F4411F72b?p=1&share_medium=iphone&share_plat=ios&share_session_id=DCB8C0E3-3D5F-41DB-8807-A9600D838E55&share_source=COPY&share_tag=s_i&timestamp=1639031677&unique_k=L94cK9Q) **软件基本介绍:**      因为第一次做WiFi上位机,就做了一个非常简单的雏形,实现WIFI状态检测,本机IP的扫描和服务器链接,基波谐波的显示,时域频域波形的显示,并且能像串口助手一样完成数据收发。如图,就是本一开始做的最简单的软件界面,本软件基于widge控件制作,当然你可以选择其他的,更可以自己定义类。      我们是基于QT的网络协议之TCP通信,用到了两个类,QTcpServer和QTcpSocket,TCP分为了服务器和客户端,就是跟网络调试助手差不多的。我们这里使用手机作为服务器,wifi模块(esp8266)作为客户端,那么只要连接在同一个网络,就可以互相通信,传输数据了。      当然我们还需要制定简单的数据传输协议:因为有了协议,你才知道发过来的是什么类型的数据,一次发多少个,要显示在哪里,下面是部分代码,源码放在最后面了,大家可以下载来慢慢查看。      同样我们也给大家提供了学习QT的视频链接方便大家学习:【【北京迅为】嵌入式学习之QT学习篇-哔哩哔哩】 [https://b23.tv/gP8rDCd](https://b23.tv/gP8rDCd) ![42LMG`UQB28_PU663E3XOKO.jpg](//image.lceda.cn/pullimage/kE86mjwQrAaFpkNkYEH5y6zCj7ZhdhQKSe41EMl4.jpeg) ``` #include "qglobal.h" #include "cmd_queue.h" #include "process_fun.h" #include "widget.h" uint8_t cmd_buffer[A_CMD_MAX_SIZE]; void A_ProcessMessage(A_PCTRL_MSG msg, uint16_t size,Ui::Widget *dis) { uint8_t cmd_type = msg->cmd_type; //指令类型 uint16_t screen_id = A_PTR2U16(&msg->screen_id); //画面ID uint16_t control_id = A_PTR2U16(&msg->control_id); //控件ID uint32_t value = A_PTR2U32(msg->param); //数值 uint16_t len = A_PTR2U16(msg->param); switch(cmd_type) { case A_kCtrlButton: //按钮控件 A_NotifyButton(screen_id,control_id); break; case A_kCtrlText: //文本控件 A_NotifyText(screen_id,control_id,msg->param,dis); break; case A_kCtrlGraph: A_NotifyGraph(screen_id,control_id,len,&msg->param[2]); //画图控件 default: break; } } void A_NotifyText(uint16_t screen_id, uint16_t control_id, uint8_t *str,Ui::Widget *dis) { if(screen_id == 0) { if(control_id == 3) { Widget::updatedata3(str,1,dis); } ``` - - - ### 实物图展示

**     作品实物图:**

![image.png](//image.lceda.cn/pullimage/ThZY7CXjaH1hzJEpBnCBtVGb0qXpPzSM8JAATS2h.png)
**    人机交互界面:**

![image.png](//image.lceda.cn/pullimage/etnsoTS2YuDtGz3F39dk6kTfWZlFSZfKYmnS2y68.png)
**手机APP:**
![image.png](//image.lceda.cn/pullimage/7wvyr38uP01UQtfVmUeKVVi1EPIaYSpB0Velmrie.png) ### 总结      对于此题,我们队伍还是抱有一点遗憾,因为之前对TI的MCU没有足够了解,面对此题现学TI的板卡开发,包括在选型时也吃了亏,当时手头有430、432、C2000三种型号的MCU,简单看了官网上的介绍就选择了MSP432,虽然能完成题目规定的各项指标,但相对于其他选择C2000的组来说还是有很大差距,听说其他学校用C2000能测到1M频率,而MSP432E401Y的ADC采样速率只能到1M,对于100kHz的基波,五次谐波已经达到500kHz,用1M速率来采已经非常勉强。而且MSP432E401Y内部没有DA,无法做连续的程控,要么采用控继电器、模拟开关等实现离散放大倍数的控制;要么就只能外接DA模块。
最后也十分感谢平常给我们培训,答疑解惑的实验室老师们和学长学姐们,感谢一同奋战电赛的兄弟们和学弟学妹们,感谢在考研紧张复习的时期抽出时间的队友,本科期间最后一场电赛结束了,但电赛不是终点,谨以此与君共勉。 ### 演示视频
设计图
原理图
1 /
PCB
1 /
未生成预览图,请在编辑器重新保存一次
ID Name Designator Footprint Quantity
1 100n C1,C2,C5,C6,C9,C21 C-0805 6
2 1u C3,C4,C7,C8 C-0805 4
3 10uF C10 1812 1
4 0.1uF C11,C13 1812 2
5 1uF C12 1812 1
6 SMA IN_1,IN_2,OUT_1,OUT_2,OUT_JF,IN,S2 SMA 7
7 Header 3 PGND,PVCC,PVCC2,PVEE,PVEE2 HDR1X3 5
8 SMB PIN_1,PIN_2 SMB_V-RJ45 2
9 1M R1 C-0805 1
10 3.3k R2 C-0805 1
11 10K R3,R4,R5,R6 2012[0805] 4
12 1k RAJ _____-3 1
13 OPA277U U1_GEZHI,U2_ZL TI-D8_N 2
14 OPA227 U3_JIAFAQI TI-D8_N 1
15 820n C1 C-0805 1
16 1N4148 D1 DO-35 1
17 HDR-F-2.54_1x2 H1,H2 HDR-F-2.54_1X2 2
18 100 R1,R3 C-0805 2
19 49.9 R2,R4 C-0805 2
20 NC R5,R13 C-0805 2
21 1K R6 C-0805 1
22 820 R7 C-0805 1
23 2.2M R8 C-0805 1
24 150 R9 C-0805 1
25 51K R10 C-0805 1
26 20K R12 C-0805 1
27 10k RW1 _____-3 1
28 AD603ARZ U1,U2 SOIC-8_L4.9-W3.9-P1.27-LS6.0-BL 2
29 AD8561ARUZ U3 TSSOP-8_L4.4-W3.0-P0.65-LS6.4-TL 1

展开

工程视频/附件
侵权投诉
相关工程
换一批
加载中...
添加到专辑 ×

加载中...

温馨提示 ×

是否需要添加此工程到专辑?

温馨提示
动态内容涉嫌违规
内容:
  • 153 6159 2675

服务时间

周一至周五 9:00~18:00
  • 技术支持

support
  • 开源平台公众号

MP