Skip to content
forward-, reverse-, and mixed-mode automatic differentiation primitives for Julia Base + StdLibs
Branch: master
Clone or download
Type Name Latest commit message Commit time
Failed to load latest commit information.
docs Add Logo (#113) Sep 27, 2019
src Rename `DNE` -> `DoesNotExist` Oct 28, 2019
test Rename `DNE` -> `DoesNotExist` Oct 28, 2019
.gitignore Add documentation setup (#4) Apr 2, 2019
.travis.yml Allow 1.3 to fail Aug 3, 2019 init Nov 16, 2018
Project.toml Add bounds (#129) Oct 29, 2019 Typo fix. Oct 4, 2019


Travis Coveralls


The ChainRules package provides a variety of common utilities that can be used by downstream automatic differentiation (AD) tools to define and execute forward-, reverse-, and mixed-mode primitives.

The core logic of ChainRules is implemented in ChainRulesCore.jl. To add ChainRules support to your package, by defining new rrules or frules, you only need to depend on the very light-weight package ChainRulesCore.jl. This repository contains ChainRules.jl, which is what people actually use directly. ChainRules reexports all the ChainRulesCore functionality, and has all the rules for the Julia standard library.

Here are some of the core features of the package:

  • Mixed-mode composability without being coupled to a specific AD implementation.
  • Extensible rules: package authors can add rules (and thus AD support) to the functions in their packages, without needing to make a PR to ChainRules.jl .
  • Control-inverted design: rule authors can fully specify derivatives in a concise manner that supports computational efficiencies, so we will only compute as much as the user requests.
  • Propagation semantics built-in, with default implementations that allow rule authors to easily opt-in to common optimizations (fusion, increment elision, memoization, etc.).

The ChainRules source code follows the YASGuide.

You can’t perform that action at this time.