Average Error: 29.6 → 0.6
Time: 27.2s
Precision: 64
Internal Precision: 128
\[\left(e^{x} - 2\right) + e^{-x}\]
\[{x}^{2} + \left({x}^{6} \cdot \frac{1}{360} + \frac{1}{12} \cdot {x}^{4}\right)\]

Error

Bits error versus x

Try it out

Your Program's Arguments

Results

Enter valid numbers for all inputs

Target

Original29.6
Target0.1
Herbie0.6
\[4 \cdot {\left(\sinh \left(\frac{x}{2}\right)\right)}^{2}\]

Derivation

  1. Initial program 29.6

    \[\left(e^{x} - 2\right) + e^{-x}\]
  2. Taylor expanded around 0 0.6

    \[\leadsto \color{blue}{{x}^{2} + \left(\frac{1}{12} \cdot {x}^{4} + \frac{1}{360} \cdot {x}^{6}\right)}\]
  3. Final simplification0.6

    \[\leadsto {x}^{2} + \left({x}^{6} \cdot \frac{1}{360} + \frac{1}{12} \cdot {x}^{4}\right)\]

Reproduce

herbie shell --seed 2019018 
(FPCore (x)
  :name "exp2 (problem 3.3.7)"

  :herbie-target
  (* 4 (pow (sinh (/ x 2)) 2))

  (+ (- (exp x) 2) (exp (- x))))

Details

Time bar (total: 26.6s)Debug log

sample173.0ms

Algorithm
intervals
Results
112.0ms175×body1280valid
17.0ms43×body640valid
16.0ms263×body80valid
6.0ms24×body320valid
1.0msbody160valid

simplify31.0ms

Counts
1 → 1
Calls
1 calls:
Slowest
31.0ms
(+ (- (exp x) 2) (exp (- x)))

prune5.0ms

Pruning

1 alts after pruning (1 fresh and 0 done)

Merged error: 31.0b

localize32.0ms

Local error

Found 2 expressions with local error:

2.8b
(+ (- (exp x) 2) (exp (- x)))
0.0b
(- (exp x) 2)

rewrite18.0ms

Algorithm
rewrite-expression-head
Rules
add-log-exp
frac-add
*-un-lft-identity
flip--
flip3--
add-cube-cbrt
add-exp-log
exp-diff
add-cbrt-cube
sub-neg
associate-+l+
pow1
exp-neg
add-sqr-sqrt
neg-sub0
distribute-lft-out
flip-+
associate-+l-
flip3-+
sum-log
+-commutative
Counts
2 → 30
Calls
2 calls:
Slowest
13.0ms
(+ (- (exp x) 2) (exp (- x)))
5.0ms
(- (exp x) 2)

series96.0ms

Counts
2 → 6
Calls
2 calls:
Slowest
88.0ms
(+ (- (exp x) 2) (exp (- x)))
9.0ms
(- (exp x) 2)

simplify1.5s

Counts
19 → 36
Calls
19 calls:
Slowest
317.0ms
(+ (* (- (pow (exp x) 3) (pow 2 3)) (exp x)) (* (+ (* (exp x) (exp x)) (+ (* 2 2) (* (exp x) 2))) (exp 0)))
304.0ms
(+ (* (- (pow (exp x) 3) (pow 2 3)) (exp x)) (* (+ (* (exp x) (exp x)) (+ (* 2 2) (* (exp x) 2))) 1))
249.0ms
(+ (* (- (* (exp x) (exp x)) (* 2 2)) (exp x)) (* (+ (exp x) 2) (exp 0)))
190.0ms
(+ (* (- (* (exp x) (exp x)) (* 2 2)) (exp x)) (* (+ (exp x) 2) 1))
114.0ms
(* (+ (* (exp x) (exp x)) (+ (* 2 2) (* (exp x) 2))) (exp x))

prune312.0ms

Pruning

4 alts after pruning (4 fresh and 0 done)

Merged error: 0.1b

localize41.0ms

Local error

Found 4 expressions with local error:

0.1b
(* 1/12 (pow x 4))
0.1b
(* 1/360 (pow x 6))
0.0b
(+ (pow x 2) (+ (* 1/12 (pow x 4)) (* 1/360 (pow x 6))))
0.0b
(+ (* 1/12 (pow x 4)) (* 1/360 (pow x 6)))

rewrite12.0ms

Algorithm
rewrite-expression-head
Rules
11×add-log-exp
*-un-lft-identity
add-cube-cbrt
associate-*r*
add-sqr-sqrt
add-exp-log
add-cbrt-cube
sum-log
pow1
flip-+
*-commutative
flip3-+
+-commutative
distribute-lft-out
associate-+r+
Counts
4 → 47
Calls
4 calls:
Slowest
6.0ms
(+ (pow x 2) (+ (* 1/12 (pow x 4)) (* 1/360 (pow x 6))))
3.0ms
(+ (* 1/12 (pow x 4)) (* 1/360 (pow x 6)))
1.0ms
(* 1/12 (pow x 4))
1.0ms
(* 1/360 (pow x 6))

series128.0ms

Counts
4 → 12
Calls
4 calls:
Slowest
63.0ms
(+ (* 1/12 (pow x 4)) (* 1/360 (pow x 6)))
30.0ms
(+ (pow x 2) (+ (* 1/12 (pow x 4)) (* 1/360 (pow x 6))))
19.0ms
(* 1/360 (pow x 6))
16.0ms
(* 1/12 (pow x 4))

simplify249.0ms

Counts
23 → 59
Calls
23 calls:
Slowest
39.0ms
(* (exp (pow x 2)) (* (exp (* 1/12 (pow x 4))) (exp (* 1/360 (pow x 6)))))
32.0ms
(* (exp (pow x 2)) (exp (+ (* 1/12 (pow x 4)) (* 1/360 (pow x 6)))))
27.0ms
(+ (pow x 2) (+ (* 1/12 (pow x 4)) (* 1/360 (pow x 6))))
26.0ms
(+ (pow x 2) (+ (* 1/12 (pow x 4)) (* 1/360 (pow x 6))))
25.0ms
(+ (pow x 2) (+ (* 1/12 (pow x 4)) (* 1/360 (pow x 6))))

prune644.0ms

Pruning

5 alts after pruning (4 fresh and 1 done)

Merged error: 0.0b

localize28.0ms

Local error

Found 4 expressions with local error:

3.0b
(+ (/ (- (pow (exp x) 3) (pow 2 3)) (+ (* (exp x) (exp x)) (+ (* 2 2) (* (exp x) 2)))) (exp (- x)))
0.0b
(pow (exp x) 3)
0.0b
(* (exp x) (exp x))
0.0b
(/ (- (pow (exp x) 3) (pow 2 3)) (+ (* (exp x) (exp x)) (+ (* 2 2) (* (exp x) 2))))

rewrite152.0ms

Algorithm
rewrite-expression-head
Rules
45×add-sqr-sqrt
31×*-un-lft-identity
24×times-frac
21×add-cube-cbrt
12×difference-of-squares
10×pow1
add-cbrt-cube
associate-/l*
cube-prod
unpow-prod-down
add-log-exp
add-exp-log
distribute-lft-out--
difference-cubes
associate-*l*
associate-*r*
associate-/r*
associate-/l/
flip-+
associate-/r/
frac-add
div-sub
flip3-+
rem-cube-cbrt
distribute-lft-out
flip--
div-inv
cbrt-unprod
associate-+l-
pow-prod-up
*-commutative
prod-exp
pow-exp
pow-prod-down
div-exp
unpow3
exp-diff
flip3--
pow-plus
frac-2neg
pow-pow
sum-log
clear-num
+-commutative
cbrt-undiv
pow-to-exp
cube-mult
exp-neg
neg-sub0
pow2
Counts
4 → 106
Calls
4 calls:
Slowest
109.0ms
(+ (/ (- (pow (exp x) 3) (pow 2 3)) (+ (* (exp x) (exp x)) (+ (* 2 2) (* (exp x) 2)))) (exp (- x)))
34.0ms
(/ (- (pow (exp x) 3) (pow 2 3)) (+ (* (exp x) (exp x)) (+ (* 2 2) (* (exp x) 2))))
7.0ms
(* (exp x) (exp x))
2.0ms
(pow (exp x) 3)

series391.0ms

Counts
4 → 12
Calls
4 calls:
Slowest
290.0ms
(+ (/ (- (pow (exp x) 3) (pow 2 3)) (+ (* (exp x) (exp x)) (+ (* 2 2) (* (exp x) 2)))) (exp (- x)))
70.0ms
(/ (- (pow (exp x) 3) (pow 2 3)) (+ (* (exp x) (exp x)) (+ (* 2 2) (* (exp x) 2))))
16.0ms
(pow (exp x) 3)
15.0ms
(* (exp x) (exp x))

simplify4.9s

Counts
103 → 118
Calls
103 calls:
Slowest
273.0ms
(+ (* (- (pow (exp x) 3) (pow 2 3)) (exp x)) (* (+ (* (exp x) (exp x)) (+ (* 2 2) (* (exp x) 2))) 1))
234.0ms
(+ (* (- (pow (exp x) 3) (pow 2 3)) (exp x)) (* (+ (* (exp x) (exp x)) (+ (* 2 2) (* (exp x) 2))) (exp 0)))
216.0ms
(- (* (pow (exp x) 3) (pow (exp x) 3)) (* (pow 2 3) (pow 2 3)))
157.0ms
(/ (* (* (- (pow (exp x) 3) (pow 2 3)) (- (pow (exp x) 3) (pow 2 3))) (- (pow (exp x) 3) (pow 2 3))) (* (* (+ (* (exp x) (exp x)) (+ (* 2 2) (* (exp x) 2))) (+ (* (exp x) (exp x)) (+ (* 2 2) (* (exp x) 2)))) (+ (* (exp x) (exp x)) (+ (* 2 2) (* (exp x) 2)))))
139.0ms
(+ (* (* (exp x) (exp x)) (* (exp x) (exp x))) (- (* (+ (* 2 2) (* (exp x) 2)) (+ (* 2 2) (* (exp x) 2))) (* (* (exp x) (exp x)) (+ (* 2 2) (* (exp x) 2)))))

prune1.4s

Pruning

5 alts after pruning (3 fresh and 2 done)

Merged error: 0.0b

localize46.0ms

Local error

Found 4 expressions with local error:

3.5b
(+ (+ 4 (+ (pow (exp x) 4) (* (exp x) -8))) (* (exp x) (+ (exp x) 2)))
0.0b
(pow (exp x) 4)
0.0b
(/ (+ (+ 4 (+ (pow (exp x) 4) (* (exp x) -8))) (* (exp x) (+ (exp x) 2))) (+ (* (+ (exp x) 2) (exp (+ x x))) (* 4 (exp x))))
0.0b
(+ 4 (+ (pow (exp x) 4) (* (exp x) -8)))

rewrite166.0ms

Algorithm
rewrite-expression-head
Rules
13×add-cube-cbrt
13×*-un-lft-identity
13×add-sqr-sqrt
12×flip-+
12×flip3-+
times-frac
associate-*r/
frac-add
associate-/l/
add-log-exp
add-exp-log
add-cbrt-cube
pow1
associate-/l*
unpow-prod-down
associate-/r*
associate-+r+
associate-/r/
+-commutative
div-inv
pow-exp
div-exp
distribute-lft-in
frac-2neg
pow-pow
sum-log
clear-num
associate-+l+
cbrt-undiv
pow-to-exp
distribute-rgt-in
Counts
4 → 77
Calls
4 calls:
Slowest
136.0ms
(/ (+ (+ 4 (+ (pow (exp x) 4) (* (exp x) -8))) (* (exp x) (+ (exp x) 2))) (+ (* (+ (exp x) 2) (exp (+ x x))) (* 4 (exp x))))
22.0ms
(+ (+ 4 (+ (pow (exp x) 4) (* (exp x) -8))) (* (exp x) (+ (exp x) 2)))
5.0ms
(+ 4 (+ (pow (exp x) 4) (* (exp x) -8)))
2.0ms
(pow (exp x) 4)

series430.0ms

Counts
4 → 12
Calls
4 calls:
Slowest
293.0ms
(/ (+ (+ 4 (+ (pow (exp x) 4) (* (exp x) -8))) (* (exp x) (+ (exp x) 2))) (+ (* (+ (exp x) 2) (exp (+ x x))) (* 4 (exp x))))
82.0ms
(+ (+ 4 (+ (pow (exp x) 4) (* (exp x) -8))) (* (exp x) (+ (exp x) 2)))
31.0ms
(+ 4 (+ (pow (exp x) 4) (* (exp x) -8)))
24.0ms
(pow (exp x) 4)

simplify9.0s

Counts
62 → 89
Calls
62 calls:
Slowest
448.0ms
(* (+ (* 4 4) (- (* (+ (pow (exp x) 4) (* (exp x) -8)) (+ (pow (exp x) 4) (* (exp x) -8))) (* 4 (+ (pow (exp x) 4) (* (exp x) -8))))) (- (exp x) 2))
400.0ms
(/ (* (* (+ (+ 4 (+ (pow (exp x) 4) (* (exp x) -8))) (* (exp x) (+ (exp x) 2))) (+ (+ 4 (+ (pow (exp x) 4) (* (exp x) -8))) (* (exp x) (+ (exp x) 2)))) (+ (+ 4 (+ (pow (exp x) 4) (* (exp x) -8))) (* (exp x) (+ (exp x) 2)))) (* (* (+ (* (+ (exp x) 2) (exp (+ x x))) (* 4 (exp x))) (+ (* (+ (exp x) 2) (exp (+ x x))) (* 4 (exp x)))) (+ (* (+ (exp x) 2) (exp (+ x x))) (* 4 (exp x)))))
390.0ms
(/ (- (+ (pow (exp x) 2) (+ (pow (exp x) 4) 4)) (* 6 (exp x))) (+ (* 4 (exp x)) (+ (* (exp x) (exp (* 2 x))) (* 2 (exp (* 2 x))))))
340.0ms
(/ (- (+ (pow (exp x) 2) (+ (pow (exp x) 4) 4)) (* 6 (exp x))) (+ (* 4 (exp x)) (+ (* (exp x) (exp (* 2 x))) (* 2 (exp (* 2 x))))))
288.0ms
(/ (sqrt (+ (+ 4 (+ (pow (exp x) 4) (* (exp x) -8))) (* (exp x) (+ (exp x) 2)))) 1)

prune1.2s

Pruning

5 alts after pruning (3 fresh and 2 done)

Merged error: 0.0b

regimes35.0ms

Accuracy

0% (0.5b remaining)

Error of 0.6b against oracle of 0.1b and baseline of 0.6b

bsearch2.0ms

end0.0ms

sample5.6s

Algorithm
intervals
Results
4.4s5721×body1280valid
475.0ms1221×body640valid
453.0ms7867×body80valid
129.0ms597×body320valid
41.0ms308×body160valid