Differentiable expression templates in Rust.
At runtime:
rust
use dxpr::prelude::*;
let x = 4;
assert_eq!(-4, (-var(&x)).eval());
assert_eq!(-1, (-var(&x)).grad(&x).eval());
assert_eq!(0, (-var(&x)).grad(&x).grad(&x).eval());
assert_eq!(0, (-var(&x)).grad(&x).grad(&x).grad(&x).grad(&x).grad(&x).eval());
At compile time: ```rust
use dxpr::{expr::Expr, ops, prelude::*};
const X: i32 = 4;
const A: Expr<&i32> = var(&X);
const EXPRESSION: Exprbuild.rs
could easily evaluate an arbitrary expression and write it, unevaluated, to a file.
```
We can reuse an expression without copying any variables by calling eval
or grad
on a reference:
rust
use dxpr::prelude::*;
let x = 4;
let a = var(&x);
let expression = -a;
assert_eq!(-4, (&expression).eval());
assert_eq!(-4, (&expression).eval());
assert_eq!(-4, (&expression).eval());
// still movable the last time:
assert_eq!(-4, expression.eval());
// can't use it again: ------ `expression` moved due to this method call
// /* bad! */ assert_eq!(-4, expression.eval());
// ^^^^^^^^^^ value used here after move
Index
and RangeBound
operators (i.e. a[b]
and a..b
)