>
首页 » 业界动态 » 基于CPLD的步进伺服控制系统中插补运算的设计

基于CPLD的步进伺服控制系统中插补运算的设计

作者:  时间:2007-10-27 11:22  来源:

摘 要:本文首先介绍了cpld器件epm7128svlc84的结构特点和编程下载电缆的制作,然后给出了步进伺服控制系统中插补运算的电路设计,最后说明了插补运算的仿真结果。该设计方法大大提高了系统的性能,同时还使设计具有了自主知识产权。

关键词:cpld;步进伺服;插补运算

引言

步进伺服控制系统是经济型数控机床的驱动控制部分,其插补运算的实现方法将对整个伺服系统的性能产生直接的影响。通常,实现插补运算的方法有基于逻辑电路的方法、基于软件技术的方法,以及软件和硬件相结合的方法。通过对以上各种方法进行比较和分析,本文提出了基于cpld来实现插补运算的方法。随着eda技术和cpld的发展,基于cpld实现插补运算不仅可以提高插补速度,减轻主cpu的运算负担,而且能够大大提高插补运算的可靠性。

  

图1 byteblastermv编程下载电缆

  

图2 步进伺服控制系统的

硬件结构图

步进伺服控制系统的设计

byteblastermv的制作

本系统在开发过程中需要通过计算机对目标cpld芯片进行算法程序和数据的在系统下载和调试,为此制作了jtag方式的byteblastermv编程下载电缆。该下载方式是通过计算机的打印机并行端口进行程序和数据的下载编程和调试。图1给出了jtag方式编程下载电缆byteblastermv用于进行数据转换的原理图,其中j1为与系统电路板上cpld器件编程下载接口相连的10针插座,j2为与计算机的打印机并行端口相连的25针插座,采用74als244器件对从计算机并行端口接受的编程数据进行转换,转换后的数据连接到cpld芯片的编程下载接口,从而完成对cpld芯片的编程和调试。

硬件电路结构

图2给出了步进伺服控制系统的硬件结构图。本系统由51系列单片机87c51、键盘输入模块、串口通信模块、液晶显示模块、插补运算模块和步进电机驱动构成。由4×4键盘阵列构成系统的输入模块。对键盘阵列中各个按键设定必要的功能定义,通过不断地扫描单片机的键盘接口就可以完成对运算所需原始数据的输入以及对系统的运行进行控制。采用87c51单片机自带的异步通信串口外接高速三态差分总线收发器ds75176构成rs-485半双工串口通信接口模块,实现系统和外部设备之间的串行通信功能。显示模块部分由内含两片sed1520控制器的图形液晶显示模块mgls10032a-led03构成,该液晶显示模块采用led边背光方式,实现对插补运算过程中运动轨迹和刀具位置等信息的实时显示。87c51单片机作为主要的控制单元接收操作命令,发出对外围接口模块的控制信号,读写数据并与外部设备进行通信。系统中为该单片机进行了外围ram的扩展,通过74ls373地址/数据锁存器对地址线中的低8位进行锁存,并采用62256作为外部扩展ram存储运算中产生的中间变量和数据。插补运算采用altera公司的max7000s系列cpld芯片epm7128svlc84来完成。这主要是由于所设计出来的产品需要以独立板卡的形式插到工控机的扩展插槽中,这就要求设计出的电路板体积小,如果采用fpga来实现,则必须外加专门的eeprom配置芯片,从而增加了电路板的尺寸,因此基于尺寸方面的因素,我们选择了cpld芯片来实现。同时考虑到本设计所需逻辑资源数不是很大,altera公司的epm7128svlc84芯片含有84个逻辑宏单元,恰好满足设计需求。本设计用vhdl语言编写插补运算算法,在max+pulsii 10.2开发环境中进行逻辑综合、功能仿真和时序仿真,得到正确的仿真结果,然后将编程目标文件(扩展名为.pof)的数据通过编程下载电缆接口下载到芯片中进行固化,芯片接受单片机和外部ram送来的控制指令和数据执行插补运算,插补的结果是产生控制步进电机运转的脉冲序列,并将脉冲序列送到步进电机驱动器的接口处。步进电机驱动器采用了北京凯恩帝公司的bd-3h三相混合式步进电机驱动器。

设计中的关键问题

在设计通信模块时,为了实现rs-485总线与单片机系统的隔离,在87c51单片机的异步通信串口与ds75176之间增加光电耦合器进行隔离,同时在进行电路设计时,必须根据光电耦合器的输入端和输出端与电路其他模块间的信号连接关系保证其电源与地的网络标号不同。同时,在pcb布线时必须保证不能使同一根信号连接线贯通光电耦合器的输入端和输出端。

为了保证串口通信正常进行,需要在87c51单片机上电复位时使ds75176的使能信号de为0。为达到这一目的,将单片机的复位信号reset引入光电耦合器进行信号变换,以保证单片机上电复位时光电耦合器输出为0,并将光电耦合器的输出信号送给ds75176的de端。由于工业控制领域的工程环境比较恶劣,现场通常存在各种形式的干扰源,所以在电路设计中采用稳压管d1、d2组成的吸收回路,在rs-485总线的传输端增加保护措施,从而防止线路上的干扰。

考虑到系统对信号的平稳性要求较高并且为防止直流信号引起的干扰,在每个集成块的电源与地之间跨接上滤波电容,从而隔断直流干扰信号。同时,因为epm7128svlc84芯片执行插补运算所产生的进给指令脉冲,其电流幅度不能满足bd-3h混合式步进电机驱动器的要求,所以还在epm7128svlc84和电机驱动器接口之间采用光电隔离器6n137和具有oc输出特性的ttl门电路74ls06。6n137具有强大的驱动放大能力,它接受的输入信号最大电流为5ma,通过oc输出放大,能够输出最小电流为15ma的信号。

由于epm7128svlc84芯片内部没有振荡电路,本设计将单片机的时钟由其输出端引出,然后通过ttl逻辑门进行整形滤波后为cpld芯片epm7128svlc84提供全局时钟信号。

插补运算的原理及算法实现

直线插补运算

以第一象限直线插补运算为例,给出直线插补运算的程序设计实现方法。

采用vhdl语言实现该算法,实体部分定义reset、clk和直线终点坐标(xe,ye)为全局输入信号,定义cpx1、cpx2、cpy1和cpy2为全局输出信号。全局输入信号都是由电路系统中其他的各个模块提供的控制信号,全局输出信号分别是x轴正/负向进给脉冲、y轴正/负向进给脉冲,分别控制步进电机向不同方向进给。在实体的结构体中设定q记录执行每一步直线插补运算后产生的偏差值,设定(q1,q2)为插步运算过程中刀具的加工点坐标,它们在结构体中被定义成变量的形式。reset是用于对算法初始化的复位信号,插补运算启动后,首先令reset=‘0’时对偏差值q和加工点坐标q1和q2清零,从而使刀具回到坐标原点。clk是插补运算的时钟控制信号,只有当clk上升沿到来时才进行插补运算的处理。在插补运算过程中,首先根据终点坐标判定直线所在的象限,然后按照具体的象限执行插补运算,产生控制步进电机运动的进给脉冲。对于第一象限内的直线执行插补运算,当刀具在直线上时,满足q=xe×q2-ye×q1=0。如果q≥0,那么当前加工点(q1,q2)在目标直线上或在直线的上方,则向x轴正向产生一进给脉冲,该脉冲信号通过bd-3h步进电机驱动器驱动步进电机,使刀具向x正向进给一个步进角,新加工点的偏差为q=q-ye;如果q<0,那么当前加工点(q1,q2)在目标直线的下方,则刀具向y轴正向进给一个步进角,新加工点的偏差为q=q+xe。该过程循环往复执行,直到加工点到达目标直线的终点时退出循环,完成直线插补运算过程。对于其他象限的直线插补算法,可通过相似的方法完成算法的程序设计。

圆弧插补运算

以第一象限逆圆插补运算为例,采用vhdl语言实现该算法,其设计原理与第一象限直线插补运算类似,只是在偏差判别时所采用的判别方程为q=q1×q1+q2×q2-x0×x0-y0×y0。对于其他象限的圆弧插补算法,方法类似。

结语

步进伺服系统因其价格低廉等原因在工业控制等领域依然被广泛应用,经过对cpld芯片进行vhdl编程、仿真,程序和数据下载及测试验证,本文完成了基于cpld芯片设计实现步进伺服系统的插补运算。同时,在插补运算的速度、精度和可靠性上都有了很大的提高。

相关推荐

多元化整合:PCB抄板搭上尧顺科技顺风车

PCB  CPLD  2013-03-12

Altium与Altera发布全新在线元件资源和软件支持

Altium  FPGA  CPLD  2012-02-15

嵌入式系统的实时数据接口扩展

嵌入式系统  CPLD  2011-09-02

基于CPLD的USB总线的隔离接口实现

CPLD  USB总线  2011-08-17

基于MAX6675多路温度采集系统设计与实现

温度采集  MAX6675  CPLD  2011-07-07

基于CPLD和嵌入式系统的高速数据采集系统

数据采集  CPLD  嵌入式系统  2011-02-17
在线研讨会
焦点