Thanks to visit codestin.com
Credit goes to github.com

Skip to content

exclamaforte/diode

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

89 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

diode

torch-diode

torch-diode is a library for programmatically altering the performance-relevant decisions made by torch.compile. It makes it easy to gather data on the outcomes of decisions, and then train Machine Learning models on that data. It initially focuses on Matmul Kernel selection, but it will be expanded to other decisions in the future. Documentation

Target Audience:

  • Developers looking to adapt the compilation of their model to their specific situation.
  • Hardware Vendors looking to optimize torch.compile heuristics for their hardware.
  • OSS Contributors looking to add support for less popular hardware.

Features:

  • Pre-Trained Models: Profit from community efforts to gather data and train models.
  • Data collection: Gather data from torch external interfaces.
  • Stable Type Definitions: storing data from the external interfaces.
  • Model Training Code: Train ML models on the gathered data and contribute back to the torch community.

Featured Models

  • Matrix Multiplication Kernel Prediction: Predict the runtime of matrix multiplication kernels. The results of this model are enabled in fast-autotune.

Option 1: Installation with Pre-Trained Models

If you want to get access to the pre-trained performance models, as well as the libraries, install torch-diode:

$ pip install torch-diode

And then import torch_diode in python:

import torch_diode

This import has several side-effects, each of which are dependent on the success of the previous step:

  1. Attempt to import torch.
  2. Register dummy models to the relevant torch.compile interfaces.
  3. For each registration that is successful, it will load the actual model and register it.
  4. Enable the configs in torch.compile that engage the models.

Option 2: Installation without Pre-Trained Models

diode requires nightly pytorch, or pytorch 2.9 or later.

For developers who don't want these side effects, simply installing torch-diode-lib will get access to the library.

$ pip install torch-diode-lib

The import remains the same:

import torch_diode

Option 3: Install from Source

git clone https://github.com/exclamaforte/diode.git
cd diode
pip install .

Model Organization

Directory Structure

Models are organized in a structured directory format:

trained_models/
├── <model_purpose>/
│   ├── <model_name>.pt
│   └── ...
└── <other_model_file>.pt

Example:

trained_models/
├── matmul_kernel_runtime_prediction/
│   ├── v1_model.pt
│   └── v2_model.pt
└── matmul_model_exhaustive.pt

Get Started

The main entry point is in workflows.

Package Variants

  • torch-diode: Full package with auto-registration to PyTorch Inductor
  • torch-diode-lib: Library-only version without auto-registration

About

torch-diode: Train ML models that interact with torch.compile

Resources

License

Contributing

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Contributors 2

  •  
  •  

Languages