DAC0832是8分辨率的D/A转换集成芯片。与微处理器完全兼容。这个DA芯片以其价格低廉、接口简单、转换控制容易等优点,在单片机应用系统中得到广泛的应用。D/A转换器由8位输入锁存器、8位DAC寄存器、8位D/A转换电路及转换控制电路构成。
dac0832结构
* D0~D7:8位数据输入线,TTL电平,有效时间应大于90ns(否则锁存器的数据会出错);
* ILE:数据锁存允许控制信号输入线,高电平有效;
* CS:片选信号输入线(选通数据锁存器),低电平有效;
* WR1:数据锁存器写选通输入线,负脉冲(脉宽应大于500ns)有效。由ILE、CS、WR1的逻辑组合产生LE1,当LE1为高电平时,数据锁存器状态随输入数据线变换,LE1的负跳变时将输入数据锁存;
* XFER:数据传输控制信号输入线,低电平有效,负脉冲(脉宽应大于500ns)有效;
* WR2:DAC寄存器选通输入线,负脉冲(脉宽应大于500ns)有效。由WR2、XFER的逻辑组合产生LE2,当LE2为高电平时,DAC寄存器的输出随寄存器的输入而变化,LE2的负跳变时将数据锁存器的内容打入DAC寄存器并开始D/A转换。
* IOUT1:电流输出端1,其值随DAC寄存器的内容线性变化;
* IOUT2:电流输出端2,其值与IOUT1值之和为一常数;
* Rfb:反馈信号输入线,改变Rfb端外接电阻值可调整转换满量程精度;
* Vcc:电源输入端,Vcc的范围为+5V~+15V;
* VREF:基准电压输入线,VREF的范围为-10V~+10V;
* AGND:模拟信号地;
* DGND:数字信号地。
dac0832程序流程图
dac0832程序
#include
typedef unsigned char uchar;
#define DAC P1
/* 延时函数 */
void delay(uchar t)
{
while(t--);
}
/* 锯齿波发生函数 */
void saw(void)
{
uchar i;
for (i=0;i《255;i++)
{
DAC=i;
}
}
/* 方波发生函数 */
void square(void)
{
DAC=0x00;
delay(0x80);
DAC=0xff;
delay(0x80);
}
//SIN b波
void sin(void)
{
uchar i,j;
}
void main(void)
{
uchar i,j;
i=j=0xff;
//while(i--)
//{
//saw(); /* 产生一段锯齿波 */
//}
while(j--)
{
square(); /* 产生一段方波 */
}
}