ADC通道检测功能-单片机通用模板

ADC通道检测功能-单片机通用模板

使用ADC外设的流程:

  1. 先初始化ADC外设的时钟
  2. 选择ADC的参考电压以及需要采集的通道
  3. ADSOC=1 开始转换,死循环等待转换完成ADSOC=0;
  4. 从ADCDH、ADCDL数据寄存器取出ADC转换数值
  5. 进行中位值平均滤波限幅平均滤波限幅消抖滤波滑动平均滤波加权递推平均滤波一阶互补滤波等滤波处理。
//=============================================================================
//函数名称:ADCInit
//输	入:无
//输	出:无
//功	能:系统ADC外设初始化
//=============================================================================
void ADCInit(void)
{OPTION = (OPTION&ADCKS_Mask)|ADCKS_sys_4;	//ADC 时钟频率选择FSys/32
}//=============================================================================
//函数名称:getChannelVal
//输	入:channel 通道
//输	出:无
//功	能:中位值平均滤波获取channel通道ADC值
//=============================================================================
u16 getChannelVal(u8 channel)
{u8 i=0;u16 adcValMin=0xffff,adcValMax=0;u16 adcValue=0,adcValueSum=0;ADCHS = (ADCHS & ~ADCHS_MASK)|channel;SET_ADVREFS_00;for(i=0;i<4;i++){ADSOC = 1;while(ADSOC);adcValue = (ADCDH<<4)|(ADCDL>>4);adcValueSum += adcValue;if(adcValMin>adcValue)adcValMin=adcValue;if(adcValMax<adcValue)adcValMax=adcValue;}return	(adcValueSum-adcValMin-adcValMax)/2;//return	(adcValueSum-adcValMin-adcValMax)>>2;		//移位
}//=============================================================================
//函数名称:setAdv_getChannelVal
//输	入:adv 参考电压 channel 通道
//输	出:adcValue 12bit的Adc数据
//功	能:设置参考电压ADV和通道channel获取ADC
//=============================================================================
u16 setAdv_getChannelVal(ADV adv,u8 channel)
{u16 adcValue=0;ADCHS = channel;switch(adv){case ADV_VCC:SET_ADVREFS_00;break;case ADV_25:SET_ADVREFS_01;break;case ADV_4:SET_ADVREFS_02;break;case ADV_5:SET_ADVREFS_03;break;}ADSOC = 1;while(ADSOC);adcValue = (ADCDH<<4)|(ADCDL>>4);return	adcValue;
}//=============================================================================
//函数名称:Lim_filter
//输	入:new_Adcdata 最新采集ADC limmit 限幅范围
//输	出:无
//功	能:限幅滤波,超出限定范围内波动取上一次的值
//=============================================================================
/*u16 Lim_filter(u16 new_Adcdata,u16 limmit)
{static u16 old_Adcdata;int deta;deta = (int)(new_Adcdata- old_Adcdata);if(deta < limmit && deta >-limmit){old_Adcdata= new_Adcdata;return new_Adcdata;}else{old_Adcdata= new_Adcdata;return old_Adcdata;}
}
*///=============================================================================
//函数名称:Lim_filter
//输	入:new_Adcdata 最新采集ADC limmit 限幅范围 aveCnt 平均的总数
//输	出:无
//功	能:限幅平均滤波,限定范围内波动取最新值,达到aveCnt 后取平均
//=============================================================================
/*u16 Lim_ave_filter(u16 new_Adcdata,u16 limmit,u8 aveCnt)
{static u16 old_Adcdata=0,filterCnt=0;u16 new_value,adcValueSum =0;int deta=0;deta = (int)(new_Adcdata- old_Adcdata);if(deta < limmit && deta >-limmit)filter_v[filterCnt++]=new_value;if(filterCnt==aveCnt) filterCnt=0;for(count =0 ;count<aveCnt;count++)adcValueSum +=filter_v[count];return (adcValueSum /aveCnt);
*/
//=============================================================================
//函数名称:sort
//输	入:buf 数据 len 数据长度
//输	出:无
//功	能:排序  小到大(冒泡排序)
//=============================================================================
/*static void sort(u16 *buf, u8 len)
{u8 i,j;u16 temp;for (j = 0; j < len - 1; j++) //排序  小到大{for (i = j + 1; i < len; i++){if (buf[j] > buf[i]){temp = buf[i];buf[i] = buf[j];buf[j] = temp;}}}
}
*/
//=============================================================================
//函数名称:Glide_ave_filter
//输	入:new_Adcdata 最新采集ADC aveCnt 平均的总数
//输	出:无
//功	能:滑动平均滤波,更新最新的值取平均
//=============================================================================
/*u16 Glide_ave_filter(u16 new_Adcdata, u8 aveCnt)
{u8 i;u16 adcValueSum = 0;u16 temp_buf[ADC_FILTER_CNT];for(i = 0; i < ADC_FILTER_CNT - 1; i++)  //去掉最旧{filter_v[i] = filter_v[i + 1];}filter_v[ADC_FILTER_CNT - 1] = new_Adcdata;  //最新值memcpy(temp_buf, filter_v, ADC_FILTER_CNT);sort(temp_buf, ADC_FILTER_CNT);  //排序  小到大for(i = aveCnt; i < ADC_FILTER_CNT - aveCnt; i++){adcValueSum += temp_buf[i];}return (u16)(adcValueSum / (ADC_FILTER_CNT - aveCnt * 2));
}
*/

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/819685.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

一套3种风格经典的wordpress免费主题模板

wordpress免费企业主题 https://www.wpniu.com/themes/39.html 免费wordpress企业模板 https://www.wpniu.com/themes/43.html 免费wordpress企业主题 https://www.wpniu.com/themes/44.html

波奇学Linux:ip协议

ip报头是c语言的结构体 报头和有效载荷如何分离&#xff1f; 固定长度四位首部长度 4位版本号就是IPV4 8位服务类型&#xff1a;4位TOS位段和位保留字段 4位TOS分别表示&#xff1a;最小延时&#xff0c;最大吞吐量&#xff0c;最高可靠性&#xff0c;最小成本 给路由器提…

【JAVA基础篇教学】第十六篇:Java连接和操作MySQL数据库

博主打算从0-1讲解下java基础教学&#xff0c;今天教学第十六篇&#xff1a;Java连接和操作MySQL数据库。 我将提供一个简单的示例代码&#xff0c;涵盖数据库连接、查询、插入和更新等操作。 一、下载MySQL驱动包 1.下载地址&#xff1a;MySQL :: Download Connector/J 2.解…

Navicat for MySQL 使用基础与 SQL 语言的DDL

一、目的&#xff1a; Navicat for MySQL 是一套专为 MySQL 设计的高性能数据库管理及开发 工具。它可以用于任何版本 3.21 或以上的 MySQL 数据库服务器&#xff0c;并支持大 部份 MySQL 最新版本的功能&#xff0c;包括触发器、存储过程、函数、事件、视图、 管理用户等。…

VMware配置CentOS 7 并实现ssh连接

Vmware 17下载地址 ***永久许可证&#xff1a;***5Y012-8HL8P-0J8U0-032Q6-93KKF CentOS 7 下载地址 一、配置CentOS 如下 创建新的虚拟机&#xff0c;选择典型&#xff0c;点击下一步 选择上述下载镜像存储位置&#xff0c;选择镜像&#xff0c;点击下一步 3.填写相关信息…

微信小程序wx.getLocation 真机调试不出现隐私弹窗

在小程序的开发过程中&#xff0c;首页中包含要获取用户地理位置的功能&#xff0c;所以在这里的onLoad&#xff08;&#xff09;中调用了wx.getLocation()&#xff0c;模拟调试时一切正常&#xff0c;但到了真机环境中就隐私框就不再弹出&#xff0c;并且出现了报错&#xff0…

智能生活新体验:小米香薰加湿器技术解码

在现代家居生活中&#xff0c;科技与舒适性日益交织&#xff0c;智能家居产品成为提升生活品质的重要工具。小米香薰加湿器作为一款集科技与生活美学于一体的产品&#xff0c;其独特的设计和多功能性受到了广泛欢迎。今天&#xff0c;我们就来详细拆解这款融合了科技与香薰元素…

Sony Camera Remote SDK在Windows上的使用

Sony官方提供了相机遥控软件开发包&#xff0c;允许用户自行开发应用软件&#xff0c;实现对相机的远程控制&#xff0c;包括拍摄、监看和文件传输等。截至目前最新的版本是2024.4.12发布的1.12.00版本&#xff0c;下载链接如下&#xff1a;Camera Remote SDK | LICENSE AGREEM…

初学python记录:力扣706. 设计哈希映射

题目&#xff1a; 不使用任何内建的哈希表库设计一个哈希映射&#xff08;HashMap&#xff09;。 实现 MyHashMap 类&#xff1a; MyHashMap() 用空映射初始化对象void put(int key, int value) 向 HashMap 插入一个键值对 (key, value) 。如果 key 已经存在于映射中&#x…

SpringCloud之LoadBalancer自定义负载均衡算法,基于nacos权重

LoadBalancer基于Nacos权重自定义负载算法 ReactorLoadBalancer接口&#xff0c;实现自定义负载算法需要实现该接口&#xff0c;并实现choose逻辑&#xff0c;选取对应的节点 public interface ReactorLoadBalancer<T> extends ReactiveLoadBalancer<T> {Mono<…

VMware Workstation部署最新版OpenWrt 23.05.3

正文共&#xff1a;1456 字 51 图&#xff0c;预估阅读时间&#xff1a;2 分钟 我们之前介绍了如何在VMware Workstation上安装OpenWrt&#xff08;软路由是啥&#xff1f;OpenWrt又是啥&#xff1f;长啥样&#xff1f;在VMware装一个瞅瞅&#xff09;&#xff0c;也介绍了如何…

【计算机毕业设计】物流管理系统设计与实现——后附源码

&#x1f389;**欢迎来到琛哥的技术世界&#xff01;**&#x1f389; &#x1f4d8; 博主小档案&#xff1a; 琛哥&#xff0c;一名来自世界500强的资深程序猿&#xff0c;毕业于国内知名985高校。 &#x1f527; 技术专长&#xff1a; 琛哥在深度学习任务中展现出卓越的能力&a…

ubuntu16.04安装Eclipse C/C++

1.安装 JDK 官网源码安装 首先打开JDK官网&#xff0c;JDK1.8的下载网址为&#xff1a;https://www.oracle.com/cn/java/technologies/downloads/#java8-windows&#xff0c;进入到网址如下图所示&#xff1a; 向下滑动到 JDK1.8的下载界面&#xff0c;如下图所示&#xff1a…

3_2Linux中内核级加强型火墙的管理

### 一.Selinux的功能 ### 观察现象 ①当Selinux未开启时 在/mnt中建立文件被移动到/var/ftp下可以被vsftpd服务访问 匿名用户可以通过设置后上传文件 当使用ls -Z /var/ftp查看文件时显示"?" ps auxZ | grep vsftpd 时显示&#xff1a; - root 8546 0.0 0.0 26952 …

四.音视频编辑-音频混合-概述

引言 当我们在前两篇博客中成功地构建了一个媒体组合&#xff0c;并且略过了音频部分时&#xff0c;我们意识到了我们需要对这个项目进行更详细的探讨。在本篇博客中&#xff0c;我们将会展示如何创建一个包含视频轨道、配音音频轨道以及背景音频轨道的完整媒体组合。更进一步…

Antd:在文本框中展示格式化JSON

要想将对象转换为格式化 JSON 展示在文本框中&#xff0c;需要用到 JSON.stringify JSON.stringify 方法接受三个参数&#xff1a; value&#xff1a;必需&#xff0c;一个 JavaScript 值&#xff08;通常为对象或数组&#xff09;要转换为 JSON 字符串。replacer&#xff1a…

MySql 安装,小白也可以学会成功安装的保姆级教程

MySql 安装 文章目录 MySql 安装1.Mysql下载1.1 访问下载链接1.2 选择合适版本1.3 下载安装包 2.MySql安装3.安装成功检测验证3.1 mysql自带控制台验证3.2 win系统控制台进入验证 4. mysql 配置path5. navicat 连接 mysql 1.Mysql下载 1.1 访问下载链接 MySQL Downloads 这里…

【自由看门狗配置及计算】

一、看门狗使用场景 看门狗是一个硬件计时电路&#xff0c;用来监测由软件故障导致的系统故障。 片上有两个看门狗定时器外设&#xff0c;自由看门狗定时器&#xff08;FWDGT也叫独立看门狗&#xff09;和窗口看门狗定时器&#xff08;WWDGT&#xff09;。 当嵌入式程序在运…

Linux程序调试优化(1)——内存占用详解及优化思路

文章目录 1.free查看总体的内存占用2./proc/$PID/status 查看某进程状态 linux开发最重要的两个参数&#xff0c;分别是内存以及CPU使用率&#xff0c;若内存出现严重不足&#xff0c;则在需要使用内存时&#xff0c;可能出现申请不到的情况&#xff0c;导致 OOM&#xff0c;L…

不出天府锋巢直播产业基地,即可激活电商直播产业、产教融合及人才培训服务

天府锋巢直播产业基地打造直播产业产教融合及人才培训服务新模式&#xff0c;携手政府、企业、高校&#xff0c;促进直播产业与创新人才双向奔赴&#xff0c;推进教学与实战深度融合&#xff0c;推动实习与就业无缝衔接。 各方资讯一应俱全 直播产业产教融合及人才培训服务全套…