CA2544390C - Automatic personal playlist generation with implicit user feedback - Google Patents

Automatic personal playlist generation with implicit user feedback Download PDF

Info

Publication number
CA2544390C
CA2544390C CA2544390A CA2544390A CA2544390C CA 2544390 C CA2544390 C CA 2544390C CA 2544390 A CA2544390 A CA 2544390A CA 2544390 A CA2544390 A CA 2544390A CA 2544390 C CA2544390 C CA 2544390C
Authority
CA
Canada
Prior art keywords
media
media pieces
pieces
user
songs
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Expired - Fee Related
Application number
CA2544390A
Other languages
French (fr)
Other versions
CA2544390A1 (en
Inventor
Hannu Toivonen
Seppo Pyhaelammi
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Nokia Oyj
Original Assignee
Nokia Oyj
Nokia Technologies Oy
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Nokia Oyj, Nokia Technologies Oy filed Critical Nokia Oyj
Publication of CA2544390A1 publication Critical patent/CA2544390A1/en
Application granted granted Critical
Publication of CA2544390C publication Critical patent/CA2544390C/en
Expired - Fee Related legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • GPHYSICS
    • G11INFORMATION STORAGE
    • G11BINFORMATION STORAGE BASED ON RELATIVE MOVEMENT BETWEEN RECORD CARRIER AND TRANSDUCER
    • G11B27/00Editing; Indexing; Addressing; Timing or synchronising; Monitoring; Measuring tape travel
    • G11B27/02Editing, e.g. varying the order of information signals recorded on, or reproduced from, record carriers
    • G11B27/031Electronic editing of digitised analogue information signals, e.g. audio or video signals
    • G11B27/034Electronic editing of digitised analogue information signals, e.g. audio or video signals on discs
    • GPHYSICS
    • G10MUSICAL INSTRUMENTS; ACOUSTICS
    • G10HELECTROPHONIC MUSICAL INSTRUMENTS; INSTRUMENTS IN WHICH THE TONES ARE GENERATED BY ELECTROMECHANICAL MEANS OR ELECTRONIC GENERATORS, OR IN WHICH THE TONES ARE SYNTHESISED FROM A DATA STORE
    • G10H1/00Details of electrophonic musical instruments
    • GPHYSICS
    • G10MUSICAL INSTRUMENTS; ACOUSTICS
    • G10HELECTROPHONIC MUSICAL INSTRUMENTS; INSTRUMENTS IN WHICH THE TONES ARE GENERATED BY ELECTROMECHANICAL MEANS OR ELECTRONIC GENERATORS, OR IN WHICH THE TONES ARE SYNTHESISED FROM A DATA STORE
    • G10H1/00Details of electrophonic musical instruments
    • G10H1/0033Recording/reproducing or transmission of music for electrophonic musical instruments
    • G10H1/0041Recording/reproducing or transmission of music for electrophonic musical instruments in coded form
    • G10H1/0058Transmission between separate instruments or between individual components of a musical system
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04QSELECTING
    • H04Q1/00Details of selecting apparatus or arrangements
    • GPHYSICS
    • G10MUSICAL INSTRUMENTS; ACOUSTICS
    • G10HELECTROPHONIC MUSICAL INSTRUMENTS; INSTRUMENTS IN WHICH THE TONES ARE GENERATED BY ELECTROMECHANICAL MEANS OR ELECTRONIC GENERATORS, OR IN WHICH THE TONES ARE SYNTHESISED FROM A DATA STORE
    • G10H2230/00General physical, ergonomic or hardware implementation of electrophonic musical tools or instruments, e.g. shape or architecture
    • G10H2230/005Device type or category
    • G10H2230/015PDA [personal digital assistant] or palmtop computing devices used for musical purposes, e.g. portable music players, tablet computers, e-readers or smart phones in which mobile telephony functions need not be used
    • GPHYSICS
    • G10MUSICAL INSTRUMENTS; ACOUSTICS
    • G10HELECTROPHONIC MUSICAL INSTRUMENTS; INSTRUMENTS IN WHICH THE TONES ARE GENERATED BY ELECTROMECHANICAL MEANS OR ELECTRONIC GENERATORS, OR IN WHICH THE TONES ARE SYNTHESISED FROM A DATA STORE
    • G10H2240/00Data organisation or data communication aspects, specifically adapted for electrophonic musical tools or instruments
    • G10H2240/121Musical libraries, i.e. musical databases indexed by musical parameters, wavetables, indexing schemes using musical parameters, musical rule bases or knowledge bases, e.g. for automatic composing methods
    • G10H2240/125Library distribution, i.e. distributing musical pieces from a central or master library
    • GPHYSICS
    • G10MUSICAL INSTRUMENTS; ACOUSTICS
    • G10HELECTROPHONIC MUSICAL INSTRUMENTS; INSTRUMENTS IN WHICH THE TONES ARE GENERATED BY ELECTROMECHANICAL MEANS OR ELECTRONIC GENERATORS, OR IN WHICH THE TONES ARE SYNTHESISED FROM A DATA STORE
    • G10H2240/00Data organisation or data communication aspects, specifically adapted for electrophonic musical tools or instruments
    • G10H2240/171Transmission of musical instrument data, control or status information; Transmission, remote access or control of music data for electrophonic musical instruments
    • G10H2240/281Protocol or standard connector for transmission of analog or digital data to or from an electrophonic musical instrument
    • G10H2240/295Packet switched network, e.g. token ring
    • G10H2240/305Internet or TCP/IP protocol use for any electrophonic musical instrument data or musical parameter transmission purposes
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04MTELEPHONIC COMMUNICATION
    • H04M3/00Automatic or semi-automatic exchanges
    • H04M3/42Systems providing special services or facilities to subscribers
    • H04M3/487Arrangements for providing information services, e.g. recorded voice services or time announcements
    • H04M3/493Interactive information services, e.g. directory enquiries ; Arrangements therefor, e.g. interactive voice response [IVR] systems or voice portals

Abstract

Music selection systems and methods are disclosed. An adaptive set of songs is selected based on implicit feedback from a user. A random set of songs is also selected. A playlist selection module creates a playlist that includes songs from the adaptive set and the random set in a ratio determined by a surprise factor provided by a user. The playlist may also begin with a sure set of songs that are known to be enjoyed by the user.

Description

2 PCT/IB2004/003651 AUTOMATIC PERSONAL PLAYLIST GENERATION WITH IMPLICIT
USER FEEDBACK

BACKGROUND OF THE INVENTION
FIELD OF THE INVENTION

The invention relates to mobile media playback devices. More particularly, the invention relates to the generation of playlists of media content to playback on mobile media playback devices.

DESCRIPTION OF RELATED ART

Conventional mobile media playback devices allow users to download and playback media, such as music, videos, pictures and images. Exemplary mobile media playback devices include mobile terminals, personal digital assistants, digital cameras, digital video recorders and combination devices. Typical mobile audio players, for example, generally have a relatively small memory capacity that allow for the storage and playback of a limited number of songs. Users store a music library containing songs on a PC or other computer device having a relatively large memory and download a portion of the songs in the music library to the mobile audio player.

The manual selection of songs to add to a playlist can be time consuming and tedious.
Attempts have been made to automate the playlist selection process. One method includes selecting a random group of songs from the music library. This method can result in the playlist including a large number of songs that are not liked by the user.
Another prior art method includes generating a playlist that includes songs most liked by the user. This approach can lead to degenerative playlists. The playlists can become dominated by the same songs played over and over again. Some systems rely on the use of metadata to compare attributes of new songs to the attributes of songs CONFIRMATION COPY

that a user has indicated as enjoying. Without the required metadata, such systems do not work.
These drawbacks are not unique to mobile audio players and also apply to other mobile media playback devices.
Therefore, there is a need in the art for playlist selection systems and methods that automatically generate lists that include media pieces that a user likes while minimizing repetition and keeping aspects of surprise within the lists.

BRIEF SUMMARY OF THE INVENTION

One or more of the above-mentioned needs in the art are satisfied by the disclosed playlists selection systems and methods. An adaptive set of media pieces is selected based on activities of a user. A random set of media pieces is also selected. A playlist selection module creates a playlist that includes media pieces from the adaptive set and the random set in a ratio determined by a surprise factor provided by a user. The playlist may also begin with a sure set of media pieces that are known to be enjoyed by the user.

Accordingly, in one aspect there is provided a method comprising:
(a) assigning individual weights to a plurality of media pieces based on activities of a user in relation to the media pieces;
(b) selecting a plurality of media pieces from a media library to form an adaptive set of media pieces, wherein the probability of each media piece being selected corresponds to the weight assigned to the media pieces;
(c) selecting a random group of media pieces from the media library to form a random set of media pieces, the random set of media pieces being different than the adaptive set of media pieces; and (d) generating in a computer readable memory a playlist that is executable in a computer device, wherein the playlist includes media pieces selected from the adaptive set and media pieces selected from the random set with a ratio that corresponds to a surprise parameter.

According to another aspect there is provided a computer-readable medium containing computer-executable instructions for causing a media device to perform the steps comprising:

(a) assigning individual weights to a plurality of media pieces based on activities of a user in relation to the media pieces;
(b) selecting a plurality of media pieces from the media library to form an adaptive set of media pieces, wherein the probability of each media piece being selected corresponds to the weight assigned to the media pieces;
(c) selecting a random group of media pieces from the media library to form a random set of media pieces, the random set of media pieces being different than the adaptive set of media pieces; and (d) generating in a computer readable memory a playlist that is executable in a computer device, wherein the playlist includes media pieces selected from the adaptive set and media pieces selected from the random set with a ratio that corresponds to a surprise parameter.
According to yet another aspect there is provided a mobile media device comprising:
a playlist generation module configured to generate a media playlist by:
assigning individual weights to a plurality of media pieces based on activities of a user in relation to the media pieces;
selecting a plurality of media pieces from a media library to form an adaptive set of media pieces, wherein the probability of each media piece being selected corresponds to the weight assigned to the media pieces;
selecting a random group of media pieces from the media library to form a random set of media pieces, the random set of media pieces being different than the adaptive set of media pieces; and generating in a computer readable memory a media playlist that is executable in a computer device, wherein the media playlist includes the media pieces selected from the adaptive set based on weight and the media pieces selected in random from the random set with a ratio that corresponds to a surprise parameter-According to still yet another aspect there is provided a system comprising-a computer device that includes a playlist generation module configured to generate a media playlist by:
assigning individual weights to a plurality of media pieces based on activities 2a of a user in relation to the media pieces;
selecting a plurality of media pieces from a media library to form an adaptive set of media pieces, wherein the probability of each media piece being selected corresponds to the weight assigned to the media piece;
selecting a random group of media pieces from the media library to form a random set of media pieces, the random set of media pieces being different than the adaptive set of media pieces; and generating a media playlist that includes the media pieces selected from the adaptive set based on weight and media pieces selected in random from the random set with a ratio that corresponds to a surprise parameter; and a mobile media device that receives from the computer device media pieces selected by the playlist generation module.

According to still yet another aspect there is provided a system for providing music to a user, the system comprising:
a mobile music device that includes a playlist generation module configured to generate an audio playlist by:
assigning individual weights to a plurality of songs based on activities of a user in relation to the songs;
selecting a plurality of songs from a music library to form an adaptive set of songs, wherein the probability of each song being selected corresponds to the weight assigned to the song;
selecting a random group of songs from the music library to form a random set of songs, the random set of songs being different than the adaptive set of songs; and generating a playlist that includes the songs selected from the adaptive set based on weight and songs selected in random from the random set with a ratio that corresponds to a surprise parameter; and a computer device that includes a music reproduction module and that receives the audio playlist from the mobile music device.
In other embodiments of the invention, computer-executable instructions for implementing the disclosed methods are stored on computer-readable media.

2b BRIEF DESCRIPTION OF THE DRAWINGS

The present invention is illustrated by way of example and not limited in the accompanying figures in which like reference numerals indicate similar elements and in which:

Figure 1 shows a schematic diagram of a mobile music system in accordance with an embodiment of the invention;

Figure IA illustrates an exemplary mobile music device, in accordance with an embodiment of the invention;

Figure 1B illustrates an exemplary wireless communications system in which systems and methods of the present invention may be employed;

Figure 2 illustrates a relationship between sets of songs and a playlist in accordance with an embodiment of the invention;

Figure 3 illustrates a method of generating a playlist in accordance with an embodiment of the invention; and Figure 4 illustrates a mobile media playback system, in accordance with an embodiment of the invention.

DETAILED DESCRIPTION OF THE INVENTION

Figure 1 illustrates a mobile music system in accordance with an embodiment of the invention. A mobile music device 102 stores and plays songs to a user. Mobile music device 102 may be implemented with an MP3 player, mobile telephone, personal digital assistant or other portable hand-held electronic devices that are capable of storing and reproducing music. Mobile music device 102 includes a song memory
3 104 for storing songs. Song memory 104 may be implemented with a removable memory module or a stationary memory module.

Mobile music device 102 may be coupled to a computer device 108, such as a laptop or desktop computer. One skilled in the art will appreciate that computer device 108 may be implemented with several different devices that have processor capacity for generating a playlist and a memory storage. Computer device 108 may include a personal music library database 110 for storing songs. The capacity of personal music library database 110 is generally larger than the capacity of song memory 104.
A
playlist generation module 106 is used to select a subset of songs from personal music library database 110 to store in song memory 104. In one alternative embodiment of the invention, one or more of the functions of playlist generation module 106 are performed by a module (not shown) within mobile music device 102.

Computer device 108 may be coupled to a wide area network, such as the Internet 112. Of course numerous databases and music websites, such as music library database 114 are also coupled to the Internet 112. Music library database 114 may store songs that are transmitted to the music library database and/or song memory 104. In one embodiment of the invention, mobile music device 102 is coupled to music library database 114 via the Internet 112 and downloads content directly from the music library database 114. Music library database 114 may also include a playlist generation module for selecting songs to transmit to personal music library database 110 and/or song memory 104.

In one embodiment, computer device 108 may be implemented with a device that reproduces music. A user may record music with mobile music device 102. Mobile music device 102 may generate a playlist or playlist data and transmit the playlist or playlist data to computer device 108. This particular embodiment allows the user to use mobile music device 102 in order to generate a personal playlist while away from home and have the information transferred to a relatively stationary computer device 108.
4 Figure IA illustrates an exemplary mobile music device 120 in accordance with an embodiment of the invention. Mobile music device 120 includes a song memory 104.
Song memory 104 is described above. A playlist module 122 may be included for recording and and/or maintaining a log of user behaviors that may be used to generate playlists. Exemplary behaviors include recording a song, skipping a song, replaying a song, etc. A CPU 124 may be included to control the overall operation of mobile music device 120.

Mobile music device 120 may include one or more components for communicating with external devices. A short-range transceiver 126 may be included for communicating with devices such as computer device 108. In one embodiment, short-range transceiver 126 uses the Bluetooth protocol. Ultra Wideband technology may also be used for transferring large files. It should be noted that also other wireless short-range technologies may be used for communicating with other devices.
Mobile music device 120 may also include conventional components such as an audio output 128, a network transceiver 130, a display 132 and an antenna 134. Moreover, mobile music device 120 may also include a camera that allows a user to record media pieces in the form of pictures, images and video. Display 132 may be used to playback picture, image and video media pieces. A time module and calendar module may be included to provide inputs during the music selection process.

Figure 1 B shows an example of a wireless communication system 10 in which the systems and methods of the present invention may be advantageously employed.
One or more network-enabled mobile devices 12, such as a personal digital assistant (PDA), digital camera, cellular phone, mobile terminal, or combinations thereof, is in communication with a server 14. Although not shown in Figure 1 B, server 14 may act as a file server for a network such as home network, some other Local Area Network (LAN), or a Wide Area Network (WAN). Server 14 may be a personal computer, a mainframe, a television set-top box, or other device capable of storing and accessing data. Mobile device 12 may communicate with server 14 in a variety of manners. For example, mobile device 12 may communicate with server 14 via
5 wireless network 18. Wireless network 18 may be a third-generation (3G) cellular data communications network, a Global System for Mobile communications network (GSM), or other wireless communication network. Mobile device 12 may also have one or more ports allowing a wired connection to server 14 via, e.g., universal serial bus (USB) cable 15. Mobile device 12 may also be capable of short-range wireless connection 20 (e.g., a BLUETOOTH link) to server 14. A single mobile device 12 may be able to communicate with server 14 in multiple manners.

Server 14 may act as a repository for storing files received from mobile device 12 and from other sources. Server 14 may have, or be coupled to, a wireless interface configured to transmit and/or receive communications (such as messages, files, or other data) with mobile network 18. Server 14 may alternatively (or also) have one or more other communication network connections. For example, server 14 may be linked (directly or via one or more intermediate networks) to the Internet, to a conventional wired telephone system, or to some other communication network.

In one embodiment, mobile device 12 has a wireless interface configured to send and/or receive digital wireless communications within wireless network 18. As part of wireless network 18, one or more base stations (not shown) may support digital communications with mobile device 12 while the mobile device is located within the administrative domain of wireless network 18. The base station of wireless network 18 that is in communication with mobile device 12 may be the same or a different base station that is in communication with server 14. Indeed, mobile device 12 and server 14 may each be in communication with different wireless networks (e.g., mobile device 12 could be roaming), which could in turn be interlinked via one or more intermediate wired or wireless networks. For simplicity, server 14 and mobile device 12 are shown within the same wireless network 18.

Mobile device 12 communicates with server 14 via wireless network 18 and is configured to transmit data (such as, e.g., music content) for remote storage on server 14. Mobile device 12 may also be configured to access data previously stored on
6 server 14. In one embodiment, file transfers between mobile device 12 and server 14 may occur via Short Message Service (SMS) messages and/or Multimedia Messaging Service (MMS) messages transmitted via short message service center (SMSC) 24 and/or a multimedia messaging service center (MMSC) 26. Although shown as part of network 18, SMSC 24 and MMSC 26 may be part of another network or otherwise outside of network 18. Although shown as separate logical entities, SMSC 24 and MMSC 26 could be a single entity. Further, SMSC 24 and MMSC 26 may coordinate via signaling between themselves for improving the file transfer process. For example, because SMSC 24 and MMSC 26 may be store-and-forward systems, rather than real-time systems, a file requested via an SMS message from mobile device may still reside on MMSC 26 based upon a previous request. As such, SMSC 24 may copy MMSC 26 on an SMS file request and, if applicable, MMSC 26 may notify the user of the previously stored file. Further, MMSC 26 may simply transfer the requested file based on its stored copy of the file. In other embodiments, may act as a repository for files, and mobile device 12 may simply request transfer of files from MMSC 26.

Figure 2 illustrates a relationship between sets of songs and a playlist in accordance with an embodiment of the invention. The basic relationship shown in Figure 2 may be applied to other implementations that include other media pieces, such as songs and video clips. A playlist generation module 202 generates an adaptive set of songs 204, a random set of songs 206, a sure set of songs 208 and receives a surprise parameter 210 and produces a playlist 212. Playlist generation module 202 may also receive adaptive set of songs 204, random set of songs 206 and/or sure set of songs 208 from another source.

Adaptive set of songs 204 may be selected based on attributes that correspond to activities of a user or other factors such as the time of day and date. Such activities may include recording the songs, repeating the songs and not skipping the songs.
Time information may be used, for example, to select a playlist based on whether it is early in the morning or in the afternoon. Date information may be used, for example,
7 to select different music during holidays or weekends than would be selected during a work week.

Exemplary attributes and values that capture aspects of a user's behavior with respect to a song include:

1. Recorded: boolean. Is the song recorded by the user (vs. automatically by the system)?
2. Skipped: integer >= 0. Approximate number of times the song has been skipped by the user during replay. A song may be considered skipped if the user presses a "next" button during the replay of the song and the song has been playing for less than a predetermined period of time, such as 1 minute. In one embodiment, a song is not considered skipped if a "previous" button was used to reach the song.
3. Repeated: integer >= 0. Number of songs replayed since the song was last repeated by the user. A song may be considered repeated when a user presses "previous" button to reach the song and listens to it more than, say, 30 seconds. A user might be looking for a song replayed some time ago, and during the search for the song he listens to the beginnings of other songs. When counting the number of songs replayed since last repeat, also skipped and repeated songs count as replayed.
4. Age: integer >= 0. Number of days since the song was recorded (by the user or by the system). In alternative embodiments different time frames may be used.
5. Lastplayed: integer >= 0. Number of songs replayed since the last replay of this song. One advantage of using the number of songs is that the choice adapts to the user's rate of listening to a playlist.
Alternatively Last played could be the number of days since the last replay of this song.
8 An attribute of a given song, such as repeated, may be denoted by song.repeated.

In one embodiment, adaptive set of songs 204 is more likely to include recently recorded songs than older recordings. Random set of songs 206 may include a set of songs that are not necessarily preferred by the user. Random set of songs 206 may be used to add variety to the ultimate playlist. Sure set of songs may include songs that are known to be liked by the user. The user may indicate which songs to include in sure set of songs 208. In an alternative embodiment, one or more activities of the user, such as recording a song and repeating a song, may be used in the selection of sure set of songs 208. Surprise parameter 210 may be supplied by the user and may determine the percentage of songs included in the playlist that are from random set of songs 206. Surprise parameter may have a value of 0% to 100% or may comprise other values such as high, medium and low.

In one embodiment of the invention, playlist 212 includes a first group of songs selected from sure set of songs 208. These songs may be placed at the beginning of the playlist to ensure a good user experience. Next, playlist 212 includes songs selected both from adaptive set of songs 204 and random set of songs 206 with a ratio determined by surprise parameter 210. Once playlist 212 is generated, the corresponding music files are downloaded from personal music library database 110, or alternatively from music library database 114 over the Internet 112.

Playlist 212 may be created separately for each station or genre that the user listens to.
For example, a first genre of music may include jazz songs and the songs comprising playlist 212 may be selected from a particular jazz station. Time, place and other factors may influence the content of playlist 212.

Figure 3 illustrates a method of generating a playlist in accordance with an embodiment of the invention. First, in step 302, individual weights are assigned to a plurality of songs based on activities of a user. The weights may be used to select an
9 adaptive set of songs. A first weight wl a(song) may be selected to favor recorded songs, such that:

W1a(song) = 1 if song. recorded = true w 1 a(song) = 0 otherwise.

A second weight wlb(song) may be selected to favor songs that the user has repeated over other songs. Recently repeated songs may also be favored over older songs. For example, wlb(song) may be used to define how much more likely recently repeated songs are to select than songs that have never been repeated by defining w l b(song) as follows:

wlb(song) = 1 + 2-song.repeated/hlb * max weightlb=

In one embodiment, the following values are used as default choices.
max_weightlb = 3 hlb = 20 For a song that has never been repeated, wlb(song) may be defined to equal 1.
When the last song that was replayed was also repeated, wlb(song) = l+max_weightlb=
The weight (actually weight - 1) halves every hlb days and approaches 1 for songs last repeated a long time ago.

A third weight wlc(song) may be selected to favor songs that have not been skipped by the user over songs that have been skipped. In one embodiment, songs that have never been skipped may have a have a wlc(song) equal to one. Songs skipped and not recorded by the user may have a wlc(song) equal to zero and songs recorded by the user may have a w(song) that quickly decreases. For example:

If song. skipped = 0 then w l c(song) = 1 If song.recorded = true then wlc(song) = 2-song.skipped/hlc If song.recorded = false and song.skipped > 0 then wlc(song) = 0 In one embodiment, h I c = 0.5.

A fourth weight wld(song) may be selected to favor recently recorded songs. In one embodiment, w l d(song) may be equal to one for sounds recorded on the day that the weight is used and wld(song) may be equal to 2-song.age/hid for songs recorded at other times. The value hld may be used to represent a half-life of the weight.
For example, an hld=10 implies only very recent songs are favored and an hld=1000 implies older songs have almost equal weights. A suitable default value for hld is A fifth weight w3a(song) may be selected to favor songs that have not been replayed recently over songs that have been replayed recently. For recently played songs w3a(song) may be very small and w3a(song) may approach 1 for songs that have not been played in a long time. For example:

w3a(song) = 1, if song has never been replayed w3a(song) = 1/(1+steep-song.last_played+h3a), if the song has been replayed where "steep" is a parameter that governs how steep or sharp the division to recent and old songs is and h3a is the half life and governs where the division takes place.
A suitable default value for steep is 1.2 and for h3a is 30.

In step 304, a plurality of songs are selected from the music library, wherein the probability of each song being selected corresponds to the weight assigned to the song. In one embodiment, the weight assigned to each song wadapt(song) is equal to the product of the five weights described above. The probability of a given song being selected Padapt(song) is proportional to its weight wadapt(song). For example:
Pradapt(song) = wadapt(song)/Y- iwadapt(songi).

In step 306, a random group of songs is selected from the music library. In one embodiment, the random group of songs may be selected based on random weights assigned to each song and the random weight of each song wrand(song) may be defined as follows:

wrand(song) = wIc(song) * w3a(song).

In step 308, a surprise parameter may be received. The surprise parameter may be received from a user or selected by a playlist generation module. The surprise parameter may have a value of 0-100% and may represent the fraction of songs selected without regard to weights wla(song), wlb(song) and wld(song). A
suitable default value for surprise factor is 20%.

Finally, in step 310, a playlist is generated that includes songs selected in step 304 and songs selected in step 306 with a ratio that corresponds to the surprise parameter.
After the songs in the playlist are replayed, the songs may be reordered to provide variety.

As mentioned above, embodiments of the invention may use media pieces other than music or songs. In particular, the playlist selection methods disclosed herein may be used to generate playlists of images, pictures, video clips and other visual and/or audio pieces. Figure 4 illustrates a mobile media playback system that is similar to the mobile music system shown in Figure 1. A mobile media playback device 402 stores and plays back media to a user. For example, mobile media playback device 402 may be a personal digital assistant that plays back images to a user.
Mobile music device 402 includes a media piece memory 404 for storing media pieces.
Media piece memory 404 may be implemented with a removable memory module or a stationary memory module.

Mobile music device 402 may be coupled to a computer device 408 that includes a personal media piece library database 410 for storing media pieces and a playlist generation module 406. Computer device 408 may be similar to computer device (shown in Figure 1). Computer device 408 may be coupled to a wide area network, such as the Internet 412. Numerous databases and media websites, such as media piece library database 414 may also be coupled to the Internet 412. The operation of the elements shown in Figure 4 is substantially similar to the operation of the elements shown in Figure 4.

Aspects of the resent invention may also be applied to other embodiments that do not include mobile devices. For example, the playlist selection methods disclosed herein may be used to generate a playlist of images to display on a wall mounted display devices, such as a plasma television or liquid crystal television.

While the invention has been described with respect to specific examples including presently preferred modes of carrying out the invention, those skilled in the art will appreciate that there are numerous variations and permutations of the above described systems and techniques that fall within the spirit and scope of the invention as set forth in the appended claims.

APPENDIX
The following code written in Perl is an exemplary algorithm that may be used by a playlist generation module to select a playlist.

Variables used (and not introduced in the algorithm):
= music_library_size: total number of songs in the music library = recorded-by-the-user: number of songs recorded by the user = first songs: number of first songs to be selected as "sure"

= surprise ratio: surprise-ratio = last played [ 1: array of last_played attributes of songs For simplicity, in the algorithm below songs are identified by an index between 0 and music library size-1, and the first recorded-by-the-user songs are the ones recorded by the user.

# 1. init playlist my @playlist = (); # playlist to be generated my $playlist_filled = 0; # number of songs in playlist so far my $users_songs = 0; # number of user recorded songs in playlist so far # 2, find out largest weights (normalization factors) my $max_w_sure = 0;
my $max_w_adapt = 0;
my $max_w_rand = 0;
for ($s = 0; $s < $music library size; $s++) {
$max_w_sure = (w_sure($s) > $max_w_sure ? w_sure($s) : $max_w_sure);
$max_w_adapt = (w_adapt($s) > $max_w adapt ? w_adapt($s) $max_w_adapt);
$max_w_rand = (w_rand($s) > $max_w_rand ? w_rand($s) : $max_w_rand);
}

# 3, create a backup copy of last_played my @last_played_copy;
for ($s = 0; $s < $music library_size; $s++) {
$last_played_copy[$s] _ $last_played[$s];
}
# 4. while playlist has room repeat while (($playlist_ filled < $playlist_ size) ($playlist_ filled < $music_library_size)) {

# 4.1. decide how to select a song and then search for one my $randomsong;
if ($playlist_ filled < $first_songs) {
# Make a sure selection # (Using rejection sampling: propose a random song (1), reject it # stochastically (2) depending on the relative probability of the # song. Repeat this until a proposed song is accepted.) do {
$random song = int(rand($recorded_by_the_user)); # (1) } while (rand() > w_sure($random song)/$max_w_sure); # (2) } elsif ((rand() > $surprise ratio/100) &&
($users_songs < $recorded_by_the_user)) {
# Select a song recorded by the user do {
$random song = int(rand($recorded_by_the_user));
} while (rand() > w_adapt($random song)/$max_w_adapt);
$users_songs++;
} else {
# Select a random song do {
$random song = $recorded_by_the_user +

int(rand($music_library_size - $recorded_by_the_user));
} while (rand() > w_rand($random song)/$max_w_rand);
}

# 4.2. add the song to the playlist $playlist[$playlist_filled++] = $random_song;
# 4.3. update last_played fields for ($s = 0; $s < $music_library_size; $s++) {
$last played[$s]++;
}
$last_played[$random_song] = 0;
# 4.4. find out new largest weights my $max_w_sure = 0;
my $max_w_adapt = 0;
my $max_w_rand = 0;
for ($s = 0; $s < $music_library_size; $s++) {
$max_w_sure = (w_sure($s) > $max_w_sure ? w_sure($s) $max w sure);
$max_w_adapt = (w_adapt($s) > $max_w_adapt ? w_adapt($s) $max_w_adapt);
$max w rand = (w rand($s) > $max_w_rand ? w_rand($s) $max w rand);
}
}

# 5. restore last played to its original value for ($s = 0; $s < $music_library_size; $s++) {
$last_played[$s] = $last_played_copy[$s];

Claims (43)

What is claimed is:
1. A method comprising:
(a) assigning individual weights to a plurality of media pieces based on activities of a user in relation to the media pieces;
(b) selecting a plurality of media pieces from a media library to form an adaptive set of media pieces, wherein the probability of each media piece being selected corresponds to the weight assigned to the media pieces;
(c) selecting a random group of media pieces from the media library to form a random set of media pieces, the random set of media pieces being different than the adaptive set of media pieces; and (d) generating in a computer readable memory a playlist that is executable in a computer device, wherein the playlist includes media pieces selected from the adaptive set and media pieces selected from the random set with a ratio that corresponds to a surprise parameter.
2. The method of claim 1, wherein (a) comprises favoring media pieces that have been imported by the user over media pieces that have been recorded automatically.
3. The method of claim 1, wherein (a) comprises favoring media pieces repeated by a user over media pieces that have not been repeated by the user.
4. The method of claim 1, wherein (a) comprises favoring media pieces that have not been skipped by the user over media pieces that have been skipped by the user.
5. The method of claim 1, wherein (a) comprises favoring recently recorded media pieces over less recently recorded media pieces.
6. The method of claim 1, wherein (a) comprises favoring media pieces that have not been replayed recently over media pieces that have been replayed recently.
7. The method of claim 1, wherein (a) comprises:

(i) favoring media pieces that have been recorded by the user over media pieces that have been recorded automatically;
(ii) favoring media pieces repeated by a user over media pieces that have not been repeated by the user;
(iii) favoring media pieces that have not been skipped by the user over media pieces that have been skipped by the user;
(iv) favoring recently recorded media pieces over less recently recorded media pieces;
and (v) favoring media pieces that have not been replayed recently over media pieces that have been replayed recently.
8. The method of claim 1, further including assigning preferred media pieces to the beginning of the playlist.
9. The method of claim 8, wherein the preferred media pieces comprise media pieces imported by the user.
10. The method of claim 9, wherein the preferred media pieces further comprise media pieces that have not been skipped by the user.
11. The method of any one of claims 1 to 10, wherein the surprise parameter is selected by the user.
12. The method of any one of claims 1 to 11, further including reordering the media pieces after all of the media pieces have been played.
13. The method of any one of claims 1 to 12, further including (e) downloading the plurality of media pieces from the media library.
14. The method of claim 13, wherein (e) comprises downloading the plurality of media pieces from a website.
15. The method of claim 13, wherein (e) comprises downloading the plurality of media pieces from a computer to an audio player coupled to the computer.
16. A computer-readable medium containing computer-executable instructions for causing a media device to perform the steps comprising:
(a) assigning individual weights to a plurality of media pieces based on activities of a user in relation to the media pieces;
(b) selecting a plurality of media pieces from the media library to form an adaptive set of media pieces, wherein the probability of each media piece being selected corresponds to the weight assigned to the media pieces;
(c) selecting a random group of media pieces from the media library to form a random set of media pieces, the random set of media pieces being different than the adaptive set of media pieces; and (d) generating in a computer readable memory a playlist that is executable in a computer device, wherein the playlist includes media pieces selected from the adaptive set and media pieces selected from the random set with a ratio that corresponds to a surprise parameter.
17. The computer-readable medium of claim 16, wherein the computer-executable instructions for (a) cause the media device to favor at least one of:
(i) media pieces that have been recorded by the user over media pieces that have been recorded automatically;

(ii) media pieces repeated by a user over media pieces that have not been repeated by the user;
(iii) media pieces that have not been skipped by the user over media pieces that have been skipped by the user;

(iv) recently recorded media pieces over less recently recorded media pieces;
and (v) media pieces that have not been replayed recently over media pieces that have been replayed recently.
18. The computer-readable medium of claim 16, wherein the computer-executable instructions for (a) cause the media device to favor:

(i) media pieces that have been recorded by the user over media pieces that have been recorded automatically;
(ii) media pieces repeated by a user over media pieces that have not been repeated by the user;
(iii) media pieces that have not been skipped by the user over media pieces that have been skipped by the user;
(iv) recently recorded media pieces over less recently recorded media pieces;
and (v) media pieces that have not been replayed recently over media pieces that have been replayed recently.
19. The computer-readable medium of any one of claims 16 to 18, further containing computer-executable instructions for causing the media device to reorder the media pieces after all of the media pieces have been played.
20. The computer-readable medium of any one of claims 16 to 19, further containing computer-executable instructions for causing the media device to download the plurality of media pieces from the media library.
21. A mobile media device comprising:
a playlist generation module configured to generate a media playlist by:
assigning individual weights to a plurality of media pieces based on activities of a user in relation to the media pieces;

selecting a plurality of media pieces from a media library to form an adaptive set of media pieces, wherein the probability of each media piece being selected corresponds to the weight assigned to the media pieces;

selecting a random group of media pieces from the media library to form a random set of media pieces, the random set of media pieces being different than the adaptive set of media pieces; and generating in a computer readable memory a media playlist that is executable in a computer device, wherein the media playlist includes the media pieces selected from the adaptive set based on weight and the media pieces selected in random from the random set with a ratio that corresponds to a surprise parameter.
22. The mobile media device of claim 21, further including a short-range transceiver.
23. The mobile media device of claim 22, wherein the short-range transceiver is configured to use a Bluetooth protocol.
24. The mobile media device of any one of claims 21 to 23, further including a time module that tracks the current time.
25. The mobile media device of any one of claims 21 to 24, further including a calendar module that tracks the current date.
26. The mobile media device of any one of claims 21 to 25, wherein the individual weights are assigned to favor at least one of:
(i) media pieces that have been recorded by the user over media pieces that have been recorded automatically;
(ii) media pieces repeated by a user over media pieces that have not been repeated by the user;
(iii) media pieces that have not been skipped by the user over media pieces that have been skipped by the user;
(iv) recently recorded media pieces over less recently recorded media pieces;
and (v) media pieces that have not been replayed recently over media pieces that have been replayed recently.
27. The mobile media device of any one of claims 21 to 25, wherein the individual weights are assigned to favor:
(i) media pieces that have been recorded by the user over media pieces that have been recorded automatically;
(ii) media pieces repeated by a user over media pieces that have not been repeated by the user;
(iii) media pieces that have not been skipped by the user over media pieces that have been skipped by the user;
(iv) recently recorded media pieces over less recently recorded media pieces;
and (v) media pieces that have not been replayed recently over media pieces that have been replayed recently.
28. The mobile media device of any one of claims 16 to 27, wherein the playlist generation module is further configured to reorder the media pieces after all of the media pieces have been played.
29. The mobile media device of any one of claims 16 to 28, wherein the playlist generation module is further configured to download the plurality of media pieces from the media library.
30. A system comprising:
a computer device that includes a playlist generation module configured to generate a media playlist by:
assigning individual weights to a plurality of media pieces based on activities of a user in relation to the media pieces;
selecting a plurality of media pieces from a media library to form an adaptive set of media pieces, wherein the probability of each media piece being selected corresponds to the weight assigned to the media piece;
selecting a random group of media pieces from the media library to form a random set of media pieces, the random set of media pieces being different than the adaptive set of media pieces; and generating a media playlist that includes the media pieces selected from the adaptive set based on weight and media pieces selected in random from the random set with a ratio that corresponds to a surprise parameter; and a mobile media device that receives from the computer device media pieces selected by the playlist generation module.
31. The system of claim 30, wherein the individual weights are assigned to favor at least one of:

(i) media pieces that have been recorded by the user over media pieces that have been recorded automatically;

(ii) media pieces repeated by a user over media pieces that have not been repeated by the user;
(iii) media pieces that have not been skipped by the user over media pieces that have been skipped by the user;
(iv) recently recorded media pieces over less recently recorded media pieces;
and (v) media pieces that have not been replayed recently over media pieces that have been replayed recently.
32. The system of claim 30, wherein the individual weights are assigned to favor:
(i) media pieces that have been recorded by the user over media pieces that have been recorded automatically;
(ii) media pieces repeated by a user over media pieces that have not been repeated by the user;
(iii) media pieces that have not been skipped by the user over media pieces that have been skipped by the user;
(iv) recently recorded media pieces over less recently recorded media pieces;
and (v) media pieces that have not been replayed recently over media pieces that have been replayed recently.
33. The system of any one of claims 30 to 32, wherein the playlist generation module is further configured to reorder the media pieces after all of the media pieces have been played.
34. The system of any one of claims 30 to 33, wherein the playlist generation module is further configured to download the plurality of media pieces from the media library.
35. The system of any one of claims 30 to 34, wherein the mobile media device includes a short-range transceiver for communicating with the computer device to receive the selected media pieces.
36. The mobile media device of claim 35, wherein the short-range transceiver is configured to use a Bluetooth protocol.
37. A system for providing music to a user, the system comprising:
a mobile music device that includes a playlist generation module configured to generate an audio playlist by:
assigning individual weights to a plurality of songs based on activities of a user in relation to the songs;
selecting a plurality of songs from a music library to form an adaptive set of songs, wherein the probability of each song being selected corresponds to the weight assigned to the song;
selecting a random group of songs from the music library to form a random set of songs, the random set of songs being different than the adaptive set of songs; and generating a playlist that includes the songs selected from the adaptive set based on weight and songs selected in random from the random set with a ratio that corresponds to a surprise parameter; and a computer device that includes a music reproduction module and that receives the audio playlist from the mobile music device.
38. The system of claim 37, wherein the individual weights are assigned to favor at least one of:

(i) songs that have been recorded by the user over songs that have been recorded automatically;

(ii) songs repeated by a user over songs that have not been repeated by the user;
(iii) songs that have not been skipped by the user over songs that have been skipped by the user;

(iv) recently recorded songs over less recently recorded songs; and (v) songs that have not been replayed recently over songs that have been replayed recently.
39. The system of claim 37, wherein the individual weights are assigned to favor:
(i) songs that have been recorded by the user over songs that have been recorded automatically;

(ii) songs repeated by a user over songs that have not been repeated by the user;

(iii) songs that have not been skipped by the user over songs that have been skipped by the user;
(iv) recently recorded songs over less recently recorded songs; and (v) songs that have not been replayed recently over songs that have been replayed recently.
40. The system of any one of claims 37 to 39, wherein the playlist generation module is further configured to reorder the songs after all of the songs have been played.
41. The system of any one of claims 37 to 40, wherein the playlist generation module is further configured to download the plurality of songs from the music library.
42. The system of any one of claims 37 to 41, wherein the mobile music device includes a short-range transceiver for communicating with the computer device to receive the selected songs.
43. The system of claim 42, wherein the short-range transceiver is configured to use a Bluetooth protocol.
CA2544390A 2003-11-06 2004-11-05 Automatic personal playlist generation with implicit user feedback Expired - Fee Related CA2544390C (en)

Applications Claiming Priority (3)

Application Number Priority Date Filing Date Title
US10/702,626 US7345232B2 (en) 2003-11-06 2003-11-06 Automatic personal playlist generation with implicit user feedback
US10/702,626 2003-11-06
PCT/IB2004/003651 WO2005046252A2 (en) 2003-11-06 2004-11-05 Automatic personal playlist generation with implicit user feedback

Publications (2)

Publication Number Publication Date
CA2544390A1 CA2544390A1 (en) 2005-05-19
CA2544390C true CA2544390C (en) 2012-05-15

Family

ID=34551702

Family Applications (1)

Application Number Title Priority Date Filing Date
CA2544390A Expired - Fee Related CA2544390C (en) 2003-11-06 2004-11-05 Automatic personal playlist generation with implicit user feedback

Country Status (8)

Country Link
US (1) US7345232B2 (en)
EP (1) EP1680930A4 (en)
JP (1) JP4242896B2 (en)
KR (2) KR20080083218A (en)
CN (1) CN1875639B (en)
BR (1) BRPI0415912A (en)
CA (1) CA2544390C (en)
WO (1) WO2005046252A2 (en)

Families Citing this family (111)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6941324B2 (en) * 2002-03-21 2005-09-06 Microsoft Corporation Methods and systems for processing playlists
US7159000B2 (en) * 2002-03-21 2007-01-02 Microsoft Corporation Methods and systems for repairing playlists
US7220910B2 (en) 2002-03-21 2007-05-22 Microsoft Corporation Methods and systems for per persona processing media content-associated metadata
US7096234B2 (en) * 2002-03-21 2006-08-22 Microsoft Corporation Methods and systems for providing playlists
US7827259B2 (en) * 2004-04-27 2010-11-02 Apple Inc. Method and system for configurable automatic media selection
US20040225519A1 (en) * 2002-06-25 2004-11-11 Martin Keith D. Intelligent music track selection
US20050021470A1 (en) * 2002-06-25 2005-01-27 Bose Corporation Intelligent music track selection
US20040117442A1 (en) * 2002-12-10 2004-06-17 Thielen Kurt R. Handheld portable wireless digital content player
EP1665252B1 (en) * 2003-09-01 2008-05-21 Koninklijke Philips Electronics N.V. Media item selection
US8554681B1 (en) * 2003-11-03 2013-10-08 James W. Wieder Providing “identified” compositions and digital-works
JP4214475B2 (en) * 2004-02-03 2009-01-28 ソニー株式会社 Information processing apparatus and method, and program
US7657885B2 (en) * 2004-04-16 2010-02-02 Gateway, Inc. System and method for downloading software and services
US20060083119A1 (en) * 2004-10-20 2006-04-20 Hayes Thomas J Scalable system and method for predicting hit music preferences for an individual
US7734569B2 (en) * 2005-02-03 2010-06-08 Strands, Inc. Recommender system for identifying a new set of media items responsive to an input set of media items and knowledge base metrics
US7756388B2 (en) * 2005-03-21 2010-07-13 Microsoft Corporation Media item subgroup generation from a library
US20060218187A1 (en) * 2005-03-25 2006-09-28 Microsoft Corporation Methods, systems, and computer-readable media for generating an ordered list of one or more media items
US7533091B2 (en) * 2005-04-06 2009-05-12 Microsoft Corporation Methods, systems, and computer-readable media for generating a suggested list of media items based upon a seed
US20110016394A1 (en) * 2005-04-18 2011-01-20 Nettune, Inc. Systems and methods of selection, characterization and automated sequencing of media content
CN100555278C (en) * 2005-07-08 2009-10-28 鸿富锦精密工业(深圳)有限公司 A kind of play list generation system and method
CN100468389C (en) * 2005-06-24 2009-03-11 鸿富锦精密工业(深圳)有限公司 Play list generation system and method
CN100468388C (en) * 2005-06-24 2009-03-11 鸿富锦精密工业(深圳)有限公司 Play list generation system and method
US7627605B1 (en) 2005-07-15 2009-12-01 Sun Microsystems, Inc. Method and apparatus for generating media playlists by defining paths through media similarity space
JP2007041722A (en) 2005-08-01 2007-02-15 Sony Corp Information processor, content reproduction device, information processing method, event log recording method and computer program
US7680824B2 (en) * 2005-08-11 2010-03-16 Microsoft Corporation Single action media playlist generation
US20070048713A1 (en) * 2005-08-12 2007-03-01 Microsoft Corporation Media player service library
US7831605B2 (en) * 2005-08-12 2010-11-09 Microsoft Corporation Media player service library
US20070048714A1 (en) * 2005-08-12 2007-03-01 Microsoft Corporation Media player service library
US7685210B2 (en) * 2005-12-30 2010-03-23 Microsoft Corporation Media discovery and curation of playlists
US20070199014A1 (en) * 2006-02-22 2007-08-23 E-Cast, Inc. Consumer portal
US8812580B2 (en) * 2006-03-15 2014-08-19 Beats Music, Llc Override of automatically shared meta-data of media
US8316081B2 (en) * 2006-04-13 2012-11-20 Domingo Enterprises, Llc Portable media player enabled to obtain previews of a user's media collection
US20070244985A1 (en) * 2006-04-13 2007-10-18 Concert Technology Corporation User system providing previews of a user's media collection to an associated portable media player
US7603434B2 (en) * 2006-04-13 2009-10-13 Domingo Enterprises, Llc Central system providing previews of a user's media collection to a portable media player
US20070245377A1 (en) * 2006-04-13 2007-10-18 Concert Technology Corporation Central system providing previews to a portable media player
US20070245378A1 (en) * 2006-04-13 2007-10-18 Concert Technology Corporation User system providing previews to an associated portable media player
US20070245376A1 (en) * 2006-04-13 2007-10-18 Concert Technology Corporation Portable media player enabled to obtain previews of media content
US20070250445A1 (en) * 2006-04-19 2007-10-25 Napster Llc Real time, on the fly, distribution of pre-selected electronic content
JP2007294036A (en) * 2006-04-26 2007-11-08 Sony Corp Information processing device and method, and program
US7822318B2 (en) * 2006-04-26 2010-10-26 Sony Ericsson Mobile Communications Ab Smart random media object playback
US8185584B2 (en) * 2006-05-31 2012-05-22 Red Hat, Inc. Activity history management for open overlay for social networks and online services
US7792903B2 (en) 2006-05-31 2010-09-07 Red Hat, Inc. Identity management for open overlay for social networks and online services
US8688742B2 (en) 2006-05-31 2014-04-01 Red Hat, Inc. Open overlay for social networks and online services
US8615550B2 (en) 2006-05-31 2013-12-24 Red Hat, Inc. Client-side data scraping for open overlay for social networks and online services
US8612483B2 (en) 2006-05-31 2013-12-17 Red Hat, Inc. Link swarming in an open overlay for social networks and online services
US9165282B2 (en) * 2006-05-31 2015-10-20 Red Hat, Inc. Shared playlist management for open overlay for social networks and online services
EP2816562A1 (en) * 2006-07-06 2014-12-24 Sundaysky Ltd. Automatic generation of video from structured content
US8560553B2 (en) * 2006-09-06 2013-10-15 Motorola Mobility Llc Multimedia device for providing access to media content
EP2110818A1 (en) * 2006-09-20 2009-10-21 John W Hannay & Company Limited Methods and apparatus for creation, distribution and presentation of polymorphic media
US20090297120A1 (en) * 2006-09-20 2009-12-03 Claudio Ingrosso Methods an apparatus for creation and presentation of polymorphic media
US20090297121A1 (en) * 2006-09-20 2009-12-03 Claudio Ingrosso Methods and apparatus for creation, distribution and presentation of polymorphic media
US7642444B2 (en) * 2006-11-17 2010-01-05 Yamaha Corporation Music-piece processing apparatus and method
US9405827B2 (en) * 2006-11-30 2016-08-02 Red Hat, Inc. Playlist generation of content gathered from multiple sources
US8463893B2 (en) * 2006-11-30 2013-06-11 Red Hat, Inc. Automatic playlist generation in correlation with local events
US8091032B2 (en) * 2006-11-30 2012-01-03 Red Hat, Inc. Automatic generation of content recommendations weighted by social network context
US8176191B2 (en) * 2006-11-30 2012-05-08 Red Hat, Inc. Automated identification of high/low value content based on social feedback
US9021045B2 (en) * 2006-11-30 2015-04-28 Red Hat, Inc. Sharing images in a social network
US8812582B2 (en) * 2006-11-30 2014-08-19 Red Hat, Inc. Automated screen saver with shared media
US20080133475A1 (en) * 2006-11-30 2008-06-05 Donald Fischer Identification of interesting content based on observation of passive user interaction
US8832277B2 (en) * 2006-11-30 2014-09-09 Red Hat, Inc. Community tagging of a multimedia stream and linking to related content
US8943210B2 (en) * 2006-11-30 2015-01-27 Red Hat, Inc. Mastering music played among a plurality of users
US8060827B2 (en) 2006-11-30 2011-11-15 Red Hat, Inc. Method and system for preloading suggested content onto digital video recorder based on social recommendations
US20130031104A1 (en) * 2007-01-04 2013-01-31 Choicestream, Inc Recommendation jitter
JP2008178037A (en) * 2007-01-22 2008-07-31 Sony Corp Information processing device, information processing method, and information processing program
DE102007006432B4 (en) * 2007-02-05 2010-07-08 Arndt-Helge Grap Apparatus and method for providing data
JP2008204506A (en) * 2007-02-16 2008-09-04 Onkyo Corp Content list generating apparatus
US7700865B1 (en) * 2007-03-05 2010-04-20 Tp Lab, Inc. Method and system for music program selection
US20080320415A1 (en) * 2007-06-22 2008-12-25 Nokia Corporation Apparatus, method and computer-readable storage medium for accessing media content
US20090013260A1 (en) * 2007-07-06 2009-01-08 Martin Keith D Intelligent music track selection in a networked environment
JP4470189B2 (en) * 2007-09-14 2010-06-02 株式会社デンソー Car music playback system
TW200919206A (en) * 2007-10-17 2009-05-01 Micro Star Int Co Ltd Method of automatically creating play lists on multimedia player
US8094891B2 (en) * 2007-11-01 2012-01-10 Sony Ericsson Mobile Communications Ab Generating music playlist based on facial expression
CN101448009B (en) * 2007-11-27 2013-02-20 鸿富锦精密工业(深圳)有限公司 Music synchronous playing system and method therefor and music player
EP2068255A3 (en) * 2007-12-07 2010-03-17 Magix Ag System and method for efficient generation and management of similarity playlists on portable devices
US8642872B2 (en) * 2008-03-03 2014-02-04 Microsoft Corporation Music steering with automatically detected musical attributes
US8122037B2 (en) * 2008-05-12 2012-02-21 Research In Motion Limited Auto-selection of media files
US8706690B2 (en) 2008-05-12 2014-04-22 Blackberry Limited Systems and methods for space management in file systems
US10552384B2 (en) 2008-05-12 2020-02-04 Blackberry Limited Synchronizing media files available from multiple sources
GB2457968A (en) * 2008-08-06 2009-09-02 John W Hannay & Co Ltd Forming a presentation of content
US8601003B2 (en) * 2008-09-08 2013-12-03 Apple Inc. System and method for playlist generation based on similarity data
US8392505B2 (en) * 2008-09-26 2013-03-05 Apple Inc. Collaborative playlist management
CN102165527B (en) * 2008-09-29 2014-08-27 皇家飞利浦电子股份有限公司 Initialising of a system for automatically selecting content based on a user's physiological response
US20100235328A1 (en) * 2009-03-10 2010-09-16 Nokia Corporation Method and apparatus for tracking content playback
US8655464B2 (en) * 2009-06-09 2014-02-18 Microsoft Corporation Adaptive playlist onboard a vehicle
US9106803B2 (en) * 2009-07-30 2015-08-11 Cellco Partnership Broadcast media information capture and communication via a wireless network
US20110060738A1 (en) * 2009-09-08 2011-03-10 Apple Inc. Media item clustering based on similarity data
US8782035B2 (en) 2009-09-17 2014-07-15 My6Sense Inc. Syndicated data stream content provisioning
US20110129201A1 (en) * 2009-11-30 2011-06-02 International Business Machines Corporation Customized playback of broadcast media
JP2011221133A (en) * 2010-04-06 2011-11-04 Sony Corp Information processing device, client device, server device, list generating method, list retrieving method, list providing method, and program
US9747948B2 (en) 2010-11-09 2017-08-29 David Wallace Croft Method of automatically modifying the probability of random selection of a presentation based on how long the user delays before skipping (time-based skip weighting)
US8805758B2 (en) 2010-11-09 2014-08-12 David Wallace Croft Method of automatically modifying the probability of random selection of a presentation based on how long the user delays before skipping (time-based skip weighting)
US8319087B2 (en) 2011-03-30 2012-11-27 Google Inc. System and method for dynamic, feature-based playlist generation
US20130097222A1 (en) * 2011-10-14 2013-04-18 Adaptive Artistry, Llc Adaptive artistry
US20130097558A1 (en) * 2011-10-14 2013-04-18 Adaptive Artistry, Llc Adaptive artistry
US9436929B2 (en) * 2012-01-24 2016-09-06 Verizon Patent And Licensing Inc. Collaborative event playlist systems and methods
US9524487B1 (en) * 2012-03-15 2016-12-20 Google Inc. System and methods for detecting temporal music trends from online services
US8788659B1 (en) 2012-03-29 2014-07-22 Google Inc. Playlist analytics
US20140040258A1 (en) * 2012-07-31 2014-02-06 Novelsong Industries Llc Content association based on triggering parameters and associated triggering conditions
US8990203B2 (en) 2012-10-10 2015-03-24 Google Inc. Methods and systems for prefetching music for devices
CN103065655B (en) * 2012-12-26 2015-11-18 广东欧珀移动通信有限公司 A kind of mobile terminal generates the method and system of song playlist automatically
CN103970802B (en) * 2013-02-05 2018-12-14 北京音之邦文化科技有限公司 A kind of method and device of song recommendations
US11803561B1 (en) * 2014-03-31 2023-10-31 Amazon Technologies, Inc. Approximation query
CN104065998B (en) * 2014-06-06 2018-09-18 惠州Tcl移动通信有限公司 A kind of mobile terminal video synchronous sharing method and its system
KR102211684B1 (en) * 2014-07-14 2021-02-03 현대모비스 주식회사 Apparatus and Method for playing media data randomly in feedback type in a vehicle
CN104978377B (en) * 2014-09-25 2019-08-23 腾讯科技(深圳)有限公司 A kind of method, apparatus and terminal of multimedia-data procession
CN104835516A (en) * 2015-05-05 2015-08-12 小米科技有限责任公司 Music playing method and apparatus, and intelligent terminal
CN105718566B (en) * 2016-01-20 2020-04-07 中山大学 Intelligent music recommendation system
CN107025277B (en) * 2017-03-27 2019-08-20 华南理工大学 A kind of Quantitative marking method of user concealed feedback
US10936653B2 (en) 2017-06-02 2021-03-02 Apple Inc. Automatically predicting relevant contexts for media items
CN108255460A (en) * 2018-01-11 2018-07-06 上海展扬通信技术有限公司 Music shuffle method, mobile terminal and computer readable storage medium
WO2019164041A1 (en) * 2018-02-26 2019-08-29 라인플러스 주식회사 Method and system for predicting song reproduction length on basis of playlist configuration
US10885092B2 (en) 2018-04-17 2021-01-05 International Business Machines Corporation Media selection based on learning past behaviors

Family Cites Families (30)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5798785A (en) * 1992-12-09 1998-08-25 Discovery Communications, Inc. Terminal for suggesting programs offered on a television program delivery system
US5410344A (en) * 1993-09-22 1995-04-25 Arrowsmith Technologies, Inc. Apparatus and method of selecting video programs based on viewers' preferences
JP3500741B2 (en) * 1994-03-01 2004-02-23 ソニー株式会社 Channel selection method and channel selection device for television broadcasting
DK0932398T3 (en) * 1996-06-28 2006-09-25 Ortho Mcneil Pharm Inc Use of topiramate or derivatives thereof for the manufacture of a medicament for the treatment of manic depressive bipolar disorders
US5801747A (en) * 1996-11-15 1998-09-01 Hyundai Electronics America Method and apparatus for creating a television viewer profile
US6243725B1 (en) * 1997-05-21 2001-06-05 Premier International, Ltd. List building system
JP2002501343A (en) 1998-01-08 2002-01-15 トムソン ライセンシング ソシエテ アノニム Video program guide apparatus and method
US6446080B1 (en) * 1998-05-08 2002-09-03 Sony Corporation Method for creating, modifying, and playing a custom playlist, saved as a virtual CD, to be played by a digital audio/visual actuator device
KR100326337B1 (en) * 1998-09-05 2002-09-12 엘지전자주식회사 Generation and recording method of data reproduction order information on a rewritable recording medium
JP4221803B2 (en) * 1999-03-02 2009-02-12 ソニー株式会社 Storage / reproduction apparatus and storage / reproduction method
US6438752B1 (en) * 1999-06-22 2002-08-20 Mediaone Group, Inc. Method and system for selecting television programs based on the past selection history of an identified user
US20050038819A1 (en) * 2000-04-21 2005-02-17 Hicken Wendell T. Music Recommendation system and method
US6883135B1 (en) 2000-01-28 2005-04-19 Microsoft Corporation Proxy server using a statistical model
US7206775B2 (en) * 2000-07-06 2007-04-17 Microsoft Corporation System and methods for the automatic transmission of new, high affinity media
KR100886092B1 (en) * 2000-11-08 2009-02-27 코닌클리케 필립스 일렉트로닉스 엔.브이. Method of composing a list of TV or radio programs
JP3827522B2 (en) 2000-11-14 2006-09-27 パイオニア株式会社 Information reproducing apparatus, method of the same, and recording medium on which the method is programmed and recorded
MY147018A (en) * 2001-01-04 2012-10-15 Thomson Licensing Sa A method and apparatus for acquiring media services available from content aggregators
US20020103796A1 (en) * 2001-01-31 2002-08-01 Sonicblue, Inc. Method for parametrically sorting music files
US20020129693A1 (en) * 2001-03-16 2002-09-19 Brad Wilks Interactive audio distribution system
JP2003030964A (en) * 2001-07-11 2003-01-31 Sony Corp Playback device and editing device
US7149156B2 (en) * 2001-07-11 2006-12-12 Sony Corporation Editing apparatus for optical reproducing device
US7220910B2 (en) * 2002-03-21 2007-05-22 Microsoft Corporation Methods and systems for per persona processing media content-associated metadata
KR100444469B1 (en) * 2002-05-28 2004-08-16 현대자동차주식회사 Engine structure for intensifying cooling function engine coolant
US6987221B2 (en) * 2002-05-30 2006-01-17 Microsoft Corporation Auto playlist generation with multiple seed songs
JP4047135B2 (en) * 2002-10-31 2008-02-13 キヤノン株式会社 Reproduction method of toner supply container
KR20030066326A (en) * 2002-11-14 2003-08-09 바로비젼(주) Method for protecting screen in computer monitor
US20040117442A1 (en) * 2002-12-10 2004-06-17 Thielen Kurt R. Handheld portable wireless digital content player
KR100520115B1 (en) * 2002-12-27 2005-10-10 삼성전자주식회사 Apparatus and method for managing playlist
US20040131333A1 (en) * 2003-01-06 2004-07-08 Fung Kam Keung Playback device for audio and/or video content
US20050174488A1 (en) * 2003-03-10 2005-08-11 Sandeep Chennakeshu Methods, devices, and systems for displaying information from a remote electronic device

Also Published As

Publication number Publication date
WO2005046252A3 (en) 2006-03-23
WO2005046252A2 (en) 2005-05-19
BRPI0415912A (en) 2007-01-16
KR20080083218A (en) 2008-09-16
CN1875639A (en) 2006-12-06
KR20060088124A (en) 2006-08-03
CN1875639B (en) 2010-05-12
US7345232B2 (en) 2008-03-18
EP1680930A2 (en) 2006-07-19
CA2544390A1 (en) 2005-05-19
US20050098023A1 (en) 2005-05-12
JP4242896B2 (en) 2009-03-25
JP2007511857A (en) 2007-05-10
EP1680930A4 (en) 2006-11-22
KR100972400B1 (en) 2010-07-27

Similar Documents

Publication Publication Date Title
CA2544390C (en) Automatic personal playlist generation with implicit user feedback
US9992267B2 (en) Method and device for sharing a playlist at a dedicated media player device
KR100690819B1 (en) Mobile terminal having bookmark function for contents service and operation method thereof
US8544050B2 (en) Rule-based playlist engine
CN1788319B (en) Portable device for storing media content
US8543095B2 (en) Multimedia services include method, system and apparatus operable in a different data processing network, and sync other commonly owned apparatus
JP5622210B2 (en) Method and apparatus for transferring digital content from a personal computer to a portable handset
US7577757B2 (en) Multimedia synchronization method and device
KR100910975B1 (en) Method for reproducing an interactive optical disc using an internet
KR100930340B1 (en) Chat data playback method in interactive optical disk device, Chat data provision method in content providing server
US20140143204A1 (en) Intelligent identification of multimedia content for grouping
WO2008110087A1 (en) Mehtod for playing multimedia, system, client-side and server
KR100575712B1 (en) Multimedia contents searching and playing method for mobile communication terminal
WO2011156785A2 (en) Media server providing unlimited medai access over wireless infrastructure
US20070061194A1 (en) Device and method for generating commercial-containing music data and commercial-containing music data
EP1992145A1 (en) Managing playlists
JP2008182319A (en) Stream data reproduction system and reproducing method, and portable terminal device
KR20030016151A (en) Method for protecting a copyright of contents
KR100690754B1 (en) Voice recording method for mobile communication terminal
JP2006080773A (en) Server
CN102752268A (en) Streaming media on-line video-on-demand system based on Android and video-on-demand method thereof
KR20020029798A (en) System and method for providing information with multimedia using network
JP2002203117A (en) System and method for distributing book content
KR20070023277A (en) Mobile communication Terminal Deciding Play list of Contents by Received Message and method thereof

Legal Events

Date Code Title Description
EEER Examination request
MKLA Lapsed

Effective date: 20210831

MKLA Lapsed

Effective date: 20191105