inference.py 2.03 KB
Newer Older
1
2
3
4
5
6
7
8
9
10
11
import argparse
import torch

from chatgpt.nn import BLOOMActor, GPTActor, OPTActor
from transformers import AutoTokenizer
from transformers.models.gpt2.tokenization_gpt2 import GPT2Tokenizer


def eval(args):
    # configure model
    if args.model == 'gpt2':
12
        actor = GPTActor().to(torch.cuda.current_device())
13
    elif args.model == 'bloom':
14
        actor = BLOOMActor().to(torch.cuda.current_device())
15
    elif args.model == 'opt':
16
        actor = OPTActor().to(torch.cuda.current_device())
17
18
19
    else:
        raise ValueError(f'Unsupported model "{args.model}"')

20
21
22
23
    state_dict = torch.load(args.pretrain)
    actor.model.load_state_dict(state_dict)
    
    
24
25
26
27
28
    # configure tokenizer
    if args.model == 'gpt2':
        tokenizer = GPT2Tokenizer.from_pretrained('gpt2')
        tokenizer.pad_token = tokenizer.eos_token
    elif args.model == 'bloom':
29
        tokenizer = AutoTokenizer.from_pretrained('bigscience/bloom-560m')
30
31
        tokenizer.pad_token = tokenizer.eos_token
    elif args.model == 'opt':
32
        tokenizer = AutoTokenizer.from_pretrained('facebook/opt-350m')
33
34
35
    else:
        raise ValueError(f'Unsupported model "{args.model}"')

36
    actor.eval()
37
38
    input = args.input
    input_ids = tokenizer.encode(input, return_tensors='pt').to(torch.cuda.current_device())
39
    outputs = actor.generate(input_ids,
40
41
42
43
44
45
46
47
48
49
50
51
52
                             max_length=args.max_length,
                             do_sample=True,
                             top_k=50,
                             top_p=0.95,
                             num_return_sequences=1)
    output = tokenizer.batch_decode(outputs[0], skip_special_tokens=True)
    print(output)


if __name__ == '__main__':
    parser = argparse.ArgumentParser()
    parser.add_argument('--model', default='gpt2', choices=['gpt2', 'bloom', 'opt'])
    parser.add_argument('--pretrain', type=str, default=None)
53
    parser.add_argument('--input', type=str, default='Question: How are you ? Answer:')
54
55
56
    parser.add_argument('--max_length', type=int, default=100)
    args = parser.parse_args()
    eval(args)