import pickle

def save_data(filename, data):
    #Storing data with labels
    a_file = open(filename, "wb")
    pickle.dump(data, a_file)
    a_file.close()
    

def load_data(filename):
    a_file = open(filename, "rb")
    output = pickle.load(a_file)
    a_file.close()
    return output

# def load_data_split(filename, split):
#     a_file = open(filename, "rb")
#     output = pickle.load(a_file)
#     a_file.close()
#     return output[:split], output[split:]

FEW_SHOT_TEST_SPLIT = 100

def load_data_split(filename, number_of_few_shots, number_of_tests):
    # a_file = open(filename, "rb")# 'rb'是文件打开模式，以二进制读取模式打开文件，即read binary,这里使用的原因是要读取pickle文件
    # 序列化（Serialization）：将 Python 对象转换为字节流（二进制数据），以便存储到文件或通过网络传输。反序列化（Deserialization）：将字节流转换回 Python 对象。
    # pickle 是 Python 的内置序列化模块：pickle.dump() - 序列化并保存到文件；pickle.load() - 从文件加载并反序列化；
    # pickle支持几乎所有 Python 类型：列表、字典、元组、集合、类实例等，保持对象结构：嵌套关系、引用关系都能保持，高效：专为 Python 设计，速度快
    # output = pickle.load(a_file)
    # a_file.close()
    with open(filename, "rb") as f:
        output = pickle.load(f)
    assert number_of_few_shots <= FEW_SHOT_TEST_SPLIT, f"The largest number of few shot can only be 100, we received {number_of_few_shots}"
    if not number_of_tests is None:
        assert number_of_tests <= len(output) - FEW_SHOT_TEST_SPLIT,  f"The largest number of test for this task can only be {len(output) - FEW_SHOT_TEST_SPLIT}, we received {number_of_tests}"
    else:
        number_of_tests = len(output) - FEW_SHOT_TEST_SPLIT
    allow_few_shots, allow_tests = output[:FEW_SHOT_TEST_SPLIT], output[FEW_SHOT_TEST_SPLIT:]
    return allow_few_shots[:number_of_few_shots], allow_tests[:number_of_tests]

# 3.1 将下面的代码中的"llama3-8b-instruct": 4096改为"meta-llama-3-8b-instruct": 4096
MODEL_NAME_TO_MAXIMUM_CONTEXT_LENGTH_MAP = {
    "gpt2-xl": 1024,
    "llama-2-7b-hf": 4096,
    "meta-llama-3-8b-instruct": 4096,
    "gpt-j-6b": 2048,
    "gpt2-large": 1024,
    "gpt2-medium": 1024,
    "mistral-7b-v0.3": 4096,
    "phi-4": 2048,
    "qwen2.5-7b-instruct": 4096
}