蓝桥杯备战——12.PCF8591芯片的使用

目录

    • 1.芯片简介
    • 2.读写时序
    • 3.控制字
    • 4.代码封装库
    • 5.原理图分析
    • 6.使用示例

1.芯片简介

在这里插入图片描述

截取自NXP的PCF8591芯片数据手册,我把重点关注部分划出来了,请务必自行阅读一遍数据手册!

2.读写时序

①器件地址
在这里插入图片描述
Bit0决定是读还是写操作,Bit1~Bit3由外部引脚A0到A2确定。由于A0到A2接地,所有写地址为0X90,读地址为0X91。

②DAC
在这里插入图片描述
由上图我们可以看到,如果要进行D/A转换输出,我们只需写起始信号,地址写,等待应答,写控制字,等待应答,写DAC值(0~255),等待应答,发送停止信号。

③ADC:
在这里插入图片描述
由上图我们可以看到,如果要进行A/D转换,我们只需写起始信号,地址写,等待应答,写控制字,等待应答,写起始信号,地址读,等待应答,读ADC值,发送不应答,发送停止信号。

3.控制字

我就不细讲了,自己翻译一遍就懂了
在这里插入图片描述

在这里插入图片描述

4.代码封装库

#include "pcf8591.h"
#include "iic.h"

//****************获取ADC转换值******************
//mode:0~3,analog input programming
//channel:A/D channal number
//return: 0~5V to 0~255 ADC Value
//***********************************************
u8 Get_AdcValue(u8 mode,u8 channel)
{
	u8 ADC_Value;
	IIC_Start();	//发送IIC开始信号
	IIC_Send_Byte(0X90);	//发送写命令
	IIC_Wait_Ack();
	IIC_Send_Byte(0x40|(mode<<4)|channel); //写控制字
	IIC_Wait_Ack();
	
	IIC_Start();
	IIC_Send_Byte(0X91); //发送读命令			   
	IIC_Wait_Ack();
  	ADC_Value=IIC_Read_Byte(0);	//读入ADC值
  	IIC_Stop();//产生停止信号	    
	return ADC_Value;
}

//输出DAC 0~255 to 0~5V
void Write_DAC(u8 DAC_Value)
{
	IIC_Start();	//发送IIC开始信号
	IIC_Send_Byte(0X90);	//发送写命令
	IIC_Wait_Ack();
	IIC_Send_Byte(0x40);  //写控制字:使能DAC输出
	IIC_Wait_Ack();
	IIC_Send_Byte(DAC_Value);	//写DAC值
	IIC_Wait_Ack();
	IIC_Stop();//产生停止信号
}

//获取ADC转换值,输出DAC
u8 RAdc_WDac(u8 mode,u8 channel,u8 DAC_Value)
{
	u8 ADC_Value;
	IIC_Start();	//发送IIC开始信号
	IIC_Send_Byte(0X90);	//发送写命令
	IIC_Wait_Ack();
	IIC_Send_Byte(0x40|(mode<<4)|channel);  //写控制字:使能DAC输出,配置ADC模式及通道
	IIC_Wait_Ack();
	IIC_Send_Byte(DAC_Value);	//写DAC值
	IIC_Wait_Ack();
	
	IIC_Start();
	IIC_Send_Byte(0X91); //发送读命令			   
	IIC_Wait_Ack();
 	ADC_Value=IIC_Read_Byte(0);	//读入ADC值
  	IIC_Stop();//产生停止信号	    
	return ADC_Value;
}


注释即解析,请自行体会!

5.原理图分析

①测量放大电路
在这里插入图片描述
研究过运放的同学一眼就能看出这是个仪表放大电路哈,蓝桥杯运放是必考项目,包括理论部分也会考。所以有不懂的,请自行补上哦!最终的输出AIN2作为了PCF8591的模拟输入2,下图是此电路的计算分析:
在这里插入图片描述
注:此截图来源于B站UP唐老师讲电赛运放大师讲运放系列,若有侵权,请联系删除!

②电阻分压电路
就一滑动变阻器分压之后输出的AIN3作为PCF8591的模拟输入3,
在这里插入图片描述
③光强采集电路
也是一个光明电阻和电阻串联分压输出AIN1作为PCF8591的模拟输入1,
在这里插入图片描述
④外部输入
正好AIN0与OUT挨着,我们可以用跳线帽短接来测试D/A与A/D
在这里插入图片描述

6.使用示例

按键按下之后先输出D/A,然后采集AIN0的ADC值,并通过数码管显示出来。
在这里插入图片描述
在这里插入图片描述
关于上面的函数我前面几节都封装过,请自行查看。

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

阳光倒灌光催化太阳光(太阳能)模拟器

太阳光&#xff08;太阳能&#xff09;模拟器是一种模拟太阳光照射的设备。由于太阳模拟器本身体积较小&#xff0c;测试过程不受环境、气候、时间等因素影响&#xff0c;从而避免了室外测量的各种因素限制&#xff0c;广泛应用于太阳能电池特性测试&#xff0c;光电材料特性测…

数学建模比赛期间,网上的各种思路靠谱吗

美赛第二天&#xff0c;很多人已经撑不住了。 从昨天起网上就那么多“思路”、“指导”、“代做”、“成品论文”&#xff0c;有免费的&#xff0c;也有收钱的。 有人说那些思路都是滥竽充数&#xff0c;纯坑钱浪费时间 有人说自己啥都不会&#xff0c;看那些思路就有启发 有…

一些你可能用到的函数和头文件

对于排序想必大家应该挺熟悉的&#xff0c;如果要是给一连串打乱的整数让你由小到大排序&#xff0c;常见的方法有冒泡排序法和选择排序法等&#xff0c;今天我就给大家介绍一个十分好用的方法&#xff0c;就是使用 sort 函数来进行快排。 sort 函数是位于头文件 #include <…

正点原子--STM32定时器学习笔记(2)

书接上文&#xff0c;本篇是对基本定时器实验部分进行的总结~ 实验目标&#xff1a;通过TIM6基本定时器定时500ms&#xff0c;让LED0每隔500ms闪烁。 解决思路&#xff1a;使用定时器6&#xff0c;实现500ms产生一次定时器更新中断&#xff0c;在中断里执行“翻转LED0”。 定时…

其他发现:开源数据可视化分析工具DataEase介绍文档

一、 简介 DataEase 是开源的数据可视化分析工具&#xff0c;帮助用户快速分析数据并洞察业务趋势&#xff0c;从而实现业务的改进与优化。DataEase 支持丰富的数据源连接&#xff0c;能够通过拖拉拽方式快速制作图表&#xff0c;并可以方便地与他人分享。 二、 优势 1、 开…

MySQL-----DML基础操作

DML语句 DML英文全称是Data Manipulation Language(数据操作语言)&#xff0c;用来对数据库中表的数据记录进行增删改操作。 ▶ 添加数据(INSERT) 【语法】 1. 给指定字段添加数据 INSERTO 表名 (字段名1&#xff0c;字段名2,...) VALUES (值1&#xff0c;值2,...); 2.给全…

npm install一直报错 failed, reason: certificate has expired

刚开始我以为是taobao镜像源的问题&#xff0c;所以我把npm的地址切换成了 https://resgistry.npmjs.org/ &#xff0c;发现还是不行。 问题解决&#xff1a; npm config set strict-ssl false 执行上面命令之后&#xff0c;npm install 成功

如何搭建私有云盘SeaFile并实现远程访问本地文件资料

&#x1f308;个人主页: Aileen_0v0 &#x1f525;热门专栏: 华为鸿蒙系统学习|计算机网络|数据结构与算法 ​&#x1f4ab;个人格言:“没有罗马,那就自己创造罗马~” #mermaid-svg-hsDnDEybLME85dTx {font-family:"trebuchet ms",verdana,arial,sans-serif;font-siz…

有限合伙协议书(模板)上

第一章 合伙的目的和合伙经营范围 第一条 合伙目的&#xff1a;为了适应市场经济的发展&#xff0c;满足市场需求&#xff0c;按照《合伙企业法》规范企业行为&#xff0c;合伙人本着公平、平等、互利的原则&#xff0c;成立 聚源企业管理中心&#xff08;有限合伙&am…

React 面试题

1、组件通信的方式 父组件传子组件&#xff1a;通过props 的方式 子组件传父组件&#xff1a;父组件将自身函数传入&#xff0c;子组件调用该函数&#xff0c;父组件在函数中拿到子组件传递的数据 兄弟组件通信&#xff1a;找到共同的父节点&#xff0c;用父节点转发进行通信 …

三层交换组网实验(思科)

一&#xff0c;技术简介 三层交换技术的出现&#xff0c;解决子网必须依赖路由器进行管理的问题&#xff0c;解决传统路由器低速、复杂所造成的网络瓶颈问题。一个具有三层交换功能的设备可简单理解为&#xff1a;一个带有第三层路由功能的第二层交换机。 二&#xff0c;实验目…

yum命令下载出现Failed to synchronize cache for repo ‘AppStream‘, ignoring this repo.

修改下面的配置文件 问题&#xff1a; cd /etc/yum.repos.d 修改下面四个文件 vim CentOS-Base.repo vim CentOS-AppStream.repo vim CentOS-Extras.repo vim CentOS-PowerTools.repo测试yum是否正常 yum -y install wget

备战蓝桥杯---搜索(DFS基础1)

何为深搜&#xff1f; 即不撞南墙不罢休。 话不多说&#xff0c;直接看题&#xff1a; 我们可以把这看成深搜的模板题&#xff0c;下面是AC代码&#xff1a; #include<bits/stdc.h> using namespace std; int a[15];//存值并输出 int vis[15]; int n18; void dfs(int …

【Git】04 .git目录

文章目录 一、.git目录二、切换分支三、仓库配置信息四、引用五、对象六、总结 一、.git目录 ls -a .git/./ COMMIT_EDITMSG description hooks/ info/ objects/ ../ config HEAD index logs/ refs/二、切换分支 cat .git/HEAD #…

2024年美国大学生数学建模比赛MCM问题B:搜索潜水器-思路解析与代码解答

2024 MCM Problem B Searching for Submersibles 一、题目翻译 背景&#xff1a; 总部位于希腊的小型海上巡航潜艇&#xff08;MCMS&#xff09;公司&#xff0c;制造能够将人类运送到海洋最深处的潜水器。潜水器被移动到该位置&#xff0c;并不受主船的束缚。MCMS现在希望用…

跟着pink老师前端入门教程-day17

2、CSS3 动画 动画&#xff08;animation&#xff09;是CSS3中就要有颠覆性的特征之一&#xff0c;可通过设置多个节点来精确控制一个或一组动画&#xff0c;常用来实现复杂的动画效果 相比较过渡&#xff0c;动画可以实现更多变化&#xff0c;更多控制&#xff0c;连续自动播…

HSRP配置指南

实验大纲 第 1 部分&#xff1a;验证连通性 步骤 1&#xff1a;追踪从 PC-A 到 Web 服务器的路径 步骤 2&#xff1a;追踪从 PC-B 到 Web 服务器的路径 步骤 3&#xff1a;观察当 R3 不可用时&#xff0c;网络的行为 第 2 部分&#xff1a;配置 HSRP 主用和 备用路由器 步…

WebGL+Three.js入门与实战——绘制水平移动的点、通过鼠标控制绘制(点击绘制、移动绘制、模拟画笔)

个人简介 &#x1f440;个人主页&#xff1a; 前端杂货铺 &#x1f64b;‍♂️学习方向&#xff1a; 主攻前端方向&#xff0c;正逐渐往全干发展 &#x1f4c3;个人状态&#xff1a; 研发工程师&#xff0c;现效力于中国工业软件事业 &#x1f680;人生格言&#xff1a; 积跬步…

【微服务】skywalking自定义链路追踪与日志采集

目录 一、前言 二、自定义链路追踪简介 2.1 自定义链路追踪应用场景 2.2 链路追踪几个关键概念 三、skywalking 自定义链路追踪实现 3.1 环境准备 3.2 集成过程 3.2.1 导入核心依赖 3.2.2 几个常用注解 3.2.3 方法集成 3.2.4 上报追踪信息 四、skywalking 自定义日志…

代码随想录 Leetcode491. 非递减子序列

题目&#xff1a; 代码(首刷看解析 2024年2月3日&#xff09;&#xff1a; class Solution { private:vector<vector<int>> res;vector<int> path; public:void backtracking(vector<int>& nums, int startIndex) {if (path.size() > 1) {res.…