-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathtrain_vgg.py
74 lines (58 loc) · 2.4 KB
/
train_vgg.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
from lpl.model import LPLVGG11
import torch
import torchvision
from lpl.transform import DoubleTransformDataset, make_simclr_transforms
from visdom import Visdom
EPOCHS_PER_LAYER = 70
LA_1 = 1.
LA_2 = 10.
PRED = 1.
device = torch.device("cuda")
model = LPLVGG11()
# model.load_state_dict(torch.load("models/STL_lplvgg11_noPred.pth"))
model.to(device)
n_layers = 8
ds = torchvision.datasets.STL10(
root='../datasets/',
transform=torchvision.transforms.ToTensor(),
split='unlabeled'
)
contrastive_transform = make_simclr_transforms(
jitter_strength=0.5, blur=0.5, img_size=96)
ds = DoubleTransformDataset(ds, contrastive_transform)
dl = torch.utils.data.DataLoader(
ds, batch_size=1024, num_workers=8,
shuffle=True, drop_last=True)
for layer in range(n_layers):
optimizer = torch.optim.Adam(
model.weighted_layers[layer].parameters(),
lr=1e-3, weight_decay=1.5e-6)
scheduler = torch.optim.lr_scheduler.CosineAnnealingWarmRestarts(
optimizer, T_0=10, T_mult=2, eta_min=1e-7)
viz = Visdom()
viz.line([0.], [0.], win='Hebbian', opts=dict(title='Hebbian loss'))
viz.line([0.], [0.], win='Decorr', opts=dict(title='Decorr loss'))
viz.line([0.], [0.], win='Predictive', opts=dict(title='Predictive loss'))
viz.line([0.], [0.], win='LR', opts=dict(title='Learning rate'))
step = 0
for epoch in range(EPOCHS_PER_LAYER):
print(f"OPT LAYER {layer}, EPOCH {epoch}")
for images1, images2, _ in dl:
step += 1
out = model(images1.to(device)) # first forward
out = model(images2.to(device)) # second forward
lpl_layer = model.lpl_layers[layer]
predictive = lpl_layer.predictive_loss() * PRED
hebbian = lpl_layer.hebbian_loss() * LA_1
decorr = lpl_layer.decorr_loss() * LA_2
viz.line([hebbian.item()], [step], win='Hebbian', update='append')
viz.line([decorr.item()], [step], win='Decorr', update='append')
viz.line([predictive.item()], [step], win='Predictive', update='append')
viz.line([scheduler.get_lr()], [step], win='LR', update='append')
optimized_loss = hebbian + decorr + predictive
optimized_loss.backward()
optimizer.step()
optimizer.zero_grad()
model.reset()
scheduler.step()
torch.save(model.state_dict(), "models/STL_lplvgg11_70epochs.pth")