The present invention relates generally to systems and methods for providing and managing on-line user communities and social networks.
Since computer users have first been able to communicate with one another through a telecommunication connection between their computers, there has been a growing desire to utilize computers and telecommunication systems for social interaction with others. While e-mail provided one-to-one communication with the advent of dial-in bulletin board systems (BBS) in the early 1980s, computer users discovered the joy of being able to communicate with many other users at once. Most of the early BBSs were either dedicated to particular interests or were used by groups of friends or other types of socially connected individuals.
In recent years, the popularity of the Word Wide Web (WWW) coupled with incredible growth in availability and accessibility of high bandwidth Internet connections resulted in an unprecedented proliferation of “on-line communities.” These phenomena include, but are not limited to, chat-rooms, on-line forums, groups, clubs, and digital photograph-sharing websites. In particular, on-line “portals” that provided WWW users with a variety of services (e.g., searching, news, free-email, etc.) immediately recognized the great value of hosting (i.e., providing storage resources and administration tools to) such communities. The more time the users spent using the communities, the greater their exposure to the hosting portal's advertising and other offered fee-based services.
As a natural extension of the concept of on-line communities there have been many efforts to translate the benefits of multiple-interest groups of users into advantageous business models or to otherwise utilize them for commercial purposes. These efforts typically took several different approaches: (1) websites for digital image sharing and management, (2) on-line merchant systems utilizing user-feedback for making product or service recommendations based on feedback received from other users with similar interests (also known as collaborative filtering), (3) systems that facilitate on-line and real-world social activities, such as event-planning and contact management websites; (4) dating websites which attempt to match users to one another using a number of different techniques; and most commonly “forum” style communities or web logs (“blogs”) where in addition to content users could interact with one another through topic-related posts or through chatting.
However, all of the above approaches suffer from a number of disadvantages:
The fourth disadvantage noted above has been the greatest barrier to further evolution of on-line communities and related services/functions. It is well known that the attention span of an average on-line user is tiny. In fact, the very reason that the portals are constantly developing new services and features, is to keep the users on their websites as long as possible. Accordingly, providing the information to a system to take advantage of its features often took more effort that most users were willing to put in, and the users either ignored the service or feature, or more often gave up before all necessary information was provided, and then disparaged the “poor quality” of the feature. Also the growth of virtually all communities (aside from Adult-oriented ones) has been relatively slow after rapid initial growth, as new users are becoming harder and harder to attract. Even though, in the last few years, new developments in the online communities called “social networks” have solved at least some of the above disadvantages, the key challenge of lack of desire by users to make active efforts to contribute to system functionality, remains unanswered.
Additionally, in recent years, searching for specific relevant content has become an arduous task because many search engines utilize algorithms that can be readily manipulated by their parties to push their content to the forefront of results presented to the searcher typically with little regard for relevance. Thus, a user searching for information on a LCD monitor would be bombarded with dozens of results of stores and price-comparison sites—significant time is then required to sift through the content to locate a relevant website with a review. Other forms of searching content (category browsing, community based, etc,) have other disadvantages. In each approach, the user must expend significant effort to seek out and identify relevant content.
It would thus be desirable to provide a system and method for forming social communities implemented in content-based online networks that automatically increase in relevance, usefulness, number of features, and functionality as a result of utilization by users thereof. It would also be desirable to provide a system and method for customizing the community experience and functionality based on context-relevance to user's current activities. It would further be desirable to provide a system and method for implementing dynamic community formation processes that automatically improve the scope, quality, and relevance of dynamically formed contextual communities based on data implicitly derived from routine utilization of the system by the users without requiring additional efforts from the users. It would further be desirable to provide a contextual community formation system and method that automatically increases the number and usefulness of features available to a user based on the user's continued participation in interactive featured offered by the system. Other desirable features also exist. These features are described herein.
Exemplary embodiments of the present invention that are shown in the drawings are summarized below. These and other embodiments are more fully described in the Detailed Description section. It is to be understood, however, that there is no intention to limit the invention to the particular forms described in this Summary of the Invention or in the Detailed Description. One skilled in the art can recognize that there are numerous modifications, equivalents and alternative constructions that fall within the spirit and scope of the invention as expressed in the claims.
A system and method for generating recommendations for a user is described. One embodiment includes a method for identifying users that are performing actions related to actions performed by a primary user, the method comprising: identifying an action performed by the primary user; identifying secondary users who performed the action; identifying actions performed by the secondary users; selecting a relevant action included in the identified actions performed the secondary users; identifying at least one secondary user that recently performed the selected relevant action; identify the action currently being performed by the identified secondary user; and providing a recommendation to user, the recommendation including an indication of the identified secondary user and the identified action.
In the drawings, wherein like reference characters denote elements throughout the several views:
Referring now to the drawings, where like or similar elements are designated with identical reference numerals throughout the several views, and referring in particular to
Referring now to
Referring now to
Referring first to the interface module 160, it is an input-output controller and serves as the interface for actors or the actor's computing devices to interact with the recommendation engine. Similarly, the interface module 160 directs the communications from the recommendation engine to the actors. For example, the interface module 160 could decide which network should be used to communicate with a particular actor.
The second software module shown in
The information collector software module 170 is responsible for interacting with the actor's software, including the plug-ins at the user computer, and matching incoming data from the actor with the particular session created by the session creator software. In a typical implementation, the recommendation engine may be interacting with hundreds of thousands of actors simultaneously and the information collector module 170 is responsible for gathering that information and then sorting it according to the appropriate actor or sessions.
Referring now to the information evaluator software module 175, it is responsible for analyzing information collected and sorted by the information collector and analyzing that data to produce a recommendation for a particular user. The information evaluator module 175, for example, correlates records across all the actor and determines which users are performing similar actions to the particular actor seeking the recommendation. The operation of the information evaluator module 175 is described in more detail in the subsequent flow charts.
The next software module in
The next module is the graphical location generator module 185. The graphical location generator is responsible for generating graphics that convey to the actor where groups of people are performing similar actions to the actions that that actor is performing. In essence, the graphical location generator is responsible for generating graphics that show crowds or individuals performing certain tasks similar to those performed by the user.
The actor interaction controller module 190 is the software module responsible for controlling communication between various actors. The actor interaction controller module 190 software could include chat programs, email programs, privacy-protection programs, and internet-based phone programs.
The final software module shown in
Referring now to
Regarding the first purpose, building community information, performance data is potentially collected from thousands of actors. The identity of the actors is typically, but not always, removed from that data and just the action and time information is stored. This action data reflects the different actions that the various actors in the community typically perform or have recently performed. For the purposes of this document, the term “performance” generally refers at least to a particular action performed by a particular actor at a specific time. For example, a performance would be actor “A” accessing www.cnn.com at a particular time. In this example, the action would be accessing www.cnn.com and the action type would be accessing a web site.
Once the recommendation engine either receives or determines for itself the time that a particular action was performed, the recommendation engine can store that information and generate correlations between particular actions. (Block 220) For example, the recommendation engine could link a actor's previous performance with actor's most recent performance. This information could be stored in a table or other data structure. In essence, the recommendation engine can collect all the actor's performances over a period of time and use those to generate recommendations for future actions based on community activity. Similarly, the list of performances performed by a particular actor can be added to the community information so that others can see the series of actions that this particular actor performed. Typically, community information does not identify particular actors but is rather just a collection of actions performed by members of the community and the correlation between those actions. These processes are described in more detail in the subsequent flow charts.
Referring now to
Next, the importance of the latest performance in the actor's tail can be calculated. (Block 240) Typically, the importance of a performance is represented by a number calculated from information available to the system. For example, a performance upon which the actor spends more time might be considered more important than one upon which the actor spends less time. Similarly, certain action types may be more important than other action types. Scrolling down a web page may be more important than rolling over an ad on a web page with a mouse.
The next three blocks (245, 250, 255) perform a loop that is performed on each performance in the actor's tail. For example, if the actor had three performances in his tail, the next three steps would be performed on each performance. The initial block in this loop involves calculating the importance of the earlier performance. (Block 245) This step recalculates the importance of the earlier performances to the actor. The importance data can change because of the time factor. For example, performances performed an hour ago may not be as important as recent performances. Typical importance data includes the time between the earlier performance and the latest performance and the time between the earlier performance and the subsequent performance. This type of data can be factored in to recalculate the importance of the earlier performance to the actor.
Using the calculated performance data of both the latest performance and the earlier performances, the explicit action correlation between the earlier and latest performances can be recalculated. (Block 250) The explicit action correlation is generally a numerical indicator of the correlation between two explicit actions.
Next, the correlations between the explicit actions in the actor's tail and the corresponding implicit actions can be recalculated. (Block 255) An implicit action is typically an action derived from the explicit action by substituting a more generic action type. For example, if an actor access www.cnn.com/tech/space, that would be a particular action. An implicit action based upon that action would be accessing www.cnn.com/tech, with one degree of generalization, or accessing www.cnn.com, with two degrees of generalization. Accordingly, the implicit action correlation, demonstrates the correlation between the explicit action in a actor's tail and these generalized actions. The strength of the correlation between an implicit action and an explicit action is often based upon the degree of generalization required. For example, an explicit action might be more closely correlated to www.cnn.com/tech than it is to just www.cnn.com.
The data calculated from performing the previous three actions for each performance in the actor's tail is stored for subsequent use in generating the actor's recommendations. In particular, this data can be used to find other people that have performed a similar series of actions. This data can also be stored as part of the community data to indicate what the community typically does. In this situation, the identifying actor information is generally stripped out and only the action and action correlation information is retained.
Once the previous three steps have been calculated for each performance in the actor's tail, the practice variable can be adjusted. The practice variable indicates the relationship between an actor and an action that the actor has performed. Its strength is determined by the frequency and how recently the actor performs the action. The practice variable is unique to a particular actor, because it reflects the frequency with which an actor performs a particular task as well as the importance of the particular task. Practice variables can exist both for explicit actions and for implicit actions. Accordingly, the practice variable can be adjusted for both implicit actions and explicit actions. (Block 260, 265)
Finally, the correlation variables such as practice and importance can be written out to a community data file, which represents the collective actors' data and the correlations. (Block 270) In this document, the data file is also referred to as the graph. The graph can be any type of data structure, but for simplicity it is described as a table herein. Exemplary graphs are shown in
Additionally, the actor's tail can be amended to include the actor's most recent performance and the calculated strength data. (Block 275) In this embodiment, the actor's tail could include several components referred to as session tails. For example, if a user had two web browsers open, the actions performed in each web browser together would make up the actor's tail. However, within the actor's tail the actor would have two session tails, one corresponding to each web-browser session and activities in each web-browser session would be recorded in the corresponding session tail. By maintaining separate session tails, this embodiment of the invention allows recommendations to be generated that are specific to a particular web-browsing session.
Referring now that
The main variation between
An actor can have several task tails simultaneously. Accordingly, the appropriate task tail for the most recent performance must be identified prior to adding an entry. (Block 285, 290) This process is described in detail in subsequent flow charts. In essence, the task tail represent clusters of performances from the actor's complete tail that make up a particular task.
Referring now to
Referring now to
Referring now to
The first step in this method involves using the performances' numbers that were previously calculated. (Block 360) The steps described in
Referring now to
Typically, this process begins by generating generalizations of the latest action performed by an actor, which corresponds to the latest performance. (Block 385) As previously discussed, a generalization for accessing the website www.cnn.com/tech/space could be accessing www.cnn.com/tech and another generalization would be accessing www.cnn.com. Not all generalizations need be calculated for every action. The system can include a limiter that only generates a certain number of generalizations for any action.
Next, the earlier actions from the actor's tail are identified. (Block 390) Then the strength between each of these earlier actions and the generalized latest action is calculated. (Block 395) This strength could include information such as time intervals, action types and degree of generalization for the latest action. Finally, the calculated strength number can be added to the corresponding entry in an implicit later action correlation table. (Block 400) An exemplary implicit later action table is shown in
Referring now to
Referring now to
Initially, the actor's task tails are identified and retrieved. (Block 435) For each task tail, the strengths of the implicit and explicit correlations between the new performance's action and each action in the tail are combined to determine the degree to which the new performance is correlated with the task tail. (Block 440) This number can be weighted to adjust for time factors or other relevant information. The end result is that each task tail will be associated a strength number. Assuming that the strength number is greater than some minimal threshold, then the task tail with the highest strength number most likely corresponds to the users most recent performance. (Block 445, 450) Accordingly, the actor's most recent performance is added to that task tail. (Block 455) Alternatively, the actor's most recent performance is added to any task tail that corresponds to a strength number greater than a threshold.
Referring to
In this method, relevant actions for an actor are identified. These relevant actions (or just a single action) could be simply the last action performed by the actor or it could be a set of actions previously performed by the actor. For example, the relevant action could be selected from the actor's tail based on recency, frequency, or the correlation number.
In this embodiment, the first two Blocks (465, 470) are repeated for each performance in an actor's session tail or task tail to identify correlated actions. The first block involves gathering the strongest explicitly correlated actions connected to the actor's most recent performance. (Block 465) This information could be retrieved from the record created for the actor. The second step involves gathering the strongest implicitly correlated actions corresponding to the actor's most recent performance. (Block 470) This information could be retrieved from the record created for the actor.
The gathered explicit actions and implicit actions can then be combined. For overlapping actions, the weights assigned to those actions can be added together. (Block 475) The most recent actions performed by the actor can then be added to the gathered actions, thereby forming a set of relevant actions. (Blocks 480, 485) This list of relevant actions can then be sorted according to importance, weight, frequency, recency, or other. In certain embodiments, the list of relevant actions is reduced to a set number of relevant actions.
The next series of steps involve identifying other actors who have performed actions similar to the identified relevant actions. (Block 490) For each of the relevant actions determined in the previous steps, other actors who have performed these steps are identified. For example, the records for other actors can be searched for the identified relevant actions.
Alternatively, the next series of steps could identify actions that correspond to the identified relevant actions. In one embodiment, community data, which reflects the actions of all actors and the correlation of those actions, can be searched to identify actions that are correlated to the identified relevant actions. For example, the other actors could have performed the identified actions in conjunction with the relevant actions identified in Blocks 480 and 485. These sets of actions would be correlated—as described previously. These actions performed in conjunction with the relevant actions could then be used to search for other actors to list in the recommendation.
Referring again to
In one embodiment, the previously-performed actions performed by the identified actors are collected and aggregated. (Block 500) This aggregated list of actions can then be sorted according to the actions performed by the most actors, the actions performed most frequently, the actions performed most recently, or any combination thereof. (Block 505, 510) This sorted list can then be used to identify most relevant actors. (Block 515) These actors can form part of the recommendation provided to the actor. (Block 520, 525)
In another embodiment, for each relevant actor, or at least a subset of the actors, the individual actor tails for those actors are retrieved. And for each of those actors, the most recently, frequently, and/or highest-rated relevant actions are identified. These actions can be identified using the correlating strengths stored in the implicit correlation charts and the explicit correlation charts for each of the actors.
Using these identified actions, the actors can then be grouped and sorted based upon the recency and/or frequency that they practiced the identified actions. For example, the weight of the correlated actions from other actors can be added up to identify the actions performed most frequently/recently by other actors. The highest weighted actions can then be selected. For each of these selected highest weighted actions, the actors who most recently and/or frequently performs those actions can be identified. The list of actors and actions can then be returned to the original actor as a recommendation.
In conclusion, embodiments of the present invention provide, among other things, a system and method for generating recommendations based on an actor's actions. Those skilled in the art can readily recognize that numerous variations and substitutions may be made in the invention, its use and its configuration to achieve substantially the same results as achieved by the embodiments described herein. Accordingly, there is no intention to limit the invention to the disclosed exemplary forms. Many variations, modifications and alternative constructions fall within the scope and spirit of the disclosed invention as expressed in the claims.
The present application is a continuation application of application Ser. No. 11/556,655, filed Nov. 3, 2006, Attorney Docket No. MEDM-001/01US, and a continuation application of application Ser. No. 11/556,659, filed Nov. 3, 2006, Attorney Docket No. MEDM-001/02US, both entitled SYSTEM AND METHOD FOR DYNAMICALLY GENERATING AND MANAGING AN ON-LINE CONTEXT-DRIVEN INTERACTIVE SOCIAL NETWORK; each of which claims priority to commonly owned and assigned Application No. 60/734,005, filed Nov. 3, 2005, Attorney Docket No. 1047-2PROV, entitled SYSTEM AND METHOD FOR DYNAMICALLY GENERATING AND MANAGING AN ONLINE CONTEXT DRIVEN INTERACTIVE SOCIAL NETWORK, and Application No. 60/822,593, filed Aug. 16, 2006, Attorney Docket No. MEDM-001/00US, entitled SYSTEM AND METHOD FOR DYNAMICALLY GENERATING AND MANAGING AN ONLINE CONTEXT-DRIVEN INTERACTIVE SOCIAL NETWORK. Each of the foregoing applications is incorporated herein by reference in its entirety. This application is related to commonly owned and assigned Application No. 60/887,691, filed Feb. 1, 2007, Attorney Docket No. MEDM-002/00US, entitled SYSTEM, METHOD AND APPARATUS FOR IMPLEMENTING DYNAMIC COMMUNITY FORMATION PROCESSES WITHIN AN ONLINE CONTEXT-DRIVEN INTERACTIVE SOCIAL NETWORK; and application Ser. No. 12/024,984, filed Feb. 1, 2008, Attorney Docket No. MEDM-002/01US, entitled SYSTEM, METHOD AND APPARATUS FOR IMPLEMENTING DYNAMIC COMMUNITY FORMATION PROCESSES WITHIN AN ONLINE CONTEXT-DRIVEN INTERACTIVE SOCIAL NETWORK.
Number | Date | Country | |
---|---|---|---|
60734005 | Nov 2005 | US | |
60822593 | Aug 2006 | US | |
60734005 | Nov 2005 | US | |
60822593 | Aug 2006 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 11556655 | Nov 2006 | US |
Child | 12098772 | US | |
Parent | 11556659 | Nov 2006 | US |
Child | 11556655 | US |