Method and system for selecting media

Abstract
A system and method for selecting media. In one embodiment, the media is selected based on a desired relationship measure, a user input, relationship data, and the identity of a media file. In another embodiment, the present method and system is implemented onto portable devices, car audio systems, consumer electronics devices, cellular phones or software programs running on personal computers and any other device capable of reproducing media files.
Description
FIELD OF THE INVENTION

The present disclosure pertains to a system and method for selecting media. In one embodiment, the media is selected based on a desired relationship measure, a user input, relationship data, and the identity of a media file. In another embodiment, the present method and system is implemented onto portable devices, car audio systems, consumer electronics devices, cellular phones or software programs running on personal computers and any other device capable of reproducing media files.


BACKGROUND OF THE PRESENT DISCLOSURE

The advent of digital audio compression technologies such as MP3, combined with inexpensive devices capable of storing ever-increasing amounts of data, have led to revolutionary new ways to manage and access music collections and media files. Digital Media Players or Media Jukeboxes pioneered by Musicmatch, Real Networks, Yahoo! and others allowed users to copy their music collections from Compact Disc and Vinyl record albums to compressed digital audio formats stored on computer hard-drives.


Once stored in this format, the jukebox software allows the user to catalog and organize their media files and music collections. More importantly, advances in software allow the user unprecedented control over the playback of the recordings. Tracks can be played in any order with virtually no delay required to retrieve the track. The ‘random access’ across an entire music collection allowed users to create ordered lists of tracks in advance of playback and to skip, pause, replay, shuffle or otherwise edit the order of the playlist during playback itself.


The introduction of cheaper computer memory (RAM) led to the creation of relatively low-capacity portable music players with some of these same capabilities.


More recently, the introduction of cheaper, smaller, and relatively sturdy mass storage devices has led to a new generation of portable devices with storage capacity for thousands of songs. An entire music collection can now fit in a pocket, purse, or car audio system.


However, portable media devices often have limited resources for user interfaces. Displays are generally small because the devices themselves are small. Input devices such as button controls and choosing devices are simple. Pointing devices and keyboards are rare or unpractical. The portable device must opt for a simple user interface to ensure that the device is portable, cost-effective, easy to use, and sturdy enough to survive its intended environment.


Portable media players are designed to operate in environments that not only challenge the ability of the device to operate, but that also challenge the user to operate the device. Increasingly, portable media players are being used in automobiles. Joggers and those operating exercise equipment also commonly use portables.


With limited display and user input capabilities, the task of manipulating playlists and choosing an artist, album, or track from hundreds or thousands of choices can become burdensome. With regard to media player appliances in an automobile, when the user is operating the automobile, the task of selecting then next audio recording becomes downright dangerous. The user is forced to become passive and listen only to pre-programmed or random playlists.


Personal computer based media players have undergone a transition that can put the user in a similar predicament. Personal computer based media players are now often driving home entertainment systems consisting of component audio amplifiers and speakers. In such an environment, the listening environment may be in a different room from the Personal computer.


‘Media Center’ Personal computers use a simplified user interface displayed on a large format display device such as a television screen.


Such simplified user interfaces designed for viewing from a distance are often called ‘10 foot UIs’ referring to the typical distance of the user from the display. As with portables, the power to manipulate playlists and interact with the music based on mood or situation is reduced and the user is likely to be passive.


The ‘living room’ listening environment also may discourage the user from interacting with the music selection process. If the personal computer is remote, the user may need to walk into another room to access the interface. If the personal computer is a media center personal computer, the display must be on and switched appropriately and the interface devices (wireless remote, mouse, keyboard) accessible.


SUMMARY OF THE PRESENT DISCLOSURE

The present disclosure addresses these issues where limits of the media player interface and the complexities of the listening environment conspire to prevent the user from interacting with the selection of musical recordings.


The present disclosure describes a method and system, that enables interaction with media devices in such a way as to tailor the music program to the user, especially when the user interface to the media devices is simple and the operating environment of the user is not conducive to complex device interactions.


In a general embodiment, a method of selecting media is disclosed. In one embodiment, the method of selecting media comprises recognizing the identity of a first media file of a plurality of media files; receiving a user input indicative of a desired relationship measure and a desire to select a second media file of said plurality; accessing relationship data that indicates a relationship measure among the media files of said plurality of media files; and selecting said second media file in accordance with said desired relationship measure, said user input, said relationship data, and said identity of said first media file. In one embodiment, the relationship data is created autonomously by a media device. In another embodiment, the relationship data is communicated from a remote database. In one embodiment, the method further comprises playing said second media file on a media device.


In one embodiment, the media device may comprise a portable media player, a personal computer-based media player, a streaming appliance, a personal computer-based media player, or a cellular telephone.


In one embodiment, the method further comprises streaming said second media file to a media device.


In one embodiment, the method further comprises recognizing said identity of said second media file; receiving a user input indicative of a desired relationship measure and a desire to select a third media file of said plurality; and selecting said third media file in accordance with said desired relationship measure and said identity of said second media file. In one embodiment, the identity of said first media file comprises an artist name associated with said media file. In another embodiment, the identity of said first media file comprises a genre associated with said media file.


In one embodiment, the relationship data is based upon a statistical measure of co-occurrence of media files in a particular set of media files of said plurality of media files. In one embodiment, the set of media files may be a playlist or a media library. In another embodiment, the relationship data is established by analyzing a playback history of users of said plurality of media files. In another embodiment, the relationship data is established by analyzing playlists constructed by users of said plurality of media files. In another embodiment, the relationship data is based upon explicit user preferences. In one embodiment, the relationship data is based observed user behavior.


In one embodiment, the relationship measure correlates to a degree of similarity between said first media file and said second media file. In other embodiments, the relationship measure may correlates to a degree of similarity between said first media file and other media files of said plurality.


In one embodiment, the relationship data between one or more media files of said plurality of media files is established by human judgments. In one embodiment said human judgments comprise a categorization of said media files. In one embodiment, said relationship data is established by analyzing a statistical measure of co-occurrence of said plurality of media files in published documents. In another embodiment, said relationship data is established by a similarity of attributes associated with said plurality of media files. The attributes may comprise a mood, a tempo, or a situational preference.


In one embodiment, the relationship data is established by analyzing waveforms of said plurality of media files.


In another embodiment, said media files are represented by geometric vectors and said relationship measure is determined by geometric comparisons of said vectors. In one embodiment, said geometric comparison is a dot product operation. In a further embodiment, said geometric comparison is a calculation of distance between said vectors. In one embodiment, said relationship data is stored as a graph with said media files associated to vertexes in said graph and edges representing relationships between said media files. In a further embodiment, said edges contain weights corresponding to a strength of said relationships.


In one embodiment, said input element is a skip icon located on a user interface of a device. In one embodiment, the input element is selectable by a user contacting said user interface of said device once. In one embodiment, said user input comprises a least one user interaction with said input element. In one embodiment, said input element is voice-activated. In one embodiment, the media file may be an audio or video file.


In one embodiment, one or more computer-readable media having computer-readable instructions thereon which, when executed by one or more computing devices, implements the methods disclosed above.


In one embodiment, a method of selecting recordings for playback where a set of relationships associates the recordings comprises receiving an event to trigger selection of a new recording for playback wherein said event is associated with a magnitude; and selecting said new recording for playback based on said magnitude and said set of relationships, such that said magnitude in combination with associations between a current recording and selectable recordings affects a likelihood of selection. In one embodiment, the recordings are digital audio files.


In one embodiment, one or more computer-readable media having computer-readable instructions thereon which, when executed by one or more computing devices, implements the method of the present method. Further disclosed is a system comprising one or more computer-readable media having computer-readable instructions thereon which, when executed by one or more computing devices, implements the method of the present embodiment and a computing device embodying the one or more computer-readable media.


In one embodiment, the set of relationships is defined in terms of similarity of said recordings. In another embodiment, said similarity of said recordings is established by analyzing a playback history of users of said recordings. In one embodiment, the similarity of said recordings is established by analyzing playlists constructed by users of said recordings. In another embodiment, said similarity of said recordings is established by analyzing a statistical measure of co-occurrence of recording references in published documents. In another embodiment, the similarity of said recordings is established by a similarity of recordings associated with an artist. In another embodiment, said similarity of said recordings is established by human judgments. In one embodiment, the human judgments consist of categorization of said recordings. In one embodiment, the similarity of said recordings may be established by analyzing waveforms of said recordings, established by analyzing playback history of listeners, established by analyzing playlists constructed by users, established by analyzing the co-occurrence of said recording references in published document, established by human judgments. In one embodiment, the human judgments consist of categorization of recordings. In another embodiment, said human judgments consist of categorization of albums associated with said recordings. In this embodiment, the similarity of said recordings may be is established by a similarity of attributes associated with said recordings wherein the attributes associated with said recordings comprises a tempo, mood, or situational preferences, or any other type of category. Further the recordings or media files may comprise music videos, television programs, or movies.


In the present embodiment, the recordings may be represented by geometric vectors and a relationship strength is determined by geometric comparisons of said vectors. In a further embodiment, the geometric comparison is a dot product operation. In another embodiment, the geometric comparison is a calculation of distance between said vectors. In yet another embodiment, the relationships are stored as a graph with recordings associated to vertexes in the graph and edges representing said set of relationships between recordings. In one embodiment, the edges contain weights corresponding to said relationship strength.


In an embodiment, a method of creating sequences of recordings is disclosed. In one embodiment ,the method of creating sequence of recordings (or media files) where a set of relationships associates the recordings comprises selection of a starting recording; and selecting each subsequent recording for playback based on the previous recording by receiving as input a next skip magnitude to use and selecting the next recording such that the magnitude of skip and associations between the current recording and selectable recordings affects the likelihood of selection. Further, one or more computer-readable media may have computer-readable instructions thereon which, when executed by one or more computing devices, implements the method of the present embodiment. Further, a system may comprise one or more computer-readable media having computer-readable instructions thereon which, when executed by one or more computing devices, implements the method of claim of the present embodiment; and a computing device embodying the one or more computer-readable media.


In an embodiment, a method of selecting media is disclosed. In one embodiment, a method of selecting media comprises recognizing the value of a first attribute of a first media file of a plurality of media files; receiving a user input indicative of a desired relationship measure and a desire to select a second media file of said plurality of media files; accessing relationship data that indicates a relationship measure among the values of the first attribute of the media files of said plurality of media files; selecting a second attribute value in accordance with said desired relationship measure, said user input, said relationship data, and said first attribute value; and selecting said second media file in accordance with said selected second attribute value. Further, in the present embodiment, one or more computer-readable media having computer-readable instructions thereon which, when executed by one or more computing devices, implements the method of the present embodiment. Further, a system comprising one or more computer-readable media having computer-readable instructions thereon which, when executed by one or more computing devices, implements the method of claim of the present embodiment and a computing device embodying the one or more computer-readable media.


In one embodiment, the media file may comprise a sound recording, a principle recording artist, and/or the genre of the recording.


In a further embodiment, the method of selecting media further comprises biasing said selection of said second media file based on an additional attribute. The attribute may represents a popularity of said media file, an explicit rating of said media file, and/or the implicit rating of said media file based upon observed user behavior.


In one embodiment, a system of selecting media comprises means for recognizing the identity of a first media file of a plurality of media files; means for receiving a user input indicative of a desired relationship measure and a desire to select a second media file of said plurality; means for accessing relationship data that indicates a relationship measure among the media files of said plurality of media files; and means for selecting said second media file in accordance with said desired relationship measure, said user input, said relationship data, and said identity of said first media file.


In another embodiment, a system of selecting media files using a skip command, comprises means for recognizing the identity of a first media file of a plurality of media files; means for recognizing an end user input of a skip command, said skip command being associated with a desired relationship measure between said first media file and a second media file of said plurality; and means for identifying said second media file in accordance with said relationship measure and the occurrence of said skip command input.


In another embodiment, a system of selecting a media file for playback comprises means for receiving an event to trigger a playback function, the playback function being associated with a particular degree of similarity between a first media file being experienced by a user and other media files, the particular degree of similarity being based on data associated with the first and the other media files; means for selecting a next media file to be experienced by the user, the selection being based on at least the playback function triggered and the data associated with the first media file; and means for playing the media file.


In one embodiment a system of selecting recordings for playback where a set of relationships associates the recordings comprises means for receiving an event to trigger selection of a new recording for playback wherein the event is associated with a magnitude; and means for selecting the next recording for playback based on said magnitude and said set of relationships, such that the magnitude in combination with associations between the current recording and selectable recordings affects the likelihood of selection.


In another embodiment, a system of creating sequences of recordings where a set of relationships associates the recordings comprises means for selecting of a starting recording; and means for selecting each subsequent recording for playback based on the previous recording by accepting a user input representative of a next skip magnitude to use and selecting the next recording such that the magnitude of skip and associations between the current recording and selectable recordings affects the likelihood of selection.


In another embodiment, a system of selecting media comprises means for recognizing the value of a first attribute of the media file of a plurality of media files; means for receiving a user input indicative of a desired relationship measure and a desire to select a second media file of said plurality of media files; means for accessing relationship data that indicates a relationship measure among the values of the first attribute of the media files of said plurality of media files; means for selecting a second attribute value in accordance with said desired relationship measure, said user input, said relationship data, and said first attribute value; and means for selecting said second media file in accordance with said selected second attribute value.


In one embodiment, a computer data signal embodied in a carrier wave comprising instructions for receiving signals transmitted by network entities, wherein at least a subset of said signals comprise code for performing the steps of recognizing the identity of a first media file of a plurality of media files; receiving a user input indicative of a desired relationship measure and a desire to select a second media file of said plurality; accessing relationship data that indicates a relationship measure among the media files of said plurality of media files; and selecting said second media file in accordance with said desired relationship measure, said user input, said relationship data, and said identity of said first media file.


In another embodiment, a system comprises one or more computer-readable media having computer-readable instructions thereon which, when executed by one or more computing devices, implements the method disclosed above and a computing device embodying the one or more computer-readable media.


In one embodiment, a method of selecting media files using a skip command, comprises recognizing the identity of a first media file of a plurality of media files; recognizing a user input indicative of a skip command, said skip command being associated with a desired relationship measure between said first media file and a second media file of said plurality; and identifying said second media file in accordance with said skip command. In one embodiment, one or more computer-readable media having computer-readable instructions thereon which, when executed by one or more computing devices, implements the method of selecting media files using a skip command. In a further embodiment, a system comprises one or more computer-readable media having computer-readable instructions thereon which, when executed by one or more computing devices, implements the method of selecting media files using a skip commands and a computing device embodying the one or more computer-readable media.


In one embodiment, a method of selecting a media file for playback comprises receiving an event to trigger a playback function, the playback function being associated with a particular degree of similarity between a first media file being experienced by a user and a plurality of media files, the particular degree of similarity being based on data associated with the first and the other media files; selecting a next media file to be experienced by the user, the selection being based on at least the playback function triggered and the data associated with the first media file; and playing the media file. Further, in one embodiment, one or more computer-readable media having computer-readable instructions thereon which, when executed by one or more computing devices, implements the method of selecting a media file for playback. In another embodiment, a system comprises one or more computer-readable media having computer-readable instructions thereon which, when executed by one or more computing devices, implements the method of selecting a media file for playback; and a computing device embodying the one or more computer-readable media.


It is further noted that although the present disclosure refers to media files, all types of files that can be read by automated means to provide a perceptible experience to a user, including but not limited to files such as video and audio, are contemplated as within the scope of the present disclosure.




BRIEF DESCRIPTION OF THE DRAWINGS

The following drawing figures, which form a part of this application, are illustrative of embodiments of the present invention and are not meant to limit the scope of the invention in any manner, which scope shall be based on the claims appended hereto.



FIG. 1 is a flowchart illustrating an exemplary method of creating and/or loading relationship data onto a portable device;



FIG. 2 illustrates an exemplary system configuration or architecture creating and/or loading relationship data onto a portable device;



FIG. 3 illustrates a navigation path of an exemplary embodiment;



FIG. 4 illustrates an exemplary system configuration or architecture for creating and/or loading relationship data onto a personal computer based media appliance;



FIG. 5 is a flowchart illustrating an exemplary method of creating and/or loading relationship data onto a personal computer based media appliance;



FIG. 6 illustrates an exemplary system configuration or architecture for creating and/or loading relationship data onto a media appliance;



FIG. 7 is a flowchart illustrating an exemplary method of creating and/or loading relationship data onto a media appliance;



FIG. 8 illustrates an exemplary system configuration or architecture for creating and/or loading relationship data onto a streaming media appliance;



FIG. 9 is a flowchart illustrating an exemplary method of creating and/or loading relationship data onto a streaming media appliance;



FIG. 10 illustrates a navigation path of an exemplary embodiment;



FIG. 11 illustrates a organizational tree built on genre-based relationships;



FIG. 12 illustrates an exemplary embodiment of the artist selection logic supporting a big skip playback function using genre-based relationships;



FIG. 13 is a flowchart illustrating an exemplary embodiment of the track selection logic supporting a big skip playback function using genre-based relationships;



FIG. 14 illustrates a state machine of one exemplary embodiment;



FIG. 15 is a flowchart illustrating for determining the popularity attribute of an exemplary embodiment;



FIG. 16 illustrates an exemplary embodiment of the artist selection logic supporting a playback finctions using artist-based relationships;



FIG. 17 is a flowchart illustrating an exemplary embodiment of the track selection logic supporting playback finctions using artist-based relationships;



FIG. 18 illustrates a user interface of an exemplary embodiment;



FIG. 19 illustrates a user interface of an exemplary embodiment; and



FIG. 20 illustrates an icon of an exemplary embodiment.




DETAILED DESCRIPTION OF PREFERRED EMBODIMENTS

Several exemplary embodiments of the present disclosure will now be discussed with reference to the aforementioned figures, wherein like reference numerals refer to like components.


In general, the present disclosure relates to a method, media device, system, and user interface for selecting media. In one embodiment, media is selected based on a desired relationship measure, a user input, relationship data, and the identity of a media file on a device. Such devices include but are not limited to, a portable media device, a personal computer-based media player, a media appliance, a streaming media appliance, satellite radio or video receiver, a cellular telephone and/or any other appliance or hardware/software configuration appropriate for converting stored information into a perceptible user experience. Accordingly, each device is supported by a particular system configuration or architecture to facilitate the selection of a media.


In another embodiment of a method of selecting media, the method comprises recognizing the value of at least one attribute of a media file of a plurality of media files; receiving a user input indicative of a desired relationship measure and a desire to select a second media file of said plurality of media files; accessing relationship data that indicates a relationship measure among the values of the at least one attribute of the media files of said plurality of media files; selecting said second attribute value in accordance with said desired relationship measure, said user input, said relationship data, and said first attribute value; and selecting a second media file in accordance with said selected second attribute value.


In one embodiment, the attribute is the principle recording artist of the media file. In another embodiment, the attribute is the genre of the media file or recording. In one embodiment, the media file is a sound recording.


In a further embodiment, the method further comprises biasing the selection of the second media file based on an additional attribute. In one embodiment, the additional attribute is the popularity of the media file. In another embodiment, the additional attribute represents the explicit rating of the media file. In another embodiment, the additional attributes represents the implicit rating of the media file based upon observed user behavior tracked by one or more components of the system (e.g. user track selection, frequency of selection of a track, standard skipping to avoid a track, deletion of track from playlists, etc.).


In another embodiment, each device is supported by a particular system configuration or architecture to also facilitate the creation of the data that indicates a relationship measure among media files.


In one embodiment, when the device stores the data that indicates a relationship measure among a plurality of media files, the user is able to engage in several playback functions with respect to the plurality of media files. These interactive playback functions are described in greater detail later.


Portable Media Device Exemplary Embodiment

In one embodiment, as depicted in FIG. 1 and FIG. 2 together, a portable media device or portable media player has the capability to select a media file based on a desired relationship measure, a user input, relationship data, and the identity of a media file. Such portable media player devices include but are not limited to MP3 players such as those known by the trade names APPLE IPOD, CREATIVE LABS ZEN MICRO, DELL DJ, IRIVER H10, RIO CARBON, or cell phones incorporating such functionality, or similar devices capable of storing and/or reproducing media files. FIG. 1 depicts an exemplary method of creating, relationship data and loading the relationship data onto a portable media device. FIG. 2 depicts an exemplary system architecture or configuration for creating and then loading relationship data onto the portable media device. FIG. 2 depicts a portable music player 205 connected to a personal computer 210 which is connected to a centralized music information server 215. The portable music player 205 comprises at least one user input icon such as button 206, an optional display 207, a selection engine 209, audio rendering capabilities 203, a synchronization manager 208, a relationship graph 201 that be based on artist, genre, album or any other type of category, and audio recordings 202. The personal computer 210 comprises a music management software 212, a portable device manager 204, and an audio library 211. The centralized music information server 215 comprises a server interface adapter 213, a relationship database 214, and an identification database 216.


In addition, FIG. 1 depicts an exemplary method for creating and then loading relationship data onto a portable media device. As depicted in FIG. 1, a connection is established 100 between the portable media device, the personal computer, and a centralized music information server. In one embodiment, there may be multiple connections between the portable media device, the personal computer, and the centralized music information server. Such communication connections may be wired or wireless, LAN, WAN, WiFi, cellular, satellite, or other means of establishing communication now known or to become known. In one exemplary embodiment, there may be one type of connection between the personal computer and the portable media device and another type connection between the personal computer and the centralized music information server. Thus various types of combinations, components, and configurations for connecting the portable media device, PC, and centralized music information server are contemplated. For example, referring to FIG. 2, the personal computer 210 interfaces with the centralized music information server 215 through the music management software 212 and server interface adapter 213. Further, the personal computer 210 interfaces with the portable music player 205 through the synchronization manager 208 and the portable device manager 204. In one embodiment, the function of the portable device manager 204 is to synchronize all of the user's media library 212 which is located on the personal computer 210 with the media files located on the portable device 205. In one embodiment, synchronization may be accomplished by transferring some or all of the media files located on the personal computer to the portable device.


Turning back to FIG. 1, after the connection is established 100, the playlist data is synchronized 105 between the portable media device and the personal computer. In one embodiment, as depicted in FIG. 2, the synchronization manager 208 manages the transfer of media files from the personal computer 210 to the portable device 205. Furthermore, the synchronization manager 208 stores the transferred media files. Thus, together, the synchronization manager 208 and the portable device manager 204 work together to transfer and list all the media files on the portable device 205.


A list of files to be transferred to the portable device is built 110. In other words, a “target list” is built 110. Referring to FIG. 2, the portable device manager 204 and the synchronization manager 208 work together to create a list of associated artists (can be album, genre, or any other type of category) with the media files that will be stored on the portable device 205 at the completion of the synchronization process.


Turning back to FIG. 1, once the list of complete artists or media files (target list) is built 110, the list may be transferred 115 from the PC to a centralized music information server. In one embodiment, the centralized music information server may be located on the internet, or a network. In one embodiment, the server interface adapter processes a request containing the target list. For example, artists' names are identified, as necessary, using an identification database. In one embodiment, each artist name is assigned a unique identifier corresponding to the particular artist. It is noted that the reference to relationships based on artists is exemplary and that many other types of relationships may be used. It is contemplated in further embodiments that each media file is associated not only, or in addition to, the artist's name, but with respect to the album name, and/or genre name, or any other type of category. For example, in other embodiments, the relationships between one or more media files may be based on an album, track, ratings, user Id, genre and/or era. Of course, other metadata related to a media file may also be utilized to form relationships, depending on the file type and associated metadata. For example, if the media file is a text article, metadata may include author, title, subject or abstract.


Next, as depicted in FIG. 1, the centralized music information server constructs 120 a relationship data between media files in the target list. In one embodiment, the relationships data is a graph constructed and based on a master relationship database. In one embodiment, the graph contains a vertex for each unique artist ID (or any other type of ID) and an edge between artists that are related. The edge contains a value called a “weight” which encodes the strength of the relationship between the two artists. The relationship data set can be constructed in other ways as well, provided the information concerning interrelationships may be stored, interpreted, and accessed in accordance with the teachings set forth herein.


In the embodiment of using artist based relationships, the graph and the mapping of artists' names to IDs are encoded in such a way (for example, serialized) that it may be transferred over the network and sent to the music management software as the reply to the original request.


In an another embodiment, the relationship data between one or more media files may established at the portable device itself, without the use of a remote network server, or other connected comprising devices. In one embodiment, this may be accomplished by forming a relationship data based on analysis of the media files on the portable device and, then by digital signal processing of the device itself. In a further embodiment, the portable device could host the master database of keep or media files relationships and host a method and way for mapping the recordings or media files loaded on the portable device against this database. It should be clear that there are many possible ways to distribute the processing described in the methods of the present disclosure.


Turning back to FIG. 1, the relationship set is constructed 120 (whether via graphs and maps or some other type) 120, the relationship data is sent 125 to the personal computer. For example, referring to FIG. 2, the relationship data is sent from the centralized music server 215 to the personal computer 210 by interfacing the server interface adapter 213 and the music management software 212.


Next, turning back to FIG. 1, the server sends the relationship data to the personal computer and the personal computer sends 130 the relationship data to the portable device. For example, referring to FIG. 2, the personal computer 210 sends the relationship data set to the portable device 205 by interfacing the portable device manager 204 and the synchronization manager 204. At this time 135, the portable device or portable media player contains the relationship data set and is capable of selecting a media file based on a desired relationship measure, a user input, relationship data, and the identity of a media file. In one embodiment, the user can select the media file not only based on based on a desired relationship measure, a user input, relationship data, but also the identity of a media file. In one embodiment, this media file is the currently playing media file. In another embodiment, this media file is the currently paused media file. In one embodiment, the user can initiate the selection and/or playback of these media files on the portable device using the existing user interface buttons or other type of media device input element or icon. These playback functions are described in greater detail further below.


It will be understood throughout the disclosure herein that the specific functions and methods may be carried out in hardware, software, firmware, or combinations thereof, and the variously described features and functions can be distributed across multiple processors, or aggregated into single devices, as a matter of choice. Thus, features or functions described as operable on the device may be carried out on the personal computer, or the personal computer can be eliminated and the portable device may communicate directly with the server, or the server functions can be carried out by the personal computer without the need for the server, etc.


Also, as further described below, a stand alone device capable of autonomously creating and relationship data may carry out the features or functions described as operable on any device. In one aspect, this device has the appropriate processing power and the capability to receive and/or derive the relationship data, invoke a playback function, and to select a media file based on a desired relationship measure, a user input, the relationship data, and the identity of a media file.


Personal Computer Based Media Device Exemplary Embodiment

Another exemplary embodiment of a method, device, and system configuration for selecting a media file based on a desired relationship measure, a user input, relationship data, and the identity of a media file on a personal computer-based music management system is depicted in FIGS. 4 and 5. Examples of personal computer based music management systems include but are not limited to, systems marketed under the trade names YAHOO! MUSIC ENGINE, MUSICMATCH JUKEBOX, WINDOWS MEDIA PLAYER, APPLE ITUNES, AND REAL JUKEBOX. FIG. 5 depicts an exemplary method of creating relationship data and loading the relationship data onto the personal computer. In addition, FIG. 4 depicts an exemplary system architecture or configuration for creating and loading the relationship data onto the personal computer. As depicted in FIG. 5, a connection is established between the centralized music information server, the personal computer, at least one audio rendering device, and at least one remote or local input device 505. Furthermore, in other embodiments, a streaming server can be connected within the system. Referring to FIG. 4, the system configuration includes a personal computer 210, a centralized music information server 215, a streaming server 440, at least one remote or local input device 430, and at least one or more remote or local audio rendering device 425. In particular, the personal computer 210 includes a media management software user interface 212, audio rendering capabilities 420, a selection engine 415, and an artist relationship graph 405 (based on any type of category), an audio library 211, and a streaming library inventory 410. The centralized music information server 215 further includes a server interface adapter 213, a streaming inventory database 435, a relationship database 214, and an identification database 216. Note that it is customary in server environments to distribute load and functionality over multiple servers, thus the functionality represented by the centralized music information server may be implemented by one or more servers. For example, in FIG. 4, the personal computer 210 may be connected to the centralized music information server 215 by interfacing the media management software 212 of a personal computer based music management system 212 and the server interface adapter 213. The personal computer 210 is also connected to the streaming server 440 via the media management software 212. Additionally, the personal computer 210 is connected to at least one remote or local input device 430 via the media management software 212. The personal computer 210 is connected to at least one local or remote input device 430 that provides input events to the media management software 212. The media management software 212 renders audio using the device. Thus, the media management software 212 which may be located on the personal computer 210 acts to integrate the components used to play back the digital audio or media files.


Next, turning back to FIG. 5, after the appropriate connections are made 505, the personal computer builds 510 a list of media files, otherwise referred as a target list. For example, as referring to FIG. 4, the personal computer 210 can build the list of media files via the media management software 212. Then, the media management software 212 transmits a list of artists (or any other type of media file association) to the centralized music information server 215 through the server's interface adapter 213. In one embodiment, the list is comprised of artists associated with locally stored media files from the user's library.


Referring to FIG. 5, then the centralized music information server constructs 520 a relationship data set between the media files and the target list.


After the relationship data is constructed 520, the relationship data is sent 525 to the personal computer. For example, referring to FIG. 4, the centralized music information server 215 sends the relationship data set to the personal computer 210 through the server interface adapter 213 and the media management software 212. Thus, in one embodiment, the centralized music server can construct a relationship data set between the media files and the target list and send the relationship data to the personal computer 210 by assigning each media file an identifier, constructing a graph based on the relationship, and sending back the graph and the map of the artists' or media files' names and IDs back to the media management software located on the personal computer.


In a further embodiment, if the media management software supports streaming media files and the user has access to streaming content, either through subscription or other access modes, the server can supplement the relationships with artists or media files, not stored in the user's local library, but available through the streaming service. This optional step 530 is also depicted in FIG. 5. In one embodiment, based on the settings managed by the user, the selection engine may elect to select a track or media file from the local library or a track or media file from the available streaming library. Portions or the entirety of the streaming library inventory are transferred from the music information server database to the personal computer for use by the selection engine. In one embodiment, the software located on the PC integrates the selection engine to interactively select tracks or media files for playback based on data stored on the relationship graph. In one embodiment, the selection engine may be located on the user's personal computer. In alternate embodiments, the selection engine may be located on a remote server.


Turning back to the method depicted in FIG. 5, next, after the server sends 525 the relationship data to the personal computer, regardless of whether the personal computer accesses media files from the streaming service or personal media library, a user can now engage 535 the personal computer in selecting a media file based on a desired relationship measure, a user input, relationship data, and the identity of a media file. For example, the user can apply a playback function based on the currently playing or paused artist and/or media file. These playback functions are described in greater detail further below.


Media Appliance Exemplary Embodiment

Another exemplary embodiment of a system configuration and method for loading and/or creating relationship data onto a media appliance and/or component audio device is depicted in FIGS. 6 and 7. FIG. 6 depicts the exemplary method of creating and then loading relationship data onto a media appliance. FIG. 6 illustrates the system architecture or configuration 600 of a system for loading and/or creating a relationship data using a media appliance and/or a component audio device 610. Such media appliances or component audio devices include, but are not limited to networked component audio devices (digital multimedia receivers) marketed under trade names such as NETGEAR MP101 and LINKSYS WMSL11.



FIG. 7 depicts a connection that is established 700 between a centralized music information server, a personal computer and at least one media appliance and/or component audio device 700. In further embodiments, the component audio device or media appliance is connected to at least one remote input device or local input device and at least one external display. As depicted in FIG. 6, the system configuration 600 of the exemplary embodiment comprises a personal computer 210, a centralized music information server 215, a component audio device or a media appliance 610, at least one remote or local input device 430, and at least one external display 605. As can be seen in FIG. 6, the personal computer 210 further comprises a music management software 212, a UPNP adapter 650, an audio library 211, and a component audio device gateway 655. The centralized music information server 215 comprises a server interface adapter 213, a relationship database 214, and an identification database 216. Further, the component audio device 610 comprises a user input element, or icon such as an input button 620, a display 615, a selection engine 625, audio rendering 630, a Universal Plug & Play (UPNP) adapter 635, an artist relationship graph 640, and an audio library inventory 645. In one embodiment, the external display 605, which is connected to the component audio device 610 or media appliance, includes, but is not limited to, a TV, CRT, plasma screen, LCD or any other contemplated appliances or methods for displaying. In one embodiment, the remote input device 430 or local input device can include a remote control. For example, as depicted in FIG. 6, the component audio device or media appliance 610 is connected to the personal computer 210 via the Universal Plug & Play adaptor (UPNP) 650. In this embodiment, the UPNP adaptor 650 obtains the list of media files and transfers the media files to the audio rendering device 630 as necessary. Furthermore, the component audio device gateway 655 located on the personal computer 210 interfaces the centralized music server 215 with the selection engine 625 located on the component audio device or media appliance 610.


Turning back to FIG. 7, the personal computer builds 705 a list of media files, (target list). As discussed above, in one embodiment, the personal computer may build and synchronizes the target list with the server. Then, the target list is transferred from the personal computer to the centralized music information server. Then, the server constructs 715 a relationship data between the media files and the target list 715. In one embodiment, the relationship data is constructed by first associating each artist's name or media file with a unique identifier corresponding to the artist or media file. In one embodiment, this is accomplished using the identification database. Then, a graph is constructed based on the master relationship database. The graph contains a vertex for each unique artist or media file ID and an edge between the artist or media files that are related. The edge contains a value called a “weight” which encodes the strength of the relationship between the two artists or media files. The graph and the mapping of the artists' names to the IDs is encoded in such a way that it can be transferred over the network (serialized) and is sent to the media management software as the reply to the original request.


After the server constructs 715 the relationship data, the server either sends 720 the relationship data set to the personal computer or the server can send 730 the relationship data directly to the media appliance. In one embodiment, the server can send the relationship data set to the media appliance through a gateway program installed on a personal computer. For example, referring to FIG. 6, using the component audio device gateway 655, the server 215 can send the relationship data to the component audio device 610. If the server does not send the relationship data directly to the media appliance or component audio device 730, the server can send 720 the relationship data to the personal computer, and then the personal computer will send 725 the relationship data set to the media appliance.


Once the relationship data set is created and loaded onto the component audio device or media appliance 725/730, the user can 735 select media files on the component audio device or media appliance based upon a desired relationship measure, a user input, relationship data, and the identity of a media file. In one embodiment, referring to FIG. 6, the media appliance 610 typically interfaces with at least one remote or local input device 430 and an external display 605 so that the user can view the selection of a media file.


Streaming Media Appliance Embodiment

Another exemplary embodiment of a system and method for selecting a media file using a streaming media appliance is depicted in FIGS. 8 and 9. FIG. 9 depicts an exemplary method of creating relationship data and loading the relationship data onto a personal computer or other type of streaming media appliance. FIG. 8 depicts an architecture or configuration of a system for selecting a media file using a personal computer or other streaming appliance 805. Such streaming appliances include, but are not limited to items marketed under trade names such as the PHILIPS STREAMIUM. PC based streaming applications include services such as those marketed under trade names REAL RHAPSODY, YAHOO! UNLIMITED and MUSICMATCH ‘ON DEMAND’.


As depicted in FIG. 9a, a connection is established 900 between at least a centralized music information server, a personal computer or streaming appliance, a streaming server, an input device, and/or an audio rendering device.


Next, the user invokes 905 a playback function. Then, the personal computer or streaming appliance process 910 the playback function as a request and sends this request to a centralized music information server. (E) As depicted in FIG. 8, the system configuration of the exemplary embodiment comprises a personal computer or streaming appliance 805, a centralized music information server 215, a remote or local input device 430, and optionally, a remote audio rendering device 425. Such remote or local input devices 430 include, but are not limited to a keyboard, mouse, and/or remote control. Such remote audio rendering devices 425 include, but are not limited to a home stereo component with a wireless connection to the personal computer or streaming appliance 805. Audio rendering may also take place through direct attached amplifiers and speakers. As seen in FIG. 8, the personal computer or streaming appliance 805 comprises a streaming/interactive radio user interface 810, audio rendering capabilities 820, and at least one streaming client 815. In this embodiment, the audio is streamed from a remote server 440. The streaming client component 815 receives the audio stream from the remote server 440 and a rendering component renders the audio 820 to local or remote amplifiers and speakers. The centralized music information server 215 comprises at least a server interface adapter 213, a relationship database 214, a selection engine 830, and a streaming inventory database 825. For example, referring to FIG. 8, the personal computer or streaming appliance 805 facilitates this communication with the centralized music information server 215 through the streaming/interactive radio user interface 810 and the server interface adapter 213.


Next, turning back to FIG. 9, the centralized music information server selects 915 the next media file and returns streaming identifiers/instruction to the personal computer or streaming appliance. Then, the personal computer or streaming appliance uses the identifier/instructions to initiate 920 streaming of the next media file from the streaming server. Thus, the personal computer or streaming appliance communicates 925 with the streaming media file server. In one embodiment, referring to FIG. 8, the streaming is initiated by the streaming client 815 located on the personal computer or streaming appliance 805 and the streaming server 440.


Next, turning back to FIG. 9, the personal computer or streaming appliance renders 930 the audio. In one embodiment, referring to FIG. 8, the personal computer or streaming appliance 850 renders the audio through its audio rendering capabilities 820 which is connected to a remote audio rendering device 425.


In another exemplary embodiment, the relationship data is created autonomously by a stand alone device (not depicted). In one aspect, this device has the appropriate processing power and the capability to receive and/or derive the data used to create and implement the relationship data, and playback functions. In one exemplary embodiment, the stand alone device would have the full capabilities of the embodiments described above, yet may not require being connected to server, and/or connection to a separate audio rendering device, and/or require a separate display device.


Regardless of the particular system architecture or configuration, device, described in the exemplary embodiments above, in some embodiments, the method and system for selecting a media file is based upon relationship data. In other embodiments, the method and system for selecting a media file is based on relationship data and attributes associated with a media file. Furthermore, it is contemplated that given an appropriate set of relationship data one skilled in the art will be able to re-create the invention for a wide variety of media types and system configurations now known or hereafter to become known, whether hardware or software, wired or wireless, terrestrial or satellite-based.


One aspect of the relationship data is to denote a relationship measure. For example, the similarity of one media file to another media file. Thus, one relationship can deal with Media File A and Media File B, and the relationship is defined as the probability that Media File B will directly follow Media File A as a selected media file. In one embodiment, the relationship data may be based on these probabilities and other similar statistics that can be established or determined by analyzing explicit and/or implicit user playlist data among a population of users. The population can be large or small, from one user to many, or may in fact encompass an entire user population of a music service provider. For example, the relationship data can be based on recording and analyzing the explicit and/or implicit user behavior on an on-demand streaming media service. A community site that encourages users to publish and share playlists is another source of data that can be used to derive relationship data. Media players that report the sequence of songs played or the playlists created by end users is another source of this data. E-commerce applications that sell media, peer-to-peer applications that observe the files a user requests or downloads, or music recognition services that observe at least some of the contents of a user's media library through recognition requests are other possible sources of data that can be used to form relationship data.


In one embodiment, a relationship measure is based on a particular degree of similarity between one or more media files. In one embodiment, the degree of similarity between at least two media files is based upon whether the two media files are associated with the same or similar genre. In another embodiment, the degree of similarity between at least two media files is based upon whether the two media files are related by a statistical measure of co-occurrences in playlists, documents, purchased behavior, explicit user preferences, and/ or observed user interactions with web sites or services. In another embodiment, the degree of similarity between at least two media files is based upon whether they are associated with artists that are related by statistical measure of co-occurrences in playlist, documents, purchase behavior, explicit user preferences, or observed user interactions with web sites or services. In another embodiment, the degree of similarity between at least two media files is based upon whether they are associated with albums that are related by statistical measure of co-occurrences in playlist, documents, purchase behavior, explicit user preferences, or observed user interactions with web sites or services. In another embodiment, the degree of similarity between at least two media files is based upon whether the media files are identified as similar by expert or naïve listeners. In another embodiment, the degree of similarity between at least two media files is based upon whether the media files have similar attributes as perceived by listeners. For example, tempo, mood, and/or rhythmic power or intensity, and/or volume. In further embodiment, the degree of similarity between at least two media files is based upon whether the media files have similar attributes as extracted by algorithms that that analyze the wave forms of the recordings.


Once the relationship data is created and loaded onto the device, the user can engage in playback functions based on the currently playing artist and/or media file. These playback functions enable the user to select media based on a desired relationship measure, a user input, relationship data, and the identity of a media file. Such playback functions include, but are not limited to, a “Next” playback function, a “Small Skip” playback function and a “Big Skip” playback function. Moreover, while reference is made herein to playlists, no particular playlist or subset of media files need to be selected from, but rather the entire universe of available media may be utilized as the playlist, or any portion or subset thereof.


Each one of these playback functions or functionalities is invoked by a user input and represents a particular relationship measure between one or more media files whether based on artist, genre, album, track, ratings, another user, or era relationships. Thus, a playback function which can be invoked by a user input can correlate to a degree of similarity between media files. Invoking a playback functions allows the user to select a media file based on a desired relationship measure, a user input, relationship data, and the identity of a media file.


For example, in one embodiment, the “Next” playback function represents a high level of similarity between the currently playing or paused media file and the next media file to be played. Thus, if the user wishes the next media file to be very similar to the currently playing or paused media file, the user can invoke the “Next” playback function. The methods for invoking the playback functions are described in further detail below. Further, the “Small Skip” playback functions represents a mid level of similarity between the currently playing or paused media file and the next media file to be played. Thus, if the user wishes the next media file to be somewhat similar to the currently playing or paused media file, the user can invoke the small skip playback function. Again, the methods for invoking the playback functions are described in further detail below. Accordingly, the “Big Skip” playback function represents a low level of similarity, i.e. dissimilarity, between the currently playing or paused media file and the next media file to be played. Thus, if the user wishes the next media file to be dissimilar to the currently playing media file, the user can invoke the big skip playback function. Again, the methods for invoking the playback functions are described in further detail below. Of course, it is contemplated that there can be numerous types of playback functions each associated with a particular degree of similarity or based on any type of relationship that can be constructed between one or more media files. For example, the device could present an array of knobs or input elements to the user representing genre, era, tempo, and artist-similarity. Thus for example, a small turn of the knob would select a next track that is similar to the previous track on that dimension. A large turn of the knob would select a track that is dissimilar to the previous track along that dimension. In another embodiment, there could be multiple skip controls for genre, artist, tempo, etc., that facilitate making a small skip in genre but a big skip in artist. Other control linkages and combinations can be carried out in accordance with the teachings herein.


In one exemplary embodiment, the relationship data is created using artist relationships and is loaded onto a media or device. Of course any type of relationship may be used such as genre, album, track, or any other type of category.


An exemplary state machine for this embodiment is depicted in FIG. 14. As can be seen in FIG. 14, the portable media player can be in a playing 1405, paused 1415, or stopped 1410 state. The user can select media files by playing, stopping, pausing within the playlist and engage in playback functions such as “Back” 1430, “Next” 1440, “Small Skip” 1435, or “Big Skip” 1445.


In one embodiment, the user can select the initial media file or track 1425 manually. In an alternative embodiment, the initial media file or track can be selected 1425 randomly.


In one embodiment, the playing state 1405 denotes that the system is reproducing a media file. From this playing state 1405, the user can invoke any one of the playback functions to select a media file. If the user selects any one of the playback functions (Back 1430, Next 1440, Small Skip 1435, or Big Skip 1445), a new media file is selected and the media device begins playing that new media file. In one embodiment, the audio rendering engine starts playback of the media file. In a further embodiment, if the user selects play during the playing state 1405, the system “re-centers” on the current track and the current track becomes the ‘Playlist Center’. For example, in an embodiment based on artist relationships, if the system is centered on artist A and the system plays related artist B, then the system can re-center on artist B if the user presses the play button while artist B is playing, meaning, artist B becomes the current or “center” (Playlist Center). In one embodiment, this means that if the user does not execute a playback function, some fixed percentage of tracks will be chosen from the artist at the “center” of the playlist and the remaining percentage will be chosen from artists that are similar to the artist at the “center”.


In one embodiment, the stopped state 1410 is similar to a start state, meaning, no media files are being played. Thus, a play event may be required to initiate playing of the media files.


In one embodiment, the “Back” playback function 1430 selects and replays the current track from the start, or plays the previous track if the current track has not yet started (or is already very near the beginning.) Furthermore, the “Back” playback function 1430 resets the Playlist Center to the artist associated with the selected track.


As can be seen in FIG. 14, when a media file is playing 1405, and the current track ends or the user invokes the “Next” playback function 1440, the next playback function logic (FIGS. 16 and 17) is executed, and the next track is selected and is played 1405.


Furthermore, when the media file is playing 1405 and the user invokes the “Small skip” playback function 1435, the small skip playback function logic (FIGS. 16 and 17) is executed and the next track is selected and is played 1405.


Accordingly, as depicted in FIG. 14, when the media file is playing 1405 and the user invokes the “Big Skip” playback function 1445, the big skip playback function logic (FIGS. 12 and 13) is executed and the next track is selected and played 1405. Also, in one embodiment, when the media player transitions from a stopped state 1410 to a playing state 1405, the media file histories are cleared 1450, that is the histories the algorithms prevent repeated media files.


In one embodiment, the system chooses the next media file based upon the artist that is the playlist center. In further embodiments, the Playlist Center can be an album, genre, track, and or era.



FIGS. 16 and 17 depict an exemplary embodiment of the logic supporting the next playback function when the relationship data is based on artist relationships. Specifically, in an embodiment where the relationship data is created from artist relationships when the next playback function is selected, the system selects the next artist based on the artist playlist center (denoted current artist in FIG. 16) as depicted in FIG. 16. Then, as depicted in FIG. 17, once the next artist is determined, the system determines which track or media file from that artist will be selected and played.


As depicted in FIG. 16, the next playback function logic is triggered when the user selects the “Next” playback function. As stated earlier, the next playback function is correlated to a particular user interface button. Alternatively, the “Next” playback function is correlated and invoked by a specific pattern of pressing a user interface button. For example, the “Next” playback function could be correlated to the fast forward button of the device's user interface or to pressing the fast forward button twice rapidly or in any other pattern. Furthermore, the “Next” playback function is preferably associated with a highly similar media file with respect to the current Playlist Center media file. In FIG. 16, the relationship and similarities are based upon how artists are related to one another and how similar one artist is to another.


First, the user invokes the “Next” playback function, 1600 by pressing the designated button or dial, key pattern, or associated key on the device's user interface or any other type of input element. In another embodiment, the “Next” playback function is invoked by a user input which can further include a voice activated command. In one embodiment, the “Next” playback function is also invoked automatically on the user's behalf when the currently playing track ends.


Next, the system determines whether the current artist is marked as exhausted or not 1601, meaning, whether the current artist has no more un-played tracks. If the current artist is not marked as exhausted, the system generates a random number between 0 and 100 and then compares 1602 this number to the focus setting position. This comparison 1602 determines whether the media file should be selected from the current artist or a related artist.


If the current artist is selected 1608, then the system attempts to select a track 1700 for the artist and determines if a track 1610 can be selected. If no track can be selected, the artist is marked 1612 as exhausted, meaning the artist has no more un-played tracks. Otherwise, a track from that artist is selected 1611 for playback.


If the artist is exhausted 1612, then the system selects 1603 a next related artist relative to the current artist. Furthermore, the system will reach this step 1603 if the system determined that the next artist to be selected should be a related artist and not the current artist.


If a track from a related artist will be chosen, all artists related to the current artist are scored 1606. In one embodiment, scores are generated based on the strength of the relationship to the current artist (stronger relationships score higher) 1606 and are biased by the history of which has been recently played. For example, related artists that have been played in the last 5 (or any other number) tracks get a score of 0.0. In one aspect, this biasing ensures that a high scoring artist who has been played in the last 5 times is not selected again.


In one embodiment, the weights in the artist relationship graphs represent the rank of the related artists. For example, the most similar artist receives rank of 1.0, the next most related artist gets a rank of 2.0, the next most related artist gets a rank of 3.0 and so on. In the present embodiment, the inverse (1.0 / rank) is used as the base score for selection of related artists. Of course, many alternate formulations are possible and should be considered as configuration or tuning parameters.


After the related artists are scored 1606, related artists and their associated scores are added 1607 into a list for selection. The process of scoring 1607 artists and adding 1607 each score to the selector list is repeated until all the related artists have been scored. If the selection list is empty 1612, the system will return 1621 a response indicating that there are no more tracks.


Once all the related artists are scored, a random number is generated and applied 1615 to the list such that the probability of selection of an element is proportional to its score relative the other elements in the list. One such technique is to ensure that all scores in the list are non-negative. A random number is generated between 0.0 and the sum of all scores in the list. The list is iterated until the sum of scores of iterated elements would equal or exceed the random number. The last element in the iteration is selected. One skilled in the art can easily implement this technique or similar ones yielding the same results.


Once the artist is determined, a track for the artist is selected 1700. If there are no more tracks to be selected from the artist, the artist is marked 1619 as exhausted and the artist is removed 1620 from the selection (selector) list. FIG. 17 depicts one exemplary embodiment of the track selection logic for an artist-based relationship embodiment.


As can be seen in FIG. 17, each track or media file associated with the selected artist is scored 1703. In one embodiment, the tracks or media files are scored relative to their popularity attribute. Thus, the position of the popularity setting determines how the popularity attribute will affect the probability of track or media file selection. The popularity position is discussed in further detail below.


Using logic similar to that described for selecting relating artists, each track or media file is scored 1703 based on track selection criteria and then added 1704 into a selection or selector list. This process (1701-1704) is repeated until all the media files or tracks for that particular artist have been scored 1703 and added 1704 to the selection list. Then a weighted random selector chooses 1707 the appropriate track. When the last track for the artist has been selected 1708 the artist is marked as exhausted 1709 and the track history is updated.


The chosen track or media file and its associated artist are added to history tables 1710, 1711. In one embodiment, the media file or track history tables prevent the same media file or track from being repeated in a single session. In a further embodiment, the artist history table ensures a variety of related artists are played. Thus, history tables are used to prevent repetition in the media files being selected. In one embodiment, the history tables are used when scoring tracks 1703 or artists 1606 for selection. In a further embodiment, the song or other attribute of the media file is added to a table to prevent alternate renditions of the same media file from appearing.


In another embodiment, a list of the last 5 (or other number) artists played is also maintained. When choosing a related artist, an artist's score is penalized to 0.0 when that artist is associated with one of the last five tracks played.


Furthermore, in one embodiment, a set of all artists played in the session is kept. In particular, a set of all artist edges that have been used is kept. When selecting the next artist, if the candidate relationship already has been used, a penalty is applied to reduce the probability of selection of the repeat edge. The penalty factor for repeat edges is a parameter to the system and is applied as a multiplicative factor to the relationship score. The repeat edge penalty factor ranges from 0.0 (maximum penalty) to 1.0 (no penalty). Thus, when the user invokes a playback function, artists or media files that have already been played will not be chosen. In one embodiment, the transition from Stopped to Playing state clears the histories and creates a new ‘session’.


In another exemplary embodiment, the logic supporting the “Small Skip” playback function is the same as “Next” playback function logic as depicted in FIGS. 16 and 17 with the exception that a new artist is always selected and this new artist becomes the Playlist Center. As described above, in an embodiment where the relationship data is created from artist relationships, when the “Small Skip” playback function is selected, the system selects the next artist based on the Playlist Center/current artist. Then, once the next artist is determined (FIG. 16), the system determines (FIG. 17) which track or media file from that artist will be selected and played and the selected artist becomes the new current artist.


In one embodiment, when the user invokes a number of “Small Skip” playback functions, the user can move through a plurality of media files in small increments with each step related to the previous step. Accordingly, the history mechanism generally prevents repeat artists, so the system will tour through the user's media library or set of media files. While each track is related to the previous track, the current track, after a number of skips, may be far removed from the starting track.


In one embodiment, in contrast to the “Small Skip” playback function, the object of the “Big Skip” playback function is to choose a track or media file that is unrelated or dissimilar to the currently playing track. In one embodiment, the relationship data score which relates every item to every other item, as used to determine the “Next” playback function logic is inverted. Thus, the Big Skip log is the same as depicted in FIGS. 16 and 17, except that the relationship score (1606 in FIG. 16) is inverted. Thus, resulting in selecting a dissimilar artist and then track.


In one embodiment, if relationship data is incomplete, that is, each artist in a graph of the relationships is only directly connected to a subset of all the artists in the graph; a ‘shortest path’ graph traversal algorithm can be used to compute the distance between any two artists. For example, the Dijkstra Shortest Path algorithm is well known to those skilled in the art and can be used for this purpose. However, often, the Dijkstra algorithm results in the second and third order relations being extremely weak compared to first order relationships. In one embodiment, a solution is to create a relationship graph that stores only the top N relations for each artist and contains homogenous weights (for example, 1.0). In this embodiment, the Shortest Path algorithm calculates the number of invoked playback functions required to get from artist A to artist B. This forms the basis of the score used to select an appropriate artist for the “Big Skip” playback function.


In a another embodiment, an alternative formulation for the “Big Skip” playback function is to use “Genre based” playback functions. The “Genre Based” playback function uses the same relationship/graph based algorithms as discussed in the embodiments above. In one aspect, a genre is a label placed on a set of artists, albums, or tracks that are thematically related. Genres can be determined by clustering the elements comprising them. Usually, however, human experts create genres by categorizing based on styles, roots, peers, and influences.


In one exemplary embodiment, a genre is comprised of a label and a ranked set of artists. The rank of an artist within the genre is determined by the ‘fit’ of the artist to the genre. Furthermore, an artist within a genre can be ranked by looking at the artist relationships and scoring based on how many of the related artists are also in the set defined by the genre.


Alternate embodiments of the present disclosure could define genres in terms of sets of albums, tracks, or other recordings. For example, other types of media such as in the television domain, one might use a channel as the genre for the programs that appear on that channel.


In one embodiment, a relationship graph is constructed for the set of genres. In the case of music and artist-based genres, the relationship strengths are defined in terms of the number of artists in common. In another embodiment, genres are ranked by number of artists in common and the rank becomes the weight in the relationship graph.


In yet another alternate embodiment, sub-genres and super-genres can also be used to define relationships and relationship data. In this embodiment, sub-genres are grouped under super-genres. When a hierarchical categorization of content is available, skips or movement from one media file to another, of different magnitudes can be achieved by going up one or more levels of the tree, making a lateral move, and descending again as illustrated in FIG. 11. As depicted in FIG. 11, a hierarchical (tree) organization of genres 1100 is depicted. Within this tree 1100, numerous playback functions such as a “Small Skip”, “Medium Skip”, and “Big Skip” can be executed. Furthermore, the sub-genres are represented by items such as 1118, 1111, 1113, 1105 and 1122; the super-genres are represented by items such as 1112, 1119, and 1121; and the root of the genre tree is represented by item 1120. FIG. 11 illustrates an example of how these playback functions allow the user to select a media file based in part upon genre relationships.


In particular, in FIG. 11, a “Small Skip” playback function is illustrated by a solid, bold line 1107. As shown in FIG. 11, when the user invokes the “Small Skip” playback function within a genre based hierarchy, the solid, bold line 1107 ascends to the parent node and descends to a different artist in the same sub-genre. In one embodiment, a “Small Skip” playback function represents a mid level of similarity between the currently playing media file and the media file to be played next. For example, in FIG. 11, considering the currently playing artist, Mandy Moore 1106, invoking the “Small Skip” playback function results in selecting Britney Spears 1109 as the next media file. As can be seen in FIG. 11, the solid, bold line 1107 which represents the “Small Skip” playback function 1107 begins at the artist Mandy Moore 1106, moves to the parent node, Teen Pop 1118, then descends to a different artist, Britney Spears 1109.


Similarly, in FIG. 11, a medium skip playback function is illustrated by a dotted line 1115. As shown in FIG. 11, when the user invokes the “Medium Skip” playback function within a genre-based hierarchy, the dotted line 1115 ascends two levels in the tree (up a sub genre and a genre) and then descends two levels down to another artist. In one embodiment, a “Medium Skip” playback function could represent a mid level of similarity (as compared to the Small Skip and Big Skip as described in the present embodiment) between the currently playing media file and the media file to be played next. For example, in FIG. 11, considering the currently playing artist, Kylie Minogue 1110, invoking the “Medium Skip” playback function results in selecting Abba 1114 as the next artist file. As can be seen in FIG. 11, the dotted line 1115 which represents the “Medium Skip” playback function begins at the artist Kylie Minogue 1110, moves up two parent nodes Dance Pop 1111 and Pop 1112, and then descends down two a different node Euro Pop 1113 and then to a different artist, Abba 1109.


Further, in FIG. 11, a “Big Skip” playback function is illustrated by a dashed line 1117. As shown in FIG. 11, when the user invokes the “Big Skip” playback function within a genre-based hierarchy, the dashed line 1117 ascends three levels in the tree and then descends three levels down to another artist.


In one embodiment, a “Big Skip” playback function could represent a low level of similarity or dissimilarity (as compared to the Small Skip and Medium Skip as described in the present embodiment) between the currently playing or paused media file and the media file to be selected next. For example, in FIG. 11, considering the currently playing artist, Aerosmith 1116, invoking the “Big Skip” playback function results in selecting Diana Krall 1123 as the next media file. As can be seen in FIG. 11, the dashed line 1117 which represents the “Big Skip” playback function 1117 begins at the artist Aerosmith 1116, moves up three parent nodes Album Rock 1105, Rock 1119, and All Genres 1120, and then descends down two different nodes Jazz 1121, Swing 1122 and then to a different artist, Diana Krall 1123.


An exemplary embodiment of the logic supporting a “Big Skip” playback function using genre based relationships is illustrated in FIG. 12. First, the “Big Skip” playback function logic is invoked by the user via the device's existing user interface 1200. Next, the currently playing artist is mapped to a genre 1201. In one embodiment, the currently playing artist is mapped to a genre using an artist to genre map. For example, the artist to genre mapping can come from the central music database and may be stored a part of the artist relationship graph. Thus, for each artist in the graph, a genre is also stored. The genre for the current artist is now called the current genre.


For each genre, a score is calculated based on the strength of the relationship between itself and the current genre. When a genre score has been calculated 1205, the genre/score pair is added 1206 to a selection list. This process (1202-1206) continues until all the genres have been scored and added into the selection list. Thus, the algorithm loops on all genres related to the Current Genre. In one embodiment, the genre relationships are obtained from the centralized music information server's relationship database along with the artist relationships.


In one embodiment, for “Big Skip” playback functions, the score 9 is related to the inverse of the relationship strength. That is, similar genres yield smaller scores resulting in less probability of selection. One such scoring is to take the relationship rank as the score, or 1000 if there is no relationship between the genres. Many other methods of calculating score are possible. In another embodiment, for “Medium Skip” playback functions based on genre, the selection may be heavily biased towards the related genres. In other words, the inverse of the “Big Skip” scoring method can be used: 1.0 /relationship rank.


Once all genres have been scored 1205 and added 1206 the selection list, a genre is selected from the selection list 1209 with the probability of selection equal to the genre score divided by the sum of all scores of genres added to the selector. If there are no eligible genres, the selection list will be empty 1207 and a ‘No More Tracks’ status is returned 1208.


Once a genre has been selected 1209, an artist and track are selected for the genre 1210. An exemplary embodiment of selecting an artist and track for the genre 1210 is depicted in further detail in FIG. 13. If an artist/track cannot be selected for the genre 1211, the genre is marked as exhausted 1213 and is removed 1214 from the selection list. The genre selection is retired until a track is found 1212 or all genres are exhausted.



FIG. 13 depicts an exemplary embodiment of selecting and artist and track once the genre has been selected as depicted in FIG. 12. Specifically, FIG. 13 illustrates exemplary logic supporting the artist and track selection in a “Big Skip” playback function using genre based relationships.


In one embodiment, each artist is scored 1304 based on its ‘fit’ to the current genre. In one embodiment, ‘fit’ is based on the size of the intersection of the set of artists in the genre and the set of artists comprising the related artists for the given artist. In an alternate embodiment, the score is based on artist popularity scaled by the ‘fit’ metric.


When an artist score has been calculated 1304, the artist/score pair is added 1305 to a selection list. This process (1301-1305) continues until all the artists have been scored and added to the selector list. In other words, the algorithm loops over all artists associated with the selected Genre.


Once all eligible artists have scored 1304 been added to the Selector List 1305, an artist is selected 1307 such that the probability of selection is equal to the artist score divided by the sum of all scores of artists added to the selector list.


Once an artist is selected 1307, the track is selected 1700 for the artist as described previously and depicted in FIG. 17. If there are no eligible tracks for the artist 1309, the artist is marked as exhausted 1310, removed 1311 from the selector or selection list, and a new artist is selected. If all eligible artists are exhausted 1306, the ‘No More Tracks’ status is returned 1313.


Thus, in one embodiment, the user can select a media file by invoking a series and combination of playback functions as described above. In other words, when the user invokes a number of playback functions, through a user input, the user is selecting a media file based on a first media file and the playback function which represents a relationship measure between the first media file and the media file to be selected. Thus, the user can move through a plurality of media files in designated increments, depending on the playback function invoked, with each step related to the previous step.



FIG. 3 illustrates an exemplary embodiment of a selection engine's interface which shows the navigation path of a session constrained to the contents of a local library consisting of about 2000 media files. Artist based relationships are used for small skips as described in FIGS. 16-17. Genre based relationships are used for medium and big skips as described in FIGS. 12 and 13. As stated above, in one embodiment, the device keeps track of what has been played and skipped, and avoids repeating tracks. As can be seen in FIG. 3, a tab 310 with a large window pane 300 is displayed with a text box 305 denoting a starting artist 315 a button with the word “Random” 313, a “Back” button 380, a “Play” button 390 a “Next” button 303, a “Stop” button 309, a “Small Skip” button 385, a “Medium Skip” button 395, and a “Big Skip” button 307. In FIG. 3, the window pane 300 includes lists of artists and associated tracks (Items numbered 315-375). Within this list, a playback function is denoted in parentheses before each artist entry. Thus, the list of artists in the window pane shows not only the artist's name and media file title relative to the starting artist 315, but also the associated playback function invoked by the user prior resulting in the selection of that media file. Accordingly, the window pane 300 shows the navigation path of the particular session. Meaning, the order and selection of playback functions the user invoked and what media files that were selected in a particular session.


For example, as in FIG. 3, The Clash is the starting artist 315. As can be seen in the window pane 300, The Clash is listed 315, and in parentheses the term “Play” appears before it, denoting that The Clash is the first artist selected when the user initiated the playback function or the user input session by pressing the “Play” button. The next playback function invoked by the user was a “Big Skip” playback function 307, which selected the artist M.C. Hammer and the track “Pray 320”. In other words, the user selected a “Big Skip” playback function, meaning that the user desired the next media file's artist to be dissimilar from the currently playing artist, The Clash 315. Accordingly, as can be seen in FIG. 3, M.C. Hammer 320 was selected, a dissimilar artist relative to the Clash 315.


Next, the user invoked a series of several “Big Skip” playback functions 320-355, each rendering a media file which had a dissimilar artist with respect to the previous media file.


In another example, Diana Krall, “Deed I Do” 355 was the currently playing artist and track. Then, the user invoked the “Small Skip” playback function and the artist Charlie Christian and track “I found a new baby” 360 was selected. Thus, by invoking the “Small Skip” playback function, the user was able to move from one artist to a somewhat similar artist.


Similarly, FIG. 10 illustrates a sessions' navigation when constrained to a large streaming service catalog containing several hundred thousand tracks. In one embodiment, artist based relationships may be used for small skips as described in FIGS. 16-17 and genre based relationships are used for medium and big skips as described in FIGS. 12-13.


As can be seen in FIG. 10, a tab 1000 with a large window pane 1003 is displayed with a text box 1001 denoting a starting artist 1010, a “Back” button 1004, a “Play” button 1006, a “Next” button 1008, a “Stop” button 1027, a “Small Skip” button 1005, a “Medium Skip” button 1007, and a “Big Skip” button 1009.


In FIG. 10, a window pane 1003 includes lists of artists and associated tracks (Items numbered 1011-1026) in a session. As can be seen in FIG. 10, the session began with Rage against the machine 1010 as the starting artist. Next, the user invoked a “Big Skip” playback function and the artist Bezerra Da Silva and the Malandragem Da um Tempo 1012 track media file was selected. In other words, as can be seen by the navigation list in window pane 1003, the currently playing artist was Rage Against the Machine 1010, then the user, desiring a dissimilar genre, invoked a “Big Skip” playback function which selected the artist (using logic as depicted in FIGS. 12-13) and track in a dissimilar genre with respect to the currently playing artist. Specifically, the currently playing media file 1011 was under the heavy metal genre and a “Big Skip” playback function selected a media file in a dissimilar genre, Salsa 1012. As can be seen in FIG. 10, the user continued to select media files based using “Big Skip”, “Medium Skip”, and “Small Skip” playback functions that selected the next media file based on a level of similarity based on genres with respect to the currently playing or paused media file. For example, in one embodiment, Miles Davis, Blue in Green 1017 a media file in the Bop genre, was the currently playing media file, then, the user invoked the “Medium Skip” playback function which selected Boney James, Ain't No Sunshine 1018, which is under the Smooth Jazz genre. Thus, by invoking the “Medium Skip” playback function the user was able to move from the Bob category to a somewhat similar category, Smooth Jazz.


Thus, the user can navigate and hone in on particular media file using a series and combination of playback functions. The user does not need to know in advance which particular file is desired, but can request and select media files using the playback functions to choose media files that are highly similar, somewhat similar, or dissimilar from the currently playing or paused media file. In one embodiment, the user can select a media file with a simple interface. However, in further embodiments, the feedback can be principally auditory. Thus, the present disclosure is well suited for use in an automobile. Furthermore, in such settings, the user can select a media file and invoke playback functions through a remote control or fob.


In a further embodiment, a user can further shape or customize the relationship data through one or more settings. In one embodiment, the user can set these settings before creating the relationship data and/or loading the relationship data onto a device. Thus, the settings will be applied during the creation and loading of the relationship data. In another embodiment, these settings can have default criteria.


In one embodiment, the user can specify these settings through a property sheet available on the device's user interface, as a software plug-in tool, or as any other graphical user interface which allows the user to select and specify one or more settings.


One exemplary embodiment of a setting is a focus setting. For example, the focus setting may be represented on a user interface as a slider or a series of radio buttons, a dial, a drop down menu, or any other visual representation of a setting. In one aspect, the focus setting biases the selection of media files relative to the currently playing media file. For example, the focus slider could bias the selection of media files relative to the currently playing artist, album, or track. Meaning, the focus setting determines the approximate probability that the next media file will be the most strongly associated item to the current playing artist, album or track. For example, the focus setting could have a range of 0-100. The 100 setting denotes that media files will be chosen largely in the order of their relationship strength to the currently playing media file will be selected. For example, if the currently playing artist is the Rolling Stones, and the focus setting is set at 100, then the only media files from the Rolling Stones will be selected.


Similarly, a 0 setting denotes that the media files related to (but not the same as) the currently playing media file will be selected. For example, again, if the currently playing artist is the Rolling Stones and the focus setting is set at 0, then only media files with artists which are related to the Rolling Stones will be selected.


Another exemplary embodiment of a setting is a popularity setting. Again, through a user interface, the popularity setting can take many forms such as, but not limited to, a slider, a dial, a series of radio buttons, and/or a drop down menu. In one embodiment, the popularity setting biases the selection of media files relative to the currently playing or paused media file. The 100 setting denotes that the most popular tracks relative to the currently playing media file will be chosen. Again, in one embodiment, the media file selection with respect to the currently playing media file can have a relationship set based on artist relationships, album relationships, genre, and/or era relationships.


In one embodiment, the popularity is based upon relationship or affinity data between media files. In one embodiment, where the media file selection is based on artist relationships, the popularity setting determines the track or media selection related to a particular artist.


The popularity attribute of a particular track or media file can be based and gathered from several sources such as implicit and explicit user behavior or ratings and/or implicit and explicit data collected from a large group of users. One example of implicit user behavior or input is the frequency of play for a particular media file by the user. Thus, the frequency of play can be used to determine the popularity attribute. One example of explicit user data is a rating which the user applies to a track or media file. For example, a rating system can be based on a 1 to 5 star scale where 1 star denotes a low or disfavorable rating, 3 stars denote a mid or favorable rating, and 5 stars denote a high or very favorable rating. In one embodiment, when data is collected from a large group of users, the aggregate popularity data is normalized to a 1 to 5 star ranking. The tracks can be ranked relative to each other. For example, the top 10% media files are those media files with a 5 star rating. The next 15% media files are a 4 star rating. The middle 50% are a 3 star rating. The following 15% media files are a 2 star rating, and the bottom 10% media files are a 1 star rating.


In one embodiment, the system determines the popularity attribute from a hierarchical process using the available data. An exemplary process for determining the popularity attribute of each media file is depicted in FIG. 15. This process ensures that each media file is assigned a popularity rating. In FIG. 15, the system determines 1505 if an explicit user rating is available for the particular media file. An explicit user rating may be rating consciously applied to a media file by a user. If an explicit user rating is available, then the system assigns 1510 this rating to the particular media file. If an explicit user rating is not available, then the system determines 1515 if aggregate popularity gathered from a large number of users is available 1515. In one embodiment, “a large number of users” can refer to the users in an on-demand, streaming music service or a similar online community. If an aggregate popularity attribute is available, then the system assigns 1520 this attribute or rating to the media file. If aggregate popularity data from a large number of users is not available, then the system determines 1525 whether popularity attributes based on the users' frequency of play is available 1525. If this data is available, the system assigns 1530 this popularity attribute or rating to the media file. If the frequency of play popularity attribute is not available, then the system assigns 1535 a default popularity attribute or rating to the media file 1535. For example, the default popularity attribute could be an average rating such as a 3.0 on a 1 to 5 star rating scale.


Once every media file is assigned a popularity attribute, the position of setting of the popularity setting is used to determine the appropriate scoring function. For example, Table 1 below illustrates an exemplary table which associates popularity settings with a scoring function. In this table, probabilities are shown assuming 10% of the population is 5 star, 15% is 4 star, 15% is 2 star, and 10% is 1 star.

TABLE 1SliderScoringChance ofChance ofChance ofChance ofChance ofpositionFunction f(n)1 star2 star3 star4 star5 starN/A1/n{circumflex over ( )}299.5%  0.24%  0.20%  0.06%  0.01%  <151/nlogn + filter96%4%00015-291/nlogn90%3.5%   5% 1% .5%30-441/n84%5% 8%1.7%  .8%45-54Flat10%15% 50%15%10%55-69Nlogn .1%8%50%22%20%70-84n{circumflex over ( )}2˜0%4%39%26%31% 85-100N{circumflex over ( )}2 + filter00045%65%


Similarly, the 0 setting denotes that the least popular tracks will be selected. This allows the user to play less commonly known media files from the area of the particular playlist center (artist, album, track, genre, and/or era).


Accordingly, focus and popularity settings have selectors ranging in between the 0 and 100 settings. For example, in an embodiment based on artist relationships, if the focus setting is set to 75, the system will choose media files from the currently playing artist 75% of the time and will choose media files from related artists (relative to the currently playing artist) 25% of the time.


Furthermore, in one embodiment, the user can select settings in both the focus and popularity settings. This allows the user to shape or customize the media files available for selection based on a specified level of popularity and diversity with respect to the currently playing media files.


As stated above, once relationship data is created and/or loaded onto a device, the user can invoke any number of playback functions. Generally, the user invokes these playback functions by a user input or using the device's existing user interface. For example, in one embodiment, each playback function is associated with a button, key, dial, switch, touch screen, or key pattern of the device's user interface. For example, FIG. 18 depicts an user interface of one exemplary embodiment. As can be seen in FIG. 18, the user interface comprises of a wheel or dial 1805 with a fast forward icon 1810, a rewind icon 1820, and a pause, play, or stop icon 1815. FIG. 19 depicts another wheel or dial user interface 1805 of another exemplary embodiment with similar icons.


In another example, most media rendering devices contain a fast forward icon a rewind icon and a play or pause icon. FIG. 20 depicts one exemplary embodiment of icons that may be used to invoke a playback function. As can be seen in FIG. 20, FIG. 20a depicts a rewind icon, FIG. 20b depicts a fast forward icon, and FIG. 20c depicts a pause or play icon. Thus, in one example, the “Next” playback function can be invoked by pressing the fast forward button (FIG. 20b) once, the “Small Skip” playback function can be invoked by double-clicking the Fast Forward (FIG. 20b) button twice rapidly; and the “Big Skip” playback function can be invoked by pressing down the fast forward button (FIG. 20b) for at least one second and then letting go. Thus, once the relationship is created and/or loaded onto the device, the user is able to selecting a media file based on a desired relationship measure, a user input, relationship data, and the identity of a media file using the device's existing user interface.


It is important to note that the present disclosure is not dependent on a particular implementation of the user interface element for skipping and invoking playback functions. Nor is it dependent on exactly two magnitudes of skip as described as Small Skip and Big Skip. For example, if the portable device has a wheel or dial base scroll mechanism, an appropriate implementation of the present disclosure might be to map the speed or distance traveled by the wheel or dial scroll to the magnitude of a skip performed. One exemplary embodiment of a dial based user interface is depicted in FIGS. 18 and 19. In other words, the user can perform the “Next”, “Small Skip”, and “Big Skip” playback functions on a currently-playing or paused track or media file by correlating these interactive functionalities to a specific turn or speed of turn of the wheel or dial. For example, if the user moves the wheel or dial in 45 degrees in a certain direction that could be correlated with the “Next” playback function. Thus, when the user moves the dial 45 degrees the user is signaling that he or she wishes to play a track or media file closely related to the currently-playing media file. Furthermore, a 90 degree turn of the dial to correlate to the “Small Skip” playback function. Thus, when the user turns the scroll-based dial 90 degrees the user is signifying or signaling that the user wishes to select an artist that is somewhat related to the currently playing or paused artist. Finally, if the user wishes to invoke the “Big Skip playback function, the user can turn the scroll-based dial 180 degrees. That will signal that the user wishes to select very different or not similar at all to the currently-playing artist.


Of course, the particular key, button, icon or dial associated with the playback functions will depend on the particular device. Indeed, a device with a single user input or incon element could be utilized, e.g. the entire user interface could comprise a skip button or icon.


As stated before, the method, device and system for selecting a media file based on a desired relationship measure, a user input, relationship data, and the identity of a media file on an external device encompasses not only portable music players and media files, but can also encompass video, DVDR, satellite or on-demand programming, and any other type of device capable of reproducing media. So in one embodiment, it could be applied to television programming so the effect is the pressing of certain correlated buttons on a remote will change and allow the user to select the next channel or program based on the relationship between programming. For example, in one exemplary embodiment applied to TV programming and video files, the list of programs is synchronized with the personal computer and then the personal computer sends this to the server. Again, the server initiates a list of relationships or relationship data among those programs. Those listed relationships can be based on genre, play date, play time, similar actors, similar channels, ratings. Once the server has created this list as relationship data among the media programs, it will send it back to the personal computer and then it can be loaded onto the on-demand video programming service. Next, the use can invoke playback functions by pressing particular buttons on the remote or any other user input. For example, if the user is watching a media program and hits the button which invokes the “Next” playback function, the channel will change to a television program which is very similar to the previous television program. Again, these playback functions will be invoked by buttons such as the FAST FORWARD button, the UP/DOWN button on a remote control, or any buttons located on the existing interface for the television program or on-demand programming device.


In further embodiments, it is contemplated that this relationship data is loaded onto devices with a minimal or basically no display, or where it is not practical for a user to select a media file through the display, such as an MP3 player or CD player in an automobile. Thus, it is contemplated that the control and selection of a media file, once loaded onto these types of devices, can be facilitated through voice command, a remote control, fob, which will have different keys corresponding to the playback functions, such as “Next”, “Small Skip” or “Big Skip” or other types of playback functions such as “Yes”, “No, But Close To”, “No and Not Close To.” For example, in a key-fob having at least one button, a possible mapping could be that pressing and holding the button invokes the playing function or a stop function if the playlist is currently playing. Pressing the button once could invoke the “Next” playback function and pressing the button twice could invoke the “Small Skip” playback function, three times “Big Skip” and so on.


In another example, such as an iPOd or a device with a similar key/buttons layout where the buttons point in a North, East, South, and West directions, each direction could correlate, be mapped to, or invoke a particular playback function. For example, pressing the North direction could invoke the “Big” playback function. Pressing the South direction could invoke the “Small Skip” playback function. Pressing the East direction could invoke the “Next” playback function. And pressing the West direction could invoke the “Back” playback function. Further, pressing the center could invoke the playlist to re-center on the current track.


Those skilled in the art will recognize that the method and system of the present invention within the application may be implemented in many manners and as such is not to be limited by the foregoing exemplary embodiments and examples. In other words, functional elements being performed by a single or multiple components, in various combinations of hardware and software, and individual functions can be distributed among software applications at either the client or server level. In this regard, any number of the features of the different embodiments described herein may be combined into one single embodiment and alternate embodiments having fewer than or more than all of the features herein described are possible. Functionality may also be, in whole or in part, distributed among multiple components, in manners now known or to become known. Thus, myriad software/hardware/firmware combinations are possible in achieving the functions, features, interfaces and preferences described herein. Moreover, the scope of the present invention covers conventionally known and features of those variations and modifications through the system component described herein as would be understood by those skilled in the art.

Claims
  • 1. A method of selecting media: recognizing the identity of a first media file of a plurality of media files; receiving a user input indicative of a desired relationship measure and a desire to select a second media file of said plurality; accessing relationship data that indicates a relationship measure among the media files of said plurality of media files; and selecting said second media file in accordance with said desired relationship measure, said user input, said relationship data, and said identity of said first media file.
  • 2. The method of claim 1 wherein said relationship data is created autonomously by a media device.
  • 3. The method of claim 1 wherein said relationship data is communicated from a remote database.
  • 4. The method of claim 1 further comprising playing said second media file on a media device.
  • 5. The method of claim 4 wherein said device comprises portable media player.
  • 6. The method of claim 4 wherein said device comprises a personal computer-based media player.
  • 7. The method of claim 4 wherein said device comprises a streaming appliance.
  • 8. The method of claim 4 wherein said device comprises a personal computer-based media player.
  • 9. The method of claim 4 wherein said device comprises a cellular telephone.
  • 10. The method of claim 1 further comprising: recognizing said identity of said second media file; receiving a user input indicative of a desired relationship measure and a desire to select a third media file of said plurality; and selecting said third media file in accordance with said desired relationship measure and said identity of said second media file.
  • 11. The method of claim 1 wherein said identity of said first media file comprises an artist name associated with said media file.
  • 12. The method of claim 1 wherein said identity of said first media file comprises a genre associated with said media file.
  • 13. The method of claim 1 wherein said relationship data is based upon a statistical measure of co-occurrence of media files in a particular set of media files of said plurality of media files.
  • 14. The method of claim 13 wherein said set of media files is a playlist.
  • 15. The method of claim 13 wherein said set of media files is a media library.
  • 16. The method of claim 1 wherein said relationship data is established by analyzing a playback history of users of said plurality of media files.
  • 17. The method of claim 1 wherein said relationship data is established by analyzing playlists constructed by users of said plurality of media files.
  • 18. The method of claim 1 wherein said relationship data is based upon explicit user preferences.
  • 19. The method of claim 1 wherein said relationship data is based observed user behavior.
  • 20. The method of claim 1 further comprising streaming said second media file to a media device.
  • 21. The method of claim 1 wherein said relationship measure correlates to a degree of similarity between said first media file and said second media file.
  • 22. The method of claim 1 wherein said relationship measure correlates to a degree of similarity between said first media file and other media files of said plurality.
  • 23. The method of claim 1 wherein said relationship data between one or more media files of said plurality of media files is established by human judgments.
  • 24. The method of claim 23 wherein said human judgments comprise a categorization of said media files.
  • 25. The method of claim 1 wherein said relationship data is established by analyzing waveforms of said plurality of media files.
  • 26. The method of claim 1 wherein said media files are represented by geometric vectors and said relationship measure is determined by geometric comparisons of said vectors.
  • 27. The method of claim 26 wherein said geometric comparison is a dot product operation.
  • 28. The method of claim 26 wherein said geometric comparison is a calculation of distance between said vectors.
  • 29. The method of claim 1 wherein said relationship data is stored as a graph with said media files associated to vertexes in said graph and edges representing relationships between said media files.
  • 30. The method of claim 29 wherein said edges contain weights corresponding to a strength of said relationships.
  • 31. The method of claim 1 wherein said relationship data is established by analyzing a statistical measure of co-occurrence of said plurality of media files in published documents.
  • 32. The method of claim 1 wherein said relationship data is established by a similarity of attributes associated with said plurality of media files.
  • 33. The method of claim 32 wherein said attributes comprises a mood.
  • 34. The method of claim 32 wherein said attributes comprises a tempo.
  • 36. The method of claim 32 wherein said attributes comprises a situational preference.
  • 37. The method of claim 36 wherein said input element is a skip icon located on a user interface of a device.
  • 38. The method of claim 37 wherein said input element is selectable by a user contacting said user interface of said device once.
  • 39. The method of claim 1 wherein said user input comprises a least one user interaction with said input element.
  • 40. The method of claim 1 wherein said input element is voice-activated.
  • 41. The method of claim 1 wherein said media file is an audio file.
  • 42. The method of claim 1 wherein said media file is a video file.
  • 43. One or more computer-readable media having computer-readable instructions thereon which, when executed by one or more computing devices, implements the method of claim 1.
  • 44. A method of selecting recordings for playback where a set of relationships associates the recordings comprising: receiving an event to trigger selection of a new recording for playback wherein said event is associated with a magnitude; and selecting said new recording for playback based on said magnitude and said set of relationships, such that said magnitude in combination with associations between a current recording and selectable recordings affects a likelihood of selection.
  • 45. A method of claim 44 wherein said recordings are digital audio files.
  • 46. A method of claim 44 wherein said set of relationships is defined in terms of similarity of said recordings.
  • 47. A method of claim 46 wherein said similarity of said recordings is established by analyzing a playback history of users of said recordings.
  • 48. A method of claim 46 wherein said similarity of said recordings is established by analyzing playlists constructed by users of said recordings.
  • 49. A method of claim 46 wherein said similarity of said recordings is established by analyzing a statistical measure of co-occurrence of recording references in published documents.
  • 50. A method of claim 46 wherein said similarity of said recordings is established by a similarity of recordings associated with an artist.
  • 51. A method of claim 44 wherein said similarity of said recordings is established by human judgments.
  • 52. A method of claim 51 wherein said human judgments consist of categorization of said recordings.
  • 53. A method of claim 46 wherein said similarity of said recordings is established by analyzing waveforms of said recordings.
  • 54. A method of claim 46 wherein said similarity of said recordings is established by analyzing playback history of listeners.
  • 55. A method of claim 46 wherein said similarity of said recordings is established by analyzing playlists constructed by users.
  • 56. A method of claim 46 wherein said similarity of said recordings is established by analyzing the co-occurrence of said recording references in published documents.
  • 57. A method of claim 46 wherein said similarity of said recordings is established by human judgments.
  • 58. A method of claim 57 wherein said human judgments consist of categorization of recordings.
  • 59. A method of claim 57 wherein said human judgments consist of categorization of albums associated with said recordings.
  • 60. A method of claim 46 wherein said similarity of said recordings is established by a similarity of attributes associated with said recordings.
  • 61. A method of claim 60 wherein said attributes associated with said recordings comprises a tempo.
  • 62. A method of claim 60 wherein said attributes associated with said recordings comprises a mood.
  • 63. A method of claim 60 wherein said attributes associated with said recording comprises a situational preference.
  • 64. A method of claim 44 wherein said recordings comprise music videos.
  • 65. A method of claim 44 wherein said recordings comprise television programs.
  • 66. A method of claim 44 wherein said recordings comprise movies.
  • 67. A method of claim 44 wherein said recordings are represented by geometric vectors and a relationship strength is determined by geometric comparisons of said vectors.
  • 68. A method of claim 67 wherein said geometric comparison is a dot product operation.
  • 69. A method of claim 67 wherein said geometric comparison is a calculation of distance between said vectors.
  • 70. A method of claim 44 wherein said relationships are stored as a graph with recordings associated to vertexes in the graph and edges representing said set of relationships between recordings.
  • 71. A method of claim 70 wherein said edges contain weights corresponding to said relationship strength.
  • 72. One or more computer-readable media having computer-readable instructions thereon which, when executed by one or more computing devices, implements the method of claim 44.
  • 73. A system comprising: one or more computer-readable media having computer-readable instructions thereon which, when executed by one or more computing devices, implements the method of claim 44; and a computing device embodying the one or more computer-readable media.
  • 74. A method of creating sequences of recordings where a set of relationships associates the recordings comprising: selecting of a starting recording; and selecting each subsequent recording for playback based on the previous recording by receiving as input a next skip magnitude to use and selecting the next recording such that the magnitude of skip and associations between the current recording and selectable recordings affects the likelihood of selection.
  • 75. One or more computer-readable media having computer-readable instructions thereon which, when executed by one or more computing devices, implements the method of claim 74.
  • 76. A system comprising: one or more computer-readable media having computer-readable instructions thereon which, when executed by one or more computing devices, implements the method of claim 74; and a computing device embodying the one or more computer-readable media.
  • 77. A method of selecting media, the method comprising: recognizing the value of a first attribute of a first media file of a plurality of media files; receiving a user input indicative of a desired relationship measure and a desire to select a second media file of said plurality of media files; accessing relationship data that indicates a relationship measure among the values of the first attribute of the media files of said plurality of media files; selecting a second attribute value in accordance with said desired relationship measure, said user input, said relationship data, and said first attribute value; and selecting said second media file in accordance with said selected second attribute value.
  • 78. The method of claim 77 wherein said media file comprises a sound recording.
  • 79. The method of claim 78 wherein said first attribute comprises a principle recording artist.
  • 80. The method of claim 77 wherein said first attribute comprises the genre of the recording.
  • 81. The method of claim 77 further comprising biasing said selection of said second media file based on an additional attribute.
  • 82. The method of claim 81 wherein said additional attribute represents a popularity of said media file.
  • 83. The method of claim 81 wherein said additional attributes represents an explicit rating of said media file.
  • 84. The method of claim 81 wherein said additional attributes represents the implicit rating of said media file based upon observed user behavior.
  • 85. One or more computer-readable media having computer-readable instructions thereon which, when executed by one or more computing devices, implements the method of claim 77.
  • 86. A system comprising: one or more computer-readable media having computer-readable instructions thereon which, when executed by one or more computing devices, implements the method of claim 77; and a computing device embodying the one or more computer-readable media.
  • 87. A system of selecting media, the system comprising: means for recognizing the identity of a first media file of a plurality of media files; means for receiving a user input indicative of a desired relationship measure and a desire to select a second media file of said plurality; means for accessing relationship data that indicates a relationship measure among the media files of said plurality of media files; and means for selecting said second media file in accordance with said desired relationship measure, said user input, said relationship data, and said identity of said first media file.
  • 88. A system of selecting media files using a skip command, comprising: means for recognizing the identity of a first media file of a plurality of media files; means for recognizing an end user input of a skip command, said skip command being associated with a desired relationship measure between said first media file and a second media file of said plurality; and means for identifying said second media file in accordance with said relationship measure and the occurrence of said skip command input.
  • 89. A system of selecting a media file for playback comprising: means for receiving an event to trigger a playback function, the playback function being associated with a particular degree of similarity between a first media file being experienced by a user and other media files, the particular degree of similarity being based on data associated with the first and the other media files; means for selecting a next media file to be experienced by the user, the selection being based on at least the playback function triggered and the data associated with the first media file; and means for playing the media file.
  • 90. A system of selecting recordings for playback where a set of relationships associates the recordings comprising: means for receiving an event to trigger selection of a new recording for playback wherein the event is associated with a magnitude; and means for selecting the next recording for playback based on said magnitude and said set of relationships, such that the magnitude in combination with associations between the current recording and selectable recordings affects the likelihood of selection.
  • 91. A system of creating sequences of recordings where a set of relationships associates the recordings comprising: means for selecting of a starting recording; and means for selecting each subsequent recording for playback based on the previous recording by accepting a user input representative of a next skip magnitude to use and selecting the next recording such that the magnitude of skip and associations between the current recording and selectable recordings affects the likelihood of selection.
  • 92. A system of selecting media comprising: means for recognizing the value of a first attribute of the media file of a plurality of media files; means for receiving a user input indicative of a desired relationship measure and a desire to select a second media file of said plurality of media files; means for accessing relationship data that indicates a relationship measure among the values of the first attribute of the media files of said plurality of media files; means for selecting a second attribute value in accordance with said desired relationship measure, said user input, said relationship data, and said first attribute value; and means for selecting said second media file in accordance with said selected second attribute value.
  • 93. A computer data signal embodied in a carrier wave comprising instructions for receiving signals transmitted by network entities, wherein at least a subset of said signals comprise code for performing the steps of: recognizing the identity of a first media file of a plurality of media files; receiving a user input indicative of a desired relationship measure and a desire to select a second media file of said plurality; accessing relationship data that indicates a relationship measure among the media files of said plurality of media files; and selecting said second media file in accordance with said desired relationship measure, said user input, said relationship data, and said identity of said first media file.
  • 94. A system comprising: one or more computer-readable media having computer-readable instructions thereon which, when executed by one or more computing devices, implements the method of claim 1; and a computing device embodying the one or more computer-readable media.
  • 95. A method of selecting media files using a skip command, comprising: recognizing the identity of a first media file of a plurality of media files; recognizing a user input indicative of a skip command, said skip command being associated with a desired relationship measure between said first media file and a second media file of said plurality; and identifying said second media file in accordance with said skip command.
  • 96. One or more computer-readable media having computer-readable instructions thereon which, when executed by one or more computing devices, implements the method of claim 44.
  • 97. A system comprising: one or more computer-readable media having computer-readable instructions thereon which, when executed by one or more computing devices, implements the method of claim 44; and a computing device embodying the one or more computer-readable media.
  • 98. A method of selecting a media file for playback comprising: receiving an event to trigger a playback function, the playback function being associated with a particular degree of similarity between a first media file being experienced by a user and a plurality of media files, the particular degree of similarity being based on data associated with the first and the other media files; selecting a next media file to be experienced by the user, the selection being based on at least the playback function triggered and the data associated with the first media file; and playing the media file.
  • 99. One or more computer-readable media having computer-readable instructions thereon which, when executed by one or more computing devices, implements the method of claim 98.
  • 100. A system comprising: one or more computer-readable media having computer-readable instructions thereon which, when executed by one or more computing devices, implements the method of claim 98; and a computing device embodying the one or more computer-readable media.