Under the hood of Radio Pop
Yesterday, Tristan introduced Radio Pop, our social radio listening prototype. For those of you who would like to know a bit more about its architecture, how it works and how you can use your data, this post is for you.
Technology
is a application. Why? Because that's where the R&D team's experience lies. Rails for a real-time web application meant to support a large number of users, but I'm not about to get anywhere near the debate as to what should be. In order to give our application a fighting chance of serving a (potentially) large number of concurrent listeners, it runs on the super-lightweight and super-fast web server . The availability of each instance is further enhanced using the . And of course we are using to avoid hitting the database where possible.
Listening and popping
Radio Pop tracks what you listen to through an HTTP POST 'pulse event' sent by the client radio player (either on the Radio Pop site, a or other) every 60 seconds. This pulse simply tells Radio Pop who you are and what network you are currently listening to. Radio Pop then retrieves the programme, series and brand information for that network - all of which comes from /programmes - and stores it. When you start listening to a different network or listen over a programme boundary, these pulse events are combined into a single 'listen event' for that programme. When you stop listening, a sweeper processes your recent listening after about 5 minutes of inactivity. Pop events work in the same way as pulse events.
This process works for both live and on-demand listening, but we are yet to implement an on-demand Radio Pop player. (And if RealPlayer is not your favourite audio player, we are looking at building a player which utilises .)
Open standards and data portability
We have attempted to support open standards which are applicable to a social listening application. We've tried to make the barrier to entry as low as possible and ask for as little information about you as we can so you can sign up using your alongside standard username and password entry. You can actually link a number of OpenIDs to your account should you wish and remove them at any time - its pretty flexible.
Radio Pop supports authentication for client applications which need to be able to update your listening profile, so you don't have to enter your username and password into third-party applications (should there ever be any). This is also how the desktop widget works.
We are currently not doing a great deal with your listening and popping data. We have plans to introduce recommendations and personalisation but that is some way off. In the mean time I recommend you have a look at the feeds and formats in which you can get your data (and your friends' data and everyone's data). Here's just a selection:
- My profile, including what I'm listening to:
- My friends list:
- My recent listening RSS feed:
- My Radio 1 listening history:
- My recent friends' pops RSS feed:
- My pops history:
You can also get your listening habits in APML (an open format for attention data), here's mine:
As a starter, I built the below using user profile XML data. Check out the full for more information and if you build an interesting visualisation or mashup please let us know.
Comment number 1.
At 16th Sep 2008, radio_listener wrote:In the paragraph you are discussing other technologies to listen to Â鶹Éç radio you linked to Adobe AIR and FLEX as possible alternatives to the Realplayer.
But Adobes technologies are like the Realplayer proprietary.
Think about implementing the iplayer for the iPhone. There is the need for a complete different version compared to the version for Windows. As far as I recall the Windows-Version is relying heavily on proprietary Windows standards.
So maybe it would be a good idea to use some non-proprietary standards. Like simple MP3, AAC or even OGG Vorbis streams.
Complain about this comment (Comment number 1)