stm8s103k3 周期 捕获_STM8S103之tim1捕获周期及占空比

本文详细介绍了如何使用STM8S103F3P6微控制器的定时器1进行周期和占空比的捕获。通过配置系统时钟、初始化定时器1、设置输入捕获以及编写中断服务函数,实现了对100Hz信号的捕获,结果显示周期为10000us,占空比为50%,验证了实验的准确性。
摘要由CSDN通过智能技术生成

本文以STM8S103F3P6编程为例,介绍STM8S103F3P6定时器1捕获周期及占空比

电脑平台:Windows7 64位旗舰

编译软件:IAR

硬件平台:STM8S103F3P6

1.系统时钟初始化为内部16M

CLK_HSIPrescalerConfig(CLK_PRESCALER_HSIDIV1);    //时钟   初始化时钟为1分频 16M   2分频8M

2.初始化定时器1设置PC6为捕获输入

void Init_Timer1(void)

{

GPIO_Init(GPIOC, GPIO_PIN_6, GPIO_MODE_IN_FL_NO_IT);   //输入浮动,没有外部中断

TIM1_DeInit();                                         //tim1 定时器寄存器全部复位

TIM1_TimeBaseInit(0x0f, TIM1_COUNTERMODE_UP, 50000-1, 0);//  50ms  最小捕获50hz      设置时间分频  向上计数    捕捉50Hz及 以上的周期和占空比

TIM1_PWMIConfig(TIM1_CHANNEL_1, TIM1_ICPOLARITY_RISING, TIM1_ICSELECTION_DIRECTTI, TIM1_ICPSC_DIV1, 0x00); //选择TI1输入上升沿触发 选择TI2输入下降沿触发 输入捕捉预定标器  无滤波

TIM1_SelectInputTrigger(TIM1_TS_TI1FP1);   //滤波后输入TI1

TIM1_SelectSlaveMode(TIM1_SLAVEMODE_RESET);//复位输入

TIM1_ClearFlag(TIM1_FLAG_CC1);                         //指定要清除的标志

TIM1_ClearFlag(TIM1_FLAG_CC2);                         //指定要清除的标志

TIM1_ITConfig( TIM1_IT_CC1, ENABLE);                  //去掉是查询方式,否则是中断方式

TIM1_ITConfig( TIM1_IT_CC2, ENABLE);                  //去掉是查询方式,否则是中断方式

TIM1_CCxCmd(TIM1_CHANNEL_1, ENABLE);                   //使能输入捕获通道1

TIM1_CCxCmd(TIM1_CHANNEL_2, ENABLE);                   //使能输入捕获通道2

TIM1_Cmd(ENABLE);                                      //使能定时器

}

3.编写主函数

void main(void)

{

CLK_HSIPrescalerConfig(CLK_PRESCALER_HSIDIV1);    //内部时钟16M

Init_UART1();

Init_Timer1();

enableInterrupts();

while(1);

}

4、编写中断服务函数

INTERRUPT_HANDLER(TIM1_CAP_COM_IRQHandler, 12)

{

uint16_t num = 0;

static uint16_t num1;

static float num2;

uint8_t data[11]={0};

uint8_t len = 0;

if(TIM1_GetITStatus(TIM1_IT_CC1) != RESET) //如果CH1边沿触发

{

num1 = TIM1_GetCapture1();

TIM1_ClearITPendingBit(TIM1_IT_CC1);    //清除标志位

}

else if(TIM1_GetITStatus(TIM1_IT_CC2) != RESET) //如果CH2边沿触发

{

num2 = TIM1_GetCapture2();             //

TIM1_ClearITPendingBit(TIM1_IT_CC2);    //清除标志位

num = (uint16_t)((num2 / num1) * 100.0); //计算占空比

data[len++] = num1 / 10000 % 10 + '0';

data[len++] = num1 / 1000 % 10 + '0';

data[len++] = num1 / 100 % 10 + '0';

data[len++] = num1 / 100 % 10 + '0';

data[len++] = num1 / 10 % 10 + '0';

data[len++] = num1 % 10 + '0';

data[len++] = 'n';         //输出周期时间  单位us

data[len++] = num / 100 % 10 + '0';

data[len++] = num / 10 % 10 + '0';

data[len++] = num  % 10 + '0';

data[len++] = 'n';         //输出占空比   单位 50% = 50

Set_UART1Interrupt(data,len);

}

}

5、结果

输入100Hz,占空比为50%,结果输出周期10000us 占空比为50% 结果正确,实验成功。

下面是STM32F103 TIM1输入捕获测量频率,周期占空比的代码示例: 1. 配置TIM1输入捕获模式: ```c TIM_ICInitTypeDef TIM_ICInitStructure; TIM_ICInitStructure.TIM_Channel = TIM_Channel_1; TIM_ICInitStructure.TIM_ICPolarity = TIM_ICPolarity_Rising; TIM_ICInitStructure.TIM_ICSelection = TIM_ICSelection_DirectTI; TIM_ICInitStructure.TIM_ICPrescaler = TIM_ICPSC_DIV1; TIM_ICInitStructure.TIM_ICFilter = 0x0; TIM_ICInit(TIM1, &TIM_ICInitStructure); TIM_Cmd(TIM1, ENABLE); ``` 2. 定义变量存储捕获的值: ```c uint16_t IC1Value = 0; uint16_t IC2Value = 0; ``` 3. 在TIM1输入捕获中断处理函数中获取捕获的值: ```c void TIM1_CC_IRQHandler(void) { if(TIM_GetITStatus(TIM1, TIM_IT_CC1) != RESET) { TIM_ClearITPendingBit(TIM1, TIM_IT_CC1); IC1Value = TIM_GetCapture1(TIM1); } else if(TIM_GetITStatus(TIM1, TIM_IT_CC2) != RESET) { TIM_ClearITPendingBit(TIM1, TIM_IT_CC2); IC2Value = TIM_GetCapture2(TIM1); } } ``` 4. 计算测量值: ```c uint32_t TIM1Freq = SystemCoreClock / (TIM_GetPrescaler(TIM1) + 1); uint32_t TIM1Period = (IC2Value - IC1Value + 0xFFFF) % 0xFFFF; float TIM1DutyCycle = 100.0 * (IC2Value - IC1Value) / TIM1Period; ``` 其中,`SystemCoreClock`为系统时钟频率。 完整代码示例: ```c #include "stm32f10x.h" uint16_t IC1Value = 0; uint16_t IC2Value = 0; int main(void) { RCC_APB2PeriphClockCmd(RCC_APB2Periph_TIM1, 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(TIM1, &TIM_TimeBaseStructure); TIM_ICInitTypeDef TIM_ICInitStructure; TIM_ICInitStructure.TIM_Channel = TIM_Channel_1; TIM_ICInitStructure.TIM_ICPolarity = TIM_ICPolarity_Rising; TIM_ICInitStructure.TIM_ICSelection = TIM_ICSelection_DirectTI; TIM_ICInitStructure.TIM_ICPrescaler = TIM_ICPSC_DIV1; TIM_ICInitStructure.TIM_ICFilter = 0x0; TIM_ICInit(TIM1, &TIM_ICInitStructure); TIM_ICInitStructure.TIM_Channel = TIM_Channel_2; TIM_ICInitStructure.TIM_ICPolarity = TIM_ICPolarity_Falling; TIM_ICInit(TIM1, &TIM_ICInitStructure); NVIC_InitTypeDef NVIC_InitStructure; NVIC_InitStructure.NVIC_IRQChannel = TIM1_CC_IRQn; NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 0; NVIC_InitStructure.NVIC_IRQChannelSubPriority = 0; NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE; NVIC_Init(&NVIC_InitStructure); TIM_ITConfig(TIM1, TIM_IT_CC1 | TIM_IT_CC2, ENABLE); TIM_Cmd(TIM1, ENABLE); while(1); } void TIM1_CC_IRQHandler(void) { if(TIM_GetITStatus(TIM1, TIM_IT_CC1) != RESET) { TIM_ClearITPendingBit(TIM1, TIM_IT_CC1); IC1Value = TIM_GetCapture1(TIM1); } else if(TIM_GetITStatus(TIM1, TIM_IT_CC2) != RESET) { TIM_ClearITPendingBit(TIM1, TIM_IT_CC2); IC2Value = TIM_GetCapture2(TIM1); } uint32_t TIM1Freq = SystemCoreClock / (TIM_GetPrescaler(TIM1) + 1); uint32_t TIM1Period = (IC2Value - IC1Value + 0xFFFF) % 0xFFFF; float TIM1DutyCycle = 100.0 * (IC2Value - IC1Value) / TIM1Period; } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值