基于GAL器件的步进电机控制器的研究与设计

时间:2007-04-28

摘要:介绍了利用阵列逻辑器件GAL16V8对三相六拍步进电机实现控制的方法及其电路设计。通过计算机编程器对GAL进行编程,可以满足各种控制要求。该电路简单,工作稳定可靠,编程灵活方便。

关键词:通用阵列逻辑器件 步进电机 GAL16V8 三相六拍

步进电机广泛应用于对要求比较高的运动控制系统中,如机器人、打印机、软盘驱动器、绘图仪、机械阀门控制器等。目前,对步进电机的控制主要有由分散器件组成的环形脉冲分配器、软件环形脉冲分配器、专用集成芯片环形脉冲分配器等。分散器件组成的环形脉冲分配器体积比较大,同时由于分散器件的延时,其可靠性大大降低;软件环形分配器要占用主机的运行时间,降低了速度;专用集成芯片环形脉冲分配器集成度高、可靠性好,但其适应性受到限制,同时开发周期长、需求费用较高。通用阵列逻辑GAL(Generic Array Logic)是美国Lattice公司研制的一种电可擦除的可编程的新型PLD器件。近几年来,GAL以其高性能、高可靠性、可擦除及输出逻辑结构可组态等特性和100%的成品率,博得广大用户的信赖。它可以用来构成译码器、优先级编码器、多路开关、比较器、移位寄存器、计数器、总线仲裁器等。采用GAL器件对三相步进电机进行控制,不仅简化了系统的结构,降低了成本,而且编程灵活方便,提高了系统的可靠性,使系统具有更强的适应性。
1 三相六拍步进电机控制要求

矩角特性是步进电机运行时一个很重要的参数,矩角特性好,步进电机启动转矩就大,运行不易失步。改善矩角特性一般通过增加步进电机的运行拍数来实现。三相六拍比三相二拍的矩角特性好一倍,因此在很多情况下,三相步进电机采用三相六拍运行方式。三相步进电机工作在三相六拍运行方式时,每个状态的变化使电机转动1/6齿距,三相激励规律为A-AB-B-BC-C-CA共六拍,对应时序如所示。A、B、C分别代表接到三相步进电机A相、B相、C相绕组的驱动脉冲。

通常,步进电机的脉冲控制是由逻辑电路实现的。在计算机控制的系统中,也可以通过编制程序,由扩展I/O口输出脉冲来决定电机的运行方式、方向及转速。这种方式电路简单、控制灵活,但占用CPU的时间过多,每次驱动电机时,PC机都得被占用。本文采用可编程逻辑器件(PLD)中的GALl6V8设计逻辑电路。在此,选三个控制信号:(1)启动控制信号S,当S=1时为停止,S=0为启动;(2)正反转控制信号D,当D=1时电机正转,D=0时电机反转;(3)转速切换信号R和C,当R=0、C=0时,频率为fck;R=1、C=1时,频率为fck/2。步进电机的转速通常都是通过改变时序脉冲的频率来控制的,所以这里用频率来表示转速的改变。由于GAL器件所有触发器的时钟是连在一起的,不能同时引入两种以上频率的时钟,因此从改造组合逻辑部分人手,达到对电动机转速的二分频控制。同理也可以实现四相八拍、五相十拍、六项十二拍的步进电机控制,这就比专用的集成电路功能更强。
2 采用GAL控制脉冲分配的逻辑设计

若采用集成电路芯片来实现三相六拍步进电机的控制,所用器件较多,电路一般比较复杂。为了满足电机转速的二分频,在同一时钟频率控制下,必须利用一个D型触发器,通过C参与组合逻辑来实现。其逻辑电路如所示。CK为控制信号,三个D型触发器的输出O、P、Q分别接步进电机的三项绕组。根据步进电机驱动相数及控制要求,必须有相应于相数的延迟触发器保持现态与次态间的转换过程。对此,可利用GAL中八个输出逻辑宏单元中的三个来完成,电机的工作状态(O、P、Q)中的现态与控制信号(S、R、D)可通过GAL的与、或阵列组合逻辑来完成。

2.1 逻辑控制状态表

按照电机的激励规律,在时序脉冲作用下,时序电路的状态将在六个状态中循环,驱动电机运转。这里用a、b、c、d、e、f分别表示其六个状态,即a=100、b=110、c=010、d=011、e=001、f=101。根据逻辑电路图可得其状态表,如表1所示。
表1 逻辑控制状态表

S
RDC
现态
10
×000010100110101111
aafbfbaa
bbecacbb
ccddbdcc
ddcecedd
eebfdfee
ffaaeaff

表1中分频控制量R决定C的取值,即C=RC。当R=0时,电机按fck频率运行,当R=1时,C重复取0和1,电机按fck/2频率运行。

2.2 状态真值表

由表1可得状态真值表,如表2所示。表中O、P、Q状态是在时钟脉冲控制下变化的,在控制变量的控制下,决定电机的启动、转向和转速大小。
表2 状态真值表

OPQSRDCDoDpDq OPQSRDCDoDpDq
1000010110 0110110001
1100010011 0010111001
0110010001 0010110101
0110010001 1010111101
0010010101 1010110100
1010010100 1000101100
1000000101 1000100101
1010000001 1010101101
0010000011 1010100001
0110000010 0010101001
0100000110 0010100011
1100000100 0110101011
1000111100 0110100010
1000110110 0100101010
1100111110 0100100110
1100110010 1100101110
0100110010 1101100100
0100110011 ×××1×××000
0110111011           

2.3 卡诺图

在卡诺图中,输入变量分两排表示,变量的取值次序按照循环码排列。这种排列方法使得卡诺图中几何上相邻的两个小方块所代表的项只有一个变量不同这正是利用卡诺图化简逻辑函数的基础。

对于多变量输入,使用卡诺图时要注意以下几点:

(1)按照"少、"的原则(即圈数少,圈内的项个数尽可能多)圈起所有取值为1的相邻相。

(2)卡诺图中四个角与两对边的各项也是相邻的,卡诺图里上、下或左右部分中对称的项也是相邻的。

(3)每圈一个矩形圈时,必须至少包含一个在其它圈中未出现过的项,否则出现重复而得不到简式。 (4)每一个取值为"1"的小方块都可以被圈多次,但不能遗漏,圈可以只包含一个小方块,即不能简化。

以O为例,由状态真值表可得其卡诺图,如所示。根据圈数和项可得其逻辑表达式为:

同样,也可以求得P、Q的逻辑表达式
3 GAL的软件设计

3.1 GAL器件选型及引脚变量分配

GAL器件有多种型号,根据设计的需要,同时从经济的角度考虑,选用GALl6V8来实现三相六拍步进电机的控制。

3.2 GAL源文件设计

根据控制要求和编程格式,对已得到的时序逻辑方程编写的源文件如下:

在实际输入时不需要加入,注释行以";"开始。将上述源文件输入计算机,再对文件进行编译或汇编以生成JEDEC文件、引脚配置图、熔丝图等。用编程器对GAL器件进行编程,编程器在编程结束后还具有对编程芯片所有的存储单元进行自动检验的功能。
4 系统的硬件连接

电路原理图如所示,左边为GALl6V8芯片的引线图,S、D、R分别决定电机的启动、转向和转速大小,输出O、P、Q分别接电机的A、B、C三个线包。图中只给出一个线包的驱动电路。注意:GAL元件不用的引脚应该直接接地或接电源,不要悬空,否则会增大功耗,降低抗干扰能力。 这种主要由GALl6V8组成的步进电机控制器用于对三相六拍工作制步进电机的自动控制,既可以独立运用于驱动对象,又可以在微机管理下运行,且不占用CPU的时间。用一片GAL便可以实现复杂的时序电路,缩小组成系统的体积。借助计算机辅助设计,大大加快了设计速度,减少了差错,降低了成本,提高了系统的可靠性和稳定性,且可反复修改和编程,灵活性极强。


  

参考文献:

[1]. GAL16V8 datasheet https://www.dzsc.com/datasheet/GAL16V8_345888.html.


上一篇:基于FPGA实现FIR滤波器的研究
下一篇:基于FPGA的高频时钟的分频和分配设计

免责声明: 凡注明来源本网的所有作品,均为本网合法拥有版权或有权使用的作品,欢迎转载,注明出处。非本网作品均来自互联网,转载目的在于传递更多信息,并不代表本网赞同其观点和对其真实性负责。

相关技术资料