"""Human evaluation latex generation for Winogrande."""
import abc
import dataclasses
import re
from typing import Optional, List, Sequence, Tuple

import numpy as np
from transformers import PreTrainedTokenizer

from npeff_torch.datasets.winogrande import winogrande_analysis
from npeff_torch.examination.top_examples import top_examples_common
from npeff_torch.examination.top_examples.human_evals import humev_top_examples_same_theme_latex
from npeff_torch.examination.top_examples.human_evals import humev_top_examples_theme_latex
from npeff_torch.examination.top_examples import top_examples_latex
from npeff_torch.util import latex_utils


###############################################################################
_DEFAULT_INTRO = R"""
This document contains groupings of examples from Winogrande. Winogrande is a
pronoun coreference resolution task where the goal is to determine what person/object
a pronoun refers to. In the examples presented here, the pronoun itself is replaced by
its potential options given in curly brackets.

For each group of examples, please determine if there is some common theme among the examples
in the group. In the second column of the CSV, please write \texttt{yes}, \texttt{maybe}, or \texttt{no}
(and only those three options) depending whether you detected the presence of a theme. In you put
\texttt{yes} or \texttt{maybe}, please put a brief description of the theme in the third column of
the CSV.
"""
###############################################################################
_DEFAULT_SAME_THEME_LATEX_INTRO = R"""
This document contains groupings of examples from Winogrande. Winogrande is a
pronoun coreference resolution task where the goal is to determine what person/object
a pronoun refers to. In the examples presented here, the pronoun itself is replaced by
its potential options given in curly brackets.

This document contains pairs of groups of examples. For each pairing, please determine whether each group
individually contains a common theme among its examples. If both groups do contain a theme, then determine
whether the themes of the two groups are very similar. In the second column of the CSV, please write
\texttt{yes}, \texttt{maybe}, or \texttt{no} (and only those three options) depending on whether both groups
contain very similar themes. To be clear, write \texttt{yes} only if both groups contain a theme that is very
similar; write \texttt{no} if both groups contain different themes or if both groups do not contain a detectable
theme. If put \texttt{yes} or \texttt{maybe}, please put a brief description of the theme in the third column of
the CSV.
"""
###############################################################################


class _HumevThemeMixin:

    def make_example_latex_string(self, example_info: 'top_examples_common.TopExampleInfo') -> str:
        winogrande_example = winogrande_analysis.WinograndeExample.from_top_example_info(self.tokenizer, example_info)

        options = '{' + (', '.join(winogrande_example.options)) + '}'
        s = winogrande_example.sentence.replace('_', options)

        s = latex_utils.escape(s)
        s = R'\noindent\texttt{' + s + R'\vspace{2mm} \\' + '\n}'

        return s


###############################################################################


@dataclasses.dataclass
class WinograndeHumevTopExamplesThemeLatexGeneratorForLm(_HumevThemeMixin, humev_top_examples_theme_latex.HumevTopExamplesThemeLatexGeneratorAbc):
    tokenizer: PreTrainedTokenizer
    
    components_fontsize: Optional[str] = 'footnotesize'

    #######################################################

    def make_latex_intro(self) -> str:
        # Should contain information to help reviewers about the task.
        return _DEFAULT_INTRO


@dataclasses.dataclass
class WinograndeHumevTopExamplesSameThemeLatexGeneratorForLm(_HumevThemeMixin, humev_top_examples_same_theme_latex.HumevTopExamplesSameThemeLatexGeneratorAbc):
    tokenizer: PreTrainedTokenizer
    
    components_fontsize: Optional[str] = 'footnotesize'

    #######################################################

    def make_latex_intro(self) -> str:
        # Should contain information to help reviewers about the task.
        return _DEFAULT_SAME_THEME_LATEX_INTRO
