# ToolRetV4.py
from aoeb.abstasks.LocalRetrieval import LocalRetrieval
from mteb.abstasks.TaskMetadata import TaskMetadata


class MTRAG(LocalRetrieval):
    metadata = TaskMetadata(
        name="MTRAG",
        description=(
            "Instruction retrieval benchmark: queries include an instruction + query, "
            "corpus contains tool documentation passages."
        ),
        reference="https://example.com/toolret",
        type="Retrieval",
        category="s2p",  # sentence-to-passage retrieval
        modalities=["text"],
        eval_splits=["test"],
        eval_langs={
            "clapnq/lastturn": ["eng-Latn"],
            "clapnq/rewrite": ["eng-Latn"],
            "cloud/lastturn": ["eng-Latn"],
            "cloud/rewrite": ["eng-Latn"],
            "fiqa/lastturn": ["eng-Latn"],
            "fiqa/rewrite": ["eng-Latn"],
            "govt/lastturn": ["eng-Latn"],
            "govt/rewrite": ["eng-Latn"],
        },
        main_score="ndcg_at_10",
        date=("2024-01-01", "2024-12-31"),
        domains=["Programming", "Web"],
        task_subtypes=[],
        license="cc-by-nc-sa-4.0",
        annotations_creators="derived",
        dialect=[],
        sample_creation="found",
        bibtex_citation="""@inproceedings{your_citation_2024,
title={ToolRet: A Benchmark for Tool Retrieval},
author={...},
booktitle={...},
year={2024}
}""",
        dataset={
            "path": "xxx-ai/mt-rag-benchmark",
            "revision": "1.0",
            "query_file_name": "queries.jsonl",
            "query_id_field": "id",
            "query_text_field": "text",
            "corpus_file_name": "corpus.jsonl",
            "corpus_id_field": "id",
            "corpus_title_field": "title",
            "corpus_text_field": "text",
            "qrels_dir": "",
            "qrels_file_name": "qrels.tsv",
            
        },        
    )
