代码:
#include <reg52.h>sbit SCLK = P2^0; // sbit:为寄存器的某位取名
sbit CS = P2^1;
sbit DIN = P2^2;sbit key1 = P1^0;
sbit key2 = P1^1;
sbit key3 = P1^2;
sbit key4 = P1^3;unsigned char rect; void delay(unsigned char i) {while(i--);
}// 发送12位数据的函数
void write_12bits(unsigned char dat) {unsigned char i;CS = 0; // 片选最初置0for (i = 0; i < 8; i++) { // 先发送八位数据dat <<= 1; // dat最高位溢出DIN = CY; // 将溢出的高位给DINSCLK = 1; delay(5); // 产生一次SCLK的正脉冲以发送数据SCLK = 0; delay(5); }for (i = 0; i < 4; i++) { // 再发送四个零DIN = 0;SCLK = 1;delay(5);SCLK = 0;delay(5);}CS = 1; // 发送完全部数据后,必须让CS = 1
}void triangle() { // 产生三角波unsigned char i;for (i = 0; i < 255; i++) {write_12bits(i);}for (i = 255; i > 0; i--) {write_12bits(i);}
}void serration1() { // 产生锯齿波1unsigned char i;for (i = 0; i < 255; i++) {write_12bits(i);}
} void serration2() { // 产生锯齿波2unsigned char i;for (i = 255; i > 0; i--) {write_12bits(i);}
}void tixing() { // 产生梯形unsigned char i;for (i = 255; i > 0; i--) {write_12bits(i);}for (i = 0; i < 255; i++) {write_12bits(0);}for (i = 0; i < 255; i++) {write_12bits(i);}for (i = 0; i < 255; i++) {write_12bits(255);}
}void main() {rect = 0x00;TMOD = 0x01; // 利用定时器 T0 的方式一TH0 = 0x3c; // 定时器延时初值TL0 = 0xb0;EA = 1; // 总中断ET0 = 1; // 定时器0的溢出中断 TR0 = 1; // 开启定时器0while (1) {while (!key1) {TR0 = 0; // 关闭定时器triangle();}while (!key2) {TR0 = 0;serration1();}while (!key3) {TR0 = 0;serration2();}while (!key4) {TR0 = 0;tixing();}TR0 = 1; // 开启定时器0}
}void timer0() interrupt 1 { // 产生方波TH0 = 0x3c;TL0 = 0xb0;rect = ~rect;write_12bits(rect);
}
仿真:
介绍:
在单片机测控系统中,非电量如温度、压力、流量、速度等,经传感器先转换成连续变化的模拟电信号(电压或电流),然后再将模拟电信号转换成数字量后才能在单片机中进行处理。实现模拟量转换成数字量的器件称为ADC(A/D转换器)。
单片机处理完毕的数字量,有时根据控制要求需要转换为模拟信号输出。数字量转换成模拟量的器件称为DAC(D/A转换器)。本章从应用的角度,介绍典型的ADC、DAC芯片与AT89S51单片机的硬件接口设计以及接口驱动程序设计。
单片机扩展AD转换
单片机只能输出数字量,但是对于某些控制场合,常常需要输出模拟量,例如直流电动机的转速控制。下面介绍单片机如何扩展DAC。
目前集成化的DAC芯片种类繁多,设计者只需要合理选用芯片,了解它们的性能、引脚外特性以及与单片机的接口设计方法即可。由于现在部分单片机的芯片中集成了DAC,位数一般在10位左右,且转换速度也很快,所以单片的DAC开始向高的位数和高转换速度上转变。而低端的并行8位DAC,开始面临被淘汰的危险,但是在实验室或涉及某些工业控制方面的应用,低端8位DAC以其优异的性价比还是具有较大的应用空间。
1.D/A转换器简介
购买和使用D/A转换器时,要注意有关D/A转换器选择的几个问题。
(1)D/A转换器的输出形式
D/A转换器有两种输出形式:电压输出和电流输出。电流输出的D/A转换器在输出端加一个运算放大器构成的I-V转换电路,即可转换为电压输出。
(2)D/A转换器与单片机的接口形式
单片机与D/A转换器的连接,早期多采用8位的并行传输的接口,现在除了并行接口外,带有串行口的D/A转换器品种也不断增多,目前较为流行多采用SPI串行接口。在选择单片D/A转换器时,要根据系统结构考虑单片机与D/A转换器的接口形式。
2.主要技术指标
D/A转换器的指标很多,设计者最关心的几个指标如下。
(1)分辨率
分辨率指单片机输入给D/A转换器的单位数字量的变化,所引起的模拟量输出的变化,通常定义为输出满刻度值与2n之比(n为D/A转换器的二进制位数),习惯上用输入数字量的位数表示。显然,二进制位数越多,分辨率越高,即D/A转换器输出对输入数字量变化的敏感程度越高。例如,8位的D/A转换器,若满量程输出为10V,根据分辨率定义,则分辨率为10V/2n,分辨率为10V/256 = 39.1mV,即输入的二进制数最低位数字量的变化可引起输出的模拟电压变化39.1mV,该值占满量程的0.391%,常用符号1LSB表示。
同理:
10位D/A转换 1 LSB = 9.77mV = 0.1%满量程
12位D/A转换 1 LSB = 2.44mV = 0.024%满量程
16位D/A转换 1 LSB = 0.076mV = 0.00076%满量程
使用时,应根据对D/A转换器分辨率的需要选定D/A转换器的位数。
(2)建立时间
建立时间是描述D/A转换器转换速度的参数,表明转换时间长短。其值为从输入数字量到输出达到终值误差± (1/2)LSB(最低有效位)时所需的时间。电流输出的转换时间较短,而电压输出的转换器,由于要加上完成I-V转换的时间,因此建立时间要长一些。快速D/A转换器的建立时间可控制在1us以下。
(3)转换精度
理想情况下,转换精度与分辨率基本一致,位数越多精度越高。但由于电源电压、基准电压、电阻、制造工艺等各种因素存在误差。严格地讲,转换精度与分辨率并不完全一致。两个相同位数的不同的DAC,只要位数相同,分辨率则相同,但转换精度会有所不同。例如,某种型号的8位DAC精度为±0.19%,而另一种型号的8位DAC精度为±0.05%
AT89S51扩展10位串行DAC-TLC5615
-
串行DACTLC5615简介
美国TI公司产品,串行接口DAC,电压输出型,最大输出电压是基准电压值两倍。带上电复位功能,即上电时把 DAC 寄存器复位至全零。单片机只需用3 根串行总线就可完成 10 位数据的串行输入,易于和工业标准的微处理器或单片机接口,非常适于电池供电的测试仪表、移动电话,也适用于数字失调与增益调整以及工业控制场合。
- DIN:串行数据输入端;
- SCLK:串行时钟输入端;
- CS:片选端,低电平有效;
- DOUT:用于级联时的串行数据输出端;
- AGND:模拟地;
- REFIN:基准电压输入端,2V~ (VDD - 2);
- OUT:DAC 模拟电压输出端;
- VDD:正电源端,4.5~5.5V ,通常取5V
- TLC5615内部功能框图
- 10 位 DAC 电路;
- 一个 16 位移位寄存器, 接收串行移入的二进制数,且有一个级联的数据输出端DOUT ;
- 并行输入输出的 10 bit DAC 寄存器, 为 10 位 DAC 电路提供待转换的二进制数据;
- 电压跟随器为参考电压端REFIN提供高输入阻抗,大约10MΩ;
- ×2 电路提供最大值为 2 倍于REFIN输出;
- 上电复位电路和控制逻辑电路
两种工作方式:
(1)第1种工作方式:12 位数据序列。从图10-8看出,16 位移位寄存器分为高4位的虚拟位、低2位的填充位以及10位有效数据位。在TLC5615 工作时,只需要向 16 位移位寄存器先后输入10位有效位和低2位的任意填充位。
(2)第2种工作方式:级联方式, 即 16 位数据列,可将本片的DOUT接到下一片的 DIN,需向 16 位移位寄存器先后输入高 4 位虚拟位、10 位有效位和低 2 位填充位,由于增加了高 4 位虚拟位, 所以需要 16 个时钟脉冲 。
当TLC5615片选脚CS为低时, 串行输入数据才能被移入16位移位寄存器。当CS为低时,在每一个 SCLK 时钟的上升沿将 DIN 的一位数据移入 16 位移寄存器。注意, 二进制最高有效位被导前移入。接着, CS的上升沿将16位移位寄存器的10位有效数据锁存于10位 DAC 寄存器,供DAC电路进行转换。