研发日记,Matlab/Simulink避坑指南(三)——向上取整Bug

发布时间:2024年01月13日

文章目录

前言

背景

问题

排查

解决

总结


前言

????????见《研发日记,Matlab/Simulink避坑指南(一)——Data Store Memory模块执行时序Bug

????????见《研发日记,Matlab/Simulink避坑指南(二)——非对称数据溢出Bug

背景

????????在一个嵌入式软件项目中,需要对一个可变数组进行数据处理。要求是原始数据相邻四个合并在一起,在这个算法中需要对原始可变数组的lengh除4后向上取整。算法的思路是,length对4整除,除不尽的加1,示例如下:

function y = fcn(u)
 
if mod(u,4) == 0
    y = floor(u/4);
else
    y = floor(u/4) + 1;
end

问题

????????按照上述示例,预想不同的lengh都能除4后向上取整,但是实际运行的结果如下:

排查

????????把数据处理算法的过程变量都输出来,看到求余和求商都是正确的,if分段判定也没有问题,示例如下:

function [Mod, Shg, y] = fcn(u)
 
Mod = mod(u,4);
Shg = floor(u/4);
 
if Mod == 0
    y = Shg;
else
    y = Shg + 1;
end

解决

????????换一种算法实现方式,用Gain模块直接做整除向上取整,示例如下:

????????重新运行程序,问题不再出现,Bug修复完工。示例如下:

总结

????????整除后四舍五入,向上取整,向下取整,这类算法在Matlab/Simulink中官方已经集成了,只要熟悉一下就能应用,不需要开发者自己再开发了,如下图所示:


????????版权声明:原创文章,转载和引用请注明出处和链接,侵权必究!

????????上述例程使用的Demo工程,可以到笔者的主页查找和下载。

文章来源:https://blog.csdn.net/CSSUST/article/details/135563990
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。