# 四相步进电机驱动及电机参数采集系统设计

## 黄云龙, 李丕丁

上海理工大学健康科学与工程学院,上海

收稿日期: 2024年8月5日; 录用日期: 2024年8月30日; 发布日期: 2024年9月6日

# 摘要

步进电机具有精确定位,高重复精度,高稳定性、高可靠性以及容易开环控制等优点,广泛应用于医疗器械、消费电子以及光学设备等精度要求较高的领域。而四相步进电机相较于两相步进电机具有更高的分辨率、平滑度以及动态性能等优点,于是需要加强对四相步进电机驱动系统研究,以应对更高需求的应用领域。本文设计了一款基于FPGA的四相步进电机驱动及参数采集系统,该系统可灵活地配置电机驱动电压和步进方式,并且采用以太网传输协议与DDR3存储器,为步进电机驱动需要的速度曲线提供大量数据存储空间,并且经过仿真与测试后该系统达到了相应功能,最终本系统实现了四相步进电机驱动,其中电机驱动电压最大可到20 V以及最大微步细分可达256细分,同时上位机可实时监测电机相电压、相电流、霍尔信号以及编码器等电机相关参数。

#### 关键词

以太网,FPGA,步进电机

# **Design of Four-Phase Stepper Motor Drive and Motor Parameter Acquisition System**

## Yunlong Huang, Piding Li

School of Health Science and Engineering, University of Shanghai for Science and Technology, Shanghai

Received: Aug. 5<sup>th</sup>, 2024; accepted: Aug. 30<sup>th</sup>, 2024; published: Sep. 6<sup>th</sup>, 2024

## Abstract

Stepper motor has the advantages of precise positioning, high repeatability, high stability, high reliability and easy open-loop control, etc., and is widely used in medical devices, consumer electronics and optical equipment and other fields with high precision requirements. The four-phase stepper motor has the advantages of higher resolution, smoothness and dynamic performance compared with the two-phase stepper motor, so it is necessary to strengthen the research on the

four-phase stepper motor drive system to cope with the application field of higher demand. This paper designs a four-phase stepper motor drive and parameter acquisition system based on FPGA. The system can flexibly configure the motor drive voltage and stepping mode, and adopts Ethernet transmission protocol and DDR3 memory to provide a large amount of data storage space for the speed curve required by the stepper motor drive. After simulation and testing, the system achieves the corresponding function. Finally, the system realizes the four-phase stepper motor drive, in which the maximum motor drive voltage can reach 20 V and the maximum microstep subdivision can reach 256 subdivision, and the upper computer can monitor the motor phase voltage, phase current, Hall signal, encoder and other motor related parameters in real time.

## **Keywords**

**Ethernet, FPGA, Stepper Motor** 

Copyright © 2024 by author(s) and Hans Publishers Inc. This work is licensed under the Creative Commons Attribution International License (CC BY 4.0). http://creativecommons.org/licenses/by/4.0/

# 1. 引言

步进电机根据输入的脉冲信号转变成角位移或者线位移的开环控制电机,在医疗器械、数控机床以 及光学设备等领域实现广泛应用[1]。在步进电机正常运作的情况下,电机的转速大小与停止位置只受脉 冲信号频率与个数的控制,不受负载的影响。步进电机是以固定旋转角度运行的,可通过控制脉冲个数 与频率来控制位移量,进而实现准确步进定位的目的[2]。近年来,研究人员提出基于单片机对步进电机 进行控制系统设计[3]-[5],但在实际应用中,基于单片机的控制系统对电机的控制精度相较于 FPGA 控制 来说更低;基于 FPGA 的步进电机控制系统研究[6]-[9]使得电机启停频率进行精确控制、系统稳定性与抗 干扰性更高;但目前四相电机驱动控制设备研究较少,并存在一定的不足:首先,电机的控制驱动策略 单一,调节范围小,稳定性不足以及缺少更精细化的控制方式,难以满足一些需要高精度与高稳定性的 应用背景;其次,在一些应用环境较为恶劣或对操作人员身体存在一定风险的地方,人员难以接近步进 电机控制装置,若步进电机运作过程中出现过流情况,但因缺少监测装置导致相关人员不能及时应对突 发情况,于是可能会引发安全事故。因此,本文基于上述问题,提出基于 FPGA 的四相步进电机驱动及 电机参数采集系统设计,使步进电机驱动更加精细,运行更加安全。

## 2. 系统框架



本设计的系统框图如图 1 所示,用户经上位机对四相步进电机的驱动电压、微步细分、目标转速等驱动参数进行配置,之后由 FPGA 内部相应的逻辑组合,对用户的配置进行实现;当电机运行时,经相应的数据采集电路对电机的相电压、相电流、霍尔信号以及编码器等数据进行采集,经 FPGA 内部对不同数据汇总后,定时上传至上位机以便用户实时监测电机相关性能参数。

## 3. 各模块功能设计

## 3.1. 高速网络接口搭建

在工业控制系统中,基于以太网协议进行数据传输已经得到广泛应用[10]-[12]。目前千兆以太网接口设计方案常采用端口物理接口收发器(PHY, port physical layer)芯片与媒体接入控制器(MAC, Media Access Control Address)来实现[13]。网络接口常用的有 GMII (Gigabit Medium Independent Interface)和 RGMII (Reduced Gigabit Medium Independent Interface)两种媒体独立接口,二者接口的传输速率都可达到 1000 Mbps,区别在于 GMII 接口数据传输位宽为 8 位,而 RGMII 接口数据传输位宽为 4 位[14]。从 FPGA 引脚资源方面考虑,本设计采用 RGMII 接口作为 PHY 芯片与 MAC 的通信接口,接口信息如图 2 所示。



**Figure 2.** RGMII interface 图 2. RGMII 接口

UDP 协议和 TCP 协议都是位于开放式系统互联(OSI, Open System Interconnection)参考的模型中的第 四层(传输层),属于无连接型的传输层协议,位于 IP 协议层(网络层)之上[15],如图 3 所示为 OSI 参考模型。相较 TCP 协议而言,UDP 协议的特点在于不需要握手操作,并且通信速率快,资源占用较少,所以本设计采用 UDP 协议作为 FPGA 主控和上位机通信的传输协议。

| OSI参考模型 |         | 各层的解释          |           |
|---------|---------|----------------|-----------|
| 应用层     | <b></b> | 为应用程序提供服务      | $\supset$ |
| 表示层     | <b></b> | 数据格式转化、数据加密    | $\supset$ |
| 会话层     |         | 建立、管理和维护会话     | $\supset$ |
| 传输层 一   |         | 建立、管理和维护端到端的连接 | $\supset$ |
| 网络层     |         | IP选址及路由选择      | $\supset$ |
| 数据链路层 — |         | 提供介质访问和链路管理    | $\supset$ |
| 物理层     |         | 物理层            | $\supset$ |

Figure 3. OSI model 图 3. OSI 模型 以太网 UDP 传输数据帧的格式由图 4 所示。从图中可以看出,以太网的数据帧通过对各层协议组合 封装后实现数据的传输。每帧数据包含前导码(preamble)、帧起始界定符(SFD, Start Frame Delimiter)、以 太网帧头、IP 首部、UDP 首部、用户数据和帧检验序列(FCS, Frame Check Sequence)。



Figure 4. UDP data frame format 图 4. UDP 数据帧格式

为使 FPGA 实现 UDP 通信功能,可通过如下两个方案架构: FPGA + CPU 架构和 FPGA + PHY + MAC 架构,对于这两种方案架构, FPGA + CPU 架构是通过 CPU 将经 UDP 协议发送来的数据进行解析 后再交由 FPGA 进行数据处理; FPGA + PHY + MAC 架构是运用 FPGA 的内部逻辑资源对 UDP 传输层 协议进行构建,通过 PHY 芯片进行物理层的传递,并结合 MAC 实现数据链路层功能,以此实现 UDP 传输功能[16]。前者架构中,由于 CPU 进行网络传输会触发中断,所以将存在传输延迟不固定的隐患。于 是本设计根据 FPGA + PHY + MAC 架构进行 UDP 协议的传输功能构建。本系统选用 Xilinx 公司型号 XC7A35TFGG484-2 的 FPGA 芯片开发板为主控,PHY 芯片型号为 RTL8211,运用三段式状态机实现其 功能,其状态跳转如图 5 和图 6 所示。



**Figure 5.** UDP receive part of the state machine 图 5. UDP 接收部分状态机



**Figure 6.** UDP transmit part of the state machine 图 6. UDP 发送部分状态机

## 3.2. 电机驱动模块搭建

### 3.2.1. 电机驱动电路设计

本文设计驱动的电机为四相步进电机,而电机驱动芯片中少有四相步进电机驱动芯片,于是本设计 决定采用两片两相步进电机驱动芯片进行组合,搭建相应驱动电路对四相电机进行驱动。电机驱动芯片 TMC2590 具有 5~60 V 高驱动电压范围以及微步细分最高可支持 256 细分,符号本设计的设计需求。如 图 7 所示为电机驱动电压电路,采用分压法控制数字电位器 MCP41010 的阻值大小,进而调节电机驱动 电压 VM 的大小。为实现电机驱动电压范围为 4~20 V,直接驱动 MOS 管的方案无法满足设计需求,因 此决定采用外部栅极驱动 IC 芯片,如图 8 为电机的 H 桥驱动电路。







#### Figure 8. H-bridge circuit 图 8. H 桥电路

## 3.2.2. 电机驱动软件控制设计

步进电机作为感应负载,通过控制电机上的电流大小可实现对电机的步进控制。于是根据 TMC2590 芯片内的 SPI 驱动模式,为H 桥电路提供高、低边的控制信号,结合 FPGA 主控内存储的微步表以及上 位机下发的 S 型速度曲线,可使步进电机按照整步或微步的方式进行变速转动。如图 9 所示为电机控制 模块功能结构。此模块根据上位机下发的电机启动和停止指令对此模块进行控制,根据上位机设定的目标转速、电机细分以及驱动模式进行相应环节响应,由 S 型速度曲线模块将存储的电机转速值按一定量 输入该模块的 ram 中存储,然后对当前电机转速和目标转速进行比较,决定需要加速或是减速,再根据 设置的微步细分将相应数据以 SPI 的接口协议输出给驱动芯片 TMC2590 进行配置。



Figure 9. Motor control module function structure 图 9. 电机控制模块功能结构

S型速度曲线广泛应用于对步进电机的控制中,S型速度曲线是一种平滑的速度曲线,其加减速过程更加平滑,能够避免因突变速度对电机和机械系统造成的冲击和振动[17]。而在加减速的过程中速度等级 细分的越多,则会使步进电机的转动更加流畅。考虑到 FPGA 的内部资源有限,不适合使用 RAM 对 S型速度曲线的数据存储,于是决定采用外部的 DDR3 存储器对其进行存储。

本系统采用的主控开发板上配有一个型号为 MT41J128M16HA-125 的 2 Gbit (256 MB)的 DDR3 芯 片,为高效的使用 DDR3 存储器,采用 Vivado 软件提供的 MIG IP 核作为存储器的控制器。MIG IP 核主 要由用户接口块(User Interface Block)、存储器控制器(Memory Controller)和物理层(Physical Layer)这三部 分组成[18]。用户需线根据数据手册对接口时钟、存储器类型以及位宽等参数在配置页面进行 MIG IP 核 的配置,待配置成功后则实现存储器控制器与物理层之间的连接,之后需要考虑用户接口块的读写逻辑。 如图 10 为 DDR3 读写状态机。



Figure 10. DDR3 read/write state machine 图 10. DDR3 读写状态机

本设计采用降压转换芯片 TPS5450 与数字电位器 MCP41010 组合进行可变分压操作,即可提供电机 不同的驱动电压。电机驱动电压设置流程: 首先由用户在上位机输入设定的电机驱动电压数值,之后由 上位机根据降压转换芯片 TPS5450 数据手册中的计算公式,即公式(1)进行计算数字电位器的阻值大小, 再将此阻值大小转换成二进制码值发送给主控,当主控接收到数据后,通过 SPI 接口将数据发送给 MCP41010 进行阻值配置。

$$R_2 = \frac{R_1 \times 1.221}{V_{OUT} - 1.221} \tag{1}$$

式中*V<sub>out</sub>*为上位机输入的电机驱动电压数值,*R*<sub>1</sub>为用来串联分压的阻值,大小为10KΩ,*R*<sub>2</sub>为数字电位器的阻值大小。

## 3.3. 数据采集模块搭建

## 3.3.1. 电机相电压、相电流采集

本设计不仅需要对四相步进电机的相电压与相电流的测量分辨率达到毫伏与毫安级别,还需要对多 通道进行同步采集,而 AD7606C 是一款 8 通道 16 位同步采样模数数据采集系统(DAS),其每个通道均 包含模拟输入箝位保护、可编程增益放大器(PGA)、低通滤波器(LPF)和 16 位逐次逼近寄存器(SAR)模数 转换器(ADC),可满足本文的设计需求,于是本文采用模数转换芯片 AD7606C 作为数据采集芯片,采集 电路如图 11 所示。



Figure 11. Acquisition circuit 图 11. 采集电路

## 3.3.2. 霍尔信号采集

霍尔信号传感器有三根连接线,+5V电源线、地线、霍尔信号输出线,霍尔信号输出有效为低电平,为便于主控采集,将其转换成3.3V电平,如图12所示为霍尔信号电路。根据设计要求,通过相邻的霍尔信号之间的时间差来判断四相电机在匀速转动时是否出现丢步或振动等造成转动不稳定的现象,于是采用50MHz的主时钟对相邻霍尔信号之间的时间差计时。



## 3.3.3. 编码器数据采集

感栅编码器与光电编码器相比具有更高的抗污染、抗冲击能力,于是本设计采用感栅编码器对电机 位置信息进行采集。本设计采用的感栅编码器的传输协议为同步串行接口(Synchronous Serial interface, SSI) 协议,而 SSI 协议是 RS422 通信协议上的单向串行协议, RS422 接口电路如图 13 所示。



Figure 13. RS422 interface circuit 图 13. RS422 接口电路

# 3.4. 上位机与主控传输协议搭建

为实现上位机精准驱动四相步进电机与电机参数实时监测,需设计上位机与主控之间的传输协议, 如图 14 为 FPGA 内部指令解析与数据上传框图。如框图中所示,上位机下发的数据帧经 UDP 收发单元 接收后传输至指令解析模块进行指令区分,并将区分的指令分别流入对应模块以便于后续逻辑单元的使 用。在四相步进电机运行时,电机的相电压、相电流、霍尔信号以及编码器等数据被采集后,经数据组 帧模块将不同数据定时汇总上传至上位机,经上位机相应处理后进行实时显示对应参数的波形。



Figure 14. Instruction parsing and data upload block diagram 图 14. 指令解析与数据上传框图

# 4. 系统仿真与测试

# 4.1. 系统仿真

为验证主控数据上传的准确性,本设计决定采用信号发生器产生频率为1 KHz,幅值为2 V 的正弦 信号作为芯片 AD7606C 采集通道的输入信号,对比经上位机处理后存储的数据绘制的波形来测试数据 采集上传的准确性。如图 15 为存储数据绘图,从图中可看出采集到的数据绘制出来是正弦波形,其幅值 是 2 V,周期为 200 个采样点,而此次测试对 AD7606C 设置采样频率是 200 KHz,所以该正弦波形周期 为 1 µs。根据输入的正弦信号与上位机采集到的数据绘制出的波形对比,可认为本设计的数据采集上传 准确无误。



## 4.2. 系统测试

为确定本系统实现相应功能,于是对系统进行测试验证。本次测试设定的电机驱动电压为9V、微步 细分为全步模式,以及电机的目标转速为15r/min,并设置霍尔信号时间间隔的上限值与下限值。四相步

进电机达到匀速状态下四个相线上的相电压与相电流的波形图如图 16 和图 17 所示,根据此波形图可对 电机运行时四相进行监测,观察四个相线上的电压值与电流值是否出现的异常状态,并且在电机运行过 程中,可通过霍尔信号的时间间隔与编码器的位置信息分别计算出电机运行时的平均速度与瞬时速度, 进而监测电机运行过程中是否出现丢步以及堵转等异常运行现象。



**Figure 16.** Motor phase voltage waveform 图 16. 电机相电压波形



图 17. 电机相电流波形

# 5. 结论

本文基于 FPGA 设计出四相步进电机驱动及电机参数采集系统,主要具有以下几项优点: 1. 电机驱动电压实现 4~20 V 可调,步进细分最高支持 256 细分,并且可自由组合,实现步进电机驱动灵活配置; 2. 根据 UDP 协议与 DDR3 存储器的结合应用,为步进电机控制需要的变速曲线提供大量的存储空间,为实现更精细化的驱动步进电机提供可能; 3. 在此基础上,本设计将步进电机相电压、相电流、霍尔信号以及编码器等电机相关参数进行采集、上传后进行实时波形显示,从而可对步进电机运行时的电压、电流、瞬时速度以及平均速度进行实时监测; 4. 本设计不仅可对各电机参数进行设置阈值上下限,还有

相应的报警方式,在出现异常现象可通过不同的报警方式定位到问题根源,为操作人员排查问题提供便利。本文设计了更加精细化的四相步进电机驱动方式以及对四相步进电机的运行进行实时监测,可实现 高精度的四相步进电机驱动控制,并且通过实时监测四相步进电机运行以及相应的报警方式,为安全性 提供更多保障,具有较高的工程应用价值。

# 参考文献

- [1] 刘旭辉, 简震, 丁志娟, 等. 基于 Labview 的步进电机闭环控制系统设计[J]. 电力电子技术, 2021, 55(2): 54-56.
- [2] 张婧, 樊艳艳, 李勇. 基于 STM32 和 TMC5160 的步进电机控制系统[J]. 仪器仪表用户, 2020, 27(2): 63-66.
- [3] 刘成淦,王直.基于 STM32 的一种步进电机系统的设计[J].电子设计工程,2018,26(1):131-134+139.
- [4] 张曼玲, 汪钊旭, 穆旭阳, 等. 基于单片机的步进电机控制系统探究[J]. 机电产品开发与创新, 2023, 36(3): 133-135+145.
- [5] 谭人铭,张仁杰,江涛.基于 STM32 的步进电机位置闭环控制系统设计[J].黑龙江工业学院学报(综合版),2023, 23(1):58-62.
- [6] 孙磊. 基于 FPGA 的步进电机矢量控制研究[D]: [硕士学位论文]. 南京: 南京航空航天大学, 2019.
- [7] 向云峰, 王秀莲. 基于 FPGA 的步进电机驱动控制系统的研究与设计[J]. 南方农机, 2023, 54(13): 148-151.
- [8] 段简, 张奕婷, 郑晓峰, 等. 基于 HDL/FPGA 的步进电机驱动控制器设计[J]. 科技与创新, 2023(4): 5-7+12.
- [9] 张华西,陈佳宇,刘卿卿,等. FPGA 的多通道步进电机控制系统设计[J]. 单片机与嵌入式系统应用, 2023, 23(3): 71-75.
- [10] 陈乾. 基于以太网的带式输送机监控系统下位机的设计与实现[D]: [硕士学位论文]. 天津: 天津工业大学, 2019.
- [11] 贺建华,国芳,崔洁.基于 FX5U 以太网通信的多台电机联合控制系统设计[J].电工技术,2023(22):12-14+18.
- [12] 齐国栋, 姚达毛, 仲崇峰. 类 ITER 多功能机械臂关节三电机控制系统设计[J]. 核聚变与等离子体物理, 2024: 1-6. <u>http://kns.cnki.net/kcms/detail/51.1151.tl.20240313.1529.002.html</u>, 2024-08-30.
- [13] 贺政. 基于 FPGA 的多轴运动控制系统的研究[D]: [硕士学位论文]. 广州: 广东工业大学, 2021.
- [14] 孔德伟, 袁国顺, 刘小强. 基于 FPGA 的万兆以太网链路的设计与实现[J]. 微电子学与计算机, 2019, 36(12): 21-25.
- [15] 潘忠英. 以太网与 CAN 总线通信的 FPGA 设计与实现[J]. 计算机时代, 2022(7): 44-48.
- [16] 李杨, 苏和平, 张丹, 等. 基于 FPGA + ARM 多路千兆以太网通信接口设计[J]. 现代电子技术, 2022, 45(15): 25-29.
- [17] 梁洪涛, 王一兵, 朱燕萍, 等. 旋转惯导中转位电机控制算法对导航精度的影响分析[J]. 宇航计测技术, 2023, 43(4): 41-47.
- [18] 梁宽宽, 刘敏. 基于 FPGA 的多通道红外信号采集系统设计[J]. 工业仪表与自动化装置, 2023(1): 21-25.