OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 2051|回复: 2

另一种求平均数方法,不容易溢出

[复制链接]

45

主题

198

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1109
金钱
1109
注册时间
2016-3-25
在线时间
360 小时
发表于 2018-10-26 20:09:04 | 显示全部楼层 |阅读模式
本帖最后由 Mr.liu 于 2018-10-26 20:14 编辑

这是另一种求平均数方法,不容易产生数据溢出,但是会比较占用CPU时间。这个算法适合数据比较大,且数据量比较多的情况。

这完全是我个人突然想出来的。现在共享给大家,帮忙看看有没有BUG。我也没有仔细去推敲,欢迎大家发表意见。



uint32_t MeanNumber(int32_t *Data,uint8_t DataLen)
{
        uint8_t  i,Remain=0;
        
        int32_t BaseNumber=0,AverValue=0;
        BaseNumber=Data[0];                        
        
        for(i=0;i<DataLen;i++)
        {
                if(Data[0]>Data[i+1])                                                                                                
                {
                        AverValue-=Data[0]-Data[i+1];                                                                                    
                }
                else                                                                                                                                                               
                {
                        AverValue+=Data[i+1]-Data[0];               
                }
        }
        if(AverValue>=0x80000000)
        {
                AverValue=~AverValue-1;
                AverValue=AverValue/DataLen;
                Remain=AverValue%DataLen;
                if(Remain>=5)
                {
                        AverValue=Data[0]-AverValue+1;
                       return AverValue;
                }
                else
                {
                        AverValue=Data[0]-AverValue;
                       return AverValue;
                }
        }
        else
        {
                AverValue=AverValue/DataLen;
                Remain=AverValue%DataLen;
                if(Remain>=5)
                {
                        AverValue=Data[0]+AverValue+1;
                       return AverValue;
                }
                else
                {
                        AverValue=Data[0]+AverValue;
                       return AverValue;
                }
        }
        
}

不知道有几个朋友能看懂这逻辑,能看懂的估计是知音来得。








代写STM32各类驱动,DEMO程序
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

45

主题

198

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1109
金钱
1109
注册时间
2016-3-25
在线时间
360 小时
 楼主| 发表于 2018-10-26 20:13:58 | 显示全部楼层
本帖最后由 Mr.liu 于 2018-10-26 20:15 编辑

——                                  ————
代写STM32各类驱动,DEMO程序
回复 支持 反对

使用道具 举报

10

主题

3281

帖子

1

精华

论坛元老

Rank: 8Rank: 8

积分
8205
金钱
8205
注册时间
2020-5-11
在线时间
3700 小时
发表于 2024-7-6 14:46:06 | 显示全部楼层
大概思路是:以Data[0]为基准,其它数据与它的差值累加起来求平均,最后再加上Data[0]?
累加没必要判断 if(Data[0]>Data[i+1])  ,直接AverValue+=Data[i+1]-Data[0];  就完了。
if(AverValue>=0x80000000)可能有问题,你把它当无符号数,但int32_t是有符号数,可能一直会成立。
AverValue=~AverValue-1; 是想把负数转正数?那应该是取反加1才对。
验证过没有啊?
专治疑难杂症
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2024-11-23 19:30

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

快速回复 返回顶部 返回列表