OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 18794|回复: 18

怎样让定时器输出一定数量的脉冲

[复制链接]

19

主题

85

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
202
金钱
202
注册时间
2014-9-16
在线时间
11 小时
发表于 2014-11-14 20:12:22 | 显示全部楼层 |阅读模式
5金钱
如题,如何让定时器输出一定数量的PWM呢,我要用它来做工作前监测。

最佳答案

查看完整内容[请看2#楼]

看看这个:http://www.openedv.com/posts/list/41832.htm
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165524
金钱
165524
注册时间
2010-12-1
在线时间
2116 小时
发表于 2014-11-14 20:12:23 | 显示全部楼层
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复

使用道具 举报

0

主题

14

帖子

0

精华

高级会员

Rank: 4

积分
975
金钱
975
注册时间
2014-11-10
在线时间
106 小时
发表于 2014-11-14 20:41:19 | 显示全部楼层
我是个40岁的初学者,这阶段比较清闲才学单片机,而选择正点原子也是因为店主说按我目前的水平学STM32有点难(目前说实话的人越来越少了),但看了楼主的标题感觉更难了~~~ 用定时器中断就可以了吧而且还要看你的具体要求啊。这个不难吧~~
回复

使用道具 举报

19

主题

85

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
202
金钱
202
注册时间
2014-9-16
在线时间
11 小时
 楼主| 发表于 2014-11-15 21:13:45 | 显示全部楼层
我用回复【3楼】 正点原子 :
---------------------------------
我用这个里面的002  以给定频率f、输出n个脉冲,进行软件仿真,根本实现不了输出n个脉冲停止的效果啊
脉冲仍然连续输出,中间无中断和停止迹象,怎么回事


回复

使用道具 举报

19

主题

85

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
202
金钱
202
注册时间
2014-9-16
在线时间
11 小时
 楼主| 发表于 2014-11-15 21:15:29 | 显示全部楼层
原子哥,帮看看啊,他这个原理是什么,看不太明白。

哪位有主从门控方式产生固定数量PWM的程序供参考一下,谢谢
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165524
金钱
165524
注册时间
2010-12-1
在线时间
2116 小时
发表于 2014-11-15 22:53:23 | 显示全部楼层
回复【5楼】laoguren1122:
---------------------------------
你可以去问问原作者。
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复

使用道具 举报

19

主题

85

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
202
金钱
202
注册时间
2014-9-16
在线时间
11 小时
 楼主| 发表于 2014-11-16 10:21:33 | 显示全部楼层
回复【6楼】正点原子:
---------------------------------
原子哥有采用主从定时器门控方式输出PWM的例程供参考一下么?
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165524
金钱
165524
注册时间
2010-12-1
在线时间
2116 小时
发表于 2014-11-16 12:27:16 | 显示全部楼层
回复【7楼】laoguren1122:
---------------------------------
我在论坛发过,你找找。不过好久以前写的代码了,具体细节得你自己去整理了。
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复

使用道具 举报

19

主题

85

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
202
金钱
202
注册时间
2014-9-16
在线时间
11 小时
 楼主| 发表于 2014-11-16 13:47:21 | 显示全部楼层
我在网上查了很多资料,总结一下:输出一定数量PWM脉冲,
主要有几种方法:

1.单脉冲法,需要一个脉冲中断一次,中断次数多,影响效率,而且能保证每次的脉冲连续性么?
2.另一定时器进行中断计数,与1一样,需要频繁中断;
3.用主从定时器门控方式,还没完全搞清楚怎么用,比较繁琐,应该能满足大部分人的需要;
4.高级定时器T1、T8的重复计数方式,RCR计数中断,看手册好像这种方式最简单,能满足一部分人要求,缺点是寄存器只有8位,最多实现     255个脉冲计数输出,还没完全试出来,正在仿真。

个人拙见,请指点!
回复

使用道具 举报

19

主题

85

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
202
金钱
202
注册时间
2014-9-16
在线时间
11 小时
 楼主| 发表于 2014-11-17 19:54:14 | 显示全部楼层
采用重复计数方式还是有问题,暂时搁置;
采用门控方式实现了
回复

使用道具 举报

4

主题

14

帖子

0

精华

初级会员

Rank: 2

积分
82
金钱
82
注册时间
2015-3-19
在线时间
11 小时
发表于 2015-5-6 15:12:35 | 显示全部楼层
回复【9楼】laoguren1122:
---------------------------------
回复【9楼】laoguren1122:
---------------------------------
大神,能给共享一下,门控方式的历程吗
回复

使用道具 举报

19

主题

85

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
202
金钱
202
注册时间
2014-9-16
在线时间
11 小时
 楼主| 发表于 2015-5-18 13:16:54 | 显示全部楼层
TIM2,TIM1进行主从配置
void TIM_PWM_Number_Init(u16 master_arr, u16 master_psc, u16 slave_arr, u16 slave_psc)

{    

GPIO_InitTypeDef GPIO_InitStructure;
TIM_TimeBaseInitTypeDef  TIM_TimeBaseStructure;
TIM_OCInitTypeDef  TIM_OCInitStructure; 
NVIC_InitTypeDef NVIC_InitStructure;

    RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM2,ENABLE);//使能定时器2的时钟
    RCC_APB2PeriphClockCmd(RCC_APB2Periph_TIM1|RCC_APB2Periph_GPIOA|RCC_APB2Periph_AFIO,ENABLE);//使能定时器3的时钟
   
   //设置该引脚为复用输出功能,输出TIM3 CH2的PWM脉冲波形 GPIOB.5
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_0|GPIO_Pin_8|GPIO_Pin_9;  //TIM_CH2
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP;   //复用推挽输出
GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
GPIO_Init(GPIOA, &GPIO_InitStructure);   //初始化GPIO
   

  //TIM2工作在单脉冲下
   TIM_TimeBaseStructure.TIM_Period = master_arr;//TIM2per;//重装值
   TIM_TimeBaseStructure.TIM_Prescaler = master_psc;//7200;//预分频值,每100us计数一次
   TIM_TimeBaseStructure.TIM_ClockDivision = TIM_CKD_DIV1;//0;//TIM_CKD_DIV1;//没有时钟分割
   TIM_TimeBaseStructure.TIM_CounterMode = TIM_CounterMode_Up;//向上计数模式
   TIM_TimeBaseInit(TIM2,&TIM_TimeBaseStructure);

 
   TIM_SelectOnePulseMode(TIM2,TIM_OPMode_Single);//设置TIM2在单脉冲模式,且是单一的脉冲,在下一个更新事件停止
   TIM_OC1PreloadConfig(TIM2,TIM_OCPreload_Enable);//使能定时器2的通道1预装载寄存器
   TIM_SelectOutputTrigger(TIM2,TIM_TRGOSource_OC1Ref);

    TIM_ITConfig( TIM2, TIM_IT_Update, ENABLE); // 中断源, TIM 触发中断源 使能
    
NVIC_InitStructure.NVIC_IRQChannel = TIM2_IRQn;  //TIM3中断
NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 0;  //先占优先级0级
NVIC_InitStructure.NVIC_IRQChannelSubPriority = 3;  //从优先级3级
NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE; //IRQ通道被使能
NVIC_Init(&NVIC_InitStructure);  //根据NVIC_InitStruct中指定的参数初始化外设NVIC寄存器

  TIM_OCInitStructure.TIM_OCMode = TIM_OCMode_PWM2;//在向上计数时,一旦TIMx_CNT<TIMx_CCR1时通道1为无效电平,否则为有效电平
  TIM_OCInitStructure.TIM_OutputState = TIM_OutputState_Enable;//OC1输出使能
  TIM_OCInitStructure.TIM_OCPolarity = TIM_OCPolarity_High;//有效电平为高
  TIM_OCInitStructure.TIM_OCIdleState = TIM_OCIdleState_Reset;
//  TIM_OCInitStructure.TIM_Pulse = 1;//比较捕获1的预装载值
  TIM_OC1Init(TIM2,&TIM_OCInitStructure);  

  TIM_Cmd(TIM2,DISABLE);//先不使能能TIM2

   

  //TIM1工作在从模式的门控模式下的PWM输出模式
   TIM_TimeBaseStructure.TIM_Period = slave_arr; //TIM3per;设置在下一个更新事件装入活动的自动重装载寄存器周期的值
TIM_TimeBaseStructure.TIM_Prescaler = slave_psc; //720;设置用来作为TIMx时钟频率除数的预分频值 
TIM_TimeBaseStructure.TIM_ClockDivision = TIM_CKD_DIV1;//0; //TIM_CKD_DIV1;/设置时钟分割:TDTS = Tck_tim
TIM_TimeBaseStructure.TIM_CounterMode = TIM_CounterMode_CenterAligned3;  //TIM向上计数模式
// TIM_TimeBaseStructure.TIM_RepetitionCounter = 10;
TIM_TimeBaseInit(TIM1, &TIM_TimeBaseStructure); 
  

  TIM_SelectSlaveMode(TIM1, TIM_SlaveMode_Gated);//TIM3为门控模式
 // TIM_SelectMasterSlaveMode(TIM1,TIM_MasterSlaveMode_Enable);//使能TIM3的主从模式
  TIM_SelectInputTrigger(TIM1,TIM_TS_ITR1);//内部触发,从TIM2触发

//初始化TIM3 Channel2 WM模式  
TIM_OCInitStructure.TIM_OCMode = TIM_OCMode_PWM2; //选择定时器模式:TIM脉冲宽度调制模式2
  TIM_OCInitStructure.TIM_OutputState = TIM_OutputState_Enable; //比较输出使能
TIM_OCInitStructure.TIM_OCPolarity = TIM_OCPolarity_High; //输出极性:TIM输出比较极性高
TIM_OCInitStructure.TIM_OCIdleState = TIM_OCIdleState_Reset;
// TIM_OCInitStructure.TIM_Pulse = TIM3Compare1;//比较捕获1的预装载值
TIM_OC1Init(TIM1, &TIM_OCInitStructure);  //根据T指定的参数初始化外设TIM3 OC2

    TIM_OCInitStructure.TIM_OCMode = TIM_OCMode_PWM1; //选择定时器模式:TIM脉冲宽度调制模式2
  TIM_OCInitStructure.TIM_OutputState = TIM_OutputState_Enable; //比较输出使能
TIM_OCInitStructure.TIM_OCPolarity = TIM_OCPolarity_High;//TIM_OCNPolarity_Low; //输出极性:TIM输出比较极性高
// TIM_OCInitStructure.TIM_Pulse = TIM3Compare1;//比较捕获1的预装载值
  TIM_OC2Init(TIM1, &TIM_OCInitStructure); 
 
    TIM_CtrlPWMOutputs(TIM1,ENABLE);
    TIM_Cmd(TIM1,ENABLE);//使能TIM3

}


void TIM2_IRQHandler(void)   //TIM3中断
{
if (TIM_GetITStatus(TIM2, TIM_IT_Update) != RESET) //检查指定的TIM中断发生与否:TIM 中断源 
{
TIM_ClearITPendingBit(TIM2, TIM_IT_Update  );  //清除TIMx的中断待处理位:TIM 中断源 
// LED1=!LED1;
     TIM_ForcedOC1Config(TIM1, TIM_ForcedAction_InActive);
TIM_ForcedOC2Config(TIM1, TIM_ForcedAction_InActive);
}
}


main()
{
 //初始化TIM1,2使其固定数量脉冲输出
TIM_PWM_Number_Init(3999,719,999,71);
TIM_SetCompare1(TIM1,arr/2+400);
TIM_SetCompare2(TIM1,arr/2-400);
TIM_CtrlPWMOutputs(TIM1,ENABLE);
TIM_Cmd(TIM1, ENABLE);
 
TIM_SetCompare1(TIM2,10);
TIM_Cmd(TIM2, ENABLE);

}>
回复

使用道具 举报

10

主题

50

帖子

1

精华

中级会员

Rank: 3Rank: 3

积分
291
金钱
291
注册时间
2014-11-6
在线时间
24 小时
发表于 2015-7-19 12:49:58 | 显示全部楼层
回复【4楼】laoguren1122:
---------------------------------
不好意思。
主程序中的注释错了。应该是以“frequency”的频率发出“ num”个脉冲
关于函数
void MyTimer2_Startup(u16 num,u16 frequency)
第一个参数是“脉冲数目”
第二个参数是“脉冲频率(速度)”
可以修改后再编译、验证。
回复

使用道具 举报

9

主题

93

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
426
金钱
426
注册时间
2011-7-11
在线时间
49 小时
发表于 2015-7-30 19:07:42 | 显示全部楼层
一时看不懂,慢慢看
回复

使用道具 举报

0

主题

41

帖子

0

精华

初级会员

Rank: 2

积分
139
金钱
139
注册时间
2014-1-11
在线时间
23 小时
发表于 2015-12-12 11:56:11 | 显示全部楼层
还好学习一下。
回复

使用道具 举报

0

主题

3

帖子

0

精华

新手入门

积分
4
金钱
4
注册时间
2017-8-3
在线时间
0 小时
发表于 2017-8-3 15:47:31 | 显示全部楼层
laoguren1122 发表于 2015-5-18 13:16
TIM2,TIM1进行主从配置
void&nbsp;TIM_PWM_Number_Init(u16&nbsp;master_arr,&nbsp;u16&nbsp;master_psc,&n ...

你好,可以分享一份完整的工程文件给我吗?万分感激!!!1424589066@qq.com
回复

使用道具 举报

0

主题

1

帖子

0

精华

新手入门

积分
12
金钱
12
注册时间
2019-8-4
在线时间
4 小时
发表于 2019-11-4 16:25:24 | 显示全部楼层
楼主,有没有库函数版本的
回复

使用道具 举报

75

主题

458

帖子

4

精华

金牌会员

Rank: 6Rank: 6

积分
1635
金钱
1635
注册时间
2012-8-28
在线时间
71 小时
发表于 2020-4-25 15:39:32 | 显示全部楼层
#ifndef _motor_h
#define _motor_h//两相四线步进电机
///////////
#include "stm32f10x.h"
#include "delay.h"
#include "sys.h"//io引用
////////////////////////////////////////
//作者QQ750273008   祁成 2018.5.29
////////////////////////////////////////

//电机类型:只能选一种
    #define phase_two//两相四线步进电机
//                        #define phase_four//四相五线步进电机


////////////////////////////////////////
//双拍
#define use_motor_4code  1 //0:8拍模式, 1:4拍模式

typedef struct
{
        u8 num;                                          //电机轴的编号0~0xFF
  const u8 *drive_code;          //步进电机节拍:停止+8种节拍
        u8  rotate_val;        //电机旋转值
        int add;                          //当前绝对位置
        int go;                                  //预计移动
        //加减速参数
        u32 dead_us;    //最小死区时间(最快速度)//迷你滑台1ms
  u32 delay_ms;                //电机转一拍停留时间(可以为0)
        u16  VF;        //加减速曲线,(值越大,加减速越快)
       
}motors;
////////////////////////////////////////



//电机默认参数表
extern motors zhou;
//当前可用轴
//extern motors zhou1;//x->dead_us =950 ;
//extern motors zhou2;//x->dead_us =950 ;
extern motors X;//x->dead_us =950 ;
extern motors Y;
extern motors Z;//电机Z轴
extern motors A;
extern motors B;
extern motors C;
extern motors D;

//////////////////////////////////////////
void motor_init(void);//轴初始化
u8 motorGoto(motors *x,int Goto);//轴定位
u8 motorGo(motors *x,long int go);//轴移动

void io_out(motors *x,u8 code);//输出驱动编码
void motor_cmd(motors *x,FunctionalState NewState);//电机失效(自由运动)
//////////////
//////////////
//io
//#define motor1_1   PAout(12)   //PB12 左轮 A相  IN1
//#define motor1_2   PAout(13)   //PB13 左轮 A'相 IN2
//#define motor1_3   PAout(14)   //PB14 左轮 B相  IN3
//#define motor1_4   PAout(15)   //PB15 左轮 B'相 IN4

//#define motor2_1   PBout(11)   //PB11 右轮 A相  IN1
//#define motor2_2   PBout(10)   //PB10 右轮 A'相 IN2
//#define motor2_3   PBout(1)    //PB1  右轮 B相  IN3
//#define motor2_4   PBout(0)    //PB0  右轮 B'相 IN4


#endif

////////////////////////// 下面是c文件
#include "stm32f10x.h"
#include "motor.h"//两相四线步进电机
#include "delay.h"//延时

//两相四线步进电机 56A9
#ifdef phase_two//两相四线步进电机(D0:A)  ,(D1:A非),   (D2:B),  (D3:B非)
//8拍                                        A    AB   B    A'B  A'   A'B' B'   AB'
  static const u8 motor_code[9]={0X00,0x01,0x05,0X04,0X06,0X02,0X0A,0X08,0X09};//步进电机,停止+8种节拍
//        static const u8 motor_code[9]={0X00,0x08,0x0A,0X02,0X06,0X04,0X05,0X01,0X09};//步进电机,停止+8种节拍
        #endif
//4拍                                   AB   A'B  A'B' AB'
//static const u8 motor_4code[9]={0X00,0x0A,0X06,0X05,0X09};//停止+4种节拍

//四相五线步进电机
#ifdef phase_four//四相五线步进电机
//8拍                                A    AB   B    BC   C    CD   D    DA
static const u8 motor_code[9]={0X00,0x01,0x03,0X02,0X06,0X04,0X0C,0X08,0X09};//步进电机,停止+8种节拍
#endif


//电机默认参数表
static motors zhou={
        0,//电机轴的编号0~0xFF
  motor_code, //步进电机节拍:停止+8种节拍
  0,//电机当前节拍位置
        0,//当前绝对位置
        0,//预计移动
        950,//最小死区时间(最快速度)//迷你滑台1000us
        0,//电机转一拍停留时间(可以为0)
        25//加减速曲线,(值越大,加减速变化越大)
};

//当前可用轴
motors X={0x01,motor_code,0,0,0,1000,0,50};//x->dead_us =950 ;
motors Y={0x02,motor_code,0,0,0,1000,0,50};//x->dead_us =950 ;
motors Z={0x03,motor_code,0,0,0,1000,0,50};//x->dead_us =950 ;
         motors A={0x04,motor_code,0,0,0,1000,0,50};//x->dead_us =950 ;
          motors B={0x05,motor_code,0,0,0,1000,0,50};//x->dead_us =950 ;
                 motors C={0x06,motor_code,0,0,0,1000,0,50};//x->dead_us =950 ;
//extern motors zhou1;//x->dead_us =950 ;
//extern motors zhou2;

///////////////////////////
///////////////////////////
/*初始化*/
void motor_init(void)//初始化
{
        //添加并初始化需要用的轴
        //X=zhou;
//        X.num=0x01;
//        Y.num =0x02;
//        Y.delay_ms=0;
        motorGoto(&X,0);
        motorGoto(&Y,0);
        motorGoto(&Z,0);
        delay_s(5);
        motorGoto(&X,1);
        motorGoto(&Y,1);
        motorGoto(&Z,1);
}

/*轴定位*/
u8 motorGoto(motors *x,int Goto)//轴定位
{
        int i;
        i=Goto - x->add;//偏移量;
        motorGo(x,i);//轴移动(定位值 减 当前位置)
        return 0;
}

/*轴移动*/
u8 motorGo(motors *x,long int go)//轴移动
{
        u8  rotate,drive_val;//节拍,线圈驱动值
  long int        i;//脉冲数
       
        if(go>0)//正转
                {
                        x->go=go;//距离脉冲
                       
                        for(i=0;i < x->go;i++)//正转循环
                                {
                                        //得到下一个节拍,齿轮
                                        rotate=(x->rotate_val + (1+use_motor_4code))%9;//当前节拍 + 偏移节拍
                                            //一拍是否小于一拍
                                                if(rotate < (1+use_motor_4code))//一节拍值
                                                        {
                                                                rotate = 1 + use_motor_4code;//绕过电机停止的编码值0x00,齿轮
                                                        }
                                                       
                                        drive_val=x->drive_code[rotate];//得到电机8拍驱动编码
                                        //////////////////////////////
                                        //输出:
                                               io_out(x,drive_val);//输出驱动编码
                                                     x->rotate_val=rotate;        //记录电机最后一次节拍编号
                                }
                                //记录当前地址
                                x->add += go;
                        return 0;
                }
        else//反转
                {
                        x->go=go;//距离脉冲
                        for(i=0;i > x->go;i--)//负数
                                {
                                        //补一圈回到原点,减1步节拍。
                                        rotate = (x->rotate_val + 9-1-use_motor_4code)%9;
                                        ///////////////
                                  //旋转纠错
                                        if(use_motor_4code) rotate += rotate%2 ;//回到双4拍的节拍上
                                        if(rotate==0)
                                         {
                                                 rotate=8;//绕过电机停止的编码值0x00
                                         }
                                        drive_val=x->drive_code[rotate];//得到电机8拍驱动编码
                                        //////////////////////////////
                                        //输出:
                                               io_out(x,drive_val);//输出驱动编码
                                                     x->rotate_val=rotate;        //记录电机最后一次节拍编号
                                }
                                //记录当前地址
                                x->add += go;
                        return 0;
                }

}


void motor_cmd(motors *x,FunctionalState NewState)//电机失效(自由运动)
{
        if(NewState==ENABLE)
                {
                        io_out(x,0x08);//轴控制
                }
        else
                {
                        io_out(x,0x00);//取消轴控制
                }
//        io_out(&zhou2,0x00);//取消轴控制
       
        /////////////////////////////////
//        u32 i,j,code=0x0f;
//        //////////////////////////////
//                                //输出:
//                        GPIOB->ODR&=0XFFFF0FFF,//轴1
//                                                                GPIOB->BSRR = code<<12;
//                                   
//                        GPIOB->ODR&=0XFFFFF3FC,//轴2
//                                                                i=code & 0x0C;//d3,d2
//                                                                i=i << 8;//d10
//                                                                j=code & 0x03;
//                                                                i |= j;
//                                                                GPIOB->BSRR = i;

}


void io_out(motors *x,u8 drive_code)//输出驱动编码
{  
        u32 i=0,j;
        switch(x->num)
                {
                        //////////////////////////////
                                //输出:
                        case 0x01:GPIOB->ODR&=0XFFFF0FFF;          //轴1
                                                                GPIOB->BSRR = drive_code<<12;         //PB15,14,13,12
                                   break;
                        case 0x02:GPIOB->ODR&=0XFFFFF3FC;          //轴2
                                                                i=drive_code & 0xC; //1100                 
                                                                i=i << 8;                   //PB11,PB10
                                                                j=drive_code & 0x3;
                                                                i |= j;                     //PB1,B0
                                                                GPIOB->BSRR = i;                      //PB11,10,1,0
                                  break;
//                        case 0x03:GPIOB->ODR&=0XFFFF0FFF,
//                                                                GPIOB->BSRR |=code<<12;break;
                }
                //////////////////////////////
                        //停留时间:
                //电机转一拍停留时间
                    if(x->dead_us > 0)delay_us(x->dead_us);//最小死区时间(最快速度)
                                if(x->delay_ms > 0)delay_ms(x->delay_ms);
}






QQ750273008有好的资料记得发给我哦。。。
回复

使用道具 举报

75

主题

458

帖子

4

精华

金牌会员

Rank: 6Rank: 6

积分
1635
金钱
1635
注册时间
2012-8-28
在线时间
71 小时
发表于 2020-4-25 16:21:20 | 显示全部楼层
今天我在研究tim1输出固定脉冲数。发现除了利用定时器1独有的重复寄存器,其他方案感觉没思路。加减速感觉要用其他定时器做tim1的时钟源。
我上面发的是42步进电机的驱动。我写的思路是,节拍轮询,永远知道下一个节拍的编码。加减速靠节拍循环内延时。从最慢速度的延时递减(加速度值),达到最小的delay时就停止,这时电机速度最快。再要接近终点时保留一定的节拍数量,然后在循环中delay递增(加速度值)让电机成倍数的减到运动终点。我用的迷你导轨看的(光驱那种一体式导轨)效果很明显。只是不能直线插补画圆。G代码的G01还在研究中

zet6.zip

19.19 MB, 下载次数: 27

QQ750273008有好的资料记得发给我哦。。。
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2025-5-26 02:43

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

快速回复 返回顶部 返回列表