在好例子网,分享、交流、成长!
您当前所在位置:首页C/C++ 开发实例嵌入式开发 → STM32F103 的AD抖动问题代码(main.c)

STM32F103 的AD抖动问题代码(main.c)

嵌入式开发

下载此实例
  • 开发语言:C/C++
  • 实例大小:0.02M
  • 下载次数:14
  • 浏览次数:245
  • 发布时间:2020-11-03
  • 实例类别:嵌入式开发
  • 发 布 人:cgyks9035
  • 文件格式:.c
  • 所需积分:2
 相关标签: STM32f103的AD抖动

实例介绍

【实例简介】解决STM32f103的AD抖动,两次平均值滤波,最终用变权值的加权滤波
【实例截图】
【核心代码】

void getad(void)
{
 u8 k,i,j,k1,k3,k5,pr;
 u16 temp[9],k2,adv[4][12];
 int dif;
 u32 sum;
  int rav[4];
 temp[0]=50;temp[1]=150;temp[2]=500;temp[3]=1000;temp[4]=2000;
 temp[5]=5000;temp[6]=9000;temp[7]=9750;temp[8]=9900;
 
 for(i=0;i<4;i )                             //测11次9位的分辨率
   {
   for(j=0;j<11;j ) {adv[i][j]=getadc(i); delayus(1);}    
   }                               

  for(i=0;i<4;i )
   {
   for(j=10;j>0;j--)                         //冒泡法排序                 
    for(k=0;k<j;k )
     if (adv[i][k]>adv[i][k 1])
     {k2=adv[i][k];adv[i][k]=adv[i][k 1];adv[i][k 1]=k2;}
 
     sum=0;
     for(j=4;j<7;j )  sum =adv[i][j];   //只要中间5个
   adv[i][11]=sum/3;
  }
 for(i=0;i<4;i )
    { for(j=0;j<10;j ) advo[i][j]=advo[i][j 1];
      advo[i][10]=adv[i][11];
    }

 for(i=0;i<4;i )
  for(j=0;j<11;j ) adv[i][j]=advo[i][j];
 
 for(i=0;i<4;i )
   {
   for(j=10;j>0;j--)                         //冒泡法排序                 
    for(k=0;k<j;k )
     if (adv[i][k]>adv[i][k 1])
     {k2=adv[i][k];adv[i][k]=adv[i][k 1];adv[i][k 1]=k2;}
 
     sum=0;
     for(j=4;j<7;j )  sum =adv[i][j];   //只要中间5个
   adv[i][11]=sum/3;
     pr=1;
     rav[i]=adv[i][11]*9999/4096;
   dif=rav[i]-te[6 i];
   if (dif<0) dif=-dif;
   if (dif<50) pr=99;
   if (rav[i]>0&&(dif*100/rav[i])<5) pr=99;
   tempad[i]=(tempad[i]*pr (100-pr)*rav[i])/100;

  /*
      此处将插入一致性校准
    */ 
    if (linad)
   {
    if (tempad[i]<=lin[i][0]) te[6 i]=tempad[i]*temp[0]/lin[i][0];
       if (tempad[i]>lin[i][8]) te[6 i]=temp[8] (tempad[i]-lin[i][8])*(9999-temp[8])/(9999-lin[i][8]);
    for(j=0;j<9;j )
      if (tempad[i]>lin[i][j]&&tempad[i]<=lin[i][j 1])
      te[6 i]=temp[j] (tempad[i]-lin[i][j])*(temp[j 1]-temp[j])/(lin[i][j 1]-lin[i][j]);
     }
  if (linad==0) te[6 i]=tempad[i];
  } 

实例下载地址

STM32F103 的AD抖动问题代码(main.c)

不能下载?内容有错? 点击这里报错 + 投诉 + 提问

好例子网口号:伸出你的我的手 — 分享

网友评论

发表评论

(您的评论需要经过审核才能显示)

查看所有0条评论>>

小贴士

感谢您为本站写下的评论,您的评论对其它用户来说具有重要的参考价值,所以请认真填写。

  • 类似“顶”、“沙发”之类没有营养的文字,对勤劳贡献的楼主来说是令人沮丧的反馈信息。
  • 相信您也不想看到一排文字/表情墙,所以请不要反馈意义不大的重复字符,也请尽量不要纯表情的回复。
  • 提问之前请再仔细看一遍楼主的说明,或许是您遗漏了。
  • 请勿到处挖坑绊人、招贴广告。既占空间让人厌烦,又没人会搭理,于人于己都无利。

关于好例子网

本站旨在为广大IT学习爱好者提供一个非营利性互相学习交流分享平台。本站所有资源都可以被免费获取学习研究。本站资源来自网友分享,对搜索内容的合法性不具有预见性、识别性、控制性,仅供学习研究,请务必在下载后24小时内给予删除,不得用于其他任何用途,否则后果自负。基于互联网的特殊性,平台无法对用户传输的作品、信息、内容的权属或合法性、安全性、合规性、真实性、科学性、完整权、有效性等进行实质审查;无论平台是否已进行审查,用户均应自行承担因其传输的作品、信息、内容而可能或已经产生的侵权或权属纠纷等法律责任。本站所有资源不代表本站的观点或立场,基于网友分享,根据中国法律《信息网络传播权保护条例》第二十二与二十三条之规定,若资源存在侵权或相关问题请联系本站客服人员,点此联系我们。关于更多版权及免责申明参见 版权及免责申明

;
报警