⑴ 五一单片机与数模转换芯片dac 0832的硬件连接如图编写输出锯齿波的程序
可以这样,DAC0832是根据输入的数字量,输出相应的模拟量,锯齿波是有规律的模拟量。
单片机内部程序可以通过算法(规律计算或数组),定时生成一个数字量发送到DAC0832,使其输出相应模拟量,即可。
例如锯齿波是从0~3V,将0~3V分为若干个点(分辨率),定时输出每个点的数字量。
⑵ 用51单片机控制ISD1820语音芯片的原理图及c程序或汇编程序
#include<reg52.h>
code unsigned char seg7code[11]={0x3f,0x06,0x5b,0x4f,0x66,
0x6d,0x7d,0x07,0x7f,0x6f,0x40}; //显示段码
void Delay(unsigned int tc) //显示延时程序
{while( tc != 0 )
{unsigned int i;
for(i=0; i<100; i++);
tc--;}
}
sbit TMDAT =P3^1; //DS18B20的数据输入/输出脚DQ,根据情况设定
unsigned int sdata;//测量到的温度的整数部分
unsigned char xiaoshu1;//小数第一位
unsigned char xiaoshu2;//小数第二位
unsigned char xiaoshu;//两位小数
bitfg=1; //温度正负标志
void dmsec (unsigned int count) //延时部分
{
unsigned char i;
while(count--)
{for(i=0;i<115;i++);}
}
void tmreset (void) //发送复位
{
unsigned char i;
TMDAT=0; for(i=0;i<103;i++);
TMDAT = 1; for(i=0;i<4;i++);
}
bit tmrbit (void) //读一位//
{
unsigned int i;
bit dat;
TMDAT = 0;
i++;
TMDAT = 1;
i++; i++;//微量延时 //
dat = TMDAT;
for(i=0;i<8;i++);
return (dat);
}
unsigned char tmrbyte (void) //读一个字节
{
unsigned char i,j,dat;
dat = 0;
for (i=1;i<=8;i++)
{ j = tmrbit();dat = (j << 7) | (dat >> 1); }
return (dat);
}
void tmwbyte (unsigned char dat) //写一个字节
{
unsigned char j,i;
bit testb;
for (j=1;j<=8;j++)
{ testb = dat & 0x01;
dat = dat >> 1;
if (testb)
{ TMDAT = 0; //写0
i++; i++;
TMDAT = 1;
for(i=0;i<8;i++); }
else
{TMDAT = 0; //写0
for(i=0;i<8;i++);
TMDAT = 1;
i++; i++;}
}
}
void tmstart (void) //发送ds1820 开始转换
{tmreset();//复位
dmsec(1);//延时
tmwbyte(0xcc);//跳过序列号命令
tmwbyte(0x44);//发转换命令 44H,
}
void tmrtemp (void) //读取温度
{
unsigned char a,b;
tmreset ();//复位
dmsec (1);//延时
tmwbyte (0xcc);//跳过序列号命令
tmwbyte (0xbe);//发送读取命令
a = tmrbyte ();//读取低位温度
b = tmrbyte (); //读取高位温度
if(b>0x7f) //最高位为1时温度是负
{a=~a; b=~b+1; //补码转换,取反加一
fg=0; //读取温度为负时fg=0
}
sdata = a/16+b*16; //整数部分
xiaoshu1 = (a&0x0f)*10/16; //小数第一位
xiaoshu2 = (a&0x0f)*100/16%10;//小数第二位
xiaoshu=xiaoshu1*10+xiaoshu2; //小数两位
}
void DS18B20PRO(void)
{tmstart();
//dmsec(5);//如果是不断地读取的话可以不延时 //
tmrtemp();//读取温度,执行完毕温度将存于TMP中 //
}
void Led()
{
if(fg==1) //温度为正时显示的数据
{ P2=P2&0xef;
P0=seg7code[sdata/10]; //输出十位数
Delay(8); P2=P2|0xf0; P2=P2&0xdf;
P0=seg7code[sdata%10]|0x80; //输出个位和小数点
Delay(8); P2=P2|0xf0; P2=P2&0xbf;
P0=seg7code[xiaoshu1]; //输出小数点后第一位
Delay(8); P2=P2|0xf0; P2=P2&0x7f;
P0=seg7code[xiaoshu2]; //输出小数点后第二位
Delay(4); P2=P2|0xf0;
}
if(fg==0)//温度为负时显示的数据
{ P2=P2&0xef;
P0=seg7code[11]; //负号
Delay(8); P2=P2|0xf0; P2=P2&0xdf;
P0=seg7code[sdata/10]|0x80; //输出十位数
Delay(8); P2=P2|0xf0; P2=P2&0xbf;
P0=seg7code[sdata%10]; //输出个位和小数点
Delay(8); P2=P2|0xf0; P2=P2&0x7f;
P0=seg7code[xiaoshu1]; //输出小数点后第一位
Delay(4); P2=P2|0xf0;
}
}
main()
{fg=1;
while(1)
{
DS18B20PRO();
Led();
}
}
⑶ 单片机喇叭dac发声原理
单片机喇叭dac发声原理:
在进行DAC输出扰森的时候,我们颤乎也可同样采用16位宽的DAC进行采样,然后以44kHz的频率将声音信号转化出来,这对于MCU上去操作DAC并非难事,只需要启用一个16位宽的DAC和一个定时器即可,定时器用于控制声茄李悉音输出的频率,如采样率位44.1KHz,则按照该时钟频率输出即可。
⑷ 求用单片机制作简易信号发生器的程序以及电路图
<p>运放选OP07就可以了,由于DAC0832是单电源供电的,只能产握唤生正记性波形,所以利用外部运放来段滑凯实让余现负极性波形的产生</p>
<p></p>
⑸ 51单片机与AD转换程序
#include<reg51.h>
#defineucharunsignedchar
#defineuintunsignedint
sbitwr=P2^6;
sbitrd=P2^7;
sbitadint=P2^5;
delay(uintz)
{
ucharw;
while(z--)
{
for(w=0;w<125;w++);
}
}
ad_star()
{
wr=1;
wr=0;
wr=1;
}
main()
{
uchara;
while(1)
{
ad_star();
while(adint);
rd=0;
a=P0;
delay(10);
rd=1;
if(a>0&a<=20){P3=0xc0;}
if(a>20&a<=40){P3=0xf9;}
if(a>40&a<=60){P3=0xa4;}
if(a>60&a<=80){P3=0xb0;}
if(a>80&a<=100){P3=0x99;}
if(a>100&a<=120){P3=0x92;}
if(a>120&a<=140){P3=0x82;}
if(a>140&a<160){P3=0xf8;}
if(a>160&a<=180){P3=0x80;}
if(a>180&a<=200){P3=0x90;}
if(a>200&a<=220){P3=0x88;}
if(a>220&a<=240){P3=0x83;}
if(a>240&a<=255){P3=0xc6;}
}
}