2 releases

0.0.6 Jan 9, 2025
0.0.2 Jan 7, 2025

#1543 in Math

Download history 44/week @ 2025-01-01 221/week @ 2025-01-08

265 downloads per month
Used in 3 crates

GPL-3.0-only

18KB
413 lines

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

~16MB
~297K SLoC