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

文章目录

前言

背景

问题

排查

解决

总结


前言

        见《研发日记,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工程,可以到笔者的主页查找和下载。

评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Mr.Cssust

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值