Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/kurtschelfthout/tensorken
A fun, hackable, GPU-accelerated, neural network library in Rust, written by an idiot
https://github.com/kurtschelfthout/tensorken
Last synced: about 2 months ago
JSON representation
A fun, hackable, GPU-accelerated, neural network library in Rust, written by an idiot
- Host: GitHub
- URL: https://github.com/kurtschelfthout/tensorken
- Owner: kurtschelfthout
- Created: 2023-05-01T12:51:27.000Z (over 1 year ago)
- Default Branch: main
- Last Pushed: 2024-04-07T15:55:11.000Z (9 months ago)
- Last Synced: 2024-04-07T16:44:45.563Z (9 months ago)
- Language: Rust
- Homepage:
- Size: 768 KB
- Stars: 95
- Watchers: 10
- Forks: 9
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
- awesome-rust-list - kurtschelfthout/tensorken - accelerated, neural network library in Rust, written by an idiot. (Machine Learning)
- awesome-rust-list - kurtschelfthout/tensorken - accelerated, neural network library in Rust, written by an idiot. (Machine Learning)
README
# Tensorken: A Fun, Hackable, GPU-Accelerated, Neural Network library in Rust, Written by an Idiot
Understanding deep learning from the perspective of a programmer, by building a deep learning framework from the ground up, in the spirit of [tinygrad](https://github.com/geohot/tinygrad) and [micrograd](https://github.com/karpathy/micrograd).
- Fun and hackable: most importantly Tensorken doesn't take itself too seriously. It's meant to be small, hackable, easy to understand and change above all else. If you want something usable for real work, look elsewhere.
- GPU-Accelerated: Tensorken runs on the GPU via [wgpu](https://wgpu.rs/), Rust's implementation of WebGPU. Accelerated comes with a grain of salt: tensor operations are much faster than the bundled but very naïve CPU implementation.
- Neural network: There are basic tensor operations that run on CPU and GPU and a pretty powerful autodiff implementation with a JAX-style API. It can do forward mode and reverse mode automatic differentiation, and you can calculate higher-order derivatives, combining forward and reverse however you wish. For example, Tensorken can calculate Hessians using forward-over-reverse or reverse-over-reverse.
- Rust: No particular reason other than that I'm learning Rust.
- Written by an idiot: Hi there! I know nothing about neural network or GPU programming. As a result, anything and everything in here may be slow, backward, wrong, or stupid, and that's not an exclusive or exhaustive list.## "Tensorken"?
The suffix -ke means "small" in Flemish. So tensorke is a small tensor. Some Flemish dialects append an extra n, which sounds better in English.
## The shoulders of giants
Some cool stuff I looked at while figuring out how to build this.
- [micrograd](https://github.com/karpathy/micrograd)
- [tinygrad](https://github.com/geohot/tinygrad)
- [MiniTorch](https://minitorch.github.io/module0/module0/)
- [JAX](https://jax.readthedocs.io/en/latest/autodidax.html#jax-core-machinery)
- [DiffSharp](https://diffsharp.github.io/)## Getting started
Clone the repo and run `cargo run --example tour` for an overview of tensor operations. The `jax_autodiff_cookbook` is a partial adaptation of JAX's [autodiff cookbook](https://jax.readthedocs.io/en/latest/notebooks/autodiff_cookbook.html), to demonstrate Tensorken's AD capabilities. The `makemore` examples are a translation to Tensorken (from PyTorch) of the first part of Andrej Karpathy's [Zero to Hero](https://karpathy.ai/zero-to-hero.html) neural network course, in which he builds and trains a simple neural network to generate baby names.
Then explore the code - it's not big!
Emerging posts with more explanation of the various stages of development of Tensorken. Intended to be read in order.
- [v0.1](https://github.com/kurtschelfthout/tensorken/releases/tag/v0.1): [Fun and Hackable Tensors in Rust, From Scratch](https://getcode.substack.com/p/fun-and-hackable-tensors-in-rust)
- [v0.2](https://github.com/kurtschelfthout/tensorken/releases/tag/v0.2): [Massively Parallel Fun with GPUs: Accelerating Tensors in Rust](https://getcode.substack.com/p/massively-parallel-fun-with-gpus)
- [v0.3](https://github.com/kurtschelfthout/tensorken/releases/tag/v0.3): [Beyond Backpropagation - Higher Order, Forward and Reverse-mode Automatic Differentiation for Tensorken](https://getcode.substack.com/p/beyond-backpropagation-higher-order)
- [v0.4](https://github.com/kurtschelfthout/tensorken/releases/tag/v0.4): [From Basic to Fancy Indexing - 50 ways to index your tensor](https://getcode.substack.com/p/from-basic-to-fancy-indexing)