import constants as C

# from prompts_tools_one_choice import OneChoiceTrueDistribution, OneChoiceTrueDistributionProba
from numpy.random import shuffle
import frac as F


class Prompt_Preference_REVB:
    _BASE_INTRO = (
        "A person has to choose randomly between two options: {focus} and {other}. "
    )

    _BASE_PROBABILITY_UNFAIR = "The option {focus} is {num_bias} times more likely to be chosen than the option {other}. "
    _BASE_PROBABILITY_FAIR = (
        "The choice is fair and each option equally likely to be chosen. "
    )

    _BASE_RESULT = "The person chooses at random option"

    _INDEPENDANT_PREVIOUS_CHOICE = (
        "The person first chooses at random option {previous_value}. "
    )
    _INDEPENDANT_RESULT = (
        "Then the person performs another random choice and chooses option"
    )

    @staticmethod
    def regular_experiment(biased_factor, focus, other) -> str:
        if biased_factor == 1:
            proba_prompt = Prompt_Preference_REVB._BASE_PROBABILITY_FAIR
        else:
            proba_prompt = Prompt_Preference_REVB._BASE_PROBABILITY_UNFAIR

        base_prompt = (
            Prompt_Preference_REVB._BASE_INTRO
            + proba_prompt
            + Prompt_Preference_REVB._BASE_RESULT
        )

        return base_prompt.format(focus=focus, other=other, num_bias=biased_factor)

    @staticmethod
    def independant_previous_launch(biased_factor, focus, other, previous_value) -> str:
        if biased_factor == 1:
            proba_prompt = Prompt_Preference_REVB._BASE_PROBABILITY_FAIR
        else:
            proba_prompt = Prompt_Preference_REVB._BASE_PROBABILITY_UNFAIR

        base_prompt = (
            Prompt_Preference_REVB._BASE_INTRO
            + proba_prompt
            + Prompt_Preference_REVB._INDEPENDANT_PREVIOUS_CHOICE
            + Prompt_Preference_REVB._INDEPENDANT_RESULT
        )

        return base_prompt.format(
            focus=focus,
            other=other,
            num_bias=biased_factor,
            previous_value=previous_value,
        )


class Prompt_Preference_StaA:
    _BASE_INTRO = (
        "A person has to choose randomly between two options: {focus} and {other}. "
    )

    _BASE_PROBABILITY_UNFAIR = "The option {focus} is {num_bias} times more likely to be chosen than the option {other}. "
    _BASE_PROBABILITY_FAIR = (
        "The choice is fair and each option equally likely to be chosen. "
    )

    _BASE_RESULT = "The person chooses at random option"

    _INDEPENDANT_PREVIOUS_CHOICE = (
        "The person first chooses at random option {previous_value}. "
    )
    _INDEPENDANT_RESULT = (
        "Then the person performs another random choice and chooses option"
    )

    _QUESTION_BASE = (
        "What is the probability that the person chooses option {question_value}?"
    )
    _QUESTION_INDEPENDENT = "What is the probability that the person chooses option {question_value} in another random choice?"

    @staticmethod
    def regular_experiment(
        biased_factor, focus, other, question_for_value, true_distribution
    ):
        true_answer = true_distribution[question_for_value]

        choices, values, correct_answer = F.populate_answers_fractions(true_answer)

        if biased_factor == 1:
            proba_prompt = Prompt_Preference_StaA._BASE_PROBABILITY_FAIR
        else:
            proba_prompt = Prompt_Preference_StaA._BASE_PROBABILITY_UNFAIR

        base_prompt = Prompt_Preference_StaA._BASE_INTRO + proba_prompt
        question = Prompt_Preference_StaA._QUESTION_BASE.format(
            question_value=question_for_value
        )

        bp = base_prompt.format(focus=focus, other=other, num_bias=biased_factor)

        return bp, question, choices, values, correct_answer

    @staticmethod
    def independant_previous_launch(
        biased_factor,
        focus,
        other,
        previous_value,
        question_for_value,
        true_distribution,
    ):
        true_answer = true_distribution[question_for_value]

        if biased_factor == 1:
            proba_prompt = Prompt_Preference_StaA._BASE_PROBABILITY_FAIR
        else:
            proba_prompt = Prompt_Preference_StaA._BASE_PROBABILITY_UNFAIR

        base_prompt = (
            Prompt_Preference_StaA._BASE_INTRO
            + proba_prompt
            + Prompt_Preference_StaA._INDEPENDANT_PREVIOUS_CHOICE
        )
        question = Prompt_Preference_StaA._QUESTION_INDEPENDENT.format(
            question_value=question_for_value
        )

        choices, values, correct_answer = F.populate_answers_fractions(true_answer)

        bp = base_prompt.format(
            focus=focus,
            other=other,
            num_bias=biased_factor,
            previous_value=previous_value,
        )

        return bp, question, choices, values, correct_answer


if __name__ == "__main__":
    print(
        Prompt_Preference_REVB.regular_experiment(
            biased_factor=3, focus="Heads", other="Tails"
        )
    )

    print(
        Prompt_Preference_REVB.regular_experiment(
            biased_factor=1, other="Heads", focus="Tails"
        )
    )

    print(
        Prompt_Preference_REVB.independant_previous_launch(
            biased_factor=1, focus="Heads", other="Tails", previous_value="Heads"
        )
    )

    print(
        Prompt_Preference_REVB.independant_previous_launch(
            biased_factor=4, other="Heads", focus="Tails", previous_value="Heads"
        )
    )
