搜索
bottom↓
回复: 1

求教高手解析下这个滤波程序......

[复制链接]

出0入0汤圆

发表于 2012-3-27 22:17:02 | 显示全部楼层 |阅读模式
这是一个别人写好的防抖滤波程序
用于计算交流电压有效值防抖
形参num为通道号,Value为最小变化量
phase_result[num][i]为全局变量,保存8次测量有效值.
请高手分析他是怎么完成滤波功能的....
特别是
for (i = 0; i < 8; i++)
    {
      phase_result[num][i] = phase_result[num][result_channle];
    }
这句,为什么全赋这个值.

uint queue(uchar num, uint value)
{
  uchar i, j;
  int queue_tmp[8];
  long tmp,tmp1;
  for (i = 0; i < 8; i++)
  {
    queue_tmp[i] = phase_result[num][i];
  }
  for (i = 0; i < 8; i++)
  {
    for (j = i; j < 8; j++)
    {
      if (queue_tmp[i] < queue_tmp[j])
      {
        tmp = queue_tmp[i];
        queue_tmp[i] = queue_tmp[j];
        queue_tmp[j] = tmp;
      }
    }
  }
  tmp = queue_tmp[2] + queue_tmp[3] + queue_tmp[4] + queue_tmp[5];
  if (tmp > phase_result[num][8])
  {
    tmp1 = tmp - phase_result[num][8];
  }
  else
    tmp1 = phase_result[num][8] - tmp;
  if (tmp1 < value)
  {
    return (phase_result[num][8]);
  }
  else if (tmp1 < (value << 1))
  {
    phase_result[num][8] += (value >> 2);
    return (phase_result[num][8]);
  }
  else
  {
    for (i = 0; i < 8; i++)
    {
      phase_result[num][i] = phase_result[num][result_channle];
    }
    phase_result[num][8] = (phase_result[num][result_channle] << 2);
    return (phase_result[num][8]);
  }
}

阿莫论坛20周年了!感谢大家的支持与爱护!!

一只鸟敢站在脆弱的枝条上歇脚,它依仗的不是枝条不会断,而是自己有翅膀,会飞。

出0入0汤圆

 楼主| 发表于 2012-3-28 10:16:03 | 显示全部楼层
等高人呢???????????
回帖提示: 反政府言论将被立即封锁ID 在按“提交”前,请自问一下:我这样表达会给举报吗,会给自己惹麻烦吗? 另外:尽量不要使用Mark、顶等没有意义的回复。不得大量使用大字体和彩色字。【本论坛不允许直接上传手机拍摄图片,浪费大家下载带宽和论坛服务器空间,请压缩后(图片小于1兆)才上传。压缩方法可以在微信里面发给自己(不要勾选“原图),然后下载,就能得到压缩后的图片】。另外,手机版只能上传图片,要上传附件需要切换到电脑版(不需要使用电脑,手机上切换到电脑版就行,页面底部)。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

手机版|Archiver|amobbs.com 阿莫电子技术论坛 ( 粤ICP备2022115958号, 版权所有:东莞阿莫电子贸易商行 创办于2004年 (公安交互式论坛备案:44190002001997 ) )

GMT+8, 2024-6-19 01:42

© Since 2004 www.amobbs.com, 原www.ourdev.cn, 原www.ouravr.com

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