Skip to main content

Visualize easily the loss landscape of your neural networks

Project description

loss + landscape = losscape 🌄

This is losscape, a lightweight, modular, and straightforward Python library that empowers you to visualize the loss landscape of your neural networks, as in Visualizing the Loss Landscape of Neural Nets.

losscape is designed as a plug-and-play extension for your existing PyTorch models. It boasts its simplicity, modularity, and fast rendering speed.

Key Features ✨

  • 🏃 Fast Rendering: Leveraging PyTorch's torch.no_grad() feature and controlling the number of examples to compute the loss, losscape speeds up the visualization process dramatically, thus saving valuable wall time.
  • 📊 Flexible Plotting: Supports both 2D and 3D plotting options for your loss landscapes, giving you the power to choose based on your requirements and computational constraints.
  • 🔌 Plug and Play: Easy to integrate with your existing PyTorch models. No substantial modifications to your codebase are needed!

Installation 📦

You can install losscape via pip:

pip install losscape

Usage ⚙️

Here's a quick example on how to use losscape:

from losscape.train import train
from losscape.create_landscape import create_2D_losscape

model = ... # create your torch model (subclass of torch.nn.Module)
train_loader = ... # the DataLoader containing your favorite dataset

train(model, train_loader) # losscape can perform the training for you
create_2D_losscape(model, train_loader, output_vtp=True)

Typical results :

To visualize the loss landscape in 3D, use the .vtp file created by the library and simply drag-and-drop it in a VTK viewer :

Documentation 📖

For more details, please refer to the documentation. It provides a global overview on how losscape works, and on how you can leverage it with your own model. (to be written : for now you can refer to the code, its simple enough to understand the structure of the library, and you can spin up using the juypter notebook example, all available on the Github repo).

References 📚

Roadmap 🚀

Here are a couple of additions I'm planning to add in the near future:

  • 📈 Validation Loss Landscape: I'm working on the ability to visualize the validation loss landscape, in addition to the training loss landscape.
  • 🛤 Optimizer Path Visualization: Future updates will include the ability to visualize the path of gradient descent (or any other optimizer) on these landscapes using PCA.

Contact 📞

Feel free to open an issue if you find a bug or have any suggestions to improve the library. Feedback is much appreciated!

Enjoy your visualization journey with losscape ! 🎉

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

losscape-1.4.5.tar.gz (8.9 kB view hashes)

Uploaded Source

Built Distribution

losscape-1.4.5-py3-none-any.whl (8.8 kB view hashes)

Uploaded Python 3

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page