Смекни!
smekni.com

Modular Arithmetic Essay Research Paper Modular arithmetic

Modular Arithmetic Essay, Research Paper

Modular arithmetic can be used to compute exactly, at low cost, a set of simple

computations. These include most geometric predicates, that need to be checked

exactly, and especially, the sign of determinants and more general polynomial

expressions. Modular arithmetic resides on the Chinese Remainder Theorem, which

states that, when computing an integer expression, you only have to compute it

modulo several relatively prime integers called the modulis. The true integer

value can then be deduced, but also only its sign, in a simple and efficient

maner. The main drawback with modular arithmetic is its static nature, because

we need to have a bound on the result to be sure that we preserve ourselves from

overflows (that can’t be detected easily while computing). The smaller this

known bound is, the less computations we have to do. We have developped a set of

efficient tools to deal with these problems, and we propose a filtered approach,

that is, an approximate computation using floating point arithmetic, followed,

in the bad case, by a modular computation of the expression of which we know a

bound, thanks to the floating point computation we have just done. Theoretical

work has been done in common with , , Victor Pan and. See the bibliography for

details. At the moment, only the tools to compute without filters are available.

The aim is now to build a compiler, that produces exact geometric predicates

with the following scheme: filter + modular computation. This approach is not

compulsory optimal in all cases, but it has the advantage of simpleness in most

geometric tests, because it’s general enough. Concerning the implementation, the

Modular Package contains routines to compute sign of determinants and polynomial

expressions, using modular arithmetic. It is already usable, to compute signs of

determinants, in any dimension, with integer entries of less than 53 bits. In

the near future, we plan to add a floating point filter before the modular

computation.