Average Error: 29.1 → 0.6
Time: 12.3s
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.1
Target0.0
Herbie0.6
\[4 \cdot {\left(\sinh \left(\frac{x}{2}\right)\right)}^{2}\]

Derivation

  1. Initial program 29.1

    \[\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 2019021 
(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: 11.8s)Debug log

sample171.0ms

Algorithm
intervals
Results
115.0ms179×body1280valid
15.0ms40×body640valid
15.0ms243×body80valid
5.0ms18×body320valid
2.0ms14×body160valid

simplify37.0ms

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

prune10.0ms

Pruning

1 alts after pruning (1 fresh and 0 done)

Merged error: 31.1b

localize38.0ms

Local error

Found 2 expressions with local error:

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

rewrite21.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
15.0ms
(+ (- (exp x) 2) (exp (- x)))
5.0ms
(- (exp x) 2)

series90.0ms

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

simplify1.3s

Counts
19 → 36
Calls
19 calls:
Slowest
285.0ms
(+ (* (- (pow (exp x) 3) (pow 2 3)) (exp x)) (* (+ (* (exp x) (exp x)) (+ (* 2 2) (* (exp x) 2))) 1))
282.0ms
(+ (* (- (pow (exp x) 3) (pow 2 3)) (exp x)) (* (+ (* (exp x) (exp x)) (+ (* 2 2) (* (exp x) 2))) (exp 0)))
212.0ms
(+ (* (- (* (exp x) (exp x)) (* 2 2)) (exp x)) (* (+ (exp x) 2) (exp 0)))
145.0ms
(+ (* (- (* (exp x) (exp x)) (* 2 2)) (exp x)) (* (+ (exp x) 2) 1))
90.0ms
(* (+ (* (exp x) (exp x)) (+ (* 2 2) (* (exp x) 2))) (exp x))

prune313.0ms

Pruning

3 alts after pruning (3 fresh and 0 done)

Merged error: 0.0b

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
(+ (* 1/12 (pow x 4)) (* 1/360 (pow x 6)))
0.0b
(+ (pow x 2) (+ (* 1/12 (pow x 4)) (* 1/360 (pow x 6))))

rewrite24.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
12.0ms
(+ (pow x 2) (+ (* 1/12 (pow x 4)) (* 1/360 (pow x 6))))
6.0ms
(+ (* 1/12 (pow x 4)) (* 1/360 (pow x 6)))
2.0ms
(* 1/12 (pow x 4))
2.0ms
(* 1/360 (pow x 6))

series151.0ms

Counts
4 → 12
Calls
4 calls:
Slowest
68.0ms
(+ (* 1/12 (pow x 4)) (* 1/360 (pow x 6)))
32.0ms
(* 1/360 (pow x 6))
27.0ms
(* 1/12 (pow x 4))
24.0ms
(+ (pow x 2) (+ (* 1/12 (pow x 4)) (* 1/360 (pow x 6))))

simplify212.0ms

Counts
23 → 59
Calls
23 calls:
Slowest
42.0ms
(* (exp (pow x 2)) (exp (+ (* 1/12 (pow x 4)) (* 1/360 (pow x 6)))))
33.0ms
(* (exp (pow x 2)) (* (exp (* 1/12 (pow x 4))) (exp (* 1/360 (pow x 6)))))
24.0ms
(+ (pow x 2) (+ (* 1/12 (pow x 4)) (* 1/360 (pow x 6))))
24.0ms
(+ (pow x 2) (+ (* 1/12 (pow x 4)) (* 1/360 (pow x 6))))
12.0ms
(+ (pow x 2) (+ (* 1/12 (pow x 4)) (* 1/360 (pow x 6))))

prune669.0ms

Pruning

4 alts after pruning (3 fresh and 1 done)

Merged error: 0b

localize19.0ms

Local error

Found 4 expressions with local error:

2.1b
(log (exp (+ (* 1/12 (pow x 4)) (* 1/360 (pow x 6)))))
0.1b
(* 1/12 (pow x 4))
0.1b
(* 1/360 (pow x 6))
0.0b
(+ (* 1/12 (pow x 4)) (* 1/360 (pow x 6)))

rewrite22.0ms

Algorithm
rewrite-expression-head
Rules
add-cube-cbrt
*-un-lft-identity
add-sqr-sqrt
add-log-exp
associate-*r*
pow1
log-pow
add-exp-log
add-cbrt-cube
log-prod
exp-prod
*-commutative
flip-+
exp-sum
rem-log-exp
flip3-+
sum-log
+-commutative
Counts
4 → 49
Calls
4 calls:
Slowest
11.0ms
(log (exp (+ (* 1/12 (pow x 4)) (* 1/360 (pow x 6)))))
5.0ms
(+ (* 1/12 (pow x 4)) (* 1/360 (pow x 6)))
2.0ms
(* 1/12 (pow x 4))
2.0ms
(* 1/360 (pow x 6))

series180.0ms

Counts
4 → 12
Calls
4 calls:
Slowest
63.0ms
(log (exp (+ (* 1/12 (pow x 4)) (* 1/360 (pow x 6)))))
57.0ms
(+ (* 1/12 (pow x 4)) (* 1/360 (pow x 6)))
31.0ms
(* 1/360 (pow x 6))
30.0ms
(* 1/12 (pow x 4))

simplify114.0ms

Counts
27 → 61
Calls
27 calls:
Slowest
12.0ms
(log (* (cbrt (exp (+ (* 1/12 (pow x 4)) (* 1/360 (pow x 6))))) (cbrt (exp (+ (* 1/12 (pow x 4)) (* 1/360 (pow x 6)))))))
11.0ms
(* (exp (* 1/12 (pow x 4))) (exp (* 1/360 (pow x 6))))
10.0ms
(log (sqrt (exp (+ (* 1/12 (pow x 4)) (* 1/360 (pow x 6))))))
7.0ms
(+ (* 1/12 (pow x 4)) (* 1/360 (pow x 6)))
7.0ms
(+ (* 1/12 (pow x 4)) (* 1/360 (pow x 6)))

prune836.0ms

Pruning

4 alts after pruning (2 fresh and 2 done)

Merged error: 0b

localize33.0ms

Local error

Found 4 expressions with local error:

6.4b
(+ (pow (exp x) 3) (+ (+ (exp x) 2) (* (exp x) -4)))
0.1b
(+ (+ (exp x) 2) (* (exp x) -4))
0.0b
(pow (exp x) 3)
0.0b
(* (+ (exp x) 2) (exp x))

rewrite56.0ms

Algorithm
rewrite-expression-head
Rules
11×add-log-exp
10×*-un-lft-identity
add-cube-cbrt
add-sqr-sqrt
add-cbrt-cube
pow1
add-exp-log
sum-log
flip-+
associate-*l*
associate-*r*
cube-prod
flip3-+
unpow-prod-down
associate-*l/
+-commutative
rem-cube-cbrt
distribute-lft-out
cbrt-unprod
*-commutative
prod-exp
pow-exp
pow-prod-down
unpow3
pow-pow
associate-+r+
associate-+l+
pow-to-exp
cube-mult
Counts
4 → 64
Calls
4 calls:
Slowest
37.0ms
(+ (pow (exp x) 3) (+ (+ (exp x) 2) (* (exp x) -4)))
11.0ms
(+ (+ (exp x) 2) (* (exp x) -4))
7.0ms
(* (+ (exp x) 2) (exp x))
1.0ms
(pow (exp x) 3)

series107.0ms

Counts
4 → 12
Calls
4 calls:
Slowest
62.0ms
(+ (pow (exp x) 3) (+ (+ (exp x) 2) (* (exp x) -4)))
18.0ms
(* (+ (exp x) 2) (exp x))
14.0ms
(+ (+ (exp x) 2) (* (exp x) -4))
14.0ms
(pow (exp x) 3)

simplify1.7s

Counts
37 → 76
Calls
37 calls:
Slowest
421.0ms
(* (* (* (+ (exp x) 2) (+ (exp x) 2)) (+ (exp x) 2)) (* (* (exp x) (exp x)) (exp x)))
201.0ms
(* (- (* (exp x) (exp x)) (* 2 2)) (exp x))
166.0ms
(* (exp (pow (exp x) 3)) (exp (+ (+ (exp x) 2) (* (exp x) -4))))
154.0ms
(* (exp (pow (exp x) 3)) (* (exp (+ (exp x) 2)) (exp (* (exp x) -4))))
127.0ms
(- (+ (* 3 x) (+ (* 3/2 (pow x 2)) 1)))

prune678.0ms

Pruning

3 alts after pruning (1 fresh and 2 done)

Merged error: 0b

regimes28.0ms

Accuracy

0% (0.5b remaining)

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

bsearch3.0ms

end0.0ms

sample5.0s

Algorithm
intervals
Results
3.7s5689×body1280valid
469.0ms7894×body80valid
415.0ms1215×body640valid
171.0ms613×body320valid
41.0ms325×body160valid