import strings as S


AUTHENTICATION_TOKEN = None
VERBOSE = False

ALLOW_GENERATION_TOKENS = True  # if True, the model is allowed to generate tokens to reason, up to 2000. If False, the model is only allowed to generate up to 10 tokens (for instance, to write "here is the answer")

RESULT_DIR = "results/results_full"

MODEL_LIST = [
    "microsoft/phi-4",
    "mistralai/Mistral-Small-24B-Instruct-2501",
    "google/gemma-3-27b-it",
    "Qwen/Qwen3-30B-A3B-Instruct-2507",
    "deepseek-ai/DeepSeek-R1-Distill-Qwen-32B",
    
    "meta-llama/Llama-3.3-70B-Instruct",
    "deepseek-ai/DeepSeek-R1-Distill-Llama-70B",
    "Qwen/Qwen2.5-72B-Instruct",
    
    "mistralai/Mistral-Large-Instruct-2411",
    
    "Qwen/Qwen3-235B-A22B-Instruct-2507",
]


MODEL_TO_GPU_LIST = {
    "microsoft/phi-4": "0",
    "mistralai/Mistral-Small-24B-Instruct-2501": "0",
    "google/gemma-3-27b-it": "0",
    "Qwen/Qwen3-30B-A3B-Instruct-2507": "0",
    "deepseek-ai/DeepSeek-R1-Distill-Qwen-32B": "0",

    "meta-llama/Llama-3.3-70B-Instruct": "4,5",
    "deepseek-ai/DeepSeek-R1-Distill-Llama-70B": "4,5",
    "Qwen/Qwen2.5-72B-Instruct": "4,5",

    "mistralai/Mistral-Large-Instruct-2411": "3,4,5",

    "Qwen/Qwen3-235B-A22B-Instruct-2507": "0,1,2,3,4,5",
}
assert MODEL_TO_GPU_LIST.keys() == set(MODEL_LIST), "MODEL_TO_GPU_LIST keys do not match MODEL_LIST"

VRAM_HEADROOM_GB: int = 5
GPUID_TO_MAX_MEMORY: dict[int, str] = {
    0: f"{81 - VRAM_HEADROOM_GB}GIB",
    1: f"{95 - VRAM_HEADROOM_GB}GIB",
    2: f"{81 - VRAM_HEADROOM_GB}GIB",
    3: f"{81 - VRAM_HEADROOM_GB}GIB",
    4: f"{95 - VRAM_HEADROOM_GB}GIB",
    5: f"{95 - VRAM_HEADROOM_GB}GIB",
}



CONFIG_SCENARIO_TEMPLATE = {
    S.prompt_parameter.SCENARIO: S.scenario_names.DICE,  # pick a scenario from strings.SCENARIO_NAMES, and fill the parameters below that belong to this scenario
    S.prompt_parameter.SUBSCENARIO: S.subscenario_names.REGULAR,  # pick a subscenario, as described in the paper. not all subscenarios are available for all scenarios (see paper)
    S.scenario_names.DICE: {  # fill the parameters that are relevant to the scenario/subscenario
        S.prompt_parameter.NUMBER: 2,  # number of dices. tested values in paper : 1,2,3
        S.prompt_parameter.FACES: 6,  # number of faces per die. tested values in paper : 4,6,8,10,12
        S.prompt_parameter.PREVIOUS_RESULT: 2,  # result of the previous dice, must be in [number, number*FACES]. only for REPEATED_INDEPENDENT and REPEATED_DEPENDENT subscenarios
        S.prompt_parameter.OBSERVATIONS: [],  # partial observation(s) of the result, see strings.observations_names. only for OBSERVATIONS subscenarios. tested values in paper: all combinations of 1 or 2 observations
    },
    S.scenario_names.COINS: {  # fill the parameters that are relevant to the scenario/subscenario
        S.prompt_parameter.NUMBER: 2,  # number of coins. tested values in paper : 2,3,4
        S.prompt_parameter.FOCUS: S.coin_faces.HEADS,  # the outcome of the coin highlighted in the prompt, can be HEADS or TAILS
        S.prompt_parameter.BIAS: 1,  # bias on the focused outcome, must be a >0 integer. 1= no bias. tested values in paper : 1,3,5
        S.prompt_parameter.PREVIOUS_RESULT: 0,  # result of the previous coin flip, must be in [0, number] only for REPEATED_INDEPENDENT and REPEATED_DEPENDENT subscenarios
    },
    S.scenario_names.PREFERENCES: {  # fill the parameters that are relevant to the scenario/subscenario
        S.prompt_parameter.OPTIONS: [
            "LEFT",
            "RIGHT",
        ],  # list of the two options to choose from, e.g. ["LEFT", "RIGHT"]
        S.prompt_parameter.FOCUS: "LEFT",  # the outcome highlighted in the prompt, must be one the options
        S.prompt_parameter.BIAS: 1,  # bias on the highlighted outcome, must be a >0 integer. 1= no bia. tested values in paper : 1,2,3
        S.prompt_parameter.PREVIOUS_RESULT: "LEFT",  # result of the previous choice, must be in OPTIONS. only for REPEATED_INDEPENDENT subscenarios
    },
    S.scenario_names.CHOICE: {  # fill the parameters that are relevant to the scenario/subscenario
        S.prompt_parameter.NUMBER: 6,  # number of abstract choices [A B C ...]. tested values in paper : 2,4,6
        S.prompt_parameter.PREVIOUS_RESULT: "A",  #  the result of the previous choice, must be in [A B C ...]
    },
}

