TEA5767在电路中是如何达到使收音机有自动搜台效果的

TEA5767在电路中是如何达到使收音机有自动搜台效果的,第1张

进行 自动搜索时, 使用的是TE A5 7 6 7 HN的搜索功能。需要注意的是 S S L设定的值将影响搜索到的电台数量。只 有接收到的电台RF信号ADC值大于设定的S S L值时,才 会停止搜索。SSL设定值大, 则弱信号电台有可能无法搜索 到, 使得搜索到的电台数量偏少;S S L 设定值小, 有可能电 台的镜像频率 ( 假台)也会接收到,因此,要选取合适的SSL值以得到期望的搜台效果。

实际的程序搜索电台的过程简述如下:

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

}

}

程序太多,请查收你的邮箱!


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/yw/7795951.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-10
下一篇 2023-04-10

发表评论

登录后才能评论

评论列表(0条)

保存