STM32CubeMX,定时器之定时功能,入门学习,如何设置prescaler,以及timer计算PWM输入捕获方法(重要)

频率变小,周期变长

1,参考链接(重要)

STM32CubeMX------定时器之定时功能(学习使用timer定时器的设置)
STM32测量PWM信息(学习使用设置pwm输入捕获)
通用定时器中两个重要参数的设置心得(TIM_Prescaler、TIM_Period)

2,视频学习

【STM32F030C8T6系列】5. 实验例程------PWM输入实验(重要)

这个视频的里面设置的有点问题:prescaler这里设置的有问题吧,应该是8000-1吧

3,我自己的设置:

计算的方式很多,我喜欢用这种计算方式,比较直接,当然可以选择下面两种计算方法,这三种计算方法分别在上面的参考链接里。

我的计算(8000/8000 000)*500=0.5s也就是20HZ,也就是支持500ms的周期,一般我们就按照计算的值来作为周期了。
如果我要100hz,也就是10次上报一次,这里不写500-1,写10-1了,也就是10ms,也就是100HZ,也就是我计算可以支持0-100HZ的pwm输入了。当然也可以通过修改预分频率的值。

1选择TIM2

2定时器时钟选择内部时钟

Clock Source(时钟来源)

计数器设置:

Prtscaler (定时器预分频系数) : 31999

Counter Mode(计数模式) : Up(向上计数模式)

Counter Period(自动重装载值) : 499

CKD(时钟分频因子) : No Division 不分频 (可以选择二分频和四分频 )

auto-reload-preload(自动重装载) : Enable 使能

定时器的定时周期

T = (psc+1)(arr+1)/Tclk

psc 为定时器预分频系数

arr为自动重装载值

Tclk为系统时钟频率

通过计算
T = (psc+1)(arr+1)/Tclk=(31999+1)(499+1)/32us=500ms


4,其他设置案例详细说明:

A.案例1

主频72MHZ,最大计数次数5000,所以系统的最小采样频率是:2HZ,最大采样频率是72MHZ

一般为了方便中断,我们都是按照计数完成之后再触发,所以采样频率就是2hz,也就是500ms

//对于71MHZ的频率,500ms中断一次,这两个参数设置如下:

TIM_Prescaler=7199; //预分频值

TIM_Period=4999; //下一个更新事件装入活动的自动重装载寄存器周期的值

//分频7200,用72000000/7200=10000Hz

//此时的周期就是1/10000=0.0001s

//500ms=0.0001s*5000次

//5000-1=4999次

//即通过4999次系统的运行,就是500ms


B.案例2

72M的主时钟,7200分频后,单个计数时间是0.0001秒,最大计时长度是0.0001*65535=0.65535秒,所以最小频率不能小于1.5Hz。同时这个分频也影响你对频率测量的精度。

相关推荐
许白掰1 小时前
Linux入门篇学习——Linux 编写第一个自己的命令,make 工具和 makefile 文件
linux·运维·服务器·学习
李白洗一夜2 小时前
(新手友好)MySQL学习笔记(12):触发器,视图,三范式
笔记·学习·mysql
baynk6 小时前
逆向入门(9)汇编篇-bound指令的学习
汇编·学习
EutoCool8 小时前
Qt:布局管理器Layout
开发语言·c++·windows·嵌入式硬件·qt·前端框架
网易独家音乐人Mike Zhou9 小时前
【Linux应用】开发板USB共享网络,网线或USB以太网共享网络(局域网连接PC和开发板,实现PC给开发板共享网络,USB通过NDIS驱动共享)
linux·网络·单片机·mcu·物联网·嵌入式·iot
小眼睛FPGA9 小时前
【RK3568+PG2L50H开发板实验例程】FPGA部分 | DDR3 读写实验例程
科技·嵌入式硬件·ai·fpga开发·fpga
DoraBigHead10 小时前
比特的尽头,是世界的入口
网络协议
future141210 小时前
游戏开发日记
数据结构·学习·c#
棱镜研途11 小时前
学习笔记丨卷积神经网络(CNN):原理剖析与多领域Github应用
图像处理·笔记·学习·计算机视觉·cnn·卷积神经网络·信号处理
皮蛋sol周12 小时前
嵌入式学习C语言(八)二维数组及排序算法
c语言·学习·算法·排序算法