产品概述

51单片机dac0832 51单片机学习29-DAC0832

小编 2024-11-24 产品概述 23 0

51单片机学习29-DAC0832

仿真图:用的是我自己做的一个51单片机开发板 图纸比较大,截图可能看不清,需要的话可以私信联系我。

DAC0832实现 数字量转换成模拟量

DAC0832工作方式,根据对DAC0832的数据锁存器和DAC寄存器的不同的控制方式,DAC0832有三种工作方式:直通方式、单缓冲方式和双缓冲方式。

1、单缓冲方式。单缓冲方式是控制输入寄存器和DAC寄存器同时接收资料,或者只用输入寄存器而把DAC寄存器接成直通方式。此方式适用只有一路模拟量输出或几路模拟量异步输出的情形。

2、双缓冲方式。双缓冲方式是先使输入寄存器接收资料,再控制输入寄存器的输出资料到DAC寄存器,即分两次锁存输入资料。此方式适用于多个D/A转换同步输出的情节。

3、直通方式。直通方式是资料不经两级锁存器锁存,即 CS*,XFER* ,WR1* ,WR2* 均接地,ILE接高电平。此方式适用于连续反馈控制线路和不带微机的控制系统,不过在使用时,必须通过另加I/O接口与CPU连接,以匹配CPU与D/A转换。

我们这个程序采用的是直通方式

程序:

源代码:

#include<reg52.h>

#define uint unsigned int

#define uchar unsigned char

sbit DACS=P3^2;

sbit DAWR=P3^4;

sbit leden=P1^6;

sbit dzen=P2^0;

void delay_ms(uint z)

{

uint x,

uchar y;

for(x=z;x>0;x--)

for(y=115;y>0;y--);

}

void main()

{

uchar i;

DACS=0; //直通方式

DAWR=0; //直通方式

leden=0; //关闭锁存器

dzen=0; //关闭锁存器

while(1)

{

P0=i;

delay_ms(2);

i++;

}

}

仿真结果:

DA转换器DAC0832的应用

单片机应用技术课程报告

实验名称

D/A转换器DAC0832的应用

实验时间

2020年6月 30 日

学生姓名

实验地点

钉钉群线上

同组人员

专业班级

1、实验目的

(1)了解D/A转换与单片机的接口方法;

(2)了解D/A转换芯片DAC0832的性能及编程方法

(3)掌握D/A转换的程序设计方法。

2、任务设计要求

(1)掌握实验原理,读懂实验线路图,了解所用到的元器件特性。

(2)会绘制电路原理图,会连接电路原理图。

(3)将编制的锯齿波、方波程序运行,用示波器观察波形。

使用STC89C51单片机、DAC0832芯片,设计一个波形发生器,能产生正弦波、方波、三角波、锯齿波,梯形波,要求通过编程实现不同波型的产生,通过按键实现不同波形输出的切换。

3、总体设计方案

硬件电路设计

5、软件程序设计

#include<absacc.h>

#include<reg51.h>

#define DAC0832 XBYTE[0x7fff]

sbit k1=P1^0;

sbit k2=P1^1;

sbit k3=P1^2;

sbit k4=P1^3;

sbit k5=P1^4;

int flag1=0;

int flag2=0;

int flag3=0;

int flag4=0;

int flag5=0;

unsigned char code zhengxian[256]=

{0x80,0x83,0x86,0x89,0x8c,0x8f,0x92,0x95,0x98,0x9c,0x9f,0xa2,0xa5,

0xa8,0xab,0xae,0xb0,0xb3,0xb6,0xb9,0xbc,0xbf,0xc1,0xc4,0xc7,0xc9,

0xcc,0xce,0xd1,0xd3,0xd5,0xd8,0xda,0xdc,0xde,0xe0,0xe2,0xe4,0xe6,

0xe8,0xea,0xec,0xed,0xef,0xf0,0xf2,0xf3,0xf4,0xf6,0xf7,0xf8,0xf9,

0xfa,0xfb,0xfc,0xfc,0xfd,0xfe,0xfe,0xff,0xff,0xff,0xff,0xff,0xff,

0xff,0xff,0xff,0xff,0xff,0xfe,0xfe,0xfd,0xfc,0xfc,0xfb,0xfa,0xf9,

0xf8,0xf7,0xf6,0xf4,0xf3,0xf2,0xf0,0xef,0xed,0xec,0xea,0xe8,0xe6,

0xe4,0xe2,0xe0,0xde,0xdc,0xda,0xd8,0xd6,0xd3,0xd1,0xce,0xcc,0xc9,

0xc7,0xc4,0xc1,0xbf,0xbc,0xb9,0xb6,0xb4,0xb1,0xae,0xab,0xa8,0xa5,

0xa2,0x9f,0x9c,0x99,0x96,0x92,0x8f,0x8c,0x89,0x86,0x83,0x80,0x7d,

0x7a,0x76,0x73,0x70,0x6d,0x6a,0x67,0x64,0x61,0x5e,0x5b,0x58,0x55,

0x52,0x4f,0x4c,0x49,0x46,0x43,0x41,0x3e,0x3b,0x39,0x36,0x33,0x31,

0x2e,0x2c,0x2a,0x27,0x25,0x23,0x21,0x1f,0x1d,0x1b,0x19,0x17,0x15,

0x14,0x12,0x10,0x0f,0x0d,0x0c,0x0b,0x09,0x08,0x07,0x06,0x05,0x04,

0x03,0x03,0x02,0x01,0x01,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,

0x00,0x00,0x00,0x01,0x01,0x02,0x03,0x03,0x04,0x05,0x06,0x07,0x08,

0x09,0x0a,0x0c,0x0d,0x0e,0x10,0x12,0x13,0x15,0x17,0x18,0x1a,0x1c,

0x1e,0x20,0x23,0x25,0x27,0x29,0x2c,0x2e,0x30,0x33,0x35,0x38,0x3b,

0x3d,0x40,0x43,0x46,0x48,0x4b,0x4e,0x51,0x54,0x57,0x5a,0x5d,0x60,

0x63,0x66,0x69,0x6c,0x6f,0x73,0x76,0x79,0x7c};

void delay()//延时程序

{

int i;

for(i=0;i<1000;i++);

}

void panduan (void)//函数panduan用于扫描按键状态判断输出波形

{

if (k1==0){//按键消抖

delay();

if (k1==0)//通过赋值flag选择波形

flag1=1;

flag2=0;

flag3=0;

flag4=0;

flag5=0;}

if(k2==0){

delay();

if (k2==0)

flag1=0;

flag2=1;

flag3=0;

flag4=0;

flag5=0;

}

if (k3==0){

//补充程序

flag1=0;

flag2=0;

flag3=1;

flag4=0;

flag5=0;

}

if (k4==0){

delay();

if (k4==0)

flag1=0;

flag2=0;

flag3=0;

flag4=1;

flag5=0;

}

if (k5==0){

delay();

if(k5==0)

flag1=0;

flag2=0;

flag3=0;

flag4=0;

flag5=1;

}

}

void boxing (void)//函数boxing用于产生选择好的波形

{if (flag1==1)//产生方波

{DAC0832=0x00;

delay();

DAC0832=0xff;

delay();

}

else if (flag2==1)//产生正弦波

{

//补充程序

int i;

for(i=0;i<256;i++)

{

DAC0832=zhengxian[i];

}

}

else if (flag3==1)//三角波

{

//补充程序

int i;

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

DAC0832=i;

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

DAC0832=i;

}

else if (flag4==1)//梯形波

{

//补充程序

int i;

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

DAC0832=0;

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

DAC0832=i;

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

DAC0832=0XFF;

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

DAC0832=i;

}

else if (flag5==1)//锯齿波

{

//补充程序

int i;

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

DAC0832=i;

}

}

void main(){//主函数

P1=0xFF;

while(1)

{panduan();

boxing();

}

}

性能指标测试及结果分析

7、项目总结

D/A转换器的转换精度与D/A转换器的集成芯片的结构和接口电路配置有关。如果不考虑其他D/A转换误差时,D/A的转换精度就是分辨率的大小,因此要获得高精度的D/A转换结果,首先要保证选择有足够分辨率的D/A转换器。同时D/A转换精度还与外接电路的配置有关,当外部电路器件或电源误差较大时,会造成较大的D/A转换误差,当这些误差超过一定程度时,D/A转换就产生错误。

在D/A转换过程中,影响转换精度的主要因素有失调误差、增益误差、非线性误差和微分非线性误差。

通过本实验,熟悉了DAC0832数模转换器的特性和接口方法,掌握D/A输出程序的设计和调试方法。提高了动手能力,加深了对知识的理解。

8、项目设计报告成绩

指导教师签字:

年 月 日

相关问答

【英语翻译本文以89S52为核心,结合 DAC0832 实现程序控制产生...

[回答]89s52thisarticletotherealizationofaprogramcombiningdac0832controlsinusoidalwaves,wavea...

DAC0832 是多大反馈电阻?要将生成的交流电放大,是否需要知道...

[回答]DAC0832内部有一个电阻R,大概10k~15k.所以看你自己要放大大少倍咯!如果两倍,则选择反馈电阻为R就行了.DAC0832内部有一个电阻R,大概10k~15k.所以看...

DAC0832 数字量转换成模拟量的过程 - 182****8607 的回答 - 懂得

这个是DAC0832工作在双缓冲方式下.至于你说的数字量到模拟量的转换过程,这个其实就是DAC0832的工作原理,而且不管是直通方式,还是单缓冲方式还是你...

dac0832 最大输出电压是5V?

最大输出电压10v,同时电源电压要超过输出电压。最大输出电压10v,同时电源电压要超过输出电压。

怎么用汇编语言使 dac0832 产生三角波?

MOVDX,PORTDMOVAL,0FFHRepeat:INCALOUTDX,ALJMPRepeat若改变锯齿波周期,可用NOP或延时指令控制,如下:MOVDX,PORTDMOVAL,0FFHRepe...

dac0832 与cpu有几种连接方式?

DAC0832与CPU有两种主要的连接方式,一种是并行连接,即将DAC0832的多个数据引脚直接连接到CPU的多个数据引脚上,实现数据传输;另一种是串行连接,一般通过SPI...

大神们!救急! DAC0832 +STM32输出正弦波频率最大值是多少?能达到1MHz吗?

一个stm32就完全可能了,如果不需要放大信号记录一个正弦的数组用stm32的dac、pwm输出数组,就是你想要的正弦波。频率可以通过调定时器pwm输出调节一个stm3...

有没有谁给我推荐一下,大兴库房设计价格表,库房设计专不专...

[回答]直流稳压电源是常用的电子设备,它能保证在电网电压波动或负载发生变化时,输出稳定的电压。一个低纹波、高精度的稳压源在仪器仪表、工业控制及测量...

老表们 我想知道:供应 DAC 高速线缆价格?

[回答]首先来弄清楚两个概念:DAC是数模转换器,就是把数字信号转换成模似信号。这个转换出来的模拟信号功率是不够的,还需要功放来放大。功放就是把信号放...

次氯酸钠发生器的主要作用是什么?

低频信号发生器采用单片机波形合成发生器产生高精度,低失真的正弦波电压,可用于校验频率继电器,同步继电器等,也可作为低频变频电源使用。以单片机...

猜你喜欢