智元灵犀X1-本体通讯架构分析2:CAN/FD总线性能优化分析

接上一篇智元灵犀X1-本体通讯架构分析1:整体架构

更多机器人本体控制总线分析,请关注系列文章:

《具身神经-机器人运控通讯架构与实现系列》

我们知道灵犀X1本体CANFD通讯的几个关键信息

  1. 整机总共使用6路CANFD,波特率1M/5M
  2. 电机CANFD命令控制频率1KHz
  3. 一路CANFD总线最多的控制8个电机

本篇深入分析灵犀X2的CAN/FD通讯细节设计,并做详细性能分析。

CAN/FD通讯帧率和负载率

灵犀X1电机数量最多的是2两条手臂的CANFD总线-各挂了8个电机。

按1KHz控制频率计算,每秒钟需要发送8*1000条命令控制电机,再加8*1000条命令电机回复状态。

总计每秒帧数 = 发送8*1000 + 接收8*1000 = 1.6万帧/秒

但是,PowerFlow R系列电机支持广播命令可以通过单个64字节的CANFD数据帧发送8个电机的控制参数来减少帧率,提高总线通讯效率

实际上通讯帧率是:

发送64字节控制命令帧:1*1000 = 1000帧/秒

接收8字节电机状态帧:8*1000 = 8000帧/秒

总计9000帧/秒

CAN/FD总线通讯负载率计算

得到不同字节帧的帧率后,继续计算1M/5M 波特率下CANFD总线负载率

采用64字节广播命令

先计算1秒钟时长中所有CANFD帧通讯总时间开销。

|---------------|----------|----------|-------------|
| CANFD数据长度 | 单帧耗时 | 帧/每秒 | 总耗时 |
| 64字控制命令 | ~140us | 1000 | 140ms |
| 8字节电机回复 | ~50us | 8000 | 400ms |
| 合计 ||| ~540ms |

CANFD总线负载率就等于所有帧时间开销比计算周期1秒

总线负载率 : 540ms/1000ms = 54%

也就是说灵犀X1负载最大的手臂CANFD总线负载率为54%, 这个负载率不算高。这是通过CANFD的64字节帧优化通讯协议,尽可能利用了CANFD数据段高波特率的特性的结果。

如果不采用64字节协议,电机命令也使用8字节帧分别传输

|---------------|----------|----------|-------------|
| CANFD数据长度 | 单帧耗时 | 帧/每秒 | 总耗时 |
| 8字节电机命令 | ~50us | 8000 | 400ms |
| 8字节电机回复 | ~50us | 8000 | 400ms |
| 合计 ||| ~800ms |

若不采用64字节广播协议,负载率加重到了800ms/1000ms = 80%

CANFD协议负载率优化关键

可以看出在控制频率和电机数量不变的情况下,提升CANFD单帧字节数来合并单帧传输更多命令,可以有效提高总线通讯效率。

核心原理解析

核心原因就在:CANFD总线超过1M的高速波特率仅使用在数据段

对于灵犀X1使用CANFD总线1M/5M来说,只有传输数据时才用到的5M的波特率加速传输,而ID(仲裁段)还是使用1M的波特率。

提升CANFD通讯效率的关键,就在于:尽可能的有效使用CANFD长数据帧进行传输

总结

灵犀X1 CANFD总线使用非常合理,值得参考学习:

  1. 通过5M高速波特率,单路CANFD总线可1KHz控制8个电机,保证关节流畅运行
  2. 通过合并多个电机的控制命令到单条CANFD 64字节报文,有效降低了约26%的总线负载率
  3. CANFD总线最大负载率54%左右,留有通讯余量,避免高负载率下的总线竞争,保证了通讯的实时性
相关推荐
sweet丶7 小时前
Kingfisher 深度指南:Swift 生态下的高性能图片处理艺术
架构
老前端的功夫7 小时前
前端高可靠架构:医疗级Web应用的实时通信设计与实践
前端·javascript·vue.js·ubuntu·架构·前端框架
CoderYanger8 小时前
动态规划算法-01背包问题:50.分割等和子集
java·算法·leetcode·动态规划·1024程序员节
小小测试开发9 小时前
提升WebUI自动化效率与性能:从脚本到架构的全链路优化指南
运维·架构·自动化
CoderYanger12 小时前
动态规划算法-两个数组的dp(含字符串数组):48.最长重复子数组
java·算法·leetcode·动态规划·1024程序员节
用户930510658222412 小时前
module federation,monorepo分不清楚?
前端·架构
狗哥哥12 小时前
Vue 3 统一面包屑导航系统:从配置地狱到单一数据源
前端·vue.js·架构
无限大613 小时前
为什么计算机要使用二进制?——从算盘到晶体管的数字革命
前端·后端·架构
金融小师妹13 小时前
美联储议息夜:基于多智能体决策分歧模型的“鹰派降息”推演
人工智能·深度学习·1024程序员节