Symbolic differentiation and Rust code generation library.
Project description
Gradgen: what it does
Gradgen is a Python library for symbolic differentiation and (embedded) Rust code generation.
Code generation example
Here is an example where we will define the function
$$f(x, u) = \Vert x \Vert_2^2 + u \sin(x_1) + x_2 x_3,$$
for a three-dimensional input $x$ and scalar $u$.
The goal is to generate Rust code for the functions $f$, $Jf$ (the Jacobian matrix of $f$).
Furthermore, we want to generate a Rust function that computes simultaneous $f$
and $\nabla_x f$. This often is computationally more efficient compared to computing
$f(x, u)$ and $\nabla_x f(x, u)$ in separate functions (look for FunctionBundle below).
from gradgen import CodeGenerationBuilder, Function, RustBackendConfig, SXVector, sin
# Define the symbolic inputs.
x = SXVector.sym("x", 3)
u = SXVector.sym("u", 1)
# Build a simple scalar-valued function of x and u
# f(x, u) = ||x||_2^2 + u_1 * sin(x_1) + x_2 * x_3
f_expr = x.norm2sq() + u[0] * sin(x[0]) + x[1] * x[2]
# Define a Function object
f = Function(
"energy",
[x, u],
[f_expr],
input_names=["x", "u"],
output_names=["energy"],
)
# (Optional) Evaluate f in Python
x_value = [1.0, 2.0, -0.5]
u_value = [3.0]
print("f(x, u) =", f(x_value, u_value))
# Generate code
project = (
CodeGenerationBuilder()
.with_backend_config(
RustBackendConfig()
.with_crate_name("my_kernel")
.with_backend_mode("no_std")
.with_scalar_type("f64")
)
.for_function(f)
.add_primal()
.add_jacobian()
.add_joint(
FunctionBundle()
.add_f()
.add_jf(wrt=0)
)
.with_simplification("medium")
.done()
.build(Path(__file__).resolve().parent / "codegen_kernel")
)
See the demos and this more complete tutorial.
Special case: optimal control
In applications such as optimal control, the generated code can become too large very easily. However, the problem structure can be exploited to generate code with complexity that doesn't increase with the prediction horizon.
Instead of completely unrolled code, Gradgen exploits the problem structure to create high-performance, human-readable embeddable Rust code.
See this complete tutorial for details.
Unique features
- Truly embdedable safe Rust code with optional
#[no_std], no dynamic memory allocation, nopanic!s - Specialised code generation tools for optimal control problems (docs)
- Very efficient code generation thanks to modular code generation using
map,zip,repeat, andchainhigh-order functions. - Supports both single (
f32) and double (f64) precision arithmetic
Where to go next?
See the demos and this more complete documentation for details.
Show us some love!
If you find Gradgen useful, give us a star on GitHub!
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file gradgen-0.4.2a1.tar.gz.
File metadata
- Download URL: gradgen-0.4.2a1.tar.gz
- Upload date:
- Size: 176.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.13.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
49ce47312d382ad69600a51b1bd690242c4e83b67f3598d0c4401b85e6c233e2
|
|
| MD5 |
b39558481e9a5078bb6b3143b7547302
|
|
| BLAKE2b-256 |
bbab121ea5ce24dad7df2d6f576632426034f61d1a345fcb9f9eaaa09fa4749e
|
File details
Details for the file gradgen-0.4.2a1-py3-none-any.whl.
File metadata
- Download URL: gradgen-0.4.2a1-py3-none-any.whl
- Upload date:
- Size: 132.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.13.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
f4e3b3660f65953f94ea7e1d50698f9da3c1cf6780c9fa36f60333c55a3a5f4a
|
|
| MD5 |
501072d334adb345c020146b9d56af8a
|
|
| BLAKE2b-256 |
06b59a8ac115a79ab85a3cb2e4c605f726dc9b92a0b4b25de3d5f58036859d78
|