racket/collects/math/private/flonum
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
..
expansion Fixed some limits and accuracy issues with flonum expansions 2013-01-19 18:09:44 -07:00
flonum-bits.rkt Precise flonum tests (error usually must be <= 0.5 ulp), and prerequisite 2012-12-27 17:30:04 -07:00
flonum-constants.rkt Initial math library commit. The history for these changes is preserved 2012-11-16 11:39:51 -07:00
flonum-error.rkt Fixed some limits and accuracy issues with flonum expansions 2013-01-19 18:09:44 -07:00
flonum-exp.rkt Added flexp2', fllog2', `fllogb'; refactored and documented flonum testing 2013-01-28 17:44:33 -07:00
flonum-factorial.rkt Precise flonum tests (error usually must be <= 0.5 ulp), and prerequisite 2012-12-27 17:30:04 -07:00
flonum-functions.rkt Fixed some limits and accuracy issues with flonum expansions 2013-01-19 18:09:44 -07:00
flonum-log.rkt Added flexp2', fllog2', `fllogb'; refactored and documented flonum testing 2013-01-28 17:44:33 -07:00
flonum-log1pmx.rkt Initial math library commit. The history for these changes is preserved 2012-11-16 11:39:51 -07:00
flonum-more-functions.rkt Precise flonum tests (error usually must be <= 0.5 ulp), and prerequisite 2012-12-27 17:30:04 -07:00
flonum-polyfun.rkt Initial math library commit. The history for these changes is preserved 2012-11-16 11:39:51 -07:00
flonum-search.rkt Initial math library commit. The history for these changes is preserved 2012-11-16 11:39:51 -07:00
flvector-syntax.rkt Finished array documentation! 2012-11-29 15:45:17 -07:00
flvector.rkt Finished array documentation! 2012-11-29 15:45:17 -07:00
utils.rkt Fixed some limits and accuracy issues with flonum expansions 2013-01-19 18:09:44 -07:00