Loading [MathJax]/jax/output/HTML-CSS/fonts/TeX/fontdata.js

Associativity and identity testing

Revision en6, by adamant, 2021-06-14 23:11:11

Hi everyone!

Five days passed since my previous post, so I guess I'll continue doing posts like this for time being.

Abstract algebra was among my favorite subjects. One particular thing I found quite impressive is the associativity of binary operations. One of harder problems from my contests revolves exactly around this property as you need to construct an operation with a given number of non-associative triples. This time I want to talk about how one can check this property both for groups and for arbitrary magmas.

First part of my post goes about Light's associativity test and how it can be used to deterministically check whether some operation defines a group in O(n2logn). Second part of the post is about Rajagopalan and Schulman probabilistic identity testing which allows to test associativity of arbitrary operation in O(n2lognlogδ1) where δ is error tolerance. Finally, the third part of my post is dedicated to the proof of Rajagopalan--Schulman method and bears some insights into identity verification in general and higher-dimensional linear algebra.


Let (G,) be a finite magma (that is, a set G with |G|=n and an operation :G×GG) defined by its Cayley table.

You need to check if it is a semigroup (that is, if (ab)c=a(bc) for all a,b,cG).

Despite the task being quite well-known, until 1996 there were no known sub-n3 algorithms for this task. In 1949 Alfred Clifford and Gordon Preston published the following procedure, attributed as Light's associativity test:

Let gG be arbitrary magma element. Define operations xgy=(xg)y and xgy=x(gy).

By definition, is associative if and only if gg for every gG. Checking these identities for all gG would take O(n3) time but it can be proven that if (G,) has generating set S then it is enough to test the equivalence of operations only for gS, which follows from the fact that a=a and b=b implies ab=ab as well:

x((ab)y)=x(a(by))=(xa)(by)=((xa)b)y=(x(ab))y

It doesn't help for the generic case as there are associative magmas with n elements in the minimum generating set, for example A consists of numbers 1, 2, , n and ab=max. But it turns out that if (G, \cdot) is a quasigroup, that is for every a, b \in G there exists unique x \in G such that x \cdot a = b then (G, \cdot) has a generating set of at most \lfloor \log_2 n \rfloor + 1 elements.

Let T \subset G be such set that \langle T \rangle \neq G where \langle T \rangle is the closure of T under \cdot and let b \in G \setminus \langle T \rangle. Due to quasigroup properties, all elements b \cdot a where a \in \langle T \rangle are unique and are not present in \langle T \rangle, which means that |\langle T \cup {b}\rangle| \geq 2 |\langle T \rangle|, that is adding new elements to non-empty T until \langle T\rangle=G is only possible at most \log_2 n times, which allows to find generating set in O(n^2 \log n).

It is possible to test the magma for being a quasigroup in O(n^2), thus the whole associativity testing with Light's test can be done in O(n^2 \log n) if both conditions need to be present. In particular, every group is also a quasigroup, thus it is possible to deterministically check if given magma is a group in O(n^2 \log n).


But what if we really want to check associativity in arbitrary magma? Probabilistic solution to this was proposed by Sridhar Rajagopalan and Leonard Schulman in 1996. To nail this bugaboo they consider so-called group ring \mathbb Z_2[G] which elements are formal sums of the form \sum\limits_{g \in G} a_g g where a_g \in \mathbb Z_2. In this ring, addition and multiplication of elements A=\sum\limits_{g \in G} a_g g and B=\sum\limits_{g \in G} b_g g are defined:

  1. A+B=\sum\limits_{g\in G} (a_g \oplus b_g)g where a_g \oplus b_g is an xor of a_g and b_g;
  2. A\cdot B=\sum\limits_{g\in G} \left(\bigoplus\limits_{x \cdot y = g}a_x b_y\right)g where a_g b_g is the conjunction of a_g and b_g.

It can be proven A \cdot (B \cdot C) = (A \cdot B) \cdot C holds for all A, B, C \in \mathbb Z_2[G] if and only if (G, \cdot) is a semigroup. Moreover, if it is not a semigroup, probability of A \cdot (B \cdot C) = (A \cdot B) \cdot C for uniformly randomly picked A, B, C is at most \frac{7}{8}, which allows adjusting error probability to \delta by repeating the same test \log_\frac{8}{7}\delta^{-1} times, making it a total time of O(n^2 \log \delta^{-1}) for the error tolerance \delta.


Proof here is in a way similar to Freivalds' algorithm which checks (AB-C)x=0 for matrices to verify that AB=C. In the associativity case, A \cdot (B \cdot C) - (A \cdot B) \cdot C=0 is checked and it may be rewritten in Einstein notation as \begin{equation} (F_{ijkl}-G_{ijkl})a_i b_j c_k = 0 \end{equation} Where summations and products are done in \mathbb Z_2 and F_{ijkl}, G_{ijkl} are 4-dimensional arrays (tensors) defined as \begin{equation} \begin{matrix} F_{ijkl} = \begin{cases} 1& \text{if }(i \cdot j) \cdot k = l,\newline 0& \text{otherwise}\end{cases} & G_{ijkl} = \begin{cases} 1& \text{if }i \cdot (j \cdot k) = l,\newline 0& \text{otherwise}\end{cases} \end{matrix} \end{equation}

For better understanding, the matrix identity from Freivalds' algorithm looks like this in Einstein notation \begin{equation} (A_{ik} B_{kj} -C_{ij})x_j = 0 \end{equation}

We will prove probability bounds for both tests in a similar generic manner. Let A_{i_1 \dots i_{k+1}} be a rank k+1 tensor. Then the identity

\begin{equation} A_{i_1 \dots i_{k+1}} x^{(1)}_{i_1} \dots x^{(k)}_{i_k} = 0 \end{equation}

where addition and multiplication is done in some field \mathbb F (in our case \mathbb F = \mathbb Z_2) can be checked by uniformly independently sampling vectors x^{(1)}, \dots, x^{(k)} and calculating the identity with these vectors. Probability of obtaining non-zero result is at least \frac{1}{2^k}.


As a friendly reminder, this post is of my mindbun series. Once in a while I write something of interest to me, usually related to computer science and the mathematics it requires, and post it in the Telegram channel (English) and VK group (partially Russian). Hop in if you find this stuff interesting and/or want to get new posts first-hand!

Tags mindbun, algebra, linear algebra, groups, associativity, tensor

History

 
 
 
 
Revisions
 
 
  Rev. Lang. By When Δ Comment
en17 English adamant 2021-06-17 13:00:21 37 seems to work with rings
en16 English adamant 2021-06-15 11:38:05 343
en15 English adamant 2021-06-15 11:29:39 6
en14 English adamant 2021-06-15 02:59:11 18 clarification
en13 English adamant 2021-06-15 01:21:43 353 cleanup 3
en12 English adamant 2021-06-15 01:11:43 307 cleanup 2
en11 English adamant 2021-06-15 01:06:36 940 cleanup 1
en10 English adamant 2021-06-15 00:24:34 22
en9 English adamant 2021-06-14 23:56:48 430 posting (published)
en8 English adamant 2021-06-14 23:42:37 1369
en7 English adamant 2021-06-14 23:12:41 72
en6 English adamant 2021-06-14 23:11:11 592
en5 English adamant 2021-06-14 23:06:28 8
en4 English adamant 2021-06-14 23:05:31 8
en3 English adamant 2021-06-14 23:04:57 822
en2 English adamant 2021-06-14 22:07:19 6639 Tiny change: 'mapsto A$).\n\nYou n' -> 'mapsto A$) defined by its multiplication table.\n\nYou n'
en1 English adamant 2021-06-13 01:49:53 380 Initial revision (saved to drafts)