untitled.c

来自「使用cs5512做的电子秤,精度0.002kg」· C语言 代码 · 共 68 行

C
68
字号



unsigned int AD_Max=AD_buffer[0];
unsigned int AD_Min=AD_buffer[0];

for(j=AD_buffer_size-1;j!=0;j--)
   {
   if(AD_buffer[j]>=AD_Max) AD_Max=AD_buffer[j];
   else if((AD_buffer[j]=<AD_Min)) AD_Min=AD_buffer[j];
   AD_Sum += AD_buffer[j];
   AD_buffer[j]=AD_buffer[j-1];
   }
   
New_AD=(AD_Sum-AD_Max-AD_Min)/(AD_buffer_size-2); //滑动滤波平均值

//此处加中位值处理函数(去掉数组中的最大值与最小值)
for(j=0;j<AD_buffer_size-1;j++)
{
    for(k=0;k<AD_buffer_size-j;k++)
      {
        if(AD_buffer[k]>AD_buffer[k+1])
          {
            temp = AD_buffer[k];
            AD_buffer[k] = AD_buffer[k+1]; 
            AD_buffer[k+1] = temp;
          }
      }
}



for(i=1;i<AD_buffer_size-1;i++)
{
  AD_Sum += AD_buffer[i];
}      
                  
New_AD=AD_Sum/(AD_buffer_size); //滑动滤波平均值











  
         for(j=0;j<AD_buffer_size-1;j++)
            {
              for(T=0;T<AD_buffer_size-j;T++)
                {
                  if(AD_buffer[T]>=AD_buffer[T+1])
                    {
                      temp = AD_buffer[T];
                      AD_buffer[T] = AD_buffer[T+1]; 
                      AD_buffer[T+1] = temp;
                    }
                }
            }
   
        for(i=1;i<(AD_buffer_size-1);i++)
           {
             AD_Sum += AD_buffer[i];
           }                        
         New_AD=AD_Sum/(AD_buffer_size-2); //滑动滤波平均值

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?