|
import torch.nn as nn |
|
from huggingface_hub import PyTorchModelHubMixin |
|
|
|
class ModelColorization(nn.Module, PyTorchModelHubMixin): |
|
def __init__(self): |
|
super(ModelColorization, self).__init__() |
|
self.encoder = nn.Sequential( |
|
nn.Conv2d(1, 256, kernel_size=3, stride=1, padding=1), |
|
nn.MaxPool2d(kernel_size=2, stride=2), |
|
nn.ReLU(), |
|
nn.BatchNorm2d(256), |
|
nn.Conv2d(256, 128, kernel_size=3, stride=1, padding=1), |
|
nn.MaxPool2d(kernel_size=2, stride=2), |
|
nn.ReLU(), |
|
nn.BatchNorm2d(128), |
|
nn.Conv2d(128, 64, kernel_size=3, stride=1, padding=1), |
|
nn.MaxPool2d(kernel_size=2, stride=2), |
|
nn.ReLU(), |
|
nn.BatchNorm2d(64), |
|
nn.Flatten(), |
|
nn.Linear(64 * 16 * 16, 1024), |
|
) |
|
self.decoder = nn.Sequential( |
|
nn.Linear(1024, 64 * 16 * 16), |
|
nn.ReLU(), |
|
nn.Unflatten(1, (64, 16, 16)), |
|
nn.ConvTranspose2d(64, 128, kernel_size=2, stride=2), |
|
nn.ReLU(), |
|
nn.BatchNorm2d(128), |
|
nn.ConvTranspose2d(128, 256, kernel_size=2, stride=2), |
|
nn.ReLU(), |
|
nn.BatchNorm2d(256), |
|
nn.ConvTranspose2d(256, 3, kernel_size=2, stride=2), |
|
nn.Sigmoid(), |
|
) |
|
|
|
def forward(self, x): |
|
x = self.encoder(x) |
|
x = self.decoder(x) |
|
return x |