Discounted cumulative gain

Discounted cumulative gain (DCG) is a measure of ranking quality in information retrieval. It is often normalized so that it is comparable across queries, giving Normalized DCG (nDCG or NDCG). NDCG is often used to measure effectiveness of search engine algorithms and related applications. Using a graded relevance scale of documents in a search-engine result set, DCG sums the usefulness, or gain, of the results discounted by their position in the result list. NDCG is DCG normalized by the maximum possible DCG of the result set when ranked from highest to lowest gain, thus adjusting for the different numbers of relevant results for different queries.

Overview
Two assumptions are made in using DCG and its related measures.


 * 1) Highly relevant documents are more useful when appearing earlier in a search engine result list (have higher ranks)
 * 2) Highly relevant documents are more useful than marginally relevant documents, which are in turn more useful than non-relevant documents.

Cumulative Gain
DCG is a refinement of a simpler measure, Cumulative Gain (CG). Cumulative Gain is the sum of the graded relevance values of all results in a search result list. CG does not take into account the rank (position) of a result in the result list. The CG at a particular rank position $$p$$ is defined as:


 * $$ \mathrm{CG_{p}} = \sum_{i=1}^{p} rel_{i} $$

Where $$rel_{i}$$ is the graded relevance of the result at position $$i$$.

The value computed with the CG function is unaffected by changes in the ordering of search results. That is, moving a highly relevant document $$d_{i}$$ above a higher ranked, less relevant, document $$d_{j}$$ does not change the computed value for CG (assuming $$i,j \leq p$$). Based on the two assumptions made above about the usefulness of search results, (N)DCG is usually preferred over CG. Cumulative Gain is sometimes called Graded Precision.

Discounted Cumulative Gain
The premise of DCG is that highly relevant documents appearing lower in a search result list should be penalized, as the graded relevance value is reduced logarithmically proportional to the position of the result.

The usual formula of DCG accumulated at a particular rank position $$p$$ is defined as:


 * $$ \mathrm{DCG_{p}} = \sum_{i=1}^{p} \frac{rel_{i}}{\log_{2}(i+1)} = rel_1 + \sum_{i=2}^{p} \frac{rel_{i}}{\log_{2}(i+1)} $$

Until 2013, there was no theoretically sound justification for using a logarithmic reduction factor other than the fact that it produces a smooth reduction. But Wang et al. (2013) gave theoretical guarantee for using the logarithmic reduction factor in Normalized DCG (NDCG). The authors show that for every pair of substantially different ranking functions, the NDCG can decide which one is better in a consistent manner.

An alternative formulation of DCG places stronger emphasis on retrieving relevant documents:


 * $$ \mathrm{DCG_{p}} = \sum_{i=1}^{p} \frac{ 2^{rel_{i}} - 1 }{ \log_{2}(i+1)} $$

The latter formula is commonly used in industrial applications including major web search companies and data science competition platforms such as Kaggle.

These two formulations of DCG are the same when the relevance values of documents are binary; $$rel_{i} \in \{0,1\}$$.

Note that Croft et al. (2010) and Burges et al. (2005) present the second DCG with a log of base e, while both versions of DCG above use a log of base 2. When computing NDCG with the first formulation of DCG, the base of the log does not matter, but the base of the log does affect the value of NDCG for the second formulation. Clearly, the base of the log affects the value of DCG in both formulations.

Convex and smooth approximations to DCG have also been developed, for use as an objective function in gradient based learning methods.

Normalized DCG
Search result lists vary in length depending on the query. Comparing a search engine's performance from one query to the next cannot be consistently achieved using DCG alone, so the cumulative gain at each position for a chosen value of $$p$$ should be normalized across queries. This is done by sorting all relevant documents in the corpus by their relative relevance, producing the maximum possible DCG through position $$p$$, also called Ideal DCG (IDCG) through that position. For a query, the normalized discounted cumulative gain, or nDCG, is computed as:


 * $$ \mathrm{nDCG_{p}} = \frac{DCG_{p}}{IDCG_{p}} $$,

where IDCG is ideal discounted cumulative gain,


 * $$ \mathrm{IDCG_{p}} = \sum_{i=1}^{|REL_p|} \frac{ 2^{rel_{i}} - 1 }{ \log_{2}(i+1)} $$

and $$REL_p$$ represents the list of relevant documents (ordered by their relevance) in the corpus up to position p.

The nDCG values for all queries can be averaged to obtain a measure of the average performance of a search engine's ranking algorithm. Note that in a perfect ranking algorithm, the $$DCG_p$$ will be the same as the $$IDCG_p$$ producing an nDCG of 1.0. All nDCG calculations are then relative values on the interval 0.0 to 1.0 and so are cross-query comparable.

The main difficulty encountered in using nDCG is the unavailability of an ideal ordering of results when only partial relevance feedback is available.

Example
Presented with a list of documents in response to a search query, an experiment participant is asked to judge the relevance of each document to the query. Each document is to be judged on a scale of 0-3 with 0 meaning not relevant, 3 meaning highly relevant, and 1 and 2 meaning "somewhere in between". For the documents ordered by the ranking algorithm as


 * $$ D_{1}, D_{2}, D_{3}, D_{4}, D_{5}, D_{6} $$

the user provides the following relevance scores:


 * $$ 3, 2, 3, 0, 1, 2 $$

That is: document 1 has a relevance of 3, document 2 has a relevance of 2, etc. The Cumulative Gain of this search result listing is:


 * $$ \mathrm{CG_{6}} = \sum_{i=1}^{6} rel_{i} = 3 + 2 + 3 + 0 + 1 + 2 = 11$$

Changing the order of any two documents does not affect the CG measure. If $$D_3$$ and $$D_4$$ are switched, the CG remains the same, 11. DCG is used to emphasize highly relevant documents appearing early in the result list. Using the logarithmic scale for reduction, the DCG for each result in order is:

So the $$DCG_{6}$$ of this ranking is:


 * $$ \mathrm{DCG_{6}} = \sum_{i=1}^{6} \frac{rel_{i}}{\log_{2}(i+1)} = 3 + 1.262 + 1.5 + 0 + 0.387 + 0.712 = 6.861$$

Now a switch of $$D_3$$ and $$D_4$$ results in a reduced DCG because a less relevant document is placed higher in the ranking; that is, a more relevant document is discounted more by being placed in a lower rank.

The performance of this query to another is incomparable in this form since the other query may have more results, resulting in a larger overall DCG which may not necessarily be better. In order to compare, the DCG values must be normalized.

To normalize DCG values, an ideal ordering for the given query is needed. For this example, that ordering would be the monotonically decreasing sort of all known relevance judgments. In addition to the six from this experiment, suppose we also know there is a document $$D_7$$ with relevance grade 3 to the same query and a document $$D_8$$ with relevance grade 2 to that query. Then the ideal ordering is:
 * $$ 3, 3, 3, 2, 2, 2, 1, 0 $$

The ideal ranking is cut again to length 6 to match the depth of analysis of the ranking:
 * $$ 3, 3, 3, 2, 2, 2 $$

The DCG of this ideal ordering, or IDCG (Ideal DCG), is computed to rank 6:


 * $$ \mathrm{IDCG_{6}} = 8.740 $$

And so the nDCG for this query is given as:


 * $$ \mathrm{nDCG_{6}} = \frac{DCG_{6}}{IDCG_{6}} = \frac{6.861}{8.740} = 0.785 $$

Limitations

 * 1) Normalized DCG does not penalize containing bad documents in the result. For example, if a query returns two results with scores $1,1,1$ and $1,1,1,0$ respectively, both would be considered equally good, even if the latter contains a bad document. For the ranking judgments $Excellent, Fair, Bad$ one might use numerical scores $1,0,-1$ instead of $2,1,0$. This would cause the score to be lowered if bad results are returned, prioritizing the precision of the results over the recall; however, this approach can result in an overall negative score.
 * 2) Normalized DCG does not penalize missing documents in the result. For example, if a query returns two results with scores $1,1,1$ and $1,1,1,1,1$ respectively, both would be considered equally good, assuming ideal DCG is computed to rank 3 for the former and rank 5 for the latter. One way to take into account this limitation is to enforce a fixed set size for the result set and use minimum scores for the missing documents. In the previous example, we would use the scores $1,1,1,0,0$ and $1,1,1,1,1$ and quote nDCG as nDCG@5.
 * 3) Normalized DCG may not be suitable to measure the performance of queries that may have several equally good results. This is especially true when this metric is limited to only the first few results, as it is often done in practice. For example, for queries such as "restaurants" nDCG@1 accounts for only the first result. If one result set contains only 1 restaurant from the nearby area while the other contains 5, both would end up having the same score even though the latter is more comprehensive.