STM32F407 三路输出互补pwm波(库函数版)

1 篇文章 0 订阅
1 篇文章 0 订阅

 

 

 

void TIM1_Int_Init(u32 arr,u16 psc)
{
    GPIO_InitTypeDef  GPIO_InitStructure;
    TIM_TimeBaseInitTypeDef TIM_TimeBaseInitStructure;
    TIM_BDTRInitTypeDef TIM_BDTRStructure;
    
//    NVIC_InitTypeDef NVIC_InitStructure;
    TIM_OCInitTypeDef  TIM_OCInitStructure;    
    
    RCC_APB2PeriphClockCmd(RCC_APB2Periph_TIM1,ENABLE);  ///使能TIM1时钟
  RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_GPIOA|RCC_AHB1Periph_GPIOB, ENABLE);//使能GPIO时钟
    
    //互补方波
    GPIO_PinAFConfig(GPIOA,GPIO_PinSource8, GPIO_AF_TIM1 );//CH1
    GPIO_PinAFConfig(GPIOA,GPIO_PinSource7, GPIO_AF_TIM1 );    //CH1N
    //互补方波
    GPIO_PinAFConfig(GPIOA,GPIO_PinSource9, GPIO_AF_TIM1 );//CH2
    GPIO_PinAFConfig(GPIOB,GPIO_PinSource0, GPIO_AF_TIM1 );    //CH2N
    //互补方波
    GPIO_PinAFConfig(GPIOA,GPIO_PinSource10, GPIO_AF_TIM1 );//CH3
    GPIO_PinAFConfig(GPIOB,GPIO_PinSource1, GPIO_AF_TIM1 );    //CH3N
    
    GPIO_PinAFConfig(GPIOA,GPIO_PinSource11, GPIO_AF_TIM1 );//CH4
    
  //GPIO初始化设置
  GPIO_InitStructure.GPIO_Pin = GPIO_Pin_7 | GPIO_Pin_8 | GPIO_Pin_9 | GPIO_Pin_10 | GPIO_Pin_11;
  GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF;//复用输出模式
  GPIO_InitStructure.GPIO_OType = GPIO_OType_PP;//推挽输出
  GPIO_InitStructure.GPIO_Speed = GPIO_Speed_100MHz;//100MHz
  GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_UP;//上拉
  GPIO_Init(GPIOA, &GPIO_InitStructure);//初始化
    
    
    GPIO_InitStructure.GPIO_Pin = GPIO_Pin_0 | GPIO_Pin_1 ;
  GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF;//复用输出模式
  GPIO_InitStructure.GPIO_OType = GPIO_OType_PP;//推挽输出
  GPIO_InitStructure.GPIO_Speed = GPIO_Speed_100MHz;//100MHz
  GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_UP;//上拉
  GPIO_Init(GPIOB, &GPIO_InitStructure);//初始化

    //时基单元配置
    TIM_TimeBaseInitStructure.TIM_Prescaler=psc;  //定时器分频
    TIM_TimeBaseInitStructure.TIM_CounterMode=TIM_CounterMode_Up; //向上计数模式
    TIM_TimeBaseInitStructure.TIM_Period=arr;   //自动重装载值
    TIM_TimeBaseInitStructure.TIM_ClockDivision=TIM_CKD_DIV1; 
    TIM_TimeBaseInit(TIM1,&TIM_TimeBaseInitStructure);
    
    //刹车和死区
    TIM_BDTRStructure.TIM_AutomaticOutput=TIM_AutomaticOutput_Enable;
    TIM_BDTRStructure.TIM_OSSIState=TIM_OSSIState_Disable;
    TIM_BDTRStructure.TIM_OSSRState=TIM_OSSRState_Disable;
    TIM_BDTRStructure.TIM_Break=TIM_Break_Disable;
    TIM_BDTRStructure.TIM_BreakPolarity=TIM_BreakPolarity_High;
    TIM_BDTRStructure.TIM_LOCKLevel=TIM_LOCKLevel_OFF;
    TIM_BDTRStructure.TIM_DeadTime=0x04;// 1/168=5.95 20/5.95=3.36
    TIM_BDTRConfig(TIM1,&TIM_BDTRStructure);
    
    
    //初始化TIM1 Channel1 PWM模式     
    TIM_OCInitStructure.TIM_OCMode = TIM_OCMode_PWM1; //选择定时器模式:TIM脉冲宽度调制模式2
     TIM_OCInitStructure.TIM_OutputState = TIM_OutputState_Enable; //比较输出使能
//    TIM_OCInitStructure.TIM_OCPolarity = TIM_OCPolarity_High; //输出极性:TIM输出比较极性低
  TIM_OCInitStructure.TIM_OCPolarity = TIM_OCPolarity_High;        //当定时器计数值小于CCR1_Val时为高电平
    TIM_OCInitStructure.TIM_OutputNState=TIM_OutputNState_Enable;    
    TIM_OCInitStructure.TIM_OCNPolarity=TIM_OCNPolarity_High;
    TIM_OCInitStructure.TIM_OCIdleState=TIM_OCIdleState_Reset; //输出空闲电平低
    TIM_OCInitStructure.TIM_OCNIdleState=TIM_OCNIdleState_Reset;
    TIM_OCInitStructure.TIM_Pulse = ((arr+1)/2);


    TIM_SetCompare1(TIM1, ((arr+1)/2));
    TIM_OC1Init(TIM1, &TIM_OCInitStructure);     //使能通道1
    TIM_OC1PreloadConfig(TIM3, TIM_OCPreload_Enable);
    
    TIM_SetCompare2(TIM1, ((arr+1)/2));
    TIM_OC2Init(TIM1, &TIM_OCInitStructure);     //使能通道2
    TIM_OC2PreloadConfig(TIM1, TIM_OCPreload_Enable);
    
    TIM_SetCompare3(TIM1, ((arr+1)/2));
    TIM_OC3Init(TIM1, &TIM_OCInitStructure);     //使能通道3
    TIM_OC3PreloadConfig(TIM1, TIM_OCPreload_Enable);
    
    TIM_SetCompare4(TIM1, ((arr+1)/2));
    TIM_OC4Init(TIM1, &TIM_OCInitStructure);     //使能通道4
    TIM_OC4PreloadConfig(TIM1, TIM_OCPreload_Enable);
    
    TIM_ARRPreloadConfig(TIM1,ENABLE);//ARPE使能
//    TIM_ITConfig(TIM1,TIM_IT_Update,ENABLE); //允许定时器1更新中断
    TIM_Cmd(TIM1,ENABLE); //使能定时器3
    TIM_CtrlPWMOutputs(TIM1,ENABLE);
    
    
  
  
  
    
//    NVIC_InitStructure.NVIC_IRQChannel=TIM1_IRQn; //定时器1中断
//    NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority=0x01; //抢占优先级1
//    NVIC_InitStructure.NVIC_IRQChannelSubPriority=0x03; //子优先级3
//    NVIC_InitStructure.NVIC_IRQChannelCmd=ENABLE;
//    NVIC_Init(&NVIC_InitStructure);
    
}

int main(void)
{
    int i=0,fx=0;

        delay_init(168);  //初始化延时函数

    TIM3_Int_Init(8400-1,10-1);

    TIM1_Int_Init(6720-1,0);

    while(1)
    {

        
if(fx==0)
        {
            i+=100;;
            if(i>=6718)
            {
                fx=1;
            
            }
        }
        else
        {
            i--;
            if(i==0)
            {
                fx=0;
                
            }
        }
        TIM_SetCompare1(TIM1,i);    //修改比较值,修改占空比
        TIM_SetCompare2(TIM1,i);    //修改比较值,修改占空比
        TIM_SetCompare3(TIM1,i);    //修改比较值,修改占空比
        TIM_SetCompare4(TIM1,i);    //修改比较值,修改占空比
    
    }
}

看了手册只有三路的互补方波,第四路只有一个方波,没有互补的;

引脚就是这几个

如有错误请各位大佬指出,谢谢! 

### 回答1: STM32F103是一种高性能32位微控制器,具有丰富的外设和强大的计算能力。要实现互补PWM输出,可以通过配置STM32F103的定时器和通道来完成。 首先,选择一个定时器作为PWM输出的时基。比如,选择定时器1(TIM1)。 然后,配置定时器1的工作模式为PWM模式,将其通道1和通道2设置为互补模式。 在这个设置中,通道1产生一个PWM形,通道2产生一个与通道1相位相反的PWM形,在输出上形成互补PWM。 配置定时器1的频率和周期,可以通过设置ARR(自动重载寄存器)的值来实现。通常情况下,ARR的值决定PWM的频率,而分辨率则取决于PSC(预分频系数)的设置。更具体的数值可以根据需要进行调整。 接下来,设置通道1和通道2的占空比。可以通过改变CCR1(捕获比较寄存器1)和CCR2(捕获比较寄存器2)的值来调整。CCR1和CCR2的范围在0到ARR之间,分别代表着PWM形的占空比。 最后,使能定时器1以开始输出PWM形。 通过上述步骤的设置,即可实现STM32F103输出互补PWM形。这种方式可以应用于很多领域,比如直流电机驱动、LED驱动等。具体的应用场景可以根据需要进行调整和优化。 ### 回答2: stm32f103是一款32位的ARM Cortex-M3核心微控制器,具有丰富的外设和强大的计算能力。要输出互补PWM,可以通过使用定时器来实现。 首先,选择一个合适的定时器和通道来输出PWMstm32f103有多个定时器可供选择,例如TIM1、TIM2等。选择其中一个定时器,并判断它是否具有互补PWM功能。 接下来,配置定时器的工作模式。使用PWM输出模式,并设置计数器自动重装载值。这样定时器将会周期性地从0开始计数。 然后,设置定时器的预分频因子和计数器的重装载值,以确定PWM的频率和占空比。预分频因子用来将外部时钟信号分频,计数器的重装载值决定了PWM的周期。 设置定时器的通道为PWM输出模式。通过设置通道的比较值和占空比来产生PWM形。通常需要两个通道用于产生互补PWM。 将两个通道设置为互补模式,使得它们的输出相位相反。 最后,启动定时器并使能相应的通道输出。这样,stm32f103就会输出互补PWM。 需要注意的是,在配置和使用定时器的过程中,还需要注意时钟的配置、GPIO引脚的初始化等相关设置,以确保PWM输出正常工作。 以上是关于stm32f103输出互补PWM的简要步骤,具体实现依赖于具体的需求和使用的库函数。 ### 回答3: STM32F103是一款常用的STM32单片机系列中的一员,它提供了多个通用定时器,可以用于输出互补PWM互补PWM是一种特殊的PWM形,它由两个互补的信号组成,其特点是一个信号占空比逐渐增加,而另一个信号占空比逐渐减小。 在STM32F103中,我们可以通过配置定时器的工作模式和相关寄存器来实现互补PWM输出。下面是一个简单的实现步骤: 1. 配置定时器:选择一个合适的定时器(如TIM1、TIM2等),根据需求配置该定时器的工作模式和时钟源。 2. 配置通道:选择一个通道作为互补PWM输出的通道,一般选择定时器的通道1或通道2。配置通道的工作模式和输出极性,使其能够输出PWM。 3. 配置PWM输出:配置定时器的ARR寄存器和CCR寄存器,分别设置周期和占空比。对于互补PWM,可以通过调整两个通道的CCR寄存器的值来实现占空比的增减。 4. 使能定时器:使能定时器和相关通道的输出,开始生成互补PWM。 通过以上步骤的配置,就可以利用STM32F103的定时器输出互补PWM。在实际应用中,可以根据需求调整定时器的工作模式、时钟源和各个寄存器的值,实现不同频率和占空比的互补PWM输出
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值