Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/marco-christiani/zigrad
A deep learning framework built on an autograd engine with high level abstractions and low level control.
https://github.com/marco-christiani/zigrad
autograd deep-learning machine-learning neural-network tensor zig zig-package ziglang
Last synced: about 2 months ago
JSON representation
A deep learning framework built on an autograd engine with high level abstractions and low level control.
- Host: GitHub
- URL: https://github.com/marco-christiani/zigrad
- Owner: Marco-Christiani
- License: lgpl-3.0
- Created: 2023-12-01T18:38:16.000Z (about 1 year ago)
- Default Branch: main
- Last Pushed: 2024-11-30T04:08:06.000Z (about 2 months ago)
- Last Synced: 2024-11-30T04:19:24.241Z (about 2 months ago)
- Topics: autograd, deep-learning, machine-learning, neural-network, tensor, zig, zig-package, ziglang
- Language: Zig
- Homepage: http://zigrad.datatician.io/
- Size: 6.97 MB
- Stars: 33
- Watchers: 2
- Forks: 2
- Open Issues: 10
-
Metadata Files:
- Readme: README.md
- License: LICENSE
- Roadmap: docs/roadmap.norg
Awesome Lists containing this project
README
# Zigrad
#### A deep learning framework built on an autograd engine with high level abstractions and low level control.https://github.com/user-attachments/assets/3842aa72-9b16-4c25-8789-eac7159e3768
**Fast**
2.5x+ speedup over a compiled PyTorch model on Apple Silicon, 1.5x on x86. Expect similar performance gains across more architectures and platforms as MKL/CUDA support improves and Zigrad's ML graph compiler is operational.*
*Tensorflow excluded for scaling purposes (too slow). A hermetic, reproducible benchmarking pipeline built on Bazel will allow testing across more platforms (in progress, testers needed).
**Built for specialized optimization**
Zigrad's design enables deep control and customization
- Fine-grained control over memory management
- Flexible tradeoffs between performance characteristics like latency vs throughput
- Optimize for your specific hardware, use case, and system requirements
- No abstraction layers or build systems that make aggressive optimizations challenging or complexBut wait, there's more..
- Tiny binaries: binaries for the MNIST tests shown are under 400kb in `ReleaseFast` mode and under 200kb in `ReleaseSmall`.
- Graph tracing
- Tensorboard integration*
- Cross platform
- Statically linked executables
- Minimal and transparent heap allocations*Not yet merged
## Features
### Trace the Computation Graph
![](./docs/comp_graph_mnist_simple_noag.svg)
An example of tracing the computation graph generated by a fully connected neural network for MNIST.
- *Input:* Batch of images 28x28 pixel samples.
- **Flatten:** `28x28 -> 784`
- **FC1**: Linear layer `784 -> 128`
- **ReLU**
- **FC2:** Linear layer `128 -> 64`
- **ReLU**
- **FC3:** Linear layer `64 -> 10`
- *Output:* Value for each of the 10 classesWe did not have to use Zigrad's modules to write this network at all, as Zigrad is backed by a capable autograd engine. Even when using the autograd backend to dynamically construct the same neural network Zigrad can still trace the graph and render it.
> Note: Since the graph is generated from the autograd information, we set the labels for the nodes by naming the tensors for the sake of the diagram.
![](./docs/comp_graph_mnist_simple_ag.svg)
## Getting Started
Only dependency is a BLAS library.
### Linux
On linux (or intel mac) you have some options,
- MKL (recommended for best performance)
- See https://www.intel.com/content/www/us/en/developer/tools/oneapi/onemkl-download.html
- Reccommend a system installation for simplicity although this can work with `conda` for example, just make sure you adjust the library paths as necessary.
- OpenBLAS
- See https://github.com/OpenMathLib/OpenBLAS/wiki/Precompiled-installation-packages
- Likely available through your package manager as `libopenblas-dev` or `openblas-devel`### Apple Silicon
- Nothing :)
### Examples
The `examples/` directory has some standalone templates you can take and modify, the zon files are pinned to commit hashes.
Hello world example shows how to run a backward pass using the `GraphManager.` Note that in this very simple example, we do not need the `GraphManager` and the script could be simplified but this is designed to get you familiar with the workflow.
```shell
git clone https://github.com/Marco-Christiani/zigrad/
cd zigrad/examples/hello-world
zig build run
```Run the mnist demo
```shell
cd zigrad/examples/mnist
make help
make
```## Roadmap
A lot is planned and hoping for support from the Zig community so we can accomplish some of the more ambitious goals.
- More comprehensive MKL support
- More parallelization (e.g. activation functions)
- CUDA support
- Lazy tensors
- Static graph optimization
- Dynamic graph compiler
- MLIR
- Support for popular formats like ONNX and ggml.
- ZML translation for inference## Known Issues and Limitations
- Lack of GPU support for now
- Effort has been directed towards performant primitives, not many layer types have been implemented
- e.g. conv, pooling, etc are test implementations for verification, they are slow and unoptimized, I would not use them
-## Contributing
- In addition to the above list, anything in in [docs/roadmap.norg](docs/roadmap.norg) is planned
- Any open issue is available for development, just leave a comment mentioning your interest and I can provide support to help get you started if necessary
- Otherwise, **please open an issue first, before working on a PR**
- If you are interested in contributing but do not know where to start then open an issue or leave a comment