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

STM32定时器PWM模式实战:用TIM1和TIM2实现呼吸灯效果(附完整代码)

STM32定时器PWM模式实战用TIM1和TIM2实现呼吸灯效果附完整代码在嵌入式开发中PWM脉冲宽度调制技术是实现LED亮度控制、电机调速等功能的基石。本文将深入探讨如何利用STM32的TIM1和TIM2定时器通过PWM模式实现平滑的呼吸灯效果。不同于简单的亮灭控制呼吸灯需要精确的占空比动态调整这正是展示STM32定时器强大功能的绝佳案例。1. PWM基础与硬件准备1.1 PWM工作原理精要PWM通过快速切换高低电平来模拟中间电压值其核心参数包括频率每秒完成的完整周期数Hz占空比高电平时间占整个周期的百分比分辨率占空比可调节的最小步进值对于呼吸灯应用我们需要选择足够高的PWM频率通常100Hz以避免人眼察觉闪烁实现占空比的平滑变化0%-100%确保变化曲线符合视觉舒适度常用正弦或指数曲线1.2 硬件连接方案以STM32F103C8T6为例推荐配置定时器通道引脚LED连接方式TIM1CH1PA8串联220Ω电阻TIM2CH1PA0串联220Ω电阻提示高级定时器TIM1支持互补输出等高级功能而通用定时器TIM2配置更简单适合基础应用。2. TIM1高级定时器配置2.1 时钟树配置TIM1挂载在APB2总线上时钟配置需考虑// 系统时钟72MHz假设下 RCC_APB2PeriphClockCmd(RCC_APB2Periph_TIM1, ENABLE); RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA, ENABLE);2.2 时基单元初始化关键参数计算目标PWM频率1kHz时钟预分频PSC72MHz/72 1MHz自动重载值ARR1000-1 999TIM_TimeBaseInitTypeDef TIM_TimeBaseStruct; TIM_TimeBaseStruct.TIM_Prescaler 71; // 72分频 TIM_TimeBaseStruct.TIM_Period 999; // 1000计数 TIM_TimeBaseStruct.TIM_CounterMode TIM_CounterMode_Up; TIM_TimeBaseStruct.TIM_ClockDivision TIM_CKD_DIV1; TIM_TimeBaseStruct.TIM_RepetitionCounter 0; TIM_TimeBaseInit(TIM1, TIM_TimeBaseStruct);2.3 PWM输出配置高级定时器特有的MOE主输出使能配置TIM_OCInitTypeDef TIM_OCStruct; TIM_OCStruct.TIM_OCMode TIM_OCMode_PWM1; TIM_OCStruct.TIM_OutputState TIM_OutputState_Enable; TIM_OCStruct.TIM_OutputNState TIM_OutputNState_Disable; TIM_OCStruct.TIM_Pulse 0; // 初始占空比0% TIM_OCStruct.TIM_OCPolarity TIM_OCPolarity_High; TIM_OCStruct.TIM_OCNPolarity TIM_OCNPolarity_High; TIM_OCStruct.TIM_OCIdleState TIM_OCIdleState_Reset; TIM_OCStruct.TIM_OCNIdleState TIM_OCNIdleState_Reset; TIM_OC1Init(TIM1, TIM_OCStruct); TIM_CtrlPWMOutputs(TIM1, ENABLE); // 关键高级定时器特有 TIM_Cmd(TIM1, ENABLE);3. TIM2通用定时器配置3.1 简化初始化流程TIM2配置相对简单但需注意其挂载在APB1总线最大36MHz// 时钟配置 RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM2, ENABLE); RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA, ENABLE); // GPIO配置 GPIO_InitTypeDef GPIO_InitStruct; GPIO_InitStruct.GPIO_Pin GPIO_Pin_0; GPIO_InitStruct.GPIO_Mode GPIO_Mode_AF_PP; GPIO_InitStruct.GPIO_Speed GPIO_Speed_50MHz; GPIO_Init(GPIOA, GPIO_InitStruct);3.2 时基与PWM配置TIM_TimeBaseInitTypeDef TIM_TimeBaseStruct; TIM_TimeBaseStruct.TIM_Prescaler 71; // 1MHz TIM_TimeBaseStruct.TIM_Period 999; // 1kHz TIM_TimeBaseStruct.TIM_CounterMode TIM_CounterMode_Up; TIM_TimeBaseInit(TIM2, TIM_TimeBaseStruct); TIM_OCInitTypeDef TIM_OCStruct; TIM_OCStruct.TIM_OCMode TIM_OCMode_PWM1; TIM_OCStruct.TIM_OutputState TIM_OutputState_Enable; TIM_OCStruct.TIM_Pulse 500; // 初始50%占空比 TIM_OCStruct.TIM_OCPolarity TIM_OCPolarity_High; TIM_OC1Init(TIM2, TIM_OCStruct); TIM_Cmd(TIM2, ENABLE);4. 呼吸灯算法实现4.1 亮度变化曲线设计人眼对亮度的感知呈对数关系推荐使用以下算法之一正弦曲线最自然float brightness 0.5f * (sin(2 * PI * t / period) 1);指数曲线省计算资源float brightness pow(t / period, 2); // 渐亮 float brightness 1 - pow(1 - t / period, 2); // 渐暗4.2 完整呼吸灯实现代码#include stm32f10x.h #include math.h #define PERIOD_MS 2000 // 完整呼吸周期2秒 void TIM1_PWM_Init(void) { // 初始化代码见前文... } void TIM2_PWM_Init(void) { // 初始化代码见前文... } int main(void) { TIM1_PWM_Init(); TIM2_PWM_Init(); uint32_t startTime 0; while(1) { float elapsed (SysTick-VAL - startTime) / 72000.0f; // 72MHz时钟 if(elapsed PERIOD_MS) startTime SysTick-VAL; // TIM1使用正弦曲线 float ratio 0.5f * (sinf(2 * 3.14159f * elapsed / PERIOD_MS) 1); TIM_SetCompare1(TIM1, (uint16_t)(ratio * 999)); // TIM2使用指数曲线 if(elapsed PERIOD_MS/2) { ratio powf(elapsed / (PERIOD_MS/2), 2); } else { ratio 1 - powf(1 - (elapsed - PERIOD_MS/2) / (PERIOD_MS/2), 2); } TIM_SetCompare1(TIM2, (uint16_t)(ratio * 999)); } }4.3 性能优化技巧查表法预先计算亮度值数组减少实时计算开销const uint16_t brightnessTable[100] {0, 3, 12, ..., 999};DMA传输通过DMA自动更新CCR值减轻CPU负担DMA_Cmd(DMA1_Channel5, ENABLE); TIM_DMACmd(TIM2, TIM_DMA_CC1, ENABLE);中断优化使用定时器更新中断触发占空比变更5. 调试与问题排查常见问题及解决方案现象可能原因解决方法无输出GPIO未配置为复用功能检查GPIO_Mode_AF_PP输出频率不对预分频或ARR计算错误重新计算时钟树高级定时器无输出未启用MOE调用TIM_CtrlPWMOutputsLED闪烁不均亮度变化算法不连续改用浮点计算或更高分辨率查表示波器测量关键点PWM引脚波形频率和占空比时钟信号稳定性中断响应时间如使用中断注意调试时建议先固定占空比如50%确认基础PWM正常工作后再实现动态变化。通过TIM1和TIM2的对比实践不仅能掌握STM32定时器的核心功能还能深入理解高级定时器与通用定时器的差异。实际项目中TIM1更适合需要死区控制、互补输出的电机驱动等场景而TIM2等通用定时器在简单的PWM应用中更具性价比。

相关文章:

STM32定时器PWM模式实战:用TIM1和TIM2实现呼吸灯效果(附完整代码)

STM32定时器PWM模式实战:用TIM1和TIM2实现呼吸灯效果(附完整代码) 在嵌入式开发中,PWM(脉冲宽度调制)技术是实现LED亮度控制、电机调速等功能的基石。本文将深入探讨如何利用STM32的TIM1和TIM2定时器&#…...

EagleEye DAMO-YOLO TinyNAS在智慧交通中的应用:车辆行人实时检测

EagleEye DAMO-YOLO TinyNAS在智慧交通中的应用:车辆行人实时检测 1. 智慧交通中的实时检测挑战 现代城市交通系统面临着日益复杂的监控需求。从繁忙的十字路口到高速公路隧道,每秒钟都有数百辆汽车、行人、非机动车需要被准确识别和追踪。传统基于规则…...

MCP 2026漏洞修复实战沙箱环境(限首批200名CTF认证工程师领取):含3个未公开CVE利用链与Bypass绕过样本

第一章:MCP 2026漏洞修复实战沙箱环境概览MCP 2026 是一种影响主流微服务通信协议栈的高危逻辑绕过漏洞(CVSS 9.1),其核心成因在于服务端对跨域元数据头(X-MCP-Trace-ID)的校验缺失与上下文混淆。本章所构建…...

pybind11进阶技巧:如何高效处理C++与Python间的数据转换(2024最新版)

pybind11进阶技巧:如何高效处理C与Python间的数据转换(2024最新版) 在当今高性能计算与科学计算领域,C与Python的结合已成为开发者工具箱中的标配。pybind11作为两者间的桥梁,其基础用法或许能让你快速实现功能调用&am…...

SiameseUIE实战教程:基于SiameseUIE构建微信公众号文章标签生成系统

SiameseUIE实战教程:基于SiameseUIE构建微信公众号文章标签生成系统 1. 引言:为什么需要智能标签生成? 每天都有成千上万的微信公众号文章发布,但很多作者都面临一个共同问题:如何为文章添加准确的关键词标签&#x…...

Cloudflare CDN自动更换优质IP实战:15分钟搞定腾讯云+DNSPod配置

Cloudflare CDN智能优化实战:腾讯云DNSPod自动化IP优选方案 当你的网站访问者遍布全球时,Cloudflare的免费CDN就像一把双刃剑——它既可能成为性能瓶颈,也可能成为加速利器。关键在于如何驾驭这套系统,特别是对亚洲地区的用户而言…...

手把手配置GD32F407的CAN过滤器:从原理到实战(附常见配置误区)

深入解析GD32F407的CAN过滤器配置:从掩码模式到实战避坑指南 在工业控制与汽车电子领域,CAN总线因其高可靠性和实时性成为首选通信协议。作为GD32F407开发者,正确配置CAN过滤器往往是项目成功的关键一步,却也是最容易被忽视的技术…...

OFA模型效果对比:传统CV方法与深度学习方案差异分析

OFA模型效果对比:传统CV方法与深度学习方案差异分析 图文理解的技术革命:从规则匹配到语义感知的跨越 1. 引言:图文理解的技术演进 在计算机视觉领域,图文语义理解一直是个令人着迷又充满挑战的问题。简单来说,就是让…...

4个核心功能让自动驾驶开发者实现高效3D点云标注

4个核心功能让自动驾驶开发者实现高效3D点云标注 【免费下载链接】point-cloud-annotation-tool 项目地址: https://gitcode.com/gh_mirrors/po/point-cloud-annotation-tool 在自动驾驶技术研发过程中,3D点云数据标注是连接感知算法与真实世界的关键桥梁。…...

Unity 2020.3+Pico SDK 214环境搭建避坑指南:从Android模块到XR配置全流程

Unity 2020.3与Pico SDK 214环境搭建全流程实战解析 VR开发正成为技术领域的新风口,而Pico作为国内领先的VR设备厂商,其与Unity的生态整合为开发者提供了强大支持。本文将深入剖析Unity 2020.3与Pico SDK 214环境搭建的全流程,特别针对开发初…...

GNU Mailman目录遍历漏洞(CVE-2025-43919)深度分析与防护策略

1. 从一次“意外”的配置文件泄露说起 前几天,一个做运维的朋友半夜给我打电话,语气里透着后怕。他负责维护的一个内部邮件列表服务器,突然发现日志里出现了大量异常的访问记录,指向一个本不该被外部访问的路径。他起初没太在意&a…...

Redisson分布式锁实战:如何用tryLock避免高并发下的线程阻塞?

Redisson分布式锁实战:如何用tryLock避免高并发下的线程阻塞? 在高并发系统中,分布式锁是保证数据一致性的重要工具。Redisson作为Redis的Java客户端,提供了强大的分布式锁功能。本文将深入探讨如何利用tryLock方法优化高并发场景…...

长上下文语言模型(LCLMs):让AI拥有更强的长期记忆

引言 想象一下,当你阅读一本小说时,如果只能记住最后几页的内容,会是多么糟糕的体验?同样,大语言模型(LLM)在处理长文本时也曾面临类似的困境。 为什么长上下文如此重要? 在实际应…...

西门子1200与台达DT330温控器通讯实战:XMZ1200 - 4项目解析

西门子1200与台达DT330温控器通讯程序(XMZ1200-4)功能:实现西门子1200 PLC对台达DT330温控器进行485通讯控制,在触摸屏上设定温度,读取温度 器件:西门子1200 1214DC/DC/DC.昆仑通态TPC7022NI,西门子KTP700 Basic PN&am…...

从IPEX到SMA:深入解析无线设备天线接口的选型、原理与实战焊接

1. 无线设备天线接口的江湖恩怨 第一次拆开路由器后盖时,我被主板上那些微型接口搞懵了——IPEX、SMA、U.FL这些字母组合就像密码。直到某次把IPEX座子焊盘扯掉,才意识到选对接口类型比焊工技术更重要。天线接口看似只是金属触点,实则直接影响…...

一键部署UNIT-00:Berserk Interface至CSDN云原生环境教程

一键部署UNIT-00:Berserk Interface至CSDN云原生环境教程 最近在折腾一些有意思的AI模型,发现了一个叫UNIT-00:Berserk Interface的项目,看介绍是个挺强大的多模态交互界面。正好手头有CSDN星图平台的GPU资源,就想着能…...

OpenFAST仿真结果分析指南:如何利用.sum和.out文件优化你的风力涡轮机设计

OpenFAST仿真结果深度解析:从.sum/.out文件到风力机设计优化实战 在风力发电行业,仿真技术已成为涡轮机设计与性能验证的核心工具。作为开源风力涡轮机仿真软件的标杆,OpenFAST凭借其高精度多体动力学模型和模块化架构,被全球顶尖…...

UniApp登录注册页面实战:从零搭建到接口联调(附完整代码)

UniApp登录注册页面实战:从零搭建到接口联调 在移动应用开发中,登录注册功能是几乎所有应用的基础模块。作为开发者,我们不仅需要实现功能,还要考虑用户体验、安全性和性能优化。本文将带你从零开始构建一个完整的UniApp登录注册系…...

Windows系统下Apache Superset一站式部署与避坑指南

1. 环境准备:从零搭建Python生态 在Windows系统部署Apache Superset前,需要先构建稳定的Python运行环境。我强烈推荐使用Anaconda作为基础工具链,它不仅能自动处理Python版本管理,还能解决后续可能出现的依赖冲突问题。去年我在客…...

PyTorch 2.8实战:利用GPU加速快速训练你的第一个神经网络

PyTorch 2.8实战:利用GPU加速快速训练你的第一个神经网络 1. 准备工作与环境搭建 1.1 为什么选择PyTorch 2.8 PyTorch 2.8作为最新稳定版本,带来了多项性能优化和新特性。对于初学者而言,最值得关注的是它对GPU加速的全面支持,…...

基于STM32的数字频率计系统设计与实现解析

基于stm32的频率计设计本文深入剖析一款基于STM32F10x系列微控制器的数字频率计系统。该系统旨在对外部输入信号进行高精度、实时的频率测量,并通过仿真环境验证其功能。整个设计充分利用了STM32丰富的片上外设资源,构建了一个结构清晰、性能可靠的嵌入式…...

Qwen3-0.6B-FP8在Java面试题智能解答中的应用实战

Qwen3-0.6B-FP8在Java面试题智能解答中的应用实战 最近和几个做Java开发的朋友聊天,发现大家准备面试时都挺头疼的。网上资料虽然多,但质量参差不齐,有时候找个靠谱的答案得翻好几个网站。而且每个人的基础和理解深度不一样,有些…...

问卷设计:从“匠人手工”到“书匠策AI智造”的华丽转身

书匠策AI官网:www.shujiangce.com 微信公众号搜一搜:书匠策AI 在学术研究的广袤天地里,问卷设计犹如一座桥梁,连接着研究者与受访者的心灵,传递着知识的火花。然而,传统问卷设计往往如同匠人手工雕琢&…...

单片机/C语言八股:(十四)const 关键字的作用(和 define 比呢?)

上一篇下一篇C 语言实现矩阵乘法 目 录 const 关键字的作用(和 define 比呢?)1)const 修饰变量① 局部变量(函数内部)② 全局变量(文件作用域) 2)const 与指针的组合&…...

想学AI大模型应用开发,努力的顺序不能反!

因篇幅有限,仅展示部分资料,需要点击下方链接即可前往获取...

2026年档案管理软件:数字时代的“记忆守护者“

2026年档案管理软件:数字时代的"记忆守护者" 在信息爆炸的今天,企业每天产生的文档数量呈指数级增长。一份合同、一张发票、一封邮件,这些看似普通的文件,实则承载着组织的核心记忆。如何高效管理这些"数字资产&qu…...

常用Git命令总结

Git(读音为/git/)是一个开源的分布式版本控制系统,凭借高效、灵活的特性,能够轻松处理从小型项目到大型项目的版本管理需求,是程序员日常开发中不可或缺的工具。 整理了自己日常开发中高频使用的Git命令,按…...

告别卡顿!AI写作大师Qwen3-4B CPU优化实战:16GB内存稳定运行技巧

告别卡顿!AI写作大师Qwen3-4B CPU优化实战:16GB内存稳定运行技巧 1. 为什么选择Qwen3-4B-Instruct在CPU上运行? 在大多数人的认知中,40亿参数的大模型似乎必须依赖高端GPU才能运行。然而,Qwen3-4B-Instruct通过精心设…...

Qt for Android(Android Studio) 连接各种模拟器

虚拟机按照Android机启动开发者模式雷电模拟器直接就可以使用1、夜神模拟器 nox_adb.exe connect 127.0.0.1:62001(效果不好)nox_adb.exe devices 2、通用: adb.exe connect 127.0.0.1:62001(暂不确定)...

如何设计一个可扩展的CRM客户管理模块

温馨提示:文末有资源获取方式 在企业数字化转型的浪潮中,CRM系统不再是简单的“客户通讯录”。一个设计优秀的客户管理模块,必须同时满足销售团队的易用性、管理层的可视化以及IT部门的二次开发需求。最近,帮企团队发布了一套基于…...