# Magma (algebra)

In abstract algebra, a **magma**, **binar**^{[1]} or, rarely, **groupoid** is a basic kind of algebraic structure. Specifically, a magma consists of a set equipped with a single binary operation that must be closed by definition. No other properties are imposed.

The term *groupoid* was introduced in 1927 by Heinrich Brandt describing his Brandt groupoid (translated from the German *Gruppoid*). The term was then appropriated by B. A. Hausmann and Øystein Ore (1937)^{[2]} in the sense (of a set with a binary operation) used in this article. In a couple of reviews of subsequent papers in Zentralblatt, Brandt strongly disagreed with this overloading of terminology. The Brandt groupoid is a groupoid in the sense used in category theory, but not in the sense used by Hausmann and Ore. Nevertheless, influential books in semigroup theory, including Clifford and Preston (1961) and Howie (1995) use groupoid in the sense of Hausmann and Ore. Hollings (2014) writes that the term *groupoid* is "perhaps most often used in modern mathematics" in the sense given to it in category theory.^{[3]}

According to Bergman and Hausknecht (1996): "There is no generally accepted word for a set with a not necessarily associative binary operation. The word *groupoid* is used by many universal algebraists, but workers in category theory and related areas object strongly to this usage because they use the same word to mean 'category in which all morphisms are invertible'. The term *magma* was used by Serre [Lie Algebras and Lie Groups, 1965]."^{[4]} It also appears in Bourbaki's *Éléments de mathématique, Algèbre, chapitres 1 à 3, 1970*.^{[5]}

A magma is a set *M* matched with an operation • that sends any two elements *a*, *b* ∈ *M* to another element, *a* • *b*. The symbol • is a general placeholder for a properly defined operation. To qualify as a magma, the set and operation (*M*, •) must satisfy the following requirement (known as the *magma* or *closure axiom*):

If • is instead a partial operation, then (*M*, •) is called a **partial magma**^{[6]} or more often a partial groupoid.^{[6]}^{[7]}

A morphism of magmas is a function *f* : *M* → *N* mapping magma *M* to magma *N* that preserves the binary operation:

The magma operation may be applied repeatedly, and in the general, non-associative case, the order matters, which is notated with parentheses. Also, the operation • is often omitted and notated by juxtaposition:

A shorthand is often used to reduce the number of parentheses, in which the innermost operations and pairs of parentheses are omitted, being replaced just with juxtaposition: *xy* • *z* ≡ (*x* • *y*) • *z*. For example, the above is abbreviated to the following expression, still containing parentheses:

A way to avoid completely the use of parentheses is prefix notation, in which the same expression would be written ••*a*•*bcd*. Another way, familiar to programmers, is postfix notation (reverse Polish notation), in which the same expression would be written *abc*••*d*•, in which the order of execution is simply left-to-right (no currying).

The set of all possible strings consisting of symbols denoting elements of the magma, and sets of balanced parentheses is called the Dyck language. The total number of different ways of writing *n* applications of the magma operator is given by the Catalan number *C _{n}*. Thus, for example,

*C*

_{2}= 2, which is just the statement that (

*ab*)

*c*and

*a*(

*bc*) are the only two ways of pairing three elements of a magma with two operations. Less trivially,

*C*

_{3}= 5: ((

*ab*)

*c*)

*d*, (

*a*(

*bc*))

*d*, (

*ab*)(

*cd*),

*a*((

*bc*)

*d*), and

*a*(

*b*(

*cd*)).

There are *n*^{n2} magmas with *n* elements, so there are 1, 1, 16, 19683, 4294967296, ... (sequence in the OEIS) magmas with 0, 1, 2, 3, 4, ... elements. The corresponding numbers of non-isomorphic magmas are 1, 1, 10, 3330, 178981952, ... (sequence in the OEIS) and the numbers of simultaneously non-isomorphic and non-antiisomorphic magmas are 1, 1, 7, 1734, 89521056, ... (sequence in the OEIS).^{[8]}

A **free magma** *M _{X}* on a set

*X*is the "most general possible" magma generated by

*X*(i.e., there are no relations or axioms imposed on the generators; see free object). The binary operation on

*M*is formed by wrapping each of the two operands in parenthesis and juxtaposing them in the same order. For example:

_{X}*M _{X}* can be described as the set of non-associative words on

*X*with parentheses retained.

^{[9]}

It can also be viewed, in terms familiar in computer science, as the magma of binary trees with leaves labelled by elements of *X*. The operation is that of joining trees at the root. It therefore has a foundational role in syntax.

A free magma has the universal property such that if *f* : *X* → *N* is a function from *X* to any magma *N*, then there is a unique extension of *f* to a morphism of magmas *f* ′

Magmas are not often studied as such; instead there are several different kinds of magma, depending on what axioms the operation is required to satisfy. Commonly studied types of magma include:

Note that each of divisibility and invertibility imply the cancellation property.

The category of magmas, denoted **Mag**, is the category whose objects are magmas and whose morphisms are magma homomorphisms. The category **Mag** has direct products, and there is an inclusion functor: **Set → Med ↪ Mag** as trivial magmas, with operations given by projection *x* T *y* = *y* .

An important property is that an injective endomorphism can be extended to an automorphism of a magma extension, just the colimit of the (constant sequence of the) endomorphism.