2 releases
new 0.0.6 | Jan 9, 2025 |
---|---|
0.0.2 | Jan 7, 2025 |
#1093 in Math
73 downloads per month
Used in algebraeon-rings
125KB
3.5K
SLoC
Algebraeon
Algebraeon is a computer algebra system written purely in Rust. It implements algorithms for working with matrices, polynomials, algebraic numbers, factorizations, etc. The focus is on exact algebraic computations rather than approximate numerical solutions.
What it can do
Algebraeon can currently do the following:
- Euclids algorithm for GCD and the extended version for obtaining Bezout coefficients.
- Polynomial GCD computations using subresultant pseudo-remainder sequences.
- AKS algorithm for natural number primality testing.
- Matrix algorithms including:
- Putting a matrix into Hermite normal form. In particular putting it into echelon form.
- Putting a matrix into Smith normal form.
- Gram–Schmidt algorithm for orthogonalization and orthonormalization.
- Putting a matrix into Jordan normal.
- Finding the general solution to a linear or affine system of equations.
- Polynomial factoring algorithms including:
- Kronecker's method for factoring polynomials over the integers (slow).
- Berlekamp-Zassenhaus algorithm for factoring polynomials over the integers.
- Berlekamp's algorithm for factoring polynomials over finite fields.
- Trager's algorithm for factoring polynomials over algebraic number fields.
- Expressing symmetric polynomials in terms of elementary symmetric polynomials.
- Computations with algebraic numbers:
- Real root isolation and arithmetic.
- Complex root isolation and arithmetic.
- Computations with multiplication tables for small finite groups.
- Todd-Coxeter algorithm for the enumeration of finite index cosets of a finitely generated groups. and much more.
Planned algorithms
- Fast integer factorization.
- LLL basis reduction algorithm.
- Universal cyclotomic field.
- Ideals in algebraic number fields.
- Algebraic closure and Galois theory of finite fields.
- Splitting fields of algebraic number fields.
- Galois groups of algebraic number fields.
- P-adic root approximation and arithmetic.
Usage
Add the required crates to your cargo.toml
file
Factoring an polynomials
use algebraeon_rings::{polynomial::polynomial::*, ring_structure::{elements::*, structure::*}};
use malachite_nz::integer::Integer;
let x = &Polynomial::<Integer>::var().into_ergonomic();
let f = (x.pow(30) - 1).into_verbose();
println!("unfactored f = {}", f);
println!("factored f = {}", f.factor().unwrap());
Dependencies
~18MB
~321K SLoC