-
Notifications
You must be signed in to change notification settings - Fork 10
/
train.py
69 lines (54 loc) · 2.07 KB
/
train.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
from torch.utils.data import Dataset
import torch
import torch.nn as nn
import torchvision.datasets as dset
import torchvision.transforms as transforms
from DCSS import DCSS
from Network import AutoEncoder, Mutual_net, myBottleneck
batch_size = 500
dataset_size = 70000
train_set = dset.MNIST(root='/home/mrsadeghi/Spectral_clustering_network', train=True,
transform=transforms.ToTensor(), download=True)
test_set = dset.MNIST(root='/home/mrsadeghi/Spectral_clustering_network', train=False,
transform=transforms.ToTensor(), download=True)
kwargs = {'num_workers': 1}
train1 = torch.utils.data.ConcatDataset([train_set, test_set])
data_loader = torch.utils.data.DataLoader(
dataset=train1,
batch_size=batch_size,
shuffle=True, **kwargs)
def weights_init(m):
if isinstance(m, nn.Conv2d):
torch.nn.init.xavier_uniform_(m.weight.data)
if m.bias is not None:
torch.nn.init.zeros_(m.bias.data)
# torch.nn.init.xavier_uniform(m.bias.data)
if isinstance(m, nn.Linear):
torch.nn.init.xavier_uniform_(m.weight.data)
if m.bias is not None:
torch.nn.init.zeros_(m.bias.data)
if __name__ == '__main__':
AE = AutoEncoder(myBottleneck, [1, 1, 1]).cuda()
AE.apply(weights_init)
MNet = Mutual_net().cuda()
MNet.apply(weights_init)
batch_size = 500
pretraining_epoch = 0
MaxIter1 = 200
MaxIter2 = 20
num_cluster = 10
m = 1.5
T1 = 2
T2 = 5
latent_size = 10
zeta = 0.8
gamma = 0.2
dataset_name = 'MNIST'
DCSS = DCSS(AE, MNet, data_loader, dataset_size, batch_size=batch_size, pretraining_epoch =pretraining_epoch,
MaxIter1 = MaxIter1, MaxIter2 = MaxIter2,num_cluster = num_cluster, m = m, T1=T1, T2 = T2, latent_size = latent_size, zeta = zeta, gamma = gamma , dataset_name = dataset_name)
if pretraining_epoch!= 0:
DCSS.pretrain()
if MaxIter1 != 0:
DCSS.first_phase()
if MaxIter2 !=0:
DCSS.second_phase()