- Fiddle - Pax's layer library, Praxis, now has layers and BaseParameterizable configured with Fiddle, a Python-first configuration library. Fiddle reduces boilerplate, and adds productivity features including history tracking, graphviz visualization, support for aliasing objects, and more.
- CLI Experiment and Data Injectability - Pax users are now able to select which experiments to run without the need to recompile for each experiment. Using a CLI interface based on Fiddle, users can override subsets of the experiment’s canonical dataset.
- CLU Metrics - Through Praxis, Pax has adopted CLU metrics as its standard metric interface. This allows other Jax/Flax codebases that have CLU metrics to use them in Praxis.
- Orbax Integration - Pax has consolidated on the Orbax checkpoint library as the standard checkpointing library. Orbax supports pjit, pmap, and Pathways checkpointing. Orbax facilitates checkpoint compatibility with other frameworks and provides common functionality throughout the JAX ecosystem.
- Flax Interoperability - Through Praxis, Pax now supports shape inference,
__call__
for forward propagation, and has adopted Linen’s AxisMetadata for its mid-level sharding APIs. These changes improve interoperability with other Flax-based libraries such as T5X. - Custom Training Loop Support - Pax now provides limited support for customized training pipelines. Users can define a custom "train program" to encapsulate their training logic and use it in BaseExperiment. Customizable training loops pave the path for features such as multi-task support.
- SeqIO - Pax has adopted SeqIO. Supporting SeqIO allows users with existing SeqIO Tasks, input pipelines and evaluation workflows to use them directly in Pax. We are working to make the Pax-SeqIO evaluation setup more flexible and robust.
- Documentation - We have added documentation and Jupyter Notebook tutorials to our docs folder. (Although you may notice some empty links in the doc, they are placeholders for upcoming docs.)
- Version: 1.0.0
- Build Date: 20230329
- Paxml commit: 033eb2421a6fc3e24f76bb19dd260c6776c5933b
- Praxis version: 1.0.0
- Praxis commit: 621c2ca7bfcd0e21ea118a3d8e40e29b48313c0c
- Version: 0.4.0
- Build Date: 20230329
- Paxml commit: 033eb2421a6fc3e24f76bb19dd260c6776c5933b
- Praxis version: 0.4.0
- Praxis commit: 621c2ca7bfcd0e21ea118a3d8e40e29b48313c0c
- Partitioning API refactoring
- Orbax checkpointing integration
- Improve AutoML and hyperparameter search support
- Improve support for differential privacy
- Support for bool, int32, etc. as non-trainable parameters
- Version: 0.3.0
- Build Date: 20230201
- Paxml commit: cab3ed811174682733e2c836363510162fbfb1da
- Praxis version: 0.3.0
- Praxis commit: 9e1d13d888ac18a567e249ddb41e6b1bd1fe505a
- fix the HBM OOM error when loading the checkpoint using orbax
- Version: 0.2.1
- Build Date: 20221121
- Paxml commit: c4628a21946dd13eb5a42b6f5862284088d90730
- Praxis version: 0.2.1
- Praxis commit: f7e98026c1c5ecbc6e4aff175621d443fa37fcf2
- Revamp training and evaluation/decoding loops in preparation of multi-task learning support
- Better seqio metrics and clu metrics support
- Suppot per-core batch size < 1
- Introduction of training input specifications
- Add GPT-3-like Language Modeling configuration
- Add ResNet-50 image classification configuration
- Checkpointing
- Save on-demand checkpoint when preemption signal is received
- Migration to Orbax checkpointing
- Save checkpoints more consistently after pre-emption and when training completes
- Summaries
- Add support for aggregation across steps
- TPU profiling can be configured and automated
- Improvements to Auto-ML and hyperparameters sweeping using PyGlove
- Use etils for handling filenames / directories
- Version: 0.2.0
- Build Date: 20221114
- Paxml commit: 16fd2143827522acfb7a7e22767a008eaae07e24
- Praxis version: 0.2.0
- Praxis commit: 413da1ad8148f27faebca119f8c5deedca66228b
- Version: 0.1.0
- Build Date: 20220702
- Commit: 546370f5323ef8b27d38ddc32445d7d3d1e4da9a
- Praxis version: 0.1.0