functorch
functorch
functorch | functorch | |
---|---|---|
3 | 11 | |
397 | 1,375 | |
- | 0.6% | |
9.7 | 0.0 | |
over 2 years ago | 5 days ago | |
C++ | Jupyter Notebook | |
BSD 3-clause "New" or "Revised" License | BSD 3-clause "New" or "Revised" License |
Stars - the number of stars that a project has on GitHub. Growth - month over month growth in stars.
Activity is a relative number indicating how actively a project is being developed. Recent commits have higher weight than older ones.
For example, an activity of 9.0 indicates that a project is amongst the top 10% of the most actively developed projects that we are tracking.
functorch
- Functorch: Jax-like composable function transforms for PyTorch
-
[P] Announcing Equinox! Filtered transformations + callable PyTrees = elegant neural networks in JAX
By the way, those aren't really inherent to functional programming/Jax - this is an implementation of those (at least grad/vmap/jvp/etc.) in PyTorch: https://github.com/facebookresearch/functorch
-
[Discussion] What do you like or dislike about RL Systems/Frameworks? TF, PyTorch, JAX, RLLib, Acme, SEED
If you want vmap in PyTorch, you can check out https://github.com/facebookresearch/functorch. It’s largely an imitation of Jax’s API, but in PyTorch.
functorch
-
What is the most efficient approach to ensemble a pytorch actor-critic model?
I would suggest checking https://pytorch.org/functorch/ and https://github.com/metaopt/torchopt for efficient inference and training with ensembles (e.g., t be independent actors in a multi-agent setting or multiple critics).
-
[P] Multidimensional array batch indexing for pytorch and numpy
There were some bugs still with advanced indexing in an older release of functorch, I believe they should be fixed now though: https://github.com/pytorch/functorch/pull/862
- Functorch: Jax-like composable function transforms for PyTorch
-
Jax vs. Julia (Vs PyTorch)
Tangentially related but there is an effort to get some of the features of JAX into PyTorch: https://pytorch.org/functorch/
-
[D] Current State of JAX vs Pytorch?
Fwiw, composable vmap and stuff like that have also been implemented in PyTorch now - see functorch :) https://github.com/pytorch/functorch
-
[D] Ideal deep learning library
Fwiw, it’s not like Pytorch’s design prevents function transformations from being implemented. See functorch for an example of grad/vmap function transforms: https://github.com/pytorch/functorch
-
[P] Made Some Pytorch Modules For Agent Systems
You may find vmap from functorch to be quite useful: https://github.com/pytorch/functorch
-
[D] Are you using PyTorch or TensorFlow going into 2022?
If you're interested in function transformations in PyTorch, try out functorch :) https://github.com/pytorch/functorch
- PyTorch: Where we are headed and why it looks a lot like Julia (but not exactly)
-
Show HN: How does Jax allocate memory on a TPU? An interactive C++ walkthrough
The pytorch programming model is just really hard to adapt to an XLA-like compiler. Imperative python code doesn't translate to an ML graph compiler particularly well; Jax's API is functional, so it's easier to translate to the XLA API. By contrast, torch/xla uses "lazy tensors" that record the computation graph and compile when needed. The trouble is, if the compute graph changes from run to run, you end up recompiling a lot.
I guess in Jax you'd just only apply `jax.jit` to the parts where the compute graph is static? I'd be curious to see examples of how this works in practice. Fwiw, there's an offshoot of pytorch that is aiming to provide this sort of API (see https://github.com/pytorch/functorch and look at eager_compilation.py).
(Disclaimer: I worked on this until quite recently.)
What are some alternatives?
wenet - Production First and Production Ready End-to-End Speech Recognition Toolkit
jax - Composable transformations of Python+NumPy programs: differentiate, vectorize, JIT to GPU/TPU, and more
equinox - Elegant easy-to-use neural networks + scientific computing in JAX. https://docs.kidger.site/equinox/
nn - 🧑🏫 60 Implementations/tutorials of deep learning papers with side-by-side notes 📝; including transformers (original, xl, switch, feedback, vit, ...), optimizers (adam, adabelief, sophia, ...), gans(cyclegan, stylegan2, ...), 🎮 reinforcement learning (ppo, dqn), capsnet, distillation, ... 🧠
onnxruntime - ONNX Runtime: cross-platform, high performance ML inferencing and training accelerator
onnx-simplifier - Simplify your onnx model
ncnn - ncnn is a high-performance neural network inference framework optimized for the mobile platform
torch2trt - An easy to use PyTorch to TensorRT converter
Open3D - Open3D: A Modern Library for 3D Data Processing
BinaryBuilder.jl - Binary Dependency Builder for Julia
py2many - Transpiler of Python to many other languages
vision - Datasets, Transforms and Models specific to Computer Vision