标题:
单片机波形发生器(6种)源程序+仿真电路
[打印本页]
作者:
ziyin
时间:
2019-12-20 14:22
标题:
单片机波形发生器(6种)源程序+仿真电路
波形发生器(6种)源程序+仿真电路
51hei.png
(18.11 KB, 下载次数: 61)
下载附件
2019-12-20 14:24 上传
单片机源程序如下:
#include<reg51.h>
#include<absacc.h>
#define uchar unsigned char
#define uint unsigned int
#define DAC0832 XBYTE[0xfffe]
sbit k0=P1^0; //产生方波
sbit k1=P1^1; //产生锯齿波
sbit k2=P1^2; //产生三角波
sbit k3=P1^3; //产生阶梯波
sbit k4=P1^4; //产生正弦波
sbit k5=P1^5;//产生梯形波
uchar mm=0,x=0,y=0;
uchar flag=0;//不同值对应不同波形
uchar code SETTAB[256]={0x80,0x82,0x85,0x88,0x8b,0x8e,0x91,0x94,0x97,0x9a,0x9d,
0xa0,0xa3,0xa6,0xa9,0xac,0xaf,0xb2,0xb6,0xb9,0xbc,0xbf,0xc2,0xc5,0xc7,0xca,0xcc,0xcf,
0xd1,0xd4,0xd6,0xd8,0xda,0xdd,0xdf,0xe1,0xe3,0xe5,0xe7,0xe9,0xea,0xec,
0xee,0xef,0xf1,0xf2,0xf4,0xf5,0xf6,0xf7,0xf8,0xf9,0xfa,0xfb,0xfc,0xfd,
0xfd,0xfe,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,
0xfe,0xfd,0xfd,0xfc,0xfb,0xfa,0xf9,0xf8,0xf7,0xf6,0xf5,0xf4,0xf2,0xf1,
0xef,0xee,0xec,0xea,0xe9,0xe7,0xe5,0xe3,0xe1,0xde,0xdd,0xda,0xd8,0xd6,
0xd4,0xd1,0xcf,0xcc,0xca,0xc7,0xc5,0xc2,0xbf,0xbc,0xba,0xb7,0xb4,0xb1,
0xae,0xab,0xa8,0xa5,0xa2,0x9f,0x9c,0x99,0x96,0x93,0x90,0x8d,0x89,0x86,
0x83,0x80,0x80,0x7c,0x79,0x76,0x72,0x6f,0x6c,0x69,0x66,0x63,0x60,0x5d,
0x5a,0x57,0x55,0x51,0x4e,0x4c,0x48,0x45,0x43,0x40,0x3d,0x3a,0x38,0x35,
0x33,0x30,0x2e,0x2b,0x29,0x27,0x25,0x22,0x20,0x1e,0x1c,0x1a,0x18,0x16,
0x15,0x13,0x11,0x10,0x0e,0x0d,0x0b,0x0a,0x09,0x08,0x07,0x06,0x05,0x04,
0x03,0x02,0x02,0x01,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
0x00,0x00,0x01,0x02,0x02,0x03,0x04,0x05,0x06,0x07,0x08,0x09,0x0a,0x0b,
0x0d,0x0e,0x10,0x11,0x13,0x15,0x16,0x18,0x1a,0x1c,0x1e,0x20,0x22,0x25,
0x27,0x29,0x2b,0x2e,0x30,0x33,0x35,0x38,0x3a,0x3d,0x40,0x43,0x45,0x48,
0x4c,0x4e,0x51,0x55,0x57,0x5a,0x5d,0x60,0x63,0x66,0x69,0x6c,0x6f,0x72,
0x76,0x79,0x7c,0x80};
void delay(uint ms)
{uchar i;
while(ms--)for(i=0;i<120;i++);}
void sin() //正弦波发生函数
{DAC0832=SETTAB[y];
x++;y++;}
void fangbo( ) //方波发生函数
{ DAC0832=y;
x++;
if(flag==0)
{y=0xff;
if(x==128){flag=1;y=0x00;}}//方波+
else {y=0x00;
if(x==0){flag=0;y=0xff;}}}//方波-
void sanjiaobo( ) //三角波发生函数
{ DAC0832=y;
x++;
if(flag==0)
{y+=2;
if(x==128){flag=1;y-=2;}}//三角波+
else {y-=2;
if(x==0){flag=0;y=0;}}}//三角波-
void juchibo() //锯齿波发生函数
{DAC0832=y; y++;}
void jietibo()//阶梯波发生函数
{DAC0832=y;
y+=25;}
void tixing( ) //梯形波发生函数
{uint i;
DAC0832=y;
if(flag==0){y+=2;x++;if(x==128){flag=1;y-=2;}}
else {y-=2;x--;if(x==0){for(i=0;i<5000;i++)y=0x00;flag=0;}}}
void read_key()
{if(k0==0){delay(10);if(k0==0){mm=1;while(k0==0);}}
else if(k1==0){delay(10);if(k1==0){mm=2;while(k1==0);}}
else if(k2==0){delay(10);if(k2==0){mm=3;while(k2==0);}}
else if(k3==0){delay(10);if(k3==0){mm=4;while(k3==0);}}
else if(k4==0){delay(10);if(k4==0){mm=5;while(k4==0);}}
else if(k5==0){delay(10);if(k5==0){mm=6;while(k5==0);}}}
void main()
{TMOD=0x02;
TH0=TL0=156;
TR0=1;ET0=1;EA=1;
mm=0;
for(;;)read_key();}
void timer0() interrupt 1 using 2
{{switch(mm)
{case 1:fangbo();break;
case 2:juchibo();break;
case 3:sanjiaobo();break;
case 4:jietibo();break;
case 5:sin();break;
case 6:tixing();break;}} }
复制代码
所有资料51hei提供下载:
波形发生器(6种).zip
(52.42 KB, 下载次数: 116)
2019-12-20 14:21 上传
点击文件名下载附件
下载积分: 黑币 -5
作者:
保持沉默
时间:
2019-12-25 11:00
不好用,只显示一种错误波形啊,
作者:
113265
时间:
2019-12-25 13:49
刚好需要谢谢啦
作者:
HWL0541
时间:
2019-12-27 12:05
谢谢楼主分享
作者:
pangshe
时间:
2019-12-27 16:48
仿真只有一个波形,有错误。
作者:
埃斯顿林米
时间:
2020-2-25 18:55
感谢楼主分享
作者:
p1364090187
时间:
2020-4-25 04:12
虽然可以参考,但是仿真的只有一个波形,应该是只编写一个波形的么?
欢迎光临 (http://www.51hei.com/bbs/)
Powered by Discuz! X3.1