Skip to main content

FM stereo radio receiver with RDS

This tuner circuit is a quick prototype which I build to test the RDA5807M FM radio tuner IC. RDA5807M is a single-chip tuner IC with RDS and MPX decoder, and it equipped with I2C interface for control. The main reason to build this prototype is to understand the behavior of this chip.

The prototype version of the RDA5807M receiver.

At the time of this design, the website of the RDA microelectronics is not accessible from my location. Because of this reason, I download different versions of RDA5807M datasheets from the internet. While going-through those datasheets, I observed that it comes with limited information. Finally, I decided to build this receiver to verify some of those parameters and to review the RDS functionality of the chip.

I build this receiver around ATmega16A MCU. I choose this MCU because I got a few of ATmega16A MCUs in my inventory and also due to the higher number of  I/O pin count.

RDA5807M module.


In this design, the volume is controlled using M62429 IC. For the output stage, I used AN7147N, 2×5.3W audio power amplifier IC.

Based on the specifications of the switching-regulator and power amplifier, this circuit can drive between 9V to 20V DC input. At prototyping stages, we power this circuit using a 12V - 2.5A power supply unit.

The main problem which I encounter with this project is its PCB design. At prototyping stages, I did a couple of PCB designs to avoid interference and distortions. It seems like RDA5807M and AN7147N are sensitive to noise and need a proper PCB layout. In this final design, I got excellent results, and it performs better than I expected.

Receiving YES FM at 101.00MHz.

At the testing stages, this receiver decodes RDS signals from all the FM station including weak stations. "RanOne FM" is the most attractive station name which I captured from this receiver. This station transmits its name in an animated style and its display on the receiver's LCD without any problems.

The firmware of this receiver is developed using two verification buffers to avoid RDS decode errors. This technique helps to filter garbage data received due to poor reception.

The current version of the firmware supports both manual and auto-tuning functionalities with 100kHz spacing and, it is set to operate within 87MHz to 108MHz range.

The circuit diagram, PCB designs and firmware source code of this receiver are available at github.com.

Comments

aditya said…
This comment has been removed by the author.
Anonymous said…
Silicon Labs also has another near FM band chip that not only receives it can transmit too!
Nice information post and share.thanks.
evask.ru

Popular posts from this blog

CD2003 - yet another simple FM radio receiver

In the last few days, we are looking for some simple FM radio receiver to integrate into one of our ongoing projects. For that, we try several FM radio receiver ICs including TDA7000, CD2003/TA2003/TA8164, CXA1019, and KA22429. Out of all those chips we select CD2003 (or TA2003/TA8164) based receiver for our project because of its simplicity and outstanding performance. Except to CD2003, Sony CXA1019 also perform well but we drop it because of its higher component count. We design our receiver based on Toshiba TA2003 datasheet and later we try TA8164 and CD2003 with the same circuit. Either CD2003 or TA8164 can directly replace TA2003 IC, and as per our observations, TA8164 gives excellent results out of those 3 chips. A prototype version of CD2003 FM radio receiver The PCB design and schematic which we used in our prototype project are available to download at google drive (including pin-outs of crystal filters and inductors ). Except for CD2003 IC, this receiver consist

Arduino superheterodyne receiver

In this project, we extend the shortwave superheterodyne receiver we developed a few years ago . Like the previous design, this receiver operates on the traditional superheterodyne principle.  In this upgrade, we enhanced the local oscillator with Si5351 clock generator module and Arduino control circuit. Compared to the old design, this new receiver uses an improved version of an intermediate frequency amplifier with 3 I.F transformers. In this new design, we divide this receiver into several blocks, which include, mixer with a detector, a local oscillator, and an I.F amplifier. The I.F amplifier builds into one PCB. The filter stage, mixer, and detector stages place in another PCB. Prototype version of 455kHz I.F amplifier. In this prototype build, the Si5351 clock generator drives using an Arduino Uno board. With the given sketch, the user can tune and switch the shortwave meter bands using a rotary encoder. The supplied sketch support clock generation from 5205kHz (tuner frequ

Calculator for audio output transformers

Audio output transformers are heavily used in a vacuum tube and some (older) transistor base audio power amplifiers, but these days output transformer are quite hard to find and expensive item. For homebrew projects, the best option is to construct those transformers by ourselves and this script helps to calculate winding parameters for those transformers. This " AF output transformer calculator " script is written using Python and it works with most of the commonly available Python interpreters . The script is available to download at google drive under the terms of GNU General Public License version 3.0 . Homebrewed 25k: 4 output transformer Once supplied the input parameters this script provides a winding ratio, the number of turns required for primary and secondary winding and required copper wire gauges for both primary and secondary windings, etc. We construct several AF output transformers based on results of this script, which including transformers for M