File size: 1,996 Bytes
d1b4e48 |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 |
import torch
from transformers import GPT2Tokenizer, GPT2LMHeadModel
import time
class GPT2Assistant:
def __init__(self, model_dir):
self.model = GPT2LMHeadModel.from_pretrained(model_dir)
self.tokenizer = GPT2Tokenizer.from_pretrained(model_dir)
def generate_answer(self, prompt, max_length=1024):
input_ids = self.tokenizer.encode(prompt, return_tensors="pt")
if self.tokenizer.pad_token_id is None:
self.tokenizer.pad_token = self.tokenizer.eos_token
attention_mask = (input_ids != self.tokenizer.pad_token_id).long()
output = self.model.generate(
input_ids,
attention_mask=attention_mask,
max_length=max_length,
num_return_sequences=1,
no_repeat_ngram_size=2,
do_sample=True,
top_k=50,
top_p=0.95,
temperature=0.70
)
answer = self.tokenizer.decode(output[0], skip_special_tokens=True)
return answer[len(prompt):]
def query(self, prompt):
generated_answer = self.generate_answer(prompt)
return generated_answer
def main():
start_time = time.time()
model_output_dir = "/Users/migueldeguzman/Desktop/gpt2xl_algos/RLLMv10/v8-aterasu/"
assistant = GPT2Assistant(model_output_dir)
num_iterations = 50
prompt = input(f"Enter your question to ask the model {num_iterations} times: ")
for i in range(num_iterations):
print(f"Answering question {i + 1}/{num_iterations}...")
response = assistant.query(prompt)
print(f"Response {i + 1}: {response}\n")
end_time = time.time()
elapsed_time = (end_time - start_time) / 60 # Convert to minutes
print(f"Time-stamp: {elapsed_time:.2f} minutes")
end_time = time.time()
elapsed_time = (end_time - start_time) / 60 # Convert to minutes
print(f"Time taken to complete the task: {elapsed_time:.2f} minutes")
if __name__ == "__main__":
main()
|