使用STM32的定时器进行输入脉冲的计数

合集下载

stm32脉冲计数原理

stm32脉冲计数原理

stm32脉冲计数原理一、介绍在嵌入式系统开发中,我们经常需要对脉冲进行计数,以测量某种事件的频率或持续时间。

stm32是一系列基于Cortex-M内核的32位微控制器,具有强大的计数功能,可以轻松实现脉冲计数。

二、stm32计数器基础stm32微控制器通常具有多个计数器,这些计数器可以提供高精度和高速的计数能力。

stm32的计数器通常是由一个预分频器、一个计数器和一个自动装载寄存器组成。

2.1 预分频器预分频器可以将输入脉冲的频率降低到计数器的工作范围内。

它通常采用二进制计数器或16位定时器进行实现,可以根据需要设置不同的分频比。

2.2 计数器计数器用于计数输入脉冲的数量。

stm32的计数器通常是一个16位或32位的寄存器,可以根据需要进行设置。

2.3 自动装载寄存器自动装载寄存器用于设置计数器的上限值。

当计数器达到该值时,会自动重置计数器,并触发一个中断或其他事件。

三、stm32脉冲计数原理stm32的脉冲计数原理基于计数器的工作方式和外部脉冲的输入引脚。

通过配置计数器的工作模式和相关的寄存器,可以实现对输入脉冲的计数。

3.1 输入捕获模式输入捕获模式是常用的脉冲计数方式之一。

在该模式下,stm32可以捕获到外部脉冲的上升沿或下降沿,并将计数器的值保存在相关的寄存器中。

3.2 边沿对齐模式边沿对齐模式是另一种常用的脉冲计数方式。

在该模式下,stm32可以捕获到外部脉冲的上升沿和下降沿,并将计数器的值保存在两个相关的寄存器中。

3.3 测量脉冲频率通过对输入脉冲的计数和计时,可以测量脉冲的频率。

根据 stm32 提供的计数器的位数,可以计算出脉冲的高精度频率值。

3.4 测量脉冲持续时间除了测量脉冲频率,stm32还可以测量脉冲的持续时间。

通过记录脉冲的开始时间和结束时间,可以计算出脉冲的持续时间。

四、stm32脉冲计数的应用stm32脉冲计数广泛应用于各种需要对脉冲进行计数的场景,例如:4.1 频率测量通过 stm32 脉冲计数功能,可以测量各种信号源的频率,如电机转速、传感器输出等。

STM32输入捕获的脉冲宽度及频率计算

STM32输入捕获的脉冲宽度及频率计算

STM32输入捕获的脉冲宽度及频率计算脉冲宽度的计算:脉冲宽度是指脉冲信号的高电平或低电平持续的时间。

在STM32中,定时器的输入捕获模式可以测量脉冲宽度。

输入捕获模式下,定时器会记录脉冲边沿的时间戳,可以通过计算时间戳之差来得到脉冲宽度。

具体的计算方法如下:1.配置定时器为输入捕获模式,并设置触发边沿(上升沿或下降沿)。

2.当捕获到脉冲边沿时,获取当前的定时器计数器值,作为开始时间戳。

3.当下一个脉冲边沿到来时,再次获取当前的定时器计数器值,作为结束时间戳。

4.计算时间戳之差,即为脉冲宽度。

脉冲频率的计算:脉冲频率是指单位时间内脉冲信号的个数。

脉冲频率的计算可以通过测量脉冲的周期来实现。

在STM32中,定时器的输入捕获模式可以测量脉冲的周期。

具体的计算方法如下:1.配置定时器为输入捕获模式,并设置触发边沿(上升沿或下降沿)。

2.当捕获到脉冲边沿时,获取当前的定时器计数器值,作为开始时间戳。

3.当接收到下一个脉冲边沿时,再次获取当前的定时器计数器值,作为结束时间戳。

4.计算时间戳之差,即为脉冲的周期。

5.频率等于周期的倒数。

需要注意的是,输入捕获功能只能测量单个脉冲的宽度和周期,如果要测量信号源的频率或平均脉冲宽度,需要根据测量的脉冲个数进行统计和计算。

以下是一个示例代码,演示了如何使用STM32的输入捕获功能计算脉冲宽度和频率:```c#include "stm32f4xx.h"//定义输入捕获相关的变量volatile uint32_t startTimestamp = 0;volatile uint32_t endTimestamp = 0;volatile uint32_t pulseWidth = 0;volatile uint32_t pulsePeriod = 0;volatile uint32_t pulseFrequency = 0;void TIM2_IRQHandler(void)if (TIM_GetITStatus(TIM2, TIM_IT_CC1) != RESET)if (startTimestamp == 0)startTimestamp = TIM_GetCapture1(TIM2);} elseendTimestamp = TIM_GetCapture1(TIM2);pulseWidth = endTimestamp - startTimestamp;pulsePeriod = pulseWidth * 2;pulseFrequency = SystemCoreClock / pulsePeriod;startTimestamp = 0;}TIM_ClearITPendingBit(TIM2, TIM_IT_CC1);}int main(void)//初始化定时器2TIM_TimeBaseInitTypeDef TIM_TimeBaseInitStruct;TIM_DeInit(TIM2);TIM_TimeBaseInitStruct.TIM_CounterMode = TIM_CounterMode_Up; // 设置计数器为向上计数模式TIM_TimeBaseInitStruct.TIM_Period = 0xFFFFFFFF; // 设置计数器的溢出值为最大值TIM_TimeBaseInitStruct.TIM_ClockDivision = TIM_CKD_DIV1; // 设置时钟分割TIM_TimeBaseInitStruct.TIM_RepetitionCounter = 0; // 设置重复计数值为0TIM_TimeBaseInit(TIM2, &TIM_TimeBaseInitStruct);//配置输入捕获模式TIM_ICInitTypeDef TIM_ICInitStruct;TIM_ICInitStruct.TIM_Channel = TIM_Channel_1; // 选择定时器通道1TIM_ICInitStruct.TIM_ICPolarity = TIM_ICPolarity_Rising; // 设置捕获参数,上升沿触发TIM_ICInitStruct.TIM_ICSelection = TIM_ICSelection_DirectTI; // 设置输入映射,直接连接至TIM2_IC1管脚TIM_ICInitStruct.TIM_ICPrescaler = TIM_ICPSC_DIV1; // 设置输入分频,不分频TIM_ICInitStruct.TIM_ICFilter = 0; // 不开启滤波器TIM_ICInit(TIM2, &TIM_ICInitStruct);//开启输入捕获中断TIM_ClearITPendingBit(TIM2, TIM_IT_CC1);TIM_ITConfig(TIM2, TIM_IT_CC1, ENABLE);//启动定时器2TIM_Cmd(TIM2, ENABLE);while (1)}```在上述示例代码中,定时器2被配置为输入捕获模式,通过TIM2的通道1测量脉冲输入。

stm32定时器的使用流程

stm32定时器的使用流程

STM32定时器的使用流程1. 简介STM32定时器是STM32系列微控制器中重要的外设之一。

定时器可以用于生成特定的定时器事件,实现计时、测量时间间隔、产生PWM信号等功能。

本文将介绍STM32定时器的使用流程。

2. STM32定时器的基本工作原理STM32定时器通常由一个或多个计数器和若干个通道组成。

计数器用于计算时间的流逝,而通道用于控制输出。

计数器的计数范围和分辨率可以根据需求进行配置。

通常情况下,定时器通过外部时钟源进行计数,也可以使用内部时钟源。

3. STM32定时器的使用流程使用STM32定时器通常需要以下步骤:3.1 初始化定时器在使用定时器之前,需要初始化定时器的相关参数,包括计数器的计数范围、分频系数等。

通常可以通过寄存器的设置来完成初始化工作。

使用HAL库的话,可以使用HAL_TIM_Base_Init()函数进行初始化。

3.2 配置定时器的工作模式定时器可以根据需求配置为不同的工作模式,常见的模式包括单脉冲模式、连续模式、PWM输出模式等。

可以使用TIM_CR1、TIM_CR2等寄存器进行配置。

使用HAL库的话,可以使用相应的函数进行配置。

3.3 配置定时器的中断和DMA定时器可以配置中断和DMA功能,在特定的条件下触发相应的中断或DMA请求。

可以使用TIM_DIER寄存器进行配置。

使用HAL库的话,可以使用相应的函数进行配置。

3.4 启动定时器在配置完成后,需要启动定时器开始计数。

可以使用TIM_CR1寄存器进行配置。

使用HAL库的话,可以使用相应的函数进行配置。

3.5 处理定时器中断如果配置了定时器中断,当定时器达到设定的计数值时,会触发中断。

在中断服务函数中可以根据需求进行相应的处理。

3.6 设置定时器输出如果配置了定时器的通道输出模式,可以在定时器计数到一定值时,通过通道输出相应的信号。

可以使用TIM_CCR1、TIM_CCR2等寄存器进行配置。

3.7 停止定时器如果需要停止定时器的计数,可以使用TIM_CR1寄存器进行配置。

stm32的tim计算脉冲频率低频溢出问题

stm32的tim计算脉冲频率低频溢出问题

stm32的tim计算脉冲频率低频溢出问题《STM32的TIM计算脉冲频率低频溢出问题》一、概述在嵌入式系统中,计算脉冲频率是一个常见的需求。

而在使用STM32系列单片机时,我们通常会使用定时器(TIM)来实现这一功能。

然而,当脉冲频率较低时,就会出现脉冲溢出的问题。

本文将针对这一问题展开深入讨论。

二、STM32定时器介绍在开始讨论脉冲频率低频溢出问题之前,值得先对STM32的定时器进行简要介绍。

STM32系列单片机包含多个定时器,每个定时器都有多个通道。

定时器主要用于生成延时、计时和脉冲频率测量等功能。

其中,TIM2、TIM3、TIM4、TIM5等是常用的通用定时器。

三、脉冲频率低频溢出问题当我们需要测量低频脉冲频率时,比如几十Hz或者更低的频率,就会遇到脉冲频率低频溢出的问题。

在STM32中,定时器的计数值是一个16位的寄存器,当脉冲频率较低时,定时器的计数值可能会在一个周期内溢出。

这就会导致无法准确计算脉冲频率,甚至造成测量结果错误的情况。

四、解决方案针对脉冲频率低频溢出问题,我们可以采取一些解决方案来解决这一难题。

其中,常见的方法包括软件滤波、使用外部中断、改变定时器的预分频系数等。

这些方法都可以有效地解决脉冲频率低频溢出的问题,确保准确地测量低频脉冲频率。

五、个人观点在实际应用中,遇到脉冲频率低频溢出问题是很常见的。

对于这一问题,我个人倾向于使用外部中断的方法来解决。

通过外部中断,可以及时地捕获脉冲信号,避免定时器计数值溢出的情况,从而确保测量的准确性。

总结:本文对STM32的TIM计算脉冲频率低频溢出问题进行了深入的探讨。

首先介绍了STM32的定时器功能,然后详细分析了脉冲频率低频溢出问题的原因和解决方案。

最后共享了我个人对于解决这一问题的观点。

希望通过本文的阐述,读者能更全面、深刻和灵活地理解和解决脉冲频率低频溢出问题。

以上就是本文的全部内容,希望对你有所帮助。

六、软件滤波方法软件滤波是一种常见的解决低频脉冲频率溢出问题的方法。

使用STM32的TIMER进行外部计数TIMER

使用STM32的TIMER进行外部计数TIMER
TIM_TimeBaseInit(TIM2, &TIM_TimeBaseStructure); // Time base configuration
TIM_ETRClockMode2Config(TIM2, TIM_ExtTRGPSC_OFF, TIM_ExtTRGPolarity_NonInverted, 0);
13:采样频率fSAMPLING=fDTS/32,N=5
14:采样频率fSAMPLING=fDTS/32,N=6
15:采样频率fSAMPLING=fDTS/32,N=8
TIM_SetCounter(TIM2, 0);
初始化Timer的计数器初始值为0;
TIM_Cmd(TIM2, ENABLE);
使用ETR引脚的输入信号作为计数时钟,本例程使用Timer 2,其ETR输入引脚为PA1,该引脚工作模式为输
入模式,Timer的工作模式为从模式;另外使用PC6输出一模拟方波时钟信号。
测试时将PC6与PA1短接。(用户也可另外连接一个时钟信号到PA1引脚d)
TIM_SetCounter(TIM2, 0);
TIM_Cmd(TIM2, ENABLE);
for(i_Loop = 0; i_Loop < 100; i_Loop ++) {
GPIO_SetBits(GPIOC, GPIO_Pin_6);
Delay(10);
NVIC_Configuration(); // NVIC configuration
GPIO_Configuration(); // Configure the GPIO ports
TIM_TimeBaseStructure.TIM_Period = 0xFFFF;

stm32定时器脉冲计数

stm32定时器脉冲计数

今天,尝试使用S‎T M32的‎计数器的外‎部时钟功能‎,来对外部脉‎冲信号进行‎计数。

效果还不错‎。

具体设置如‎下:/* TIM3_‎C H2 为脉冲输入‎口1. 配置GPI‎O_GPI‎O A_PI‎N7 输入2. 配置TIM‎3计数器在T‎I2 端的上升沿‎计数:1). TIMx_‎C CMR1‎:CC2S =01; 配置通道2‎检测TI2‎输入的上升‎沿2). TIMx_‎C CMR1‎:IC2F =000; 选择输入滤‎波器带宽3). TIMx_‎C CER: CC2P =0; 配置上升沿‎极性√4). TIMx_‎S MCR: SMS =111; 选择定时器‎外部时钟模‎式15). TIMx_‎S MCR: TS =110; 选择TI2‎作为触发输‎入源√6). TIMx_‎C R1: CEN =1; 启动计数器‎*/void TIM3_‎E xter‎n al_C‎l ock_‎C ount‎i ngMo‎d e(void){GPIO_‎I nitT‎y peDe‎f GPIO_‎I nitS‎t ruct‎u re;TIM_T‎i meBa‎s eIni‎t Type‎D ef TIM_T‎i meBa‎s eStr‎u ctur‎e;// TIM_I‎C Init‎T ypeD‎e f TIM_I‎C Init‎S truc‎t ure;RCC_A‎P B2Pe‎r iphC‎l ockC‎m d(RCC_A‎P B2Pe‎r iph_‎G PIOB‎,ENABL‎E);GPIO_‎I nitS‎t ruct‎u re.GPIO_‎P in = GPIO_‎P in_7‎;GPIO_‎I nitS‎t ruct‎u re.GPIO_‎M ode = GPIO_‎M ode_‎I N_FL‎O ATIN‎G;GPIO_‎I nitS‎t ruct‎u re.GPIO_‎S peed‎= GPIO_‎S peed‎_50MH‎z;GPIO_‎I nit(GPIOA‎,&GPIO_‎I nitS‎t ruct‎u re);RCC_A‎P B1Pe‎r iphC‎l ockC‎m d(RCC_A‎P B1Pe‎r iph_‎T IM3, ENABL‎E);TIM_D‎e Init‎(TIM3);TIM_T‎i meBa‎s eStr‎u ctur‎e.TIM_P‎e riod‎= 0xFFF‎F;TIM_T‎i meBa‎s eStr‎u ctur‎e.TIM_P‎r esca‎l er = 0x00;TIM_T‎i meBa‎s eStr‎u ctur‎e.TIM_C‎l ockD‎i visi‎o n = 0x0; /*定时器时钟‎(CK_IN‎T)频率与数字‎滤波器(ETR,TIx)使用的采样‎频率之间的‎分频比为1‎*/TIM_T‎i meBa‎s eStr‎u ctur‎e.TIM_C‎o unte‎r Mode‎= TIM_C‎o unte‎r Mode‎_Up;TIM_T‎i meBa‎s eIni‎t( TIM3, &TIM_T‎i meBa‎s eStr‎u ctur‎e); // Time base confi‎gurat‎i on/*tmpcc‎m r1 |= (uint1‎6_t)(TIM_I‎C Filt‎e r << 12); // CCMR1‎_IC2F‎tmpcc‎m r1 |= (uint1‎6_t)(TIM_I‎C Sele‎c tion‎<< 8); // CCMR1‎_CC2S‎由TIM_‎T IxEx‎t erna‎l CLK1‎S ourc‎e_TI2‎决定了TIM_I‎C Sele‎c tion‎=TIM_I‎C Sele‎c tion‎_Dire‎c tTI: CCMR1‎_CC2S‎= 01;TIM_I‎C Pola‎r ity_‎R isin‎g= CCER_‎C C2PTIM_T‎I xExt‎e rnal‎C LK1S‎o urce‎_TI2 = TIM_S‎M CR_T‎S该函数定义‎了TIM_‎S lave‎M ode_‎E xter‎n al1;外部时钟模‎式1*/TIM_T‎I xExt‎e rnal‎C lock‎C onfi‎g(TIM3,TIM_T‎I xExt‎e rnal‎C LK1S‎o urce‎_TI2,TIM_I‎C Po la‎r ity_‎R isin‎g,0);//// TIM_S‎e tCou‎n ter(TIM3, 0); // 清零计数器‎C NT// TIM_C‎m d(TIM3,ENABL‎E);}// 下面是使用‎方法:TIM3_‎E xter‎n al_C‎l ock_‎C ount‎i ngMo‎d e();TIM_S‎e tCou‎n ter(TIM3, 0); // 清零计数器‎C NTTIM_C‎m d(TIM3,ENABL‎E);SecCn‎t= 0;TFgs.Secok‎= 0;i=0;while‎(1){Delay‎_Nms(1000);Count‎P ulse‎= TIM_G‎e tCou‎n ter(TIM3);Displ‎a yDat‎(10,10+24*i,Count‎P ulse‎,5);TFgs.Secok‎= 0;if(++Count‎T ims>=120){TIM_C‎m d(TIM3,DISAB‎L E);Count‎P ulse‎= TIM_G‎e tCou‎n ter(TIM3);Displ‎a yDat‎(10,10+24*i,Count‎P ulse‎,5);if(++i>11)i=0;TIM_S‎e tCou‎n ter(TIM3, 0); // 清零计数器‎C NTTIM_C‎m d(TIM3,ENABL‎E);SecCn‎t= 0;TFgs.Secok‎= 0;Count‎T ims =0;}};上述程序经‎过硬件测试‎。

stm32的tim计算脉冲频率低频溢出问题

stm32的tim计算脉冲频率低频溢出问题

stm32的tim计算脉冲频率低频溢出问题(实用版)目录1.引言2.STM32 的 TIM 功能介绍3.计算脉冲频率的方法4.低频溢出问题的出现5.解决低频溢出问题的方法6.总结正文1.引言随着科技的发展,单片机技术也在不断进步。

STM32 作为一款性能优异的单片机,在各个领域都有广泛应用。

其中,定时器(TIM)是 STM32 中一个重要的功能模块,可以实现对输入信号的捕获和计数,进而计算脉冲频率。

然而,在实际应用中,可能会遇到低频溢出问题,影响脉冲频率的准确计算。

本文将针对这一问题进行分析,并提出相应的解决方案。

2.STM32 的 TIM 功能介绍STM32 的 TIM 功能主要包括输入捕获、输出比较和 PWM 控制等。

其中,输入捕获功能可以实现对输入信号的实时监测,并根据设定的阈值产生相应的中断或触发事件。

通过使用 TIM 输入捕获功能,可以实现对脉冲信号的频率和占空比的测量。

3.计算脉冲频率的方法在 STM32 中,可以通过 TIM 输入捕获功能计算脉冲频率。

具体步骤如下:1) 配置 TIM 通道,使它能够捕获输入信号。

2) 设置 TIM 通道的触发条件,例如:双触发或单触发。

3) 在 TIM 中断服务函数中,读取捕获到的脉冲次数。

4) 根据捕获到的脉冲次数和捕获间隔时间,计算脉冲频率。

4.低频溢出问题的出现在计算脉冲频率时,可能会遇到低频溢出问题。

这是因为当输入信号的频率过低时,TIM 计数器可能无法在规定时间内完成计数,导致脉冲频率计算不准确。

这种情况下,TIM 计数器可能会出现溢出,影响脉冲频率的测量结果。

5.解决低频溢出问题的方法为了解决低频溢出问题,可以采取以下措施:1) 调整 TIM 计数器的时钟源,选择一个频率更高的时钟源,以提高计数速度。

2) 延长 TIM 计数器的计数时间,以便在低频信号下也能完成计数。

3) 增加 TIM 通道的数量,以便同时捕获多个脉冲信号,提高信号检测的准确性。

stm32计算脉冲时间间隔

stm32计算脉冲时间间隔

stm32计算脉冲时间间隔
要计算STM32微控制器上的脉冲时间间隔,你可以使用定时器来实现。

以下是一种可能的方法:
首先,你需要配置一个定时器来捕获脉冲的上升沿和下降沿。

你可以选择任何可用的定时器,比如TIM2或TIM3,具体取决于你的STM32型号和可用的资源。

一旦定时器配置完成,你可以在脉冲的上升沿和下降沿中断中获取定时器的当前值。

在上升沿中断中获取定时器的值t1,在下降沿中断中获取定时器的值t2。

然后,你可以计算脉冲时间间隔,即t2 t1。

这将给出脉冲的时间间隔,单位取决于你定时器的配置(比如毫秒、微秒等)。

另外,你还可以使用STM32提供的库函数来实现这一功能。

ST 官方提供了丰富的库函数,你可以查阅相关的文档和例程来了解如何使用定时器捕获功能来计算脉冲时间间隔。

需要注意的是,以上仅仅是一种基本的实现方法,具体的实现
细节还需要根据你的具体应用和STM32型号来进行调整。

希望这些信息能对你有所帮助。

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

使用STM32的定时器进行输入脉冲的计数STM32的定时器具有计数功能,在实际应用中可以用来对引脚上的输入信号进行统计。

其输入信号作为计数时钟,输入引脚为ETR引脚。

本例程使用Timer 2,其ETR输入引脚为PA1,初始化是设置该引脚工作模式为输入模式,Timer2的工作模式为从模式。

为了方便测试,另外使用PC6模式输出一个时钟信号。

测试时将PC6与PA1短接。

(用户也可另外连接一个时钟信号到PA1引脚上。


代码如下:
int main(void)
{
unsigned char i_Loop;
unsigned char n_Counter;
#ifdef DEBUG
debug();
#endif
RCC_Configuration(); // System Clocks Configuration
NVIC_Configuration(); // NVIC configuration
GPIO_Configuration(); // Configure the GPIO ports
TIM_TimeBaseStructure.TIM_Period = 0xFFFF;
TIM_TimeBaseStructure.TIM_Prescaler = 0x00;
TIM_TimeBaseStructure.TIM_ClockDivision = 0x0;
TIM_TimeBaseStructure.TIM_CounterMode = TIM_CounterMode_Up;
TIM_TimeBaseInit(TIM2, &TIM_TimeBaseStructure); //
Time base configuration
TIM_ETRClockMode2Config(TIM2,TIM_ExtTRGPSC_OFF,TIM_ExtTRGPolarity_NonInver ted,0);
TIM_SetCounter(TIM2, 0);
TIM_Cmd(TIM2, ENABLE);
for(i_Loop = 0; i_Loop < 100; i_Loop ++)
{
GPIO_SetBits(GPIOC, GPIO_Pin_6);
Delay(10);
GPIO_ResetBits(GPIOC, GPIO_Pin_6);
Delay(10);
}
n_Counter = TIM_GetCounter(TIM2);
while (1) {}
}
前三行进行了时钟、中断、和I/O口的配置。

然后进行Timer的基本配置,计数器自动装载值为0xFFFF,计数频率不分频,定时器时钟(CK_INT)频率与数字滤波器(ETR,TIx)使用的采样频率之间的分频比为1,计数器向上计数。

TIM_ETRClockMode2Config(TIM2,TIM_ExtTRGPSC_OFF,TIM_ExtTRGPolarity_NonInver ted,
0);
使用ETR时钟作为计数时钟需要设置为外部时钟模式2,故调用该函数,在设置时
1、关闭预分频:TIM_ExtTRGPSC_OFF。

可选项:
TIM_ExtTRGPSC_OFF 0x0000
TIM_ExtTRGPSC_DIV2 0x1000
TIM_ExtTRGPSC_DIV4 0x2000
TIM_ExtTRGPSC_DIV8 0x3000
2、外部触发极性ETR不反相,高电平或上升沿有效:TIM_ExtTRGPolarity_NonInverted。

可选项:
TIM_ExtTRGPolarity_Inverted和
TIM_ExtTRGPolarity_NonInverted。

3、外部触发无滤波器:0000。

可选项:
0:无滤波器,以fDTS采样
1:采样频率fSAMPLING=fCK_INT,N=2 2:采样频率fSAMPLING=fCK_INT,N=4 3:采样频率fSAMPLING=fCK_INT,N=8 4:采样频率fSAMPLING=fDTS/2,N=6 5:采样频率fSAMPLING=fDTS/2,N=8 6:采样频率fSAMPLING=fDTS/4,N=6 7:采样频率fSAMPLING=fDTS/4,N=8 8:采样频率fSAMPLING=fDTS/8,N=6 9:采样频率fSAMPLING=fDTS/8,N=8 10:采样频率fSAMPLING=fDTS/16,N=5 11:采样频率fSAMPLING=fDTS/16,N=6 12:采样频率fSAMPLING=fDTS/16,N=8 13:采样频率fSAMPLING=fDTS/32,N=5 14:采样频率fSAMPLING=fDTS/32,N=6 15:采样频率fSAMPLING=fDTS/32,N=8 TIM_SetCounter(TIM2, 0);
初始化Timer的计数器初始值为0;
TIM_Cmd(TIM2, ENABLE);
启动Timer2
代码下载: /bbs/index.php?act=Article&tid=30009。

相关文档
最新文档