IntegerRoots I¶
intfact.spad line 201 [edit on github]
The IntegerRoots package computes square roots and nth roots of integers efficiently.
- approxNthRoot: (I, NonNegativeInteger) -> I
- approxRoot(n, r)returns an approximation- xto- n^(1/r)such that- -1 < x - n^(1/r) < 1
- approxSqrt: I -> I
- approxSqrt(n)returns an approximation- xto- sqrt(n)such that- -1 < x - sqrt(n) < 1. Returns 0 if- nis negative. A variable precision Newton iteration is used. The running time is- O( log(n)^2 ).
- perfectNthPower?: (I, NonNegativeInteger) -> Boolean
- perfectNthPower?(n, r)returns- trueif- nis an- rth power and- falseotherwise
- perfectNthRoot: (I, NonNegativeInteger) -> Union(I, failed)
- perfectNthRoot(n, r)returns the- rth root of- nif- nis an- rth power and returns “failed” otherwise
- perfectNthRoot: I -> Record(base: I, exponent: NonNegativeInteger)
- perfectNthRoot(n)returns- [x, r], where- n = x\^rand- ris the largest integer such that- nis a perfect- rth power
- perfectSqrt: I -> Union(I, failed)
- perfectSqrt(n)returns the square root of- nif- nis a perfect square and returns “failed” otherwise
- perfectSquare?: I -> Boolean
- perfectSquare?(n)returns- trueif- nis a perfect square and- falseotherwise