leffa / examples /pytorch_lightning_multinode.py
dhairya16's picture
Upload folder using huggingface_hub
a45dd37 verified
import torch, torch.nn as nn, torch.utils.data as data, torchvision as tv
import lightning as L
encoder = nn.Sequential(nn.Linear(28 * 28, 128), nn.ReLU(), nn.Linear(128, 3))
decoder = nn.Sequential(nn.Linear(3, 128), nn.ReLU(), nn.Linear(128, 28 * 28))
class LitAutoEncoder(L.LightningModule):
def __init__(self, encoder, decoder):
super().__init__()
self.encoder, self.decoder = encoder, decoder
def training_step(self, batch, batch_idx):
x, y = batch
x = x.view(x.size(0), -1)
z = self.encoder(x)
x_hat = self.decoder(z)
loss = nn.functional.mse_loss(x_hat, x)
self.log("train_loss", loss)
return loss
def configure_optimizers(self):
return torch.optim.Adam(self.parameters(), lr=1e-3)
def prepare_data(self):
tv.datasets.MNIST(".", download=True)
def train_dataloader(self):
dataset = tv.datasets.MNIST(".", transform=tv.transforms.ToTensor())
return data.DataLoader(dataset, batch_size=64)
# Lightning will automatically use all available GPUs!
trainer = L.Trainer()
trainer.fit(LitAutoEncoder(encoder, decoder))