STM32定时器基本知识

这篇具有很好参考价值的文章主要介绍了STM32定时器基本知识。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

STM32定时器

PWM模式
#include "stm32f4xx.h"

void GPIO_Configuration(void);
void TIM3_Configuration(void);

int main(void)
{
    GPIO_Configuration();
    TIM3_Configuration();
    
    while (1)
    {
        // 在这里可以根据需要调整电机的运动状态
    }
}

void GPIO_Configuration(void)
{
    GPIO_InitTypeDef GPIO_InitStructure;

    // 使能GPIOB时钟
    RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_GPIOB, ENABLE);

    // 配置PB4引脚为复用功能,用于TIM3的通道1
    GPIO_InitStructure.GPIO_Pin = GPIO_Pin_4;
    GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF; // 复用功能
    GPIO_InitStructure.GPIO_OType = GPIO_OType_PP; // 推挽输出
    GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_UP; // 上拉
    GPIO_InitStructure.GPIO_Speed = GPIO_Speed_100MHz; // 100MHz
    GPIO_Init(GPIOB, &GPIO_InitStructure);

    // 配置PB4引脚为TIM3的通道1
    GPIO_PinAFConfig(GPIOB, GPIO_PinSource4, GPIO_AF_TIM3);
}

void TIM3_Configuration(void)
{
    TIM_TimeBaseInitTypeDef TIM_TimeBaseStructure;
    TIM_OCInitTypeDef TIM_OCInitStructure;

    // 使能TIM3时钟
    RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM3, ENABLE);

    // 配置TIM3的基本参数
    TIM_TimeBaseStructure.TIM_Period = 999; // PWM周期为1000个时钟周期
    TIM_TimeBaseStructure.TIM_Prescaler = 8399; // 时钟预分频为8400,使定时器时钟为10kHz
    TIM_TimeBaseStructure.TIM_ClockDivision = 0;
    TIM_TimeBaseStructure.TIM_CounterMode = TIM_CounterMode_Up;
    TIM_TimeBaseInit(TIM3, &TIM_TimeBaseStructure);

    // 配置TIM3的通道1为PWM模式1
    TIM_OCInitStructure.TIM_OCMode = TIM_OCMode_PWM1;
    TIM_OCInitStructure.TIM_OutputState = TIM_OutputState_Enable;
    TIM_OCInitStructure.TIM_OCPolarity = TIM_OCPolarity_High;
    TIM_OC1Init(TIM3, &TIM_OCInitStructure);

    // 启动TIM3的通道1
    TIM_OC1PreloadConfig(TIM3, TIM_OCPreload_Enable);

    // 启动TIM3
    TIM_Cmd(TIM3, ENABLE);
}

在上面的例子中,我们使用了STM32的定时器3和GPIOB的引脚4来控制电机的运动。

首先,我们需要在GPIO配置函数中使能GPIOB的时钟,并将PB4引脚配置为复用功能,用于TIM3的通道1。

然后,在定时器配置函数中,我们使能了TIM3的时钟,并配置了TIM3的基本参数和通道1的PWM模式。

最后,我们在主函数中可以根据需要调整电机的运动状态。

上述代码中,我们使用了STM32的定时器3的通道1来输出PWM信号。在TIM3的配置函数中,我们使用了TIM_OCMode_PWM1模式来配置通道1为PWM输出模式1。

在PWM模式1下,当计数器的值小于或等于通道的比较值时,输出为高电平当计数器的值大于通道的比较值时,输出为低电平通过调整比较值的大小,我们可以控制PWM信号的占空比,从而控制电机的运动状态

在上述代码中,我们将TIM3的周期设置为999,即PWM周期为1000个时钟周期。我们将TIM3的预分频器设置为8399,使得TIM3的时钟频率为10kHz。这样,我们可以通过调整比较值(即TIM3的通道1的比较寄存器的值)来控制PWM信号的占空比。

例如,如果我们将比较值设置为500,那么PWM信号的占空比将为50%(高电平500个时钟周期,低电平500个时钟周期),电机将以一定速度运动。如果我们将比较值设置为100,那么PWM信号的占空比将为10%(高电平100个时钟周期,低电平900个时钟周期),电机将以较慢的速度运动。

在主函数中,我们可以根据需要调整比较值的大小从而控制电机的运动状态


在上述代码中,电机的控制周期是通过定时器TIM3的配置来确定的。具体来说,我们将TIM3的周期设置为999,即PWM周期为1000个时钟周期。同时,我们将TIM3的预分频器设置为8399,使得TIM3的时钟频率为10kHz。因此,电机的控制周期为1000个时钟周期,即每个周期的时间为1000个时钟周期的时间。由于TIM3的时钟频率为10kHz,因此电机的控制周期为1000个时钟周期的时间,即0.1秒。

需要注意的是,电机的控制周期可以根据实际需求进行调整。在上述代码中,我们将TIM3的预分频器设置为8399,使得TIM3的时钟频率为10kHz,以便实现较高的控制精度。如果需要更快的控制周期,可以调整预分频器的值和TIM3的周期的值。
在代码中,我们将TIM3的预分频器设置为8399,使得TIM3的时钟频率为10kHz。而TIM3的周期被设置为999,即PWM周期为1000个时钟周期。因此,每个时钟周期的时间是由TIM3的时钟频率决定的,即100us(1 / 10kHz)。

由于TIM3的周期被设置为999,所以PWM信号的一个完整周期需要1000个时钟周期,即100ms(100us * 1000)。这个周期内,PWM信号的高电平时间(占空比)由比较值(TIM3的通道1的比较寄存器的值)决定。

所以,每个时钟周期的时间并不是1000个时钟周期,而是由TIM3的时钟频率决定的。在上述代码中,TIM3的时钟频率为10kHz,因此每个时钟周期的时间为100us。
编码器模式

以下是一个使用STM32的定时器4设置为编码器模式,并通过脉冲数来判断电机转动位置的示例代码:

#include "stm32f4xx.h"

#define ENCODER_PULSES_PER_REVOLUTION 1000 // 每转脉冲数
#define MOTOR_GEAR_RATIO 10 // 电机齿轮比

volatile int32_t encoder_count = 0; // 编码器计数器

void TIM4_IRQHandler(void)
{
    if (TIM_GetITStatus(TIM4, TIM_IT_Update) != RESET) {
        // 每次定时器溢出中断发生时,更新编码器计数器
        encoder_count += (TIM4->CR1 & TIM_CR1_DIR) ? -1 : 1;
        TIM_ClearITPendingBit(TIM4, TIM_IT_Update);
    }
}

void configure_encoder(void)
{
    RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM4, ENABLE);

    TIM_TimeBaseInitTypeDef TIM_TimeBaseStructure;
    TIM_TimeBaseStructure.TIM_Period = 0xFFFF;
    TIM_TimeBaseStructure.TIM_Prescaler = 0;
    TIM_TimeBaseStructure.TIM_ClockDivision = 0;
    TIM_TimeBaseStructure.TIM_CounterMode = TIM_CounterMode_Up;
    TIM_TimeBaseInit(TIM4, &TIM_TimeBaseStructure);

    TIM_EncoderInterfaceConfig(TIM4, TIM_EncoderMode_TI12, TIM_ICPolarity_Rising, TIM_ICPolarity_Rising);
    TIM_SetAutoreload(TIM4, 0xFFFF);

    TIM_ClearFlag(TIM4, TIM_FLAG_Update);
    TIM_ITConfig(TIM4, TIM_IT_Update, ENABLE);

    NVIC_InitTypeDef NVIC_InitStructure;
    NVIC_InitStructure.NVIC_IRQChannel = TIM4_IRQn;
    NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 0;
    NVIC_InitStructure.NVIC_IRQChannelSubPriority = 0;
    NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;
    NVIC_Init(&NVIC_InitStructure);

    TIM_Cmd(TIM4, ENABLE);
}

int32_t get_motor_position(void)
{
    int32_t pulses_per_revolution = ENCODER_PULSES_PER_REVOLUTION * MOTOR_GEAR_RATIO;
    return (encoder_count * 360) / pulses_per_revolution;
}

int main(void)
{
    configure_encoder();

    while (1) {
        int32_t position = get_motor_position();
        // 在这里使用获取到的位置进行相应的操作
    }
}

在这个示例代码中,我们首先定义了每转脉冲数和电机齿轮比,然后声明了一个全局的encoder_count变量来存储编码器脉冲计数。

TIM4_IRQHandler中断处理函数中,我们在每次定时器溢出中断发生时更新encoder_count变量。根据定时器的方向位来判断是增加还是减少计数。

configure_encoder函数用于配置定时器4为编码器模式,设置定时器的时钟分频、计数模式和编码器接口。

get_motor_position函数用于计算电机的位置,根据编码器计数和设定的脉冲数和齿轮比来计算电机的位置。

main函数中,我们通过调用configure_encoder函数来配置编码器,然后在一个无限循环中不断获取电机的位置并进行相应的操作。

请注意,以上代码仅为示例,具体的实现可能需要根据您的具体硬件和需求进行适当的修改。文章来源地址https://www.toymoban.com/news/detail-511809.html

代码中的定时器4编码器模式

以上代码是使用STM32的定时器4设置为编码器模式,并实时输出脉冲数的示例。

首先,在Encoder_Init_TIM4函数中,进行了以下设置:
1. 使能TIM4时钟和PORTB时钟。
2. 配置GPIOB的PB6和PB7引脚为浮空输入模式。
3. 初始化TIM4的预分频器和计数器自动重装值。
4. 选择时钟分频为不分频,选择计数模式为边沿对齐模式。
5. 配置输入捕获1滤波器和所有输入上升沿和下降沿都有效。
6. 设定计数器初始值。
7. 使能定时器。

然后,Read_Encoder函数用于单位时间读取编码器计数。根据传入的TIMX参数,选择相应的定时器,并返回其计数值。
在Encoder_Init_TIM4函数中,设置了定时器的计数器初始值为TIM4->CNT = 10000; 这里将计数器初始值设为一个固定值,可以根据实际需求进行调整。

然后,在Read_Encoder函数中,根据传入的TIMX参数选择相应的定时器,通过读取对应定时器的CNT寄存器,即可获取到编码器的计数值。

例如,如果传入的TIMX为4,则通过读取TIM4的CNT寄存器来获取编码器的计数值:
Encoder_TIM= (short)TIM4 -> CNT;

注意,这里使用了(short)进行类型转换,将CNT寄存器的值转换为一个有符号的短整型,以适应不同的计数范围。具体的计数范围可以根据实际的编码器和定时器配置进行调整。
(int)TIM4->CNT; 是将 TIM4 的 CNT 寄存器的值强制转换为 int 类型的数据。CNT 寄存器是定时器/计数器的计数器值寄存器,用于存储当前的计数器值。

在编码器模式下,TIM4 的 CNT 寄存器会根据编码器的脉冲输入进行自动计数。每当编码器的脉冲信号发生一个上升沿或下降沿时,CNT 寄存器的值就会相应地增加或减少。

通过读取 CNT 寄存器的值,可以获取当前的编码器计数值。在示例代码中,通过将 CNT 寄存器的值强制转换为 int 类型,可以将计数值作为整数返回。

到了这里,关于STM32定时器基本知识的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • STM32—定时器(TIM)_基本定时

    本文主要通过介绍定时器基本结构去学习如何使用定时器进行定时。 定时器可以对输入的时钟进行计数,并在计数值达到设定值时触发中断,从而达到计时功能。 本文从通用定时器介绍。本文所使用芯片为 STM32F103C8T6,拥有TIM1-TIM4 四个定时器资源。 图.2为基本定时器结构  

    2024年02月02日
    浏览(50)
  • STM32基本定时器中断

    提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 提示:这里可以添加本文要记录的大概内容: 定时器有什么用?精准延时,PWM,做一个时钟:年月日,时分秒。时钟最基本的就是1s怎么来? 提示:以下是本篇文章正文内容,下面案例可供参考 1.1如何实

    2024年02月06日
    浏览(49)
  • STM32中TIM定时器定时功能详解(适用基本,通用,高级定时器)

    定时器有高级定时器、通用定时器、基本定时器三种类型。具体功能如下。 上面是每种定时器所具有的功能。 我们可以看到每种定时器都有一个定时功能,(可能是名字的由来吧)。当然,每个定时器都可以来使用定时功能,但是我们往往在基本定时器和通用定时器上面使用

    2024年01月19日
    浏览(63)
  • STM32之基本定时器中断

    一、TIM(Timer)定时器 基本定时器中断可以对输入的时钟进行计数,并在计数值达到设定值(自动重装值)时触发中断; 16位计数器、预分频器、自动重装寄存器的时基单元,在72MHz计数时钟下可以实现最大59.65s的定时; 不仅具备基本的定时中断功能,而且还包含内外时钟源

    2024年02月08日
    浏览(44)
  • 聊聊STM32的基本定时器

      STM32 的基本定时器(Basic Timer)是一种简单的定时器模块,用于生成基于时钟频率的定时中断。它可以用于实现各种定时和计时功能,例如延时、频率测量、PWM 生成等。 基本定时器通常由一个 16 位的自由运行计数器和一个预分频器组成。计数器的值可以根据预分频器的设

    2024年02月16日
    浏览(46)
  • STM32CubeMX教程5 TIM 定时器概述及基本定时器

    开发板(STM32F407G-DISC1) STM32CubeMX软件(Version 6.10.0) keil µVision5 IDE(MDK-Arm) ST-LINK/V2驱动 逻辑分析仪nanoDLA 使用STM32CubeMX软件配置STM32F407开发板 使用基本定时器TIM6实现每500ms控制绿灯状态变化一次,基本定时器TIM7实现每1s控制红灯状态变化一次 STM32F407拥有2个基础定时器、

    2024年02月03日
    浏览(92)
  • STM32 基本定时器反转LED

    引脚是什么为什么要初始化引脚?      在嵌入式系统中,引脚是微控制器或微处理器上的物理引脚,用于连接外部设备、传感器或其他芯片。每个引脚都有特定的功能和用途,例如输入、输出、模拟输入、电源供应等。STM32F103C8T6引脚图: 初始化引脚的目的在于: 确定引脚

    2024年01月25日
    浏览(44)
  • # HAL库STM32常用外设教程(四)—— 定时器 基本定时

    1、STM32F407ZGT6 2、STM32CubeMx软件 3、keil5 内容简述: 通篇文章将涉及以下内容,如有错误,欢迎指出 : 1、基础定时器特性 2、基础定时器的结构和功能 3、基础定时器HAL库驱动程序 (1)CubeMx配置 (2)TIM驱动程序   STM32F407有2个高级控制定时器(TIM1、TIM8)、8个通用定时器和

    2024年02月02日
    浏览(68)
  • 【STM32】定时器PWM模式详解

    PWM模式: PWM模式1,向上计数时,PWM信号从 有效电平 变为 无效电平 PWM模式2,向上计数时,PWM信号从 无效电平 变为 有效电平 PWM极性: 极性为高时, 高电平为有效电平 ,低电平为无效电平 极性为低时, 低电平为有效电平 ,高电平为无效电平 中心对齐模式(先向上再向下

    2024年02月09日
    浏览(39)
  • STM32物联网实战开发(4)——基本定时器

            我使用的是正点原子的阿波罗F429开发板,他有14个定时器,本次实验使用STM32F429的基本定时器6作定时,在中断中每隔1秒翻转LED电平状态。 1.CubeMX初始化定时器 先开启定时器6          再对定时器6的参数进行配置,将定时器6定时时间配置为 5ms ,在中断中再累

    2024年02月01日
    浏览(39)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包