prototorch_models/examples/glvq_spiral.py

53 lines
1.3 KiB
Python
Raw Normal View History

"""GLVQ example using the spiral dataset."""
2021-05-07 13:25:04 +00:00
import prototorch as pt
import pytorch_lightning as pl
import torch
class StopOnNaN(pl.Callback):
def __init__(self, param):
super().__init__()
self.param = param
def on_epoch_end(self, trainer, pl_module, logs={}):
if torch.isnan(self.param).any():
raise ValueError("NaN encountered. Stopping.")
if __name__ == "__main__":
# Dataset
2021-05-07 13:25:04 +00:00
train_ds = pt.datasets.Spiral(n_samples=600, noise=0.6)
# Dataloaders
2021-05-07 13:25:04 +00:00
train_loader = torch.utils.data.DataLoader(train_ds,
num_workers=0,
batch_size=256)
# Hyperparameters
2021-05-11 14:15:08 +00:00
nclasses = 2
prototypes_per_class = 20
hparams = dict(
2021-05-11 14:15:08 +00:00
distribution=(nclasses, prototypes_per_class),
prototype_initializer=pt.components.SSI(train_ds, noise=1e-1),
2021-05-04 18:56:16 +00:00
transfer_function="sigmoid_beta",
transfer_beta=10.0,
lr=0.01,
)
# Initialize the model
2021-05-07 13:25:04 +00:00
model = pt.models.GLVQ(hparams)
# Callbacks
2021-05-07 13:25:04 +00:00
vis = pt.models.VisGLVQ2D(train_ds, show_last_only=True, block=True)
snan = StopOnNaN(model.proto_layer.components)
# Setup trainer
trainer = pl.Trainer(
max_epochs=200,
callbacks=[vis, snan],
)
# Training loop
trainer.fit(model, train_loader)