big.hlp 10.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256
  1. Beryl Morrison, 4 June 1982
  2. BigNum Structure and "Constants"
  3. The current PSL bignum package was written using vectors of "Big Digits" or
  4. "Bigits". The first element of each vector is either BIGPOS or BIGNEG,
  5. depending whether the number is positive or negative. A bignum of the form
  6. [BIGPOS a b c d]
  7. has a value of
  8. a + b * bbase!* + c * bbase!* ** 2 + d * bbase!* ** 3
  9. BBase!* is a fluid variable which varies from one machine to another. For the
  10. VAX and the DEC-20, it is calculated as follows:
  11. bbits!* := (n-1)/2;
  12. bbase!* := 2 ** bbits!*;
  13. "n" is the total number of bits per word on the given machine. On the DEC-20,
  14. n is 36, so bbits!* is 17 and bbase!* is 131072. On the VAX, n is 32, so
  15. bbits!* is 15 and bbase!* is 32768.
  16. There are some other constants used in the system as well. The sources are in
  17. pu:bigbig.red on the DEC-20, /u/benson/psl-dist/util/bigbig.red on the VAX.
  18. Starting BigNums
  19. "Load Big;" will bring in the bignum package. A file called big.lap loads
  20. arith.b which provides an interface via tags for when inum functions
  21. and when bignum functions should be used; (sources are in
  22. test-arith.red)
  23. vector-fix.b which provides a means of truncating vectors without copying
  24. them;
  25. bigbig.b which provides the bignum versions of functions as required by
  26. arith.b;
  27. bigface.b which provides the final interface between bigbig.b and
  28. arith.b.
  29. The order of loading the files must remain as shown; arith and vector-fix may
  30. be swapped, but otherwise function definitions must be presented in the order
  31. given.
  32. Building the BigNum Package
  33. Each of the individual files may be rebuilt (to form a new *.b file)
  34. separately. A file XXX.red may be rebuilt as follows:
  35. [1] faslout "YYY";
  36. [2] in "XXX.red"$
  37. 2
  38. [3] faslout;
  39. On the DEC-20, the resulting YYY.b file is put on the directory pl:; on the
  40. VAX, it is put on the connected directory. They should be on pl: on the DEC-20
  41. for public access, and on /usr/local/lib/psl on the VAX.
  42. The Functions in BigBig
  43. The functions defined by BigBig for bignums are as follows:
  44. BLOr Takes two BigNum arguments, returning a bignum. Calls BSize,
  45. GtPos, PosIfZero.
  46. BLXOr Takes two BigNum arguments, returning a bignum. Calls BSize,
  47. GtPos, TrimBigNum1.
  48. BLAnd Takes two BigNum arguments, returning a bignum. Calls BSize,
  49. GtPos, TrimBigNum1.
  50. BLNot Takes one BigNum argument, returning a bignum. Calls BMinus,
  51. BSmallAdd.
  52. BLShift Takes two BigNum arguments, returning a bignum. Calls BMinusP,
  53. BQuotient, BTwoPower, BMinus, BTimes2.
  54. BMinus Takes one BigNum argument, returning a bignum. Calls BZeroP,
  55. BSize, BMinusP, GtPos, GtNeg.
  56. BMinusP Takes one BigNum argument, returning a bignum or NIL.
  57. BPlus2 Takes two BigNum arguments, returning a bignum. Calls BMinusP,
  58. BDifference2, BMinus, BPlusA2.
  59. BDifference BZeroP, BMinus, BMinusP, BPlusA2, BDifference2.
  60. BTimes2 Takes two BigNum arguments, returning a bignum. Calls BSize,
  61. BMinusP, GtPos, GtNeg, BDigitTimes2, PosIfZero, TrimBigNum1.
  62. BDivide Takes two BigNum arguments, returning a pair of bignums. Calls
  63. BSize, GtPos, BSimpleDivide, BHardDivide.
  64. BGreaterP Takes two BigNum arguments, returning a bignum or NIL. Calls
  65. BMinusP, BDifference.
  66. BLessP Takes two BigNum arguments, returning a bignum or NIL. Calls
  67. BMinusP, BDifference.
  68. BAdd1 Takes a BigNum argument, returning a bignum. Calls BSmallAdd.
  69. BSub1 Takes a BigNum argument, returning a bignum. Calls
  70. BigSmallDiff.
  71. 3
  72. FloatFromBigNum Takes a bignum, returning a float. Calls BZeroP, BGreaterP,
  73. BLessP, BSize, BMinusP.
  74. BChannelPrin2 Calls BigNumP, NonBigNumError, BSimpleDivide, BSize, BZeroP.
  75. BRead Calls GtPos, BReadAdd, BMinus.
  76. BigFromFloat Takes a float and converts to a bignum. Calls BNum, BPlus2,
  77. BTimes2, BTwoPower, FloatFromBigNum, BMinus, PosIfZero.
  78. The following functions are support functions for those given above.
  79. SetBits Takes as an argument the total number of bits per word on a
  80. given machine; sets some fluid variables accordingly. NOTE:
  81. FloatHi!* must be changed separately from this procedure by
  82. hand when moving to a new machine both in bigbig.red and in
  83. bigface.red. Calls TwoPower, BNum, BMinus, BSub1, BTwoPower,
  84. BAdd1.
  85. BigNumP Checks if the argument is a bignum. Calls no special
  86. functions.
  87. NonBigNumError Calls no special functions.
  88. BSize Gives size of a bignum, i.e. total number of bigits (the tag
  89. "BIGPOS" or "BIGNEG" is number 0). Calls BigNumP.
  90. PosIfZero Takes a bignum; if it is a negative zero, it is converted to a
  91. positive zero. Calls BPosOrNegZeroP, BMinusP.
  92. BPosOrNegZeroP Takes a BigNum; checks if magnitude is zero. Calls BSize.
  93. GtPos Takes an inum/fixnum. Returns a vector of size of the
  94. argument; first (i.e.0th) element is BIGPOS, others are NIL.
  95. GtNeg Takes an inum/fixnum. Returns a vector of size of the
  96. argument; first (i.e.0th) element is BIGNEG, others are NIL.
  97. TrimBigNum Takes a BigNum as an argument; truncates any trailing "NIL"s.
  98. Calls BigNumP, NonBigNumError, TrimBigNum1, BSize.
  99. TrimBigNum1 Does dirty work for TrimBigNum, with second argument the size
  100. of the BigNum.
  101. Big2Sys Calls BLessP, BGreaterP, BSize, BMinusP.
  102. TwoPower Takes and returns a fix/inum. 2**n.
  103. BTwoPower Takes a fix/inum or bignum, returns a bignum of value 2**n.
  104. Calls BigNumP, Big2Sys, GtPos, TwoPower, TrimBigNum1.
  105. BZeroP Checks size of BigNum (0) and sign. Calls BSize, BMinusP.
  106. 4
  107. BOneP Calls BMinusP, BSize.
  108. BAbs Calls BMinusP, BMinus.
  109. BGeq Calls BLessP.
  110. BLeq Calls BGreaterP.
  111. BMax Calls BGeq.
  112. BMin Calls BLeq.
  113. BExpt Takes a BigNum and a fix/inum. Calls Int2B, BTimes2,
  114. BQuotient.
  115. AddCarry Support for trapping the carry in addition.
  116. BPlusA2 Does the dirty work of addition of two BigNums with signs
  117. pre-checked and identical. Calls BSize, GtNeg, GtPos,
  118. AddCarry, PosIfZero, TrimBigNum1.
  119. SubCarry Mechanism to get carry in subtractions.
  120. BDifference2 Does the dirty work of subtraction with signs pre-checked and
  121. identical. Calls BSize, GtNeg, GtPos, SubCarry, PosIfZero,
  122. TrimBigNum1.
  123. BDigitTimes2 Multiplies the first argument (BigNum) by a single Bigit of the
  124. second BigNum argument. Returns the partially completed
  125. result. Calls no special functions.
  126. BSmallTimes2 Takes a BigNum argument and a fixnum argument, returning a
  127. bignum. Calls GtPos, BMinusP, GtNeg, PosIfZero, TrimBigNum1.
  128. BQuotient Takes two BigNum arguments, returning a bignum. Calls BDivide.
  129. BRemainder Takes two BigNum arguments, returning a bignum. Calls BDivide.
  130. BSimpleQuotient Calls BSimpleDivide.
  131. BSimpleRemainder
  132. Calls BSimpleDivide.
  133. BSimpleDivide Used to divide a BigNum by an inum. Returns a dotted pair of
  134. quotient and remainder, both being bignums. Calls BMinusP,
  135. GtPos, GtNeg, PosIfZero, TrimBigNum1.
  136. BHardDivide Used to divide two "true" BigNums. Returns a pair of bignums.
  137. Algorithm taken from Knuth. Calls BMinusP, GtPos, GtNeg, BAbs,
  138. BSmallTimes2, BSize, BDifference, BPlus2, TrimBigNum1,
  139. BSimpleQuotient, PosIfZero.
  140. 5
  141. BReadAdd Calls BSmallTimes2, BSmallAdd.
  142. BSmallAdd Adds an inum to a BigNum, returning a bignum. Calls BZeroP,
  143. BMinusP, BMinus, BSmallDiff, BSize, GtPos, AddCarry, PosIfZero,
  144. TrimBigNum1.
  145. BNum Takes an inum and returns a BigNum of one bigit; test that the
  146. inum is less than bbase!* is assumed done. Calls GtPos, GtNeg.
  147. BSmallDiff Calls BZeroP, BMinusP, BMinus, BSmallAdd, GtPos, SubCarry,
  148. PosIfZero, TrimBigNum1.
  149. int2b Takes a fix/inum and converts to a BigNum. Calls BNum, BRead.
  150. Problems
  151. - Should the "vectors" be changed to hwords?
  152. - Should there be primitives so that each bigit uses almost the whole
  153. word instead of almost half the word? This would involve writing
  154. "overflow" functions, checking and trapping overflow in operations
  155. such as multiplication. This would allow integers to be returned as
  156. inums or fixnums if they are geq the current bbase!* and lessp 2 **
  157. (n-1). Currently, anything bbase!* or larger is kept as a bignum
  158. once the bignum package is loaded.
  159. - Make the constants real constants instead of fluids: bbase!*,
  160. bbits!*, floathi!*, floatlow!*, logicalbits!*, wordhi!*, wordlow!*,
  161. syshi!*, syslo!*, digit2letter!*. Carry!* should be a fluid.
  162. - Try to make the whole package loaded as one *.b file.
  163. - Change arith.b so that divide is used for the interface instead of
  164. quotient and remainder. As it stands, doing a "Divide" when bignums
  165. are loaded would mean doing the quotient and then the remainder
  166. separately, although Knuth's algorithm computes them together.
  167. - Get rid of superfluous functions.
  168. - Put in more calls to NonBigNumError for greater safety?