1. Technical Field
The present disclosure relates to assigning keyphrases to items.
2. Introduction
Media player applications are commonly used for purchasing, downloading, storing, playing, and organizing digital media items in a user's library. However, as music libraries grow, users can have a difficult time organizing and navigating through their media files to find a media item that they want to consume.
Some attempted solutions for organizing media items involve manually creating playlists of media items.
Some other attempted solutions for organizing a group of media items include displaying a list of all media items and by filtering and ordering media items vertically in the list by associated metadata.
As explained herein, improved systems, methods, and computer-readable media are needed to improve the features made available to users for navigating through libraries of media items, searching for media items, and organizing groups of media items for consumption.
Additional features and advantages of the disclosure will be set forth in the description which follows, and in part will be obvious from the description, or can be learned by practice of the herein disclosed principles. The features and advantages of the disclosure can be realized and obtained by means of the instruments and combinations particularly pointed out in the appended claims. These and other features of the disclosure will become more fully apparent from the following description and appended claims, or can be learned by the practice of the principles set forth herein.
Disclosed are systems, methods, and non-transitory computer-readable storage media for improving features that are made available to users for navigating through libraries of media items, searching for media items, and organizing groups of media items for consumption.
Some embodiments of the present technology involve receiving a user-tagged keyphrase for a media item from a subset of media libraries from among a collection of media libraries and determining that the user-tagged keyphrase meets a predefined criterion. Upon determining that the user-tagged keyphrase meets the predefined criterion, a command is sent to all of the media libraries in the collection of media libraries to associate the keyphrase with the media item.
Some embodiments of the present technology involve determining if a size of the subset of media libraries from which the user-tagged keyphrase is over a predetermined threshold, determining that a number of user-tagged keyphrases for a media item meets predefined threshold, or determining that a predetermined acceleration in the receipt of the user-tagged keyphrase is met.
Some embodiments of the present technology involve determining if the user-tagged keyphrase for a media item is located in a predetermined percentile of a distribution including all of the user-tagged keyphrases received for the media item. Some embodiments also involve filtering a user-tagged keyphrase from the plurality of user-tagged keyphrases based on rules dictating that a user-tagged keyphrase matching an existing metadata value for the media item is filtered from the distribution, rules dictating that a user-tagged keyphrase containing a proper name is filtered from the distribution, and rules dictating that a user-tagged keyphrase containing profanity is filtered from the distribution.
Some embodiments of the present technology involve associating an operator-tagged keyphrase and keyphrase meeting a criterion with the media item in a database of media items. Some embodiments involve sending a command to all of the media libraries in the collection of media libraries to associate updated keyphrases with the media item.
Some embodiments of the present technology involve sending a command to all of the media libraries in the collection of media libraries to truncate an amount of keyphrases used in association with a media item by truncating operator-tagged keyphrases and keyphrases that meet the predefined criterion in favor of updated operator-tagged keyphrases and updated keyphrases that meet the predefined criterion, but not truncating user-tagged keyphrases.
Some embodiments of the present technology involve using keyphrases to search an online store. Some embodiments of the present technology involve using keyphrases to sort media items. Some embodiments of the present technology involve using keyphrases along with a recommender system to recommend media items. Some embodiments of the present technology involve using keyphrases along with an invitational content system to serve invitational content.
In order to describe the manner in which the above-recited and other advantages and features of the disclosure can be obtained, a more particular description of the principles briefly described above will be rendered by reference to specific embodiments thereof which are illustrated in the appended drawings. Understanding that these drawings depict only exemplary embodiments of the disclosure and are not therefore to be considered to be limiting of its scope, the principles herein are described and explained with additional specificity and detail through the use of the accompanying drawings in which:
Various embodiments of the disclosure are discussed in detail below. While specific implementations are discussed, it should be understood that this is done for illustration purposes only. A person skilled in the relevant art will recognize that other components and configurations may be used without parting from the spirit and scope of the disclosure.
The present disclosure addresses the need in the art for improved media item navigation. A system, method and non-transitory computer-readable media are disclosed which improve on features that allow users to navigate through libraries of media items and organize groups of media items for consumption.
Some embodiments of the present technology involve users tagging media items with keyphrases that capture consumers' thoughts and feeling about media items. A keyphrase can include single or multiple words, partial words, acronyms, abbreviations, or emoticons including alphabetic characters, diacriticals, numerals, symbols, ideograms, or other glyphs that can convey meaning about media in a way that cannot be accomplished by traditional metadata or that can otherwise serve as delineators. In some ways, keyphrases act as metadata; however, unlike traditional metadata, keyphrases can be subjective, free-form, non-uniform for various users, etc. Although the term keyphrase is used herein, one of ordinary skill in the art having the benefit of this disclosure can utilize the disclosed technology with any way of allowing users to assign additional data to a media file.
Some embodiments of the present technology involve using keyphrases to organize media. In the case of tagging digital music files, keyphrases can be used to organize music files into meaningful groups.
In some embodiments, users can tag music files with keyphrases that imply a feeling associated with listening to a song or sentiment felt when the user first heard the song or at another time which left an emotional imprint. For example, users can tag music files as “happy,” “sad,” “inspired,” “depressed,” etc. In some embodiments, users can tag media files with tags independent from a song's original style, meaning, etc. For example, a user might tag a song as “romantic,” not because the song itself is a romantic song, but because it was the song playing when something romantic happened in the user's life.
In some embodiments, users can tag music files with situational keyphrases that describe situations that can be associated with the music. For example, users can tag music files as “exercise,” “cooking,” “snowboarding,” “romantic music,” “wedding,” etc. In a more particular example, a user can tag Pachelbel's “Cannon in D” with the keyphrase “wedding” to connote that it is a song often heard at weddings. A user may also tag The Village People's “YMCA” with the keyphrase “wedding” to provide the same connotation. Consequently, organizing a collection of music by keyphrase will group Pachelbel's “Cannon in D” with The Village People's “YMCA.”
In some embodiments users can tag music files with a place or context in which they heard a song. For example a user can tag Fleetwood Mac's original version of “Landslide” with the keyphrase “Glee” after hearing the cast of the television show Glee perform a cover of the song. In another example, a user can tag a song with “college” to establish an association between the song and his college memories.
In some embodiments users can tag music files with characteristics about the song incapable of being captured with known standard metadata definitions. For example, a song might be tagged as instrumental. By itself “instrumental” is not a genre because multiple genres can include instrumental songs. In another illustrative example, a media item can be tagged with an instrument that is highlighted in that song, e.g. “drum solo.”
In some embodiments, user-tagged keyphrases can overlap. For example, a track tagged with “exercise” could also be tagged with “happy,” or “The Biggest Loser.”
Although specific examples of tags, tag types, and keyphrases are mentioned explicitly, those with ordinary skill in the art having the benefit of this disclosure will readily appreciate that a wide variety of keyphrases can be used as tags to provide media items with a wide variety of descriptions, connotations, etc.
Some embodiments of the present technology involve interfaces and tools for allowing users to tag media items with keyphrases.
As explained above, keyphrases can allow users to organize media items.
As explained herein, some embodiments of the present technology involve users tagging their own media items with keyphrases. In some embodiments, users' self-tagged keyphrases are augmented with analyzed keyphrases or operator-defined keyphrases. Some embodiments of the present technology also involve a media platform pushing keyphrases that have been associated with a media item by other users or by a system operator.
The system 600 of
In some embodiments of the present technology, the one or more media distribution system includes an eBook distribution and management system 660, such as iBookstroreSM, available from Apple Inc. of Cupertino, Calif. In some embodiments of the present technology, the one or more media distribution system includes an application distribution and management system 650, such as App StoreSM, available from Apple Inc. of Cupertino, Calif.
In some embodiments of the present technology, the media platform 620 also includes a cloud storage component 680, such as iCloud™, available from Apple Inc. of Cupertino, Calif. In some embodiments, the cloud storage component 680 includes a processing module 682 and a storage component 684.
In some embodiments of the present technology, the media platform 620 also includes a media item recommendation system 690, such as Genius®, available from Apple Inc. of Cupertino, Calif. In some embodiments of the present technology, the media platform 620 also includes an invitational content system 691, such as iAd®, available from Apple Inc. of Cupertino, Calif.
The media platform 620 is operatively coupled with a plurality of computing devices 6021, 6022, 6023, 6024, . . . , 602n which include a media player computer program client used for playing, downloading, saving, and organizing digital media items, such as an iTunes® client for computers and mobile devices, available from Apple Inc. of Cupertino, Calif.
The media platform 620 is also operatively coupled with a plurality of media item providers 6041, 6042, 6043, 6044, . . . , 604n which upload media content, applications, updates, etc. to the media platform 620. The media platform 620 facilitates the sale, rent, license, etc. of the media content and tenders the providers 6041, 6042, 6043, 6044, . . . , 604n with a portion of a payment. In some embodiments of the present technology, the media item providers provide metadata embedded in the digital media items. For example, digital music content oftentimes includes metadata relating to artist, album, genre, track name, etc. In some embodiments of the present technology, an operator of the media platform 620 can tag the media items with keyphrases before they are sold, rented, or licensed and transferred to a computing device. In some embodiments, operator-added keyphrases help users find the media items that they are looking for or serve to introduce users to the concepts and benefits of keyphrase tagging.
As illustrated in
In some embodiments, an operator of the media platform 620 tags media items with keyphrases. In some embodiments, the uploaded user-tagged keyphrases and the operator-tagged keyphrases are stored in a keyphrase database 692.
In some embodiments of the present technology, the media platform 620 also includes a keyphrase analyzer engine 694 configured for analyzing keyphrases which are tagged and uploaded from users (referred to as a “collective set” of keyphrases) and configured for detecting one or more keyphrases associated with a media item that meet a predetermined criterion. In some embodiments, the predetermined criterion can include one or more numerical or statistical analysis on the collective set of keyphrases to determine what keyphrases are most frequently used, what keyphrases are currently most popular, what keyphrases are experiencing most growth in usage, etc.
For example, in some embodiments, all user-tagged keyphrases associated with a particular media item are arranged in a distribution and the keyphrase analyzer engine 694 determines if the user-tagged keyphrase is located in a predetermined percentile of the distribution. In another example, the keyphrase analyzer engine 694 determines if the user-tagged keyphrase meets a predetermined acceleration in the receipt of the user-tagged keyphrase from the subset of media libraries. In another example, the keyphrase analyzer engine 694 determines if a size of the subset of media libraries from which the user-tagged keyphrase is tagged is over a predetermined threshold.
In some embodiments, the keyphrase analyzer engine 694 performs one or more filtering function before determining if the user-tagged keyphrase is located in a predetermined percentile of a distribution. For example, some users will tag media items with keyphrases already described in existing metadata, e.g. tagging a Jazz song with the keyphrase “jazz.” In these cases, the keyphrase analyzer engine 694 can filter keyphrases that describe a genre from the collective set of keyphrases.
Also, the keyphrase analyzer engine 694 can filter user-tagged keyphrases containing a proper name. In another example, some users will tag media items with people's names, e.g. “Chris's Music.” To the user, “Chris's Music” might help the user organize his music, but “Chris's Music” may not help anyone else organize music. Accordingly, the keyphrase analyzer engine 694 can filter out the “Chris's Music” tag from a collective set of keyphrases.
In some embodiments, the keyphrase analyzer engine 694 can filter user-tagged keyphrases that contain profanity, describe violence, include hate speech, include sexually-explicit content, etc.
In some embodiments of the present technology, the keyphrase analyzer engine 694 is also configured for forming a subset of keyphrases for each media item that can be best used to organize the media item in users' playlists, as determined by the statistical analysis and filtering. The keyphrase analyzer engine 694 is also configured for sending the keyphrases back to the computing devices 6021, 6022, 6023, 6024, . . . , 602n that meet a predetermined criterion.
In some embodiments of the present technology, tag updates and media suggestions based on keyphrases are sent to the computing devices 6021, 6022, 6023, 6024, . . . , 602n from the media platform 620.
Some embodiments of the present technology involve methods for receiving a user-tagged keyphrase for a media item from a subset of media libraries from among a collection of media libraries and determining if the user-tagged keyphrase meets a predefined criterion. Upon determining that the user-tagged keyphrase meets the predefined criterion, a command is sent to all of the media libraries in the collection of media libraries to associate the keyphrase with the media item.
In some embodiments of the present technology, the method optionally delivers 720 operator-tagged keyphrases upon the user opting in to using keyphrases. The operator-tagged keyphrases are used to orient a user on how keyphrase tagging works and on how to organize and search for media items using keyphrases.
Next, a user tags 730 his own media items with keyphrases and the server receives 740 user-tagged keyphrases associated with media items. In some embodiments of the present technology, the server pulls user-tagged keyphrases from client applications. In some embodiments, pulling is automatically performed periodically, e.g. one per week. In some embodiments, the client device pushes user-tagged keyphrases to the server. In some embodiments, the user pushes keyphrases associated with media items each time the user requests that the media player client application match his media library with the cloud-based storage component of the server-based media distribution system. The server optionally tracks 745 user-tagged keyphrases differently than operator-tagged keyphrases.
Upon the server receiving user-tagged keyphrases, the server adds 750 the user-tagged keyphrases to a collective set of keyphrases for each media item. Next, the server analyzes 760 the collective sets of keyphrases based on a predetermined criterion to obtain a subset of keyphrases that are determined to be the most common, most popular, trending, etc.
In some embodiments of the present technology, only the user-tagged keyphrases are analyzed for a predetermined criterion. However, some embodiments involve analyzing both user-tagged keyphrases and operator-tagged keyphrases.
Next, the keyphrases meeting a predetermined criterion are pushed 770 to all users who have opted in to the media distribution system's keyphrase tagging service. Upon receiving the key phrases, users' client applications automatically add 780 keyphrases to the media items that they are associated with. Although this example involves a media distribution system pushing keyphrases to client applications, one of ordinary skill in the art having the benefit of this disclosure will appreciate that any method of transferring keyphrases can benefit from the present technology. For example, client applications can be configured with a command to pull keyphrases from a media distribution platform.
Keyphrases that people frequently associate with media items can change over time. For example, if a song is featured in a popular movie or television program, users might begin to associate the song with the movie or television show. In a more specific example, suppose the television show “Glee” performs a rendition of Fleetwood Mac's “Landslide”. After the episode of Glee airs, users may begin to tag the original version of the song with “Glee,” despite the fact that the original version was not featured on the episode.
To accommodate changing associations with media items, some embodiments of the present technology involve updating users' keyphrases.
The method 800 illustrated in
Next, the keyphrases that meet a predetermined criterion are pushed 870 to users who have opted in to the media distribution system's keyphrase tagging service and added 880 to the media items that they are associated with.
Over time, the results of analysis on the collective set of user-tagged keyphrases changes based on evolving user associations with the media items. Consequently, the method 800 involves periodically re-analyzing 890 keyphrases. In some embodiments, re-analyzing keyphrases involves reexamining whether a predetermined criterion is met, filtering new phrases from a set of keyphrases, checking for updates to a set of operator-tagged keyphrases, etc. The re-examination results in updated keyphrases being sent to and received 892 by the client device. Next, the client application replaces 894 keyphrases with the updated keyphrases. In some embodiments of the present technology, keyphrases that are annotated as user-tagged keyphrases are not replaced by updated keyphrases, but operated-tagged keyphrases and keyphrases sent because they meet a predetermined criterion are updated.
As explained above, keyphrases are very useful in organizing a media library. Additionally, keyphrases provide added utility in a number of other ways, such as searching for media items and recommending other media items to users.
In some embodiments of the present technology, a media item recommendation system uses keyphrases to analyze a user's taste and recommend other media items to the user in which they might like. In some embodiments, users' taste data can be used to recommend invitational content such as promotions or advertisements for goods or services that the user might be interested in.
In some embodiments of the present technology, a media player can be configured to search for media items using keyphrases. For example, using an example from above, a search using “wedding” as a search term can result in a list of media items tagged with “wedding” such as Pachelbel's “Cannon in D,” The Village People's “YMCA,” and “White Wedding” by Billy Idol. Likewise, following another example from above, a user searching for “Glee” can result in the system displaying Fleetwood Mac's original version of “Landslide.”
As explained above, some embodiments of the present technology involve the keyphrase analyzer engine 694 only examining user-tagged keyphrases. In some embodiments, the keyphrase analyzer engine 694 performs an individual analysis for users and only examines keyphrases tagged by a user's connections in a social media platform. In some embodiments only examines keyphrases tagged by users in a certain geographical area or nation.
The systems, methods, and computer-readable media described above can be employed in a variety of ways known to those with ordinary skill in the art having the benefit of this disclosure; however, a brief description of a basic general purpose system or computing device in
With reference to
The system bus 910 may be any of several types of bus structures including a memory bus or memory controller, a peripheral bus, and a local bus using any of a variety of bus architectures. A basic input/output (BIOS) stored in ROM 940 or the like, may provide the basic routine that helps to transfer information between elements within the computing device 900, such as during start-up. The computing device 900 further includes storage devices 160 such as a hard disk drive, a magnetic disk drive, an optical disk drive, tape drive or the like. The storage device 960 can include software modules 962, 964, 966 for controlling the processor 920. Other hardware or software modules are contemplated. The storage device 960 is connected to the system bus 910 by a drive interface. The drives and the associated computer readable storage media provide nonvolatile storage of computer readable instructions, data structures, program modules and other data for the computing device 100. In one aspect, a hardware module that performs a particular function includes the software component stored in a non-transitory computer-readable medium in connection with the necessary hardware components, such as the processor 920, bus 910, display 970, and so forth, to carry out the function. The basic components are known to those of skill in the art and appropriate variations are contemplated depending on the type of device, such as whether the device 900 is a small, handheld computing device, a desktop computer, or a computer server.
Although the exemplary embodiment described herein employs the hard disk 960, it should be appreciated by those skilled in the art that other types of computer readable media which can store data that are accessible by a computer, such as magnetic cassettes, flash memory cards, digital versatile disks, cartridges, random access memories (RAMs) 950, read only memory (ROM) 940, a cable or wireless signal containing a bit stream and the like, may also be used in the exemplary operating environment. Non-transitory computer-readable storage media expressly exclude media such as energy, carrier signals, electromagnetic waves, and signals per se.
To enable user interaction with the computing device 900, an input device 990 represents any number of input mechanisms, such as a microphone for speech, a touch-sensitive screen for gesture or graphical input, keyboard, mouse, motion input, speech and so forth. An output device 970 can also be one or more of a number of output mechanisms known to those of skill in the art. In some instances, multimodal systems enable a user to provide multiple types of input to communicate with the computing device 900. The communications interface 980 generally governs and manages the user input and system output. There is no restriction on operating on any particular hardware arrangement and therefore the basic features here may easily be substituted for improved hardware or firmware arrangements as they are developed.
For clarity of explanation, the illustrative system embodiment is presented as including individual functional blocks including functional blocks labeled as a “processor” or processor 920. The functions these blocks represent may be provided through the use of either shared or dedicated hardware, including, but not limited to, hardware capable of executing software and hardware, such as a processor 920, that is purpose-built to operate as an equivalent to software executing on a general purpose processor. For example the functions of one or more processors presented in
The logical operations of the various embodiments are implemented as: (1) a sequence of computer implemented steps, operations, or procedures running on a programmable circuit within a general use computer, (2) a sequence of computer implemented steps, operations, or procedures running on a specific-use programmable circuit; and/or (3) interconnected machine modules or program engines within the programmable circuits. The system 900 shown in
Embodiments within the scope of the present disclosure may also include tangible and/or non-transitory computer-readable storage media for carrying or having computer-executable instructions or data structures stored thereon. Such non-transitory computer-readable storage media can be any available media that can be accessed by a general purpose or special purpose computer, including the functional design of any special purpose processor as discussed above. By way of example, and not limitation, such non-transitory computer-readable media can include RAM, ROM, EEPROM, CD-ROM or other optical disk storage, magnetic disk storage or other magnetic storage devices, or any other medium which can be used to carry or store desired program code means in the form of computer-executable instructions, data structures, or processor chip design. When information is transferred or provided over a network or another communications connection (either hardwired, wireless, or combination thereof) to a computer, the computer properly views the connection as a computer-readable medium. Thus, any such connection is properly termed a computer-readable medium. Combinations of the above should also be included within the scope of the computer-readable media.
Computer-executable instructions include, for example, instructions and data which cause a general purpose computer, special purpose computer, or special purpose processing device to perform a certain function or group of functions. Computer-executable instructions also include program modules that are executed by computers in stand-alone or network environments. Generally, program modules include routines, programs, components, data structures, objects, and the functions inherent in the design of special-purpose processors, etc. that perform particular tasks or implement particular abstract data types. Computer-executable instructions, associated data structures, and program modules represent examples of the program code means for executing steps of the methods disclosed herein. The particular sequence of such executable instructions or associated data structures represents examples of corresponding acts for implementing the functions described in such steps.
Those of skill in the art will appreciate that other embodiments of the disclosure may be practiced in network computing environments with many types of computer system configurations, including personal computers, hand-held devices, multi-processor systems, microprocessor-based or programmable consumer electronics, network PCs, minicomputers, mainframe computers, and the like. Embodiments may also be practiced in distributed computing environments where tasks are performed by local and remote processing devices that are linked (either by hardwired links, wireless links, or by a combination thereof) through a communications network. In a distributed computing environment, program modules may be located in both local and remote memory storage devices.
As described herein, one aspect of the present technology is the gathering and use of data available from various sources to improve the delivery of invitational content including, promotions, advertisements, or any other content that may be of interest to users. The present disclosure contemplates that, in some instances, this gathered data may include personal information data that uniquely identifies or can be used to contact or locate a specific person. Such personal information data can include demographic data, location-based data, telephone numbers, email addresses, twitter ID's, home addresses, or any other identifying information.
The present disclosure recognizes that the use of such personal information data in the present technology can be used to the benefit of users. For example, the personal information data can be used to better understand user behavior, facilitate and measure the effectiveness of advertisements, applications, and delivered content. Accordingly, use of such personal information data enables calculated control of the delivered content. For example, the system can reduce the number of times a user receives a given ad or other content and can thereby select and deliver content that is more meaningful to users. Such changes in system behavior improve the user experience. Further, other uses for personal information data that benefit the user are also contemplated by the present disclosure.
The present disclosure further contemplates that the entities responsible for the collection, analysis, disclosure, transfer, storage, or other use of such personal information data should implement and consistently use privacy policies and practices that that are generally recognized as meeting or exceeding industry or governmental requirements for maintaining personal information data private and secure. For example, personal information from users should be collected for legitimate and reasonable uses of the entity and not shared or sold outside of those legitimate uses. Further, such collection should occur only after the informed consent of the users. Additionally, such entities would take any needed steps for safeguarding and securing access to such personal information data and ensuring that others with access to the personal information data adhere to their privacy and security policies and procedures. Further, such entities can subject themselves to evaluation by third parties to certify their adherence to widely accepted privacy policies and practices.
Despite the foregoing, the present disclosure also contemplates embodiments in which users selectively block the use of, or access to, personal information data. That is, the present disclosure contemplates that hardware and/or software elements can be provided to prevent or block access to such personal information data. For example, in the case of advertisement delivery services, the present technology can be configured to allow users to select to “opt in” or “opt out” of participation in the collection of personal information data during registration for services. In another example, users can select not to provide location information for advertisement delivery services. In yet another example, users can configure their devices or user terminals to prevent storage or use of cookies and other mechanisms from which personal information data can be discerned. The present disclosure also contemplates that other methods or technologies may exist for blocking access to their personal information data.
Therefore, although the present disclosure broadly covers use of personal information data to implement one or more various disclosed embodiments, the present disclosure also contemplates that the various embodiments can also be implemented without the need for accessing such personal information data. That is, the various embodiments of the present technology are not rendered inoperable due to the lack of all or a portion of such personal information data. For example, content can be selected and delivered to users by inferring preferences based on non-personal information data or a bare minimum amount of personal information, such as the content being requested by the device associated with a user, other non-personal information available to the content delivery services, or publically available information.
The various embodiments described above are provided by way of illustration only and should not be construed to limit the scope of the disclosure. Those skilled in the art will readily recognize various modifications and changes that may be made to the principles described herein without following the example embodiments and applications illustrated and described herein, and without departing from the spirit and scope of the disclosure.
This application claims the benefit of U.S. Provisional Patent Application No. 61/699,283, entitled “ASSIGNING KEYPHRASES”, filed on Sep. 10, 2012, which is hereby expressly incorporated herein by reference in its entirety.
Number | Date | Country | |
---|---|---|---|
61699283 | Sep 2012 | US |