DAC0832输出三角波的频率[dac0832输出波形原理]

您所在的位置:网站首页 0832初始化 DAC0832输出三角波的频率[dac0832输出波形原理]

DAC0832输出三角波的频率[dac0832输出波形原理]

#DAC0832输出三角波的频率[dac0832输出波形原理]| 来源: 网络整理| 查看: 265

编程,利用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