Metrics
Evaluation modules.
MRR #
Bases: BaseRetrievalMetric
MRR (Mean Reciprocal Rank) metric with two calculation options.
- The default method calculates the reciprocal rank of the first relevant retrieved document.
- The more granular method sums the reciprocal ranks of all relevant retrieved documents and divides by the count of relevant documents.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
use_granular_mrr
|
bool
|
|
False
|
Attributes:
Name | Type | Description |
---|---|---|
metric_name |
str
|
The name of the metric. |
use_granular_mrr |
bool
|
Determines whether to use the granular method for calculation. |
Source code in llama-index-core/llama_index/core/evaluation/retrieval/metrics.py
76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 |
|
compute #
compute(query: Optional[str] = None, expected_ids: Optional[List[str]] = None, retrieved_ids: Optional[List[str]] = None, expected_texts: Optional[List[str]] = None, retrieved_texts: Optional[List[str]] = None, **kwargs: Any) -> RetrievalMetricResult
Compute MRR based on the provided inputs and selected method.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
query
|
Optional[str]
|
The query string (not used in the current implementation). |
None
|
expected_ids
|
Optional[List[str]]
|
Expected document IDs. |
None
|
retrieved_ids
|
Optional[List[str]]
|
Retrieved document IDs. |
None
|
expected_texts
|
Optional[List[str]]
|
Expected texts (not used in the current implementation). |
None
|
retrieved_texts
|
Optional[List[str]]
|
Retrieved texts (not used in the current implementation). |
None
|
Raises:
Type | Description |
---|---|
ValueError
|
If the necessary IDs are not provided. |
Returns:
Name | Type | Description |
---|---|---|
RetrievalMetricResult |
RetrievalMetricResult
|
The result with the computed MRR score. |
Source code in llama-index-core/llama_index/core/evaluation/retrieval/metrics.py
90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 |
|
HitRate #
Bases: BaseRetrievalMetric
Hit rate metric: Compute hit rate with two calculation options.
- The default method checks for a single match between any of the retrieved docs and expected docs.
- The more granular method checks for all potential matches between retrieved docs and expected docs.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
use_granular_hit_rate
|
bool
|
|
False
|
Attributes:
Name | Type | Description |
---|---|---|
metric_name |
str
|
The name of the metric. |
use_granular_hit_rate |
bool
|
Determines whether to use the granular method for calculation. |
Source code in llama-index-core/llama_index/core/evaluation/retrieval/metrics.py
16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 |
|
compute #
compute(query: Optional[str] = None, expected_ids: Optional[List[str]] = None, retrieved_ids: Optional[List[str]] = None, expected_texts: Optional[List[str]] = None, retrieved_texts: Optional[List[str]] = None, **kwargs: Any) -> RetrievalMetricResult
Compute metric based on the provided inputs.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
query
|
Optional[str]
|
The query string (not used in the current implementation). |
None
|
expected_ids
|
Optional[List[str]]
|
Expected document IDs. |
None
|
retrieved_ids
|
Optional[List[str]]
|
Retrieved document IDs. |
None
|
expected_texts
|
Optional[List[str]]
|
Expected texts (not used in the current implementation). |
None
|
retrieved_texts
|
Optional[List[str]]
|
Retrieved texts (not used in the current implementation). |
None
|
Raises:
Type | Description |
---|---|
ValueError
|
If the necessary IDs are not provided. |
Returns:
Name | Type | Description |
---|---|---|
RetrievalMetricResult |
RetrievalMetricResult
|
The result with the computed hit rate score. |
Source code in llama-index-core/llama_index/core/evaluation/retrieval/metrics.py
30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 |
|
RetrievalMetricResult #
Bases: BaseModel
Metric result.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
score
|
float
|
Score for the metric |
required |
Attributes:
Name | Type | Description |
---|---|---|
score |
float
|
Score for the metric |
metadata |
Dict[str, Any]
|
Metadata for the metric result |
Source code in llama-index-core/llama_index/core/evaluation/retrieval/metrics_base.py
7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 |
|
resolve_metrics #
resolve_metrics(metrics: List[str]) -> List[Type[BaseRetrievalMetric]]
Resolve metrics from list of metric names.
Source code in llama-index-core/llama_index/core/evaluation/retrieval/metrics.py
465 466 467 468 469 470 471 |
|