实际的程序搜索电台的过程简述如下:
1 . 首先送人合适的P L L值进行搜索, 每隔50ms 左右读 取一次TE A5 7 6 7 HN的值。如果RF标志位=1 表示收到电 台,如果RF = O则没有收到,等待5 0 ms 后再次读取。直到 RF=1 。
2 . RF=I 后,再判断BLF是否=1 。BLF =1 说明是搜索 到波段极限而停止的,需要重新设定搜索频率重新搜索。 BLF =0 ,表示没有搜索到波段极限。
3 . BLF = 0 ,再判断STEREO是否等于 1 。STERE O =O 表示 收到的不是立 体声 电台 ,需要在 当前频率值调 整 0.1MHz 后重新搜索,STEREO=1 表示搜索到一个立体声 电台。
4 . STERE O =1 , 需要再判断 I F计数器值是否在31H~ 3EH之间。如果不在31H~3EH之间,则在读出的频率基 础上调整0.1MHz 重新搜索, 如果IF计数器值在31H~3EH 之间,才表示正确的搜索到一个电台。
自动搜索时需要判断的标志位比较多。 STEREO标志和I F计数器值的检验主要是防止收到假台, 因为假台是立体声的比较少。 如果仅用RF和B LF标志, 而 不使用STEREO标志和IF计数器值 , 那么将会搜索到很多 假台。 但是这样一来, 单声道的电台将会被忽略。 好在大多 数FM电台都是立体声的, 因此对实际使用影响比较小。 如 果你所在的地区有单声道发射的电台,请略去检测S T E— RE O标志或者不使用自动搜索而使用手动搜索。
TEA5767采用I2C或者三线接口控制,我是用的I2C,单片机用STC89C52,带1K EEPROM,可以掉电存台,1602LCD显示. TEA5767读写数据都是5个字节,其中PLL参数14位,具体数据格式请看datasheet.以下程序中的函数可以直接在主程序中调用.
#include "iic.c"
#define max_freq 108000
#define min_freq 87500
unsigned char radio_write_data[5]={0x29,0xc2,0x20,0x11,0x00} //要写入TEA5767
的数据
unsigned char radio_read_data[5] //TEA5767读出的状态
unsigned int default_pll=0x29c2//0x29f9 //默认存台的pll,87.8MHz
//unsigned int max_pll=0x339b //108MHz时的pll,
//unsigned int min_pll=9000 //70MHz时的pll
void radio_write(void)
{
unsigned char i
iic_start()
iic_write8bit(0xc0) //TEA5767写地址
if(!iic_testack())
{
for(i=0i<5i++)
{
iic_write8bit(radio_write_data[i])
iic_ack()
}
}
iic_stop()
}
//读TEA5767状态并转换成频率
void radio_read(void)
{
unsigned char i
unsigned char temp_l,temp_h
pll=0
iic_start()
iic_write8bit(0xc1) //TEA5767读地址
if(!iic_testack())
{
for(i=0i<5i++)
{
radio_read_data[i]=iic_read8bit()
iic_ack()
}
}
iic_stop()
temp_l=radio_read_data[1]
temp_h=radio_read_data[0]
temp_h&=0x3f
pll=temp_h*256+temp_l
get_frequency()
}
//由频率计算PLL
void get_pll(void)
{
unsigned char hlsi
unsigned int twpll=0
hlsi=radio_write_data[2]&0x10
if (hlsi)
pll=(unsigned int)((float)((frequency+225)*4)/(float)32.768) //频率单位:k
else
pll=(unsigned int)((float)((frequency-225)*4)/(float)32.768) //率单位:k
}
//由PLL计算频率
void get_frequency(void)
{
unsigned char hlsi
unsigned int npll=0
npll=pll
hlsi=radio_write_data[2]&0x10
if (hlsi)
frequency=(unsigned long)((float)(npll)*(float)8.192-225) //频率单位:KHz
else
frequency=(unsigned long)((float)(npll)*(float)8.192+225) //频率单位:KHz
}
//手动设置频率
,mode=1,+0.1MHz mode=0:-0.1MHz ,不用考虑TEA5767用于搜台的相关位:SM,SUD
void search(bit mode)
{
radio_read()
if(mode)
{
frequency+=100
if(frequency>max_freq)
frequency=min_freq
}
else
{
frequency-=100
if(frequency<min_freq)
frequency=max_freq
}
get_pll()
radio_write_data[0]=pll/256
radio_write_data[1]=pll%256
radio_write_data[2]=0x20
radio_write_data[3]=0x11
radio_write_data[4]=0x00
radio_write()
}
//自动搜台,mode=1,频率增加搜台 mode=0:频率减小搜台,不过这个好像不能循环搜台
void auto_search(bit mode)
{
radio_read()
get_pll()
if(mode)
radio_write_data[2]=0xa0
else
radio_write_data[2]=0x20
radio_write_data[0]=pll/256+0x40
radio_write_data[1]=pll%256
radio_write_data[3]=0x11
radio_write_data[4]=0x00
radio_write()
radio_read()
while(!(radio_read_data[0]&0x80)) //搜台成功标志
{
radio_read()
disp_freq(9,1)
}
}
本篇文章来源于单片机仿真网|www.mcufz.com 原文链接: http://www.mcufz.com/html/danpianjiyingyong/2009/1017/986.html
#include"reg52.h"#include"24c02.h"
#include"lcm.h"
#define max_freq 108000
#define min_freq 87500
unsigned char radio_write_data[5]={0xb1,0xa0,0x20,0x11,0x00} //要写入TEA5767的数据
unsigned char radio_write_data1[5]={0x31,0xa0,0x20,0x11,0x00} //要写入TEA5767的数据
unsigned char radio_read_data[5] //TEA5767读出的状态
unsigned int default_pll=0x29c2//0x29f9 //默认存台的pll,87.8MHz
unsigned int pll=0
float frequency=0
void get_frequency(void)
extern void sta()
extern void wrbyt(unsigned char byt)
extern bit iic_testack()
extern void mack()
extern void stop()
extern unsigned char rdbyt()
extern uchar frq[10]
sbit ds_1302=P1^5
void radio_write(void)
{
unsigned char i
stop()
sta()
wrbyt(0xc0) //TEA5767写地址
if(!iic_testack())
{
for(i=0i<5i++)
{
wrbyt(radio_write_data1[i])
mack()
}
}
stop()
}
//读TEA5767状态,并转换成频率
void radio_read(void)
{
unsigned char i
unsigned char temp_l,temp_h
pll=0
stop()
sta()
wrbyt(0xc1) //TEA5767读地址
if(!iic_testack())
{
for(i=0i<5i++)
{
radio_read_data[i]=rdbyt()
mack()
}
}
stop()
temp_l=radio_read_data[1]
temp_h=radio_read_data[0]
temp_h&=0x3f
pll=temp_h*256+temp_l
get_frequency()
}
//由频率计算PLL
void get_pll(void)
{
unsigned char hlsi
unsigned int twpll=0
hlsi=radio_write_data[2]&0x10
if (hlsi)
pll=(unsigned int)((float)((frequency+225)*4)/(float)32.768) //频率单位:k
else
pll=(unsigned int)((float)((frequency-225)*4)/(float)32.768) //频率单位:k
}
//由PLL计算频率
void get_frequency(void)
{
unsigned char hlsi
unsigned int npll=0
npll=pll
hlsi=radio_write_data[2]&0x10
if (hlsi)
frequency=(unsigned long)((float)(npll)*(float)8.192-225) //频率单位:KHz
else
frequency=(unsigned long)((float)(npll)*(float)8.192+225) //频率单位:KHz
}
//手动设置频率,mode=1,+0.1MHzmode=0:-0.1MHz ,不用考虑TEA5767用于搜台的相关位:SM,SUD
void search(bit mode)
{
radio_read()
if(mode)
{
frequency+=50
if(frequency>max_freq)
frequency=min_freq
}
else
{
frequency-=50
if(frequency<min_freq)
frequency=max_freq
}
EA=0
get_pll()
radio_write_data1[0]=pll/256
radio_write_data1[1]=pll%256
radio_write_data1[2]=0x20
radio_write_data1[3]=0x11
radio_write_data1[4]=0x00
radio_write()
EA=1
}
void set_frq(uchar *frq_m)
{
EA=0
frequency=(float)((*frq_m)*1000+(*(frq_m+1))*100+(*(frq_m+2))*10+(*(frq_m+3)))*100
if((frequency<87500)||(frequency>108500))
{
EA=1
*frq_m=0
*(frq_m+1)=0
*(frq_m+2)=0
*(frq_m+3)=0
return
}
get_pll()
radio_write_data1[0]=pll/256
radio_write_data1[1]=pll%256
radio_write_data1[2]=0x20
radio_write_data1[3]=0x11
radio_write_data1[4]=0x00
radio_write()
EA=1
}
void auto_search(uchar dec)
{
int k=0
unsigned char aa[6]={0}
ds_1302=0
radio_write()
if(dec)
{
while(frequency<max_freq)
{
get_pll()
radio_write_data1[0]=pll/256
radio_write_data1[1]=pll%256
radio_write_data1[2]=0xA0
radio_write_data1[3]=0x11
radio_write_data1[4]=0x00
radio_write_data1[0]|=0x40
radio_write()
for(k=0k<20000k++)
EA=0
radio_read()
if((radio_read_data[0]&0x80))
{
EA=0
frequency+=50
return
}
}
frequency=min_freq
}
else
{
while(frequency>min_freq)
{
get_pll()
radio_write_data1[0]=pll/256
radio_write_data1[1]=pll%256
radio_write_data1[2]=0x20
radio_write_data1[3]=0x11
radio_write_data1[4]=0x00
radio_write_data1[0]|=0x40
radio_write()
for(k=0k<20000k++)
EA=0
radio_read()
if((radio_read_data[0]&0x80))
{
EA=0
frequency-=50
return
}
}
frequency=max_freq
}
}
程序太多,请查收你的邮箱!
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)