
Time bar (total: 3.8s)
| 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)
| 508.0ms | 8 256× | 0 | valid |
| 269.0ms | 2 893× | 0 | exit |
ival-exp: 276.0ms (68.2% of total)ival-div: 70.0ms (17.3% of total)ival-add: 53.0ms (13.1% of total)ival-assert: 4.0ms (1% of total)adjust: 3.0ms (0.7% of total)| Ground Truth | Overpredictions | Example | Underpredictions | Example | Subexpression |
|---|---|---|---|---|---|
| 1 | 0 | - | 0 | - | (/.f64 (exp.f64 a) (+.f64 (exp.f64 a) (exp.f64 b))) |
| 0 | 0 | - | 0 | - | (+.f64 (exp.f64 a) (exp.f64 b)) |
| 0 | 0 | - | 0 | - | a |
| 0 | 0 | - | 0 | - | (exp.f64 b) |
| 0 | 0 | - | 0 | - | b |
| 0 | 0 | - | 0 | - | (exp.f64 a) |
| Operator | Subexpression | Explanation | Count | |
|---|---|---|---|---|
/.f64 | (/.f64 (exp.f64 a) (+.f64 (exp.f64 a) (exp.f64 b))) | o/o | 1 | 0 |
| ↳ | (exp.f64 a) | overflow | 1 | |
| ↳ | (+.f64 (exp.f64 a) (exp.f64 b)) | overflow | 71 | |
| ↳ | (exp.f64 a) | overflow | 1 | |
| ↳ | (exp.f64 b) | overflow | 70 |
| Predicted + | Predicted - | |
|---|---|---|
| + | 1 | 0 |
| - | 0 | 255 |
| Predicted + | Predicted Maybe | Predicted - | |
|---|---|---|---|
| + | 1 | 0 | 0 |
| - | 0 | 0 | 255 |
| number | freq |
|---|---|
| 0 | 255 |
| 1 | 1 |
| Predicted + | Predicted Maybe | Predicted - | |
|---|---|---|---|
| + | 1 | 0 | 0 |
| - | 0 | 0 | 0 |
| 38.0ms | 512× | 0 | valid |
Compiled 50 to 22 computations (56% saved)
ival-exp: 9.0ms (58.8% of total)ival-div: 3.0ms (19.6% of total)ival-add: 2.0ms (13.1% of total)ival-true: 0.0ms (0% of total)adjust: 0.0ms (0% of total)ival-assert: 0.0ms (0% of total)Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 18 | 56 |
| 1 | 46 | 56 |
| 2 | 147 | 56 |
| 3 | 563 | 51 |
| 4 | 3260 | 51 |
| 0 | 6 | 8 |
| 0 | 10 | 8 |
| 1 | 17 | 8 |
| 2 | 43 | 8 |
| 3 | 119 | 8 |
| 4 | 582 | 8 |
| 5 | 5983 | 8 |
| 0 | 8050 | 8 |
| 1× | iter limit |
| 1× | node limit |
| 1× | iter limit |
| 1× | node limit |
| Inputs |
|---|
(/.f64 (exp.f64 a) (+.f64 (exp.f64 a) (exp.f64 b))) |
| Outputs |
|---|
(/.f64 (exp.f64 a) (+.f64 (exp.f64 a) (exp.f64 b))) |
(/.f64 (exp.f64 a) (+.f64 (exp.f64 b) (exp.f64 a))) |
Compiled 8 to 6 computations (25% saved)
Compiled 0 to 2 computations (-∞% saved)
| Status | Accuracy | Program |
|---|---|---|
| ▶ | 99.6% | (/.f64 (exp.f64 a) (+.f64 (exp.f64 a) (exp.f64 b))) |
Compiled 8 to 6 computations (25% 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))))) |
(exp.f64 a) |
(+.f64 (cosh.f64 a) (sinh.f64 a)) |
a |
(/.f64 (-.f64 (pow.f64 (exp.f64 b) #s(literal 2 binary64)) (pow.f64 (exp.f64 a) #s(literal 2 binary64))) (-.f64 (exp.f64 b) (exp.f64 a))) |
(/.f64 (+.f64 (pow.f64 (exp.f64 b) #s(literal 3 binary64)) (pow.f64 (exp.f64 a) #s(literal 3 binary64))) (fma.f64 (exp.f64 b) (exp.f64 b) (-.f64 (pow.f64 (exp.f64 a) #s(literal 2 binary64)) (*.f64 (exp.f64 b) (exp.f64 a))))) |
(/.f64 (neg.f64 (-.f64 (pow.f64 (exp.f64 a) #s(literal 2 binary64)) (pow.f64 (exp.f64 b) #s(literal 2 binary64)))) (neg.f64 (-.f64 (exp.f64 a) (exp.f64 b)))) |
(/.f64 (neg.f64 (+.f64 (pow.f64 (exp.f64 a) #s(literal 3 binary64)) (pow.f64 (exp.f64 b) #s(literal 3 binary64)))) (neg.f64 (fma.f64 (exp.f64 a) (exp.f64 a) (-.f64 (pow.f64 (exp.f64 b) #s(literal 2 binary64)) (exp.f64 (+.f64 a b)))))) |
(/.f64 (-.f64 (pow.f64 (exp.f64 a) #s(literal 2 binary64)) (pow.f64 (exp.f64 b) #s(literal 2 binary64))) (-.f64 (exp.f64 a) (exp.f64 b))) |
(/.f64 (+.f64 (pow.f64 (exp.f64 a) #s(literal 3 binary64)) (pow.f64 (exp.f64 b) #s(literal 3 binary64))) (fma.f64 (exp.f64 a) (exp.f64 a) (-.f64 (pow.f64 (exp.f64 b) #s(literal 2 binary64)) (exp.f64 (+.f64 a b))))) |
(-.f64 (/.f64 (pow.f64 (exp.f64 a) #s(literal 2 binary64)) (-.f64 (exp.f64 a) (exp.f64 b))) (/.f64 (pow.f64 (exp.f64 b) #s(literal 2 binary64)) (-.f64 (exp.f64 a) (exp.f64 b)))) |
(+.f64 (/.f64 (pow.f64 (exp.f64 a) #s(literal 3 binary64)) (fma.f64 (exp.f64 a) (exp.f64 a) (-.f64 (pow.f64 (exp.f64 b) #s(literal 2 binary64)) (exp.f64 (+.f64 a b))))) (/.f64 (pow.f64 (exp.f64 b) #s(literal 3 binary64)) (fma.f64 (exp.f64 a) (exp.f64 a) (-.f64 (pow.f64 (exp.f64 b) #s(literal 2 binary64)) (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))))) |
(exp.f64 b) |
(+.f64 (cosh.f64 b) (sinh.f64 b)) |
b |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (pow.f64 (-.f64 (exp.f64 b) #s(literal -1 binary64)) #s(literal -1 binary64))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (fma.f64 (-.f64 (pow.f64 (-.f64 (exp.f64 b) #s(literal -1 binary64)) #s(literal -1 binary64)) (pow.f64 (-.f64 (exp.f64 b) #s(literal -1 binary64)) #s(literal -2 binary64))) a (pow.f64 (-.f64 (exp.f64 b) #s(literal -1 binary64)) #s(literal -1 binary64)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (fma.f64 (-.f64 (fma.f64 (-.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 #s(literal 3/2 binary64) (pow.f64 (-.f64 (exp.f64 b) #s(literal -1 binary64)) #s(literal -2 binary64)))) a (pow.f64 (-.f64 (exp.f64 b) #s(literal -1 binary64)) #s(literal -1 binary64))) (pow.f64 (-.f64 (exp.f64 b) #s(literal -1 binary64)) #s(literal -2 binary64))) a (pow.f64 (-.f64 (exp.f64 b) #s(literal -1 binary64)) #s(literal -1 binary64)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (fma.f64 (-.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) (pow.f64 (-.f64 (exp.f64 b) #s(literal -1 binary64)) #s(literal 2 binary64))) (fma.f64 (/.f64 (-.f64 (pow.f64 (-.f64 (exp.f64 b) #s(literal -1 binary64)) #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))) #s(literal 1/2 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 #s(literal 3/2 binary64) (pow.f64 (-.f64 (exp.f64 b) #s(literal -1 binary64)) #s(literal -2 binary64)))) a (pow.f64 (-.f64 (exp.f64 b) #s(literal -1 binary64)) #s(literal -1 binary64))) (pow.f64 (-.f64 (exp.f64 b) #s(literal -1 binary64)) #s(literal -2 binary64))) a (pow.f64 (-.f64 (exp.f64 b) #s(literal -1 binary64)) #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 (log1p.f64 (exp.f64 a)) #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 (log1p.f64 (exp.f64 a)) #s(literal 2 binary64)))) #s(literal 1/2 binary64) (neg.f64 (exp.f64 (-.f64 a (*.f64 (log1p.f64 (exp.f64 a)) #s(literal 3 binary64))))))) (exp.f64 (-.f64 a (*.f64 (log1p.f64 (exp.f64 a)) #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) (fma.f64 (/.f64 (fma.f64 (exp.f64 (-.f64 a (*.f64 (log1p.f64 (exp.f64 a)) #s(literal 2 binary64)))) #s(literal 1/2 binary64) (neg.f64 (exp.f64 (-.f64 a (*.f64 (log1p.f64 (exp.f64 a)) #s(literal 3 binary64)))))) (-.f64 (exp.f64 a) #s(literal -1 binary64))) #s(literal -1 binary64) (fma.f64 #s(literal -1/2 binary64) (exp.f64 (-.f64 a (*.f64 (log1p.f64 (exp.f64 a)) #s(literal 3 binary64)))) (*.f64 (exp.f64 (-.f64 a (*.f64 (log1p.f64 (exp.f64 a)) #s(literal 2 binary64)))) #s(literal 1/6 binary64))))) (fma.f64 (exp.f64 (-.f64 a (*.f64 (log1p.f64 (exp.f64 a)) #s(literal 2 binary64)))) #s(literal 1/2 binary64) (neg.f64 (exp.f64 (-.f64 a (*.f64 (log1p.f64 (exp.f64 a)) #s(literal 3 binary64))))))) b) (exp.f64 (-.f64 a (*.f64 (log1p.f64 (exp.f64 a)) #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 1 313 to 267 computations (79.7% saved)
3 alts after pruning (3 fresh and 0 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 62 | 3 | 65 |
| Fresh | 0 | 0 | 0 |
| Picked | 1 | 0 | 1 |
| Done | 0 | 0 | 0 |
| Total | 63 | 3 | 66 |
| Status | Accuracy | Program |
|---|---|---|
| ▶ | 66.5% | (/.f64 (exp.f64 a) (+.f64 (exp.f64 a) #s(approx (exp b) #s(literal 1 binary64)))) |
| ▶ | 64.3% | #s(approx (/ (exp a) (+ (exp a) (exp b))) (fma.f64 (neg.f64 b) (exp.f64 (-.f64 a (*.f64 (log1p.f64 (exp.f64 a)) #s(literal 2 binary64)))) (/.f64 (exp.f64 a) (-.f64 (exp.f64 a) #s(literal -1 binary64))))) |
| ▶ | 81.5% | #s(approx (/ (exp a) (+ (exp a) (exp b))) (pow.f64 (-.f64 (exp.f64 b) #s(literal -1 binary64)) #s(literal -1 binary64))) |
Compiled 52 to 37 computations (28.8% saved)
| Inputs |
|---|
#s(approx (/ (exp a) (+ (exp a) (exp b))) (pow.f64 (-.f64 (exp.f64 b) #s(literal -1 binary64)) #s(literal -1 binary64))) |
(pow.f64 (-.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) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (fma.f64 (neg.f64 b) (exp.f64 (-.f64 a (*.f64 (log1p.f64 (exp.f64 a)) #s(literal 2 binary64)))) (/.f64 (exp.f64 a) (-.f64 (exp.f64 a) #s(literal -1 binary64))))) |
(fma.f64 (neg.f64 b) (exp.f64 (-.f64 a (*.f64 (log1p.f64 (exp.f64 a)) #s(literal 2 binary64)))) (/.f64 (exp.f64 a) (-.f64 (exp.f64 a) #s(literal -1 binary64)))) |
(neg.f64 b) |
(exp.f64 (-.f64 a (*.f64 (log1p.f64 (exp.f64 a)) #s(literal 2 binary64)))) |
(-.f64 a (*.f64 (log1p.f64 (exp.f64 a)) #s(literal 2 binary64))) |
a |
(*.f64 (log1p.f64 (exp.f64 a)) #s(literal 2 binary64)) |
(log1p.f64 (exp.f64 a)) |
(exp.f64 a) |
#s(literal 2 binary64) |
(/.f64 (exp.f64 a) (-.f64 (exp.f64 a) #s(literal -1 binary64))) |
(-.f64 (exp.f64 a) #s(literal -1 binary64)) |
(/.f64 (exp.f64 a) (+.f64 (exp.f64 a) #s(approx (exp b) #s(literal 1 binary64)))) |
(+.f64 (exp.f64 a) #s(approx (exp b) #s(literal 1 binary64))) |
#s(approx (exp b) #s(literal 1 binary64)) |
#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 (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(hole binary64 (+ 1/2 (* -1 (* b (exp (neg (* 2 (log 2))))))))) |
#s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(hole binary64 (+ 1/2 (+ (* -1 (* b (exp (neg (* 2 (log 2)))))) (* 1/4 a))))) |
#s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(hole binary64 (+ 1/2 (+ (* -1 (* b (exp (neg (* 2 (log 2)))))) (* a (+ 1/4 (* 1/4 (* a (* b (exp (neg (* 2 (log 2))))))))))))) |
#s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(hole binary64 (+ 1/2 (+ (* -1 (* b (exp (neg (* 2 (log 2)))))) (* a (+ 1/4 (* a (+ (* -1/48 a) (* 1/4 (* b (exp (neg (* 2 (log 2)))))))))))))) |
#s(approx (exp (- a (* (log (+ 1 (exp a))) 2))) #s(hole binary64 (exp (neg (* 2 (log 2)))))) |
#s(approx (exp (- a (* (log (+ 1 (exp a))) 2))) #s(hole binary64 (+ (exp (neg (* 2 (log 2)))) (* -1/4 (* (pow a 2) (exp (neg (* 2 (log 2))))))))) |
#s(approx (exp (- a (* (log (+ 1 (exp a))) 2))) #s(hole binary64 (+ (exp (neg (* 2 (log 2)))) (* (pow a 2) (+ (* -1/4 (exp (neg (* 2 (log 2))))) (* 1/24 (* (pow a 2) (exp (neg (* 2 (log 2))))))))))) |
#s(approx (exp (- a (* (log (+ 1 (exp a))) 2))) #s(hole binary64 (+ (exp (neg (* 2 (log 2)))) (* (pow a 2) (+ (* -1/4 (exp (neg (* 2 (log 2))))) (* (pow a 2) (+ (* -17/2880 (* (pow a 2) (exp (neg (* 2 (log 2)))))) (* 1/24 (exp (neg (* 2 (log 2)))))))))))) |
#s(approx (- a (* (log (+ 1 (exp a))) 2)) #s(hole binary64 (* -2 (log 2)))) |
#s(approx (- a (* (log (+ 1 (exp a))) 2)) #s(hole binary64 (- (* -1/4 (pow a 2)) (* 2 (log 2))))) |
#s(approx (- a (* (log (+ 1 (exp a))) 2)) #s(hole binary64 (- (* (pow a 2) (- (* 1/96 (pow a 2)) 1/4)) (* 2 (log 2))))) |
#s(approx (- a (* (log (+ 1 (exp a))) 2)) #s(hole binary64 (- (* (pow a 2) (- (* (pow a 2) (+ 1/96 (* -1/1440 (pow a 2)))) 1/4)) (* 2 (log 2))))) |
#s(approx a #s(hole binary64 a)) |
#s(approx (* (log (+ 1 (exp a))) 2) #s(hole binary64 (* 2 (log 2)))) |
#s(approx (* (log (+ 1 (exp a))) 2) #s(hole binary64 (+ a (* 2 (log 2))))) |
#s(approx (* (log (+ 1 (exp a))) 2) #s(hole binary64 (+ (* 2 (log 2)) (* a (+ 1 (* 1/4 a)))))) |
#s(approx (* (log (+ 1 (exp a))) 2) #s(hole binary64 (+ (* 2 (log 2)) (* a (+ 1 (* a (+ 1/4 (* -1/96 (pow a 2))))))))) |
#s(approx (log (+ 1 (exp a))) #s(hole binary64 (log 2))) |
#s(approx (log (+ 1 (exp a))) #s(hole binary64 (+ (log 2) (* 1/2 a)))) |
#s(approx (log (+ 1 (exp a))) #s(hole binary64 (+ (log 2) (* a (+ 1/2 (* 1/8 a)))))) |
#s(approx (log (+ 1 (exp a))) #s(hole binary64 (+ (log 2) (* a (+ 1/2 (* a (+ 1/8 (* -1/192 (pow a 2))))))))) |
#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 (/ (exp a) (- (exp a) -1)) #s(hole binary64 1/2)) |
#s(approx (/ (exp a) (- (exp a) -1)) #s(hole binary64 (+ 1/2 (* 1/4 a)))) |
#s(approx (/ (exp a) (- (exp a) -1)) #s(hole binary64 (+ 1/2 (* a (+ 1/4 (* -1/48 (pow a 2))))))) |
#s(approx (/ (exp a) (- (exp a) -1)) #s(hole binary64 (+ 1/2 (* a (+ 1/4 (* (pow a 2) (- (* 1/480 (pow a 2)) 1/48))))))) |
#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 (+ (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 (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(hole binary64 (+ (* -1 (* b (exp (- a (* 2 (log (+ 1 (exp a)))))))) (/ (exp a) (+ 1 (exp a)))))) |
#s(approx (exp (- a (* (log (+ 1 (exp a))) 2))) #s(hole binary64 (exp (- a (* 2 (log (+ 1 (exp a)))))))) |
#s(approx (- a (* (log (+ 1 (exp a))) 2)) #s(hole binary64 a)) |
#s(approx (- a (* (log (+ 1 (exp a))) 2)) #s(hole binary64 (* a (+ 1 (* -2 (/ (log (+ 1 (exp a))) a)))))) |
#s(approx (* (log (+ 1 (exp a))) 2) #s(hole binary64 (* 2 (log (+ 1 (exp a)))))) |
#s(approx (log (+ 1 (exp a))) #s(hole binary64 (log (+ 1 (exp a))))) |
#s(approx (exp a) #s(hole binary64 (exp a))) |
#s(approx (/ (exp a) (- (exp a) -1)) #s(hole binary64 (/ (exp a) (+ 1 (exp a))))) |
#s(approx (- (exp a) -1) #s(hole binary64 (+ 1 (exp a)))) |
#s(approx (+ (exp a) (exp b)) #s(hole binary64 (+ (exp a) (exp b)))) |
#s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(hole binary64 (+ (* -1 (* b (exp (neg (+ (* -1 a) (* 2 (log (+ 1 (exp a))))))))) (/ (exp a) (+ 1 (exp a)))))) |
#s(approx (exp (- a (* (log (+ 1 (exp a))) 2))) #s(hole binary64 (exp (neg (+ (* -1 a) (* 2 (log (+ 1 (exp a))))))))) |
#s(approx (- a (* (log (+ 1 (exp a))) 2)) #s(hole binary64 (* -1 (* a (- (* 2 (/ (log (+ 1 (exp a))) a)) 1))))) |
#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 (pow (- (exp b) -1) -1) #s(hole binary64 1/2)) |
#s(approx (pow (- (exp b) -1) -1) #s(hole binary64 (+ 1/2 (* -1/4 b)))) |
#s(approx (pow (- (exp b) -1) -1) #s(hole binary64 (+ 1/2 (* b (- (* 1/48 (pow b 2)) 1/4))))) |
#s(approx (pow (- (exp b) -1) -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 (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(hole binary64 (/ (exp a) (+ 1 (exp a))))) |
#s(approx (neg b) #s(hole binary64 (* -1 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 (pow (- (exp b) -1) -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))) |
#s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(hole binary64 (* -1 (* b (exp (- a (* 2 (log (+ 1 (exp a)))))))))) |
#s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(hole binary64 (* b (+ (* -1 (exp (- a (* 2 (log (+ 1 (exp a))))))) (/ (exp a) (* b (+ 1 (exp a)))))))) |
#s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(hole binary64 (* -1 (* b (+ (exp (- a (* 2 (log (+ 1 (exp a)))))) (* -1 (/ (exp a) (* b (+ 1 (exp a)))))))))) |
6 calls:
| Time | Variable | Point | Expression | |
|---|---|---|---|---|
| 32.0ms | a | @ | inf | ((/ (exp a) (+ (exp a) (exp b))) (pow (- (exp b) -1) -1) (- (exp b) -1) (exp b) b -1 (/ (exp a) (+ (exp a) (exp b))) (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) (neg b) (exp (- a (* (log (+ 1 (exp a))) 2))) (- a (* (log (+ 1 (exp a))) 2)) a (* (log (+ 1 (exp a))) 2) (log (+ 1 (exp a))) (exp a) 2 (/ (exp a) (- (exp a) -1)) (- (exp a) -1) (/ (exp a) (+ (exp a) (exp b))) (+ (exp a) (exp b)) (exp b) 1) |
| 27.0ms | a | @ | -inf | ((/ (exp a) (+ (exp a) (exp b))) (pow (- (exp b) -1) -1) (- (exp b) -1) (exp b) b -1 (/ (exp a) (+ (exp a) (exp b))) (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) (neg b) (exp (- a (* (log (+ 1 (exp a))) 2))) (- a (* (log (+ 1 (exp a))) 2)) a (* (log (+ 1 (exp a))) 2) (log (+ 1 (exp a))) (exp a) 2 (/ (exp a) (- (exp a) -1)) (- (exp a) -1) (/ (exp a) (+ (exp a) (exp b))) (+ (exp a) (exp b)) (exp b) 1) |
| 17.0ms | b | @ | 0 | ((/ (exp a) (+ (exp a) (exp b))) (pow (- (exp b) -1) -1) (- (exp b) -1) (exp b) b -1 (/ (exp a) (+ (exp a) (exp b))) (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) (neg b) (exp (- a (* (log (+ 1 (exp a))) 2))) (- a (* (log (+ 1 (exp a))) 2)) a (* (log (+ 1 (exp a))) 2) (log (+ 1 (exp a))) (exp a) 2 (/ (exp a) (- (exp a) -1)) (- (exp a) -1) (/ (exp a) (+ (exp a) (exp b))) (+ (exp a) (exp b)) (exp b) 1) |
| 3.0ms | a | @ | 0 | ((/ (exp a) (+ (exp a) (exp b))) (pow (- (exp b) -1) -1) (- (exp b) -1) (exp b) b -1 (/ (exp a) (+ (exp a) (exp b))) (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) (neg b) (exp (- a (* (log (+ 1 (exp a))) 2))) (- a (* (log (+ 1 (exp a))) 2)) a (* (log (+ 1 (exp a))) 2) (log (+ 1 (exp a))) (exp a) 2 (/ (exp a) (- (exp a) -1)) (- (exp a) -1) (/ (exp a) (+ (exp a) (exp b))) (+ (exp a) (exp b)) (exp b) 1) |
| 3.0ms | b | @ | inf | ((/ (exp a) (+ (exp a) (exp b))) (pow (- (exp b) -1) -1) (- (exp b) -1) (exp b) b -1 (/ (exp a) (+ (exp a) (exp b))) (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) (neg b) (exp (- a (* (log (+ 1 (exp a))) 2))) (- a (* (log (+ 1 (exp a))) 2)) a (* (log (+ 1 (exp a))) 2) (log (+ 1 (exp a))) (exp a) 2 (/ (exp a) (- (exp a) -1)) (- (exp a) -1) (/ (exp a) (+ (exp a) (exp b))) (+ (exp a) (exp b)) (exp b) 1) |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 380 | 1947 |
| 0 | 410 | 1825 |
| 1 | 2388 | 1774 |
| 0 | 10543 | 1687 |
| 1× | iter limit |
| 1× | node limit |
| 1× | iter limit |
| Inputs |
|---|
#s(approx (/ (exp a) (+ (exp a) (exp b))) (pow.f64 (-.f64 (exp.f64 b) #s(literal -1 binary64)) #s(literal -1 binary64))) |
(pow.f64 (-.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) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (fma.f64 (neg.f64 b) (exp.f64 (-.f64 a (*.f64 (log1p.f64 (exp.f64 a)) #s(literal 2 binary64)))) (/.f64 (exp.f64 a) (-.f64 (exp.f64 a) #s(literal -1 binary64))))) |
(fma.f64 (neg.f64 b) (exp.f64 (-.f64 a (*.f64 (log1p.f64 (exp.f64 a)) #s(literal 2 binary64)))) (/.f64 (exp.f64 a) (-.f64 (exp.f64 a) #s(literal -1 binary64)))) |
(neg.f64 b) |
(exp.f64 (-.f64 a (*.f64 (log1p.f64 (exp.f64 a)) #s(literal 2 binary64)))) |
(-.f64 a (*.f64 (log1p.f64 (exp.f64 a)) #s(literal 2 binary64))) |
a |
(*.f64 (log1p.f64 (exp.f64 a)) #s(literal 2 binary64)) |
(log1p.f64 (exp.f64 a)) |
(exp.f64 a) |
#s(literal 2 binary64) |
(/.f64 (exp.f64 a) (-.f64 (exp.f64 a) #s(literal -1 binary64))) |
(-.f64 (exp.f64 a) #s(literal -1 binary64)) |
(/.f64 (exp.f64 a) (+.f64 (exp.f64 a) #s(approx (exp b) #s(literal 1 binary64)))) |
(+.f64 (exp.f64 a) #s(approx (exp b) #s(literal 1 binary64))) |
#s(approx (exp b) #s(literal 1 binary64)) |
#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 (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(hole binary64 (+ 1/2 (* -1 (* b (exp (neg (* 2 (log 2))))))))) |
#s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(hole binary64 (+ 1/2 (+ (* -1 (* b (exp (neg (* 2 (log 2)))))) (* 1/4 a))))) |
#s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(hole binary64 (+ 1/2 (+ (* -1 (* b (exp (neg (* 2 (log 2)))))) (* a (+ 1/4 (* 1/4 (* a (* b (exp (neg (* 2 (log 2))))))))))))) |
#s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(hole binary64 (+ 1/2 (+ (* -1 (* b (exp (neg (* 2 (log 2)))))) (* a (+ 1/4 (* a (+ (* -1/48 a) (* 1/4 (* b (exp (neg (* 2 (log 2)))))))))))))) |
#s(approx (exp (- a (* (log (+ 1 (exp a))) 2))) #s(hole binary64 (exp (neg (* 2 (log 2)))))) |
#s(approx (exp (- a (* (log (+ 1 (exp a))) 2))) #s(hole binary64 (+ (exp (neg (* 2 (log 2)))) (* -1/4 (* (pow a 2) (exp (neg (* 2 (log 2))))))))) |
#s(approx (exp (- a (* (log (+ 1 (exp a))) 2))) #s(hole binary64 (+ (exp (neg (* 2 (log 2)))) (* (pow a 2) (+ (* -1/4 (exp (neg (* 2 (log 2))))) (* 1/24 (* (pow a 2) (exp (neg (* 2 (log 2))))))))))) |
#s(approx (exp (- a (* (log (+ 1 (exp a))) 2))) #s(hole binary64 (+ (exp (neg (* 2 (log 2)))) (* (pow a 2) (+ (* -1/4 (exp (neg (* 2 (log 2))))) (* (pow a 2) (+ (* -17/2880 (* (pow a 2) (exp (neg (* 2 (log 2)))))) (* 1/24 (exp (neg (* 2 (log 2)))))))))))) |
#s(approx (- a (* (log (+ 1 (exp a))) 2)) #s(hole binary64 (* -2 (log 2)))) |
#s(approx (- a (* (log (+ 1 (exp a))) 2)) #s(hole binary64 (- (* -1/4 (pow a 2)) (* 2 (log 2))))) |
#s(approx (- a (* (log (+ 1 (exp a))) 2)) #s(hole binary64 (- (* (pow a 2) (- (* 1/96 (pow a 2)) 1/4)) (* 2 (log 2))))) |
#s(approx (- a (* (log (+ 1 (exp a))) 2)) #s(hole binary64 (- (* (pow a 2) (- (* (pow a 2) (+ 1/96 (* -1/1440 (pow a 2)))) 1/4)) (* 2 (log 2))))) |
#s(approx a #s(hole binary64 a)) |
#s(approx (* (log (+ 1 (exp a))) 2) #s(hole binary64 (* 2 (log 2)))) |
#s(approx (* (log (+ 1 (exp a))) 2) #s(hole binary64 (+ a (* 2 (log 2))))) |
#s(approx (* (log (+ 1 (exp a))) 2) #s(hole binary64 (+ (* 2 (log 2)) (* a (+ 1 (* 1/4 a)))))) |
#s(approx (* (log (+ 1 (exp a))) 2) #s(hole binary64 (+ (* 2 (log 2)) (* a (+ 1 (* a (+ 1/4 (* -1/96 (pow a 2))))))))) |
#s(approx (log (+ 1 (exp a))) #s(hole binary64 (log 2))) |
#s(approx (log (+ 1 (exp a))) #s(hole binary64 (+ (log 2) (* 1/2 a)))) |
#s(approx (log (+ 1 (exp a))) #s(hole binary64 (+ (log 2) (* a (+ 1/2 (* 1/8 a)))))) |
#s(approx (log (+ 1 (exp a))) #s(hole binary64 (+ (log 2) (* a (+ 1/2 (* a (+ 1/8 (* -1/192 (pow a 2))))))))) |
#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 (/ (exp a) (- (exp a) -1)) #s(hole binary64 1/2)) |
#s(approx (/ (exp a) (- (exp a) -1)) #s(hole binary64 (+ 1/2 (* 1/4 a)))) |
#s(approx (/ (exp a) (- (exp a) -1)) #s(hole binary64 (+ 1/2 (* a (+ 1/4 (* -1/48 (pow a 2))))))) |
#s(approx (/ (exp a) (- (exp a) -1)) #s(hole binary64 (+ 1/2 (* a (+ 1/4 (* (pow a 2) (- (* 1/480 (pow a 2)) 1/48))))))) |
#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 (+ (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 (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(hole binary64 (+ (* -1 (* b (exp (- a (* 2 (log (+ 1 (exp a)))))))) (/ (exp a) (+ 1 (exp a)))))) |
#s(approx (exp (- a (* (log (+ 1 (exp a))) 2))) #s(hole binary64 (exp (- a (* 2 (log (+ 1 (exp a)))))))) |
#s(approx (- a (* (log (+ 1 (exp a))) 2)) #s(hole binary64 a)) |
#s(approx (- a (* (log (+ 1 (exp a))) 2)) #s(hole binary64 (* a (+ 1 (* -2 (/ (log (+ 1 (exp a))) a)))))) |
#s(approx (* (log (+ 1 (exp a))) 2) #s(hole binary64 (* 2 (log (+ 1 (exp a)))))) |
#s(approx (log (+ 1 (exp a))) #s(hole binary64 (log (+ 1 (exp a))))) |
#s(approx (exp a) #s(hole binary64 (exp a))) |
#s(approx (/ (exp a) (- (exp a) -1)) #s(hole binary64 (/ (exp a) (+ 1 (exp a))))) |
#s(approx (- (exp a) -1) #s(hole binary64 (+ 1 (exp a)))) |
#s(approx (+ (exp a) (exp b)) #s(hole binary64 (+ (exp a) (exp b)))) |
#s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(hole binary64 (+ (* -1 (* b (exp (neg (+ (* -1 a) (* 2 (log (+ 1 (exp a))))))))) (/ (exp a) (+ 1 (exp a)))))) |
#s(approx (exp (- a (* (log (+ 1 (exp a))) 2))) #s(hole binary64 (exp (neg (+ (* -1 a) (* 2 (log (+ 1 (exp a))))))))) |
#s(approx (- a (* (log (+ 1 (exp a))) 2)) #s(hole binary64 (* -1 (* a (- (* 2 (/ (log (+ 1 (exp a))) a)) 1))))) |
#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 (pow (- (exp b) -1) -1) #s(hole binary64 1/2)) |
#s(approx (pow (- (exp b) -1) -1) #s(hole binary64 (+ 1/2 (* -1/4 b)))) |
#s(approx (pow (- (exp b) -1) -1) #s(hole binary64 (+ 1/2 (* b (- (* 1/48 (pow b 2)) 1/4))))) |
#s(approx (pow (- (exp b) -1) -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 (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(hole binary64 (/ (exp a) (+ 1 (exp a))))) |
#s(approx (neg b) #s(hole binary64 (* -1 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 (pow (- (exp b) -1) -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))) |
#s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(hole binary64 (* -1 (* b (exp (- a (* 2 (log (+ 1 (exp a)))))))))) |
#s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(hole binary64 (* b (+ (* -1 (exp (- a (* 2 (log (+ 1 (exp a))))))) (/ (exp a) (* b (+ 1 (exp a)))))))) |
#s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(hole binary64 (* -1 (* b (+ (exp (- a (* 2 (log (+ 1 (exp a)))))) (* -1 (/ (exp a) (* b (+ 1 (exp a)))))))))) |
| Outputs |
|---|
#s(approx (/ (exp a) (+ (exp a) (exp b))) (pow.f64 (-.f64 (exp.f64 b) #s(literal -1 binary64)) #s(literal -1 binary64))) |
(*.f64 (neg.f64 (pow.f64 (-.f64 (exp.f64 b) #s(literal -1 binary64)) #s(literal -1/2 binary64))) (neg.f64 (pow.f64 (-.f64 (exp.f64 b) #s(literal -1 binary64)) #s(literal -1/2 binary64)))) |
(*.f64 (fabs.f64 (pow.f64 (-.f64 (exp.f64 b) #s(literal -1 binary64)) #s(literal -1/2 binary64))) (fabs.f64 (pow.f64 (-.f64 (exp.f64 b) #s(literal -1 binary64)) #s(literal -1/2 binary64)))) |
(*.f64 (pow.f64 (-.f64 (exp.f64 b) #s(literal -1 binary64)) #s(literal -1/2 binary64)) (pow.f64 (-.f64 (exp.f64 b) #s(literal -1 binary64)) #s(literal -1/2 binary64))) |
(pow.f64 (exp.f64 (log.f64 (-.f64 (exp.f64 b) #s(literal -1 binary64)))) #s(literal -1 binary64)) |
(pow.f64 (*.f64 (-.f64 (exp.f64 b) #s(literal -1 binary64)) (-.f64 (exp.f64 b) #s(literal -1 binary64))) #s(literal -1/2 binary64)) |
(pow.f64 (pow.f64 (-.f64 (exp.f64 b) #s(literal -1 binary64)) #s(literal -1/2 binary64)) #s(literal 2 binary64)) |
(pow.f64 (-.f64 (exp.f64 b) #s(literal -1 binary64)) #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))) |
(/.f64 #s(literal -1 binary64) (neg.f64 (-.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))) |
(+.f64 (cosh.f64 (*.f64 (log.f64 (-.f64 (exp.f64 b) #s(literal -1 binary64))) #s(literal -1 binary64))) (sinh.f64 (*.f64 (log.f64 (-.f64 (exp.f64 b) #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 (pow.f64 (exp.f64 b) #s(literal 3 binary64)) #s(literal -1 binary64))) (neg.f64 (fma.f64 (exp.f64 b) (exp.f64 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 (pow.f64 (exp.f64 b) #s(literal 3 binary64)) #s(literal -1 binary64)) (fma.f64 (exp.f64 b) (exp.f64 b) (+.f64 #s(literal 1 binary64) (*.f64 (exp.f64 b) #s(literal -1 binary64))))) |
(-.f64 (/.f64 (pow.f64 (exp.f64 b) #s(literal 2 binary64)) (+.f64 (exp.f64 b) #s(literal -1 binary64))) (/.f64 #s(literal 1 binary64) (+.f64 (exp.f64 b) #s(literal -1 binary64)))) |
(-.f64 (/.f64 (pow.f64 (exp.f64 b) #s(literal 3 binary64)) (fma.f64 (exp.f64 b) (exp.f64 b) (+.f64 #s(literal 1 binary64) (*.f64 (exp.f64 b) #s(literal -1 binary64))))) (/.f64 #s(literal -1 binary64) (fma.f64 (exp.f64 b) (exp.f64 b) (+.f64 #s(literal 1 binary64) (*.f64 (exp.f64 b) #s(literal -1 binary64)))))) |
(-.f64 (exp.f64 b) #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))))) |
(exp.f64 b) |
(+.f64 (cosh.f64 b) (sinh.f64 b)) |
b |
#s(literal -1 binary64) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (fma.f64 (exp.f64 (-.f64 a (*.f64 (log1p.f64 (exp.f64 a)) #s(literal 2 binary64)))) (neg.f64 b) (/.f64 (exp.f64 a) (-.f64 (exp.f64 a) #s(literal -1 binary64))))) |
(/.f64 (+.f64 (pow.f64 (/.f64 (exp.f64 a) (-.f64 (exp.f64 a) #s(literal -1 binary64))) #s(literal 3 binary64)) (pow.f64 (*.f64 (exp.f64 (-.f64 a (*.f64 (log1p.f64 (exp.f64 a)) #s(literal 2 binary64)))) (neg.f64 b)) #s(literal 3 binary64))) (+.f64 (pow.f64 (/.f64 (exp.f64 a) (-.f64 (exp.f64 a) #s(literal -1 binary64))) #s(literal 2 binary64)) (-.f64 (pow.f64 (*.f64 (exp.f64 (-.f64 a (*.f64 (log1p.f64 (exp.f64 a)) #s(literal 2 binary64)))) (neg.f64 b)) #s(literal 2 binary64)) (*.f64 (/.f64 (exp.f64 a) (-.f64 (exp.f64 a) #s(literal -1 binary64))) (*.f64 (exp.f64 (-.f64 a (*.f64 (log1p.f64 (exp.f64 a)) #s(literal 2 binary64)))) (neg.f64 b)))))) |
(/.f64 (neg.f64 (-.f64 (pow.f64 (*.f64 (exp.f64 (-.f64 a (*.f64 (log1p.f64 (exp.f64 a)) #s(literal 2 binary64)))) (neg.f64 b)) #s(literal 2 binary64)) (pow.f64 (/.f64 (exp.f64 a) (-.f64 (exp.f64 a) #s(literal -1 binary64))) #s(literal 2 binary64)))) (neg.f64 (-.f64 (*.f64 (exp.f64 (-.f64 a (*.f64 (log1p.f64 (exp.f64 a)) #s(literal 2 binary64)))) (neg.f64 b)) (/.f64 (exp.f64 a) (-.f64 (exp.f64 a) #s(literal -1 binary64)))))) |
(/.f64 (neg.f64 (fma.f64 (pow.f64 (*.f64 (exp.f64 (-.f64 a (*.f64 (log1p.f64 (exp.f64 a)) #s(literal 2 binary64)))) b) #s(literal 3 binary64)) #s(literal -1 binary64) (pow.f64 (/.f64 (exp.f64 a) (-.f64 (exp.f64 a) #s(literal -1 binary64))) #s(literal 3 binary64)))) (neg.f64 (+.f64 (pow.f64 (*.f64 (exp.f64 (-.f64 a (*.f64 (log1p.f64 (exp.f64 a)) #s(literal 2 binary64)))) (neg.f64 b)) #s(literal 2 binary64)) (-.f64 (pow.f64 (/.f64 (exp.f64 a) (-.f64 (exp.f64 a) #s(literal -1 binary64))) #s(literal 2 binary64)) (*.f64 (*.f64 (exp.f64 (-.f64 a (*.f64 (log1p.f64 (exp.f64 a)) #s(literal 2 binary64)))) (neg.f64 b)) (/.f64 (exp.f64 a) (-.f64 (exp.f64 a) #s(literal -1 binary64)))))))) |
(/.f64 (fma.f64 (neg.f64 (exp.f64 a)) (pow.f64 (+.f64 #s(literal 1 binary64) (exp.f64 a)) #s(literal 2 binary64)) (*.f64 (neg.f64 (-.f64 (exp.f64 a) #s(literal -1 binary64))) (*.f64 #s(literal -1 binary64) (*.f64 b (exp.f64 a))))) (*.f64 (neg.f64 (-.f64 (exp.f64 a) #s(literal -1 binary64))) (pow.f64 (+.f64 #s(literal 1 binary64) (exp.f64 a)) #s(literal 2 binary64)))) |
(/.f64 (fma.f64 (exp.f64 a) (pow.f64 (+.f64 #s(literal 1 binary64) (exp.f64 a)) #s(literal 2 binary64)) (*.f64 (-.f64 (exp.f64 a) #s(literal -1 binary64)) (*.f64 #s(literal -1 binary64) (*.f64 b (exp.f64 a))))) (*.f64 (-.f64 (exp.f64 a) #s(literal -1 binary64)) (pow.f64 (+.f64 #s(literal 1 binary64) (exp.f64 a)) #s(literal 2 binary64)))) |
(/.f64 (fma.f64 (*.f64 #s(literal -1 binary64) (*.f64 b (exp.f64 a))) (neg.f64 (-.f64 (exp.f64 a) #s(literal -1 binary64))) (*.f64 (pow.f64 (+.f64 #s(literal 1 binary64) (exp.f64 a)) #s(literal 2 binary64)) (neg.f64 (exp.f64 a)))) (*.f64 (pow.f64 (+.f64 #s(literal 1 binary64) (exp.f64 a)) #s(literal 2 binary64)) (neg.f64 (-.f64 (exp.f64 a) #s(literal -1 binary64))))) |
(/.f64 (fma.f64 (*.f64 #s(literal -1 binary64) (*.f64 b (exp.f64 a))) (-.f64 (exp.f64 a) #s(literal -1 binary64)) (*.f64 (pow.f64 (+.f64 #s(literal 1 binary64) (exp.f64 a)) #s(literal 2 binary64)) (exp.f64 a))) (*.f64 (pow.f64 (+.f64 #s(literal 1 binary64) (exp.f64 a)) #s(literal 2 binary64)) (-.f64 (exp.f64 a) #s(literal -1 binary64)))) |
(/.f64 (-.f64 (pow.f64 (*.f64 (exp.f64 (-.f64 a (*.f64 (log1p.f64 (exp.f64 a)) #s(literal 2 binary64)))) (neg.f64 b)) #s(literal 2 binary64)) (pow.f64 (/.f64 (exp.f64 a) (-.f64 (exp.f64 a) #s(literal -1 binary64))) #s(literal 2 binary64))) (-.f64 (*.f64 (exp.f64 (-.f64 a (*.f64 (log1p.f64 (exp.f64 a)) #s(literal 2 binary64)))) (neg.f64 b)) (/.f64 (exp.f64 a) (-.f64 (exp.f64 a) #s(literal -1 binary64))))) |
(/.f64 (fma.f64 (pow.f64 (*.f64 (exp.f64 (-.f64 a (*.f64 (log1p.f64 (exp.f64 a)) #s(literal 2 binary64)))) b) #s(literal 3 binary64)) #s(literal -1 binary64) (pow.f64 (/.f64 (exp.f64 a) (-.f64 (exp.f64 a) #s(literal -1 binary64))) #s(literal 3 binary64))) (+.f64 (pow.f64 (*.f64 (exp.f64 (-.f64 a (*.f64 (log1p.f64 (exp.f64 a)) #s(literal 2 binary64)))) (neg.f64 b)) #s(literal 2 binary64)) (-.f64 (pow.f64 (/.f64 (exp.f64 a) (-.f64 (exp.f64 a) #s(literal -1 binary64))) #s(literal 2 binary64)) (*.f64 (*.f64 (exp.f64 (-.f64 a (*.f64 (log1p.f64 (exp.f64 a)) #s(literal 2 binary64)))) (neg.f64 b)) (/.f64 (exp.f64 a) (-.f64 (exp.f64 a) #s(literal -1 binary64))))))) |
(fma.f64 (/.f64 #s(literal -1 binary64) (+.f64 #s(literal 1 binary64) (exp.f64 a))) (/.f64 (*.f64 b (exp.f64 a)) (+.f64 #s(literal 1 binary64) (exp.f64 a))) (/.f64 (exp.f64 a) (-.f64 (exp.f64 a) #s(literal -1 binary64)))) |
(fma.f64 (*.f64 (exp.f64 (-.f64 a (*.f64 (log1p.f64 (exp.f64 a)) #s(literal 2 binary64)))) b) #s(literal -1 binary64) (/.f64 (exp.f64 a) (-.f64 (exp.f64 a) #s(literal -1 binary64)))) |
(fma.f64 (exp.f64 (-.f64 a (*.f64 (log1p.f64 (exp.f64 a)) #s(literal 2 binary64)))) (neg.f64 b) (/.f64 (exp.f64 a) (-.f64 (exp.f64 a) #s(literal -1 binary64)))) |
(fma.f64 (neg.f64 b) (exp.f64 (-.f64 a (*.f64 (log1p.f64 (exp.f64 a)) #s(literal 2 binary64)))) (/.f64 (exp.f64 a) (-.f64 (exp.f64 a) #s(literal -1 binary64)))) |
(fma.f64 #s(literal -1 binary64) (*.f64 (exp.f64 (-.f64 a (*.f64 (log1p.f64 (exp.f64 a)) #s(literal 2 binary64)))) b) (/.f64 (exp.f64 a) (-.f64 (exp.f64 a) #s(literal -1 binary64)))) |
(-.f64 (/.f64 (pow.f64 (*.f64 (exp.f64 (-.f64 a (*.f64 (log1p.f64 (exp.f64 a)) #s(literal 2 binary64)))) (neg.f64 b)) #s(literal 2 binary64)) (-.f64 (*.f64 (exp.f64 (-.f64 a (*.f64 (log1p.f64 (exp.f64 a)) #s(literal 2 binary64)))) (neg.f64 b)) (/.f64 (exp.f64 a) (-.f64 (exp.f64 a) #s(literal -1 binary64))))) (/.f64 (pow.f64 (/.f64 (exp.f64 a) (-.f64 (exp.f64 a) #s(literal -1 binary64))) #s(literal 2 binary64)) (-.f64 (*.f64 (exp.f64 (-.f64 a (*.f64 (log1p.f64 (exp.f64 a)) #s(literal 2 binary64)))) (neg.f64 b)) (/.f64 (exp.f64 a) (-.f64 (exp.f64 a) #s(literal -1 binary64)))))) |
(+.f64 (/.f64 (pow.f64 (*.f64 (exp.f64 (-.f64 a (*.f64 (log1p.f64 (exp.f64 a)) #s(literal 2 binary64)))) (neg.f64 b)) #s(literal 3 binary64)) (+.f64 (pow.f64 (*.f64 (exp.f64 (-.f64 a (*.f64 (log1p.f64 (exp.f64 a)) #s(literal 2 binary64)))) (neg.f64 b)) #s(literal 2 binary64)) (-.f64 (pow.f64 (/.f64 (exp.f64 a) (-.f64 (exp.f64 a) #s(literal -1 binary64))) #s(literal 2 binary64)) (*.f64 (*.f64 (exp.f64 (-.f64 a (*.f64 (log1p.f64 (exp.f64 a)) #s(literal 2 binary64)))) (neg.f64 b)) (/.f64 (exp.f64 a) (-.f64 (exp.f64 a) #s(literal -1 binary64))))))) (/.f64 (pow.f64 (/.f64 (exp.f64 a) (-.f64 (exp.f64 a) #s(literal -1 binary64))) #s(literal 3 binary64)) (+.f64 (pow.f64 (*.f64 (exp.f64 (-.f64 a (*.f64 (log1p.f64 (exp.f64 a)) #s(literal 2 binary64)))) (neg.f64 b)) #s(literal 2 binary64)) (-.f64 (pow.f64 (/.f64 (exp.f64 a) (-.f64 (exp.f64 a) #s(literal -1 binary64))) #s(literal 2 binary64)) (*.f64 (*.f64 (exp.f64 (-.f64 a (*.f64 (log1p.f64 (exp.f64 a)) #s(literal 2 binary64)))) (neg.f64 b)) (/.f64 (exp.f64 a) (-.f64 (exp.f64 a) #s(literal -1 binary64)))))))) |
(+.f64 (/.f64 (exp.f64 a) (-.f64 (exp.f64 a) #s(literal -1 binary64))) (*.f64 (exp.f64 (-.f64 a (*.f64 (log1p.f64 (exp.f64 a)) #s(literal 2 binary64)))) (neg.f64 b))) |
(+.f64 (*.f64 (exp.f64 (-.f64 a (*.f64 (log1p.f64 (exp.f64 a)) #s(literal 2 binary64)))) (neg.f64 b)) (/.f64 (exp.f64 a) (-.f64 (exp.f64 a) #s(literal -1 binary64)))) |
(*.f64 #s(literal -1 binary64) b) |
(*.f64 b #s(literal -1 binary64)) |
(neg.f64 b) |
(*.f64 (exp.f64 a) (exp.f64 (*.f64 (neg.f64 (log1p.f64 (exp.f64 a))) #s(literal 2 binary64)))) |
(*.f64 (exp.f64 a) (exp.f64 (*.f64 #s(literal -2 binary64) (log1p.f64 (exp.f64 a))))) |
(/.f64 (+.f64 (pow.f64 (cosh.f64 (-.f64 a (*.f64 (log1p.f64 (exp.f64 a)) #s(literal 2 binary64)))) #s(literal 3 binary64)) (pow.f64 (sinh.f64 (-.f64 a (*.f64 (log1p.f64 (exp.f64 a)) #s(literal 2 binary64)))) #s(literal 3 binary64))) (fma.f64 (cosh.f64 (-.f64 a (*.f64 (log1p.f64 (exp.f64 a)) #s(literal 2 binary64)))) (cosh.f64 (-.f64 a (*.f64 (log1p.f64 (exp.f64 a)) #s(literal 2 binary64)))) (-.f64 (*.f64 (sinh.f64 (-.f64 a (*.f64 (log1p.f64 (exp.f64 a)) #s(literal 2 binary64)))) (sinh.f64 (-.f64 a (*.f64 (log1p.f64 (exp.f64 a)) #s(literal 2 binary64))))) (*.f64 (cosh.f64 (-.f64 a (*.f64 (log1p.f64 (exp.f64 a)) #s(literal 2 binary64)))) (sinh.f64 (-.f64 a (*.f64 (log1p.f64 (exp.f64 a)) #s(literal 2 binary64)))))))) |
(/.f64 (neg.f64 (neg.f64 (exp.f64 a))) (neg.f64 (neg.f64 (pow.f64 (+.f64 #s(literal 1 binary64) (exp.f64 a)) #s(literal 2 binary64))))) |
(/.f64 (neg.f64 (exp.f64 a)) (neg.f64 (pow.f64 (+.f64 #s(literal 1 binary64) (exp.f64 a)) #s(literal 2 binary64)))) |
(/.f64 (exp.f64 a) (pow.f64 (+.f64 #s(literal 1 binary64) (exp.f64 a)) #s(literal 2 binary64))) |
(exp.f64 (-.f64 a (*.f64 (log1p.f64 (exp.f64 a)) #s(literal 2 binary64)))) |
(+.f64 (/.f64 (cosh.f64 a) (pow.f64 (+.f64 #s(literal 1 binary64) (exp.f64 a)) #s(literal 2 binary64))) (/.f64 (sinh.f64 a) (pow.f64 (+.f64 #s(literal 1 binary64) (exp.f64 a)) #s(literal 2 binary64)))) |
(+.f64 (cosh.f64 (-.f64 a (*.f64 (log1p.f64 (exp.f64 a)) #s(literal 2 binary64)))) (sinh.f64 (-.f64 a (*.f64 (log1p.f64 (exp.f64 a)) #s(literal 2 binary64))))) |
(/.f64 (+.f64 (pow.f64 a #s(literal 3 binary64)) (pow.f64 (*.f64 (neg.f64 (log1p.f64 (exp.f64 a))) #s(literal 2 binary64)) #s(literal 3 binary64))) (fma.f64 a a (-.f64 (*.f64 (*.f64 (neg.f64 (log1p.f64 (exp.f64 a))) #s(literal 2 binary64)) (*.f64 (neg.f64 (log1p.f64 (exp.f64 a))) #s(literal 2 binary64))) (*.f64 a (*.f64 (neg.f64 (log1p.f64 (exp.f64 a))) #s(literal 2 binary64)))))) |
(/.f64 (+.f64 (pow.f64 a #s(literal 3 binary64)) (pow.f64 (*.f64 #s(literal -2 binary64) (log1p.f64 (exp.f64 a))) #s(literal 3 binary64))) (fma.f64 a a (-.f64 (*.f64 (*.f64 #s(literal -2 binary64) (log1p.f64 (exp.f64 a))) (*.f64 #s(literal -2 binary64) (log1p.f64 (exp.f64 a)))) (*.f64 a (*.f64 #s(literal -2 binary64) (log1p.f64 (exp.f64 a))))))) |
(/.f64 (neg.f64 (-.f64 (*.f64 a a) (pow.f64 (*.f64 (log1p.f64 (exp.f64 a)) #s(literal 2 binary64)) #s(literal 2 binary64)))) (neg.f64 (+.f64 a (*.f64 (log1p.f64 (exp.f64 a)) #s(literal 2 binary64))))) |
(/.f64 (neg.f64 (-.f64 (pow.f64 a #s(literal 3 binary64)) (pow.f64 (*.f64 (log1p.f64 (exp.f64 a)) #s(literal 2 binary64)) #s(literal 3 binary64)))) (neg.f64 (fma.f64 a a (+.f64 (pow.f64 (*.f64 (log1p.f64 (exp.f64 a)) #s(literal 2 binary64)) #s(literal 2 binary64)) (*.f64 a (*.f64 (log1p.f64 (exp.f64 a)) #s(literal 2 binary64))))))) |
(/.f64 (-.f64 (*.f64 a a) (pow.f64 (*.f64 (log1p.f64 (exp.f64 a)) #s(literal 2 binary64)) #s(literal 2 binary64))) (+.f64 a (*.f64 (log1p.f64 (exp.f64 a)) #s(literal 2 binary64)))) |
(/.f64 (-.f64 (pow.f64 a #s(literal 3 binary64)) (pow.f64 (*.f64 (log1p.f64 (exp.f64 a)) #s(literal 2 binary64)) #s(literal 3 binary64))) (fma.f64 a a (+.f64 (pow.f64 (*.f64 (log1p.f64 (exp.f64 a)) #s(literal 2 binary64)) #s(literal 2 binary64)) (*.f64 a (*.f64 (log1p.f64 (exp.f64 a)) #s(literal 2 binary64)))))) |
(-.f64 (/.f64 (*.f64 a a) (+.f64 a (*.f64 (log1p.f64 (exp.f64 a)) #s(literal 2 binary64)))) (/.f64 (pow.f64 (*.f64 (log1p.f64 (exp.f64 a)) #s(literal 2 binary64)) #s(literal 2 binary64)) (+.f64 a (*.f64 (log1p.f64 (exp.f64 a)) #s(literal 2 binary64))))) |
(-.f64 (/.f64 (pow.f64 a #s(literal 3 binary64)) (fma.f64 a a (+.f64 (pow.f64 (*.f64 (log1p.f64 (exp.f64 a)) #s(literal 2 binary64)) #s(literal 2 binary64)) (*.f64 a (*.f64 (log1p.f64 (exp.f64 a)) #s(literal 2 binary64)))))) (/.f64 (pow.f64 (*.f64 (log1p.f64 (exp.f64 a)) #s(literal 2 binary64)) #s(literal 3 binary64)) (fma.f64 a a (+.f64 (pow.f64 (*.f64 (log1p.f64 (exp.f64 a)) #s(literal 2 binary64)) #s(literal 2 binary64)) (*.f64 a (*.f64 (log1p.f64 (exp.f64 a)) #s(literal 2 binary64))))))) |
(-.f64 a (*.f64 (log1p.f64 (exp.f64 a)) #s(literal 2 binary64))) |
(+.f64 a (*.f64 (neg.f64 (log1p.f64 (exp.f64 a))) #s(literal 2 binary64))) |
(+.f64 a (*.f64 #s(literal -2 binary64) (log1p.f64 (exp.f64 a)))) |
a |
(*.f64 (log1p.f64 (exp.f64 a)) #s(literal 2 binary64)) |
(*.f64 #s(literal 2 binary64) (log1p.f64 (exp.f64 a))) |
(/.f64 (+.f64 (pow.f64 (log1p.f64 (exp.f64 a)) #s(literal 3 binary64)) (pow.f64 (log1p.f64 (exp.f64 a)) #s(literal 3 binary64))) (fma.f64 (log1p.f64 (exp.f64 a)) (log1p.f64 (exp.f64 a)) (-.f64 (*.f64 (log1p.f64 (exp.f64 a)) (log1p.f64 (exp.f64 a))) (*.f64 (log1p.f64 (exp.f64 a)) (log1p.f64 (exp.f64 a)))))) |
(+.f64 (log1p.f64 (exp.f64 a)) (log1p.f64 (exp.f64 a))) |
(log.f64 (pow.f64 (+.f64 #s(literal 1 binary64) (exp.f64 a)) #s(literal 2 binary64))) |
(log1p.f64 (exp.f64 a)) |
(-.f64 (log.f64 (-.f64 #s(literal 1 binary64) (pow.f64 (exp.f64 a) #s(literal 2 binary64)))) (log.f64 (-.f64 #s(literal 1 binary64) (exp.f64 a)))) |
(-.f64 (log1p.f64 (pow.f64 (exp.f64 a) #s(literal 3 binary64))) (log1p.f64 (-.f64 (pow.f64 (exp.f64 a) #s(literal 2 binary64)) (*.f64 #s(literal 1 binary64) (exp.f64 a))))) |
(log.f64 (+.f64 #s(literal 1 binary64) (exp.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))))) |
(exp.f64 a) |
(+.f64 (cosh.f64 a) (sinh.f64 a)) |
#s(literal 2 binary64) |
(/.f64 (neg.f64 (neg.f64 (exp.f64 a))) (neg.f64 (neg.f64 (-.f64 (exp.f64 a) #s(literal -1 binary64))))) |
(/.f64 (neg.f64 (exp.f64 a)) (neg.f64 (-.f64 (exp.f64 a) #s(literal -1 binary64)))) |
(/.f64 (exp.f64 a) (-.f64 (exp.f64 a) #s(literal -1 binary64))) |
(+.f64 (/.f64 (cosh.f64 a) (-.f64 (exp.f64 a) #s(literal -1 binary64))) (/.f64 (sinh.f64 a) (-.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 (pow.f64 (exp.f64 a) #s(literal 3 binary64)) #s(literal -1 binary64))) (neg.f64 (fma.f64 (exp.f64 a) (exp.f64 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 (pow.f64 (exp.f64 a) #s(literal 3 binary64)) #s(literal -1 binary64)) (fma.f64 (exp.f64 a) (exp.f64 a) (+.f64 #s(literal 1 binary64) (*.f64 (exp.f64 a) #s(literal -1 binary64))))) |
(-.f64 (/.f64 (pow.f64 (exp.f64 a) #s(literal 2 binary64)) (+.f64 (exp.f64 a) #s(literal -1 binary64))) (/.f64 #s(literal 1 binary64) (+.f64 (exp.f64 a) #s(literal -1 binary64)))) |
(-.f64 (/.f64 (pow.f64 (exp.f64 a) #s(literal 3 binary64)) (fma.f64 (exp.f64 a) (exp.f64 a) (+.f64 #s(literal 1 binary64) (*.f64 (exp.f64 a) #s(literal -1 binary64))))) (/.f64 #s(literal -1 binary64) (fma.f64 (exp.f64 a) (exp.f64 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 (+.f64 #s(approx (exp b) #s(literal 1 binary64)) (exp.f64 a))))) |
(/.f64 (neg.f64 (exp.f64 a)) (neg.f64 (+.f64 #s(approx (exp b) #s(literal 1 binary64)) (exp.f64 a)))) |
(/.f64 (exp.f64 a) (+.f64 #s(approx (exp b) #s(literal 1 binary64)) (exp.f64 a))) |
(+.f64 (/.f64 (cosh.f64 a) (+.f64 #s(approx (exp b) #s(literal 1 binary64)) (exp.f64 a))) (/.f64 (sinh.f64 a) (+.f64 #s(approx (exp b) #s(literal 1 binary64)) (exp.f64 a)))) |
(/.f64 (+.f64 (pow.f64 #s(approx (exp b) #s(literal 1 binary64)) #s(literal 3 binary64)) (pow.f64 (exp.f64 a) #s(literal 3 binary64))) (fma.f64 #s(approx (exp b) #s(literal 1 binary64)) #s(approx (exp b) #s(literal 1 binary64)) (-.f64 (pow.f64 (exp.f64 a) #s(literal 2 binary64)) (*.f64 #s(approx (exp b) #s(literal 1 binary64)) (exp.f64 a))))) |
(/.f64 (neg.f64 (-.f64 (pow.f64 (exp.f64 a) #s(literal 2 binary64)) (pow.f64 #s(approx (exp b) #s(literal 1 binary64)) #s(literal 2 binary64)))) (neg.f64 (-.f64 (exp.f64 a) #s(approx (exp b) #s(literal 1 binary64))))) |
(/.f64 (neg.f64 (+.f64 (pow.f64 (exp.f64 a) #s(literal 3 binary64)) (pow.f64 #s(approx (exp b) #s(literal 1 binary64)) #s(literal 3 binary64)))) (neg.f64 (fma.f64 (exp.f64 a) (exp.f64 a) (-.f64 (pow.f64 #s(approx (exp b) #s(literal 1 binary64)) #s(literal 2 binary64)) (*.f64 (exp.f64 a) #s(approx (exp b) #s(literal 1 binary64))))))) |
(/.f64 (-.f64 (pow.f64 (exp.f64 a) #s(literal 2 binary64)) (pow.f64 #s(approx (exp b) #s(literal 1 binary64)) #s(literal 2 binary64))) (-.f64 (exp.f64 a) #s(approx (exp b) #s(literal 1 binary64)))) |
(/.f64 (+.f64 (pow.f64 (exp.f64 a) #s(literal 3 binary64)) (pow.f64 #s(approx (exp b) #s(literal 1 binary64)) #s(literal 3 binary64))) (fma.f64 (exp.f64 a) (exp.f64 a) (-.f64 (pow.f64 #s(approx (exp b) #s(literal 1 binary64)) #s(literal 2 binary64)) (*.f64 (exp.f64 a) #s(approx (exp b) #s(literal 1 binary64)))))) |
(-.f64 (/.f64 (pow.f64 (exp.f64 a) #s(literal 2 binary64)) (-.f64 (exp.f64 a) #s(approx (exp b) #s(literal 1 binary64)))) (/.f64 (pow.f64 #s(approx (exp b) #s(literal 1 binary64)) #s(literal 2 binary64)) (-.f64 (exp.f64 a) #s(approx (exp b) #s(literal 1 binary64))))) |
(+.f64 (/.f64 (pow.f64 (exp.f64 a) #s(literal 3 binary64)) (fma.f64 (exp.f64 a) (exp.f64 a) (-.f64 (pow.f64 #s(approx (exp b) #s(literal 1 binary64)) #s(literal 2 binary64)) (*.f64 (exp.f64 a) #s(approx (exp b) #s(literal 1 binary64)))))) (/.f64 (pow.f64 #s(approx (exp b) #s(literal 1 binary64)) #s(literal 3 binary64)) (fma.f64 (exp.f64 a) (exp.f64 a) (-.f64 (pow.f64 #s(approx (exp b) #s(literal 1 binary64)) #s(literal 2 binary64)) (*.f64 (exp.f64 a) #s(approx (exp b) #s(literal 1 binary64))))))) |
(+.f64 #s(approx (exp b) #s(literal 1 binary64)) (exp.f64 a)) |
(+.f64 (exp.f64 a) #s(approx (exp b) #s(literal 1 binary64))) |
#s(approx (exp b) #s(literal 1 binary64)) |
#s(literal 1 binary64) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (pow.f64 (+.f64 #s(literal 1 binary64) (exp.f64 b)) #s(literal -1 binary64))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (fma.f64 (-.f64 (pow.f64 (+.f64 #s(literal 1 binary64) (exp.f64 b)) #s(literal -1 binary64)) (pow.f64 (+.f64 #s(literal 1 binary64) (exp.f64 b)) #s(literal -2 binary64))) a (pow.f64 (+.f64 #s(literal 1 binary64) (exp.f64 b)) #s(literal -1 binary64)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (fma.f64 (-.f64 (fma.f64 (-.f64 (+.f64 (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 #s(literal 3/2 binary64) (pow.f64 (+.f64 #s(literal 1 binary64) (exp.f64 b)) #s(literal -2 binary64)))) a (pow.f64 (+.f64 #s(literal 1 binary64) (exp.f64 b)) #s(literal -1 binary64))) (pow.f64 (+.f64 #s(literal 1 binary64) (exp.f64 b)) #s(literal -2 binary64))) a (pow.f64 (+.f64 #s(literal 1 binary64) (exp.f64 b)) #s(literal -1 binary64)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (fma.f64 (-.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) (pow.f64 (+.f64 #s(literal 1 binary64) (exp.f64 b)) #s(literal 2 binary64))) (fma.f64 (/.f64 (-.f64 (pow.f64 (+.f64 #s(literal 1 binary64) (exp.f64 b)) #s(literal -1 binary64)) (pow.f64 (+.f64 #s(literal 1 binary64) (exp.f64 b)) #s(literal -2 binary64))) (+.f64 #s(literal 1 binary64) (exp.f64 b))) #s(literal 1/2 binary64) (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 #s(literal 3/2 binary64) (pow.f64 (+.f64 #s(literal 1 binary64) (exp.f64 b)) #s(literal -2 binary64)))) a (pow.f64 (+.f64 #s(literal 1 binary64) (exp.f64 b)) #s(literal -1 binary64))) (pow.f64 (+.f64 #s(literal 1 binary64) (exp.f64 b)) #s(literal -2 binary64))) a (pow.f64 (+.f64 #s(literal 1 binary64) (exp.f64 b)) #s(literal -1 binary64)))) |
#s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) (fma.f64 (neg.f64 b) #s(literal 1/4 binary64) #s(literal 1/2 binary64))) |
#s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) (+.f64 (fma.f64 #s(literal 1/4 binary64) a (*.f64 (neg.f64 b) #s(literal 1/4 binary64))) #s(literal 1/2 binary64))) |
#s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) (+.f64 (fma.f64 (fma.f64 (*.f64 (*.f64 #s(literal 1/4 binary64) b) a) #s(literal 1/4 binary64) #s(literal 1/4 binary64)) a (*.f64 (neg.f64 b) #s(literal 1/4 binary64))) #s(literal 1/2 binary64))) |
#s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) (+.f64 (fma.f64 (fma.f64 (fma.f64 #s(literal -1/48 binary64) a (*.f64 #s(literal 1/4 binary64) (*.f64 #s(literal 1/4 binary64) b))) a #s(literal 1/4 binary64)) a (*.f64 (neg.f64 b) #s(literal 1/4 binary64))) #s(literal 1/2 binary64))) |
#s(approx (exp (- a (* (log (+ 1 (exp a))) 2))) #s(literal 1/4 binary64)) |
#s(approx (exp (- a (* (log (+ 1 (exp a))) 2))) (fma.f64 (*.f64 (*.f64 a a) #s(literal 1/4 binary64)) #s(literal -1/4 binary64) #s(literal 1/4 binary64))) |
#s(approx (exp (- a (* (log (+ 1 (exp a))) 2))) (fma.f64 (fma.f64 #s(literal 1/24 binary64) (*.f64 (*.f64 a a) #s(literal 1/4 binary64)) #s(literal -1/16 binary64)) (*.f64 a a) #s(literal 1/4 binary64))) |
#s(approx (exp (- a (* (log (+ 1 (exp a))) 2))) (fma.f64 (fma.f64 (fma.f64 #s(literal -17/2880 binary64) (*.f64 (*.f64 a a) #s(literal 1/4 binary64)) #s(literal 1/96 binary64)) (*.f64 a a) #s(literal -1/16 binary64)) (*.f64 a a) #s(literal 1/4 binary64))) |
#s(approx (- a (* (log (+ 1 (exp a))) 2)) (log.f64 #s(literal 1/4 binary64))) |
#s(approx (- a (* (log (+ 1 (exp a))) 2)) (fma.f64 (*.f64 a a) #s(literal -1/4 binary64) (log.f64 #s(literal 1/4 binary64)))) |
#s(approx (- a (* (log (+ 1 (exp a))) 2)) (fma.f64 (-.f64 (*.f64 #s(literal 1/96 binary64) (*.f64 a a)) #s(literal 1/4 binary64)) (*.f64 a a) (log.f64 #s(literal 1/4 binary64)))) |
#s(approx (- a (* (log (+ 1 (exp a))) 2)) (fma.f64 (-.f64 (*.f64 (fma.f64 #s(literal -1/1440 binary64) (*.f64 a a) #s(literal 1/96 binary64)) (*.f64 a a)) #s(literal 1/4 binary64)) (*.f64 a a) (log.f64 #s(literal 1/4 binary64)))) |
#s(approx a a) |
#s(approx (* (log (+ 1 (exp a))) 2) (log.f64 #s(literal 4 binary64))) |
#s(approx (* (log (+ 1 (exp a))) 2) (-.f64 a (log.f64 #s(literal 1/4 binary64)))) |
#s(approx (* (log (+ 1 (exp a))) 2) (fma.f64 (fma.f64 #s(literal 1/4 binary64) a #s(literal 1 binary64)) a (log.f64 #s(literal 4 binary64)))) |
#s(approx (* (log (+ 1 (exp a))) 2) (fma.f64 (fma.f64 (fma.f64 #s(literal -1/96 binary64) (*.f64 a a) #s(literal 1/4 binary64)) a #s(literal 1 binary64)) a (log.f64 #s(literal 4 binary64)))) |
#s(approx (log (+ 1 (exp a))) (log.f64 #s(literal 2 binary64))) |
#s(approx (log (+ 1 (exp a))) (fma.f64 #s(literal 1/2 binary64) a (log.f64 #s(literal 2 binary64)))) |
#s(approx (log (+ 1 (exp a))) (fma.f64 (fma.f64 #s(literal 1/8 binary64) a #s(literal 1/2 binary64)) a (log.f64 #s(literal 2 binary64)))) |
#s(approx (log (+ 1 (exp a))) (fma.f64 (fma.f64 (fma.f64 #s(literal -1/192 binary64) (*.f64 a a) #s(literal 1/8 binary64)) a #s(literal 1/2 binary64)) a (log.f64 #s(literal 2 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 (/ (exp a) (- (exp a) -1)) #s(literal 1/2 binary64)) |
#s(approx (/ (exp a) (- (exp a) -1)) (fma.f64 #s(literal 1/4 binary64) a #s(literal 1/2 binary64))) |
#s(approx (/ (exp a) (- (exp a) -1)) (fma.f64 (fma.f64 (*.f64 a a) #s(literal -1/48 binary64) #s(literal 1/4 binary64)) a #s(literal 1/2 binary64))) |
#s(approx (/ (exp a) (- (exp a) -1)) (fma.f64 (fma.f64 (-.f64 (*.f64 #s(literal 1/480 binary64) (*.f64 a a)) #s(literal 1/48 binary64)) (*.f64 a a) #s(literal 1/4 binary64)) a #s(literal 1/2 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 (+ (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) (+ (exp a) (exp b))) (/.f64 (exp.f64 a) (+.f64 (exp.f64 b) (exp.f64 a)))) |
#s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) (fma.f64 (exp.f64 (-.f64 a (*.f64 (log1p.f64 (exp.f64 a)) #s(literal 2 binary64)))) (neg.f64 b) (/.f64 (exp.f64 a) (+.f64 #s(literal 1 binary64) (exp.f64 a))))) |
#s(approx (exp (- a (* (log (+ 1 (exp a))) 2))) (exp.f64 (-.f64 a (*.f64 (log1p.f64 (exp.f64 a)) #s(literal 2 binary64))))) |
#s(approx (- a (* (log (+ 1 (exp a))) 2)) a) |
#s(approx (- a (* (log (+ 1 (exp a))) 2)) (*.f64 (fma.f64 (/.f64 (log1p.f64 (exp.f64 a)) a) #s(literal -2 binary64) #s(literal 1 binary64)) a)) |
#s(approx (* (log (+ 1 (exp a))) 2) (*.f64 (log1p.f64 (exp.f64 a)) #s(literal 2 binary64))) |
#s(approx (log (+ 1 (exp a))) (log1p.f64 (exp.f64 a))) |
#s(approx (exp a) (exp.f64 a)) |
#s(approx (/ (exp a) (- (exp a) -1)) (/.f64 (exp.f64 a) (+.f64 #s(literal 1 binary64) (exp.f64 a)))) |
#s(approx (- (exp a) -1) (+.f64 #s(literal 1 binary64) (exp.f64 a))) |
#s(approx (+ (exp a) (exp b)) (+.f64 (exp.f64 b) (exp.f64 a))) |
#s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) (fma.f64 (neg.f64 b) (exp.f64 (neg.f64 (fma.f64 (log1p.f64 (exp.f64 a)) #s(literal 2 binary64) (neg.f64 a)))) (/.f64 (exp.f64 a) (+.f64 #s(literal 1 binary64) (exp.f64 a))))) |
#s(approx (exp (- a (* (log (+ 1 (exp a))) 2))) (exp.f64 (neg.f64 (fma.f64 (log1p.f64 (exp.f64 a)) #s(literal 2 binary64) (neg.f64 a))))) |
#s(approx (- a (* (log (+ 1 (exp a))) 2)) (*.f64 (neg.f64 a) (-.f64 (/.f64 (*.f64 (log1p.f64 (exp.f64 a)) #s(literal 2 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))) (fma.f64 (exp.f64 (-.f64 a (*.f64 (log1p.f64 (exp.f64 a)) #s(literal 2 binary64)))) (neg.f64 b) (/.f64 (exp.f64 a) (+.f64 #s(literal 1 binary64) (exp.f64 a))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (fma.f64 (-.f64 (*.f64 (neg.f64 b) (fma.f64 (exp.f64 (-.f64 a (*.f64 (log1p.f64 (exp.f64 a)) #s(literal 2 binary64)))) #s(literal 1/2 binary64) (neg.f64 (exp.f64 (-.f64 a (*.f64 (log1p.f64 (exp.f64 a)) #s(literal 3 binary64))))))) (exp.f64 (-.f64 a (*.f64 (log1p.f64 (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 a) (exp b))) (fma.f64 (-.f64 (*.f64 (-.f64 (*.f64 (neg.f64 b) (fma.f64 (/.f64 (fma.f64 (exp.f64 (-.f64 a (*.f64 (log1p.f64 (exp.f64 a)) #s(literal 2 binary64)))) #s(literal 1/2 binary64) (neg.f64 (exp.f64 (-.f64 a (*.f64 (log1p.f64 (exp.f64 a)) #s(literal 3 binary64)))))) (+.f64 #s(literal 1 binary64) (exp.f64 a))) #s(literal -1 binary64) (fma.f64 #s(literal -1/2 binary64) (exp.f64 (-.f64 a (*.f64 (log1p.f64 (exp.f64 a)) #s(literal 3 binary64)))) (*.f64 (exp.f64 (-.f64 a (*.f64 (log1p.f64 (exp.f64 a)) #s(literal 2 binary64)))) #s(literal 1/6 binary64))))) (fma.f64 (exp.f64 (-.f64 a (*.f64 (log1p.f64 (exp.f64 a)) #s(literal 2 binary64)))) #s(literal 1/2 binary64) (neg.f64 (exp.f64 (-.f64 a (*.f64 (log1p.f64 (exp.f64 a)) #s(literal 3 binary64))))))) b) (exp.f64 (-.f64 a (*.f64 (log1p.f64 (exp.f64 a)) #s(literal 2 binary64))))) b (/.f64 (exp.f64 a) (+.f64 #s(literal 1 binary64) (exp.f64 a))))) |
#s(approx (pow (- (exp b) -1) -1) #s(literal 1/2 binary64)) |
#s(approx (pow (- (exp b) -1) -1) (fma.f64 #s(literal -1/4 binary64) b #s(literal 1/2 binary64))) |
#s(approx (pow (- (exp b) -1) -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 (pow (- (exp b) -1) -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 (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) (/.f64 (exp.f64 a) (+.f64 #s(literal 1 binary64) (exp.f64 a)))) |
#s(approx (neg b) (neg.f64 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 (pow (- (exp b) -1) -1) (pow.f64 (+.f64 #s(literal 1 binary64) (exp.f64 b)) #s(literal -1 binary64))) |
#s(approx (- (exp b) -1) (+.f64 #s(literal 1 binary64) (exp.f64 b))) |
#s(approx (exp b) (exp.f64 b)) |
#s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) (*.f64 (exp.f64 (-.f64 a (*.f64 (log1p.f64 (exp.f64 a)) #s(literal 2 binary64)))) (neg.f64 b))) |
#s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) (*.f64 (fma.f64 (exp.f64 (-.f64 a (*.f64 (log1p.f64 (exp.f64 a)) #s(literal 2 binary64)))) #s(literal -1 binary64) (/.f64 (/.f64 (exp.f64 a) b) (+.f64 #s(literal 1 binary64) (exp.f64 a)))) b)) |
#s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) (*.f64 (neg.f64 b) (fma.f64 (exp.f64 a) (exp.f64 (*.f64 #s(literal -2 binary64) (log1p.f64 (exp.f64 a)))) (neg.f64 (/.f64 (/.f64 (exp.f64 a) b) (+.f64 #s(literal 1 binary64) (exp.f64 a))))))) |
Compiled 7 461 to 1 037 computations (86.1% saved)
11 alts after pruning (10 fresh and 1 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 226 | 10 | 236 |
| Fresh | 0 | 0 | 0 |
| Picked | 2 | 1 | 3 |
| Done | 0 | 0 | 0 |
| Total | 228 | 11 | 239 |
| Status | Accuracy | Program |
|---|---|---|
| ✓ | 66.5% | (/.f64 (exp.f64 a) (+.f64 (exp.f64 a) #s(approx (exp b) #s(literal 1 binary64)))) |
| 65.8% | (/.f64 (exp.f64 a) (+.f64 #s(approx (exp a) #s(literal 1 binary64)) #s(approx (exp b) #s(literal 1 binary64)))) | |
| 55.1% | #s(approx (/ (exp a) (+ (exp a) (exp b))) (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))) | |
| ▶ | 38.7% | #s(approx (/ (exp a) (+ (exp a) (exp b))) (pow.f64 #s(approx (- (exp b) -1) (+.f64 #s(literal 2 binary64) b)) #s(literal -1 binary64))) |
| ▶ | 81.5% | #s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) (-.f64 (exp.f64 b) #s(literal -1 binary64)))) |
| ▶ | 37.8% | #s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (pow (- (exp b) -1) -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)))) |
| 37.4% | #s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (pow (- (exp b) -1) -1) (fma.f64 (-.f64 (*.f64 (*.f64 b b) #s(literal 1/48 binary64)) #s(literal 1/4 binary64)) b #s(literal 1/2 binary64)))) | |
| 38.2% | #s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (pow (- (exp b) -1) -1) (fma.f64 #s(literal -1/4 binary64) b #s(literal 1/2 binary64)))) | |
| ▶ | 40.5% | #s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (pow (- (exp b) -1) -1) #s(literal 1/2 binary64))) |
| 38.1% | #s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) (+.f64 (fma.f64 (fma.f64 (fma.f64 #s(literal -1/48 binary64) a (*.f64 #s(literal 1/4 binary64) (*.f64 #s(literal 1/4 binary64) b))) a #s(literal 1/4 binary64)) a (*.f64 (neg.f64 b) #s(literal 1/4 binary64))) #s(literal 1/2 binary64)))) | |
| ▶ | 38.2% | #s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) (+.f64 (fma.f64 #s(literal 1/4 binary64) a (*.f64 (neg.f64 b) #s(literal 1/4 binary64))) #s(literal 1/2 binary64)))) |
Compiled 516 to 360 computations (30.2% 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) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (pow (- (exp b) -1) -1) #s(literal 1/2 binary64))) |
#s(approx (pow (- (exp b) -1) -1) #s(literal 1/2 binary64)) |
#s(literal 1/2 binary64) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) (+.f64 (fma.f64 #s(literal 1/4 binary64) a (*.f64 (neg.f64 b) #s(literal 1/4 binary64))) #s(literal 1/2 binary64)))) |
#s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) (+.f64 (fma.f64 #s(literal 1/4 binary64) a (*.f64 (neg.f64 b) #s(literal 1/4 binary64))) #s(literal 1/2 binary64))) |
(+.f64 (fma.f64 #s(literal 1/4 binary64) a (*.f64 (neg.f64 b) #s(literal 1/4 binary64))) #s(literal 1/2 binary64)) |
(fma.f64 #s(literal 1/4 binary64) a (*.f64 (neg.f64 b) #s(literal 1/4 binary64))) |
#s(literal 1/4 binary64) |
a |
(*.f64 (neg.f64 b) #s(literal 1/4 binary64)) |
(neg.f64 b) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (pow (- (exp b) -1) -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 (pow (- (exp b) -1) -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))) |
(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)) |
(-.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)) |
(*.f64 (fma.f64 #s(literal -1/480 binary64) (*.f64 b b) #s(literal 1/48 binary64)) (*.f64 b b)) |
(fma.f64 #s(literal -1/480 binary64) (*.f64 b b) #s(literal 1/48 binary64)) |
#s(literal -1/480 binary64) |
(*.f64 b b) |
#s(literal 1/48 binary64) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (pow.f64 #s(approx (- (exp b) -1) (+.f64 #s(literal 2 binary64) b)) #s(literal -1 binary64))) |
(pow.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 #s(literal 2 binary64) b) |
#s(literal 2 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 (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(hole binary64 (+ 1/2 (* -1 (* b (exp (neg (* 2 (log 2))))))))) |
#s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(hole binary64 (+ 1/2 (+ (* -1 (* b (exp (neg (* 2 (log 2)))))) (* 1/4 a))))) |
#s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(hole binary64 (+ 1/2 (+ (* -1 (* b (exp (neg (* 2 (log 2)))))) (* a (+ 1/4 (* 1/4 (* a (* b (exp (neg (* 2 (log 2))))))))))))) |
#s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(hole binary64 (+ 1/2 (+ (* -1 (* b (exp (neg (* 2 (log 2)))))) (* a (+ 1/4 (* a (+ (* -1/48 a) (* 1/4 (* b (exp (neg (* 2 (log 2)))))))))))))) |
#s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) #s(hole binary64 (+ 1/2 (* -1/4 b)))) |
#s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) #s(hole binary64 (+ 1/2 (+ (* -1/4 b) (* 1/4 a))))) |
#s(approx (+ (* 1/4 a) (* (neg b) 1/4)) #s(hole binary64 (* -1/4 b))) |
#s(approx (+ (* 1/4 a) (* (neg b) 1/4)) #s(hole binary64 (+ (* -1/4 b) (* 1/4 a)))) |
#s(approx a #s(hole binary64 a)) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(hole binary64 (/ (exp a) (+ (exp a) (exp b))))) |
#s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(hole binary64 (+ (* -1 (* b (exp (- a (* 2 (log (+ 1 (exp a)))))))) (/ (exp a) (+ 1 (exp a)))))) |
#s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) #s(hole binary64 (* 1/4 a))) |
#s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) #s(hole binary64 (* a (+ 1/4 (+ (* -1/4 (/ b a)) (* 1/2 (/ 1 a))))))) |
#s(approx (+ (* 1/4 a) (* (neg b) 1/4)) #s(hole binary64 (* 1/4 a))) |
#s(approx (+ (* 1/4 a) (* (neg b) 1/4)) #s(hole binary64 (* a (+ 1/4 (* -1/4 (/ b a)))))) |
#s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(hole binary64 (+ (* -1 (* b (exp (neg (+ (* -1 a) (* 2 (log (+ 1 (exp a))))))))) (/ (exp a) (+ 1 (exp a)))))) |
#s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) #s(hole binary64 (* -1 (* a (- (* -1 (/ (+ 1/2 (* -1/4 b)) a)) 1/4))))) |
#s(approx (+ (* 1/4 a) (* (neg b) 1/4)) #s(hole binary64 (* -1 (* a (- (* 1/4 (/ b a)) 1/4))))) |
#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 (pow (- (exp b) -1) -1) #s(hole binary64 1/2)) |
#s(approx (pow (- (exp b) -1) -1) #s(hole binary64 (+ 1/2 (* -1/4 b)))) |
#s(approx (pow (- (exp b) -1) -1) #s(hole binary64 (+ 1/2 (* b (- (* 1/48 (pow b 2)) 1/4))))) |
#s(approx (pow (- (exp b) -1) -1) #s(hole binary64 (+ 1/2 (* b (- (* (pow b 2) (+ 1/48 (* -1/480 (pow b 2)))) 1/4))))) |
#s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(hole binary64 (/ (exp a) (+ 1 (exp a))))) |
#s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) #s(hole binary64 (+ 1/2 (* 1/4 a)))) |
#s(approx (* (neg b) 1/4) #s(hole binary64 (* -1/4 b))) |
#s(approx (neg b) #s(hole binary64 (* -1 b))) |
#s(approx (+ (* (- (* (+ (* -1/480 (* b b)) 1/48) (* b b)) 1/4) b) 1/2) #s(hole binary64 1/2)) |
#s(approx (+ (* (- (* (+ (* -1/480 (* b b)) 1/48) (* b b)) 1/4) b) 1/2) #s(hole binary64 (+ 1/2 (* -1/4 b)))) |
#s(approx (+ (* (- (* (+ (* -1/480 (* b b)) 1/48) (* b b)) 1/4) b) 1/2) #s(hole binary64 (+ 1/2 (* b (- (* 1/48 (pow b 2)) 1/4))))) |
#s(approx (+ (* (- (* (+ (* -1/480 (* b b)) 1/48) (* b b)) 1/4) b) 1/2) #s(hole binary64 (+ 1/2 (* b (- (* (pow b 2) (+ 1/48 (* -1/480 (pow b 2)))) 1/4))))) |
#s(approx (- (* (+ (* -1/480 (* b b)) 1/48) (* b b)) 1/4) #s(hole binary64 -1/4)) |
#s(approx (- (* (+ (* -1/480 (* b b)) 1/48) (* b b)) 1/4) #s(hole binary64 (- (* 1/48 (pow b 2)) 1/4))) |
#s(approx (- (* (+ (* -1/480 (* b b)) 1/48) (* b b)) 1/4) #s(hole binary64 (- (* (pow b 2) (+ 1/48 (* -1/480 (pow b 2)))) 1/4))) |
#s(approx (* (+ (* -1/480 (* b b)) 1/48) (* b b)) #s(hole binary64 (* 1/48 (pow b 2)))) |
#s(approx (* (+ (* -1/480 (* b b)) 1/48) (* b b)) #s(hole binary64 (* (pow b 2) (+ 1/48 (* -1/480 (pow b 2)))))) |
#s(approx (+ (* -1/480 (* b b)) 1/48) #s(hole binary64 1/48)) |
#s(approx (+ (* -1/480 (* b b)) 1/48) #s(hole binary64 (+ 1/48 (* -1/480 (pow b 2))))) |
#s(approx (* b b) #s(hole binary64 (pow b 2))) |
#s(approx (+ 2 b) #s(hole binary64 2)) |
#s(approx (+ 2 b) #s(hole binary64 (+ 2 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))) |
#s(approx (pow (- (exp b) -1) -1) #s(hole binary64 (/ 1 (+ 1 (exp b))))) |
#s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(hole binary64 (* -1 (* b (exp (- a (* 2 (log (+ 1 (exp a)))))))))) |
#s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(hole binary64 (* b (+ (* -1 (exp (- a (* 2 (log (+ 1 (exp a))))))) (/ (exp a) (* b (+ 1 (exp a)))))))) |
#s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) #s(hole binary64 (* -1/4 b))) |
#s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) #s(hole binary64 (* b (- (+ (* 1/4 (/ a b)) (* 1/2 (/ 1 b))) 1/4)))) |
#s(approx (+ (* 1/4 a) (* (neg b) 1/4)) #s(hole binary64 (* b (- (* 1/4 (/ a b)) 1/4)))) |
#s(approx (+ (* (- (* (+ (* -1/480 (* b b)) 1/48) (* b b)) 1/4) b) 1/2) #s(hole binary64 (* -1/480 (pow b 5)))) |
#s(approx (+ (* (- (* (+ (* -1/480 (* b b)) 1/48) (* b b)) 1/4) b) 1/2) #s(hole binary64 (* (pow b 5) (- (* 1/48 (/ 1 (pow b 2))) 1/480)))) |
#s(approx (+ (* (- (* (+ (* -1/480 (* b b)) 1/48) (* b b)) 1/4) b) 1/2) #s(hole binary64 (* (pow b 5) (- (* 1/48 (/ 1 (pow b 2))) (+ 1/480 (/ 1/4 (pow b 4))))))) |
#s(approx (+ (* (- (* (+ (* -1/480 (* b b)) 1/48) (* b b)) 1/4) b) 1/2) #s(hole binary64 (* (pow b 5) (- (+ (* 1/48 (/ 1 (pow b 2))) (* 1/2 (/ 1 (pow b 5)))) (+ 1/480 (/ 1/4 (pow b 4))))))) |
#s(approx (- (* (+ (* -1/480 (* b b)) 1/48) (* b b)) 1/4) #s(hole binary64 (* -1/480 (pow b 4)))) |
#s(approx (- (* (+ (* -1/480 (* b b)) 1/48) (* b b)) 1/4) #s(hole binary64 (* (pow b 4) (- (* 1/48 (/ 1 (pow b 2))) 1/480)))) |
#s(approx (- (* (+ (* -1/480 (* b b)) 1/48) (* b b)) 1/4) #s(hole binary64 (* (pow b 4) (- (* 1/48 (/ 1 (pow b 2))) (+ 1/480 (/ 1/4 (pow b 4))))))) |
#s(approx (* (+ (* -1/480 (* b b)) 1/48) (* b b)) #s(hole binary64 (* -1/480 (pow b 4)))) |
#s(approx (* (+ (* -1/480 (* b b)) 1/48) (* b b)) #s(hole binary64 (* (pow b 4) (- (* 1/48 (/ 1 (pow b 2))) 1/480)))) |
#s(approx (+ (* -1/480 (* b b)) 1/48) #s(hole binary64 (* -1/480 (pow b 2)))) |
#s(approx (+ (* -1/480 (* b b)) 1/48) #s(hole binary64 (* (pow b 2) (- (* 1/48 (/ 1 (pow b 2))) 1/480)))) |
#s(approx (+ 2 b) #s(hole binary64 b)) |
#s(approx (+ 2 b) #s(hole binary64 (* b (+ 1 (* 2 (/ 1 b)))))) |
#s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(hole binary64 (* -1 (* b (+ (exp (- a (* 2 (log (+ 1 (exp a)))))) (* -1 (/ (exp a) (* b (+ 1 (exp a)))))))))) |
#s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) #s(hole binary64 (* -1 (* b (+ 1/4 (* -1 (/ (+ 1/2 (* 1/4 a)) b))))))) |
#s(approx (+ (* 1/4 a) (* (neg b) 1/4)) #s(hole binary64 (* -1 (* b (+ 1/4 (* -1/4 (/ a b))))))) |
#s(approx (+ (* (- (* (+ (* -1/480 (* b b)) 1/48) (* b b)) 1/4) b) 1/2) #s(hole binary64 (* -1 (* (pow b 5) (- 1/480 (* 1/48 (/ 1 (pow b 2)))))))) |
#s(approx (+ (* (- (* (+ (* -1/480 (* b b)) 1/48) (* b b)) 1/4) b) 1/2) #s(hole binary64 (* -1 (* (pow b 5) (- (+ 1/480 (/ 1/4 (pow b 4))) (* 1/48 (/ 1 (pow b 2)))))))) |
#s(approx (+ (* (- (* (+ (* -1/480 (* b b)) 1/48) (* b b)) 1/4) b) 1/2) #s(hole binary64 (* -1 (* (pow b 5) (- (+ 1/480 (/ 1/4 (pow b 4))) (+ (* 1/48 (/ 1 (pow b 2))) (* 1/2 (/ 1 (pow b 5))))))))) |
6 calls:
| Time | Variable | Point | Expression | |
|---|---|---|---|---|
| 7.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))) (pow (- (exp b) -1) -1) 1/2 (/ (exp a) (+ (exp a) (exp b))) (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) (+ (* 1/4 a) (* (neg b) 1/4)) 1/4 a (* (neg b) 1/4) (neg b) (/ (exp a) (+ (exp a) (exp b))) (pow (- (exp b) -1) -1) (+ (* (- (* (+ (* -1/480 (* b b)) 1/48) (* b b)) 1/4) b) 1/2) (- (* (+ (* -1/480 (* b b)) 1/48) (* b b)) 1/4) (* (+ (* -1/480 (* b b)) 1/48) (* b b)) (+ (* -1/480 (* b b)) 1/48) -1/480 (* b b) 1/48 (/ (exp a) (+ (exp a) (exp b))) (pow (- (exp b) -1) -1) (- (exp b) -1) (+ 2 b) 2) |
| 5.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))) (pow (- (exp b) -1) -1) 1/2 (/ (exp a) (+ (exp a) (exp b))) (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) (+ (* 1/4 a) (* (neg b) 1/4)) 1/4 a (* (neg b) 1/4) (neg b) (/ (exp a) (+ (exp a) (exp b))) (pow (- (exp b) -1) -1) (+ (* (- (* (+ (* -1/480 (* b b)) 1/48) (* b b)) 1/4) b) 1/2) (- (* (+ (* -1/480 (* b b)) 1/48) (* b b)) 1/4) (* (+ (* -1/480 (* b b)) 1/48) (* b b)) (+ (* -1/480 (* b b)) 1/48) -1/480 (* b b) 1/48 (/ (exp a) (+ (exp a) (exp b))) (pow (- (exp b) -1) -1) (- (exp b) -1) (+ 2 b) 2) |
| 5.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))) (pow (- (exp b) -1) -1) 1/2 (/ (exp a) (+ (exp a) (exp b))) (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) (+ (* 1/4 a) (* (neg b) 1/4)) 1/4 a (* (neg b) 1/4) (neg b) (/ (exp a) (+ (exp a) (exp b))) (pow (- (exp b) -1) -1) (+ (* (- (* (+ (* -1/480 (* b b)) 1/48) (* b b)) 1/4) b) 1/2) (- (* (+ (* -1/480 (* b b)) 1/48) (* b b)) 1/4) (* (+ (* -1/480 (* b b)) 1/48) (* b b)) (+ (* -1/480 (* b b)) 1/48) -1/480 (* b b) 1/48 (/ (exp a) (+ (exp a) (exp b))) (pow (- (exp b) -1) -1) (- (exp b) -1) (+ 2 b) 2) |
| 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))) (pow (- (exp b) -1) -1) 1/2 (/ (exp a) (+ (exp a) (exp b))) (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) (+ (* 1/4 a) (* (neg b) 1/4)) 1/4 a (* (neg b) 1/4) (neg b) (/ (exp a) (+ (exp a) (exp b))) (pow (- (exp b) -1) -1) (+ (* (- (* (+ (* -1/480 (* b b)) 1/48) (* b b)) 1/4) b) 1/2) (- (* (+ (* -1/480 (* b b)) 1/48) (* b b)) 1/4) (* (+ (* -1/480 (* b b)) 1/48) (* b b)) (+ (* -1/480 (* b b)) 1/48) -1/480 (* b b) 1/48 (/ (exp a) (+ (exp a) (exp b))) (pow (- (exp b) -1) -1) (- (exp b) -1) (+ 2 b) 2) |
| 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))) (pow (- (exp b) -1) -1) 1/2 (/ (exp a) (+ (exp a) (exp b))) (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) (+ (* 1/4 a) (* (neg b) 1/4)) 1/4 a (* (neg b) 1/4) (neg b) (/ (exp a) (+ (exp a) (exp b))) (pow (- (exp b) -1) -1) (+ (* (- (* (+ (* -1/480 (* b b)) 1/48) (* b b)) 1/4) b) 1/2) (- (* (+ (* -1/480 (* b b)) 1/48) (* b b)) 1/4) (* (+ (* -1/480 (* b b)) 1/48) (* b b)) (+ (* -1/480 (* b b)) 1/48) -1/480 (* b b) 1/48 (/ (exp a) (+ (exp a) (exp b))) (pow (- (exp b) -1) -1) (- (exp b) -1) (+ 2 b) 2) |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 371 | 2401 |
| 0 | 395 | 2268 |
| 1 | 2064 | 2244 |
| 0 | 9092 | 2138 |
| 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) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (pow (- (exp b) -1) -1) #s(literal 1/2 binary64))) |
#s(approx (pow (- (exp b) -1) -1) #s(literal 1/2 binary64)) |
#s(literal 1/2 binary64) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) (+.f64 (fma.f64 #s(literal 1/4 binary64) a (*.f64 (neg.f64 b) #s(literal 1/4 binary64))) #s(literal 1/2 binary64)))) |
#s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) (+.f64 (fma.f64 #s(literal 1/4 binary64) a (*.f64 (neg.f64 b) #s(literal 1/4 binary64))) #s(literal 1/2 binary64))) |
(+.f64 (fma.f64 #s(literal 1/4 binary64) a (*.f64 (neg.f64 b) #s(literal 1/4 binary64))) #s(literal 1/2 binary64)) |
(fma.f64 #s(literal 1/4 binary64) a (*.f64 (neg.f64 b) #s(literal 1/4 binary64))) |
#s(literal 1/4 binary64) |
a |
(*.f64 (neg.f64 b) #s(literal 1/4 binary64)) |
(neg.f64 b) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (pow (- (exp b) -1) -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 (pow (- (exp b) -1) -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))) |
(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)) |
(-.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)) |
(*.f64 (fma.f64 #s(literal -1/480 binary64) (*.f64 b b) #s(literal 1/48 binary64)) (*.f64 b b)) |
(fma.f64 #s(literal -1/480 binary64) (*.f64 b b) #s(literal 1/48 binary64)) |
#s(literal -1/480 binary64) |
(*.f64 b b) |
#s(literal 1/48 binary64) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (pow.f64 #s(approx (- (exp b) -1) (+.f64 #s(literal 2 binary64) b)) #s(literal -1 binary64))) |
(pow.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 #s(literal 2 binary64) b) |
#s(literal 2 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 (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(hole binary64 (+ 1/2 (* -1 (* b (exp (neg (* 2 (log 2))))))))) |
#s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(hole binary64 (+ 1/2 (+ (* -1 (* b (exp (neg (* 2 (log 2)))))) (* 1/4 a))))) |
#s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(hole binary64 (+ 1/2 (+ (* -1 (* b (exp (neg (* 2 (log 2)))))) (* a (+ 1/4 (* 1/4 (* a (* b (exp (neg (* 2 (log 2))))))))))))) |
#s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(hole binary64 (+ 1/2 (+ (* -1 (* b (exp (neg (* 2 (log 2)))))) (* a (+ 1/4 (* a (+ (* -1/48 a) (* 1/4 (* b (exp (neg (* 2 (log 2)))))))))))))) |
#s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) #s(hole binary64 (+ 1/2 (* -1/4 b)))) |
#s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) #s(hole binary64 (+ 1/2 (+ (* -1/4 b) (* 1/4 a))))) |
#s(approx (+ (* 1/4 a) (* (neg b) 1/4)) #s(hole binary64 (* -1/4 b))) |
#s(approx (+ (* 1/4 a) (* (neg b) 1/4)) #s(hole binary64 (+ (* -1/4 b) (* 1/4 a)))) |
#s(approx a #s(hole binary64 a)) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(hole binary64 (/ (exp a) (+ (exp a) (exp b))))) |
#s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(hole binary64 (+ (* -1 (* b (exp (- a (* 2 (log (+ 1 (exp a)))))))) (/ (exp a) (+ 1 (exp a)))))) |
#s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) #s(hole binary64 (* 1/4 a))) |
#s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) #s(hole binary64 (* a (+ 1/4 (+ (* -1/4 (/ b a)) (* 1/2 (/ 1 a))))))) |
#s(approx (+ (* 1/4 a) (* (neg b) 1/4)) #s(hole binary64 (* 1/4 a))) |
#s(approx (+ (* 1/4 a) (* (neg b) 1/4)) #s(hole binary64 (* a (+ 1/4 (* -1/4 (/ b a)))))) |
#s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(hole binary64 (+ (* -1 (* b (exp (neg (+ (* -1 a) (* 2 (log (+ 1 (exp a))))))))) (/ (exp a) (+ 1 (exp a)))))) |
#s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) #s(hole binary64 (* -1 (* a (- (* -1 (/ (+ 1/2 (* -1/4 b)) a)) 1/4))))) |
#s(approx (+ (* 1/4 a) (* (neg b) 1/4)) #s(hole binary64 (* -1 (* a (- (* 1/4 (/ b a)) 1/4))))) |
#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 (pow (- (exp b) -1) -1) #s(hole binary64 1/2)) |
#s(approx (pow (- (exp b) -1) -1) #s(hole binary64 (+ 1/2 (* -1/4 b)))) |
#s(approx (pow (- (exp b) -1) -1) #s(hole binary64 (+ 1/2 (* b (- (* 1/48 (pow b 2)) 1/4))))) |
#s(approx (pow (- (exp b) -1) -1) #s(hole binary64 (+ 1/2 (* b (- (* (pow b 2) (+ 1/48 (* -1/480 (pow b 2)))) 1/4))))) |
#s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(hole binary64 (/ (exp a) (+ 1 (exp a))))) |
#s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) #s(hole binary64 (+ 1/2 (* 1/4 a)))) |
#s(approx (* (neg b) 1/4) #s(hole binary64 (* -1/4 b))) |
#s(approx (neg b) #s(hole binary64 (* -1 b))) |
#s(approx (+ (* (- (* (+ (* -1/480 (* b b)) 1/48) (* b b)) 1/4) b) 1/2) #s(hole binary64 1/2)) |
#s(approx (+ (* (- (* (+ (* -1/480 (* b b)) 1/48) (* b b)) 1/4) b) 1/2) #s(hole binary64 (+ 1/2 (* -1/4 b)))) |
#s(approx (+ (* (- (* (+ (* -1/480 (* b b)) 1/48) (* b b)) 1/4) b) 1/2) #s(hole binary64 (+ 1/2 (* b (- (* 1/48 (pow b 2)) 1/4))))) |
#s(approx (+ (* (- (* (+ (* -1/480 (* b b)) 1/48) (* b b)) 1/4) b) 1/2) #s(hole binary64 (+ 1/2 (* b (- (* (pow b 2) (+ 1/48 (* -1/480 (pow b 2)))) 1/4))))) |
#s(approx (- (* (+ (* -1/480 (* b b)) 1/48) (* b b)) 1/4) #s(hole binary64 -1/4)) |
#s(approx (- (* (+ (* -1/480 (* b b)) 1/48) (* b b)) 1/4) #s(hole binary64 (- (* 1/48 (pow b 2)) 1/4))) |
#s(approx (- (* (+ (* -1/480 (* b b)) 1/48) (* b b)) 1/4) #s(hole binary64 (- (* (pow b 2) (+ 1/48 (* -1/480 (pow b 2)))) 1/4))) |
#s(approx (* (+ (* -1/480 (* b b)) 1/48) (* b b)) #s(hole binary64 (* 1/48 (pow b 2)))) |
#s(approx (* (+ (* -1/480 (* b b)) 1/48) (* b b)) #s(hole binary64 (* (pow b 2) (+ 1/48 (* -1/480 (pow b 2)))))) |
#s(approx (+ (* -1/480 (* b b)) 1/48) #s(hole binary64 1/48)) |
#s(approx (+ (* -1/480 (* b b)) 1/48) #s(hole binary64 (+ 1/48 (* -1/480 (pow b 2))))) |
#s(approx (* b b) #s(hole binary64 (pow b 2))) |
#s(approx (+ 2 b) #s(hole binary64 2)) |
#s(approx (+ 2 b) #s(hole binary64 (+ 2 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))) |
#s(approx (pow (- (exp b) -1) -1) #s(hole binary64 (/ 1 (+ 1 (exp b))))) |
#s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(hole binary64 (* -1 (* b (exp (- a (* 2 (log (+ 1 (exp a)))))))))) |
#s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(hole binary64 (* b (+ (* -1 (exp (- a (* 2 (log (+ 1 (exp a))))))) (/ (exp a) (* b (+ 1 (exp a)))))))) |
#s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) #s(hole binary64 (* -1/4 b))) |
#s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) #s(hole binary64 (* b (- (+ (* 1/4 (/ a b)) (* 1/2 (/ 1 b))) 1/4)))) |
#s(approx (+ (* 1/4 a) (* (neg b) 1/4)) #s(hole binary64 (* b (- (* 1/4 (/ a b)) 1/4)))) |
#s(approx (+ (* (- (* (+ (* -1/480 (* b b)) 1/48) (* b b)) 1/4) b) 1/2) #s(hole binary64 (* -1/480 (pow b 5)))) |
#s(approx (+ (* (- (* (+ (* -1/480 (* b b)) 1/48) (* b b)) 1/4) b) 1/2) #s(hole binary64 (* (pow b 5) (- (* 1/48 (/ 1 (pow b 2))) 1/480)))) |
#s(approx (+ (* (- (* (+ (* -1/480 (* b b)) 1/48) (* b b)) 1/4) b) 1/2) #s(hole binary64 (* (pow b 5) (- (* 1/48 (/ 1 (pow b 2))) (+ 1/480 (/ 1/4 (pow b 4))))))) |
#s(approx (+ (* (- (* (+ (* -1/480 (* b b)) 1/48) (* b b)) 1/4) b) 1/2) #s(hole binary64 (* (pow b 5) (- (+ (* 1/48 (/ 1 (pow b 2))) (* 1/2 (/ 1 (pow b 5)))) (+ 1/480 (/ 1/4 (pow b 4))))))) |
#s(approx (- (* (+ (* -1/480 (* b b)) 1/48) (* b b)) 1/4) #s(hole binary64 (* -1/480 (pow b 4)))) |
#s(approx (- (* (+ (* -1/480 (* b b)) 1/48) (* b b)) 1/4) #s(hole binary64 (* (pow b 4) (- (* 1/48 (/ 1 (pow b 2))) 1/480)))) |
#s(approx (- (* (+ (* -1/480 (* b b)) 1/48) (* b b)) 1/4) #s(hole binary64 (* (pow b 4) (- (* 1/48 (/ 1 (pow b 2))) (+ 1/480 (/ 1/4 (pow b 4))))))) |
#s(approx (* (+ (* -1/480 (* b b)) 1/48) (* b b)) #s(hole binary64 (* -1/480 (pow b 4)))) |
#s(approx (* (+ (* -1/480 (* b b)) 1/48) (* b b)) #s(hole binary64 (* (pow b 4) (- (* 1/48 (/ 1 (pow b 2))) 1/480)))) |
#s(approx (+ (* -1/480 (* b b)) 1/48) #s(hole binary64 (* -1/480 (pow b 2)))) |
#s(approx (+ (* -1/480 (* b b)) 1/48) #s(hole binary64 (* (pow b 2) (- (* 1/48 (/ 1 (pow b 2))) 1/480)))) |
#s(approx (+ 2 b) #s(hole binary64 b)) |
#s(approx (+ 2 b) #s(hole binary64 (* b (+ 1 (* 2 (/ 1 b)))))) |
#s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(hole binary64 (* -1 (* b (+ (exp (- a (* 2 (log (+ 1 (exp a)))))) (* -1 (/ (exp a) (* b (+ 1 (exp a)))))))))) |
#s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) #s(hole binary64 (* -1 (* b (+ 1/4 (* -1 (/ (+ 1/2 (* 1/4 a)) b))))))) |
#s(approx (+ (* 1/4 a) (* (neg b) 1/4)) #s(hole binary64 (* -1 (* b (+ 1/4 (* -1/4 (/ a b))))))) |
#s(approx (+ (* (- (* (+ (* -1/480 (* b b)) 1/48) (* b b)) 1/4) b) 1/2) #s(hole binary64 (* -1 (* (pow b 5) (- 1/480 (* 1/48 (/ 1 (pow b 2)))))))) |
#s(approx (+ (* (- (* (+ (* -1/480 (* b b)) 1/48) (* b b)) 1/4) b) 1/2) #s(hole binary64 (* -1 (* (pow b 5) (- (+ 1/480 (/ 1/4 (pow b 4))) (* 1/48 (/ 1 (pow b 2)))))))) |
#s(approx (+ (* (- (* (+ (* -1/480 (* b b)) 1/48) (* b b)) 1/4) b) 1/2) #s(hole binary64 (* -1 (* (pow b 5) (- (+ 1/480 (/ 1/4 (pow b 4))) (+ (* 1/48 (/ 1 (pow b 2))) (* 1/2 (/ 1 (pow b 5))))))))) |
| Outputs |
|---|
#s(approx (/ (exp a) (+ (exp a) (exp b))) (pow.f64 (-.f64 (exp.f64 b) #s(literal -1 binary64)) #s(literal -1 binary64))) |
(*.f64 (neg.f64 (pow.f64 (-.f64 (exp.f64 b) #s(literal -1 binary64)) #s(literal -1/2 binary64))) (neg.f64 (pow.f64 (-.f64 (exp.f64 b) #s(literal -1 binary64)) #s(literal -1/2 binary64)))) |
(*.f64 (fabs.f64 (pow.f64 (-.f64 (exp.f64 b) #s(literal -1 binary64)) #s(literal -1/2 binary64))) (fabs.f64 (pow.f64 (-.f64 (exp.f64 b) #s(literal -1 binary64)) #s(literal -1/2 binary64)))) |
(*.f64 (pow.f64 (-.f64 (exp.f64 b) #s(literal -1 binary64)) #s(literal -1/2 binary64)) (pow.f64 (-.f64 (exp.f64 b) #s(literal -1 binary64)) #s(literal -1/2 binary64))) |
(pow.f64 (exp.f64 (log.f64 (-.f64 (exp.f64 b) #s(literal -1 binary64)))) #s(literal -1 binary64)) |
(pow.f64 (*.f64 (-.f64 (exp.f64 b) #s(literal -1 binary64)) (-.f64 (exp.f64 b) #s(literal -1 binary64))) #s(literal -1/2 binary64)) |
(pow.f64 (pow.f64 (-.f64 (exp.f64 b) #s(literal -1 binary64)) #s(literal -1/2 binary64)) #s(literal 2 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))) |
(+.f64 (cosh.f64 (*.f64 (log.f64 (-.f64 (exp.f64 b) #s(literal -1 binary64))) #s(literal -1 binary64))) (sinh.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 (pow.f64 (exp.f64 b) #s(literal 3 binary64)) #s(literal -1 binary64))) (neg.f64 (fma.f64 (exp.f64 b) (exp.f64 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 (pow.f64 (exp.f64 b) #s(literal 3 binary64)) #s(literal -1 binary64)) (fma.f64 (exp.f64 b) (exp.f64 b) (+.f64 #s(literal 1 binary64) (*.f64 (exp.f64 b) #s(literal -1 binary64))))) |
(-.f64 (/.f64 (pow.f64 (exp.f64 b) #s(literal 2 binary64)) (+.f64 (exp.f64 b) #s(literal -1 binary64))) (/.f64 #s(literal 1 binary64) (+.f64 (exp.f64 b) #s(literal -1 binary64)))) |
(-.f64 (/.f64 (pow.f64 (exp.f64 b) #s(literal 3 binary64)) (fma.f64 (exp.f64 b) (exp.f64 b) (+.f64 #s(literal 1 binary64) (*.f64 (exp.f64 b) #s(literal -1 binary64))))) (/.f64 #s(literal -1 binary64) (fma.f64 (exp.f64 b) (exp.f64 b) (+.f64 #s(literal 1 binary64) (*.f64 (exp.f64 b) #s(literal -1 binary64)))))) |
(-.f64 (exp.f64 b) #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))))) |
(exp.f64 b) |
(+.f64 (cosh.f64 b) (sinh.f64 b)) |
b |
#s(literal -1 binary64) |
#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))) #s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) (fma.f64 #s(literal 1/4 binary64) a (fma.f64 #s(literal 1/4 binary64) (neg.f64 b) #s(literal 1/2 binary64))))) |
#s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) (fma.f64 #s(literal 1/4 binary64) a (fma.f64 #s(literal 1/4 binary64) (neg.f64 b) #s(literal 1/2 binary64)))) |
(/.f64 (fma.f64 (pow.f64 a #s(literal 3 binary64)) #s(literal 1/64 binary64) (pow.f64 (fma.f64 #s(literal 1/4 binary64) (neg.f64 b) #s(literal 1/2 binary64)) #s(literal 3 binary64))) (+.f64 (pow.f64 (*.f64 #s(literal 1/4 binary64) a) #s(literal 2 binary64)) (-.f64 (*.f64 (fma.f64 #s(literal 1/4 binary64) (neg.f64 b) #s(literal 1/2 binary64)) (fma.f64 #s(literal 1/4 binary64) (neg.f64 b) #s(literal 1/2 binary64))) (*.f64 (*.f64 #s(literal 1/4 binary64) a) (fma.f64 #s(literal 1/4 binary64) (neg.f64 b) #s(literal 1/2 binary64)))))) |
(/.f64 (+.f64 (pow.f64 (fma.f64 #s(literal 1/4 binary64) (neg.f64 b) #s(literal 1/2 binary64)) #s(literal 3 binary64)) (pow.f64 (*.f64 #s(literal 1/4 binary64) a) #s(literal 3 binary64))) (fma.f64 (fma.f64 #s(literal 1/4 binary64) (neg.f64 b) #s(literal 1/2 binary64)) (fma.f64 #s(literal 1/4 binary64) (neg.f64 b) #s(literal 1/2 binary64)) (-.f64 (pow.f64 (*.f64 #s(literal 1/4 binary64) a) #s(literal 2 binary64)) (*.f64 (fma.f64 #s(literal 1/4 binary64) (neg.f64 b) #s(literal 1/2 binary64)) (*.f64 #s(literal 1/4 binary64) a))))) |
(/.f64 (neg.f64 (-.f64 (pow.f64 (fma.f64 #s(literal 1/4 binary64) (neg.f64 b) (*.f64 #s(literal 1/4 binary64) a)) #s(literal 2 binary64)) #s(literal 1/4 binary64))) (neg.f64 (-.f64 (fma.f64 #s(literal 1/4 binary64) (neg.f64 b) (*.f64 #s(literal 1/4 binary64) a)) #s(literal 1/2 binary64)))) |
(/.f64 (neg.f64 (+.f64 (pow.f64 (fma.f64 #s(literal 1/4 binary64) (neg.f64 b) (*.f64 #s(literal 1/4 binary64) a)) #s(literal 3 binary64)) #s(literal 1/8 binary64))) (neg.f64 (+.f64 (pow.f64 (fma.f64 #s(literal 1/4 binary64) (neg.f64 b) (*.f64 #s(literal 1/4 binary64) a)) #s(literal 2 binary64)) (-.f64 #s(literal 1/4 binary64) (*.f64 (fma.f64 #s(literal 1/4 binary64) (neg.f64 b) (*.f64 #s(literal 1/4 binary64) a)) #s(literal 1/2 binary64)))))) |
(/.f64 (neg.f64 (-.f64 #s(literal 1/4 binary64) (pow.f64 (fma.f64 #s(literal 1/4 binary64) (neg.f64 b) (*.f64 #s(literal 1/4 binary64) a)) #s(literal 2 binary64)))) (neg.f64 (-.f64 #s(literal 1/2 binary64) (fma.f64 #s(literal 1/4 binary64) (neg.f64 b) (*.f64 #s(literal 1/4 binary64) a))))) |
(/.f64 (neg.f64 (+.f64 #s(literal 1/8 binary64) (pow.f64 (fma.f64 #s(literal 1/4 binary64) (neg.f64 b) (*.f64 #s(literal 1/4 binary64) a)) #s(literal 3 binary64)))) (neg.f64 (+.f64 #s(literal 1/4 binary64) (-.f64 (pow.f64 (fma.f64 #s(literal 1/4 binary64) (neg.f64 b) (*.f64 #s(literal 1/4 binary64) a)) #s(literal 2 binary64)) (*.f64 #s(literal 1/2 binary64) (fma.f64 #s(literal 1/4 binary64) (neg.f64 b) (*.f64 #s(literal 1/4 binary64) a))))))) |
(/.f64 (-.f64 (pow.f64 (fma.f64 #s(literal 1/4 binary64) (neg.f64 b) (*.f64 #s(literal 1/4 binary64) a)) #s(literal 2 binary64)) #s(literal 1/4 binary64)) (-.f64 (fma.f64 #s(literal 1/4 binary64) (neg.f64 b) (*.f64 #s(literal 1/4 binary64) a)) #s(literal 1/2 binary64))) |
(/.f64 (-.f64 #s(literal 1/4 binary64) (pow.f64 (fma.f64 #s(literal 1/4 binary64) (neg.f64 b) (*.f64 #s(literal 1/4 binary64) a)) #s(literal 2 binary64))) (-.f64 #s(literal 1/2 binary64) (fma.f64 #s(literal 1/4 binary64) (neg.f64 b) (*.f64 #s(literal 1/4 binary64) a)))) |
(/.f64 (+.f64 (pow.f64 (fma.f64 #s(literal 1/4 binary64) (neg.f64 b) (*.f64 #s(literal 1/4 binary64) a)) #s(literal 3 binary64)) #s(literal 1/8 binary64)) (+.f64 (pow.f64 (fma.f64 #s(literal 1/4 binary64) (neg.f64 b) (*.f64 #s(literal 1/4 binary64) a)) #s(literal 2 binary64)) (-.f64 #s(literal 1/4 binary64) (*.f64 (fma.f64 #s(literal 1/4 binary64) (neg.f64 b) (*.f64 #s(literal 1/4 binary64) a)) #s(literal 1/2 binary64))))) |
(/.f64 (+.f64 #s(literal 1/8 binary64) (pow.f64 (fma.f64 #s(literal 1/4 binary64) (neg.f64 b) (*.f64 #s(literal 1/4 binary64) a)) #s(literal 3 binary64))) (+.f64 #s(literal 1/4 binary64) (-.f64 (pow.f64 (fma.f64 #s(literal 1/4 binary64) (neg.f64 b) (*.f64 #s(literal 1/4 binary64) a)) #s(literal 2 binary64)) (*.f64 #s(literal 1/2 binary64) (fma.f64 #s(literal 1/4 binary64) (neg.f64 b) (*.f64 #s(literal 1/4 binary64) a)))))) |
(fma.f64 #s(literal 1/4 binary64) a (fma.f64 #s(literal 1/4 binary64) (neg.f64 b) #s(literal 1/2 binary64))) |
(fma.f64 a #s(literal 1/4 binary64) (fma.f64 #s(literal 1/4 binary64) (neg.f64 b) #s(literal 1/2 binary64))) |
(-.f64 (/.f64 (pow.f64 (fma.f64 #s(literal 1/4 binary64) (neg.f64 b) (*.f64 #s(literal 1/4 binary64) a)) #s(literal 2 binary64)) (-.f64 (fma.f64 #s(literal 1/4 binary64) (neg.f64 b) (*.f64 #s(literal 1/4 binary64) a)) #s(literal 1/2 binary64))) (/.f64 #s(literal 1/4 binary64) (-.f64 (fma.f64 #s(literal 1/4 binary64) (neg.f64 b) (*.f64 #s(literal 1/4 binary64) a)) #s(literal 1/2 binary64)))) |
(-.f64 (/.f64 #s(literal 1/4 binary64) (-.f64 #s(literal 1/2 binary64) (fma.f64 #s(literal 1/4 binary64) (neg.f64 b) (*.f64 #s(literal 1/4 binary64) a)))) (/.f64 (pow.f64 (fma.f64 #s(literal 1/4 binary64) (neg.f64 b) (*.f64 #s(literal 1/4 binary64) a)) #s(literal 2 binary64)) (-.f64 #s(literal 1/2 binary64) (fma.f64 #s(literal 1/4 binary64) (neg.f64 b) (*.f64 #s(literal 1/4 binary64) a))))) |
(+.f64 (/.f64 (pow.f64 (fma.f64 #s(literal 1/4 binary64) (neg.f64 b) (*.f64 #s(literal 1/4 binary64) a)) #s(literal 3 binary64)) (+.f64 (pow.f64 (fma.f64 #s(literal 1/4 binary64) (neg.f64 b) (*.f64 #s(literal 1/4 binary64) a)) #s(literal 2 binary64)) (-.f64 #s(literal 1/4 binary64) (*.f64 (fma.f64 #s(literal 1/4 binary64) (neg.f64 b) (*.f64 #s(literal 1/4 binary64) a)) #s(literal 1/2 binary64))))) (/.f64 #s(literal 1/8 binary64) (+.f64 (pow.f64 (fma.f64 #s(literal 1/4 binary64) (neg.f64 b) (*.f64 #s(literal 1/4 binary64) a)) #s(literal 2 binary64)) (-.f64 #s(literal 1/4 binary64) (*.f64 (fma.f64 #s(literal 1/4 binary64) (neg.f64 b) (*.f64 #s(literal 1/4 binary64) a)) #s(literal 1/2 binary64)))))) |
(+.f64 (/.f64 #s(literal 1/8 binary64) (+.f64 #s(literal 1/4 binary64) (-.f64 (pow.f64 (fma.f64 #s(literal 1/4 binary64) (neg.f64 b) (*.f64 #s(literal 1/4 binary64) a)) #s(literal 2 binary64)) (*.f64 #s(literal 1/2 binary64) (fma.f64 #s(literal 1/4 binary64) (neg.f64 b) (*.f64 #s(literal 1/4 binary64) a)))))) (/.f64 (pow.f64 (fma.f64 #s(literal 1/4 binary64) (neg.f64 b) (*.f64 #s(literal 1/4 binary64) a)) #s(literal 3 binary64)) (+.f64 #s(literal 1/4 binary64) (-.f64 (pow.f64 (fma.f64 #s(literal 1/4 binary64) (neg.f64 b) (*.f64 #s(literal 1/4 binary64) a)) #s(literal 2 binary64)) (*.f64 #s(literal 1/2 binary64) (fma.f64 #s(literal 1/4 binary64) (neg.f64 b) (*.f64 #s(literal 1/4 binary64) a))))))) |
(+.f64 (fma.f64 #s(literal 1/4 binary64) (neg.f64 b) (*.f64 #s(literal 1/4 binary64) a)) #s(literal 1/2 binary64)) |
(+.f64 (*.f64 #s(literal 1/4 binary64) a) (fma.f64 #s(literal 1/4 binary64) (neg.f64 b) #s(literal 1/2 binary64))) |
(+.f64 (fma.f64 #s(literal 1/4 binary64) (neg.f64 b) #s(literal 1/2 binary64)) (*.f64 #s(literal 1/4 binary64) a)) |
(+.f64 #s(literal 1/2 binary64) (fma.f64 #s(literal 1/4 binary64) (neg.f64 b) (*.f64 #s(literal 1/4 binary64) a))) |
(/.f64 (neg.f64 (-.f64 (pow.f64 (*.f64 #s(literal 1/4 binary64) a) #s(literal 2 binary64)) (pow.f64 (*.f64 #s(literal 1/4 binary64) (neg.f64 b)) #s(literal 2 binary64)))) (neg.f64 (-.f64 (*.f64 #s(literal 1/4 binary64) a) (*.f64 #s(literal 1/4 binary64) (neg.f64 b))))) |
(/.f64 (neg.f64 (fma.f64 (pow.f64 a #s(literal 3 binary64)) #s(literal 1/64 binary64) (pow.f64 (*.f64 #s(literal 1/4 binary64) (neg.f64 b)) #s(literal 3 binary64)))) (neg.f64 (+.f64 (pow.f64 (*.f64 #s(literal 1/4 binary64) a) #s(literal 2 binary64)) (-.f64 (pow.f64 (*.f64 #s(literal 1/4 binary64) (neg.f64 b)) #s(literal 2 binary64)) (*.f64 (*.f64 #s(literal 1/4 binary64) a) (*.f64 #s(literal 1/4 binary64) (neg.f64 b))))))) |
(/.f64 (neg.f64 (-.f64 (pow.f64 (*.f64 #s(literal 1/4 binary64) (neg.f64 b)) #s(literal 2 binary64)) (pow.f64 (*.f64 #s(literal 1/4 binary64) a) #s(literal 2 binary64)))) (neg.f64 (-.f64 (*.f64 #s(literal 1/4 binary64) (neg.f64 b)) (*.f64 #s(literal 1/4 binary64) a)))) |
(/.f64 (neg.f64 (fma.f64 (pow.f64 (neg.f64 b) #s(literal 3 binary64)) #s(literal 1/64 binary64) (pow.f64 (*.f64 #s(literal 1/4 binary64) a) #s(literal 3 binary64)))) (neg.f64 (fma.f64 (*.f64 #s(literal 1/4 binary64) b) (*.f64 #s(literal 1/4 binary64) b) (-.f64 (pow.f64 (*.f64 #s(literal 1/4 binary64) a) #s(literal 2 binary64)) (*.f64 (*.f64 #s(literal 1/4 binary64) (neg.f64 b)) (*.f64 #s(literal 1/4 binary64) a)))))) |
(/.f64 (-.f64 (pow.f64 (*.f64 #s(literal 1/4 binary64) a) #s(literal 2 binary64)) (pow.f64 (*.f64 #s(literal 1/4 binary64) (neg.f64 b)) #s(literal 2 binary64))) (-.f64 (*.f64 #s(literal 1/4 binary64) a) (*.f64 #s(literal 1/4 binary64) (neg.f64 b)))) |
(/.f64 (-.f64 (pow.f64 (*.f64 #s(literal 1/4 binary64) (neg.f64 b)) #s(literal 2 binary64)) (pow.f64 (*.f64 #s(literal 1/4 binary64) a) #s(literal 2 binary64))) (-.f64 (*.f64 #s(literal 1/4 binary64) (neg.f64 b)) (*.f64 #s(literal 1/4 binary64) a))) |
(/.f64 (fma.f64 (pow.f64 a #s(literal 3 binary64)) #s(literal 1/64 binary64) (pow.f64 (*.f64 #s(literal 1/4 binary64) (neg.f64 b)) #s(literal 3 binary64))) (+.f64 (pow.f64 (*.f64 #s(literal 1/4 binary64) a) #s(literal 2 binary64)) (-.f64 (pow.f64 (*.f64 #s(literal 1/4 binary64) (neg.f64 b)) #s(literal 2 binary64)) (*.f64 (*.f64 #s(literal 1/4 binary64) a) (*.f64 #s(literal 1/4 binary64) (neg.f64 b)))))) |
(/.f64 (fma.f64 (pow.f64 (neg.f64 b) #s(literal 3 binary64)) #s(literal 1/64 binary64) (pow.f64 (*.f64 #s(literal 1/4 binary64) a) #s(literal 3 binary64))) (fma.f64 (*.f64 #s(literal 1/4 binary64) b) (*.f64 #s(literal 1/4 binary64) b) (-.f64 (pow.f64 (*.f64 #s(literal 1/4 binary64) a) #s(literal 2 binary64)) (*.f64 (*.f64 #s(literal 1/4 binary64) (neg.f64 b)) (*.f64 #s(literal 1/4 binary64) a))))) |
(fma.f64 (*.f64 #s(literal 1/4 binary64) b) #s(literal -1 binary64) (*.f64 #s(literal 1/4 binary64) a)) |
(fma.f64 #s(literal 1/4 binary64) (neg.f64 b) (*.f64 #s(literal 1/4 binary64) a)) |
(fma.f64 #s(literal 1/4 binary64) a (*.f64 #s(literal 1/4 binary64) (neg.f64 b))) |
(fma.f64 (neg.f64 b) #s(literal 1/4 binary64) (*.f64 #s(literal 1/4 binary64) a)) |
(fma.f64 #s(literal -1 binary64) (*.f64 #s(literal 1/4 binary64) b) (*.f64 #s(literal 1/4 binary64) a)) |
(fma.f64 a #s(literal 1/4 binary64) (*.f64 #s(literal 1/4 binary64) (neg.f64 b))) |
(-.f64 (/.f64 (pow.f64 (*.f64 #s(literal 1/4 binary64) a) #s(literal 2 binary64)) (-.f64 (*.f64 #s(literal 1/4 binary64) a) (*.f64 #s(literal 1/4 binary64) (neg.f64 b)))) (/.f64 (pow.f64 (*.f64 #s(literal 1/4 binary64) (neg.f64 b)) #s(literal 2 binary64)) (-.f64 (*.f64 #s(literal 1/4 binary64) a) (*.f64 #s(literal 1/4 binary64) (neg.f64 b))))) |
(-.f64 (/.f64 (pow.f64 (*.f64 #s(literal 1/4 binary64) (neg.f64 b)) #s(literal 2 binary64)) (-.f64 (*.f64 #s(literal 1/4 binary64) (neg.f64 b)) (*.f64 #s(literal 1/4 binary64) a))) (/.f64 (pow.f64 (*.f64 #s(literal 1/4 binary64) a) #s(literal 2 binary64)) (-.f64 (*.f64 #s(literal 1/4 binary64) (neg.f64 b)) (*.f64 #s(literal 1/4 binary64) a)))) |
(-.f64 (*.f64 #s(literal 1/4 binary64) a) (*.f64 (neg.f64 (neg.f64 b)) #s(literal 1/4 binary64))) |
(-.f64 (*.f64 #s(literal 1/4 binary64) a) (*.f64 #s(literal 1/4 binary64) b)) |
(-.f64 (*.f64 #s(literal 1/4 binary64) (neg.f64 b)) (*.f64 #s(literal -1/4 binary64) a)) |
(+.f64 (/.f64 (pow.f64 (*.f64 #s(literal 1/4 binary64) a) #s(literal 3 binary64)) (+.f64 (pow.f64 (*.f64 #s(literal 1/4 binary64) a) #s(literal 2 binary64)) (-.f64 (pow.f64 (*.f64 #s(literal 1/4 binary64) (neg.f64 b)) #s(literal 2 binary64)) (*.f64 (*.f64 #s(literal 1/4 binary64) a) (*.f64 #s(literal 1/4 binary64) (neg.f64 b)))))) (/.f64 (pow.f64 (*.f64 #s(literal 1/4 binary64) (neg.f64 b)) #s(literal 3 binary64)) (+.f64 (pow.f64 (*.f64 #s(literal 1/4 binary64) a) #s(literal 2 binary64)) (-.f64 (pow.f64 (*.f64 #s(literal 1/4 binary64) (neg.f64 b)) #s(literal 2 binary64)) (*.f64 (*.f64 #s(literal 1/4 binary64) a) (*.f64 #s(literal 1/4 binary64) (neg.f64 b))))))) |
(+.f64 (/.f64 (pow.f64 (*.f64 #s(literal 1/4 binary64) (neg.f64 b)) #s(literal 3 binary64)) (fma.f64 (*.f64 #s(literal 1/4 binary64) b) (*.f64 #s(literal 1/4 binary64) b) (-.f64 (pow.f64 (*.f64 #s(literal 1/4 binary64) a) #s(literal 2 binary64)) (*.f64 (*.f64 #s(literal 1/4 binary64) (neg.f64 b)) (*.f64 #s(literal 1/4 binary64) a))))) (/.f64 (pow.f64 (*.f64 #s(literal 1/4 binary64) a) #s(literal 3 binary64)) (fma.f64 (*.f64 #s(literal 1/4 binary64) b) (*.f64 #s(literal 1/4 binary64) b) (-.f64 (pow.f64 (*.f64 #s(literal 1/4 binary64) a) #s(literal 2 binary64)) (*.f64 (*.f64 #s(literal 1/4 binary64) (neg.f64 b)) (*.f64 #s(literal 1/4 binary64) a)))))) |
(+.f64 (*.f64 #s(literal 1/4 binary64) a) (*.f64 #s(literal 1/4 binary64) (neg.f64 b))) |
(+.f64 (*.f64 #s(literal 1/4 binary64) (neg.f64 b)) (*.f64 #s(literal 1/4 binary64) a)) |
#s(literal 1/4 binary64) |
a |
(*.f64 (*.f64 #s(literal 1/4 binary64) b) #s(literal -1 binary64)) |
(*.f64 #s(literal 1/4 binary64) (neg.f64 b)) |
(*.f64 (neg.f64 b) #s(literal 1/4 binary64)) |
(*.f64 #s(literal -1 binary64) (*.f64 #s(literal 1/4 binary64) b)) |
(neg.f64 (*.f64 #s(literal 1/4 binary64) b)) |
(*.f64 #s(literal -1 binary64) b) |
(*.f64 b #s(literal -1 binary64)) |
(neg.f64 b) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (/ 1 (- (exp b) -1)) (fma.f64 (-.f64 (*.f64 (*.f64 (fma.f64 (*.f64 b b) #s(literal -1/480 binary64) #s(literal 1/48 binary64)) b) b) #s(literal 1/4 binary64)) b #s(literal 1/2 binary64)))) |
#s(approx (/ 1 (- (exp b) -1)) (fma.f64 (-.f64 (*.f64 (*.f64 (fma.f64 (*.f64 b b) #s(literal -1/480 binary64) #s(literal 1/48 binary64)) b) b) #s(literal 1/4 binary64)) b #s(literal 1/2 binary64))) |
(/.f64 (neg.f64 (-.f64 (pow.f64 (*.f64 (-.f64 (*.f64 (*.f64 (fma.f64 (*.f64 b b) #s(literal -1/480 binary64) #s(literal 1/48 binary64)) b) b) #s(literal 1/4 binary64)) b) #s(literal 2 binary64)) #s(literal 1/4 binary64))) (neg.f64 (-.f64 (*.f64 (-.f64 (*.f64 (*.f64 (fma.f64 (*.f64 b b) #s(literal -1/480 binary64) #s(literal 1/48 binary64)) b) b) #s(literal 1/4 binary64)) b) #s(literal 1/2 binary64)))) |
(/.f64 (neg.f64 (-.f64 #s(literal 1/4 binary64) (pow.f64 (*.f64 (-.f64 (*.f64 (*.f64 (fma.f64 (*.f64 b b) #s(literal -1/480 binary64) #s(literal 1/48 binary64)) b) b) #s(literal 1/4 binary64)) b) #s(literal 2 binary64)))) (neg.f64 (-.f64 #s(literal 1/2 binary64) (*.f64 (-.f64 (*.f64 (*.f64 (fma.f64 (*.f64 b b) #s(literal -1/480 binary64) #s(literal 1/48 binary64)) b) b) #s(literal 1/4 binary64)) b)))) |
(/.f64 (neg.f64 (+.f64 (pow.f64 (*.f64 (-.f64 (*.f64 (*.f64 (fma.f64 (*.f64 b b) #s(literal -1/480 binary64) #s(literal 1/48 binary64)) b) b) #s(literal 1/4 binary64)) b) #s(literal 3 binary64)) #s(literal 1/8 binary64))) (neg.f64 (+.f64 (pow.f64 (*.f64 (-.f64 (*.f64 (*.f64 (fma.f64 (*.f64 b b) #s(literal -1/480 binary64) #s(literal 1/48 binary64)) b) b) #s(literal 1/4 binary64)) b) #s(literal 2 binary64)) (-.f64 #s(literal 1/4 binary64) (*.f64 (*.f64 (-.f64 (*.f64 (*.f64 (fma.f64 (*.f64 b b) #s(literal -1/480 binary64) #s(literal 1/48 binary64)) b) b) #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 (fma.f64 (*.f64 b b) #s(literal -1/480 binary64) #s(literal 1/48 binary64)) b) b) #s(literal 1/4 binary64)) b) #s(literal 3 binary64)))) (neg.f64 (+.f64 #s(literal 1/4 binary64) (-.f64 (pow.f64 (*.f64 (-.f64 (*.f64 (*.f64 (fma.f64 (*.f64 b b) #s(literal -1/480 binary64) #s(literal 1/48 binary64)) b) b) #s(literal 1/4 binary64)) b) #s(literal 2 binary64)) (*.f64 #s(literal 1/2 binary64) (*.f64 (-.f64 (*.f64 (*.f64 (fma.f64 (*.f64 b b) #s(literal -1/480 binary64) #s(literal 1/48 binary64)) b) b) #s(literal 1/4 binary64)) b)))))) |
(/.f64 (-.f64 (pow.f64 (*.f64 (-.f64 (*.f64 (*.f64 (fma.f64 (*.f64 b b) #s(literal -1/480 binary64) #s(literal 1/48 binary64)) b) b) #s(literal 1/4 binary64)) b) #s(literal 2 binary64)) #s(literal 1/4 binary64)) (-.f64 (*.f64 (-.f64 (*.f64 (*.f64 (fma.f64 (*.f64 b b) #s(literal -1/480 binary64) #s(literal 1/48 binary64)) b) b) #s(literal 1/4 binary64)) b) #s(literal 1/2 binary64))) |
(/.f64 (-.f64 #s(literal 1/4 binary64) (pow.f64 (*.f64 (-.f64 (*.f64 (*.f64 (fma.f64 (*.f64 b b) #s(literal -1/480 binary64) #s(literal 1/48 binary64)) b) b) #s(literal 1/4 binary64)) b) #s(literal 2 binary64))) (-.f64 #s(literal 1/2 binary64) (*.f64 (-.f64 (*.f64 (*.f64 (fma.f64 (*.f64 b b) #s(literal -1/480 binary64) #s(literal 1/48 binary64)) b) b) #s(literal 1/4 binary64)) b))) |
(/.f64 (+.f64 (pow.f64 (*.f64 (-.f64 (*.f64 (*.f64 (fma.f64 (*.f64 b b) #s(literal -1/480 binary64) #s(literal 1/48 binary64)) b) b) #s(literal 1/4 binary64)) b) #s(literal 3 binary64)) #s(literal 1/8 binary64)) (+.f64 (pow.f64 (*.f64 (-.f64 (*.f64 (*.f64 (fma.f64 (*.f64 b b) #s(literal -1/480 binary64) #s(literal 1/48 binary64)) b) b) #s(literal 1/4 binary64)) b) #s(literal 2 binary64)) (-.f64 #s(literal 1/4 binary64) (*.f64 (*.f64 (-.f64 (*.f64 (*.f64 (fma.f64 (*.f64 b b) #s(literal -1/480 binary64) #s(literal 1/48 binary64)) b) b) #s(literal 1/4 binary64)) b) #s(literal 1/2 binary64))))) |
(/.f64 (+.f64 #s(literal 1/8 binary64) (pow.f64 (*.f64 (-.f64 (*.f64 (*.f64 (fma.f64 (*.f64 b b) #s(literal -1/480 binary64) #s(literal 1/48 binary64)) b) b) #s(literal 1/4 binary64)) b) #s(literal 3 binary64))) (+.f64 #s(literal 1/4 binary64) (-.f64 (pow.f64 (*.f64 (-.f64 (*.f64 (*.f64 (fma.f64 (*.f64 b b) #s(literal -1/480 binary64) #s(literal 1/48 binary64)) b) b) #s(literal 1/4 binary64)) b) #s(literal 2 binary64)) (*.f64 #s(literal 1/2 binary64) (*.f64 (-.f64 (*.f64 (*.f64 (fma.f64 (*.f64 b b) #s(literal -1/480 binary64) #s(literal 1/48 binary64)) b) b) #s(literal 1/4 binary64)) b))))) |
(fma.f64 (-.f64 (*.f64 (*.f64 (fma.f64 (*.f64 b b) #s(literal -1/480 binary64) #s(literal 1/48 binary64)) b) b) #s(literal 1/4 binary64)) b #s(literal 1/2 binary64)) |
(fma.f64 b (-.f64 (*.f64 (*.f64 (fma.f64 (*.f64 b b) #s(literal -1/480 binary64) #s(literal 1/48 binary64)) b) b) #s(literal 1/4 binary64)) #s(literal 1/2 binary64)) |
(-.f64 (/.f64 (pow.f64 (*.f64 (-.f64 (*.f64 (*.f64 (fma.f64 (*.f64 b b) #s(literal -1/480 binary64) #s(literal 1/48 binary64)) b) b) #s(literal 1/4 binary64)) b) #s(literal 2 binary64)) (-.f64 (*.f64 (-.f64 (*.f64 (*.f64 (fma.f64 (*.f64 b b) #s(literal -1/480 binary64) #s(literal 1/48 binary64)) b) b) #s(literal 1/4 binary64)) b) #s(literal 1/2 binary64))) (/.f64 #s(literal 1/4 binary64) (-.f64 (*.f64 (-.f64 (*.f64 (*.f64 (fma.f64 (*.f64 b b) #s(literal -1/480 binary64) #s(literal 1/48 binary64)) b) b) #s(literal 1/4 binary64)) b) #s(literal 1/2 binary64)))) |
(-.f64 (/.f64 #s(literal 1/4 binary64) (-.f64 #s(literal 1/2 binary64) (*.f64 (-.f64 (*.f64 (*.f64 (fma.f64 (*.f64 b b) #s(literal -1/480 binary64) #s(literal 1/48 binary64)) b) b) #s(literal 1/4 binary64)) b))) (/.f64 (pow.f64 (*.f64 (-.f64 (*.f64 (*.f64 (fma.f64 (*.f64 b b) #s(literal -1/480 binary64) #s(literal 1/48 binary64)) b) b) #s(literal 1/4 binary64)) b) #s(literal 2 binary64)) (-.f64 #s(literal 1/2 binary64) (*.f64 (-.f64 (*.f64 (*.f64 (fma.f64 (*.f64 b b) #s(literal -1/480 binary64) #s(literal 1/48 binary64)) b) b) #s(literal 1/4 binary64)) b)))) |
(-.f64 #s(literal 1/2 binary64) (*.f64 (neg.f64 b) (-.f64 (*.f64 (*.f64 (fma.f64 (*.f64 b b) #s(literal -1/480 binary64) #s(literal 1/48 binary64)) b) b) #s(literal 1/4 binary64)))) |
(+.f64 (/.f64 (pow.f64 (*.f64 (-.f64 (*.f64 (*.f64 (fma.f64 (*.f64 b b) #s(literal -1/480 binary64) #s(literal 1/48 binary64)) b) b) #s(literal 1/4 binary64)) b) #s(literal 3 binary64)) (+.f64 (pow.f64 (*.f64 (-.f64 (*.f64 (*.f64 (fma.f64 (*.f64 b b) #s(literal -1/480 binary64) #s(literal 1/48 binary64)) b) b) #s(literal 1/4 binary64)) b) #s(literal 2 binary64)) (-.f64 #s(literal 1/4 binary64) (*.f64 (*.f64 (-.f64 (*.f64 (*.f64 (fma.f64 (*.f64 b b) #s(literal -1/480 binary64) #s(literal 1/48 binary64)) b) b) #s(literal 1/4 binary64)) b) #s(literal 1/2 binary64))))) (/.f64 #s(literal 1/8 binary64) (+.f64 (pow.f64 (*.f64 (-.f64 (*.f64 (*.f64 (fma.f64 (*.f64 b b) #s(literal -1/480 binary64) #s(literal 1/48 binary64)) b) b) #s(literal 1/4 binary64)) b) #s(literal 2 binary64)) (-.f64 #s(literal 1/4 binary64) (*.f64 (*.f64 (-.f64 (*.f64 (*.f64 (fma.f64 (*.f64 b b) #s(literal -1/480 binary64) #s(literal 1/48 binary64)) b) b) #s(literal 1/4 binary64)) b) #s(literal 1/2 binary64)))))) |
(+.f64 (/.f64 #s(literal 1/8 binary64) (+.f64 #s(literal 1/4 binary64) (-.f64 (pow.f64 (*.f64 (-.f64 (*.f64 (*.f64 (fma.f64 (*.f64 b b) #s(literal -1/480 binary64) #s(literal 1/48 binary64)) b) b) #s(literal 1/4 binary64)) b) #s(literal 2 binary64)) (*.f64 #s(literal 1/2 binary64) (*.f64 (-.f64 (*.f64 (*.f64 (fma.f64 (*.f64 b b) #s(literal -1/480 binary64) #s(literal 1/48 binary64)) b) b) #s(literal 1/4 binary64)) b))))) (/.f64 (pow.f64 (*.f64 (-.f64 (*.f64 (*.f64 (fma.f64 (*.f64 b b) #s(literal -1/480 binary64) #s(literal 1/48 binary64)) b) b) #s(literal 1/4 binary64)) b) #s(literal 3 binary64)) (+.f64 #s(literal 1/4 binary64) (-.f64 (pow.f64 (*.f64 (-.f64 (*.f64 (*.f64 (fma.f64 (*.f64 b b) #s(literal -1/480 binary64) #s(literal 1/48 binary64)) b) b) #s(literal 1/4 binary64)) b) #s(literal 2 binary64)) (*.f64 #s(literal 1/2 binary64) (*.f64 (-.f64 (*.f64 (*.f64 (fma.f64 (*.f64 b b) #s(literal -1/480 binary64) #s(literal 1/48 binary64)) b) b) #s(literal 1/4 binary64)) b)))))) |
(+.f64 (*.f64 (-.f64 (*.f64 (*.f64 (fma.f64 (*.f64 b b) #s(literal -1/480 binary64) #s(literal 1/48 binary64)) b) b) #s(literal 1/4 binary64)) b) #s(literal 1/2 binary64)) |
(+.f64 #s(literal 1/2 binary64) (*.f64 (-.f64 (*.f64 (*.f64 (fma.f64 (*.f64 b b) #s(literal -1/480 binary64) #s(literal 1/48 binary64)) b) b) #s(literal 1/4 binary64)) b)) |
(/.f64 (neg.f64 (-.f64 (pow.f64 (*.f64 (*.f64 (fma.f64 (*.f64 b b) #s(literal -1/480 binary64) #s(literal 1/48 binary64)) b) b) #s(literal 2 binary64)) #s(literal 1/16 binary64))) (neg.f64 (fma.f64 (fma.f64 (*.f64 b b) #s(literal -1/480 binary64) #s(literal 1/48 binary64)) (*.f64 b b) #s(literal 1/4 binary64)))) |
(/.f64 (neg.f64 (-.f64 (pow.f64 (*.f64 (*.f64 (fma.f64 (*.f64 b b) #s(literal -1/480 binary64) #s(literal 1/48 binary64)) b) b) #s(literal 3 binary64)) #s(literal 1/64 binary64))) (neg.f64 (+.f64 (pow.f64 (*.f64 (*.f64 (fma.f64 (*.f64 b b) #s(literal -1/480 binary64) #s(literal 1/48 binary64)) b) b) #s(literal 2 binary64)) (+.f64 #s(literal 1/16 binary64) (*.f64 (*.f64 (*.f64 (fma.f64 (*.f64 b b) #s(literal -1/480 binary64) #s(literal 1/48 binary64)) b) b) #s(literal 1/4 binary64)))))) |
(/.f64 (-.f64 (pow.f64 (*.f64 (*.f64 (fma.f64 (*.f64 b b) #s(literal -1/480 binary64) #s(literal 1/48 binary64)) b) b) #s(literal 2 binary64)) #s(literal 1/16 binary64)) (fma.f64 (fma.f64 (*.f64 b b) #s(literal -1/480 binary64) #s(literal 1/48 binary64)) (*.f64 b b) #s(literal 1/4 binary64))) |
(/.f64 (-.f64 (pow.f64 (*.f64 (*.f64 (fma.f64 (*.f64 b b) #s(literal -1/480 binary64) #s(literal 1/48 binary64)) b) b) #s(literal 3 binary64)) #s(literal 1/64 binary64)) (+.f64 (pow.f64 (*.f64 (*.f64 (fma.f64 (*.f64 b b) #s(literal -1/480 binary64) #s(literal 1/48 binary64)) b) b) #s(literal 2 binary64)) (+.f64 #s(literal 1/16 binary64) (*.f64 (*.f64 (*.f64 (fma.f64 (*.f64 b b) #s(literal -1/480 binary64) #s(literal 1/48 binary64)) b) b) #s(literal 1/4 binary64))))) |
(-.f64 (/.f64 (pow.f64 (*.f64 (*.f64 (fma.f64 (*.f64 b b) #s(literal -1/480 binary64) #s(literal 1/48 binary64)) b) b) #s(literal 2 binary64)) (fma.f64 (fma.f64 (*.f64 b b) #s(literal -1/480 binary64) #s(literal 1/48 binary64)) (*.f64 b b) #s(literal 1/4 binary64))) (/.f64 #s(literal 1/16 binary64) (fma.f64 (fma.f64 (*.f64 b b) #s(literal -1/480 binary64) #s(literal 1/48 binary64)) (*.f64 b b) #s(literal 1/4 binary64)))) |
(-.f64 (/.f64 (pow.f64 (*.f64 (*.f64 (fma.f64 (*.f64 b b) #s(literal -1/480 binary64) #s(literal 1/48 binary64)) b) b) #s(literal 3 binary64)) (+.f64 (pow.f64 (*.f64 (*.f64 (fma.f64 (*.f64 b b) #s(literal -1/480 binary64) #s(literal 1/48 binary64)) b) b) #s(literal 2 binary64)) (+.f64 #s(literal 1/16 binary64) (*.f64 (*.f64 (*.f64 (fma.f64 (*.f64 b b) #s(literal -1/480 binary64) #s(literal 1/48 binary64)) b) b) #s(literal 1/4 binary64))))) (/.f64 #s(literal 1/64 binary64) (+.f64 (pow.f64 (*.f64 (*.f64 (fma.f64 (*.f64 b b) #s(literal -1/480 binary64) #s(literal 1/48 binary64)) b) b) #s(literal 2 binary64)) (+.f64 #s(literal 1/16 binary64) (*.f64 (*.f64 (*.f64 (fma.f64 (*.f64 b b) #s(literal -1/480 binary64) #s(literal 1/48 binary64)) b) b) #s(literal 1/4 binary64)))))) |
(-.f64 (*.f64 (*.f64 (fma.f64 (*.f64 b b) #s(literal -1/480 binary64) #s(literal 1/48 binary64)) b) b) #s(literal 1/4 binary64)) |
(*.f64 (*.f64 (fma.f64 (*.f64 b b) #s(literal -1/480 binary64) #s(literal 1/48 binary64)) b) b) |
(*.f64 (fma.f64 (*.f64 b b) #s(literal -1/480 binary64) #s(literal 1/48 binary64)) (*.f64 b b)) |
(*.f64 (*.f64 b b) (fma.f64 (*.f64 b b) #s(literal -1/480 binary64) #s(literal 1/48 binary64))) |
(/.f64 (fma.f64 (pow.f64 (*.f64 b b) #s(literal 3 binary64)) #s(literal 1/110592 binary64) (pow.f64 (*.f64 (*.f64 (*.f64 b b) #s(literal -1/480 binary64)) (*.f64 b b)) #s(literal 3 binary64))) (+.f64 (pow.f64 (*.f64 #s(literal 1/48 binary64) (*.f64 b b)) #s(literal 2 binary64)) (-.f64 (*.f64 (*.f64 (*.f64 (*.f64 b b) #s(literal -1/480 binary64)) (*.f64 b b)) (*.f64 (*.f64 (*.f64 b b) #s(literal -1/480 binary64)) (*.f64 b b))) (*.f64 (*.f64 #s(literal 1/48 binary64) (*.f64 b b)) (*.f64 (*.f64 (*.f64 b b) #s(literal -1/480 binary64)) (*.f64 b b)))))) |
(/.f64 (fma.f64 (pow.f64 (*.f64 b b) #s(literal 3 binary64)) #s(literal 1/110592 binary64) (pow.f64 (*.f64 (*.f64 b b) (*.f64 (*.f64 b b) #s(literal -1/480 binary64))) #s(literal 3 binary64))) (+.f64 (pow.f64 (*.f64 #s(literal 1/48 binary64) (*.f64 b b)) #s(literal 2 binary64)) (-.f64 (*.f64 (*.f64 (*.f64 b b) (*.f64 (*.f64 b b) #s(literal -1/480 binary64))) (*.f64 (*.f64 b b) (*.f64 (*.f64 b b) #s(literal -1/480 binary64)))) (*.f64 (*.f64 #s(literal 1/48 binary64) (*.f64 b b)) (*.f64 (*.f64 b b) (*.f64 (*.f64 b b) #s(literal -1/480 binary64))))))) |
(fma.f64 #s(literal 1/48 binary64) (*.f64 b b) (*.f64 (*.f64 (*.f64 b b) #s(literal -1/480 binary64)) (*.f64 b b))) |
(fma.f64 #s(literal 1/48 binary64) (*.f64 b b) (*.f64 (*.f64 b b) (*.f64 (*.f64 b b) #s(literal -1/480 binary64)))) |
(fma.f64 (*.f64 b b) #s(literal 1/48 binary64) (*.f64 (*.f64 (*.f64 b b) #s(literal -1/480 binary64)) (*.f64 b b))) |
(fma.f64 (*.f64 b b) #s(literal 1/48 binary64) (*.f64 (*.f64 b b) (*.f64 (*.f64 b b) #s(literal -1/480 binary64)))) |
(+.f64 (*.f64 #s(literal 1/48 binary64) (*.f64 b b)) (*.f64 (*.f64 (*.f64 b b) #s(literal -1/480 binary64)) (*.f64 b b))) |
(+.f64 (*.f64 #s(literal 1/48 binary64) (*.f64 b b)) (*.f64 (*.f64 b b) (*.f64 (*.f64 b b) #s(literal -1/480 binary64)))) |
(/.f64 (neg.f64 (-.f64 #s(literal 1/2304 binary64) (pow.f64 (*.f64 (*.f64 b b) #s(literal -1/480 binary64)) #s(literal 2 binary64)))) (neg.f64 (-.f64 #s(literal 1/48 binary64) (*.f64 (*.f64 b b) #s(literal -1/480 binary64))))) |
(/.f64 (neg.f64 (-.f64 (pow.f64 (*.f64 (*.f64 b b) #s(literal -1/480 binary64)) #s(literal 2 binary64)) #s(literal 1/2304 binary64))) (neg.f64 (-.f64 (*.f64 (*.f64 b b) #s(literal -1/480 binary64)) #s(literal 1/48 binary64)))) |
(/.f64 (neg.f64 (+.f64 #s(literal 1/110592 binary64) (pow.f64 (*.f64 (*.f64 b b) #s(literal -1/480 binary64)) #s(literal 3 binary64)))) (neg.f64 (+.f64 #s(literal 1/2304 binary64) (-.f64 (pow.f64 (*.f64 (*.f64 b b) #s(literal -1/480 binary64)) #s(literal 2 binary64)) (*.f64 #s(literal 1/48 binary64) (*.f64 (*.f64 b b) #s(literal -1/480 binary64))))))) |
(/.f64 (neg.f64 (fma.f64 #s(literal -1/110592000 binary64) (pow.f64 (*.f64 b b) #s(literal 3 binary64)) #s(literal 1/110592 binary64))) (neg.f64 (+.f64 (pow.f64 (*.f64 (*.f64 b b) #s(literal -1/480 binary64)) #s(literal 2 binary64)) (-.f64 #s(literal 1/2304 binary64) (*.f64 (*.f64 (*.f64 b b) #s(literal -1/480 binary64)) #s(literal 1/48 binary64)))))) |
(/.f64 (-.f64 #s(literal 1/2304 binary64) (pow.f64 (*.f64 (*.f64 b b) #s(literal -1/480 binary64)) #s(literal 2 binary64))) (-.f64 #s(literal 1/48 binary64) (*.f64 (*.f64 b b) #s(literal -1/480 binary64)))) |
(/.f64 (-.f64 (pow.f64 (*.f64 (*.f64 b b) #s(literal -1/480 binary64)) #s(literal 2 binary64)) #s(literal 1/2304 binary64)) (-.f64 (*.f64 (*.f64 b b) #s(literal -1/480 binary64)) #s(literal 1/48 binary64))) |
(/.f64 (+.f64 #s(literal 1/110592 binary64) (pow.f64 (*.f64 (*.f64 b b) #s(literal -1/480 binary64)) #s(literal 3 binary64))) (+.f64 #s(literal 1/2304 binary64) (-.f64 (pow.f64 (*.f64 (*.f64 b b) #s(literal -1/480 binary64)) #s(literal 2 binary64)) (*.f64 #s(literal 1/48 binary64) (*.f64 (*.f64 b b) #s(literal -1/480 binary64)))))) |
(/.f64 (fma.f64 #s(literal -1/110592000 binary64) (pow.f64 (*.f64 b b) #s(literal 3 binary64)) #s(literal 1/110592 binary64)) (+.f64 (pow.f64 (*.f64 (*.f64 b b) #s(literal -1/480 binary64)) #s(literal 2 binary64)) (-.f64 #s(literal 1/2304 binary64) (*.f64 (*.f64 (*.f64 b b) #s(literal -1/480 binary64)) #s(literal 1/48 binary64))))) |
(fma.f64 (*.f64 #s(literal -1/480 binary64) b) b #s(literal 1/48 binary64)) |
(fma.f64 (*.f64 b b) #s(literal -1/480 binary64) #s(literal 1/48 binary64)) |
(fma.f64 #s(literal -1/480 binary64) (*.f64 b b) #s(literal 1/48 binary64)) |
(-.f64 (/.f64 #s(literal 1/2304 binary64) (-.f64 #s(literal 1/48 binary64) (*.f64 (*.f64 b b) #s(literal -1/480 binary64)))) (/.f64 (pow.f64 (*.f64 (*.f64 b b) #s(literal -1/480 binary64)) #s(literal 2 binary64)) (-.f64 #s(literal 1/48 binary64) (*.f64 (*.f64 b b) #s(literal -1/480 binary64))))) |
(-.f64 (/.f64 (pow.f64 (*.f64 (*.f64 b b) #s(literal -1/480 binary64)) #s(literal 2 binary64)) (-.f64 (*.f64 (*.f64 b b) #s(literal -1/480 binary64)) #s(literal 1/48 binary64))) (/.f64 #s(literal 1/2304 binary64) (-.f64 (*.f64 (*.f64 b b) #s(literal -1/480 binary64)) #s(literal 1/48 binary64)))) |
(-.f64 #s(literal 1/48 binary64) (*.f64 #s(literal 1/480 binary64) (*.f64 b b))) |
(+.f64 (/.f64 #s(literal 1/110592 binary64) (+.f64 #s(literal 1/2304 binary64) (-.f64 (pow.f64 (*.f64 (*.f64 b b) #s(literal -1/480 binary64)) #s(literal 2 binary64)) (*.f64 #s(literal 1/48 binary64) (*.f64 (*.f64 b b) #s(literal -1/480 binary64)))))) (/.f64 (pow.f64 (*.f64 (*.f64 b b) #s(literal -1/480 binary64)) #s(literal 3 binary64)) (+.f64 #s(literal 1/2304 binary64) (-.f64 (pow.f64 (*.f64 (*.f64 b b) #s(literal -1/480 binary64)) #s(literal 2 binary64)) (*.f64 #s(literal 1/48 binary64) (*.f64 (*.f64 b b) #s(literal -1/480 binary64))))))) |
(+.f64 (/.f64 (pow.f64 (*.f64 (*.f64 b b) #s(literal -1/480 binary64)) #s(literal 3 binary64)) (+.f64 (pow.f64 (*.f64 (*.f64 b b) #s(literal -1/480 binary64)) #s(literal 2 binary64)) (-.f64 #s(literal 1/2304 binary64) (*.f64 (*.f64 (*.f64 b b) #s(literal -1/480 binary64)) #s(literal 1/48 binary64))))) (/.f64 #s(literal 1/110592 binary64) (+.f64 (pow.f64 (*.f64 (*.f64 b b) #s(literal -1/480 binary64)) #s(literal 2 binary64)) (-.f64 #s(literal 1/2304 binary64) (*.f64 (*.f64 (*.f64 b b) #s(literal -1/480 binary64)) #s(literal 1/48 binary64)))))) |
(+.f64 (*.f64 (*.f64 b b) #s(literal -1/480 binary64)) #s(literal 1/48 binary64)) |
(+.f64 #s(literal 1/48 binary64) (*.f64 (*.f64 b b) #s(literal -1/480 binary64))) |
#s(literal -1/480 binary64) |
(*.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 (neg.f64 b)) (neg.f64 (neg.f64 b))) |
(*.f64 (fabs.f64 b) (fabs.f64 b)) |
(*.f64 (neg.f64 b) (neg.f64 b)) |
(*.f64 b b) |
(pow.f64 (exp.f64 (log.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 (neg.f64 b) #s(literal 2 binary64)) |
(pow.f64 b #s(literal 2 binary64)) |
(fabs.f64 (*.f64 b b)) |
(exp.f64 (*.f64 (log.f64 b) #s(literal 2 binary64))) |
(+.f64 (cosh.f64 (*.f64 (log.f64 b) #s(literal 2 binary64))) (sinh.f64 (*.f64 (log.f64 b) #s(literal 2 binary64)))) |
#s(literal 1/48 binary64) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (pow.f64 #s(approx (- (exp b) -1) (+.f64 #s(literal 2 binary64) b)) #s(literal -1 binary64))) |
(*.f64 (neg.f64 (pow.f64 #s(approx (- (exp b) -1) (+.f64 #s(literal 2 binary64) b)) #s(literal -1/2 binary64))) (neg.f64 (pow.f64 #s(approx (- (exp b) -1) (+.f64 #s(literal 2 binary64) b)) #s(literal -1/2 binary64)))) |
(*.f64 (fabs.f64 (pow.f64 #s(approx (- (exp b) -1) (+.f64 #s(literal 2 binary64) b)) #s(literal -1/2 binary64))) (fabs.f64 (pow.f64 #s(approx (- (exp b) -1) (+.f64 #s(literal 2 binary64) b)) #s(literal -1/2 binary64)))) |
(*.f64 (pow.f64 #s(approx (- (exp b) -1) (+.f64 #s(literal 2 binary64) b)) #s(literal -1/2 binary64)) (pow.f64 #s(approx (- (exp b) -1) (+.f64 #s(literal 2 binary64) b)) #s(literal -1/2 binary64))) |
(pow.f64 (exp.f64 (log.f64 #s(approx (- (exp b) -1) (+.f64 #s(literal 2 binary64) b)))) #s(literal -1 binary64)) |
(pow.f64 (*.f64 #s(approx (- (exp b) -1) (+.f64 #s(literal 2 binary64) b)) #s(approx (- (exp b) -1) (+.f64 #s(literal 2 binary64) b))) #s(literal -1/2 binary64)) |
(pow.f64 (pow.f64 #s(approx (- (exp b) -1) (+.f64 #s(literal 2 binary64) b)) #s(literal -1/2 binary64)) #s(literal 2 binary64)) |
(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) (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))) |
(+.f64 (cosh.f64 (*.f64 (log.f64 #s(approx (- (exp b) -1) (+.f64 #s(literal 2 binary64) b))) #s(literal -1 binary64))) (sinh.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 (+.f64 (pow.f64 b #s(literal 3 binary64)) #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) (pow.f64 b #s(literal 3 binary64)))) (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) (pow.f64 b #s(literal 3 binary64))) (+.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 (pow.f64 b #s(literal 3 binary64)) (+.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))) (pow.f64 (+.f64 #s(literal 1 binary64) (exp.f64 b)) #s(literal -1 binary64))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (fma.f64 (-.f64 (pow.f64 (+.f64 #s(literal 1 binary64) (exp.f64 b)) #s(literal -1 binary64)) (pow.f64 (+.f64 #s(literal 1 binary64) (exp.f64 b)) #s(literal -2 binary64))) a (pow.f64 (+.f64 #s(literal 1 binary64) (exp.f64 b)) #s(literal -1 binary64)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (fma.f64 (-.f64 (fma.f64 (-.f64 (+.f64 (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 #s(literal 3/2 binary64) (pow.f64 (+.f64 #s(literal 1 binary64) (exp.f64 b)) #s(literal -2 binary64)))) a (pow.f64 (+.f64 #s(literal 1 binary64) (exp.f64 b)) #s(literal -1 binary64))) (pow.f64 (+.f64 #s(literal 1 binary64) (exp.f64 b)) #s(literal -2 binary64))) a (pow.f64 (+.f64 #s(literal 1 binary64) (exp.f64 b)) #s(literal -1 binary64)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (fma.f64 (-.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) (pow.f64 (+.f64 #s(literal 1 binary64) (exp.f64 b)) #s(literal 2 binary64))) (fma.f64 (/.f64 (-.f64 (pow.f64 (+.f64 #s(literal 1 binary64) (exp.f64 b)) #s(literal -1 binary64)) (pow.f64 (+.f64 #s(literal 1 binary64) (exp.f64 b)) #s(literal -2 binary64))) (+.f64 #s(literal 1 binary64) (exp.f64 b))) #s(literal 1/2 binary64) (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 #s(literal 3/2 binary64) (pow.f64 (+.f64 #s(literal 1 binary64) (exp.f64 b)) #s(literal -2 binary64)))) a (pow.f64 (+.f64 #s(literal 1 binary64) (exp.f64 b)) #s(literal -1 binary64))) (pow.f64 (+.f64 #s(literal 1 binary64) (exp.f64 b)) #s(literal -2 binary64))) a (pow.f64 (+.f64 #s(literal 1 binary64) (exp.f64 b)) #s(literal -1 binary64)))) |
#s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) (fma.f64 #s(literal 1/4 binary64) (neg.f64 b) #s(literal 1/2 binary64))) |
#s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) (fma.f64 #s(literal 1/4 binary64) a (fma.f64 #s(literal 1/4 binary64) (neg.f64 b) #s(literal 1/2 binary64)))) |
#s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) (+.f64 (fma.f64 (fma.f64 (*.f64 (*.f64 #s(literal 1/4 binary64) b) a) #s(literal 1/4 binary64) #s(literal 1/4 binary64)) a (*.f64 #s(literal 1/4 binary64) (neg.f64 b))) #s(literal 1/2 binary64))) |
#s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) (+.f64 (fma.f64 (fma.f64 (fma.f64 #s(literal -1/48 binary64) a (*.f64 (*.f64 #s(literal 1/4 binary64) b) #s(literal 1/4 binary64))) a #s(literal 1/4 binary64)) a (*.f64 #s(literal 1/4 binary64) (neg.f64 b))) #s(literal 1/2 binary64))) |
#s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) (fma.f64 #s(literal -1/4 binary64) b #s(literal 1/2 binary64))) |
#s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) (+.f64 (fma.f64 #s(literal -1/4 binary64) b (*.f64 #s(literal 1/4 binary64) a)) #s(literal 1/2 binary64))) |
#s(approx (+ (* 1/4 a) (* (neg b) 1/4)) (*.f64 #s(literal -1/4 binary64) b)) |
#s(approx (+ (* 1/4 a) (* (neg b) 1/4)) (fma.f64 #s(literal -1/4 binary64) b (*.f64 #s(literal 1/4 binary64) a))) |
#s(approx a a) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 (exp.f64 a) (+.f64 (exp.f64 b) (exp.f64 a)))) |
#s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) (fma.f64 (exp.f64 (-.f64 a (*.f64 #s(literal 2 binary64) (log1p.f64 (exp.f64 a))))) (neg.f64 b) (/.f64 (exp.f64 a) (+.f64 #s(literal 1 binary64) (exp.f64 a))))) |
#s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) (*.f64 #s(literal 1/4 binary64) a)) |
#s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) (*.f64 (+.f64 (/.f64 (fma.f64 #s(literal -1/4 binary64) b #s(literal 1/2 binary64)) a) #s(literal 1/4 binary64)) a)) |
#s(approx (+ (* 1/4 a) (* (neg b) 1/4)) (*.f64 #s(literal 1/4 binary64) a)) |
#s(approx (+ (* 1/4 a) (* (neg b) 1/4)) (*.f64 (fma.f64 (/.f64 b a) #s(literal -1/4 binary64) #s(literal 1/4 binary64)) a)) |
#s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) (fma.f64 (neg.f64 b) (exp.f64 (neg.f64 (fma.f64 #s(literal 2 binary64) (log1p.f64 (exp.f64 a)) (neg.f64 a)))) (/.f64 (exp.f64 a) (+.f64 #s(literal 1 binary64) (exp.f64 a))))) |
#s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) (*.f64 (neg.f64 a) (-.f64 (neg.f64 (/.f64 (fma.f64 #s(literal -1/4 binary64) b #s(literal 1/2 binary64)) a)) #s(literal 1/4 binary64)))) |
#s(approx (+ (* 1/4 a) (* (neg b) 1/4)) (*.f64 (neg.f64 a) (-.f64 (*.f64 (/.f64 b a) #s(literal 1/4 binary64)) #s(literal 1/4 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))) (fma.f64 (exp.f64 (-.f64 a (*.f64 #s(literal 2 binary64) (log1p.f64 (exp.f64 a))))) (neg.f64 b) (/.f64 (exp.f64 a) (+.f64 #s(literal 1 binary64) (exp.f64 a))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (fma.f64 (-.f64 (*.f64 (neg.f64 b) (fma.f64 (exp.f64 (-.f64 a (*.f64 #s(literal 2 binary64) (log1p.f64 (exp.f64 a))))) #s(literal 1/2 binary64) (neg.f64 (exp.f64 (-.f64 a (*.f64 (log1p.f64 (exp.f64 a)) #s(literal 3 binary64))))))) (exp.f64 (-.f64 a (*.f64 #s(literal 2 binary64) (log1p.f64 (exp.f64 a)))))) b (/.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 (*.f64 (neg.f64 b) (fma.f64 (/.f64 (fma.f64 (exp.f64 (-.f64 a (*.f64 #s(literal 2 binary64) (log1p.f64 (exp.f64 a))))) #s(literal 1/2 binary64) (neg.f64 (exp.f64 (-.f64 a (*.f64 (log1p.f64 (exp.f64 a)) #s(literal 3 binary64)))))) (+.f64 #s(literal 1 binary64) (exp.f64 a))) #s(literal -1 binary64) (fma.f64 #s(literal -1/2 binary64) (exp.f64 (-.f64 a (*.f64 (log1p.f64 (exp.f64 a)) #s(literal 3 binary64)))) (*.f64 (exp.f64 (-.f64 a (*.f64 #s(literal 2 binary64) (log1p.f64 (exp.f64 a))))) #s(literal 1/6 binary64))))) (fma.f64 (exp.f64 (-.f64 a (*.f64 #s(literal 2 binary64) (log1p.f64 (exp.f64 a))))) #s(literal 1/2 binary64) (neg.f64 (exp.f64 (-.f64 a (*.f64 (log1p.f64 (exp.f64 a)) #s(literal 3 binary64))))))) b) (exp.f64 (-.f64 a (*.f64 #s(literal 2 binary64) (log1p.f64 (exp.f64 a)))))) 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 #s(literal 1/48 binary64) (*.f64 b b)) #s(literal 1/4 binary64)) b #s(literal 1/2 binary64))) |
#s(approx (/ 1 (- (exp b) -1)) (fma.f64 (-.f64 (*.f64 (*.f64 (fma.f64 (*.f64 b b) #s(literal -1/480 binary64) #s(literal 1/48 binary64)) 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 (/ 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 #s(literal 1/48 binary64) (*.f64 b b)) #s(literal 1/4 binary64)) b #s(literal 1/2 binary64))) |
#s(approx (/ 1 (- (exp b) -1)) (fma.f64 (-.f64 (*.f64 (*.f64 (fma.f64 (*.f64 b b) #s(literal -1/480 binary64) #s(literal 1/48 binary64)) b) b) #s(literal 1/4 binary64)) b #s(literal 1/2 binary64))) |
#s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) (/.f64 (exp.f64 a) (+.f64 #s(literal 1 binary64) (exp.f64 a)))) |
#s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) (fma.f64 #s(literal 1/4 binary64) a #s(literal 1/2 binary64))) |
#s(approx (* (neg b) 1/4) (*.f64 #s(literal -1/4 binary64) b)) |
#s(approx (neg b) (neg.f64 b)) |
#s(approx (+ (* (- (* (+ (* -1/480 (* b b)) 1/48) (* b b)) 1/4) b) 1/2) #s(literal 1/2 binary64)) |
#s(approx (+ (* (- (* (+ (* -1/480 (* b b)) 1/48) (* b b)) 1/4) b) 1/2) (fma.f64 #s(literal -1/4 binary64) b #s(literal 1/2 binary64))) |
#s(approx (+ (* (- (* (+ (* -1/480 (* b b)) 1/48) (* b b)) 1/4) b) 1/2) (fma.f64 (-.f64 (*.f64 #s(literal 1/48 binary64) (*.f64 b b)) #s(literal 1/4 binary64)) b #s(literal 1/2 binary64))) |
#s(approx (+ (* (- (* (+ (* -1/480 (* b b)) 1/48) (* b b)) 1/4) b) 1/2) (fma.f64 (-.f64 (*.f64 (*.f64 (fma.f64 (*.f64 b b) #s(literal -1/480 binary64) #s(literal 1/48 binary64)) b) b) #s(literal 1/4 binary64)) b #s(literal 1/2 binary64))) |
#s(approx (- (* (+ (* -1/480 (* b b)) 1/48) (* b b)) 1/4) #s(literal -1/4 binary64)) |
#s(approx (- (* (+ (* -1/480 (* b b)) 1/48) (* b b)) 1/4) (-.f64 (*.f64 #s(literal 1/48 binary64) (*.f64 b b)) #s(literal 1/4 binary64))) |
#s(approx (- (* (+ (* -1/480 (* b b)) 1/48) (* b b)) 1/4) (-.f64 (*.f64 (*.f64 (fma.f64 (*.f64 b b) #s(literal -1/480 binary64) #s(literal 1/48 binary64)) b) b) #s(literal 1/4 binary64))) |
#s(approx (* (+ (* -1/480 (* b b)) 1/48) (* b b)) (*.f64 #s(literal 1/48 binary64) (*.f64 b b))) |
#s(approx (* (+ (* -1/480 (* b b)) 1/48) (* b b)) (*.f64 (*.f64 (fma.f64 (*.f64 b b) #s(literal -1/480 binary64) #s(literal 1/48 binary64)) b) b)) |
#s(approx (+ (* -1/480 (* b b)) 1/48) #s(literal 1/48 binary64)) |
#s(approx (+ (* -1/480 (* b b)) 1/48) (fma.f64 (*.f64 b b) #s(literal -1/480 binary64) #s(literal 1/48 binary64))) |
#s(approx (* b b) (*.f64 b b)) |
#s(approx (+ 2 b) #s(literal 2 binary64)) |
#s(approx (+ 2 b) (+.f64 #s(literal 2 binary64) b)) |
#s(approx (/ 1 (- (exp b) -1)) (pow.f64 (+.f64 #s(literal 1 binary64) (exp.f64 b)) #s(literal -1 binary64))) |
#s(approx (- (exp b) -1) (+.f64 #s(literal 1 binary64) (exp.f64 b))) |
#s(approx (exp b) (exp.f64 b)) |
#s(approx (/ 1 (- (exp b) -1)) (pow.f64 (+.f64 #s(literal 1 binary64) (exp.f64 b)) #s(literal -1 binary64))) |
#s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) (*.f64 (exp.f64 (-.f64 a (*.f64 #s(literal 2 binary64) (log1p.f64 (exp.f64 a))))) (neg.f64 b))) |
#s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) (*.f64 (fma.f64 (exp.f64 (-.f64 a (*.f64 #s(literal 2 binary64) (log1p.f64 (exp.f64 a))))) #s(literal -1 binary64) (/.f64 (/.f64 (exp.f64 a) b) (+.f64 #s(literal 1 binary64) (exp.f64 a)))) b)) |
#s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) (*.f64 #s(literal -1/4 binary64) b)) |
#s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) (*.f64 (-.f64 (/.f64 (fma.f64 #s(literal 1/4 binary64) a #s(literal 1/2 binary64)) b) #s(literal 1/4 binary64)) b)) |
#s(approx (+ (* 1/4 a) (* (neg b) 1/4)) (*.f64 (-.f64 (*.f64 (/.f64 a b) #s(literal 1/4 binary64)) #s(literal 1/4 binary64)) b)) |
#s(approx (+ (* (- (* (+ (* -1/480 (* b b)) 1/48) (* b b)) 1/4) b) 1/2) (*.f64 (pow.f64 b #s(literal 5 binary64)) #s(literal -1/480 binary64))) |
#s(approx (+ (* (- (* (+ (* -1/480 (* b b)) 1/48) (* b b)) 1/4) b) 1/2) (*.f64 (-.f64 (*.f64 (pow.f64 b #s(literal -2 binary64)) #s(literal 1/48 binary64)) #s(literal 1/480 binary64)) (pow.f64 b #s(literal 5 binary64)))) |
#s(approx (+ (* (- (* (+ (* -1/480 (* b b)) 1/48) (* b b)) 1/4) b) 1/2) (*.f64 (-.f64 (-.f64 (*.f64 (pow.f64 b #s(literal -2 binary64)) #s(literal 1/48 binary64)) #s(literal 1/480 binary64)) (/.f64 #s(literal 1/4 binary64) (pow.f64 b #s(literal 4 binary64)))) (pow.f64 b #s(literal 5 binary64)))) |
#s(approx (+ (* (- (* (+ (* -1/480 (* b b)) 1/48) (* b b)) 1/4) b) 1/2) (*.f64 (-.f64 (-.f64 (fma.f64 (pow.f64 b #s(literal -5 binary64)) #s(literal 1/2 binary64) (*.f64 (pow.f64 b #s(literal -2 binary64)) #s(literal 1/48 binary64))) #s(literal 1/480 binary64)) (/.f64 #s(literal 1/4 binary64) (pow.f64 b #s(literal 4 binary64)))) (pow.f64 b #s(literal 5 binary64)))) |
#s(approx (- (* (+ (* -1/480 (* b b)) 1/48) (* b b)) 1/4) (*.f64 (pow.f64 b #s(literal 4 binary64)) #s(literal -1/480 binary64))) |
#s(approx (- (* (+ (* -1/480 (* b b)) 1/48) (* b b)) 1/4) (*.f64 (pow.f64 b #s(literal 4 binary64)) (-.f64 (*.f64 (pow.f64 b #s(literal -2 binary64)) #s(literal 1/48 binary64)) #s(literal 1/480 binary64)))) |
#s(approx (- (* (+ (* -1/480 (* b b)) 1/48) (* b b)) 1/4) (*.f64 (-.f64 (-.f64 (*.f64 (pow.f64 b #s(literal -2 binary64)) #s(literal 1/48 binary64)) #s(literal 1/480 binary64)) (/.f64 #s(literal 1/4 binary64) (pow.f64 b #s(literal 4 binary64)))) (pow.f64 b #s(literal 4 binary64)))) |
#s(approx (* (+ (* -1/480 (* b b)) 1/48) (* b b)) (*.f64 (pow.f64 b #s(literal 4 binary64)) #s(literal -1/480 binary64))) |
#s(approx (* (+ (* -1/480 (* b b)) 1/48) (* b b)) (*.f64 (pow.f64 b #s(literal 4 binary64)) (-.f64 (*.f64 (pow.f64 b #s(literal -2 binary64)) #s(literal 1/48 binary64)) #s(literal 1/480 binary64)))) |
#s(approx (+ (* -1/480 (* b b)) 1/48) (*.f64 (*.f64 b b) #s(literal -1/480 binary64))) |
#s(approx (+ (* -1/480 (* b b)) 1/48) (*.f64 (-.f64 (*.f64 (pow.f64 b #s(literal -2 binary64)) #s(literal 1/48 binary64)) #s(literal 1/480 binary64)) (*.f64 b 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 (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) (*.f64 (neg.f64 b) (fma.f64 (exp.f64 a) (exp.f64 (*.f64 #s(literal -2 binary64) (log1p.f64 (exp.f64 a)))) (neg.f64 (/.f64 (/.f64 (exp.f64 a) b) (+.f64 #s(literal 1 binary64) (exp.f64 a))))))) |
#s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) (*.f64 (neg.f64 b) (fma.f64 (/.f64 (fma.f64 #s(literal 1/4 binary64) a #s(literal 1/2 binary64)) b) #s(literal -1 binary64) #s(literal 1/4 binary64)))) |
#s(approx (+ (* 1/4 a) (* (neg b) 1/4)) (*.f64 (neg.f64 b) (fma.f64 (/.f64 a b) #s(literal -1/4 binary64) #s(literal 1/4 binary64)))) |
#s(approx (+ (* (- (* (+ (* -1/480 (* b b)) 1/48) (* b b)) 1/4) b) 1/2) (neg.f64 (*.f64 (-.f64 #s(literal 1/480 binary64) (*.f64 (pow.f64 b #s(literal -2 binary64)) #s(literal 1/48 binary64))) (pow.f64 b #s(literal 5 binary64))))) |
#s(approx (+ (* (- (* (+ (* -1/480 (* b b)) 1/48) (* b b)) 1/4) b) 1/2) (neg.f64 (*.f64 (-.f64 (+.f64 (/.f64 #s(literal 1/4 binary64) (pow.f64 b #s(literal 4 binary64))) #s(literal 1/480 binary64)) (*.f64 (pow.f64 b #s(literal -2 binary64)) #s(literal 1/48 binary64))) (pow.f64 b #s(literal 5 binary64))))) |
#s(approx (+ (* (- (* (+ (* -1/480 (* b b)) 1/48) (* b b)) 1/4) b) 1/2) (neg.f64 (*.f64 (-.f64 (+.f64 (/.f64 #s(literal 1/4 binary64) (pow.f64 b #s(literal 4 binary64))) #s(literal 1/480 binary64)) (fma.f64 (pow.f64 b #s(literal -5 binary64)) #s(literal 1/2 binary64) (*.f64 (pow.f64 b #s(literal -2 binary64)) #s(literal 1/48 binary64)))) (pow.f64 b #s(literal 5 binary64))))) |
Compiled 11 759 to 1 477 computations (87.4% saved)
15 alts after pruning (11 fresh and 4 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 287 | 9 | 296 |
| Fresh | 3 | 2 | 5 |
| Picked | 2 | 3 | 5 |
| Done | 0 | 1 | 1 |
| Total | 292 | 15 | 307 |
| Status | Accuracy | Program |
|---|---|---|
| ✓ | 66.5% | (/.f64 (exp.f64 a) (+.f64 (exp.f64 a) #s(approx (exp b) #s(literal 1 binary64)))) |
| ▶ | 65.8% | (/.f64 (exp.f64 a) (+.f64 #s(approx (exp a) #s(literal 1 binary64)) #s(approx (exp b) #s(literal 1 binary64)))) |
| ✓ | 81.5% | #s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) (-.f64 (exp.f64 b) #s(literal -1 binary64)))) |
| 58.0% | #s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 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))))) | |
| ▶ | 55.1% | #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))))) |
| ▶ | 38.7% | #s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) #s(approx (- (exp b) -1) (+.f64 #s(literal 2 binary64) b)))) |
| ✓ | 37.8% | #s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (pow (- (exp b) -1) -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)))) |
| 37.4% | #s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (pow (- (exp b) -1) -1) (fma.f64 (-.f64 (*.f64 (*.f64 b b) #s(literal 1/48 binary64)) #s(literal 1/4 binary64)) b #s(literal 1/2 binary64)))) | |
| 38.2% | #s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (pow (- (exp b) -1) -1) (fma.f64 #s(approx (- (* (+ (* -1/480 (* b b)) 1/48) (* b b)) 1/4) #s(literal -1/4 binary64)) b #s(literal 1/2 binary64)))) | |
| 18.4% | #s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (pow (- (exp b) -1) -1) #s(approx (+ (* (- (* (+ (* -1/480 (* b b)) 1/48) (* b b)) 1/4) b) 1/2) (*.f64 (pow.f64 b #s(literal 5 binary64)) #s(literal -1/480 binary64))))) | |
| ✓ | 40.5% | #s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (pow (- (exp b) -1) -1) #s(literal 1/2 binary64))) |
| 38.1% | #s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) (+.f64 (fma.f64 (fma.f64 (fma.f64 #s(literal -1/48 binary64) a (*.f64 (*.f64 #s(literal 1/4 binary64) b) #s(literal 1/4 binary64))) a #s(literal 1/4 binary64)) a (*.f64 #s(literal 1/4 binary64) (neg.f64 b))) #s(literal 1/2 binary64)))) | |
| ▶ | 40.5% | #s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) (fma.f64 #s(literal 1/4 binary64) a #s(literal 1/2 binary64))))) |
| 3.9% | #s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) (*.f64 #s(literal 1/4 binary64) a)))) | |
| ▶ | 3.8% | #s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) (*.f64 #s(literal -1/4 binary64) b)))) |
Compiled 803 to 550 computations (31.5% saved)
| Inputs |
|---|
(/.f64 (exp.f64 a) (+.f64 #s(approx (exp a) #s(literal 1 binary64)) #s(approx (exp b) #s(literal 1 binary64)))) |
(exp.f64 a) |
a |
(+.f64 #s(approx (exp a) #s(literal 1 binary64)) #s(approx (exp b) #s(literal 1 binary64))) |
#s(approx (exp a) #s(literal 1 binary64)) |
#s(literal 1 binary64) |
#s(approx (exp b) #s(literal 1 binary64)) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) (*.f64 #s(literal -1/4 binary64) b)))) |
#s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) (*.f64 #s(literal -1/4 binary64) b))) |
#s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) (*.f64 #s(literal -1/4 binary64) b)) |
(*.f64 #s(literal -1/4 binary64) b) |
#s(literal -1/4 binary64) |
b |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) (fma.f64 #s(literal 1/4 binary64) a #s(literal 1/2 binary64))))) |
#s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) (fma.f64 #s(literal 1/4 binary64) a #s(literal 1/2 binary64)))) |
#s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) (fma.f64 #s(literal 1/4 binary64) a #s(literal 1/2 binary64))) |
(fma.f64 #s(literal 1/4 binary64) a #s(literal 1/2 binary64)) |
#s(literal 1/4 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))) (/.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)) |
| 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 (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(hole binary64 (+ 1/2 (* -1 (* b (exp (neg (* 2 (log 2))))))))) |
#s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(hole binary64 (+ 1/2 (+ (* -1 (* b (exp (neg (* 2 (log 2)))))) (* 1/4 a))))) |
#s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(hole binary64 (+ 1/2 (+ (* -1 (* b (exp (neg (* 2 (log 2)))))) (* a (+ 1/4 (* 1/4 (* a (* b (exp (neg (* 2 (log 2))))))))))))) |
#s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(hole binary64 (+ 1/2 (+ (* -1 (* b (exp (neg (* 2 (log 2)))))) (* a (+ 1/4 (* a (+ (* -1/48 a) (* 1/4 (* b (exp (neg (* 2 (log 2)))))))))))))) |
#s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) #s(hole binary64 (+ 1/2 (* -1/4 b)))) |
#s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) #s(hole binary64 (+ 1/2 (+ (* -1/4 b) (* 1/4 a))))) |
#s(approx (+ (* 1/4 a) 1/2) #s(hole binary64 1/2)) |
#s(approx (+ (* 1/4 a) 1/2) #s(hole binary64 (+ 1/2 (* 1/4 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 (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(hole binary64 (+ (* -1 (* b (exp (- a (* 2 (log (+ 1 (exp a)))))))) (/ (exp a) (+ 1 (exp a)))))) |
#s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) #s(hole binary64 (* 1/4 a))) |
#s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) #s(hole binary64 (* a (+ 1/4 (+ (* -1/4 (/ b a)) (* 1/2 (/ 1 a))))))) |
#s(approx (+ (* 1/4 a) 1/2) #s(hole binary64 (* 1/4 a))) |
#s(approx (+ (* 1/4 a) 1/2) #s(hole binary64 (* a (+ 1/4 (* 1/2 (/ 1 a)))))) |
#s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(hole binary64 (+ (* -1 (* b (exp (neg (+ (* -1 a) (* 2 (log (+ 1 (exp a))))))))) (/ (exp a) (+ 1 (exp a)))))) |
#s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) #s(hole binary64 (* -1 (* a (- (* -1 (/ (+ 1/2 (* -1/4 b)) a)) 1/4))))) |
#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 (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(hole binary64 (/ (exp a) (+ 1 (exp a))))) |
#s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) #s(hole binary64 (+ 1/2 (* 1/4 a)))) |
#s(approx (* -1/4 b) #s(hole binary64 (* -1/4 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 (+ (* (+ (* 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 (exp b))) |
#s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(hole binary64 (* -1 (* b (exp (- a (* 2 (log (+ 1 (exp a)))))))))) |
#s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(hole binary64 (* b (+ (* -1 (exp (- a (* 2 (log (+ 1 (exp a))))))) (/ (exp a) (* b (+ 1 (exp a)))))))) |
#s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) #s(hole binary64 (* -1/4 b))) |
#s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) #s(hole binary64 (* b (- (+ (* 1/4 (/ a b)) (* 1/2 (/ 1 b))) 1/4)))) |
#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 (+ (* (+ (* 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 (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(hole binary64 (* -1 (* b (+ (exp (- a (* 2 (log (+ 1 (exp a)))))) (* -1 (/ (exp a) (* b (+ 1 (exp a)))))))))) |
#s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) #s(hole binary64 (* -1 (* b (+ 1/4 (* -1 (/ (+ 1/2 (* 1/4 a)) b))))))) |
6 calls:
| Time | Variable | Point | Expression | |
|---|---|---|---|---|
| 4.0ms | b | @ | -inf | ((/ (exp a) (+ (exp a) (exp b))) (exp a) a (+ (exp a) (exp b)) (exp a) 1 (exp b) (/ (exp a) (+ (exp a) (exp b))) (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) (* -1/4 b) -1/4 b (/ (exp a) (+ (exp a) (exp b))) (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) (+ (* 1/4 a) 1/2) 1/4 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)) (- (exp b) -1) (+ (* (+ (* 1/2 b) 1) b) 2) (+ (* 1/2 b) 1)) |
| 3.0ms | b | @ | inf | ((/ (exp a) (+ (exp a) (exp b))) (exp a) a (+ (exp a) (exp b)) (exp a) 1 (exp b) (/ (exp a) (+ (exp a) (exp b))) (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) (* -1/4 b) -1/4 b (/ (exp a) (+ (exp a) (exp b))) (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) (+ (* 1/4 a) 1/2) 1/4 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)) (- (exp b) -1) (+ (* (+ (* 1/2 b) 1) b) 2) (+ (* 1/2 b) 1)) |
| 3.0ms | b | @ | 0 | ((/ (exp a) (+ (exp a) (exp b))) (exp a) a (+ (exp a) (exp b)) (exp a) 1 (exp b) (/ (exp a) (+ (exp a) (exp b))) (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) (* -1/4 b) -1/4 b (/ (exp a) (+ (exp a) (exp b))) (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) (+ (* 1/4 a) 1/2) 1/4 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)) (- (exp b) -1) (+ (* (+ (* 1/2 b) 1) b) 2) (+ (* 1/2 b) 1)) |
| 3.0ms | a | @ | inf | ((/ (exp a) (+ (exp a) (exp b))) (exp a) a (+ (exp a) (exp b)) (exp a) 1 (exp b) (/ (exp a) (+ (exp a) (exp b))) (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) (* -1/4 b) -1/4 b (/ (exp a) (+ (exp a) (exp b))) (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) (+ (* 1/4 a) 1/2) 1/4 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)) (- (exp b) -1) (+ (* (+ (* 1/2 b) 1) b) 2) (+ (* 1/2 b) 1)) |
| 2.0ms | a | @ | -inf | ((/ (exp a) (+ (exp a) (exp b))) (exp a) a (+ (exp a) (exp b)) (exp a) 1 (exp b) (/ (exp a) (+ (exp a) (exp b))) (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) (* -1/4 b) -1/4 b (/ (exp a) (+ (exp a) (exp b))) (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) (+ (* 1/4 a) 1/2) 1/4 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)) (- (exp b) -1) (+ (* (+ (* 1/2 b) 1) b) 2) (+ (* 1/2 b) 1)) |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 343 | 1992 |
| 0 | 352 | 1869 |
| 1 | 2093 | 1839 |
| 0 | 9591 | 1725 |
| 1× | iter limit |
| 1× | node limit |
| 1× | iter limit |
| Inputs |
|---|
(/.f64 (exp.f64 a) (+.f64 #s(approx (exp a) #s(literal 1 binary64)) #s(approx (exp b) #s(literal 1 binary64)))) |
(exp.f64 a) |
a |
(+.f64 #s(approx (exp a) #s(literal 1 binary64)) #s(approx (exp b) #s(literal 1 binary64))) |
#s(approx (exp a) #s(literal 1 binary64)) |
#s(literal 1 binary64) |
#s(approx (exp b) #s(literal 1 binary64)) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) (*.f64 #s(literal -1/4 binary64) b)))) |
#s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) (*.f64 #s(literal -1/4 binary64) b))) |
#s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) (*.f64 #s(literal -1/4 binary64) b)) |
(*.f64 #s(literal -1/4 binary64) b) |
#s(literal -1/4 binary64) |
b |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) (fma.f64 #s(literal 1/4 binary64) a #s(literal 1/2 binary64))))) |
#s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) (fma.f64 #s(literal 1/4 binary64) a #s(literal 1/2 binary64)))) |
#s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) (fma.f64 #s(literal 1/4 binary64) a #s(literal 1/2 binary64))) |
(fma.f64 #s(literal 1/4 binary64) a #s(literal 1/2 binary64)) |
#s(literal 1/4 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))) (/.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)) |
#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 (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(hole binary64 (+ 1/2 (* -1 (* b (exp (neg (* 2 (log 2))))))))) |
#s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(hole binary64 (+ 1/2 (+ (* -1 (* b (exp (neg (* 2 (log 2)))))) (* 1/4 a))))) |
#s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(hole binary64 (+ 1/2 (+ (* -1 (* b (exp (neg (* 2 (log 2)))))) (* a (+ 1/4 (* 1/4 (* a (* b (exp (neg (* 2 (log 2))))))))))))) |
#s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(hole binary64 (+ 1/2 (+ (* -1 (* b (exp (neg (* 2 (log 2)))))) (* a (+ 1/4 (* a (+ (* -1/48 a) (* 1/4 (* b (exp (neg (* 2 (log 2)))))))))))))) |
#s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) #s(hole binary64 (+ 1/2 (* -1/4 b)))) |
#s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) #s(hole binary64 (+ 1/2 (+ (* -1/4 b) (* 1/4 a))))) |
#s(approx (+ (* 1/4 a) 1/2) #s(hole binary64 1/2)) |
#s(approx (+ (* 1/4 a) 1/2) #s(hole binary64 (+ 1/2 (* 1/4 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 (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(hole binary64 (+ (* -1 (* b (exp (- a (* 2 (log (+ 1 (exp a)))))))) (/ (exp a) (+ 1 (exp a)))))) |
#s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) #s(hole binary64 (* 1/4 a))) |
#s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) #s(hole binary64 (* a (+ 1/4 (+ (* -1/4 (/ b a)) (* 1/2 (/ 1 a))))))) |
#s(approx (+ (* 1/4 a) 1/2) #s(hole binary64 (* 1/4 a))) |
#s(approx (+ (* 1/4 a) 1/2) #s(hole binary64 (* a (+ 1/4 (* 1/2 (/ 1 a)))))) |
#s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(hole binary64 (+ (* -1 (* b (exp (neg (+ (* -1 a) (* 2 (log (+ 1 (exp a))))))))) (/ (exp a) (+ 1 (exp a)))))) |
#s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) #s(hole binary64 (* -1 (* a (- (* -1 (/ (+ 1/2 (* -1/4 b)) a)) 1/4))))) |
#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 (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(hole binary64 (/ (exp a) (+ 1 (exp a))))) |
#s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) #s(hole binary64 (+ 1/2 (* 1/4 a)))) |
#s(approx (* -1/4 b) #s(hole binary64 (* -1/4 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 (+ (* (+ (* 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 (exp b))) |
#s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(hole binary64 (* -1 (* b (exp (- a (* 2 (log (+ 1 (exp a)))))))))) |
#s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(hole binary64 (* b (+ (* -1 (exp (- a (* 2 (log (+ 1 (exp a))))))) (/ (exp a) (* b (+ 1 (exp a)))))))) |
#s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) #s(hole binary64 (* -1/4 b))) |
#s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) #s(hole binary64 (* b (- (+ (* 1/4 (/ a b)) (* 1/2 (/ 1 b))) 1/4)))) |
#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 (+ (* (+ (* 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 (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(hole binary64 (* -1 (* b (+ (exp (- a (* 2 (log (+ 1 (exp a)))))) (* -1 (/ (exp a) (* b (+ 1 (exp a)))))))))) |
#s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) #s(hole binary64 (* -1 (* b (+ 1/4 (* -1 (/ (+ 1/2 (* 1/4 a)) b))))))) |
| Outputs |
|---|
(/.f64 (neg.f64 (neg.f64 (exp.f64 a))) (neg.f64 (neg.f64 (+.f64 #s(approx (exp b) #s(literal 1 binary64)) #s(approx (exp a) #s(literal 1 binary64)))))) |
(/.f64 (neg.f64 (exp.f64 a)) (neg.f64 (+.f64 #s(approx (exp b) #s(literal 1 binary64)) #s(approx (exp a) #s(literal 1 binary64))))) |
(/.f64 (exp.f64 a) (+.f64 #s(approx (exp b) #s(literal 1 binary64)) #s(approx (exp a) #s(literal 1 binary64)))) |
(+.f64 (/.f64 (cosh.f64 a) (+.f64 #s(approx (exp b) #s(literal 1 binary64)) #s(approx (exp a) #s(literal 1 binary64)))) (/.f64 (sinh.f64 a) (+.f64 #s(approx (exp b) #s(literal 1 binary64)) #s(approx (exp a) #s(literal 1 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))))) |
(exp.f64 a) |
(+.f64 (cosh.f64 a) (sinh.f64 a)) |
a |
(/.f64 (+.f64 (pow.f64 #s(approx (exp b) #s(literal 1 binary64)) #s(literal 3 binary64)) (pow.f64 #s(approx (exp a) #s(literal 1 binary64)) #s(literal 3 binary64))) (fma.f64 #s(approx (exp b) #s(literal 1 binary64)) #s(approx (exp b) #s(literal 1 binary64)) (-.f64 (pow.f64 #s(approx (exp a) #s(literal 1 binary64)) #s(literal 2 binary64)) (*.f64 #s(approx (exp b) #s(literal 1 binary64)) #s(approx (exp a) #s(literal 1 binary64)))))) |
(/.f64 (neg.f64 (-.f64 (pow.f64 #s(approx (exp a) #s(literal 1 binary64)) #s(literal 2 binary64)) (pow.f64 #s(approx (exp b) #s(literal 1 binary64)) #s(literal 2 binary64)))) (neg.f64 (-.f64 #s(approx (exp a) #s(literal 1 binary64)) #s(approx (exp b) #s(literal 1 binary64))))) |
(/.f64 (neg.f64 (+.f64 (pow.f64 #s(approx (exp a) #s(literal 1 binary64)) #s(literal 3 binary64)) (pow.f64 #s(approx (exp b) #s(literal 1 binary64)) #s(literal 3 binary64)))) (neg.f64 (fma.f64 #s(approx (exp a) #s(literal 1 binary64)) #s(approx (exp a) #s(literal 1 binary64)) (-.f64 (pow.f64 #s(approx (exp b) #s(literal 1 binary64)) #s(literal 2 binary64)) (*.f64 #s(approx (exp a) #s(literal 1 binary64)) #s(approx (exp b) #s(literal 1 binary64))))))) |
(/.f64 (-.f64 (pow.f64 #s(approx (exp a) #s(literal 1 binary64)) #s(literal 2 binary64)) (pow.f64 #s(approx (exp b) #s(literal 1 binary64)) #s(literal 2 binary64))) (-.f64 #s(approx (exp a) #s(literal 1 binary64)) #s(approx (exp b) #s(literal 1 binary64)))) |
(/.f64 (+.f64 (pow.f64 #s(approx (exp a) #s(literal 1 binary64)) #s(literal 3 binary64)) (pow.f64 #s(approx (exp b) #s(literal 1 binary64)) #s(literal 3 binary64))) (fma.f64 #s(approx (exp a) #s(literal 1 binary64)) #s(approx (exp a) #s(literal 1 binary64)) (-.f64 (pow.f64 #s(approx (exp b) #s(literal 1 binary64)) #s(literal 2 binary64)) (*.f64 #s(approx (exp a) #s(literal 1 binary64)) #s(approx (exp b) #s(literal 1 binary64)))))) |
(-.f64 (/.f64 (pow.f64 #s(approx (exp a) #s(literal 1 binary64)) #s(literal 2 binary64)) (-.f64 #s(approx (exp a) #s(literal 1 binary64)) #s(approx (exp b) #s(literal 1 binary64)))) (/.f64 (pow.f64 #s(approx (exp b) #s(literal 1 binary64)) #s(literal 2 binary64)) (-.f64 #s(approx (exp a) #s(literal 1 binary64)) #s(approx (exp b) #s(literal 1 binary64))))) |
(+.f64 (/.f64 (pow.f64 #s(approx (exp a) #s(literal 1 binary64)) #s(literal 3 binary64)) (fma.f64 #s(approx (exp a) #s(literal 1 binary64)) #s(approx (exp a) #s(literal 1 binary64)) (-.f64 (pow.f64 #s(approx (exp b) #s(literal 1 binary64)) #s(literal 2 binary64)) (*.f64 #s(approx (exp a) #s(literal 1 binary64)) #s(approx (exp b) #s(literal 1 binary64)))))) (/.f64 (pow.f64 #s(approx (exp b) #s(literal 1 binary64)) #s(literal 3 binary64)) (fma.f64 #s(approx (exp a) #s(literal 1 binary64)) #s(approx (exp a) #s(literal 1 binary64)) (-.f64 (pow.f64 #s(approx (exp b) #s(literal 1 binary64)) #s(literal 2 binary64)) (*.f64 #s(approx (exp a) #s(literal 1 binary64)) #s(approx (exp b) #s(literal 1 binary64))))))) |
(+.f64 #s(approx (exp b) #s(literal 1 binary64)) #s(approx (exp a) #s(literal 1 binary64))) |
(+.f64 #s(approx (exp a) #s(literal 1 binary64)) #s(approx (exp b) #s(literal 1 binary64))) |
#s(approx (exp a) #s(literal 1 binary64)) |
#s(literal 1 binary64) |
#s(approx (exp b) #s(literal 1 binary64)) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) (*.f64 #s(literal -1/4 binary64) b)))) |
#s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) (*.f64 #s(literal -1/4 binary64) b))) |
#s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) (*.f64 #s(literal -1/4 binary64) b)) |
(*.f64 #s(literal -1/4 binary64) b) |
(*.f64 b #s(literal -1/4 binary64)) |
#s(literal -1/4 binary64) |
b |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) (fma.f64 #s(literal 1/4 binary64) a #s(literal 1/2 binary64))))) |
#s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) (fma.f64 #s(literal 1/4 binary64) a #s(literal 1/2 binary64)))) |
#s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) (fma.f64 #s(literal 1/4 binary64) a #s(literal 1/2 binary64))) |
(/.f64 (neg.f64 (-.f64 #s(literal 1/4 binary64) (pow.f64 (*.f64 #s(literal 1/4 binary64) a) #s(literal 2 binary64)))) (neg.f64 (-.f64 #s(literal 1/2 binary64) (*.f64 #s(literal 1/4 binary64) a)))) |
(/.f64 (neg.f64 (-.f64 (pow.f64 (*.f64 #s(literal 1/4 binary64) a) #s(literal 2 binary64)) #s(literal 1/4 binary64))) (neg.f64 (-.f64 (*.f64 #s(literal 1/4 binary64) a) #s(literal 1/2 binary64)))) |
(/.f64 (neg.f64 (+.f64 #s(literal 1/8 binary64) (pow.f64 (*.f64 #s(literal 1/4 binary64) a) #s(literal 3 binary64)))) (neg.f64 (+.f64 #s(literal 1/4 binary64) (-.f64 (pow.f64 (*.f64 #s(literal 1/4 binary64) a) #s(literal 2 binary64)) (*.f64 #s(literal 1/2 binary64) (*.f64 #s(literal 1/4 binary64) a)))))) |
(/.f64 (neg.f64 (fma.f64 (pow.f64 a #s(literal 3 binary64)) #s(literal 1/64 binary64) #s(literal 1/8 binary64))) (neg.f64 (+.f64 (pow.f64 (*.f64 #s(literal 1/4 binary64) a) #s(literal 2 binary64)) (-.f64 #s(literal 1/4 binary64) (*.f64 (*.f64 #s(literal 1/4 binary64) a) #s(literal 1/2 binary64)))))) |
(/.f64 (-.f64 #s(literal 1/4 binary64) (pow.f64 (*.f64 #s(literal 1/4 binary64) a) #s(literal 2 binary64))) (-.f64 #s(literal 1/2 binary64) (*.f64 #s(literal 1/4 binary64) a))) |
(/.f64 (-.f64 (pow.f64 (*.f64 #s(literal 1/4 binary64) a) #s(literal 2 binary64)) #s(literal 1/4 binary64)) (-.f64 (*.f64 #s(literal 1/4 binary64) a) #s(literal 1/2 binary64))) |
(/.f64 (+.f64 #s(literal 1/8 binary64) (pow.f64 (*.f64 #s(literal 1/4 binary64) a) #s(literal 3 binary64))) (+.f64 #s(literal 1/4 binary64) (-.f64 (pow.f64 (*.f64 #s(literal 1/4 binary64) a) #s(literal 2 binary64)) (*.f64 #s(literal 1/2 binary64) (*.f64 #s(literal 1/4 binary64) a))))) |
(/.f64 (fma.f64 (pow.f64 a #s(literal 3 binary64)) #s(literal 1/64 binary64) #s(literal 1/8 binary64)) (+.f64 (pow.f64 (*.f64 #s(literal 1/4 binary64) a) #s(literal 2 binary64)) (-.f64 #s(literal 1/4 binary64) (*.f64 (*.f64 #s(literal 1/4 binary64) a) #s(literal 1/2 binary64))))) |
(fma.f64 #s(literal 1/4 binary64) a #s(literal 1/2 binary64)) |
(fma.f64 a #s(literal 1/4 binary64) #s(literal 1/2 binary64)) |
(-.f64 (/.f64 #s(literal 1/4 binary64) (-.f64 #s(literal 1/2 binary64) (*.f64 #s(literal 1/4 binary64) a))) (/.f64 (pow.f64 (*.f64 #s(literal 1/4 binary64) a) #s(literal 2 binary64)) (-.f64 #s(literal 1/2 binary64) (*.f64 #s(literal 1/4 binary64) a)))) |
(-.f64 (/.f64 (pow.f64 (*.f64 #s(literal 1/4 binary64) a) #s(literal 2 binary64)) (-.f64 (*.f64 #s(literal 1/4 binary64) a) #s(literal 1/2 binary64))) (/.f64 #s(literal 1/4 binary64) (-.f64 (*.f64 #s(literal 1/4 binary64) a) #s(literal 1/2 binary64)))) |
(-.f64 #s(literal 1/2 binary64) (*.f64 #s(literal -1/4 binary64) a)) |
(+.f64 (/.f64 #s(literal 1/8 binary64) (+.f64 #s(literal 1/4 binary64) (-.f64 (pow.f64 (*.f64 #s(literal 1/4 binary64) a) #s(literal 2 binary64)) (*.f64 #s(literal 1/2 binary64) (*.f64 #s(literal 1/4 binary64) a))))) (/.f64 (pow.f64 (*.f64 #s(literal 1/4 binary64) a) #s(literal 3 binary64)) (+.f64 #s(literal 1/4 binary64) (-.f64 (pow.f64 (*.f64 #s(literal 1/4 binary64) a) #s(literal 2 binary64)) (*.f64 #s(literal 1/2 binary64) (*.f64 #s(literal 1/4 binary64) a)))))) |
(+.f64 (/.f64 (pow.f64 (*.f64 #s(literal 1/4 binary64) a) #s(literal 3 binary64)) (+.f64 (pow.f64 (*.f64 #s(literal 1/4 binary64) a) #s(literal 2 binary64)) (-.f64 #s(literal 1/4 binary64) (*.f64 (*.f64 #s(literal 1/4 binary64) a) #s(literal 1/2 binary64))))) (/.f64 #s(literal 1/8 binary64) (+.f64 (pow.f64 (*.f64 #s(literal 1/4 binary64) a) #s(literal 2 binary64)) (-.f64 #s(literal 1/4 binary64) (*.f64 (*.f64 #s(literal 1/4 binary64) a) #s(literal 1/2 binary64)))))) |
(+.f64 #s(literal 1/2 binary64) (*.f64 #s(literal 1/4 binary64) a)) |
(+.f64 (*.f64 #s(literal 1/4 binary64) a) #s(literal 1/2 binary64)) |
#s(literal 1/4 binary64) |
#s(literal 1/2 binary64) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (pow.f64 #s(approx (- (exp b) -1) (+.f64 #s(literal 2 binary64) b)) #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) (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 (+.f64 (pow.f64 b #s(literal 3 binary64)) #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) (pow.f64 b #s(literal 3 binary64)))) (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) (pow.f64 b #s(literal 3 binary64))) (+.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 (pow.f64 b #s(literal 3 binary64)) (+.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))) (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))) |
(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 #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 (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)))) |
(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 (pow.f64 (*.f64 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b) #s(literal 2 binary64)) #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) (pow.f64 (*.f64 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b) #s(literal 2 binary64)))) (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 (+.f64 (pow.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 (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 (pow.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 (pow.f64 (*.f64 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b) #s(literal 2 binary64)) #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) (pow.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 (pow.f64 (*.f64 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b) #s(literal 3 binary64)) #s(literal 8 binary64)) (+.f64 (pow.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 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 (pow.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))))) |
(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 (pow.f64 (*.f64 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b) #s(literal 2 binary64)) (-.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 (pow.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 #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)) (+.f64 (pow.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 #s(literal 8 binary64) (+.f64 (pow.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 8 binary64) (+.f64 #s(literal 4 binary64) (-.f64 (pow.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 (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 (pow.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 (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 (pow.f64 b #s(literal -1 binary64)) #s(literal 1/2 binary64)) b) |
(*.f64 b (+.f64 (pow.f64 b #s(literal -1 binary64)) #s(literal 1/2 binary64))) |
(/.f64 (fma.f64 (pow.f64 b #s(literal 3 binary64)) #s(literal 1/8 binary64) (pow.f64 (*.f64 b (pow.f64 b #s(literal -1 binary64))) #s(literal 3 binary64))) (+.f64 (pow.f64 (*.f64 #s(literal 1/2 binary64) b) #s(literal 2 binary64)) (-.f64 (*.f64 (*.f64 b (pow.f64 b #s(literal -1 binary64))) (*.f64 b (pow.f64 b #s(literal -1 binary64)))) (*.f64 (*.f64 #s(literal 1/2 binary64) b) (*.f64 b (pow.f64 b #s(literal -1 binary64))))))) |
(/.f64 (neg.f64 (-.f64 #s(literal 1 binary64) (pow.f64 (*.f64 #s(literal 1/2 binary64) b) #s(literal 2 binary64)))) (neg.f64 (-.f64 #s(literal 1 binary64) (*.f64 #s(literal 1/2 binary64) b)))) |
(/.f64 (neg.f64 (-.f64 (pow.f64 (*.f64 #s(literal 1/2 binary64) b) #s(literal 2 binary64)) #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 (pow.f64 b #s(literal 3 binary64)) #s(literal 1/8 binary64)))) (neg.f64 (+.f64 #s(literal 1 binary64) (-.f64 (pow.f64 (*.f64 #s(literal 1/2 binary64) b) #s(literal 2 binary64)) (*.f64 #s(literal 1 binary64) (*.f64 #s(literal 1/2 binary64) b)))))) |
(/.f64 (neg.f64 (fma.f64 (pow.f64 b #s(literal 3 binary64)) #s(literal 1/8 binary64) #s(literal 1 binary64))) (neg.f64 (+.f64 (pow.f64 (*.f64 #s(literal 1/2 binary64) b) #s(literal 2 binary64)) (-.f64 #s(literal 1 binary64) (*.f64 (*.f64 #s(literal 1/2 binary64) b) #s(literal 1 binary64)))))) |
(/.f64 (-.f64 #s(literal 1 binary64) (pow.f64 (*.f64 #s(literal 1/2 binary64) b) #s(literal 2 binary64))) (-.f64 #s(literal 1 binary64) (*.f64 #s(literal 1/2 binary64) b))) |
(/.f64 (-.f64 (pow.f64 (*.f64 #s(literal 1/2 binary64) b) #s(literal 2 binary64)) #s(literal 1 binary64)) (-.f64 (*.f64 #s(literal 1/2 binary64) b) #s(literal 1 binary64))) |
(/.f64 (+.f64 #s(literal 1 binary64) (*.f64 (pow.f64 b #s(literal 3 binary64)) #s(literal 1/8 binary64))) (+.f64 #s(literal 1 binary64) (-.f64 (pow.f64 (*.f64 #s(literal 1/2 binary64) b) #s(literal 2 binary64)) (*.f64 #s(literal 1 binary64) (*.f64 #s(literal 1/2 binary64) b))))) |
(/.f64 (fma.f64 (pow.f64 b #s(literal 3 binary64)) #s(literal 1/8 binary64) #s(literal 1 binary64)) (+.f64 (pow.f64 (*.f64 #s(literal 1/2 binary64) b) #s(literal 2 binary64)) (-.f64 #s(literal 1 binary64) (*.f64 (*.f64 #s(literal 1/2 binary64) b) #s(literal 1 binary64))))) |
(fma.f64 #s(literal 1/2 binary64) b (*.f64 b (pow.f64 b #s(literal -1 binary64)))) |
(fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) |
(fma.f64 b #s(literal 1/2 binary64) (*.f64 b (pow.f64 b #s(literal -1 binary64)))) |
(fma.f64 b #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) b))) (/.f64 (pow.f64 (*.f64 #s(literal 1/2 binary64) b) #s(literal 2 binary64)) (-.f64 #s(literal 1 binary64) (*.f64 #s(literal 1/2 binary64) b)))) |
(-.f64 (/.f64 (pow.f64 (*.f64 #s(literal 1/2 binary64) b) #s(literal 2 binary64)) (-.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 #s(literal 1 binary64) (*.f64 #s(literal -1/2 binary64) b)) |
(+.f64 (/.f64 #s(literal 1 binary64) (+.f64 #s(literal 1 binary64) (-.f64 (pow.f64 (*.f64 #s(literal 1/2 binary64) b) #s(literal 2 binary64)) (*.f64 #s(literal 1 binary64) (*.f64 #s(literal 1/2 binary64) b))))) (/.f64 (*.f64 (pow.f64 b #s(literal 3 binary64)) #s(literal 1/8 binary64)) (+.f64 #s(literal 1 binary64) (-.f64 (pow.f64 (*.f64 #s(literal 1/2 binary64) b) #s(literal 2 binary64)) (*.f64 #s(literal 1 binary64) (*.f64 #s(literal 1/2 binary64) b)))))) |
(+.f64 (/.f64 (*.f64 (pow.f64 b #s(literal 3 binary64)) #s(literal 1/8 binary64)) (+.f64 (pow.f64 (*.f64 #s(literal 1/2 binary64) b) #s(literal 2 binary64)) (-.f64 #s(literal 1 binary64) (*.f64 (*.f64 #s(literal 1/2 binary64) b) #s(literal 1 binary64))))) (/.f64 #s(literal 1 binary64) (+.f64 (pow.f64 (*.f64 #s(literal 1/2 binary64) b) #s(literal 2 binary64)) (-.f64 #s(literal 1 binary64) (*.f64 (*.f64 #s(literal 1/2 binary64) b) #s(literal 1 binary64)))))) |
(+.f64 (*.f64 #s(literal 1/2 binary64) b) (*.f64 b (pow.f64 b #s(literal -1 binary64)))) |
(+.f64 (*.f64 #s(literal 1/2 binary64) b) #s(literal 1 binary64)) |
(+.f64 #s(literal 1 binary64) (*.f64 #s(literal 1/2 binary64) b)) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (pow.f64 (+.f64 (exp.f64 b) #s(literal 1 binary64)) #s(literal -1 binary64))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (fma.f64 (-.f64 (pow.f64 (+.f64 (exp.f64 b) #s(literal 1 binary64)) #s(literal -1 binary64)) (pow.f64 (+.f64 (exp.f64 b) #s(literal 1 binary64)) #s(literal -2 binary64))) a (pow.f64 (+.f64 (exp.f64 b) #s(literal 1 binary64)) #s(literal -1 binary64)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (fma.f64 (-.f64 (fma.f64 (-.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 #s(literal 3/2 binary64) (pow.f64 (+.f64 (exp.f64 b) #s(literal 1 binary64)) #s(literal -2 binary64)))) a (pow.f64 (+.f64 (exp.f64 b) #s(literal 1 binary64)) #s(literal -1 binary64))) (pow.f64 (+.f64 (exp.f64 b) #s(literal 1 binary64)) #s(literal -2 binary64))) a (pow.f64 (+.f64 (exp.f64 b) #s(literal 1 binary64)) #s(literal -1 binary64)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (fma.f64 (-.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) (pow.f64 (+.f64 (exp.f64 b) #s(literal 1 binary64)) #s(literal 2 binary64))) (fma.f64 (/.f64 (-.f64 (pow.f64 (+.f64 (exp.f64 b) #s(literal 1 binary64)) #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))) #s(literal 1/2 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 #s(literal 3/2 binary64) (pow.f64 (+.f64 (exp.f64 b) #s(literal 1 binary64)) #s(literal -2 binary64)))) a (pow.f64 (+.f64 (exp.f64 b) #s(literal 1 binary64)) #s(literal -1 binary64))) (pow.f64 (+.f64 (exp.f64 b) #s(literal 1 binary64)) #s(literal -2 binary64))) a (pow.f64 (+.f64 (exp.f64 b) #s(literal 1 binary64)) #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 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 (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) (fma.f64 #s(literal 1/4 binary64) (neg.f64 b) #s(literal 1/2 binary64))) |
#s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) (fma.f64 #s(literal 1/4 binary64) a (fma.f64 #s(literal 1/4 binary64) (neg.f64 b) #s(literal 1/2 binary64)))) |
#s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) (+.f64 (fma.f64 (fma.f64 (*.f64 (*.f64 #s(literal 1/4 binary64) b) a) #s(literal 1/4 binary64) #s(literal 1/4 binary64)) a (*.f64 #s(literal 1/4 binary64) (neg.f64 b))) #s(literal 1/2 binary64))) |
#s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) (+.f64 (fma.f64 (fma.f64 (fma.f64 #s(literal -1/48 binary64) a (*.f64 (*.f64 #s(literal 1/4 binary64) b) #s(literal 1/4 binary64))) a #s(literal 1/4 binary64)) a (*.f64 #s(literal 1/4 binary64) (neg.f64 b))) #s(literal 1/2 binary64))) |
#s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) (fma.f64 #s(literal -1/4 binary64) b #s(literal 1/2 binary64))) |
#s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) (+.f64 (fma.f64 #s(literal -1/4 binary64) b (*.f64 #s(literal 1/4 binary64) a)) #s(literal 1/2 binary64))) |
#s(approx (+ (* 1/4 a) 1/2) #s(literal 1/2 binary64)) |
#s(approx (+ (* 1/4 a) 1/2) (fma.f64 #s(literal 1/4 binary64) a #s(literal 1/2 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 (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) (fma.f64 (exp.f64 (-.f64 a (*.f64 #s(literal 2 binary64) (log1p.f64 (exp.f64 a))))) (neg.f64 b) (/.f64 (exp.f64 a) (+.f64 #s(literal 1 binary64) (exp.f64 a))))) |
#s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) (*.f64 #s(literal 1/4 binary64) a)) |
#s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) (*.f64 (+.f64 (/.f64 (fma.f64 #s(literal -1/4 binary64) b #s(literal 1/2 binary64)) a) #s(literal 1/4 binary64)) a)) |
#s(approx (+ (* 1/4 a) 1/2) (*.f64 #s(literal 1/4 binary64) a)) |
#s(approx (+ (* 1/4 a) 1/2) (*.f64 (+.f64 (/.f64 #s(literal 1/2 binary64) a) #s(literal 1/4 binary64)) a)) |
#s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) (fma.f64 (*.f64 #s(literal -1 binary64) b) (exp.f64 (neg.f64 (fma.f64 #s(literal 2 binary64) (log1p.f64 (exp.f64 a)) (neg.f64 a)))) (/.f64 (exp.f64 a) (+.f64 #s(literal 1 binary64) (exp.f64 a))))) |
#s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) (*.f64 (neg.f64 a) (-.f64 (neg.f64 (/.f64 (fma.f64 #s(literal -1/4 binary64) b #s(literal 1/2 binary64)) a)) #s(literal 1/4 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))) (fma.f64 (exp.f64 (-.f64 a (*.f64 #s(literal 2 binary64) (log1p.f64 (exp.f64 a))))) (neg.f64 b) (/.f64 (exp.f64 a) (+.f64 #s(literal 1 binary64) (exp.f64 a))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (fma.f64 (-.f64 (neg.f64 (*.f64 (fma.f64 (exp.f64 (-.f64 a (*.f64 #s(literal 2 binary64) (log1p.f64 (exp.f64 a))))) #s(literal 1/2 binary64) (neg.f64 (exp.f64 (-.f64 a (*.f64 (log1p.f64 (exp.f64 a)) #s(literal 3 binary64)))))) b)) (exp.f64 (-.f64 a (*.f64 #s(literal 2 binary64) (log1p.f64 (exp.f64 a)))))) b (/.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 (fma.f64 (/.f64 (fma.f64 (exp.f64 (-.f64 a (*.f64 #s(literal 2 binary64) (log1p.f64 (exp.f64 a))))) #s(literal 1/2 binary64) (neg.f64 (exp.f64 (-.f64 a (*.f64 (log1p.f64 (exp.f64 a)) #s(literal 3 binary64)))))) (+.f64 #s(literal 1 binary64) (exp.f64 a))) #s(literal -1 binary64) (fma.f64 #s(literal -1/2 binary64) (exp.f64 (-.f64 a (*.f64 (log1p.f64 (exp.f64 a)) #s(literal 3 binary64)))) (*.f64 (exp.f64 (-.f64 a (*.f64 #s(literal 2 binary64) (log1p.f64 (exp.f64 a))))) #s(literal 1/6 binary64)))) b)) (fma.f64 (exp.f64 (-.f64 a (*.f64 #s(literal 2 binary64) (log1p.f64 (exp.f64 a))))) #s(literal 1/2 binary64) (neg.f64 (exp.f64 (-.f64 a (*.f64 (log1p.f64 (exp.f64 a)) #s(literal 3 binary64))))))) b) (exp.f64 (-.f64 a (*.f64 #s(literal 2 binary64) (log1p.f64 (exp.f64 a)))))) 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 (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) (/.f64 (exp.f64 a) (+.f64 #s(literal 1 binary64) (exp.f64 a)))) |
#s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) (fma.f64 #s(literal 1/4 binary64) a #s(literal 1/2 binary64))) |
#s(approx (* -1/4 b) (*.f64 #s(literal -1/4 binary64) b)) |
#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 (+ (* (+ (* 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) (exp.f64 b)) |
#s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) (*.f64 (exp.f64 (-.f64 a (*.f64 #s(literal 2 binary64) (log1p.f64 (exp.f64 a))))) (neg.f64 b))) |
#s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) (*.f64 (fma.f64 (exp.f64 (-.f64 a (*.f64 #s(literal 2 binary64) (log1p.f64 (exp.f64 a))))) #s(literal -1 binary64) (/.f64 (/.f64 (exp.f64 a) b) (+.f64 #s(literal 1 binary64) (exp.f64 a)))) b)) |
#s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) (*.f64 #s(literal -1/4 binary64) b)) |
#s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) (*.f64 (-.f64 (/.f64 (fma.f64 #s(literal 1/4 binary64) a #s(literal 1/2 binary64)) b) #s(literal 1/4 binary64)) b)) |
#s(approx (/ 1 (- (exp b) -1)) (pow.f64 (+.f64 (exp.f64 b) #s(literal 1 binary64)) #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 (+ (* (+ (* 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 (pow.f64 b #s(literal -1 binary64)) #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 (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) (neg.f64 (*.f64 (fma.f64 (exp.f64 a) (exp.f64 (*.f64 #s(literal -2 binary64) (log1p.f64 (exp.f64 a)))) (neg.f64 (/.f64 (/.f64 (exp.f64 a) b) (+.f64 #s(literal 1 binary64) (exp.f64 a))))) b))) |
#s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) (neg.f64 (*.f64 (fma.f64 (/.f64 (fma.f64 #s(literal 1/4 binary64) a #s(literal 1/2 binary64)) b) #s(literal -1 binary64) #s(literal 1/4 binary64)) b))) |
Compiled 6 834 to 920 computations (86.5% saved)
21 alts after pruning (12 fresh and 9 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 194 | 6 | 200 |
| Fresh | 0 | 6 | 6 |
| Picked | 0 | 5 | 5 |
| Done | 0 | 4 | 4 |
| Total | 194 | 21 | 215 |
| Status | Accuracy | Program |
|---|---|---|
| ✓ | 66.5% | (/.f64 (exp.f64 a) (+.f64 (exp.f64 a) #s(approx (exp b) #s(literal 1 binary64)))) |
| ✓ | 65.8% | (/.f64 (exp.f64 a) (+.f64 #s(approx (exp a) #s(literal 1 binary64)) #s(approx (exp b) #s(literal 1 binary64)))) |
| 40.1% | (/.f64 #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))) (+.f64 #s(approx (exp a) #s(literal 1 binary64)) #s(approx (exp b) #s(literal 1 binary64)))) | |
| 40.2% | (/.f64 #s(approx (exp a) (fma.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a #s(literal 1 binary64))) (+.f64 #s(approx (exp a) #s(literal 1 binary64)) #s(approx (exp b) #s(literal 1 binary64)))) | |
| 40.3% | (/.f64 #s(approx (exp a) (+.f64 #s(literal 1 binary64) a)) (+.f64 #s(approx (exp a) #s(literal 1 binary64)) #s(approx (exp b) #s(literal 1 binary64)))) | |
| ✓ | 81.5% | #s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) (-.f64 (exp.f64 b) #s(literal -1 binary64)))) |
| 58.0% | #s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 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))))) | |
| ✓ | 55.1% | #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))))) |
| ✓ | 38.7% | #s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) #s(approx (- (exp b) -1) (+.f64 #s(literal 2 binary64) b)))) |
| 20.0% | #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))))) | |
| 20.3% | #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.6% | #s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) #s(approx (- (exp b) -1) #s(approx (+ 2 b) b)))) | |
| ✓ | 37.8% | #s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (pow (- (exp b) -1) -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)))) |
| 37.4% | #s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (pow (- (exp b) -1) -1) (fma.f64 (-.f64 (*.f64 (*.f64 b b) #s(literal 1/48 binary64)) #s(literal 1/4 binary64)) b #s(literal 1/2 binary64)))) | |
| 38.2% | #s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (pow (- (exp b) -1) -1) (fma.f64 #s(approx (- (* (+ (* -1/480 (* b b)) 1/48) (* b b)) 1/4) #s(literal -1/4 binary64)) b #s(literal 1/2 binary64)))) | |
| 18.4% | #s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (pow (- (exp b) -1) -1) #s(approx (+ (* (- (* (+ (* -1/480 (* b b)) 1/48) (* b b)) 1/4) b) 1/2) (*.f64 (pow.f64 b #s(literal 5 binary64)) #s(literal -1/480 binary64))))) | |
| ✓ | 40.5% | #s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (pow (- (exp b) -1) -1) #s(literal 1/2 binary64))) |
| 38.1% | #s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) (+.f64 (fma.f64 (fma.f64 (fma.f64 #s(literal -1/48 binary64) a (*.f64 (*.f64 #s(literal 1/4 binary64) b) #s(literal 1/4 binary64))) a #s(literal 1/4 binary64)) a (*.f64 #s(literal 1/4 binary64) (neg.f64 b))) #s(literal 1/2 binary64)))) | |
| ✓ | 40.5% | #s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) (fma.f64 #s(literal 1/4 binary64) a #s(literal 1/2 binary64))))) |
| 3.9% | #s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) (*.f64 #s(literal 1/4 binary64) a)))) | |
| ✓ | 3.8% | #s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) (*.f64 #s(literal -1/4 binary64) b)))) |
Compiled 1 364 to 581 computations (57.4% saved)
| Inputs |
|---|
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (pow (- (exp b) -1) -1) #s(literal 1/2 binary64))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) (*.f64 #s(literal -1/4 binary64) b)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) (*.f64 #s(literal 1/4 binary64) a)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) (fma.f64 #s(literal 1/4 binary64) a #s(literal 1/2 binary64))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (pow (- (exp b) -1) -1) (fma.f64 #s(literal -1/4 binary64) b #s(literal 1/2 binary64)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (pow (- (exp b) -1) -1) (fma.f64 #s(approx (- (* (+ (* -1/480 (* b b)) 1/48) (* b b)) 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) #s(approx (+ 2 b) b)))) |
#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 (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) (+.f64 (fma.f64 #s(literal 1/4 binary64) a (*.f64 (neg.f64 b) #s(literal 1/4 binary64))) #s(literal 1/2 binary64)))) |
(/.f64 #s(approx (exp a) (+.f64 #s(literal 1 binary64) a)) (+.f64 #s(approx (exp a) #s(literal 1 binary64)) #s(approx (exp b) #s(literal 1 binary64)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (pow (- (exp b) -1) -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 (/ (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 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b #s(literal 2 binary64))))) |
(/.f64 #s(approx (exp a) (fma.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a #s(literal 1 binary64))) (+.f64 #s(approx (exp a) #s(literal 1 binary64)) #s(approx (exp b) #s(literal 1 binary64)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 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 a) (+ (exp a) (exp b))) #s(approx (pow (- (exp b) -1) -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)))) |
(/.f64 #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))) (+.f64 #s(approx (exp a) #s(literal 1 binary64)) #s(approx (exp b) #s(literal 1 binary64)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) (+.f64 (fma.f64 (fma.f64 (fma.f64 #s(literal -1/48 binary64) a (*.f64 #s(literal 1/4 binary64) (*.f64 #s(literal 1/4 binary64) b))) a #s(literal 1/4 binary64)) a (*.f64 (neg.f64 b) #s(literal 1/4 binary64))) #s(literal 1/2 binary64)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) (+.f64 (fma.f64 (fma.f64 (fma.f64 #s(literal -1/48 binary64) a (*.f64 (*.f64 #s(literal 1/4 binary64) b) #s(literal 1/4 binary64))) a #s(literal 1/4 binary64)) a (*.f64 #s(literal 1/4 binary64) (neg.f64 b))) #s(literal 1/2 binary64)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (pow.f64 #s(approx (- (exp b) -1) (+.f64 #s(literal 2 binary64) b)) #s(literal -1 binary64))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (pow (- (exp b) -1) -1) #s(approx (+ (* (- (* (+ (* -1/480 (* b b)) 1/48) (* b b)) 1/4) b) 1/2) (*.f64 (pow.f64 b #s(literal 5 binary64)) #s(literal -1/480 binary64))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (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))) |
#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) (+.f64 #s(approx (exp a) #s(literal 1 binary64)) #s(approx (exp b) #s(literal 1 binary64)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (pow.f64 (-.f64 (exp.f64 b) #s(literal -1 binary64)) #s(literal -1 binary64))) |
(/.f64 (exp.f64 a) (+.f64 (exp.f64 a) #s(approx (exp b) #s(literal 1 binary64)))) |
(/.f64 (exp.f64 a) (+.f64 (exp.f64 a) (exp.f64 b))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (fma.f64 (neg.f64 b) (exp.f64 (-.f64 a (*.f64 (log1p.f64 (exp.f64 a)) #s(literal 2 binary64)))) (/.f64 (exp.f64 a) (-.f64 (exp.f64 a) #s(literal -1 binary64))))) |
| Outputs |
|---|
(/.f64 (exp.f64 a) (+.f64 (exp.f64 a) (exp.f64 b))) |
5 calls:
| 8.0ms | b |
| 8.0ms | a |
| 7.0ms | (exp.f64 a) |
| 6.0ms | (exp.f64 b) |
| 6.0ms | (/.f64 (exp.f64 a) (+.f64 (exp.f64 a) (exp.f64 b))) |
| Accuracy | Segments | Branch |
|---|---|---|
| 99.6% | 1 | (exp.f64 b) |
| 99.6% | 1 | (exp.f64 a) |
| 99.6% | 1 | (/.f64 (exp.f64 a) (+.f64 (exp.f64 a) (exp.f64 b))) |
| 99.6% | 1 | a |
| 99.6% | 1 | b |
Compiled 14 to 16 computations (-14.3% saved)
| Inputs |
|---|
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (pow (- (exp b) -1) -1) #s(literal 1/2 binary64))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) (*.f64 #s(literal -1/4 binary64) b)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) (*.f64 #s(literal 1/4 binary64) a)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) (fma.f64 #s(literal 1/4 binary64) a #s(literal 1/2 binary64))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (pow (- (exp b) -1) -1) (fma.f64 #s(literal -1/4 binary64) b #s(literal 1/2 binary64)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (pow (- (exp b) -1) -1) (fma.f64 #s(approx (- (* (+ (* -1/480 (* b b)) 1/48) (* b b)) 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) #s(approx (+ 2 b) b)))) |
#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 (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) (+.f64 (fma.f64 #s(literal 1/4 binary64) a (*.f64 (neg.f64 b) #s(literal 1/4 binary64))) #s(literal 1/2 binary64)))) |
(/.f64 #s(approx (exp a) (+.f64 #s(literal 1 binary64) a)) (+.f64 #s(approx (exp a) #s(literal 1 binary64)) #s(approx (exp b) #s(literal 1 binary64)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (pow (- (exp b) -1) -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 (/ (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 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b #s(literal 2 binary64))))) |
(/.f64 #s(approx (exp a) (fma.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a #s(literal 1 binary64))) (+.f64 #s(approx (exp a) #s(literal 1 binary64)) #s(approx (exp b) #s(literal 1 binary64)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 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 a) (+ (exp a) (exp b))) #s(approx (pow (- (exp b) -1) -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)))) |
(/.f64 #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))) (+.f64 #s(approx (exp a) #s(literal 1 binary64)) #s(approx (exp b) #s(literal 1 binary64)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) (+.f64 (fma.f64 (fma.f64 (fma.f64 #s(literal -1/48 binary64) a (*.f64 #s(literal 1/4 binary64) (*.f64 #s(literal 1/4 binary64) b))) a #s(literal 1/4 binary64)) a (*.f64 (neg.f64 b) #s(literal 1/4 binary64))) #s(literal 1/2 binary64)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) (+.f64 (fma.f64 (fma.f64 (fma.f64 #s(literal -1/48 binary64) a (*.f64 (*.f64 #s(literal 1/4 binary64) b) #s(literal 1/4 binary64))) a #s(literal 1/4 binary64)) a (*.f64 #s(literal 1/4 binary64) (neg.f64 b))) #s(literal 1/2 binary64)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (pow.f64 #s(approx (- (exp b) -1) (+.f64 #s(literal 2 binary64) b)) #s(literal -1 binary64))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (pow (- (exp b) -1) -1) #s(approx (+ (* (- (* (+ (* -1/480 (* b b)) 1/48) (* b b)) 1/4) b) 1/2) (*.f64 (pow.f64 b #s(literal 5 binary64)) #s(literal -1/480 binary64))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (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))) |
#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) (+.f64 #s(approx (exp a) #s(literal 1 binary64)) #s(approx (exp b) #s(literal 1 binary64)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (pow.f64 (-.f64 (exp.f64 b) #s(literal -1 binary64)) #s(literal -1 binary64))) |
(/.f64 (exp.f64 a) (+.f64 (exp.f64 a) #s(approx (exp b) #s(literal 1 binary64)))) |
| Outputs |
|---|
(/.f64 (exp.f64 a) (+.f64 (exp.f64 a) #s(approx (exp 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)))) |
5 calls:
| 13.0ms | (exp.f64 a) |
| 7.0ms | b |
| 7.0ms | a |
| 5.0ms | (exp.f64 b) |
| 5.0ms | (/.f64 (exp.f64 a) (+.f64 (exp.f64 a) (exp.f64 b))) |
| Accuracy | Segments | Branch |
|---|---|---|
| 99.9% | 3 | (exp.f64 b) |
| 99.3% | 2 | (exp.f64 a) |
| 81.5% | 1 | (/.f64 (exp.f64 a) (+.f64 (exp.f64 a) (exp.f64 b))) |
| 99.3% | 2 | a |
| 99.9% | 3 | b |
Compiled 14 to 16 computations (-14.3% saved)
| Inputs |
|---|
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (pow (- (exp b) -1) -1) #s(literal 1/2 binary64))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) (*.f64 #s(literal -1/4 binary64) b)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) (*.f64 #s(literal 1/4 binary64) a)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) (fma.f64 #s(literal 1/4 binary64) a #s(literal 1/2 binary64))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (pow (- (exp b) -1) -1) (fma.f64 #s(literal -1/4 binary64) b #s(literal 1/2 binary64)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (pow (- (exp b) -1) -1) (fma.f64 #s(approx (- (* (+ (* -1/480 (* b b)) 1/48) (* b b)) 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) #s(approx (+ 2 b) b)))) |
#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 (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) (+.f64 (fma.f64 #s(literal 1/4 binary64) a (*.f64 (neg.f64 b) #s(literal 1/4 binary64))) #s(literal 1/2 binary64)))) |
(/.f64 #s(approx (exp a) (+.f64 #s(literal 1 binary64) a)) (+.f64 #s(approx (exp a) #s(literal 1 binary64)) #s(approx (exp b) #s(literal 1 binary64)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (pow (- (exp b) -1) -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 (/ (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 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b #s(literal 2 binary64))))) |
(/.f64 #s(approx (exp a) (fma.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a #s(literal 1 binary64))) (+.f64 #s(approx (exp a) #s(literal 1 binary64)) #s(approx (exp b) #s(literal 1 binary64)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 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 a) (+ (exp a) (exp b))) #s(approx (pow (- (exp b) -1) -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)))) |
(/.f64 #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))) (+.f64 #s(approx (exp a) #s(literal 1 binary64)) #s(approx (exp b) #s(literal 1 binary64)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) (+.f64 (fma.f64 (fma.f64 (fma.f64 #s(literal -1/48 binary64) a (*.f64 #s(literal 1/4 binary64) (*.f64 #s(literal 1/4 binary64) b))) a #s(literal 1/4 binary64)) a (*.f64 (neg.f64 b) #s(literal 1/4 binary64))) #s(literal 1/2 binary64)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) (+.f64 (fma.f64 (fma.f64 (fma.f64 #s(literal -1/48 binary64) a (*.f64 (*.f64 #s(literal 1/4 binary64) b) #s(literal 1/4 binary64))) a #s(literal 1/4 binary64)) a (*.f64 #s(literal 1/4 binary64) (neg.f64 b))) #s(literal 1/2 binary64)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (pow.f64 #s(approx (- (exp b) -1) (+.f64 #s(literal 2 binary64) b)) #s(literal -1 binary64))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (pow (- (exp b) -1) -1) #s(approx (+ (* (- (* (+ (* -1/480 (* b b)) 1/48) (* b b)) 1/4) b) 1/2) (*.f64 (pow.f64 b #s(literal 5 binary64)) #s(literal -1/480 binary64))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (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))) |
#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) (+.f64 #s(approx (exp a) #s(literal 1 binary64)) #s(approx (exp b) #s(literal 1 binary64)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (pow.f64 (-.f64 (exp.f64 b) #s(literal -1 binary64)) #s(literal -1 binary64))) |
| Outputs |
|---|
(/.f64 (exp.f64 a) (+.f64 #s(approx (exp a) #s(literal 1 binary64)) #s(approx (exp 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)))) |
2 calls:
| 7.0ms | a |
| 5.0ms | (exp.f64 a) |
| Accuracy | Segments | Branch |
|---|---|---|
| 99.3% | 2 | (exp.f64 a) |
| 99.3% | 2 | a |
Compiled 3 to 5 computations (-66.7% saved)
| Inputs |
|---|
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (pow (- (exp b) -1) -1) #s(literal 1/2 binary64))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) (*.f64 #s(literal -1/4 binary64) b)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) (*.f64 #s(literal 1/4 binary64) a)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) (fma.f64 #s(literal 1/4 binary64) a #s(literal 1/2 binary64))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (pow (- (exp b) -1) -1) (fma.f64 #s(literal -1/4 binary64) b #s(literal 1/2 binary64)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (pow (- (exp b) -1) -1) (fma.f64 #s(approx (- (* (+ (* -1/480 (* b b)) 1/48) (* b b)) 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) #s(approx (+ 2 b) b)))) |
#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 (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) (+.f64 (fma.f64 #s(literal 1/4 binary64) a (*.f64 (neg.f64 b) #s(literal 1/4 binary64))) #s(literal 1/2 binary64)))) |
(/.f64 #s(approx (exp a) (+.f64 #s(literal 1 binary64) a)) (+.f64 #s(approx (exp a) #s(literal 1 binary64)) #s(approx (exp b) #s(literal 1 binary64)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (pow (- (exp b) -1) -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 (/ (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 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b #s(literal 2 binary64))))) |
(/.f64 #s(approx (exp a) (fma.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a #s(literal 1 binary64))) (+.f64 #s(approx (exp a) #s(literal 1 binary64)) #s(approx (exp b) #s(literal 1 binary64)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 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 a) (+ (exp a) (exp b))) #s(approx (pow (- (exp b) -1) -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)))) |
(/.f64 #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))) (+.f64 #s(approx (exp a) #s(literal 1 binary64)) #s(approx (exp b) #s(literal 1 binary64)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) (+.f64 (fma.f64 (fma.f64 (fma.f64 #s(literal -1/48 binary64) a (*.f64 #s(literal 1/4 binary64) (*.f64 #s(literal 1/4 binary64) b))) a #s(literal 1/4 binary64)) a (*.f64 (neg.f64 b) #s(literal 1/4 binary64))) #s(literal 1/2 binary64)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) (+.f64 (fma.f64 (fma.f64 (fma.f64 #s(literal -1/48 binary64) a (*.f64 (*.f64 #s(literal 1/4 binary64) b) #s(literal 1/4 binary64))) a #s(literal 1/4 binary64)) a (*.f64 #s(literal 1/4 binary64) (neg.f64 b))) #s(literal 1/2 binary64)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (pow.f64 #s(approx (- (exp b) -1) (+.f64 #s(literal 2 binary64) b)) #s(literal -1 binary64))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (pow (- (exp b) -1) -1) #s(approx (+ (* (- (* (+ (* -1/480 (* b b)) 1/48) (* b b)) 1/4) b) 1/2) (*.f64 (pow.f64 b #s(literal 5 binary64)) #s(literal -1/480 binary64))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (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))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) (-.f64 (exp.f64 b) #s(literal -1 binary64)))) |
| Outputs |
|---|
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (pow (- (exp b) -1) -1) #s(approx (+ (* (- (* (+ (* -1/480 (* b b)) 1/48) (* b b)) 1/4) b) 1/2) (*.f64 (pow.f64 b #s(literal 5 binary64)) #s(literal -1/480 binary64))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) (-.f64 (exp.f64 b) #s(literal -1 binary64)))) |
4 calls:
| 8.0ms | b |
| 6.0ms | a |
| 5.0ms | (exp.f64 b) |
| 5.0ms | (exp.f64 a) |
| Accuracy | Segments | Branch |
|---|---|---|
| 81.5% | 1 | (exp.f64 b) |
| 81.5% | 1 | b |
| 89.4% | 2 | (exp.f64 a) |
| 89.8% | 2 | a |
Compiled 6 to 10 computations (-66.7% saved)
| Inputs |
|---|
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (pow (- (exp b) -1) -1) #s(literal 1/2 binary64))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) (*.f64 #s(literal -1/4 binary64) b)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) (*.f64 #s(literal 1/4 binary64) a)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) (fma.f64 #s(literal 1/4 binary64) a #s(literal 1/2 binary64))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (pow (- (exp b) -1) -1) (fma.f64 #s(literal -1/4 binary64) b #s(literal 1/2 binary64)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (pow (- (exp b) -1) -1) (fma.f64 #s(approx (- (* (+ (* -1/480 (* b b)) 1/48) (* b b)) 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) #s(approx (+ 2 b) b)))) |
#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 (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) (+.f64 (fma.f64 #s(literal 1/4 binary64) a (*.f64 (neg.f64 b) #s(literal 1/4 binary64))) #s(literal 1/2 binary64)))) |
(/.f64 #s(approx (exp a) (+.f64 #s(literal 1 binary64) a)) (+.f64 #s(approx (exp a) #s(literal 1 binary64)) #s(approx (exp b) #s(literal 1 binary64)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (pow (- (exp b) -1) -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 (/ (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 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b #s(literal 2 binary64))))) |
(/.f64 #s(approx (exp a) (fma.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a #s(literal 1 binary64))) (+.f64 #s(approx (exp a) #s(literal 1 binary64)) #s(approx (exp b) #s(literal 1 binary64)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 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 a) (+ (exp a) (exp b))) #s(approx (pow (- (exp b) -1) -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)))) |
(/.f64 #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))) (+.f64 #s(approx (exp a) #s(literal 1 binary64)) #s(approx (exp b) #s(literal 1 binary64)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) (+.f64 (fma.f64 (fma.f64 (fma.f64 #s(literal -1/48 binary64) a (*.f64 #s(literal 1/4 binary64) (*.f64 #s(literal 1/4 binary64) b))) a #s(literal 1/4 binary64)) a (*.f64 (neg.f64 b) #s(literal 1/4 binary64))) #s(literal 1/2 binary64)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) (+.f64 (fma.f64 (fma.f64 (fma.f64 #s(literal -1/48 binary64) a (*.f64 (*.f64 #s(literal 1/4 binary64) b) #s(literal 1/4 binary64))) a #s(literal 1/4 binary64)) a (*.f64 #s(literal 1/4 binary64) (neg.f64 b))) #s(literal 1/2 binary64)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (pow.f64 #s(approx (- (exp b) -1) (+.f64 #s(literal 2 binary64) b)) #s(literal -1 binary64))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (pow (- (exp b) -1) -1) #s(approx (+ (* (- (* (+ (* -1/480 (* b b)) 1/48) (* b b)) 1/4) b) 1/2) (*.f64 (pow.f64 b #s(literal 5 binary64)) #s(literal -1/480 binary64))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (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))) |
| Outputs |
|---|
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (pow (- (exp b) -1) -1) #s(approx (+ (* (- (* (+ (* -1/480 (* b b)) 1/48) (* b b)) 1/4) b) 1/2) (*.f64 (pow.f64 b #s(literal 5 binary64)) #s(literal -1/480 binary64))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 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))))) |
5 calls:
| 9.0ms | (/.f64 (exp.f64 a) (+.f64 (exp.f64 a) (exp.f64 b))) |
| 6.0ms | a |
| 6.0ms | b |
| 5.0ms | (exp.f64 b) |
| 5.0ms | (exp.f64 a) |
| Accuracy | Segments | Branch |
|---|---|---|
| 60.6% | 2 | (/.f64 (exp.f64 a) (+.f64 (exp.f64 a) (exp.f64 b))) |
| 60.6% | 2 | (exp.f64 b) |
| 60.6% | 2 | b |
| 68.1% | 2 | (exp.f64 a) |
| 68.1% | 2 | a |
Compiled 14 to 16 computations (-14.3% saved)
| Inputs |
|---|
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (pow (- (exp b) -1) -1) #s(literal 1/2 binary64))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) (*.f64 #s(literal -1/4 binary64) b)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) (*.f64 #s(literal 1/4 binary64) a)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) (fma.f64 #s(literal 1/4 binary64) a #s(literal 1/2 binary64))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (pow (- (exp b) -1) -1) (fma.f64 #s(literal -1/4 binary64) b #s(literal 1/2 binary64)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (pow (- (exp b) -1) -1) (fma.f64 #s(approx (- (* (+ (* -1/480 (* b b)) 1/48) (* b b)) 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) #s(approx (+ 2 b) b)))) |
#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 (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) (+.f64 (fma.f64 #s(literal 1/4 binary64) a (*.f64 (neg.f64 b) #s(literal 1/4 binary64))) #s(literal 1/2 binary64)))) |
(/.f64 #s(approx (exp a) (+.f64 #s(literal 1 binary64) a)) (+.f64 #s(approx (exp a) #s(literal 1 binary64)) #s(approx (exp b) #s(literal 1 binary64)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (pow (- (exp b) -1) -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 (/ (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 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b #s(literal 2 binary64))))) |
(/.f64 #s(approx (exp a) (fma.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a #s(literal 1 binary64))) (+.f64 #s(approx (exp a) #s(literal 1 binary64)) #s(approx (exp b) #s(literal 1 binary64)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 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 a) (+ (exp a) (exp b))) #s(approx (pow (- (exp b) -1) -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)))) |
(/.f64 #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))) (+.f64 #s(approx (exp a) #s(literal 1 binary64)) #s(approx (exp b) #s(literal 1 binary64)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) (+.f64 (fma.f64 (fma.f64 (fma.f64 #s(literal -1/48 binary64) a (*.f64 #s(literal 1/4 binary64) (*.f64 #s(literal 1/4 binary64) b))) a #s(literal 1/4 binary64)) a (*.f64 (neg.f64 b) #s(literal 1/4 binary64))) #s(literal 1/2 binary64)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) (+.f64 (fma.f64 (fma.f64 (fma.f64 #s(literal -1/48 binary64) a (*.f64 (*.f64 #s(literal 1/4 binary64) b) #s(literal 1/4 binary64))) a #s(literal 1/4 binary64)) a (*.f64 #s(literal 1/4 binary64) (neg.f64 b))) #s(literal 1/2 binary64)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) (pow.f64 #s(approx (- (exp b) -1) (+.f64 #s(literal 2 binary64) b)) #s(literal -1 binary64))) |
| Outputs |
|---|
#s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 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 a) (+ (exp a) (exp b))) #s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) (fma.f64 #s(literal 1/4 binary64) a #s(literal 1/2 binary64))))) |
3 calls:
| 6.0ms | a |
| 4.0ms | (/.f64 (exp.f64 a) (+.f64 (exp.f64 a) (exp.f64 b))) |
| 4.0ms | (exp.f64 a) |
| Accuracy | Segments | Branch |
|---|---|---|
| 60.6% | 2 | (/.f64 (exp.f64 a) (+.f64 (exp.f64 a) (exp.f64 b))) |
| 58.0% | 1 | (exp.f64 a) |
| 58.0% | 1 | a |
Compiled 11 to 11 computations (0% saved)
| Inputs |
|---|
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (pow (- (exp b) -1) -1) #s(literal 1/2 binary64))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) (*.f64 #s(literal -1/4 binary64) b)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) (*.f64 #s(literal 1/4 binary64) a)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) (fma.f64 #s(literal 1/4 binary64) a #s(literal 1/2 binary64))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (pow (- (exp b) -1) -1) (fma.f64 #s(literal -1/4 binary64) b #s(literal 1/2 binary64)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (pow (- (exp b) -1) -1) (fma.f64 #s(approx (- (* (+ (* -1/480 (* b b)) 1/48) (* b b)) 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) #s(approx (+ 2 b) b)))) |
#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 (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) (+.f64 (fma.f64 #s(literal 1/4 binary64) a (*.f64 (neg.f64 b) #s(literal 1/4 binary64))) #s(literal 1/2 binary64)))) |
(/.f64 #s(approx (exp a) (+.f64 #s(literal 1 binary64) a)) (+.f64 #s(approx (exp a) #s(literal 1 binary64)) #s(approx (exp b) #s(literal 1 binary64)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (pow (- (exp b) -1) -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 (/ (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 (fma.f64 #s(literal 1/2 binary64) b #s(literal 1 binary64)) b #s(literal 2 binary64))))) |
(/.f64 #s(approx (exp a) (fma.f64 (fma.f64 #s(literal 1/2 binary64) a #s(literal 1 binary64)) a #s(literal 1 binary64))) (+.f64 #s(approx (exp a) #s(literal 1 binary64)) #s(approx (exp b) #s(literal 1 binary64)))) |
| Outputs |
|---|
#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))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) (fma.f64 #s(literal 1/4 binary64) a #s(literal 1/2 binary64))))) |
5 calls:
| 8.0ms | b |
| 4.0ms | a |
| 3.0ms | (exp.f64 b) |
| 3.0ms | (/.f64 (exp.f64 a) (+.f64 (exp.f64 a) (exp.f64 b))) |
| 3.0ms | (exp.f64 a) |
| Accuracy | Segments | Branch |
|---|---|---|
| 55.1% | 1 | a |
| 55.1% | 1 | (exp.f64 a) |
| 57.6% | 2 | (exp.f64 b) |
| 57.6% | 2 | b |
| 57.7% | 2 | (/.f64 (exp.f64 a) (+.f64 (exp.f64 a) (exp.f64 b))) |
Compiled 14 to 16 computations (-14.3% saved)
| Inputs |
|---|
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (pow (- (exp b) -1) -1) #s(literal 1/2 binary64))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) (*.f64 #s(literal -1/4 binary64) b)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) (*.f64 #s(literal 1/4 binary64) a)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) (fma.f64 #s(literal 1/4 binary64) a #s(literal 1/2 binary64))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (pow (- (exp b) -1) -1) (fma.f64 #s(literal -1/4 binary64) b #s(literal 1/2 binary64)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (pow (- (exp b) -1) -1) (fma.f64 #s(approx (- (* (+ (* -1/480 (* b b)) 1/48) (* b b)) 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) #s(approx (+ 2 b) b)))) |
#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 (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) (+.f64 (fma.f64 #s(literal 1/4 binary64) a (*.f64 (neg.f64 b) #s(literal 1/4 binary64))) #s(literal 1/2 binary64)))) |
(/.f64 #s(approx (exp a) (+.f64 #s(literal 1 binary64) a)) (+.f64 #s(approx (exp a) #s(literal 1 binary64)) #s(approx (exp b) #s(literal 1 binary64)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (pow (- (exp b) -1) -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 (/ (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 (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) (fma.f64 #s(literal 1/4 binary64) a #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))))) |
3 calls:
| 4.0ms | b |
| 3.0ms | (/.f64 (exp.f64 a) (+.f64 (exp.f64 a) (exp.f64 b))) |
| 3.0ms | (exp.f64 b) |
| Accuracy | Segments | Branch |
|---|---|---|
| 57.4% | 2 | (exp.f64 b) |
| 57.4% | 2 | b |
| 57.4% | 2 | (/.f64 (exp.f64 a) (+.f64 (exp.f64 a) (exp.f64 b))) |
Compiled 11 to 11 computations (0% saved)
| Inputs |
|---|
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (pow (- (exp b) -1) -1) #s(literal 1/2 binary64))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) (*.f64 #s(literal -1/4 binary64) b)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) (*.f64 #s(literal 1/4 binary64) a)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) (fma.f64 #s(literal 1/4 binary64) a #s(literal 1/2 binary64))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (pow (- (exp b) -1) -1) (fma.f64 #s(literal -1/4 binary64) b #s(literal 1/2 binary64)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (pow (- (exp b) -1) -1) (fma.f64 #s(approx (- (* (+ (* -1/480 (* b b)) 1/48) (* b b)) 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) #s(approx (+ 2 b) b)))) |
#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 (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) (+.f64 (fma.f64 #s(literal 1/4 binary64) a (*.f64 (neg.f64 b) #s(literal 1/4 binary64))) #s(literal 1/2 binary64)))) |
(/.f64 #s(approx (exp a) (+.f64 #s(literal 1 binary64) a)) (+.f64 #s(approx (exp a) #s(literal 1 binary64)) #s(approx (exp b) #s(literal 1 binary64)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (pow (- (exp b) -1) -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 (/ (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 (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) (fma.f64 #s(literal 1/4 binary64) a #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:
| 5.0ms | b |
| 3.0ms | (exp.f64 b) |
| Accuracy | Segments | Branch |
|---|---|---|
| 57.4% | 2 | (exp.f64 b) |
| 57.4% | 2 | b |
Compiled 3 to 5 computations (-66.7% saved)
Total -24.9b remaining (-65.5%)
Threshold costs -24.9b (-65.5%)
| Inputs |
|---|
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (pow (- (exp b) -1) -1) #s(literal 1/2 binary64))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) (*.f64 #s(literal -1/4 binary64) b)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) (*.f64 #s(literal 1/4 binary64) a)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) (fma.f64 #s(literal 1/4 binary64) a #s(literal 1/2 binary64))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (pow (- (exp b) -1) -1) (fma.f64 #s(literal -1/4 binary64) b #s(literal 1/2 binary64)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (pow (- (exp b) -1) -1) (fma.f64 #s(approx (- (* (+ (* -1/480 (* b b)) 1/48) (* b b)) 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) #s(approx (+ 2 b) b)))) |
#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 (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) (+.f64 (fma.f64 #s(literal 1/4 binary64) a (*.f64 (neg.f64 b) #s(literal 1/4 binary64))) #s(literal 1/2 binary64)))) |
(/.f64 #s(approx (exp a) (+.f64 #s(literal 1 binary64) a)) (+.f64 #s(approx (exp a) #s(literal 1 binary64)) #s(approx (exp b) #s(literal 1 binary64)))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (pow (- (exp b) -1) -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 |
|---|
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (pow (- (exp b) -1) -1) #s(literal 1/2 binary64))) |
5 calls:
| 3.0ms | b |
| 3.0ms | a |
| 3.0ms | (exp.f64 b) |
| 3.0ms | (/.f64 (exp.f64 a) (+.f64 (exp.f64 a) (exp.f64 b))) |
| 2.0ms | (exp.f64 a) |
| Accuracy | Segments | Branch |
|---|---|---|
| 40.5% | 1 | (exp.f64 a) |
| 40.5% | 1 | a |
| 40.5% | 1 | (/.f64 (exp.f64 a) (+.f64 (exp.f64 a) (exp.f64 b))) |
| 40.5% | 1 | (exp.f64 b) |
| 40.5% | 1 | b |
Compiled 14 to 16 computations (-14.3% saved)
| 1× | binary-search |
| 1× | narrow-enough |
| Time | Left | Right |
|---|---|---|
| 65.0ms | -1.13374640920361e-14 | -3.1291485394263574e-25 |
| 8.0ms | 160× | 0 | valid |
Compiled 261 to 231 computations (11.5% saved)
ival-exp: 3.0ms (66% of total)ival-div: 1.0ms (22% of total)ival-add: 1.0ms (22% of total)ival-true: 0.0ms (0% of total)adjust: 0.0ms (0% of total)ival-assert: 0.0ms (0% of total)| 1× | binary-search |
| 1× | narrow-enough |
| Time | Left | Right |
|---|---|---|
| 13.0ms | -6239.081164447537 | -1.13374640920361e-14 |
| 8.0ms | 160× | 0 | valid |
Compiled 281 to 251 computations (10.7% saved)
ival-exp: 3.0ms (68.7% of total)ival-div: 1.0ms (22.9% of total)ival-add: 1.0ms (22.9% of total)ival-true: 0.0ms (0% of total)adjust: 0.0ms (0% of total)ival-assert: 0.0ms (0% of total)| 1× | binary-search |
| 1× | narrow-enough |
| Time | Left | Right |
|---|---|---|
| 13.0ms | -9.755038946684978e+27 | -8.923663520336257e+24 |
| 6.0ms | 128× | 0 | valid |
| 1.0ms | 20× | 0 | exit |
Compiled 443 to 339 computations (23.5% saved)
ival-exp: 2.0ms (55.4% of total)ival-div: 1.0ms (27.7% of total)ival-add: 1.0ms (27.7% of total)ival-true: 0.0ms (0% of total)adjust: 0.0ms (0% of total)ival-assert: 0.0ms (0% of total)| 1× | binary-search |
| 1× | narrow-enough |
| Time | Left | Right |
|---|---|---|
| 2.0ms | -6239.081164447537 | -1.13374640920361e-14 |
Compiled 661 to 481 computations (27.2% saved)
| 1× | left-value |
| Time | Left | Right |
|---|---|---|
| 0.0ms | 0.500000000107424 | 0.5047207635469279 |
Compiled 11 to 11 computations (0% saved)
| 1× | left-value |
| Time | Left | Right |
|---|---|---|
| 0.0ms | 0.500000000107424 | 0.5047207635469279 |
Compiled 11 to 11 computations (0% saved)
| 1× | binary-search |
| 1× | narrow-enough |
| Time | Left | Right |
|---|---|---|
| 16.0ms | 2.97474617796779e-23 | 3.7642871043576143e-6 |
| 8.0ms | 160× | 0 | valid |
Compiled 791 to 571 computations (27.8% saved)
ival-exp: 2.0ms (45.5% of total)ival-div: 1.0ms (22.7% of total)ival-add: 1.0ms (22.7% of total)ival-true: 0.0ms (0% of total)adjust: 0.0ms (0% of total)ival-assert: 0.0ms (0% of total)| 1× | binary-search |
| 1× | narrow-enough |
| Time | Left | Right |
|---|---|---|
| 1.0ms | 2.97474617796779e-23 | 3.7642871043576143e-6 |
Compiled 781 to 571 computations (26.9% saved)
Useful iterations: 1 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 106 | 534 |
| 1 | 161 | 518 |
| 2 | 382 | 518 |
| 3 | 1169 | 518 |
| 4 | 5753 | 518 |
| 1× | node limit |
| Inputs |
|---|
(/.f64 (exp.f64 a) (+.f64 (exp.f64 a) (exp.f64 b))) |
(if (<=.f64 a #s(literal -7098843361278085/633825300114114700748351602688 binary64)) (/.f64 (exp.f64 a) (+.f64 (exp.f64 a) #s(approx (exp 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))))) |
(if (<=.f64 a #s(literal -700 binary64)) (/.f64 (exp.f64 a) (+.f64 #s(approx (exp a) #s(literal 1 binary64)) #s(approx (exp 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))))) |
(if (<=.f64 a #s(literal -9000000000000000385875968 binary64)) #s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (pow (- (exp b) -1) -1) #s(approx (+ (* (- (* (+ (* -1/480 (* b b)) 1/48) (* b b)) 1/4) b) 1/2) (*.f64 (pow.f64 b #s(literal 5 binary64)) #s(literal -1/480 binary64))))) #s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) (-.f64 (exp.f64 b) #s(literal -1 binary64))))) |
(if (<=.f64 a #s(literal -700 binary64)) #s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (pow (- (exp b) -1) -1) #s(approx (+ (* (- (* (+ (* -1/480 (* b b)) 1/48) (* b b)) 1/4) b) 1/2) (*.f64 (pow.f64 b #s(literal 5 binary64)) #s(literal -1/480 binary64))))) #s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 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)))))) |
(if (<=.f64 (/.f64 (exp.f64 a) (+.f64 (exp.f64 a) (exp.f64 b))) #s(literal 2260807012939989/4503599627370496 binary64)) #s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 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 a) (+ (exp a) (exp b))) #s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) (fma.f64 #s(literal 1/4 binary64) a #s(literal 1/2 binary64)))))) |
(if (<=.f64 (/.f64 (exp.f64 a) (+.f64 (exp.f64 a) (exp.f64 b))) #s(literal 2260807012939989/4503599627370496 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))))) #s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) (fma.f64 #s(literal 1/4 binary64) a #s(literal 1/2 binary64)))))) |
(if (<=.f64 b #s(literal 2184094498327211/590295810358705651712 binary64)) #s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) (fma.f64 #s(literal 1/4 binary64) a #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)))))) |
(if (<=.f64 b #s(literal 2184094498327211/590295810358705651712 binary64)) #s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) (fma.f64 #s(literal 1/4 binary64) a #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))))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (pow (- (exp b) -1) -1) #s(literal 1/2 binary64))) |
| Outputs |
|---|
(/.f64 (exp.f64 a) (+.f64 (exp.f64 a) (exp.f64 b))) |
(if (<=.f64 a #s(literal -7098843361278085/633825300114114700748351602688 binary64)) (/.f64 (exp.f64 a) (+.f64 (exp.f64 a) #s(approx (exp 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))))) |
(if (<=.f64 a #s(literal -700 binary64)) (/.f64 (exp.f64 a) (+.f64 #s(approx (exp a) #s(literal 1 binary64)) #s(approx (exp 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))))) |
(if (<=.f64 a #s(literal -9000000000000000385875968 binary64)) #s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (pow (- (exp b) -1) -1) #s(approx (+ (* (- (* (+ (* -1/480 (* b b)) 1/48) (* b b)) 1/4) b) 1/2) (*.f64 (pow.f64 b #s(literal 5 binary64)) #s(literal -1/480 binary64))))) #s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 binary64) (-.f64 (exp.f64 b) #s(literal -1 binary64))))) |
(if (<=.f64 a #s(literal -700 binary64)) #s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (pow (- (exp b) -1) -1) #s(approx (+ (* (- (* (+ (* -1/480 (* b b)) 1/48) (* b b)) 1/4) b) 1/2) (*.f64 (pow.f64 b #s(literal 5 binary64)) #s(literal -1/480 binary64))))) #s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 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)))))) |
(if (<=.f64 (/.f64 (exp.f64 a) (+.f64 (exp.f64 a) (exp.f64 b))) #s(literal 2260807012939989/4503599627370496 binary64)) #s(approx (/ (exp a) (+ (exp a) (exp b))) (/.f64 #s(literal 1 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 a) (+ (exp a) (exp b))) #s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) (fma.f64 #s(literal 1/4 binary64) a #s(literal 1/2 binary64)))))) |
(if (<=.f64 (/.f64 (exp.f64 a) (+.f64 (exp.f64 a) (exp.f64 b))) #s(literal 2260807012939989/4503599627370496 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))))) #s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) (fma.f64 #s(literal 1/4 binary64) a #s(literal 1/2 binary64)))))) |
(if (<=.f64 b #s(literal 2184094498327211/590295810358705651712 binary64)) #s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) (fma.f64 #s(literal 1/4 binary64) a #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)))))) |
(if (<=.f64 b #s(literal 2184094498327211/590295810358705651712 binary64)) #s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (+ (* (neg b) (exp (- a (* (log (+ 1 (exp a))) 2)))) (/ (exp a) (- (exp a) -1))) #s(approx (+ (+ (* 1/4 a) (* (neg b) 1/4)) 1/2) (fma.f64 #s(literal 1/4 binary64) a #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))))))) |
#s(approx (/ (exp a) (+ (exp a) (exp b))) #s(approx (pow (- (exp b) -1) -1) #s(literal 1/2 binary64))) |
| 1× | fuel |
Compiled 538 to 112 computations (79.2% saved)
Compiled 1 108 to 250 computations (77.4% saved)
Loading profile data...