Package org.opensearch.index.rankeval
Class RecallAtK
- java.lang.Object
-
- org.opensearch.index.rankeval.RecallAtK
-
- All Implemented Interfaces:
NamedWriteable,Writeable,ToXContent,ToXContentObject,EvaluationMetric
public class RecallAtK extends java.lang.Object implements EvaluationMetric
Metric implementing Recall@K (https://en.wikipedia.org/wiki/Evaluation_measures_(information_retrieval)#Recall).
By default documents with a rating equal or bigger than 1 are considered to be "relevant" for this calculation. This value can be changed using the `relevant_rating_threshold` parameter.
The `k` parameter (defaults to 10) controls the search window size.
-
-
Nested Class Summary
Nested Classes Modifier and Type Class Description static classRecallAtK.Detail-
Nested classes/interfaces inherited from interface org.opensearch.common.xcontent.ToXContent
ToXContent.DelegatingMapParams, ToXContent.MapParams, ToXContent.Params
-
Nested classes/interfaces inherited from interface org.opensearch.common.io.stream.Writeable
Writeable.Reader<V extends java.lang.Object>, Writeable.Writer<V extends java.lang.Object>
-
-
Field Summary
Fields Modifier and Type Field Description static java.lang.StringNAME-
Fields inherited from interface org.opensearch.common.xcontent.ToXContent
EMPTY_PARAMS
-
-
Method Summary
All Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method Description booleanequals(java.lang.Object obj)EvalQueryQualityevaluate(java.lang.String taskId, SearchHit[] hits, java.util.List<RatedDocument> ratedDocs)Compute recall at k based on provided relevant document IDs.java.util.OptionalIntforcedSearchSize()Metrics can define a size of the search hits windows they want to retrieve by overwriting this method.static RecallAtKfromXContent(XContentParser parser)intgetK()intgetRelevantRatingThreshold()Return the rating threshold above which ratings are considered to be "relevant" for this metric.java.lang.StringgetWriteableName()inthashCode()XContentBuildertoXContent(XContentBuilder builder, ToXContent.Params params)voidwriteTo(StreamOutput out)-
Methods inherited from class java.lang.Object
clone, finalize, getClass, notify, notifyAll, toString, wait, wait, wait
-
Methods inherited from interface org.opensearch.index.rankeval.EvaluationMetric
combine
-
Methods inherited from interface org.opensearch.common.xcontent.ToXContentObject
isFragment
-
-
-
-
Field Detail
-
NAME
public static final java.lang.String NAME
- See Also:
- Constant Field Values
-
-
Constructor Detail
-
RecallAtK
public RecallAtK(int relevantRatingThreshold, int k)Metric implementing Recall@K.- Parameters:
relevantRatingThreshold- ratings equal or above this value will be considered relevant.k- controls the window size for the search results the metric takes into account
-
RecallAtK
public RecallAtK()
-
-
Method Detail
-
fromXContent
public static RecallAtK fromXContent(XContentParser parser)
-
writeTo
public void writeTo(StreamOutput out) throws java.io.IOException
-
toXContent
public XContentBuilder toXContent(XContentBuilder builder, ToXContent.Params params) throws java.io.IOException
- Specified by:
toXContentin interfaceToXContent- Throws:
java.io.IOException
-
getWriteableName
public java.lang.String getWriteableName()
- Specified by:
getWriteableNamein interfaceNamedWriteable
-
getRelevantRatingThreshold
public int getRelevantRatingThreshold()
Return the rating threshold above which ratings are considered to be "relevant" for this metric. Defaults to 1.
-
getK
public int getK()
-
forcedSearchSize
public java.util.OptionalInt forcedSearchSize()
Description copied from interface:EvaluationMetricMetrics can define a size of the search hits windows they want to retrieve by overwriting this method. The default implementation returns an empty optional.- Specified by:
forcedSearchSizein interfaceEvaluationMetric- Returns:
- the number of search hits this metrics requests
-
evaluate
public EvalQueryQuality evaluate(java.lang.String taskId, SearchHit[] hits, java.util.List<RatedDocument> ratedDocs)
Compute recall at k based on provided relevant document IDs.- Specified by:
evaluatein interfaceEvaluationMetric- Parameters:
taskId- an identifier of the query for which the search ranking is evaluatedhits- the search result hitsratedDocs- the documents that contain the document rating for this query case- Returns:
- recall at k for above
SearchResultlist.
-
equals
public final boolean equals(java.lang.Object obj)
- Overrides:
equalsin classjava.lang.Object
-
hashCode
public final int hashCode()
- Overrides:
hashCodein classjava.lang.Object
-
-