# answer = "def has_close_elements(numbers: List[float], threshold: float) -> bool:\n    for i in range(len(numbers)):\n        for j in range(i + 1, len(numbers)):\n            if abs(numbers[i] - numbers[j]) < threshold:\n                return True\n    return False\n'''"

# class empty:
#     pass

# s=empty()

# s.a = 20
# print(1)
# exit(0)

from huggingface_hub import login


import torch
c = torch.tensor([[2,3],[1,4]])
print(c.reshape(-1).shape[0])

from transformers import AutoModelForCausalLM, AutoTokenizer, BitsAndBytesConfig
 
 
ckpt = 'mistralai/Mistral-7B-Instruct-v0.2'
tokenizer = AutoTokenizer.from_pretrained(ckpt)
tokenizer.pad_token = tokenizer.unk_token
print(tokenizer.pad_token)
tokenizer.max_seq_length = 4096
tokenizer.padding_side='left'
# tokenizer.pad_token = pad_token
print(tokenizer.pad_token_id)
exit(0)
# 检查PyTorch是否能检测到GPU
if torch.cuda.is_available():
    print("Number of GPUs:", torch.cuda.device_count())
    for i in range(torch.cuda.device_count()):
        print(f"GPU {i}: {torch.cuda.get_device_name(i)}")
else:
    print("No GPU found.")
exit(0)
# answer = answer[answer.find('def'):]
# answer_list = answer.split('\n')
# print(answer_list)
# for i in range(len(answer_list)-1,1,-1):
#     if answer_list[i][0]!='\t':
#         answer = '\n'.join(answer_list[:i-1])
#         break
# print(answer)
import os,glob, subprocess, re
# os.environ['HF_HOME'] = "../llama_on_glue/checkpoints"
from huggingface_hub import login
#

from transformers import AutoModelForCausalLM, AutoTokenizer, BitsAndBytesConfig
from datasets import load_dataset
import torch
from tqdm import tqdm
import pandas as pd
import local_datasets.ceval_exam as ceval 
from human_eval.data import write_jsonl, read_problems

def extract_from_logs(log):
    ret = []
    with open(log,"r+") as f:
        lines = ('\n'.join(f.readlines()))
        words = re.split('[()|]', lines)
        ret = []
        for i in words:
            try:
                ret += [float(i)]
            except:
                continue
    return ret, lines

def load_ckpt(ckpt, device):
    dtype = torch.bfloat16
    tokenizer = AutoTokenizer.from_pretrained(ckpt)
    model = AutoModelForCausalLM.from_pretrained(ckpt, torch_dtype=dtype, device_map={'': device})
    return model, tokenizer

ckpt = 'checkpoints/hub/models--meta-llama--Meta-Llama-3-8B/snapshots/8cde5ca8380496c9a6cc7ef3a8b46a0372a1d920'
device = 'cuda:0'
