利用51单片机配合dac0832设计一个 可以输出100hz——10khz 方波、正弦波、三角波的波形发生器的程序代码
时间: 2024-01-25 21:04:22 浏览: 108
好的,以下是一个简单的程序代码,可以实现输出100hz——10khz方波、正弦波、三角波:
```
#include <reg51.h>
// 定义dac0832引脚
sbit DAC_CS = P2^0; // 片选信号
sbit DAC_CLK = P2^1; // 时钟信号
sbit DAC_DIN = P2^2; // 数据输入信号
// 定义定时器
sbit TIMER0 = P3^4; // 定时器0
// 定义三角函数表
// 采样点数
#define SAMPLE_NUM 256
// 三角函数表
unsigned char SineTable[SAMPLE_NUM] = {
128,131,134,137,140,143,146,149,152,155,158,162,165,168,171,174,
176,179,182,185,188,191,193,196,199,201,204,206,209,211,213,216,
218,220,222,224,226,228,229,231,233,234,236,237,239,240,241,242,
243,244,245,246,247,248,248,249,249,250,250,251,251,251,251,251,
251,251,251,251,250,250,249,249,248,248,247,246,245,244,243,242,
241,240,239,237,236,234,233,231,229,228,226,224,222,220,218,216,
213,211,209,206,204,201,199,196,193,191,188,185,182,179,176,174,
171,168,165,162,158,155,152,149,146,143,140,137,134,131,128,125,
122,119,116,113,110,107,104,101,98,94,91,88,85,82,79,77,
74,71,68,65,62,59,57,54,51,49,46,44,41,39,37,34,
32,30,28,26,24,22,21,19,17,16,14,13,11,10,9,8,
7,6,5,4,3,2,2,1,1,0,0,0,0,0,0,0,
0,0,0,0,1,1,2,2,3,4,5,6,7,8,9,10,
11,13,14,16,17,19,21,22,24,26,28,30,32,34,37,39,
41,44,46,49,51,54,57,59,62,65,68,71,74,77,79,82,
85,88,91,94,98,101,104,107,110,113,116,119,122,125
};
// 定义波形类型
#define WAVE_SQUARE 0 // 方波
#define WAVE_SINE 1 // 正弦波
#define WAVE_TRIANGLE 2 // 三角波
// 定义波形频率范围
#define FREQ_MIN 100 // 最小频率
#define FREQ_MAX 10000 // 最大频率
// 定义全局变量
unsigned int freq = 1000; // 波形频率
unsigned char wave_type = WAVE_SQUARE; // 波形类型
unsigned char wave_index = 0; // 波形表索引
// 延时函数
void Delay(unsigned int ms)
{
unsigned int i, j;
for (i = 0; i < ms; i++)
for (j = 0; j < 114; j++);
}
// dac0832写入函数
void DAC_Write(unsigned int data)
{
unsigned char i;
DAC_CS = 0;
for (i = 0; i < 16; i++) {
DAC_CLK = 0;
if (data & 0x8000)
DAC_DIN = 1;
else
DAC_DIN = 0;
data <<= 1;
DAC_CLK = 1;
}
DAC_CS = 1;
}
// 定时器0中断函数
void Timer0_ISR() interrupt 1
{
// 方波
if (wave_type == WAVE_SQUARE) {
if (wave_index < 128)
DAC_Write(0xFFF); // 高电平
else
DAC_Write(0x000); // 低电平
wave_index++;
if (wave_index >= (256 / (freq / 100))) {
wave_index = 0;
}
}
// 正弦波
else if (wave_type == WAVE_SINE) {
DAC_Write(SineTable[wave_index]); // 输出正弦波
wave_index++;
if (wave_index >= SAMPLE_NUM) {
wave_index = 0;
}
}
// 三角波
else if (wave_type == WAVE_TRIANGLE) {
if (wave_index < 128)
DAC_Write(wave_index << 5); // 0~4095
else
DAC_Write((256 - wave_index) << 5); // 0~4095
wave_index++;
if (wave_index >= (256 / (freq / 100))) {
wave_index = 0;
}
}
}
// 主函数
void main()
{
// 初始化
TMOD |= 0x01; // 定时器0工作在模式1
TH0 = (65536 - (11059200 / 12 / 256 / freq)) / 256; // 设置计数初值
TL0 = (65536 - (11059200 / 12 / 256 / freq)) % 256; // 设置计数初值
EA = 1; // 打开总中断
ET0 = 1; // 打开定时器0中断
TR0 = 1; // 启动定时器0
// 循环执行
while (1) {
// 调整波形频率
if (P1 & 0x01) {
Delay(10); // 延时去抖
if (P1 & 0x01) {
freq += 100;
if (freq > FREQ_MAX)
freq = FREQ_MAX;
TH0 = (65536 - (11059200 / 12 / 256 / freq)) / 256;
TL0 = (65536 - (11059200 / 12 / 256 / freq)) % 256;
}
}
if (P1 & 0x02) {
Delay(10); // 延时去抖
if (P1 & 0x02) {
freq -= 100;
if (freq < FREQ_MIN)
freq = FREQ_MIN;
TH0 = (65536 - (11059200 / 12 / 256 / freq)) / 256;
TL0 = (65536 - (11059200 / 12 / 256 / freq)) % 256;
}
}
// 切换波形类型
if (P1 & 0x04) {
Delay(10); // 延时去抖
if (P1 & 0x04) {
wave_type++;
if (wave_type > WAVE_TRIANGLE)
wave_type = WAVE_SQUARE;
wave_index = 0;
}
}
// 延时等待
Delay(20);
}
}
```
以上代码仅供参考,可能还存在一些问题,如果需要使用该代码,需要根据实际情况进行修改和调试。
阅读全文