\frac{x - lo}{hi - lo}
\frac{hi}{lo} \cdot \frac{hi}{lo} - hi \cdot \frac{x}{lo \cdot lo}
(FPCore (lo hi x) :precision binary64 (/ (- x lo) (- hi lo)))
(FPCore (lo hi x) :precision binary64 (- (* (/ hi lo) (/ hi lo)) (* hi (/ x (* lo lo)))))
double code(double lo, double hi, double x) {
return (x - lo) / (hi - lo);
}
double code(double lo, double hi, double x) {
return ((hi / lo) * (hi / lo)) - (hi * (x / (lo * lo)));
}



Bits error versus lo



Bits error versus hi



Bits error versus x
Results
Initial program 62.0
Taylor expanded in lo around inf 64.0
Simplified51.9
Taylor expanded in hi around inf 57.9
Simplified51.9
Taylor expanded in hi around inf 64.0
Simplified51.5
Applied div-inv_binary6451.5
Applied associate-*l*_binary6451.5
Simplified51.5
Final simplification51.5
herbie shell --seed 2021224
(FPCore (lo hi x)
:name "(/ (- x lo) (- hi lo))"
:precision binary64
:pre (and (< lo -1e+308) (> hi 1e+308))
(/ (- x lo) (- hi lo)))