AS5047P磁编码器应用设计大全解:硬件电路设计SPI通信时序逻辑波形分析注意事项

Posted Mark_md

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了AS5047P磁编码器应用设计大全解:硬件电路设计SPI通信时序逻辑波形分析注意事项相关的知识,希望对你有一定的参考价值。

1、AS5047P硬件设计



1.1 简介、性能参数


AS5047P 是一种款高分辨率旋转位置传感器,用于在整个 360 度范围内进行高速(高达 28krpm)角度测量。这种新型位置传感器配备了革命性的集成 动态角度误差补偿 (DAEC™),延迟几乎为零,并提供强大的设计,可抑制外部杂散磁场的影响。

AS5047P 非常适合具有挑战性的 BLDC 电机换向及工业应用,例如工厂自动化、楼宇自动化、机器人、PMSM(永磁同步电机)和步进电机闭环调节,以及对光学编码器的替换。

  • 14 位绝对角度位置传感器。

  • 适用于最高 28K RPM 转速的测量,动态角度误差最大值约为 ±0.2°。

  • 通信支持 标准 4线SPI 串行接口。

  • 拥有 SPI、ABI、PWM、UVW 等多种位置角度输出方式。

  • ABI 接口可配置输出为 4096/4000/2048/2000/1600/1200/1024/800/400/200/100 步每转。(有默认值,如需调整需OTP编程,只可更改一次)(注意:ABI 接口最大只支持 12位输出。)

  • 支持外部 3.3/5V 供电。封装为 TSSOP-16。



1.2 硬件设计 - 供电


AS5047P 支持两种供电方式:

  • 1、外部5V供电,使用内部LDO稳压;
  • 2、外部3.3V供电;

但要注意两种方式的通信电平不同。


1.2.1 外部5V供电,使用内部LDO稳压


使用外部5V供电,需要启用AS5047P自带的3.3V LDO。

5V由VDD输入,VDD3V3对GND接1uF电容。


1.2.2 外部3.3V供电


使用外部3.3V供电时,需要将VDD和VDD3V3短接。


1.3 硬件设计 - 注意事项


如使用外部5V的供电方式,启用AS5047P内部的3.3V LDO,则外部的供电电压必须保持在 4.5~5.5V 这个范围。

另外,还需考虑通信电平的兼容。
根据使用的 MCU3.3V/5V,来匹配 AS5047P的供电电路。
(不建议串电阻兼容。串电阻会影响SPI通信速率,实测串联100R电阻导致1MHz-SPI通信失败。)



2、AS5047P - SPI通信时序


从手册的第11页开始翻译

SPI 接口(从)
主机微控制器(主)使用 SPI 接口来读取或写入易失性存储器以及对非易失性 OTP 寄存器进行编程。 AS5047P 的 SPI 仅支持从模式。 它可以以高达 10 MHz 的时钟速率进行通信。

AS5047P SPI 使用模式=1(CPOL=0,CPHA=1)来交换数据。 如图 11 所示,数据传输从 CSn 的下降沿开始(SCL 为低电平)。 AS5047P 在 SCL 的下降沿采样 MOSI 数据。 SPI 命令在帧结束时执行(CSn 的上升沿)。 位顺序是 MSB 在前。 数据受奇偶校验保护。

注意:与AS5047P进行SPI通信的MCU,需要配置SPI为 SPI mode 1.(CPOL=0, CPHA=1),之前大多数情况用mode0,注意更改硬件配置。)

SPI时序
AS5047P SPI 时序如图 11 所示。

SPI事务
SPI 事务由一个 16 位的命令帧 和一个 16 位的数据帧 组成(也就是各两个字节)。 图 13 显示了命令帧的结构。
SPI命令帧

为了提高 SPI 通信的可靠性,必须生成和发送偶校验位 PARC。 奇偶校验位的错误设置会导致奇偶校验位错误,错误标志寄存器中的 PARERR 位显示了该错误。 奇偶校验位是从命令帧的低 15 位计算的。 16 位的命令帧由 寄存器地址读/写标志位 组成,该位来指示SPI事务是读还是写,以及奇偶校验位。

图 14 展示了读取的数据帧格式。

奇偶校验位 PARD 由 AS5047D数据帧的低 15 位计算。 如果前一个 SPI 命令帧中发生错误,则 EF 位被置1。 SPI 读取在 CSn 的上升沿进行采样,数据通过下一个读取命令在 MISO 上传输,如图 15 所示。
SPI读数据帧

表15很有参考意义的,图中包含了多个 SPI读 的消息帧。
CMD 和 DATA各16位,DATA会在下一次的CMD传输中被读出。很标准的SPI读过程。
AS5047的一个完整 SPI读 消息帧 = 表 13-命令帧(MOSI) + 表 14-读数据帧(MISO)

发送CMD的同时,可一同读出上次CMD指定的寄存器数据。这种读的方式,特别适合AS5047这样,需要以高刷新率读取电机转子位置的场合。

SPI写数据帧

奇偶校验位 PARD 必须根据 16 位数据计算。在 SPI 写事务中,写命令帧之后是 MOSI 的写数据帧。 写数据帧由地址在命令帧中的寄存器的新内容组成。

在通过写数据帧在 MOSI 上传输新内容期间,在 MISO 上发送旧内容。 在 MOSI 上的下一个命令中,寄存器的实际内容在 MISO 上传输,如图 17 所示。

区别于表15-SPI读
AS5047的一个完整 SPI写 消息帧 = 表 13-命令帧(MOSI) + 表 16-写数据帧(MOSI)
特别注意SPI写 消息帧时,MISO上的数据可以不读取,除非有需要此寄存器先前内容的需求。千万别让这个搞混了。正常按SPI写操作就行,不必关注MISO输出的数据。另外SPI写几乎用不到,除非有OTP编程的需求。



3、寄存器结构



3.1 易失性寄存器


易失性寄存器如图 18 所示。每个寄存器都有一个 14 位地址。

读取 NOP 寄存器相当于 AS5047P 的 nop(无操作)指令。

Figure 19~24 详细的说明了 易失性寄存器位功能。内容太多,请自己阅读数据手册。

简要汇总
NOP:读取 NOP 寄存器相当于 AS5047P 的 nop(无操作)指令。
ERRFL:错误标志寄存器。包括:奇偶校验错误、无效命令错误、帧错误。
PROG:用于对 OTP 存储器进行编程,二次开发基本用不到,不看了。
DIAAGC:磁场强度标志,CORDIC 溢出,及AGC控制,也用不到。
MAG:CORDIC 幅度信息,用不到。
ANGLEUNC:没有动态角度误差补偿的角度信息。
ANGLECOM:具有动态角度误差补偿的角度信息。(获取转子角度,不需要配置其他任何寄存器,在保证时序无误的前提下,只读这一个寄存器的值就够了。读取后要对 PARD进行偶校验,无误后将其转换为实际的转子角度)


3.2 非易失性寄存器 (OTP)


OTP(一次性可编程)存储器用于将传感器的绝对零位和客户设置永久存储在传感器 IC 中。

对于所有非易失性寄存器(软写入),可以多次进行 SPI 写/读访问。 硬件复位后软写入的寄存器内容将丢失。

自编程只可完成一次。 因此,非易失性寄存器的内容永久存储在传感器中。 硬件复位后寄存器内容仍然存在,不能被覆盖。

对于传感器的正确功能,不需要 OTP 编程。 如果未进行配置或编程,非易失性寄存器处于默认状态 0x0000h。
注意:注意上面的一行话,仅使用传感器的正常功能,是不需要OTP编程的。而且OTP只能固化一次,不可二次编程)

非易失性寄存器表

Figure 26~34 详细的说明了 非易失性寄存器位功能。内容太多,请自己阅读数据手册。

自己看了下 非易失性寄存器表 的功能,进行以下总结:

  • ZPOSMZPOSL绝对零位 的校准值。
  • SETTINGS1SETTINGS2 存储着用户自定义配置。这些配置包括:定义 PWM 的输出功能、禁用动态角度的误差补偿、ABI 脉冲的 十进制或二进制选择、启用 PWM输出、UVW 的极对数设置、滞后设置、ABI的分辨率(4096/4000/2048/2000/1600/1200/1024/800/400/200/100 步每转)。
  • 芯片出厂后,默认的OTP配置是怎样?

手册对ABI接口的概述:
AS5047P 可以通过增量接口将角度位置发送到主微控制器。 此接口可与其他接口同时使用。

默认情况下,增量接口设置为以每转 4096 步或每转 1024 脉冲 (ppr) 的最高分辨率工作。 可以分别使用位 ABIBIN 在每转十进制和二进制脉冲之间进行选择,并使用位 ABIRES 选择每转脉冲,如图 30 所示。
(不过我买的几块芯片,实测ABI默认是每转 4000 步,感觉和手册说的有点出入…关于ABI的说法暂不确定)

OTP编程的流程框图在手册中有介绍,不过自己没有用到,就不再继续介绍OTP。


4、SPI读AS5047P旋转角度


SPI读AS5047P旋转角度的流程

SPI读角度流程:

  • 1、AS5047P和MCU上电。
  • 2、上电后至少延时等待tpon=10ms。才可以发送有效数据。
  • 3、循环读 ANGLECOM寄存器(0x3FFF),得到 uint16 的数据。PARD位校验无误后,将其转换为转子的实际角度。

获取转子角度的过程较为简单,不需要配置其他任何寄存器,在保证时序无误的前提下,只读 ANGLECOM寄存器(0x3FFF) 这一个寄存器的值就可以了。读取后要对 PARD进行偶校验,无误后将其转换为实际的转子角度。

读的过程,需要计算 PARCPARD,他俩均为偶校验。

偶校验:确保整个被传输的数据中“1”的个数是偶数个。

故 如果载荷数据中“1”的个数是奇数个时,PARCPARD校验位填“1”,否则填“0”。

PARC是发送的(MOSI),PARD是接收的(MISO)。

所以我们在读寄存器的一帧数据内,要先对CMD进行偶检验,生成PARC。并添加到CMD的Bit15中,用MOSI发送出去,共16Bit。

MISO接收之后的16Bit数据,剥离出Bit15的PARD,对余下的数据进行偶检验,判断与PARD是否一致。

如一致,表示SPI数据传输无误,可继续进行转子实际角度计算;如不一致,则重读或者抛出异常提醒。


5、SPI测试波形


测试的 MCU 使用 ESP32,以 100KHz-SPI 的速率通信。
源码暂未放出,待后续完善个人ESP32驱动库后一同开源。获取预览版可先评论区留下邮箱。


5.1 SPI读DIAAGC


上面已经说过了 AS5047P-SPI读角度流程。不过为了方便测试,这里换个寄存器。

注意DIAAGC 寄存器地址为 0x3FFC,默认值为 0x0180。但它的值会根据磁场状态动态变化,并不是固定的。只有当磁极转子的运动状态不变,DIAAGC的值才是静止的。

连续读 DIAAGC 寄存器 波形:
使用软CS,成功。


5.2 SPI读DIAAGC(硬CS,通信失败)


先前一直用的ESP32的 硬CS 引脚,读失败。

注意读取错误时,MISO上的波形。Bit14 EF-错误标志位 会一直置1,使读取的 uint16 的值 >= 16384,可用此判断SPI通信的正常与否。


5.3 SPI读ANGLECOM(转子角度,软CS,通信成功)


ANGLECOM,转子角度。读一次。


5.4 SPI读ANGLECOM(转子角度,软CS,通信成功)


ANGLECOM,转子角度。连续读。



6、SPI测试波形


数据静态误差测试:
磁极转子静止时的数据输出。波动不大,很稳定,波动基本在 ±3内,与手册描述的 ±0.1° 基本一致。

输出的角度为旋转角度的绝对值,0~360°。用于运动控制的场合,不用像ABI每次上电都要归零点,使用很方便。



7、AS5047P调试时注意事项


  • SPI通信速率最大为 10MHz,时序为 SPI mode 1.(CPOL=0, CPHA=1)
  • SPI线路不宜过长,高速时会导致时序错乱。
  • 需要判断 PARCPARD 偶校验位,以尽量减少通信链路中产生的错误。
  • 将AS5047上的磁极旋转一周,返回的值会从0~16383变化。(14Bit)
  • 硬CS引脚由于速率过快,很大概率会导致与AS5047P通信失败。建议使用 软件控制的CS
  • 转子上的磁铁需要使用 径向冲磁 的强磁,磁铁与芯片的距离不宜超过5mm。

AS5047P这类磁编码器对编程的最大好处在于,可以随时获得磁极相对于芯片的旋转角度,即为转子角度。而不用像ABI编码器那样,每次上电都需要归位找零点。并且通信使用SPI总线,不必担心最大转速旋转时,ABI因线长或干扰等因素,导致线路传输丢步的意外情况。


同专栏相关推荐文章


TLE5012B磁编码器原理,巨磁阻(GMR)磁编码器原理及优点,径向充磁磁铁的安装

各厂商磁编码器对比,AS5047、AS5048、AS5600、TLE5012、MA730

AMS磁编码器:AS5048与AS5047区别,伺服电机闭环系统位置反馈


↓ 欢迎点赞收藏。

以上是关于AS5047P磁编码器应用设计大全解:硬件电路设计SPI通信时序逻辑波形分析注意事项的主要内容,如果未能解决你的问题,请参考以下文章

ODrive踩坑ODrive配置AS5047P-SPI绝对值磁编码器,不需每次上电校准无刷电机,直接上电可用

AS5600磁编码器开发记录

NB-IoT 智能门磁硬件搭建

MT6701磁编码器使用指南,14Bit单圈绝对值,I2C stm32 HAL库读角度,兼容AS5600

MT6701磁编码器使用指南,14Bit单圈绝对值,I2C stm32 HAL库读角度,兼容AS5600

硬件菌需要懂磁珠,学习哈用磁珠为Altera FPGA设计电源隔离滤波器