from transformers import AutoModelForCausalLM, AutoTokenizer
import torch


model_path = ""

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


tokenizer = AutoTokenizer.from_pretrained(model_path, trust_remote_code=True)


model = AutoModelForCausalLM.from_pretrained(
    model_path,
    device_map="cuda:0",            
    torch_dtype=torch.bfloat16,     
    trust_remote_code=True,
    load_in_8bit=True           
)

model.eval()

prompt = "你好，请介绍一下你自己。"
messages = [
    {"role": "system", "content": "You are a helpful assistant."},
    {"role": "user", "content": prompt}
]
text = tokenizer.apply_chat_template(
    messages,
    tokenize=False,
    add_generation_prompt=True
)
model_inputs = tokenizer([text], return_tensors="pt").to(model.device)


print("Generating...")
generated_ids = model.generate(
    model_inputs.input_ids,
    max_new_tokens=512,
    do_sample=True,
    temperature=0.7
)
generated_ids = [
    output_ids[len(input_ids):] for input_ids, output_ids in zip(model_inputs.input_ids, generated_ids)
]

response = tokenizer.batch_decode(generated_ids, skip_special_tokens=True)[0]
print("-" * 20)
print(response)