[Date Index]
[Thread Index]
[Author Index]
Re: Factoring a polynomial with many variables
*To*: mathgroup at smc.vnet.net
*Subject*: [mg129784] Re: Factoring a polynomial with many variables
*From*: Andrzej Kozlowski <akozlowski at gmail.com>
*Date*: Wed, 13 Feb 2013 04:50:31 -0500 (EST)
*Delivered-to*: l-mathgroup@mail-archive0.wolfram.com
*Delivered-to*: l-mathgroup@wolfram.com
*Delivered-to*: mathgroup-newout@smc.vnet.net
*Delivered-to*: mathgroup-newsend@smc.vnet.net
*References*: <20130212082342.5E25468DD@smc.vnet.net>
On 12 Feb 2013, at 09:23, topikarki at yahoo.com wrote:
> Is there a way to factor a polynomial in many variables. I have not studied
> algebraic geometry, or Buchberger algorithm.
>
Is your question a Mathematica question or a algorithmic algebra question? This is significant because this is a Mathematica group. Besides, do you want to factor over the integers or over the complexes or the reals? This is also significant.
In any case,the answer to all these questions is: "yes". For factoring over the integers just use Factor:
p = 5 + 5 x^2 + 7 x^3 + x^5 - 6 x y - 3 x^3 y + 3 x^4 y - 9 x^2 y^2;
Factor[p]
(5 + x^3 - 3 x y) (7 + x^2 + 3 x y)
If you want to factor over other fields you have to specify the field extension.
As for the algorithmic algebra: the classical way to factor univariate polynomials is the so called Berlekamp-Hensel algorithm, which has been generalised to the multivariate case by Wang. A faster algorithm was presented about 30 years ago by Kaltofen, in his PhD thesis. I have not followed any subsequent developments and am not sure if Mathematica implements only the original Wang algorithm (as seems to be suggested by the documentation) or later improvements.
PS. Groebner basis and, in particular, Buchsberger's algorithm, don't really enter into this.
Prev by Date:
**Re: Differencing two equations**
Next by Date:
**Re: Factoring a polynomial with many variables**
Previous by thread:
**Factoring a polynomial with many variables**
Next by thread:
**Re: Factoring a polynomial with many variables**
| |