This disclosure is directed to mechanisms for modeling the behavior and preferences of a plurality of users. In particular the disclosure is directed to the creation of a virtual participant that models common features of real participants in a session.
As broadcast media developed, it was, for numerous reasons, a social experience. At first technological and financial reasons made television, and before it radio, necessitated that the content consumed was consumed as a group and selection of the content was often nothing more than taking the one available content stream.
At first music was made both personal and portable, first with the development of record players and transistor radios, then television followed slowly and fitfully followed. Televisions became smaller, and distribution technology progressed from over the air broadcast, to over cable broadcast, and is now progressing to digital distribution that allows for content on demand to be delivered to content consumers through data packet networks, over both wired and wireless networks.
Media distribution in a digital delivery system allows users to select content to be consumed on demand. In combination with greater personalization of the delivery platform, this has lead to a private content consumption experience. Often in a single household, each member of the household will be in different rooms of the house consuming different content.
These same technologies that have removed the social aspect have also provided for a number of new communication paths. Instant messaging and voice messaging have been enabled on the same devices that are used for the content creation. In this manner, a new form of social viewing is developing. Instead of families gathered around a television watching a program, groups of friends can virtually gather to watch selected content.
This has lead to a number of new challenges, including the actual selection of content in a content on demand environment. As the size of a group increases the ability of the group to reach a consensus on the selection of content typically diminishes. The group members can be geographically spread out, can have different viewing preferences and can have different viewing histories. This makes it difficult to select content with the typically large content libraries available.
In the existing art, content recommendation engines are used to recommend suggested content.
In one example of the prior art, a content recommendation engine is employed when a user visits an electronic commerce site. When the user visits a page related to a particular product, the merchant recommends content based on a correlation between the displayed content and purchases made by other users who also bought the displayed content. Thus when viewing a book, a user is typically shown a recommendation based on the purchasing habits of other users. Although this takes into account the behavior of people who may have an interest in the same product it does not account for the particular interests of the user. If a user is partial to a particular music genre, for example operatic arias, but is looking for a gift and is looking at an album in another genre, for example heavy metal, receiving suggestions based on the buying history of heavy metal purchasers may be less than useful.
Such recommendation engines have progressed to base recommendations on a user profile. If a user's content consumption history is stored, it can be compared to the histories of other users. This allows a recommendation engine to correlate preferences across a number of users to provide more relevant recommendations.
Problems arise when more than one user is to be accounted for when suggestions are to be made. For example, if a group of people, each having a profile, are to select a single movie to watch, it becomes difficult to accommodate a wide variety of tastes. To address this, a number of solutions that utilize a plurality of user profiles have been proposed.
“TV program recommendation for multiple viewers based on user profile merging” by Yu et al. published on 10 Jun. 2006, provides both an overview of previous solutions and a suggestion for an improvement over the previous solutions. Taken as a whole, this paper teaches, as illustrated in
Although the generation of a common profile addresses some of the problems of selecting content for a group of people, it creates a number of other problems. In creating a social experience, it is often advantageous to invite a plurality of people to participate. As people indicate that they will participate, the number of profiles increases. With the above described solution an interesting problem occurs. During the invitation period it may be preferable to provide either the single suggested movie or a set of suggestions. However, as people respond to the invitation and indicate that they will participate; this requires that the common profile be re-generated. During the invitation period, people can also withdraw from the event, which also requires that the common profile be regenerated. Based on the particular manner in which the profile is generated, the arrival or departure of some participants may greatly change the suggestions. As the number of participants in the event grows, recomputing the common profile becomes a non-trivial activity, especially when the individual user profiles are large and content rich.
Furthermore, it should be understood that different participants need their preferences handled differently. The viewing history, for example, can contain both a listing of the movies seen by a user and a user assigned rating. For some users, the fact that they have seen a movie a strong reason to not want to see the movie again. For other users, watching a movie that has already been seen is not a problem, and it is the rating assigned to moves that is a bigger issue. In the above described solutions, every user is treated the same, and to a certain extent is robbed of the individual preferences. This could reduce the effectiveness of the recommendation system just as the above described problems reduce the efficiency of the recommendation system in a dynamic group environment.
Therefore, it would be desirable to provide a system and method that obviate or mitigate the above described problems
It is an object of the present invention to obviate or mitigate at least one disadvantage of the prior art.
In a first aspect of the present invention, there is provided a storage for a virtual participant profile. The storage stores preferences associated with a plurality of users that are participating in an event. The profile storage comprising a memory for storing a plurality of profile elements, each of the plurality of profile element storing both a composite element value determined in accordance with a corresponding element value associated with at least one of the users in the plurality of users, and an indication identifying the contribution that the at least one of the users had to the composite value.
In one embodiment of the first aspect, at least one of the plurality of profile elements is used to store information related to at least one of a composite demographic profile, a composite viewing history, a composite preference, a composite dislike, and a composite rating. The composite rating can be associated with one of an actor, a director and a movie. The composite preference and composite dislike may be user defined.
In a second aspect of the present invention, there is provided a method of generating a virtual participant profile associated with an event. The method comprises the steps of receiving, through a network interface, an indication that an event has been initialized;
receiving a first profile associated with both a user and the event; creating a virtual participant profile associated with the event, the profile having both at least one profile element storing a composite value determined in accordance with an associated element in the received first profile and an indication identifying the contribution of the user associated with the first profile to the composite value; and storing the created virtual participant profile in a memory.
In an embodiment of the second aspect of the present invention, the step of receiving an indication includes receiving a request from a user over a network interface to initialize the event and creating a data structure to store data associated with the event. In another embodiment, the step of receiving a first profile includes receiving, through a network interface from a user, confirmation of involvement in the event; and in response to the receipt of the confirmation, retrieving from a database a user profile associated with the user associated with the received confirmation. In a further embodiment, creating the virtual participant profile is done in accordance with both the associated element and information associated with the event provided with the indication. In yet a further embodiment, the method can further include the steps of receiving information relevant to the stored virtual participant profile; and modifying the stored virtual participant profile in accordance with the received relevant information.
In a third aspect of the present invention, there is provided a method of modifying an existing virtual participant profile representing a plurality of users and stored in a memory. The method comprises the steps of retrieving the stored virtual participant profile from a memory in response to receipt of information relevant to the stored profile; identifying an element of the retrieved profile associated with the received information; adjusting a value of the identified element in accordance with its existing value, contributions associated with at least a portion of the plurality of users and the received information; and storing the adjusted value as part of the modified virtual participant profile in the memory.
In an embodiment of the third aspect, the received information relevant to the stored profile is a profile associated with a user joining the plurality. Optionally, the step of adjusting further includes adjusting the value in accordance with a weighted average, and the step of identifying can include determining that an element of the received user profile has no corresponding element in the retrieved virtual participant profile; and creating an element in the virtual profile associated with the determined element in the received user profile.
In a further embodiment, the received information relevant to the stored profile is a modification of a profile associated with a user in the plurality. Optionally, the the step of identifying includes identifying an element in the modified user profile that has changed; and identifying the element in the retrieved profile associated with the changed element. Additionally, the step of identifying may include determining that the modified user profile has a new element; determining that the new element in the user profile is not associated with an element in the virtual participant profile; and creating an element in the virtual participant profile associated with the new element in the user profile.
In a further embodiment, the received information is an indication that a user is withdrawing from the plurality. Optionally, the step of identifying includes selecting all elements in the virtual participant profile having an associated indication identifying a contribution by the withdrawing user; and the step of adjusting includes removing the contribution associated with the withdrawing user from all selected elements. In a further embodiment, the method further includes transmitting updated information associated with the profile of the withdrawing user for storage in a user profile database where the updated information may be determined in accordance with information stored in the virtual participant profile.
In a further embodiment, the step of adjusting the value includes associating the received information with one of the users in the plurality. Optionally, the step of adjusting also includes storing an indication associated with the value to reflect the user in the plurality associated with the received information.
In a fourth aspect of the present invention, there is provided a virtual participant profile generator for generating and modifying a virtual participant profile associated with an event. The generator comprises a participant request interface, a user profile interface and a processor. The participant request interface for receiving from users request to join or leave the event. The user profile interface for communicating with a user database storing user profiles. The processor for generating the virtual participant profile in response to receipt of a user request to join the event in accordance with receipt of a user profile associated with the requesting user, the generated profile storing an indication of user contribution to at least one element of the profile, and for modifying an already generated virtual profile in accordance with a second user request to join an event or a user request to withdraw from an event.
In an embodiment of the fourth aspect of the present invention, the profile generator includes an external data interface for receiving information relevant to the virtual participant profile, and for transmitting the received information to the processor. In a further embodiment, the generator includes a virtual profile interface for receiving an already generated virtual participant profile and for transmitting the received profile to the processor for modification.
Other aspects and features of the present invention will become apparent to those ordinarily skilled in the art upon review of the following description of specific embodiments of the invention in conjunction with the accompanying figures.
Embodiments of the present invention will now be described, by way of example only, with reference to the attached Figures, wherein:
The present invention is directed to a system and method for the generation of a virtual participant profile for use in a dynamic group environment.
In observing group behavior, it becomes apparent that different users put weight in different areas of their profile. Although the teachings of Yu et al. allow different components of the profiles to be weighted differently in the minimization of the missed distance, this is a global weighting. It still results in all users being treated the same. Further observations of group behavior show that when provided a long window in which to join a group, people join and a variety of different times, and occasionally, people leave the group. The departure of a person from an established group can result in a sufficiently different group profile and accordingly a different set of movie selections could be offered. For example, if a particular user has a very strong preference to not see movies that he has seen recently leaves a group, the recommendation could change to suggest one of the movies that that user had recently seen. Those skilled in the art will appreciate that although the following discussion is centered around the example of a group of people gathering together (either gathering physically or virtually) to watch a movie, the consumption of content is not limited to selecting movies. The virtual participant profile discussed below can be used in the selection of other content including targeted advertising, television programming, music and music videos.
In the following discussion, mechanisms for allowing a user to provide further customization to a profile to reflect the relative importance of different factors will be described in the context of the creation of a profile that is assigned to a virtual participant. The virtual participant is considered to be representative of the overall group, and provides a balanced approach to finding a common ground among the participants.
Reference may be made below to specific elements, numbered in accordance with the attached figures. The discussion below should be taken to be exemplary in nature, and not as limiting of the scope of the present invention. The scope of the present invention is defined in the claims, and should not be considered as limited by the implementation details described below, which as one skilled in the art will appreciate, can be modified by replacing elements with equivalent functional elements.
The following discussion of the generation of a virtual participant profile will be provided in the context of a social event organized with the intention of having a group of people watch a movie together. One skilled in the art will appreciate that the participants need not be at the same location when watching the movie, and that either the enhanced user profile illustrated in
A first user decides to act as the host of a movie night. Instead of simply calling and emailing friends to inform them of the event, and then trying to arrange for everyone to select a movie, an invitation is issued to a group. The invitation can be emailed, or it can be delivered through one or more social media services. The recipients of the invitation are able to RSVP to the event to confirm attendance, and at the same time are able to provide their user profile as a contribution to the virtual participant profile that can then be used to generate a series of recommendations. During the week before the event, a variety of people join the event, increasing the number of user profiles contributed. As new users join, the virtual participant profile is modified, and the participants (and possibly even the invitees) are able to see what the movie suggestions are. As each user joins and the virtual participant is modified, the suggested movies can be updated. If a social media service has been employed, a discussion about the movie night in a forum associated with the invitation can be used as an input to further refine the characteristics of the virtual participant (e.g. if a user comments that there have been bad reviews on a particular movie, the profile could down prioritize that movie by creating preferences and dislikes that account for the comment). During the time between the issuance of the invitation and the final selection of a movie, a user can also watch other movies which would result in changes to the user's profile (e.g. at least the viewing history would change). These changes can be accommodated and reflected in the virtual participant profile. If a user has replied to the invitation, but later has to cancel, the user's contribution to the virtual participant profile can be adjusted.
When a new user joins a session and there is already an existing virtual participant profile, the profile can either be regenerated by requesting all the subscribing users, or the virtual participant profile 126 previously generated by the processor 116 can be received through virtual profile interface 128 and provided to processor 116. In conjunction with the recently joined user profile 100, and the virtual participant profile 126, the processor 116 is able to identify the modifications to the virtual participant profile 126 needed.
If the virtual participant profile 126 is used to generate a set of suggestions, a voting process can be undertaken to allow the users to have the final decision. Results of the voting process can be fed back to the individual users profiles stored in database 118 through user profile 120. Furthermore, external information 122 that can be attributed to a particular user can be used modify the virtual participant profile 126. It may be advantageous to store such information in the individual user profile of the user associated with the external information 122. In such a case, processor 116 can send update the user profile and send the updated user profile for storage in database 118 through user profile interface 120.
Those skilled in the art will appreciate that similar modifications can occur with respect to the composite preference 1134.2 which has contributions from user h 134.2h and user j 134.2j among others.
When a user joins the event, his or her profile elements can be added to the data structure with very little difficulty because they will simply be added as contributions. Similarly if a user profile is updated, the contribution of the user can be adjusted because any element in the profile that the user contributed to can be easily identified. The system can either remove all the contributions from the user and then re-insert them, or it can simply modify the contributions that would be affected by the change in the profile.
One skilled in the art will appreciate that the embedding of the origin data, also referred to as indications of the individual user's contribution to the profile element, allows for modifications to the virtual participant profile without requiring all the data used to generate the profile in the first place to be assembled. This can reduce overhead associated with both data transfer and computational load.
In
One skilled in the art will appreciate that the methods illustrated in
In some embodiments, the enrolled participants will consume the selected content at a variety of different locations. Chat functionality can be provided to the users through conventional means allowing the users to have the experience of consuming the content as a group even if geographically they are spread out. Following the consumption of the content (e.g. watching the movie) each enrolled user would have his or her profile updated to reflect the change in the viewing history, ratings for the content can also be obtained at this point and inserted into the individual user profile. These updates can be propagated through to the virtual participant profile, so that if a second movie is selected (a double feature event) the recent viewings and ratings can then be used to change the selection or suggested selections.
When users participate in an event associated with the virtual participant profile, information about the participants can be generated (e.g. voting preferences, viewing histories, movie ratings, etc.) This information can be either directly stored in the relevant individual user profile (which could then cause an update to the virtual participant profile if the profile is still active), or alternatively the information can be stored in the virtual participant profile. During the teardown of the virtual participant profile, information gathered about the users as a whole that has not been accounted for in the individual user profiles can be fed back into the profiles so that the information is available at a later moment.
It should be appreciated that a user could register for a plurality of different events. During the consumption of a first content, information about the user that is relevant to the user profile can be obtained. This information can be immediately stored in the user profile, or it can be stored in the virtual participant profile. At a variety of different times, user specific information can be moved out of the virtual participant profile and into the user profile. One such logical time is when the virtual participant profile is torn down (as discussed above), but this data could be stored in the individual profile at a variety of different times. It is possible that storing the data until the virtual participant is torn down will result in the user information not being relayed to other virtual participant profiles. As a result, it may be advantageous to update the user profile based on information collected in the virtual profile at different times. If the user withdraws from the event, the information associated with that user is removed from the virtual participant, and this could be a good opportunity to store the data back in the user profile. As another option, at the end of a movie in a multi-movie event, the information gathered about each of the users could be transferred back into the individual profiles. One skilled in the art will appreciate that a number of different scenarios could be provided without departing from the scope of the present invention.
Embodiments of the invention may be represented as a software product stored in a machine-readable medium (also referred to as a computer-readable medium, a processor-readable medium, or a computer usable medium having a computer readable program code embodied therein). The machine-readable medium may be any suitable tangible medium including a magnetic, optical, or electrical storage medium including a diskette, compact disk read only memory (CD-ROM), digital versatile disc read only memory (DVD-ROM) memory device (volatile or non-volatile), or similar storage mechanism. The machine-readable medium may contain various sets of instructions, code sequences, configuration information, or other data, which, when executed, cause a processor to perform steps in a method according to an embodiment of the invention. Those of ordinary skill in the art will appreciate that other instructions and operations necessary to implement the described invention may also be stored on the machine-readable medium. Software running from the machine-readable medium may interface with circuitry to perform the described tasks.
The above-described embodiments of the present invention are intended to be examples only. Alterations, modifications and variations may be effected to the particular embodiments by those of skill in the art without departing from the scope of the invention, which is defined solely by the claims appended hereto.