File size: 1,733 Bytes
71b5fcd
b69b23b
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
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
from .config import CNNConfig
from transformers import PreTrainedModel


import pytorch_lightning as pl
import torch
import torch.nn as nn


class CNN(pl.LightningModule):    
    def __init__(self):
        super().__init__()

        self.c1 =  nn.Sequential(
            nn.Conv2d(3, 32, kernel_size=3),  #32x30
            nn.ReLU(),                        
            nn.MaxPool2d(kernel_size=2)       #32x15
        )

        self.c2 = nn.Sequential(
            nn.Conv2d(32, 64, kernel_size=3),  #64x12
            nn.ReLU(),
            nn.MaxPool2d(kernel_size=2)        #64x6
        )

        self.dense = nn.Linear(64 * 6 * 6, 10)
        self.loss = nn.CrossEntropyLoss()


    def forward(self, x):
        x = self.c1(x)
        x = self.c2(x)

        # print( x.shape )

        x = x.view( x.shape[0], -1)

        x = self.dense(x)
        return x

    def training_step(self, batch, batch_idx):
        x, y = batch
        y_hat = self(x)
        loss = self.loss(y_hat, y)
        acc = (y_hat.argmax(dim=1) == y).float().mean()
        self.log('acc', acc, prog_bar=True)
        
        return loss

    
    def configure_optimizers(self):
        optimizer = torch.optim.Adam(self.parameters(), lr=1e-3)
        return optimizer

    def validation_step(self, batch, batch_idx):
        x, y = batch
        y_hat = self(x)
        loss = self.loss(y_hat, y)
        acc = (y_hat.argmax(dim=1) == y).float().mean()
        self.log('val_acc', acc, prog_bar=True)
        


class CNNModel(PreTrainedModel):
    config_class = CNNConfig

    def __init__(self, config):
        super().__init__(config)
        self.model = CNN()

    def forward(self, tensor):
        return self.model(tensor)