该模块的核心是德州仪器公司的一个微步驱动程序——DRV8825。它的体型较小(只有0.8″× 0.6″)
DRV8825步进电机驱动器的输出驱动能力可达45V。可以掌握双极步进电机每个线圈(如NEMA 17)高达2.5A的输出电流。
DRV8825驱动自带掌握程序,能简化操作,只需2个引脚就能完成掌握
一个是掌握步数另一个用来掌握旋转方向。驱动程序供应六种不同的步长分辨率
全步、半步、四分之一步、八之一步、十六之一步三十二之一步。技能规格
DRV8825引脚图
与其他步进电机驱动器不同,DRV8825只有一个电源连接。
VMOT和GND MOT为电机供电。可以将8.2V到45V的输入电压连接到这个引脚上。DRV8825模块没有逻辑电源引脚,其利用内部3V3稳压器从电机电源供电。但是须要将微掌握器的接地连接到GND逻辑引脚。根据数据表,电机电源须要一个得当的去耦电容,以便能够坚持4A稳定电流。该驱动板上有low-ESR陶瓷电容器,这使它随意马虎受到电压峰值的影响。在某些情形下,这些峰值可能超过45V (DRV8825的最大电压额定值),这有可能永久破坏电路板乃至电机。保护驱动器不受这种峰值影响的一种方法是在电机电源引脚上放置一个大的100μF(至少47μF)电解电容。微步选择引脚DRV8825驱动许可通过将单个步进划分为更小的步进来实现微步。这是通过用中间电流勉励线圈来实现的。如果选择驱动NEMA 17(1.8°步进角度或200步/转)在四分之一步模式,电机每转将须要800微步。DRV8825驱动程序有三个步长(分辨率)选择器引脚,即M0, M1和M2。通过为这些引脚设置适当的逻辑电平,可以将电机设置为六种不同的步进分辨率。这三个微步选择引脚被内部下拉电阻拉低,以是如果悬空则电机将在全步进模式下运行。掌握输入引脚:STEP和DIRSTEP步进输入引脚掌握电机的微步。每个发送到该引脚的HIGH脉冲根据由微步选择引脚决定的微步数驱动电机。脉冲越快,电机转得越快。DIR输入引脚掌握电机的旋转方向。HIGH高电平驱动电机顺时针方向,LOW低电平驱动电机逆时针方向。如果希望电机只在一个方向上旋转,可以相应地将DIR直接连接到VCC或GND。用于掌握电源状态的引脚:EN, RST和SLPEN引脚是一个低电平有效引脚。当这个引脚被拉低时,DRV8825驱动被启用。默认情形下,这个引脚被拉低,以是驱动总是启用的,除非拉高则禁用驱动。SLP引脚是一个低电平有效引脚。把这个引脚拉低,驱动器进入就寝模式,最大限度地降落功耗。当电机不该用的时候可以利用这个引脚,以节省电力。RST引脚是一个低电平有效引脚。当这个引脚被拉为LOW时,所有的STEP输入都被忽略。它还通过将内部转换器设置为预定义的HOME状态来重置驱动。HOME状态基本上是电机启动的初始位置,它取决于微步分辨率。故障检测引脚:FAULTDRV8825还具有FAULT输出,当H-bridge FETs由于过流保护或过热关闭而被禁用时,FAULT引脚是一个低电平有效引脚。实际上,Fault故障引脚可以短接到就寝引脚,每当故障引脚被触发为低电平时,全体芯片被禁用。并且在RESET或电机电压VMOT被移除并重新运用之前,它一贯处于禁用状态。输出引脚:B2, B1, A1 and A2输出引脚可以连接掌握任何中小型双极步进电机,如NEMA 17。模块上的每个输出引脚可以向电机输出高达2.5A的电流。当然,能够供应给电机的电流量取决于系统的电源、冷却系统和限流设置。冷却系统-散热器
DRV8825驱动IC的过度功耗会导致温度升高,如果超过其容量可能会破坏IC。只管DRV8825驱动IC的最大额定电流为2.5A /线圈,但在没有散热器的情形下,该芯片只能供应约1.5A /线圈而不会过热。为了得到超过1.5A/线圈电流,则散热器或其他冷却方法是必需的。DRV8825驱动常日带有散热器。建议在利用前先安装。电流限定
在利用DRV8825驱动电动机前,必须设置限定通过步进线圈的最大电流量,防止它超过电机的额定电流。为了设置电流限定,DRV8825驱动器上供应了一个小型微调电位器。方法一:通过丈量“ref”引脚上的电压(Vref)来确定电流极限。查看步进电机的数据表,记下它的额定电流(NEMA 17 200步/rev, 12V 350mA。)断开三个微步选择引脚,将驱动置于全步模式。保持电机在一个固定的位置,不计时STEP输入。丈量电位器上电压(Vref)并调度。例如,如果电机额定电流为350mA,则将调度参考电压到0.175V。一种大略的方法是利用鳄鱼夹夹住金属螺丝刀柄,并将其连接到万用表上,这样就可以同时丈量和调度电压。方法二:通过丈量流过线圈的电流来确定电流极限。步骤同方法一如果您变动了逻辑电压(VDD),则须要重新进行此调度。
将DRV8825步进电机驱动器连接到Arduino
将RST引脚连接到相邻的SLP/SLEEP引脚,并连接到Arduino上的5V,以保持驱动器处于启用状态。将GND LOGIC引脚与Arduino上的接地引脚连接。将DIR和STEP输入引脚连接到Arduino上的#2和#3数字输出引脚。将步进电机连接到B2, B1, A1和A2引脚上。在驱动器运行时连接或断开步进电机可能破坏驱动器。保持三个微步选择引脚断开,则电机事情在全步进模式。末了将电机电源连接到VMOT和GND MOT引脚上。将一个100μF去耦电解电容接入电机电源引脚,以避免大的电压峰值。Arduino代码:不该用库
// Define pin connections & motor's steps per revolution
const int dirPin = 2;
const int stepPin = 3;
const int stepsPerRevolution = 200;
void setup()
{
// Declare pins as Outputs
pinMode(stepPin, OUTPUT);
pinMode(dirPin, OUTPUT);
}
void loop()
{
// Set motor direction clockwise
digitalWrite(dirPin, HIGH);
// Spin motor slowly
for(int x = 0; x < stepsPerRevolution; x++)
{
digitalWrite(stepPin, HIGH);
delayMicroseconds(2000);
digitalWrite(stepPin, LOW);
delayMicroseconds(2000);
}
delay(1000); // Wait a second
// Set motor direction counterclockwise
digitalWrite(dirPin, LOW);
// Spin motor quickly
for(int x = 0; x < stepsPerRevolution; x++)
{
digitalWrite(stepPin, HIGH);
delayMicroseconds(1000);
digitalWrite(stepPin, LOW);
delayMicroseconds(1000);
}
delay(1000); // Wait a second
}
在loop循环中,电机先缓慢顺时针旋转,间隔1秒后,再快速逆时针旋转。掌握电机旋转方向:DIR引脚设置为HIGH或LOW。HIGH高电平输入将使电机顺时针方向迁徙改变,LOW低电平输入将使电机逆时针方向迁徙改变。掌握速率:电机的速率是由发送到STEP引脚的脉冲频率决定的。脉冲越高,电机运行越快。脉冲便是把输出拉高,等待一下子,然后拉低,再等待。通过改变两个脉冲之间的延迟,可以改变这些脉冲的频率,从而改变电机的速率。Arduino示例代码:利用accelerstepp库
对付大略的、单一的电机运用来说,掌握步进器不须要库是完备没问题的。但是当想要掌握多个步进时,就须要一个库。
accelerstepper库:加减速掌握多个同步步进器,每个步进器都有独立的同步步进。安装accelerstepper库略示例代码// Include the AccelStepper Library
#include <AccelStepper.h>
// Define pin connections
const int dirPin = 2;
const int stepPin = 3;
// Define motor interface type
#define motorInterfaceType 1
// Creates an instance
AccelStepper myStepper(motorInterfaceType, stepPin, dirPin);
void setup() {
// set the maximum speed, acceleration factor,
// initial speed and the target position
myStepper.setMaxSpeed(1000);
myStepper.setAcceleration(50);
myStepper.setSpeed(200);
myStepper.moveTo(200);
}
void loop() {
// Change direction once the motor reaches target position
if (myStepper.distanceToGo() == 0)
myStepper.moveTo(-myStepper.currentPosition());
// Move the motor one step
myStepper.run();
}