DAC0832输出三角波的频率[dac0832输出波形原理] |
您所在的位置:网站首页 › 0832初始化 › DAC0832输出三角波的频率[dac0832输出波形原理] |
编程,利用DAC0832输出连续三角波,要求三角波频率大于50Hz,并用示波器稳定显示.
这是三角波的C语言程序: #include ##include #define DAC0832Addr 0x7ffff //0832地址 #define uchar unsigned char #define uint unsogned int Uart_Init(); //申明输出口初始化子函数 sbit P26=0XA6; sbit P27=0XA7; void TransformData(ucahr c0832data); //转换函数 void delay(); //延时 main() { bit upFlag=1; xdata cdigital=1; Uart_Init(); P0=P1=P2=P3=0xff; delay(); while(1) {transformData(cDigital); //进行数模转换 if((cdigital==255)|(cDigital==0))upFlag=~upFlag;//标志位取反 if(upFlag==1){cDigital++;} else(cDigital--;) delay(); printf("digital is %d \n",cDigital); } } void TransformData(ucahr c0832data) { *((uchar xdata *)DAC0832Addr)=c0832data; } Uart_Init() { SCON=0X52; TMOD=0X21; TCON=0X69; TH1=0XF3; } void delay() { uint i; for(i=0;i200;i++); } 高分求 采用DAC0832芯片,单缓冲方式,产生三角波信号,设端口地址为BFFFH. 1,请画出单片机系统有关逻辑电把P2.7改成P2.6 程序: ORG 0000H LJMP MAIN ORG 0100H MAIN:MOV DPTR,#BFFFH MOV A,#00H UP:MOVX @DPTR,A INC A CJNE A,#200,UP MOVX @DPTR,A DOWN:DEC A MOVX @DPTR,A JNE DOWN INC A SJMP UP END 周期:6*200*1.45 频率=周期的倒数 DAC0832生成三角波的问题回答1:据观察,你生成的是三角波,也就是给0832的值是呈线性增长的,要改变频率,就要改变送给0832值的时间间隔:可以在每次传送给0832值后面加入延时子程序,这只是粗略的改变频率。最好是用定时器, 回答2:LED那个是上拉电阻,保证LED接受电平稳定,改变电阻大小估计是影响放大器的负载,最好不要改动。 回答3:那个二极管接反了,导致它低电平导通,高电平反而不导通。 [img]利用单片机和DAC0832控制输出方形波,锯齿波,三角波,并通过示波器显示 程序如下单片机和DAC0832控制输出方波,锯齿波,三角波,正弦波。 #includeat89x51.h //unsigned char TIME0_H=0xec,TIME0_L=0x78; //定时器0的初值设置;全局变量 #includesinx.h #include0832.h void main() { TMOD=0X01; TH0=0xff; TL0=0xd9; IT0=1; //设置中断触发方式,下降沿 EA=1; EX0=1; ET0=1; IP=0X01; //键盘中断级别高 TR0=1; while(1) { // square(); ; } } ******************************************************************** #ifndef __0832_h__ #define __0832_h__ //#define INPUT XBYTE[0xbfff] //即cs 与xfer 轮流低电平。 //#define DACR XBYTE[0x7fff] //单通道输出,单缓冲就行了。 unsigned char i,sqar_num=128; //最大值100,默认值50 unsigned char cho=0; //0:正弦波。1:方波。2:三角波。3:锯齿波。 unsigned char num=0; unsigned char TIME0_H=0xff,TIME0_L=0xd9; //定时器0的初值设置;全局变量.对应正弦波,锯齿波50HZ sbit chg= P1^0; //三角波100Hz. sbit freq_u=P1^1; sbit freq_d=P1^2; sbit duty_u=P1^3; sbit duty_d=P1^4; sbit cs =P3^7; bit flag=0; unsigned int FREQ=50;//初始化频率,50HZ //调节部分——频率 void freq_ud(void) { unsigned int temp; if(freq_d==0) { FREQ--; } else if(freq_u==0) { FREQ++; } if(cho==1|cho==3) //锯齿波256次中断一周期,特殊处理下。否则他的频率是100(+\-)n*2Hz. { temp=0xffff-3906/FREQ; //方波,三角波默认为100hz,切换后频率也为50HZ 65336-10^6/(256*FREQ) TIME0_H=temp/256; TIME0_L=temp%256; } else if(cho==0|cho==3){ //正弦波 三角波默认周期50hz 65536-10^6//(512*FREQ) temp=0xffff-1953/FREQ; TIME0_H=temp/256; TIME0_L=temp%256; } } //调节部分——方波的占空比 void duty_ud(void) //方波也采用512次中断构成一个周期。 { if(duty_d==0sqar_num0) sqar_num--; else if(duty_u==0sqar_num255) sqar_num++; } //波形发生函数 void sint(void) { if(!flag) { cs=0;P2=sin_num[num++];cs=1; if(num==0){num=255;flag=1;} } else if(flag) { cs=0;P2=sin_num[num--];cs=1; if(num==255){num=0;flag=0;} } } void square(void) { if(i++sqar_num) {cs=0;P2=0XFF;cs=1;} else{cs=0;P2=0X00;cs=1;} } void triangle(void) { cs=0;P2=num++;cs=1; } void stw(void) { if(~flag) { cs=0;P2=num++;cs=1; if(num==0){num=255;flag=1;} } else if(flag) { cs=0;P2=num--;cs=1; if(num==255){num=1;flag=0;} } } //按键中断处理程序。 void it0() interrupt 0 { if(chg==0) { if(++cho==4) {cho=0;num=0;} } //num=0;所有数据从新开始,保证波形的完整性 else if(freq_u==0|freq_d==0) {freq_ud();} else if (cho==1(duty_d==0|duty_u==0)) {duty_ud();} else ; } //定时器中断处理程序。 void intt0() interrupt 1 { //TH0=0x00;TL0=0x00;sinx(); switch(cho) { case 0:{TH0=TIME0_H;TL0=TIME0_L;sint() ;break;} //正弦波//每半周期256取样。 case 1:{TH0=TIME0_H;TL0=TIME0_L;square(); break;} //方波 //为了提高方波的最高频率,只有牺牲占空比的最小可调值。分100份 每次1%。 case 2:{TH0=TIME0_H;TL0=TIME0_L;triangle();break;} //三角波 case 3:{TH0=TIME0_H;TL0=TIME0_L;stw(); break;} //锯齿波 default: ; } } #endif ***************************************** //正弦表;每半个周期256个取值,最大限度保证波形不失真。 //各个值通过MATLAB算出,并四设五如取整。具体程序如下 #ifndef __sinx_h__ #define __sinx_h__ unsigned char code sin_num[]={ 0,0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 2, 2, 2, 2, 3, 3, 4, 4, 4, 5, 5, 6, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 12, 12, 13, 14, 15, 15, 16, 17, 18, 18, 19, 20, 21, 22, 23, 24, 25, 25, 26, 27, 28, 29, 30, 31, 32, 34, 35, 36, 37, 38, 39, 40, 41, 42, 44, 45, 46, 47, 49, 50, 51, 52, 54, 55, 56, 57, 59, 60, 61, 63, 64, 66, 67, 68, 70, 71, 73, 74, 75, 77, 78, 80, 81, 83, 84, 86, 87, 89, 90, 92, 93, 95, 96, 98, 99, 101,102, 104, 106, 107, 109, 110, 112, 113, 115, 116, 118, 120, 121, 123, 124, 126, 128, 129, 131, 132, 134, 135, 137, 139, 140, 142, 143, 145, 146, 148, 149, 151, 153, 154, 156, 157, 159, 160, 162, 163, 165, 166, 168, 169, 171, 172, 174, 175, 177, 178, 180, 181, 182, 184, 185, 187, 188, 189, 191, 192, 194, 195, 196, 198, 199, 200, 201, 203, 204, 205, 206, 208, 209, 210, 211, 213, 214, 215, 216, 217, 218, 219, 220, 221, 223, 224, 225, 226, 227, 228, 229, 230, 230, 231, 232, 233, 234, 235, 236, 237, 237, 238, 239, 240, 240, 241, 242, 243, 243, 244, 245, 245, 246, 246, 247, 247, 248, 248, 249, 249, 250, 250, 251, 251, 251, 252, 252, 253, 253, 253, 253, 254, 254, 254, 254, 254, 255, 255, 255, 255, 255, 255, 255, 255, 255 }; #endif //MATLAB程序: //x=linspace(-pi/2,pi/2,255);%如果过采用1位采用,很多值是重的。虽然实际中并不会。 //y=(sin(x)+1)/2.0*255; //%uint32(y)%强制类型转换。 //%fprintf('%.f\n',uint32(y));%控制输出类型 //round(y)%四舍五入函数 用8051单片机和DAC0832制作信号发生器这要费些时间的,不会有人专门给写的,除非有人正好做过。我现在发一个类似的,是别人的,正好被我看到了,你可以参考一下。 ORG 0000H LJMP MAIN ORG 0100H MAIN: JNB P1.0,P10 JNB P1.1,P11 JNB P1.2,P12 JNB P1.3,P13 LJMP MAIN P10: MOV R7,#00H LCALL SQU LJMP MAIN P11: MOV R7,#01H LCALL SAW LJMP MAIN P12: MOV R7,#02H LCALL TRI LJMP MAIN P13: MOV R7,#03H LCALL SIN LJMP MAIN SQU: JNB P1.1,N1 JNB P1.2,N2 JNB P1.3,N3 LJMP SSQU N1: MOV R7,#01H LJMP TC0 N2: MOV R7,#02H LJMP TC0 N3: MOV R7,#03H LJMP TC0 SSQU: CJNE R7,#00H,TC0 MOV R0,#00H MOV DPTR,#7FFFH K00: MOV A,#0FFH MOVX @DPTR,A MOV P0,#0FFH MOV P2,#0FFH MOV A,P2 CPL A MOV R3,A L00: DEC R3 CJNE R3,#255,L00 INC R0 INC R0 CJNE R0,#254,K00 MOV R0,#00H K01: MOV A,#00H MOVX @DPTR,A MOV P0,#00H MOV P2,#0FFH MOV A,P2 CPL A MOV R3,A L01: DEC R3 CJNE R3,#255,L01 INC R0 INC R0 CJNE R0,#254,K01 LJMP SQU TC0: RET SAW: JNB P1.0,N4 JNB P1.2,N5 JNB P1.3,N6 LJMP SSAW N4: MOV R7,#00H LJMP TC1 N5: MOV R7,#02H LJMP TC1 N6: MOV R7,#03H LJMP TC1 SSAW: CJNE R7,#01H,TC1 MOV R0,#0FFH MOV DPTR,#7FFFH K10: MOV A,R0 MOVX @DPTR,A MOV P0,R0 MOV P2,#0FFH MOV A,P2 CPL A MOV R3,A L10: DEC R3 CJNE R3,#255,L10 INC R0 CJNE R0,#255,K10 LJMP SAW TC1: RET TRI: JNB P1.0,N7 JNB P1.1,N8 JNB P1.3,N9 LJMP TTRI N7: MOV R7,#00H LJMP TC2 N8: MOV R7,#01H LJMP TC2 N9: MOV R7,#03H LJMP TC2 TTRI: CJNE R7,#02H,TC2 MOV R0,#00H MOV DPTR,#7FFFH K20: MOV A,R0 MOVX @DPTR,A MOV P0,R0 MOV P2,#0FFH MOV A,P2 CPL A MOV R3,A L20: DEC R3 CJNE R3,#255,L20 INC R0 INC R0 CJNE R0,#254,K20 K21: MOV A,R0 MOVX @DPTR,A MOV P0,R0 MOV P2,#0FFH MOV A,P2 CPL A MOV R3,A L21: DEC R3 CJNE R3,#255,L21 DEC R0 DEC R0 CJNE R0,#0,K21 LJMP TRI TC2: RET SIN: JNB P1.0,N10 JNB P1.1,N11 JNB P1.2,N12 LJMP SSIN N10: MOV R7,#00H LJMP TC3 N11: MOV R7,#01H LJMP TC3 N12: MOV R7,#02H LJMP TC3 SSIN: CJNE R7,#03H,TC3 MOV R0,#00H MOV DPTR,#7FFFH K30: MOV A,R0 MOV DPTR,#TAB MOVC A,@A+DPTR MOV DPTR,#7FFFH MOVX @DPTR,A MOV P0,A INC R0 MOV P2,#0FFH MOV A,P2 CPL A MOV R3,A L30: DEC R3 CJNE R3,#255,L30 CJNE R0,#255,K30 LJMP SIN TC3: RET TAB: DB 关于DAC0832输出三角波的频率和dac0832输出波形原理的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站。 |
今日新闻 |
推荐新闻 |
CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3 |