πŸ“„ Answer RewardΒΆ

metrics.rag.end_to_end.answer_reward

MetricPipeline(
    main_score="score",
    preprocess_steps=[
        Copy(
            field_to_field=[
                [
                "prediction/answer",
                "prediction",
                ],
            ],
        ),
        ListFieldValues(
            fields=[
                "task_data/question",
            ],
            to_field="references",
        ),
        MultiTypeSerializer(
            field="references",
            process_every_value=True,
        ),
    ],
    metric="metrics.reward.deberta_v3_large_v2[score_prefix=answer_reward_]",
)
[source]

from unitxt.operators import Copy, ListFieldValues
from unitxt.serializers import MultiTypeSerializer

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.reward.deberta_v3_large_v2

Read more about catalog usage here.