Libsemigroups

Jul 20, 2023

C++ library for semigroups and monoids

libsemigroups is a C++11 library containing implementations of several algorithms for computing finite and finitely presented semigroups. Namely

  • the Froidure-Pin algorithm for computing finite semigroups;
  • the Todd-Coxeter algorithm for finitely presented semigroups and monoids;
  • the Knuth-Bendix algorithm for finitely presented semigroups and monoids;
  • the Schreier-Sims algorithm for permutation groups.

See also https//github.com/libsemigroups/libsemigroups



Checkout these related ports:
  • Zn_poly - C library for polynomial arithmetic
  • Zimpl - Language to translate the LP models into .lp or .mps
  • Zegrapher - Software for plotting mathematical objects
  • Zarray - Dynamically typed N-D expression system based on xtensor
  • Z3 - Z3 Theorem Prover
  • Yices - SMT solver
  • Yacas - Yet Another Computer Algebra System
  • Xtensor - Multi-dimensional arrays with broadcasting and lazy computing
  • Xtensor-python - Python bindings for xtensor
  • Xtensor-io - Xtensor plugin to read/write images, audio files, numpy npz and HDF5
  • Xtensor-blas - BLAS extension to xtensor
  • Xspread - Spreadsheet program for X and terminals
  • Xppaut - Graphical tool for solving differential equations, etc
  • Xplot - X11 plotting package
  • Xlife++ - XLiFE++ eXtended Library of Finite Elements in C++