When displaying content items to a user, the content items are typically ranked so that a desired set of content items is displayed first. One problem is that, when a user rating is used to rank items, a content item with only a few ratings that are very high can be displayed within the desired set. However, this content item may not be appropriately ranked because the few very high ratings may not represent the content item's rating after more rating are aggregated.
Various embodiments of the invention are disclosed in the following detailed description and the accompanying drawings.
The invention can be implemented in numerous ways, including as a process; an apparatus; a system; a composition of matter; a computer program product embodied on a computer readable storage medium; and/or a processor, such as a processor configured to execute instructions stored on and/or provided by a memory coupled to the processor. In this specification, these implementations, or any other form that the invention may take, may be referred to as techniques. In general, the order of the steps of disclosed processes may be altered within the scope of the invention. Unless stated otherwise, a component such as a processor or a memory described as being configured to perform a task may be implemented as a general component that is temporarily configured to perform the task at a given time or a specific component that is manufactured to perform the task. As used herein, the term ‘processor’ refers to one or more devices, circuits, and/or processing cores configured to process data, such as computer program instructions.
A detailed description of one or more embodiments of the invention is provided below along with accompanying figures that illustrate the principles of the invention. The invention is described in connection with such embodiments, but the invention is not limited to any embodiment. The scope of the invention is limited only by the claims and the invention encompasses numerous alternatives, modifications and equivalents. Numerous specific details are set forth in the following description in order to provide a thorough understanding of the invention. These details are provided for the purpose of example and the invention may be practiced according to the claims without some or all of these specific details. For the purpose of clarity, technical material that is known in the technical fields related to the invention has not been described in detail so that the invention is not unnecessarily obscured.
Ranking content items is disclosed. A user input is received from each of one or more users indicating an opinion of the user with respect to a content item included in a plurality of content items. Based at least in part on a number of users from whom user input has been received, a degree is determined to which a ranking of the content item relative to one or more other content items in the plurality of content items is determined by user input. In some embodiments, the content item is associated with an event. In some embodiments, the user input is weighted by a user reputation. In some embodiments, the degree of contribution of user ratings to the overall ranking varies depending on how many user ratings there are; if there are very few, they are not counted much (e.g., to discount being a non-representative sample); if there are more, they are counted more; at some point though the contribution levels out with regard to the number of user ratings.
A relevance of a content item to an event is determined. A user rating of the content item is received. A ranking of the content item is determined with respect to the event, relative to one or more other content items associated with the event based at least in part on the relevance and the user rating. In some embodiments, the ranking is determined based at least in part on a sentiment score associated with the content item.
In some embodiments, the ranking algorithm disclosed provides a novel method for retrieving, scoring, ranking, and presenting content related to an event based on a combination of: Geography, Time, Similarity, Sentiment, User rating and User preferences. It is aimed at providing users with the most relevant, engaging, and informative content concerning events of interest to them.
2 Description
This document presents the components of a content ranking algorithm and describes the various scoring contributions that it utilizes.
2.1 Conceptual Description
The ranking algorithm dynamically combines the various scoring contributions in different ways over time, as the importance of those respective contributions (see section 2.3) will vary over time. The overall scoring method for a content item and an event are both defined in section 2.4. An example of an example scoring history for a content item in the system can be seen in
The most basic element of scoring a content item is its relevance to a given event in the information retrieval sense, i.e., some characterization of similarity to a query or set of queries, or to a base or “seed” content item or set of items, associated with the event. This scoring contribution provides a baseline characterization of how topically related the content item is to that event. The model of similarity is fundamentally text overlap, for example, using the standard term frequency-inverse document frequency (TF-IDF) model, overlap of named entities, or similar measures.
Two additional scoring contributions also address the topical relevance of a content item to an event: temporal and geographic proximity of times and locations mentioned in the content item, or attached as metadata to the content item, to times and locations associated with the event.
The ranking algorithm also assesses the emotional impact of content items, in terms of valence (i.e., positive or negative and with what intensity), as part of the process of ranking those items. This scoring contribution allows the system to identify and prioritize potentially high-impact content.
Finally, the ranking algorithm also employs user ratings as one of its scoring contributions. The user rating score (U(t), see section 2.3.1) is defined by both the number and value of user votes (s(t)) with user reputation (hm(t)) taken into account. Basically, a few votes by highly reputable users will have the same effect as a large number of votes from less reputable users. This behavior is defined by the equations (3) and (4) described below.
For small numbers of user votes, the overall score of a content item will be primarily defined by the relevance score (R(t), see section 2.3.2) and the emotional score (E(t), see section 2.3.3). As the number of user votes grows, i.e., becomes statistically reliable, the effect of the user votes increases.
Finally, as the number of user votes increases further, the importance of additional user votes decreases. This behavior is modeled by the weighting function defined in equation (9) described below.
User reputation is based on both long term and short term interaction with the system.
By defining the user reputation as a function of both long term and short term interactions in this way, the algorithm is forgiving of isolated “mistakes” by users, such as submission of low quality content or less frequent visits to the system. On the other hand, long term abusive behavior will result in much slower growth of a user's reputation. The exact definition of the user reputation, hm(t), is found in section 2.2.
An event score is defined by a weighted sum of the user rating score of the event itself and the (possibly weighted) average total score of the content items associated with that event. It can easily be extended to be valid for non-linear weights.
2.2 Definition of the User Reputation, hm(t)
The user interaction score, us(t), measures the interactivity of a user with the system. Some general characteristics of the user interaction score include:
1 The larger the number of visits, the higher user interaction score.
2 The higher frequency of revisits, the higher user interaction score.
3 Attempts to cram the system, as well as abusive behavior or language, will lower the user's interaction score.
4 The quality of a user's submitted content is also an important factor in his or her interaction score.
An example of a user interaction history, us(t), is shown in
User reputation is defined as a weighted sum of the long term user interaction history (defined by the model parameter t1) as well as the more recent user interaction history (defined by the model parameter t0) inside the system. (See
where ω1 and ω0 are weights and ω0+ω1=1. The respective partial user reputation h−1,m h0,m and h1,m . . . is defined as,
where t−1=t1, τ−1,0=0, τ0,0=t−t0 and τ1,0=t−t1 and us(τ) is the user interaction score at time τ. Note that τ−t≦0 for all t≧0. The integral can be computed using simple numerical integration.
The model parameters—t0, t1 and ω0—enable control of the relative weight between recent and long term actions. A too high ratio of t1/t0 will damp fluctuations of the user reputation over time. For t1=1000 days (almost 3 years), there is a visual artifact that one can obtain an overall growth in the user reputation, hm(t), for higher t1. This artifact is purely an effect of the formulation of equation (1) and can be eliminated by introducing time-dependent weights ω0(t) and ω1(t). Large values of ω0 will drastically damp high-frequency fluctuations in the user reputation in time. Basically, choosing large values of ω0 results in low-frequency fluctuations in the user reputation, hm(t), in time.
2.3 Definition of the Scoring Contributions
The scoring distributions are shown in
2.3.1 User Rating Score, U(t)
The importance of user rating contribution should increase over time, but should also be bounded for large t. Furthermore, to handle different abusive behaviors in online communities such as creation of multiple accounts to vote multiple times, other cramming attempts, and/or to fight online trolls, each user vote, smj, should be weighted depending on their user reputation, hm. The user rating contribution can easily be extended to vary in different stages of the event detection process.
As the system will automatically detect such interactions, such attempts will result in a lower user interaction score and consequently a lower effective user rating score. The system allows the user interaction behavior to be dynamic over time, and the formulation of the user reputation ensures that the system automatically responds to such attempts and recalculates the total score of a content item in response.
Let s be the user vote by user m on the content piece j, hm(t), the reputation of the user m and ω(u) be the weighting function depending of the user reputation h(t). (Note that ω(u) is a different weight than the previously mentioned ω0 and ω1.) Furthermore, let Sj=Sj(t), be the set of users who have voted on a content piece j. The total user rating score, Uj=Uj(t) for a content piece j, will then be defined as,
where sje,n is the effective user rating score. The weighting function below has been specifically designed to solve the issues previously mentioned. It gives low weight for users with low reputation and for the intermediate interval of the user reputation has an only slightly varying constant weight (Part 1) and controls the obtained weight for users with higher user reputation (Part 2). Also as the user reputation varies with time, the hierarchy in the system is time-dependent and thus also the effective vote, sje,m, by a user m on the content item j.
The weighting function, ω(hm), is therefore defined as,
where him are are model parameters.
2.3.2 Relevance Score, R(t)
The relevance score, R(t), measures how relevant an item of content is to a particular event. An event is a collection of stories, blogs, user contributions, videos and images and can thus be considered as a container of content items j. (Typical events are, for instance, “The Conflict in Lebanon”, “The tragic death of Josh Hancock” or “Tom Cruise and Katie Holmes wedding”). The relevance score of an item will depend on:
2.3.3 Emotional Score, E(t)
An important element of any story, video or image is the emotional element, which determines the emotional impact a particular item of content has. The emotional score, E(t), provides a quantitive measure on the sentiment, attitude and/or opinion of piece of content—whether it is positive or negative, and how much. Sentiment of a content item in this sense can be assessed using a variety of statistical or other methods, for the most part derived from corpora of labeled data used to determine features or feature combinations indicative of particular sentiment values.
2.4 Definition of the Scores
2.4.1 The Score of a Content Item
A content item can be a document, an image, a video or any other type of content in the system. The score of a content item j is denoted, gj, and is defined as a weighted sum of its scoring contributions. Let the vector of the scoring contributions be defined as
vj(t)=[Uj(t) Rj(t) Ej(t)],
where vij(t) denotes the ith element of the vector vj(t) The score, gj, then defined by,
where Ni is the normalization constant of contribution i and ωij are the weighting function for the vector element vij(t). The scores need to be normalized as the different scores result from different sorts of computation, have different magnitudes, and are not directly comparable. The weighting functions used in the scoring model are,
ω1j=ω10·ƒ(Uj(t)) (user rating score weight) (6)
ω2j=ω20 (relevance score weight) (7)
ω3j=ω30 (emotional score weight) (8)
where ωi0 is the model parameter for weight of scoring contribution i. The weighting function, f(Uj(t)), is defined as,
Some examples and basic sensitivity analysis of the score are presented in
2.4.2 The Event Score
Let the user rating score for the event k itself be U0k, the average score for the associated content to event k,
gk(t)=ωk·U0k(t)+(1−ωk)·
Note that the total event score is then only given by one model function 107k, and the respective scores Uk0(t) and g-ack(t) can be defined via one SQL-query.
3 Description of the Preferred Embodiment
The system provides users with the ability to access and contribute content about events of interest to them, defining these events, tracking the evolution of the events over time, and organizing the events and the associated content to ensure users receive the most interesting and engaging experience. An event in its basic form is a collection of content items that refer to the same situation or circumstance. The scope of each event will be dynamic and vary over time. A content item may be a story, an image and/or a video. Both the content items and the events will be stored in databases and files, including XML-files.
The ranking algorithm is distributed throughout the system, and consists of both on-demand and batch processes, including steps of both a serial and parallel nature.
4 Advantages
The ranking algorithm provides an appropriate prioritization of the content related to an event, automatically and without relying on human intervention, and is therefore scalable. The algorithm utilizes a combination of different scoring contributions -user rating, relevance or similarity, geography, time, and emotional impact. The user ratings are weighted by user reputation to get the necessary slight community hierarchy structure, as it is well-known that a too-flat authority hierarchy internally can destroy groups as much as one that is too steep. The scoring algorithm solves some of the common problems with user ratings by varying its contribution vis a vis other scoring contributions in a dynamic manner. The community help decide what is important, intelligent information retrieval technology help to decide what is relevant, and emotional analysis help to decide what is impactful. Therefore the ranking algorithm can assess and prioritize content along all these three dimensions—community, information retrieval, emotional analysis -jointly. The ranking algorithm, together with the event detection model, also enables the swift detection of breaking events, which any model based on human editing or community assessment alone will be unable to match.
The simplicity of the ranking algorithm makes it easy to implement but also makes the dynamics of the score predictable. The algorithm can also be easily extended to include additional scoring contributions, and it can be optimized via only a few model parameters. The formulation of the ranking algorithm makes it possible to introduce more complex weighting functions for different types of content, different users, and different types of events, varying over time as information about those events evolves.
Although the foregoing embodiments have been described in some detail for purposes of clarity of understanding, the invention is not limited to the details provided. There are many alternative ways of implementing the invention. The disclosed embodiments are illustrative and not restrictive.
This application is a continuation of, and claims a benefit of priority under 35 U.S.C. 120 of the filing date of U.S. patent application Ser. No. 12/215,684, by inventors Tareen et al., entitled “RANKING CONTENT ITEMS RELATED TO AN EVENT,” filed on Jun. 27, 2008, which in turn claims the benefit of priority under 35 U.S.C. §119 to U.S. Provisional Patent Application No. 60/937,685, entitled “SYSTEM AND METHODS FOR RETRIEVING, RANKING, AND PRESENTING CONTENT RELATED TO AN EVENT,” filed Jun. 29, 2007, which are both incorporated herein by reference for all purposes.
Number | Date | Country | |
---|---|---|---|
60937685 | Jun 2007 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 12215684 | Jun 2008 | US |
Child | 14036610 | US |