
Time bar (total: 3.0s)
| 1× | search |
| Probability | Valid | Unknown | Precondition | Infinite | Domain | Can't | Iter |
|---|---|---|---|---|---|---|---|
| 0% | 0% | 99.9% | 0.1% | 0% | 0% | 0% | 0 |
| 0% | 0% | 99.9% | 0.1% | 0% | 0% | 0% | 1 |
| 50% | 50% | 50% | 0.1% | 0% | 0% | 0% | 2 |
| 75% | 74.9% | 25% | 0.1% | 0% | 0% | 0% | 3 |
| 87.5% | 87.4% | 12.5% | 0.1% | 0% | 0% | 0% | 4 |
| 93.8% | 93.7% | 6.2% | 0.1% | 0% | 0% | 0% | 5 |
| 93.8% | 93.7% | 6.2% | 0.1% | 0% | 0% | 0% | 6 |
| 95.2% | 93.7% | 4.7% | 0.1% | 0% | 1.6% | 0% | 7 |
| 96% | 93.7% | 3.9% | 0.1% | 0% | 2.3% | 0% | 8 |
| 97.2% | 93.7% | 2.7% | 0.1% | 0% | 3.5% | 0% | 9 |
| 97.8% | 93.7% | 2.1% | 0.1% | 0% | 4.1% | 0% | 10 |
| 98.5% | 93.7% | 1.5% | 0.1% | 0% | 4.8% | 0% | 11 |
| 98.8% | 93.7% | 1.1% | 0.1% | 0% | 5.1% | 0% | 12 |
Compiled 10 to 8 computations (20% saved)
| 464.0ms | 8 256× | 0 | valid |
| 131.0ms | 2 941× | 0 | exit |
ival-exp: 247.0ms (71.5% of total)ival-div!: 68.0ms (19.7% of total)ival-add!: 29.0ms (8.4% of total)adjust: 2.0ms (0.6% of total)Useful iterations: 3 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 18 | 56 |
| 1 | 46 | 56 |
| 2 | 147 | 56 |
| 3 | 563 | 51 |
| 4 | 3260 | 51 |
| 1× | node-limit |
| Status | Accuracy | Program |
|---|---|---|
| ▶ | 98.0% | (/.f64 (exp.f64 a) (+.f64 (exp.f64 a) (exp.f64 b))) |
Compiled 14 to 12 computations (14.3% saved)
| Inputs |
|---|
(/.f64 (exp.f64 a) (+.f64 (exp.f64 a) (exp.f64 b))) |
(exp.f64 a) |
a |
(+.f64 (exp.f64 a) (exp.f64 b)) |
(exp.f64 b) |
b |
| Outputs |
|---|
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(hole binary64 (/ 1 (+ 1 (exp b))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(hole binary64 (+ (* a (- (/ 1 (+ 1 (exp b))) (/ 1 (pow (+ 1 (exp b)) 2)))) (/ 1 (+ 1 (exp b)))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(hole binary64 (+ (* a (- (+ (* a (- (+ (* 1/2 (/ 1 (+ 1 (exp b)))) (/ 1 (pow (+ 1 (exp b)) 3))) (* 3/2 (/ 1 (pow (+ 1 (exp b)) 2))))) (/ 1 (+ 1 (exp b)))) (/ 1 (pow (+ 1 (exp b)) 2)))) (/ 1 (+ 1 (exp b)))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(hole binary64 (+ (* a (- (+ (* a (- (+ (* 1/2 (/ 1 (+ 1 (exp b)))) (+ (* a (- (+ (* 1/6 (/ 1 (+ 1 (exp b)))) (* 3/2 (/ 1 (pow (+ 1 (exp b)) 3)))) (+ (* 1/6 (/ 1 (pow (+ 1 (exp b)) 2))) (+ (* 1/2 (/ 1 (pow (+ 1 (exp b)) 2))) (+ (* 1/2 (/ (- (/ 1 (+ 1 (exp b))) (/ 1 (pow (+ 1 (exp b)) 2))) (+ 1 (exp b)))) (/ 1 (pow (+ 1 (exp b)) 4))))))) (/ 1 (pow (+ 1 (exp b)) 3)))) (* 3/2 (/ 1 (pow (+ 1 (exp b)) 2))))) (/ 1 (+ 1 (exp b)))) (/ 1 (pow (+ 1 (exp b)) 2)))) (/ 1 (+ 1 (exp b)))))) |
#s(approx (exp a) #s(hole binary64 1)) |
#s(approx (exp a) #s(hole binary64 (+ 1 a))) |
#s(approx (exp a) #s(hole binary64 (+ 1 (* a (+ 1 (* 1/2 a)))))) |
#s(approx (exp a) #s(hole binary64 (+ 1 (* a (+ 1 (* a (+ 1/2 (* 1/6 a)))))))) |
#s(approx a #s(hole binary64 a)) |
#s(approx (+ (exp a) (exp b)) #s(hole binary64 (+ 1 (exp b)))) |
#s(approx (+ (exp a) (exp b)) #s(hole binary64 (+ 1 (+ a (exp b))))) |
#s(approx (+ (exp a) (exp b)) #s(hole binary64 (+ 1 (+ (exp b) (* a (+ 1 (* 1/2 a))))))) |
#s(approx (+ (exp a) (exp b)) #s(hole binary64 (+ 1 (+ (exp b) (* a (+ 1 (* a (+ 1/2 (* 1/6 a))))))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(hole binary64 (/ (exp a) (+ (exp a) (exp b))))) |
#s(approx (exp a) #s(hole binary64 (exp a))) |
#s(approx (+ (exp a) (exp b)) #s(hole binary64 (+ (exp a) (exp b)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(hole binary64 (/ (exp a) (+ 1 (exp a))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(hole binary64 (+ (* -1 (/ (* b (exp a)) (pow (+ 1 (exp a)) 2))) (/ (exp a) (+ 1 (exp a)))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(hole binary64 (+ (* b (- (* -1 (* b (+ (* -1 (/ (exp a) (pow (+ 1 (exp a)) 3))) (* 1/2 (/ (exp a) (pow (+ 1 (exp a)) 2)))))) (/ (exp a) (pow (+ 1 (exp a)) 2)))) (/ (exp a) (+ 1 (exp a)))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(hole binary64 (+ (* b (- (* b (- (* -1 (* b (+ (* -1 (/ (+ (* -1 (/ (exp a) (pow (+ 1 (exp a)) 3))) (* 1/2 (/ (exp a) (pow (+ 1 (exp a)) 2)))) (+ 1 (exp a)))) (+ (* -1/2 (/ (exp a) (pow (+ 1 (exp a)) 3))) (* 1/6 (/ (exp a) (pow (+ 1 (exp a)) 2))))))) (+ (* -1 (/ (exp a) (pow (+ 1 (exp a)) 3))) (* 1/2 (/ (exp a) (pow (+ 1 (exp a)) 2)))))) (/ (exp a) (pow (+ 1 (exp a)) 2)))) (/ (exp a) (+ 1 (exp a)))))) |
#s(approx (+ (exp a) (exp b)) #s(hole binary64 (+ 1 (exp a)))) |
#s(approx (+ (exp a) (exp b)) #s(hole binary64 (+ 1 (+ b (exp a))))) |
#s(approx (+ (exp a) (exp b)) #s(hole binary64 (+ 1 (+ (exp a) (* b (+ 1 (* 1/2 b))))))) |
#s(approx (+ (exp a) (exp b)) #s(hole binary64 (+ 1 (+ (exp a) (* b (+ 1 (* b (+ 1/2 (* 1/6 b))))))))) |
#s(approx (exp b) #s(hole binary64 1)) |
#s(approx (exp b) #s(hole binary64 (+ 1 b))) |
#s(approx (exp b) #s(hole binary64 (+ 1 (* b (+ 1 (* 1/2 b)))))) |
#s(approx (exp b) #s(hole binary64 (+ 1 (* b (+ 1 (* b (+ 1/2 (* 1/6 b)))))))) |
#s(approx b #s(hole binary64 b)) |
#s(approx (exp b) #s(hole binary64 (exp b))) |
6 calls:
| Time | Variable | Point | Expression | |
|---|---|---|---|---|
| 1.0ms | a | @ | 0 | ((/ (exp a) (+ (exp a) (exp b))) (exp a) a (+ (exp a) (exp b)) (exp b) b) |
| 1.0ms | a | @ | -inf | ((/ (exp a) (+ (exp a) (exp b))) (exp a) a (+ (exp a) (exp b)) (exp b) b) |
| 1.0ms | b | @ | 0 | ((/ (exp a) (+ (exp a) (exp b))) (exp a) a (+ (exp a) (exp b)) (exp b) b) |
| 1.0ms | a | @ | inf | ((/ (exp a) (+ (exp a) (exp b))) (exp a) a (+ (exp a) (exp b)) (exp b) b) |
| 1.0ms | b | @ | -inf | ((/ (exp a) (+ (exp a) (exp b))) (exp a) a (+ (exp a) (exp b)) (exp b) b) |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 154 | 730 |
| 0 | 158 | 693 |
| 1 | 1024 | 684 |
| 0 | 8044 | 638 |
| 1× | iter-limit |
| 1× | node-limit |
| 1× | iter-limit |
| Inputs |
|---|
(/.f64 (exp.f64 a) (+.f64 (exp.f64 a) (exp.f64 b))) |
(exp.f64 a) |
a |
(+.f64 (exp.f64 a) (exp.f64 b)) |
(exp.f64 b) |
b |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(hole binary64 (/ 1 (+ 1 (exp b))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(hole binary64 (+ (* a (- (/ 1 (+ 1 (exp b))) (/ 1 (pow (+ 1 (exp b)) 2)))) (/ 1 (+ 1 (exp b)))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(hole binary64 (+ (* a (- (+ (* a (- (+ (* 1/2 (/ 1 (+ 1 (exp b)))) (/ 1 (pow (+ 1 (exp b)) 3))) (* 3/2 (/ 1 (pow (+ 1 (exp b)) 2))))) (/ 1 (+ 1 (exp b)))) (/ 1 (pow (+ 1 (exp b)) 2)))) (/ 1 (+ 1 (exp b)))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(hole binary64 (+ (* a (- (+ (* a (- (+ (* 1/2 (/ 1 (+ 1 (exp b)))) (+ (* a (- (+ (* 1/6 (/ 1 (+ 1 (exp b)))) (* 3/2 (/ 1 (pow (+ 1 (exp b)) 3)))) (+ (* 1/6 (/ 1 (pow (+ 1 (exp b)) 2))) (+ (* 1/2 (/ 1 (pow (+ 1 (exp b)) 2))) (+ (* 1/2 (/ (- (/ 1 (+ 1 (exp b))) (/ 1 (pow (+ 1 (exp b)) 2))) (+ 1 (exp b)))) (/ 1 (pow (+ 1 (exp b)) 4))))))) (/ 1 (pow (+ 1 (exp b)) 3)))) (* 3/2 (/ 1 (pow (+ 1 (exp b)) 2))))) (/ 1 (+ 1 (exp b)))) (/ 1 (pow (+ 1 (exp b)) 2)))) (/ 1 (+ 1 (exp b)))))) |
#s(approx (exp a) #s(hole binary64 1)) |
#s(approx (exp a) #s(hole binary64 (+ 1 a))) |
#s(approx (exp a) #s(hole binary64 (+ 1 (* a (+ 1 (* 1/2 a)))))) |
#s(approx (exp a) #s(hole binary64 (+ 1 (* a (+ 1 (* a (+ 1/2 (* 1/6 a)))))))) |
#s(approx a #s(hole binary64 a)) |
#s(approx (+ (exp a) (exp b)) #s(hole binary64 (+ 1 (exp b)))) |
#s(approx (+ (exp a) (exp b)) #s(hole binary64 (+ 1 (+ a (exp b))))) |
#s(approx (+ (exp a) (exp b)) #s(hole binary64 (+ 1 (+ (exp b) (* a (+ 1 (* 1/2 a))))))) |
#s(approx (+ (exp a) (exp b)) #s(hole binary64 (+ 1 (+ (exp b) (* a (+ 1 (* a (+ 1/2 (* 1/6 a))))))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(hole binary64 (/ (exp a) (+ (exp a) (exp b))))) |
#s(approx (exp a) #s(hole binary64 (exp a))) |
#s(approx (+ (exp a) (exp b)) #s(hole binary64 (+ (exp a) (exp b)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(hole binary64 (/ (exp a) (+ 1 (exp a))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(hole binary64 (+ (* -1 (/ (* b (exp a)) (pow (+ 1 (exp a)) 2))) (/ (exp a) (+ 1 (exp a)))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(hole binary64 (+ (* b (- (* -1 (* b (+ (* -1 (/ (exp a) (pow (+ 1 (exp a)) 3))) (* 1/2 (/ (exp a) (pow (+ 1 (exp a)) 2)))))) (/ (exp a) (pow (+ 1 (exp a)) 2)))) (/ (exp a) (+ 1 (exp a)))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(hole binary64 (+ (* b (- (* b (- (* -1 (* b (+ (* -1 (/ (+ (* -1 (/ (exp a) (pow (+ 1 (exp a)) 3))) (* 1/2 (/ (exp a) (pow (+ 1 (exp a)) 2)))) (+ 1 (exp a)))) (+ (* -1/2 (/ (exp a) (pow (+ 1 (exp a)) 3))) (* 1/6 (/ (exp a) (pow (+ 1 (exp a)) 2))))))) (+ (* -1 (/ (exp a) (pow (+ 1 (exp a)) 3))) (* 1/2 (/ (exp a) (pow (+ 1 (exp a)) 2)))))) (/ (exp a) (pow (+ 1 (exp a)) 2)))) (/ (exp a) (+ 1 (exp a)))))) |
#s(approx (+ (exp a) (exp b)) #s(hole binary64 (+ 1 (exp a)))) |
#s(approx (+ (exp a) (exp b)) #s(hole binary64 (+ 1 (+ b (exp a))))) |
#s(approx (+ (exp a) (exp b)) #s(hole binary64 (+ 1 (+ (exp a) (* b (+ 1 (* 1/2 b))))))) |
#s(approx (+ (exp a) (exp b)) #s(hole binary64 (+ 1 (+ (exp a) (* b (+ 1 (* b (+ 1/2 (* 1/6 b))))))))) |
#s(approx (exp b) #s(hole binary64 1)) |
#s(approx (exp b) #s(hole binary64 (+ 1 b))) |
#s(approx (exp b) #s(hole binary64 (+ 1 (* b (+ 1 (* 1/2 b)))))) |
#s(approx (exp b) #s(hole binary64 (+ 1 (* b (+ 1 (* b (+ 1/2 (* 1/6 b)))))))) |
#s(approx b #s(hole binary64 b)) |
#s(approx (exp b) #s(hole binary64 (exp b))) |
| Outputs |
|---|
(/.f64 (neg.f64 (neg.f64 (exp.f64 a))) (neg.f64 (neg.f64 (+.f64 (exp.f64 b) (exp.f64 a))))) |
(/.f64 (neg.f64 (exp.f64 a)) (neg.f64 (+.f64 (exp.f64 b) (exp.f64 a)))) |
(/.f64 (exp.f64 a) (+.f64 (exp.f64 b) (exp.f64 a))) |
(+.f64 (/.f64 (cosh.f64 a) (+.f64 (exp.f64 b) (exp.f64 a))) (/.f64 (sinh.f64 a) (+.f64 (exp.f64 b) (exp.f64 a)))) |
(/.f64 (-.f64 (*.f64 (cosh.f64 a) (cosh.f64 a)) (*.f64 (sinh.f64 a) (sinh.f64 a))) (-.f64 (cosh.f64 a) (sinh.f64 a))) |
(/.f64 (+.f64 (pow.f64 (cosh.f64 a) #s(literal 3 binary64)) (pow.f64 (sinh.f64 a) #s(literal 3 binary64))) (fma.f64 (cosh.f64 a) (cosh.f64 a) (-.f64 (*.f64 (sinh.f64 a) (sinh.f64 a)) (*.f64 (cosh.f64 a) (sinh.f64 a))))) |
(+.f64 (cosh.f64 a) (sinh.f64 a)) |
(exp.f64 a) |
a |
(/.f64 (-.f64 (exp.f64 (+.f64 b b)) (exp.f64 (+.f64 a a))) (-.f64 (exp.f64 b) (exp.f64 a))) |
(/.f64 (+.f64 (exp.f64 (*.f64 b #s(literal 3 binary64))) (exp.f64 (*.f64 a #s(literal 3 binary64)))) (+.f64 (exp.f64 (+.f64 b b)) (-.f64 (exp.f64 (+.f64 a a)) (*.f64 (exp.f64 b) (exp.f64 a))))) |
(/.f64 (neg.f64 (-.f64 (exp.f64 (+.f64 a a)) (exp.f64 (+.f64 b b)))) (neg.f64 (-.f64 (exp.f64 a) (exp.f64 b)))) |
(/.f64 (neg.f64 (+.f64 (exp.f64 (*.f64 a #s(literal 3 binary64))) (exp.f64 (*.f64 b #s(literal 3 binary64))))) (neg.f64 (+.f64 (exp.f64 (+.f64 a a)) (-.f64 (exp.f64 (+.f64 b b)) (exp.f64 (+.f64 a b)))))) |
(/.f64 (-.f64 (exp.f64 (+.f64 a a)) (exp.f64 (+.f64 b b))) (-.f64 (exp.f64 a) (exp.f64 b))) |
(/.f64 (+.f64 (exp.f64 (*.f64 a #s(literal 3 binary64))) (exp.f64 (*.f64 b #s(literal 3 binary64)))) (+.f64 (exp.f64 (+.f64 a a)) (-.f64 (exp.f64 (+.f64 b b)) (exp.f64 (+.f64 a b))))) |
(-.f64 (/.f64 (exp.f64 (+.f64 a a)) (-.f64 (exp.f64 a) (exp.f64 b))) (/.f64 (exp.f64 (+.f64 b b)) (-.f64 (exp.f64 a) (exp.f64 b)))) |
(+.f64 (/.f64 (exp.f64 (*.f64 a #s(literal 3 binary64))) (+.f64 (exp.f64 (+.f64 a a)) (-.f64 (exp.f64 (+.f64 b b)) (exp.f64 (+.f64 a b))))) (/.f64 (exp.f64 (*.f64 b #s(literal 3 binary64))) (+.f64 (exp.f64 (+.f64 a a)) (-.f64 (exp.f64 (+.f64 b b)) (exp.f64 (+.f64 a b)))))) |
(+.f64 (exp.f64 b) (exp.f64 a)) |
(+.f64 (exp.f64 a) (exp.f64 b)) |
(/.f64 (-.f64 (*.f64 (cosh.f64 b) (cosh.f64 b)) (*.f64 (sinh.f64 b) (sinh.f64 b))) (-.f64 (cosh.f64 b) (sinh.f64 b))) |
(/.f64 (+.f64 (pow.f64 (cosh.f64 b) #s(literal 3 binary64)) (pow.f64 (sinh.f64 b) #s(literal 3 binary64))) (fma.f64 (cosh.f64 b) (cosh.f64 b) (-.f64 (*.f64 (sinh.f64 b) (sinh.f64 b)) (*.f64 (cosh.f64 b) (sinh.f64 b))))) |
(+.f64 (cosh.f64 b) (sinh.f64 b)) |
(exp.f64 b) |
b |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) (-.f64 (exp.f64 b) #s(literal -1 binary64)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (fma.f64 (-.f64 (/.f64 #s(literal 1 binary64) (-.f64 (exp.f64 b) #s(literal -1 binary64))) (pow.f64 (-.f64 (exp.f64 b) #s(literal -1 binary64)) #s(literal -2 binary64))) a (/.f64 #s(literal 1 binary64) (-.f64 (exp.f64 b) #s(literal -1 binary64))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (fma.f64 (-.f64 (fma.f64 a (-.f64 (+.f64 (pow.f64 (-.f64 (exp.f64 b) #s(literal -1 binary64)) #s(literal -3 binary64)) (/.f64 #s(literal 1/2 binary64) (-.f64 (exp.f64 b) #s(literal -1 binary64)))) (*.f64 (pow.f64 (-.f64 (exp.f64 b) #s(literal -1 binary64)) #s(literal -2 binary64)) #s(literal 3/2 binary64))) (/.f64 #s(literal 1 binary64) (-.f64 (exp.f64 b) #s(literal -1 binary64)))) (pow.f64 (-.f64 (exp.f64 b) #s(literal -1 binary64)) #s(literal -2 binary64))) a (/.f64 #s(literal 1 binary64) (-.f64 (exp.f64 b) #s(literal -1 binary64))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (fma.f64 (fma.f64 (+.f64 (/.f64 #s(literal 1/2 binary64) (-.f64 (exp.f64 b) #s(literal -1 binary64))) (-.f64 (fma.f64 (-.f64 (fma.f64 #s(literal 3/2 binary64) (pow.f64 (-.f64 (exp.f64 b) #s(literal -1 binary64)) #s(literal -3 binary64)) (/.f64 #s(literal 1/6 binary64) (-.f64 (exp.f64 b) #s(literal -1 binary64)))) (+.f64 (/.f64 #s(literal 2/3 binary64) (*.f64 (-.f64 (exp.f64 b) #s(literal -1 binary64)) (-.f64 (exp.f64 b) #s(literal -1 binary64)))) (fma.f64 #s(literal 1/2 binary64) (/.f64 (-.f64 (/.f64 #s(literal 1 binary64) (-.f64 (exp.f64 b) #s(literal -1 binary64))) (pow.f64 (-.f64 (exp.f64 b) #s(literal -1 binary64)) #s(literal -2 binary64))) (-.f64 (exp.f64 b) #s(literal -1 binary64))) (pow.f64 (-.f64 (exp.f64 b) #s(literal -1 binary64)) #s(literal -4 binary64))))) a (pow.f64 (-.f64 (exp.f64 b) #s(literal -1 binary64)) #s(literal -3 binary64))) (*.f64 (pow.f64 (-.f64 (exp.f64 b) #s(literal -1 binary64)) #s(literal -2 binary64)) #s(literal 3/2 binary64)))) a (-.f64 (/.f64 #s(literal 1 binary64) (-.f64 (exp.f64 b) #s(literal -1 binary64))) (pow.f64 (-.f64 (exp.f64 b) #s(literal -1 binary64)) #s(literal -2 binary64)))) a (/.f64 #s(literal 1 binary64) (-.f64 (exp.f64 b) #s(literal -1 binary64))))) |
#s(approx (exp a) #s(literal 1 binary64)) |
#s(approx (exp a) (-.f64 a #s(literal -1 binary64))) |
#s(approx (exp a) (fma.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a #s(literal 1 binary64))) |
#s(approx (exp a) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) a #s(literal 1/2 binary64)) a #s(literal 1 binary64)) a #s(literal 1 binary64))) |
#s(approx a a) |
#s(approx (+ (exp a) (exp b)) (-.f64 (exp.f64 b) #s(literal -1 binary64))) |
#s(approx (+ (exp a) (exp b)) (-.f64 (+.f64 (exp.f64 b) a) #s(literal -1 binary64))) |
#s(approx (+ (exp a) (exp b)) (-.f64 (fma.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a (exp.f64 b)) #s(literal -1 binary64))) |
#s(approx (+ (exp a) (exp b)) (-.f64 (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) a #s(literal 1/2 binary64)) a #s(literal 1 binary64)) a (exp.f64 b)) #s(literal -1 binary64))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 (exp.f64 a) (+.f64 (exp.f64 b) (exp.f64 a)))) |
#s(approx (exp a) (exp.f64 a)) |
#s(approx (+ (exp a) (exp b)) (+.f64 (exp.f64 b) (exp.f64 a))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 (exp.f64 a) (-.f64 (exp.f64 a) #s(literal -1 binary64)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (fma.f64 (neg.f64 b) (exp.f64 (-.f64 a (*.f64 (log.f64 (-.f64 (exp.f64 a) #s(literal -1 binary64))) #s(literal 2 binary64)))) (/.f64 (exp.f64 a) (-.f64 (exp.f64 a) #s(literal -1 binary64))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (fma.f64 (-.f64 (*.f64 (neg.f64 b) (fma.f64 (exp.f64 (-.f64 a (*.f64 (log.f64 (-.f64 (exp.f64 a) #s(literal -1 binary64))) #s(literal 2 binary64)))) #s(literal 1/2 binary64) (neg.f64 (exp.f64 (-.f64 a (*.f64 (log.f64 (-.f64 (exp.f64 a) #s(literal -1 binary64))) #s(literal 3 binary64))))))) (exp.f64 (-.f64 a (*.f64 (log.f64 (-.f64 (exp.f64 a) #s(literal -1 binary64))) #s(literal 2 binary64))))) b (/.f64 (exp.f64 a) (-.f64 (exp.f64 a) #s(literal -1 binary64))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (fma.f64 (-.f64 (*.f64 (-.f64 (*.f64 (neg.f64 b) (+.f64 (fma.f64 #s(literal -1/2 binary64) (exp.f64 (-.f64 a (*.f64 (log.f64 (-.f64 (exp.f64 a) #s(literal -1 binary64))) #s(literal 3 binary64)))) (*.f64 (exp.f64 (-.f64 a (*.f64 (log.f64 (-.f64 (exp.f64 a) #s(literal -1 binary64))) #s(literal 2 binary64)))) #s(literal 1/6 binary64))) (neg.f64 (/.f64 (fma.f64 (exp.f64 (-.f64 a (*.f64 (log.f64 (-.f64 (exp.f64 a) #s(literal -1 binary64))) #s(literal 2 binary64)))) #s(literal 1/2 binary64) (neg.f64 (exp.f64 (-.f64 a (*.f64 (log.f64 (-.f64 (exp.f64 a) #s(literal -1 binary64))) #s(literal 3 binary64)))))) (-.f64 (exp.f64 a) #s(literal -1 binary64)))))) (fma.f64 (exp.f64 (-.f64 a (*.f64 (log.f64 (-.f64 (exp.f64 a) #s(literal -1 binary64))) #s(literal 2 binary64)))) #s(literal 1/2 binary64) (neg.f64 (exp.f64 (-.f64 a (*.f64 (log.f64 (-.f64 (exp.f64 a) #s(literal -1 binary64))) #s(literal 3 binary64))))))) b) (exp.f64 (-.f64 a (*.f64 (log.f64 (-.f64 (exp.f64 a) #s(literal -1 binary64))) #s(literal 2 binary64))))) b (/.f64 (exp.f64 a) (-.f64 (exp.f64 a) #s(literal -1 binary64))))) |
#s(approx (+ (exp a) (exp b)) (-.f64 (exp.f64 a) #s(literal -1 binary64))) |
#s(approx (+ (exp a) (exp b)) (-.f64 (+.f64 (exp.f64 a) b) #s(literal -1 binary64))) |
#s(approx (+ (exp a) (exp b)) (-.f64 (fma.f64 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b (exp.f64 a)) #s(literal -1 binary64))) |
#s(approx (+ (exp a) (exp b)) (-.f64 (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) b #s(literal 1/2 binary64)) b #s(literal 1 binary64)) b (exp.f64 a)) #s(literal -1 binary64))) |
#s(approx (exp b) #s(literal 1 binary64)) |
#s(approx (exp b) (-.f64 b #s(literal -1 binary64))) |
#s(approx (exp b) (fma.f64 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b #s(literal 1 binary64))) |
#s(approx (exp b) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) b #s(literal 1/2 binary64)) b #s(literal 1 binary64)) b #s(literal 1 binary64))) |
#s(approx b b) |
#s(approx (exp b) (exp.f64 b)) |
Compiled 698 to 270 computations (61.3% saved)
4 alts after pruning (4 fresh and 0 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 54 | 4 | 58 |
| Fresh | 0 | 0 | 0 |
| Picked | 1 | 0 | 1 |
| Done | 0 | 0 | 0 |
| Total | 55 | 4 | 59 |
| Status | Accuracy | Program |
|---|---|---|
| ▶ | 97.8% | (/.f64 (exp.f64 a) (+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) (exp.f64 b))) |
| ▶ | 97.4% | (/.f64 (exp.f64 a) #s(approx (+ (exp a) (exp b)) (-.f64 (exp.f64 b) #s(literal -1 binary64)))) |
| ▶ | 62.8% | (/.f64 (exp.f64 a) #s(approx (+ (exp a) (exp b)) (-.f64 (exp.f64 a) #s(literal -1 binary64)))) |
| ▶ | 82.1% | #s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) (-.f64 (exp.f64 b) #s(literal -1 binary64)))) |
Compiled 45 to 43 computations (4.4% saved)
| Inputs |
|---|
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) (-.f64 (exp.f64 b) #s(literal -1 binary64)))) |
(/.f64 #s(literal 1 binary64) (-.f64 (exp.f64 b) #s(literal -1 binary64))) |
#s(literal 1 binary64) |
(-.f64 (exp.f64 b) #s(literal -1 binary64)) |
(exp.f64 b) |
b |
#s(literal -1 binary64) |
(/.f64 (exp.f64 a) #s(approx (+ (exp a) (exp b)) (-.f64 (exp.f64 a) #s(literal -1 binary64)))) |
(exp.f64 a) |
a |
#s(approx (+ (exp a) (exp b)) (-.f64 (exp.f64 a) #s(literal -1 binary64))) |
(-.f64 (exp.f64 a) #s(literal -1 binary64)) |
(/.f64 (exp.f64 a) #s(approx (+ (exp a) (exp b)) (-.f64 (exp.f64 b) #s(literal -1 binary64)))) |
#s(approx (+ (exp a) (exp b)) (-.f64 (exp.f64 b) #s(literal -1 binary64))) |
(/.f64 (exp.f64 a) (+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) (exp.f64 b))) |
(+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) (exp.f64 b)) |
#s(approx (exp a) (-.f64 a #s(literal -1 binary64))) |
(-.f64 a #s(literal -1 binary64)) |
| Outputs |
|---|
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(hole binary64 (/ 1 (+ 1 (exp b))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(hole binary64 (+ (* a (- (/ 1 (+ 1 (exp b))) (/ 1 (pow (+ 1 (exp b)) 2)))) (/ 1 (+ 1 (exp b)))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(hole binary64 (+ (* a (- (+ (* a (- (+ (* 1/2 (/ 1 (+ 1 (exp b)))) (/ 1 (pow (+ 1 (exp b)) 3))) (* 3/2 (/ 1 (pow (+ 1 (exp b)) 2))))) (/ 1 (+ 1 (exp b)))) (/ 1 (pow (+ 1 (exp b)) 2)))) (/ 1 (+ 1 (exp b)))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(hole binary64 (+ (* a (- (+ (* a (- (+ (* 1/2 (/ 1 (+ 1 (exp b)))) (+ (* a (- (+ (* 1/6 (/ 1 (+ 1 (exp b)))) (* 3/2 (/ 1 (pow (+ 1 (exp b)) 3)))) (+ (* 1/6 (/ 1 (pow (+ 1 (exp b)) 2))) (+ (* 1/2 (/ 1 (pow (+ 1 (exp b)) 2))) (+ (* 1/2 (/ (- (/ 1 (+ 1 (exp b))) (/ 1 (pow (+ 1 (exp b)) 2))) (+ 1 (exp b)))) (/ 1 (pow (+ 1 (exp b)) 4))))))) (/ 1 (pow (+ 1 (exp b)) 3)))) (* 3/2 (/ 1 (pow (+ 1 (exp b)) 2))))) (/ 1 (+ 1 (exp b)))) (/ 1 (pow (+ 1 (exp b)) 2)))) (/ 1 (+ 1 (exp b)))))) |
#s(approx (exp a) #s(hole binary64 1)) |
#s(approx (exp a) #s(hole binary64 (+ 1 a))) |
#s(approx (exp a) #s(hole binary64 (+ 1 (* a (+ 1 (* 1/2 a)))))) |
#s(approx (exp a) #s(hole binary64 (+ 1 (* a (+ 1 (* a (+ 1/2 (* 1/6 a)))))))) |
#s(approx a #s(hole binary64 a)) |
#s(approx (+ (exp a) (exp b)) #s(hole binary64 (+ 1 (exp b)))) |
#s(approx (+ (exp a) (exp b)) #s(hole binary64 (+ 1 (+ a (exp b))))) |
#s(approx (+ (exp a) (exp b)) #s(hole binary64 (+ 1 (+ (exp b) (* a (+ 1 (* 1/2 a))))))) |
#s(approx (+ (exp a) (exp b)) #s(hole binary64 (+ 1 (+ (exp b) (* a (+ 1 (* a (+ 1/2 (* 1/6 a))))))))) |
#s(approx (- (exp a) -1) #s(hole binary64 2)) |
#s(approx (- (exp a) -1) #s(hole binary64 (+ 2 a))) |
#s(approx (- (exp a) -1) #s(hole binary64 (+ 2 (* a (+ 1 (* 1/2 a)))))) |
#s(approx (- (exp a) -1) #s(hole binary64 (+ 2 (* a (+ 1 (* a (+ 1/2 (* 1/6 a)))))))) |
#s(approx (- a -1) #s(hole binary64 1)) |
#s(approx (- a -1) #s(hole binary64 (+ 1 a))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(hole binary64 (/ (exp a) (+ (exp a) (exp b))))) |
#s(approx (exp a) #s(hole binary64 (exp a))) |
#s(approx (+ (exp a) (exp b)) #s(hole binary64 (+ (exp a) (exp b)))) |
#s(approx (- (exp a) -1) #s(hole binary64 (+ 1 (exp a)))) |
#s(approx (- a -1) #s(hole binary64 a)) |
#s(approx (- a -1) #s(hole binary64 (* a (+ 1 (/ 1 a))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(hole binary64 (/ (exp a) (+ 1 (exp a))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(hole binary64 (+ (* -1 (/ (* b (exp a)) (pow (+ 1 (exp a)) 2))) (/ (exp a) (+ 1 (exp a)))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(hole binary64 (+ (* b (- (* -1 (* b (+ (* -1 (/ (exp a) (pow (+ 1 (exp a)) 3))) (* 1/2 (/ (exp a) (pow (+ 1 (exp a)) 2)))))) (/ (exp a) (pow (+ 1 (exp a)) 2)))) (/ (exp a) (+ 1 (exp a)))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(hole binary64 (+ (* b (- (* b (- (* -1 (* b (+ (* -1 (/ (+ (* -1 (/ (exp a) (pow (+ 1 (exp a)) 3))) (* 1/2 (/ (exp a) (pow (+ 1 (exp a)) 2)))) (+ 1 (exp a)))) (+ (* -1/2 (/ (exp a) (pow (+ 1 (exp a)) 3))) (* 1/6 (/ (exp a) (pow (+ 1 (exp a)) 2))))))) (+ (* -1 (/ (exp a) (pow (+ 1 (exp a)) 3))) (* 1/2 (/ (exp a) (pow (+ 1 (exp a)) 2)))))) (/ (exp a) (pow (+ 1 (exp a)) 2)))) (/ (exp a) (+ 1 (exp a)))))) |
#s(approx (/ 1 (- (exp b) -1)) #s(hole binary64 1/2)) |
#s(approx (/ 1 (- (exp b) -1)) #s(hole binary64 (+ 1/2 (* -1/4 b)))) |
#s(approx (/ 1 (- (exp b) -1)) #s(hole binary64 (+ 1/2 (* b (- (* 1/48 (pow b 2)) 1/4))))) |
#s(approx (/ 1 (- (exp b) -1)) #s(hole binary64 (+ 1/2 (* b (- (* (pow b 2) (+ 1/48 (* -1/480 (pow b 2)))) 1/4))))) |
#s(approx (- (exp b) -1) #s(hole binary64 2)) |
#s(approx (- (exp b) -1) #s(hole binary64 (+ 2 b))) |
#s(approx (- (exp b) -1) #s(hole binary64 (+ 2 (* b (+ 1 (* 1/2 b)))))) |
#s(approx (- (exp b) -1) #s(hole binary64 (+ 2 (* b (+ 1 (* b (+ 1/2 (* 1/6 b)))))))) |
#s(approx (exp b) #s(hole binary64 1)) |
#s(approx (exp b) #s(hole binary64 (+ 1 b))) |
#s(approx (exp b) #s(hole binary64 (+ 1 (* b (+ 1 (* 1/2 b)))))) |
#s(approx (exp b) #s(hole binary64 (+ 1 (* b (+ 1 (* b (+ 1/2 (* 1/6 b)))))))) |
#s(approx b #s(hole binary64 b)) |
#s(approx (+ (exp a) (exp b)) #s(hole binary64 (+ 1 (exp a)))) |
#s(approx (+ (exp a) (exp b)) #s(hole binary64 (+ 1 (+ b (exp a))))) |
#s(approx (+ (exp a) (exp b)) #s(hole binary64 (+ 1 (+ (exp a) (* b (+ 1 (* 1/2 b))))))) |
#s(approx (+ (exp a) (exp b)) #s(hole binary64 (+ 1 (+ (exp a) (* b (+ 1 (* b (+ 1/2 (* 1/6 b))))))))) |
#s(approx (/ 1 (- (exp b) -1)) #s(hole binary64 (/ 1 (+ 1 (exp b))))) |
#s(approx (- (exp b) -1) #s(hole binary64 (+ 1 (exp b)))) |
#s(approx (exp b) #s(hole binary64 (exp b))) |
6 calls:
| Time | Variable | Point | Expression | |
|---|---|---|---|---|
| 2.0ms | a | @ | -inf | ((/ (exp a) (+ (exp a) (exp b))) (/ 1 (- (exp b) -1)) 1 (- (exp b) -1) (exp b) b -1 (/ (exp a) (+ (exp a) (exp b))) (exp a) a (+ (exp a) (exp b)) (- (exp a) -1) (/ (exp a) (+ (exp a) (exp b))) (+ (exp a) (exp b)) (/ (exp a) (+ (exp a) (exp b))) (+ (exp a) (exp b)) (exp a) (- a -1)) |
| 1.0ms | b | @ | -inf | ((/ (exp a) (+ (exp a) (exp b))) (/ 1 (- (exp b) -1)) 1 (- (exp b) -1) (exp b) b -1 (/ (exp a) (+ (exp a) (exp b))) (exp a) a (+ (exp a) (exp b)) (- (exp a) -1) (/ (exp a) (+ (exp a) (exp b))) (+ (exp a) (exp b)) (/ (exp a) (+ (exp a) (exp b))) (+ (exp a) (exp b)) (exp a) (- a -1)) |
| 1.0ms | b | @ | inf | ((/ (exp a) (+ (exp a) (exp b))) (/ 1 (- (exp b) -1)) 1 (- (exp b) -1) (exp b) b -1 (/ (exp a) (+ (exp a) (exp b))) (exp a) a (+ (exp a) (exp b)) (- (exp a) -1) (/ (exp a) (+ (exp a) (exp b))) (+ (exp a) (exp b)) (/ (exp a) (+ (exp a) (exp b))) (+ (exp a) (exp b)) (exp a) (- a -1)) |
| 1.0ms | a | @ | inf | ((/ (exp a) (+ (exp a) (exp b))) (/ 1 (- (exp b) -1)) 1 (- (exp b) -1) (exp b) b -1 (/ (exp a) (+ (exp a) (exp b))) (exp a) a (+ (exp a) (exp b)) (- (exp a) -1) (/ (exp a) (+ (exp a) (exp b))) (+ (exp a) (exp b)) (/ (exp a) (+ (exp a) (exp b))) (+ (exp a) (exp b)) (exp a) (- a -1)) |
| 1.0ms | b | @ | 0 | ((/ (exp a) (+ (exp a) (exp b))) (/ 1 (- (exp b) -1)) 1 (- (exp b) -1) (exp b) b -1 (/ (exp a) (+ (exp a) (exp b))) (exp a) a (+ (exp a) (exp b)) (- (exp a) -1) (/ (exp a) (+ (exp a) (exp b))) (+ (exp a) (exp b)) (/ (exp a) (+ (exp a) (exp b))) (+ (exp a) (exp b)) (exp a) (- a -1)) |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 213 | 1037 |
| 0 | 235 | 1000 |
| 1 | 1324 | 989 |
| 0 | 8398 | 929 |
| 1× | iter-limit |
| 1× | node-limit |
| 1× | iter-limit |
| Inputs |
|---|
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) (-.f64 (exp.f64 b) #s(literal -1 binary64)))) |
(/.f64 #s(literal 1 binary64) (-.f64 (exp.f64 b) #s(literal -1 binary64))) |
#s(literal 1 binary64) |
(-.f64 (exp.f64 b) #s(literal -1 binary64)) |
(exp.f64 b) |
b |
#s(literal -1 binary64) |
(/.f64 (exp.f64 a) #s(approx (+ (exp a) (exp b)) (-.f64 (exp.f64 a) #s(literal -1 binary64)))) |
(exp.f64 a) |
a |
#s(approx (+ (exp a) (exp b)) (-.f64 (exp.f64 a) #s(literal -1 binary64))) |
(-.f64 (exp.f64 a) #s(literal -1 binary64)) |
(/.f64 (exp.f64 a) #s(approx (+ (exp a) (exp b)) (-.f64 (exp.f64 b) #s(literal -1 binary64)))) |
#s(approx (+ (exp a) (exp b)) (-.f64 (exp.f64 b) #s(literal -1 binary64))) |
(/.f64 (exp.f64 a) (+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) (exp.f64 b))) |
(+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) (exp.f64 b)) |
#s(approx (exp a) (-.f64 a #s(literal -1 binary64))) |
(-.f64 a #s(literal -1 binary64)) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(hole binary64 (/ 1 (+ 1 (exp b))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(hole binary64 (+ (* a (- (/ 1 (+ 1 (exp b))) (/ 1 (pow (+ 1 (exp b)) 2)))) (/ 1 (+ 1 (exp b)))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(hole binary64 (+ (* a (- (+ (* a (- (+ (* 1/2 (/ 1 (+ 1 (exp b)))) (/ 1 (pow (+ 1 (exp b)) 3))) (* 3/2 (/ 1 (pow (+ 1 (exp b)) 2))))) (/ 1 (+ 1 (exp b)))) (/ 1 (pow (+ 1 (exp b)) 2)))) (/ 1 (+ 1 (exp b)))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(hole binary64 (+ (* a (- (+ (* a (- (+ (* 1/2 (/ 1 (+ 1 (exp b)))) (+ (* a (- (+ (* 1/6 (/ 1 (+ 1 (exp b)))) (* 3/2 (/ 1 (pow (+ 1 (exp b)) 3)))) (+ (* 1/6 (/ 1 (pow (+ 1 (exp b)) 2))) (+ (* 1/2 (/ 1 (pow (+ 1 (exp b)) 2))) (+ (* 1/2 (/ (- (/ 1 (+ 1 (exp b))) (/ 1 (pow (+ 1 (exp b)) 2))) (+ 1 (exp b)))) (/ 1 (pow (+ 1 (exp b)) 4))))))) (/ 1 (pow (+ 1 (exp b)) 3)))) (* 3/2 (/ 1 (pow (+ 1 (exp b)) 2))))) (/ 1 (+ 1 (exp b)))) (/ 1 (pow (+ 1 (exp b)) 2)))) (/ 1 (+ 1 (exp b)))))) |
#s(approx (exp a) #s(hole binary64 1)) |
#s(approx (exp a) #s(hole binary64 (+ 1 a))) |
#s(approx (exp a) #s(hole binary64 (+ 1 (* a (+ 1 (* 1/2 a)))))) |
#s(approx (exp a) #s(hole binary64 (+ 1 (* a (+ 1 (* a (+ 1/2 (* 1/6 a)))))))) |
#s(approx a #s(hole binary64 a)) |
#s(approx (+ (exp a) (exp b)) #s(hole binary64 (+ 1 (exp b)))) |
#s(approx (+ (exp a) (exp b)) #s(hole binary64 (+ 1 (+ a (exp b))))) |
#s(approx (+ (exp a) (exp b)) #s(hole binary64 (+ 1 (+ (exp b) (* a (+ 1 (* 1/2 a))))))) |
#s(approx (+ (exp a) (exp b)) #s(hole binary64 (+ 1 (+ (exp b) (* a (+ 1 (* a (+ 1/2 (* 1/6 a))))))))) |
#s(approx (- (exp a) -1) #s(hole binary64 2)) |
#s(approx (- (exp a) -1) #s(hole binary64 (+ 2 a))) |
#s(approx (- (exp a) -1) #s(hole binary64 (+ 2 (* a (+ 1 (* 1/2 a)))))) |
#s(approx (- (exp a) -1) #s(hole binary64 (+ 2 (* a (+ 1 (* a (+ 1/2 (* 1/6 a)))))))) |
#s(approx (- a -1) #s(hole binary64 1)) |
#s(approx (- a -1) #s(hole binary64 (+ 1 a))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(hole binary64 (/ (exp a) (+ (exp a) (exp b))))) |
#s(approx (exp a) #s(hole binary64 (exp a))) |
#s(approx (+ (exp a) (exp b)) #s(hole binary64 (+ (exp a) (exp b)))) |
#s(approx (- (exp a) -1) #s(hole binary64 (+ 1 (exp a)))) |
#s(approx (- a -1) #s(hole binary64 a)) |
#s(approx (- a -1) #s(hole binary64 (* a (+ 1 (/ 1 a))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(hole binary64 (/ (exp a) (+ 1 (exp a))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(hole binary64 (+ (* -1 (/ (* b (exp a)) (pow (+ 1 (exp a)) 2))) (/ (exp a) (+ 1 (exp a)))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(hole binary64 (+ (* b (- (* -1 (* b (+ (* -1 (/ (exp a) (pow (+ 1 (exp a)) 3))) (* 1/2 (/ (exp a) (pow (+ 1 (exp a)) 2)))))) (/ (exp a) (pow (+ 1 (exp a)) 2)))) (/ (exp a) (+ 1 (exp a)))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(hole binary64 (+ (* b (- (* b (- (* -1 (* b (+ (* -1 (/ (+ (* -1 (/ (exp a) (pow (+ 1 (exp a)) 3))) (* 1/2 (/ (exp a) (pow (+ 1 (exp a)) 2)))) (+ 1 (exp a)))) (+ (* -1/2 (/ (exp a) (pow (+ 1 (exp a)) 3))) (* 1/6 (/ (exp a) (pow (+ 1 (exp a)) 2))))))) (+ (* -1 (/ (exp a) (pow (+ 1 (exp a)) 3))) (* 1/2 (/ (exp a) (pow (+ 1 (exp a)) 2)))))) (/ (exp a) (pow (+ 1 (exp a)) 2)))) (/ (exp a) (+ 1 (exp a)))))) |
#s(approx (/ 1 (- (exp b) -1)) #s(hole binary64 1/2)) |
#s(approx (/ 1 (- (exp b) -1)) #s(hole binary64 (+ 1/2 (* -1/4 b)))) |
#s(approx (/ 1 (- (exp b) -1)) #s(hole binary64 (+ 1/2 (* b (- (* 1/48 (pow b 2)) 1/4))))) |
#s(approx (/ 1 (- (exp b) -1)) #s(hole binary64 (+ 1/2 (* b (- (* (pow b 2) (+ 1/48 (* -1/480 (pow b 2)))) 1/4))))) |
#s(approx (- (exp b) -1) #s(hole binary64 2)) |
#s(approx (- (exp b) -1) #s(hole binary64 (+ 2 b))) |
#s(approx (- (exp b) -1) #s(hole binary64 (+ 2 (* b (+ 1 (* 1/2 b)))))) |
#s(approx (- (exp b) -1) #s(hole binary64 (+ 2 (* b (+ 1 (* b (+ 1/2 (* 1/6 b)))))))) |
#s(approx (exp b) #s(hole binary64 1)) |
#s(approx (exp b) #s(hole binary64 (+ 1 b))) |
#s(approx (exp b) #s(hole binary64 (+ 1 (* b (+ 1 (* 1/2 b)))))) |
#s(approx (exp b) #s(hole binary64 (+ 1 (* b (+ 1 (* b (+ 1/2 (* 1/6 b)))))))) |
#s(approx b #s(hole binary64 b)) |
#s(approx (+ (exp a) (exp b)) #s(hole binary64 (+ 1 (exp a)))) |
#s(approx (+ (exp a) (exp b)) #s(hole binary64 (+ 1 (+ b (exp a))))) |
#s(approx (+ (exp a) (exp b)) #s(hole binary64 (+ 1 (+ (exp a) (* b (+ 1 (* 1/2 b))))))) |
#s(approx (+ (exp a) (exp b)) #s(hole binary64 (+ 1 (+ (exp a) (* b (+ 1 (* b (+ 1/2 (* 1/6 b))))))))) |
#s(approx (/ 1 (- (exp b) -1)) #s(hole binary64 (/ 1 (+ 1 (exp b))))) |
#s(approx (- (exp b) -1) #s(hole binary64 (+ 1 (exp b)))) |
#s(approx (exp b) #s(hole binary64 (exp b))) |
| Outputs |
|---|
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) (-.f64 (exp.f64 b) #s(literal -1 binary64)))) |
(pow.f64 (-.f64 (exp.f64 b) #s(literal -1 binary64)) #s(literal -1 binary64)) |
(/.f64 #s(literal -1 binary64) (neg.f64 (-.f64 (exp.f64 b) #s(literal -1 binary64)))) |
(/.f64 #s(literal 1 binary64) (neg.f64 (neg.f64 (-.f64 (exp.f64 b) #s(literal -1 binary64))))) |
(/.f64 #s(literal 1 binary64) (pow.f64 (-.f64 (exp.f64 b) #s(literal -1 binary64)) #s(literal 1 binary64))) |
(/.f64 #s(literal 1 binary64) (-.f64 (exp.f64 b) #s(literal -1 binary64))) |
(exp.f64 (*.f64 (log.f64 (-.f64 (exp.f64 b) #s(literal -1 binary64))) #s(literal -1 binary64))) |
#s(literal 1 binary64) |
(/.f64 (neg.f64 (expm1.f64 (+.f64 b b))) (neg.f64 (+.f64 (exp.f64 b) #s(literal -1 binary64)))) |
(/.f64 (neg.f64 (-.f64 (exp.f64 (*.f64 b #s(literal 3 binary64))) #s(literal -1 binary64))) (neg.f64 (+.f64 (exp.f64 (+.f64 b b)) (+.f64 #s(literal 1 binary64) (*.f64 (exp.f64 b) #s(literal -1 binary64)))))) |
(/.f64 (expm1.f64 (+.f64 b b)) (+.f64 (exp.f64 b) #s(literal -1 binary64))) |
(/.f64 (-.f64 (exp.f64 (*.f64 b #s(literal 3 binary64))) #s(literal -1 binary64)) (+.f64 (exp.f64 (+.f64 b b)) (+.f64 #s(literal 1 binary64) (*.f64 (exp.f64 b) #s(literal -1 binary64))))) |
(-.f64 (/.f64 (exp.f64 (+.f64 b b)) (+.f64 (exp.f64 b) #s(literal -1 binary64))) (/.f64 #s(literal 1 binary64) (+.f64 (exp.f64 b) #s(literal -1 binary64)))) |
(-.f64 (/.f64 (exp.f64 (*.f64 b #s(literal 3 binary64))) (+.f64 (exp.f64 (+.f64 b b)) (+.f64 #s(literal 1 binary64) (*.f64 (exp.f64 b) #s(literal -1 binary64))))) (/.f64 #s(literal -1 binary64) (+.f64 (exp.f64 (+.f64 b b)) (+.f64 #s(literal 1 binary64) (*.f64 (exp.f64 b) #s(literal -1 binary64)))))) |
(-.f64 (exp.f64 b) #s(literal -1 binary64)) |
(/.f64 (-.f64 (*.f64 (cosh.f64 b) (cosh.f64 b)) (*.f64 (sinh.f64 b) (sinh.f64 b))) (-.f64 (cosh.f64 b) (sinh.f64 b))) |
(/.f64 (+.f64 (pow.f64 (cosh.f64 b) #s(literal 3 binary64)) (pow.f64 (sinh.f64 b) #s(literal 3 binary64))) (fma.f64 (cosh.f64 b) (cosh.f64 b) (-.f64 (*.f64 (sinh.f64 b) (sinh.f64 b)) (*.f64 (cosh.f64 b) (sinh.f64 b))))) |
(+.f64 (cosh.f64 b) (sinh.f64 b)) |
(exp.f64 b) |
b |
#s(literal -1 binary64) |
(/.f64 (neg.f64 (neg.f64 (exp.f64 a))) (neg.f64 (neg.f64 #s(approx (+ (exp a) (exp b)) (-.f64 (exp.f64 a) #s(literal -1 binary64)))))) |
(/.f64 (neg.f64 (exp.f64 a)) (neg.f64 #s(approx (+ (exp a) (exp b)) (-.f64 (exp.f64 a) #s(literal -1 binary64))))) |
(/.f64 (exp.f64 a) #s(approx (+ (exp a) (exp b)) (-.f64 (exp.f64 a) #s(literal -1 binary64)))) |
(+.f64 (/.f64 (cosh.f64 a) #s(approx (+ (exp a) (exp b)) (-.f64 (exp.f64 a) #s(literal -1 binary64)))) (/.f64 (sinh.f64 a) #s(approx (+ (exp a) (exp b)) (-.f64 (exp.f64 a) #s(literal -1 binary64))))) |
(/.f64 (-.f64 (*.f64 (cosh.f64 a) (cosh.f64 a)) (*.f64 (sinh.f64 a) (sinh.f64 a))) (-.f64 (cosh.f64 a) (sinh.f64 a))) |
(/.f64 (+.f64 (pow.f64 (cosh.f64 a) #s(literal 3 binary64)) (pow.f64 (sinh.f64 a) #s(literal 3 binary64))) (fma.f64 (cosh.f64 a) (cosh.f64 a) (-.f64 (*.f64 (sinh.f64 a) (sinh.f64 a)) (*.f64 (cosh.f64 a) (sinh.f64 a))))) |
(+.f64 (cosh.f64 a) (sinh.f64 a)) |
(exp.f64 a) |
a |
#s(approx (+ (exp a) (exp b)) (-.f64 (exp.f64 a) #s(literal -1 binary64))) |
(/.f64 (neg.f64 (expm1.f64 (+.f64 a a))) (neg.f64 (+.f64 (exp.f64 a) #s(literal -1 binary64)))) |
(/.f64 (neg.f64 (-.f64 (exp.f64 (*.f64 a #s(literal 3 binary64))) #s(literal -1 binary64))) (neg.f64 (+.f64 (exp.f64 (+.f64 a a)) (+.f64 #s(literal 1 binary64) (*.f64 (exp.f64 a) #s(literal -1 binary64)))))) |
(/.f64 (expm1.f64 (+.f64 a a)) (+.f64 (exp.f64 a) #s(literal -1 binary64))) |
(/.f64 (-.f64 (exp.f64 (*.f64 a #s(literal 3 binary64))) #s(literal -1 binary64)) (+.f64 (exp.f64 (+.f64 a a)) (+.f64 #s(literal 1 binary64) (*.f64 (exp.f64 a) #s(literal -1 binary64))))) |
(-.f64 (/.f64 (exp.f64 (+.f64 a a)) (+.f64 (exp.f64 a) #s(literal -1 binary64))) (/.f64 #s(literal 1 binary64) (+.f64 (exp.f64 a) #s(literal -1 binary64)))) |
(-.f64 (/.f64 (exp.f64 (*.f64 a #s(literal 3 binary64))) (+.f64 (exp.f64 (+.f64 a a)) (+.f64 #s(literal 1 binary64) (*.f64 (exp.f64 a) #s(literal -1 binary64))))) (/.f64 #s(literal -1 binary64) (+.f64 (exp.f64 (+.f64 a a)) (+.f64 #s(literal 1 binary64) (*.f64 (exp.f64 a) #s(literal -1 binary64)))))) |
(-.f64 (exp.f64 a) #s(literal -1 binary64)) |
(/.f64 (neg.f64 (neg.f64 (exp.f64 a))) (neg.f64 (neg.f64 #s(approx (+ (exp a) (exp b)) (-.f64 (exp.f64 b) #s(literal -1 binary64)))))) |
(/.f64 (neg.f64 (exp.f64 a)) (neg.f64 #s(approx (+ (exp a) (exp b)) (-.f64 (exp.f64 b) #s(literal -1 binary64))))) |
(/.f64 (exp.f64 a) #s(approx (+ (exp a) (exp b)) (-.f64 (exp.f64 b) #s(literal -1 binary64)))) |
(+.f64 (/.f64 (cosh.f64 a) #s(approx (+ (exp a) (exp b)) (-.f64 (exp.f64 b) #s(literal -1 binary64)))) (/.f64 (sinh.f64 a) #s(approx (+ (exp a) (exp b)) (-.f64 (exp.f64 b) #s(literal -1 binary64))))) |
#s(approx (+ (exp a) (exp b)) (-.f64 (exp.f64 b) #s(literal -1 binary64))) |
(/.f64 (neg.f64 (neg.f64 (exp.f64 a))) (neg.f64 (neg.f64 (+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) (exp.f64 b))))) |
(/.f64 (neg.f64 (exp.f64 a)) (neg.f64 (+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) (exp.f64 b)))) |
(/.f64 (exp.f64 a) (+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) (exp.f64 b))) |
(+.f64 (/.f64 (cosh.f64 a) (+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) (exp.f64 b))) (/.f64 (sinh.f64 a) (+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) (exp.f64 b)))) |
(/.f64 (-.f64 (exp.f64 (+.f64 b b)) (*.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp a) (-.f64 a #s(literal -1 binary64))))) (-.f64 (exp.f64 b) #s(approx (exp a) (-.f64 a #s(literal -1 binary64))))) |
(/.f64 (+.f64 (exp.f64 (*.f64 b #s(literal 3 binary64))) (*.f64 (*.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp a) (-.f64 a #s(literal -1 binary64)))) #s(approx (exp a) (-.f64 a #s(literal -1 binary64))))) (+.f64 (exp.f64 (+.f64 b b)) (-.f64 (*.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp a) (-.f64 a #s(literal -1 binary64)))) (*.f64 (exp.f64 b) #s(approx (exp a) (-.f64 a #s(literal -1 binary64))))))) |
(/.f64 (neg.f64 (-.f64 (*.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp a) (-.f64 a #s(literal -1 binary64)))) (exp.f64 (+.f64 b b)))) (neg.f64 (-.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) (exp.f64 b)))) |
(/.f64 (neg.f64 (fma.f64 (*.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp a) (-.f64 a #s(literal -1 binary64)))) #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) (exp.f64 (*.f64 b #s(literal 3 binary64))))) (neg.f64 (fma.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) (-.f64 (exp.f64 (+.f64 b b)) (*.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) (exp.f64 b)))))) |
(/.f64 (-.f64 (*.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp a) (-.f64 a #s(literal -1 binary64)))) (exp.f64 (+.f64 b b))) (-.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) (exp.f64 b))) |
(/.f64 (fma.f64 (*.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp a) (-.f64 a #s(literal -1 binary64)))) #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) (exp.f64 (*.f64 b #s(literal 3 binary64)))) (fma.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) (-.f64 (exp.f64 (+.f64 b b)) (*.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) (exp.f64 b))))) |
(-.f64 (/.f64 (*.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp a) (-.f64 a #s(literal -1 binary64)))) (-.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) (exp.f64 b))) (/.f64 (exp.f64 (+.f64 b b)) (-.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) (exp.f64 b)))) |
(+.f64 (/.f64 (*.f64 (*.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp a) (-.f64 a #s(literal -1 binary64)))) #s(approx (exp a) (-.f64 a #s(literal -1 binary64)))) (fma.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) (-.f64 (exp.f64 (+.f64 b b)) (*.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) (exp.f64 b))))) (/.f64 (exp.f64 (*.f64 b #s(literal 3 binary64))) (fma.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) (-.f64 (exp.f64 (+.f64 b b)) (*.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) (exp.f64 b)))))) |
(+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) (exp.f64 b)) |
(+.f64 (exp.f64 b) #s(approx (exp a) (-.f64 a #s(literal -1 binary64)))) |
#s(approx (exp a) (-.f64 a #s(literal -1 binary64))) |
(/.f64 (neg.f64 (-.f64 (*.f64 a a) #s(literal 1 binary64))) (neg.f64 (+.f64 a #s(literal -1 binary64)))) |
(/.f64 (neg.f64 (-.f64 (*.f64 (*.f64 a a) a) #s(literal -1 binary64))) (neg.f64 (fma.f64 a a (+.f64 #s(literal 1 binary64) (*.f64 a #s(literal -1 binary64)))))) |
(/.f64 (-.f64 (*.f64 a a) #s(literal 1 binary64)) (+.f64 a #s(literal -1 binary64))) |
(/.f64 (-.f64 (*.f64 (*.f64 a a) a) #s(literal -1 binary64)) (fma.f64 a a (+.f64 #s(literal 1 binary64) (*.f64 a #s(literal -1 binary64))))) |
(-.f64 (/.f64 (*.f64 a a) (+.f64 a #s(literal -1 binary64))) (/.f64 #s(literal 1 binary64) (+.f64 a #s(literal -1 binary64)))) |
(-.f64 (/.f64 (*.f64 (*.f64 a a) a) (fma.f64 a a (+.f64 #s(literal 1 binary64) (*.f64 a #s(literal -1 binary64))))) (/.f64 #s(literal -1 binary64) (fma.f64 a a (+.f64 #s(literal 1 binary64) (*.f64 a #s(literal -1 binary64)))))) |
(-.f64 a #s(literal -1 binary64)) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) (+.f64 #s(literal 1 binary64) (exp.f64 b)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (fma.f64 (-.f64 (/.f64 #s(literal 1 binary64) (+.f64 #s(literal 1 binary64) (exp.f64 b))) (pow.f64 (+.f64 #s(literal 1 binary64) (exp.f64 b)) #s(literal -2 binary64))) a (/.f64 #s(literal 1 binary64) (+.f64 #s(literal 1 binary64) (exp.f64 b))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (fma.f64 (-.f64 (fma.f64 a (+.f64 (/.f64 #s(literal 1/2 binary64) (+.f64 #s(literal 1 binary64) (exp.f64 b))) (-.f64 (pow.f64 (+.f64 #s(literal 1 binary64) (exp.f64 b)) #s(literal -3 binary64)) (*.f64 (pow.f64 (+.f64 #s(literal 1 binary64) (exp.f64 b)) #s(literal -2 binary64)) #s(literal 3/2 binary64)))) (/.f64 #s(literal 1 binary64) (+.f64 #s(literal 1 binary64) (exp.f64 b)))) (pow.f64 (+.f64 #s(literal 1 binary64) (exp.f64 b)) #s(literal -2 binary64))) a (/.f64 #s(literal 1 binary64) (+.f64 #s(literal 1 binary64) (exp.f64 b))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (fma.f64 (fma.f64 (-.f64 (+.f64 (fma.f64 (-.f64 (fma.f64 #s(literal 3/2 binary64) (pow.f64 (+.f64 #s(literal 1 binary64) (exp.f64 b)) #s(literal -3 binary64)) (/.f64 #s(literal 1/6 binary64) (+.f64 #s(literal 1 binary64) (exp.f64 b)))) (+.f64 (/.f64 #s(literal 2/3 binary64) (*.f64 (+.f64 #s(literal 1 binary64) (exp.f64 b)) (+.f64 #s(literal 1 binary64) (exp.f64 b)))) (fma.f64 #s(literal 1/2 binary64) (/.f64 (-.f64 (/.f64 #s(literal 1 binary64) (+.f64 #s(literal 1 binary64) (exp.f64 b))) (pow.f64 (+.f64 #s(literal 1 binary64) (exp.f64 b)) #s(literal -2 binary64))) (+.f64 #s(literal 1 binary64) (exp.f64 b))) (pow.f64 (+.f64 #s(literal 1 binary64) (exp.f64 b)) #s(literal -4 binary64))))) a (pow.f64 (+.f64 #s(literal 1 binary64) (exp.f64 b)) #s(literal -3 binary64))) (/.f64 #s(literal 1/2 binary64) (+.f64 #s(literal 1 binary64) (exp.f64 b)))) (*.f64 (pow.f64 (+.f64 #s(literal 1 binary64) (exp.f64 b)) #s(literal -2 binary64)) #s(literal 3/2 binary64))) a (-.f64 (/.f64 #s(literal 1 binary64) (+.f64 #s(literal 1 binary64) (exp.f64 b))) (pow.f64 (+.f64 #s(literal 1 binary64) (exp.f64 b)) #s(literal -2 binary64)))) a (/.f64 #s(literal 1 binary64) (+.f64 #s(literal 1 binary64) (exp.f64 b))))) |
#s(approx (exp a) #s(literal 1 binary64)) |
#s(approx (exp a) (+.f64 #s(literal 1 binary64) a)) |
#s(approx (exp a) (fma.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a #s(literal 1 binary64))) |
#s(approx (exp a) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) a #s(literal 1/2 binary64)) a #s(literal 1 binary64)) a #s(literal 1 binary64))) |
#s(approx a a) |
#s(approx (+ (exp a) (exp b)) (+.f64 #s(literal 1 binary64) (exp.f64 b))) |
#s(approx (+ (exp a) (exp b)) (+.f64 (+.f64 (exp.f64 b) a) #s(literal 1 binary64))) |
#s(approx (+ (exp a) (exp b)) (+.f64 (fma.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a (exp.f64 b)) #s(literal 1 binary64))) |
#s(approx (+ (exp a) (exp b)) (+.f64 (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) a #s(literal 1/2 binary64)) a #s(literal 1 binary64)) a (exp.f64 b)) #s(literal 1 binary64))) |
#s(approx (- (exp a) -1) #s(literal 2 binary64)) |
#s(approx (- (exp a) -1) (+.f64 #s(literal 2 binary64) a)) |
#s(approx (- (exp a) -1) (fma.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a #s(literal 2 binary64))) |
#s(approx (- (exp a) -1) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) a #s(literal 1/2 binary64)) a #s(literal 1 binary64)) a #s(literal 2 binary64))) |
#s(approx (- a -1) #s(literal 1 binary64)) |
#s(approx (- a -1) (+.f64 #s(literal 1 binary64) a)) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 (exp.f64 a) (+.f64 (exp.f64 b) (exp.f64 a)))) |
#s(approx (exp a) (exp.f64 a)) |
#s(approx (+ (exp a) (exp b)) (+.f64 (exp.f64 b) (exp.f64 a))) |
#s(approx (- (exp a) -1) (+.f64 #s(literal 1 binary64) (exp.f64 a))) |
#s(approx (- a -1) a) |
#s(approx (- a -1) (fma.f64 #s(literal 1 binary64) a #s(literal 1 binary64))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 (exp.f64 a) (+.f64 #s(literal 1 binary64) (exp.f64 a)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (+.f64 (neg.f64 (*.f64 b (exp.f64 (-.f64 a (*.f64 (log.f64 (+.f64 #s(literal 1 binary64) (exp.f64 a))) #s(literal 2 binary64)))))) (/.f64 (exp.f64 a) (+.f64 #s(literal 1 binary64) (exp.f64 a))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (fma.f64 b (-.f64 (neg.f64 (*.f64 (fma.f64 (exp.f64 (-.f64 a (*.f64 (log.f64 (+.f64 #s(literal 1 binary64) (exp.f64 a))) #s(literal 2 binary64)))) #s(literal 1/2 binary64) (neg.f64 (exp.f64 (-.f64 a (*.f64 (log.f64 (+.f64 #s(literal 1 binary64) (exp.f64 a))) #s(literal 3 binary64)))))) b)) (exp.f64 (-.f64 a (*.f64 (log.f64 (+.f64 #s(literal 1 binary64) (exp.f64 a))) #s(literal 2 binary64))))) (/.f64 (exp.f64 a) (+.f64 #s(literal 1 binary64) (exp.f64 a))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (fma.f64 (-.f64 (*.f64 (-.f64 (neg.f64 (*.f64 (+.f64 (fma.f64 #s(literal -1/2 binary64) (exp.f64 (-.f64 a (*.f64 (log.f64 (+.f64 #s(literal 1 binary64) (exp.f64 a))) #s(literal 3 binary64)))) (*.f64 (exp.f64 (-.f64 a (*.f64 (log.f64 (+.f64 #s(literal 1 binary64) (exp.f64 a))) #s(literal 2 binary64)))) #s(literal 1/6 binary64))) (neg.f64 (/.f64 (fma.f64 (exp.f64 (-.f64 a (*.f64 (log.f64 (+.f64 #s(literal 1 binary64) (exp.f64 a))) #s(literal 2 binary64)))) #s(literal 1/2 binary64) (neg.f64 (exp.f64 (-.f64 a (*.f64 (log.f64 (+.f64 #s(literal 1 binary64) (exp.f64 a))) #s(literal 3 binary64)))))) (+.f64 #s(literal 1 binary64) (exp.f64 a))))) b)) (fma.f64 (exp.f64 (-.f64 a (*.f64 (log.f64 (+.f64 #s(literal 1 binary64) (exp.f64 a))) #s(literal 2 binary64)))) #s(literal 1/2 binary64) (neg.f64 (exp.f64 (-.f64 a (*.f64 (log.f64 (+.f64 #s(literal 1 binary64) (exp.f64 a))) #s(literal 3 binary64))))))) b) (exp.f64 (-.f64 a (*.f64 (log.f64 (+.f64 #s(literal 1 binary64) (exp.f64 a))) #s(literal 2 binary64))))) b (/.f64 (exp.f64 a) (+.f64 #s(literal 1 binary64) (exp.f64 a))))) |
#s(approx (/ 1 (- (exp b) -1)) #s(literal 1/2 binary64)) |
#s(approx (/ 1 (- (exp b) -1)) (fma.f64 #s(literal -1/4 binary64) b #s(literal 1/2 binary64))) |
#s(approx (/ 1 (- (exp b) -1)) (fma.f64 (-.f64 (*.f64 (*.f64 b b) #s(literal 1/48 binary64)) #s(literal 1/4 binary64)) b #s(literal 1/2 binary64))) |
#s(approx (/ 1 (- (exp b) -1)) (fma.f64 (-.f64 (*.f64 (fma.f64 #s(literal -1/480 binary64) (*.f64 b b) #s(literal 1/48 binary64)) (*.f64 b b)) #s(literal 1/4 binary64)) b #s(literal 1/2 binary64))) |
#s(approx (- (exp b) -1) #s(literal 2 binary64)) |
#s(approx (- (exp b) -1) (+.f64 #s(literal 2 binary64) b)) |
#s(approx (- (exp b) -1) (fma.f64 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b #s(literal 2 binary64))) |
#s(approx (- (exp b) -1) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) b #s(literal 1/2 binary64)) b #s(literal 1 binary64)) b #s(literal 2 binary64))) |
#s(approx (exp b) #s(literal 1 binary64)) |
#s(approx (exp b) (+.f64 #s(literal 1 binary64) b)) |
#s(approx (exp b) (fma.f64 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b #s(literal 1 binary64))) |
#s(approx (exp b) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) b #s(literal 1/2 binary64)) b #s(literal 1 binary64)) b #s(literal 1 binary64))) |
#s(approx b b) |
#s(approx (+ (exp a) (exp b)) (+.f64 #s(literal 1 binary64) (exp.f64 a))) |
#s(approx (+ (exp a) (exp b)) (+.f64 (+.f64 b (exp.f64 a)) #s(literal 1 binary64))) |
#s(approx (+ (exp a) (exp b)) (+.f64 (fma.f64 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b (exp.f64 a)) #s(literal 1 binary64))) |
#s(approx (+ (exp a) (exp b)) (+.f64 (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) b #s(literal 1/2 binary64)) b #s(literal 1 binary64)) b (exp.f64 a)) #s(literal 1 binary64))) |
#s(approx (/ 1 (- (exp b) -1)) (/.f64 #s(literal 1 binary64) (+.f64 #s(literal 1 binary64) (exp.f64 b)))) |
#s(approx (- (exp b) -1) (+.f64 #s(literal 1 binary64) (exp.f64 b))) |
#s(approx (exp b) (exp.f64 b)) |
Compiled 1 651 to 595 computations (64% saved)
12 alts after pruning (10 fresh and 2 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 143 | 10 | 153 |
| Fresh | 0 | 0 | 0 |
| Picked | 2 | 2 | 4 |
| Done | 0 | 0 | 0 |
| Total | 145 | 12 | 157 |
| Status | Accuracy | Program |
|---|---|---|
| 61.8% | (/.f64 (exp.f64 a) (+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp b) #s(literal 1 binary64)))) | |
| ✓ | 62.8% | (/.f64 (exp.f64 a) #s(approx (+ (exp a) (exp b)) (-.f64 (exp.f64 a) #s(literal -1 binary64)))) |
| 61.6% | (/.f64 (exp.f64 a) #s(approx (+ (exp a) (exp b)) #s(approx (- (exp b) -1) #s(literal 2 binary64)))) | |
| 61.9% | (/.f64 (exp.f64 a) #s(approx (+ (exp a) (exp b)) #s(approx (- (exp a) -1) (fma.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a #s(literal 2 binary64))))) | |
| ▶ | 61.8% | (/.f64 (exp.f64 a) #s(approx (+ (exp a) (exp b)) #s(approx (- (exp a) -1) (+.f64 #s(literal 2 binary64) a)))) |
| ▶ | 82.7% | (/.f64 #s(approx (exp a) (+.f64 #s(literal 1 binary64) a)) (+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) (exp.f64 b))) |
| ✓ | 82.1% | #s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) (-.f64 (exp.f64 b) #s(literal -1 binary64)))) |
| 46.7% | #s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) #s(approx (- (exp b) -1) (fma.f64 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b #s(literal 2 binary64))))) | |
| ▶ | 33.2% | #s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) #s(approx (- (exp b) -1) (+.f64 #s(literal 2 binary64) b)))) |
| ▶ | 32.4% | #s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (/ 1 (- (exp b) -1)) (fma.f64 (-.f64 (*.f64 (*.f64 b b) #s(literal 1/48 binary64)) #s(literal 1/4 binary64)) b #s(literal 1/2 binary64)))) |
| 33.3% | #s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (/ 1 (- (exp b) -1)) (fma.f64 #s(literal -1/4 binary64) b #s(literal 1/2 binary64)))) | |
| ▶ | 35.3% | #s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (/ 1 (- (exp b) -1)) #s(literal 1/2 binary64))) |
Compiled 336 to 306 computations (8.9% saved)
| Inputs |
|---|
(/.f64 #s(approx (exp a) (+.f64 #s(literal 1 binary64) a)) (+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) (exp.f64 b))) |
#s(approx (exp a) (+.f64 #s(literal 1 binary64) a)) |
(+.f64 #s(literal 1 binary64) a) |
#s(literal 1 binary64) |
a |
(+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) (exp.f64 b)) |
#s(approx (exp a) (-.f64 a #s(literal -1 binary64))) |
(-.f64 a #s(literal -1 binary64)) |
#s(literal -1 binary64) |
(exp.f64 b) |
b |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (/ 1 (- (exp b) -1)) #s(literal 1/2 binary64))) |
#s(approx (/ 1 (- (exp b) -1)) #s(literal 1/2 binary64)) |
#s(literal 1/2 binary64) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) #s(approx (- (exp b) -1) (+.f64 #s(literal 2 binary64) b)))) |
(/.f64 #s(literal 1 binary64) #s(approx (- (exp b) -1) (+.f64 #s(literal 2 binary64) b))) |
#s(approx (- (exp b) -1) (+.f64 #s(literal 2 binary64) b)) |
(+.f64 #s(literal 2 binary64) b) |
#s(literal 2 binary64) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (/ 1 (- (exp b) -1)) (fma.f64 (-.f64 (*.f64 (*.f64 b b) #s(literal 1/48 binary64)) #s(literal 1/4 binary64)) b #s(literal 1/2 binary64)))) |
#s(approx (/ 1 (- (exp b) -1)) (fma.f64 (-.f64 (*.f64 (*.f64 b b) #s(literal 1/48 binary64)) #s(literal 1/4 binary64)) b #s(literal 1/2 binary64))) |
(fma.f64 (-.f64 (*.f64 (*.f64 b b) #s(literal 1/48 binary64)) #s(literal 1/4 binary64)) b #s(literal 1/2 binary64)) |
(-.f64 (*.f64 (*.f64 b b) #s(literal 1/48 binary64)) #s(literal 1/4 binary64)) |
(*.f64 (*.f64 b b) #s(literal 1/48 binary64)) |
(*.f64 b b) |
#s(literal 1/48 binary64) |
#s(literal 1/4 binary64) |
(/.f64 (exp.f64 a) #s(approx (+ (exp a) (exp b)) #s(approx (- (exp a) -1) (+.f64 #s(literal 2 binary64) a)))) |
(exp.f64 a) |
#s(approx (+ (exp a) (exp b)) #s(approx (- (exp a) -1) (+.f64 #s(literal 2 binary64) a))) |
#s(approx (- (exp a) -1) (+.f64 #s(literal 2 binary64) a)) |
(+.f64 #s(literal 2 binary64) a) |
| Outputs |
|---|
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(hole binary64 (/ 1 (+ 1 (exp b))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(hole binary64 (+ (* a (- (/ 1 (+ 1 (exp b))) (/ 1 (pow (+ 1 (exp b)) 2)))) (/ 1 (+ 1 (exp b)))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(hole binary64 (+ (* a (- (+ (* a (- (+ (* 1/2 (/ 1 (+ 1 (exp b)))) (/ 1 (pow (+ 1 (exp b)) 3))) (* 3/2 (/ 1 (pow (+ 1 (exp b)) 2))))) (/ 1 (+ 1 (exp b)))) (/ 1 (pow (+ 1 (exp b)) 2)))) (/ 1 (+ 1 (exp b)))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(hole binary64 (+ (* a (- (+ (* a (- (+ (* 1/2 (/ 1 (+ 1 (exp b)))) (+ (* a (- (+ (* 1/6 (/ 1 (+ 1 (exp b)))) (* 3/2 (/ 1 (pow (+ 1 (exp b)) 3)))) (+ (* 1/6 (/ 1 (pow (+ 1 (exp b)) 2))) (+ (* 1/2 (/ 1 (pow (+ 1 (exp b)) 2))) (+ (* 1/2 (/ (- (/ 1 (+ 1 (exp b))) (/ 1 (pow (+ 1 (exp b)) 2))) (+ 1 (exp b)))) (/ 1 (pow (+ 1 (exp b)) 4))))))) (/ 1 (pow (+ 1 (exp b)) 3)))) (* 3/2 (/ 1 (pow (+ 1 (exp b)) 2))))) (/ 1 (+ 1 (exp b)))) (/ 1 (pow (+ 1 (exp b)) 2)))) (/ 1 (+ 1 (exp b)))))) |
#s(approx (exp a) #s(hole binary64 1)) |
#s(approx (exp a) #s(hole binary64 (+ 1 a))) |
#s(approx (exp a) #s(hole binary64 (+ 1 (* a (+ 1 (* 1/2 a)))))) |
#s(approx (exp a) #s(hole binary64 (+ 1 (* a (+ 1 (* a (+ 1/2 (* 1/6 a)))))))) |
#s(approx (+ 1 a) #s(hole binary64 1)) |
#s(approx (+ 1 a) #s(hole binary64 (+ 1 a))) |
#s(approx a #s(hole binary64 a)) |
#s(approx (+ (exp a) (exp b)) #s(hole binary64 (+ 1 (exp b)))) |
#s(approx (+ (exp a) (exp b)) #s(hole binary64 (+ 1 (+ a (exp b))))) |
#s(approx (+ (exp a) (exp b)) #s(hole binary64 (+ 1 (+ (exp b) (* a (+ 1 (* 1/2 a))))))) |
#s(approx (+ (exp a) (exp b)) #s(hole binary64 (+ 1 (+ (exp b) (* a (+ 1 (* a (+ 1/2 (* 1/6 a))))))))) |
#s(approx (- a -1) #s(hole binary64 1)) |
#s(approx (- a -1) #s(hole binary64 (+ 1 a))) |
#s(approx (- (exp a) -1) #s(hole binary64 2)) |
#s(approx (- (exp a) -1) #s(hole binary64 (+ 2 a))) |
#s(approx (- (exp a) -1) #s(hole binary64 (+ 2 (* a (+ 1 (* 1/2 a)))))) |
#s(approx (- (exp a) -1) #s(hole binary64 (+ 2 (* a (+ 1 (* a (+ 1/2 (* 1/6 a)))))))) |
#s(approx (+ 2 a) #s(hole binary64 2)) |
#s(approx (+ 2 a) #s(hole binary64 (+ 2 a))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(hole binary64 (/ (exp a) (+ (exp a) (exp b))))) |
#s(approx (exp a) #s(hole binary64 (exp a))) |
#s(approx (+ 1 a) #s(hole binary64 a)) |
#s(approx (+ 1 a) #s(hole binary64 (* a (+ 1 (/ 1 a))))) |
#s(approx (+ (exp a) (exp b)) #s(hole binary64 (+ (exp a) (exp b)))) |
#s(approx (- a -1) #s(hole binary64 a)) |
#s(approx (- a -1) #s(hole binary64 (* a (+ 1 (/ 1 a))))) |
#s(approx (- (exp a) -1) #s(hole binary64 (+ 1 (exp a)))) |
#s(approx (+ 2 a) #s(hole binary64 a)) |
#s(approx (+ 2 a) #s(hole binary64 (* a (+ 1 (* 2 (/ 1 a)))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(hole binary64 (/ (exp a) (+ 1 (exp a))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(hole binary64 (+ (* -1 (/ (* b (exp a)) (pow (+ 1 (exp a)) 2))) (/ (exp a) (+ 1 (exp a)))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(hole binary64 (+ (* b (- (* -1 (* b (+ (* -1 (/ (exp a) (pow (+ 1 (exp a)) 3))) (* 1/2 (/ (exp a) (pow (+ 1 (exp a)) 2)))))) (/ (exp a) (pow (+ 1 (exp a)) 2)))) (/ (exp a) (+ 1 (exp a)))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(hole binary64 (+ (* b (- (* b (- (* -1 (* b (+ (* -1 (/ (+ (* -1 (/ (exp a) (pow (+ 1 (exp a)) 3))) (* 1/2 (/ (exp a) (pow (+ 1 (exp a)) 2)))) (+ 1 (exp a)))) (+ (* -1/2 (/ (exp a) (pow (+ 1 (exp a)) 3))) (* 1/6 (/ (exp a) (pow (+ 1 (exp a)) 2))))))) (+ (* -1 (/ (exp a) (pow (+ 1 (exp a)) 3))) (* 1/2 (/ (exp a) (pow (+ 1 (exp a)) 2)))))) (/ (exp a) (pow (+ 1 (exp a)) 2)))) (/ (exp a) (+ 1 (exp a)))))) |
#s(approx (+ (exp a) (exp b)) #s(hole binary64 (+ 1 (exp a)))) |
#s(approx (+ (exp a) (exp b)) #s(hole binary64 (+ 1 (+ b (exp a))))) |
#s(approx (+ (exp a) (exp b)) #s(hole binary64 (+ 1 (+ (exp a) (* b (+ 1 (* 1/2 b))))))) |
#s(approx (+ (exp a) (exp b)) #s(hole binary64 (+ 1 (+ (exp a) (* b (+ 1 (* b (+ 1/2 (* 1/6 b))))))))) |
#s(approx (exp b) #s(hole binary64 1)) |
#s(approx (exp b) #s(hole binary64 (+ 1 b))) |
#s(approx (exp b) #s(hole binary64 (+ 1 (* b (+ 1 (* 1/2 b)))))) |
#s(approx (exp b) #s(hole binary64 (+ 1 (* b (+ 1 (* b (+ 1/2 (* 1/6 b)))))))) |
#s(approx b #s(hole binary64 b)) |
#s(approx (/ 1 (- (exp b) -1)) #s(hole binary64 1/2)) |
#s(approx (/ 1 (- (exp b) -1)) #s(hole binary64 (+ 1/2 (* -1/4 b)))) |
#s(approx (/ 1 (- (exp b) -1)) #s(hole binary64 (+ 1/2 (* b (- (* 1/48 (pow b 2)) 1/4))))) |
#s(approx (/ 1 (- (exp b) -1)) #s(hole binary64 (+ 1/2 (* b (- (* (pow b 2) (+ 1/48 (* -1/480 (pow b 2)))) 1/4))))) |
#s(approx (- (exp b) -1) #s(hole binary64 2)) |
#s(approx (- (exp b) -1) #s(hole binary64 (+ 2 b))) |
#s(approx (- (exp b) -1) #s(hole binary64 (+ 2 (* b (+ 1 (* 1/2 b)))))) |
#s(approx (- (exp b) -1) #s(hole binary64 (+ 2 (* b (+ 1 (* b (+ 1/2 (* 1/6 b)))))))) |
#s(approx (+ 2 b) #s(hole binary64 2)) |
#s(approx (+ 2 b) #s(hole binary64 (+ 2 b))) |
#s(approx (+ (* (- (* (* b b) 1/48) 1/4) b) 1/2) #s(hole binary64 1/2)) |
#s(approx (+ (* (- (* (* b b) 1/48) 1/4) b) 1/2) #s(hole binary64 (+ 1/2 (* -1/4 b)))) |
#s(approx (+ (* (- (* (* b b) 1/48) 1/4) b) 1/2) #s(hole binary64 (+ 1/2 (* b (- (* 1/48 (pow b 2)) 1/4))))) |
#s(approx (- (* (* b b) 1/48) 1/4) #s(hole binary64 -1/4)) |
#s(approx (- (* (* b b) 1/48) 1/4) #s(hole binary64 (- (* 1/48 (pow b 2)) 1/4))) |
#s(approx (* (* b b) 1/48) #s(hole binary64 (* 1/48 (pow b 2)))) |
#s(approx (* b b) #s(hole binary64 (pow b 2))) |
#s(approx (exp b) #s(hole binary64 (exp b))) |
#s(approx (/ 1 (- (exp b) -1)) #s(hole binary64 (/ 1 (+ 1 (exp b))))) |
#s(approx (- (exp b) -1) #s(hole binary64 (+ 1 (exp b)))) |
#s(approx (+ 2 b) #s(hole binary64 b)) |
#s(approx (+ 2 b) #s(hole binary64 (* b (+ 1 (* 2 (/ 1 b)))))) |
#s(approx (+ (* (- (* (* b b) 1/48) 1/4) b) 1/2) #s(hole binary64 (* 1/48 (pow b 3)))) |
#s(approx (+ (* (- (* (* b b) 1/48) 1/4) b) 1/2) #s(hole binary64 (* (pow b 3) (- 1/48 (* 1/4 (/ 1 (pow b 2))))))) |
#s(approx (+ (* (- (* (* b b) 1/48) 1/4) b) 1/2) #s(hole binary64 (* (pow b 3) (- (+ 1/48 (/ 1/2 (pow b 3))) (* 1/4 (/ 1 (pow b 2))))))) |
#s(approx (- (* (* b b) 1/48) 1/4) #s(hole binary64 (* 1/48 (pow b 2)))) |
#s(approx (- (* (* b b) 1/48) 1/4) #s(hole binary64 (* (pow b 2) (- 1/48 (* 1/4 (/ 1 (pow b 2))))))) |
#s(approx (+ (* (- (* (* b b) 1/48) 1/4) b) 1/2) #s(hole binary64 (* -1 (* (pow b 3) (- (* 1/4 (/ 1 (pow b 2))) 1/48))))) |
#s(approx (+ (* (- (* (* b b) 1/48) 1/4) b) 1/2) #s(hole binary64 (* -1 (* (pow b 3) (- (* 1/4 (/ 1 (pow b 2))) (+ 1/48 (/ 1/2 (pow b 3)))))))) |
6 calls:
| Time | Variable | Point | Expression | |
|---|---|---|---|---|
| 3.0ms | b | @ | -inf | ((/ (exp a) (+ (exp a) (exp b))) (exp a) (+ 1 a) 1 a (+ (exp a) (exp b)) (exp a) (- a -1) -1 (exp b) b (/ (exp a) (+ (exp a) (exp b))) (/ 1 (- (exp b) -1)) 1/2 (/ (exp a) (+ (exp a) (exp b))) (/ 1 (- (exp b) -1)) (- (exp b) -1) (+ 2 b) 2 (/ (exp a) (+ (exp a) (exp b))) (/ 1 (- (exp b) -1)) (+ (* (- (* (* b b) 1/48) 1/4) b) 1/2) (- (* (* b b) 1/48) 1/4) (* (* b b) 1/48) (* b b) 1/48 1/4 (/ (exp a) (+ (exp a) (exp b))) (exp a) (+ (exp a) (exp b)) (- (exp a) -1) (+ 2 a)) |
| 2.0ms | b | @ | inf | ((/ (exp a) (+ (exp a) (exp b))) (exp a) (+ 1 a) 1 a (+ (exp a) (exp b)) (exp a) (- a -1) -1 (exp b) b (/ (exp a) (+ (exp a) (exp b))) (/ 1 (- (exp b) -1)) 1/2 (/ (exp a) (+ (exp a) (exp b))) (/ 1 (- (exp b) -1)) (- (exp b) -1) (+ 2 b) 2 (/ (exp a) (+ (exp a) (exp b))) (/ 1 (- (exp b) -1)) (+ (* (- (* (* b b) 1/48) 1/4) b) 1/2) (- (* (* b b) 1/48) 1/4) (* (* b b) 1/48) (* b b) 1/48 1/4 (/ (exp a) (+ (exp a) (exp b))) (exp a) (+ (exp a) (exp b)) (- (exp a) -1) (+ 2 a)) |
| 1.0ms | b | @ | 0 | ((/ (exp a) (+ (exp a) (exp b))) (exp a) (+ 1 a) 1 a (+ (exp a) (exp b)) (exp a) (- a -1) -1 (exp b) b (/ (exp a) (+ (exp a) (exp b))) (/ 1 (- (exp b) -1)) 1/2 (/ (exp a) (+ (exp a) (exp b))) (/ 1 (- (exp b) -1)) (- (exp b) -1) (+ 2 b) 2 (/ (exp a) (+ (exp a) (exp b))) (/ 1 (- (exp b) -1)) (+ (* (- (* (* b b) 1/48) 1/4) b) 1/2) (- (* (* b b) 1/48) 1/4) (* (* b b) 1/48) (* b b) 1/48 1/4 (/ (exp a) (+ (exp a) (exp b))) (exp a) (+ (exp a) (exp b)) (- (exp a) -1) (+ 2 a)) |
| 1.0ms | a | @ | -inf | ((/ (exp a) (+ (exp a) (exp b))) (exp a) (+ 1 a) 1 a (+ (exp a) (exp b)) (exp a) (- a -1) -1 (exp b) b (/ (exp a) (+ (exp a) (exp b))) (/ 1 (- (exp b) -1)) 1/2 (/ (exp a) (+ (exp a) (exp b))) (/ 1 (- (exp b) -1)) (- (exp b) -1) (+ 2 b) 2 (/ (exp a) (+ (exp a) (exp b))) (/ 1 (- (exp b) -1)) (+ (* (- (* (* b b) 1/48) 1/4) b) 1/2) (- (* (* b b) 1/48) 1/4) (* (* b b) 1/48) (* b b) 1/48 1/4 (/ (exp a) (+ (exp a) (exp b))) (exp a) (+ (exp a) (exp b)) (- (exp a) -1) (+ 2 a)) |
| 1.0ms | a | @ | inf | ((/ (exp a) (+ (exp a) (exp b))) (exp a) (+ 1 a) 1 a (+ (exp a) (exp b)) (exp a) (- a -1) -1 (exp b) b (/ (exp a) (+ (exp a) (exp b))) (/ 1 (- (exp b) -1)) 1/2 (/ (exp a) (+ (exp a) (exp b))) (/ 1 (- (exp b) -1)) (- (exp b) -1) (+ 2 b) 2 (/ (exp a) (+ (exp a) (exp b))) (/ 1 (- (exp b) -1)) (+ (* (- (* (* b b) 1/48) 1/4) b) 1/2) (- (* (* b b) 1/48) 1/4) (* (* b b) 1/48) (* b b) 1/48 1/4 (/ (exp a) (+ (exp a) (exp b))) (exp a) (+ (exp a) (exp b)) (- (exp a) -1) (+ 2 a)) |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 277 | 1496 |
| 0 | 293 | 1441 |
| 1 | 1551 | 1428 |
| 0 | 8687 | 1367 |
| 1× | iter-limit |
| 1× | node-limit |
| 1× | iter-limit |
| Inputs |
|---|
(/.f64 #s(approx (exp a) (+.f64 #s(literal 1 binary64) a)) (+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) (exp.f64 b))) |
#s(approx (exp a) (+.f64 #s(literal 1 binary64) a)) |
(+.f64 #s(literal 1 binary64) a) |
#s(literal 1 binary64) |
a |
(+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) (exp.f64 b)) |
#s(approx (exp a) (-.f64 a #s(literal -1 binary64))) |
(-.f64 a #s(literal -1 binary64)) |
#s(literal -1 binary64) |
(exp.f64 b) |
b |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (/ 1 (- (exp b) -1)) #s(literal 1/2 binary64))) |
#s(approx (/ 1 (- (exp b) -1)) #s(literal 1/2 binary64)) |
#s(literal 1/2 binary64) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) #s(approx (- (exp b) -1) (+.f64 #s(literal 2 binary64) b)))) |
(/.f64 #s(literal 1 binary64) #s(approx (- (exp b) -1) (+.f64 #s(literal 2 binary64) b))) |
#s(approx (- (exp b) -1) (+.f64 #s(literal 2 binary64) b)) |
(+.f64 #s(literal 2 binary64) b) |
#s(literal 2 binary64) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (/ 1 (- (exp b) -1)) (fma.f64 (-.f64 (*.f64 (*.f64 b b) #s(literal 1/48 binary64)) #s(literal 1/4 binary64)) b #s(literal 1/2 binary64)))) |
#s(approx (/ 1 (- (exp b) -1)) (fma.f64 (-.f64 (*.f64 (*.f64 b b) #s(literal 1/48 binary64)) #s(literal 1/4 binary64)) b #s(literal 1/2 binary64))) |
(fma.f64 (-.f64 (*.f64 (*.f64 b b) #s(literal 1/48 binary64)) #s(literal 1/4 binary64)) b #s(literal 1/2 binary64)) |
(-.f64 (*.f64 (*.f64 b b) #s(literal 1/48 binary64)) #s(literal 1/4 binary64)) |
(*.f64 (*.f64 b b) #s(literal 1/48 binary64)) |
(*.f64 b b) |
#s(literal 1/48 binary64) |
#s(literal 1/4 binary64) |
(/.f64 (exp.f64 a) #s(approx (+ (exp a) (exp b)) #s(approx (- (exp a) -1) (+.f64 #s(literal 2 binary64) a)))) |
(exp.f64 a) |
#s(approx (+ (exp a) (exp b)) #s(approx (- (exp a) -1) (+.f64 #s(literal 2 binary64) a))) |
#s(approx (- (exp a) -1) (+.f64 #s(literal 2 binary64) a)) |
(+.f64 #s(literal 2 binary64) a) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(hole binary64 (/ 1 (+ 1 (exp b))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(hole binary64 (+ (* a (- (/ 1 (+ 1 (exp b))) (/ 1 (pow (+ 1 (exp b)) 2)))) (/ 1 (+ 1 (exp b)))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(hole binary64 (+ (* a (- (+ (* a (- (+ (* 1/2 (/ 1 (+ 1 (exp b)))) (/ 1 (pow (+ 1 (exp b)) 3))) (* 3/2 (/ 1 (pow (+ 1 (exp b)) 2))))) (/ 1 (+ 1 (exp b)))) (/ 1 (pow (+ 1 (exp b)) 2)))) (/ 1 (+ 1 (exp b)))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(hole binary64 (+ (* a (- (+ (* a (- (+ (* 1/2 (/ 1 (+ 1 (exp b)))) (+ (* a (- (+ (* 1/6 (/ 1 (+ 1 (exp b)))) (* 3/2 (/ 1 (pow (+ 1 (exp b)) 3)))) (+ (* 1/6 (/ 1 (pow (+ 1 (exp b)) 2))) (+ (* 1/2 (/ 1 (pow (+ 1 (exp b)) 2))) (+ (* 1/2 (/ (- (/ 1 (+ 1 (exp b))) (/ 1 (pow (+ 1 (exp b)) 2))) (+ 1 (exp b)))) (/ 1 (pow (+ 1 (exp b)) 4))))))) (/ 1 (pow (+ 1 (exp b)) 3)))) (* 3/2 (/ 1 (pow (+ 1 (exp b)) 2))))) (/ 1 (+ 1 (exp b)))) (/ 1 (pow (+ 1 (exp b)) 2)))) (/ 1 (+ 1 (exp b)))))) |
#s(approx (exp a) #s(hole binary64 1)) |
#s(approx (exp a) #s(hole binary64 (+ 1 a))) |
#s(approx (exp a) #s(hole binary64 (+ 1 (* a (+ 1 (* 1/2 a)))))) |
#s(approx (exp a) #s(hole binary64 (+ 1 (* a (+ 1 (* a (+ 1/2 (* 1/6 a)))))))) |
#s(approx (+ 1 a) #s(hole binary64 1)) |
#s(approx (+ 1 a) #s(hole binary64 (+ 1 a))) |
#s(approx a #s(hole binary64 a)) |
#s(approx (+ (exp a) (exp b)) #s(hole binary64 (+ 1 (exp b)))) |
#s(approx (+ (exp a) (exp b)) #s(hole binary64 (+ 1 (+ a (exp b))))) |
#s(approx (+ (exp a) (exp b)) #s(hole binary64 (+ 1 (+ (exp b) (* a (+ 1 (* 1/2 a))))))) |
#s(approx (+ (exp a) (exp b)) #s(hole binary64 (+ 1 (+ (exp b) (* a (+ 1 (* a (+ 1/2 (* 1/6 a))))))))) |
#s(approx (- a -1) #s(hole binary64 1)) |
#s(approx (- a -1) #s(hole binary64 (+ 1 a))) |
#s(approx (- (exp a) -1) #s(hole binary64 2)) |
#s(approx (- (exp a) -1) #s(hole binary64 (+ 2 a))) |
#s(approx (- (exp a) -1) #s(hole binary64 (+ 2 (* a (+ 1 (* 1/2 a)))))) |
#s(approx (- (exp a) -1) #s(hole binary64 (+ 2 (* a (+ 1 (* a (+ 1/2 (* 1/6 a)))))))) |
#s(approx (+ 2 a) #s(hole binary64 2)) |
#s(approx (+ 2 a) #s(hole binary64 (+ 2 a))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(hole binary64 (/ (exp a) (+ (exp a) (exp b))))) |
#s(approx (exp a) #s(hole binary64 (exp a))) |
#s(approx (+ 1 a) #s(hole binary64 a)) |
#s(approx (+ 1 a) #s(hole binary64 (* a (+ 1 (/ 1 a))))) |
#s(approx (+ (exp a) (exp b)) #s(hole binary64 (+ (exp a) (exp b)))) |
#s(approx (- a -1) #s(hole binary64 a)) |
#s(approx (- a -1) #s(hole binary64 (* a (+ 1 (/ 1 a))))) |
#s(approx (- (exp a) -1) #s(hole binary64 (+ 1 (exp a)))) |
#s(approx (+ 2 a) #s(hole binary64 a)) |
#s(approx (+ 2 a) #s(hole binary64 (* a (+ 1 (* 2 (/ 1 a)))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(hole binary64 (/ (exp a) (+ 1 (exp a))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(hole binary64 (+ (* -1 (/ (* b (exp a)) (pow (+ 1 (exp a)) 2))) (/ (exp a) (+ 1 (exp a)))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(hole binary64 (+ (* b (- (* -1 (* b (+ (* -1 (/ (exp a) (pow (+ 1 (exp a)) 3))) (* 1/2 (/ (exp a) (pow (+ 1 (exp a)) 2)))))) (/ (exp a) (pow (+ 1 (exp a)) 2)))) (/ (exp a) (+ 1 (exp a)))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(hole binary64 (+ (* b (- (* b (- (* -1 (* b (+ (* -1 (/ (+ (* -1 (/ (exp a) (pow (+ 1 (exp a)) 3))) (* 1/2 (/ (exp a) (pow (+ 1 (exp a)) 2)))) (+ 1 (exp a)))) (+ (* -1/2 (/ (exp a) (pow (+ 1 (exp a)) 3))) (* 1/6 (/ (exp a) (pow (+ 1 (exp a)) 2))))))) (+ (* -1 (/ (exp a) (pow (+ 1 (exp a)) 3))) (* 1/2 (/ (exp a) (pow (+ 1 (exp a)) 2)))))) (/ (exp a) (pow (+ 1 (exp a)) 2)))) (/ (exp a) (+ 1 (exp a)))))) |
#s(approx (+ (exp a) (exp b)) #s(hole binary64 (+ 1 (exp a)))) |
#s(approx (+ (exp a) (exp b)) #s(hole binary64 (+ 1 (+ b (exp a))))) |
#s(approx (+ (exp a) (exp b)) #s(hole binary64 (+ 1 (+ (exp a) (* b (+ 1 (* 1/2 b))))))) |
#s(approx (+ (exp a) (exp b)) #s(hole binary64 (+ 1 (+ (exp a) (* b (+ 1 (* b (+ 1/2 (* 1/6 b))))))))) |
#s(approx (exp b) #s(hole binary64 1)) |
#s(approx (exp b) #s(hole binary64 (+ 1 b))) |
#s(approx (exp b) #s(hole binary64 (+ 1 (* b (+ 1 (* 1/2 b)))))) |
#s(approx (exp b) #s(hole binary64 (+ 1 (* b (+ 1 (* b (+ 1/2 (* 1/6 b)))))))) |
#s(approx b #s(hole binary64 b)) |
#s(approx (/ 1 (- (exp b) -1)) #s(hole binary64 1/2)) |
#s(approx (/ 1 (- (exp b) -1)) #s(hole binary64 (+ 1/2 (* -1/4 b)))) |
#s(approx (/ 1 (- (exp b) -1)) #s(hole binary64 (+ 1/2 (* b (- (* 1/48 (pow b 2)) 1/4))))) |
#s(approx (/ 1 (- (exp b) -1)) #s(hole binary64 (+ 1/2 (* b (- (* (pow b 2) (+ 1/48 (* -1/480 (pow b 2)))) 1/4))))) |
#s(approx (- (exp b) -1) #s(hole binary64 2)) |
#s(approx (- (exp b) -1) #s(hole binary64 (+ 2 b))) |
#s(approx (- (exp b) -1) #s(hole binary64 (+ 2 (* b (+ 1 (* 1/2 b)))))) |
#s(approx (- (exp b) -1) #s(hole binary64 (+ 2 (* b (+ 1 (* b (+ 1/2 (* 1/6 b)))))))) |
#s(approx (+ 2 b) #s(hole binary64 2)) |
#s(approx (+ 2 b) #s(hole binary64 (+ 2 b))) |
#s(approx (+ (* (- (* (* b b) 1/48) 1/4) b) 1/2) #s(hole binary64 1/2)) |
#s(approx (+ (* (- (* (* b b) 1/48) 1/4) b) 1/2) #s(hole binary64 (+ 1/2 (* -1/4 b)))) |
#s(approx (+ (* (- (* (* b b) 1/48) 1/4) b) 1/2) #s(hole binary64 (+ 1/2 (* b (- (* 1/48 (pow b 2)) 1/4))))) |
#s(approx (- (* (* b b) 1/48) 1/4) #s(hole binary64 -1/4)) |
#s(approx (- (* (* b b) 1/48) 1/4) #s(hole binary64 (- (* 1/48 (pow b 2)) 1/4))) |
#s(approx (* (* b b) 1/48) #s(hole binary64 (* 1/48 (pow b 2)))) |
#s(approx (* b b) #s(hole binary64 (pow b 2))) |
#s(approx (exp b) #s(hole binary64 (exp b))) |
#s(approx (/ 1 (- (exp b) -1)) #s(hole binary64 (/ 1 (+ 1 (exp b))))) |
#s(approx (- (exp b) -1) #s(hole binary64 (+ 1 (exp b)))) |
#s(approx (+ 2 b) #s(hole binary64 b)) |
#s(approx (+ 2 b) #s(hole binary64 (* b (+ 1 (* 2 (/ 1 b)))))) |
#s(approx (+ (* (- (* (* b b) 1/48) 1/4) b) 1/2) #s(hole binary64 (* 1/48 (pow b 3)))) |
#s(approx (+ (* (- (* (* b b) 1/48) 1/4) b) 1/2) #s(hole binary64 (* (pow b 3) (- 1/48 (* 1/4 (/ 1 (pow b 2))))))) |
#s(approx (+ (* (- (* (* b b) 1/48) 1/4) b) 1/2) #s(hole binary64 (* (pow b 3) (- (+ 1/48 (/ 1/2 (pow b 3))) (* 1/4 (/ 1 (pow b 2))))))) |
#s(approx (- (* (* b b) 1/48) 1/4) #s(hole binary64 (* 1/48 (pow b 2)))) |
#s(approx (- (* (* b b) 1/48) 1/4) #s(hole binary64 (* (pow b 2) (- 1/48 (* 1/4 (/ 1 (pow b 2))))))) |
#s(approx (+ (* (- (* (* b b) 1/48) 1/4) b) 1/2) #s(hole binary64 (* -1 (* (pow b 3) (- (* 1/4 (/ 1 (pow b 2))) 1/48))))) |
#s(approx (+ (* (- (* (* b b) 1/48) 1/4) b) 1/2) #s(hole binary64 (* -1 (* (pow b 3) (- (* 1/4 (/ 1 (pow b 2))) (+ 1/48 (/ 1/2 (pow b 3)))))))) |
| Outputs |
|---|
(/.f64 (neg.f64 (neg.f64 #s(approx (exp a) (+.f64 #s(literal 1 binary64) a)))) (neg.f64 (neg.f64 (+.f64 (exp.f64 b) #s(approx (exp a) (-.f64 a #s(literal -1 binary64))))))) |
(/.f64 (neg.f64 #s(approx (exp a) (+.f64 #s(literal 1 binary64) a))) (neg.f64 (+.f64 (exp.f64 b) #s(approx (exp a) (-.f64 a #s(literal -1 binary64)))))) |
(/.f64 #s(approx (exp a) (+.f64 #s(literal 1 binary64) a)) (+.f64 (exp.f64 b) #s(approx (exp a) (-.f64 a #s(literal -1 binary64))))) |
#s(approx (exp a) (+.f64 #s(literal 1 binary64) a)) |
(/.f64 (fma.f64 (*.f64 a a) a #s(literal 1 binary64)) (fma.f64 a a (-.f64 #s(literal 1 binary64) (*.f64 a #s(literal 1 binary64))))) |
(/.f64 (neg.f64 (-.f64 #s(literal 1 binary64) (*.f64 a a))) (neg.f64 (-.f64 #s(literal 1 binary64) a))) |
(/.f64 (neg.f64 (+.f64 #s(literal 1 binary64) (*.f64 (*.f64 a a) a))) (neg.f64 (+.f64 #s(literal 1 binary64) (-.f64 (*.f64 a a) (*.f64 #s(literal 1 binary64) a))))) |
(/.f64 (-.f64 #s(literal 1 binary64) (*.f64 a a)) (-.f64 #s(literal 1 binary64) a)) |
(/.f64 (+.f64 #s(literal 1 binary64) (*.f64 (*.f64 a a) a)) (+.f64 #s(literal 1 binary64) (-.f64 (*.f64 a a) (*.f64 #s(literal 1 binary64) a)))) |
(-.f64 (/.f64 #s(literal 1 binary64) (-.f64 #s(literal 1 binary64) a)) (/.f64 (*.f64 a a) (-.f64 #s(literal 1 binary64) a))) |
(+.f64 (/.f64 #s(literal 1 binary64) (+.f64 #s(literal 1 binary64) (-.f64 (*.f64 a a) (*.f64 #s(literal 1 binary64) a)))) (/.f64 (*.f64 (*.f64 a a) a) (+.f64 #s(literal 1 binary64) (-.f64 (*.f64 a a) (*.f64 #s(literal 1 binary64) a))))) |
(+.f64 #s(literal 1 binary64) a) |
(+.f64 a #s(literal 1 binary64)) |
#s(literal 1 binary64) |
a |
(/.f64 (+.f64 (exp.f64 (*.f64 b #s(literal 3 binary64))) (*.f64 (*.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp a) (-.f64 a #s(literal -1 binary64)))) #s(approx (exp a) (-.f64 a #s(literal -1 binary64))))) (+.f64 (exp.f64 (+.f64 b b)) (-.f64 (*.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp a) (-.f64 a #s(literal -1 binary64)))) (*.f64 (exp.f64 b) #s(approx (exp a) (-.f64 a #s(literal -1 binary64))))))) |
(/.f64 (neg.f64 (-.f64 (*.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp a) (-.f64 a #s(literal -1 binary64)))) (exp.f64 (+.f64 b b)))) (neg.f64 (-.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) (exp.f64 b)))) |
(/.f64 (neg.f64 (fma.f64 (*.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp a) (-.f64 a #s(literal -1 binary64)))) #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) (exp.f64 (*.f64 b #s(literal 3 binary64))))) (neg.f64 (fma.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) (-.f64 (exp.f64 (+.f64 b b)) (*.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) (exp.f64 b)))))) |
(/.f64 (-.f64 (*.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp a) (-.f64 a #s(literal -1 binary64)))) (exp.f64 (+.f64 b b))) (-.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) (exp.f64 b))) |
(/.f64 (fma.f64 (*.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp a) (-.f64 a #s(literal -1 binary64)))) #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) (exp.f64 (*.f64 b #s(literal 3 binary64)))) (fma.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) (-.f64 (exp.f64 (+.f64 b b)) (*.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) (exp.f64 b))))) |
(-.f64 (/.f64 (*.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp a) (-.f64 a #s(literal -1 binary64)))) (-.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) (exp.f64 b))) (/.f64 (exp.f64 (+.f64 b b)) (-.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) (exp.f64 b)))) |
(+.f64 (/.f64 (*.f64 (*.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp a) (-.f64 a #s(literal -1 binary64)))) #s(approx (exp a) (-.f64 a #s(literal -1 binary64)))) (fma.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) (-.f64 (exp.f64 (+.f64 b b)) (*.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) (exp.f64 b))))) (/.f64 (exp.f64 (*.f64 b #s(literal 3 binary64))) (fma.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) (-.f64 (exp.f64 (+.f64 b b)) (*.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) (exp.f64 b)))))) |
(+.f64 (exp.f64 b) #s(approx (exp a) (-.f64 a #s(literal -1 binary64)))) |
(+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) (exp.f64 b)) |
#s(approx (exp a) (-.f64 a #s(literal -1 binary64))) |
(/.f64 (neg.f64 (-.f64 (*.f64 a a) #s(literal 1 binary64))) (neg.f64 (+.f64 a #s(literal -1 binary64)))) |
(/.f64 (neg.f64 (-.f64 (*.f64 (*.f64 a a) a) #s(literal -1 binary64))) (neg.f64 (fma.f64 a a (+.f64 #s(literal 1 binary64) (*.f64 a #s(literal -1 binary64)))))) |
(/.f64 (-.f64 (*.f64 a a) #s(literal 1 binary64)) (+.f64 a #s(literal -1 binary64))) |
(/.f64 (-.f64 (*.f64 (*.f64 a a) a) #s(literal -1 binary64)) (fma.f64 a a (+.f64 #s(literal 1 binary64) (*.f64 a #s(literal -1 binary64))))) |
(-.f64 (/.f64 (*.f64 a a) (+.f64 a #s(literal -1 binary64))) (/.f64 #s(literal 1 binary64) (+.f64 a #s(literal -1 binary64)))) |
(-.f64 (/.f64 (*.f64 (*.f64 a a) a) (fma.f64 a a (+.f64 #s(literal 1 binary64) (*.f64 a #s(literal -1 binary64))))) (/.f64 #s(literal -1 binary64) (fma.f64 a a (+.f64 #s(literal 1 binary64) (*.f64 a #s(literal -1 binary64)))))) |
(-.f64 a #s(literal -1 binary64)) |
#s(literal -1 binary64) |
(/.f64 (+.f64 (pow.f64 (cosh.f64 b) #s(literal 3 binary64)) (pow.f64 (sinh.f64 b) #s(literal 3 binary64))) (fma.f64 (cosh.f64 b) (cosh.f64 b) (-.f64 (*.f64 (sinh.f64 b) (sinh.f64 b)) (*.f64 (cosh.f64 b) (sinh.f64 b))))) |
(+.f64 (cosh.f64 b) (sinh.f64 b)) |
(exp.f64 b) |
b |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (/ 1 (- (exp b) -1)) #s(literal 1/2 binary64))) |
#s(approx (/ 1 (- (exp b) -1)) #s(literal 1/2 binary64)) |
#s(literal 1/2 binary64) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) #s(approx (- (exp b) -1) (+.f64 #s(literal 2 binary64) b)))) |
(pow.f64 #s(approx (- (exp b) -1) (+.f64 #s(literal 2 binary64) b)) #s(literal -1 binary64)) |
(/.f64 #s(literal -1 binary64) (neg.f64 #s(approx (- (exp b) -1) (+.f64 #s(literal 2 binary64) b)))) |
(/.f64 #s(literal 1 binary64) (neg.f64 (neg.f64 #s(approx (- (exp b) -1) (+.f64 #s(literal 2 binary64) b))))) |
(/.f64 #s(literal 1 binary64) (pow.f64 #s(approx (- (exp b) -1) (+.f64 #s(literal 2 binary64) b)) #s(literal 1 binary64))) |
(/.f64 #s(literal 1 binary64) #s(approx (- (exp b) -1) (+.f64 #s(literal 2 binary64) b))) |
(exp.f64 (*.f64 (log.f64 #s(approx (- (exp b) -1) (+.f64 #s(literal 2 binary64) b))) #s(literal -1 binary64))) |
#s(approx (- (exp b) -1) (+.f64 #s(literal 2 binary64) b)) |
(/.f64 (fma.f64 (*.f64 b b) b #s(literal 8 binary64)) (fma.f64 b b (-.f64 #s(literal 4 binary64) (*.f64 b #s(literal 2 binary64))))) |
(/.f64 (neg.f64 (-.f64 #s(literal 4 binary64) (*.f64 b b))) (neg.f64 (-.f64 #s(literal 2 binary64) b))) |
(/.f64 (neg.f64 (+.f64 #s(literal 8 binary64) (*.f64 (*.f64 b b) b))) (neg.f64 (+.f64 #s(literal 4 binary64) (-.f64 (*.f64 b b) (*.f64 #s(literal 2 binary64) b))))) |
(/.f64 (-.f64 #s(literal 4 binary64) (*.f64 b b)) (-.f64 #s(literal 2 binary64) b)) |
(/.f64 (+.f64 #s(literal 8 binary64) (*.f64 (*.f64 b b) b)) (+.f64 #s(literal 4 binary64) (-.f64 (*.f64 b b) (*.f64 #s(literal 2 binary64) b)))) |
(-.f64 (/.f64 #s(literal 4 binary64) (-.f64 #s(literal 2 binary64) b)) (/.f64 (*.f64 b b) (-.f64 #s(literal 2 binary64) b))) |
(+.f64 (/.f64 #s(literal 8 binary64) (+.f64 #s(literal 4 binary64) (-.f64 (*.f64 b b) (*.f64 #s(literal 2 binary64) b)))) (/.f64 (*.f64 (*.f64 b b) b) (+.f64 #s(literal 4 binary64) (-.f64 (*.f64 b b) (*.f64 #s(literal 2 binary64) b))))) |
(+.f64 #s(literal 2 binary64) b) |
(+.f64 b #s(literal 2 binary64)) |
#s(literal 2 binary64) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (/ 1 (- (exp b) -1)) (fma.f64 (-.f64 (*.f64 (*.f64 b b) #s(literal 1/48 binary64)) #s(literal 1/4 binary64)) b #s(literal 1/2 binary64)))) |
#s(approx (/ 1 (- (exp b) -1)) (fma.f64 (-.f64 (*.f64 (*.f64 b b) #s(literal 1/48 binary64)) #s(literal 1/4 binary64)) b #s(literal 1/2 binary64))) |
(/.f64 (-.f64 #s(literal 1/8 binary64) (pow.f64 (*.f64 (neg.f64 b) (-.f64 (*.f64 (*.f64 b b) #s(literal 1/48 binary64)) #s(literal 1/4 binary64))) #s(literal 3 binary64))) (+.f64 #s(literal 1/4 binary64) (fma.f64 (*.f64 (neg.f64 b) (-.f64 (*.f64 (*.f64 b b) #s(literal 1/48 binary64)) #s(literal 1/4 binary64))) (*.f64 (neg.f64 b) (-.f64 (*.f64 (*.f64 b b) #s(literal 1/48 binary64)) #s(literal 1/4 binary64))) (*.f64 #s(literal 1/2 binary64) (*.f64 (neg.f64 b) (-.f64 (*.f64 (*.f64 b b) #s(literal 1/48 binary64)) #s(literal 1/4 binary64))))))) |
(/.f64 (neg.f64 (-.f64 #s(literal 1/4 binary64) (*.f64 (*.f64 (-.f64 (*.f64 (*.f64 b b) #s(literal 1/48 binary64)) #s(literal 1/4 binary64)) b) (*.f64 (-.f64 (*.f64 (*.f64 b b) #s(literal 1/48 binary64)) #s(literal 1/4 binary64)) b)))) (neg.f64 (-.f64 #s(literal 1/2 binary64) (*.f64 (-.f64 (*.f64 (*.f64 b b) #s(literal 1/48 binary64)) #s(literal 1/4 binary64)) b)))) |
(/.f64 (neg.f64 (-.f64 (*.f64 (*.f64 (-.f64 (*.f64 (*.f64 b b) #s(literal 1/48 binary64)) #s(literal 1/4 binary64)) b) (*.f64 (-.f64 (*.f64 (*.f64 b b) #s(literal 1/48 binary64)) #s(literal 1/4 binary64)) b)) #s(literal 1/4 binary64))) (neg.f64 (-.f64 (*.f64 (-.f64 (*.f64 (*.f64 b b) #s(literal 1/48 binary64)) #s(literal 1/4 binary64)) b) #s(literal 1/2 binary64)))) |
(/.f64 (neg.f64 (+.f64 #s(literal 1/8 binary64) (pow.f64 (*.f64 (-.f64 (*.f64 (*.f64 b b) #s(literal 1/48 binary64)) #s(literal 1/4 binary64)) b) #s(literal 3 binary64)))) (neg.f64 (+.f64 #s(literal 1/4 binary64) (-.f64 (*.f64 (*.f64 (-.f64 (*.f64 (*.f64 b b) #s(literal 1/48 binary64)) #s(literal 1/4 binary64)) b) (*.f64 (-.f64 (*.f64 (*.f64 b b) #s(literal 1/48 binary64)) #s(literal 1/4 binary64)) b)) (*.f64 #s(literal 1/2 binary64) (*.f64 (-.f64 (*.f64 (*.f64 b b) #s(literal 1/48 binary64)) #s(literal 1/4 binary64)) b)))))) |
(/.f64 (neg.f64 (+.f64 (pow.f64 (*.f64 (-.f64 (*.f64 (*.f64 b b) #s(literal 1/48 binary64)) #s(literal 1/4 binary64)) b) #s(literal 3 binary64)) #s(literal 1/8 binary64))) (neg.f64 (fma.f64 (*.f64 (-.f64 (*.f64 (*.f64 b b) #s(literal 1/48 binary64)) #s(literal 1/4 binary64)) b) (*.f64 (-.f64 (*.f64 (*.f64 b b) #s(literal 1/48 binary64)) #s(literal 1/4 binary64)) b) (-.f64 #s(literal 1/4 binary64) (*.f64 (*.f64 (-.f64 (*.f64 (*.f64 b b) #s(literal 1/48 binary64)) #s(literal 1/4 binary64)) b) #s(literal 1/2 binary64)))))) |
(/.f64 (-.f64 #s(literal 1/4 binary64) (*.f64 (*.f64 (-.f64 (*.f64 (*.f64 b b) #s(literal 1/48 binary64)) #s(literal 1/4 binary64)) b) (*.f64 (-.f64 (*.f64 (*.f64 b b) #s(literal 1/48 binary64)) #s(literal 1/4 binary64)) b))) (-.f64 #s(literal 1/2 binary64) (*.f64 (-.f64 (*.f64 (*.f64 b b) #s(literal 1/48 binary64)) #s(literal 1/4 binary64)) b))) |
(/.f64 (-.f64 (*.f64 (*.f64 (-.f64 (*.f64 (*.f64 b b) #s(literal 1/48 binary64)) #s(literal 1/4 binary64)) b) (*.f64 (-.f64 (*.f64 (*.f64 b b) #s(literal 1/48 binary64)) #s(literal 1/4 binary64)) b)) #s(literal 1/4 binary64)) (-.f64 (*.f64 (-.f64 (*.f64 (*.f64 b b) #s(literal 1/48 binary64)) #s(literal 1/4 binary64)) b) #s(literal 1/2 binary64))) |
(/.f64 (+.f64 #s(literal 1/8 binary64) (pow.f64 (*.f64 (-.f64 (*.f64 (*.f64 b b) #s(literal 1/48 binary64)) #s(literal 1/4 binary64)) b) #s(literal 3 binary64))) (+.f64 #s(literal 1/4 binary64) (-.f64 (*.f64 (*.f64 (-.f64 (*.f64 (*.f64 b b) #s(literal 1/48 binary64)) #s(literal 1/4 binary64)) b) (*.f64 (-.f64 (*.f64 (*.f64 b b) #s(literal 1/48 binary64)) #s(literal 1/4 binary64)) b)) (*.f64 #s(literal 1/2 binary64) (*.f64 (-.f64 (*.f64 (*.f64 b b) #s(literal 1/48 binary64)) #s(literal 1/4 binary64)) b))))) |
(/.f64 (+.f64 (pow.f64 (*.f64 (-.f64 (*.f64 (*.f64 b b) #s(literal 1/48 binary64)) #s(literal 1/4 binary64)) b) #s(literal 3 binary64)) #s(literal 1/8 binary64)) (fma.f64 (*.f64 (-.f64 (*.f64 (*.f64 b b) #s(literal 1/48 binary64)) #s(literal 1/4 binary64)) b) (*.f64 (-.f64 (*.f64 (*.f64 b b) #s(literal 1/48 binary64)) #s(literal 1/4 binary64)) b) (-.f64 #s(literal 1/4 binary64) (*.f64 (*.f64 (-.f64 (*.f64 (*.f64 b b) #s(literal 1/48 binary64)) #s(literal 1/4 binary64)) b) #s(literal 1/2 binary64))))) |
(fma.f64 (-.f64 (*.f64 (*.f64 b b) #s(literal 1/48 binary64)) #s(literal 1/4 binary64)) b #s(literal 1/2 binary64)) |
(fma.f64 b (-.f64 (*.f64 (*.f64 b b) #s(literal 1/48 binary64)) #s(literal 1/4 binary64)) #s(literal 1/2 binary64)) |
(-.f64 (/.f64 #s(literal 1/4 binary64) (-.f64 #s(literal 1/2 binary64) (*.f64 (-.f64 (*.f64 (*.f64 b b) #s(literal 1/48 binary64)) #s(literal 1/4 binary64)) b))) (/.f64 (*.f64 (*.f64 (-.f64 (*.f64 (*.f64 b b) #s(literal 1/48 binary64)) #s(literal 1/4 binary64)) b) (*.f64 (-.f64 (*.f64 (*.f64 b b) #s(literal 1/48 binary64)) #s(literal 1/4 binary64)) b)) (-.f64 #s(literal 1/2 binary64) (*.f64 (-.f64 (*.f64 (*.f64 b b) #s(literal 1/48 binary64)) #s(literal 1/4 binary64)) b)))) |
(-.f64 (/.f64 (*.f64 (*.f64 (-.f64 (*.f64 (*.f64 b b) #s(literal 1/48 binary64)) #s(literal 1/4 binary64)) b) (*.f64 (-.f64 (*.f64 (*.f64 b b) #s(literal 1/48 binary64)) #s(literal 1/4 binary64)) b)) (-.f64 (*.f64 (-.f64 (*.f64 (*.f64 b b) #s(literal 1/48 binary64)) #s(literal 1/4 binary64)) b) #s(literal 1/2 binary64))) (/.f64 #s(literal 1/4 binary64) (-.f64 (*.f64 (-.f64 (*.f64 (*.f64 b b) #s(literal 1/48 binary64)) #s(literal 1/4 binary64)) b) #s(literal 1/2 binary64)))) |
(-.f64 #s(literal 1/2 binary64) (*.f64 (neg.f64 b) (-.f64 (*.f64 (*.f64 b b) #s(literal 1/48 binary64)) #s(literal 1/4 binary64)))) |
(+.f64 (/.f64 #s(literal 1/8 binary64) (+.f64 #s(literal 1/4 binary64) (-.f64 (*.f64 (*.f64 (-.f64 (*.f64 (*.f64 b b) #s(literal 1/48 binary64)) #s(literal 1/4 binary64)) b) (*.f64 (-.f64 (*.f64 (*.f64 b b) #s(literal 1/48 binary64)) #s(literal 1/4 binary64)) b)) (*.f64 #s(literal 1/2 binary64) (*.f64 (-.f64 (*.f64 (*.f64 b b) #s(literal 1/48 binary64)) #s(literal 1/4 binary64)) b))))) (/.f64 (pow.f64 (*.f64 (-.f64 (*.f64 (*.f64 b b) #s(literal 1/48 binary64)) #s(literal 1/4 binary64)) b) #s(literal 3 binary64)) (+.f64 #s(literal 1/4 binary64) (-.f64 (*.f64 (*.f64 (-.f64 (*.f64 (*.f64 b b) #s(literal 1/48 binary64)) #s(literal 1/4 binary64)) b) (*.f64 (-.f64 (*.f64 (*.f64 b b) #s(literal 1/48 binary64)) #s(literal 1/4 binary64)) b)) (*.f64 #s(literal 1/2 binary64) (*.f64 (-.f64 (*.f64 (*.f64 b b) #s(literal 1/48 binary64)) #s(literal 1/4 binary64)) b)))))) |
(+.f64 (/.f64 (pow.f64 (*.f64 (-.f64 (*.f64 (*.f64 b b) #s(literal 1/48 binary64)) #s(literal 1/4 binary64)) b) #s(literal 3 binary64)) (fma.f64 (*.f64 (-.f64 (*.f64 (*.f64 b b) #s(literal 1/48 binary64)) #s(literal 1/4 binary64)) b) (*.f64 (-.f64 (*.f64 (*.f64 b b) #s(literal 1/48 binary64)) #s(literal 1/4 binary64)) b) (-.f64 #s(literal 1/4 binary64) (*.f64 (*.f64 (-.f64 (*.f64 (*.f64 b b) #s(literal 1/48 binary64)) #s(literal 1/4 binary64)) b) #s(literal 1/2 binary64))))) (/.f64 #s(literal 1/8 binary64) (fma.f64 (*.f64 (-.f64 (*.f64 (*.f64 b b) #s(literal 1/48 binary64)) #s(literal 1/4 binary64)) b) (*.f64 (-.f64 (*.f64 (*.f64 b b) #s(literal 1/48 binary64)) #s(literal 1/4 binary64)) b) (-.f64 #s(literal 1/4 binary64) (*.f64 (*.f64 (-.f64 (*.f64 (*.f64 b b) #s(literal 1/48 binary64)) #s(literal 1/4 binary64)) b) #s(literal 1/2 binary64)))))) |
(+.f64 (*.f64 (-.f64 (*.f64 (*.f64 b b) #s(literal 1/48 binary64)) #s(literal 1/4 binary64)) b) #s(literal 1/2 binary64)) |
(+.f64 #s(literal 1/2 binary64) (*.f64 (-.f64 (*.f64 (*.f64 b b) #s(literal 1/48 binary64)) #s(literal 1/4 binary64)) b)) |
(/.f64 (neg.f64 (-.f64 (*.f64 (*.f64 (*.f64 b b) #s(literal 1/48 binary64)) (*.f64 (*.f64 b b) #s(literal 1/48 binary64))) #s(literal 1/16 binary64))) (neg.f64 (fma.f64 (*.f64 b b) #s(literal 1/48 binary64) #s(literal 1/4 binary64)))) |
(/.f64 (neg.f64 (-.f64 (pow.f64 (*.f64 (*.f64 b b) #s(literal 1/48 binary64)) #s(literal 3 binary64)) #s(literal 1/64 binary64))) (neg.f64 (fma.f64 (*.f64 (*.f64 b b) #s(literal 1/48 binary64)) (*.f64 (*.f64 b b) #s(literal 1/48 binary64)) (+.f64 #s(literal 1/16 binary64) (*.f64 (*.f64 (*.f64 b b) #s(literal 1/48 binary64)) #s(literal 1/4 binary64)))))) |
(/.f64 (-.f64 (*.f64 (*.f64 (*.f64 b b) #s(literal 1/48 binary64)) (*.f64 (*.f64 b b) #s(literal 1/48 binary64))) #s(literal 1/16 binary64)) (fma.f64 (*.f64 b b) #s(literal 1/48 binary64) #s(literal 1/4 binary64))) |
(/.f64 (-.f64 (pow.f64 (*.f64 (*.f64 b b) #s(literal 1/48 binary64)) #s(literal 3 binary64)) #s(literal 1/64 binary64)) (fma.f64 (*.f64 (*.f64 b b) #s(literal 1/48 binary64)) (*.f64 (*.f64 b b) #s(literal 1/48 binary64)) (+.f64 #s(literal 1/16 binary64) (*.f64 (*.f64 (*.f64 b b) #s(literal 1/48 binary64)) #s(literal 1/4 binary64))))) |
(-.f64 (/.f64 (*.f64 (*.f64 (*.f64 b b) #s(literal 1/48 binary64)) (*.f64 (*.f64 b b) #s(literal 1/48 binary64))) (fma.f64 (*.f64 b b) #s(literal 1/48 binary64) #s(literal 1/4 binary64))) (/.f64 #s(literal 1/16 binary64) (fma.f64 (*.f64 b b) #s(literal 1/48 binary64) #s(literal 1/4 binary64)))) |
(-.f64 (/.f64 (pow.f64 (*.f64 (*.f64 b b) #s(literal 1/48 binary64)) #s(literal 3 binary64)) (fma.f64 (*.f64 (*.f64 b b) #s(literal 1/48 binary64)) (*.f64 (*.f64 b b) #s(literal 1/48 binary64)) (+.f64 #s(literal 1/16 binary64) (*.f64 (*.f64 (*.f64 b b) #s(literal 1/48 binary64)) #s(literal 1/4 binary64))))) (/.f64 #s(literal 1/64 binary64) (fma.f64 (*.f64 (*.f64 b b) #s(literal 1/48 binary64)) (*.f64 (*.f64 b b) #s(literal 1/48 binary64)) (+.f64 #s(literal 1/16 binary64) (*.f64 (*.f64 (*.f64 b b) #s(literal 1/48 binary64)) #s(literal 1/4 binary64)))))) |
(-.f64 (*.f64 (*.f64 b b) #s(literal 1/48 binary64)) #s(literal 1/4 binary64)) |
(*.f64 (*.f64 b b) #s(literal 1/48 binary64)) |
(*.f64 #s(literal 1/48 binary64) (*.f64 b b)) |
(*.f64 b (*.f64 b #s(literal 1/48 binary64))) |
(*.f64 (neg.f64 (neg.f64 b)) (neg.f64 (neg.f64 b))) |
(*.f64 (neg.f64 (fabs.f64 b)) (neg.f64 (fabs.f64 b))) |
(*.f64 (fabs.f64 (fabs.f64 b)) (fabs.f64 (fabs.f64 b))) |
(*.f64 (exp.f64 (log.f64 b)) (exp.f64 (log.f64 b))) |
(*.f64 (neg.f64 b) (neg.f64 b)) |
(*.f64 (fabs.f64 b) (fabs.f64 b)) |
(*.f64 b b) |
(pow.f64 (exp.f64 (log.f64 b)) #s(literal 2 binary64)) |
(pow.f64 (neg.f64 b) #s(literal 2 binary64)) |
(pow.f64 (fabs.f64 b) #s(literal 2 binary64)) |
(pow.f64 (*.f64 b b) #s(literal 1 binary64)) |
(pow.f64 b #s(literal 2 binary64)) |
(fabs.f64 (*.f64 b b)) |
(+.f64 (cosh.f64 (*.f64 (log.f64 b) #s(literal 2 binary64))) (sinh.f64 (*.f64 (log.f64 b) #s(literal 2 binary64)))) |
(exp.f64 (*.f64 (log.f64 b) #s(literal 2 binary64))) |
#s(literal 1/48 binary64) |
#s(literal 1/4 binary64) |
(/.f64 (neg.f64 (neg.f64 (exp.f64 a))) (neg.f64 (neg.f64 #s(approx (+ (exp a) (exp b)) #s(approx (- (exp a) -1) (+.f64 #s(literal 2 binary64) a)))))) |
(/.f64 (neg.f64 (exp.f64 a)) (neg.f64 #s(approx (+ (exp a) (exp b)) #s(approx (- (exp a) -1) (+.f64 #s(literal 2 binary64) a))))) |
(/.f64 (exp.f64 a) #s(approx (+ (exp a) (exp b)) #s(approx (- (exp a) -1) (+.f64 #s(literal 2 binary64) a)))) |
(+.f64 (/.f64 (cosh.f64 a) #s(approx (+ (exp a) (exp b)) #s(approx (- (exp a) -1) (+.f64 #s(literal 2 binary64) a)))) (/.f64 (sinh.f64 a) #s(approx (+ (exp a) (exp b)) #s(approx (- (exp a) -1) (+.f64 #s(literal 2 binary64) a))))) |
(/.f64 (+.f64 (pow.f64 (cosh.f64 a) #s(literal 3 binary64)) (pow.f64 (sinh.f64 a) #s(literal 3 binary64))) (fma.f64 (cosh.f64 a) (cosh.f64 a) (-.f64 (*.f64 (sinh.f64 a) (sinh.f64 a)) (*.f64 (cosh.f64 a) (sinh.f64 a))))) |
(+.f64 (cosh.f64 a) (sinh.f64 a)) |
(exp.f64 a) |
#s(approx (+ (exp a) (exp b)) #s(approx (- (exp a) -1) (+.f64 #s(literal 2 binary64) a))) |
#s(approx (- (exp a) -1) (+.f64 #s(literal 2 binary64) a)) |
(/.f64 (fma.f64 (*.f64 a a) a #s(literal 8 binary64)) (fma.f64 a a (-.f64 #s(literal 4 binary64) (*.f64 a #s(literal 2 binary64))))) |
(/.f64 (neg.f64 (-.f64 #s(literal 4 binary64) (*.f64 a a))) (neg.f64 (-.f64 #s(literal 2 binary64) a))) |
(/.f64 (neg.f64 (+.f64 #s(literal 8 binary64) (*.f64 (*.f64 a a) a))) (neg.f64 (+.f64 #s(literal 4 binary64) (-.f64 (*.f64 a a) (*.f64 #s(literal 2 binary64) a))))) |
(/.f64 (-.f64 #s(literal 4 binary64) (*.f64 a a)) (-.f64 #s(literal 2 binary64) a)) |
(/.f64 (+.f64 #s(literal 8 binary64) (*.f64 (*.f64 a a) a)) (+.f64 #s(literal 4 binary64) (-.f64 (*.f64 a a) (*.f64 #s(literal 2 binary64) a)))) |
(-.f64 (/.f64 #s(literal 4 binary64) (-.f64 #s(literal 2 binary64) a)) (/.f64 (*.f64 a a) (-.f64 #s(literal 2 binary64) a))) |
(+.f64 (/.f64 #s(literal 8 binary64) (+.f64 #s(literal 4 binary64) (-.f64 (*.f64 a a) (*.f64 #s(literal 2 binary64) a)))) (/.f64 (*.f64 (*.f64 a a) a) (+.f64 #s(literal 4 binary64) (-.f64 (*.f64 a a) (*.f64 #s(literal 2 binary64) a))))) |
(+.f64 #s(literal 2 binary64) a) |
(+.f64 a #s(literal 2 binary64)) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) (+.f64 (exp.f64 b) #s(literal 1 binary64)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (fma.f64 (-.f64 (/.f64 #s(literal 1 binary64) (+.f64 (exp.f64 b) #s(literal 1 binary64))) (pow.f64 (+.f64 (exp.f64 b) #s(literal 1 binary64)) #s(literal -2 binary64))) a (/.f64 #s(literal 1 binary64) (+.f64 (exp.f64 b) #s(literal 1 binary64))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (fma.f64 (-.f64 (fma.f64 a (+.f64 (/.f64 #s(literal 1/2 binary64) (+.f64 (exp.f64 b) #s(literal 1 binary64))) (-.f64 (pow.f64 (+.f64 (exp.f64 b) #s(literal 1 binary64)) #s(literal -3 binary64)) (*.f64 (pow.f64 (+.f64 (exp.f64 b) #s(literal 1 binary64)) #s(literal -2 binary64)) #s(literal 3/2 binary64)))) (/.f64 #s(literal 1 binary64) (+.f64 (exp.f64 b) #s(literal 1 binary64)))) (pow.f64 (+.f64 (exp.f64 b) #s(literal 1 binary64)) #s(literal -2 binary64))) a (/.f64 #s(literal 1 binary64) (+.f64 (exp.f64 b) #s(literal 1 binary64))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (fma.f64 (fma.f64 (-.f64 (+.f64 (fma.f64 (-.f64 (fma.f64 #s(literal 3/2 binary64) (pow.f64 (+.f64 (exp.f64 b) #s(literal 1 binary64)) #s(literal -3 binary64)) (/.f64 #s(literal 1/6 binary64) (+.f64 (exp.f64 b) #s(literal 1 binary64)))) (+.f64 (/.f64 #s(literal 2/3 binary64) (*.f64 (+.f64 (exp.f64 b) #s(literal 1 binary64)) (+.f64 (exp.f64 b) #s(literal 1 binary64)))) (fma.f64 #s(literal 1/2 binary64) (/.f64 (-.f64 (/.f64 #s(literal 1 binary64) (+.f64 (exp.f64 b) #s(literal 1 binary64))) (pow.f64 (+.f64 (exp.f64 b) #s(literal 1 binary64)) #s(literal -2 binary64))) (+.f64 (exp.f64 b) #s(literal 1 binary64))) (pow.f64 (+.f64 (exp.f64 b) #s(literal 1 binary64)) #s(literal -4 binary64))))) a (pow.f64 (+.f64 (exp.f64 b) #s(literal 1 binary64)) #s(literal -3 binary64))) (/.f64 #s(literal 1/2 binary64) (+.f64 (exp.f64 b) #s(literal 1 binary64)))) (*.f64 (pow.f64 (+.f64 (exp.f64 b) #s(literal 1 binary64)) #s(literal -2 binary64)) #s(literal 3/2 binary64))) a (-.f64 (/.f64 #s(literal 1 binary64) (+.f64 (exp.f64 b) #s(literal 1 binary64))) (pow.f64 (+.f64 (exp.f64 b) #s(literal 1 binary64)) #s(literal -2 binary64)))) a (/.f64 #s(literal 1 binary64) (+.f64 (exp.f64 b) #s(literal 1 binary64))))) |
#s(approx (exp a) #s(literal 1 binary64)) |
#s(approx (exp a) (+.f64 #s(literal 1 binary64) a)) |
#s(approx (exp a) (fma.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a #s(literal 1 binary64))) |
#s(approx (exp a) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) a #s(literal 1/2 binary64)) a #s(literal 1 binary64)) a #s(literal 1 binary64))) |
#s(approx (+ 1 a) #s(literal 1 binary64)) |
#s(approx (+ 1 a) (+.f64 #s(literal 1 binary64) a)) |
#s(approx a a) |
#s(approx (+ (exp a) (exp b)) (+.f64 (exp.f64 b) #s(literal 1 binary64))) |
#s(approx (+ (exp a) (exp b)) (+.f64 (+.f64 (exp.f64 b) a) #s(literal 1 binary64))) |
#s(approx (+ (exp a) (exp b)) (+.f64 (fma.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a (exp.f64 b)) #s(literal 1 binary64))) |
#s(approx (+ (exp a) (exp b)) (+.f64 (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) a #s(literal 1/2 binary64)) a #s(literal 1 binary64)) a (exp.f64 b)) #s(literal 1 binary64))) |
#s(approx (- a -1) #s(literal 1 binary64)) |
#s(approx (- a -1) (+.f64 #s(literal 1 binary64) a)) |
#s(approx (- (exp a) -1) #s(literal 2 binary64)) |
#s(approx (- (exp a) -1) (+.f64 #s(literal 2 binary64) a)) |
#s(approx (- (exp a) -1) (fma.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a #s(literal 2 binary64))) |
#s(approx (- (exp a) -1) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) a #s(literal 1/2 binary64)) a #s(literal 1 binary64)) a #s(literal 2 binary64))) |
#s(approx (+ 2 a) #s(literal 2 binary64)) |
#s(approx (+ 2 a) (+.f64 #s(literal 2 binary64) a)) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 (exp.f64 a) (+.f64 (exp.f64 b) (exp.f64 a)))) |
#s(approx (exp a) (exp.f64 a)) |
#s(approx (+ 1 a) a) |
#s(approx (+ 1 a) (fma.f64 #s(literal 1 binary64) a #s(literal 1 binary64))) |
#s(approx (+ (exp a) (exp b)) (+.f64 (exp.f64 b) (exp.f64 a))) |
#s(approx (- a -1) a) |
#s(approx (- a -1) (fma.f64 #s(literal 1 binary64) a #s(literal 1 binary64))) |
#s(approx (- (exp a) -1) (+.f64 #s(literal 1 binary64) (exp.f64 a))) |
#s(approx (+ 2 a) a) |
#s(approx (+ 2 a) (*.f64 (+.f64 (/.f64 #s(literal 2 binary64) a) #s(literal 1 binary64)) a)) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 (exp.f64 a) (+.f64 #s(literal 1 binary64) (exp.f64 a)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (+.f64 (neg.f64 (*.f64 b (exp.f64 (-.f64 a (*.f64 (log.f64 (+.f64 #s(literal 1 binary64) (exp.f64 a))) #s(literal 2 binary64)))))) (/.f64 (exp.f64 a) (+.f64 #s(literal 1 binary64) (exp.f64 a))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (fma.f64 b (-.f64 (neg.f64 (*.f64 (fma.f64 (exp.f64 (-.f64 a (*.f64 (log.f64 (+.f64 #s(literal 1 binary64) (exp.f64 a))) #s(literal 2 binary64)))) #s(literal 1/2 binary64) (neg.f64 (exp.f64 (-.f64 a (*.f64 (log.f64 (+.f64 #s(literal 1 binary64) (exp.f64 a))) #s(literal 3 binary64)))))) b)) (exp.f64 (-.f64 a (*.f64 (log.f64 (+.f64 #s(literal 1 binary64) (exp.f64 a))) #s(literal 2 binary64))))) (/.f64 (exp.f64 a) (+.f64 #s(literal 1 binary64) (exp.f64 a))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (fma.f64 (-.f64 (*.f64 (-.f64 (neg.f64 (*.f64 (+.f64 (fma.f64 #s(literal -1/2 binary64) (exp.f64 (-.f64 a (*.f64 (log.f64 (+.f64 #s(literal 1 binary64) (exp.f64 a))) #s(literal 3 binary64)))) (*.f64 (exp.f64 (-.f64 a (*.f64 (log.f64 (+.f64 #s(literal 1 binary64) (exp.f64 a))) #s(literal 2 binary64)))) #s(literal 1/6 binary64))) (neg.f64 (/.f64 (fma.f64 (exp.f64 (-.f64 a (*.f64 (log.f64 (+.f64 #s(literal 1 binary64) (exp.f64 a))) #s(literal 2 binary64)))) #s(literal 1/2 binary64) (neg.f64 (exp.f64 (-.f64 a (*.f64 (log.f64 (+.f64 #s(literal 1 binary64) (exp.f64 a))) #s(literal 3 binary64)))))) (+.f64 #s(literal 1 binary64) (exp.f64 a))))) b)) (fma.f64 (exp.f64 (-.f64 a (*.f64 (log.f64 (+.f64 #s(literal 1 binary64) (exp.f64 a))) #s(literal 2 binary64)))) #s(literal 1/2 binary64) (neg.f64 (exp.f64 (-.f64 a (*.f64 (log.f64 (+.f64 #s(literal 1 binary64) (exp.f64 a))) #s(literal 3 binary64))))))) b) (exp.f64 (-.f64 a (*.f64 (log.f64 (+.f64 #s(literal 1 binary64) (exp.f64 a))) #s(literal 2 binary64))))) b (/.f64 (exp.f64 a) (+.f64 #s(literal 1 binary64) (exp.f64 a))))) |
#s(approx (+ (exp a) (exp b)) (+.f64 #s(literal 1 binary64) (exp.f64 a))) |
#s(approx (+ (exp a) (exp b)) (+.f64 (+.f64 b (exp.f64 a)) #s(literal 1 binary64))) |
#s(approx (+ (exp a) (exp b)) (+.f64 (fma.f64 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b (exp.f64 a)) #s(literal 1 binary64))) |
#s(approx (+ (exp a) (exp b)) (+.f64 (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) b #s(literal 1/2 binary64)) b #s(literal 1 binary64)) b (exp.f64 a)) #s(literal 1 binary64))) |
#s(approx (exp b) #s(literal 1 binary64)) |
#s(approx (exp b) (+.f64 b #s(literal 1 binary64))) |
#s(approx (exp b) (fma.f64 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b #s(literal 1 binary64))) |
#s(approx (exp b) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) b #s(literal 1/2 binary64)) b #s(literal 1 binary64)) b #s(literal 1 binary64))) |
#s(approx b b) |
#s(approx (/ 1 (- (exp b) -1)) #s(literal 1/2 binary64)) |
#s(approx (/ 1 (- (exp b) -1)) (fma.f64 #s(literal -1/4 binary64) b #s(literal 1/2 binary64))) |
#s(approx (/ 1 (- (exp b) -1)) (fma.f64 (-.f64 (*.f64 (*.f64 b b) #s(literal 1/48 binary64)) #s(literal 1/4 binary64)) b #s(literal 1/2 binary64))) |
#s(approx (/ 1 (- (exp b) -1)) (fma.f64 (-.f64 (*.f64 (fma.f64 #s(literal -1/480 binary64) (*.f64 b b) #s(literal 1/48 binary64)) (*.f64 b b)) #s(literal 1/4 binary64)) b #s(literal 1/2 binary64))) |
#s(approx (- (exp b) -1) #s(literal 2 binary64)) |
#s(approx (- (exp b) -1) (+.f64 #s(literal 2 binary64) b)) |
#s(approx (- (exp b) -1) (fma.f64 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b #s(literal 2 binary64))) |
#s(approx (- (exp b) -1) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) b #s(literal 1/2 binary64)) b #s(literal 1 binary64)) b #s(literal 2 binary64))) |
#s(approx (+ 2 b) #s(literal 2 binary64)) |
#s(approx (+ 2 b) (+.f64 #s(literal 2 binary64) b)) |
#s(approx (+ (* (- (* (* b b) 1/48) 1/4) b) 1/2) #s(literal 1/2 binary64)) |
#s(approx (+ (* (- (* (* b b) 1/48) 1/4) b) 1/2) (fma.f64 #s(literal -1/4 binary64) b #s(literal 1/2 binary64))) |
#s(approx (+ (* (- (* (* b b) 1/48) 1/4) b) 1/2) (fma.f64 (-.f64 (*.f64 (*.f64 b b) #s(literal 1/48 binary64)) #s(literal 1/4 binary64)) b #s(literal 1/2 binary64))) |
#s(approx (- (* (* b b) 1/48) 1/4) #s(literal -1/4 binary64)) |
#s(approx (- (* (* b b) 1/48) 1/4) (-.f64 (*.f64 (*.f64 b b) #s(literal 1/48 binary64)) #s(literal 1/4 binary64))) |
#s(approx (* (* b b) 1/48) (*.f64 (*.f64 b b) #s(literal 1/48 binary64))) |
#s(approx (* b b) (*.f64 b b)) |
#s(approx (exp b) (exp.f64 b)) |
#s(approx (/ 1 (- (exp b) -1)) (/.f64 #s(literal 1 binary64) (+.f64 (exp.f64 b) #s(literal 1 binary64)))) |
#s(approx (- (exp b) -1) (+.f64 (exp.f64 b) #s(literal 1 binary64))) |
#s(approx (+ 2 b) b) |
#s(approx (+ 2 b) (*.f64 (+.f64 (/.f64 #s(literal 2 binary64) b) #s(literal 1 binary64)) b)) |
#s(approx (+ (* (- (* (* b b) 1/48) 1/4) b) 1/2) (*.f64 (*.f64 (*.f64 b b) b) #s(literal 1/48 binary64))) |
#s(approx (+ (* (- (* (* b b) 1/48) 1/4) b) 1/2) (*.f64 (-.f64 #s(literal 1/48 binary64) (/.f64 #s(literal 1/4 binary64) (*.f64 b b))) (*.f64 (*.f64 b b) b))) |
#s(approx (+ (* (- (* (* b b) 1/48) 1/4) b) 1/2) (*.f64 (-.f64 (+.f64 (/.f64 #s(literal 1/2 binary64) (*.f64 (*.f64 b b) b)) #s(literal 1/48 binary64)) (/.f64 #s(literal 1/4 binary64) (*.f64 b b))) (*.f64 (*.f64 b b) b))) |
#s(approx (- (* (* b b) 1/48) 1/4) (*.f64 (*.f64 b b) #s(literal 1/48 binary64))) |
#s(approx (- (* (* b b) 1/48) 1/4) (*.f64 (-.f64 #s(literal 1/48 binary64) (/.f64 #s(literal 1/4 binary64) (*.f64 b b))) (*.f64 b b))) |
#s(approx (+ (* (- (* (* b b) 1/48) 1/4) b) 1/2) (neg.f64 (*.f64 (-.f64 (/.f64 #s(literal 1/4 binary64) (*.f64 b b)) #s(literal 1/48 binary64)) (*.f64 (*.f64 b b) b)))) |
#s(approx (+ (* (- (* (* b b) 1/48) 1/4) b) 1/2) (neg.f64 (*.f64 (-.f64 (-.f64 (/.f64 #s(literal 1/4 binary64) (*.f64 b b)) #s(literal 1/48 binary64)) (/.f64 #s(literal 1/2 binary64) (*.f64 (*.f64 b b) b))) (*.f64 (*.f64 b b) b)))) |
Compiled 2 042 to 905 computations (55.7% saved)
16 alts after pruning (10 fresh and 6 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 159 | 7 | 166 |
| Fresh | 2 | 3 | 5 |
| Picked | 1 | 4 | 5 |
| Done | 0 | 2 | 2 |
| Total | 162 | 16 | 178 |
| Status | Accuracy | Program |
|---|---|---|
| ✓ | 62.8% | (/.f64 (exp.f64 a) #s(approx (+ (exp a) (exp b)) (-.f64 (exp.f64 a) #s(literal -1 binary64)))) |
| 61.6% | (/.f64 (exp.f64 a) #s(approx (+ (exp a) (exp b)) #s(approx (- (exp b) -1) #s(literal 2 binary64)))) | |
| ▶ | 61.9% | (/.f64 (exp.f64 a) #s(approx (+ (exp a) (exp b)) #s(approx (- (exp a) -1) (fma.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a #s(literal 2 binary64))))) |
| ✓ | 61.8% | (/.f64 (exp.f64 a) #s(approx (+ (exp a) (exp b)) #s(approx (- (exp a) -1) (+.f64 #s(literal 2 binary64) a)))) |
| 47.2% | (/.f64 #s(approx (exp a) (+.f64 #s(literal 1 binary64) a)) (+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp b) (fma.f64 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b #s(literal 1 binary64))))) | |
| ▶ | 33.6% | (/.f64 #s(approx (exp a) (+.f64 #s(literal 1 binary64) a)) (+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp b) (+.f64 b #s(literal 1 binary64))))) |
| 35.9% | (/.f64 #s(approx (exp a) (+.f64 #s(literal 1 binary64) a)) (+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp b) #s(literal 1 binary64)))) | |
| 39.2% | (/.f64 #s(approx (exp a) (+.f64 #s(literal 1 binary64) a)) (+.f64 #s(approx (exp a) #s(approx (- a -1) a)) (exp.f64 b))) | |
| ✓ | 82.1% | #s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) (-.f64 (exp.f64 b) #s(literal -1 binary64)))) |
| ▶ | 46.7% | #s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) #s(approx (- (exp b) -1) (fma.f64 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b #s(literal 2 binary64))))) |
| ✓ | 33.2% | #s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) #s(approx (- (exp b) -1) (+.f64 #s(literal 2 binary64) b)))) |
| ▶ | 3.3% | #s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) #s(approx (- (exp b) -1) #s(approx (+ 2 b) b)))) |
| ✓ | 32.4% | #s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (/ 1 (- (exp b) -1)) (fma.f64 (-.f64 (*.f64 (*.f64 b b) #s(literal 1/48 binary64)) #s(literal 1/4 binary64)) b #s(literal 1/2 binary64)))) |
| 33.3% | #s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (/ 1 (- (exp b) -1)) (fma.f64 #s(approx (- (* (* b b) 1/48) 1/4) #s(literal -1/4 binary64)) b #s(literal 1/2 binary64)))) | |
| ▶ | 12.8% | #s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (/ 1 (- (exp b) -1)) #s(approx (+ (* (- (* (* b b) 1/48) 1/4) b) 1/2) (*.f64 (*.f64 (*.f64 b b) b) #s(literal 1/48 binary64))))) |
| ✓ | 35.3% | #s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (/ 1 (- (exp b) -1)) #s(literal 1/2 binary64))) |
Compiled 440 to 403 computations (8.4% saved)
| Inputs |
|---|
(/.f64 (exp.f64 a) #s(approx (+ (exp a) (exp b)) #s(approx (- (exp a) -1) (fma.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a #s(literal 2 binary64))))) |
(exp.f64 a) |
a |
#s(approx (+ (exp a) (exp b)) #s(approx (- (exp a) -1) (fma.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a #s(literal 2 binary64)))) |
#s(approx (- (exp a) -1) (fma.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a #s(literal 2 binary64))) |
(fma.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a #s(literal 2 binary64)) |
(fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) |
#s(literal 1/2 binary64) |
#s(literal 1 binary64) |
#s(literal 2 binary64) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) #s(approx (- (exp b) -1) #s(approx (+ 2 b) b)))) |
(/.f64 #s(literal 1 binary64) #s(approx (- (exp b) -1) #s(approx (+ 2 b) b))) |
#s(approx (- (exp b) -1) #s(approx (+ 2 b) b)) |
#s(approx (+ 2 b) b) |
b |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (/ 1 (- (exp b) -1)) #s(approx (+ (* (- (* (* b b) 1/48) 1/4) b) 1/2) (*.f64 (*.f64 (*.f64 b b) b) #s(literal 1/48 binary64))))) |
#s(approx (/ 1 (- (exp b) -1)) #s(approx (+ (* (- (* (* b b) 1/48) 1/4) b) 1/2) (*.f64 (*.f64 (*.f64 b b) b) #s(literal 1/48 binary64)))) |
#s(approx (+ (* (- (* (* b b) 1/48) 1/4) b) 1/2) (*.f64 (*.f64 (*.f64 b b) b) #s(literal 1/48 binary64))) |
(*.f64 (*.f64 (*.f64 b b) b) #s(literal 1/48 binary64)) |
(*.f64 (*.f64 b b) b) |
(*.f64 b b) |
#s(literal 1/48 binary64) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) #s(approx (- (exp b) -1) (fma.f64 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b #s(literal 2 binary64))))) |
(/.f64 #s(literal 1 binary64) #s(approx (- (exp b) -1) (fma.f64 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b #s(literal 2 binary64)))) |
#s(approx (- (exp b) -1) (fma.f64 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b #s(literal 2 binary64))) |
(fma.f64 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b #s(literal 2 binary64)) |
(fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) |
(/.f64 #s(approx (exp a) (+.f64 #s(literal 1 binary64) a)) (+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp b) (+.f64 b #s(literal 1 binary64))))) |
#s(approx (exp a) (+.f64 #s(literal 1 binary64) a)) |
(+.f64 #s(literal 1 binary64) a) |
(+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp b) (+.f64 b #s(literal 1 binary64)))) |
#s(approx (exp a) (-.f64 a #s(literal -1 binary64))) |
(-.f64 a #s(literal -1 binary64)) |
#s(literal -1 binary64) |
#s(approx (exp b) (+.f64 b #s(literal 1 binary64))) |
(+.f64 b #s(literal 1 binary64)) |
| Outputs |
|---|
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(hole binary64 (/ 1 (+ 1 (exp b))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(hole binary64 (+ (* a (- (/ 1 (+ 1 (exp b))) (/ 1 (pow (+ 1 (exp b)) 2)))) (/ 1 (+ 1 (exp b)))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(hole binary64 (+ (* a (- (+ (* a (- (+ (* 1/2 (/ 1 (+ 1 (exp b)))) (/ 1 (pow (+ 1 (exp b)) 3))) (* 3/2 (/ 1 (pow (+ 1 (exp b)) 2))))) (/ 1 (+ 1 (exp b)))) (/ 1 (pow (+ 1 (exp b)) 2)))) (/ 1 (+ 1 (exp b)))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(hole binary64 (+ (* a (- (+ (* a (- (+ (* 1/2 (/ 1 (+ 1 (exp b)))) (+ (* a (- (+ (* 1/6 (/ 1 (+ 1 (exp b)))) (* 3/2 (/ 1 (pow (+ 1 (exp b)) 3)))) (+ (* 1/6 (/ 1 (pow (+ 1 (exp b)) 2))) (+ (* 1/2 (/ 1 (pow (+ 1 (exp b)) 2))) (+ (* 1/2 (/ (- (/ 1 (+ 1 (exp b))) (/ 1 (pow (+ 1 (exp b)) 2))) (+ 1 (exp b)))) (/ 1 (pow (+ 1 (exp b)) 4))))))) (/ 1 (pow (+ 1 (exp b)) 3)))) (* 3/2 (/ 1 (pow (+ 1 (exp b)) 2))))) (/ 1 (+ 1 (exp b)))) (/ 1 (pow (+ 1 (exp b)) 2)))) (/ 1 (+ 1 (exp b)))))) |
#s(approx (exp a) #s(hole binary64 1)) |
#s(approx (exp a) #s(hole binary64 (+ 1 a))) |
#s(approx (exp a) #s(hole binary64 (+ 1 (* a (+ 1 (* 1/2 a)))))) |
#s(approx (exp a) #s(hole binary64 (+ 1 (* a (+ 1 (* a (+ 1/2 (* 1/6 a)))))))) |
#s(approx a #s(hole binary64 a)) |
#s(approx (+ (exp a) (exp b)) #s(hole binary64 (+ 1 (exp b)))) |
#s(approx (+ (exp a) (exp b)) #s(hole binary64 (+ 1 (+ a (exp b))))) |
#s(approx (+ (exp a) (exp b)) #s(hole binary64 (+ 1 (+ (exp b) (* a (+ 1 (* 1/2 a))))))) |
#s(approx (+ (exp a) (exp b)) #s(hole binary64 (+ 1 (+ (exp b) (* a (+ 1 (* a (+ 1/2 (* 1/6 a))))))))) |
#s(approx (- (exp a) -1) #s(hole binary64 2)) |
#s(approx (- (exp a) -1) #s(hole binary64 (+ 2 a))) |
#s(approx (- (exp a) -1) #s(hole binary64 (+ 2 (* a (+ 1 (* 1/2 a)))))) |
#s(approx (- (exp a) -1) #s(hole binary64 (+ 2 (* a (+ 1 (* a (+ 1/2 (* 1/6 a)))))))) |
#s(approx (+ (* (+ (* 1/2 a) 1) a) 2) #s(hole binary64 2)) |
#s(approx (+ (* (+ (* 1/2 a) 1) a) 2) #s(hole binary64 (+ 2 a))) |
#s(approx (+ (* (+ (* 1/2 a) 1) a) 2) #s(hole binary64 (+ 2 (* a (+ 1 (* 1/2 a)))))) |
#s(approx (+ (* 1/2 a) 1) #s(hole binary64 1)) |
#s(approx (+ (* 1/2 a) 1) #s(hole binary64 (+ 1 (* 1/2 a)))) |
#s(approx (+ 1 a) #s(hole binary64 1)) |
#s(approx (+ 1 a) #s(hole binary64 (+ 1 a))) |
#s(approx (- a -1) #s(hole binary64 1)) |
#s(approx (- a -1) #s(hole binary64 (+ 1 a))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(hole binary64 (/ (exp a) (+ (exp a) (exp b))))) |
#s(approx (exp a) #s(hole binary64 (exp a))) |
#s(approx (+ (exp a) (exp b)) #s(hole binary64 (+ (exp a) (exp b)))) |
#s(approx (- (exp a) -1) #s(hole binary64 (+ 1 (exp a)))) |
#s(approx (+ (* (+ (* 1/2 a) 1) a) 2) #s(hole binary64 (* 1/2 (pow a 2)))) |
#s(approx (+ (* (+ (* 1/2 a) 1) a) 2) #s(hole binary64 (* (pow a 2) (+ 1/2 (/ 1 a))))) |
#s(approx (+ (* (+ (* 1/2 a) 1) a) 2) #s(hole binary64 (* (pow a 2) (+ 1/2 (+ (/ 1 a) (/ 2 (pow a 2))))))) |
#s(approx (+ (* 1/2 a) 1) #s(hole binary64 (* 1/2 a))) |
#s(approx (+ (* 1/2 a) 1) #s(hole binary64 (* a (+ 1/2 (/ 1 a))))) |
#s(approx (+ 1 a) #s(hole binary64 a)) |
#s(approx (+ 1 a) #s(hole binary64 (* a (+ 1 (/ 1 a))))) |
#s(approx (- a -1) #s(hole binary64 a)) |
#s(approx (- a -1) #s(hole binary64 (* a (+ 1 (/ 1 a))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(hole binary64 (/ (exp a) (+ 1 (exp a))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(hole binary64 (+ (* -1 (/ (* b (exp a)) (pow (+ 1 (exp a)) 2))) (/ (exp a) (+ 1 (exp a)))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(hole binary64 (+ (* b (- (* -1 (* b (+ (* -1 (/ (exp a) (pow (+ 1 (exp a)) 3))) (* 1/2 (/ (exp a) (pow (+ 1 (exp a)) 2)))))) (/ (exp a) (pow (+ 1 (exp a)) 2)))) (/ (exp a) (+ 1 (exp a)))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(hole binary64 (+ (* b (- (* b (- (* -1 (* b (+ (* -1 (/ (+ (* -1 (/ (exp a) (pow (+ 1 (exp a)) 3))) (* 1/2 (/ (exp a) (pow (+ 1 (exp a)) 2)))) (+ 1 (exp a)))) (+ (* -1/2 (/ (exp a) (pow (+ 1 (exp a)) 3))) (* 1/6 (/ (exp a) (pow (+ 1 (exp a)) 2))))))) (+ (* -1 (/ (exp a) (pow (+ 1 (exp a)) 3))) (* 1/2 (/ (exp a) (pow (+ 1 (exp a)) 2)))))) (/ (exp a) (pow (+ 1 (exp a)) 2)))) (/ (exp a) (+ 1 (exp a)))))) |
#s(approx (+ (exp a) (exp b)) #s(hole binary64 (+ 1 (exp a)))) |
#s(approx (+ (exp a) (exp b)) #s(hole binary64 (+ 1 (+ b (exp a))))) |
#s(approx (+ (exp a) (exp b)) #s(hole binary64 (+ 1 (+ (exp a) (* b (+ 1 (* 1/2 b))))))) |
#s(approx (+ (exp a) (exp b)) #s(hole binary64 (+ 1 (+ (exp a) (* b (+ 1 (* b (+ 1/2 (* 1/6 b))))))))) |
#s(approx (/ 1 (- (exp b) -1)) #s(hole binary64 1/2)) |
#s(approx (/ 1 (- (exp b) -1)) #s(hole binary64 (+ 1/2 (* -1/4 b)))) |
#s(approx (/ 1 (- (exp b) -1)) #s(hole binary64 (+ 1/2 (* b (- (* 1/48 (pow b 2)) 1/4))))) |
#s(approx (/ 1 (- (exp b) -1)) #s(hole binary64 (+ 1/2 (* b (- (* (pow b 2) (+ 1/48 (* -1/480 (pow b 2)))) 1/4))))) |
#s(approx (- (exp b) -1) #s(hole binary64 2)) |
#s(approx (- (exp b) -1) #s(hole binary64 (+ 2 b))) |
#s(approx (- (exp b) -1) #s(hole binary64 (+ 2 (* b (+ 1 (* 1/2 b)))))) |
#s(approx (- (exp b) -1) #s(hole binary64 (+ 2 (* b (+ 1 (* b (+ 1/2 (* 1/6 b)))))))) |
#s(approx (+ 2 b) #s(hole binary64 2)) |
#s(approx (+ 2 b) #s(hole binary64 (+ 2 b))) |
#s(approx b #s(hole binary64 b)) |
#s(approx (+ (* (- (* (* b b) 1/48) 1/4) b) 1/2) #s(hole binary64 1/2)) |
#s(approx (+ (* (- (* (* b b) 1/48) 1/4) b) 1/2) #s(hole binary64 (+ 1/2 (* -1/4 b)))) |
#s(approx (+ (* (- (* (* b b) 1/48) 1/4) b) 1/2) #s(hole binary64 (+ 1/2 (* b (- (* 1/48 (pow b 2)) 1/4))))) |
#s(approx (* (* (* b b) b) 1/48) #s(hole binary64 (* 1/48 (pow b 3)))) |
#s(approx (* (* b b) b) #s(hole binary64 (pow b 3))) |
#s(approx (* b b) #s(hole binary64 (pow b 2))) |
#s(approx (+ (* (+ (* 1/2 b) 1) b) 2) #s(hole binary64 2)) |
#s(approx (+ (* (+ (* 1/2 b) 1) b) 2) #s(hole binary64 (+ 2 b))) |
#s(approx (+ (* (+ (* 1/2 b) 1) b) 2) #s(hole binary64 (+ 2 (* b (+ 1 (* 1/2 b)))))) |
#s(approx (+ (* 1/2 b) 1) #s(hole binary64 1)) |
#s(approx (+ (* 1/2 b) 1) #s(hole binary64 (+ 1 (* 1/2 b)))) |
#s(approx (exp b) #s(hole binary64 1)) |
#s(approx (exp b) #s(hole binary64 (+ 1 b))) |
#s(approx (exp b) #s(hole binary64 (+ 1 (* b (+ 1 (* 1/2 b)))))) |
#s(approx (exp b) #s(hole binary64 (+ 1 (* b (+ 1 (* b (+ 1/2 (* 1/6 b)))))))) |
#s(approx (+ b 1) #s(hole binary64 1)) |
#s(approx (+ b 1) #s(hole binary64 (+ 1 b))) |
#s(approx (/ 1 (- (exp b) -1)) #s(hole binary64 (/ 1 (+ 1 (exp b))))) |
#s(approx (- (exp b) -1) #s(hole binary64 (+ 1 (exp b)))) |
#s(approx (+ 2 b) #s(hole binary64 b)) |
#s(approx (+ 2 b) #s(hole binary64 (* b (+ 1 (* 2 (/ 1 b)))))) |
#s(approx (+ (* (- (* (* b b) 1/48) 1/4) b) 1/2) #s(hole binary64 (* 1/48 (pow b 3)))) |
#s(approx (+ (* (- (* (* b b) 1/48) 1/4) b) 1/2) #s(hole binary64 (* (pow b 3) (- 1/48 (* 1/4 (/ 1 (pow b 2))))))) |
#s(approx (+ (* (- (* (* b b) 1/48) 1/4) b) 1/2) #s(hole binary64 (* (pow b 3) (- (+ 1/48 (/ 1/2 (pow b 3))) (* 1/4 (/ 1 (pow b 2))))))) |
#s(approx (+ (* (+ (* 1/2 b) 1) b) 2) #s(hole binary64 (* 1/2 (pow b 2)))) |
#s(approx (+ (* (+ (* 1/2 b) 1) b) 2) #s(hole binary64 (* (pow b 2) (+ 1/2 (/ 1 b))))) |
#s(approx (+ (* (+ (* 1/2 b) 1) b) 2) #s(hole binary64 (* (pow b 2) (+ 1/2 (+ (/ 1 b) (/ 2 (pow b 2))))))) |
#s(approx (+ (* 1/2 b) 1) #s(hole binary64 (* 1/2 b))) |
#s(approx (+ (* 1/2 b) 1) #s(hole binary64 (* b (+ 1/2 (/ 1 b))))) |
#s(approx (exp b) #s(hole binary64 (exp b))) |
#s(approx (+ b 1) #s(hole binary64 b)) |
#s(approx (+ b 1) #s(hole binary64 (* b (+ 1 (/ 1 b))))) |
#s(approx (+ (* (- (* (* b b) 1/48) 1/4) b) 1/2) #s(hole binary64 (* -1 (* (pow b 3) (- (* 1/4 (/ 1 (pow b 2))) 1/48))))) |
#s(approx (+ (* (- (* (* b b) 1/48) 1/4) b) 1/2) #s(hole binary64 (* -1 (* (pow b 3) (- (* 1/4 (/ 1 (pow b 2))) (+ 1/48 (/ 1/2 (pow b 3)))))))) |
6 calls:
| Time | Variable | Point | Expression | |
|---|---|---|---|---|
| 2.0ms | b | @ | -inf | ((/ (exp a) (+ (exp a) (exp b))) (exp a) a (+ (exp a) (exp b)) (- (exp a) -1) (+ (* (+ (* 1/2 a) 1) a) 2) (+ (* 1/2 a) 1) 1/2 1 2 (/ (exp a) (+ (exp a) (exp b))) (/ 1 (- (exp b) -1)) (- (exp b) -1) (+ 2 b) b (/ (exp a) (+ (exp a) (exp b))) (/ 1 (- (exp b) -1)) (+ (* (- (* (* b b) 1/48) 1/4) b) 1/2) (* (* (* b b) b) 1/48) (* (* b b) b) (* b b) 1/48 (/ (exp a) (+ (exp a) (exp b))) (/ 1 (- (exp b) -1)) (- (exp b) -1) (+ (* (+ (* 1/2 b) 1) b) 2) (+ (* 1/2 b) 1) (/ (exp a) (+ (exp a) (exp b))) (exp a) (+ 1 a) (+ (exp a) (exp b)) (exp a) (- a -1) -1 (exp b) (+ b 1)) |
| 2.0ms | a | @ | inf | ((/ (exp a) (+ (exp a) (exp b))) (exp a) a (+ (exp a) (exp b)) (- (exp a) -1) (+ (* (+ (* 1/2 a) 1) a) 2) (+ (* 1/2 a) 1) 1/2 1 2 (/ (exp a) (+ (exp a) (exp b))) (/ 1 (- (exp b) -1)) (- (exp b) -1) (+ 2 b) b (/ (exp a) (+ (exp a) (exp b))) (/ 1 (- (exp b) -1)) (+ (* (- (* (* b b) 1/48) 1/4) b) 1/2) (* (* (* b b) b) 1/48) (* (* b b) b) (* b b) 1/48 (/ (exp a) (+ (exp a) (exp b))) (/ 1 (- (exp b) -1)) (- (exp b) -1) (+ (* (+ (* 1/2 b) 1) b) 2) (+ (* 1/2 b) 1) (/ (exp a) (+ (exp a) (exp b))) (exp a) (+ 1 a) (+ (exp a) (exp b)) (exp a) (- a -1) -1 (exp b) (+ b 1)) |
| 2.0ms | b | @ | inf | ((/ (exp a) (+ (exp a) (exp b))) (exp a) a (+ (exp a) (exp b)) (- (exp a) -1) (+ (* (+ (* 1/2 a) 1) a) 2) (+ (* 1/2 a) 1) 1/2 1 2 (/ (exp a) (+ (exp a) (exp b))) (/ 1 (- (exp b) -1)) (- (exp b) -1) (+ 2 b) b (/ (exp a) (+ (exp a) (exp b))) (/ 1 (- (exp b) -1)) (+ (* (- (* (* b b) 1/48) 1/4) b) 1/2) (* (* (* b b) b) 1/48) (* (* b b) b) (* b b) 1/48 (/ (exp a) (+ (exp a) (exp b))) (/ 1 (- (exp b) -1)) (- (exp b) -1) (+ (* (+ (* 1/2 b) 1) b) 2) (+ (* 1/2 b) 1) (/ (exp a) (+ (exp a) (exp b))) (exp a) (+ 1 a) (+ (exp a) (exp b)) (exp a) (- a -1) -1 (exp b) (+ b 1)) |
| 1.0ms | b | @ | 0 | ((/ (exp a) (+ (exp a) (exp b))) (exp a) a (+ (exp a) (exp b)) (- (exp a) -1) (+ (* (+ (* 1/2 a) 1) a) 2) (+ (* 1/2 a) 1) 1/2 1 2 (/ (exp a) (+ (exp a) (exp b))) (/ 1 (- (exp b) -1)) (- (exp b) -1) (+ 2 b) b (/ (exp a) (+ (exp a) (exp b))) (/ 1 (- (exp b) -1)) (+ (* (- (* (* b b) 1/48) 1/4) b) 1/2) (* (* (* b b) b) 1/48) (* (* b b) b) (* b b) 1/48 (/ (exp a) (+ (exp a) (exp b))) (/ 1 (- (exp b) -1)) (- (exp b) -1) (+ (* (+ (* 1/2 b) 1) b) 2) (+ (* 1/2 b) 1) (/ (exp a) (+ (exp a) (exp b))) (exp a) (+ 1 a) (+ (exp a) (exp b)) (exp a) (- a -1) -1 (exp b) (+ b 1)) |
| 1.0ms | a | @ | -inf | ((/ (exp a) (+ (exp a) (exp b))) (exp a) a (+ (exp a) (exp b)) (- (exp a) -1) (+ (* (+ (* 1/2 a) 1) a) 2) (+ (* 1/2 a) 1) 1/2 1 2 (/ (exp a) (+ (exp a) (exp b))) (/ 1 (- (exp b) -1)) (- (exp b) -1) (+ 2 b) b (/ (exp a) (+ (exp a) (exp b))) (/ 1 (- (exp b) -1)) (+ (* (- (* (* b b) 1/48) 1/4) b) 1/2) (* (* (* b b) b) 1/48) (* (* b b) b) (* b b) 1/48 (/ (exp a) (+ (exp a) (exp b))) (/ 1 (- (exp b) -1)) (- (exp b) -1) (+ (* (+ (* 1/2 b) 1) b) 2) (+ (* 1/2 b) 1) (/ (exp a) (+ (exp a) (exp b))) (exp a) (+ 1 a) (+ (exp a) (exp b)) (exp a) (- a -1) -1 (exp b) (+ b 1)) |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 323 | 1811 |
| 0 | 342 | 1728 |
| 1 | 1776 | 1709 |
| 0 | 8114 | 1640 |
| 1× | iter-limit |
| 1× | node-limit |
| 1× | iter-limit |
| Inputs |
|---|
(/.f64 (exp.f64 a) #s(approx (+ (exp a) (exp b)) #s(approx (- (exp a) -1) (fma.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a #s(literal 2 binary64))))) |
(exp.f64 a) |
a |
#s(approx (+ (exp a) (exp b)) #s(approx (- (exp a) -1) (fma.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a #s(literal 2 binary64)))) |
#s(approx (- (exp a) -1) (fma.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a #s(literal 2 binary64))) |
(fma.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a #s(literal 2 binary64)) |
(fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) |
#s(literal 1/2 binary64) |
#s(literal 1 binary64) |
#s(literal 2 binary64) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) #s(approx (- (exp b) -1) #s(approx (+ 2 b) b)))) |
(/.f64 #s(literal 1 binary64) #s(approx (- (exp b) -1) #s(approx (+ 2 b) b))) |
#s(approx (- (exp b) -1) #s(approx (+ 2 b) b)) |
#s(approx (+ 2 b) b) |
b |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (/ 1 (- (exp b) -1)) #s(approx (+ (* (- (* (* b b) 1/48) 1/4) b) 1/2) (*.f64 (*.f64 (*.f64 b b) b) #s(literal 1/48 binary64))))) |
#s(approx (/ 1 (- (exp b) -1)) #s(approx (+ (* (- (* (* b b) 1/48) 1/4) b) 1/2) (*.f64 (*.f64 (*.f64 b b) b) #s(literal 1/48 binary64)))) |
#s(approx (+ (* (- (* (* b b) 1/48) 1/4) b) 1/2) (*.f64 (*.f64 (*.f64 b b) b) #s(literal 1/48 binary64))) |
(*.f64 (*.f64 (*.f64 b b) b) #s(literal 1/48 binary64)) |
(*.f64 (*.f64 b b) b) |
(*.f64 b b) |
#s(literal 1/48 binary64) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) #s(approx (- (exp b) -1) (fma.f64 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b #s(literal 2 binary64))))) |
(/.f64 #s(literal 1 binary64) #s(approx (- (exp b) -1) (fma.f64 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b #s(literal 2 binary64)))) |
#s(approx (- (exp b) -1) (fma.f64 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b #s(literal 2 binary64))) |
(fma.f64 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b #s(literal 2 binary64)) |
(fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) |
(/.f64 #s(approx (exp a) (+.f64 #s(literal 1 binary64) a)) (+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp b) (+.f64 b #s(literal 1 binary64))))) |
#s(approx (exp a) (+.f64 #s(literal 1 binary64) a)) |
(+.f64 #s(literal 1 binary64) a) |
(+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp b) (+.f64 b #s(literal 1 binary64)))) |
#s(approx (exp a) (-.f64 a #s(literal -1 binary64))) |
(-.f64 a #s(literal -1 binary64)) |
#s(literal -1 binary64) |
#s(approx (exp b) (+.f64 b #s(literal 1 binary64))) |
(+.f64 b #s(literal 1 binary64)) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(hole binary64 (/ 1 (+ 1 (exp b))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(hole binary64 (+ (* a (- (/ 1 (+ 1 (exp b))) (/ 1 (pow (+ 1 (exp b)) 2)))) (/ 1 (+ 1 (exp b)))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(hole binary64 (+ (* a (- (+ (* a (- (+ (* 1/2 (/ 1 (+ 1 (exp b)))) (/ 1 (pow (+ 1 (exp b)) 3))) (* 3/2 (/ 1 (pow (+ 1 (exp b)) 2))))) (/ 1 (+ 1 (exp b)))) (/ 1 (pow (+ 1 (exp b)) 2)))) (/ 1 (+ 1 (exp b)))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(hole binary64 (+ (* a (- (+ (* a (- (+ (* 1/2 (/ 1 (+ 1 (exp b)))) (+ (* a (- (+ (* 1/6 (/ 1 (+ 1 (exp b)))) (* 3/2 (/ 1 (pow (+ 1 (exp b)) 3)))) (+ (* 1/6 (/ 1 (pow (+ 1 (exp b)) 2))) (+ (* 1/2 (/ 1 (pow (+ 1 (exp b)) 2))) (+ (* 1/2 (/ (- (/ 1 (+ 1 (exp b))) (/ 1 (pow (+ 1 (exp b)) 2))) (+ 1 (exp b)))) (/ 1 (pow (+ 1 (exp b)) 4))))))) (/ 1 (pow (+ 1 (exp b)) 3)))) (* 3/2 (/ 1 (pow (+ 1 (exp b)) 2))))) (/ 1 (+ 1 (exp b)))) (/ 1 (pow (+ 1 (exp b)) 2)))) (/ 1 (+ 1 (exp b)))))) |
#s(approx (exp a) #s(hole binary64 1)) |
#s(approx (exp a) #s(hole binary64 (+ 1 a))) |
#s(approx (exp a) #s(hole binary64 (+ 1 (* a (+ 1 (* 1/2 a)))))) |
#s(approx (exp a) #s(hole binary64 (+ 1 (* a (+ 1 (* a (+ 1/2 (* 1/6 a)))))))) |
#s(approx a #s(hole binary64 a)) |
#s(approx (+ (exp a) (exp b)) #s(hole binary64 (+ 1 (exp b)))) |
#s(approx (+ (exp a) (exp b)) #s(hole binary64 (+ 1 (+ a (exp b))))) |
#s(approx (+ (exp a) (exp b)) #s(hole binary64 (+ 1 (+ (exp b) (* a (+ 1 (* 1/2 a))))))) |
#s(approx (+ (exp a) (exp b)) #s(hole binary64 (+ 1 (+ (exp b) (* a (+ 1 (* a (+ 1/2 (* 1/6 a))))))))) |
#s(approx (- (exp a) -1) #s(hole binary64 2)) |
#s(approx (- (exp a) -1) #s(hole binary64 (+ 2 a))) |
#s(approx (- (exp a) -1) #s(hole binary64 (+ 2 (* a (+ 1 (* 1/2 a)))))) |
#s(approx (- (exp a) -1) #s(hole binary64 (+ 2 (* a (+ 1 (* a (+ 1/2 (* 1/6 a)))))))) |
#s(approx (+ (* (+ (* 1/2 a) 1) a) 2) #s(hole binary64 2)) |
#s(approx (+ (* (+ (* 1/2 a) 1) a) 2) #s(hole binary64 (+ 2 a))) |
#s(approx (+ (* (+ (* 1/2 a) 1) a) 2) #s(hole binary64 (+ 2 (* a (+ 1 (* 1/2 a)))))) |
#s(approx (+ (* 1/2 a) 1) #s(hole binary64 1)) |
#s(approx (+ (* 1/2 a) 1) #s(hole binary64 (+ 1 (* 1/2 a)))) |
#s(approx (+ 1 a) #s(hole binary64 1)) |
#s(approx (+ 1 a) #s(hole binary64 (+ 1 a))) |
#s(approx (- a -1) #s(hole binary64 1)) |
#s(approx (- a -1) #s(hole binary64 (+ 1 a))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(hole binary64 (/ (exp a) (+ (exp a) (exp b))))) |
#s(approx (exp a) #s(hole binary64 (exp a))) |
#s(approx (+ (exp a) (exp b)) #s(hole binary64 (+ (exp a) (exp b)))) |
#s(approx (- (exp a) -1) #s(hole binary64 (+ 1 (exp a)))) |
#s(approx (+ (* (+ (* 1/2 a) 1) a) 2) #s(hole binary64 (* 1/2 (pow a 2)))) |
#s(approx (+ (* (+ (* 1/2 a) 1) a) 2) #s(hole binary64 (* (pow a 2) (+ 1/2 (/ 1 a))))) |
#s(approx (+ (* (+ (* 1/2 a) 1) a) 2) #s(hole binary64 (* (pow a 2) (+ 1/2 (+ (/ 1 a) (/ 2 (pow a 2))))))) |
#s(approx (+ (* 1/2 a) 1) #s(hole binary64 (* 1/2 a))) |
#s(approx (+ (* 1/2 a) 1) #s(hole binary64 (* a (+ 1/2 (/ 1 a))))) |
#s(approx (+ 1 a) #s(hole binary64 a)) |
#s(approx (+ 1 a) #s(hole binary64 (* a (+ 1 (/ 1 a))))) |
#s(approx (- a -1) #s(hole binary64 a)) |
#s(approx (- a -1) #s(hole binary64 (* a (+ 1 (/ 1 a))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(hole binary64 (/ (exp a) (+ 1 (exp a))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(hole binary64 (+ (* -1 (/ (* b (exp a)) (pow (+ 1 (exp a)) 2))) (/ (exp a) (+ 1 (exp a)))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(hole binary64 (+ (* b (- (* -1 (* b (+ (* -1 (/ (exp a) (pow (+ 1 (exp a)) 3))) (* 1/2 (/ (exp a) (pow (+ 1 (exp a)) 2)))))) (/ (exp a) (pow (+ 1 (exp a)) 2)))) (/ (exp a) (+ 1 (exp a)))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(hole binary64 (+ (* b (- (* b (- (* -1 (* b (+ (* -1 (/ (+ (* -1 (/ (exp a) (pow (+ 1 (exp a)) 3))) (* 1/2 (/ (exp a) (pow (+ 1 (exp a)) 2)))) (+ 1 (exp a)))) (+ (* -1/2 (/ (exp a) (pow (+ 1 (exp a)) 3))) (* 1/6 (/ (exp a) (pow (+ 1 (exp a)) 2))))))) (+ (* -1 (/ (exp a) (pow (+ 1 (exp a)) 3))) (* 1/2 (/ (exp a) (pow (+ 1 (exp a)) 2)))))) (/ (exp a) (pow (+ 1 (exp a)) 2)))) (/ (exp a) (+ 1 (exp a)))))) |
#s(approx (+ (exp a) (exp b)) #s(hole binary64 (+ 1 (exp a)))) |
#s(approx (+ (exp a) (exp b)) #s(hole binary64 (+ 1 (+ b (exp a))))) |
#s(approx (+ (exp a) (exp b)) #s(hole binary64 (+ 1 (+ (exp a) (* b (+ 1 (* 1/2 b))))))) |
#s(approx (+ (exp a) (exp b)) #s(hole binary64 (+ 1 (+ (exp a) (* b (+ 1 (* b (+ 1/2 (* 1/6 b))))))))) |
#s(approx (/ 1 (- (exp b) -1)) #s(hole binary64 1/2)) |
#s(approx (/ 1 (- (exp b) -1)) #s(hole binary64 (+ 1/2 (* -1/4 b)))) |
#s(approx (/ 1 (- (exp b) -1)) #s(hole binary64 (+ 1/2 (* b (- (* 1/48 (pow b 2)) 1/4))))) |
#s(approx (/ 1 (- (exp b) -1)) #s(hole binary64 (+ 1/2 (* b (- (* (pow b 2) (+ 1/48 (* -1/480 (pow b 2)))) 1/4))))) |
#s(approx (- (exp b) -1) #s(hole binary64 2)) |
#s(approx (- (exp b) -1) #s(hole binary64 (+ 2 b))) |
#s(approx (- (exp b) -1) #s(hole binary64 (+ 2 (* b (+ 1 (* 1/2 b)))))) |
#s(approx (- (exp b) -1) #s(hole binary64 (+ 2 (* b (+ 1 (* b (+ 1/2 (* 1/6 b)))))))) |
#s(approx (+ 2 b) #s(hole binary64 2)) |
#s(approx (+ 2 b) #s(hole binary64 (+ 2 b))) |
#s(approx b #s(hole binary64 b)) |
#s(approx (+ (* (- (* (* b b) 1/48) 1/4) b) 1/2) #s(hole binary64 1/2)) |
#s(approx (+ (* (- (* (* b b) 1/48) 1/4) b) 1/2) #s(hole binary64 (+ 1/2 (* -1/4 b)))) |
#s(approx (+ (* (- (* (* b b) 1/48) 1/4) b) 1/2) #s(hole binary64 (+ 1/2 (* b (- (* 1/48 (pow b 2)) 1/4))))) |
#s(approx (* (* (* b b) b) 1/48) #s(hole binary64 (* 1/48 (pow b 3)))) |
#s(approx (* (* b b) b) #s(hole binary64 (pow b 3))) |
#s(approx (* b b) #s(hole binary64 (pow b 2))) |
#s(approx (+ (* (+ (* 1/2 b) 1) b) 2) #s(hole binary64 2)) |
#s(approx (+ (* (+ (* 1/2 b) 1) b) 2) #s(hole binary64 (+ 2 b))) |
#s(approx (+ (* (+ (* 1/2 b) 1) b) 2) #s(hole binary64 (+ 2 (* b (+ 1 (* 1/2 b)))))) |
#s(approx (+ (* 1/2 b) 1) #s(hole binary64 1)) |
#s(approx (+ (* 1/2 b) 1) #s(hole binary64 (+ 1 (* 1/2 b)))) |
#s(approx (exp b) #s(hole binary64 1)) |
#s(approx (exp b) #s(hole binary64 (+ 1 b))) |
#s(approx (exp b) #s(hole binary64 (+ 1 (* b (+ 1 (* 1/2 b)))))) |
#s(approx (exp b) #s(hole binary64 (+ 1 (* b (+ 1 (* b (+ 1/2 (* 1/6 b)))))))) |
#s(approx (+ b 1) #s(hole binary64 1)) |
#s(approx (+ b 1) #s(hole binary64 (+ 1 b))) |
#s(approx (/ 1 (- (exp b) -1)) #s(hole binary64 (/ 1 (+ 1 (exp b))))) |
#s(approx (- (exp b) -1) #s(hole binary64 (+ 1 (exp b)))) |
#s(approx (+ 2 b) #s(hole binary64 b)) |
#s(approx (+ 2 b) #s(hole binary64 (* b (+ 1 (* 2 (/ 1 b)))))) |
#s(approx (+ (* (- (* (* b b) 1/48) 1/4) b) 1/2) #s(hole binary64 (* 1/48 (pow b 3)))) |
#s(approx (+ (* (- (* (* b b) 1/48) 1/4) b) 1/2) #s(hole binary64 (* (pow b 3) (- 1/48 (* 1/4 (/ 1 (pow b 2))))))) |
#s(approx (+ (* (- (* (* b b) 1/48) 1/4) b) 1/2) #s(hole binary64 (* (pow b 3) (- (+ 1/48 (/ 1/2 (pow b 3))) (* 1/4 (/ 1 (pow b 2))))))) |
#s(approx (+ (* (+ (* 1/2 b) 1) b) 2) #s(hole binary64 (* 1/2 (pow b 2)))) |
#s(approx (+ (* (+ (* 1/2 b) 1) b) 2) #s(hole binary64 (* (pow b 2) (+ 1/2 (/ 1 b))))) |
#s(approx (+ (* (+ (* 1/2 b) 1) b) 2) #s(hole binary64 (* (pow b 2) (+ 1/2 (+ (/ 1 b) (/ 2 (pow b 2))))))) |
#s(approx (+ (* 1/2 b) 1) #s(hole binary64 (* 1/2 b))) |
#s(approx (+ (* 1/2 b) 1) #s(hole binary64 (* b (+ 1/2 (/ 1 b))))) |
#s(approx (exp b) #s(hole binary64 (exp b))) |
#s(approx (+ b 1) #s(hole binary64 b)) |
#s(approx (+ b 1) #s(hole binary64 (* b (+ 1 (/ 1 b))))) |
#s(approx (+ (* (- (* (* b b) 1/48) 1/4) b) 1/2) #s(hole binary64 (* -1 (* (pow b 3) (- (* 1/4 (/ 1 (pow b 2))) 1/48))))) |
#s(approx (+ (* (- (* (* b b) 1/48) 1/4) b) 1/2) #s(hole binary64 (* -1 (* (pow b 3) (- (* 1/4 (/ 1 (pow b 2))) (+ 1/48 (/ 1/2 (pow b 3)))))))) |
| Outputs |
|---|
(/.f64 (neg.f64 (neg.f64 (exp.f64 a))) (neg.f64 (neg.f64 #s(approx (+ (exp a) (exp b)) #s(approx (- (exp a) -1) (fma.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a #s(literal 2 binary64))))))) |
(/.f64 (neg.f64 (exp.f64 a)) (neg.f64 #s(approx (+ (exp a) (exp b)) #s(approx (- (exp a) -1) (fma.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a #s(literal 2 binary64)))))) |
(/.f64 (exp.f64 a) #s(approx (+ (exp a) (exp b)) #s(approx (- (exp a) -1) (fma.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a #s(literal 2 binary64))))) |
(+.f64 (/.f64 (cosh.f64 a) #s(approx (+ (exp a) (exp b)) #s(approx (- (exp a) -1) (fma.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a #s(literal 2 binary64))))) (/.f64 (sinh.f64 a) #s(approx (+ (exp a) (exp b)) #s(approx (- (exp a) -1) (fma.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a #s(literal 2 binary64)))))) |
(/.f64 (+.f64 (pow.f64 (cosh.f64 a) #s(literal 3 binary64)) (pow.f64 (sinh.f64 a) #s(literal 3 binary64))) (fma.f64 (cosh.f64 a) (cosh.f64 a) (-.f64 (*.f64 (sinh.f64 a) (sinh.f64 a)) (*.f64 (cosh.f64 a) (sinh.f64 a))))) |
(+.f64 (cosh.f64 a) (sinh.f64 a)) |
(exp.f64 a) |
a |
#s(approx (+ (exp a) (exp b)) #s(approx (- (exp a) -1) (fma.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a #s(literal 2 binary64)))) |
#s(approx (- (exp a) -1) (fma.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a #s(literal 2 binary64))) |
(/.f64 (neg.f64 (-.f64 #s(literal 4 binary64) (*.f64 (*.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a) (*.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a)))) (neg.f64 (-.f64 #s(literal 2 binary64) (*.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a)))) |
(/.f64 (neg.f64 (-.f64 (*.f64 (*.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a) (*.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a)) #s(literal 4 binary64))) (neg.f64 (-.f64 (*.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a) #s(literal 2 binary64)))) |
(/.f64 (neg.f64 (+.f64 #s(literal 8 binary64) (pow.f64 (*.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a) #s(literal 3 binary64)))) (neg.f64 (+.f64 #s(literal 4 binary64) (-.f64 (*.f64 (*.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a) (*.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a)) (*.f64 #s(literal 2 binary64) (*.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a)))))) |
(/.f64 (neg.f64 (+.f64 (pow.f64 (*.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a) #s(literal 3 binary64)) #s(literal 8 binary64))) (neg.f64 (fma.f64 (*.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a) (*.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a) (-.f64 #s(literal 4 binary64) (*.f64 (*.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a) #s(literal 2 binary64)))))) |
(/.f64 (-.f64 #s(literal 4 binary64) (*.f64 (*.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a) (*.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a))) (-.f64 #s(literal 2 binary64) (*.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a))) |
(/.f64 (-.f64 (*.f64 (*.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a) (*.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a)) #s(literal 4 binary64)) (-.f64 (*.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a) #s(literal 2 binary64))) |
(/.f64 (+.f64 #s(literal 8 binary64) (pow.f64 (*.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a) #s(literal 3 binary64))) (+.f64 #s(literal 4 binary64) (-.f64 (*.f64 (*.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a) (*.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a)) (*.f64 #s(literal 2 binary64) (*.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a))))) |
(/.f64 (+.f64 (pow.f64 (*.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a) #s(literal 3 binary64)) #s(literal 8 binary64)) (fma.f64 (*.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a) (*.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a) (-.f64 #s(literal 4 binary64) (*.f64 (*.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a) #s(literal 2 binary64))))) |
(fma.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a #s(literal 2 binary64)) |
(fma.f64 a (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) #s(literal 2 binary64)) |
(-.f64 (/.f64 #s(literal 4 binary64) (-.f64 #s(literal 2 binary64) (*.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a))) (/.f64 (*.f64 (*.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a) (*.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a)) (-.f64 #s(literal 2 binary64) (*.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a)))) |
(-.f64 (/.f64 (*.f64 (*.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a) (*.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a)) (-.f64 (*.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a) #s(literal 2 binary64))) (/.f64 #s(literal 4 binary64) (-.f64 (*.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a) #s(literal 2 binary64)))) |
(-.f64 #s(literal 2 binary64) (*.f64 (neg.f64 a) (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)))) |
(+.f64 (/.f64 #s(literal 8 binary64) (+.f64 #s(literal 4 binary64) (-.f64 (*.f64 (*.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a) (*.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a)) (*.f64 #s(literal 2 binary64) (*.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a))))) (/.f64 (pow.f64 (*.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a) #s(literal 3 binary64)) (+.f64 #s(literal 4 binary64) (-.f64 (*.f64 (*.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a) (*.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a)) (*.f64 #s(literal 2 binary64) (*.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a)))))) |
(+.f64 (/.f64 (pow.f64 (*.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a) #s(literal 3 binary64)) (fma.f64 (*.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a) (*.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a) (-.f64 #s(literal 4 binary64) (*.f64 (*.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a) #s(literal 2 binary64))))) (/.f64 #s(literal 8 binary64) (fma.f64 (*.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a) (*.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a) (-.f64 #s(literal 4 binary64) (*.f64 (*.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a) #s(literal 2 binary64)))))) |
(+.f64 (*.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a) #s(literal 2 binary64)) |
(+.f64 #s(literal 2 binary64) (*.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a)) |
(*.f64 (+.f64 (/.f64 #s(literal 1 binary64) a) #s(literal 1/2 binary64)) a) |
(*.f64 a (+.f64 (/.f64 #s(literal 1 binary64) a) #s(literal 1/2 binary64))) |
(/.f64 (fma.f64 (*.f64 (*.f64 a a) a) #s(literal 1/8 binary64) (pow.f64 (*.f64 a (/.f64 #s(literal 1 binary64) a)) #s(literal 3 binary64))) (fma.f64 (*.f64 #s(literal 1/2 binary64) a) (*.f64 #s(literal 1/2 binary64) a) (-.f64 (*.f64 (*.f64 a (/.f64 #s(literal 1 binary64) a)) (*.f64 a (/.f64 #s(literal 1 binary64) a))) (*.f64 (*.f64 #s(literal 1/2 binary64) a) (*.f64 a (/.f64 #s(literal 1 binary64) a)))))) |
(/.f64 (neg.f64 (-.f64 #s(literal 1 binary64) (*.f64 (*.f64 #s(literal 1/2 binary64) a) (*.f64 #s(literal 1/2 binary64) a)))) (neg.f64 (-.f64 #s(literal 1 binary64) (*.f64 #s(literal 1/2 binary64) a)))) |
(/.f64 (neg.f64 (-.f64 (*.f64 (*.f64 #s(literal 1/2 binary64) a) (*.f64 #s(literal 1/2 binary64) a)) #s(literal 1 binary64))) (neg.f64 (-.f64 (*.f64 #s(literal 1/2 binary64) a) #s(literal 1 binary64)))) |
(/.f64 (neg.f64 (+.f64 #s(literal 1 binary64) (*.f64 (*.f64 (*.f64 a a) a) #s(literal 1/8 binary64)))) (neg.f64 (+.f64 #s(literal 1 binary64) (-.f64 (*.f64 (*.f64 #s(literal 1/2 binary64) a) (*.f64 #s(literal 1/2 binary64) a)) (*.f64 #s(literal 1 binary64) (*.f64 #s(literal 1/2 binary64) a)))))) |
(/.f64 (neg.f64 (fma.f64 (*.f64 (*.f64 a a) a) #s(literal 1/8 binary64) #s(literal 1 binary64))) (neg.f64 (fma.f64 (*.f64 #s(literal 1/2 binary64) a) (*.f64 #s(literal 1/2 binary64) a) (-.f64 #s(literal 1 binary64) (*.f64 (*.f64 #s(literal 1/2 binary64) a) #s(literal 1 binary64)))))) |
(/.f64 (-.f64 #s(literal 1 binary64) (*.f64 (*.f64 #s(literal 1/2 binary64) a) (*.f64 #s(literal 1/2 binary64) a))) (-.f64 #s(literal 1 binary64) (*.f64 #s(literal 1/2 binary64) a))) |
(/.f64 (-.f64 (*.f64 (*.f64 #s(literal 1/2 binary64) a) (*.f64 #s(literal 1/2 binary64) a)) #s(literal 1 binary64)) (-.f64 (*.f64 #s(literal 1/2 binary64) a) #s(literal 1 binary64))) |
(/.f64 (+.f64 #s(literal 1 binary64) (*.f64 (*.f64 (*.f64 a a) a) #s(literal 1/8 binary64))) (+.f64 #s(literal 1 binary64) (-.f64 (*.f64 (*.f64 #s(literal 1/2 binary64) a) (*.f64 #s(literal 1/2 binary64) a)) (*.f64 #s(literal 1 binary64) (*.f64 #s(literal 1/2 binary64) a))))) |
(/.f64 (fma.f64 (*.f64 (*.f64 a a) a) #s(literal 1/8 binary64) #s(literal 1 binary64)) (fma.f64 (*.f64 #s(literal 1/2 binary64) a) (*.f64 #s(literal 1/2 binary64) a) (-.f64 #s(literal 1 binary64) (*.f64 (*.f64 #s(literal 1/2 binary64) a) #s(literal 1 binary64))))) |
(fma.f64 #s(literal 1/2 binary64) a (*.f64 a (/.f64 #s(literal 1 binary64) a))) |
(fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) |
(fma.f64 a #s(literal 1/2 binary64) (*.f64 a (/.f64 #s(literal 1 binary64) a))) |
(fma.f64 a #s(literal 1/2 binary64) #s(literal 1 binary64)) |
(-.f64 (/.f64 #s(literal 1 binary64) (-.f64 #s(literal 1 binary64) (*.f64 #s(literal 1/2 binary64) a))) (/.f64 (*.f64 (*.f64 #s(literal 1/2 binary64) a) (*.f64 #s(literal 1/2 binary64) a)) (-.f64 #s(literal 1 binary64) (*.f64 #s(literal 1/2 binary64) a)))) |
(-.f64 (/.f64 (*.f64 (*.f64 #s(literal 1/2 binary64) a) (*.f64 #s(literal 1/2 binary64) a)) (-.f64 (*.f64 #s(literal 1/2 binary64) a) #s(literal 1 binary64))) (/.f64 #s(literal 1 binary64) (-.f64 (*.f64 #s(literal 1/2 binary64) a) #s(literal 1 binary64)))) |
(-.f64 #s(literal 1 binary64) (*.f64 #s(literal -1/2 binary64) a)) |
(+.f64 (/.f64 #s(literal 1 binary64) (+.f64 #s(literal 1 binary64) (-.f64 (*.f64 (*.f64 #s(literal 1/2 binary64) a) (*.f64 #s(literal 1/2 binary64) a)) (*.f64 #s(literal 1 binary64) (*.f64 #s(literal 1/2 binary64) a))))) (/.f64 (*.f64 (*.f64 (*.f64 a a) a) #s(literal 1/8 binary64)) (+.f64 #s(literal 1 binary64) (-.f64 (*.f64 (*.f64 #s(literal 1/2 binary64) a) (*.f64 #s(literal 1/2 binary64) a)) (*.f64 #s(literal 1 binary64) (*.f64 #s(literal 1/2 binary64) a)))))) |
(+.f64 (/.f64 (*.f64 (*.f64 (*.f64 a a) a) #s(literal 1/8 binary64)) (fma.f64 (*.f64 #s(literal 1/2 binary64) a) (*.f64 #s(literal 1/2 binary64) a) (-.f64 #s(literal 1 binary64) (*.f64 (*.f64 #s(literal 1/2 binary64) a) #s(literal 1 binary64))))) (/.f64 #s(literal 1 binary64) (fma.f64 (*.f64 #s(literal 1/2 binary64) a) (*.f64 #s(literal 1/2 binary64) a) (-.f64 #s(literal 1 binary64) (*.f64 (*.f64 #s(literal 1/2 binary64) a) #s(literal 1 binary64)))))) |
(+.f64 (*.f64 #s(literal 1/2 binary64) a) (*.f64 a (/.f64 #s(literal 1 binary64) a))) |
(+.f64 (*.f64 #s(literal 1/2 binary64) a) #s(literal 1 binary64)) |
(+.f64 #s(literal 1 binary64) (*.f64 #s(literal 1/2 binary64) a)) |
#s(literal 1/2 binary64) |
#s(literal 1 binary64) |
#s(literal 2 binary64) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) #s(approx (- (exp b) -1) #s(approx (+ 2 b) b)))) |
(pow.f64 #s(approx (- (exp b) -1) #s(approx (+ 2 b) b)) #s(literal -1 binary64)) |
(/.f64 #s(literal 1 binary64) (neg.f64 (neg.f64 #s(approx (- (exp b) -1) #s(approx (+ 2 b) b))))) |
(/.f64 #s(literal 1 binary64) (pow.f64 #s(approx (- (exp b) -1) #s(approx (+ 2 b) b)) #s(literal 1 binary64))) |
(/.f64 #s(literal 1 binary64) #s(approx (- (exp b) -1) #s(approx (+ 2 b) b))) |
(/.f64 #s(literal -1 binary64) (neg.f64 #s(approx (- (exp b) -1) #s(approx (+ 2 b) b)))) |
(exp.f64 (*.f64 (log.f64 #s(approx (- (exp b) -1) #s(approx (+ 2 b) b))) #s(literal -1 binary64))) |
#s(approx (- (exp b) -1) #s(approx (+ 2 b) b)) |
#s(approx (+ 2 b) b) |
b |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (/ 1 (- (exp b) -1)) #s(approx (+ (* (- (* (* b b) 1/48) 1/4) b) 1/2) (*.f64 (*.f64 (*.f64 b b) b) #s(literal 1/48 binary64))))) |
#s(approx (/ 1 (- (exp b) -1)) #s(approx (+ (* (- (* (* b b) 1/48) 1/4) b) 1/2) (*.f64 (*.f64 (*.f64 b b) b) #s(literal 1/48 binary64)))) |
#s(approx (+ (* (- (* (* b b) 1/48) 1/4) b) 1/2) (*.f64 (*.f64 (*.f64 b b) b) #s(literal 1/48 binary64))) |
(*.f64 (*.f64 (*.f64 b b) b) #s(literal 1/48 binary64)) |
(*.f64 (*.f64 b b) (*.f64 b #s(literal 1/48 binary64))) |
(*.f64 #s(literal 1/48 binary64) (*.f64 (*.f64 b b) b)) |
(*.f64 (neg.f64 (pow.f64 b #s(literal 3/2 binary64))) (neg.f64 (pow.f64 b #s(literal 3/2 binary64)))) |
(*.f64 (fabs.f64 (pow.f64 b #s(literal 3/2 binary64))) (fabs.f64 (pow.f64 b #s(literal 3/2 binary64)))) |
(*.f64 (pow.f64 b #s(literal 3/2 binary64)) (pow.f64 b #s(literal 3/2 binary64))) |
(*.f64 (*.f64 b b) b) |
(*.f64 b (*.f64 b b)) |
(pow.f64 (exp.f64 (log.f64 b)) #s(literal 3 binary64)) |
(pow.f64 (pow.f64 b #s(literal 3/2 binary64)) #s(literal 2 binary64)) |
(pow.f64 (*.f64 b b) #s(literal 3/2 binary64)) |
(pow.f64 b #s(literal 3 binary64)) |
(+.f64 (cosh.f64 (*.f64 (log.f64 b) #s(literal 3 binary64))) (sinh.f64 (*.f64 (log.f64 b) #s(literal 3 binary64)))) |
(exp.f64 (*.f64 (log.f64 b) #s(literal 3 binary64))) |
(*.f64 (neg.f64 (neg.f64 b)) (neg.f64 (neg.f64 b))) |
(*.f64 (neg.f64 (fabs.f64 b)) (neg.f64 (fabs.f64 b))) |
(*.f64 (fabs.f64 (fabs.f64 b)) (fabs.f64 (fabs.f64 b))) |
(*.f64 (exp.f64 (log.f64 b)) (exp.f64 (log.f64 b))) |
(*.f64 (neg.f64 b) (neg.f64 b)) |
(*.f64 (fabs.f64 b) (fabs.f64 b)) |
(*.f64 b b) |
(pow.f64 (exp.f64 (log.f64 b)) #s(literal 2 binary64)) |
(pow.f64 (neg.f64 b) #s(literal 2 binary64)) |
(pow.f64 (fabs.f64 b) #s(literal 2 binary64)) |
(pow.f64 (*.f64 b b) #s(literal 1 binary64)) |
(pow.f64 b #s(literal 2 binary64)) |
(fabs.f64 (*.f64 b b)) |
(+.f64 (cosh.f64 (*.f64 (log.f64 b) #s(literal 2 binary64))) (sinh.f64 (*.f64 (log.f64 b) #s(literal 2 binary64)))) |
(exp.f64 (*.f64 (log.f64 b) #s(literal 2 binary64))) |
#s(literal 1/48 binary64) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) #s(approx (- (exp b) -1) (fma.f64 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b #s(literal 2 binary64))))) |
(pow.f64 #s(approx (- (exp b) -1) (fma.f64 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b #s(literal 2 binary64))) #s(literal -1 binary64)) |
(/.f64 #s(literal 1 binary64) (neg.f64 (neg.f64 #s(approx (- (exp b) -1) (fma.f64 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b #s(literal 2 binary64)))))) |
(/.f64 #s(literal 1 binary64) (pow.f64 #s(approx (- (exp b) -1) (fma.f64 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b #s(literal 2 binary64))) #s(literal 1 binary64))) |
(/.f64 #s(literal 1 binary64) #s(approx (- (exp b) -1) (fma.f64 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b #s(literal 2 binary64)))) |
(/.f64 #s(literal -1 binary64) (neg.f64 #s(approx (- (exp b) -1) (fma.f64 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b #s(literal 2 binary64))))) |
(exp.f64 (*.f64 (log.f64 #s(approx (- (exp b) -1) (fma.f64 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b #s(literal 2 binary64)))) #s(literal -1 binary64))) |
#s(approx (- (exp b) -1) (fma.f64 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b #s(literal 2 binary64))) |
(/.f64 (neg.f64 (-.f64 (*.f64 (*.f64 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b) (*.f64 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b)) #s(literal 4 binary64))) (neg.f64 (-.f64 (*.f64 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b) #s(literal 2 binary64)))) |
(/.f64 (neg.f64 (-.f64 #s(literal 4 binary64) (*.f64 (*.f64 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b) (*.f64 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b)))) (neg.f64 (-.f64 #s(literal 2 binary64) (*.f64 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b)))) |
(/.f64 (neg.f64 (+.f64 (pow.f64 (*.f64 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b) #s(literal 3 binary64)) #s(literal 8 binary64))) (neg.f64 (fma.f64 (*.f64 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b) (*.f64 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b) (-.f64 #s(literal 4 binary64) (*.f64 (*.f64 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b) #s(literal 2 binary64)))))) |
(/.f64 (neg.f64 (+.f64 #s(literal 8 binary64) (pow.f64 (*.f64 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b) #s(literal 3 binary64)))) (neg.f64 (+.f64 #s(literal 4 binary64) (-.f64 (*.f64 (*.f64 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b) (*.f64 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b)) (*.f64 #s(literal 2 binary64) (*.f64 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b)))))) |
(/.f64 (-.f64 (*.f64 (*.f64 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b) (*.f64 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b)) #s(literal 4 binary64)) (-.f64 (*.f64 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b) #s(literal 2 binary64))) |
(/.f64 (-.f64 #s(literal 4 binary64) (*.f64 (*.f64 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b) (*.f64 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b))) (-.f64 #s(literal 2 binary64) (*.f64 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b))) |
(/.f64 (+.f64 (pow.f64 (*.f64 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b) #s(literal 3 binary64)) #s(literal 8 binary64)) (fma.f64 (*.f64 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b) (*.f64 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b) (-.f64 #s(literal 4 binary64) (*.f64 (*.f64 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b) #s(literal 2 binary64))))) |
(/.f64 (+.f64 #s(literal 8 binary64) (pow.f64 (*.f64 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b) #s(literal 3 binary64))) (+.f64 #s(literal 4 binary64) (-.f64 (*.f64 (*.f64 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b) (*.f64 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b)) (*.f64 #s(literal 2 binary64) (*.f64 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b))))) |
(fma.f64 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b #s(literal 2 binary64)) |
(fma.f64 b (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) #s(literal 2 binary64)) |
(-.f64 (/.f64 (*.f64 (*.f64 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b) (*.f64 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b)) (-.f64 (*.f64 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b) #s(literal 2 binary64))) (/.f64 #s(literal 4 binary64) (-.f64 (*.f64 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b) #s(literal 2 binary64)))) |
(-.f64 (/.f64 #s(literal 4 binary64) (-.f64 #s(literal 2 binary64) (*.f64 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b))) (/.f64 (*.f64 (*.f64 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b) (*.f64 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b)) (-.f64 #s(literal 2 binary64) (*.f64 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b)))) |
(-.f64 #s(literal 2 binary64) (*.f64 (neg.f64 b) (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)))) |
(+.f64 (/.f64 (pow.f64 (*.f64 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b) #s(literal 3 binary64)) (fma.f64 (*.f64 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b) (*.f64 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b) (-.f64 #s(literal 4 binary64) (*.f64 (*.f64 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b) #s(literal 2 binary64))))) (/.f64 #s(literal 8 binary64) (fma.f64 (*.f64 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b) (*.f64 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b) (-.f64 #s(literal 4 binary64) (*.f64 (*.f64 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b) #s(literal 2 binary64)))))) |
(+.f64 (/.f64 #s(literal 8 binary64) (+.f64 #s(literal 4 binary64) (-.f64 (*.f64 (*.f64 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b) (*.f64 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b)) (*.f64 #s(literal 2 binary64) (*.f64 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b))))) (/.f64 (pow.f64 (*.f64 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b) #s(literal 3 binary64)) (+.f64 #s(literal 4 binary64) (-.f64 (*.f64 (*.f64 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b) (*.f64 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b)) (*.f64 #s(literal 2 binary64) (*.f64 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b)))))) |
(+.f64 (*.f64 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b) #s(literal 2 binary64)) |
(+.f64 #s(literal 2 binary64) (*.f64 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b)) |
(*.f64 (+.f64 (/.f64 #s(literal 1 binary64) b) #s(literal 1/2 binary64)) b) |
(*.f64 b (+.f64 (/.f64 #s(literal 1 binary64) b) #s(literal 1/2 binary64))) |
(/.f64 (fma.f64 #s(literal 1/8 binary64) (*.f64 (*.f64 b b) b) (pow.f64 (*.f64 b (/.f64 #s(literal 1 binary64) b)) #s(literal 3 binary64))) (fma.f64 (*.f64 #s(literal 1/2 binary64) b) (*.f64 #s(literal 1/2 binary64) b) (-.f64 (*.f64 (*.f64 b (/.f64 #s(literal 1 binary64) b)) (*.f64 b (/.f64 #s(literal 1 binary64) b))) (*.f64 (*.f64 #s(literal 1/2 binary64) b) (*.f64 b (/.f64 #s(literal 1 binary64) b)))))) |
(/.f64 (neg.f64 (-.f64 (*.f64 (*.f64 #s(literal 1/2 binary64) b) (*.f64 #s(literal 1/2 binary64) b)) #s(literal 1 binary64))) (neg.f64 (-.f64 (*.f64 #s(literal 1/2 binary64) b) #s(literal 1 binary64)))) |
(/.f64 (neg.f64 (-.f64 #s(literal 1 binary64) (*.f64 (*.f64 #s(literal 1/2 binary64) b) (*.f64 #s(literal 1/2 binary64) b)))) (neg.f64 (-.f64 #s(literal 1 binary64) (*.f64 #s(literal 1/2 binary64) b)))) |
(/.f64 (neg.f64 (fma.f64 #s(literal 1/8 binary64) (*.f64 (*.f64 b b) b) #s(literal 1 binary64))) (neg.f64 (fma.f64 (*.f64 #s(literal 1/2 binary64) b) (*.f64 #s(literal 1/2 binary64) b) (-.f64 #s(literal 1 binary64) (*.f64 (*.f64 #s(literal 1/2 binary64) b) #s(literal 1 binary64)))))) |
(/.f64 (neg.f64 (+.f64 #s(literal 1 binary64) (*.f64 #s(literal 1/8 binary64) (*.f64 (*.f64 b b) b)))) (neg.f64 (+.f64 #s(literal 1 binary64) (-.f64 (*.f64 (*.f64 #s(literal 1/2 binary64) b) (*.f64 #s(literal 1/2 binary64) b)) (*.f64 #s(literal 1 binary64) (*.f64 #s(literal 1/2 binary64) b)))))) |
(/.f64 (-.f64 (*.f64 (*.f64 #s(literal 1/2 binary64) b) (*.f64 #s(literal 1/2 binary64) b)) #s(literal 1 binary64)) (-.f64 (*.f64 #s(literal 1/2 binary64) b) #s(literal 1 binary64))) |
(/.f64 (-.f64 #s(literal 1 binary64) (*.f64 (*.f64 #s(literal 1/2 binary64) b) (*.f64 #s(literal 1/2 binary64) b))) (-.f64 #s(literal 1 binary64) (*.f64 #s(literal 1/2 binary64) b))) |
(/.f64 (fma.f64 #s(literal 1/8 binary64) (*.f64 (*.f64 b b) b) #s(literal 1 binary64)) (fma.f64 (*.f64 #s(literal 1/2 binary64) b) (*.f64 #s(literal 1/2 binary64) b) (-.f64 #s(literal 1 binary64) (*.f64 (*.f64 #s(literal 1/2 binary64) b) #s(literal 1 binary64))))) |
(/.f64 (+.f64 #s(literal 1 binary64) (*.f64 #s(literal 1/8 binary64) (*.f64 (*.f64 b b) b))) (+.f64 #s(literal 1 binary64) (-.f64 (*.f64 (*.f64 #s(literal 1/2 binary64) b) (*.f64 #s(literal 1/2 binary64) b)) (*.f64 #s(literal 1 binary64) (*.f64 #s(literal 1/2 binary64) b))))) |
(fma.f64 #s(literal 1/2 binary64) b (*.f64 b (/.f64 #s(literal 1 binary64) b))) |
(fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) |
(fma.f64 b #s(literal 1/2 binary64) (*.f64 b (/.f64 #s(literal 1 binary64) b))) |
(fma.f64 b #s(literal 1/2 binary64) #s(literal 1 binary64)) |
(-.f64 (/.f64 (*.f64 (*.f64 #s(literal 1/2 binary64) b) (*.f64 #s(literal 1/2 binary64) b)) (-.f64 (*.f64 #s(literal 1/2 binary64) b) #s(literal 1 binary64))) (/.f64 #s(literal 1 binary64) (-.f64 (*.f64 #s(literal 1/2 binary64) b) #s(literal 1 binary64)))) |
(-.f64 (/.f64 #s(literal 1 binary64) (-.f64 #s(literal 1 binary64) (*.f64 #s(literal 1/2 binary64) b))) (/.f64 (*.f64 (*.f64 #s(literal 1/2 binary64) b) (*.f64 #s(literal 1/2 binary64) b)) (-.f64 #s(literal 1 binary64) (*.f64 #s(literal 1/2 binary64) b)))) |
(-.f64 #s(literal 1 binary64) (*.f64 #s(literal -1/2 binary64) b)) |
(+.f64 (/.f64 (*.f64 #s(literal 1/8 binary64) (*.f64 (*.f64 b b) b)) (fma.f64 (*.f64 #s(literal 1/2 binary64) b) (*.f64 #s(literal 1/2 binary64) b) (-.f64 #s(literal 1 binary64) (*.f64 (*.f64 #s(literal 1/2 binary64) b) #s(literal 1 binary64))))) (/.f64 #s(literal 1 binary64) (fma.f64 (*.f64 #s(literal 1/2 binary64) b) (*.f64 #s(literal 1/2 binary64) b) (-.f64 #s(literal 1 binary64) (*.f64 (*.f64 #s(literal 1/2 binary64) b) #s(literal 1 binary64)))))) |
(+.f64 (/.f64 #s(literal 1 binary64) (+.f64 #s(literal 1 binary64) (-.f64 (*.f64 (*.f64 #s(literal 1/2 binary64) b) (*.f64 #s(literal 1/2 binary64) b)) (*.f64 #s(literal 1 binary64) (*.f64 #s(literal 1/2 binary64) b))))) (/.f64 (*.f64 #s(literal 1/8 binary64) (*.f64 (*.f64 b b) b)) (+.f64 #s(literal 1 binary64) (-.f64 (*.f64 (*.f64 #s(literal 1/2 binary64) b) (*.f64 #s(literal 1/2 binary64) b)) (*.f64 #s(literal 1 binary64) (*.f64 #s(literal 1/2 binary64) b)))))) |
(+.f64 (*.f64 #s(literal 1/2 binary64) b) (*.f64 b (/.f64 #s(literal 1 binary64) b))) |
(+.f64 (*.f64 #s(literal 1/2 binary64) b) #s(literal 1 binary64)) |
(+.f64 #s(literal 1 binary64) (*.f64 #s(literal 1/2 binary64) b)) |
(/.f64 (neg.f64 (neg.f64 #s(approx (exp a) (+.f64 #s(literal 1 binary64) a)))) (neg.f64 (neg.f64 (+.f64 #s(approx (exp b) (+.f64 #s(literal 1 binary64) b)) #s(approx (exp a) (-.f64 a #s(literal -1 binary64))))))) |
(/.f64 (neg.f64 #s(approx (exp a) (+.f64 #s(literal 1 binary64) a))) (neg.f64 (+.f64 #s(approx (exp b) (+.f64 #s(literal 1 binary64) b)) #s(approx (exp a) (-.f64 a #s(literal -1 binary64)))))) |
(/.f64 #s(approx (exp a) (+.f64 #s(literal 1 binary64) a)) (+.f64 #s(approx (exp b) (+.f64 #s(literal 1 binary64) b)) #s(approx (exp a) (-.f64 a #s(literal -1 binary64))))) |
#s(approx (exp a) (+.f64 #s(literal 1 binary64) a)) |
(/.f64 (fma.f64 (*.f64 a a) a #s(literal 1 binary64)) (fma.f64 a a (-.f64 #s(literal 1 binary64) (*.f64 a #s(literal 1 binary64))))) |
(/.f64 (neg.f64 (-.f64 #s(literal 1 binary64) (*.f64 a a))) (neg.f64 (-.f64 #s(literal 1 binary64) a))) |
(/.f64 (neg.f64 (+.f64 #s(literal 1 binary64) (*.f64 (*.f64 a a) a))) (neg.f64 (+.f64 #s(literal 1 binary64) (-.f64 (*.f64 a a) (*.f64 #s(literal 1 binary64) a))))) |
(/.f64 (-.f64 #s(literal 1 binary64) (*.f64 a a)) (-.f64 #s(literal 1 binary64) a)) |
(/.f64 (+.f64 #s(literal 1 binary64) (*.f64 (*.f64 a a) a)) (+.f64 #s(literal 1 binary64) (-.f64 (*.f64 a a) (*.f64 #s(literal 1 binary64) a)))) |
(-.f64 (/.f64 #s(literal 1 binary64) (-.f64 #s(literal 1 binary64) a)) (/.f64 (*.f64 a a) (-.f64 #s(literal 1 binary64) a))) |
(+.f64 (/.f64 #s(literal 1 binary64) (+.f64 #s(literal 1 binary64) (-.f64 (*.f64 a a) (*.f64 #s(literal 1 binary64) a)))) (/.f64 (*.f64 (*.f64 a a) a) (+.f64 #s(literal 1 binary64) (-.f64 (*.f64 a a) (*.f64 #s(literal 1 binary64) a))))) |
(+.f64 #s(literal 1 binary64) a) |
(+.f64 a #s(literal 1 binary64)) |
(/.f64 (fma.f64 (*.f64 #s(approx (exp b) (+.f64 #s(literal 1 binary64) b)) #s(approx (exp b) (+.f64 #s(literal 1 binary64) b))) #s(approx (exp b) (+.f64 #s(literal 1 binary64) b)) (*.f64 (*.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp a) (-.f64 a #s(literal -1 binary64)))) #s(approx (exp a) (-.f64 a #s(literal -1 binary64))))) (fma.f64 #s(approx (exp b) (+.f64 #s(literal 1 binary64) b)) #s(approx (exp b) (+.f64 #s(literal 1 binary64) b)) (-.f64 (*.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp a) (-.f64 a #s(literal -1 binary64)))) (*.f64 #s(approx (exp b) (+.f64 #s(literal 1 binary64) b)) #s(approx (exp a) (-.f64 a #s(literal -1 binary64))))))) |
(/.f64 (neg.f64 (-.f64 (*.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp a) (-.f64 a #s(literal -1 binary64)))) (*.f64 #s(approx (exp b) (+.f64 #s(literal 1 binary64) b)) #s(approx (exp b) (+.f64 #s(literal 1 binary64) b))))) (neg.f64 (-.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp b) (+.f64 #s(literal 1 binary64) b))))) |
(/.f64 (neg.f64 (fma.f64 (*.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp a) (-.f64 a #s(literal -1 binary64)))) #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) (*.f64 (*.f64 #s(approx (exp b) (+.f64 #s(literal 1 binary64) b)) #s(approx (exp b) (+.f64 #s(literal 1 binary64) b))) #s(approx (exp b) (+.f64 #s(literal 1 binary64) b))))) (neg.f64 (fma.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) (-.f64 (*.f64 #s(approx (exp b) (+.f64 #s(literal 1 binary64) b)) #s(approx (exp b) (+.f64 #s(literal 1 binary64) b))) (*.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp b) (+.f64 #s(literal 1 binary64) b))))))) |
(/.f64 (-.f64 (*.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp a) (-.f64 a #s(literal -1 binary64)))) (*.f64 #s(approx (exp b) (+.f64 #s(literal 1 binary64) b)) #s(approx (exp b) (+.f64 #s(literal 1 binary64) b)))) (-.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp b) (+.f64 #s(literal 1 binary64) b)))) |
(/.f64 (fma.f64 (*.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp a) (-.f64 a #s(literal -1 binary64)))) #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) (*.f64 (*.f64 #s(approx (exp b) (+.f64 #s(literal 1 binary64) b)) #s(approx (exp b) (+.f64 #s(literal 1 binary64) b))) #s(approx (exp b) (+.f64 #s(literal 1 binary64) b)))) (fma.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) (-.f64 (*.f64 #s(approx (exp b) (+.f64 #s(literal 1 binary64) b)) #s(approx (exp b) (+.f64 #s(literal 1 binary64) b))) (*.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp b) (+.f64 #s(literal 1 binary64) b)))))) |
(-.f64 (/.f64 (*.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp a) (-.f64 a #s(literal -1 binary64)))) (-.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp b) (+.f64 #s(literal 1 binary64) b)))) (/.f64 (*.f64 #s(approx (exp b) (+.f64 #s(literal 1 binary64) b)) #s(approx (exp b) (+.f64 #s(literal 1 binary64) b))) (-.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp b) (+.f64 #s(literal 1 binary64) b))))) |
(+.f64 (/.f64 (*.f64 (*.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp a) (-.f64 a #s(literal -1 binary64)))) #s(approx (exp a) (-.f64 a #s(literal -1 binary64)))) (fma.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) (-.f64 (*.f64 #s(approx (exp b) (+.f64 #s(literal 1 binary64) b)) #s(approx (exp b) (+.f64 #s(literal 1 binary64) b))) (*.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp b) (+.f64 #s(literal 1 binary64) b)))))) (/.f64 (*.f64 (*.f64 #s(approx (exp b) (+.f64 #s(literal 1 binary64) b)) #s(approx (exp b) (+.f64 #s(literal 1 binary64) b))) #s(approx (exp b) (+.f64 #s(literal 1 binary64) b))) (fma.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) (-.f64 (*.f64 #s(approx (exp b) (+.f64 #s(literal 1 binary64) b)) #s(approx (exp b) (+.f64 #s(literal 1 binary64) b))) (*.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp b) (+.f64 #s(literal 1 binary64) b))))))) |
(+.f64 #s(approx (exp b) (+.f64 #s(literal 1 binary64) b)) #s(approx (exp a) (-.f64 a #s(literal -1 binary64)))) |
(+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp b) (+.f64 #s(literal 1 binary64) b))) |
#s(approx (exp a) (-.f64 a #s(literal -1 binary64))) |
(/.f64 (neg.f64 (-.f64 (*.f64 a a) #s(literal 1 binary64))) (neg.f64 (+.f64 a #s(literal -1 binary64)))) |
(/.f64 (neg.f64 (-.f64 (*.f64 (*.f64 a a) a) #s(literal -1 binary64))) (neg.f64 (fma.f64 a a (+.f64 #s(literal 1 binary64) (*.f64 a #s(literal -1 binary64)))))) |
(/.f64 (-.f64 (*.f64 a a) #s(literal 1 binary64)) (+.f64 a #s(literal -1 binary64))) |
(/.f64 (-.f64 (*.f64 (*.f64 a a) a) #s(literal -1 binary64)) (fma.f64 a a (+.f64 #s(literal 1 binary64) (*.f64 a #s(literal -1 binary64))))) |
(-.f64 (/.f64 (*.f64 a a) (+.f64 a #s(literal -1 binary64))) (/.f64 #s(literal 1 binary64) (+.f64 a #s(literal -1 binary64)))) |
(-.f64 (/.f64 (*.f64 (*.f64 a a) a) (fma.f64 a a (+.f64 #s(literal 1 binary64) (*.f64 a #s(literal -1 binary64))))) (/.f64 #s(literal -1 binary64) (fma.f64 a a (+.f64 #s(literal 1 binary64) (*.f64 a #s(literal -1 binary64)))))) |
(-.f64 a #s(literal -1 binary64)) |
#s(literal -1 binary64) |
#s(approx (exp b) (+.f64 #s(literal 1 binary64) b)) |
(/.f64 (neg.f64 (-.f64 #s(literal 1 binary64) (*.f64 b b))) (neg.f64 (-.f64 #s(literal 1 binary64) b))) |
(/.f64 (neg.f64 (-.f64 (*.f64 b b) #s(literal 1 binary64))) (neg.f64 (-.f64 b #s(literal 1 binary64)))) |
(/.f64 (neg.f64 (+.f64 #s(literal 1 binary64) (*.f64 (*.f64 b b) b))) (neg.f64 (+.f64 #s(literal 1 binary64) (-.f64 (*.f64 b b) (*.f64 #s(literal 1 binary64) b))))) |
(/.f64 (neg.f64 (fma.f64 (*.f64 b b) b #s(literal 1 binary64))) (neg.f64 (fma.f64 b b (-.f64 #s(literal 1 binary64) (*.f64 b #s(literal 1 binary64)))))) |
(/.f64 (-.f64 #s(literal 1 binary64) (*.f64 b b)) (-.f64 #s(literal 1 binary64) b)) |
(/.f64 (-.f64 (*.f64 b b) #s(literal 1 binary64)) (-.f64 b #s(literal 1 binary64))) |
(/.f64 (+.f64 #s(literal 1 binary64) (*.f64 (*.f64 b b) b)) (+.f64 #s(literal 1 binary64) (-.f64 (*.f64 b b) (*.f64 #s(literal 1 binary64) b)))) |
(/.f64 (fma.f64 (*.f64 b b) b #s(literal 1 binary64)) (fma.f64 b b (-.f64 #s(literal 1 binary64) (*.f64 b #s(literal 1 binary64))))) |
(-.f64 (/.f64 #s(literal 1 binary64) (-.f64 #s(literal 1 binary64) b)) (/.f64 (*.f64 b b) (-.f64 #s(literal 1 binary64) b))) |
(-.f64 (/.f64 (*.f64 b b) (-.f64 b #s(literal 1 binary64))) (/.f64 #s(literal 1 binary64) (-.f64 b #s(literal 1 binary64)))) |
(+.f64 (/.f64 #s(literal 1 binary64) (+.f64 #s(literal 1 binary64) (-.f64 (*.f64 b b) (*.f64 #s(literal 1 binary64) b)))) (/.f64 (*.f64 (*.f64 b b) b) (+.f64 #s(literal 1 binary64) (-.f64 (*.f64 b b) (*.f64 #s(literal 1 binary64) b))))) |
(+.f64 (/.f64 (*.f64 (*.f64 b b) b) (fma.f64 b b (-.f64 #s(literal 1 binary64) (*.f64 b #s(literal 1 binary64))))) (/.f64 #s(literal 1 binary64) (fma.f64 b b (-.f64 #s(literal 1 binary64) (*.f64 b #s(literal 1 binary64)))))) |
(+.f64 #s(literal 1 binary64) b) |
(+.f64 b #s(literal 1 binary64)) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) (+.f64 #s(literal 1 binary64) (exp.f64 b)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (fma.f64 (-.f64 (/.f64 #s(literal 1 binary64) (+.f64 #s(literal 1 binary64) (exp.f64 b))) (pow.f64 (+.f64 #s(literal 1 binary64) (exp.f64 b)) #s(literal -2 binary64))) a (/.f64 #s(literal 1 binary64) (+.f64 #s(literal 1 binary64) (exp.f64 b))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (fma.f64 (-.f64 (fma.f64 a (+.f64 (/.f64 #s(literal 1/2 binary64) (+.f64 #s(literal 1 binary64) (exp.f64 b))) (-.f64 (pow.f64 (+.f64 #s(literal 1 binary64) (exp.f64 b)) #s(literal -3 binary64)) (*.f64 (pow.f64 (+.f64 #s(literal 1 binary64) (exp.f64 b)) #s(literal -2 binary64)) #s(literal 3/2 binary64)))) (/.f64 #s(literal 1 binary64) (+.f64 #s(literal 1 binary64) (exp.f64 b)))) (pow.f64 (+.f64 #s(literal 1 binary64) (exp.f64 b)) #s(literal -2 binary64))) a (/.f64 #s(literal 1 binary64) (+.f64 #s(literal 1 binary64) (exp.f64 b))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (fma.f64 (fma.f64 (-.f64 (+.f64 (fma.f64 (-.f64 (fma.f64 #s(literal 3/2 binary64) (pow.f64 (+.f64 #s(literal 1 binary64) (exp.f64 b)) #s(literal -3 binary64)) (/.f64 #s(literal 1/6 binary64) (+.f64 #s(literal 1 binary64) (exp.f64 b)))) (+.f64 (/.f64 #s(literal 2/3 binary64) (*.f64 (+.f64 #s(literal 1 binary64) (exp.f64 b)) (+.f64 #s(literal 1 binary64) (exp.f64 b)))) (fma.f64 #s(literal 1/2 binary64) (/.f64 (-.f64 (/.f64 #s(literal 1 binary64) (+.f64 #s(literal 1 binary64) (exp.f64 b))) (pow.f64 (+.f64 #s(literal 1 binary64) (exp.f64 b)) #s(literal -2 binary64))) (+.f64 #s(literal 1 binary64) (exp.f64 b))) (pow.f64 (+.f64 #s(literal 1 binary64) (exp.f64 b)) #s(literal -4 binary64))))) a (pow.f64 (+.f64 #s(literal 1 binary64) (exp.f64 b)) #s(literal -3 binary64))) (/.f64 #s(literal 1/2 binary64) (+.f64 #s(literal 1 binary64) (exp.f64 b)))) (*.f64 (pow.f64 (+.f64 #s(literal 1 binary64) (exp.f64 b)) #s(literal -2 binary64)) #s(literal 3/2 binary64))) a (-.f64 (/.f64 #s(literal 1 binary64) (+.f64 #s(literal 1 binary64) (exp.f64 b))) (pow.f64 (+.f64 #s(literal 1 binary64) (exp.f64 b)) #s(literal -2 binary64)))) a (/.f64 #s(literal 1 binary64) (+.f64 #s(literal 1 binary64) (exp.f64 b))))) |
#s(approx (exp a) #s(literal 1 binary64)) |
#s(approx (exp a) (+.f64 #s(literal 1 binary64) a)) |
#s(approx (exp a) (fma.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a #s(literal 1 binary64))) |
#s(approx (exp a) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) a #s(literal 1/2 binary64)) a #s(literal 1 binary64)) a #s(literal 1 binary64))) |
#s(approx a a) |
#s(approx (+ (exp a) (exp b)) (+.f64 #s(literal 1 binary64) (exp.f64 b))) |
#s(approx (+ (exp a) (exp b)) (+.f64 (+.f64 (exp.f64 b) a) #s(literal 1 binary64))) |
#s(approx (+ (exp a) (exp b)) (+.f64 (fma.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a (exp.f64 b)) #s(literal 1 binary64))) |
#s(approx (+ (exp a) (exp b)) (+.f64 (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) a #s(literal 1/2 binary64)) a #s(literal 1 binary64)) a (exp.f64 b)) #s(literal 1 binary64))) |
#s(approx (- (exp a) -1) #s(literal 2 binary64)) |
#s(approx (- (exp a) -1) (+.f64 #s(literal 2 binary64) a)) |
#s(approx (- (exp a) -1) (fma.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a #s(literal 2 binary64))) |
#s(approx (- (exp a) -1) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) a #s(literal 1/2 binary64)) a #s(literal 1 binary64)) a #s(literal 2 binary64))) |
#s(approx (+ (* (+ (* 1/2 a) 1) a) 2) #s(literal 2 binary64)) |
#s(approx (+ (* (+ (* 1/2 a) 1) a) 2) (+.f64 #s(literal 2 binary64) a)) |
#s(approx (+ (* (+ (* 1/2 a) 1) a) 2) (fma.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a #s(literal 2 binary64))) |
#s(approx (+ (* 1/2 a) 1) #s(literal 1 binary64)) |
#s(approx (+ (* 1/2 a) 1) (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64))) |
#s(approx (+ 1 a) #s(literal 1 binary64)) |
#s(approx (+ 1 a) (+.f64 #s(literal 1 binary64) a)) |
#s(approx (- a -1) #s(literal 1 binary64)) |
#s(approx (- a -1) (+.f64 #s(literal 1 binary64) a)) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 (exp.f64 a) (+.f64 (exp.f64 b) (exp.f64 a)))) |
#s(approx (exp a) (exp.f64 a)) |
#s(approx (+ (exp a) (exp b)) (+.f64 (exp.f64 b) (exp.f64 a))) |
#s(approx (- (exp a) -1) (+.f64 #s(literal 1 binary64) (exp.f64 a))) |
#s(approx (+ (* (+ (* 1/2 a) 1) a) 2) (*.f64 (*.f64 a a) #s(literal 1/2 binary64))) |
#s(approx (+ (* (+ (* 1/2 a) 1) a) 2) (fma.f64 (*.f64 a a) #s(literal 1/2 binary64) a)) |
#s(approx (+ (* (+ (* 1/2 a) 1) a) 2) (*.f64 (+.f64 (+.f64 (/.f64 #s(literal 1 binary64) a) #s(literal 1/2 binary64)) (/.f64 #s(literal 2 binary64) (*.f64 a a))) (*.f64 a a))) |
#s(approx (+ (* 1/2 a) 1) (*.f64 #s(literal 1/2 binary64) a)) |
#s(approx (+ (* 1/2 a) 1) (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64))) |
#s(approx (+ 1 a) a) |
#s(approx (+ 1 a) (fma.f64 #s(literal 1 binary64) a #s(literal 1 binary64))) |
#s(approx (- a -1) a) |
#s(approx (- a -1) (fma.f64 #s(literal 1 binary64) a #s(literal 1 binary64))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 (exp.f64 a) (+.f64 #s(literal 1 binary64) (exp.f64 a)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (+.f64 (neg.f64 (*.f64 b (exp.f64 (-.f64 a (*.f64 (log.f64 (+.f64 #s(literal 1 binary64) (exp.f64 a))) #s(literal 2 binary64)))))) (/.f64 (exp.f64 a) (+.f64 #s(literal 1 binary64) (exp.f64 a))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (fma.f64 b (-.f64 (neg.f64 (*.f64 (fma.f64 (exp.f64 (-.f64 a (*.f64 (log.f64 (+.f64 #s(literal 1 binary64) (exp.f64 a))) #s(literal 2 binary64)))) #s(literal 1/2 binary64) (neg.f64 (exp.f64 (-.f64 a (*.f64 (log.f64 (+.f64 #s(literal 1 binary64) (exp.f64 a))) #s(literal 3 binary64)))))) b)) (exp.f64 (-.f64 a (*.f64 (log.f64 (+.f64 #s(literal 1 binary64) (exp.f64 a))) #s(literal 2 binary64))))) (/.f64 (exp.f64 a) (+.f64 #s(literal 1 binary64) (exp.f64 a))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (fma.f64 (-.f64 (*.f64 (-.f64 (neg.f64 (*.f64 (+.f64 (fma.f64 #s(literal -1/2 binary64) (exp.f64 (-.f64 a (*.f64 (log.f64 (+.f64 #s(literal 1 binary64) (exp.f64 a))) #s(literal 3 binary64)))) (*.f64 (exp.f64 (-.f64 a (*.f64 (log.f64 (+.f64 #s(literal 1 binary64) (exp.f64 a))) #s(literal 2 binary64)))) #s(literal 1/6 binary64))) (neg.f64 (/.f64 (fma.f64 (exp.f64 (-.f64 a (*.f64 (log.f64 (+.f64 #s(literal 1 binary64) (exp.f64 a))) #s(literal 2 binary64)))) #s(literal 1/2 binary64) (neg.f64 (exp.f64 (-.f64 a (*.f64 (log.f64 (+.f64 #s(literal 1 binary64) (exp.f64 a))) #s(literal 3 binary64)))))) (+.f64 #s(literal 1 binary64) (exp.f64 a))))) b)) (fma.f64 (exp.f64 (-.f64 a (*.f64 (log.f64 (+.f64 #s(literal 1 binary64) (exp.f64 a))) #s(literal 2 binary64)))) #s(literal 1/2 binary64) (neg.f64 (exp.f64 (-.f64 a (*.f64 (log.f64 (+.f64 #s(literal 1 binary64) (exp.f64 a))) #s(literal 3 binary64))))))) b) (exp.f64 (-.f64 a (*.f64 (log.f64 (+.f64 #s(literal 1 binary64) (exp.f64 a))) #s(literal 2 binary64))))) b (/.f64 (exp.f64 a) (+.f64 #s(literal 1 binary64) (exp.f64 a))))) |
#s(approx (+ (exp a) (exp b)) (+.f64 #s(literal 1 binary64) (exp.f64 a))) |
#s(approx (+ (exp a) (exp b)) (+.f64 (+.f64 b (exp.f64 a)) #s(literal 1 binary64))) |
#s(approx (+ (exp a) (exp b)) (+.f64 (fma.f64 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b (exp.f64 a)) #s(literal 1 binary64))) |
#s(approx (+ (exp a) (exp b)) (+.f64 (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) b #s(literal 1/2 binary64)) b #s(literal 1 binary64)) b (exp.f64 a)) #s(literal 1 binary64))) |
#s(approx (/ 1 (- (exp b) -1)) #s(literal 1/2 binary64)) |
#s(approx (/ 1 (- (exp b) -1)) (fma.f64 #s(literal -1/4 binary64) b #s(literal 1/2 binary64))) |
#s(approx (/ 1 (- (exp b) -1)) (fma.f64 (-.f64 (*.f64 (*.f64 b b) #s(literal 1/48 binary64)) #s(literal 1/4 binary64)) b #s(literal 1/2 binary64))) |
#s(approx (/ 1 (- (exp b) -1)) (fma.f64 (-.f64 (*.f64 (fma.f64 #s(literal -1/480 binary64) (*.f64 b b) #s(literal 1/48 binary64)) (*.f64 b b)) #s(literal 1/4 binary64)) b #s(literal 1/2 binary64))) |
#s(approx (- (exp b) -1) #s(literal 2 binary64)) |
#s(approx (- (exp b) -1) (+.f64 #s(literal 2 binary64) b)) |
#s(approx (- (exp b) -1) (fma.f64 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b #s(literal 2 binary64))) |
#s(approx (- (exp b) -1) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) b #s(literal 1/2 binary64)) b #s(literal 1 binary64)) b #s(literal 2 binary64))) |
#s(approx (+ 2 b) #s(literal 2 binary64)) |
#s(approx (+ 2 b) (+.f64 #s(literal 2 binary64) b)) |
#s(approx b b) |
#s(approx (+ (* (- (* (* b b) 1/48) 1/4) b) 1/2) #s(literal 1/2 binary64)) |
#s(approx (+ (* (- (* (* b b) 1/48) 1/4) b) 1/2) (fma.f64 #s(literal -1/4 binary64) b #s(literal 1/2 binary64))) |
#s(approx (+ (* (- (* (* b b) 1/48) 1/4) b) 1/2) (fma.f64 (-.f64 (*.f64 (*.f64 b b) #s(literal 1/48 binary64)) #s(literal 1/4 binary64)) b #s(literal 1/2 binary64))) |
#s(approx (* (* (* b b) b) 1/48) (*.f64 (*.f64 (*.f64 b b) b) #s(literal 1/48 binary64))) |
#s(approx (* (* b b) b) (*.f64 (*.f64 b b) b)) |
#s(approx (* b b) (*.f64 b b)) |
#s(approx (+ (* (+ (* 1/2 b) 1) b) 2) #s(literal 2 binary64)) |
#s(approx (+ (* (+ (* 1/2 b) 1) b) 2) (+.f64 #s(literal 2 binary64) b)) |
#s(approx (+ (* (+ (* 1/2 b) 1) b) 2) (fma.f64 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b #s(literal 2 binary64))) |
#s(approx (+ (* 1/2 b) 1) #s(literal 1 binary64)) |
#s(approx (+ (* 1/2 b) 1) (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64))) |
#s(approx (exp b) #s(literal 1 binary64)) |
#s(approx (exp b) (+.f64 #s(literal 1 binary64) b)) |
#s(approx (exp b) (fma.f64 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b #s(literal 1 binary64))) |
#s(approx (exp b) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/6 binary64) b #s(literal 1/2 binary64)) b #s(literal 1 binary64)) b #s(literal 1 binary64))) |
#s(approx (+ b 1) #s(literal 1 binary64)) |
#s(approx (+ b 1) (+.f64 #s(literal 1 binary64) b)) |
#s(approx (/ 1 (- (exp b) -1)) (/.f64 #s(literal 1 binary64) (+.f64 #s(literal 1 binary64) (exp.f64 b)))) |
#s(approx (- (exp b) -1) (+.f64 #s(literal 1 binary64) (exp.f64 b))) |
#s(approx (+ 2 b) b) |
#s(approx (+ 2 b) (*.f64 (+.f64 (/.f64 #s(literal 2 binary64) b) #s(literal 1 binary64)) b)) |
#s(approx (+ (* (- (* (* b b) 1/48) 1/4) b) 1/2) (*.f64 (*.f64 (*.f64 b b) b) #s(literal 1/48 binary64))) |
#s(approx (+ (* (- (* (* b b) 1/48) 1/4) b) 1/2) (*.f64 (-.f64 #s(literal 1/48 binary64) (/.f64 #s(literal 1/4 binary64) (*.f64 b b))) (*.f64 (*.f64 b b) b))) |
#s(approx (+ (* (- (* (* b b) 1/48) 1/4) b) 1/2) (*.f64 (-.f64 (+.f64 (/.f64 #s(literal 1/2 binary64) (*.f64 (*.f64 b b) b)) #s(literal 1/48 binary64)) (/.f64 #s(literal 1/4 binary64) (*.f64 b b))) (*.f64 (*.f64 b b) b))) |
#s(approx (+ (* (+ (* 1/2 b) 1) b) 2) (*.f64 (*.f64 b b) #s(literal 1/2 binary64))) |
#s(approx (+ (* (+ (* 1/2 b) 1) b) 2) (fma.f64 (*.f64 b b) #s(literal 1/2 binary64) b)) |
#s(approx (+ (* (+ (* 1/2 b) 1) b) 2) (*.f64 (+.f64 (+.f64 (/.f64 #s(literal 1 binary64) b) #s(literal 1/2 binary64)) (/.f64 #s(literal 2 binary64) (*.f64 b b))) (*.f64 b b))) |
#s(approx (+ (* 1/2 b) 1) (*.f64 #s(literal 1/2 binary64) b)) |
#s(approx (+ (* 1/2 b) 1) (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64))) |
#s(approx (exp b) (exp.f64 b)) |
#s(approx (+ b 1) b) |
#s(approx (+ b 1) (fma.f64 #s(literal 1 binary64) b #s(literal 1 binary64))) |
#s(approx (+ (* (- (* (* b b) 1/48) 1/4) b) 1/2) (neg.f64 (*.f64 (-.f64 (/.f64 #s(literal 1/4 binary64) (*.f64 b b)) #s(literal 1/48 binary64)) (*.f64 (*.f64 b b) b)))) |
#s(approx (+ (* (- (* (* b b) 1/48) 1/4) b) 1/2) (neg.f64 (*.f64 (-.f64 (-.f64 (/.f64 #s(literal 1/4 binary64) (*.f64 b b)) #s(literal 1/48 binary64)) (/.f64 #s(literal 1/2 binary64) (*.f64 (*.f64 b b) b))) (*.f64 (*.f64 b b) b)))) |
Compiled 2 928 to 1 392 computations (52.5% saved)
23 alts after pruning (13 fresh and 10 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 235 | 10 | 245 |
| Fresh | 2 | 3 | 5 |
| Picked | 1 | 4 | 5 |
| Done | 0 | 6 | 6 |
| Total | 238 | 23 | 261 |
| Status | Accuracy | Program |
|---|---|---|
| ✓ | 62.8% | (/.f64 (exp.f64 a) #s(approx (+ (exp a) (exp b)) (-.f64 (exp.f64 a) #s(literal -1 binary64)))) |
| 61.6% | (/.f64 (exp.f64 a) #s(approx (+ (exp a) (exp b)) #s(approx (- (exp b) -1) #s(literal 2 binary64)))) | |
| ✓ | 61.8% | (/.f64 (exp.f64 a) #s(approx (+ (exp a) (exp b)) #s(approx (- (exp a) -1) (+.f64 #s(literal 2 binary64) a)))) |
| 35.7% | (/.f64 #s(approx (exp a) (fma.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a #s(literal 1 binary64))) #s(approx (+ (exp a) (exp b)) #s(approx (- (exp a) -1) (fma.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a #s(literal 2 binary64))))) | |
| 47.2% | (/.f64 #s(approx (exp a) (+.f64 #s(literal 1 binary64) a)) (+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp b) (fma.f64 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b #s(literal 1 binary64))))) | |
| ✓ | 33.6% | (/.f64 #s(approx (exp a) (+.f64 #s(literal 1 binary64) a)) (+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp b) (+.f64 b #s(literal 1 binary64))))) |
| 9.5% | (/.f64 #s(approx (exp a) (+.f64 #s(literal 1 binary64) a)) (+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp b) #s(approx (+ b 1) b)))) | |
| 35.9% | (/.f64 #s(approx (exp a) (+.f64 #s(literal 1 binary64) a)) (+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp b) #s(approx (+ b 1) #s(literal 1 binary64))))) | |
| 12.9% | (/.f64 #s(approx (exp a) #s(approx (+ 1 a) a)) (+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp b) (+.f64 b #s(literal 1 binary64))))) | |
| 33.7% | (/.f64 #s(approx (exp a) #s(approx (+ 1 a) #s(literal 1 binary64))) (+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp b) (+.f64 b #s(literal 1 binary64))))) | |
| 49.6% | (/.f64 #s(approx (exp a) #s(literal 1 binary64)) #s(approx (+ (exp a) (exp b)) #s(approx (- (exp a) -1) (fma.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a #s(literal 2 binary64))))) | |
| ✓ | 82.1% | #s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) (-.f64 (exp.f64 b) #s(literal -1 binary64)))) |
| ✓ | 46.7% | #s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) #s(approx (- (exp b) -1) (fma.f64 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b #s(literal 2 binary64))))) |
| 45.8% | #s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) #s(approx (- (exp b) -1) (fma.f64 #s(approx (+ (* 1/2 b) 1) (*.f64 #s(literal 1/2 binary64) b)) b #s(literal 2 binary64))))) | |
| ✓ | 33.2% | #s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) #s(approx (- (exp b) -1) (+.f64 #s(literal 2 binary64) b)))) |
| 16.5% | #s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) #s(approx (- (exp b) -1) #s(approx (+ (* (+ (* 1/2 b) 1) b) 2) (fma.f64 (*.f64 b b) #s(literal 1/2 binary64) b))))) | |
| 16.8% | #s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) #s(approx (- (exp b) -1) #s(approx (+ (* (+ (* 1/2 b) 1) b) 2) (*.f64 (*.f64 b b) #s(literal 1/2 binary64)))))) | |
| ✓ | 3.3% | #s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) #s(approx (- (exp b) -1) #s(approx (+ 2 b) b)))) |
| ✓ | 32.4% | #s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (/ 1 (- (exp b) -1)) (fma.f64 (-.f64 (*.f64 (*.f64 b b) #s(literal 1/48 binary64)) #s(literal 1/4 binary64)) b #s(literal 1/2 binary64)))) |
| 33.3% | #s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (/ 1 (- (exp b) -1)) (fma.f64 #s(approx (- (* (* b b) 1/48) 1/4) #s(literal -1/4 binary64)) b #s(literal 1/2 binary64)))) | |
| ✓ | 12.8% | #s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (/ 1 (- (exp b) -1)) #s(approx (+ (* (- (* (* b b) 1/48) 1/4) b) 1/2) (*.f64 (*.f64 (*.f64 b b) b) #s(literal 1/48 binary64))))) |
| 12.8% | #s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (/ 1 (- (exp b) -1)) #s(approx (+ (* (- (* (* b b) 1/48) 1/4) b) 1/2) (*.f64 (*.f64 b b) (*.f64 b #s(literal 1/48 binary64)))))) | |
| ✓ | 35.3% | #s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (/ 1 (- (exp b) -1)) #s(literal 1/2 binary64))) |
Compiled 637 to 544 computations (14.6% saved)
| Inputs |
|---|
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (/ 1 (- (exp b) -1)) #s(literal 1/2 binary64))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) #s(approx (- (exp b) -1) #s(approx (+ 2 b) b)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (/ 1 (- (exp b) -1)) (fma.f64 #s(literal -1/4 binary64) b #s(literal 1/2 binary64)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (/ 1 (- (exp b) -1)) (fma.f64 #s(approx (- (* (* b b) 1/48) 1/4) #s(literal -1/4 binary64)) b #s(literal 1/2 binary64)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) #s(approx (- (exp b) -1) (+.f64 #s(literal 2 binary64) b)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (/ 1 (- (exp b) -1)) #s(approx (+ (* (- (* (* b b) 1/48) 1/4) b) 1/2) (*.f64 (*.f64 b b) (*.f64 b #s(literal 1/48 binary64)))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (/ 1 (- (exp b) -1)) #s(approx (+ (* (- (* (* b b) 1/48) 1/4) b) 1/2) (*.f64 (*.f64 (*.f64 b b) b) #s(literal 1/48 binary64))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) #s(approx (- (exp b) -1) #s(approx (+ (* (+ (* 1/2 b) 1) b) 2) (*.f64 (*.f64 b b) #s(literal 1/2 binary64)))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) #s(approx (- (exp b) -1) #s(approx (+ (* (+ (* 1/2 b) 1) b) 2) (fma.f64 (*.f64 b b) #s(literal 1/2 binary64) b))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) #s(approx (- (exp b) -1) (fma.f64 #s(approx (+ (* 1/2 b) 1) (*.f64 #s(literal 1/2 binary64) b)) b #s(literal 2 binary64))))) |
(/.f64 #s(approx (exp a) #s(approx (+ 1 a) #s(literal 1 binary64))) (+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp b) (+.f64 b #s(literal 1 binary64))))) |
(/.f64 #s(approx (exp a) #s(approx (+ 1 a) a)) (+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp b) (+.f64 b #s(literal 1 binary64))))) |
(/.f64 #s(approx (exp a) (+.f64 #s(literal 1 binary64) a)) (+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp b) #s(literal 1 binary64)))) |
(/.f64 #s(approx (exp a) (+.f64 #s(literal 1 binary64) a)) (+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp b) #s(approx (+ b 1) #s(literal 1 binary64))))) |
(/.f64 #s(approx (exp a) (+.f64 #s(literal 1 binary64) a)) (+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp b) #s(approx (+ b 1) b)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) #s(approx (- (exp b) -1) (fma.f64 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b #s(literal 2 binary64))))) |
(/.f64 #s(approx (exp a) #s(literal 1 binary64)) #s(approx (+ (exp a) (exp b)) #s(approx (- (exp a) -1) (fma.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a #s(literal 2 binary64))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (/ 1 (- (exp b) -1)) (fma.f64 (-.f64 (*.f64 (*.f64 b b) #s(literal 1/48 binary64)) #s(literal 1/4 binary64)) b #s(literal 1/2 binary64)))) |
(/.f64 (exp.f64 a) #s(approx (+ (exp a) (exp b)) #s(approx (- (exp b) -1) #s(literal 2 binary64)))) |
(/.f64 #s(approx (exp a) (+.f64 #s(literal 1 binary64) a)) (+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp b) (+.f64 b #s(literal 1 binary64))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) (-.f64 (exp.f64 b) #s(literal -1 binary64)))) |
(/.f64 (exp.f64 a) #s(approx (+ (exp a) (exp b)) #s(approx (- (exp a) -1) (+.f64 #s(literal 2 binary64) a)))) |
(/.f64 (exp.f64 a) (+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp b) #s(literal 1 binary64)))) |
(/.f64 #s(approx (exp a) (+.f64 #s(literal 1 binary64) a)) (+.f64 #s(approx (exp a) #s(approx (- a -1) a)) (exp.f64 b))) |
(/.f64 #s(approx (exp a) (+.f64 #s(literal 1 binary64) a)) (+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp b) (fma.f64 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b #s(literal 1 binary64))))) |
(/.f64 #s(approx (exp a) (+.f64 #s(literal 1 binary64) a)) (+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) (exp.f64 b))) |
(/.f64 #s(approx (exp a) (fma.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a #s(literal 1 binary64))) #s(approx (+ (exp a) (exp b)) #s(approx (- (exp a) -1) (fma.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a #s(literal 2 binary64))))) |
(/.f64 (exp.f64 a) #s(approx (+ (exp a) (exp b)) #s(approx (- (exp a) -1) (fma.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a #s(literal 2 binary64))))) |
(/.f64 (exp.f64 a) #s(approx (+ (exp a) (exp b)) (-.f64 (exp.f64 a) #s(literal -1 binary64)))) |
(/.f64 (exp.f64 a) #s(approx (+ (exp a) (exp b)) (-.f64 (exp.f64 b) #s(literal -1 binary64)))) |
(/.f64 (exp.f64 a) (+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) (exp.f64 b))) |
(/.f64 (exp.f64 a) (+.f64 (exp.f64 a) (exp.f64 b))) |
| Outputs |
|---|
(/.f64 (exp.f64 a) (+.f64 (exp.f64 a) (exp.f64 b))) |
5 calls:
| 18.0ms | b |
| 16.0ms | (exp.f64 a) |
| 8.0ms | a |
| 6.0ms | (exp.f64 b) |
| 6.0ms | (/.f64 (exp.f64 a) (+.f64 (exp.f64 a) (exp.f64 b))) |
| Accuracy | Segments | Branch |
|---|---|---|
| 98.0% | 1 | (exp.f64 b) |
| 98.0% | 1 | (exp.f64 a) |
| 98.0% | 1 | (/.f64 (exp.f64 a) (+.f64 (exp.f64 a) (exp.f64 b))) |
| 98.0% | 1 | a |
| 98.0% | 1 | b |
Compiled 13 to 16 computations (-23.1% saved)
| Inputs |
|---|
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (/ 1 (- (exp b) -1)) #s(literal 1/2 binary64))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) #s(approx (- (exp b) -1) #s(approx (+ 2 b) b)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (/ 1 (- (exp b) -1)) (fma.f64 #s(literal -1/4 binary64) b #s(literal 1/2 binary64)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (/ 1 (- (exp b) -1)) (fma.f64 #s(approx (- (* (* b b) 1/48) 1/4) #s(literal -1/4 binary64)) b #s(literal 1/2 binary64)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) #s(approx (- (exp b) -1) (+.f64 #s(literal 2 binary64) b)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (/ 1 (- (exp b) -1)) #s(approx (+ (* (- (* (* b b) 1/48) 1/4) b) 1/2) (*.f64 (*.f64 b b) (*.f64 b #s(literal 1/48 binary64)))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (/ 1 (- (exp b) -1)) #s(approx (+ (* (- (* (* b b) 1/48) 1/4) b) 1/2) (*.f64 (*.f64 (*.f64 b b) b) #s(literal 1/48 binary64))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) #s(approx (- (exp b) -1) #s(approx (+ (* (+ (* 1/2 b) 1) b) 2) (*.f64 (*.f64 b b) #s(literal 1/2 binary64)))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) #s(approx (- (exp b) -1) #s(approx (+ (* (+ (* 1/2 b) 1) b) 2) (fma.f64 (*.f64 b b) #s(literal 1/2 binary64) b))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) #s(approx (- (exp b) -1) (fma.f64 #s(approx (+ (* 1/2 b) 1) (*.f64 #s(literal 1/2 binary64) b)) b #s(literal 2 binary64))))) |
(/.f64 #s(approx (exp a) #s(approx (+ 1 a) #s(literal 1 binary64))) (+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp b) (+.f64 b #s(literal 1 binary64))))) |
(/.f64 #s(approx (exp a) #s(approx (+ 1 a) a)) (+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp b) (+.f64 b #s(literal 1 binary64))))) |
(/.f64 #s(approx (exp a) (+.f64 #s(literal 1 binary64) a)) (+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp b) #s(literal 1 binary64)))) |
(/.f64 #s(approx (exp a) (+.f64 #s(literal 1 binary64) a)) (+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp b) #s(approx (+ b 1) #s(literal 1 binary64))))) |
(/.f64 #s(approx (exp a) (+.f64 #s(literal 1 binary64) a)) (+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp b) #s(approx (+ b 1) b)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) #s(approx (- (exp b) -1) (fma.f64 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b #s(literal 2 binary64))))) |
(/.f64 #s(approx (exp a) #s(literal 1 binary64)) #s(approx (+ (exp a) (exp b)) #s(approx (- (exp a) -1) (fma.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a #s(literal 2 binary64))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (/ 1 (- (exp b) -1)) (fma.f64 (-.f64 (*.f64 (*.f64 b b) #s(literal 1/48 binary64)) #s(literal 1/4 binary64)) b #s(literal 1/2 binary64)))) |
(/.f64 (exp.f64 a) #s(approx (+ (exp a) (exp b)) #s(approx (- (exp b) -1) #s(literal 2 binary64)))) |
(/.f64 #s(approx (exp a) (+.f64 #s(literal 1 binary64) a)) (+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp b) (+.f64 b #s(literal 1 binary64))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) (-.f64 (exp.f64 b) #s(literal -1 binary64)))) |
(/.f64 (exp.f64 a) #s(approx (+ (exp a) (exp b)) #s(approx (- (exp a) -1) (+.f64 #s(literal 2 binary64) a)))) |
(/.f64 (exp.f64 a) (+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp b) #s(literal 1 binary64)))) |
(/.f64 #s(approx (exp a) (+.f64 #s(literal 1 binary64) a)) (+.f64 #s(approx (exp a) #s(approx (- a -1) a)) (exp.f64 b))) |
(/.f64 #s(approx (exp a) (+.f64 #s(literal 1 binary64) a)) (+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp b) (fma.f64 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b #s(literal 1 binary64))))) |
(/.f64 #s(approx (exp a) (+.f64 #s(literal 1 binary64) a)) (+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) (exp.f64 b))) |
(/.f64 #s(approx (exp a) (fma.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a #s(literal 1 binary64))) #s(approx (+ (exp a) (exp b)) #s(approx (- (exp a) -1) (fma.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a #s(literal 2 binary64))))) |
(/.f64 (exp.f64 a) #s(approx (+ (exp a) (exp b)) #s(approx (- (exp a) -1) (fma.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a #s(literal 2 binary64))))) |
(/.f64 (exp.f64 a) #s(approx (+ (exp a) (exp b)) (-.f64 (exp.f64 a) #s(literal -1 binary64)))) |
(/.f64 (exp.f64 a) #s(approx (+ (exp a) (exp b)) (-.f64 (exp.f64 b) #s(literal -1 binary64)))) |
(/.f64 (exp.f64 a) (+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) (exp.f64 b))) |
| Outputs |
|---|
(/.f64 (exp.f64 a) (+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) (exp.f64 b))) |
5 calls:
| 35.0ms | (/.f64 (exp.f64 a) (+.f64 (exp.f64 a) (exp.f64 b))) |
| 22.0ms | b |
| 8.0ms | a |
| 6.0ms | (exp.f64 a) |
| 6.0ms | (exp.f64 b) |
| Accuracy | Segments | Branch |
|---|---|---|
| 97.8% | 1 | (exp.f64 b) |
| 97.8% | 1 | (exp.f64 a) |
| 97.8% | 1 | (/.f64 (exp.f64 a) (+.f64 (exp.f64 a) (exp.f64 b))) |
| 97.8% | 1 | a |
| 97.8% | 1 | b |
Compiled 13 to 16 computations (-23.1% saved)
| Inputs |
|---|
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (/ 1 (- (exp b) -1)) #s(literal 1/2 binary64))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) #s(approx (- (exp b) -1) #s(approx (+ 2 b) b)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (/ 1 (- (exp b) -1)) (fma.f64 #s(literal -1/4 binary64) b #s(literal 1/2 binary64)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (/ 1 (- (exp b) -1)) (fma.f64 #s(approx (- (* (* b b) 1/48) 1/4) #s(literal -1/4 binary64)) b #s(literal 1/2 binary64)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) #s(approx (- (exp b) -1) (+.f64 #s(literal 2 binary64) b)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (/ 1 (- (exp b) -1)) #s(approx (+ (* (- (* (* b b) 1/48) 1/4) b) 1/2) (*.f64 (*.f64 b b) (*.f64 b #s(literal 1/48 binary64)))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (/ 1 (- (exp b) -1)) #s(approx (+ (* (- (* (* b b) 1/48) 1/4) b) 1/2) (*.f64 (*.f64 (*.f64 b b) b) #s(literal 1/48 binary64))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) #s(approx (- (exp b) -1) #s(approx (+ (* (+ (* 1/2 b) 1) b) 2) (*.f64 (*.f64 b b) #s(literal 1/2 binary64)))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) #s(approx (- (exp b) -1) #s(approx (+ (* (+ (* 1/2 b) 1) b) 2) (fma.f64 (*.f64 b b) #s(literal 1/2 binary64) b))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) #s(approx (- (exp b) -1) (fma.f64 #s(approx (+ (* 1/2 b) 1) (*.f64 #s(literal 1/2 binary64) b)) b #s(literal 2 binary64))))) |
(/.f64 #s(approx (exp a) #s(approx (+ 1 a) #s(literal 1 binary64))) (+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp b) (+.f64 b #s(literal 1 binary64))))) |
(/.f64 #s(approx (exp a) #s(approx (+ 1 a) a)) (+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp b) (+.f64 b #s(literal 1 binary64))))) |
(/.f64 #s(approx (exp a) (+.f64 #s(literal 1 binary64) a)) (+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp b) #s(literal 1 binary64)))) |
(/.f64 #s(approx (exp a) (+.f64 #s(literal 1 binary64) a)) (+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp b) #s(approx (+ b 1) #s(literal 1 binary64))))) |
(/.f64 #s(approx (exp a) (+.f64 #s(literal 1 binary64) a)) (+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp b) #s(approx (+ b 1) b)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) #s(approx (- (exp b) -1) (fma.f64 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b #s(literal 2 binary64))))) |
(/.f64 #s(approx (exp a) #s(literal 1 binary64)) #s(approx (+ (exp a) (exp b)) #s(approx (- (exp a) -1) (fma.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a #s(literal 2 binary64))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (/ 1 (- (exp b) -1)) (fma.f64 (-.f64 (*.f64 (*.f64 b b) #s(literal 1/48 binary64)) #s(literal 1/4 binary64)) b #s(literal 1/2 binary64)))) |
(/.f64 (exp.f64 a) #s(approx (+ (exp a) (exp b)) #s(approx (- (exp b) -1) #s(literal 2 binary64)))) |
(/.f64 #s(approx (exp a) (+.f64 #s(literal 1 binary64) a)) (+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp b) (+.f64 b #s(literal 1 binary64))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) (-.f64 (exp.f64 b) #s(literal -1 binary64)))) |
(/.f64 (exp.f64 a) #s(approx (+ (exp a) (exp b)) #s(approx (- (exp a) -1) (+.f64 #s(literal 2 binary64) a)))) |
(/.f64 (exp.f64 a) (+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp b) #s(literal 1 binary64)))) |
(/.f64 #s(approx (exp a) (+.f64 #s(literal 1 binary64) a)) (+.f64 #s(approx (exp a) #s(approx (- a -1) a)) (exp.f64 b))) |
(/.f64 #s(approx (exp a) (+.f64 #s(literal 1 binary64) a)) (+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp b) (fma.f64 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b #s(literal 1 binary64))))) |
(/.f64 #s(approx (exp a) (+.f64 #s(literal 1 binary64) a)) (+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) (exp.f64 b))) |
(/.f64 #s(approx (exp a) (fma.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a #s(literal 1 binary64))) #s(approx (+ (exp a) (exp b)) #s(approx (- (exp a) -1) (fma.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a #s(literal 2 binary64))))) |
(/.f64 (exp.f64 a) #s(approx (+ (exp a) (exp b)) #s(approx (- (exp a) -1) (fma.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a #s(literal 2 binary64))))) |
(/.f64 (exp.f64 a) #s(approx (+ (exp a) (exp b)) (-.f64 (exp.f64 a) #s(literal -1 binary64)))) |
(/.f64 (exp.f64 a) #s(approx (+ (exp a) (exp b)) (-.f64 (exp.f64 b) #s(literal -1 binary64)))) |
| Outputs |
|---|
(/.f64 (exp.f64 a) #s(approx (+ (exp a) (exp b)) (-.f64 (exp.f64 b) #s(literal -1 binary64)))) |
5 calls:
| 57.0ms | a |
| 34.0ms | (exp.f64 a) |
| 8.0ms | b |
| 6.0ms | (/.f64 (exp.f64 a) (+.f64 (exp.f64 a) (exp.f64 b))) |
| 6.0ms | (exp.f64 b) |
| Accuracy | Segments | Branch |
|---|---|---|
| 97.4% | 1 | (exp.f64 b) |
| 97.4% | 1 | (exp.f64 a) |
| 97.4% | 1 | (/.f64 (exp.f64 a) (+.f64 (exp.f64 a) (exp.f64 b))) |
| 97.4% | 1 | a |
| 97.4% | 1 | b |
Compiled 13 to 16 computations (-23.1% saved)
| Inputs |
|---|
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (/ 1 (- (exp b) -1)) #s(literal 1/2 binary64))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) #s(approx (- (exp b) -1) #s(approx (+ 2 b) b)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (/ 1 (- (exp b) -1)) (fma.f64 #s(literal -1/4 binary64) b #s(literal 1/2 binary64)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (/ 1 (- (exp b) -1)) (fma.f64 #s(approx (- (* (* b b) 1/48) 1/4) #s(literal -1/4 binary64)) b #s(literal 1/2 binary64)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) #s(approx (- (exp b) -1) (+.f64 #s(literal 2 binary64) b)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (/ 1 (- (exp b) -1)) #s(approx (+ (* (- (* (* b b) 1/48) 1/4) b) 1/2) (*.f64 (*.f64 b b) (*.f64 b #s(literal 1/48 binary64)))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (/ 1 (- (exp b) -1)) #s(approx (+ (* (- (* (* b b) 1/48) 1/4) b) 1/2) (*.f64 (*.f64 (*.f64 b b) b) #s(literal 1/48 binary64))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) #s(approx (- (exp b) -1) #s(approx (+ (* (+ (* 1/2 b) 1) b) 2) (*.f64 (*.f64 b b) #s(literal 1/2 binary64)))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) #s(approx (- (exp b) -1) #s(approx (+ (* (+ (* 1/2 b) 1) b) 2) (fma.f64 (*.f64 b b) #s(literal 1/2 binary64) b))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) #s(approx (- (exp b) -1) (fma.f64 #s(approx (+ (* 1/2 b) 1) (*.f64 #s(literal 1/2 binary64) b)) b #s(literal 2 binary64))))) |
(/.f64 #s(approx (exp a) #s(approx (+ 1 a) #s(literal 1 binary64))) (+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp b) (+.f64 b #s(literal 1 binary64))))) |
(/.f64 #s(approx (exp a) #s(approx (+ 1 a) a)) (+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp b) (+.f64 b #s(literal 1 binary64))))) |
(/.f64 #s(approx (exp a) (+.f64 #s(literal 1 binary64) a)) (+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp b) #s(literal 1 binary64)))) |
(/.f64 #s(approx (exp a) (+.f64 #s(literal 1 binary64) a)) (+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp b) #s(approx (+ b 1) #s(literal 1 binary64))))) |
(/.f64 #s(approx (exp a) (+.f64 #s(literal 1 binary64) a)) (+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp b) #s(approx (+ b 1) b)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) #s(approx (- (exp b) -1) (fma.f64 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b #s(literal 2 binary64))))) |
(/.f64 #s(approx (exp a) #s(literal 1 binary64)) #s(approx (+ (exp a) (exp b)) #s(approx (- (exp a) -1) (fma.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a #s(literal 2 binary64))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (/ 1 (- (exp b) -1)) (fma.f64 (-.f64 (*.f64 (*.f64 b b) #s(literal 1/48 binary64)) #s(literal 1/4 binary64)) b #s(literal 1/2 binary64)))) |
(/.f64 (exp.f64 a) #s(approx (+ (exp a) (exp b)) #s(approx (- (exp b) -1) #s(literal 2 binary64)))) |
(/.f64 #s(approx (exp a) (+.f64 #s(literal 1 binary64) a)) (+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp b) (+.f64 b #s(literal 1 binary64))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) (-.f64 (exp.f64 b) #s(literal -1 binary64)))) |
(/.f64 (exp.f64 a) #s(approx (+ (exp a) (exp b)) #s(approx (- (exp a) -1) (+.f64 #s(literal 2 binary64) a)))) |
(/.f64 (exp.f64 a) (+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp b) #s(literal 1 binary64)))) |
(/.f64 #s(approx (exp a) (+.f64 #s(literal 1 binary64) a)) (+.f64 #s(approx (exp a) #s(approx (- a -1) a)) (exp.f64 b))) |
(/.f64 #s(approx (exp a) (+.f64 #s(literal 1 binary64) a)) (+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp b) (fma.f64 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b #s(literal 1 binary64))))) |
(/.f64 #s(approx (exp a) (+.f64 #s(literal 1 binary64) a)) (+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) (exp.f64 b))) |
(/.f64 #s(approx (exp a) (fma.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a #s(literal 1 binary64))) #s(approx (+ (exp a) (exp b)) #s(approx (- (exp a) -1) (fma.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a #s(literal 2 binary64))))) |
(/.f64 (exp.f64 a) #s(approx (+ (exp a) (exp b)) #s(approx (- (exp a) -1) (fma.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a #s(literal 2 binary64))))) |
(/.f64 (exp.f64 a) #s(approx (+ (exp a) (exp b)) (-.f64 (exp.f64 a) #s(literal -1 binary64)))) |
| Outputs |
|---|
(/.f64 (exp.f64 a) #s(approx (+ (exp a) (exp b)) (-.f64 (exp.f64 a) #s(literal -1 binary64)))) |
(/.f64 #s(approx (exp a) (+.f64 #s(literal 1 binary64) a)) (+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) (exp.f64 b))) |
5 calls:
| 14.0ms | a |
| 8.0ms | b |
| 6.0ms | (/.f64 (exp.f64 a) (+.f64 (exp.f64 a) (exp.f64 b))) |
| 6.0ms | (exp.f64 b) |
| 6.0ms | (exp.f64 a) |
| Accuracy | Segments | Branch |
|---|---|---|
| 98.4% | 3 | (exp.f64 b) |
| 98.9% | 2 | (exp.f64 a) |
| 82.7% | 1 | (/.f64 (exp.f64 a) (+.f64 (exp.f64 a) (exp.f64 b))) |
| 98.9% | 2 | a |
| 98.4% | 3 | b |
Compiled 13 to 16 computations (-23.1% saved)
| Inputs |
|---|
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (/ 1 (- (exp b) -1)) #s(literal 1/2 binary64))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) #s(approx (- (exp b) -1) #s(approx (+ 2 b) b)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (/ 1 (- (exp b) -1)) (fma.f64 #s(literal -1/4 binary64) b #s(literal 1/2 binary64)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (/ 1 (- (exp b) -1)) (fma.f64 #s(approx (- (* (* b b) 1/48) 1/4) #s(literal -1/4 binary64)) b #s(literal 1/2 binary64)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) #s(approx (- (exp b) -1) (+.f64 #s(literal 2 binary64) b)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (/ 1 (- (exp b) -1)) #s(approx (+ (* (- (* (* b b) 1/48) 1/4) b) 1/2) (*.f64 (*.f64 b b) (*.f64 b #s(literal 1/48 binary64)))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (/ 1 (- (exp b) -1)) #s(approx (+ (* (- (* (* b b) 1/48) 1/4) b) 1/2) (*.f64 (*.f64 (*.f64 b b) b) #s(literal 1/48 binary64))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) #s(approx (- (exp b) -1) #s(approx (+ (* (+ (* 1/2 b) 1) b) 2) (*.f64 (*.f64 b b) #s(literal 1/2 binary64)))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) #s(approx (- (exp b) -1) #s(approx (+ (* (+ (* 1/2 b) 1) b) 2) (fma.f64 (*.f64 b b) #s(literal 1/2 binary64) b))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) #s(approx (- (exp b) -1) (fma.f64 #s(approx (+ (* 1/2 b) 1) (*.f64 #s(literal 1/2 binary64) b)) b #s(literal 2 binary64))))) |
(/.f64 #s(approx (exp a) #s(approx (+ 1 a) #s(literal 1 binary64))) (+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp b) (+.f64 b #s(literal 1 binary64))))) |
(/.f64 #s(approx (exp a) #s(approx (+ 1 a) a)) (+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp b) (+.f64 b #s(literal 1 binary64))))) |
(/.f64 #s(approx (exp a) (+.f64 #s(literal 1 binary64) a)) (+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp b) #s(literal 1 binary64)))) |
(/.f64 #s(approx (exp a) (+.f64 #s(literal 1 binary64) a)) (+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp b) #s(approx (+ b 1) #s(literal 1 binary64))))) |
(/.f64 #s(approx (exp a) (+.f64 #s(literal 1 binary64) a)) (+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp b) #s(approx (+ b 1) b)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) #s(approx (- (exp b) -1) (fma.f64 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b #s(literal 2 binary64))))) |
(/.f64 #s(approx (exp a) #s(literal 1 binary64)) #s(approx (+ (exp a) (exp b)) #s(approx (- (exp a) -1) (fma.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a #s(literal 2 binary64))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (/ 1 (- (exp b) -1)) (fma.f64 (-.f64 (*.f64 (*.f64 b b) #s(literal 1/48 binary64)) #s(literal 1/4 binary64)) b #s(literal 1/2 binary64)))) |
(/.f64 (exp.f64 a) #s(approx (+ (exp a) (exp b)) #s(approx (- (exp b) -1) #s(literal 2 binary64)))) |
(/.f64 #s(approx (exp a) (+.f64 #s(literal 1 binary64) a)) (+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp b) (+.f64 b #s(literal 1 binary64))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) (-.f64 (exp.f64 b) #s(literal -1 binary64)))) |
(/.f64 (exp.f64 a) #s(approx (+ (exp a) (exp b)) #s(approx (- (exp a) -1) (+.f64 #s(literal 2 binary64) a)))) |
(/.f64 (exp.f64 a) (+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp b) #s(literal 1 binary64)))) |
(/.f64 #s(approx (exp a) (+.f64 #s(literal 1 binary64) a)) (+.f64 #s(approx (exp a) #s(approx (- a -1) a)) (exp.f64 b))) |
(/.f64 #s(approx (exp a) (+.f64 #s(literal 1 binary64) a)) (+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp b) (fma.f64 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b #s(literal 1 binary64))))) |
(/.f64 #s(approx (exp a) (+.f64 #s(literal 1 binary64) a)) (+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) (exp.f64 b))) |
(/.f64 #s(approx (exp a) (fma.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a #s(literal 1 binary64))) #s(approx (+ (exp a) (exp b)) #s(approx (- (exp a) -1) (fma.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a #s(literal 2 binary64))))) |
(/.f64 (exp.f64 a) #s(approx (+ (exp a) (exp b)) #s(approx (- (exp a) -1) (fma.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a #s(literal 2 binary64))))) |
| Outputs |
|---|
(/.f64 (exp.f64 a) #s(approx (+ (exp a) (exp b)) #s(approx (- (exp b) -1) #s(literal 2 binary64)))) |
(/.f64 #s(approx (exp a) (+.f64 #s(literal 1 binary64) a)) (+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) (exp.f64 b))) |
2 calls:
| 42.0ms | (exp.f64 a) |
| 7.0ms | a |
| Accuracy | Segments | Branch |
|---|---|---|
| 98.6% | 2 | (exp.f64 a) |
| 98.6% | 2 | a |
Compiled 3 to 5 computations (-66.7% saved)
| Inputs |
|---|
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (/ 1 (- (exp b) -1)) #s(literal 1/2 binary64))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) #s(approx (- (exp b) -1) #s(approx (+ 2 b) b)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (/ 1 (- (exp b) -1)) (fma.f64 #s(literal -1/4 binary64) b #s(literal 1/2 binary64)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (/ 1 (- (exp b) -1)) (fma.f64 #s(approx (- (* (* b b) 1/48) 1/4) #s(literal -1/4 binary64)) b #s(literal 1/2 binary64)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) #s(approx (- (exp b) -1) (+.f64 #s(literal 2 binary64) b)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (/ 1 (- (exp b) -1)) #s(approx (+ (* (- (* (* b b) 1/48) 1/4) b) 1/2) (*.f64 (*.f64 b b) (*.f64 b #s(literal 1/48 binary64)))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (/ 1 (- (exp b) -1)) #s(approx (+ (* (- (* (* b b) 1/48) 1/4) b) 1/2) (*.f64 (*.f64 (*.f64 b b) b) #s(literal 1/48 binary64))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) #s(approx (- (exp b) -1) #s(approx (+ (* (+ (* 1/2 b) 1) b) 2) (*.f64 (*.f64 b b) #s(literal 1/2 binary64)))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) #s(approx (- (exp b) -1) #s(approx (+ (* (+ (* 1/2 b) 1) b) 2) (fma.f64 (*.f64 b b) #s(literal 1/2 binary64) b))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) #s(approx (- (exp b) -1) (fma.f64 #s(approx (+ (* 1/2 b) 1) (*.f64 #s(literal 1/2 binary64) b)) b #s(literal 2 binary64))))) |
(/.f64 #s(approx (exp a) #s(approx (+ 1 a) #s(literal 1 binary64))) (+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp b) (+.f64 b #s(literal 1 binary64))))) |
(/.f64 #s(approx (exp a) #s(approx (+ 1 a) a)) (+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp b) (+.f64 b #s(literal 1 binary64))))) |
(/.f64 #s(approx (exp a) (+.f64 #s(literal 1 binary64) a)) (+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp b) #s(literal 1 binary64)))) |
(/.f64 #s(approx (exp a) (+.f64 #s(literal 1 binary64) a)) (+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp b) #s(approx (+ b 1) #s(literal 1 binary64))))) |
(/.f64 #s(approx (exp a) (+.f64 #s(literal 1 binary64) a)) (+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp b) #s(approx (+ b 1) b)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) #s(approx (- (exp b) -1) (fma.f64 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b #s(literal 2 binary64))))) |
(/.f64 #s(approx (exp a) #s(literal 1 binary64)) #s(approx (+ (exp a) (exp b)) #s(approx (- (exp a) -1) (fma.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a #s(literal 2 binary64))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (/ 1 (- (exp b) -1)) (fma.f64 (-.f64 (*.f64 (*.f64 b b) #s(literal 1/48 binary64)) #s(literal 1/4 binary64)) b #s(literal 1/2 binary64)))) |
(/.f64 (exp.f64 a) #s(approx (+ (exp a) (exp b)) #s(approx (- (exp b) -1) #s(literal 2 binary64)))) |
(/.f64 #s(approx (exp a) (+.f64 #s(literal 1 binary64) a)) (+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp b) (+.f64 b #s(literal 1 binary64))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) (-.f64 (exp.f64 b) #s(literal -1 binary64)))) |
(/.f64 (exp.f64 a) #s(approx (+ (exp a) (exp b)) #s(approx (- (exp a) -1) (+.f64 #s(literal 2 binary64) a)))) |
(/.f64 (exp.f64 a) (+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp b) #s(literal 1 binary64)))) |
(/.f64 #s(approx (exp a) (+.f64 #s(literal 1 binary64) a)) (+.f64 #s(approx (exp a) #s(approx (- a -1) a)) (exp.f64 b))) |
(/.f64 #s(approx (exp a) (+.f64 #s(literal 1 binary64) a)) (+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp b) (fma.f64 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b #s(literal 1 binary64))))) |
| Outputs |
|---|
(/.f64 (exp.f64 a) #s(approx (+ (exp a) (exp b)) #s(approx (- (exp b) -1) #s(literal 2 binary64)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) (-.f64 (exp.f64 b) #s(literal -1 binary64)))) |
2 calls:
| 7.0ms | a |
| 5.0ms | (exp.f64 a) |
| Accuracy | Segments | Branch |
|---|---|---|
| 98.0% | 2 | (exp.f64 a) |
| 98.0% | 2 | a |
Compiled 3 to 5 computations (-66.7% saved)
| Inputs |
|---|
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (/ 1 (- (exp b) -1)) #s(literal 1/2 binary64))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) #s(approx (- (exp b) -1) #s(approx (+ 2 b) b)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (/ 1 (- (exp b) -1)) (fma.f64 #s(literal -1/4 binary64) b #s(literal 1/2 binary64)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (/ 1 (- (exp b) -1)) (fma.f64 #s(approx (- (* (* b b) 1/48) 1/4) #s(literal -1/4 binary64)) b #s(literal 1/2 binary64)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) #s(approx (- (exp b) -1) (+.f64 #s(literal 2 binary64) b)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (/ 1 (- (exp b) -1)) #s(approx (+ (* (- (* (* b b) 1/48) 1/4) b) 1/2) (*.f64 (*.f64 b b) (*.f64 b #s(literal 1/48 binary64)))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (/ 1 (- (exp b) -1)) #s(approx (+ (* (- (* (* b b) 1/48) 1/4) b) 1/2) (*.f64 (*.f64 (*.f64 b b) b) #s(literal 1/48 binary64))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) #s(approx (- (exp b) -1) #s(approx (+ (* (+ (* 1/2 b) 1) b) 2) (*.f64 (*.f64 b b) #s(literal 1/2 binary64)))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) #s(approx (- (exp b) -1) #s(approx (+ (* (+ (* 1/2 b) 1) b) 2) (fma.f64 (*.f64 b b) #s(literal 1/2 binary64) b))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) #s(approx (- (exp b) -1) (fma.f64 #s(approx (+ (* 1/2 b) 1) (*.f64 #s(literal 1/2 binary64) b)) b #s(literal 2 binary64))))) |
(/.f64 #s(approx (exp a) #s(approx (+ 1 a) #s(literal 1 binary64))) (+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp b) (+.f64 b #s(literal 1 binary64))))) |
(/.f64 #s(approx (exp a) #s(approx (+ 1 a) a)) (+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp b) (+.f64 b #s(literal 1 binary64))))) |
(/.f64 #s(approx (exp a) (+.f64 #s(literal 1 binary64) a)) (+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp b) #s(literal 1 binary64)))) |
(/.f64 #s(approx (exp a) (+.f64 #s(literal 1 binary64) a)) (+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp b) #s(approx (+ b 1) #s(literal 1 binary64))))) |
(/.f64 #s(approx (exp a) (+.f64 #s(literal 1 binary64) a)) (+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp b) #s(approx (+ b 1) b)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) #s(approx (- (exp b) -1) (fma.f64 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b #s(literal 2 binary64))))) |
(/.f64 #s(approx (exp a) #s(literal 1 binary64)) #s(approx (+ (exp a) (exp b)) #s(approx (- (exp a) -1) (fma.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a #s(literal 2 binary64))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (/ 1 (- (exp b) -1)) (fma.f64 (-.f64 (*.f64 (*.f64 b b) #s(literal 1/48 binary64)) #s(literal 1/4 binary64)) b #s(literal 1/2 binary64)))) |
(/.f64 (exp.f64 a) #s(approx (+ (exp a) (exp b)) #s(approx (- (exp b) -1) #s(literal 2 binary64)))) |
(/.f64 #s(approx (exp a) (+.f64 #s(literal 1 binary64) a)) (+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp b) (+.f64 b #s(literal 1 binary64))))) |
| Outputs |
|---|
(/.f64 (exp.f64 a) #s(approx (+ (exp a) (exp b)) #s(approx (- (exp b) -1) #s(literal 2 binary64)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) #s(approx (- (exp b) -1) #s(approx (+ (* (+ (* 1/2 b) 1) b) 2) (*.f64 (*.f64 b b) #s(literal 1/2 binary64)))))) |
5 calls:
| 6.0ms | b |
| 6.0ms | a |
| 4.0ms | (exp.f64 b) |
| 4.0ms | (/.f64 (exp.f64 a) (+.f64 (exp.f64 a) (exp.f64 b))) |
| 4.0ms | (exp.f64 a) |
| Accuracy | Segments | Branch |
|---|---|---|
| 61.6% | 1 | (/.f64 (exp.f64 a) (+.f64 (exp.f64 a) (exp.f64 b))) |
| 64.4% | 2 | (exp.f64 b) |
| 69.6% | 2 | b |
| 68.2% | 2 | (exp.f64 a) |
| 68.2% | 2 | a |
Compiled 13 to 16 computations (-23.1% saved)
| Inputs |
|---|
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (/ 1 (- (exp b) -1)) #s(literal 1/2 binary64))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) #s(approx (- (exp b) -1) #s(approx (+ 2 b) b)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (/ 1 (- (exp b) -1)) (fma.f64 #s(literal -1/4 binary64) b #s(literal 1/2 binary64)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (/ 1 (- (exp b) -1)) (fma.f64 #s(approx (- (* (* b b) 1/48) 1/4) #s(literal -1/4 binary64)) b #s(literal 1/2 binary64)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) #s(approx (- (exp b) -1) (+.f64 #s(literal 2 binary64) b)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (/ 1 (- (exp b) -1)) #s(approx (+ (* (- (* (* b b) 1/48) 1/4) b) 1/2) (*.f64 (*.f64 b b) (*.f64 b #s(literal 1/48 binary64)))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (/ 1 (- (exp b) -1)) #s(approx (+ (* (- (* (* b b) 1/48) 1/4) b) 1/2) (*.f64 (*.f64 (*.f64 b b) b) #s(literal 1/48 binary64))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) #s(approx (- (exp b) -1) #s(approx (+ (* (+ (* 1/2 b) 1) b) 2) (*.f64 (*.f64 b b) #s(literal 1/2 binary64)))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) #s(approx (- (exp b) -1) #s(approx (+ (* (+ (* 1/2 b) 1) b) 2) (fma.f64 (*.f64 b b) #s(literal 1/2 binary64) b))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) #s(approx (- (exp b) -1) (fma.f64 #s(approx (+ (* 1/2 b) 1) (*.f64 #s(literal 1/2 binary64) b)) b #s(literal 2 binary64))))) |
(/.f64 #s(approx (exp a) #s(approx (+ 1 a) #s(literal 1 binary64))) (+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp b) (+.f64 b #s(literal 1 binary64))))) |
(/.f64 #s(approx (exp a) #s(approx (+ 1 a) a)) (+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp b) (+.f64 b #s(literal 1 binary64))))) |
(/.f64 #s(approx (exp a) (+.f64 #s(literal 1 binary64) a)) (+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp b) #s(literal 1 binary64)))) |
(/.f64 #s(approx (exp a) (+.f64 #s(literal 1 binary64) a)) (+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp b) #s(approx (+ b 1) #s(literal 1 binary64))))) |
(/.f64 #s(approx (exp a) (+.f64 #s(literal 1 binary64) a)) (+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp b) #s(approx (+ b 1) b)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) #s(approx (- (exp b) -1) (fma.f64 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b #s(literal 2 binary64))))) |
(/.f64 #s(approx (exp a) #s(literal 1 binary64)) #s(approx (+ (exp a) (exp b)) #s(approx (- (exp a) -1) (fma.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a #s(literal 2 binary64))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (/ 1 (- (exp b) -1)) (fma.f64 (-.f64 (*.f64 (*.f64 b b) #s(literal 1/48 binary64)) #s(literal 1/4 binary64)) b #s(literal 1/2 binary64)))) |
| Outputs |
|---|
(/.f64 #s(approx (exp a) #s(literal 1 binary64)) #s(approx (+ (exp a) (exp b)) #s(approx (- (exp a) -1) (fma.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a #s(literal 2 binary64))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) #s(approx (- (exp b) -1) #s(approx (+ (* (+ (* 1/2 b) 1) b) 2) (*.f64 (*.f64 b b) #s(literal 1/2 binary64)))))) |
5 calls:
| 5.0ms | b |
| 5.0ms | a |
| 4.0ms | (exp.f64 b) |
| 4.0ms | (/.f64 (exp.f64 a) (+.f64 (exp.f64 a) (exp.f64 b))) |
| 4.0ms | (exp.f64 a) |
| Accuracy | Segments | Branch |
|---|---|---|
| 49.6% | 1 | (/.f64 (exp.f64 a) (+.f64 (exp.f64 a) (exp.f64 b))) |
| 57.9% | 2 | (exp.f64 b) |
| 58.4% | 2 | a |
| 56.1% | 2 | (exp.f64 a) |
| 60.3% | 2 | b |
Compiled 13 to 16 computations (-23.1% saved)
| Inputs |
|---|
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (/ 1 (- (exp b) -1)) #s(literal 1/2 binary64))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) #s(approx (- (exp b) -1) #s(approx (+ 2 b) b)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (/ 1 (- (exp b) -1)) (fma.f64 #s(literal -1/4 binary64) b #s(literal 1/2 binary64)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (/ 1 (- (exp b) -1)) (fma.f64 #s(approx (- (* (* b b) 1/48) 1/4) #s(literal -1/4 binary64)) b #s(literal 1/2 binary64)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) #s(approx (- (exp b) -1) (+.f64 #s(literal 2 binary64) b)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (/ 1 (- (exp b) -1)) #s(approx (+ (* (- (* (* b b) 1/48) 1/4) b) 1/2) (*.f64 (*.f64 b b) (*.f64 b #s(literal 1/48 binary64)))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (/ 1 (- (exp b) -1)) #s(approx (+ (* (- (* (* b b) 1/48) 1/4) b) 1/2) (*.f64 (*.f64 (*.f64 b b) b) #s(literal 1/48 binary64))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) #s(approx (- (exp b) -1) #s(approx (+ (* (+ (* 1/2 b) 1) b) 2) (*.f64 (*.f64 b b) #s(literal 1/2 binary64)))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) #s(approx (- (exp b) -1) #s(approx (+ (* (+ (* 1/2 b) 1) b) 2) (fma.f64 (*.f64 b b) #s(literal 1/2 binary64) b))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) #s(approx (- (exp b) -1) (fma.f64 #s(approx (+ (* 1/2 b) 1) (*.f64 #s(literal 1/2 binary64) b)) b #s(literal 2 binary64))))) |
(/.f64 #s(approx (exp a) #s(approx (+ 1 a) #s(literal 1 binary64))) (+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp b) (+.f64 b #s(literal 1 binary64))))) |
(/.f64 #s(approx (exp a) #s(approx (+ 1 a) a)) (+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp b) (+.f64 b #s(literal 1 binary64))))) |
(/.f64 #s(approx (exp a) (+.f64 #s(literal 1 binary64) a)) (+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp b) #s(literal 1 binary64)))) |
(/.f64 #s(approx (exp a) (+.f64 #s(literal 1 binary64) a)) (+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp b) #s(approx (+ b 1) #s(literal 1 binary64))))) |
(/.f64 #s(approx (exp a) (+.f64 #s(literal 1 binary64) a)) (+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp b) #s(approx (+ b 1) b)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) #s(approx (- (exp b) -1) (fma.f64 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b #s(literal 2 binary64))))) |
| Outputs |
|---|
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (/ 1 (- (exp b) -1)) #s(approx (+ (* (- (* (* b b) 1/48) 1/4) b) 1/2) (*.f64 (*.f64 b b) (*.f64 b #s(literal 1/48 binary64)))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) #s(approx (- (exp b) -1) (fma.f64 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b #s(literal 2 binary64))))) |
4 calls:
| 26.0ms | a |
| 5.0ms | b |
| 3.0ms | (exp.f64 b) |
| 3.0ms | (exp.f64 a) |
| Accuracy | Segments | Branch |
|---|---|---|
| 52.0% | 2 | (exp.f64 a) |
| 49.7% | 2 | (exp.f64 b) |
| 52.5% | 2 | a |
| 51.5% | 3 | b |
Compiled 6 to 10 computations (-66.7% saved)
| Inputs |
|---|
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (/ 1 (- (exp b) -1)) #s(literal 1/2 binary64))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) #s(approx (- (exp b) -1) #s(approx (+ 2 b) b)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (/ 1 (- (exp b) -1)) (fma.f64 #s(literal -1/4 binary64) b #s(literal 1/2 binary64)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (/ 1 (- (exp b) -1)) (fma.f64 #s(approx (- (* (* b b) 1/48) 1/4) #s(literal -1/4 binary64)) b #s(literal 1/2 binary64)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) #s(approx (- (exp b) -1) (+.f64 #s(literal 2 binary64) b)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (/ 1 (- (exp b) -1)) #s(approx (+ (* (- (* (* b b) 1/48) 1/4) b) 1/2) (*.f64 (*.f64 b b) (*.f64 b #s(literal 1/48 binary64)))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (/ 1 (- (exp b) -1)) #s(approx (+ (* (- (* (* b b) 1/48) 1/4) b) 1/2) (*.f64 (*.f64 (*.f64 b b) b) #s(literal 1/48 binary64))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) #s(approx (- (exp b) -1) #s(approx (+ (* (+ (* 1/2 b) 1) b) 2) (*.f64 (*.f64 b b) #s(literal 1/2 binary64)))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) #s(approx (- (exp b) -1) #s(approx (+ (* (+ (* 1/2 b) 1) b) 2) (fma.f64 (*.f64 b b) #s(literal 1/2 binary64) b))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) #s(approx (- (exp b) -1) (fma.f64 #s(approx (+ (* 1/2 b) 1) (*.f64 #s(literal 1/2 binary64) b)) b #s(literal 2 binary64))))) |
(/.f64 #s(approx (exp a) #s(approx (+ 1 a) #s(literal 1 binary64))) (+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp b) (+.f64 b #s(literal 1 binary64))))) |
(/.f64 #s(approx (exp a) #s(approx (+ 1 a) a)) (+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp b) (+.f64 b #s(literal 1 binary64))))) |
(/.f64 #s(approx (exp a) (+.f64 #s(literal 1 binary64) a)) (+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp b) #s(literal 1 binary64)))) |
(/.f64 #s(approx (exp a) (+.f64 #s(literal 1 binary64) a)) (+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp b) #s(approx (+ b 1) #s(literal 1 binary64))))) |
(/.f64 #s(approx (exp a) (+.f64 #s(literal 1 binary64) a)) (+.f64 #s(approx (exp a) (-.f64 a #s(literal -1 binary64))) #s(approx (exp b) #s(approx (+ b 1) b)))) |
| Outputs |
|---|
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (/ 1 (- (exp b) -1)) #s(approx (+ (* (- (* (* b b) 1/48) 1/4) b) 1/2) (*.f64 (*.f64 b b) (*.f64 b #s(literal 1/48 binary64)))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) #s(approx (- (exp b) -1) (fma.f64 #s(approx (+ (* 1/2 b) 1) (*.f64 #s(literal 1/2 binary64) b)) b #s(literal 2 binary64))))) |
2 calls:
| 4.0ms | a |
| 3.0ms | (exp.f64 a) |
| Accuracy | Segments | Branch |
|---|---|---|
| 51.1% | 2 | (exp.f64 a) |
| 51.6% | 2 | a |
Compiled 3 to 5 computations (-66.7% saved)
| Inputs |
|---|
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (/ 1 (- (exp b) -1)) #s(literal 1/2 binary64))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) #s(approx (- (exp b) -1) #s(approx (+ 2 b) b)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (/ 1 (- (exp b) -1)) (fma.f64 #s(literal -1/4 binary64) b #s(literal 1/2 binary64)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (/ 1 (- (exp b) -1)) (fma.f64 #s(approx (- (* (* b b) 1/48) 1/4) #s(literal -1/4 binary64)) b #s(literal 1/2 binary64)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) #s(approx (- (exp b) -1) (+.f64 #s(literal 2 binary64) b)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (/ 1 (- (exp b) -1)) #s(approx (+ (* (- (* (* b b) 1/48) 1/4) b) 1/2) (*.f64 (*.f64 b b) (*.f64 b #s(literal 1/48 binary64)))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (/ 1 (- (exp b) -1)) #s(approx (+ (* (- (* (* b b) 1/48) 1/4) b) 1/2) (*.f64 (*.f64 (*.f64 b b) b) #s(literal 1/48 binary64))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) #s(approx (- (exp b) -1) #s(approx (+ (* (+ (* 1/2 b) 1) b) 2) (*.f64 (*.f64 b b) #s(literal 1/2 binary64)))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) #s(approx (- (exp b) -1) #s(approx (+ (* (+ (* 1/2 b) 1) b) 2) (fma.f64 (*.f64 b b) #s(literal 1/2 binary64) b))))) |
| Outputs |
|---|
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (/ 1 (- (exp b) -1)) #s(literal 1/2 binary64))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) #s(approx (- (exp b) -1) #s(approx (+ (* (+ (* 1/2 b) 1) b) 2) (fma.f64 (*.f64 b b) #s(literal 1/2 binary64) b))))) |
5 calls:
| 6.0ms | (exp.f64 a) |
| 3.0ms | b |
| 3.0ms | a |
| 2.0ms | (/.f64 (exp.f64 a) (+.f64 (exp.f64 a) (exp.f64 b))) |
| 2.0ms | (exp.f64 b) |
| Accuracy | Segments | Branch |
|---|---|---|
| 48.6% | 2 | (exp.f64 b) |
| 48.6% | 2 | b |
| 45.7% | 2 | (exp.f64 a) |
| 48.5% | 2 | (/.f64 (exp.f64 a) (+.f64 (exp.f64 a) (exp.f64 b))) |
| 45.7% | 2 | a |
Compiled 13 to 16 computations (-23.1% saved)
| Inputs |
|---|
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (/ 1 (- (exp b) -1)) #s(literal 1/2 binary64))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) #s(approx (- (exp b) -1) #s(approx (+ 2 b) b)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (/ 1 (- (exp b) -1)) (fma.f64 #s(literal -1/4 binary64) b #s(literal 1/2 binary64)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (/ 1 (- (exp b) -1)) (fma.f64 #s(approx (- (* (* b b) 1/48) 1/4) #s(literal -1/4 binary64)) b #s(literal 1/2 binary64)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) #s(approx (- (exp b) -1) (+.f64 #s(literal 2 binary64) b)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (/ 1 (- (exp b) -1)) #s(approx (+ (* (- (* (* b b) 1/48) 1/4) b) 1/2) (*.f64 (*.f64 b b) (*.f64 b #s(literal 1/48 binary64)))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (/ 1 (- (exp b) -1)) #s(approx (+ (* (- (* (* b b) 1/48) 1/4) b) 1/2) (*.f64 (*.f64 (*.f64 b b) b) #s(literal 1/48 binary64))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) #s(approx (- (exp b) -1) #s(approx (+ (* (+ (* 1/2 b) 1) b) 2) (*.f64 (*.f64 b b) #s(literal 1/2 binary64)))))) |
| Outputs |
|---|
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (/ 1 (- (exp b) -1)) #s(literal 1/2 binary64))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) #s(approx (- (exp b) -1) #s(approx (+ (* (+ (* 1/2 b) 1) b) 2) (*.f64 (*.f64 b b) #s(literal 1/2 binary64)))))) |
2 calls:
| 3.0ms | b |
| 2.0ms | (exp.f64 b) |
| Accuracy | Segments | Branch |
|---|---|---|
| 48.6% | 2 | (exp.f64 b) |
| 48.6% | 2 | b |
Compiled 3 to 5 computations (-66.7% saved)
| Inputs |
|---|
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (/ 1 (- (exp b) -1)) #s(literal 1/2 binary64))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) #s(approx (- (exp b) -1) #s(approx (+ 2 b) b)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (/ 1 (- (exp b) -1)) (fma.f64 #s(literal -1/4 binary64) b #s(literal 1/2 binary64)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (/ 1 (- (exp b) -1)) (fma.f64 #s(approx (- (* (* b b) 1/48) 1/4) #s(literal -1/4 binary64)) b #s(literal 1/2 binary64)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) #s(approx (- (exp b) -1) (+.f64 #s(literal 2 binary64) b)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (/ 1 (- (exp b) -1)) #s(approx (+ (* (- (* (* b b) 1/48) 1/4) b) 1/2) (*.f64 (*.f64 b b) (*.f64 b #s(literal 1/48 binary64)))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (/ 1 (- (exp b) -1)) #s(approx (+ (* (- (* (* b b) 1/48) 1/4) b) 1/2) (*.f64 (*.f64 (*.f64 b b) b) #s(literal 1/48 binary64))))) |
| Outputs |
|---|
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (/ 1 (- (exp b) -1)) #s(approx (+ (* (- (* (* b b) 1/48) 1/4) b) 1/2) (*.f64 (*.f64 b b) (*.f64 b #s(literal 1/48 binary64)))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (/ 1 (- (exp b) -1)) #s(literal 1/2 binary64))) |
4 calls:
| 4.0ms | (/.f64 (exp.f64 a) (+.f64 (exp.f64 a) (exp.f64 b))) |
| 2.0ms | a |
| 2.0ms | b |
| 2.0ms | (exp.f64 b) |
| Accuracy | Segments | Branch |
|---|---|---|
| 45.7% | 2 | a |
| 45.4% | 2 | (/.f64 (exp.f64 a) (+.f64 (exp.f64 a) (exp.f64 b))) |
| 35.3% | 1 | (exp.f64 b) |
| 35.3% | 1 | b |
Compiled 11 to 13 computations (-18.2% saved)
Total -21.0b remaining (-50.8%)
Threshold costs -21b (-50.8%)
| Inputs |
|---|
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (/ 1 (- (exp b) -1)) #s(literal 1/2 binary64))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) #s(approx (- (exp b) -1) #s(approx (+ 2 b) b)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (/ 1 (- (exp b) -1)) (fma.f64 #s(literal -1/4 binary64) b #s(literal 1/2 binary64)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (/ 1 (- (exp b) -1)) (fma.f64 #s(approx (- (* (* b b) 1/48) 1/4) #s(literal -1/4 binary64)) b #s(literal 1/2 binary64)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) #s(approx (- (exp b) -1) (+.f64 #s(literal 2 binary64) b)))) |
| Outputs |
|---|
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (/ 1 (- (exp b) -1)) #s(literal 1/2 binary64))) |
3 calls:
| 2.0ms | a |
| 1.0ms | (/.f64 (exp.f64 a) (+.f64 (exp.f64 a) (exp.f64 b))) |
| 1.0ms | (exp.f64 a) |
| Accuracy | Segments | Branch |
|---|---|---|
| 35.3% | 1 | (/.f64 (exp.f64 a) (+.f64 (exp.f64 a) (exp.f64 b))) |
| 35.3% | 1 | (exp.f64 a) |
| 35.3% | 1 | a |
Compiled 10 to 11 computations (-10% saved)
| 1× | binary-search |
| 1× | narrow-enough |
| Time | Left | Right |
|---|---|---|
| 9.0ms | -6.138124158853595 | -0.219304830864386 |
| 5.0ms | 112× | 0 | valid |
Compiled 179 to 179 computations (0% saved)
ival-exp: 2.0ms (75.2% of total)adjust: 0.0ms (0% of total)ival-add!: 0.0ms (0% of total)ival-div!: 0.0ms (0% of total)| 1× | binary-search |
| 1× | narrow-enough |
| Time | Left | Right |
|---|---|---|
| 7.0ms | -6.138124158853595 | -0.219304830864386 |
| 3.0ms | 80× | 0 | valid |
Compiled 193 to 193 computations (0% saved)
ival-exp: 1.0ms (52.5% of total)adjust: 0.0ms (0% of total)ival-add!: 0.0ms (0% of total)ival-div!: 0.0ms (0% of total)| 1× | binary-search |
| 1× | narrow-enough |
| Time | Left | Right |
|---|---|---|
| 1.0ms | -6.138124158853595 | -0.219304830864386 |
Compiled 193 to 193 computations (0% saved)
| 1× | binary-search |
| 1× | narrow-enough |
| Time | Left | Right |
|---|---|---|
| 8.0ms | 2.7359658440197067e+150 | 1.548083896163419e+152 |
| 4.0ms | 112× | 0 | valid |
Compiled 277 to 270 computations (2.5% saved)
ival-exp: 2.0ms (88.4% of total)adjust: 0.0ms (0% of total)ival-add!: 0.0ms (0% of total)ival-div!: 0.0ms (0% of total)| 1× | binary-search |
| 1× | narrow-enough |
| Time | Left | Right |
|---|---|---|
| 86.0ms | 2.9790935257618324e+125 | 8.488523321417688e+126 |
| 4.0ms | 112× | 0 | valid |
Compiled 312 to 298 computations (4.5% saved)
ival-exp: 2.0ms (88.6% of total)adjust: 0.0ms (0% of total)ival-add!: 0.0ms (0% of total)ival-div!: 0.0ms (0% of total)| 1× | binary-search |
| 1× | narrow-enough |
| Time | Left | Right |
|---|---|---|
| 8.0ms | -2.7435052493631024e+93 | -1.2108383810122398e+93 |
| 3.0ms | 80× | 0 | valid |
| 1.0ms | 21× | 0 | exit |
Compiled 236 to 226 computations (4.2% saved)
ival-exp: 1.0ms (48.2% of total)adjust: 0.0ms (0% of total)ival-add!: 0.0ms (0% of total)ival-div!: 0.0ms (0% of total)| 1× | binary-search |
| 1× | narrow-enough |
| Time | Left | Right |
|---|---|---|
| 1.0ms | -2.7435052493631024e+93 | -1.2108383810122398e+93 |
Compiled 261 to 251 computations (3.8% saved)
| 1× | binary-search |
| 1× | narrow-enough |
| Time | Left | Right |
|---|---|---|
| 11.0ms | 3.412552514700398e-6 | 26.840837930361044 |
| 6.0ms | 144× | 0 | valid |
Compiled 371 to 353 computations (4.9% saved)
ival-exp: 2.0ms (59.3% of total)ival-div!: 1.0ms (29.7% of total)adjust: 0.0ms (0% of total)ival-add!: 0.0ms (0% of total)| 1× | binary-search |
| 1× | narrow-enough |
| Time | Left | Right |
|---|---|---|
| 7.0ms | 3.412552514700398e-6 | 26.840837930361044 |
| 3.0ms | 80× | 0 | valid |
Compiled 371 to 353 computations (4.9% saved)
ival-exp: 1.0ms (52.3% of total)adjust: 0.0ms (0% of total)ival-add!: 0.0ms (0% of total)ival-div!: 0.0ms (0% of total)| 1× | binary-search |
| 1× | narrow-enough |
| Time | Left | Right |
|---|---|---|
| 25.0ms | -4.980051206030211e+24 | -13134218880235382.0 |
| 6.0ms | 144× | 0 | valid |
| 1.0ms | 30× | 0 | exit |
Compiled 389 to 371 computations (4.6% saved)
ival-exp: 2.0ms (53.5% of total)ival-div!: 1.0ms (26.7% of total)adjust: 0.0ms (0% of total)ival-add!: 0.0ms (0% of total)| 1× | fuel |
Compiled 148 to 111 computations (25% saved)
Compiled 163 to 124 computations (23.9% saved)
Loading profile data...