Rational reconstruction (mathematics)

From The Right Wiki
Jump to navigationJump to search

In mathematics, rational reconstruction is a method that allows one to recover a rational number from its value modulo a sufficiently large integer.

Problem statement

In the rational reconstruction problem, one is given as input a value nr/s(modm). That is, n is an integer with the property that nsr(modm). The rational number r/s is unknown, and the goal of the problem is to recover it from the given information. In order for the problem to be solvable, it is necessary to assume that the modulus m is sufficiently large relative to r and s. Typically, it is assumed that a range for the possible values of r and s is known: |r|<N and 0<s<D for some two numerical parameters N and D. Whenever m>2ND and a solution exists, the solution is unique and can be found efficiently.

Solution

Using a method from Paul S. Wang, it is possible to recover r/s from n and m using the Euclidean algorithm, as follows.[1][2] One puts v=(m,0) and w=(n,1). One then repeats the following steps until the first component of w becomes N. Put q=v1w1, put z = v − qw. The new v and w are then obtained by putting v = w and w = z. Then with w such that w1N, one makes the second component positive by putting w = −w if w2<0. If w2<D and gcd(w1,w2)=1, then the fraction rs exists and r=w1 and s=w2, else no such fraction exists.

References

  1. Wang, Paul S. (1981), "A p-adic algorithm for univariate partial fractions", Proceedings of the Fourth International Symposium on Symbolic and Algebraic Computation (SYMSAC '81), New York, NY, USA: Association for Computing Machinery, pp. 212–217, doi:10.1145/800206.806398, ISBN 0-89791-047-8, S2CID 10695567
  2. Wang, Paul S.; Guy, M. J. T.; Davenport, J. H. (May 1982), "P-adic reconstruction of rational numbers", SIGSAM Bulletin, 16 (2), New York, NY, USA: Association for Computing Machinery: 2–3, CiteSeerX 10.1.1.395.6529, doi:10.1145/1089292.1089293, S2CID 44536107.