racket/collects/math/private
Neil Toronto aed3b39546 Added flexp2', fllog2', `fllogb'; refactored and documented flonum testing
Note: With this refactoring, `math/utils' no longer depends on `rackunit'.

* (flexp2 x) computes (flexpt 2.0 x) but in about 1/3 the time for integer
  `x' using a lookup table. Written for exact argument reduction in `fllog2'
  after discovering that (flexpt 2.0 x) was the main performance bottleneck.

* (fllog2 x) computes (/ (fllog x) (fllog 2.0)) with near perfect accuracy.
  Invented an algorithm to compute it with at least 8 extra bits before
  final rounding; quite pleased with the result. Needed `fllog2' to ensure
  (fllogb 2.0 x) would be exact when `x' is a power of two.

* (fllogb b x) computes (/ (fllog x) (fllog b)) with better accuracy, and
  also handles limit values in a way that's consistent with the mathematical
  limits. When those are ambiguous, it's consistent with `flexpt', which
  follows IEEE 754 and C99. Otherwise returns +nan.0. See docs for details.

* `bflogb' is currently just for testing `fllogb'.

* Refactored FPU testing and documented it. So far, the only documented way
  to do it is by calling `test-floating-point', which runs a comprehensive
  deterministic+randomized suite of tests and returns a list representing
  failed tests. I'll document individual tests after I document flonum
  expansions and result/error functions like `fl+/error'.

* Added `fllog2' and `fllogb' to the flonum tests.
2013-01-28 17:44:33 -07:00
..
array Made arrays strict by default; please merge to release 2013-01-15 13:53:28 -07:00
base Finished array documentation! 2012-11-29 15:45:17 -07:00
bigfloat Added flexp2', fllog2', `fllogb'; refactored and documented flonum testing 2013-01-28 17:44:33 -07:00
distributions Renamed make-flexp/base' to make-flexpt' 2012-12-03 22:45:31 -07:00
flonum Added flexp2', fllog2', `fllogb'; refactored and documented flonum testing 2013-01-28 17:44:33 -07:00
functions Renamed make-flexp/base' to make-flexpt' 2012-12-03 22:45:31 -07:00
matrix Fixed major performance issue with matrix arithmetic; please merge to 5.3.2 2013-01-21 22:04:04 -07:00
number-theory Fixed type error in "bernoulli.rkt" 2013-01-19 18:56:37 -07:00
polynomial Initial math library commit. The history for these changes is preserved 2012-11-16 11:39:51 -07:00
statistics Fixes, docs, and API changes for `math/statistics' 2012-12-10 16:45:18 -07:00
utils Added flexp2', fllog2', `fllogb'; refactored and documented flonum testing 2013-01-28 17:44:33 -07:00
vector Fixed major performance issue with matrix arithmetic; please merge to 5.3.2 2013-01-21 22:04:04 -07:00
exception.rkt Initial math library commit. The history for these changes is preserved 2012-11-16 11:39:51 -07:00
inline-sort.rkt Initial math library commit. The history for these changes is preserved 2012-11-16 11:39:51 -07:00
parameters.rkt Finished array documentation! 2012-11-29 15:45:17 -07:00
syntax-utils.rkt Initial math library commit. The history for these changes is preserved 2012-11-16 11:39:51 -07:00
unsafe.rkt Initial math library commit. The history for these changes is preserved 2012-11-16 11:39:51 -07:00
utils.rkt Finished array documentation! 2012-11-29 15:45:17 -07:00