On 15 August 2017 at 18:42, Nils Bruin <nbr...@sfu.ca> wrote:
> On Tuesday, August 15, 2017 at 7:21:03 AM UTC-7, chandra chowdhury wrote:
>>
>> Is it possible to factor polynomials completely over modular ring?
>>
>> Like
>> x = var('x')
>> factor(x^5-x, IntegerModRing(25)['x'])
>> gives
>>
>> (x-1)(x+1)(x^2+1)*x
>
> The second argument is simply ignored here, by the looks of it
>
> sage: factor(x^5-x,"moo")
> (x^2 + 1)*(x + 1)*(x - 1)*x
>
> You could file that as a (mild) bug.
>
> Factorization of Z/25 directly isn't implemented:
>
> sage: R=IntegerModRing(25)
> sage: Rx.<x>=R[]
> sage: factor(x^5-x)
> NotImplementedError: factorization of polynomials over rings with composite
> characteristic is not implemented
>
> Root finding is apparently implemented:
>
> sage: (x^5-x).roots(multiplicities=False)
> [0, 1, 7, 18, 24]
>
> Alternatively, (beccause you're working mod a prime power) you could look at
> p-adic rings:
>
> sage: R=Zp(5,2,"fixed-mod",print_mode="terse")
> sage: Rx.<x>=R[]
> sage: (x^5-x).factor()
> ((1 + O(5^2))*x + (1 + O(5^2))) * ((1 + O(5^2))*x + (7 + O(5^2))) * ((1 +
> O(5^2))*x + (18 + O(5^2))) * ((1 + O(5^2))*x + (24 + O(5^2))) * ((1 +
> O(5^2))*x + (0 + O(5^2)))
>
> The "+O(5^2)" is a p-adic thing that would be nice to suppress here.

A relevant point, perhaps, is that polynomials over Z/25Z do not form
a unique factorization domain (or even a domain) so even the
definition of what factors you might want to see is unclear.
Following Nils, for a prime power modulus, a sensible definition is to
take an approximation of the p-adic factorization.  The for a general
modulus the Chinese remainder theorem is probably relevant.

To illustrate my non-uniqueness point, modulo 8 we have x^2-1 =
(x+1)(x-1) = (x-3)(x+3).

John Cremona

>
>
> --
> You received this message because you are subscribed to the Google Groups
> "sage-support" group.
> To unsubscribe from this group and stop receiving emails from it, send an
> email to sage-support+unsubscr...@googlegroups.com.
> To post to this group, send email to sage-support@googlegroups.com.
> Visit this group at https://groups.google.com/group/sage-support.
> For more options, visit https://groups.google.com/d/optout.

-- 
You received this message because you are subscribed to the Google Groups 
"sage-support" group.
To unsubscribe from this group and stop receiving emails from it, send an email 
to sage-support+unsubscr...@googlegroups.com.
To post to this group, send email to sage-support@googlegroups.com.
Visit this group at https://groups.google.com/group/sage-support.
For more options, visit https://groups.google.com/d/optout.

Reply via email to