Academia.eduAcademia.edu

Polynomial Factorization in Maple 2019

Communications in Computer and Information Science

Abstract

Maple 2019 has a new multivariate polynomial factorization algorithm for factoring polynomials in Z[x 1 , x 2 , ..., x n ], that is, polynomials in n variables with integer coefficients. The new algorithm, which we call MTSHL, was developed by the authors at Simon Fraser University. The algorithm and its sub-algorithms have been published in a sequence of papers [3-5]. It was integrated into the Maple library in early 2018 by Baris Tuncer under a MITACS internship with Maplesoft. MTSHL is now the default factoring algorithm in Maple 2019. The multivariate factorization algorithm in all previous versions of Maple is based mainly on the work of Paul Wang in [6, 7]. Keith Geddes is the main author of the Maple code. The algorithm and sub-algorithms are described in Chapter 6 of [1]. Wang's algorithm is still available in Maple 2019 with the method="Wang" option to the factor command. Wang's method can be exponential in n the number of variables. MTSHL is a random polynomial time algorithm. In [3] we found that it is faster than previous polynomial time methods of Kaltofen [2] and Zippel [8] and competitive with Wang's method in cases where Wang's method is not exponential in n. Here we give an overview of the main idea in MTSHL. Let a be the input polynomial to be factored. Suppose a = f g for two irreducible factors f, g ∈ Z[x 1 ,. .. , x n ]. The multivariate polynomial factorization algorithm used in all computer algebra systems is based on Multivariate Hensel Lifting (MHL). For a description of MHL see Chapter 6 of [1]. MHL first chooses integers α 2 , α 3 ,. .. , α n that satisfy certain conditions and factors the univariate image a 1 = a(x 1 , α 2 ,. .. , α n) in Z[x 1 ]. Suppose a 1 (x 1) = f 1 (x 1)g 1 (x 1) and f 1 (x 1) = f (x 1 , α 2 ,. .. , α n) and g 1 (x 1) = g(x 1 , α 2 ,. .. , α n). Next MHL begins Hensel lifting. Wang's design of Hensel lifting recovers the variables x 2 ,. .. , x n in the factors f and g one at a time in a loop. Let us use the notation