这部分功能我关注的很少,我用到的CAN协议中的因子都是在消息传完之后自己增加。这样,我用到的Simulink仅仅是一个最简单的翻译功能。

       有一阵子我觉得带有factor和bias的信号使用Simulink实现就是第一个定标的实现,后来我发现无论我怎么进行定标信息的修正始终出现数据类型的不匹配。直到有一天,随手拽了一个强制数据类型转换的模块实现了代码生成。从代码中,我发现其实定标信息的实现实际上使用的是浮点方式。

       这样,进行一个信号解析就非常简单了。搭建一个如下的模型:

Simulink解析带有系数和偏移量的CAN报文信息

       其中,CAN消息中的信号定义如下:

Simulink解析带有系数和偏移量的CAN报文信息

       进行代码生成之后,查看代码中的相应信息如下:

Simulink解析带有系数和偏移量的CAN报文信息

       从上面的代码可以看出,在数据定义中的定标信息已经实现。而输入的信号实际上使用的是浮点的数据类型。而我们定标最终的数据其实也仅仅是一个最终的物理数值,使用这种方式最多也就会损失一点精度。整体的功能实现上应该基本能够满足我们的要求。

       解决了消息的打包发送,其实,消息帧的解析拆包也是类似的处理方式。这里暂且不进行相应的总结。

相关文章:

  • 2021-08-26
  • 2021-11-15
  • 2021-05-03
  • 2021-12-13
  • 2021-04-26
  • 2021-05-02
  • 2021-11-15
  • 2022-12-23
猜你喜欢
  • 2021-09-26
  • 2021-09-02
  • 2022-01-18
  • 2021-06-13
  • 2021-09-08
  • 2022-12-23
  • 2021-10-01
相关资源
相似解决方案