Skip to main content

An easy-to-use PyTorch implementation of the Kolmogorov Arnold Network

Project description

TorchKAN: A Simplified KAN Model (Version: 0)

PyPI version

This project demonstrates the training, validation, and quantization of the KAN model using PyTorch with CUDA acceleration. The torchkan model evaluates performance on the MNIST dataset.

Project Status: Under Development

The KAN model has shown promising results amidst various GAMs since the 1980s. This implementation, inspired by various sources, achieves over 97% accuracy with an eval time of 0.6 seconds and the quantised model achieves under 0.55 seconds on the MNIST dataset in 8 epochs on a Ubuntu 22.04 OS with a single Nvidia RTX4090.

As this model is still under study, further exploration into its full capabilities is ongoing.

Prerequisites

Ensure you have the following installed on your system:

  • Python (version 3.9 or higher)
  • CUDA Toolkit (corresponding to your PyTorch installation's CUDA version)
  • cuDNN (compatible with your installed CUDA Toolkit)

Installation

Tested on MacOS and Linux.

1. Clone the Repository

Clone the torchkan repository and set up the project environment:

git clone https://github.com/1ssb/torchkan.git
cd torchkan
pip install -r requirements.txt

Alternately PyPi install as:

pip install torchKAN

2. Configure CUDA environment variables if they are not already set:

export PATH=/usr/local/cuda/bin:$PATH
export LD_LIBRARY_PATH=/usr/local/cuda/lib64:$LD_LIBRARY_PATH

3. Configure Weights & Biases (wandb)

To track experiments and model performance with wandb:

  1. Set Up wandb Account:
  • Sign up or log in at Weights & Biases.
  • Find your API key in your account settings.
  1. Initialize wandb in Your Project:

Before running the training script, initialize wandb:

wandb login

When prompted, enter your API key. This will link your script executions to your wandb account.

  1. Make sure to change the Entity name in the mnist.py file to your username instead of 1ssb

This script will train the model, validate it, and log performance metrics using wandb.

Contact

For any inquiries or support, contact: Subhransu.Bhattacharjee@anu.edu.au

Cite this Project

If you use this project in your research or wish to refer to the baseline results, please use the following BibTeX entry.

@misc{torchkan,
  author = {Subhransu S. Bhattacharjee},
  title = {TorchKAN},
  year = {2024},
  publisher = {GitHub},
  journal = {GitHub repository},
  howpublished = {\url{https://github.com/1ssb/torchkan/}}
}

Contributions

Contributions are welcome. Please raise issues as necessary after commit "Fin.", scheduled end-June, 2024. The code is licensed under the MIT License.

References

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

TorchKAN-0.1.1.tar.gz (3.6 kB view details)

Uploaded Source

Built Distribution

TorchKAN-0.1.1-py3-none-any.whl (3.6 kB view details)

Uploaded Python 3

File details

Details for the file TorchKAN-0.1.1.tar.gz.

File metadata

  • Download URL: TorchKAN-0.1.1.tar.gz
  • Upload date:
  • Size: 3.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.0.0 CPython/3.11.4

File hashes

Hashes for TorchKAN-0.1.1.tar.gz
Algorithm Hash digest
SHA256 06e3529df4e15feca598bd6dcf25de1b6a75e03e897b182026ceb49c64e743af
MD5 ec2647cc35819df50c346621ce5fe38b
BLAKE2b-256 1b176e4e99e41a0bdee061a8814b3dc65eb046df83044429c1461d71a3609779

See more details on using hashes here.

File details

Details for the file TorchKAN-0.1.1-py3-none-any.whl.

File metadata

  • Download URL: TorchKAN-0.1.1-py3-none-any.whl
  • Upload date:
  • Size: 3.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.0.0 CPython/3.11.4

File hashes

Hashes for TorchKAN-0.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 b5dc5b99c1fd0246c6431254e7b04cd5e0b6bc6079456e87c064a1d0d983b3e1
MD5 3d24f6ccf3762bb3d7c25898a2768c58
BLAKE2b-256 aefda1a2479ffa4c04ad70f3f12291d986487225d991d14185ef3827b32d4a79

See more details on using hashes here.

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