πŸ“„ Context CorrectnessΒΆ

metrics.rag.end_to_end.context_correctness

MetricPipeline(
    main_score="score",
    preprocess_steps=[
        Copy(
            field_to_field=[
                [
                "prediction/context_ids",
                "prediction",
                ],
            ],
        ),
        ListFieldValues(
            fields=[
                "task_data/reference_context_ids",
            ],
            to_field="references",
        ),
    ],
    metric="metrics.mrr[score_prefix=context_correctness_]",
)
[source]

from unitxt.operators import Copy, ListFieldValues

Explanation about ListFieldValuesΒΆ

Concatenates values of multiple fields into a list, and assigns it to a new field.

Explanation about CopyΒΆ

Copies values from specified fields to specified fields.

Args (of parent class):

field_to_field (Union[List[List], Dict[str, str]]): A list of lists, where each sublist contains the source field and the destination field, or a dictionary mapping source fields to destination fields.

Examples:

An input instance {β€œa”: 2, β€œb”: 3}, when processed by Copy(field_to_field={"a": "b"}) would yield {β€œa”: 2, β€œb”: 2}, and when processed by Copy(field_to_field={"a": "c"}) would yield {β€œa”: 2, β€œb”: 3, β€œc”: 2}

with field names containing / , we can also copy inside the field: Copy(field="a/0",to_field="a") would process instance {β€œa”: [1, 3]} into {β€œa”: 1}

References: metrics.mrr

Read more about catalog usage here.