import os

import torch
import lm_eval
from lm_eval.models.huggingface import HFLM
from transformers import AutoTokenizer, AutoModelForCausalLM, BitsAndBytesConfig
import argparse
from huggingface_hub import login


def main():
    
    #model_path = "/eagle/lc-mpi/Zhendong/MoBE/Qwen3-30B-A3B-Instruct-2507_svd-MoBE-hf"
    model_path = "/eagle/lc-mpi/Zhendong/MoBE/Qwen1.5/Qwen1.5-MoE-A2.7B-MoBE60-hf"
    #model_path = "/eagle/lc-mpi/Zhendong/MoBE/Qwen3-30B-A3B-Instruct-2507-MoBE-hf"
    

    #tasks = ["winogrande", "hellaswag","arc_challenge"] 
    #tasks = ["arc_easy"]
    tasks = ["openbookqa", "arc_easy", "winogrande", "hellaswag","piqa", "mathqa"]

    #tasks = ["piqa", "mathqa"]

    print(f"Loading model from: {model_path}")


    # bnb_config = BitsAndBytesConfig(
    #     load_in_4bit=True,
    #     bnb_4bit_compute_dtype=torch.bfloat16, 
    #     bnb_4bit_use_double_quant=True,
    #     bnb_4bit_quant_type="nf4",
    # )
    

    

    # )

   
    tokenizer = AutoTokenizer.from_pretrained(
        model_path, 
        trust_remote_code=True
    )
    if tokenizer.pad_token is None:
        tokenizer.pad_token = tokenizer.eos_token


    model = AutoModelForCausalLM.from_pretrained(
    model_path,
    device_map="auto",             
    torch_dtype=torch.bfloat16,     
    trust_remote_code=True,
    #load_in_8bit=True             
)

 
    hflm = HFLM(
        pretrained=model, 
        tokenizer=tokenizer, 
        batch_size=4 
    )

    print("Starting evaluation...")
    

    results = lm_eval.simple_evaluate(
        model=hflm,
        tasks=tasks,
        num_fewshot=0,  
        device="cuda",  
        batch_size=4
    )


    print("\n" + "="*30)
    print("Evaluation Results:")
    print("="*30)

    for task, metrics in results["results"].items():
        print(f"{task}: {metrics}")
        
  
    try:
        from lm_eval.utils import make_table
        print(make_table(results))
    except ImportError:
        pass

if __name__ == '__main__':
    main()
    
    
    

