Computing the congruences of a finite semigroup or monoid

In this paper we describe two different algorithms for computing the congruences of a finite semigroup or monoid, and compare these to existing algorithms and implementations. The first algorithm is a version of Sims' low index subgroup algorithm for finding the left or right congruences of a monoid. The second algorithm involves determining the distinct principal congruences, and then finding all of their possible joins. Variations of this algorithm have been suggested in numerous contexts by numerous authors. We show how to utilise the theory of relative Green's relations, and a version of Schreier's Lemma for monoids, to reduce the number of principal congruences that must be generated as the first step of this approach. Both of the algorithms described in this paper are implemented in the GAP package Semigroups, and the first algorithm is available in the C++ library libsemigroups and in its python bindings libsemigroups_pybind11.

READ FULL TEXT

page 1

page 2

page 3

page 4

research
04/13/2017

Two variants of the Froiduire-Pin Algorithm for finite semigroups

In this paper, we present two algorithms based on the Froidure-Pin Algor...
research
07/08/2021

Complete Scanning Application Using OpenCv

In the following paper, we have combined the various basic functionaliti...
research
07/31/2018

On subgroups of minimal index

Let G be a group possessing a proper subgroup of finite index. We prove ...
research
01/30/2019

On checkable codes in group algebras

We classify, in terms of the structure of the finite group G, all group ...
research
07/17/2018

Genetic algorithms in Forth

A method for automatically finding a program (bytecode) realizing the gi...
research
11/14/2022

QMKPy: A Python Testbed for the Quadratic Multiple Knapsack Problem

QMKPy provides a Python framework for modeling and solving the quadratic...

Please sign up or login with your details

Forgot password? Click here to reset