该楼层疑似违规已被系统折叠 隐藏此楼查看此楼
为什么case 1 :
pinglv=3;
break;
case 2 :
pinglv=6;
break;
case 3 :
pinglv=9;
break;
case 4 :
pinglv=12;
break;
case 5 :
pinglv=15;
break;
case 6 :
pinglv=18;
break;
case 7 :
pinglv=21;
break;
default :
pinglv=0;
break;这一段可以对应八种相应的频率,这些频率是如何计算出来的求解
周期 T 2T 3T 4T 5T 6T 7T 8T
理论值 798.6 399.3 266.2 199.7 159.7 133.1 114.1 99.8
实际值 798.6 399.6 266.5 199.9 159.9 133.3 114.2 99.9
#include
#define uchar unsigned char
#define uint unsigned int
sbit csda=P2^2; //DAC0832的片选信号,低电平有效
sbit wr=P2^1; //输入寄存器的写选通输入端,负脉冲有效
sbit s1=P3^2; //波形选择中断入口
sbit s2=P3^3; //频率选择中断入口
uchar k=0,p=0,delay=0;
uchar bxxz=0;pinglv=0;
uchar a=1,b=0,c=0,d=0,e=0;
//正弦波数据
uchar code sin[64]={135,145,158,167,176,188,199,209,218,226,234,240,245,249,252,254,254,253,251,247,243,237,230,222,213,204,193,182,170,158,146,133,121,108,96,84,72,61,50,41,32,24,17,11,7,3,1,0,0,2,5,9,14,20,28,36,45,55,66,78,90,102,114,128};
//方波数据
uchar code juxing[64]={255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0};
//锯齿波数据
uchar code juchi[64]={0,4,8,12,16,20,24,28,32,36,40,45,49,53,57,61,65,69,73,77,81,85,89,93,97,101,105,109,113,117,121,125,130,134,138,142,146,150,154,158,162,166,170,174,178,182,186,190,194,198,202,206,210,215,219,223,227,231,235,239,243,247,251,255};
//梯形波数据
uchar code tixing[64]={0,13,26,39,52,65,78,91,104,117,130,143,156,169,182,195,208,221,234,247,247,247,247,247,247,247,247,247,247,247,247,247,247,247,247,247,247,247,247,247,247,247,247,247,247,242,229,216,203,190,177,164,151,138,125,112,99,86,73,60,47,34,21,8};
//三角波数据
uchar code sanjiao[64]={0,8,16,24,32,40,48,56,64,72,80,88,96,104,112,120,128,136,144,152,160,168,176,184,192,200,208,216,224,232,240,248,248,240,232,224,216,208,200,192,184,176,168,160,152,144,136,128,120,112,104,96,88,80,72,64,56,48,40,32,24,16,8,0};
void delay1() //延时程序
{
int a,b;
for(a=1;a>0;a--)
for(b=122;b>0;b--);
}
void int0() interrupt 0 //采用T0中断选择波形
{
EX0=0;
delay1();
if(s1==0){
bxxz++;
if(bxxz==5)
bxxz=0;
switch(bxxz)
{
case 0 : //默认为正弦波
{a=1,b=0,c=0,d=0,e=0;}
break;
case 1 : //选择方波
{a=0,b=1,c=0,d=0,e=0;}
break;
case 2 ://选择锯齿波
{a=0,b=0,c=1,d=0,e=0;}
break;
case 3 ://选择梯形波
{a=0,b=0,c=0,d=1,e=0;}
break;
case 4 : //选择三角波
{a=0,b=0,c=0,d=0,e=1;}
break;
}
delay1();//延时,判断键按S1是否真的被按下
while(!s1);//若真的被按下,为消除按键抖动影响
}
while(!s1);//等待按键松开
EX0=1;
}
void int1() interrupt 2//采用T1中断选择频率
{
EX1=0;
delay1();//延时,判断S2是否真的键被按下
if(s2==0){//若真的被按下,为消除按键抖动影响
p++;
if(p==8)
p=0;//输出波形的每一点设定延时时间长短,以便选择频率
switch(p)
{
case 1 :
pinglv=3;
break;
case 2 :
pinglv=6;
break;
case 3 :
pinglv=9;
break;
case 4 :
pinglv=12;
break;
case 5 :
pinglv=15;
break;
case 6 :
pinglv=18;
break;
case 7 :
pinglv=21;
break;
default :
pinglv=0;
break;
}
delay1();
while(!s2);
}
while(!s2);
EX1=1;
}
void main()//主程序
{//初始化
csda=0;
wr=0;
EA=1;
IT0=1;
EX0=1;
IT1=1;
EX1=1;
while(1)//设定死循环
{
while(a)//默认为正弦波;频率最高
{ delay=pinglv;
P0=sin[k];
k++;
if(k==64)
k=0;
while(delay)
delay--;
}
while(b)//方波
{ delay=pinglv;
P0=juxing[k];
k++;
if(k==64)
k=0;
while(delay)
delay--;
}
while(c)
{ delay=pinglv;
P0=juchi[k];//锯齿波
k++;
if(k==64)
k=0;
while(delay)
delay--;
}
while(d)
{ delay=pinglv;
P0=tixing[k];//梯形波
k++;
if(k==64)
k=0;
while(delay)
delay--;
}
while(e)
{ delay=pinglv;
P0=sanjiao[k];//三角波
k++;
if(k==64)
k=0;
while(delay)
delay--;
}
}
}