当前位置: 首页 > article >正文

用STM32G431RBT6复刻一个简易示波器+信号发生器:蓝桥杯嵌入式外设综合应用实战

基于STM32G431RBT6的嵌入式示波器与信号发生器开发实战在嵌入式系统开发领域将理论知识转化为实际应用能力是每个工程师成长的必经之路。本文将带你使用STM32G431RBT6开发板从零开始构建一个兼具示波器和信号发生器功能的综合系统。这个项目不仅能够巩固ADC采集、DAC输出、定时器应用等核心知识点更能培养解决实际工程问题的思维方式。1. 项目规划与硬件架构设计1.1 功能需求分析我们的目标系统需要实现以下核心功能示波器功能实时采集外部模拟信号0-3.3V范围测量信号频率和占空比在LCD上动态显示波形和参数支持触发电平调节信号发生器功能输出正弦波、方波、三角波等基本波形可调频率范围1Hz-10kHz可调幅度0-3.3V通过按键切换波形和参数系统交互按键控制模式切换LCD显示当前状态和参数实时响应参数调整1.2 硬件资源分配STM32G431RBT6开发板的硬件资源配置如下功能模块使用引脚/外设备注ADC采集PA0 (ADC1_IN1)用于外部信号输入DAC输出PA4 (DAC1_OUT1)信号发生器输出定时器输入捕获PB4 (TIM3_CH1)频率测量LCD显示开发板自带LCD接口使用FSMC驱动按键控制PB0, PB1, PB2, PA0模式切换和参数调整系统时钟HSI 16MHz通过PLL倍频到170MHz1.3 软件架构设计系统采用分层架构设计各模块职责明确应用层 ├── 用户界面处理 ├── 波形生成算法 └── 测量计算逻辑 驱动层 ├── ADC采集驱动 ├── DAC输出驱动 ├── 定时器驱动 ├── LCD显示驱动 └── 按键驱动 硬件抽象层 └── STM32 HAL库2. 核心模块实现2.1 ADC信号采集模块ADC配置采用中断模式实现高效采集// ADC初始化配置 void ADC_Init(void) { hadc1.Instance ADC1; hadc1.Init.ClockPrescaler ADC_CLOCK_SYNC_PCLK_DIV4; hadc1.Init.Resolution ADC_RESOLUTION_12B; hadc1.Init.ScanConvMode DISABLE; hadc1.Init.ContinuousConvMode ENABLE; hadc1.Init.DiscontinuousConvMode DISABLE; hadc1.Init.ExternalTrigConv ADC_SOFTWARE_START; hadc1.Init.DataAlign ADC_DATAALIGN_RIGHT; hadc1.Init.NbrOfConversion 1; HAL_ADC_Init(hadc1); // 配置ADC通道 ADC_ChannelConfTypeDef sConfig {0}; sConfig.Channel ADC_CHANNEL_1; sConfig.Rank 1; sConfig.SamplingTime ADC_SAMPLETIME_47CYCLES_5; HAL_ADC_ConfigChannel(hadc1, sConfig); // 启动ADC HAL_ADC_Start_IT(hadc1); } // ADC中断回调函数 void HAL_ADC_ConvCpltCallback(ADC_HandleTypeDef* hadc) { if(hadc-Instance ADC1) { uint16_t adcValue HAL_ADC_GetValue(hadc1); float voltage adcValue * 3.3f / 4095.0f; // 将采样值存入波形缓冲区 waveformBuffer[bufferIndex] voltage; if(bufferIndex BUFFER_SIZE) bufferIndex 0; // 重新启动ADC HAL_ADC_Start_IT(hadc1); } }2.2 DAC信号生成模块DAC配置采用定时器触发实现精确波形输出// DAC波形生成配置 void DAC_Wave_Init(void) { // DAC初始化 hdac1.Instance DAC1; HAL_DAC_Init(hdac1); // DAC通道配置 DAC_ChannelConfTypeDef sConfig {0}; sConfig.DAC_Trigger DAC_TRIGGER_T6_TRGO; sConfig.DAC_OutputBuffer DAC_OUTPUTBUFFER_ENABLE; HAL_DAC_ConfigChannel(hdac1, sConfig, DAC_CHANNEL_1); // 定时器6配置用于触发DAC htim6.Instance TIM6; htim6.Init.Prescaler 170-1; // 1MHz时钟 htim6.Init.CounterMode TIM_COUNTERMODE_UP; htim6.Init.Period 100-1; // 10kHz更新率 HAL_TIM_Base_Init(htim6); // 启动定时器 HAL_TIM_Base_Start(htim6); HAL_DAC_Start(hdac1, DAC_CHANNEL_1); } // 生成正弦波 void Generate_Sine_Wave(float amplitude, float frequency) { uint32_t period (uint32_t)(1000000.0f / frequency); for(uint32_t i0; iperiod; i) { float value amplitude * sin(2 * PI * i / period); uint32_t dacValue (uint32_t)((value amplitude) * 4095.0f / (2 * amplitude)); HAL_DAC_SetValue(hdac1, DAC_CHANNEL_1, DAC_ALIGN_12B_R, dacValue); HAL_Delay(1); } }2.3 频率测量模块使用定时器输入捕获功能实现精确频率测量// 定时器输入捕获配置 void TIM_InputCapture_Init(void) { htim3.Instance TIM3; htim3.Init.Prescaler 170-1; // 1MHz计数频率 htim3.Init.CounterMode TIM_COUNTERMODE_UP; htim3.Init.Period 0xFFFF; htim3.Init.ClockDivision TIM_CLOCKDIVISION_DIV1; HAL_TIM_IC_Init(htim3); // 输入捕获通道配置 TIM_IC_InitTypeDef sConfigIC; sConfigIC.ICPolarity TIM_INPUTCHANNELPOLARITY_RISING; sConfigIC.ICSelection TIM_ICSELECTION_DIRECTTI; sConfigIC.ICPrescaler TIM_ICPSC_DIV1; sConfigIC.ICFilter 0; HAL_TIM_IC_ConfigChannel(htim3, sConfigIC, TIM_CHANNEL_1); // 启动输入捕获 HAL_TIM_IC_Start_IT(htim3, TIM_CHANNEL_1); } // 输入捕获中断回调函数 void HAL_TIM_IC_CaptureCallback(TIM_HandleTypeDef *htim) { static uint32_t lastCapture 0; if(htim-Channel HAL_TIM_ACTIVE_CHANNEL_1) { uint32_t currentCapture HAL_TIM_ReadCapturedValue(htim, TIM_CHANNEL_1); if(lastCapture ! 0) { measuredFrequency 1000000.0f / (currentCapture - lastCapture); } lastCapture currentCapture; } }3. 系统集成与优化3.1 多任务调度实现使用状态机模式管理系统功能typedef enum { MODE_SCOPE 0, MODE_GENERATOR, MODE_SETTINGS } SystemMode; void System_Task(void) { static SystemMode currentMode MODE_SCOPE; switch(currentMode) { case MODE_SCOPE: Scope_Process(); if(Key_GetPress(KEY_MODE)) { currentMode MODE_GENERATOR; LCD_Clear(); } break; case MODE_GENERATOR: Generator_Process(); if(Key_GetPress(KEY_MODE)) { currentMode MODE_SETTINGS; LCD_Clear(); } break; case MODE_SETTINGS: Settings_Process(); if(Key_GetPress(KEY_MODE)) { currentMode MODE_SCOPE; LCD_Clear(); } break; } }3.2 显示优化技巧LCD显示采用双缓冲技术减少闪烁// LCD双缓冲实现 void LCD_Refresh(void) { static uint8_t frontBuffer[BUFFER_SIZE]; static uint8_t backBuffer[BUFFER_SIZE]; static uint8_t *currentBuffer frontBuffer; // 在后台缓冲区绘制 Draw_Waveform(backBuffer); Draw_Parameters(backBuffer); // 交换缓冲区 uint8_t *temp currentBuffer; currentBuffer backBuffer; backBuffer temp; // 更新LCD显示 LCD_WriteBuffer(currentBuffer); }3.3 性能优化策略ADC采样率优化使用DMA传输减少CPU开销合理设置采样时钟分频采用过采样技术提高分辨率波形生成优化预计算波形表减少实时计算量使用定时器精确控制输出时序采用插值算法平滑波形系统响应优化按键采用中断消抖机制参数调整采用加速算法显示更新采用差异刷新4. 调试与问题解决4.1 常见问题及解决方案问题现象可能原因解决方案ADC采样值不稳定电源噪声/参考电压不稳增加滤波电容使用外部参考电压波形显示有毛刺采样率与信号频率不匹配调整采样率添加抗混叠滤波器信号发生器输出失真DAC更新速率不足优化波形表提高定时器触发频率频率测量误差大输入信号边沿不陡峭添加信号调理电路调整输入捕获配置系统响应迟缓任务调度不合理优化状态机减少阻塞操作4.2 调试工具的使用技巧逻辑分析仪抓取SPI/I2C通信数据分析定时器波形测量中断响应时间ST-Link调试器实时变量监控断点调试性能分析串口调试助手输出系统状态信息参数实时调整故障日志记录// 调试信息输出示例 void Debug_Printf(const char *format, ...) { char buffer[128]; va_list args; va_start(args, format); vsnprintf(buffer, sizeof(buffer), format, args); va_end(args); HAL_UART_Transmit(huart1, (uint8_t*)buffer, strlen(buffer), HAL_MAX_DELAY); }4.3 系统校准方法ADC校准零点校准短接输入到GND满量程校准输入精确的3.3V参考线性度校准多点校准建立校正表DAC校准输出幅度校准直流偏移校准波形失真校正频率测量校准使用标准信号源校准补偿测量电路延迟温度漂移补偿5. 功能扩展与进阶应用5.1 高级波形生成技术任意波形生成void Generate_Arbitrary_Wave(const uint16_t *waveTable, uint32_t size, float freq) { uint32_t updateRate (uint32_t)(1000000.0f / (freq * size)); htim6.Init.Period updateRate - 1; HAL_TIM_Base_Init(htim6); for(uint32_t i0; ; i(i1)%size) { HAL_DAC_SetValue(hdac1, DAC_CHANNEL_1, DAC_ALIGN_12B_R, waveTable[i]); HAL_Delay(1); } }调制信号生成AM调幅信号FM调频信号PWM脉宽调制扫频信号生成线性扫频对数扫频步进扫频5.2 高级测量功能FFT频谱分析使用ARM CMSIS-DSP库实现窗函数应用谐波分析自动参数测量峰峰值测量有效值计算上升/下降时间测量数据记录功能波形存储数据导出历史记录回放5.3 通信接口扩展USB虚拟串口实现PC通信远程控制数据上传蓝牙/WiFi模块无线数据传输手机APP控制云端监控SD卡存储波形存储配置保存数据记录// SD卡数据存储示例 void Save_Waveform_To_SD(void) { FIL file; FRESULT res; res f_open(file, waveform.csv, FA_WRITE | FA_CREATE_ALWAYS); if(res FR_OK) { for(uint16_t i0; iBUFFER_SIZE; i) { char line[32]; sprintf(line, %d,%.3f\n, i, waveformBuffer[i]); UINT bytesWritten; f_write(file, line, strlen(line), bytesWritten); } f_close(file); } }通过这个综合项目的实践不仅能掌握STM32各外设的应用技巧更能培养完整的嵌入式系统开发思维。在实际开发中遇到的每个问题都是提升的机会建议在完成基础功能后尝试添加自己的创新功能比如语音控制、手势识别等交互方式或者增加网络远程监控等高级特性。

相关文章:

用STM32G431RBT6复刻一个简易示波器+信号发生器:蓝桥杯嵌入式外设综合应用实战

基于STM32G431RBT6的嵌入式示波器与信号发生器开发实战 在嵌入式系统开发领域,将理论知识转化为实际应用能力是每个工程师成长的必经之路。本文将带你使用STM32G431RBT6开发板,从零开始构建一个兼具示波器和信号发生器功能的综合系统。这个项目不仅能够…...

CircuitJS1:如何在浏览器中免费创建电子电路仿真

CircuitJS1:如何在浏览器中免费创建电子电路仿真 【免费下载链接】circuitjs1 Electronic Circuit Simulator in the Browser 项目地址: https://gitcode.com/gh_mirrors/ci/circuitjs1 CircuitJS1是一款强大的开源电子电路仿真工具,让你直接在浏…...

考研数学避坑指南:那些课本不讲但真题爱考的极限与无穷小细节

考研数学避坑指南:那些课本不讲但真题爱考的极限与无穷小细节 考研数学中,极限与无穷小的概念看似基础,却暗藏玄机。每年都有大量考生在看似简单的题目上失分,原因往往是对这些概念的深层理解不足。本文将聚焦真题中最常见的陷阱&…...

能力本位招聘:打破学历地域限制,聚焦实战技能与远程协作

1. 项目概述:一次非典型的团队组建实验最近,我身边不少朋友和读者都在讨论一个挺有意思的招聘启事,标题就是“朱老师研发团队招人了!学历学校不限,地域不限!”。这和我们平时在招聘网站上看到的那些要求“9…...

Adobe-GenP 3.0:5分钟解锁Adobe全家桶的专业方案

Adobe-GenP 3.0:5分钟解锁Adobe全家桶的专业方案 【免费下载链接】Adobe-GenP Adobe CC 2019/2020/2021/2022/2023 GenP Universal Patch 3.0 项目地址: https://gitcode.com/gh_mirrors/ad/Adobe-GenP 还在为高昂的Adobe订阅费用发愁吗?Adobe-Ge…...

在自动化测试场景中利用Taotoken实现多模型API调用与成本控制

🚀 告别海外账号与网络限制!稳定直连全球优质大模型,限时半价接入中。 👉 点击领取海量免费额度 在自动化测试场景中利用Taotoken实现多模型API调用与成本控制 对于工程团队而言,自动化测试是保障软件质量的关键环节。…...

手把手教你用Spark MLlib搞定协同过滤:从ItemCF到UserCF的保姆级代码解析

Spark MLlib实战:从协同过滤到深度学习推荐系统的全链路实现 推荐系统作为机器学习领域最具商业价值的应用之一,其核心算法在Spark生态中有着丰富的实现。本文将带您深入Spark MLlib的推荐算法实践,从经典的协同过滤到前沿的深度学习模型&…...

告别手写UI!用VSCode+QtDesigner+PyQt5,5分钟搞定你的第一个Python图形界面

5分钟极速构建Python GUI:VSCodeQtDesignerPyQt5全流程实战 每次看到同事用代码逐行构建UI界面时,总忍不住想起自己初学时的痛苦经历——调整一个按钮位置要反复运行程序,修改边距像素值就像在玩"猜数字"游戏。直到发现QtDesigner这…...

ASML财报解读:高毛利与利润倍增背后的光刻机技术垄断与市场逻辑

1. 财报核心数据深度解读:高毛利与利润倍增的背后 看到ASML最新发布的Q2财报,最抓人眼球的两个数字无疑是“毛利率超50%”和“每股净利润增长近一倍”。这不仅仅是两个亮眼的财务指标,更是理解这家全球光刻机巨头当前市场地位、技术壁垒和未来…...

智能硬件企业如何高效备战行业展会:从策略到执行的全流程指南

1. 展会参与的价值与策略思考又到了一年一度的行业盛会密集期,最近我们团队正在紧锣密鼓地筹备即将到来的2023慕尼黑上海电子展。对于很多技术型公司,尤其是像我们这样专注于智能硬件核心方案的公司来说,参加大型专业展会从来都不是一件“可去…...

LRC歌词制作终极指南:轻松创建专业级同步歌词的免费工具

LRC歌词制作终极指南:轻松创建专业级同步歌词的免费工具 【免费下载链接】lrc-maker 歌词滚动姬|可能是你所能见到的最好用的歌词制作工具 项目地址: https://gitcode.com/gh_mirrors/lr/lrc-maker 你是否曾经在听歌时想要制作属于自己的歌词文件…...

如何设计 Agent Harness 的默认行为与异常处理

Agent Harness 架构设计实战:默认行为规范与全链路异常处理体系从0到1落地 摘要/引言 你是否遇到过Agent Demo跑得好好的,一上线就频繁崩溃?大模型返回格式错乱导致整个业务链路报错?工具调用超时直接给用户返回500错误?多Agent协同的时候状态莫名丢失,只能让用户重新发…...

实用指南:5分钟搞定Minecraft MASA模组中文汉化

实用指南:5分钟搞定Minecraft MASA模组中文汉化 【免费下载链接】masa-mods-chinese 一个masa mods的汉化资源包 项目地址: https://gitcode.com/gh_mirrors/ma/masa-mods-chinese MASA全家桶汉化包是专为Minecraft 1.21版本设计的专业本地化解决方案&#x…...

IO杂记I

IO 杂记 一、Selector 与 select() selector.select() 不会创建新线程,而是让当前线程阻塞等待,直到有 I/O 事件就绪。 比喻:一个人站在门口,不来客人就不动。selector.selectNow() 是非阻塞版本:瞥一眼门口&#xff0…...

2023B卷,书籍叠放

👨‍⚕️ 主页: gis分享者 👨‍⚕️ 感谢各位大佬 点赞👍 收藏⭐ 留言📝 加关注✅! 👨‍⚕️ 收录于专栏:华为OD面试 文章目录 一、🍀前言 1.1 ☘️题目详情 1.2 ☘️参考解题答案 一、🍀前言 2023B卷,书籍叠放 。 1.1 ☘️题目详情 题目: 书籍的长、…...

告别混乱文件管理:用FileMeta解锁Windows隐藏的元数据超能力

告别混乱文件管理:用FileMeta解锁Windows隐藏的元数据超能力 【免费下载链接】FileMeta Enable Explorer in Vista, Windows 7 and later to see, edit and search on tags and other metadata for any file type 项目地址: https://gitcode.com/gh_mirrors/fi/Fi…...

RKNN Model Zoo实战:MobileSAM图像分割在瑞芯微平台的完整部署指南

RKNN Model Zoo实战:MobileSAM图像分割在瑞芯微平台的完整部署指南 【免费下载链接】rknn_model_zoo 项目地址: https://gitcode.com/gh_mirrors/rk/rknn_model_zoo 在边缘计算和嵌入式AI应用场景中,图像分割技术正成为智能监控、工业质检和AR/V…...

别再只用ARIMA了!用Python+statsmodels搞定SARIMA预测电商销量(附完整代码)

电商销量预测实战:用PythonSARIMA破解季节性销售波动 电商销量预测的痛点与SARIMA的破局之道 每逢大促季节,电商运营团队总会陷入两难困境:备货不足错失销售良机,库存积压又导致资金周转困难。传统ARIMA模型在预测日常销量时表现尚…...

怎样给照片去背景?2026 图片抠图方法对比|免费在线工具实测

在日常生活中,我们经常需要给照片去背景——无论是制作证件照、电商商品图、社交媒体头像,还是创意合成,去背景都是最基础的图像处理需求。但面对五花八门的工具和方法,很多人不知道如何选择。本文将从多个维度全面对比 2026 年主…...

百度网盘macOS版加速插件完全指南:三步破解限速限制

百度网盘macOS版加速插件完全指南:三步破解限速限制 【免费下载链接】BaiduNetdiskPlugin-macOS For macOS.百度网盘 破解SVIP、下载速度限制~ 项目地址: https://gitcode.com/gh_mirrors/ba/BaiduNetdiskPlugin-macOS 你是否也曾面对百度网盘macOS版那令人绝…...

OpenSTA静态时序分析工具:从入门到精通的完整指南

OpenSTA静态时序分析工具:从入门到精通的完整指南 【免费下载链接】OpenSTA OpenSTA engine 项目地址: https://gitcode.com/gh_mirrors/op/OpenSTA OpenSTA静态时序分析工具是数字集成电路设计中不可或缺的开源时序验证解决方案。作为一款功能强大的门级静态…...

带标注的胶囊缺陷识别数据集,识别率68.9%,可识别印刷不良,裂纹,戳痕,划痕,挤压变形五种缺陷,219张图,支持yolo,coco json,voc xml,文末有模型训练代码

​ 带标注的胶囊缺陷识别数据集,识别率68.9%,可识别印刷不良,裂纹,戳痕,划痕,挤压变形五种缺陷,219张图,支持yolo,coco json,voc xml,文末有模型训练代码 模…...

无王无帝定乾坤,来自田间第一人 海棠山铁哥布大道兴世

无王无帝定乾坤 ——来自田间第一人“山河起落,不在帝王;世道兴衰,系于百姓。”一、王权落幕,大道升起 古往今来,世人总把天下兴亡系于龙椅之上。 却不知—— 真正扭转乾坤的力量,深藏在乡野沃土&#xff0…...

2026年降AI工具维普检测专项实测:五款主流工具维普AIGC检测通过率完整横评

2026年降AI工具维普检测专项实测:五款主流工具维普AIGC检测通过率完整横评 拿同一篇论文,用三款工具分别处理,记录了完整检测数据。 结论先说:嘎嘎降AI(www.aigcleaner.com)效果最稳,价格也最…...

无王无帝定乾坤,来自田间第一人 立凰标定世序

谶曰 乱世去旧制,盛世出布衣。 凰标立天地,大同自此始。 一、破题:王权之外,另有乾坤 世人皆道 “普天之下,莫非王土;率土之滨,莫非王臣。” 却不知真正的变局, 起于垄亩&#xff0…...

从MySQL DBA转型ES:我的踩坑笔记与核心概念对比(Mapping/查询/索引篇)

从MySQL DBA转型ES:我的踩坑笔记与核心概念对比(Mapping/查询/索引篇) 当第一次接触Elasticsearch时,我习惯性地用MySQL的思维去理解它——结果可想而知。作为从业十年的MySQL DBA,转型过程中踩过的坑让我意识到&#…...

如何通过QuickLookVideo实现Mac视频预览效率革命:终极工具深度解析

如何通过QuickLookVideo实现Mac视频预览效率革命:终极工具深度解析 【免费下载链接】QuickLookVideo This package allows macOS Finder to display thumbnails, static QuickLook previews, cover art and metadata for most types of video files. 项目地址: ht…...

初探Taotoken模型广场如何帮助开发者快速选型与切换模型

🚀 告别海外账号与网络限制!稳定直连全球优质大模型,限时半价接入中。 👉 点击领取海量免费额度 初探Taotoken模型广场如何帮助开发者快速选型与切换模型 当开发者开始一个新的大模型应用项目时,面对市场上众多的模型…...

Godot-MCP终极指南:如何用AI助手5倍提升Godot游戏开发效率

Godot-MCP终极指南:如何用AI助手5倍提升Godot游戏开发效率 【免费下载链接】Godot-MCP An MCP for Godot that lets you create and edit games in the Godot game engine with tools like Claude 项目地址: https://gitcode.com/gh_mirrors/god/Godot-MCP 在…...

别死记硬背了!用Python+NumPy图解线性代数核心概念(特征值、秩、行列式)

用PythonNumPy图解线性代数:从抽象公式到可视化直觉 线性代数常被视为数据科学和机器学习的基础数学语言,但许多学习者在掌握公式计算后,依然难以理解矩阵乘法如何改变空间、特征值为何能揭示系统稳定性。本文将通过Python代码和可视化技术&a…...