Hostname: page-component-745bb68f8f-l4dxg Total loading time: 0 Render date: 2025-01-27T22:23:32.596Z Has data issue: false hasContentIssue false

Computation of lattice isomorphisms and the integral matrix similarity problem

Published online by Cambridge University Press:  10 October 2022

Werner Bley
Affiliation:
Ludwig-Maximilians-Universität München, Theresienstr. 39, D-80333 München, Germany; E-mail: [email protected]
Tommy Hofmann
Affiliation:
Universität Siegen, Naturwissenschaftlich-Technische Fakultät, Walter-Flex-Straße 3, 57068 Siegen, Germany; E-mail: [email protected]
Henri Johnston
Affiliation:
Department of Mathematics, University of Exeter, EX4 4QF Exeter, United Kingdom; E-mail: [email protected]

Abstract

Let K be a number field, let A be a finite-dimensional K-algebra, let $\operatorname {\mathrm {J}}(A)$ denote the Jacobson radical of A and let $\Lambda $ be an $\mathcal {O}_{K}$ -order in A. Suppose that each simple component of the semisimple K-algebra $A/{\operatorname {\mathrm {J}}(A)}$ is isomorphic to a matrix ring over a field. Under this hypothesis on A, we give an algorithm that, given two $\Lambda $ -lattices X and Y, determines whether X and Y are isomorphic and, if so, computes an explicit isomorphism $X \rightarrow Y$ . This algorithm reduces the problem to standard problems in computational algebra and algorithmic algebraic number theory in polynomial time. As an application, we give an algorithm for the following long-standing problem: Given a number field K, a positive integer n and two matrices $A,B \in \mathrm {Mat}_{n}(\mathcal {O}_{K})$ , determine whether A and B are similar over $\mathcal {O}_{K}$ , and if so, return a matrix $C \in \mathrm {GL}_{n}(\mathcal {O}_{K})$ such that $B= CAC^{-1}$ . We give explicit examples that show that the implementation of the latter algorithm for $\mathcal {O}_{K}=\mathbb {Z}$ vastly outperforms implementations of all previous algorithms, as predicted by our complexity analysis.

Type
Algebra
Creative Commons
Creative Common License - CCCreative Common License - BY
This is an Open Access article, distributed under the terms of the Creative Commons Attribution licence (https://creativecommons.org/licenses/by/4.0/), which permits unrestricted re-use, distribution, and reproduction in any medium, provided the original work is properly cited.
Copyright
© The Author(s), 2022. Published by Cambridge University Press

1 Introduction

Let K be a number field with ring of integers $\mathcal {O}_{K}$ . Let A be a finite-dimensional K-algebra, and let $\Lambda $ be an $\mathcal {O}_{K}$ -order in A. A $\Lambda $ -lattice is a (left) $\Lambda $ -module that is finitely generated and torsion-free over $\mathcal {O}_{K}$ . We will consider the following problem.

Problem ( $\mathsf {IsIsomorphic}$ )

Given two $\Lambda $ -lattices X and Y, decide whether X and Y are isomorphic, and if so, return an isomorphism $X \to Y$ .

A $\Lambda $ -lattice contained in A is said to be full if it contains a K-basis of A. We will show that $\mathsf {IsIsomorphic}$ is polynomial-time reducible (see §5) to the following problem.

Problem ( $\mathsf {IsPrincipal}$ )

Given a full $\Lambda $ -lattice X in A, decide whether there exists $\alpha \in X$ such that $X = \Lambda \alpha $ , and if so, return such an element $\alpha $ .

Let $\operatorname {\mathrm {J}}(A)$ denote the Jacobson radical of A. Note that the quotient algebra $\overline {A} := A/{\operatorname {\mathrm {J}}(A)}$ is semisimple. Let $h : A \rightarrow \overline {A}$ denote the canonical projection map, and let $\overline {\Lambda } = h(\Lambda )$ . We will show that the problem $\mathsf {IsPrincipal}$ for a full $\Lambda $ -lattice X in A is polynomial-time reducible to the problem $\mathsf {IsPrincipal}$ for the full $\overline {\Lambda }$ -lattice $\overline {X}$ in $\overline {A}$ , where $\overline {X}=h(X)$ .

Let

$$\begin{align*}A/{\operatorname{\mathrm{J}}(A)} \simeq \bigoplus_{i=1}^{r} A_{i} \end{align*}$$

be the Wedderburn decomposition. Each simple component $A_{i}$ is isomorphic to a matrix ring $\mathrm {Mat}_{n_i}(D_i)$ , where $D_i$ is a skew field extension of K. Let $K_{i}$ denote the centre of $D_{i}$ . In order to make progress on the above problems, we impose the following hypothesis.

  1. (H) Each component $A_{i}$ of the Wedderburn decomposition $A/{\operatorname {\mathrm {J}}(A)} \simeq \bigoplus _{i=1}^{r} A_{i}$ is isomorphic to a matrix ring over a field.

In the above notation, this is equivalent to the assertion that $D_{i}=K_{i}$ for each i.

Under hypothesis (H), we give algorithms that solve both $\mathsf {IsIsomorphic}$ and $\mathsf {IsPrincipal}$ . Moreover, we give the first complexity analysis of these problems and thus prove the following result. For precise definitions and statements, we refer the reader to §5 and §8.

Theorem. The problem $\mathsf {IsIsomorphic}$ for lattices over orders in algebras satisfying hypothesis (H) reduces in probabilistic polynomial time to

  1. (a) $\mathsf {Wedderburn}$ , the problem of computing explicitly the Wedderburn decomposition,

  2. (b) $\mathsf {Factor}$ , the problem of factoring integers,

  3. (c) $\mathsf {IsPrincipal}$ in the special case of rings of integers of number fields,

  4. (d) $\mathsf {UnitGroup}$ , the computation of unit groups for rings of integers of number fields,

  5. (e) $\mathsf {Primitive}$ , the computation of primitive elements in finite fields and

  6. (f) $\mathsf {DLog}$ , the computation of discrete logarithms in finite fields.

A number of articles have considered $\mathsf {IsIsomorphic}$ , $\mathsf {IsPrincipal}$ or closely related problems in special cases. In particular, [Reference Bley and EndresBE05] applies in the case that A is commutative and semisimple; [Reference Bley and WilsonBW09] applies to group rings $\mathcal {O}_{K}[G]$ , where G is a finite group, but only decides whether two lattices are both locally free and stably isomorphic; and [Reference Dembélé and DonnellyDD08, Reference Kirschmer and VoightKV10, Reference PagePag14] apply to maximal or Eichler orders in quaternion algebras. The series of articles [Reference BleyBle97, Reference Bley and JohnstonBJ08, Reference Bley and JohnstonBJ11, Reference Hofmann and JohnstonHJ20] consider progressively more general situations, culminating in a solution to $\mathsf {IsIsomorphic}$ when A is semisimple, but they all involve a very expensive enumeration step, which in many cases renders the algorithm impractical. We refer the reader to the introduction of [Reference Hofmann and JohnstonHJ20] for a more detailed overview. By contrast, Algorithm 8.3 replaces this enumeration step by a new method combining results of [Reference Bley, Boltje, Hess, Pauli and PohstBB06, Reference Bley and WilsonBW09] with an idea of Husert [Reference HusertHus17].

The original motivation for the study of these problems comes from the Galois module structure of rings of integers. Let $L/K$ be a finite Galois extension of number fields, and let $G=\mathrm {Gal}(L/K)$ . An interesting but difficult problem is to determine whether $\mathcal {O}_{L}$ is free over its so-called associated order $\mathcal {A}_{L/K} = \{ \alpha \in K[G] \mid \alpha \mathcal {O}_{L} \subseteq \mathcal {O}_{L} \}$ and, if so, to determine an explicit generator. We refer the reader to §10 and to the introduction of [Reference Hofmann and JohnstonHJ20] for a more detailed overview of this question and related problems.

The main application of $\mathsf {IsPrincipal}$ in the present article is to the following problem.

Problem ( $\mathsf {IsSimilar}$ )

Given a number field K with ring of integers $\mathcal {O}=\mathcal {O}_{K}$ , an integer $n \in \mathbb {Z}_{>0}$ and two matrices $A,B \in \mathrm {Mat}_{n}(\mathcal {O})$ , determine whether A and B are similar over $\mathcal {O}$ , and if so, return a conjugating matrix $C \in \mathrm {GL}_{n}(\mathcal {O})$ such that $B= CAC^{-1}$ .

As a special case, this problem includes the so-called conjugacy problem for $\mathrm {GL}_{n}(\mathcal {O})$ . A number of authors have considered the problem $\mathsf {IsSimilar}$ (or special cases), including Latimer–MacDuffee [Reference Latimer and MacDuffeeLM33], Sarkisyan [Reference SarkisyanSar79], Grunewald [Reference GrunewaldGru80], Husert [Reference HusertHus17] and Marseglia [Reference MarsegliaMar20]. Eick–O’Brien and the second named author of the present article gave the first practical algorithm that solves this problem in full generality [Reference Eick, Hofmann and O’BrienEHO19]. We refer the reader to §9.4 and §9.5 for a more detailed discussion of these results.

In §9, we give an efficient algorithm that solves $\mathsf {IsSimilar}$ in full generality and a complexity analysis showing that it is polynomial-time reducible to standard problems in algorithmic algebraic number theory, including the principal ideal problem in certain rings of integers and the computation of their unit groups (see Algorithm 9.13 and Theorem 9.14). As a corollary we obtain the following result (see Corollary 9.15 and Remark 5.1).

Theorem. The problem $\mathsf {IsSimilar}$ reduces in probabilistic subexponential time to the problems $\mathsf {IsPrincipal}$ and $\mathsf {UnitGroup}$ for rings of integers of number fields.

We first adapt ideas of Faddeev [Reference FaddeevFad66] to recast $\mathsf {IsSimilar}$ in terms of lattices over orders in a certain K-algebra satisfying hypothesis (H). We then show how to explicitly compute the Jacobson radical of this K-algebra as well as the Wedderburn decomposition of the semisimple quotient from the rational canonical forms of the input matrices. Thus, we show that $\mathsf {IsSimilar}$ is reducible to $\mathsf {IsPrincipal}$ . In particular, Algorithm 9.13 avoids any expensive enumeration step. For a detailed comparison with other algorithms and implementations, including explicit examples and timings, we refer the reader to §9.5. As these comparisons and our complexity analysis suggest, the implementation of Algorithm 9.13 in the computer algebra package Hecke [Reference Fieker, Hart, Hofmann and JohanssonFHHJ17] vastly outperforms implementations of other algorithms.

2 Preliminaries on lattices and orders

For further background on lattices and orders, we refer the reader to [Reference ReinerRei03, §4, §8]. Henceforth, all rings considered will be associative and unital.

Let R be an Noetherian integral domain with field of fractions K. To avoid trivialities, we assume that $R \neq K$ . An R-lattice is a finitely generated torsion-free module over R. Since R is Noetherian, any R-submodule of an R-lattice is again an R-lattice. For any finite-dimensional K-vector space V, an R-lattice in V is a finitely generated R-submodule M in V. We define a K-vector subspace of V by

$$\begin{align*}K M := \{ \alpha_{1} m_{1} + \alpha_{2} m_{2} + \cdots + \alpha_{r} m_{r} \mid r \in \mathbb{Z}_{\geq 0}, \alpha_i \in K, m_{i} \in M \} \end{align*}$$

and say that M is a full R-lattice in V if $K M=V$ . We may identify $KM$ with $K \otimes _{R} M$ .

Now, let A be a finite-dimensional K-algebra. Then A is both left and right Artinian and Noetherian. An R-order in A is a subring $\Lambda $ of A (so in particular has the same unit element as A) such that $\Lambda $ is a full R-lattice in A. Note that $\Lambda $ is both left and right Noetherian, since $\Lambda $ is finitely generated over R. A left $\Lambda $ -lattice X is a left $\Lambda $ -module that is also an R-lattice; in this case, $KX$ may be viewed as a left A-module.

Henceforth, all modules (resp. lattices) will be assumed to be left modules (resp. lattices) unless otherwise stated. Two $\Lambda $ -lattices are said to be isomorphic if they are isomorphic as $\Lambda $ -modules. The following two lemmas generalise [Reference Hofmann and JohnstonHJ20, Lemma 2.1].

Lemma 2.1. Let S be a Noetherian integral domain such that $R \subseteq S \subsetneq K$ . Let $\Gamma $ be an S-order in A. Let V be a finitely generated A-module. For any R-lattice M in V, the set

$$\begin{align*}\Gamma M := \{ \gamma_{1} m_{1} + \gamma_{2} m_{2} + \cdots + \gamma_{r} m_{r} \mid r \in \mathbb{Z}_{\geq 0}, m_{i} \in M, \gamma_{i} \in \Gamma \} \end{align*}$$

is a $\Gamma $ -lattice in V containing M.

Proof. That $M \subseteq \Gamma M$ is clear. Note that K is the field of fractions of both R and S. Write $M = \langle v_{1}, \ldots , v_{l} \rangle _{R}$ and $\Gamma = \langle w_{1}, \ldots , w_{m} \rangle _{S}$ . An easy calculation shows that

$$\begin{align*}\Gamma M = \langle w_{i} v_{j} \mid 1 \leq i \leq m, 1 \leq j \leq l \rangle_{S}, \end{align*}$$

and hence $\Gamma M$ is an S-lattice in V. Moreover, it is straightforward to see that $\Gamma M$ is also a $\Gamma $ -module and therefore is a $\Gamma $ -lattice in V.

Lemma 2.2. Let S be a Noetherian integral domain such that $R \subseteq S \subsetneq K$ . Let $\Lambda $ be an R-order in A, let $\Gamma $ be an S-order in A and suppose that $\Lambda \subseteq \Gamma $ . Let $f \colon X \to Y$ be a homomorphism of $\Lambda $ -lattices. Then the following hold.

  1. (a) There exists a unique homomorphism of A-modules $f^{A} \colon KX \to KY$ extending f.

  2. (b) There exists a unique homomorphism of $\Gamma $ -lattices $f^{\Gamma }\colon \Gamma X \to \Gamma Y$ extending f.

  3. (c) If f is injective (resp. surjective), then $f^{A}$ and $f^{\Gamma }$ are injective (resp. surjective).

Proof. This is straightforward. The key points are to (a) extend f to $KX$ using K-linearity; (b) restrict $f^{A}$ to $\Gamma X$ ; (c) (injectivity) check that $\ker (f)$ is a full R-lattice in $\ker (f^{A})$ and (c) (surjectivity) use the definitions of $K Y$ and $\Gamma Y$ .

We will often use the following result without explicit mention.

Lemma 2.3. Let $\Lambda $ be an R-order in A, and let X be a $\Lambda $ -lattice such that $\dim _{K} KX = \dim _{K} A$ . Let $\alpha \in X$ . Then $X=\Lambda \alpha $ if and only if $\alpha $ is a free generator of X over $\Lambda $ .

Proof. Suppose $X = \Lambda \alpha $ . Then the map $f : \Lambda \rightarrow X$ given by $f(\lambda ) = \lambda \alpha $ is a surjective homomorphism of $\Lambda $ -lattices. By Lemma 2.2 f extends uniquely to a surjective map $f^{A} : A \rightarrow KX$ . The hypotheses imply that $f^{A}$ is injective, thus f is an isomorphism and so $\alpha $ is a free generator of X over $\Lambda $ . The converse is trivial.

3 Reduction steps for the lattice isomorphism problem

Let R be a Noetherian integral domain with field of fractions K and assume that $R \neq K$ . Let $\Lambda $ be an R-order in a finite-dimensional K-algebra A.

3.1 Reduction to the free rank $1$ case via homomorphism groups

Let X and Y be $\Lambda $ -lattices. Let $V=KX$ and $W=KY$ , which we regard as A-modules. We have

$$\begin{align*}{\mathrm{Hom}}_\Lambda(X, Y) = \{ f|_{X} \mid f \in {\mathrm{Hom}}_{A}(V, W) \text{ such that } f(X) \subseteq Y\} \, \end{align*}$$

where $f|_{X}$ denotes the restriction of f to a map $f \colon X \to Y$ . This follows from the fact that every element in $\mathrm {Hom}_{\Lambda }(X, Y)$ extends uniquely to an element in $\mathrm {Hom}_{A}(V, W)$ (see Lemma 2.2). Since a map $f \in \mathrm {Hom}_{A}(V,W)$ is also R-linear, we have $f(X) \subseteq Y$ if and only if $f \in \mathrm {Hom}_{R}(X,Y)$ . Therefore,

$$\begin{align*}\mathrm{Hom}_{\Lambda}(X, Y) =\mathrm{Hom}_{A}(V, W) \cap \mathrm{Hom}_{R}(X, Y). \end{align*}$$

Since X and Y are finitely generated over R, so is $\mathrm {Hom}_{R}(X,Y)$ . Therefore, $\mathrm {Hom}_{\Lambda }(X,Y)$ is a full R-lattice in $\mathrm {Hom}_{A}(V,W)$ . Similarly, $\mathrm {End}_{\Lambda }(Y)$ is a full R-lattice in $\mathrm {End}_{A}(W)$ .

In fact, $\mathrm {End}_{\Lambda }(Y)$ is an R-order in $\mathrm {End}_{A}(W)$ and $\mathrm {Hom}_{\Lambda }(X,Y)$ is a (left) $\mathrm {End}_{\Lambda }(Y)$ -lattice in $\mathrm {Hom}_{A}(V,W)$ via postcomposition. The following result underpins the main results of the present article; it is a straightforward generalisation of [Reference Hofmann and JohnstonHJ20, Proposition 3.7].

Proposition 3.1. Two $\Lambda $ -lattices X and Y are isomorphic if and only if

  1. (a) the $\mathrm {End}_{\Lambda }(Y)$ -lattice $\mathrm {Hom}_{\Lambda }(X, Y)$ is free of rank $1$ , and

  2. (b) every (any) free generator of $\mathrm {Hom}_{\Lambda }(X, Y)$ over $\mathrm {End}_{\Lambda }(Y)$ is an isomorphism.

Proof. If (a) and (b) hold, then it is clear that X and Y are isomorphic. Suppose conversely that X and Y are isomorphic. Fix an isomorphism $\varphi \in \mathrm {Hom}_{\Lambda }(X, Y)$ . Then for any $g \in \mathrm {Hom}_{\Lambda }(X, Y)$ , we have $h_{g} := g \circ \varphi ^{-1} \in \mathrm {End}_{\Lambda }(Y)$ and so $g = h_{g} \circ \varphi $ . Hence, $\varphi $ is a generator of $\mathrm {Hom}_{\Lambda }(X, Y)$ over $\mathrm {End}_{\Lambda }(Y)$ and by Lemma 2.3 it is in fact a free generator. Thus, (a) holds. Now, let f be any free generator of $\mathrm {Hom}_{\Lambda }(X, Y)$ over $\mathrm {End}_{\Lambda }(Y)$ . Then there exists $\theta \in \mathrm {Aut}_{\Lambda }(Y)=\mathrm {End}_{\Lambda }(Y)^{\times }$ such that $f = \theta \circ \varphi $ , and hence f is an isomorphism. Thus, (b) holds.

We now state and prove a closely related ‘folklore’ result that appears to be well known but whose proof is difficult to locate in the literature. We include this result for completeness, and it will not be applied in the present article. For any full R-lattice M in A, we define $\mathcal {O}_{r}(M) = \{ \mu \in A \mid M\mu \subseteq M \}$ . This is an R-order in A and is called the right order of M in A (see [Reference ReinerRei03, §8]). The following result may be viewed as a corollary of Proposition 3.1, but it is easier to give a direct proof.

Proposition 3.2. Let X and Y be full $\Lambda $ -lattices in A. Then $C := \{ \lambda \in A \mid X\lambda \subseteq Y \}$ is a full $\mathcal {O}_{r}(X)$ -lattice in A. Moreover, X and Y are isomorphic if and only if

  1. (a) there exists $\alpha \in A^{\times }$ such that $C=\mathcal {O}_{r}(X) \alpha $ , and

  2. (b) we have $Y=XC$ .

Furthermore, when this is the case, $Y=X\alpha $ .

Proof. Set $\mathcal {O}:=\mathcal {O}_{r}(X)$ . Clearly, C is both an R-module and an $\mathcal {O}$ -module. Since X and Y are both full R-lattices in A, there exist nonzero $r,s \in R$ such that $Ys \subseteq X$ and $Xr \subseteq Y$ (see [Reference ReinerRei03, §4]). Thus, $\mathcal {O}r \subseteq C \subseteq \mathcal {O}s^{-1}$ , where $\mathcal {O}r$ and $\mathcal {O}s^{-1}$ are both full R-lattices in A. Hence, C is a full R-lattice and therefore a full $\mathcal {O}$ -lattice in A.

Suppose (a) and (b) hold. Then $Y=XC=X(\mathcal {O}\alpha ) = (X\mathcal {O})\alpha = X \alpha $ . Hence, X and Y are isomorphic since $\alpha \in A^{\times }$ . Suppose conversely that $f: X \rightarrow Y$ is a $\Lambda $ -isomorphism. Then by Lemma 2.2 f extends uniquely to an A-isomorphism $f^{A} : A \rightarrow A$ and hence is given by right multiplication by an element $\alpha \in A^{\times }$ . Thus, $Y = X\alpha $ . Moreover, $C = \{ \lambda \in A \mid X\lambda \subseteq X\alpha \} = \mathcal {O} \alpha $ and $Y = X\alpha = (X\mathcal {O})\alpha = X(\mathcal {O}\alpha ) \,{=}\, XC$ .

3.2 An alternative approach via localisation

We give an alternative version of Proposition 3.1 that uses localisation. This will be useful later for understanding the relation of some of our results to other results in the literature. For a nonzero prime ideal $\mathfrak {p}$ of R, we let $R_{\mathfrak {p}}$ denote the localisation (not completion) of R at $\mathfrak {p}$ . We define the localisation $M_{\mathfrak {p}}$ of M at $\mathfrak {p}$ to be $R_{\mathfrak {p}}M$ and note that this is an $R_{\mathfrak {p}}$ -lattice in $KM$ . The localisation $\Lambda _{\mathfrak {p}}$ is an $R_{\mathfrak {p}}$ -order in A, and localising a $\Lambda $ -lattice X at $\mathfrak {p}$ yields a $\Lambda _{\mathfrak {p}}$ -lattice $X_{\mathfrak {p}}$ . Two $\Lambda $ -lattices X and Y are said to be locally isomorphic if the $\Lambda _{\mathfrak {p}}$ -lattices $X_{\mathfrak {p}}$ and $Y_{\mathfrak {p}}$ are isomorphic for all maximal ideals $\mathfrak {p}$ of R.

Proposition 3.3. Two $\Lambda $ -lattices X and Y are isomorphic if and only if

  1. (a) X and Y are locally isomorphic, and

  2. (b) the $\mathrm {End}_{\Lambda }(Y)$ -lattice $\mathrm {Hom}_{\Lambda }(X, Y)$ is free of rank $1$ .

Furthermore, when this is the case, every free generator of $\mathrm {Hom}_{\Lambda }(X, Y)$ over $\mathrm {End}_{\Lambda }(Y)$ is an isomorphism.

Proof. If X and Y are isomorphic, then (a) clearly holds and (b) holds by Proposition 3.1. Suppose conversely that (a) and (b) hold. Let f be a free generator of $\mathrm {Hom}_{\Lambda }(X, Y)$ over $\mathrm {End}_{\Lambda }(Y)$ . Let $\mathfrak {p}$ be a maximal ideal of R. Then there exists an isomorphism $g_{\mathfrak {p}} \in \mathrm {Hom}_{\Lambda _{\mathfrak {p}}}(X_{\mathfrak {p}}, Y_{\mathfrak {p}})$ . Moreover, f extends to a free generator $f_{\mathfrak {p}}$ of $\mathrm {Hom}_{\Lambda _{\mathfrak {p}}}(X_{\mathfrak {p}}, Y_{\mathfrak {p}})$ over $\mathrm {End}_{\Lambda _{\mathfrak {p}}}(Y_{\mathfrak {p}})$ , and so there exists $h_{\mathfrak {p}} \in \mathrm {End}_{\Lambda _{\mathfrak {p}}}(Y_{\mathfrak {p}})$ such that $g_{\mathfrak {p}} = h_{\mathfrak {p}} \circ f_{\mathfrak {p}}$ . Note that $h_{\mathfrak {p}}$ is surjective and thus is in fact an automorphism of $Y_{\mathfrak {p}}$ by [Reference Curtis and ReinerCR81, (5.8)]. Therefore, $f_{\mathfrak {p}}$ is an isomorphism. Since this is true for all choices of $\mathfrak {p}$ , we have that f itself is an isomorphism by [Reference Curtis and ReinerCR81, (4.2)(ii)].

3.3 Reduction to the case of lattices in semisimple algebras

Let $\operatorname {\mathrm {J}}(A)$ denote the Jacobson radical of A, and note that $\overline {A} := A/{\operatorname {\mathrm {J}}(A)}$ is a semisimple K-algebra by [Reference Curtis and ReinerCR81, (5.19)]. Let $h : A \rightarrow \overline {A}$ denote the canonical projection map. For an element $a \in A$ , write $\overline {a}$ for $h(a)$ , and for a subset $S \subseteq A$ , write $\overline {S}$ for $h(S)$ . Then $\overline {\Lambda }$ is an R-order in $\overline {A}$ . The following result may be viewed as a variant of [Reference FaddeevFad66, Theorem 3].

Theorem 3.4. Let X be a full $\Lambda $ -lattice in A. Then $\overline {X}$ is a full $\overline {\Lambda }$ -lattice in $\overline {A}$ . Moreover, the following statements hold for $\alpha \in X$ .

  1. (a) If $X = \Lambda \alpha $ , then $\overline {X} = \overline {\Lambda } \overline {\alpha }$ .

  2. (b) If $\overline {X} = \overline {\Lambda } \overline {\alpha }$ , then either $X = \Lambda \alpha $ or $X \ne \Lambda \beta $ for all $\beta \in X$ .

Proof. The first claim and part (a) are both clear. Suppose that $\overline {X} = \overline {\Lambda } \overline {\alpha }$ and that there exists $\beta \in X$ such that $X=\Lambda \beta $ . Since $\alpha \in X=\Lambda \beta $ , there exists $\varepsilon \in \Lambda $ such that $\alpha = \varepsilon \beta $ . Hence, $\overline {\alpha } = \overline {\varepsilon }\overline {\beta }$ , and since each of $\overline {\alpha }$ and $\overline {\beta }$ is a free generator of $\overline {X}$ over $\overline {\Lambda }$ , we must have $\overline {\varepsilon } \in \overline {\Lambda }^{\times }$ . Let $\eta \in \Lambda $ such that $\overline {\eta }=\overline {\varepsilon }^{-1}$ . Then $\varepsilon \eta = 1 + \rho $ , where $\rho \in \operatorname {\mathrm {J}}(A)$ . Moreover, $\rho = \varepsilon \eta - 1 \in \Lambda $ . Since A is Artinian, $\operatorname {\mathrm {J}}(A)$ is a nilpotent ideal (see [Reference Curtis and ReinerCR81, (5.15)]), and so $\rho $ is a nilpotent element. Therefore,

$$\begin{align*}\varepsilon^{-1} = \eta(1 + \rho)^{-1} = \eta(1 - \rho + \rho^{2} - \rho^{3} + \dotsb) \in \Lambda, \end{align*}$$

where the alternating sum is finite. Hence, $\varepsilon \in \Lambda ^{\times }$ and so $\Lambda \alpha = \Lambda \varepsilon \beta = \Lambda \beta = X$ .

4 A necessary and sufficient condition for freeness

Let K be a number field with ring of integers $\mathcal {O}=\mathcal {O}_{K}$ , and let A be a finite-dimensional semisimple K-algebra. Let $\Lambda $ be an $\mathcal {O}$ -order in A. By [Reference ReinerRei03, (10.4)] there exists a (not necessarily unique) maximal $\mathcal {O}$ -order $\mathcal {M}$ in A containing $\Lambda $ .

Lemmas 4.1 and 4.2, as well as part of Proposition 4.3, are based on [Reference HusertHus17, §1.6].

Lemma 4.1. Let $\mathfrak {c}, \mathfrak {d}, \mathfrak {f}$ be left ideals of $\Lambda $ such that $\mathfrak {c} \subseteq \mathfrak {d}$ . Then $ \mathfrak {d} \cap (\mathfrak {c} + \mathfrak {f}) = \mathfrak {c} + (\mathfrak {d} \cap \mathfrak {f}) $ .

Proof. We follow the proof of [Reference HusertHus17, Lemma 1.37]. If $c \in \mathfrak {c}$ and $f \in \mathfrak {f}$ with $c+f \in \mathfrak {d}$ , then $f \in \mathfrak {d}$ since $c \in \mathfrak {d}$ . Hence, $c+f \in \mathfrak {c} + (\mathfrak {d} \cap \mathfrak {f})$ . Therefore, $\mathfrak {d} \cap (\mathfrak {c} + \mathfrak {f}) \subseteq \mathfrak {c} + (\mathfrak {d} \cap \mathfrak {f})$ . For the reverse inclusion, note that both $\mathfrak {c}$ and $\mathfrak {d} \cap \mathfrak {f}$ are contained in $\mathfrak {d} \cap (\mathfrak {c} + \mathfrak {f})$ , and thus the same is true for their sum.

An ideal of a ring will be said to be proper if the containment is strict. Henceforth, let $\mathfrak {f}$ be any proper full two-sided ideal of $\mathcal {M}$ that is contained in $\Lambda $ . For $\eta \in \mathcal {M}$ we write $\overline {\eta }$ for its image in $\mathcal {M} / \mathfrak {f}$ .

Lemma 4.2. Let X be a left ideal of $\Lambda $ . If $X + \mathfrak {f} = \Lambda $ and $\beta \in \mathcal {M}$ such that $\mathcal {M}X = \mathcal {M}\beta $ , then $\overline {\beta } \in (\mathcal {M}/\mathfrak {f})^{\times }$ and $\mathcal {M}X \cap \Lambda = X$ .

Proof. We adapt the proof of [Reference HusertHus17, Lemma 1.38]. Clearly, $\mathfrak {f}X \subseteq \mathcal {M}X \cap \mathfrak {f}$ . We now show the reverse inclusion. Let $\gamma \in \mathcal {M} X \cap \mathfrak {f}$ . Then we write $\gamma = \lambda \beta $ with $\lambda \in \mathcal {M}$ and we have

$$ \begin{align*} X + \mathfrak{f} = \Lambda &\implies \mathcal{M}(X + \mathfrak{f}) = \mathcal{M} \\ & \implies \mathcal{M}\beta + \mathfrak{f} = \mathcal{M} \\ & \implies \overline{\beta} \in (\mathcal{M} / \mathfrak{f})^{\times} \\ &\implies \overline{\lambda} = \overline{\gamma} \overline{\beta}^{-1} = \overline{0} (\overline{\beta})^{-1} = \overline{0} \textrm{ in } \mathcal{M}/\mathfrak{f}\\ & \implies \lambda \in \mathfrak{f} \\ &\implies \gamma=\lambda\beta \in \mathfrak{f}\beta = \mathfrak{f}\mathcal{M}\beta = \mathfrak{f}\mathcal{M} X = \mathfrak{f} X. \end{align*} $$

Therefore, $\mathfrak {f}X = \mathcal {M}X \cap \mathfrak {f}$ . Moreover, we have

$$\begin{align*}\mathcal{M} X \cap \Lambda = \mathcal{M} X \cap (X+\mathfrak{f}) = X + (\mathcal{M} X \cap \mathfrak{f}) = X + \mathfrak{f} X = X, \end{align*}$$

where the second equality holds by Lemma 4.1.

Define

$$\begin{align*}\pi : (\mathcal{M}/\mathfrak{f})^{\times} \longrightarrow {(\mathcal{M} / \mathfrak{f} )^{\times}} / {(\Lambda / \mathfrak{f} )^{\times}} \end{align*}$$

to be the map induced by the canonical projection, where the codomain is the collection of left cosets of $ (\Lambda / \mathfrak {f} )^{\times }$ in $(\mathcal {M} / \mathfrak {f} )^{\times }$ . Note that $(\Lambda /\mathfrak {f})^{\times }$ is a subgroup of $(\mathcal {M}/\mathfrak {f})^{\times }$ but is not necessarily a normal subgroup, and so $\pi $ is only a map of sets in general.

Part of the following result is a variant of [Reference HusertHus17, Theorem 1.39].

Proposition 4.3. Let X be a left ideal of $\Lambda $ . Suppose that $X + \mathfrak {f} = \Lambda $ and that there exists $\beta \in \mathcal {M}$ such that $\mathcal {M}X = \mathcal {M}\beta $ . Let $u \in \mathcal {M}^{\times }$ , and let $\alpha = u \beta $ . Then $\overline {\alpha }, \overline {\beta }, \overline {u} \in (\mathcal {M}/\mathfrak {f})^{\times }$ and the following are equivalent:

  1. (a) $X = \Lambda \alpha $ ,

  2. (b) $\Lambda \alpha + \mathfrak {f} = \Lambda $ ,

  3. (c) $\overline {\alpha } \in (\Lambda /\mathfrak {f})^{\times }$ ,

  4. (d) $\pi (\overline {\beta }) = \pi (\overline {u^{-1}})$ ,

  5. (e) $\alpha \in X$ and X is locally free over $\Lambda $ .

Proof. Lemma 4.2 and the definitions of u and $\alpha $ imply that $\overline {\alpha }, \overline {\beta }, \overline {u} \in (\mathcal {M}/\mathfrak {f})^{\times }$ . It is clear that (b) $\Leftrightarrow $ (c). Since $\beta = u^{-1} \alpha $ , that (c) $\Leftrightarrow $ (d) follows from the definition of $\pi $ . Since $X + \mathfrak {f} = \Lambda $ , we also have (a) $\Rightarrow $ (b). Assume (b) holds. By two applications of Lemma 4.2, we have

$$\begin{align*}X = \mathcal{M}X \cap \Lambda = \mathcal{M}\beta \cap \Lambda = \mathcal{M}\alpha \cap \Lambda = \mathcal{M}(\Lambda\alpha) \cap \Lambda = \Lambda\alpha, \end{align*}$$

where the first equality uses the hypothesis that $X + \mathfrak {f} = \Lambda $ and the last equality uses the assumption that (b) holds; thus (a) holds. Therefore, (a) $\Leftrightarrow $ (b). Finally, a special case of [Reference Bley and JohnstonBJ08, Proposition 2.1] shows that (a) $\Leftrightarrow $ (e).

Much of the following notation is adopted from [Reference Bley, Boltje, Hess, Pauli and PohstBB06] and [Reference Hofmann and JohnstonHJ20]. Denote the centre of a ring R by $Z(R)$ . Let $C=Z(A)$ , and let $\mathcal {O}_{C}$ be the integral closure of $\mathcal {O}$ in C. Let $\mathfrak {g} = \mathfrak {f} \cap C$ , and note that this is a proper full ideal of $\mathcal {O}_{C}$ . Let $e_{1}, \ldots , e_{r}$ be the primitive idempotents of C and set $A_{i} = Ae_{i}$ . Then

(1) $$ \begin{align} A = A_{1} \oplus \cdots \oplus A_{r} \end{align} $$

is a decomposition of A into indecomposable two-sided ideals (see [Reference Curtis and ReinerCR81, (3.22)]). Each $A_{i}$ is a simple K-algebra with identity element $e_{i}$ . The centres $K_{i} := Z(A_{i})$ are finite field extensions of K via $K \rightarrow K_{i}$ , $\alpha \mapsto \alpha e_{i}$ , and we have K-algebra isomorphisms $A_{i} \cong \mathrm {Mat}_{n_{i}}(D_{i})$ , where $D_{i}$ is a skew field with $Z(D_{i}) \cong K_{i}$ (see [Reference Curtis and ReinerCR81, (3.28)]). The Wedderburn decomposition (1) induces decompositions

(2) $$ \begin{align} C = K_{1} \oplus \cdots \oplus K_{r} \quad \textrm{and} \quad \mathcal{O}_{C} = \mathcal{O}_{K_{1}} \oplus \cdots \oplus \mathcal{O}_{K_{r}}, \end{align} $$

where $\mathcal {O}_{K_i}$ denotes the ring of algebraic integers of $K_{i}$ . By [Reference ReinerRei03, (10.5)] we have $e_{1}, \ldots , e_{r} \in \mathcal {M}$ and each $\mathcal {M}_{i}:=\mathcal {M}e_{i}$ is a maximal $\mathcal {O}$ -order (and thus a maximal $\mathcal {O}_{K_{i}}$ -order) in $A_{i}$ . Moreover, each $\mathfrak {f}_{i}:=\mathfrak {f} e_{i}$ is a full two-sided ideal of $\mathcal {M}_{i}$ , each $\mathfrak {g}_{i} := \mathfrak {g} e_{i}$ is a nonzero integral ideal of $\mathcal {O}_{K_{i}}$ and we have decompositions

(3) $$ \begin{align} \mathcal{M} = \mathcal{M}_{1} \oplus \cdots \oplus \mathcal{M}_{r}, \quad \mathfrak{f} = \mathfrak{f}_{1} \oplus \cdots \oplus \mathfrak{f}_{r} \quad \textrm{and} \quad \mathfrak{g} = \mathfrak{g}_{1} \oplus \cdots \oplus \mathfrak{g}_{r}. \end{align} $$

The reduced norm map $\mathrm {nr} : A \rightarrow C$ is defined componentwise (see [Reference ReinerRei03, §9]) and restricts to a group homomorphism $\mathrm {nr} : \mathcal {M}^{\times } \rightarrow \mathcal {O}_{C}^{\times }$ .

Lemma 4.4. There exists a surjective group homomorphism $\overline {\mathrm {nr}}: (\mathcal {M}/\mathfrak {f})^{\times } \longrightarrow (\mathcal {O}_{C}/\mathfrak {g})^{\times }$ that fits into the commutative diagram

where the vertical maps are induced by the canonical projections.

Proof. The decompositions (1), (2) and (3) and the componentwise definition of the reduced norm mean that we can and do assume without loss of generality that $r=1$ , that is, A is simple, $\mathcal {M}=\mathcal {M}_{1}$ , $\mathfrak {f}=\mathfrak {f}_{1}$ , $\mathfrak {g}=\mathfrak {g}_{1}$ and $C=K=K_{1}$ . Let $\mathfrak {p}$ be a prime ideal of $\mathcal {O}_{K}$ dividing $\mathfrak {g}$ , and let $K_{\mathfrak {p}}$ denote the completion (not localisation) of K at $\mathfrak {p}$ . If M is an $\mathcal {O}_{K}$ -module or an $\mathcal {O}_{K}$ -algebra, then we write $\widehat {M}_{\mathfrak {p}} := M \otimes _{\mathcal {O}_{K}} {\mathcal {O}_{K_{\mathfrak {p}}}}$ . By [Reference ReinerRei03, (7.6),(11.6)], $\widehat {\mathcal {M}}_{\mathfrak {p}}$ is a maximal $\mathcal {O}_{K_{\mathfrak {p}}}$ -order in the central simple $K_{\mathfrak {p}}$ -algebra $A \otimes _{K} K_{\mathfrak {p}}$ . Let $\mathrm {nr}_{\mathfrak {p}} : \widehat {\mathcal {M}}_{\mathfrak {p}}^{\times } \rightarrow \mathcal {O}_{K_{\mathfrak {p}}}^{\times }$ denote the restriction of the reduced norm map. Then by [Reference Bley, Boltje, Hess, Pauli and PohstBB06, Corollary 2.4], we have that $\mathrm {nr}_{\mathfrak {p}}(1+\widehat {\mathfrak {f}}_{\mathfrak {p}})=1+\widehat {\mathfrak {g}}_{\mathfrak {p}}$ and $\mathrm {nr}_{\mathfrak {p}}(\widehat {\mathcal {M}}_{\mathfrak {p}}^{\times })=\mathcal {O}_{K_{\mathfrak {p}}}^{\times }$ . Hence, we have a commutative diagram

where $\overline {\mathrm {nr}}_{\mathfrak {p}}$ is induced by the other two vertical maps and is surjective by the snake lemma.

The Chinese remainder theorem gives canonical isomorphisms

$$\begin{align*}(\mathcal{M}/\mathfrak{f})^{\times} \cong \prod_{\mathfrak{p} \mid \mathfrak{g}} (\widehat{\mathcal{M}}_{\mathfrak{p}}/\widehat{\mathfrak{f}}_{\mathfrak{p}})^{\times} \quad \textrm{ and } \quad (\mathcal{O}_{K}/\mathfrak{g})^{\times} \cong \prod_{\mathfrak{p} \mid \mathfrak{g}} (\mathcal{O}_{K_{\mathfrak{p}}} / \widehat{\mathfrak{g}}_{\mathfrak{p}})^{\times}. \end{align*}$$

Let $\overline {\mathrm {nr}} = \prod _{\mathfrak {p} \mid \mathfrak {g}} \overline {\mathrm {nr}}_{\mathfrak {p}}$ , and observe that the desired result now follows since the reduced norm map commutes with completion by [Reference ReinerRei03, (9.29)].

Let $\mathrm {SL}(\mathcal {M})=\ker (\mathrm {nr}: \mathcal {M}^{\times } \rightarrow \mathcal {O}_{C}^{\times })$ and $\mathrm {SL}(\mathcal {M}/\mathfrak {f})=\ker (\overline {\mathrm {nr}})$ . (Note that in the literature the set $\mathrm {SL}(\mathcal {M})$ , which is the group of units of reduced norm one, is sometimes also denoted by $\mathcal {M}^1$ .) Then by Lemma 4.4 and the definitions, we have the following commutative diagram

(4)

where the rows are exact and the vertical maps are induced by the canonical projections. Note that all the maps are group homomorphisms, apart from $\pi $ , which is only a map of sets in general.

Theorem 4.5. Let X be a left ideal of $\Lambda $ such that $X + \mathfrak {f} = \Lambda $ . Suppose that there exists $\beta \in \mathcal {M}$ such that $\mathcal {M}X = \mathcal {M}\beta $ . Then the following statements hold.

  1. (a) If X is free over $\Lambda $ , then $\pi _{2}(\overline {\mathrm {nr}}(\overline {\beta }))$ is in the image of $\pi _{2} \circ f_{2}$ .

  2. (b) If $f_{1}$ is surjective, then the converse of (a) holds. More precisely, if $u \in \mathcal {M}^\times $ and $\overline {a} \in (\Lambda /\mathfrak {f})^{\times }$ satisfy $\overline {\mathrm {nr}}(\overline {\beta }) = \overline {\mathrm {nr}}(\overline {u}) \overline {\mathrm {nr}}(\overline {a})$ , then for any $v \in \mathrm {SL}(\mathcal {M})$ with $f_{1}(v)=\overline {\beta }\overline { a}^{-1}\overline {u}^{-1}$ , we have $X = \Lambda \alpha $ , where $\alpha := (vu)^{-1}\beta $ .

Proof. (a) Suppose that X is free over $\Lambda $ . Then there exists $\alpha \in X$ such that $X=\Lambda \alpha $ . Thus, $\mathcal {M}\beta = \mathcal {M}X=\mathcal {M}(\Lambda \alpha )=\mathcal {M}\alpha $ , and so there exists $u \in \mathcal {M}^{\times }$ such that $\alpha = u\beta $ . Hence, $\pi (\overline {\beta }) = \pi (\overline {u^{-1}})$ by Proposition 4.3. In other words, there exists $a \in \Lambda $ such that $\overline {a} \in (\Lambda /\mathfrak {f})^{\times }$ and $\overline {\beta }=\overline {u^{-1}}\overline {a}$ . Thus,

$$\begin{align*}\overline{\mathrm{nr}}(\overline{\beta}) = \overline{\mathrm{nr}}(\overline{u^{-1}}\overline{a}) = \overline{\mathrm{nr}}(\overline{u^{-1}})\overline{\mathrm{nr}}(\overline{a}) = f_{2}(\mathrm{nr}(u^{-1}))\overline{\mathrm{nr}}(\overline{a}), \end{align*}$$

and so $\pi _{2}(\overline {\mathrm {nr}}(\overline {\beta }))=\pi _{2}(f_{2}(\mathrm {nr}(u^{-1})))$ .

(b) Suppose that $f_1$ is surjective and $\pi _{2}(\overline {\mathrm {nr}}(\overline {\beta }))$ is in the image of $\pi _{2} \circ f_{2}$ . Then there exist $u,a$ and v as in (b), and so $\pi (\overline {\beta })= \pi (\overline {vu})$ . Hence, by Proposition 4.3 we have $X = \Lambda \alpha $ where $\alpha := (vu)^{-1}\beta $ .

5 Preliminaries on complexity

We briefly recall the conventions that we will use for the complexity analysis of our algorithms. For details we refer the reader to Lenstra [Reference LenstraLen92] or Cohen [Reference CohenCoh93, §1.1].

Let l be the size of the input data measured by the number of required bits. Then an algorithm is polynomial time if the running time is $O(P(l))$ for a polynomial P. An algorithm is subexponential time if there exists $0 \le a < 1$ and $b \in \mathbb {R}_{>0}$ such that the running time is $O(\exp (b \cdot l^a(\log l)^{a-1}))$ .

A probabilistic algorithm may call a random number generator. In this case we say that the algorithm is probabilistic polynomial time if the expected running time is $O(P(l))$ for a polynomial P. We adopt the same convention for probabilistic subexponential time algorithms.

Given two computational problems $\mathsf {A}$ and $\mathsf {B}$ , a (probabilistic) polynomial-time reduction from $\mathsf {A}$ to $\mathsf {B}$ is an algorithm that solves $\mathsf {A}$ using a polynomial number of calls to an oracle solving $\mathsf {B}$ and is (probabilistic) polynomial time outside of those calls to the oracle.

Let K be a number field with ring of integers $\mathcal {O} = \mathcal {O}_K$ . We follow the convention of [Reference LenstraLen92] for representing our input data. In some more detail, if $V = K^{n}$ is an n-dimensional vector space over K, we represent an $\mathcal {O}$ -module $M \subseteq V$ by a pseudobasis of M, that is, by elements $v_1,\dotsc ,v_k \in V$ and fractional $\mathcal {O}$ -ideals $\mathfrak a_1,\dotsc ,\mathfrak a_k$ such that $M = \mathfrak a_1 v_1 \oplus \dotsb \oplus \mathfrak a_k v_k$ for some $k \leq n$ . A K-algebra A of dimension d is represented as a d-dimensional vector space together with the K-linear multiplication map $A \otimes _K A \to A$ , which is represented using $d^{3}$ elements of K. Given a finite-dimensional K-algebra A, an $\mathcal {O}$ -order of A is represented using a pseudobasis. An n-dimensional A-module V is represented as a vector space over K together with d matrices in $\mathrm {Mat}_{n}(K)$ , one for each basis element of A describing the action on elements of V. Given an $\mathcal {O}$ -order $\Lambda $ , a $\Lambda $ -lattice is represented by an $\mathcal {O}$ -submodule of a finite-dimensional A-module, invariant under the action of $\Lambda $ .

We will be mainly interested in solving the following two problems.

Problem ( $\mathsf {IsIsomorphic}$ )

Given a finite-dimensional K-algebra A, an $\mathcal {O}$ -order $\Lambda $ in A and two $\Lambda $ -lattices X and Y, decide whether X and Y are isomorphic, and if so, return an isomorphism $X \to Y$ .

Problem ( $\mathsf {IsPrincipal}$ )

Given a finite-dimensional K-algebra A, an $\mathcal {O}$ -order $\Lambda $ in A and a full $\Lambda $ -lattice X in A, decide whether there exists $\alpha \in X$ such that $X = \Lambda \alpha $ , and if so, return such an element $\alpha $ .

Under the assumption that A satisfies hypothesis (H), we will reduce these questions to well-studied problems in algorithmic number theory. These include $\mathsf {IsPrincipal}$ in the case where $A = K$ and $\Lambda =\mathcal {O}$ , as well as the following problems:

  • $\mathsf {Factor}$ : Given an ideal or element of the ring of integers $\mathcal {O}_{F}$ of a number field F, determine its factorisation into prime ideals.

  • $\mathsf {Primitive}$ : Given a finite field $\mathbb {F}_{q}$ , determine $\alpha \in \mathbb {F}_{q}^{\times }$ such that $\mathbb {F}_{q}^{\times } = \langle \alpha \rangle $ .

  • $\mathsf {DLog}$ : Given a finite field $\mathbb {F}_{q}$ and $\alpha , \beta \in \mathbb {F}_{q}^{\times }$ with $\mathbb {F}_{q}^{\times } = \langle \alpha \rangle $ , determine $n \in \mathbb {Z}_{\geq 0}$ such that $\alpha ^{n} = \beta $ .

  • $\mathsf {UnitGroup}$ : Given the ring of integers $\mathcal {O}_{F}$ of a number field F, determine a system of fundamental units for $\mathcal {O}_{F}^{\times }$ .

We will use the following standard convention and notation to denote variations and instances of computational problems. For example, for an $\mathcal {O}$ -order $\Lambda $ , we denote by $\mathsf {IsIsomorphic}_{\Lambda }$ the set of instances of $\mathsf {IsIsomorphic}$ restricted to $\Lambda $ -lattices. Similarly, we use $\mathsf {IsPrincipal}_\Lambda $ for the set of instances of $\mathsf {IsPrincipal}$ for $\Lambda $ -lattices. Moreover, given a $\Lambda $ -lattice X, we use $\mathsf {IsPrincipal}(X)$ to denote the instance of $\mathsf {IsPrincipal}$ for the lattice X. Note that in this case we still consider $\Lambda $ part of the input.

Remark 5.1. Currently, the following complexity statements are known.

  1. (a) The problem $\mathsf {Factor}_{\mathbb {Z}}$ can be solved in probabilistic subexponential time ([Reference Lenstra and PomeranceLP92, Theorem 10.5]). Given an ideal I of the ring of integers $\mathcal {O}_{F}$ of a number field F, the prime ideals of $\mathcal {O}_{F}$ lying above the rational prime factors of $\mathrm {Norm}_{F/\mathbb {Q}}(I)$ can be determined in probabilistic polynomial time ([Reference CohenCoh93, §6.2]); hence, there is a probabilistic polynomial-time reduction from $\mathsf {Factor}$ to $\mathsf {Factor}_{\mathbb {Z}}$ . Since $\mathsf {Primitive}(\mathbb {F}_q)$ is probabilistic polynomial-time reducible to $\mathsf {Factor}(q-1)$ , the same holds for $\mathsf {Primitive}$ . Moreover, $\mathsf {DLog}$ can be solved in subexponential time; see [Reference OdlyzkoOdl00] and the references therein. While it is conjectured that $\mathsf {IsPrincipal}$ and $\mathsf {UnitGroup}$ can also be solved in subexponential time, so far this has been established only under additional hypotheses and heuristics, including the generalised Riemann hypothesis (GRH); see [Reference BuchmannBuc90, Reference BiasseBia14, Reference Biasse and FiekerBF14].

  2. (b) There exist quantum polynomial-time algorithms for solving each of the problems $\mathsf {Factor}_{\mathbb {Z}}$ , $\mathsf {DLog}$ , $\mathsf {Primitive}$ ([Reference ShorSho97, §5, §6]), $\mathsf {UnitGroup}$ ([Reference Eisenträger, Hallgren, Kitaev and SongEHKS14, Theorem 1.2]) and $\mathsf {IsPrincipal}$ for rings of integers of number fields ([Reference Biasse and SongBS16, Theorem 1.3]).

Our approach to solving $\mathsf {IsIsomorphic}$ and $\mathsf {IsPrincipal}$ for noncommutative algebras A satisfying hypothesis (H) relies crucially on the solution of the following two subproblems.

Problem ( $\mathsf {Wedderburn}$ )

Given a number field K and a finite-dimensional semisimple K-algebra A satisfying hypothesis (H), determine number fields $K_{i}$ , integers $r, n_{i} \in \mathbb {Z}_{>0}$ and an explicit isomorphism $A \cong \prod _{i=1}^{r} \mathrm {Mat}_{n_i}(K_i)$ .

Problem ( $\mathsf {SplittingMatrixAlgebra}$ )

Given a number field K and a split central simple K-algebra A, determine an isomorphism $A \cong \mathrm {Mat}_{n}(K)$ for some $n \in \mathbb {Z}_{>0}$ .

Remark 5.2. For a finite-dimensional semisimple K-algebra A, an explicit decomposition $A \cong \prod _{i=1}^{r} A_{i}$ into simple K-algebras $A_{i}$ , as well as the centre $K_{i}$ of each $A_{i}$ , can be computed in polynomial time by [Reference Friedl and RonyaiFR85, 1.5 B]. Thus, $\mathsf {Wedderburn}$ reduces to $\mathsf {SplittingMatrixAlgebra}$ . The decision problem of checking whether $A_{i} \cong \mathrm {Mat}_{n_{i}}(K_{i})$ for some $n_{i} \in \mathbb {Z}_{>0}$ is polynomial-time reducible to the computation of (the discriminant of) a maximal order in $A_{i}$ by [Reference Nebe and SteelNS09, Corollary 3.4], hence to $\mathsf {Factor}$ by [Reference Ivanyos and RónyaiIR93, Corollary 5.3]. The problem of finding an explicit isomorphism appears to be a much harder problem. In [Reference Ivanyos, Rónyai and SchichoIRS12, Theorem 1] it was shown that for algebras of bounded dimension over a fixed number field, $\mathsf {SplittingMatrixAlgebra}$ is probabilistic polynomial-time reducible to the problem of computing a maximal order, hence to $\mathsf {Factor}$ .

6 Complexity of algorithms related to orders and their lattices

Let K be a number field with ring of integers $\mathcal {O} = \mathcal {O}_{K}$ . The aim of this section is to establish the complexity of certain algorithms related to $\mathcal {O}$ -orders and their lattices. These algorithms have already appeared in the literature, either implicitly or explicitly, but with either no or only partial analysis of their complexity.

6.1 Computing maximal orders

Let A be a finite-dimensional semisimple K-algebra, and let $\Lambda $ be an $\mathcal {O}$ -order in A. Let $d = \dim _{K}A$ and let $\mathrm {tr} \colon A \rightarrow K$ denote the reduced trace map (see [Reference Curtis and ReinerCR81, §7D]). Following [Reference Curtis and ReinerCR81, §26A], we define $\mathrm {Disc}(\Lambda )$ to be the ideal of $\mathcal {O}$ generated by all elements

$$\begin{align*}\det\left( \mathrm{tr}(x_ix_j)_{1 \le i,j \le d}\right) \text{ with } x_1, \ldots, x_d \in \Lambda. \end{align*}$$

By applying a result of [Reference Friedl and RonyaiFR85], the following is straightforward to deduce from the results of [Reference FriedrichsFri00].

Proposition 6.1. Let $\Lambda $ and A be as above. Then the problem of computing a maximal $\mathcal {O}$ -order $\mathcal {M}$ in A containing $\Lambda $ is probabilistic polynomial-time reducible to $\mathsf {Factor}(\mathrm {Disc}(\Lambda ))$ .

Proof. Let $\mathfrak {p}$ be a maximal ideal of $\mathcal {O}$ dividing $\mathrm {Disc}(\Lambda )$ , and write $v_{\mathfrak {p}}(-)$ for the $\mathfrak {p}$ -adic valuation. It follows from [Reference FriedrichsFri00, (3.17)] that the computation of an order $\Lambda ^{(\mathfrak {p})}$ such that $v_{\mathfrak {p}}([\Lambda ^{(\mathfrak {p})} : \Lambda ]_{\mathcal {O}})$ is maximal reduces in polynomial time to the problem of computing the maximal two-sided ideals of an order containing $\mathfrak {p}$ . Now, fix an order $\Gamma $ . Then the maximal two-sided ideals of $\Gamma $ containing $\mathfrak {p}$ are the preimages of the maximal two-sided ideals under the canonical projection $\Gamma \to (\Gamma /\mathfrak {p}\Gamma )/{\operatorname {\mathrm {J}}(\Gamma /\mathfrak {p}\Gamma )}$ (see [Reference FriedrichsFri00, (5.23)]). As a decomposition of this $(\mathcal {O}/\mathfrak {p})$ -algebra into simple components and therefore the maximal two-sided ideals can be found in probabilistic polynomial time by [Reference Friedl and RonyaiFR85, 1.5 B], an order $\Lambda ^{(\mathfrak {p})}$ can be determined in probabilistic polynomial time. By [Reference FriedrichsFri00, (3.19)] the order $\sum _{\mathfrak {p}} \Lambda ^{(\mathfrak {p})}$ is maximal, where $\mathfrak {p}$ runs over the maximal ideals of $\mathcal {O}$ dividing $\mathrm {Disc}(\Lambda )$ . Therefore, the computation of a maximal order $\mathcal {M}$ containing $\Lambda $ reduces in probabilistic polynomial time to $\mathsf {Factor}(\mathrm {Disc}(\Lambda ))$ .

6.2 Nice maximal orders

Let $n \in \mathbb {Z}_{>0}$ , and let $A = \mathrm {Mat}_{n}(K)$ be a full matrix algebra. For a nonzero fractional ideal $\mathfrak {a}$ of $\mathcal {O}$ , let

$$\begin{align*}\mathcal{M}_{\mathfrak a, n} := \left( \begin{array}{cccc} \mathcal{O} & \ldots & \mathcal{O} & \mathfrak{a}^{-1} \\ \vdots & \ddots & \vdots & \vdots \\ \mathcal{O} & \ldots & \mathcal{O} & \mathfrak{a}^{-1} \\ \mathfrak{a} & \ldots & \mathfrak{a} & \mathcal{O} \end{array} \right) \end{align*}$$

denote the $\mathcal {O}$ -order in A consisting of all $n \times n$ matrices $(x_{ij})_{1 \leq i,j \leq n}$ , where $x_{11}$ ranges over all elements of $\mathcal {O}$ , …, $x_{1n}$ ranges over all elements of $\mathfrak {a}^{-1}$ and so on. (In the case $n=1$ , we take $\mathcal {M}_{\mathfrak a, n}=\mathcal {O}$ .) We say that a maximal $\mathcal {O}$ -order in A is nice if it is equal to $\mathcal {M}_{\mathfrak a, n}$ for some choice of $\mathfrak {a}$ . By [Reference ReinerRei03, (27.6)] every maximal $\mathcal {O}$ -order in A is conjugate to a nice maximal order.

Lemma 6.2. There exists a probabilistic polynomial-time algorithm that, given a maximal $\mathcal {O}$ -order $\mathcal {M}$ in $A=\mathrm {Mat}_{n}(K)$ , determines a nonzero fractional ideal $\mathfrak {a}$ of $\mathcal {O}$ and $S \in \mathrm {GL}_{n}(K)$ such that $S\mathcal {M} S^{-1} = \mathcal {M}_{\mathfrak a, n}$ .

Proof. The algorithm is presented in [Reference Bley and JohnstonBJ08, §5] and works by reducing the problem to the computation of a Steinitz form of an $\mathcal {O}$ -lattice of rank n, which can be performed in probabilistic polynomial time by Corollary A.3.

6.3 Norm equations and principal ideals

Let $r \in \mathbb {Z}_{>0}$ , and let $A = \prod _{i=1}^{r} \mathrm {Mat}_{n_i}(K_i)$ , where $K_{i}$ is a finite field extension of K and $n_{i} \in \mathbb {Z}_{>0}$ for each i. In particular, A is a finite-dimensional semisimple K-algebra satisfying hypothesis (H). Let C be the centre of A, which we can and do identify with $\prod _{i=1}^{r} K_{i}$ . Let $\mathcal {M}$ be a maximal $\mathcal {O}$ -order in A, and let $\mathcal {O}_{C} = \mathcal {M} \cap C = \prod _{i=1}^{r} {\mathcal {O}_{K_{i}}}$ .

Lemma 6.3. The reduced norm map $\mathrm {nr} \colon \mathcal {M}^\times \to \mathcal {O}_C^\times $ is surjective. Moreover, there exists a probabilistic polynomial-time algorithm that given $\mathcal {M}$ and $a \in \mathcal {O}_C^\times $ determines $\alpha \in \mathcal M^\times $ such that $\mathrm {nr}(\alpha ) = a$ .

Proof. By decomposing $\mathcal {M}$ using the central primitive idempotents of A, it suffices to consider the case $A = \mathrm {Mat}_{n}(K)$ , in which we must have $\mathcal {O}_{C} = \mathcal {O}$ . Then the reduced norm map $\mathrm {nr}: A \rightarrow K$ is just the usual determinant map. Moreover, using Lemma 6.2, we can and do assume that $\mathcal {M} = \mathcal {M}_{\mathfrak a, n}$ is a nice maximal order. Since $\alpha = \operatorname {diag}(a,1,\dotsc ,1) \in \mathcal {M}_{\mathfrak a, n}^{\times }$ satisfies $\mathrm {nr}(\alpha ) = a$ , the claim follows.

An algorithm for solving the principal ideal problem for $\mathcal {M}$ -lattices was given in [Reference Bley and JohnstonBJ08, §5]. We now analyse its complexity.

Proposition 6.4. The problem $\mathsf {IsPrincipal}_{\mathcal {M}}$ is probabilistic polynomial-time reducible to one instance of $\mathsf {IsPrincipal}_{\mathcal O_{K_i}}{}$ for each $i = 1,\dotsc ,r$ .

Proof. By decomposing $\mathcal {M}$ using the central primitive idempotents of A, it suffices to consider the case $A = \mathrm {Mat}_{n}(K)$ , in which we must have $\mathcal {O}_{C} = \mathcal {O}$ . Let X be a full $\mathcal {M}$ -lattice in A. Let $e_{11} \in A$ be the matrix with the top-left entry equal to $1$ and all other entries equal to $0$ . Using Lemma 6.2, we can and do assume that $\mathcal {M} = \mathcal {M}_{\mathfrak a, n}$ is a nice maximal order. By [Reference Bley and JohnstonBJ08, Corollary 5.4], it is sufficient to check whether the Steinitz class of the $\mathcal {O}$ -module $e_{11}X$ is equal to $[\mathfrak a^{-1}]$ , which amounts to testing whether a certain ideal of $\mathcal {O}$ is principal.

6.4 Computing isomorphisms between localised lattices

Let $\Lambda $ be an $\mathcal {O}$ -order in a finite-dimensional K-algebra A. Given two $\Lambda $ -lattices X and Y and a maximal ideal $\mathfrak {p}$ of $\mathcal {O}$ , we wish to determine whether there exists an isomorphism $X_{\mathfrak p} \cong Y_{\mathfrak {p}}$ of $\Lambda _{\mathfrak {p}}$ -lattices and to compute such an isomorphism if so. By computing an isomorphism we mean computing a $\Lambda $ -morphism $f\colon X \to Y$ such that its localisation $f_{\mathfrak p} \colon X_{\mathfrak p} \to Y_{\mathfrak p}$ is an isomorphism.

We first consider the case where X is a full $\Lambda $ -lattice in A and $Y = \Lambda $ , for which an algorithm was presented in [Reference Bley and WilsonBW09, §4.2] (although the algorithm was presented only in the context of semisimple algebras, the semisimplicity hypothesis is in fact unnecessary). We now outline the algorithm and analyse its complexity.

Proposition 6.5. There exists a probabilistic polynomial-time algorithm that, given A, $\Lambda $ and $\mathfrak {p}$ as above and a full $\Lambda $ -lattice X in A, decides whether $X_{\mathfrak p}$ is free over $\Lambda _{\mathfrak {p}}$ and, if so, returns $\alpha \in X$ such that $X_{\mathfrak {p}} = \Lambda _{\mathfrak {p}} \alpha $ .

Proof. Consider the finitely generated $\mathcal {O}/\mathfrak {p}$ -algebra $R_{\mathfrak {p}} := \Lambda /\mathfrak {p} \Lambda \cong \Lambda _{\mathfrak {p}} / \mathfrak {p} \Lambda _{\mathfrak {p}}$ . It follows from [Reference Friedl and RonyaiFR85, 1.5 A] that the Jacobson radical $J_{\mathfrak {p}} = \operatorname {\mathrm {J}}(R_{\mathfrak {p}})$ can be determined in polynomial time. Let $\overline {R}_{\mathfrak {p}} = R_{\mathfrak {p}}/J_{\mathfrak {p}}$ . By Lemma 2.3 and Nakayama’s lemma, $X_{\mathfrak {p}}$ is free over $\Lambda _{\mathfrak {p}}$ if and only if $\overline {X}_{\mathfrak {p}} := (X/\mathfrak {p}X)/J_{\mathfrak {p}}(X/\mathfrak {p}X) \cong (X_{\mathfrak {p}}/\mathfrak {p}X_{\mathfrak {p}})/J_{\mathfrak {p}}(X_{\mathfrak {p}}/\mathfrak {p}X_{\mathfrak {p}})$ is free of rank $1$ over $\overline {R}_{\mathfrak {p}}$ . Using algorithms of Friedl–Rónyai [Reference Friedl and RonyaiFR85, 1.5 B] and Ronyai [Reference RonyaiRon87, Theorem 6.2], one can determine an isomorphism of $\overline {R}_{\mathfrak {p}}$ with a product of matrix algebras over finite fields $k_{i}$ in probabilistic polynomial time. The final steps are just linear algebra over finite fields.

The following algorithm without the complexity statement was given in [Reference Hofmann and JohnstonHJ20, §8.4].

Corollary 6.6. There exists a probabilistic polynomial-time algorithm that, given A, $\Lambda $ and $\mathfrak {p}$ as above and $\Lambda $ -lattices X and Y, decides whether $X_{\mathfrak {p}}$ and $Y_{\mathfrak {p}}$ are isomorphic as $\Lambda _{\mathfrak {p}}$ -lattices and, if so, returns $f \in \mathrm {Hom}_\Lambda (X, Y)$ such that the localisation $f_{\mathfrak {p}} \colon X_{\mathfrak {p}} \to Y_{\mathfrak {p}}$ is an isomorphism.

Proof. We use Proposition 6.5 together with the reduction to the free rank $1$ case given by Proposition 3.1. Both $\mathrm {End}_{\Lambda }(Y)$ and $\mathrm {Hom}_{\Lambda }(X, Y)$ can be determined as described in [Reference Hofmann and JohnstonHJ20, §7.3] using pseudo-Hermite normal form and pseudo-Smith normal form computations, which are probabilistic polynomial time by [Reference Biasse, Fieker and HofmannBFH17, Theorem 34, Proposition 43]. Using Proposition 6.5 one can determine in probabilistic polynomial time whether the $(\mathrm {End}_\Lambda (Y))_{\mathfrak {p}}$ -lattice $(\mathrm {Hom}_\Lambda (X, Y))_{\mathfrak {p}}$ is free of rank $1$ . If not, then $X_{\mathfrak {p}}$ and $Y_{\mathfrak {p}}$ are not isomorphic over $\Lambda _{\mathfrak {p}}$ . If so, then the algorithm returns a free generator $f \in \mathrm {Hom}_\Lambda (X, Y)$ of $(\mathrm {Hom}_\Lambda (X, Y))_{\mathfrak {p}}$ over $(\mathrm {End}_\Lambda (Y))_{\mathfrak {p}}$ . Then $X_{\mathfrak {p}} \cong Y_{\mathfrak {p}}$ over $\Lambda _{\mathfrak {p}}$ if and only if the localisation $f_{\mathfrak {p}} \colon X_{\mathfrak {p}} \to Y_{\mathfrak {p}}$ is an isomorphism.

Remark 6.7. Given two $\Lambda $ -lattices X and Y, Corollary 6.6 can be used to decide if X and Y are in the same genus, that is, whether $X_{\mathfrak {p}}$ and $Y_{\mathfrak {p}}$ are isomorphic $\Lambda _{\mathfrak {p}}$ -lattices for every nonzero prime ideal $\mathfrak {p}$ of $\mathcal {O}$ . Note that a necessary condition is that $KX$ and $KY$ are isomorphic as A-modules. By [Reference Chistov, Ivanyos and KarpinskiCIK97, Corollary 3] there is a polynomial-time algorithm that decides whether $KX$ and $KY$ are isomorphic as A-modules and, if so, computes an isomorphism; hence, the problem reduces to the case $KX = KY$ . In this situation, X and Y are in the same genus if and only if $X_{\mathfrak {p}}$ and $Y_{\mathfrak {p}}$ are isomorphic $\Lambda _{\mathfrak {p}}$ -lattices for the finitely many prime ideals $\mathfrak {p}$ dividing the module index $[X : Y]_{\mathcal {O}}$ (see [Reference FröhlichFrö67, §3]). Hence, checking whether X and Y are in the same genus is polynomial-time reducible to $\mathsf {Factor}([X : Y]_{\mathcal {O}})$ .

6.5 Finding a suitable choice of locally free left ideal

Let A be a finite-dimensional semisimple K-algebra, and let $\Lambda $ be an $\mathcal {O}$ -order in A. By [Reference ReinerRei03, (10.4)] there exists a (not necessarily unique) maximal $\mathcal {O}$ -order $\mathcal {M}$ in A containing $\Lambda $ . Let $\mathfrak {f}$ be any proper full two-sided ideal of $\mathcal {M}$ that is contained in $\Lambda $ . The following result without the complexity statements is a consequence of a special case of the argument given in [Reference Bley and JohnstonBJ11, §5.1].

Proposition 6.8. Given A, $\Lambda $ and $\mathfrak {f}$ as above and a full $\Lambda $ -lattice X in A, the problem of determining whether X is locally free over $\Lambda $ and, if so, computing an element $\xi \in A^{\times }$ such that $X \xi \subseteq \Lambda $ and $X\xi + \mathfrak {f} = \Lambda $ , is probabilistic polynomial-time reducible to $\mathsf {Factor}(\mathcal {O} \cap \mathfrak {f})$ .

Proof. Let $\mathrm {MaxSpec}(\mathcal {O})$ denote the set of all maximal ideals of $\mathcal {O}$ . Let $\mathfrak {S}= \{ \mathfrak {p}_{1}, \ldots , \mathfrak {p}_{n} \}$ be the subset consisting of ideals that divide $\mathcal {O} \cap \mathfrak {f}$ (note that this is a proper nonzero ideal of $\mathcal {O}$ ), and let $\mathfrak {T} = \mathrm {MaxSpec}(\mathcal {O}) \setminus \mathfrak {S}$ . Observe that, for every $\mathfrak {p} \in \mathfrak {T}$ , we have $\mathfrak {f}_{\mathfrak {p}} = \Lambda _{\mathfrak {p}}=\mathcal {M}_{\mathfrak {p}}$ , and so $X_{\mathfrak {p}}$ is free over $\Lambda _{\mathfrak {p}}$ by [Reference ReinerRei03, (18.10)]. Moreover, for each i, checking whether $X_{\mathfrak {p}_i}$ is free over $\Lambda _{\mathfrak {p}_i}$ and, if so, computing $\omega _{i} \in X$ such that $X_{\mathfrak {p}_i} = \Lambda _{\mathfrak {p}_i} \omega _{i}$ , can be performed in probabilistic polynomial time by Proposition 6.5. In particular, if this step is completed successfully, then X is locally free over $\Lambda $ .

By [Reference CohenCoh00, Proposition 1.3.11], elements $\beta _{1}, \ldots , \beta _{n} \in \mathcal {O}$ such that for each i, we have

$$\begin{align*}\beta_i \equiv 1 \bmod{\mathfrak{p}_i} \quad \text{ and } \quad \beta_i \equiv 0 \bmod{\mathfrak{p}_j} \text{ for } 1 \le j \le n, j \ne i \end{align*}$$

can be computed in polynomial time. For each i, let $\nu _i \in \mathcal {O} \setminus \mathfrak {p}_i$ be an element such that $X \omega _i^{-1} \nu _i \subseteq \Lambda $ . Then $X\xi \subseteq \Lambda $ , where $\xi := \sum _{i=1}^{n} \beta _{i} \omega _{i}^{-1} \nu _{i}$ . By construction we have $(X \xi )_{\mathfrak {p}_{i}} = \Lambda _{\mathfrak {p}_{i}}$ for each i. Moreover, $\mathfrak {f}_{\mathfrak {p}} = \Lambda _{\mathfrak {p}}$ for all $\mathfrak {p} \in \mathfrak {T}$ . Therefore, $(X\xi + \mathfrak {f})_{\mathfrak {p}} = \Lambda _{\mathfrak {p}}$ for all $\mathfrak {p} \in \mathrm {MaxSpec}(\mathcal {O})$ , and so $X\xi + \mathfrak {f} = \Lambda $ by [Reference ReinerRei03, (4.21)].

6.6 Computing generators of $(\Lambda /\mathfrak {f})^{\times }$ and $K_{1}(\Lambda /\mathfrak f)$

We first recall some definitions from algebraic K-theory and refer the reader to [Reference Curtis and ReinerCR87, §40] for more details. For any ring R, the Whitehead group $K_{1}(R)$ is defined as $\mathrm {GL}(R)/[\mathrm {GL}(R),\mathrm {GL}(R)]$ , where $\mathrm {GL}(R) = \varinjlim \mathrm {GL}_n(R)$ and $\mathrm {GL}_n(R)$ embeds into $\mathrm {GL}_{n + 1}(R)$ via

$$\begin{align*}\alpha \mapsto \begin{pmatrix} \alpha & 0 \\ 0 & 1 \end{pmatrix}. \end{align*}$$

In particular, there is a canonical map $R^\times \to \mathrm {GL}(R) \to K_1(R)$ .

Now, assume the notation and setting of §6.5. Since $\Lambda /\mathfrak {f}$ is of finite cardinality, it is semilocal, and so the canonical map

$$\begin{align*}(\Lambda/\mathfrak f)^{\times} \longrightarrow K_1(\Lambda/\mathfrak f) \end{align*}$$

is surjective by [Reference Curtis and ReinerCR87, (40.31)]. We consider the problems of computing generators of $(\Lambda /\mathfrak {f})^{\times }$ and of $K_{1}(\Lambda /\mathfrak f)$ , where the latter task means computing elements $x_1,\dotsc ,x_n \in (\Lambda /\mathfrak {f})^{\times }$ such that their images generate $K_1(\Lambda /\mathfrak f)$ .

An algorithm for computing generators of $K_1(\Lambda /\mathfrak {f})$ is described in [Reference Bley, Boltje, Hess, Pauli and PohstBB06, §3.4–3.7]. With minor modifications, this algorithm also computes a generating set of $(\Lambda /\mathfrak f)^\times $ . In this subsection, we will analyse the complexity of both these algorithms. To treat both cases simultaneously, for a ring R we let $\mathrm {G}(R)$ denote either $K_{1}(R)$ or $R^{\times }$ .

Let C denote the centre of A, and let $\mathcal {O}_{C}$ be the integral closure of $\mathcal {O}$ in C. Let $\mathfrak {g} = \mathfrak {f} \cap C$ , and note that this is a proper full ideal of $\mathcal {O}_{C}$ and of $\Lambda \cap \mathcal {O}_{C} = \Lambda \cap C$ . Let

be the prime ideal decomposition of $\mathfrak {g}$ in $\mathcal {O}_{C}$ , where the set

of prime ideals of $\mathcal {O}_{C}$ is defined by the decomposition. Set

, a set of prime ideals of $\Lambda \cap \mathcal {O}_{C}$ . For each

consider the ideal

We write

for the set of ideals $\mathfrak {q}$ . Then by [Reference Bley and EndresBE05, Proposition 3.2]

is the unique primary decomposition of $\mathfrak {g}$ when considered as an ideal of $\Lambda \cap \mathcal {O}_{C}$ . Moreover, by [Reference Bley, Boltje, Hess, Pauli and PohstBB06, Lemma 3.5], we have

and by the Chinese remainder theorem we obtain an isomorphism

This induces a decomposition

Thus, given

, it suffices to compute generators of $\mathrm {G}(\Lambda /(\mathfrak {q}\Lambda + \mathfrak {f}))$ for each

.

Now, fix , and let be the associated prime ideal of $\Lambda \cap \mathcal {O}_{C}$ for some . As shown in [Reference Bley, Boltje, Hess, Pauli and PohstBB06, §3.7], we have an exact sequence

(5) $$ \begin{align} (1 + \mathfrak p \Lambda + \mathfrak f)/(1 + \mathfrak q \Lambda + \mathfrak f) \longrightarrow \operatorname{\mathrm{G}}(\Lambda/(\mathfrak q \Lambda + \mathfrak f)) \longrightarrow \operatorname{\mathrm{G}}(\Lambda/(\mathfrak p \Lambda + \mathfrak f)) \longrightarrow 1. \end{align} $$

We consider the problems of computing generators for the first and third terms in this sequence. Let $d := \dim _{K} A$ .

Lemma 6.9. Given $\Lambda $ , $\mathfrak {f}$ and $\mathfrak p$ as above, the problem of computing generators of

$$\begin{align*}(\Lambda/(\mathfrak p \Lambda + \mathfrak{f}))^{\times} \text{ or } K_{1}(\Lambda/(\mathfrak{p} \Lambda + \mathfrak{f})) \end{align*}$$

is probabilistic polynomial-time reducible to at most d instances of the problem $\mathsf {Primitive}$ for extensions of $\mathcal {O}/(\mathcal {O}\cap \mathfrak {P})$ of degree at most d. The number of generators is at most $d([K : \mathbb {Q}]+2)$ .

Proof. Let k denote the finite field $\mathcal {O}/(\mathfrak {p} \cap \mathcal {O})$ . Let $R = \Lambda /(\mathfrak {p} \Lambda + \mathfrak {f})$ , and note that this is annihilated by $\mathfrak {p} \cap \mathcal {O}$ . Thus, R is a k-algebra such that $\dim _{k} R \leq d$ . In particular, R is Artinian, so its Jacobson radical $J = \operatorname {\mathrm {J}}(R)$ is nilpotent by [Reference Curtis and ReinerCR81, (5.15)]. Since we have a decreasing filtration $J \supseteq J^2 \supseteq \cdots \supseteq J^d$ and $\dim _k(J) \le d-1$ , we obtain $J^{d}=0$ . By [Reference Bley, Boltje, Hess, Pauli and PohstBB06, Lemma 3.6] and the same reasoning as in [Reference Bley, Boltje, Hess, Pauli and PohstBB06, §3.7], we have an exact sequence

$$\begin{align*}1 + J \longrightarrow \operatorname{\mathrm{G}}(R) \longrightarrow \operatorname{\mathrm{G}}(R/J) \longrightarrow 1. \end{align*}$$

We first discuss the computation of generators for $1 + J$ . To this end, let $l \in \mathbb {Z}_{\geq 0}$ be minimal subject to the condition $J^{2^l} = 0$ and note that $2^{l} \leq 2d$ . Consider the filtration

$$\begin{align*}1 + J \supseteq 1 + J^2 \supseteq \dotsb \supseteq 1 + J^{2^{l - 1}} \supseteq 1. \end{align*}$$

Generators of J can be determined in polynomial time using the algorithms of [Reference Friedl and RonyaiFR85, 1.5 A]. For each $i = 0,\dotsc ,l-1$ , the map $\overline {x} \mapsto \overline {x-1}$ induces an isomorphism

$$\begin{align*}(1 + J^{2^i})/(1 + J^{2^{i+1}}) \longrightarrow J^{2^i}/J^{2^{i+1}} \end{align*}$$

of abelian groups, and so it follows that we can find generators of $1 + J$ in polynomial time. For each $i = 0, \dotsc , l - 1$ the number of generators of $J^{2^i}/J^{2^{i + 1}}$ is bounded by $\dim _k(J^{2^i}/J^{2^{i+1}}) [K : \mathbb {Q}]$ . Now, summing over $i = 0,\dotsc ,l-1$ shows that $1 + J$ is generated by at most $\dim _k(J) [K : \mathbb {Q}] \leq (d-1) [K : \mathbb {Q}]$ elements.

Using algorithms of [Reference Friedl and RonyaiFR85, 1.5 B] and [Reference RonyaiRon87, Theorem 6.2], one can determine an isomorphism $R/J \cong \prod _{1 \leq i \leq r} \mathrm {Mat}_{n_{i}}(k_{i})$ with a product of matrix algebras over finite fields $k_{i}$ in probabilistic polynomial time. Since

$$\begin{align*}\operatorname{\mathrm{G}}(R/J) \cong \prod_{1 \leq i \leq r} \operatorname{\mathrm{G}}(\mathrm{Mat}_{n_i}(k_i)), \end{align*}$$

this problem reduces to the computation of each $\operatorname {\mathrm {G}}(\mathrm {Mat}_{n_i}(k_i))$ , which we claim is generated by at most $2$ elements. If $\operatorname {\mathrm {G}}{} = K_1$ , then the claim follows from the fact that the canonical maps $k_{i}^{\times } \to K_{1}(k_{i}) \to K_1(\mathrm {Mat}_{n_i}(k_i))$ are isomorphisms. If $\operatorname {\mathrm {G}}{} = (-)^\times $ , then the claim follows from [Reference TaylorTay87], where it is shown that given a primitive element of $k_i$ one can write down directly a two element generating set of $\mathrm {GL}_{n_i}(k_i)$ . Since $\dim _{k}(R/J) \leq d$ we have $r \leq d$ and $[k_i : k] \leq d$ for each i. Finally, note that $\mathcal {O}/(\mathcal {O}\cap \mathfrak {p}) = \mathcal {O} / (\mathcal {O}\cap \mathfrak {P})$ since $\mathcal {O}\subseteq \Lambda $ implies $\mathcal {O}\cap \mathfrak {p}= \mathcal {O}\cap \mathfrak {P}\cap \Lambda = \mathcal {O}\cap \mathfrak {P}$ . In particular, $G(R/J)$ is generated by at most $2r \leq 2d$ elements.

Lemma 6.10. Given $\Lambda $ , $\mathfrak {f}$ , $\mathfrak {p}$ and $\mathfrak {q}$ as above, we set

Then there exists a polynomial-time algorithm that returns m elements of $\Lambda $ whose classes generate $(1 + \mathfrak {p} \Lambda + \mathfrak {f})/(1 + \mathfrak {q} \Lambda + \mathfrak {f})$ . If $e_{\mathfrak {p}} = 1$ ; we have $m=0$ . If $e_{\mathfrak {p}}> 1$ , the number m of generators is bounded by $d (1+\log _2(e_{\mathfrak {p}})) [K:\mathbb {Q}]$ .

Proof. If $e_{\mathfrak {p}}=1$ , we clearly have $\mathfrak {p} = \mathfrak {q}$ , and so $m=0$ . If $e_{\mathfrak {p}}> 1$ , we let $l \in \mathbb {Z}_{>0}$ be minimal subject to the condition $\mathfrak {p}^{2^l} \subseteq \mathfrak {q}$ . Then there exists a filtration

$$\begin{align*}\mathfrak{p} \Lambda + \mathfrak{f} \supseteq (\mathfrak{q} + \mathfrak{p}^2)\Lambda + \mathfrak{f} \supseteq \dotsb \supseteq (\mathfrak{q} + \mathfrak{p}^{2^{l - 1}})\Lambda + \mathfrak{f} \supseteq \mathfrak{q} \Lambda + \mathfrak{f}. \end{align*}$$

For each $i = 0,\dotsc ,l-1$ , the map $\overline {x} \mapsto \overline {x-1}$ induces an isomorphism

$$\begin{align*}\frac{1 + (\mathfrak{q} + \mathfrak{p}^{2^i})\Lambda + \mathfrak{f}} {1 + (\mathfrak{q} + \mathfrak{p}^{2^{i+1}})\Lambda + \mathfrak{f}} \longrightarrow \frac{(\mathfrak{q} + \mathfrak{p}^{2^i})\Lambda + \mathfrak{f}}{(\mathfrak{q} + \mathfrak{p}^{2^{i+1}})\Lambda + \mathfrak{f}} \end{align*}$$

of abelian groups. Hence, any $\mathbb {Z}$ -basis of the right-hand side yields generators of the left-hand side. It remains to bound l. For every with $\mathfrak {P} \cap \Lambda = \mathfrak {p}$ , the inclusion $\mathfrak {p}^{e_{\mathfrak {p}}} = (\mathfrak {P} \cap \Lambda )^{e_{\mathfrak {p}}} \subseteq \mathfrak {P}^{e_{\mathfrak {p}}} \cap \Lambda \subseteq \mathfrak {P}^{e_{\mathfrak {P}}} \cap \Lambda $ holds. Hence, $\mathfrak {p}^{e_{\mathfrak {p}}} \subseteq \mathfrak {q}$ and therefore $2^{l} \leq 2e_{\mathfrak {p}}$ , which gives $l \leq 1 + \log _{2}(e_{\mathfrak {p}})$ .

Since any quotient $((\mathfrak {q} + \mathfrak {p}^{2^i})\Lambda + \mathfrak {f}) / ((\mathfrak {q} + \mathfrak {p}^{2^{i+1}})\Lambda + \mathfrak {f})$ is generated by at most $d [K : \mathbb {Q}]$ elements, the quotient $(1 + \mathfrak {p} \Lambda + \mathfrak {f})/(1 + \mathfrak {q} \Lambda + \mathfrak {f})$ is generated by at most $(1 + \log _{2}(e_{\mathfrak {p}})) d [K : \mathbb {Q}]$ elements.

Proposition 6.11. Given $\Lambda $ and $\mathfrak {f}$ as above, the problem of computing generators of $(\Lambda /\mathfrak {f})^{\times }$ and $K_{1}(\Lambda /\mathfrak {f})$ is probabilistic polynomial-time reducible to the factorisation of $\mathfrak {g} := \mathfrak {f} \cap \mathcal {O}_{C}$ as an ideal of $\mathcal {O}_{C}$ and, for each prime ideal divisor $\mathfrak {P}$ of $\mathfrak {g}$ , at most d instances of $\mathsf {Primitive}$ for extensions of $\mathcal {O}/(\mathcal {O}\cap \mathfrak {P})$ of degree at most d. The number of generators is bounded by $5 d [ K:\mathbb {Q}]\log _2|\mathcal {O}_C/\mathfrak {g}|$ .

Proof. Using the factorisation of $\mathfrak {g} = \mathfrak {f} \cap \mathcal {O}_{C}$ , one can determine the sets of ideals

,

and

in polynomial time. Since

, the claim follows from the reduction to the computation of $\mathrm {G}(\Lambda /(\mathfrak {q}\Lambda + \mathfrak {f}))$ for each

discussed at the beginning of the section, the exact sequence (5), Lemmas 6.9 and 6.10 and the following computation

The inequality $(*)$ is a consequence of

which, in turn, is immediate from

.

Remark 6.12. In the setup above, we start with a proper full two-sided ideal $\mathfrak {f}$ of $\mathcal {M}$ contained in $\Lambda $ and set $\mathfrak {g} := \mathfrak {f} \cap C$ . Under hypothesis (H) on A, we may instead start with a proper full ideal $\mathfrak {g}$ of $\mathcal {O}_{C}$ such that $\mathfrak {g}\mathcal {M}$ is contained in $\Lambda $ and then set $\mathfrak {f} := \mathfrak {g}\mathcal {M}$ . In this situation, we then have $\mathfrak {g} = \mathfrak {f} \cap \mathcal {O}_C$ by [Reference ReinerRei03, (27.6)].

7 Lifting units of reduced norm one

Let K be a number field with ring of integers $\mathcal {O} = {\mathcal {O}_K}$ . Let $r \in \mathbb {Z}_{>0}$ , and let $A = \prod _{i=1}^{r} \mathrm {Mat}_{n_i}(K_i)$ , where $K_{i}$ is a finite field extension of K and $n_{i} \in \mathbb {Z}_{>0}$ for each i. In particular, A is a finite-dimensional semisimple K-algebra satisfying hypothesis (H). Let C be the centre of A, which we can and do identify with $\prod _{i=1}^{r} K_{i}$ . In this situation, the reduced norm map $\mathrm {nr} \colon A \rightarrow C$ is equal to the product of maps $\det : \mathrm {Mat}_{n_i}(K_i) \rightarrow K_{i}$ .

Let $\mathcal {M}$ be a maximal $\mathcal {O}$ -order in A, and let $\mathcal {O}_{C} = \mathcal {M} \cap C = \prod _{i=1}^{r} {\mathcal {O}_{K_{i}}}$ . Then $\mathrm {nr}$ restricts to a group homomorphism $\mathrm {nr} \colon \mathcal {M}^{\times } \rightarrow \mathcal {O}_{C}^{\times }$ , which is surjective since A satisfies the Eichler condition relative to $\mathcal {O}$ (see [Reference Curtis and ReinerCR87, (45.4), (45.6)]). Let $\mathfrak {g}$ be a proper full ideal of $\mathcal {O}_C$ , and let $\mathfrak {f} = \mathfrak {g}\mathcal {M}$ . Then by Lemma 4.4 there exists a commutative diagram of groups

(6)

where the rows are exact, $\mathrm {SL}(\mathcal {M})$ and $\mathrm {SL}(\mathcal {M}/\mathfrak {f})$ are defined by the exactness of these rows, and the vertical maps are induced by the canonical projections. Note that this is consistent with diagram (4), but we do not require an order $\Lambda $ for the above setup.

The aim of this section is to show that, under the above assumptions on A and $\mathfrak {f}$ , the map $f_{1}$ is surjective, and there exists a polynomial-time algorithm that given an element of $\mathrm {SL}(\mathcal {M}/\mathfrak {f})=\mathrm {SL}(\mathcal {M}/\mathfrak {g}\mathcal {M})$ returns a preimage under $f_{1}$ .

7.1 Lifting unimodular matrices

We first consider the case where $A = \mathrm {Mat}_{n}(K)$ and $\mathcal {M} = \mathrm {Mat}_{n}(\mathcal {O})$ for some $n \in \mathbb {Z}_{>0}$ . In this situation, we have $\mathcal {O}=\mathcal {O}_{C}$ and $\mathcal {M}/\mathfrak {f} = \mathrm {Mat}_{n}(\mathcal {O}/\mathfrak {g})$ . Moreover, both the maps $\mathrm {nr}$ and $\overline {\mathrm {nr}}$ in diagram (6) are just the usual determinant maps, $\mathrm {SL}(\mathcal {M}) = \mathrm {SL}_{n}(\mathcal {O})$ , and $\mathrm {SL}(\mathcal {M}/\mathfrak {f}) = \mathrm {SL}_{n}(\mathcal {O}/\mathfrak {g})$ . Thus, $f_{1}$ is the canonical map $f_{1} : \mathrm {SL}_{n}(\mathcal {O}) \rightarrow \mathrm {SL}_{n}(\mathcal {O}/\mathfrak {g})$ . Note that this map is trivial when $n=1$ , so we henceforth suppose that $n \geq 2$ .

We use the following notation for a commutative ring R. Given $1 \leq i, j \leq n$ with $i \neq j$ , and $r \in R$ , we denote by $e_{ij}(r) \in \mathrm {SL}_{n}(R)$ the matrix with ones on the diagonal and entry r at position $(i, j)$ . We refer to these matrices as elementary matrices. Let $\mathrm {E}_{n}(R)$ denote the subgroup of $\mathrm {SL}_{n}(R)$ generated by all elementary matrices.

Since $\mathcal {O}/\mathfrak {g}$ is semilocal, $\mathrm {SL}_{n}(\mathcal {O}/\mathfrak {g}) = \mathrm {E}_{n}(\mathcal {O}/\mathfrak {g})$ by [Reference BassBas68, Chapter V, Corollary 9.2]. Thus, every element of $\mathrm {SL}_{n}(\mathcal {O}/\mathfrak {g})$ can be expressed as a product of elementary matrices, and every such matrix can easily be lifted to an elementary matrix in $\mathrm {SL}_{n}(\mathcal {O})$ . This immediately implies the theoretical part of Corollary 7.6 below. However, we will need a constructive proof that then translates into an efficient algorithm.

We will show that, given the factorisation of $\mathfrak {g}$ , there exists a polynomial-time algorithm for lifting unimodular matrices over $\mathcal {O}/\mathfrak {g}$ to $\mathcal {O}$ . The idea is to reduce to the local case and then apply the Chinese remainder theorem.

For any matrix M, let $M^{t}$ denote its transpose. A vector $\mathbf {v} = (v_{1}, \ldots , v_{n})^{t}$ of elements of a commutative ring R is said to be unimodular if $\sum _{i=1}^{n} R v_{i} = R$ . In the following we denote by $\mathfrak {q} = \mathfrak {p}^l$ , $l \in \mathbb {Z}_{>0}$ , the power of a nonzero prime ideal of $\mathcal {O}$ . Note that $\mathcal {O}/\mathfrak {q}$ is a local ring.

Lemma 7.1. There exists a polynomial-time algorithm that given a unimodular vector $\mathbf {v} \in (\mathcal {O}/\mathfrak {q})^{n}$ returns elementary matrices $E_{1},\dotsc ,E_{k} \in \mathrm {Mat}_{n}(\mathcal {O}/\mathfrak {q})$ such that $E_{1} \dotsm E_{k} \mathbf {v} = (x,0,\dotsc ,0)^{t}$ for some $x \in (\mathcal {O}/\mathfrak {q})^{\times }$ .

Proof. Write $\mathbf {v} = (v_1,\dotsc ,v_n)^t$ . Note that as $\mathcal {O}/\mathfrak {q}$ is local; $\mathbf {v}$ being unimodular implies that there exists $1 \leq i \leq n$ such that $v_i \in (\mathcal {O}/\mathfrak {q})^\times $ .

Case 1: If $v_1 \in (\mathcal {O}/\mathfrak {q})^\times $ , then $e_{21}(-v_1^{-1}v_2) \dotsm e_{n1}(-v_1^{-1}v_n) \mathbf {v}$ has the required form.

Case 2: If $v_i \in (\mathcal {O}/\mathfrak {q})^\times $ with $1 < i \leq n$ , then after multiplying $\mathbf {v}$ by $e_{1i}(1) e_{i1}(-1) e_{1i}(1)$ on the left, the first entry will be invertible and we are in the first case.

Lemma 7.2. There exists a polynomial-time algorithm that given a matrix $V \in \mathrm {SL}_{n}(\mathcal {O}/\mathfrak {q})$ returns elementary matrices $E_{1},\dotsc ,E_{k} \in \mathrm {Mat}_{n}(\mathcal {O}/\mathfrak {q})$ such that $E_{1} \dotsm E_{k} V$ is upper triangular. If V is lower triangular, then $E_{1} \dotsm E_{k} V$ is diagonal.

Proof. The first part follows by repeatedly applying Lemma 7.1 to V and submatrices of V. If V is lower triangular, then we are always in Case 1 of the proof of Lemma 7.1 and thus easily see that the resulting matrix is diagonal.

As we will see below, the previous results allow us to transform unimodular matrices into diagonal matrices. Thus, it remains to consider unimodular diagonal matrices.

Lemma 7.3. There exists a polynomial-time algorithm that given $V = \operatorname {diag}(v_1,\dotsc ,v_n) \in \mathrm {Mat}_{n}(\mathcal {O}/\mathfrak {q})$ with $\prod _{1 \leq i \leq n} v_i = 1$ returns elementary matrices $E_{1}, \dotsc , E_{k} \in \mathrm {Mat}_{n}(\mathcal {O}/\mathfrak {q})$ such that $E_1 \dotsm E_k V$ is the $n \times n$ identity matrix.

Proof. From [Reference RosenbergRos94, 2.1.3 Corollary] it follows that a diagonal matrix with diagonal $(1,\dotsc ,1,v,v^{-1},1,\dotsc ,1)$ with $v \in (\mathcal {O}/\mathfrak {q})^\times $ is the product of six elementary matrices since

$$\begin{align*}\begin{pmatrix} v & 0 \\ 0 & v^{-1} \end{pmatrix} = \begin{pmatrix} 1 & v \\ 0 & 1 \end{pmatrix} \begin{pmatrix} 1 & 0 \\ -v^{-1} & 1 \end{pmatrix} \begin{pmatrix} 1 & v \\ 0 & 1 \end{pmatrix} \begin{pmatrix} 1 & -1 \\ 0 & 1 \end{pmatrix} \begin{pmatrix} 1 & 0 \\ 1 & 1 \end{pmatrix} \begin{pmatrix} 1 & -1 \\ 0 & 1 \end{pmatrix}. \end{align*}$$

Hence, we can left-multiply V with $6(n - 1)$ elementary matrices to obtain $(1,1,\dotsc ,1)^t$ .

Proposition 7.4. There exists a polynomial-time algorithm that given a matrix $V \in \mathrm {SL}_n(\mathcal {O}/\mathfrak {q})$ returns elementary matrices $E_1,\dotsc ,E_k, F_1,\dotsc ,F_l \in \mathrm {Mat}_n(\mathcal {O}/\mathfrak {q})$ such that $E_1\dotsm E_k V F_1\dotsc F_l$ is the $n \times n$ identity matrix.

Proof. Using Lemma 7.2 there exist elementary matrices $E_1, \dotsc ,E_{k'}$ such that $U := E_1\dotsm E_{k'} V$ is an upper triangular matrix. Using Lemma 7.2 again, this time applied to the lower diagonal matrix $U^t$ , we can find elementary matrices $F_1,\dotsc ,F_l$ such that $D = UF_1\dotsm F_l$ is a diagonal matrix. Finally, invoking Lemma 7.3 yields elementary matrices $\tilde E_1,\dotsc ,\tilde E_{\tilde k}$ such that $\tilde E_1\dotsm \tilde E_{\tilde k} D$ is the $n \times n$ identity matrix.

Corollary 7.5. There exists a polynomial-time algorithm that given the factorisation of $\mathfrak {g}$ and a matrix $V \in \mathrm {SL}_{n}(\mathcal {O}/\mathfrak {g})$ returns elementary matrices $E_1,\dotsc ,E_k \in \mathrm {Mat}_{n}(\mathcal {O}/\mathfrak {g})$ such that $V = E_1\dotsm E_k$ .

Proof. In the case that $\mathfrak {g}$ is a prime ideal power, this follows from Proposition 7.4. Now, let $\mathfrak {g} = \mathfrak {q}_{1}\dotsm \mathfrak {q}_{m}$ be the product of m coprime prime ideal powers, and consider a matrix $V \in \mathrm {SL}_n(\mathcal {O}/\mathfrak {g})$ . For each $1 \leq i \leq m$ we can determine in polynomial time a factorisation of $V \in \mathrm {SL}_n(\mathcal {O}/\mathfrak {q}_i)$ into elementary matrices. The result follows by observing that the canonical map

$$\begin{align*}\mathrm{E}_n(\mathcal{O}/\mathfrak{g}) \to \prod_{i=1}^m \mathrm{E}_n(\mathcal{O}/\mathfrak{q}_i) \end{align*}$$

is an isomorphism by the Chinese remainder theorem which can be made effective in polynomial time ([Reference CohenCoh00, Proposition 1.3.11]).

Since we can trivially lift elementary matrices along the canonical map $f_{1}: \mathrm {SL}_{n}(\mathcal {O}) \to \mathrm {SL}_{n}(\mathcal {O}/\mathfrak {\mathfrak {g}})$ , the same is true for arbitrary matrices in $\mathrm {SL}_{n}(\mathcal {O}/\mathfrak {g})$ .

Corollary 7.6. There exists a polynomial-time algorithm that given the factorisation of $\mathfrak {g}$ and a matrix $V \in \mathrm {SL}_n(\mathcal {O}/\mathfrak {g})$ returns $U \in \mathrm {SL}_n(\mathcal {O})$ such that $f_{1}(U) = V$ .

7.2 Lifting norm one units for nice maximal orders

We now consider the case in which $A = \mathrm {Mat}_{n}(K)$ and $\mathcal {M} = \mathcal {M}_{\mathfrak a,n}$ is a nice maximal order as defined in §6.2, where $\mathfrak {a}$ is a nonzero fractional ideal of $\mathcal {O}$ and $n \in \mathbb {Z}_{\geq 2}$ . (As in §7.1, the case $n=1$ is trivial.) Some of the ideas used here are based on [Reference Bley and JohnstonBJ08, §6].

Let $\mathfrak {b}$ be an integral ideal of $\mathcal {O}$ such that $\mathfrak {b} + \mathfrak {g} = \mathcal {O}$ and $\mathfrak {a} = \xi \mathfrak {b}$ for some $\xi \in K^{\times }$ . Such an ideal $\mathfrak {b}$ and element $\xi $ can be computed in probabilistic polynomial time, as shown in Corollary A.2. Let $b \in \mathfrak b, y \in \mathfrak {g}$ such that $b + y = 1$ , and let $R=\mathcal {O}/\mathfrak {g}$ . Then we have an isomorphism $\mathcal {O}/\mathfrak {g} \rightarrow \mathfrak {a}/\mathfrak {a}\mathfrak {g}$ of R-modules defined by $z + \mathfrak {g} \mapsto zb\xi + \mathfrak {a}\mathfrak {g}$ , with the inverse map given by $x + \mathfrak {a}\mathfrak {g} \mapsto \xi ^{-1}x + \mathfrak {g}$ . The first of these maps induces an isomorphism $\theta _{1} : R^{\oplus n} \rightarrow R^{\oplus n-1} \oplus \mathfrak {a}/\mathfrak {a}\mathfrak {g}$ of R-modules, and the second map induces an inverse $\theta _{2}$ . Define $n \times n$ diagonal matrices $\Phi _{1} = \operatorname {diag}(1, \ldots , 1, \xi ^{-1})$ and $\Phi _{2} = \operatorname {diag}(1, \ldots , 1, b\xi )$ . Then we have maps

$$\begin{align*}\psi_1 \colon \mathrm{Mat}_n(\mathcal{O}) \longrightarrow \mathcal{M}, \, X \mapsto \Phi_2 X \Phi_1 \quad \text{ and } \quad \psi_2 \colon \mathcal{M} \longrightarrow \mathrm{Mat}_n(\mathcal{O}), \, Y \mapsto \Phi_1 Y \Phi_2. \end{align*}$$

These maps are not multiplicative in general. However, since $\theta _{1}$ and $\theta _{2}$ are mutually inverse isomorphisms, we see that $\psi _{1}$ and $\psi _{2}$ induce mutually inverse isomorphisms

$$\begin{align*}\overline{\psi}_1 \colon \mathrm{GL}_n(\mathcal{O}/\mathfrak{g}) \to (\mathcal{M}/\mathfrak{g}\mathcal{M})^\times \quad \text{ and } \quad \overline{\psi}_2 \colon (\mathcal{M}/\mathfrak{g}\mathcal{M})^\times \to \mathrm{GL}_n(\mathcal{O}/\mathfrak{g}). \end{align*}$$

Lemma 7.7. Let $\overline {E} \in \mathrm {SL}_n(\mathcal {O}/\mathfrak {g})$ be an elementary matrix. Then $\overline {\psi }_{1}(\overline {E})$ can be lifted to an element $U \in \mathcal {M}^\times $ with $\mathrm {nr}(U) = 1$ .

Proof. For $V \in \mathrm {Mat}_n(\mathcal {O})$ we write

$$\begin{align*}\def\arraystretch{1.2} V = \left( \begin{array}{c|c}V_1 & x \\ \hline y & d \end{array} \right) \end{align*}$$

with $V_1 \in \mathrm {Mat}_{n-1}(\mathcal {O}), x,y^t \in \mathcal {O}^{n-1}$ and $d \in \mathcal {O}$ . Then

$$\begin{align*}\def\arraystretch{1.2} \psi_{1}(V) = \left( \begin{array}{c|c}V_1 & \xi^{-1}x \\ \hline \xi b y & bd \end{array} \right). \end{align*}$$

Let $I_m \in \mathrm {Mat}_m(\mathcal {O})$ denote the identity matrix.

Case 1: If $\def \arraystretch {1.2} \overline {E} = \left ( \begin {array}{c|c} e_{ij}(\bar a) & 0 \\ \hline 0 & 1 \end {array} \right ) $ with $a \in \mathcal {O}$ , then $\def \arraystretch {1.2} \overline {\psi }_1(\overline {E}) = \left ( \begin {array}{c|c} e_{ij}(\bar a) & 0 \\ \hline 0 & \bar b \end {array} \right ) $ and a lift is given by

$$\begin{align*}\left( \begin{array}{c|c} e_{ij}(a) & 0 \\ \hline 0 & 1 \end{array} \right). \end{align*}$$

Case 2: If $\def \arraystretch {1.2} \overline {E} = \left ( \begin {array}{c|c} \overline {I}_{n-1} & \bar x \\ \hline 0 & 1 \end {array} \right ) $ with $\bar x^t = (0,\ldots ,0,\bar a, 0, \ldots , 0), a \in \mathcal {O}$ , then $\def \arraystretch {1.2} \overline {\psi }_{1}(\overline {E}) = \left ( \begin {array}{c|c} \overline {I}_{n-1} & \overline {\xi ^{-1} x}\\ \hline 0 & \bar b \end {array} \right ) $ and a lift is given by

$$\begin{align*}\left( \begin{array}{c|c} I_{n-1} & {\xi^{-1} x}\\ \hline 0 & 1 \end{array} \right). \end{align*}$$

Note that in this case $\xi ^{-1}a \in \mathfrak {b}\mathfrak {a}^{-1} \subseteq \mathfrak {a}^{-1}$ .

Case 3: If $\overline {E} = \left ( \begin {array}{c|c} \overline {I}_{n-1} & 0 \\ \hline \bar y & 1 \end {array} \right )$ with $\bar y = (0,\ldots ,0,\bar a, 0, \ldots , 0), a \in \mathcal {O}$ , then $\def \arraystretch {1.2} \psi _{1}(\overline {E}) = \left ( \begin {array}{c|c} \overline {I}_{n-1} & 0 \\ \hline \overline {\xi by} & \bar b \end {array} \right )$ and a lift is given by

$$\begin{align*}\left( \begin{array}{c|c} I_{n-1} & 0 \\ \hline \xi by & 1 \end{array} \right). \end{align*}$$

Here we note that $\xi ba \in \xi \mathfrak {b} = \mathfrak {a}$ .

Proposition 7.8. For $A = \mathrm {Mat}_{n}(K)$ let $\mathcal {M} = \mathcal {M}_{\mathfrak a,n} \subseteq A$ be a nice maximal order. Then there exists a probabilistic polynomial-time algorithm that given the factorisation of $\mathfrak {g}$ and $V \in \mathrm {SL}(\mathcal {M}/\mathfrak {g}\mathcal {M})$ returns $U \in \mathrm {SL}(\mathcal {M})$ with $f_{1}(U) = V$ .

Proof. By Corollary 7.5 we can find elementary matrices $E_1,\dotsc ,E_r \in \mathrm {Mat}_n(\mathcal {O}/\mathfrak {g})$ with $\overline {\psi }_2(V) = E_1\dotsm E_r$ . Applying $\overline {\psi }_{1}$ we obtain $V = \overline {\psi }_1(E_1)\dotsm \overline {\psi }_1(E_r)$ . Moreover, by Lemma 7.7, each of the matrices $\overline {\psi }_1(E_i)$ can be lifted to a matrix $U_i \in \mathcal {M}^\times $ with $\mathrm {nr}(U_{i}) = 1$ . Thus, we can and do take $U := \prod _{i}U_{i}$ .

7.3 Lifting norm one units in maximal orders

We now consider an arbitrary maximal order $\mathcal {M}$ of $A = \prod _{i=1}^{r}\mathrm {Mat}_{n_{i}}(K_{i})$ .

Theorem 7.9. The map $f_{1} \colon \mathrm {SL}(\mathcal {M}) \to \mathrm {SL}(\mathcal {M}/\mathfrak {g} \mathcal {M})$ is surjective. Moreover, there exists a probabilistic polynomial-time algorithm that given the factorisation of $\mathfrak {g}$ and $V \in \mathrm {SL}(\mathcal {M}/\mathfrak {g} \mathcal {M})$ returns an element $U \in \mathrm {SL}(\mathcal {M})$ with $f_{1}(U) = V$ .

Proof. By decomposing $\mathcal {M}$ using the central primitive idempotents, it is sufficient to consider the case $A = \mathrm {Mat}_{n}(K)$ . By Lemma 6.2, we can and do assume that $\mathcal {M} = \mathcal {M}_{\mathfrak a, n}$ is a nice maximal order. Thus, the result follows from Proposition 7.8.

8 Isomorphism testing and the principal ideal problem

Let K be a number field with ring of integers $\mathcal {O} = {\mathcal {O}_K}$ , and let A be a finite-dimensional K-algebra satisfying hypothesis (H). Let $\Lambda $ be an $\mathcal {O}$ -order in A. In this section, we present the main algorithm for solving the isomorphism problem $\mathsf {IsIsomorphic}$ for lattices over $\Lambda $ .

We begin with two straightforward reductions which together show that it suffices to consider the problem $\mathsf {IsPrincipal}$ in the case that A is semisimple. Note that these reductions are valid when A is an arbitrary finite-dimensional K-algebra that does not necessarily satisfy hypothesis (H).

Proposition 8.1. The problem $\mathsf {IsIsomorphic}$ is polynomial-time reducible to $\mathsf {IsPrincipal}$ . More precisely, for $\Lambda $ -lattices X and Y, the problem $\mathsf {IsIsomorphic}$ is polynomial-time reducible to $\mathsf {IsPrincipal}$ for an $\mathrm {End}_\Lambda (Y)$ -lattice in $\mathrm {End}_A(KY)$ .

Proof. Let X and Y be two $\Lambda $ -lattices. By [Reference Chistov, Ivanyos and KarpinskiCIK97, Corollary 3] we can check in polynomial time whether the A-modules $KX$ and $KY$ are isomorphic and, if so, compute an isomorphism $f \colon KY \to KX$ . Then $\Phi \colon \mathrm {Hom}_A(KX, KY) \to \mathrm {End}_A(KY), \, g \mapsto g \circ f$ is an isomorphism of $\mathrm {End}_A(KY)$ -modules. Recall from §3.1 that we consider $\mathrm {Hom}_\Lambda (X, Y)$ as a subset of $\mathrm {Hom}_A(KX, KY)$ . Thus, by Proposition 3.1, the $\Lambda $ -lattices X and Y are isomorphic if and only if the full $\mathrm {End}_\Lambda (Y)$ -lattice $\Phi (\mathrm {Hom}_\Lambda (X, Y))$ in $\mathrm {End}_A(KY)$ is free of rank $1$ and for every (any) free generator $\alpha $ the morphism $\alpha \circ f^{-1} \colon X \to Y$ is an isomorphism.

Let $\operatorname {\mathrm {J}}(A)$ denote the Jacobson radical of A, and recall that $\overline {A} := A/{\operatorname {\mathrm {J}}(A)}$ is a semisimple K-algebra by [Reference Curtis and ReinerCR81, (5.19)]. For any full $\Lambda $ -lattice X in A, let $\overline {X}$ denote its image under the canonical projection map $A \rightarrow \overline {A}$ . Note that $\overline {\Lambda }$ is an $\mathcal {O}$ -order in $\overline {A}$ .

Proposition 8.2. The problem $\mathsf {IsPrincipal}$ for an arbitrary finite-dimensional K-algebra is polynomial-time reducible to $\mathsf {IsPrincipal}$ for a finite-dimensional semisimple K-algebra. More precisely, for a full $\Lambda $ -lattice X in A, the problem $\mathsf {IsPrincipal}$ is polynomial-time reducible to the problem $\mathsf {IsPrincipal}$ for the full $\overline {\Lambda }$ -lattice $\overline {X}$ in $\overline {A}$ .

Proof. The Jacobson radical of A can be computed in polynomial time by [Reference Friedl and RonyaiFR85, 1.5 A]. The result then follows from Theorem 3.4.

The main algorithm of the present article is as follows.

Algorithm 8.3. Suppose that A is semisimple and satisfies hypothesis (H). Let X be a full $\Lambda $ -lattice in A. The following steps solve $\textsf {IsPrincipal}(X)$ , that is, they determine whether there exists $\alpha \in X$ such that $X=\Lambda \alpha $ and, if so, return such an element $\alpha $ .

  1. (1) Determine the centre C of A, the decomposition $A = \prod _{i} A_i$ into simple K-algebras $A_i$ and, for each i, an isomorphism $A_i \cong \mathrm {Mat}_{n_i}(K_i)$ .

  2. (2) Compute a maximal $\mathcal {O}$ -order $\mathcal {M}$ in A containing $\Lambda $ and its centre $\mathcal {O}_{C} := \mathcal {M} \cap C$ .

  3. (3) Compute the central primitive idempotents $e_{i}$ and the components $\mathcal {M}_{i}:=\mathcal {M} e_{i}$ .

  4. (4) Compute the central conductor $\mathfrak {g} := \{ x \in C \mid x\mathcal {M} \subseteq \Lambda \}$ of $\Lambda $ in $\mathcal {M}$ and $\mathfrak {f} := \mathfrak {g}\mathcal {M}$ .

  5. (5) Check whether $\mathcal {M}X$ is free over $\mathcal {M}$ , and if so, compute $\beta $ such that $\mathcal {M} X = \mathcal {M} \beta $ .

  6. (6) Check whether X is locally free over $\Lambda $ .

  7. (7) Replace X by $X \xi $ , where $\xi \in A^\times $ is such that $X\xi \subseteq \Lambda $ and $X\xi + \mathfrak {f} = \Lambda $ .

  8. (8) Compute a set of generators for $\left ( \Lambda / \mathfrak {f}\right )^\times $ .

  9. (9) Let $\overline {\mathrm {nr}} \colon \left ( \mathcal {M} / \mathfrak {f}\right )^\times \longrightarrow \left ( \mathcal {O}_C/\mathfrak {g} \right )^{\times }$ be the map of Lemma 4.4. Compute $\left ( \mathcal {O}_C/\mathfrak {g} \right )^\times $ as an abstract abelian group and compute $\overline {\mathrm {nr}}\left ( (\Lambda / \mathfrak {f})^\times \right )$ as a subgroup of $\left ( \mathcal {O}_C/\mathfrak {g} \right )^\times $ .

  10. (10) Let $\pi _{2}$ and $f_2$ be the maps defined in the commutative diagram (4). Decide whether $\overline {\mathrm {nr}}(\overline \beta )$ is in the image of $\pi _2\circ f_2$ , and if so, compute $\bar a \in \left ( \Lambda / \mathfrak {f}\right )^\times $ and $u \in \mathcal {M}^\times $ such that $\overline {\mathrm {nr}}(\overline {\beta a}) = \overline {\mathrm {nr}}(\bar u)$ .

  11. (11) Compute $v \in \mathrm {SL}(\mathcal {M})$ such that $\overline {\beta a u^{-1}} = \overline v$ .

If any of steps (5), (6) or (10) fail, then X is not free over $\Lambda $ . If all these steps succeed, then $X = \Lambda \alpha $ where $\alpha := (vu)^{-1}\beta $ .

Proof of correctness of Algorithm 8.3

Failure of steps (5) or (6) immediately implies that X is not free over $\Lambda $ . Otherwise, we use the local bases computed in step (6) to replace X by $X\xi $ in step (7), as described in Proposition 6.8 and its proof. After successful completion of steps (1) to (7), we then can and do assume that X is a locally free full $\Lambda $ -lattice in A such that $X+\mathfrak {f} = \Lambda $ and $\mathcal {M} X = \mathcal {M}\beta $ . These are the assumptions needed for Theorem 4.5. Moreover, since A is semisimple and satisfies hypothesis (H), the map $f_1$ in diagram (4) is surjective by Theorem 7.9, and so Theorem 4.5 (b) can be applied. Hence, X is free over $\Lambda $ if and only if $\overline {\mathrm {nr}}(\overline \beta )$ is contained in the image of $\pi _2\circ f_2$ . This is precisely what is checked in step (10). In addition, the second part of Theorem 4.5 (b) implies that $X = \Lambda \alpha $ with $\alpha $ as at the end of Algorithm 8.3.

The following result analyses the complexity of Algorithm 8.3, and further details on each step are given in the proof.

Theorem 8.4. Let $\Lambda $ be an $\mathcal {O}$ -order in a finite-dimensional semisimple K-algebra A satisfying hypothesis (H), and let $K_{1}, \ldots , K_{r}$ be the simple components of the centre of A. Let $\mathcal {M}$ be any choice of maximal $\mathcal {O}$ -order in A containing $\Lambda $ , and let $\mathfrak {h} = [\mathcal {M} : \Lambda ]_{\mathcal {O}}$ be the module index of $\Lambda $ in $\mathcal {M}$ . Then for a full $\Lambda $ -lattice X in A, Algorithm 8.3 reduces the problem $\mathsf {IsPrincipal}(X)$ in probabilistic polynomial time to

  1. (a) $\mathsf {Wedderburn}(A)$ , the computation of the Wedderburn decomposition of A,

  2. (b) $\mathsf {Factor}(\mathrm {Disc}(\Lambda ))$ , the factorisation of the discriminant of $\Lambda $ ,

  3. (c) for each i with $1 \leq i \leq r$ , one instance of $\mathsf {IsPrincipal}_{\mathcal O_{K_i}}$ ,

  4. (d) for each i with $1 \leq i \leq r$ , $\mathsf {UnitGroup}(\mathcal O_{K_i})$ ,

  5. (e) for each prime ideal divisor $\mathfrak {p}$ of $\mathfrak {h}$ , the problem $\mathsf {DLog}$ for extensions of $\mathcal {O}/\mathfrak {p}$ and

  6. (f) for each prime ideal divisor $\mathfrak {p}$ of $\mathfrak {h}$ , the problem $\mathsf {Primitive}$ for extensions of $\mathcal {O}/\mathfrak {p}$ .

Note that $\mathcal {M}$ and $\mathfrak {h}$ are not part of the input and $\mathfrak {h}$ is only needed for the above complexity statement. Moreover, $\mathfrak {h}$ does not depend on the choice of $\mathcal {M}$ .

Proof. In the following, the steps refer to those of Algorithm 8.3. Let $\mathcal {M}$ be the maximal order computed in step (2), and let $\mathfrak {f}$ be the ideal computed in step (4). Before analysing the steps, we make the following observations. By [Reference ReinerRei03, (25.3)], $\mathrm {Disc}(\mathcal {M})$ is independent of the choice of $\mathcal {M}$ . Moreover, by [Reference Curtis and ReinerCR81, (26.3)(iii)], we have $\mathrm {Disc}(\Lambda ) = \mathfrak {h}^{2} \mathrm {Disc}(\mathcal {M})$ , and so $\mathrm {Disc}(\Lambda )$ and $\mathfrak {h}$ are also independent of the choice of $\mathcal {M}$ . Since $\mathfrak {h}\mathcal {M} \subseteq \Lambda $ , we have $\mathfrak {h} \subseteq \mathfrak {g}$ for any choice of $\mathcal {M}$ . Therefore, $\mathrm {Disc}(\Lambda ) \subseteq \mathfrak {h}\subseteq \mathfrak {g}$ and $\mathfrak {h}\Lambda \subseteq \mathfrak {f}$ . In particular, $\mathsf {Factor}(\mathcal {O} \cap \mathfrak {f})$ and $\mathsf {Factor}(\mathfrak {g})$ reduce in polynomial time to $\mathsf {Factor}(\mathrm {Disc}(\Lambda ))$ .

Step (1) is an instance of $\mathsf {Wedderburn}$ . In step (2), the problem of computing a maximal $\mathcal {O}$ -order $\mathcal {M}$ in A containing $\Lambda $ reduces in probabilistic polynomial time to $\mathsf {Factor}(\mathrm {Disc}(\Lambda ))$ by Proposition 6.1. It is then trivial to determine $\mathcal {O}_C = \mathcal {M} \cap C$ . Step (3) can be easily performed using the isomorphisms $A_i \cong \mathrm {Mat}_{n_i}(K_i)$ from step (1). In step (4), the central conductor $\mathfrak {g}$ can be computed as the intersection $(\mathcal {M} : \Lambda )_l \cap C$ , where $(\mathcal {M} : \Lambda )_l := \{ x \in \mathcal {M} \mid x\mathcal {M} \subseteq \Lambda \}$ is the left conductor of $\Lambda $ into $\mathcal {M}$ . As the left conductor can be determined using a pseudo-Hermite normal form computation (see [Reference FriedrichsFri00, (2.16)]), this step can also be performed in polynomial time. Step (5) is probabilistic polynomial-time reducible to one instance of $\mathsf {IsPrincipal}_{\mathcal O_{K_i}}$ for each $1 \leq i \leq r$ , by Proposition 6.4. Steps (6) and (7) are probabilistic polynomial-time reducible to $\mathsf {Factor}(\mathcal {O} \cap \mathfrak {f})$ by Proposition 6.8.

Step (8): Proposition 6.11 shows that this is probabilistic polynomial-time reducible to $\mathsf {Factor}(\mathfrak {g})$ and for each prime ideal divisor $\mathfrak {P}$ of $\mathfrak {g}$ at most d instances of $\mathsf {Primitive}$ in extensions of $\mathcal {O}/(\mathcal {O}\cap \mathfrak {P})$ of degree at most d. Now, for each prime ideal $\mathfrak {p}$ dividing $\mathfrak {g} \cap \mathcal {O}$ , there are at most d prime ideals $\mathfrak {P}$ of $\mathcal {O}_C$ satisfying $\mathfrak {P} \cap \mathcal {O} = \mathfrak {p}$ . Finally, note that $\mathfrak {g} \cap \mathcal {O}$ divides $\mathfrak {h}$ .

Step (9): It follows from [Reference CohenCoh00, Algorithms 4.2.2 and 4.2.17] that the computation of generators and the structure of $\left ( \mathcal {O}_C/\mathfrak {g} \right )^\times $ as an abelian group is polynomial-time reducible to $\mathsf {Factor}(\mathfrak {g})$ and for each prime ideal divisor $\mathfrak {P}$ of $\mathfrak {g}$ one instance of $\mathsf {Primitive}$ in an extension $\mathcal {O}/(\mathcal {O}\cap \mathfrak {P})$ of degree at most d. Estimating the number of prime ideal divisors as in the previous paragraph shows that this part contributes d instances of $\mathsf {Primitive}$ in (e). Let $V = \{\bar a_1, \ldots , \bar a_m\}$ be a set of generators of $\left ( \Lambda / \mathfrak {f} \right )^\times $ . Let e denote the exponent of $\left ( \mathcal {O}_C / \mathfrak {g} \right )^\times $ , and let $\mathcal {G} := \prod _{i=1}^m \mathbb {Z} / e\mathbb {Z} \cdot \bar a_i$ be the $\mathbb {Z}/e\mathbb {Z}$ -free abelian group on V. Let $\overline \nu \colon \mathcal {G} \rightarrow \left ( \mathcal {O}_C / \mathfrak {g} \right )^\times $ be the homomorphism induced by $\bar a_i \mapsto \overline {\mathrm {nr}}(\bar a_i)$ . Then $\mathrm {im}(\bar \nu ) = \overline {\mathrm {nr}}\left ( (\Lambda / \mathfrak {f})^\times \right )$ and we apply algorithms for finite abelian groups (see [Reference CohenCoh00, §4.1]) to compute the image. For this we have to solve the discrete logarithm in $(\mathcal {O}_C/\mathfrak {g})^\times $ for each of the m generators $\bar a_1, \ldots , \bar a_m$ . By Proposition 6.11, the number m is bounded by $5d[K:\mathbb {Q}]\log _2|\mathcal {O}_C/\mathfrak {g}|$ . Thus, the claim in part (f) follows from

$$ \begin{align*} |\mathcal{O}_C/\mathfrak{g}| & \leq |\mathcal{O}_C/\mathfrak{h}\mathcal{O}_C| = \prod_{i=1}^{r} |\mathcal{O}_{K_i}/\mathfrak{h}\mathcal{O}_{K_i}| = \prod_{i=1}^{r} \mathrm{N}_{K_i/\mathbb{Q}}(\mathfrak{h}\mathcal{O}_{K_i}) = \prod_{i=1}^{r} \mathrm{N}_{K/\mathbb{Q}}(\mathfrak{h})^{[K_i:K]} \\ &= \mathrm{N}_{K/\mathbb{Q}}(\mathfrak{h})^{[C:K]} \leq \mathrm{N}_{K/\mathbb{Q}}(\mathfrak{h})^d. \end{align*} $$

Note that solving the discrete logarithm in $(\mathcal {O}_C/\mathfrak {g})^\times $ requires solving the discrete logarithm problem in $(\mathcal {O}_C/\mathfrak {P})^\times $ for all prime ideals $\mathfrak {P}$ dividing $\mathfrak {g}$ . As in step (8), for each prime ideal $\mathfrak {p}$ dividing $\mathfrak {g}\cap \mathcal {O}$ there are at most d prime ideals $\mathfrak {P}$ of $\mathcal {O}_C$ with $\mathfrak {P} \cap \mathcal {O} = \mathfrak {p}$ and for each of those prime ideals $\mathcal {O}_C/\mathfrak {P}$ is an extension of $\mathcal {O}/\mathfrak {p}$ of degree at most d.

Step (10): The reduced norm map $\mathrm {nr} \colon \mathcal {M}^\times \rightarrow \mathcal {O}_C^\times $ is surjective by Lemma 6.3. The computation of $\mathcal {O}_C^\times $ is performed componentwise and thus reduces to $\mathsf {UnitGroup}(\mathcal O_{K_i})$ for $1 \leq i \leq r$ . We then determine the image of the canonical projection $\mathcal {O}_C^\times \rightarrow \left ( \mathcal {O}_C/\mathfrak {g} \right )^\times / \mathrm {im}(\bar \nu )$ as an abstract subgroup of $ \left ( \mathcal {O}_C/\mathfrak {g} \right )^\times / \mathrm {im}(\bar \nu )$ . This again requires an instance of solving the discrete logarithm in $\left ( \mathcal {O}_C/\mathfrak {g} \right )^\times $ for each of the generators of $\mathcal {O}_C^\times $ . By Dirichlet’s unit theorem the number of these generators can be bounded by d. Applying standard algorithms for finite abelian groups it is then straightforward to decide whether $\overline {\mathrm {nr}}(\bar \beta )$ is contained in the image of $\mathcal {O}_C^\times \rightarrow {\left ( \mathcal {O}_C/\mathfrak {g} \right )^\times } /{\mathrm {im}(\bar \nu )}$ and, if so, to compute $\epsilon \in \mathcal {O}_C^\times $ , $a \in \left (\Lambda / \mathfrak {f}\right )^\times $ such that $\bar \epsilon \equiv \overline {\beta a} \pmod {\mathfrak {g}}$ . An element $u \in \mathcal {M}^\times $ such that $\mathrm {nr}(u) = \epsilon $ can be found using Lemma 6.3 in probabilistic polynomial time. Note that this step requires one more instance of solving the discrete logarithm in $(\mathcal {O}_C/\mathfrak {g})^{\times }$ , which was already analysed in step (9).

Step (11): As the factorisation of $\mathfrak {g}$ is known, this can be done in probabilistic polynomial time by Theorem 7.9.

We now consider the case in which we allow certain precomputations that only depend on the order $\Lambda $ and not on the $\Lambda $ -lattice X.

Corollary 8.5. Fix an $\mathcal {O}$ -order $\Lambda $ in a finite-dimensional semisimple K-algebra A satisfying hypothesis (H), and let $K_{1}, \ldots , K_{r}$ be the simple components of the centre of A. Then for a full $\Lambda $ -lattice X in A, the problem $\mathsf {IsPrincipal}(X)$ reduces in probabilistic polynomial to $\mathsf {IsPrincipal}$ for $\mathcal {O}_{K_i}$ , $1 \leq i \leq r$ , and $\mathsf {DLog}$ .

Proof. In Algorithm 8.3 we may consider all steps which do not depend on X as precomputations. Then for each lattice X only steps (5), (6), (7), (10) and (11) have to be performed. The claim follows as in the proof of Theorem 8.4.

Remark 8.6. In Theorem 8.4 better results can be obtained by describing the complexity in terms of the central conductor $\mathfrak {g}$ (which depends not only on the order $\Lambda $ but also on the maximal order computed during the algorithm) instead of $\mathfrak {h}$ . More precisely, (e) and (f) can be replaced by

  • (e $'$ ) for each prime ideal divisor $\mathfrak {P}$ of $\mathfrak {g}$ , the problem $\mathsf {DLog}$ for extensions of $\mathcal {O}/ (\mathcal {O} \cap \mathfrak {P})$ ,

  • (f $'$ ) for each prime ideal divisor $\mathfrak {P}$ of $\mathfrak {g}$ , the problem $\mathsf {Primitive}$ for extensions of $\mathcal {O} / (\mathcal {O} \cap \mathfrak {P})$ .

Remark 8.7. By Remark 5.2, in Theorem 8.4, (a) can be replaced by

  • (a $'$ ) $\mathsf {SplittingMatrixAlgebra}(A_i)$ for $1 \leq i \leq r$ , where $A = \bigoplus _{i=1}^r A_i$ is the decomposition into simple K-algebras.

Note that we have formulated Theorem 8.4 using $\mathsf {Wedderburn}$ since for certain families of algebras, one can directly solve $\mathsf {Wedderburn}$ in polynomial time (which would not necessarily be true after passing to the simple components). This happens, for example, for certain algebras of the form $A/{\operatorname {\mathrm {J}}(A)}$ that appear in the similarity problem for matrices over rings of integers of number fields (see §9.3).

Remark 8.8. In view of Remarks 5.1 and 5.2, as well as the reductions of Propositions 8.1 and 8.2, the problems $\mathsf {IsPrincipal}_{\Lambda }$ and $\mathsf {IsIsomorphic}_{\Lambda }$ for orders $\Lambda $ in finite-dimensional K-algebras A satisfying hypothesis (H) reduces

  1. (a) in probabilistic subexponential time to $\mathsf {UnitGroup}$ and $\mathsf {IsPrincipal}$ for rings of integers of number fields, and $\mathsf {Wedderburn}$ or $\mathsf {SplittingMatrixAlgebra}$ ,

  2. (b) in quantum polynomial time to $\mathsf {Wedderburn}$ or $\mathsf {SplittingMatrixAlgebra}$ .

9 Application: similarity of matrices over rings of integers

After proving some general results on the similarity of matrices over commutative rings, we will give an application of Algorithm 8.3 to the similarity problem for matrices over rings of integers of number fields.

9.1 Similarity of matrices over commutative rings

Let R be a commutative ring, and let $n \in \mathbb {Z}_{>0}$ . Recall that two matrices $A,B \in \mathrm {Mat}_{n}(R)$ are said to be similar over R if there exists a conjugating matrix $C \in \mathrm {GL}_{n}(R)$ such that $B=CAC^{-1}$ .

We will adopt the setup of Faddeev [Reference FaddeevFad66]. For $A,B \in \mathrm {Mat}_{n}(R)$ we define

$$\begin{align*}C_R(A, B) = \{ X \in \mathrm{Mat}_n(R) \mid XA = BX \} \quad \text{ and } \quad C_{R}(B) = C_{R}(B,B). \end{align*}$$

Note that $C_{R}(B)$ is an R-algebra and that $C_{R}(A,B)$ is a (left) $C_{R}(B)$ -module.

Lemma 9.1. Suppose there exists $C \in \mathrm {GL}_{n}(R)$ such that $B=CAC^{-1}$ . Then the maps

$$ \begin{align*} \theta_{C} : C_R(B) \longrightarrow C_R(A,B), \quad & X \longmapsto XC,\\ \theta_{C^{-1}} : C_R(A, B) \longrightarrow C_R(B), \quad & X \longmapsto XC^{-1}, \end{align*} $$

are mutually inverse $C_{R}(B)$ -module isomorphisms.

Proof. If $X \in C_{R}(B)$ , then $B(XC)=XBC=X(CAC^{-1})C=(XC)A$ and so $XC \in C_{R}(A,B)$ . Hence, the map $\theta _{C}$ is well defined. Similarly, the map $\theta _{C}^{-1}$ is also well defined and it is clear that $\theta _{C}$ and $\theta _{C^{-1}}$ are mutually inverse.

Proposition 9.2. Two matrices $A,B \in \mathrm {Mat}_n(R)$ are similar over R if and only if

  1. (a) the $C_R(B)$ -module $C_R(A, B)$ is free of rank $1$ , and

  2. (b) every (any) free generator C of $C_R(A, B)$ over $C_{R}(B)$ is in $\mathrm {GL}_n(R)$ .

Furthermore, when this is the case, C as in part (b) satisfies $B=CAC^{-1}$ .

Proof. Suppose that (a) and (b) hold, and let C be a free generator of $C_{R}(A, B)$ over $C_{R}(B)$ . In particular, $C \in C_{R}(A,B) \cap \mathrm {GL}_{n}(R)$ , and it easily follows that $B=CAC^{-1}$ . Suppose conversely that there exists $C \in \mathrm {GL}_{n}(R)$ such that $B=CAC^{-1}$ . Then $\theta _{C}$ is an isomorphism by Lemma 9.1, and so C is a free generator of $C_{R}(A,B)$ over $C_{R}(B)$ . Thus, (a) holds. Now, let D be any free generator of $C_{R}(A,B)$ over $C_{R}(B)$ . Then there exists $E \in C_{R}(B)^{\times } \subseteq \mathrm {GL}_{n}(R)$ such that $D=EC$ and so $D \in \mathrm {GL}_{n}(R)$ . Thus, (b) holds.

The following result was proven by Faddeev [Reference FaddeevFad66, Theorem 2] in the case $R=\mathbb {Z}$ , though it was expressed in terms of ideals rather than modules. Moreover, Guralnick [Reference GuralnickGur80, Theorem 6] observed that the proof works for any integral domain. We include a short proof for the convenience of the reader and for comparison as per Remark 9.4.

Proposition 9.3. Suppose that R is an integral domain. Two matrices $A,B \in \mathrm {Mat}_n(R)$ are similar over R if and only if

  1. (a) the $C_R(B)$ -module $C_R(A, B)$ is free of rank $1$ , and

  2. (b) for every maximal ideal $\mathfrak {p}$ of R, the matrices A and B are similar over $R_{\mathfrak {p}}$ .

Furthermore, when this is the case, any free generator C of $C_R(A, B)$ over $C_{R}(B)$ satisfies $B=CAC^{-1}$ .

Proof. Suppose that $A,B \in \mathrm {Mat}_n(R)$ are similar over R. Then (b) clearly holds and (a) holds by Proposition 9.2. Suppose conversely that (a) and (b) hold. Let C be a free generator of $C_{R}(A,B)$ over $C_{R}(B)$ . Let $\mathfrak {p}$ be a maximal ideal of R. Then there exists $C_{\mathfrak {p}} \in \mathrm {GL}_{n}(R_{\mathfrak {p}})$ such that $B=C_{\mathfrak {p}}AC_{\mathfrak {p}}^{-1}$ and so $C_{\mathfrak {p}} \in C_{R_{\mathfrak {p}}}(A,B)$ . Since C is also a free generator of $C_{R_{\mathfrak {p}}}(A,B)$ over $C_{R_{\mathfrak {p}}}(B)$ , there exists $D_{\mathfrak {p}} \in C_{R_{\mathfrak {p}}}(B)$ such that $C_{\mathfrak {p}} = D_{\mathfrak {p}} C$ . Then $\det (D_{\mathfrak {p}})\det (C)=\det (C_{\mathfrak {p}}) \in R_{\mathfrak {p}}^{\times }$ and so $\det (C) \in R_{\mathfrak {p}}^{\times }$ . Moreover, by [Reference Curtis and ReinerCR81, (4.2)(iv)], we have $R = \cap _{\mathfrak {p}} R_{\mathfrak {p}}$ which implies that $R^{\times } = \cap _{\mathfrak {p}} R_{\mathfrak {p}}^{\times }$ , where in both cases the intersection ranges over all maximal ideals $\mathfrak {p}$ of R. Therefore, $\det (C) \in R^{\times }$ and so $C \in \mathrm {GL}_{n}(R)$ . In particular, $C \in C_{R}(A,B) \cap \mathrm {GL}_{n}(R)$ , and it easily follows that $B=CAC^{-1}$ .

Remark 9.4. Propositions 9.2 and 9.3 and their proofs are analogues of Propositions 3.1 and 3.3, respectively. Indeed, in the case that R is a Noetherian integral domain, the former can be deduced from the latter, though it is easier to give more direct proofs of more general results. Moreover, as well as having weaker hypotheses, Proposition 9.2 is better suited to algorithmic applications than Proposition 9.3.

9.2 The similarity problem in terms of modules over polynomial rings

Let R be a commutative ring, and let $n \in \mathbb {Z}_{>0}$ . Let $R[x]$ be a polynomial ring in one variable over R. For $A \in \mathrm {Mat}_{n}(R)$ , we define $T_{R}(A)$ to be the $R[x]$ -module $R^{n}$ with the action $x v = Av$ for $v \in R^{n}$ .

Lemma 9.5. Let $A,B,C \in \mathrm {Mat}_{n}(R)$ . Define $\psi _{A,B,C} : T_{R}(A) \rightarrow T_{R}(B)$ by $v \mapsto Cv$ . Then $C \in C_{R}(A,B)$ if and only if $\psi _{A,B,C}$ is an $R[x]$ -module homomorphism. In particular, we have canonical isomorphisms

  1. (a) $C_{R}(A,B) \cong \mathrm {Hom}_{R[x]}(T_{R}(A),T_{R}(B))$ of R-modules;

  2. (b) $C_{R}(A) \cong \mathrm {End}_{R[x]}(T_{R}(A))$ of R-algebras.

Proof. The function $\psi _{A,B,C}$ is an $R[x]$ -module homomorphism if and only if $C(Av) = B(Cv)$ for all $v \in R^{n}$ , which in turn is equivalent to $C \in C_{R}(A,B)$ . This gives the first claim; the remaining claims now follow easily.

The following result is well known and is an easy consequence of Lemma 9.5.

Lemma 9.6. Let $A,B,C \in \mathrm {Mat}_{n}(R)$ . Then the following are equivalent:

  1. (a) $C \in C_{R}(A,B) \cap \mathrm {GL}_{n}(R)$ ,

  2. (b) $C \in \mathrm {GL}_{n}(R)$ and $B=CAC^{-1}$ ,

  3. (c) $\psi _{A,B,C}$ is an $R[x]$ -module isomorphism.

In particular, A and B are similar over R if and only if $T_R(A) \cong T_R(B)$ as $R[x]$ -modules.

9.3 Jacobson radicals of certain endomorphism algebras

Let F be a field. We now explicitly compute the Jacobson radical $\operatorname {\mathrm {J}}(\mathrm {End}_{F[x]}(V))$ of $\mathrm {End}_{F[x]}(V)$ for a finitely generated $F[x]$ -module V. The motivating application is Proposition 9.11 below.

Lemma 9.7. Let $f \in F[x]$ be an irreducible polynomial, and let $j,k \in \mathbb {Z}_{>0}$ . Let

$$\begin{align*}\lambda \in \mathrm{Hom}_{F[x]}(F[x]/(f^{j}), F[x]/(f^{k})) \quad \text{ and } \quad \mu \in \mathrm{Hom}_{F[x]}(F[x]/(f^{k}), F[x]/(f^{j})). \end{align*}$$

  1. (a) If $j \leq k$ then $\mathrm {im}(\lambda ) \subseteq f^{k-j}\cdot \left ( F[x]/(f^k) \right )$ .

  2. (b) For any choice of $j,k$ we have $\mathrm {im}(\lambda \circ \mu ) \subseteq f^{|k-j|} \cdot \left ( F[x]/(f^k) \right )$ .

Proof. Suppose $j \leq k$ . We have $\lambda (x+(f^{j})) = y + (f^{k})$ for some $y \in F[x]$ . Then

$$\begin{align*}f^{j}y + (f^{k}) = f^{j}(y + (f^{k})) = f^{j}\lambda(x+f^{j}) = \lambda(f^{j}x+(f^{j})) = \lambda(0)=0, \end{align*}$$

so $f^{j}y \in (f^{k})$ and hence $y \in (f^{k-j})$ . Thus, (a) follows from the fact that the image of $\lambda $ is uniquely determined by the image of $x+(f^j)$ . Part (b) follows easily from (a).

Proposition 9.8. Let $f \in F[x]$ be an irreducible polynomial. Let $m \in \mathbb {Z}_{>0}$ , let $d_{1}, \ldots , d_{m} \in \mathbb {Z}_{\geq 0}$ and let $V = \bigoplus _{j = 1}^{m} (F[x]/(f^j))^{d_{j}}$ . Then we have a canonical isomorphism

(7) $$ \begin{align} \mathrm{End}_{F[x]}(V) \cong E := \bigoplus_{j=1}^{m} \bigoplus_{k=1}^{m} e_{jk} \mathrm{Hom}_{F[x]}((F[x]/(f^k))^{d_k}, (F[x]/(f^j))^{d_j}), \end{align} $$

where the right-hand side denotes the $m \times m$ ‘matrix ring’ with $(j,k)$ -th entries in $\mathrm {Hom}_{F[x]}((F[x]/(f^k))^{d_k}, (F[x]/(f^j))^{d_j})$ . For $1 \leq j,k \leq m$ , define $\gamma _{jk}=f$ if $j=k$ and $\gamma _{jk}=1$ otherwise. Then the isomorphism $\mathrm {End}_{F[x]}(V) \cong E$ induces isomorphisms

(8) $$ \begin{align} \operatorname{\mathrm{J}}(\mathrm{End}_{F[x]}(V)) \cong I := \bigoplus_{j=1}^{m} \bigoplus_{k=1}^{m} e_{jk} \gamma_{jk} \mathrm{Hom}_{F[x]}((F[x]/(f^k))^{d_k}, (F[x]/(f^j))^{d_j}), \text{ and } \end{align} $$
(9) $$ \begin{align} \mathrm{End}_{F[x]}(V)/{\operatorname{\mathrm{J}}(\mathrm{End}_{F[x]}(V))} \cong E/I \cong \prod_{j = 1}^{m} \mathrm{Mat}_{d_j}(F[x]/(f)). \end{align} $$

Proof. The decomposition (7) follows from standard properties of Homs and direct sums. It follows from Lemma 9.7 (b) that I is a two-sided ideal of E. Moreover, it is straightforward to check that $E/I$ is canonically isomorphic to the right-hand side of equation (9). Thus, $E/I$ is Artinian semisimple and so $\operatorname {\mathrm {J}}(E/I) =0$ by [Reference Curtis and ReinerCR81, (5.18)]. Hence, $\operatorname {\mathrm {J}}(E) \subseteq I$ by [Reference Curtis and ReinerCR81, (5.6)(ii)]. Lemma 9.7 (a) and the definition of $\gamma _{jk}$ implies that each element $\lambda = (\lambda _{jk}) \in I$ is an upper triangular matrix in the sense that for $j \ge k$ the image of $\lambda _{jk}$ is contained in $f \cdot F[x]/(f^{j})$ . Hence, for $\mu = (\mu _{jk}) \in I^{m}$ the image of each $\mu _{jk}$ is contained in $f \cdot F[x]/(f^{j})$ . It follows that $I^{m^2} = 0$ , and thus I is nilpotent. Thus, since E is Artinian, $I \subseteq \operatorname {\mathrm {J}}(E)$ by [Reference Curtis and ReinerCR81, (5.15)]. Therefore, $\operatorname {\mathrm {J}}(E)=I$ , as claimed.

Corollary 9.9. Let $r \in \mathbb {Z}_{>0}$ , and let $V = \bigoplus _{i=1}^{r} V_{i}$ , where $V_{i} = \bigoplus _{j = 1}^{m_{i}} (F[x]/(f_{i}^{j}))^{d_{i,j}}$ for some $m_{i} \in \mathbb {Z}_{>0}$ , $d_{i,j} \in \mathbb {Z}_{\geq 0}$ , and some distinct monic irreducible polynomials $f_{i} \in F[x]$ . Then there are canonical isomorphisms

$$\begin{align*}\mathrm{End}_{F[x]}(V) \cong \prod_{i=1}^{r} \mathrm{End}_{F[x]}(V_{i}) \cong \prod_{i=1}^{r} \bigoplus_{j=1}^{m_{i}} \bigoplus_{k=1}^{m_{i}} e_{jk} \mathrm{Hom}_{F[x]}((F[x]/(f_{i}^{k}))^{d_{i,k}}, (F[x]/(f_{i}^{j}))^{d_{i,j}}) \end{align*}$$

and

$$\begin{align*}\mathrm{End}_{F[x]}(V)/{\operatorname{\mathrm{J}}(\mathrm{End}_{F[x]}(V))} \cong \prod_{i=1}^{r} \prod_{j = 1}^{m_{i}} \mathrm{Mat}_{d_{i, j}}(F[x]/(f_{i})). \end{align*}$$

In particular, if F is a number field, then $\mathrm {End}_{F[x]}(V)$ satisfies hypothesis (H).

Proof. The desired result follows from Proposition 9.8 together with the observation that $\mathrm {Hom}_{F[x]}(V_i, V_j) = 0$ for $i \neq j$ .

Proposition 9.10. Let $n \in \mathbb {Z}_{>0}$ , and let $A \in \mathrm {Mat}_{n}(F)$ .

  1. (a) The minimal polynomial of A is squarefree if and only if $C_{F}(A)$ is semisimple.

  2. (b) The minimal polynomial of A is equal to the characteristic polynomial of A if and only if $C_{F}(A)/{\operatorname {\mathrm {J}}(C_{F}(A))}$ is isomorphic to a finite product of fields.

  3. (c) The characteristic polynomial of A is squarefree if and only if $C_{F}(A)$ is isomorphic to a finite product of fields.

  4. (d) If A is nilpotent, then $C_{F}(A)/{\operatorname {\mathrm {J}}(C_{F}(A))}$ is isomorphic to $\prod _{j = 1}^{m} \mathrm {Mat}_{d_{j}}(F)$ for some $m, d_{1}, \ldots , d_{m} \in \mathbb {Z}_{>0}$ .

Proof. Let $f \in F[x]$ denote the characteristic polynomial of A. It is a standard result in linear algebra that there is an isomorphism of $F[x]$ -modules

(10) $$ \begin{align} T_{F}(A) \cong F[x]/(g_{1}) \oplus \cdots \oplus F[x]/(g_{s}), \end{align} $$

where $g_{1}, \ldots , g_{s} \in F[x]$ are the invariant factors of A and $g_{1} \mid g_{2} \mid \cdots \mid g_{s}$ . Thus, $g_{s}$ is the minimal polynomial of A and $f=g_{1}\cdots g_{s}$ . Moreover, by Lemma 9.5 (b), there is a canonical isomorphism $C_{F}(A) \cong \mathrm {End}_{F[x]}(V)$ of F-algebras, where $V:=T_{F}(A)$ . Let $f_{1}, \ldots , f_{r} \in F[x]$ denote the distinct monic irreducible factors of f. Then there exists a decomposition $V= \bigoplus _{i=1}^{r} V_{i}$ and isomorphisms $V_{i} \cong \bigoplus _{j = 1}^{m_i} F[x]/(f_{i}^{j})^{d_{i,j}}$ for some $m_{i} \in \mathbb {Z}_{>0}$ and $d_{i,j} \in \mathbb {Z}_{\geq 0}$ . (a) Observe that $g_{s}$ is squarefree if and only if each $g_{k}$ is squarefree if and only if $m_{i}=1$ for $i=1,\ldots ,r$ . By Corollary 9.9, this in turn is equivalent to the triviality of $\operatorname {\mathrm {J}}(\mathrm {End}_{F[x]}(V))$ , which is equivalent to the semisimplicity of $\mathrm {End}_{F[x]}(V)$ by [Reference Curtis and ReinerCR81, (5.18)]. (b) Observe that $g_{s}=f$ if and only if $s=1$ if and only if $d_{i,1}=1$ for $i=1,\ldots ,r$ . By Corollary 9.9, this in turn holds if and only if $\mathrm {End}_{F[x]}(V)/{\operatorname {\mathrm {J}}(\mathrm {End}_{F[x]}(V))}$ is isomorphic to a finite product of fields. (c) This follows from the previous two parts, once one obverses that if f is squarefree then it must be equal to $g_{s}$ . (d) If A is nilpotent, then f is some power of x, and so $r=1$ and $f_{1}=x$ . Thus the claim follows from Proposition 9.8 and the canonical isomorphism $F[x]/(x) \cong F$ .

Proposition 9.11. Let K be a number field, let $n \in \mathbb {Z}_{>0}$ , and let $A \in \mathrm {Mat}_{n}(K)$ . Let f be the characteristic polynomial of A, and let $f=f_{1}^{n_{1}} \cdots f_{r}^{n_{r}}$ be its factorisation, where $f_{1}, \ldots , f_{r} \in K[x]$ are distinct monic irreducible polynomials and $n_{i} \in \mathbb {Z}_{>0}$ for each i. Let $K_{i}=K[x]/(f_{i})$ for $i=1,\ldots ,r$ . Then there exists a polynomial-time algorithm that computes the factorisation of f, computes $C_{K}(A)$ and $\operatorname {\mathrm {J}}(C_K(A))$ and computes an explicit homomorphism of K-algebras

$$\begin{align*}\rho \colon C_K(A) \longrightarrow C_K(A)/{\operatorname{\mathrm{J}}(C_K(A))} \stackrel{\cong}{\longrightarrow} \prod_{i=1}^{r} \prod_{j = 1}^{m_{i}} \mathrm{Mat}_{d_{i,j}}(K_i) \end{align*}$$

for some $m_{i} \in \mathbb {Z}_{>0}$ and $d_{i,j} \in \mathbb {Z}_{\geq 0}$ such that $\sum _{j=1}^{m_{i}} jd_{i,j} = n_{i}$ for each i. In particular, this solves $\mathsf {Wedderburn}$ for $C_K(A)/{\operatorname {\mathrm {J}}(C_K(A))}$ , which satisfies hypothesis (H).

Proof. Assume the setup and notation of the proof of Proposition 9.10 with $F=K$ . The isomorphism of (10) is obtained when computing the rational canonical form, which can be performed in polynomial time (see [Reference VillardVil93, Theorem 4]). Moreover, polynomials in $K[x]$ can be factored in polynomial time by the algorithm of [Reference LenstraLen83, (4.5) Theorem]. Thus, we can explicitly compute a decomposition $T_{K}(A) = \bigoplus _{i=1}^{r} V_{i}$ and isomorphisms $V_{i} \cong \bigoplus _{j = 1}^{m_i} (K[x]/(f_{i}^{j}))^{d_{i,j}}$ for some $m_{i} \in \mathbb {Z}_{>0}$ and $d_{i,j} \in \mathbb {Z}_{\geq 0}$ . Note that, for each i, we have $\sum _{j=1}^{m_{i}} jd_{i,j} = n_{i}$ since $f=g_{1}\cdots g_{s}$ . Since $C_K(A)$ is canonically isomorphic to $\mathrm {End}_{K[x]}(T_{K}(A))$ by Lemma 9.5 (b), the desired result now follows from Corollary 9.9.

9.4 An algorithm for determining similarity and computing a conjugating matrix

We now consider the following problem.

Problem (IsSimilar)

Given a number field K with ring of integers $\mathcal {O}=\mathcal {O}_{K}$ , an integer $n \in \mathbb {Z}_{>0}$ and two matrices $A,B \in \mathrm {Mat}_{n}(\mathcal {O})$ , determine whether A and B are similar over $\mathcal {O}$ , and if so, return a conjugating matrix $C \in \mathrm {GL}_{n}(\mathcal {O})$ such that $B= CAC^{-1}$ .

Let $n \in \mathbb {Z}_{>0}$ , and let $A,B \in \mathrm {Mat}_{n}(\mathbb {Z})$ . Assume that there exists $D \in \mathrm {GL}_{n}(\mathbb {Q})$ such that $B=DAD^{-1}$ . Thus, A and B have the same minimal polynomial $f \in \mathbb {Z}[x]$ , and so the $\mathbb {Z}[x]$ -modules $T_{\mathbb {Z}}(A)$ and $T_{\mathbb {Z}}(B)$ are in fact $\mathbb {Z}[x]/(f)$ -lattices. In view of Lemma 9.6, this implies that $\mathsf {IsSimilar}$ over $\mathbb {Z}$ can be reduced to the problem of determining whether the $\mathbb {Z}[x]/(f)$ -lattices $T_{\mathbb {Z}}(A)$ and $T_{\mathbb {Z}}(B)$ are isomorphic and, if so, of computing an isomorphism between them.

Using this observation, Sarkisyan [Reference SarkisyanSar79] and Grunewald [Reference GrunewaldGru80] independently showed that the conjugacy problem over $\mathbb {Z}$ for arbitrary pairs of matrices is decidable. Moreover, Applegate and Onishi [Reference Appelgate and OnishiAO81, Reference Appelgate and OnishiAO82] considered the cases of $2 \times 2$ and $3 \times 3$ matrices, and Behn and Van der Merwe [Reference Behn and Van der MerweBVdM02] also considered the $2 \times 2$ case.

In the case that the characteristic polynomial of A (and B) is squarefree (and thus the minimal and characteristic polynomials coincide), the above approach via $\mathbb {Z}[x]/(f)$ -lattices is equivalent to a classical result of Latimer–MacDuffee [Reference Latimer and MacDuffeeLM33]. This last result was recently generalised in the dissertation of Husert [Reference HusertHus17] to the case where the minimal polynomial is squarefree but the characteristic polynomial is arbitrary. See Proposition 9.10 for properties of the $\mathbb {Q}$ -algebra $C_{\mathbb {Q}}(A)$ in both of these special cases.

For a discussion of practical algorithms that have been implemented on a computer, see §9.5.

Proposition 9.12. Let R be a Noetherian integral domain with field of fractions $K \neq R$ . Let $n \in \mathbb {Z}_{>0}$ , and let $A,B \in \mathrm {Mat}_{n}(R)$ . Suppose that $D \in \mathrm {GL}_{n}(K)$ satisfies $B=DAD^{-1}$ . Then A and B are similar over R if and only if

  1. (a) the $C_R(B)$ -lattice $C_R(A, B)D^{-1}$ in $C_{K}(B)$ is free of rank $1$ , and

  2. (b) every (any) free generator $C'$ of $C_R(A, B)D^{-1}$ over $C_{R}(B)$ satisfies $C'D \in \mathrm {GL}_n(R)$ .

Furthermore, when this is the case, $B=CAC^{-1}$ , where $C:=C'D$ .

Proof. By Lemma 9.1 the map $\theta _{D^{-1}} : C_{K}(A,B) \rightarrow C_{K}(B)$ , $X \mapsto XD^{-1}$ is an isomorphism of $C_{K}(B)$ -modules. Hence, the desired result follows from Proposition 9.2.

The main algorithm of this section is as follows.

Algorithm 9.13. Let K be a number field with ring of integers $\mathcal {O}=\mathcal {O}_{K}$ , let $n \in \mathbb {Z}_{>0}$ and let $A, B \in \mathrm {Mat}_{n}(\mathcal {O})$ . The following steps solve $\textsf {IsSimilar}$ for A and B, that is, they determine whether A and B are similar over $\mathcal {O}$ , and if so, return an element $C \in \mathrm {GL}_{n}(\mathcal {O})$ such that $B = CAC^{-1}$ .

  1. (1) Check whether A and B are similar over K, and if so, compute $D \in \mathrm {GL}_{n}(K)$ such that $B = DAD^{-1}$ . If not, then A and B are not similar over $\mathcal {O}$ .

  2. (2) Compute $C_{K}(B)$ , $\operatorname {\mathrm {J}}(C_K(B))$ and an explicit homomorphism of K-algebras

    $$\begin{align*}\rho \colon C_K(B) \longrightarrow C_K(B)/{\operatorname{\mathrm{J}}(C_K(B))} \stackrel{\cong}{\longrightarrow} \prod_{i=1}^{t} \mathrm{Mat}_{d_i}(K_i), \end{align*}$$
    where the $K_{i}$ ’s are (not necessarily distinct) finite field extensions of K.
  3. (3) Check whether $\rho (C_{\mathcal {O}}(A, B)D^{-1})$ is a free $\rho (C_{\mathcal {O}}(B))$ -lattice, and if so, compute a generator $E \in \rho (C_{\mathcal {O}}(A, B)D^{-1})$ . If not, then A and B are not similar over $\mathcal {O}$ .

  4. (4) Compute $C' \in C_{\mathcal {O}}(A, B)D^{-1}$ such that $\rho (C')=E$ .

  5. (5) Check whether $C := C'D \in \mathrm {GL}_n(\mathcal {O})$ . If so, then $B=CAC^{-1}$ . If not, then A and B are not similar over $\mathcal {O}$ .

Proof of correctness of Algorithm 9.13

If all steps succeed, then $C \in C_{\mathcal {O}}(A, B) \cap \mathrm {GL}_{n}(\mathcal {O})$ and it easily follows that $B=CAC^{-1}$ . It remains to show that if any of steps (1), (3) or (5) fail, then A and B are not similar over $\mathcal {O}$ . If step (1) fails, then this is clear. If step (3) fails, then Theorem 3.4 (a) implies that $C_{\mathcal {O}}(A, B)D^{-1}$ is not free over $C_{\mathcal {O}}(B)$ , and the result follows from Proposition 9.12 (a). Finally, suppose that step (5) fails, that is, $C \notin \mathrm {GL}_{n}(\mathcal {O})$ . If $C'$ is not a free generator of $C_{\mathcal {O}}(A, B)D^{-1}$ over $C_{\mathcal {O}}(B)$ , then Theorem 3.4 (b) implies that $C_{\mathcal {O}}(A, B)D^{-1}$ is not free over $C_{\mathcal {O}}(B)$ , and again the result follows from Proposition 9.12 (a). If $C'$ is a free generator of $C_{\mathcal {O}}(A, B)D^{-1}$ over $C_{\mathcal {O}}(B)$ , then the result follows from Proposition 9.12 (b).

The following result analyses the complexity of Algorithm 9.13, and further details on each step are given in the proof.

Theorem 9.14. Let K be a number field with ring of integers $\mathcal {O}=\mathcal {O}_{K}$ , let $n \in \mathbb {Z}_{>0}$ and let $A, B \in \mathrm {Mat}_{n}(\mathcal {O})$ . Let $f_{1}, \ldots , f_{r} \in K[x]$ be the distinct monic irreducible factors of the characteristic polynomial of B. For $i=1,\ldots ,r$ let $K_{i}=K[x]/(f_{i})$ . Let $\Lambda $ be the image of $C_{\mathcal {O}}(B)$ under the projection $C_K(B) \to C_K(B)/{\operatorname {\mathrm {J}}(C_K(B))}$ . Let $\mathcal {M}$ be any choice of maximal $\mathcal {O}$ -order in $C_K(B)/\operatorname {\mathrm {J}}(C_K(B))$ containing $\Lambda $ , and let $\mathfrak {h} = [\mathcal {M} : \Lambda ]_{\mathcal {O}}$ be the module index of $\Lambda $ in $\mathcal {M}$ . Then Algorithm 9.13 reduces the problem $\mathsf {IsSimilar}$ for A and B in probabilistic polynomial time to

  1. (a) $\mathsf {Factor}(\mathrm {Disc}(\Lambda ))$ , the factorisation of the discriminant of $\Lambda $ ,

  2. (b) for each i with $1 \leq i \leq r$ , one instance of $\mathsf {IsPrincipal}_{\mathcal O_{K_i}}$ ,

  3. (c) for each i with $1 \leq i \leq r$ , $\mathsf {UnitGroup}(\mathcal O_{K_i})$ ,

  4. (d) for each prime ideal divisor $\mathfrak {p}$ of $\mathfrak {h}$ , the problem $\mathsf {DLog}$ for extensions of $\mathcal {O}/\mathfrak {p}$ and

  5. (e) for each prime ideal divisor $\mathfrak {p}$ of $\mathfrak {h}$ , the problem $\mathsf {Primitive}$ for extensions of $\mathcal {O}/\mathfrak {p}$ .

Note that $\mathcal {M}$ and $\mathfrak {h}$ are not part of the input and $\mathfrak {h}$ is only needed for the above complexity statement. Moreover, $\mathfrak {h}$ does not depend on the choice of $\mathcal {M}$ .

Proof. In the following, the steps refer to those of Algorithm 9.13. Step (1) can be performed in polynomial time by [Reference Chistov, Ivanyos and KarpinskiCIK97, Theorem 2], and step (2) can be performed in polynomial time by Proposition 9.11. Steps (4) and (5) are straightforward and can both be performed in polynomial time. Step (3) can be performed using Algorithm 8.3, and so the desired result now follows from Theorem 8.4 after noting that $\mathsf {Wedderburn}(C_K(B)/{\operatorname {\mathrm {J}}(C_K(B)))}$ was already performed in step (2).

We also record the following two consequences of Remark 8.8.

Corollary 9.15. The problem $\mathsf {IsSimilar}$ reduces in probabilistic subexponential time to the problems $\mathsf {IsPrincipal}$ and $\mathsf {UnitGroup}$ for rings of integers of number fields.

Corollary 9.16. There exists a polynomial quantum algorithm for solving $\mathsf {IsSimilar}$ .

9.5 Implementation of the algorithm

The algorithm for solving the principal ideal problem for orders in algebras satisfying hypothesis (H), and its application to the similarity problem has been implemented using the computer algebra package Hecke [Reference Fieker, Hart, Hofmann and JohanssonFHHJ17] (also available in Oscar [OSC22]) and is included from version 0.13 onwards. The implementation works for arbitrary pairs of matrices in $\mathrm {Mat}_{n}(\mathbb {Z})$ . We now give a brief comparison with other algorithms and implementations, all of which are for pairs of matrices in $\mathrm {Mat}_{n}(\mathbb {Z})$ , subject to certain further restrictions in cases (a)–(c). Recall that in Proposition 9.10 the restrictions in (b) and (c) are rephrased in terms of the algebra $C_{\mathbb {Q}}(A)$ .

  1. (a) The algorithm of Opgenorth–Plesken–Schulz [Reference Opgenorth, Plesken and SchulzOPS98] solves the similarity problem for pairs of matrices of finite order.

  2. (b) The algorithm of Husert [Reference HusertHus17] solves the similarity problem for pairs of matrices, both of which are either nilpotent or have squarefree minimal polynomial. However, the implementation is restricted to nilpotent matrices and matrices with irreducible minimal polynomial.

  3. (c) The algorithm of Marseglia [Reference MarsegliaMar20] solves the similarity problem for pairs of matrices with squarefree characteristic polynomial (this condition implies that the minimal and characteristic polynomials coincide).

  4. (d) The algorithm of Eick–O’Brien and the second named author of the present article [Reference Eick, Hofmann and O’BrienEHO19] is based on ideas of Grunewald [Reference GrunewaldGru80] and solves the similarity problem for arbitrary pairs of matrices.

All of the above algorithms (a)–(d) have been implemented in Magma [Reference Bosma, Cannon and PlayoustBCP97], but no formal complexity analysis has been given for any of them. However, we can compare these with our algorithm using timings and heuristic reasoning. All timings in the examples below were performed using a single core of a 3.40 GHz Intel E5-2643 processor and under the assumption of GRH. Magma V2.23-3 was used to run algorithms (a)–(d).

For random pairs of matrices of a given rational canonical form, our algorithm dramatically outperforms (a) and the algorithm for nilpotent matrices of (b). In the latter case this is not surprising since the algorithm in question requires an exhaustive search among candidates within a large search space. In the case of matrices with squarefree minimal polynomial, the bottleneck of algorithm (b) is a final enumeration over a set $\Lambda /\mathfrak {f}$ , which our algorithm avoids by means of the results of §6.6 (in particular, see Proposition 6.11). In cases where the set $\Lambda /\mathfrak {f}$ is large, our algorithm dramatically outperforms that of (b).

Example 9.17. Consider the two matrices

$$\begin{align*}A = \left(\begin{smallmatrix} 0&1&0&0&0&0\\ -5336100&0&0&0&0&0\\ 0&0&0&1&0&0\\ 0&0&-5336100&0&0&0\\ 0&0&0&0&0&1\\ 0&0&0&0&-5336100&0 \end{smallmatrix}\right), \quad B = \left(\begin{smallmatrix} 0&1&5&0&53361000&0\\ -5336100&0&40&-5&0&-53361000\\ 0&0&-8&1&0&0\\ 0&0&-5336164&8&0&0\\ 0&0&0&0&0&1\\ 0&0&0&0&-5336100&0 \end{smallmatrix}\right), \end{align*}$$

both with irreducible minimal polynomial $f = x^2 + 5336100$ and characteristic polynomial $f^3$ . The algorithm of (b) requires an enumeration over a set of size $2357947691 \approx 10^9$ , thus rendering it impractical for this example. However, the implementation of our algorithm requires 6 seconds to recognise that A and B are similar over $\mathbb {Z}$ and to find a conjugating matrix. Note that $C_{\mathbb {Q}}(A) \cong \mathrm {Mat}_3(K)$ , where $K = \mathbb {Q}[x]/(x^2 + 5336100)$ .

Algorithm (c) is more restricted than (b) in that it requires the matrices in question to have squarefree characteristic polynomial. However, in contrast to the squarefree minimal polynomial case of (b), it avoids a final enumeration step, and thus it performs as well as our algorithm in this special case.

We have compared the implementation of our algorithm with that of algorithm (d) for a variety of different examples and found that in all cases the former outperformed the latter, often dramatically. However, we should mention that as a by-product, given a matrix $A \in \mathrm {Mat}_{n}(\mathbb {Z})$ , algorithm (d) can be used to determine generators of the arithmetic group $C_{\mathbb {Z}}(A)^{\times } = \{ X \in \mathrm {GL}_{n}(\mathbb {Z}) \mid XA = AX \}$ . Various examples in [Reference Eick, Hofmann and O’BrienEHO19] as well as the overall strategy of finding candidates in large search spaces suggest that algorithm (d) has at least exponential complexity. We now review some of these examples from [Reference Eick, Hofmann and O’BrienEHO19] and show how our algorithm fares in comparison.

Example 9.18 [Reference Eick, Hofmann and O’BrienEHO19, 6.3.2]

Consider the two matrices

$$\begin{align*}A = \left( \begin{smallmatrix} -3 & -1 & 3 & 0 & 0 & 0 & 0 & 0 & 0 \\ 1 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\ -5 & 0 & 1 & 0 & 0 & 0 & 0 & 0 & 0 \\ 0 & 0 & 0 & -3 & -1 & 3 & 0 & 0 & 0 \\ 0 & 0 & 0 & 1 & 0 & 0 & 0 & 0 & 0 \\ 0 & 0 & 0 & -5 & 0 & 1 & 0 & 0 & 0 \\ 0 & 0 & 0 & 0 & 0 & 0 & -3 & -1 & 3 \\ 0 & 0 & 0 & 0 & 0 & 0 & 1 & 0 & 0 \\ 0 & 0 & 0 & 0 & 0 & 0 & -5 & 0 & 1 \end{smallmatrix} \right) , \quad B = \left(\begin{smallmatrix} 13 & -15 & 16 & 24 & -16 & -7 & -35 & 15 & 0 \\ -3 & 44 & -40 & -71 & 62 & 28 & 157 & -76 & 16 \\ 18 & -15 & -3 & -7 & -31 & 6 & -226 & 129 & -52 \\ -69 & 72 & -55 & -78 & 86 & 18 & 355 & -186 & 48 \\ -75 & 98 & -82 & -124 & 117 & 35 & 406 & -206 & 46 \\ -45 & 19 & -21 & -22 & 10 & 1 & 49 & -25 & -3 \\ 24 & -66 & 53 & 89 & -89 & -31 & -289 & 147 & -37 \\ 30 & -78 & 61 & 102 & -104 & -35 & -348 & 178 & -45 \\ 24 & 11 & -8 & -23 & 26 & 14 & 58 & -29 & 11 \end{smallmatrix} \right), \end{align*}$$

both with irreducible minimal polynomial $f = x^3 + 2x^2 + 13x - 1$ and characteristic polynomial $f^{3}$ . As these are not equal, algorithm (c) cannot be applied in this situation. Moreover, algorithm (d) fails to run in reasonable time because the search space is too large. However, the implementation of our algorithm requires 10 seconds to recognise that A and B are similar over $\mathbb {Z}$ and to find a conjugating matrix. Note that $C_{\mathbb {Q}}(A) \cong \mathrm {Mat}_3(K)$ , where $K = \mathbb {Q}[x]/(f)$ .

Example 9.19 [Reference Eick, Hofmann and O’BrienEHO19, 6.3.3]

Consider the two matrices

$$\begin{align*}A = \left(\begin{smallmatrix} 13 & 67 & 6 & 0 & 0 & -1 \\ 0 & 1 & 3 & 0 & 0 & 0 \\ 0 & 0 & 1 & 0 & 0 & 0 \\ -270 & -1350 & 0 & 1 & 2 & 20 \\ -135 & -675 & 0 & 0 & 1 & 10 \\ -27 & -135 & 0 & 0 & 0 & 2 \end{smallmatrix}\right), \quad B = \left(\begin{smallmatrix} 13 & 79 & 0 & 0 & 1 & -76 \\ 0 & 1 & 0 & 0 & 0 & 3 \\ -270 & -1620 & 1 & 2 & -20 & 1620 \\ -135 & -810 & 0 & 1 & -10 & 810 \\ 27 & 162 & 0 & 0 & 2 & -162 \\ 0 & 0 & 0 & 0 & 0 & 1 \end{smallmatrix} \right), \end{align*}$$

both with minimal and characteristic polynomial equal to $(x - 1)^{4}(x^2 - 15x - 1)$ . As this is not squarefree, algorithms (b) and (c) cannot be applied in this situation. Again, the search space for a certain subproblem is too large, making the computation infeasible for algorithm (d). However, the implementation of our algorithm finds a conjugating matrix in less than one second. Note that $\dim _{\mathbb {Q}}(C_{\mathbb {Q}}(A)) = 6$ and

$$\begin{align*}C_{\mathbb{Q}}(A)/{\operatorname{\mathrm{J}}(C_{\mathbb{Q}}(A))} \cong \mathbb{Q} \times K, \end{align*}$$

where $K = \mathbb {Q}[x]/(x^2 - 15x - 1)$ .

Example 9.20. Consider the two matrices

$$\begin{align*}A = \left(\begin{smallmatrix} 1 & -4 & 0 & 0 & 1 & 0 \\ 0 & 1 & 0 & 0 & 0 & 0 \\ 0 & 0 & 1 & -3 & -6 & 0 \\ 0 & 0 & 0 & 1 & 2 & 0 \\ -4 & 16 & -3 & 0 & -5 & -6 \\ 0 & 0 & -37 & 0 & -9 & -55 \end{smallmatrix}\right), \quad B = \left(\begin{smallmatrix} -88 & -4 & 0 & -66 & -51 & 32 \\ -2683 & 225 & 326 & -2670 & 1755 & 634 \\ -2607 & -666 & -332 & -525 & -6747 & 2835 \\ 14 & 0 & 0 & 13 & 2 & 0 \\ 523 & 38 & -3 & 330 & 440 & -325 \\ 285 & 74 & 37 & 54 & 749 & -314 \end{smallmatrix}\right), \quad \end{align*}$$

both with minimal and characteristic polynomial $(x - 1)^2 (x^4 + 58x^3 + 88x^2 + 176x + 1)$ . As this is not squarefree, algorithms (b) and (c) cannot be applied in this situation. Moreover, the implementation of algorithm (d) requires approximately one hour to find a conjugating matrix. By contrast, the implementation of our algorithm finds such a matrix in less than one second. Note that $\dim _{\mathbb {Q}}(C_{\mathbb {Q}}(A)) = 6$ and

$$\begin{align*}C_{\mathbb{Q}}(A)/{\operatorname{\mathrm{J}}(C_{\mathbb{Q}}(A))} \cong \mathbb{Q} \times K, \end{align*}$$

where $K = \mathbb {Q}[x]/(x^4 + 58x^3 + 88x^2 + 176x + 1)$ .

10 Application: Galois module structure of rings of integers

An important motivation for Algorithm 8.3 and its predecessors is the investigation of the Galois module structure of rings of integers. We only briefly recall the problem here and refer the reader to the introduction of [Reference Hofmann and JohnstonHJ20] for a more detailed overview.

Let $L/K$ be a finite Galois extension of number fields, and let $G=\mathrm {Gal}(L/K)$ . The classical normal basis theorem says that $L \cong K[G]$ as $K[G]$ -modules. A much more difficult problem is that of determining whether the ring of integers $\mathcal {O}_{L}$ is free over its so-called associated order $\mathcal {A}_{L/K} = \{ \alpha \in K[G] \mid \alpha \mathcal {O}_{L} \subseteq \mathcal {O}_{L} \}$ . Note that if a prime $\mathfrak {p}$ of K is (at most) tamely ramified in $L/K$ or is such that the localised associated order $\mathcal {A}_{L/K, \mathfrak {p}}$ is maximal, then the localisation $\mathcal {O}_{L,\mathfrak {p}}$ is necessarily free over $\mathcal {A}_{L/K, \mathfrak {p}}$ . In particular, $\mathcal {O}_{L}$ is locally free over $\mathcal {A}_{L/K}$ if and only if $\mathcal {O}_{L,\mathfrak {p}}$ is free over $\mathcal {A}_{L/K, \mathfrak {p}}$ for every prime $\mathfrak {p}$ of K that is wildly ramified in $L/K$ . In this situation, one can consider the class $[\mathcal {O}_{L}]$ in the locally free class group $\mathrm {Cl}(\mathcal {A}_{L/K})$ . Moreover, if $K[G]$ satisfies hypothesis (H), then every order in $K[G]$ has the so-called locally free cancellation property (this follows from Jacobinski’s cancellation theorem [Reference Curtis and ReinerCR87, (51.24)]), and so $\mathcal {O}_{L}$ is free over $\mathcal {A}_{L/K}$ if and only if it is locally free and the class $[\mathcal {O}_{L}]$ is the trivial element of $\mathrm {Cl}(\mathcal {A}_{L/K})$ .

For an abstract finite group $\Gamma $ , we say that $L/K$ is a $\Gamma $ -extension if it is a Galois extension such that $\mathrm {Gal}(L/K) \cong \Gamma $ . Let $\Gamma =S_{4} \times C_{2}$ , the direct product of the symmetric group on $4$ letters and the cyclic group of order $2$ . Since

$$\begin{align*}\mathbb{Q}[\Gamma] \cong \prod_{i=1}^{4} \mathbb{Q} \times \prod_{j=1}^{2} \mathrm{Mat}_2(\mathbb{Q}) \times \prod_{k=1}^{4} \mathrm{Mat}_3(\mathbb{Q}), \end{align*}$$

the algebra $\mathbb {Q}[\Gamma ]$ satisfies hypothesis (H). Using the methods of [Reference Fieker, Hofmann and SircanaFHS19], we have constructed wildly ramified $\Gamma $ -extensions of $\mathbb {Q}$ of small discriminant. The wildly ramified $\Gamma $ -extension of minimal discriminant is $L_1 := K_1(\sqrt {92})$ , where $K_1$ is the $S_4$ -extension of $\mathbb {Q}$ defined by

$$ \begin{align*} x^{24} + 2 x^{22} + 27 x^{20} + 112 x^{18} + 585 x^{16} &+ 338 x^{14} + 5767 x^{12} \\ &\ \quad+ 4362 x^{10} + 1417 x^{8} - 76 x^{6} - 29 x^{4} - 6 x^{2} + 1 \in \mathbb{Q}[x]. \end{align*} $$

The field $L_1$ has discriminant $2^{84} \cdot 23^{24}$ and is wildly ramified at $2$ . Moreover, the associated order $\mathcal {A}_{L_1/\mathbb {Q}}$ has index $2^{43} \cdot 3^{3}$ in a maximal order $\mathcal {M}$ satisfying $\mathcal {A}_{L_1/\mathbb {Q}} \subseteq \mathcal {M} \subseteq \mathbb {Q}[\mathrm {Gal}(L_{1}/\mathbb {Q})]$ (note that this index is independent of the choice of $\mathcal {M}$ ). Using Algorithm 8.3 we have checked that $\mathcal {O}_{L_1}$ is free over $\mathcal {A}_{L_1/\mathbb {Q}}$ and have also obtained an explicit generator (unfortunately, the coefficients are too large to reproduce in print). The algorithms of [Reference Bley, Boltje, Hess, Pauli and PohstBB06, Reference Bley and WilsonBW09] show that $\mathrm {Cl}(\mathcal {A}_{L_1/\mathbb {Q}}) \cong C_{2}$ . However, the algorithm of [Reference Bley and WilsonBW09] for solving the discrete logarithm problem in a locally free class group is restricted to the case in which the order in question is a group ring or a maximal order, and so this approach does not allow us to determine $[\mathcal {O}_{L_1}]$ in $\mathrm {Cl}(\mathcal {A}_{L_1/\mathbb {Q}})$ .

We have performed the same computation using Algorithm 8.3 described above for all wildly ramified $\Gamma $ -extensions $L/\mathbb {Q}$ with $\lvert \mathrm {Disc}(L) \rvert \leq 60^{48}$ . For $686$ out of these $2600$ extensions, $\mathcal {O}_{L}$ is locally free over $\mathcal {A}_{L/\mathbb {Q}}$ , and in all of these cases, $\mathcal {O}_{L}$ is in fact free over $\mathcal {A}_{L/\mathbb {Q}}$ . It would be interesting to find a proof of, or counterexample to, the assertion that the same phenomenon holds without the restriction on $\lvert \mathrm {Disc}(L) \rvert $ .

A Weak approximation in probabilistic polynomial time

Let K be a number field with ring of integers $\mathcal {O} = {\mathcal {O}_K}$ . Let $\mathfrak {a}$ and $\mathfrak {b}$ be nonzero integral ideals of $\mathcal {O}$ . A classical result (see [Reference CohenCoh00, Corollary 1.3.9]) asserts that there exists a deterministic algorithm for computing $x \in K^{\times }$ such that $x \mathfrak {a}$ is integral and coprime to $\mathfrak {b}$ . If the factorisation of $\mathfrak {b}$ , or equivalently, of $\mathrm {N}(\mathfrak {b})$ , is given, the algorithm runs in polynomial time. There also exists a probabilistic algorithm [Reference CohenCoh00, Algorithm 1.3.14], which does not require the factorisation of $\mathfrak {b}$ or $\mathrm {N}(\mathfrak {b})$ , but is not polynomial time. The aim of this section is to combine the deterministic and probabilistic variants to obtain a probabilistic polynomial-time algorithm. The approach is based on the following general form of the constructive weak approximation theorem, which relies on ideas of [Reference BelabasBel04, Algorithm 6.15]. For a nonzero prime ideal $\mathfrak {p}$ of $\mathcal {O}$ , let $v_{\mathfrak {p}}(-)$ denote the $\mathfrak {p}$ -adic valuation.

Proposition A.1. There exists a probabilistic polynomial-time algorithm that given nonzero integral ideals $\mathfrak {a}$ and $\mathfrak {b}$ of $\mathcal {O}$ returns an element $x \in \mathfrak {a}$ with $v_{\mathfrak {p}}(x) = v_{\mathfrak {p}}(\mathfrak {a})$ for all prime ideals $\mathfrak {p}$ dividing $\mathfrak {b}$ .

Proof. We adapt the proofs of [Reference BelabasBel04, Lemmas 6.14, 6.16], taking into account [Reference BelabasBel04, Remark 6.17 (2)]. For the rest of the proof, we fix a positive constant $0<C<1$ . Let $a = \min (\mathfrak {a} \cap \mathbb {Z}_{>0})$ , let $b = \min (\mathfrak {b} \cap \mathbb {Z}_{>0})$ and let $d=[K:\mathbb {Q}]$ . Note that if $a=1$ or $b=1$ or $d=1$ , then we can just take $x=a$ . Thus, we can and do assume that $a, b,d \geq 2$ . We define $y \in \mathbb {R}$ by the equality $Cy\log (y) = d \log (b)$ . Then $y>2$ and we observe that y is polynomially bounded in terms of d and $\log (b)$ . Hence, we can determine the set

$$\begin{align*}S := \{ \mathfrak p \subseteq \mathcal{O} \text{ prime such that }\mathfrak p \cap \mathbb{Z} = (p) \text{ with a rational prime } p < y \} \end{align*}$$

in polynomial time. We define ideals

$$\begin{align*}\mathfrak{a}_0 = \prod_{\mathfrak{p} \in S} \mathfrak{p}^{v_{\mathfrak{p}}(\mathfrak{a})}, \quad\quad \mathfrak{b}_0 = \prod_{\mathfrak{p} \in S} \mathfrak{p}^{v_{\mathfrak{p}}(\mathfrak{b})}. \end{align*}$$

Then $\mathfrak {a} = \mathfrak {a}_0\mathfrak {a}_1$ and $\mathfrak {b} = \mathfrak {b}_0\mathfrak {b}_1$ with integral ideals $\mathfrak {a}_1, \mathfrak {b}_1$ such that

$$\begin{align*}\mathfrak{a}_0 + \mathfrak{a}_1 = \mathfrak{b}_0 + \mathfrak{b}_1 = \mathcal{O}, \end{align*}$$

which can be computed in polynomial time. We write $b = b_0 b_1$ with

$$\begin{align*}b_{0} = \prod_{p < y} p^{v_{p}(b)}. \end{align*}$$

Since the factorisations of $\mathfrak {a}_{0}$ and $\mathfrak {b}_{0}$ are known, using the deterministic polynomial-time algorithm [Reference CohenCoh00, Proposition 1.3.8] we can find $x_0 \in \mathcal {O}$ with $x_0 \in \mathfrak a_0$ and $v_{\mathfrak p}(x_0) = v_{\mathfrak p}(\mathfrak a_0)$ for all $\mathfrak p$ dividing $\mathfrak b_0$ .

We now show that we can find an element $x_{1} \in \mathfrak {a}_{1}$ with $v_{\mathfrak {p}}(x_1) = v_{\mathfrak {p}}(\mathfrak {a}_{1})$ for all $\mathfrak {p}$ dividing $\mathfrak {b}_{1}$ in probabilistic polynomial time. For the rest of the proof, we will refer to such elements as good elements. We will prove that a positive proportion (independent of $\mathfrak a$ and $\mathfrak b$ ) of elements of the finite abelian group $\mathfrak a_1/\mathfrak a_1\mathfrak b_1$ are good. For a prime ideal $\mathfrak {p}$ dividing $\mathfrak {b}_1$ , let $A_{\mathfrak {p}}$ denote the set $\mathfrak {a}_1 \mathfrak {p}/\mathfrak {a}_1 \mathfrak {b}_1$ . Then, for a set of prime ideals T dividing $\mathfrak {b}_1$ , we have

$$\begin{align*}\Bigl\lvert \bigcap_{\mathfrak{p} \in T} A_{\mathfrak{p}} \Bigr\rvert = \mathrm{N}(\mathfrak b_1)/\prod_{\mathfrak p \in T}\mathrm{N}(\mathfrak{p}). \end{align*}$$

From the inclusion-exclusion principle it follows that

$$\begin{align*}\Bigl\lvert \bigcup_{\mathfrak{p} \mid \mathfrak{b}_1 } A_{\mathfrak{p}} \Bigr\rvert = \mathrm{N}(\mathfrak{b}_1) \left( 1 - \prod_{\mathfrak{p} \mid \mathfrak{b}_1} \left(1 - \frac{1}{\mathrm{N}(\mathfrak{p})}\right) \right). \end{align*}$$

By definition, the lift of $x \in \mathfrak {a}_1/\mathfrak {a}_1\mathfrak {b}_1$ is good if and only if $x \not \in \bigcup _{\mathfrak {p} \mid \mathfrak {b}_1} A_{\mathfrak {p}}$ . Hence, the probability that (the lift) of a random element of $\mathfrak {a}_1/\mathfrak {a}_1\mathfrak {b}_1$ is good is

$$\begin{align*}\prod_{\mathfrak p \mid \mathfrak b_1}\left( 1 - \frac{1}{\mathrm{N}(\mathfrak p)} \right). \end{align*}$$

Now, set $C_1 := d \log (b_1)/(y \log (y)) \leq C$ . Since there are at most $d \log _y(b_1)$ prime ideals $\mathfrak {p}$ dividing $\mathfrak {b}_1$ , each satisfying $\mathrm {N}(\mathfrak {p}) \geq y$ , we have

$$ \begin{align*} \textstyle{\prod_{\mathfrak p \mid \mathfrak b_1}(1 - 1/\mathrm{N}(\mathfrak p))} \geq (1 - 1/y)^{d \log_y(b_1)} & \geq \exp(-1/y-1/y^{2})^{d \log_y(b_1)} = \exp(-C_1 - C_1/y) \\ &\geq \exp(-C(1+1/y)) \geq \exp(-3 C/2). \end{align*} $$

Here the second inequality follows from $1 - x \geq \exp (-x - x^2)$ for $0 \leq x \leq 1/2$ . Thus, we can find a good element in probabilistic polynomial time.

Now, given $x_i \in \mathfrak a_i$ with $v_{\mathfrak p}(x_i) = v_{\mathfrak p}(\mathfrak a_i)$ for all primes $\mathfrak p$ dividing $\mathfrak b_i$ , we proceed as follows. For $i=0,1$ let $\mathfrak {c}_i$ be the largest divisor of $\mathfrak {b}_i$ which is coprime to $\mathfrak {a}$ . Note that each $\mathfrak {c}_i$ can be determined in polynomial time by using only ideal sums and ideal division. Moreover, if $\mathfrak {p}$ is a prime ideal with $\mathfrak {p} \mid \mathfrak {b}_i$ and $\mathfrak {p} \nmid \mathfrak {a}$ , then $\mathfrak {p} \mid \mathfrak {c}_i$ . Since $\mathfrak {a}_0^2\mathfrak {c}_0 + \mathfrak {a}_1^2\mathfrak {c}_1 = \mathcal {O}$ , we can determine elements $e_i \in \mathfrak {a}_i^2\mathfrak {c}_i$ with $e_0 + e_1 = 1$ in polynomial time. We now prove that the element

$$\begin{align*}x := e_0x_1 + e_1x_0 \in \mathfrak{a} \end{align*}$$

satisfies $v_{\mathfrak {p}} (x) = v_{\mathfrak {p}}(\mathfrak {a})$ for all $\mathfrak {p}$ dividing $\mathfrak {b}$ .

Case 1: $\mathfrak {p} \nmid \mathfrak {a}$ . Assume that $\mathfrak {p} \mid \mathfrak {b}_1$ . Then $\mathfrak {p} \mid \mathfrak {c}_1$ and hence $e_1 \in \mathfrak {p}$ , $e_0 \not \in \mathfrak {p}$ . Moreover,

$$ \begin{align*} v_{\mathfrak{p}}(e_0x_1) &= v_{\mathfrak{p}}(e_0) + v_{\mathfrak{p}}(x_1) = v_{\mathfrak{p}}(e_0) + v_{\mathfrak{p}}(\mathfrak{a}_1) = v_{\mathfrak{p}}(e_0) = 0, \\ v_{\mathfrak{p}}(e_1x_0) &= v_{\mathfrak{p}}(e_1) + v_{\mathfrak{p}}(x_0) \ge v_{\mathfrak{p}}(e_1)> 0. \end{align*} $$

Hence, $v_{\mathfrak {p}}(x) = \min (v_{\mathfrak {p}}(e_0x_1), v_{\mathfrak {p}}(e_1x_0)) = 0 = v_{\mathfrak {p}}(\mathfrak {a})$ . The subcase $\mathfrak {p} \mid \mathfrak {b}_0$ is similar.

Case 2: $\mathfrak {p} \mid \mathfrak {a}$ . Assume that $\mathfrak {p} \mid \mathfrak {b}_1$ . Then $\mathfrak {p} \not \in S$ and hence $\mathfrak {p} \nmid \mathfrak {a}_0$ . It follows that $\mathfrak {p}\mid \mathfrak {a}_1$ , and hence $e_0 \not \in \mathfrak {p}, e_1 \in \mathfrak {p}$ . Moreover,

$$ \begin{align*} v_{\mathfrak{p}}(e_0x_1) &= v_{\mathfrak{p}}(e_0) + v_{\mathfrak{p}}(x_1) = v_{\mathfrak{p}}(e_0) + v_{\mathfrak{p}}(\mathfrak{a}_1) = v_{\mathfrak{p}}(e_0) + v_{\mathfrak{p}}(\mathfrak{a}) = v_{\mathfrak{p}}(\mathfrak{a}), \\ v_{\mathfrak{p}}(e_1x_0) &= v_{\mathfrak{p}}(e_1) + v_{\mathfrak{p}}(x_0) \ge v_{\mathfrak{p}}(e_1) \ge 2v_{\mathfrak{p}}(\mathfrak{a}_1)> v_{\mathfrak{p}}(\mathfrak{a}_1) = v_{\mathfrak{p}}(\mathfrak{a}). \end{align*} $$

Hence, $v_{\mathfrak {p}}(x) = \min (v_{\mathfrak {p}}(e_0x_1), v_{\mathfrak {p}}(e_1x_0)) = v_{\mathfrak {p}}(\mathfrak {a})$ . The subcase $\mathfrak {p} \mid \mathfrak {b}_0$ is similar.

Corollary A.2. There exists a probabilistic polynomial-time algorithm that given nonzero integral ideals $\mathfrak {a}$ and $\mathfrak {b}$ of $\mathcal {O}$ returns an element $x \in K^{\times }$ such that $x \mathfrak {a}$ is integral and coprime to $\mathfrak {b}$ .

Proof. We need to find an element $x \in \mathfrak {a}^{-1}$ such that $v_{\mathfrak {p}}(x) = v_{\mathfrak {p}}(\mathfrak {a}^{-1})$ for all prime ideals $\mathfrak {p}$ dividing $\mathfrak {b}$ . Setting $a = \min (\mathfrak a \cap \mathbb {Z}_{>0})$ to be the minimum of $\mathfrak a$ , this is equivalent to $v_{\mathfrak p}(ax) = v_{\mathfrak p}(a\mathfrak a^{-1})$ for all $\mathfrak p$ dividing $\mathfrak b$ . As $a \mathfrak a^{-1}$ is integral, the result follows from Proposition A.1 applied to $a\mathfrak {a}^{-1}$ and $\mathfrak {b}$ .

Corollary A.3. There exists a probabilistic polynomial-time algorithm that, given a generating set of an $\mathcal {O}$ -lattice $M \subseteq K^{n}$ of rank n, determines a Steinitz form of M, that is, elements $w_1,\dotsc ,w_n \in K^{n}$ and a fractional ideal $\mathfrak {a}$ of $\mathcal {O}$ such that

$$\begin{align*}M = \mathcal{O} w_{1} \oplus \dotsb \oplus \mathcal{O} w_{n-1} \oplus \mathfrak{a} w_n. \end{align*}$$

Proof. A pseudo-Hermite normal form can be determined in probabilistic polynomial time by [Reference Biasse, Fieker and HofmannBFH17, Theorem 34]. The reduction to the Steinitz form is described in [Reference CohenCoh00, Lemma 1.2.20] and requires the computation of coprime representatives of ideal classes. Thus, the claim follows from Corollary A.2.

Acknowledgements

The authors wish to thank Nigel Byott, Fabio Ferri, Claus Fieker and Jürgen Klüners for useful conversations and are grateful for numerous helpful comments and corrections from Nigel Byott, Gunter Malle, Stefano Marseglia and an anonymous referee. The second named author was supported by Project II.2 of SFB-TRR 195 ‘Symbolic Tools in Mathematics and Their Application’ of the German Research Foundation (DFG).

Conflicts of Interest

None.

Data availability statement

The source code for Hecke is available at https://github.com/thofma/Hecke.jl.

References

Appelgate, H. and Onishi, H., ‘Continued fractions and the conjugacy problem in $\mathrm{SL}_{2}(\mathbb{Z})$ ’, Comm. Algebra 9(11) (1981), 11211130.CrossRefGoogle Scholar
Appelgate, H. and Onishi, H., ‘The similarity problem for $3\times 3$ integer matrices’, Linear Algebra Appl. 42 (1982), 159174.CrossRefGoogle Scholar
Bass, H., Algebraic $K$ -Theory, (W. A. Benjamin, Inc., New York-Amsterdam, 1968).Google Scholar
Bley, W. and Boltje, R., ‘Computation of locally free class groups’, in Algorithmic Number Theory, Hess, F., Pauli, S., and Pohst, M., eds., Lecture Notes in Computer Science, no. 4076 (Springer, Berlin, 2006), 7286.CrossRefGoogle Scholar
Bosma, W., Cannon, J. and Playoust, C., ‘The Magma algebra system. I. The user language’, J. Symbol. Computat. 24 (1997), 235265.CrossRefGoogle Scholar
Bley, W. and Endres, W., ‘Picard groups and refined discrete logarithms’, LMS J. Comput. Math. 8 (2005), 116.CrossRefGoogle Scholar
Belabas, K., ‘Topics in computational algebraic number theory’, J. Théor. Nombres Bordeaux 16(1) (2004), 1963.CrossRefGoogle Scholar
Biasse, J.-F. and Fieker, C., ‘Subexponential class group and unit group computation in large degree number fields’, LMS J. Comput. Math. 17(suppl. A) (2014), 385403.CrossRefGoogle Scholar
Biasse, J.-F., Fieker, C. and Hofmann, T., ‘On the computation of the HNF of a module over the ring of integers of a number field’, J. Symbolic Comput. 80(3) (2017), 581615.CrossRefGoogle Scholar
Biasse, J.-F., ‘Subexponential time relations in the class group of large degree number fields’, Adv. Math. Commun. 8(4) (2014), 407425.CrossRefGoogle Scholar
Bley, W. and Johnston, H., ‘Computing generators of free modules over orders in group algebras’, J. Algebra 320(2) (2008), 836852.CrossRefGoogle Scholar
Bley, W. and Johnston, H., ‘Computing generators of free modules over orders in group algebras II’, Math. Comp. 80(276) (2011), 24112434.CrossRefGoogle Scholar
Bley, W., ‘Computing associated orders and Galois generating elements of unit lattices’, J. Number Theory 62(2) (1997), 242256.CrossRefGoogle Scholar
Biasse, J.-F. and Song, F., ‘Efficient quantum algorithms for computing class groups and solving the principal ideal problem in arbitrary degree number fields’, in Proceedings of the Twenty-Seventh Annual ACM-SIAM Symposium on Discrete Algorithms, (ACM, New York, 2016), 893902.CrossRefGoogle Scholar
Buchmann, J., ‘A subexponential algorithm for the determination of class groups and regulators of algebraic number fields’, in Séminaire de Théorie des Nombres, Paris 1988–1989, Progr. Math., vol. 91, (Birkhäuser Boston, Boston, MA, 1990), 2741.Google Scholar
Behn, A. and Van der Merwe, A. B., ‘An algorithmic version of the theorem by Latimer and MacDuffee for $2\times 2$ integral matrices’, Linear Algebra Appl. 346 (2002), 114.CrossRefGoogle Scholar
Bley, W. and Wilson, S. M. J., ‘Computations in relative algebraic $K$ -groups’, LMS J. Comput. Math. 12 (2009), 166194.CrossRefGoogle Scholar
Chistov, A., Ivanyos, G. and Karpinski, M., ‘Polynomial time algorithms for modules over finite dimensional algebras’, in Proceedings of the 1997 International Symposium on Symbolic and Algebraic Computation, (ACM, New York, 1997), 6874.Google Scholar
Cohen, H., A Course in Computational Algebraic Number Theory, Graduate Texts in Mathematics, vol. 138 (Springer-Verlag, Berlin, 1993).CrossRefGoogle Scholar
Cohen, H., Advanced Topics in Computational Number Theory, Graduate Texts in Mathematics, vol. 193 (Springer-Verlag, New York, 2000).CrossRefGoogle Scholar
Curtis, C. W. and Reiner, I., Methods of Representation Theory, vol. I (John Wiley & Sons, Inc., New York, 1981).Google Scholar
Curtis, C. W. and Reiner, I., Methods of Representation Theory, vol. II (John Wiley & Sons, Inc., New York, 1987).Google Scholar
Dembélé, L. and Donnelly, S., Computing Hilbert Modular Forms over Fields with Nontrivial Class Group, Algorithmic Number Theory, Lecture Notes in Comput. Sci., vol. 5011 (Springer, Berlin, 2008), 371386.Google Scholar
Eisenträger, K., Hallgren, S., Kitaev, A. and Song, F., ‘A quantum algorithm for computing the unit group of an arbitrary degree number field’, in STOC’14—Proceedings of the 2014 ACM Symposium on Theory of Computing (ACM, New York, 2014), 293302.Google Scholar
Eick, B., Hofmann, T., and O’Brien, E. A., ‘The conjugacy problem in $\mathrm{GL}(n,\mathbb{Z})$ ’, J. Lond. Math. Soc. (2) 100(3) (2019), 731756.CrossRefGoogle Scholar
Faddeev, D. K., ‘On the equivalence of systems of integral matrices’, Izv. Akad. Nauk SSSR Ser. Mat. 30 (1966), 449454.Google Scholar
Fieker, C., Hart, W., Hofmann, T. and Johansson, F., ‘Nemo/Hecke: computer algebra and number theory packages for the Julia programming language’, in ISSAC’17—Proceedings of the 2017 ACM International Symposium on Symbolic and Algebraic Computation (ACM, New York, 2017), 157164.CrossRefGoogle Scholar
Fieker, C., Hofmann, T. and Sircana, C., ‘On the construction of class fields’, in ANTS XIII—Proceedings of the Thirteenth Algorithmic Number Theory Symposium, Open Book Ser., vol. 2 (Math. Sci. Publ., Berkeley, CA, 2019), 239255.Google Scholar
Friedl, K. and Ronyai, L., ‘Polynomial time solutions of some problems in computational algebra’, in STOC '85: Proceedings of the Seventeenth Annual ACM Symposium on Theory of Computing (ACM, New York, 1985), 153162.CrossRefGoogle Scholar
Friedrichs, C., ‘Berechnung von Maximalordnungen über Dedekindringen’, Ph.D. thesis, Technische Universität Berlin (2000).Google Scholar
Fröhlich, A., Local Fields, Algebraic Number Theory (Proc. Instructional Conf., Brighton, 1965) (Thompson, Washington, DC, 1967), 141.Google Scholar
Grunewald, F. J., Solution of the Conjugacy Problem in Certain Arithmetic Groups, Word Problems, II (Conf. on Decision Problems in Algebra, Oxford, 1976), Stud. Logic Foundations Math., vol. 95 (North-Holland, Amsterdam-New York, 1980), 101139.Google Scholar
Guralnick, R. M., ‘A note on the local-global principle for similarity of matrices’, Linear Algebra Appl. 30 (1980), 241245.CrossRefGoogle Scholar
Hofmann, T. and Johnston, H., ‘Computing isomorphisms between lattices’, Math. Comp. 89(326) (2020), 29312963.CrossRefGoogle Scholar
Husert, D., Similarity of integer matrices, Ph.D. thesis, University of Paderborn, 2017.Google Scholar
Ivanyos, G. and Rónyai, L., ‘Finding maximal orders in semisimple algebras over $\mathit{\mathsf{Q}}$ ’, Comput. Complexity 3(3) (1993), 245261.CrossRefGoogle Scholar
Ivanyos, G., Rónyai, L. and Schicho, J., ‘Splitting full matrix algebras over algebraic number fields’, J. Algebra 354 (2012), 211223.CrossRefGoogle Scholar
Kirschmer, M. and Voight, J., ‘Algorithmic enumeration of ideal classes for quaternion orders’, SIAM J. Comput. 39(5) (2010), 17141747.CrossRefGoogle Scholar
Lenstra, A. K., Factoring Polynomials over Algebraic Number Fields, Computer Algebra (London, 1983), Lecture Notes in Comput. Sci., vol. 162 (Springer, Berlin, 1983), 245254.Google Scholar
Lenstra, H. W. Jr., ‘Algorithms in algebraic number theory’, Bull. Amer. Math. Soc. (N.S.) 26(2) (1992), 211244.CrossRefGoogle Scholar
Latimer, C. G. and MacDuffee, C. C., ‘A correspondence between classes of ideals and classes of matrices’, Ann. of Math. (2) 34(2) (1933), 313316.CrossRefGoogle Scholar
Lenstra, H. W. Jr. and Pomerance, Carl, ‘A rigorous time bound for factoring integers’, J. Amer. Math. Soc. 5(3) (1992), 483516.CrossRefGoogle Scholar
Marseglia, S., ‘Computing the ideal class monoid of an order’, J. Lond. Math. Soc. (2) 101(3) (2020), 9841007.CrossRefGoogle Scholar
Nebe, G. and Steel, A., ‘Recognition of division algebras’, J. Algebra 322(3) (2009), 903909.CrossRefGoogle Scholar
Odlyzko, A., ‘Discrete logarithms: the past and the future’, Des. Codes Cryptogr. 19(2–3) (2000), 129145.CrossRefGoogle Scholar
Opgenorth, J., Plesken, W. and Schulz, T., ‘Crystallographic algorithms and tables’, Acta Cryst. Sect. A 54(5) (1998), 517531.CrossRefGoogle Scholar
Oscar – Open Source Computer Algebra Research System, version 0.10.0, 2022.Google Scholar
Page, A., ‘An algorithm for the principal ideal problem in indefinite quaternion algebras’, LMS J. Comput. Math. 17(suppl. A) (2014), 366384.Google Scholar
Reiner, I., Maximal Orders, London Mathematical Society Monographs, vol. 28 (The Clarendon Press Oxford University Press, Oxford, 2003).Google Scholar
Ronyai, L., ‘Simple algebras are difficult’, in Proceedings of the Nineteenth Annual ACM Symposium on Theory of Computing (Association for Computing Machinery, New York, 1987) 398408.Google Scholar
Rosenberg, J., Algebraic $K$ -Theory and Its Applications, Graduate Texts in Mathematics, vol. 147 (Springer-Verlag, New York, 1994).Google Scholar
Sarkisyan, R. A., ‘Conjugacy problem for sets of integral matrices’, Math. Notes 25 (1979), 419432.CrossRefGoogle Scholar
Shor, P. W., ‘Polynomial-time algorithms for prime factorization and discrete logarithms on a quantum computer’, SIAM J. Comput. 26(5) (1997), 14841509.CrossRefGoogle Scholar
Taylor, D. E., ‘Pairs of generators for matrix groups I’, The Cayley Bulletin (3) (1987), 7685.Google Scholar
Villard, G., ‘Computation of the Smith normal form of polynomial matrices’, in Proceedings of the 1993 International Symposium on Symbolic and Algebraic Computation (ACM, New York, 1993) 209217.Google Scholar