Poutyne is a simplified framework for PyTorch and handles much of the boilerplating code needed to train neural networks.
Use Poutyne to:
Read the documentation at Poutyne.org.
Poutyne is compatible with the latest version of PyTorch and Python >= 3.8.
@misc{Paradis_Poutyne_A_Simplified_2020,
author = {Paradis, Frédérik and Beauchemin, David and Godbout, Mathieu and Alain, Mathieu and Garneau, Nicolas and Otte, Stefan and Tremblay, Alexis and Bélanger, Marc-Antoine and Laviolette, François},
title = {{Poutyne: A Simplified Framework for Deep Learning}},
year = {2020},
url = {https://poutyne.org}
}
The core data structure of Poutyne is a Model, a way to train your own PyTorch neural networks.
How Poutyne works is that you create your PyTorch module (neural network) as usual but when comes the time to train it you feed it into the Poutyne Model, which handles all the steps, stats and callbacks, similar to what Keras does.
Here is a simple example:
# Import the Poutyne Model and define a toy dataset
from poutyne import Model
import torch
import torch.nn as nn
import numpy as np
import torchmetrics
num_features = 20
num_classes = 5
hidden_state_size = 100
num_train_samples = 800
train_x = np.random.randn(num_train_samples, num_features).astype('float32')
train_y = np.random.randint(num_classes, size=num_train_samples).astype('int64')
num_valid_samples = 200
valid_x = np.random.randn(num_valid_samples, num_features).astype('float32')
valid_y = np.random.randint(num_classes, size=num_valid_samples).astype('int64')
num_test_samples = 200
test_x = np.random.randn(num_test_samples, num_features).astype('float32')
test_y = np.random.randint(num_classes, size=num_test_samples).astype('int64')
Select a PyTorch device so that it runs on GPU if you have one:
cuda_device = 0
device = torch.device("cuda:%d" % cuda_device if torch.cuda.is_available() else "cpu")
Create yourself a PyTorch network:
network = nn.Sequential(
nn.Linear(num_features, hidden_state_size),
nn.ReLU(),
nn.Linear(hidden_state_size, num_classes)
)
You can now use Poutyne's model to train your network easily:
model = Model(
network,
'sgd',
'cross_entropy',
batch_metrics=['accuracy'],
epoch_metrics=['f1', torchmetrics.AUROC(num_classes=num_classes, task="multiclass")],
device=device
)
model.fit(
train_x, train_y,
validation_data=(valid_x, valid_y),
epochs=5,
batch_size=32
)
Since Poutyne is inspired by Keras, one might have notice that this is really similar to some of its functions.
You can evaluate the performances of your network using the evaluate
method of Poutyne's model:
loss, (accuracy, f1score) = model.evaluate(test_x, test_y)
Or only predict on new data:
predictions = model.predict(test_x)
See the complete code here. Also, see this for an example for regression.
One of the strengths Poutyne are callbacks. They allow you to save checkpoints, log training statistics and more. See this notebook for an introduction to callbacks. In that vein, Poutyne also offers an ModelBundle class that offers automatic checkpointing, logging and more using callbacks under the hood. Here is an example of usage.
from poutyne import ModelBundle
# Everything is saved in ./saves/my_classification_network
model_bundle = ModelBundle.from_network(
'./saves/my_classification_network', network, optimizer='sgd', task='classif', device=device
)
model_bundle.train_data(train_x, train_y, validation_data=(valid_x, valid_y), epochs=5)
model_bundle.test_data(test_x, test_y)
See the complete code here. Also, see this for an example for regression.
Before installing Poutyne, you must have the latest version of PyTorch in your environment.
pip install poutyne
pip install -U git+https://github.com/GRAAL-Research/poutyne.git@dev
docker pull ghcr.io/graal-research/poutyne:latest
Look at notebook files with full working examples:
ResNet-18
on the CUB-200 dataset.or in Google Colab
:
ResNet-18
on the CUB-200 dataset.We welcome user input, whether it is regarding bugs found in the library or feature propositions ! Make sure to have a look at our contributing guidelines for more details on this matter.
This project supported by Frédérik Paradis and David Beauchemin. Join the sponsors - show your ❤️ and support, and appear on the list!
Poutyne is LGPLv3 licensed, as found in the LICENSE file.
Poutyne's name comes from poutine, the well-known dish from Quebec. It is usually composed of French fries, squeaky cheese curds and brown gravy. However, in Quebec, poutine also has the meaning of something that is an "ordinary or common subject or activity". Thus, Poutyne will get rid of the ordinary boilerplate code that plain PyTorch training usually entails.
Yuri Long from Arlington, VA, USA [CC BY 2.0]