- Addition-subtraction chain
An addition-subtraction chain, a generalization of
addition chain s to include subtraction, is asequence "a"0, "a"1, "a"2, "a"3, ... that satisfies::
An addition-subtraction chain for "n", of length "L", is an addition-subtraction chain such that . That is, one can thereby compute "n" by "L" additions and/or subtractions. (Note that "n" need not be positive. In this case, one may also include "a"-1=0 in the sequence, so that "n"=-1 can be obtained by a chain of length 1.)
By definition, every addition chain is also an addition-subtraction chain, but not vice-versa. Therefore, the length of the "shortest" addition-subtraction chain for "n" is bounded above by the length of the shortest addition chain for "n". In general, however, the determination of a minimal addition-subtraction chain (like the problem of determining a minimum addition chain) is a difficult problem for which no efficient algorithms are currently known. The related problem of finding an optimal
addition sequence isNP-complete (Downey et al., 1981), but it is not known for certain whether finding optimal addition or addition-subtraction chains isNP-hard .For example, one addition-subtraction chain is: , , , . This is not a "minimal" addition-subtraction chain for "n"=3, however, because we could instead have chosen . The smallest "n" for which an addition-subtraction chain is shorter than the minimal addition chain is "n"=31, which can be computed in only 6 additions (rather than 7 for the minimal addition chain):
:
Like an addition chain, an addition-subtraction chain can be used for
addition-chain exponentiation : given the addition-subtraction chain of length "L" for "n", the power can be computed by multiplying or dividing by "x" "L" times, where the subtractions correspond to divisions. This is potentially efficient in problems where division is an inexpensive operation, most notably for exponentiation onelliptic curve s where division corresponds to a mere sign change (as proposed by Morain and Olivos, 1990).References
* Hugo Volger, "Some results on addition/subtraction chains," "Information Processing Letters" 20, pp. 155-160 (1985).
* François Morain and Jorge Olivos, " [ftp://ftp.inria.fr/INRIA/publication/Theses/TU-0144/ch4.ps Speeding up the computations on an elliptic curve using addition-subtraction chains] ," "RAIRO Informatique théoretique et application" 24, pp. 531-543 (1990).
* Peter Downey, Benton Leong, and Ravi Sethi, "Computing sequences with addition chains," "SIAM J. Computing" 10 (3), 638-646 (1981).
* [http://www.research.att.com/~njas/sequences/A128998 Sequence A128998] , length of minimum addition-subtraction chain, "The On-Line Encyclopedia of Integer Sequences ".
Wikimedia Foundation. 2010.