基于51单片机的模拟量输入输出通道实验

实验一 模拟量输入输出通道实验(C51

一、实验目的:

1、了解A/D、D/A转换的基本原理。

2、了解A/D转换芯片ADC0809、D/A转换芯片DAC0832的性能及编程方法。

3、掌握过程通道中A/D转换与D/A转换与计算机的接口方法。

4、了解计算机如何进行数据采集及输出控制。

二、实验设备

计算机 1台;

缔造者系统 1套:CPU挂箱、8031CPU模块;

万用表 1块;

示波器 1台。

三、实验内容

一)、A/D转换实验

利用实验台上的ADC0809做A/D转换器,实验箱上的电位器提供模拟电压信号输入,编制程序,将模拟量转换成数字量,用数码管显示模拟量转换的结果。

1、实验电路:如图1

图1

2、实验接线:

1)0809的片选信号CS0809接CS0。

2)电位器的输出信号AN0接0809的ADIN1。

3、实验程序

   #include <reg51.h>

#include <absacc.h>

#define INT8U unsigned char

#define INT16U unsigned int

#define Val DBYTE[0x35]

#define RAM8279  XBYTE[0X0CFE9]

#define DATA8279 XBYTE[0X0CFE8]

#define ADC0809  XBYTE[0X0CFA0]

INT8U code SEG_CODE[]={0x3f,0x06,0x5B,0x4F,0x66,0x6D,0x7D,0x07,0x7F,0x6F};

  void delay1_ms(INT8U x)

  {   INT8U t;while(x--) for(t=0;t<120;t++);  }

void main()

{

INT8U ADvalue,AD1,AD2,AD3;

while(1)

   {ADC0809=1;      //start AD

   delay1_ms(10);   //delay

   ADvalue=ADC0809;

   Val=ADvalue;

   AD1=ADvalue/100;   //baiwei

   AD2=ADvalue%100/10; //shi wei

   AD3=ADvalue%10;      //ge wei

   RAM8279=0x90;

   DATA8279=SEG_CODE[AD1];

   delay1_ms(10);

   DATA8279=SEG_CODE[AD2];

   delay1_ms(10);

   DATA8279=SEG_CODE[AD3];

   delay1_ms(10);    

  }

}

4、实验步骤

1)从系统“开始”菜单进入“所有程序”,在“所有程序”中选择“Windows Virtual PC”,点击“Windows XP Mode”进入虚拟机系统。

2)根据接线图接线,并运行EL型(8051)教学实验环境,建立上位计算机与缔造者系统的通信连接。(串口选择COM2;波特率选择9600;点击屏幕中对话框确定后立刻按下设备上的复位键RST,若设备上的数码管显示C则表示通信成功。)

3)新建一个汇编文件(点击工具栏上的字母A,若程序用单片机C语言编写,则点击工具栏上的字母C),输入C51源程序,编译成功后,选择调试-运行。

4)用万用表测量电位器电压,依次调节电位器旋钮,并使数码管从一个较小的数开始变化。记录表格1。

表1 A/D转换实验数据表

序号

电位器电压(V)

理论计算的AD转换结果数字量(十进制)

数码管显示值(十进制)

理论计算与实际显示值相对误差

1

0.29

14

14

0

2

0.68

32

32

0

3

0.86

43

42

1

4

1.76

89

88

1

5

2.40

120

118

2

6

2.81

143

140

3

7

3.30

168

167

1

8

4.03

206

202

4

9

4.21

215

210

5

10

4.49

229

224

5

二)、D/A转换实验

利用DAC0832,编制程序产生波形信号。

  1. 循环产生锯齿波、三角波各10周期;
  2. 波形的VP-P峰峰值为4V。
  3. 要求DAC0832工作方式为单缓冲方式。

1、实验电路:如图2

图2

2、实验接线

DAC0832的片选CS0832接CS1,输出端OUT接示波器探头信号表笔,接地端GND接示波器地线夹子。DS2.3脚用跳线冒短接(单缓冲方式). DS1.2脚用跳线冒短接(双缓冲方式)。

3、实验程序

1)产生锯齿波程序:

#include <reg51.h>

#include <absacc.h>

#define INT8U unsigned char

#define INT16U unsigned int

#define DAC0832 XBYTE[0X0CFA8]

  void delay_ms(INT8U x)

  {   INT8U t;while(x--) for(t=0;t<1;t++);  }

void main()

{INT8U i;

  while(1)

   {

   for(i=0;i<255;i++)  //

   {DAC0832=i;

delay_ms(1);

}

   }

}   

2)产生三角波程序:

#include <reg51.h>

#include <absacc.h>

#define INT8U unsigned char

#define INT16U unsigned int

#define DAC0832 XBYTE[0X0CFA8]

  void delay_ms(INT8U x)

  {   INT8U t;while(x--) for(t=0;t<1;t++);  }

void main()

{INT8U i;

  while(1)

   {

   for(i=0;i<255;i++) //zheng ban zhou

   {DAC0832=i;

   delay_ms(1);

}

 for(i=255;i>0;i--)  //fu ban zhou

   {DAC0832=i;

   delay_ms(1);

}

 }

}  

4、实验步骤

1)从系统“开始”菜单进入“所有程序”,在“所有程序”中选择“Windows Virtual PC”,点击“Windows XP Mode”进入虚拟机系统。

2)根据接线图接线,并运行EL型(8051)教学实验环境,建立上位计算机与缔造者系统的通信连接。(串口选择COM2;波特率选择9600;点击屏幕中对话框确定后立刻按下设备上的复位键RST,若设备上的数码管显示C则表示通信成功。)3)输入产生锯齿波、三角波的C51源程序,编译连接成功后运行。

4)记录示波器显示的波形曲线,读数,填入表2。

 

表2波形产生实验数据表

锯齿波

周期(ms)\频率(Hz)

43.55Hz

峰峰值Vp-p(V)

536.0mV

三角波

周期(ms)\频率(Hz)

21.74Hz

峰峰值Vp-p(V)

512.0mV

三)、A/D转换结果控制D/A输出信号频率实验

内容及要求:

1)利用实验台上的ADC0809做A/D转换器,实验箱上的电位器提供模拟电压信号输入,编制程序,将模拟量转换成数字量,用数码管显示模拟量转换的结果(十进制)。

2)利用DAC0832,编制程序产生频率受A/D转换结果控制的波形。波形为由锯齿波、三角波各20个周期构成的循环波形。

3)当调节实验箱上的电位器,A/D显示的结果相应发生变化,D/A产生的锯齿波和三角波频率也随之改变。

4)要求单片机判断处理AD转换结束信号采用查询方式。DAC0832工作方式为双缓冲方式。

1、实验电路:如图1及图2

2、实验接线

1)0809的片选信号CS0809接CS0。

  1. 电位器的输出信号AN0接0809的ADIN0。

3)EOC接P3.2/INT0。

4)DAC0832的片选CS0832接CS1,输出端DAOUT接示波器探头信号表笔,接地端GND接示波器地线夹子。双缓冲工作方式(DS1.2脚用跳线冒短接)

(为保证在显示A/D转换结果时D/A输出波形不变,DAC0832要处于双缓冲工作方式,以保证在写数据到8279的寄存器时,DAC0832数据锁存,不受数据总线上数据的变化而发生变化。)

3、实验程序

1)频率受控锯齿波程序:

#include <reg51.h>

#include <absacc.h>

#define INT8U unsigned char

#define INT16U unsigned int

#define Val DBYTE[0x35]

#define RAM8279  XBYTE[0X0CFE9]

#define DATA8279 XBYTE[0X0CFE8]

#define ADC0809  XBYTE[0X0CFA0]

#define DAC08321  XBYTE[0X0CFA8]

#define DAC08322  XBYTE[0X0CFA9]

INT8U SEG_CODE[]={0x3f,0x06,0x5B,0x4F,0x66,0x6D,0x7D,0x07,0x7F,0x6F};

sbit EOC=P3^2;

 void delay_ms(INT8U x)

  {INT8U t;

   while(x--)

       for(t=0;t<1;t++);

     }

     

INT8U ADvalue=0,AD1=0,AD2=0,AD3=0,i;  

 main()

{

RAM8279=0x90;

DATA8279=SEG_CODE[AD1];

delay_ms(1);

DATA8279=SEG_CODE[AD2];

delay_ms(1);

DATA8279=SEG_CODE[AD3];

delay_ms(1);

while(1)

   {

ADC0809=1;  //start AD

while(!EOC);  //wait ADC finish

Val=ADC0809;  //read AD result

   AD1=Val/100;   //high

   AD2=Val%100/10; //middle

   AD3=Val%10;      //low

    DAC08321=Val;    //D/A start

    DAC08322=Val;    //D/A start

    RAM8279=0x90;   //display

    DATA8279=SEG_CODE[AD1];

    delay_ms(1);

    DATA8279=SEG_CODE[AD2];

    delay_ms(1);

    DATA8279=SEG_CODE[AD3];

    delay_ms(1);

    for(i=Val;i<255;i++)   //generate wave

{

DAC08321=i;

DAC08322=i;

delay_ms(1);

}

}

}

2)频率受控三角波程序:

#include <reg51.h>

#include <absacc.h>

#define INT8U unsigned char

#define INT16U unsigned int

#define Val DBYTE[0x35]

#define RAM8279  XBYTE[0X0CFE9]  //control register

#define DATA8279 XBYTE[0X0CFE8]  //data register

#define ADC0809  XBYTE[0X0CFA0]  //ADC address

#define DAC08321  XBYTE[0X0CFA8]  //first register address

#define DAC08322  XBYTE[0X0CFA9]  //second register address

INT8U SEG_CODE[]={0x3f,0x06,0x5B,0x4F,0x66,0x6D,0x7D,0x07,0x7F,0x6F}; //common cathode

sbit EOC=P3^2;

 void delay_ms(INT8U x)

  {   INT8U t;while(x--) for(t=0;t<1;t++);  }

INT8U ADvalue=0,AD1=0,AD2=0,AD3=0,i;  

 main()

{

RAM8279=0x90;

DATA8279=SEG_CODE[AD1];

delay_ms(1);

DATA8279=SEG_CODE[AD2];

delay_ms(1);

DATA8279=SEG_CODE[AD3];

delay_ms(1);

while(1)

   {

ADC0809=1;  //start AD

while(!EOC);  //wait ADC finish

Val=ADC0809;  //read AD result

   AD1=Val/100;   //high

   AD2=Val%100/10; //middle

   AD3=Val%10;      //low

    DAC08321=Val;    //D/A start

    DAC08322=Val;    //D/A start

    RAM8279=0x90;   //display

    DATA8279=SEG_CODE[AD1];

    delay_ms(1);

    DATA8279=SEG_CODE[AD2];

    delay_ms(1);

    DATA8279=SEG_CODE[AD3];

    delay_ms(1);

    for(i=Val;i<255;i++)   //generate wave

{

DAC08321=i;

DAC08322=i;

delay_ms(10);

}

for(i=255;i>Val;i--)

{

DAC08321=i;

DAC08322=i;

delay_ms(1);

}

}

}

4、实验步骤

1)从系统“开始”菜单进入“所有程序”,在“所有程序”中选择“Windows Virtual PC”,点击“Windows XP Mode”进入虚拟机系统。

2)根据接线图接线,并运行EL型(8051)教学实验环境,建立上位计算机与缔造者系统的通信连接。(串口选择COM2;波特率选择9600;点击屏幕中对话框确定后立刻按下设备上的复位键RST,若设备上的数码管显示C则表示通信成功。)3)输入频率受控波形生成的C51源程序,编译连接成功后运行。

4)依次调节电位器旋钮,并使数码管显示为一个较小的值开始。记录数码管显示值,及相应示波器显示的波形曲线,计算锯齿波和三角波曲线的Vp-p电压及显示波形的周期和频率并填入表3。

表3 频率受控波形实验数据表

序号

数码管显示值

锯齿波的Vp-p(V)

锯齿波频率值(Hz)

三角波的Vp-p(V)

三角波频率值(Hz)

1

0

4.96

39.97

5.04

19.34

2

50

4.00

49.75

4.08

24.13

3

100

3.04

65.79

3.12

31.87

4

150

2.24

86.84

2.08

47.01

5

200

1.28

105.34

1.12

58.60

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

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

相关文章

VSCode 正则表达式 匹配多行

VS Code 正则表达式匹配多行 (.|\n)*? //test.js const test {str: VS Code 正则表达式匹配多行VS Code 正则表达式匹配多行VS Code 正则表达式匹配多行VS Code 正则表达式匹配多行VS Code 正则表达式匹配多行VS Code 正则表达式匹配多行VS Code 正则表达式匹配多行VS Code …

数据库作业二

一&#xff0c;单表查询 1.创建表 1、显示所有职工的基本信息。 2、查询所有职工所属部门的部门号&#xff0c;不显示重复的部门号。 3、求出所有职工的人数。 4、列出最高工和最低工资。 5、列出职工的平均工资和总工资。 6、创建一个只有职工号、姓名和参加工作的…

【WPF.NET开发】WPF中的版式

本文内容 改进的文本质量和性能丰富的版式增强的国际文本支持增强的字体支持新的文本应用程序编程接口 (API) 本主题介绍 WPF 的主要版式功能。 这些功能包括改进的文本呈现质量和性能、OpenType 版式支持、增强的国际文本、增强的字体支持和新的文本应用程序编程接口 (API)。…

2024多系统萎缩最新全球特效药治疗进展

多系统萎缩是一种罕见的神经退行性疾病&#xff0c;由于缺乏有效的治疗方法&#xff0c;患者经常面临症状无法缓解和生活品质下降的困扰。然而&#xff0c;近期刘家峰大夫基于中医理论研究和临床实践&#xff0c;采用中药治疗多系统萎缩取得了显著疗效&#xff0c;给患者带来了…

VUE好看的个人简历模板

文章目录 1.设计来源1.1 首页界面1.2 关于我界面1.3 我的资历界面1.4 项目经验界面1.5 我的技能界面1.6 联系我界面 2.效果和源码2.1 动态效果2.2 源码目录结构 源码下载 作者&#xff1a;xcLeigh 文章地址&#xff1a;https://blog.csdn.net/weixin_43151418/article/details/…

RMI简介

RMI 介绍 RMI (Remote Method Invocation) 模型是一种分布式对象应用&#xff0c;使用 RMI 技术可以使一个 JVM 中的对象&#xff0c;调用另一个 JVM 中的对象方法并获取调用结果。这里的另一个 JVM 可以在同一台计算机也可以是远程计算机。因此&#xff0c;RMI 意味着需要一个…

线程安全2

文章目录 锁的可重入性死锁内存可见性引起的线程安全 锁的可重入性 直观来看这个代码不能运行 为啥没有出现阻塞&#xff1f; 当前由于是同一个线程&#xff0c;此时的锁对象&#xff0c;就知道了第二次加锁的线程&#xff0c;就是持有锁的线程&#xff0c;第二次操作&#xff…

Linux下如何快速调试I2C设备

Linux下如何快速调试I2C设备 目录 1 什么场景下需要快速调试I2C设备 2 如何快速调试I2C设备 3 如何获取I2C Tools工具集 3.1 获取I2C Tools工具集源码 3.2 编译I2C Tools工具集源码 3.3 为设备添加I2C Tools工具集 4 如何使用I2C Tools工具集 5 小结 1 什么场景下需要快…

VScode设置自动添加自定义注释及修改字体

首先安装snippet mac可以键入commanp&#xff0c;输出> 选择自己所需的需要自动添加的文件类型配置文件 安装自己的需要修改 "Print to console": {"prefix": "xx", // 自己键入内容"body": [ // 注释信息"// xxx …

SpringMVC RESTful案例

文章目录 1、准备工作2、功能清单3、具体功能&#xff1a;访问首页a>配置view-controllerb>创建页面 4、具体功能&#xff1a;查询所有员工数据a>控制器方法b>创建employee_list.html 5、具体功能&#xff1a;删除a>创建处理delete请求方式的表单b>删除超链接…

docker部署私人云盘nextcloud

首先查看效果 1.拉取镜像 docker pull nextcloud 2.创建目录 mkdir -p /data/nextcloud/{config,data,apps} 3.创建实例 docker run -itd --name yznextcloud -v /data/nextcloud/config:/var/www/html/config -v /data/nextcloud/data:/var/www/html/data -v /data/nextc…

Minikube安装

文章目录 简介安装仪表盘 简介 Minikube是一个轻量级的工具&#xff0c;用于在本地机器上运行K8s集群。它允许开发人员在没有云环境的情况下进行K8s应用程序的开发和测试。 和k8s需要一个主机两个从机不同&#xff0c;Minikube用kubectl来控制节点&#xff0c;相当于在虚拟机…

如何制作网址链接活码?网址二维码生成器的使用方法

将网址转二维码图片来使用&#xff0c;是现在很常用的一种二维码类型&#xff0c;一般网址可以根据自己的用途来制作静态码或者活码两种形式。其中静态码只是单纯将网址链接转换成二维码&#xff0c;无法统计与修改&#xff0c;而生成网址活码可以在二维码图片不变情况下替换其…

基于RNN的模型

文本数据是一种典型的具有序列结构的数据&#xff0c;因为文本通常是由一系列的词语或字符组成的序列。每个词语或字符在文本中都有特定的位置和顺序&#xff0c;这种有序的结构对于理解和处理文本的含义至关重要。因此&#xff0c;多数情况下需要使用时间序列建模来完成相应的…

按键精灵调用奥迦插件实现图色字识别模拟键鼠操作源码

奥迦插件于2019年9月开始开发,在Windows 10操作系统上使用Visual Studio 2019编写,适用于所有较新的Windows平台,是一款集网络验证,深度学习,内核,视觉,文字,图色,后台,键鼠,窗口,内存,汇编,进程,文件,网络,系统,算法及其它功能于一身的综合插件 插件使用C语言和COM技术编写,是…

C#编程-属性和反射

属性和反射 属性是将元数据信息和行为添加到应用程序代码中的简单技术。属性是允许您将声明信息添加到程序的元素。此声明信息在运行时用途广泛,可使用应用程序开发工具在设计时使用。 介绍属性 对象是由其属性值描述的。例如,汽车可以使用它的构造、型号或颜色来描述。类似…

解决方案类常用网址

1.操作系统类&#xff08;原版操作系统下载网址&#xff09; https://next.itellyou.cn/ 之前的版本 https://msdn.itellyou.cn/ 2.ppt免费网站&#xff08;不用注册&#xff09; https://www.1ppt.com/

将 RGB 转换为十六进制、生成随机十六进制

RGB与十六进制 RGB&#xff08;Red, Green, Blue&#xff09;和十六进制是两种常用的颜色表示方式。 RGB是一种加法混色模式&#xff0c;它通过调节红、绿、蓝三个颜色通道的亮度来混合出各种颜色。对于每个颜色通道&#xff0c;取值范围是0到255&#xff0c;0表示该通道对应…

高并发IO底层原理-备份

1 概述 IO底层原理是隐藏在Java编程知识之下的基础知识&#xff0c;是开发人员必须掌握的基本原理。本文从操作系统的底层原理入手&#xff0c;通过图文的方式为大家深入剖析高并发IO的底层原理&#xff0c;并介绍如何通过设置来让操作系统支持高并发。 2 IO读写的基本原理 为…