Automatic Differentiation Library

crates.io docs build rust-clippy analyze

AUTOmatic Derivatives & Jacobians by djmaxus and you

Functionality

Single variables

```rust use autodj::single::*;

let x : DualNumber = 2.0.into_variable();

// values can be borrowed for arithmetic operations let f = x * x + &1.0.into();

asserteq!(f.value(), 5.0); asserteq!(f.deriv(), 4.0);

// fmt::Display resembles Taylor expansion assert_eq!(format!("{f}"), "5+4∆"); ```

Multiple variables

Multivariate differentiation is based on multiple dual components. Such an approach requires no repetitive and "backward" differentiations. Each partial derivative is tracked separately from the start, and no repetitive calculations are made.

For built-in multivariate specializations, independent variables can be created consistently using .into_variables() method.

Static number of variables

```rust use autodj::array::*;

// consistent set of independent variables let vars : DualVariables<2> = [2.0, 3.0].intovariables(); let [x, y] = vars.get().toowned();

let f = x * (y - 1.0.into());

asserteq!(f.value(), 4.); asserteq!(f.grad() , &[2., 2.]); assert_eq!(format!("{f}"), "4+[2.0, 2.0]∆"); ```

Dynamic number of variables

```rust use autodj::vector::*;

let x : DualVariables = vec![1., 2., 3., 4., 5.].into_variables();

let f : DualNumber = x.get() .iter() .map(|x : &DualNumber| x * &2.0.into()) .sum();

assert_eq!(f.value(), 30.);

f.grad() .iter() .foreach(|deriv| asserteq!(deriv, &2.0) ); ```

Generic dual numbers

rust // can be specialized for your needs use autodj::common::Common;

Motivation

I do both academic & business R&D in the area of computational mathematics. As well as many of us, I've written a whole bunch of sophisticated Jacobians by hand.

One day, I learned about automatic differentiation based on dual numbers. Almost the same day, I learned about Rust as well :crab:

Then, I decided to:

Project goals

Anticipated features

You are very welcome to introduce issues to promote most wanted features or to report a bug.

Comparison with autodiff

As far as I noticed, autodj currently has the following differences

Some differences are planned to be eliminated as noted in the roadmap.

Within this crate, you may study & launch test target /tests/autodiff.rs to follow some differences.

shell cargo test --test autodiff -- --show-output