单片机控制步进电机

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档


前言

提示:这里可以添加本文要记录的大概内容:

之前学习了单片机控制直流电机,下一步我们一起来学习如何控制步进电机


提示:以下是本篇文章正文内容,下面案例可供参考

一、步进电机的工作原理是什么?

电机怎么控制转多少度!原理最容易理解的电机!步进电机的工作原理!

https://www.bilibili.com/video/BV1cN4y197TG/?spm_id_from=333.337.search-card.all.click

常用驱动器

一分钟学会控制步进电机

https://www.bilibili.com/video/BV11h4y1V7vK/?spm_id_from=333.337.search-card.all.click

51单片机控制步进电机输出一定的角度、转速和转向(可提供源代码)

https://www.bilibili.com/video/BV1Dq4y1E7Xj/?spm_id_from=333.337.search-card.all.click

在这里插入图片描述
ABCD A-AB-B-BC-C-CD-D-DA-A 有字母就是1 否则是0
1000 1100 0100 0110 0010 0011 0001 1001
0x80 0xc0 0x40 0x06 0x02 0x03 0x01 0x09
在这里插入图片描述

双四拍,一次给两个1: ABCD 1001 1100 0110 0011 ->1001
单四拍,一次只给一个1:ABCD 1000 0100 0010 0001 ->1000
单双八拍, 1001 1000 1100 0100 0110 0010 0011 0001 ->1001
根据我们看到步进电机的原理,电池很忙,才能让步进电机按照顺序转起来

从左往右给脉冲正转, 从右往左就是反转。

在这里插入图片描述

在这里插入图片描述

ULN2003绿色板资料下载链接:https://pan.baidu.com/s/1EqgUEpMWoq91wRWK6gaang
提取码:8888

ULN2003蓝色板资料下载链接:https://pan.baidu.com/s/1r9JF2EX3bA3JRBuEZfW5Gg
提取码:8888

二、连线图

在这里插入图片描述

在这里插入图片描述

三、程序

1.参考程序

代码如下(示例):


unsigned char ta[4]={0x01,0x02,0x04,0x08};

void delay(unsigned char ms)
{
	//
	for(x=0;x<ms;x++)
	{
		for(y=0;y<100;y++);
	}
}
void main()
{

	while(1)
	{
		for(i=0;i<4;i++)//正转
		{
					P1=ta[i];
					delay(1);
		}
		for(i=0;i<4;i++)//反转
		{
					P1=ta[3-i];
					delay(1);
		}
	}
	
}

2.实际测试

四、开发板

1.原理图

在这里插入图片描述

2.实际连接图

在这里插入图片描述

在这里插入图片描述

3.参考程序


#include <reg51.h>

unsigned char ta[4]={0x01,0x02,0x04,0x08};

void delay(unsigned char ms)
{
	//
	unsigned char x,y;
	for(x=0;x<ms;x++)
	{
		for(y=0;y<100;y++);
	}
}
void main()
{
	
	unsigned char i;

	while(1)
	{
		for(i=0;i<4;i++)//正转   一直再转
		{
					P1=ta[i];
					delay(10);
		}
//		for(i=0;i<4;i++)//反转
//		{
//					P1=ta[3-i];
//					delay(10);
//		}
	}
	
}

4.测试

在这里插入图片描述

5. 思考

1.控制步进电机转速
2.控制步进电机方向
3. 控制步进电机转动指定角度

加入按键?

按键1 :控制正反
按键2: 速度
按键3:角度 90度

程序框架


#include <reg51.h>

unsigned char ta[4]={0x01,0x02,0x04,0x08};

void delay(unsigned char ms)
{
	//
	unsigned char x,y;
	for(x=0;x<ms;x++)
	{
		for(y=0;y<100;y++);
	}
}

void zhengzhuan()
{
		for(i=0;i<4;i++)//正转   一直再转
		{
					P1=ta[i];
					delay(10);
		}
}
void fanzhuan()
{
	for(i=0;i<4;i++)//反转
		{
				P1=ta[3-i];
				delay(10);
		}
}
void main()
{
	
	unsigned char i;

	while(1)
	{
		
		if(key1==0)
		{
			zhengzhuan();
			
		}
		else
		{
			fanzhuan();	//  num
		}
		if(key2==0)
		{
			//num
		}
		if(key3==0)  //转动90度
		{
			
			zhengzhuan(90,);
		}

	}
	
}

五、步距角

在这里插入图片描述
步距角: 5.625度
转360度: 360/5.625=64 , 64一圈
由于有减速箱:1/64
所以实际想要转一圈需要 : 64*64=4096个脉冲
在这里插入图片描述

在这里插入图片描述

实际计算:根据八拍来运行

步距角: 5.625度
转360度: 360/5.625=64 , 64一圈
由于有减速箱:1/32 (实际算得减速比是32)
所以实际想要转一圈需要 : 32*64=2048个脉冲

参考程序:

#include <reg51.h>

/*
ABCD   A-B-C-D  
1000 0100 0010 0001  
0X80 0X40 0X20 0X01
*/
unsigned char ta[4]={0x01,0x02,0x04,0x08};  //  5.625*2=11.25

unsigned char ta8[8]={0x80,0xc0,0x40,0x06,0x02,0x03,0x01,0x09};  //5.625
/*
ABCD     A-AB-B-BC-C-CD-D-DA-A      有字母就是1 否则是0 
1000 1100 0100 0110 0010 0011 0001 1001
0x80  0xc0  0x40  0x06  0x02  0x03 0x01 0x09*/
void delay(unsigned char ms)
{
	//
	unsigned char x,y;
	for(x=0;x<ms;x++)
	{
		for(y=0;y<100;y++);
	}
}
void main()
{
	
	unsigned int i,j;
// 转一圈	
	for(j=0;j<256;j++)  //5.625   360/5.625=64   64*32=2048   2048/8=256 	
	{
		for(i=0;i<8;i++)//正转
		{
						P1=ta8[i];
						delay(5);
		}
	}

	while(1)
	{
	}

}

总结

  • 31
    点赞
  • 37
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
一次控制两个电机#include #define GPIO_MOTOR P1 sbit K1=P3^6; sbit K2=P3^5; sbit K3=P3^4; sbit K4=P3^3; unsigned char code ZHENG1 [8]={0xf1,0xf3,0xf2,0xf6,0xf4,0xfc,0xf8,0xf9}; //正转顺序编码 unsigned char code FAN1 [8]={0xf9,0xf8,0xfc,0xf4,0xf6,0xf2,0xf3,0xf1}; //反转顺序编码 unsigned char code ZHENG2 [8]={0x1f,0x3f,0x2f,0x6f,0x4f,0xcf,0x8f,0x9f}; //正转顺序编码 unsigned char code FAN2 [8]={0x9f,0x8f,0xcf,0x4f,0x6f,0x2f,0x3f,0x1f}; //反转顺序编码 char Motor1_Step,Motor2_Step,Speed,Speed2; void Delay(unsigned int t); void Motor1_zheng(); void Motor1_fan(); void Motor2_zheng(); void Motor2_fan(); void main() { unsigned int i; Motor1_Step=1; Motor2_Step=3; Speed=10; Speed2=40; while(1) { while(K1==0) { for(i=0;i<10;i++) { Motor1_zheng(); } } while(K2==0) { for(i=0;i<10;i++) { Motor1_fan(); } } while(K3==0) { for(i=0;i<10;i++) { Motor2_zheng(); } } while(K4==0) { for(i=0;i<10;i++) { Motor2_fan(); } } } } void Motor1_fan() { unsigned int i; for(i=0;i<8;i++) { //GPIO_MOTOR = FFW[i]&0x1f; //取数据 GPIO_MOTOR = FAN1[i]; Delay(Speed); //调节转速 } } void Motor1_zheng() { unsigned int i; for(i=0;i<8;i++) { //GPIO_MOTOR = FFZ[i]&0x1f; GPIO_MOTOR = ZHENG1[i]; Delay(Speed); //调节转速 } } void Motor2_fan() { unsigned int i; if(Motor1_Step==0) { for(i=0;i<8;i++) { //GPIO_MOTOR = FFW2[i]&0xf1; //取数据 GPIO_MOTOR = FAN2[i]; Delay(Speed2); //调节转速 } } Motor1_Step=1; } void Motor2_zheng() { unsigned int i; if(Motor1_Step==1) { for(i=0;i<8;i++) { //GPIO_MOTOR = FFZ2[i]&0xf1; GPIO_MOTOR = ZHENG2[i]; Delay(Speed2); //调节转速 } } Motor1_Step=0; } void Delay(unsigned int t) { unsigned int k; while(t--) { for(k=0; k<80; k++) { } } }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值