forked from mauricett/FishBrain
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathhf_trainer_amp.py
89 lines (64 loc) · 2.29 KB
/
hf_trainer_amp.py
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
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
#%%
import time
import numpy as np
from datasets import load_dataset
import torch
import torch.nn as nn
import torch.optim as optim
from torch.utils.data import DataLoader
from metrics.accuracy import Tester
from data.processors import process_sample, scorer
from data.tokenizer import Tokenizer
from model.conv_v0.model import ConvTransformer
BATCHSIZE = 512
N_CHECKPOINT = 5000
D_EMB = 256
N_LAYERS = 4
N_HEADS = 4
device = 'cuda'
tokenizer = Tokenizer()
tester = Tester(batchsize=BATCHSIZE, tokenizer=tokenizer)
dataset = load_dataset(path="mauricett/lichess_sf",
split="train",
streaming=True)
dataset = dataset.map(function=process_sample,
fn_kwargs={"tokenizer": tokenizer, "scorer": scorer})
dataloader = DataLoader(dataset,
batch_size=BATCHSIZE,
num_workers=4)
#%%
model = ConvTransformer(D_EMB, N_LAYERS, N_HEADS)
model = model.to(device)
model_dict = {'acc': np.zeros((1, 62, 100)),
'steps': [0],
'loss': []}
optimizer = optim.Adam(model.parameters(), lr=3e-4)
bce_loss = nn.BCEWithLogitsLoss()
#%%
n_steps = 0
n_epochs = 100
timer = time.perf_counter()
for epoch in range(n_epochs):
print("Epoch %i" % epoch)
dataset = dataset.shuffle()
for batch in dataloader:
optimizer.zero_grad()
with torch.autocast(device_type="cuda"):
x = model(batch['fens'], batch['moves'])
scores = batch['scores'].to(device)
loss = bce_loss(x, scores)
loss.backward()
optimizer.step()
n_steps += 1
model_dict['loss'].append(loss.item())
if not (n_steps % N_CHECKPOINT):
speed = (N_CHECKPOINT * BATCHSIZE) / (time.perf_counter() - timer)
accuracy = tester(model)
model_dict['acc'] = np.concatenate([model_dict['acc'], accuracy])
model_dict['steps'].append(n_steps)
print("%.1f accuracy, %i positions / s" % \
(model_dict['acc'][-1].mean() * 100, speed))
torch.save(model.state_dict(), 'model/fishweights.pt')
torch.save(optimizer.state_dict(), "model/optimizer.pt")
torch.save(model_dict, "model/model_dict.pt")
timer = time.perf_counter()