1. Field of the Invention
The present invention relates generally to the art of passive preference detection, and more particularly to a system, method, and apparatus for automatically determining the media content preferences of a user who downloads streaming media content via the Internet.
2. Description of the Related Art
There are music-distribution systems in the art that record the music preferences of the users of such systems, and play back songs based on those preferences. There are also Internet sites, for example, that allow users to manually assign a score to songs, where the score reflects the user's enjoyment of the song. Based on the user's scores, such sites intelligently select songs to send to the user that the user is likely to enjoy.
Such systems have major drawbacks, however, because a score must be manually entered for each song. Entering scores is very cumbersome and may be very confusing for new or unsophisticated users. Moreover, in a portable environment, such as in a car or on a portable player, such an elaborate controller may be difficult and/or costly to implement.
Also, such systems only use each particular user's scores when calculating which songs to send to that particular user. A drawback of this approach is that such a system may only select songs that user will like with any degree of accuracy after that user has already entered scores for a large number of songs.
Accordingly, a preference detection system is desired that does not require a user to manually score songs. A system capable of passively determining a user's music preferences is therefore desired. Such a system should be capable of learning a user's preferences based on the user's responses (such as forwarding to the next song, etc.) while each song plays. Such a system should work not only with music, but also with other types of media (video, etc.).
A preference detection system is also desired that learns which songs to send a user not only based upon that user's responses, but also based upon the responses of other users to similar songs, as patterns may appear when data from enough users is analyzed.
a is a diagram illustrating the relationship between a first song and four of the first song's attributes before system learning according to an embodiment of the present invention;
b is a diagram illustrating the relationship between the first song and four of the first song's attributes after system learning according to an embodiment of the present invention;
c is a diagram illustrating the relationship between a second song and four of the second song's attributes before system learning according to an embodiment of the present invention;
d is a diagram illustrating the relationship between the second song and four of the second song's attributes after system learning according to an embodiment of the present invention;
e is a diagram illustrating the relationship between a third song and four of the third song's attributes before system learning according to an embodiment of the present invention;
f is a diagram illustrating the relationship between the third song and four of the third song's attributes after system learning according to an embodiment of the present invention;
g is a diagram illustrating the relationship between a fourth song and four of the fourth song's attributes before system learning according to an embodiment of the present invention;
h is a diagram illustrating the relationship between the fourth song and four of the fourth song's attributes after system learning according to an embodiment of the present invention;
i is a diagram illustrating the relationship between the four songs in
j is a diagram illustrating the relationship between the four songs in
For example, a score is calculated by a calculate score module 120 for each song played by the system based upon how early the “Next Song” button is hit, if at all. A song receives the highest score if it plays completely through. A song receives a low score if the “Next Song” button is hit while it is playing. The earlier into its play the “Next Song” button is hit, the lower the score.
The media content files may be streamed from a remote site. The media content files preferably contain attribute information. For example, when song files are streamed, each song may be categorized according to many attributes, such as the year the song was released, the band, the general type of music (pop, oldies, metal), where the band was from (England, America), etc. The more attributes that are associated with each song, the more accurate the system is at determining what songs the user 100 might like.
After a score is calculated and processed by a processing module 125, that score is added to a preference profile for the user 100. The user's 100 preference profile, in conjunction with the preference database 130 is used to determine which songs to send to the user 100. The preference database 130 contains a file with the user's 100 preference profile, as well as the preference profiles of every other user who has a profile with the system. The system analyzes the data in the preference database 130 and learns from patterns it detects. For example, if a user 100 typically listens to new wave hits from 80's English bands all the way through, the system will continue to play other similar songs. If, for example, the user typically listens to songs by Falco and the Human League in their entirety, the system will stream songs by other artists with many of the same attributes, such as Frankie Goes to Hollywood, to the user 100. The streamed song files are sent from an media content database 135 to the user's network-enabled entertainment cluster 115. This entertainment cluster 115 may include a computer 140, and a device for playing the songs, such as a stereo 145. In one embodiment, song files are downloaded by the computer 140, converted, and sent to the stereo 145 in a playable format.
The automatic media content preference detection system may be used in conjunction with any content distributing system, including a music distribution system over the Internet. In such an embodiment, a user 100 is able to access a music distribution service (“MDS”) site over the Internet, where the user 100 may sign up for the MDS.
After the user 100 has signed up for the MDS, the user 100 may begin using the MDS.
The program 310 typically selects a song that it has determined the user 100 is likely to enjoy. However, the program 310 will periodically select songs that it does not know whether the user 100 will like. For example, where a user's 100 profile indicates an affinity for 80s synth dance music, the program 310 may occasionally send an oldies, classical, or country song to the user to see whether the user 100 likes the song. The newer and less-developed a user's 100 profile is, the more likely it is that the program will select such a song to be sent to the user 100. Next, the selected song is sent by the MDS to the user's 100 computer 140, where it is converted into a stereo-playable format and sent to the stereo 145, where it plays 315. The system learns 320 from the user's 100 responses while the song plays. If the user 100 skips to the next song, the system will infer that the user 100 dislikes that song and its associated attributes. The earlier into the song the user 100 skips to the next song, the more the system will infer the user 100 dislikes the song. After the song finishes playing or the user 100 skips to the next song, the program then selects 310 the next song to be played and the MDS sends it to the user's 100 computer 140. This process continues until the user 100 logs out 325 of the MDS. Upon logout, the user's 100 updated preference profile is saved 330 in the preference database 130.
a is a diagram illustrating the relationship between a first song and four of the first song's attributes before system learning according to an embodiment of the present invention. In
b is a diagram illustrating the relationship between the first song and four of the first song's attributes after system learning according to an embodiment of the present invention.
c, 4e, and 4g are similar to
d, 4f, and 4h are similar to
d and 4h are similar to
i is a diagram illustrating the relationship between the four songs in
The system infers that the user really likes songs from 1983 since the user did not skip to the next song during the play of “Don't You Want Me” 400a and “Billie Jean” 400g, both songs associated with the 1983 attribute 405a. This association is illustrated by the dark circle around 1983 405a, which is darker than the circle around 1985 405c in
If the user had logged out 325 (see
The system may also be configured to handle a situation where a user 100 logs into the system, but then either walks away from his stereo 145, or simply does not pay attention to the songs being played. In such a scenario, it would be undesirable for the system to learn from the user's nonresponsiveness because any information learned may be inaccurate. Therefore, this system may be programmed to store learned information in a temporary file until the user 100 hits the “Next Song” button, or some other button, such as volume, on the user control point 105. For example, after the user hits “Next Song” on the user control point 105, then the information in the temporary user profile is moved into the permanent user profile file. The reason for this is in case the user isn't paying attention, or leaves his stereo, this system is intelligent enough to learn that after a certain number of songs have played in their entirety, that the user 100 is passively listening, if at all. Such information is not very useful in determining the user's 100 music preferences, so it is never moved from the temporary user profile file.
The speed at which the learning process occurs is determined by the program 310. A more “heavily weighted” program may be used when a fast learning process is desired. However, where a slower learning process is desired, a more “lightly weighted” program may be used. Where a heavily weighted program is used, the system quickly learns the user's 100 preferences, and if the user's content tastes change, the system will quickly adapt to these changes. On the other hand, where a lightly weighted program is used, the system will more slowly learn the user's 100 preferences. However, where a lightly weighted program is used, any isolated instances of anomalies in the user's 100 responses (such as not wanting to listen to slow songs on rainy days or when the user is depressed, or where other people with different content preferences than the user are using the system), are insufficient to drastically change the user's 100 preference profile, because it changes only slowly over time.
The program 310 in this system may also be programmed to periodically select songs based solely upon the time of day, week, year, etc. For example, in December, the program may be configured to select Christmas songs. If the program 310 learns that the user 100 does not like Christmas songs, it may start sending songs from other cultures, such as Jewish or Indian songs. Also, the program may be programmed to, based on the user's 100 preference profile, choose songs at a particular time that a radio station would also be playing. For example, where a user's profile indicates the user 100 likes some 80's music, even if the user 100 also likes other styles, the program may be programmed to select only 80's songs on a Friday night, since there are radio stations that play only 80's music on Friday nights. Other time-sensitive programs may also be handled by the program 310, such as heavy metal Saturday nights, etc.
While the description above refers to particular embodiments of the present invention, it will be understood that many modifications may be made without departing from the spirit thereof The accompanying claims are intended to cover such modifications as would fall within the true scope and spirit of the present invention. The presently disclosed embodiments are therefore to be considered in all respects as illustrative and not restrictive, the scope of the invention being indicated by the appended claims, rather than the foregoing description, and all changes which come within the meaning and range of equivalency of the claims are therefore intended to be embraced therein.
Number | Name | Date | Kind |
---|---|---|---|
5805804 | Laursen et al. | Sep 1998 | A |
6189008 | Easty et al. | Feb 2001 | B1 |
6199076 | Logan et al. | Mar 2001 | B1 |
6587127 | Leeke et al. | Jul 2003 | B1 |
6614987 | Ismail et al. | Sep 2003 | B1 |
6662231 | Drosset et al. | Dec 2003 | B1 |
20010032336 | Kaufman et al. | Oct 2001 | A1 |
20010047349 | Easty et al. | Nov 2001 | A1 |
20020019858 | Kaiser et al. | Feb 2002 | A1 |
20020032019 | Marks et al. | Mar 2002 | A1 |
20020199193 | Gogoi et al. | Dec 2002 | A1 |
Number | Date | Country | |
---|---|---|---|
20020078056 A1 | Jun 2002 | US |