Hyperbolic arcsine

Time bar (total: 4.1s)

start0.0ms (0%)

Memory
0.1MiB live, 0.1MiB allocated; 0ms collecting garbage

analyze78.0ms (1.9%)

Memory
16.9MiB live, 118.6MiB allocated; 18ms collecting garbage
Algorithm
search
Search
ProbabilityValidUnknownPreconditionInfiniteDomainCan'tIter
0%0%100%0%0%0%0%0
0%0%100%0%0%0%0%1
0%0%100%0%0%0%0%2
25%25%75%0%0%0%0%3
50%50%50%0%0%0%0%4
62.5%62.5%37.5%0%0%0%0%5
68.8%68.7%31.2%0%0%0%0%6
71.9%71.8%28.1%0%0%0%0%7
73.4%73.4%26.5%0%0%0%0%8
74.2%74.2%25.8%0%0%0%0%9
74.6%74.6%25.4%0%0%0%0%10
74.8%74.8%25.2%0%0%0%0%11
74.9%74.9%25.1%0%0%0%0%12
Compiler

Compiled 11 to 7 computations (36.4% saved)

sample2.3s (55.8%)

Memory
15.8MiB live, 2 154.4MiB allocated; 381ms collecting garbage
Samples
873.0ms1 635×2valid
853.0ms4 423×1valid
151.0ms2 198×0valid
Precisions
Click to see histograms. Total time spent on operations: 1.5s
ival-log: 847.0ms (54.9% of total)
ival-hypot: 444.0ms (28.8% of total)
adjust: 156.0ms (10.1% of total)
ival-add: 82.0ms (5.3% of total)
ival-true: 6.0ms (0.4% of total)
exact: 6.0ms (0.4% of total)
ival-assert: 4.0ms (0.3% of total)
Bogosity

explain269.0ms (6.6%)

Memory
-11.4MiB live, 231.9MiB allocated; 20ms collecting garbage
FPErrors
Click to see full error table
Ground TruthOverpredictionsExampleUnderpredictionsExampleSubexpression
1340-0-(log.f64 (+.f64 x (sqrt.f64 (+.f64 (*.f64 x x) #s(literal 1 binary64)))))
600-0-(sqrt.f64 (+.f64 (*.f64 x x) #s(literal 1 binary64)))
590-0-(+.f64 x (sqrt.f64 (+.f64 (*.f64 x x) #s(literal 1 binary64))))
00-0-#s(literal 1 binary64)
00-0-(+.f64 (*.f64 x x) #s(literal 1 binary64))
00-0-(*.f64 x x)
00-0-x
Explanations
Click to see full explanations table
OperatorSubexpressionExplanationCount
log.f64(log.f64 (+.f64 x (sqrt.f64 (+.f64 (*.f64 x x) #s(literal 1 binary64)))))sensitivity1340
sqrt.f64(sqrt.f64 (+.f64 (*.f64 x x) #s(literal 1 binary64)))oflow-rescue600
(*.f64 x x)overflow60
(+.f64 (*.f64 x x) #s(literal 1 binary64))overflow60
+.f64(+.f64 x (sqrt.f64 (+.f64 (*.f64 x x) #s(literal 1 binary64))))cancellation590
Confusion
Predicted +Predicted -
+2200
-036
Precision
1.0
Recall
1.0
Confusion?
Predicted +Predicted MaybePredicted -
+22000
-0036
Precision?
1.0
Recall?
1.0
Freqs
test
numberfreq
036
1187
233
Total Confusion?
Predicted +Predicted MaybePredicted -
+100
-000
Precision?
1.0
Recall?
1.0
Samples
92.0ms268×1valid
59.0ms116×2valid
9.0ms128×0valid
Compiler

Compiled 79 to 25 computations (68.4% saved)

Precisions
Click to see histograms. Total time spent on operations: 139.0ms
adjust: 55.0ms (39.4% of total)
ival-log: 49.0ms (35.1% of total)
ival-hypot: 23.0ms (16.5% of total)
ival-add: 7.0ms (5% of total)
ival-mult: 5.0ms (3.6% of total)
ival-assert: 0.0ms (0% of total)
ival-true: 0.0ms (0% of total)
exact: 0.0ms (0% of total)

preprocess215.0ms (5.3%)

Memory
44.4MiB live, 176.4MiB allocated; 26ms collecting garbage
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01430
13130
25930
38330
414230
534830
6239630
7593030
079
0129
1209
2429
3829
41419
53479
624029
759039
081428
Stop Event
iter limit
node limit
iter limit
node limit
Calls
Call 1
Inputs
(log.f64 (+.f64 x (sqrt.f64 (+.f64 (*.f64 x x) #s(literal 1 binary64)))))
Outputs
(log.f64 (+.f64 x (sqrt.f64 (+.f64 (*.f64 x x) #s(literal 1 binary64)))))
(log.f64 (+.f64 (sqrt.f64 (fma.f64 x x #s(literal 1 binary64))) x))
Compiler

Compiled 9 to 7 computations (22.2% saved)

eval0.0ms (0%)

Memory
0.0MiB live, 0.0MiB allocated; 0ms collecting garbage
Compiler

Compiled 0 to 1 computations (-∞% saved)

prune0.0ms (0%)

Memory
0.6MiB live, 0.6MiB allocated; 0ms collecting garbage
Alt Table
Click to see full alt table
StatusAccuracyProgram
18.2%
(log.f64 (+.f64 x (sqrt.f64 (+.f64 (*.f64 x x) #s(literal 1 binary64)))))
Compiler

Compiled 9 to 7 computations (22.2% saved)

simplify151.0ms (3.7%)

Memory
-29.5MiB live, 128.2MiB allocated; 24ms collecting garbage
Localize:

Found 4 expressions of interest:

NewMetricScoreProgram
cost-diff0
(sqrt.f64 (+.f64 (*.f64 x x) #s(literal 1 binary64)))
cost-diff0
(+.f64 x (sqrt.f64 (+.f64 (*.f64 x x) #s(literal 1 binary64))))
cost-diff0
(log.f64 (+.f64 x (sqrt.f64 (+.f64 (*.f64 x x) #s(literal 1 binary64)))))
cost-diff1
(+.f64 (*.f64 x x) #s(literal 1 binary64))
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0733
01233
12033
24233
38233
414133
534733
6240233
7590333
0814229
Stop Event
iter limit
node limit
iter limit
Calls
Call 1
Inputs
(log.f64 (+.f64 x (sqrt.f64 (+.f64 (*.f64 x x) #s(literal 1 binary64)))))
(+.f64 x (sqrt.f64 (+.f64 (*.f64 x x) #s(literal 1 binary64))))
x
(sqrt.f64 (+.f64 (*.f64 x x) #s(literal 1 binary64)))
(+.f64 (*.f64 x x) #s(literal 1 binary64))
(*.f64 x x)
#s(literal 1 binary64)
Outputs
(log.f64 (+.f64 x (sqrt.f64 (+.f64 (*.f64 x x) #s(literal 1 binary64)))))
(log.f64 (+.f64 (sqrt.f64 (fma.f64 x x #s(literal 1 binary64))) x))
(+.f64 x (sqrt.f64 (+.f64 (*.f64 x x) #s(literal 1 binary64))))
(+.f64 (sqrt.f64 (fma.f64 x x #s(literal 1 binary64))) x)
x
(sqrt.f64 (+.f64 (*.f64 x x) #s(literal 1 binary64)))
(sqrt.f64 (fma.f64 x x #s(literal 1 binary64)))
(+.f64 (*.f64 x x) #s(literal 1 binary64))
(fma.f64 x x #s(literal 1 binary64))
(*.f64 x x)
#s(literal 1 binary64)

localize80.0ms (2%)

Memory
4.7MiB live, 150.3MiB allocated; 13ms collecting garbage
Localize:

Found 4 expressions of interest:

NewMetricScoreProgram
accuracy0.0
(*.f64 x x)
accuracy13.952059943383047
(+.f64 x (sqrt.f64 (+.f64 (*.f64 x x) #s(literal 1 binary64))))
accuracy13.95856255588032
(sqrt.f64 (+.f64 (*.f64 x x) #s(literal 1 binary64)))
accuracy31.332836590821298
(log.f64 (+.f64 x (sqrt.f64 (+.f64 (*.f64 x x) #s(literal 1 binary64)))))
Samples
34.0ms134×1valid
33.0ms58×2valid
5.0ms64×0valid
Compiler

Compiled 35 to 9 computations (74.3% saved)

Precisions
Click to see histograms. Total time spent on operations: 55.0ms
ival-log: 29.0ms (52.6% of total)
ival-hypot: 12.0ms (21.8% of total)
adjust: 7.0ms (12.7% of total)
ival-add: 4.0ms (7.3% of total)
ival-mult: 2.0ms (3.6% of total)
ival-assert: 0.0ms (0% of total)
ival-true: 0.0ms (0% of total)
exact: 0.0ms (0% of total)

series5.0ms (0.1%)

Memory
12.2MiB live, 12.2MiB allocated; 0ms collecting garbage
Counts
5 → 41
Calls
Call 1
Inputs
(+.f64 (*.f64 x x) #s(literal 1 binary64))
(log.f64 (+.f64 x (sqrt.f64 (+.f64 (*.f64 x x) #s(literal 1 binary64)))))
(+.f64 x (sqrt.f64 (+.f64 (*.f64 x x) #s(literal 1 binary64))))
(sqrt.f64 (+.f64 (*.f64 x x) #s(literal 1 binary64)))
(*.f64 x x)
Outputs
#s(approx (+ (* x x) 1) #s(hole binary64 1))
#s(approx (+ (* x x) 1) #s(hole binary64 (+ 1 (pow x 2))))
#s(approx (log (+ x (sqrt (+ (* x x) 1)))) #s(hole binary64 x))
#s(approx (log (+ x (sqrt (+ (* x x) 1)))) #s(hole binary64 (* x (+ 1 (* -1/6 (pow x 2))))))
#s(approx (log (+ x (sqrt (+ (* x x) 1)))) #s(hole binary64 (* x (+ 1 (* (pow x 2) (- (* 3/40 (pow x 2)) 1/6))))))
#s(approx (log (+ x (sqrt (+ (* x x) 1)))) #s(hole binary64 (* x (+ 1 (* (pow x 2) (- (* (pow x 2) (+ 3/40 (* -5/112 (pow x 2)))) 1/6))))))
#s(approx (+ x (sqrt (+ (* x x) 1))) #s(hole binary64 1))
#s(approx (+ x (sqrt (+ (* x x) 1))) #s(hole binary64 (+ 1 x)))
#s(approx (+ x (sqrt (+ (* x x) 1))) #s(hole binary64 (+ 1 (* x (+ 1 (* 1/2 x))))))
#s(approx (+ x (sqrt (+ (* x x) 1))) #s(hole binary64 (+ 1 (* x (+ 1 (* x (+ 1/2 (* -1/8 (pow x 2)))))))))
#s(approx (sqrt (+ (* x x) 1)) #s(hole binary64 1))
#s(approx (sqrt (+ (* x x) 1)) #s(hole binary64 (+ 1 (* 1/2 (pow x 2)))))
#s(approx (sqrt (+ (* x x) 1)) #s(hole binary64 (+ 1 (* (pow x 2) (+ 1/2 (* -1/8 (pow x 2)))))))
#s(approx (sqrt (+ (* x x) 1)) #s(hole binary64 (+ 1 (* (pow x 2) (+ 1/2 (* (pow x 2) (- (* 1/16 (pow x 2)) 1/8)))))))
#s(approx (* x x) #s(hole binary64 (pow x 2)))
#s(approx (+ (* x x) 1) #s(hole binary64 (pow x 2)))
#s(approx (+ (* x x) 1) #s(hole binary64 (* (pow x 2) (+ 1 (/ 1 (pow x 2))))))
#s(approx (log (+ x (sqrt (+ (* x x) 1)))) #s(hole binary64 (+ (log 2) (* -1 (log (/ 1 x))))))
#s(approx (log (+ x (sqrt (+ (* x x) 1)))) #s(hole binary64 (+ (log 2) (+ (* -1 (log (/ 1 x))) (* 1/4 (/ 1 (pow x 2)))))))
#s(approx (log (+ x (sqrt (+ (* x x) 1)))) #s(hole binary64 (- (+ (log 2) (+ (* -1 (log (/ 1 x))) (* 1/4 (/ 1 (pow x 2))))) (/ 3/32 (pow x 4)))))
#s(approx (log (+ x (sqrt (+ (* x x) 1)))) #s(hole binary64 (- (+ (log 2) (+ (* -1 (log (/ 1 x))) (+ (* 1/4 (/ 1 (pow x 2))) (* 5/96 (/ 1 (pow x 6)))))) (/ 3/32 (pow x 4)))))
#s(approx (+ x (sqrt (+ (* x x) 1))) #s(hole binary64 (* 2 x)))
#s(approx (+ x (sqrt (+ (* x x) 1))) #s(hole binary64 (* x (+ 2 (* 1/2 (/ 1 (pow x 2)))))))
#s(approx (+ x (sqrt (+ (* x x) 1))) #s(hole binary64 (* x (- (+ 2 (* 1/2 (/ 1 (pow x 2)))) (/ 1/8 (pow x 4))))))
#s(approx (+ x (sqrt (+ (* x x) 1))) #s(hole binary64 (* x (- (+ 2 (+ (* 1/2 (/ 1 (pow x 2))) (* 1/16 (/ 1 (pow x 6))))) (/ 1/8 (pow x 4))))))
#s(approx (sqrt (+ (* x x) 1)) #s(hole binary64 x))
#s(approx (sqrt (+ (* x x) 1)) #s(hole binary64 (* x (+ 1 (* 1/2 (/ 1 (pow x 2)))))))
#s(approx (sqrt (+ (* x x) 1)) #s(hole binary64 (* x (- (+ 1 (* 1/2 (/ 1 (pow x 2)))) (/ 1/8 (pow x 4))))))
#s(approx (sqrt (+ (* x x) 1)) #s(hole binary64 (* x (- (+ 1 (+ (* 1/2 (/ 1 (pow x 2))) (* 1/16 (/ 1 (pow x 6))))) (/ 1/8 (pow x 4))))))
#s(approx (log (+ x (sqrt (+ (* x x) 1)))) #s(hole binary64 (+ (log 1/2) (log (/ -1 x)))))
#s(approx (log (+ x (sqrt (+ (* x x) 1)))) #s(hole binary64 (- (+ (log 1/2) (log (/ -1 x))) (* 1/4 (/ 1 (pow x 2))))))
#s(approx (log (+ x (sqrt (+ (* x x) 1)))) #s(hole binary64 (- (+ (log 1/2) (+ (log (/ -1 x)) (/ 3/32 (pow x 4)))) (* 1/4 (/ 1 (pow x 2))))))
#s(approx (log (+ x (sqrt (+ (* x x) 1)))) #s(hole binary64 (- (+ (log 1/2) (+ (log (/ -1 x)) (/ 3/32 (pow x 4)))) (+ (* 1/4 (/ 1 (pow x 2))) (* 5/96 (/ 1 (pow x 6)))))))
#s(approx (+ x (sqrt (+ (* x x) 1))) #s(hole binary64 (/ -1/2 x)))
#s(approx (+ x (sqrt (+ (* x x) 1))) #s(hole binary64 (* -1 (/ (- 1/2 (* 1/8 (/ 1 (pow x 2)))) x))))
#s(approx (+ x (sqrt (+ (* x x) 1))) #s(hole binary64 (* -1 (/ (- (+ 1/2 (/ 1/16 (pow x 4))) (* 1/8 (/ 1 (pow x 2)))) x))))
#s(approx (+ x (sqrt (+ (* x x) 1))) #s(hole binary64 (* -1 (/ (- (+ 1/2 (/ 1/16 (pow x 4))) (+ (* 1/8 (/ 1 (pow x 2))) (* 5/128 (/ 1 (pow x 6))))) x))))
#s(approx (sqrt (+ (* x x) 1)) #s(hole binary64 (* -1 x)))
#s(approx (sqrt (+ (* x x) 1)) #s(hole binary64 (* -1 (* x (+ 1 (* 1/2 (/ 1 (pow x 2))))))))
#s(approx (sqrt (+ (* x x) 1)) #s(hole binary64 (* -1 (* x (- (+ 1 (* 1/2 (/ 1 (pow x 2)))) (/ 1/8 (pow x 4)))))))
#s(approx (sqrt (+ (* x x) 1)) #s(hole binary64 (* -1 (* x (- (+ 1 (+ (* 1/2 (/ 1 (pow x 2))) (* 1/16 (/ 1 (pow x 6))))) (/ 1/8 (pow x 4)))))))
Calls

3 calls:

TimeVariablePointExpression
2.0ms
x
@inf
((+ (* x x) 1) (log (+ x (sqrt (+ (* x x) 1)))) (+ x (sqrt (+ (* x x) 1))) (sqrt (+ (* x x) 1)) (* x x))
2.0ms
x
@0
((+ (* x x) 1) (log (+ x (sqrt (+ (* x x) 1)))) (+ x (sqrt (+ (* x x) 1))) (sqrt (+ (* x x) 1)) (* x x))
1.0ms
x
@-inf
((+ (* x x) 1) (log (+ x (sqrt (+ (* x x) 1)))) (+ x (sqrt (+ (* x x) 1))) (sqrt (+ (* x x) 1)) (* x x))

simplify194.0ms (4.8%)

Memory
-17.8MiB live, 250.7MiB allocated; 69ms collecting garbage
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0171794
1436786
21482776
36892776
08169716
Stop Event
iter limit
node limit
Counts
41 → 41
Calls
Call 1
Inputs
#s(approx (+ (* x x) 1) #s(hole binary64 1))
#s(approx (+ (* x x) 1) #s(hole binary64 (+ 1 (pow x 2))))
#s(approx (log (+ x (sqrt (+ (* x x) 1)))) #s(hole binary64 x))
#s(approx (log (+ x (sqrt (+ (* x x) 1)))) #s(hole binary64 (* x (+ 1 (* -1/6 (pow x 2))))))
#s(approx (log (+ x (sqrt (+ (* x x) 1)))) #s(hole binary64 (* x (+ 1 (* (pow x 2) (- (* 3/40 (pow x 2)) 1/6))))))
#s(approx (log (+ x (sqrt (+ (* x x) 1)))) #s(hole binary64 (* x (+ 1 (* (pow x 2) (- (* (pow x 2) (+ 3/40 (* -5/112 (pow x 2)))) 1/6))))))
#s(approx (+ x (sqrt (+ (* x x) 1))) #s(hole binary64 1))
#s(approx (+ x (sqrt (+ (* x x) 1))) #s(hole binary64 (+ 1 x)))
#s(approx (+ x (sqrt (+ (* x x) 1))) #s(hole binary64 (+ 1 (* x (+ 1 (* 1/2 x))))))
#s(approx (+ x (sqrt (+ (* x x) 1))) #s(hole binary64 (+ 1 (* x (+ 1 (* x (+ 1/2 (* -1/8 (pow x 2)))))))))
#s(approx (sqrt (+ (* x x) 1)) #s(hole binary64 1))
#s(approx (sqrt (+ (* x x) 1)) #s(hole binary64 (+ 1 (* 1/2 (pow x 2)))))
#s(approx (sqrt (+ (* x x) 1)) #s(hole binary64 (+ 1 (* (pow x 2) (+ 1/2 (* -1/8 (pow x 2)))))))
#s(approx (sqrt (+ (* x x) 1)) #s(hole binary64 (+ 1 (* (pow x 2) (+ 1/2 (* (pow x 2) (- (* 1/16 (pow x 2)) 1/8)))))))
#s(approx (* x x) #s(hole binary64 (pow x 2)))
#s(approx (+ (* x x) 1) #s(hole binary64 (pow x 2)))
#s(approx (+ (* x x) 1) #s(hole binary64 (* (pow x 2) (+ 1 (/ 1 (pow x 2))))))
#s(approx (log (+ x (sqrt (+ (* x x) 1)))) #s(hole binary64 (+ (log 2) (* -1 (log (/ 1 x))))))
#s(approx (log (+ x (sqrt (+ (* x x) 1)))) #s(hole binary64 (+ (log 2) (+ (* -1 (log (/ 1 x))) (* 1/4 (/ 1 (pow x 2)))))))
#s(approx (log (+ x (sqrt (+ (* x x) 1)))) #s(hole binary64 (- (+ (log 2) (+ (* -1 (log (/ 1 x))) (* 1/4 (/ 1 (pow x 2))))) (/ 3/32 (pow x 4)))))
#s(approx (log (+ x (sqrt (+ (* x x) 1)))) #s(hole binary64 (- (+ (log 2) (+ (* -1 (log (/ 1 x))) (+ (* 1/4 (/ 1 (pow x 2))) (* 5/96 (/ 1 (pow x 6)))))) (/ 3/32 (pow x 4)))))
#s(approx (+ x (sqrt (+ (* x x) 1))) #s(hole binary64 (* 2 x)))
#s(approx (+ x (sqrt (+ (* x x) 1))) #s(hole binary64 (* x (+ 2 (* 1/2 (/ 1 (pow x 2)))))))
#s(approx (+ x (sqrt (+ (* x x) 1))) #s(hole binary64 (* x (- (+ 2 (* 1/2 (/ 1 (pow x 2)))) (/ 1/8 (pow x 4))))))
#s(approx (+ x (sqrt (+ (* x x) 1))) #s(hole binary64 (* x (- (+ 2 (+ (* 1/2 (/ 1 (pow x 2))) (* 1/16 (/ 1 (pow x 6))))) (/ 1/8 (pow x 4))))))
#s(approx (sqrt (+ (* x x) 1)) #s(hole binary64 x))
#s(approx (sqrt (+ (* x x) 1)) #s(hole binary64 (* x (+ 1 (* 1/2 (/ 1 (pow x 2)))))))
#s(approx (sqrt (+ (* x x) 1)) #s(hole binary64 (* x (- (+ 1 (* 1/2 (/ 1 (pow x 2)))) (/ 1/8 (pow x 4))))))
#s(approx (sqrt (+ (* x x) 1)) #s(hole binary64 (* x (- (+ 1 (+ (* 1/2 (/ 1 (pow x 2))) (* 1/16 (/ 1 (pow x 6))))) (/ 1/8 (pow x 4))))))
#s(approx (log (+ x (sqrt (+ (* x x) 1)))) #s(hole binary64 (+ (log 1/2) (log (/ -1 x)))))
#s(approx (log (+ x (sqrt (+ (* x x) 1)))) #s(hole binary64 (- (+ (log 1/2) (log (/ -1 x))) (* 1/4 (/ 1 (pow x 2))))))
#s(approx (log (+ x (sqrt (+ (* x x) 1)))) #s(hole binary64 (- (+ (log 1/2) (+ (log (/ -1 x)) (/ 3/32 (pow x 4)))) (* 1/4 (/ 1 (pow x 2))))))
#s(approx (log (+ x (sqrt (+ (* x x) 1)))) #s(hole binary64 (- (+ (log 1/2) (+ (log (/ -1 x)) (/ 3/32 (pow x 4)))) (+ (* 1/4 (/ 1 (pow x 2))) (* 5/96 (/ 1 (pow x 6)))))))
#s(approx (+ x (sqrt (+ (* x x) 1))) #s(hole binary64 (/ -1/2 x)))
#s(approx (+ x (sqrt (+ (* x x) 1))) #s(hole binary64 (* -1 (/ (- 1/2 (* 1/8 (/ 1 (pow x 2)))) x))))
#s(approx (+ x (sqrt (+ (* x x) 1))) #s(hole binary64 (* -1 (/ (- (+ 1/2 (/ 1/16 (pow x 4))) (* 1/8 (/ 1 (pow x 2)))) x))))
#s(approx (+ x (sqrt (+ (* x x) 1))) #s(hole binary64 (* -1 (/ (- (+ 1/2 (/ 1/16 (pow x 4))) (+ (* 1/8 (/ 1 (pow x 2))) (* 5/128 (/ 1 (pow x 6))))) x))))
#s(approx (sqrt (+ (* x x) 1)) #s(hole binary64 (* -1 x)))
#s(approx (sqrt (+ (* x x) 1)) #s(hole binary64 (* -1 (* x (+ 1 (* 1/2 (/ 1 (pow x 2))))))))
#s(approx (sqrt (+ (* x x) 1)) #s(hole binary64 (* -1 (* x (- (+ 1 (* 1/2 (/ 1 (pow x 2)))) (/ 1/8 (pow x 4)))))))
#s(approx (sqrt (+ (* x x) 1)) #s(hole binary64 (* -1 (* x (- (+ 1 (+ (* 1/2 (/ 1 (pow x 2))) (* 1/16 (/ 1 (pow x 6))))) (/ 1/8 (pow x 4)))))))
Outputs
#s(approx (+ (* x x) 1) #s(hole binary64 1))
#s(approx (+ (* x x) 1) #s(literal 1 binary64))
#s(approx (+ (* x x) 1) #s(hole binary64 (+ 1 (pow x 2))))
#s(approx (+ (* x x) 1) (fma.f64 x x #s(literal 1 binary64)))
#s(approx (log (+ x (sqrt (+ (* x x) 1)))) #s(hole binary64 x))
#s(approx (log (+ x (sqrt (+ (* x x) 1)))) x)
#s(approx (log (+ x (sqrt (+ (* x x) 1)))) #s(hole binary64 (* x (+ 1 (* -1/6 (pow x 2))))))
#s(approx (log (+ x (sqrt (+ (* x x) 1)))) (fma.f64 (pow.f64 x #s(literal 3 binary64)) #s(literal -1/6 binary64) x))
#s(approx (log (+ x (sqrt (+ (* x x) 1)))) #s(hole binary64 (* x (+ 1 (* (pow x 2) (- (* 3/40 (pow x 2)) 1/6))))))
#s(approx (log (+ x (sqrt (+ (* x x) 1)))) (fma.f64 (pow.f64 x #s(literal 3 binary64)) (-.f64 (*.f64 #s(literal 3/40 binary64) (*.f64 x x)) #s(literal 1/6 binary64)) x))
#s(approx (log (+ x (sqrt (+ (* x x) 1)))) #s(hole binary64 (* x (+ 1 (* (pow x 2) (- (* (pow x 2) (+ 3/40 (* -5/112 (pow x 2)))) 1/6))))))
#s(approx (log (+ x (sqrt (+ (* x x) 1)))) (fma.f64 (pow.f64 x #s(literal 3 binary64)) (fma.f64 (pow.f64 x #s(literal 4 binary64)) #s(literal -5/112 binary64) (-.f64 (*.f64 #s(literal 3/40 binary64) (*.f64 x x)) #s(literal 1/6 binary64))) x))
#s(approx (+ x (sqrt (+ (* x x) 1))) #s(hole binary64 1))
#s(approx (+ x (sqrt (+ (* x x) 1))) #s(literal 1 binary64))
#s(approx (+ x (sqrt (+ (* x x) 1))) #s(hole binary64 (+ 1 x)))
#s(approx (+ x (sqrt (+ (* x x) 1))) (-.f64 x #s(literal -1 binary64)))
#s(approx (+ x (sqrt (+ (* x x) 1))) #s(hole binary64 (+ 1 (* x (+ 1 (* 1/2 x))))))
#s(approx (+ x (sqrt (+ (* x x) 1))) (fma.f64 (fma.f64 #s(literal 1/2 binary64) x #s(literal 1 binary64)) x #s(literal 1 binary64)))
#s(approx (+ x (sqrt (+ (* x x) 1))) #s(hole binary64 (+ 1 (* x (+ 1 (* x (+ 1/2 (* -1/8 (pow x 2)))))))))
#s(approx (+ x (sqrt (+ (* x x) 1))) (fma.f64 (fma.f64 (fma.f64 #s(literal -1/8 binary64) (*.f64 x x) #s(literal 1/2 binary64)) x #s(literal 1 binary64)) x #s(literal 1 binary64)))
#s(approx (sqrt (+ (* x x) 1)) #s(hole binary64 1))
#s(approx (sqrt (+ (* x x) 1)) #s(literal 1 binary64))
#s(approx (sqrt (+ (* x x) 1)) #s(hole binary64 (+ 1 (* 1/2 (pow x 2)))))
#s(approx (sqrt (+ (* x x) 1)) (fma.f64 (*.f64 #s(literal 1/2 binary64) x) x #s(literal 1 binary64)))
#s(approx (sqrt (+ (* x x) 1)) #s(hole binary64 (+ 1 (* (pow x 2) (+ 1/2 (* -1/8 (pow x 2)))))))
#s(approx (sqrt (+ (* x x) 1)) (fma.f64 (*.f64 (fma.f64 #s(literal -1/8 binary64) (*.f64 x x) #s(literal 1/2 binary64)) x) x #s(literal 1 binary64)))
#s(approx (sqrt (+ (* x x) 1)) #s(hole binary64 (+ 1 (* (pow x 2) (+ 1/2 (* (pow x 2) (- (* 1/16 (pow x 2)) 1/8)))))))
#s(approx (sqrt (+ (* x x) 1)) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/16 binary64) (*.f64 x x) #s(literal -1/8 binary64)) (*.f64 x x) #s(literal 1/2 binary64)) (*.f64 x x) #s(literal 1 binary64)))
#s(approx (* x x) #s(hole binary64 (pow x 2)))
#s(approx (* x x) (*.f64 x x))
#s(approx (+ (* x x) 1) #s(hole binary64 (pow x 2)))
#s(approx (+ (* x x) 1) (*.f64 x x))
#s(approx (+ (* x x) 1) #s(hole binary64 (* (pow x 2) (+ 1 (/ 1 (pow x 2))))))
#s(approx (+ (* x x) 1) (fma.f64 x x #s(literal 1 binary64)))
#s(approx (log (+ x (sqrt (+ (* x x) 1)))) #s(hole binary64 (+ (log 2) (* -1 (log (/ 1 x))))))
#s(approx (log (+ x (sqrt (+ (* x x) 1)))) (+.f64 (log.f64 x) (log.f64 #s(literal 2 binary64))))
#s(approx (log (+ x (sqrt (+ (* x x) 1)))) #s(hole binary64 (+ (log 2) (+ (* -1 (log (/ 1 x))) (* 1/4 (/ 1 (pow x 2)))))))
#s(approx (log (+ x (sqrt (+ (* x x) 1)))) (-.f64 (+.f64 (log.f64 x) (log.f64 #s(literal 2 binary64))) (/.f64 #s(literal -1/4 binary64) (*.f64 x x))))
#s(approx (log (+ x (sqrt (+ (* x x) 1)))) #s(hole binary64 (- (+ (log 2) (+ (* -1 (log (/ 1 x))) (* 1/4 (/ 1 (pow x 2))))) (/ 3/32 (pow x 4)))))
#s(approx (log (+ x (sqrt (+ (* x x) 1)))) (-.f64 (-.f64 (+.f64 (log.f64 x) (log.f64 #s(literal 2 binary64))) (/.f64 #s(literal -1/4 binary64) (*.f64 x x))) (/.f64 #s(literal 3/32 binary64) (pow.f64 x #s(literal 4 binary64)))))
#s(approx (log (+ x (sqrt (+ (* x x) 1)))) #s(hole binary64 (- (+ (log 2) (+ (* -1 (log (/ 1 x))) (+ (* 1/4 (/ 1 (pow x 2))) (* 5/96 (/ 1 (pow x 6)))))) (/ 3/32 (pow x 4)))))
#s(approx (log (+ x (sqrt (+ (* x x) 1)))) (-.f64 (-.f64 (-.f64 (+.f64 (log.f64 x) (log.f64 #s(literal 2 binary64))) (/.f64 #s(literal -1/4 binary64) (*.f64 x x))) (/.f64 #s(literal -5/96 binary64) (pow.f64 x #s(literal 6 binary64)))) (/.f64 #s(literal 3/32 binary64) (pow.f64 x #s(literal 4 binary64)))))
#s(approx (+ x (sqrt (+ (* x x) 1))) #s(hole binary64 (* 2 x)))
#s(approx (+ x (sqrt (+ (* x x) 1))) (*.f64 #s(literal 2 binary64) x))
#s(approx (+ x (sqrt (+ (* x x) 1))) #s(hole binary64 (* x (+ 2 (* 1/2 (/ 1 (pow x 2)))))))
#s(approx (+ x (sqrt (+ (* x x) 1))) (*.f64 (-.f64 (/.f64 #s(literal 1/2 binary64) (*.f64 x x)) #s(literal -2 binary64)) x))
#s(approx (+ x (sqrt (+ (* x x) 1))) #s(hole binary64 (* x (- (+ 2 (* 1/2 (/ 1 (pow x 2)))) (/ 1/8 (pow x 4))))))
#s(approx (+ x (sqrt (+ (* x x) 1))) (*.f64 (-.f64 (-.f64 (/.f64 #s(literal 1/2 binary64) (*.f64 x x)) #s(literal -2 binary64)) (/.f64 #s(literal 1/8 binary64) (pow.f64 x #s(literal 4 binary64)))) x))
#s(approx (+ x (sqrt (+ (* x x) 1))) #s(hole binary64 (* x (- (+ 2 (+ (* 1/2 (/ 1 (pow x 2))) (* 1/16 (/ 1 (pow x 6))))) (/ 1/8 (pow x 4))))))
#s(approx (+ x (sqrt (+ (* x x) 1))) (*.f64 (-.f64 (-.f64 (-.f64 (/.f64 #s(literal 1/16 binary64) (pow.f64 x #s(literal 6 binary64))) #s(literal -2 binary64)) (/.f64 #s(literal -1/2 binary64) (*.f64 x x))) (/.f64 #s(literal 1/8 binary64) (pow.f64 x #s(literal 4 binary64)))) x))
#s(approx (sqrt (+ (* x x) 1)) #s(hole binary64 x))
#s(approx (sqrt (+ (* x x) 1)) x)
#s(approx (sqrt (+ (* x x) 1)) #s(hole binary64 (* x (+ 1 (* 1/2 (/ 1 (pow x 2)))))))
#s(approx (sqrt (+ (* x x) 1)) (fma.f64 (/.f64 #s(literal 1/2 binary64) (*.f64 x x)) x x))
#s(approx (sqrt (+ (* x x) 1)) #s(hole binary64 (* x (- (+ 1 (* 1/2 (/ 1 (pow x 2)))) (/ 1/8 (pow x 4))))))
#s(approx (sqrt (+ (* x x) 1)) (fma.f64 (-.f64 (/.f64 #s(literal 1/2 binary64) (*.f64 x x)) (/.f64 #s(literal 1/8 binary64) (pow.f64 x #s(literal 4 binary64)))) x x))
#s(approx (sqrt (+ (* x x) 1)) #s(hole binary64 (* x (- (+ 1 (+ (* 1/2 (/ 1 (pow x 2))) (* 1/16 (/ 1 (pow x 6))))) (/ 1/8 (pow x 4))))))
#s(approx (sqrt (+ (* x x) 1)) (fma.f64 (-.f64 (-.f64 (/.f64 #s(literal 1/16 binary64) (pow.f64 x #s(literal 6 binary64))) (/.f64 #s(literal -1/2 binary64) (*.f64 x x))) (/.f64 #s(literal 1/8 binary64) (pow.f64 x #s(literal 4 binary64)))) x x))
#s(approx (log (+ x (sqrt (+ (* x x) 1)))) #s(hole binary64 (+ (log 1/2) (log (/ -1 x)))))
#s(approx (log (+ x (sqrt (+ (* x x) 1)))) (+.f64 (log.f64 (/.f64 #s(literal -1 binary64) x)) (log.f64 #s(literal 1/2 binary64))))
#s(approx (log (+ x (sqrt (+ (* x x) 1)))) #s(hole binary64 (- (+ (log 1/2) (log (/ -1 x))) (* 1/4 (/ 1 (pow x 2))))))
#s(approx (log (+ x (sqrt (+ (* x x) 1)))) (-.f64 (+.f64 (log.f64 (/.f64 #s(literal -1 binary64) x)) (log.f64 #s(literal 1/2 binary64))) (/.f64 #s(literal 1/4 binary64) (*.f64 x x))))
#s(approx (log (+ x (sqrt (+ (* x x) 1)))) #s(hole binary64 (- (+ (log 1/2) (+ (log (/ -1 x)) (/ 3/32 (pow x 4)))) (* 1/4 (/ 1 (pow x 2))))))
#s(approx (log (+ x (sqrt (+ (* x x) 1)))) (-.f64 (+.f64 (log.f64 (/.f64 #s(literal -1 binary64) x)) (/.f64 #s(literal 3/32 binary64) (pow.f64 x #s(literal 4 binary64)))) (-.f64 (/.f64 #s(literal 1/4 binary64) (*.f64 x x)) (log.f64 #s(literal 1/2 binary64)))))
#s(approx (log (+ x (sqrt (+ (* x x) 1)))) #s(hole binary64 (- (+ (log 1/2) (+ (log (/ -1 x)) (/ 3/32 (pow x 4)))) (+ (* 1/4 (/ 1 (pow x 2))) (* 5/96 (/ 1 (pow x 6)))))))
#s(approx (log (+ x (sqrt (+ (* x x) 1)))) (-.f64 (+.f64 (+.f64 (log.f64 #s(literal 1/2 binary64)) (/.f64 #s(literal 3/32 binary64) (pow.f64 x #s(literal 4 binary64)))) (log.f64 (/.f64 #s(literal -1 binary64) x))) (-.f64 (/.f64 #s(literal 5/96 binary64) (pow.f64 x #s(literal 6 binary64))) (/.f64 #s(literal -1/4 binary64) (*.f64 x x)))))
#s(approx (+ x (sqrt (+ (* x x) 1))) #s(hole binary64 (/ -1/2 x)))
#s(approx (+ x (sqrt (+ (* x x) 1))) (/.f64 #s(literal -1/2 binary64) x))
#s(approx (+ x (sqrt (+ (* x x) 1))) #s(hole binary64 (* -1 (/ (- 1/2 (* 1/8 (/ 1 (pow x 2)))) x))))
#s(approx (+ x (sqrt (+ (* x x) 1))) (/.f64 (-.f64 #s(literal -1/2 binary64) (/.f64 #s(literal -1/8 binary64) (*.f64 x x))) x))
#s(approx (+ x (sqrt (+ (* x x) 1))) #s(hole binary64 (* -1 (/ (- (+ 1/2 (/ 1/16 (pow x 4))) (* 1/8 (/ 1 (pow x 2)))) x))))
#s(approx (+ x (sqrt (+ (* x x) 1))) (/.f64 (-.f64 (/.f64 #s(literal 1/16 binary64) (pow.f64 x #s(literal 4 binary64))) (-.f64 (/.f64 #s(literal 1/8 binary64) (*.f64 x x)) #s(literal 1/2 binary64))) (neg.f64 x)))
#s(approx (+ x (sqrt (+ (* x x) 1))) #s(hole binary64 (* -1 (/ (- (+ 1/2 (/ 1/16 (pow x 4))) (+ (* 1/8 (/ 1 (pow x 2))) (* 5/128 (/ 1 (pow x 6))))) x))))
#s(approx (+ x (sqrt (+ (* x x) 1))) (/.f64 (-.f64 (-.f64 (/.f64 #s(literal 1/16 binary64) (pow.f64 x #s(literal 4 binary64))) (-.f64 (/.f64 #s(literal 1/8 binary64) (*.f64 x x)) #s(literal 1/2 binary64))) (/.f64 #s(literal 5/128 binary64) (pow.f64 x #s(literal 6 binary64)))) (neg.f64 x)))
#s(approx (sqrt (+ (* x x) 1)) #s(hole binary64 (* -1 x)))
#s(approx (sqrt (+ (* x x) 1)) (neg.f64 x))
#s(approx (sqrt (+ (* x x) 1)) #s(hole binary64 (* -1 (* x (+ 1 (* 1/2 (/ 1 (pow x 2))))))))
#s(approx (sqrt (+ (* x x) 1)) (*.f64 (+.f64 (/.f64 #s(literal -1/2 binary64) (*.f64 x x)) #s(literal -1 binary64)) x))
#s(approx (sqrt (+ (* x x) 1)) #s(hole binary64 (* -1 (* x (- (+ 1 (* 1/2 (/ 1 (pow x 2)))) (/ 1/8 (pow x 4)))))))
#s(approx (sqrt (+ (* x x) 1)) (neg.f64 (fma.f64 (-.f64 (/.f64 #s(literal 1/2 binary64) (*.f64 x x)) (/.f64 #s(literal 1/8 binary64) (pow.f64 x #s(literal 4 binary64)))) x x)))
#s(approx (sqrt (+ (* x x) 1)) #s(hole binary64 (* -1 (* x (- (+ 1 (+ (* 1/2 (/ 1 (pow x 2))) (* 1/16 (/ 1 (pow x 6))))) (/ 1/8 (pow x 4)))))))
#s(approx (sqrt (+ (* x x) 1)) (*.f64 (+.f64 (+.f64 (/.f64 #s(literal -1/2 binary64) (*.f64 x x)) #s(literal -1 binary64)) (-.f64 (/.f64 #s(literal -1/16 binary64) (pow.f64 x #s(literal 6 binary64))) (/.f64 #s(literal -1/8 binary64) (pow.f64 x #s(literal 4 binary64))))) x))

rewrite93.0ms (2.3%)

Memory
31.6MiB live, 78.1MiB allocated; 3ms collecting garbage
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0731
01218
15118
039117
Stop Event
iter limit
iter limit
iter limit
unsound
iter limit
Counts
5 → 85
Calls
Call 1
Inputs
(+.f64 (*.f64 x x) #s(literal 1 binary64))
(log.f64 (+.f64 x (sqrt.f64 (+.f64 (*.f64 x x) #s(literal 1 binary64)))))
(+.f64 x (sqrt.f64 (+.f64 (*.f64 x x) #s(literal 1 binary64))))
(sqrt.f64 (+.f64 (*.f64 x x) #s(literal 1 binary64)))
(*.f64 x x)
Outputs
(*.f64 (neg.f64 (cosh.f64 (asinh.f64 x))) (neg.f64 (cosh.f64 (asinh.f64 x))))
(*.f64 (fabs.f64 (cosh.f64 (asinh.f64 x))) (fabs.f64 (cosh.f64 (asinh.f64 x))))
(*.f64 (cosh.f64 (asinh.f64 x)) (cosh.f64 (asinh.f64 x)))
(pow.f64 (*.f64 (fma.f64 x x #s(literal 1 binary64)) (fma.f64 x x #s(literal 1 binary64))) #s(literal 1/2 binary64))
(pow.f64 (cosh.f64 (asinh.f64 x)) #s(literal 2 binary64))
(pow.f64 (fma.f64 x x #s(literal 1 binary64)) #s(literal 1 binary64))
(/.f64 (-.f64 #s(literal 1 binary64) (pow.f64 x #s(literal 4 binary64))) (-.f64 #s(literal 1 binary64) (*.f64 x x)))
(/.f64 (neg.f64 (-.f64 (pow.f64 x #s(literal 4 binary64)) #s(literal 1 binary64))) (neg.f64 (fma.f64 x x #s(literal -1 binary64))))
(/.f64 (neg.f64 (-.f64 (pow.f64 x #s(literal 6 binary64)) #s(literal -1 binary64))) (neg.f64 (-.f64 (+.f64 (pow.f64 x #s(literal 4 binary64)) #s(literal 1 binary64)) (*.f64 x x))))
(/.f64 (-.f64 (pow.f64 x #s(literal 4 binary64)) #s(literal 1 binary64)) (fma.f64 x x #s(literal -1 binary64)))
(/.f64 (-.f64 (pow.f64 x #s(literal 6 binary64)) #s(literal -1 binary64)) (+.f64 #s(literal 1 binary64) (-.f64 (pow.f64 x #s(literal 4 binary64)) (*.f64 x x))))
(/.f64 (-.f64 (pow.f64 x #s(literal 6 binary64)) #s(literal -1 binary64)) (-.f64 (+.f64 (pow.f64 x #s(literal 4 binary64)) #s(literal 1 binary64)) (*.f64 x x)))
(fma.f64 (*.f64 (neg.f64 x) #s(literal 1 binary64)) (*.f64 (neg.f64 x) #s(literal 1 binary64)) #s(literal 1 binary64))
(fma.f64 (*.f64 (fabs.f64 x) #s(literal 1 binary64)) (*.f64 (fabs.f64 x) #s(literal 1 binary64)) #s(literal 1 binary64))
(fma.f64 (*.f64 x #s(literal 1 binary64)) (*.f64 x #s(literal 1 binary64)) #s(literal 1 binary64))
(fma.f64 (pow.f64 x #s(literal 1 binary64)) (pow.f64 x #s(literal 1 binary64)) #s(literal 1 binary64))
(fma.f64 (neg.f64 (neg.f64 x)) (neg.f64 (neg.f64 x)) #s(literal 1 binary64))
(fma.f64 (neg.f64 (fabs.f64 x)) (neg.f64 (fabs.f64 x)) #s(literal 1 binary64))
(fma.f64 (fabs.f64 (fabs.f64 x)) (fabs.f64 (fabs.f64 x)) #s(literal 1 binary64))
(fma.f64 (neg.f64 x) (*.f64 (neg.f64 x) #s(literal 1 binary64)) #s(literal 1 binary64))
(fma.f64 (neg.f64 x) (neg.f64 x) #s(literal 1 binary64))
(fma.f64 (fabs.f64 x) (*.f64 (fabs.f64 x) #s(literal 1 binary64)) #s(literal 1 binary64))
(fma.f64 (fabs.f64 x) (fabs.f64 x) #s(literal 1 binary64))
(fma.f64 #s(literal 1 binary64) (*.f64 x x) #s(literal 1 binary64))
(fma.f64 (*.f64 x x) #s(literal 1 binary64) #s(literal 1 binary64))
(fma.f64 x (*.f64 x #s(literal 1 binary64)) #s(literal 1 binary64))
(fma.f64 x x #s(literal 1 binary64))
(sqrt.f64 (*.f64 (fma.f64 x x #s(literal 1 binary64)) (fma.f64 x x #s(literal 1 binary64))))
(-.f64 (/.f64 (pow.f64 x #s(literal 4 binary64)) (fma.f64 x x #s(literal -1 binary64))) (/.f64 #s(literal 1 binary64) (fma.f64 x x #s(literal -1 binary64))))
(-.f64 #s(literal 1 binary64) (*.f64 (neg.f64 (neg.f64 x)) (neg.f64 x)))
(-.f64 #s(literal 1 binary64) (*.f64 (neg.f64 (fabs.f64 x)) (fabs.f64 x)))
(-.f64 #s(literal 1 binary64) (*.f64 (neg.f64 x) x))
(-.f64 #s(literal 1 binary64) (*.f64 x (neg.f64 x)))
(-.f64 (*.f64 x x) #s(literal -1 binary64))
(+.f64 (/.f64 (pow.f64 x #s(literal 6 binary64)) (-.f64 (+.f64 (pow.f64 x #s(literal 4 binary64)) #s(literal 1 binary64)) (*.f64 x x))) (/.f64 #s(literal 1 binary64) (-.f64 (+.f64 (pow.f64 x #s(literal 4 binary64)) #s(literal 1 binary64)) (*.f64 x x))))
(+.f64 #s(literal 1 binary64) (*.f64 x x))
(+.f64 (*.f64 x x) #s(literal 1 binary64))
(asinh.f64 x)
(-.f64 (log.f64 (-.f64 (*.f64 x x) (fma.f64 x x #s(literal 1 binary64)))) (log.f64 (-.f64 x (cosh.f64 (asinh.f64 x)))))
(-.f64 (log.f64 (+.f64 (pow.f64 (cosh.f64 (asinh.f64 x)) #s(literal 3 binary64)) (pow.f64 x #s(literal 3 binary64)))) (log.f64 (fma.f64 (cosh.f64 (asinh.f64 x)) (-.f64 (cosh.f64 (asinh.f64 x)) x) (*.f64 x x))))
(log.f64 (+.f64 (cosh.f64 (asinh.f64 x)) x))
(/.f64 (-.f64 (fma.f64 x x #s(literal 1 binary64)) (*.f64 x x)) (-.f64 (cosh.f64 (asinh.f64 x)) x))
(/.f64 (neg.f64 (-.f64 (*.f64 x x) (fma.f64 x x #s(literal 1 binary64)))) (neg.f64 (-.f64 x (cosh.f64 (asinh.f64 x)))))
(/.f64 (neg.f64 (+.f64 (pow.f64 (cosh.f64 (asinh.f64 x)) #s(literal 3 binary64)) (pow.f64 x #s(literal 3 binary64)))) (neg.f64 (fma.f64 (cosh.f64 (asinh.f64 x)) (-.f64 (cosh.f64 (asinh.f64 x)) x) (*.f64 x x))))
(/.f64 (-.f64 (*.f64 x x) (fma.f64 x x #s(literal 1 binary64))) (-.f64 x (cosh.f64 (asinh.f64 x))))
(/.f64 (+.f64 (pow.f64 (cosh.f64 (asinh.f64 x)) #s(literal 3 binary64)) (pow.f64 x #s(literal 3 binary64))) (+.f64 (fma.f64 x x #s(literal 1 binary64)) (-.f64 (*.f64 x x) (*.f64 (cosh.f64 (asinh.f64 x)) x))))
(/.f64 (+.f64 (pow.f64 (cosh.f64 (asinh.f64 x)) #s(literal 3 binary64)) (pow.f64 x #s(literal 3 binary64))) (fma.f64 (cosh.f64 (asinh.f64 x)) (-.f64 (cosh.f64 (asinh.f64 x)) x) (*.f64 x x)))
(fma.f64 (pow.f64 (fma.f64 x x #s(literal 1 binary64)) #s(literal 1/4 binary64)) (pow.f64 (fma.f64 x x #s(literal 1 binary64)) #s(literal 1/4 binary64)) x)
(-.f64 (/.f64 (*.f64 x x) (-.f64 x (cosh.f64 (asinh.f64 x)))) (/.f64 (fma.f64 x x #s(literal 1 binary64)) (-.f64 x (cosh.f64 (asinh.f64 x)))))
(+.f64 (/.f64 (pow.f64 x #s(literal 3 binary64)) (fma.f64 (cosh.f64 (asinh.f64 x)) (-.f64 (cosh.f64 (asinh.f64 x)) x) (*.f64 x x))) (/.f64 (pow.f64 (cosh.f64 (asinh.f64 x)) #s(literal 3 binary64)) (fma.f64 (cosh.f64 (asinh.f64 x)) (-.f64 (cosh.f64 (asinh.f64 x)) x) (*.f64 x x))))
(+.f64 (cosh.f64 (asinh.f64 x)) x)
(+.f64 x (cosh.f64 (asinh.f64 x)))
(*.f64 (pow.f64 (fma.f64 x x #s(literal 1 binary64)) #s(literal 1/4 binary64)) (pow.f64 (fma.f64 x x #s(literal 1 binary64)) #s(literal 1/4 binary64)))
(pow.f64 (fma.f64 x x #s(literal 1 binary64)) #s(literal 1/2 binary64))
(/.f64 (sqrt.f64 (-.f64 (pow.f64 x #s(literal 4 binary64)) #s(literal 1 binary64))) (sqrt.f64 (fma.f64 x x #s(literal -1 binary64))))
(/.f64 (sqrt.f64 (-.f64 (pow.f64 x #s(literal 6 binary64)) #s(literal -1 binary64))) (sqrt.f64 (-.f64 (+.f64 (pow.f64 x #s(literal 4 binary64)) #s(literal 1 binary64)) (*.f64 x x))))
(/.f64 (+.f64 (exp.f64 (asinh.f64 x)) (exp.f64 (neg.f64 (asinh.f64 x)))) #s(literal 2 binary64))
(cosh.f64 (neg.f64 (asinh.f64 x)))
(cosh.f64 (asinh.f64 (neg.f64 x)))
(cosh.f64 (asinh.f64 (fabs.f64 x)))
(cosh.f64 (asinh.f64 x))
(sqrt.f64 (fma.f64 x x #s(literal 1 binary64)))
(exp.f64 (*.f64 (log1p.f64 (*.f64 x x)) #s(literal 1/2 binary64)))
(*.f64 (*.f64 (neg.f64 x) #s(literal 1 binary64)) (*.f64 (neg.f64 x) #s(literal 1 binary64)))
(*.f64 (*.f64 (fabs.f64 x) #s(literal 1 binary64)) (*.f64 (fabs.f64 x) #s(literal 1 binary64)))
(*.f64 (*.f64 x #s(literal 1 binary64)) (*.f64 x #s(literal 1 binary64)))
(*.f64 (pow.f64 x #s(literal 1 binary64)) (pow.f64 x #s(literal 1 binary64)))
(*.f64 (neg.f64 (neg.f64 x)) (neg.f64 (neg.f64 x)))
(*.f64 (neg.f64 (fabs.f64 x)) (neg.f64 (fabs.f64 x)))
(*.f64 (fabs.f64 (fabs.f64 x)) (fabs.f64 (fabs.f64 x)))
(*.f64 (neg.f64 x) (*.f64 (neg.f64 x) #s(literal 1 binary64)))
(*.f64 (neg.f64 x) (neg.f64 x))
(*.f64 (fabs.f64 x) (*.f64 (fabs.f64 x) #s(literal 1 binary64)))
(*.f64 (fabs.f64 x) (fabs.f64 x))
(*.f64 #s(literal 1 binary64) (*.f64 x x))
(*.f64 (*.f64 x x) #s(literal 1 binary64))
(*.f64 x (*.f64 x #s(literal 1 binary64)))
(*.f64 x x)
(pow.f64 (neg.f64 x) #s(literal 2 binary64))
(pow.f64 (fabs.f64 x) #s(literal 2 binary64))
(pow.f64 x #s(literal 2 binary64))
(neg.f64 (*.f64 (neg.f64 x) x))
(neg.f64 (*.f64 x (neg.f64 x)))
(fabs.f64 (*.f64 x x))
(exp.f64 (*.f64 (log.f64 x) #s(literal 2 binary64)))

eval29.0ms (0.7%)

Memory
-17.0MiB live, 39.4MiB allocated; 15ms collecting garbage
Compiler

Compiled 1 917 to 580 computations (69.7% saved)

prune3.0ms (0.1%)

Memory
8.6MiB live, 8.6MiB allocated; 0ms collecting garbage
Pruning

4 alts after pruning (4 fresh and 0 done)

PrunedKeptTotal
New1214125
Fresh000
Picked101
Done000
Total1224126
Accuracy
100.0%
Counts
126 → 4
Alt Table
Click to see full alt table
StatusAccuracyProgram
25.0%
(log.f64 (+.f64 x #s(approx (sqrt (+ (* x x) 1)) x)))
23.6%
(log.f64 #s(approx (+ x (sqrt (+ (* x x) 1))) (/.f64 #s(literal -1/2 binary64) x)))
99.9%
(asinh.f64 x)
54.9%
#s(approx (log (+ x (sqrt (+ (* x x) 1)))) x)
Compiler

Compiled 37 to 28 computations (24.3% saved)

simplify135.0ms (3.3%)

Memory
4.0MiB live, 139.9MiB allocated; 13ms collecting garbage
Localize:

Found 8 expressions of interest:

NewMetricScoreProgram
cost-diff0
#s(approx (sqrt (+ (* x x) 1)) x)
cost-diff0
(+.f64 x #s(approx (sqrt (+ (* x x) 1)) x))
cost-diff0
(log.f64 (+.f64 x #s(approx (sqrt (+ (* x x) 1)) x)))
cost-diff0
(/.f64 #s(literal -1/2 binary64) x)
cost-diff0
#s(approx (+ x (sqrt (+ (* x x) 1))) (/.f64 #s(literal -1/2 binary64) x))
cost-diff0
(log.f64 #s(approx (+ x (sqrt (+ (* x x) 1))) (/.f64 #s(literal -1/2 binary64) x)))
cost-diff0
(asinh.f64 x)
cost-diff0
#s(approx (log (+ x (sqrt (+ (* x x) 1)))) x)
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01675
02175
13075
25275
39275
415375
536175
6245375
7615975
0817869
Stop Event
iter limit
node limit
iter limit
Calls
Call 1
Inputs
#s(approx (log (+ x (sqrt (+ (* x x) 1)))) x)
x
(asinh.f64 x)
x
(log.f64 #s(approx (+ x (sqrt (+ (* x x) 1))) (/.f64 #s(literal -1/2 binary64) x)))
#s(approx (+ x (sqrt (+ (* x x) 1))) (/.f64 #s(literal -1/2 binary64) x))
(/.f64 #s(literal -1/2 binary64) x)
#s(literal -1/2 binary64)
x
(log.f64 (+.f64 x #s(approx (sqrt (+ (* x x) 1)) x)))
(+.f64 x #s(approx (sqrt (+ (* x x) 1)) x))
x
#s(approx (sqrt (+ (* x x) 1)) x)
Outputs
#s(approx (log (+ x (sqrt (+ (* x x) 1)))) x)
x
(asinh.f64 x)
x
(log.f64 #s(approx (+ x (sqrt (+ (* x x) 1))) (/.f64 #s(literal -1/2 binary64) x)))
#s(approx (+ x (sqrt (+ (* x x) 1))) (/.f64 #s(literal -1/2 binary64) x))
(/.f64 #s(literal -1/2 binary64) x)
#s(literal -1/2 binary64)
x
(log.f64 (+.f64 x #s(approx (sqrt (+ (* x x) 1)) x)))
(log.f64 (+.f64 #s(approx (sqrt (+ (* x x) 1)) x) x))
(+.f64 x #s(approx (sqrt (+ (* x x) 1)) x))
(+.f64 #s(approx (sqrt (+ (* x x) 1)) x) x)
x
#s(approx (sqrt (+ (* x x) 1)) x)

localize117.0ms (2.9%)

Memory
-48.1MiB live, 113.5MiB allocated; 73ms collecting garbage
Localize:

Found 8 expressions of interest:

NewMetricScoreProgram
accuracy13.952059943383047
(+.f64 x #s(approx (sqrt (+ (* x x) 1)) x))
accuracy31.332836590821298
(log.f64 (+.f64 x #s(approx (sqrt (+ (* x x) 1)) x)))
accuracy47.03664178941563
#s(approx (sqrt (+ (* x x) 1)) x)
accuracy0.0
(/.f64 #s(literal -1/2 binary64) x)
accuracy31.332836590821298
(log.f64 #s(approx (+ x (sqrt (+ (* x x) 1))) (/.f64 #s(literal -1/2 binary64) x)))
accuracy47.99399434130296
#s(approx (+ x (sqrt (+ (* x x) 1))) (/.f64 #s(literal -1/2 binary64) x))
accuracy0.078125
(asinh.f64 x)
accuracy28.891985918067647
#s(approx (log (+ x (sqrt (+ (* x x) 1)))) x)
Samples
62.0ms134×1valid
37.0ms58×2valid
9.0ms64×0valid
Compiler

Compiled 61 to 10 computations (83.6% saved)

Precisions
Click to see histograms. Total time spent on operations: 85.0ms
ival-log: 58.0ms (68.5% of total)
ival-hypot: 12.0ms (14.2% of total)
ival-add: 6.0ms (7.1% of total)
adjust: 5.0ms (5.9% of total)
ival-div: 2.0ms (2.4% of total)
ival-asinh: 2.0ms (2.4% of total)
ival-assert: 0.0ms (0% of total)
ival-true: 0.0ms (0% of total)
exact: 0.0ms (0% of total)

series4.0ms (0.1%)

Memory
8.3MiB live, 8.3MiB allocated; 0ms collecting garbage
Counts
8 → 49
Calls
Call 1
Inputs
#s(approx (log (+ x (sqrt (+ (* x x) 1)))) x)
(asinh.f64 x)
(log.f64 #s(approx (+ x (sqrt (+ (* x x) 1))) (/.f64 #s(literal -1/2 binary64) x)))
#s(approx (+ x (sqrt (+ (* x x) 1))) (/.f64 #s(literal -1/2 binary64) x))
(/.f64 #s(literal -1/2 binary64) x)
(log.f64 (+.f64 x #s(approx (sqrt (+ (* x x) 1)) x)))
(+.f64 x #s(approx (sqrt (+ (* x x) 1)) x))
#s(approx (sqrt (+ (* x x) 1)) x)
Outputs
#s(approx (log (+ x (sqrt (+ (* x x) 1)))) #s(hole binary64 x))
#s(approx (log (+ x (sqrt (+ (* x x) 1)))) #s(hole binary64 (* x (+ 1 (* -1/6 (pow x 2))))))
#s(approx (log (+ x (sqrt (+ (* x x) 1)))) #s(hole binary64 (* x (+ 1 (* (pow x 2) (- (* 3/40 (pow x 2)) 1/6))))))
#s(approx (log (+ x (sqrt (+ (* x x) 1)))) #s(hole binary64 (* x (+ 1 (* (pow x 2) (- (* (pow x 2) (+ 3/40 (* -5/112 (pow x 2)))) 1/6))))))
#s(approx (asinh x) #s(hole binary64 x))
#s(approx (asinh x) #s(hole binary64 (* x (+ 1 (* -1/6 (pow x 2))))))
#s(approx (asinh x) #s(hole binary64 (* x (+ 1 (* (pow x 2) (- (* 3/40 (pow x 2)) 1/6))))))
#s(approx (asinh x) #s(hole binary64 (* x (+ 1 (* (pow x 2) (- (* (pow x 2) (+ 3/40 (* -5/112 (pow x 2)))) 1/6))))))
#s(approx (+ x (sqrt (+ (* x x) 1))) #s(hole binary64 1))
#s(approx (+ x (sqrt (+ (* x x) 1))) #s(hole binary64 (+ 1 x)))
#s(approx (+ x (sqrt (+ (* x x) 1))) #s(hole binary64 (+ 1 (* x (+ 1 (* 1/2 x))))))
#s(approx (+ x (sqrt (+ (* x x) 1))) #s(hole binary64 (+ 1 (* x (+ 1 (* x (+ 1/2 (* -1/8 (pow x 2)))))))))
#s(approx (/ -1/2 x) #s(hole binary64 (/ -1/2 x)))
#s(approx (sqrt (+ (* x x) 1)) #s(hole binary64 1))
#s(approx (sqrt (+ (* x x) 1)) #s(hole binary64 (+ 1 (* 1/2 (pow x 2)))))
#s(approx (sqrt (+ (* x x) 1)) #s(hole binary64 (+ 1 (* (pow x 2) (+ 1/2 (* -1/8 (pow x 2)))))))
#s(approx (sqrt (+ (* x x) 1)) #s(hole binary64 (+ 1 (* (pow x 2) (+ 1/2 (* (pow x 2) (- (* 1/16 (pow x 2)) 1/8)))))))
#s(approx (log (+ x (sqrt (+ (* x x) 1)))) #s(hole binary64 (+ (log 2) (* -1 (log (/ 1 x))))))
#s(approx (log (+ x (sqrt (+ (* x x) 1)))) #s(hole binary64 (+ (log 2) (+ (* -1 (log (/ 1 x))) (* 1/4 (/ 1 (pow x 2)))))))
#s(approx (log (+ x (sqrt (+ (* x x) 1)))) #s(hole binary64 (- (+ (log 2) (+ (* -1 (log (/ 1 x))) (* 1/4 (/ 1 (pow x 2))))) (/ 3/32 (pow x 4)))))
#s(approx (log (+ x (sqrt (+ (* x x) 1)))) #s(hole binary64 (- (+ (log 2) (+ (* -1 (log (/ 1 x))) (+ (* 1/4 (/ 1 (pow x 2))) (* 5/96 (/ 1 (pow x 6)))))) (/ 3/32 (pow x 4)))))
#s(approx (asinh x) #s(hole binary64 (+ (log 2) (* -1 (log (/ 1 x))))))
#s(approx (asinh x) #s(hole binary64 (+ (log 2) (+ (* -1 (log (/ 1 x))) (* 1/4 (/ 1 (pow x 2)))))))
#s(approx (asinh x) #s(hole binary64 (- (+ (log 2) (+ (* -1 (log (/ 1 x))) (* 1/4 (/ 1 (pow x 2))))) (/ 3/32 (pow x 4)))))
#s(approx (asinh x) #s(hole binary64 (- (+ (log 2) (+ (* -1 (log (/ 1 x))) (+ (* 1/4 (/ 1 (pow x 2))) (* 5/96 (/ 1 (pow x 6)))))) (/ 3/32 (pow x 4)))))
#s(approx (+ x (sqrt (+ (* x x) 1))) #s(hole binary64 (* 2 x)))
#s(approx (+ x (sqrt (+ (* x x) 1))) #s(hole binary64 (* x (+ 2 (* 1/2 (/ 1 (pow x 2)))))))
#s(approx (+ x (sqrt (+ (* x x) 1))) #s(hole binary64 (* x (- (+ 2 (* 1/2 (/ 1 (pow x 2)))) (/ 1/8 (pow x 4))))))
#s(approx (+ x (sqrt (+ (* x x) 1))) #s(hole binary64 (* x (- (+ 2 (+ (* 1/2 (/ 1 (pow x 2))) (* 1/16 (/ 1 (pow x 6))))) (/ 1/8 (pow x 4))))))
#s(approx (sqrt (+ (* x x) 1)) #s(hole binary64 x))
#s(approx (sqrt (+ (* x x) 1)) #s(hole binary64 (* x (+ 1 (* 1/2 (/ 1 (pow x 2)))))))
#s(approx (sqrt (+ (* x x) 1)) #s(hole binary64 (* x (- (+ 1 (* 1/2 (/ 1 (pow x 2)))) (/ 1/8 (pow x 4))))))
#s(approx (sqrt (+ (* x x) 1)) #s(hole binary64 (* x (- (+ 1 (+ (* 1/2 (/ 1 (pow x 2))) (* 1/16 (/ 1 (pow x 6))))) (/ 1/8 (pow x 4))))))
#s(approx (log (+ x (sqrt (+ (* x x) 1)))) #s(hole binary64 (+ (log 1/2) (log (/ -1 x)))))
#s(approx (log (+ x (sqrt (+ (* x x) 1)))) #s(hole binary64 (- (+ (log 1/2) (log (/ -1 x))) (* 1/4 (/ 1 (pow x 2))))))
#s(approx (log (+ x (sqrt (+ (* x x) 1)))) #s(hole binary64 (- (+ (log 1/2) (+ (log (/ -1 x)) (/ 3/32 (pow x 4)))) (* 1/4 (/ 1 (pow x 2))))))
#s(approx (log (+ x (sqrt (+ (* x x) 1)))) #s(hole binary64 (- (+ (log 1/2) (+ (log (/ -1 x)) (/ 3/32 (pow x 4)))) (+ (* 1/4 (/ 1 (pow x 2))) (* 5/96 (/ 1 (pow x 6)))))))
#s(approx (asinh x) #s(hole binary64 (+ (log 1/2) (log (/ -1 x)))))
#s(approx (asinh x) #s(hole binary64 (- (+ (log 1/2) (log (/ -1 x))) (* 1/4 (/ 1 (pow x 2))))))
#s(approx (asinh x) #s(hole binary64 (- (+ (log 1/2) (+ (log (/ -1 x)) (/ 3/32 (pow x 4)))) (* 1/4 (/ 1 (pow x 2))))))
#s(approx (asinh x) #s(hole binary64 (- (+ (log 1/2) (+ (log (/ -1 x)) (/ 3/32 (pow x 4)))) (+ (* 1/4 (/ 1 (pow x 2))) (* 5/96 (/ 1 (pow x 6)))))))
#s(approx (+ x (sqrt (+ (* x x) 1))) #s(hole binary64 (/ -1/2 x)))
#s(approx (+ x (sqrt (+ (* x x) 1))) #s(hole binary64 (* -1 (/ (- 1/2 (* 1/8 (/ 1 (pow x 2)))) x))))
#s(approx (+ x (sqrt (+ (* x x) 1))) #s(hole binary64 (* -1 (/ (- (+ 1/2 (/ 1/16 (pow x 4))) (* 1/8 (/ 1 (pow x 2)))) x))))
#s(approx (+ x (sqrt (+ (* x x) 1))) #s(hole binary64 (* -1 (/ (- (+ 1/2 (/ 1/16 (pow x 4))) (+ (* 1/8 (/ 1 (pow x 2))) (* 5/128 (/ 1 (pow x 6))))) x))))
#s(approx (sqrt (+ (* x x) 1)) #s(hole binary64 (* -1 x)))
#s(approx (sqrt (+ (* x x) 1)) #s(hole binary64 (* -1 (* x (+ 1 (* 1/2 (/ 1 (pow x 2))))))))
#s(approx (sqrt (+ (* x x) 1)) #s(hole binary64 (* -1 (* x (- (+ 1 (* 1/2 (/ 1 (pow x 2)))) (/ 1/8 (pow x 4)))))))
#s(approx (sqrt (+ (* x x) 1)) #s(hole binary64 (* -1 (* x (- (+ 1 (+ (* 1/2 (/ 1 (pow x 2))) (* 1/16 (/ 1 (pow x 6))))) (/ 1/8 (pow x 4)))))))
Calls

3 calls:

TimeVariablePointExpression
1.0ms
x
@-inf
((log (+ x (sqrt (+ (* x x) 1)))) (asinh x) (log (+ x (sqrt (+ (* x x) 1)))) (+ x (sqrt (+ (* x x) 1))) (/ -1/2 x) (log (+ x (sqrt (+ (* x x) 1)))) (+ x (sqrt (+ (* x x) 1))) (sqrt (+ (* x x) 1)))
1.0ms
x
@0
((log (+ x (sqrt (+ (* x x) 1)))) (asinh x) (log (+ x (sqrt (+ (* x x) 1)))) (+ x (sqrt (+ (* x x) 1))) (/ -1/2 x) (log (+ x (sqrt (+ (* x x) 1)))) (+ x (sqrt (+ (* x x) 1))) (sqrt (+ (* x x) 1)))
1.0ms
x
@inf
((log (+ x (sqrt (+ (* x x) 1)))) (asinh x) (log (+ x (sqrt (+ (* x x) 1)))) (+ x (sqrt (+ (* x x) 1))) (/ -1/2 x) (log (+ x (sqrt (+ (* x x) 1)))) (+ x (sqrt (+ (* x x) 1))) (sqrt (+ (* x x) 1)))

simplify221.0ms (5.4%)

Memory
18.1MiB live, 158.2MiB allocated; 15ms collecting garbage
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0177966
1433950
21441934
35203932
08343874
Stop Event
iter limit
node limit
Counts
49 → 49
Calls
Call 1
Inputs
#s(approx (log (+ x (sqrt (+ (* x x) 1)))) #s(hole binary64 x))
#s(approx (log (+ x (sqrt (+ (* x x) 1)))) #s(hole binary64 (* x (+ 1 (* -1/6 (pow x 2))))))
#s(approx (log (+ x (sqrt (+ (* x x) 1)))) #s(hole binary64 (* x (+ 1 (* (pow x 2) (- (* 3/40 (pow x 2)) 1/6))))))
#s(approx (log (+ x (sqrt (+ (* x x) 1)))) #s(hole binary64 (* x (+ 1 (* (pow x 2) (- (* (pow x 2) (+ 3/40 (* -5/112 (pow x 2)))) 1/6))))))
#s(approx (asinh x) #s(hole binary64 x))
#s(approx (asinh x) #s(hole binary64 (* x (+ 1 (* -1/6 (pow x 2))))))
#s(approx (asinh x) #s(hole binary64 (* x (+ 1 (* (pow x 2) (- (* 3/40 (pow x 2)) 1/6))))))
#s(approx (asinh x) #s(hole binary64 (* x (+ 1 (* (pow x 2) (- (* (pow x 2) (+ 3/40 (* -5/112 (pow x 2)))) 1/6))))))
#s(approx (+ x (sqrt (+ (* x x) 1))) #s(hole binary64 1))
#s(approx (+ x (sqrt (+ (* x x) 1))) #s(hole binary64 (+ 1 x)))
#s(approx (+ x (sqrt (+ (* x x) 1))) #s(hole binary64 (+ 1 (* x (+ 1 (* 1/2 x))))))
#s(approx (+ x (sqrt (+ (* x x) 1))) #s(hole binary64 (+ 1 (* x (+ 1 (* x (+ 1/2 (* -1/8 (pow x 2)))))))))
#s(approx (/ -1/2 x) #s(hole binary64 (/ -1/2 x)))
#s(approx (sqrt (+ (* x x) 1)) #s(hole binary64 1))
#s(approx (sqrt (+ (* x x) 1)) #s(hole binary64 (+ 1 (* 1/2 (pow x 2)))))
#s(approx (sqrt (+ (* x x) 1)) #s(hole binary64 (+ 1 (* (pow x 2) (+ 1/2 (* -1/8 (pow x 2)))))))
#s(approx (sqrt (+ (* x x) 1)) #s(hole binary64 (+ 1 (* (pow x 2) (+ 1/2 (* (pow x 2) (- (* 1/16 (pow x 2)) 1/8)))))))
#s(approx (log (+ x (sqrt (+ (* x x) 1)))) #s(hole binary64 (+ (log 2) (* -1 (log (/ 1 x))))))
#s(approx (log (+ x (sqrt (+ (* x x) 1)))) #s(hole binary64 (+ (log 2) (+ (* -1 (log (/ 1 x))) (* 1/4 (/ 1 (pow x 2)))))))
#s(approx (log (+ x (sqrt (+ (* x x) 1)))) #s(hole binary64 (- (+ (log 2) (+ (* -1 (log (/ 1 x))) (* 1/4 (/ 1 (pow x 2))))) (/ 3/32 (pow x 4)))))
#s(approx (log (+ x (sqrt (+ (* x x) 1)))) #s(hole binary64 (- (+ (log 2) (+ (* -1 (log (/ 1 x))) (+ (* 1/4 (/ 1 (pow x 2))) (* 5/96 (/ 1 (pow x 6)))))) (/ 3/32 (pow x 4)))))
#s(approx (asinh x) #s(hole binary64 (+ (log 2) (* -1 (log (/ 1 x))))))
#s(approx (asinh x) #s(hole binary64 (+ (log 2) (+ (* -1 (log (/ 1 x))) (* 1/4 (/ 1 (pow x 2)))))))
#s(approx (asinh x) #s(hole binary64 (- (+ (log 2) (+ (* -1 (log (/ 1 x))) (* 1/4 (/ 1 (pow x 2))))) (/ 3/32 (pow x 4)))))
#s(approx (asinh x) #s(hole binary64 (- (+ (log 2) (+ (* -1 (log (/ 1 x))) (+ (* 1/4 (/ 1 (pow x 2))) (* 5/96 (/ 1 (pow x 6)))))) (/ 3/32 (pow x 4)))))
#s(approx (+ x (sqrt (+ (* x x) 1))) #s(hole binary64 (* 2 x)))
#s(approx (+ x (sqrt (+ (* x x) 1))) #s(hole binary64 (* x (+ 2 (* 1/2 (/ 1 (pow x 2)))))))
#s(approx (+ x (sqrt (+ (* x x) 1))) #s(hole binary64 (* x (- (+ 2 (* 1/2 (/ 1 (pow x 2)))) (/ 1/8 (pow x 4))))))
#s(approx (+ x (sqrt (+ (* x x) 1))) #s(hole binary64 (* x (- (+ 2 (+ (* 1/2 (/ 1 (pow x 2))) (* 1/16 (/ 1 (pow x 6))))) (/ 1/8 (pow x 4))))))
#s(approx (sqrt (+ (* x x) 1)) #s(hole binary64 x))
#s(approx (sqrt (+ (* x x) 1)) #s(hole binary64 (* x (+ 1 (* 1/2 (/ 1 (pow x 2)))))))
#s(approx (sqrt (+ (* x x) 1)) #s(hole binary64 (* x (- (+ 1 (* 1/2 (/ 1 (pow x 2)))) (/ 1/8 (pow x 4))))))
#s(approx (sqrt (+ (* x x) 1)) #s(hole binary64 (* x (- (+ 1 (+ (* 1/2 (/ 1 (pow x 2))) (* 1/16 (/ 1 (pow x 6))))) (/ 1/8 (pow x 4))))))
#s(approx (log (+ x (sqrt (+ (* x x) 1)))) #s(hole binary64 (+ (log 1/2) (log (/ -1 x)))))
#s(approx (log (+ x (sqrt (+ (* x x) 1)))) #s(hole binary64 (- (+ (log 1/2) (log (/ -1 x))) (* 1/4 (/ 1 (pow x 2))))))
#s(approx (log (+ x (sqrt (+ (* x x) 1)))) #s(hole binary64 (- (+ (log 1/2) (+ (log (/ -1 x)) (/ 3/32 (pow x 4)))) (* 1/4 (/ 1 (pow x 2))))))
#s(approx (log (+ x (sqrt (+ (* x x) 1)))) #s(hole binary64 (- (+ (log 1/2) (+ (log (/ -1 x)) (/ 3/32 (pow x 4)))) (+ (* 1/4 (/ 1 (pow x 2))) (* 5/96 (/ 1 (pow x 6)))))))
#s(approx (asinh x) #s(hole binary64 (+ (log 1/2) (log (/ -1 x)))))
#s(approx (asinh x) #s(hole binary64 (- (+ (log 1/2) (log (/ -1 x))) (* 1/4 (/ 1 (pow x 2))))))
#s(approx (asinh x) #s(hole binary64 (- (+ (log 1/2) (+ (log (/ -1 x)) (/ 3/32 (pow x 4)))) (* 1/4 (/ 1 (pow x 2))))))
#s(approx (asinh x) #s(hole binary64 (- (+ (log 1/2) (+ (log (/ -1 x)) (/ 3/32 (pow x 4)))) (+ (* 1/4 (/ 1 (pow x 2))) (* 5/96 (/ 1 (pow x 6)))))))
#s(approx (+ x (sqrt (+ (* x x) 1))) #s(hole binary64 (/ -1/2 x)))
#s(approx (+ x (sqrt (+ (* x x) 1))) #s(hole binary64 (* -1 (/ (- 1/2 (* 1/8 (/ 1 (pow x 2)))) x))))
#s(approx (+ x (sqrt (+ (* x x) 1))) #s(hole binary64 (* -1 (/ (- (+ 1/2 (/ 1/16 (pow x 4))) (* 1/8 (/ 1 (pow x 2)))) x))))
#s(approx (+ x (sqrt (+ (* x x) 1))) #s(hole binary64 (* -1 (/ (- (+ 1/2 (/ 1/16 (pow x 4))) (+ (* 1/8 (/ 1 (pow x 2))) (* 5/128 (/ 1 (pow x 6))))) x))))
#s(approx (sqrt (+ (* x x) 1)) #s(hole binary64 (* -1 x)))
#s(approx (sqrt (+ (* x x) 1)) #s(hole binary64 (* -1 (* x (+ 1 (* 1/2 (/ 1 (pow x 2))))))))
#s(approx (sqrt (+ (* x x) 1)) #s(hole binary64 (* -1 (* x (- (+ 1 (* 1/2 (/ 1 (pow x 2)))) (/ 1/8 (pow x 4)))))))
#s(approx (sqrt (+ (* x x) 1)) #s(hole binary64 (* -1 (* x (- (+ 1 (+ (* 1/2 (/ 1 (pow x 2))) (* 1/16 (/ 1 (pow x 6))))) (/ 1/8 (pow x 4)))))))
Outputs
#s(approx (log (+ x (sqrt (+ (* x x) 1)))) #s(hole binary64 x))
#s(approx (log (+ x (sqrt (+ (* x x) 1)))) x)
#s(approx (log (+ x (sqrt (+ (* x x) 1)))) #s(hole binary64 (* x (+ 1 (* -1/6 (pow x 2))))))
#s(approx (log (+ x (sqrt (+ (* x x) 1)))) (fma.f64 (pow.f64 x #s(literal 3 binary64)) #s(literal -1/6 binary64) x))
#s(approx (log (+ x (sqrt (+ (* x x) 1)))) #s(hole binary64 (* x (+ 1 (* (pow x 2) (- (* 3/40 (pow x 2)) 1/6))))))
#s(approx (log (+ x (sqrt (+ (* x x) 1)))) (fma.f64 (pow.f64 x #s(literal 3 binary64)) (-.f64 (*.f64 #s(literal 3/40 binary64) (*.f64 x x)) #s(literal 1/6 binary64)) x))
#s(approx (log (+ x (sqrt (+ (* x x) 1)))) #s(hole binary64 (* x (+ 1 (* (pow x 2) (- (* (pow x 2) (+ 3/40 (* -5/112 (pow x 2)))) 1/6))))))
#s(approx (log (+ x (sqrt (+ (* x x) 1)))) (fma.f64 (pow.f64 x #s(literal 3 binary64)) (fma.f64 (pow.f64 x #s(literal 4 binary64)) #s(literal -5/112 binary64) (-.f64 (*.f64 #s(literal 3/40 binary64) (*.f64 x x)) #s(literal 1/6 binary64))) x))
#s(approx (asinh x) #s(hole binary64 x))
#s(approx (asinh x) x)
#s(approx (asinh x) #s(hole binary64 (* x (+ 1 (* -1/6 (pow x 2))))))
#s(approx (asinh x) (fma.f64 (pow.f64 x #s(literal 3 binary64)) #s(literal -1/6 binary64) x))
#s(approx (asinh x) #s(hole binary64 (* x (+ 1 (* (pow x 2) (- (* 3/40 (pow x 2)) 1/6))))))
#s(approx (asinh x) (fma.f64 (pow.f64 x #s(literal 3 binary64)) (-.f64 (*.f64 #s(literal 3/40 binary64) (*.f64 x x)) #s(literal 1/6 binary64)) x))
#s(approx (asinh x) #s(hole binary64 (* x (+ 1 (* (pow x 2) (- (* (pow x 2) (+ 3/40 (* -5/112 (pow x 2)))) 1/6))))))
#s(approx (asinh x) (fma.f64 (pow.f64 x #s(literal 3 binary64)) (fma.f64 (pow.f64 x #s(literal 4 binary64)) #s(literal -5/112 binary64) (-.f64 (*.f64 #s(literal 3/40 binary64) (*.f64 x x)) #s(literal 1/6 binary64))) x))
#s(approx (+ x (sqrt (+ (* x x) 1))) #s(hole binary64 1))
#s(approx (+ x (sqrt (+ (* x x) 1))) #s(literal 1 binary64))
#s(approx (+ x (sqrt (+ (* x x) 1))) #s(hole binary64 (+ 1 x)))
#s(approx (+ x (sqrt (+ (* x x) 1))) (-.f64 x #s(literal -1 binary64)))
#s(approx (+ x (sqrt (+ (* x x) 1))) #s(hole binary64 (+ 1 (* x (+ 1 (* 1/2 x))))))
#s(approx (+ x (sqrt (+ (* x x) 1))) (fma.f64 (fma.f64 #s(literal 1/2 binary64) x #s(literal 1 binary64)) x #s(literal 1 binary64)))
#s(approx (+ x (sqrt (+ (* x x) 1))) #s(hole binary64 (+ 1 (* x (+ 1 (* x (+ 1/2 (* -1/8 (pow x 2)))))))))
#s(approx (+ x (sqrt (+ (* x x) 1))) (fma.f64 (fma.f64 (fma.f64 #s(literal -1/8 binary64) (*.f64 x x) #s(literal 1/2 binary64)) x #s(literal 1 binary64)) x #s(literal 1 binary64)))
#s(approx (/ -1/2 x) #s(hole binary64 (/ -1/2 x)))
#s(approx (/ -1/2 x) (/.f64 #s(literal -1/2 binary64) x))
#s(approx (sqrt (+ (* x x) 1)) #s(hole binary64 1))
#s(approx (sqrt (+ (* x x) 1)) #s(literal 1 binary64))
#s(approx (sqrt (+ (* x x) 1)) #s(hole binary64 (+ 1 (* 1/2 (pow x 2)))))
#s(approx (sqrt (+ (* x x) 1)) (fma.f64 (*.f64 #s(literal 1/2 binary64) x) x #s(literal 1 binary64)))
#s(approx (sqrt (+ (* x x) 1)) #s(hole binary64 (+ 1 (* (pow x 2) (+ 1/2 (* -1/8 (pow x 2)))))))
#s(approx (sqrt (+ (* x x) 1)) (fma.f64 (*.f64 (fma.f64 #s(literal -1/8 binary64) (*.f64 x x) #s(literal 1/2 binary64)) x) x #s(literal 1 binary64)))
#s(approx (sqrt (+ (* x x) 1)) #s(hole binary64 (+ 1 (* (pow x 2) (+ 1/2 (* (pow x 2) (- (* 1/16 (pow x 2)) 1/8)))))))
#s(approx (sqrt (+ (* x x) 1)) (fma.f64 (fma.f64 (fma.f64 #s(literal 1/16 binary64) (*.f64 x x) #s(literal -1/8 binary64)) (*.f64 x x) #s(literal 1/2 binary64)) (*.f64 x x) #s(literal 1 binary64)))
#s(approx (log (+ x (sqrt (+ (* x x) 1)))) #s(hole binary64 (+ (log 2) (* -1 (log (/ 1 x))))))
#s(approx (log (+ x (sqrt (+ (* x x) 1)))) (+.f64 (log.f64 x) (log.f64 #s(literal 2 binary64))))
#s(approx (log (+ x (sqrt (+ (* x x) 1)))) #s(hole binary64 (+ (log 2) (+ (* -1 (log (/ 1 x))) (* 1/4 (/ 1 (pow x 2)))))))
#s(approx (log (+ x (sqrt (+ (* x x) 1)))) (-.f64 (+.f64 (log.f64 x) (log.f64 #s(literal 2 binary64))) (/.f64 #s(literal -1/4 binary64) (*.f64 x x))))
#s(approx (log (+ x (sqrt (+ (* x x) 1)))) #s(hole binary64 (- (+ (log 2) (+ (* -1 (log (/ 1 x))) (* 1/4 (/ 1 (pow x 2))))) (/ 3/32 (pow x 4)))))
#s(approx (log (+ x (sqrt (+ (* x x) 1)))) (-.f64 (-.f64 (+.f64 (log.f64 x) (log.f64 #s(literal 2 binary64))) (/.f64 #s(literal -1/4 binary64) (*.f64 x x))) (/.f64 #s(literal 3/32 binary64) (pow.f64 x #s(literal 4 binary64)))))
#s(approx (log (+ x (sqrt (+ (* x x) 1)))) #s(hole binary64 (- (+ (log 2) (+ (* -1 (log (/ 1 x))) (+ (* 1/4 (/ 1 (pow x 2))) (* 5/96 (/ 1 (pow x 6)))))) (/ 3/32 (pow x 4)))))
#s(approx (log (+ x (sqrt (+ (* x x) 1)))) (-.f64 (-.f64 (-.f64 (+.f64 (log.f64 x) (log.f64 #s(literal 2 binary64))) (/.f64 #s(literal -1/4 binary64) (*.f64 x x))) (/.f64 #s(literal -5/96 binary64) (pow.f64 x #s(literal 6 binary64)))) (/.f64 #s(literal 3/32 binary64) (pow.f64 x #s(literal 4 binary64)))))
#s(approx (asinh x) #s(hole binary64 (+ (log 2) (* -1 (log (/ 1 x))))))
#s(approx (asinh x) (+.f64 (log.f64 x) (log.f64 #s(literal 2 binary64))))
#s(approx (asinh x) #s(hole binary64 (+ (log 2) (+ (* -1 (log (/ 1 x))) (* 1/4 (/ 1 (pow x 2)))))))
#s(approx (asinh x) (-.f64 (+.f64 (log.f64 x) (log.f64 #s(literal 2 binary64))) (/.f64 #s(literal -1/4 binary64) (*.f64 x x))))
#s(approx (asinh x) #s(hole binary64 (- (+ (log 2) (+ (* -1 (log (/ 1 x))) (* 1/4 (/ 1 (pow x 2))))) (/ 3/32 (pow x 4)))))
#s(approx (asinh x) (-.f64 (-.f64 (+.f64 (log.f64 x) (log.f64 #s(literal 2 binary64))) (/.f64 #s(literal -1/4 binary64) (*.f64 x x))) (/.f64 #s(literal 3/32 binary64) (pow.f64 x #s(literal 4 binary64)))))
#s(approx (asinh x) #s(hole binary64 (- (+ (log 2) (+ (* -1 (log (/ 1 x))) (+ (* 1/4 (/ 1 (pow x 2))) (* 5/96 (/ 1 (pow x 6)))))) (/ 3/32 (pow x 4)))))
#s(approx (asinh x) (-.f64 (-.f64 (-.f64 (+.f64 (log.f64 x) (log.f64 #s(literal 2 binary64))) (/.f64 #s(literal -1/4 binary64) (*.f64 x x))) (/.f64 #s(literal -5/96 binary64) (pow.f64 x #s(literal 6 binary64)))) (/.f64 #s(literal 3/32 binary64) (pow.f64 x #s(literal 4 binary64)))))
#s(approx (+ x (sqrt (+ (* x x) 1))) #s(hole binary64 (* 2 x)))
#s(approx (+ x (sqrt (+ (* x x) 1))) (*.f64 #s(literal 2 binary64) x))
#s(approx (+ x (sqrt (+ (* x x) 1))) #s(hole binary64 (* x (+ 2 (* 1/2 (/ 1 (pow x 2)))))))
#s(approx (+ x (sqrt (+ (* x x) 1))) (*.f64 (-.f64 (/.f64 #s(literal 1/2 binary64) (*.f64 x x)) #s(literal -2 binary64)) x))
#s(approx (+ x (sqrt (+ (* x x) 1))) #s(hole binary64 (* x (- (+ 2 (* 1/2 (/ 1 (pow x 2)))) (/ 1/8 (pow x 4))))))
#s(approx (+ x (sqrt (+ (* x x) 1))) (*.f64 (-.f64 (-.f64 (/.f64 #s(literal 1/2 binary64) (*.f64 x x)) #s(literal -2 binary64)) (/.f64 #s(literal 1/8 binary64) (pow.f64 x #s(literal 4 binary64)))) x))
#s(approx (+ x (sqrt (+ (* x x) 1))) #s(hole binary64 (* x (- (+ 2 (+ (* 1/2 (/ 1 (pow x 2))) (* 1/16 (/ 1 (pow x 6))))) (/ 1/8 (pow x 4))))))
#s(approx (+ x (sqrt (+ (* x x) 1))) (*.f64 (-.f64 (-.f64 (-.f64 (/.f64 #s(literal 1/16 binary64) (pow.f64 x #s(literal 6 binary64))) #s(literal -2 binary64)) (/.f64 (/.f64 #s(literal -1/2 binary64) x) x)) (/.f64 #s(literal 1/8 binary64) (pow.f64 x #s(literal 4 binary64)))) x))
#s(approx (sqrt (+ (* x x) 1)) #s(hole binary64 x))
#s(approx (sqrt (+ (* x x) 1)) x)
#s(approx (sqrt (+ (* x x) 1)) #s(hole binary64 (* x (+ 1 (* 1/2 (/ 1 (pow x 2)))))))
#s(approx (sqrt (+ (* x x) 1)) (fma.f64 (/.f64 #s(literal 1/2 binary64) (*.f64 x x)) x x))
#s(approx (sqrt (+ (* x x) 1)) #s(hole binary64 (* x (- (+ 1 (* 1/2 (/ 1 (pow x 2)))) (/ 1/8 (pow x 4))))))
#s(approx (sqrt (+ (* x x) 1)) (fma.f64 (-.f64 (/.f64 #s(literal 1/2 binary64) (*.f64 x x)) (/.f64 #s(literal 1/8 binary64) (pow.f64 x #s(literal 4 binary64)))) x x))
#s(approx (sqrt (+ (* x x) 1)) #s(hole binary64 (* x (- (+ 1 (+ (* 1/2 (/ 1 (pow x 2))) (* 1/16 (/ 1 (pow x 6))))) (/ 1/8 (pow x 4))))))
#s(approx (sqrt (+ (* x x) 1)) (fma.f64 (-.f64 (-.f64 (/.f64 #s(literal 1/16 binary64) (pow.f64 x #s(literal 6 binary64))) (/.f64 (/.f64 #s(literal -1/2 binary64) x) x)) (/.f64 #s(literal 1/8 binary64) (pow.f64 x #s(literal 4 binary64)))) x x))
#s(approx (log (+ x (sqrt (+ (* x x) 1)))) #s(hole binary64 (+ (log 1/2) (log (/ -1 x)))))
#s(approx (log (+ x (sqrt (+ (* x x) 1)))) (+.f64 (log.f64 (/.f64 #s(literal -1 binary64) x)) (log.f64 #s(literal 1/2 binary64))))
#s(approx (log (+ x (sqrt (+ (* x x) 1)))) #s(hole binary64 (- (+ (log 1/2) (log (/ -1 x))) (* 1/4 (/ 1 (pow x 2))))))
#s(approx (log (+ x (sqrt (+ (* x x) 1)))) (-.f64 (+.f64 (log.f64 (/.f64 #s(literal -1 binary64) x)) (log.f64 #s(literal 1/2 binary64))) (/.f64 #s(literal 1/4 binary64) (*.f64 x x))))
#s(approx (log (+ x (sqrt (+ (* x x) 1)))) #s(hole binary64 (- (+ (log 1/2) (+ (log (/ -1 x)) (/ 3/32 (pow x 4)))) (* 1/4 (/ 1 (pow x 2))))))
#s(approx (log (+ x (sqrt (+ (* x x) 1)))) (-.f64 (+.f64 (log.f64 (/.f64 #s(literal -1 binary64) x)) (/.f64 #s(literal 3/32 binary64) (pow.f64 x #s(literal 4 binary64)))) (-.f64 (/.f64 #s(literal 1/4 binary64) (*.f64 x x)) (log.f64 #s(literal 1/2 binary64)))))
#s(approx (log (+ x (sqrt (+ (* x x) 1)))) #s(hole binary64 (- (+ (log 1/2) (+ (log (/ -1 x)) (/ 3/32 (pow x 4)))) (+ (* 1/4 (/ 1 (pow x 2))) (* 5/96 (/ 1 (pow x 6)))))))
#s(approx (log (+ x (sqrt (+ (* x x) 1)))) (-.f64 (+.f64 (+.f64 (log.f64 #s(literal 1/2 binary64)) (/.f64 #s(literal 3/32 binary64) (pow.f64 x #s(literal 4 binary64)))) (log.f64 (/.f64 #s(literal -1 binary64) x))) (-.f64 (/.f64 #s(literal 5/96 binary64) (pow.f64 x #s(literal 6 binary64))) (/.f64 #s(literal -1/4 binary64) (*.f64 x x)))))
#s(approx (asinh x) #s(hole binary64 (+ (log 1/2) (log (/ -1 x)))))
#s(approx (asinh x) (+.f64 (log.f64 (/.f64 #s(literal -1 binary64) x)) (log.f64 #s(literal 1/2 binary64))))
#s(approx (asinh x) #s(hole binary64 (- (+ (log 1/2) (log (/ -1 x))) (* 1/4 (/ 1 (pow x 2))))))
#s(approx (asinh x) (-.f64 (+.f64 (log.f64 (/.f64 #s(literal -1 binary64) x)) (log.f64 #s(literal 1/2 binary64))) (/.f64 #s(literal 1/4 binary64) (*.f64 x x))))
#s(approx (asinh x) #s(hole binary64 (- (+ (log 1/2) (+ (log (/ -1 x)) (/ 3/32 (pow x 4)))) (* 1/4 (/ 1 (pow x 2))))))
#s(approx (asinh x) (-.f64 (+.f64 (log.f64 (/.f64 #s(literal -1 binary64) x)) (/.f64 #s(literal 3/32 binary64) (pow.f64 x #s(literal 4 binary64)))) (-.f64 (/.f64 #s(literal 1/4 binary64) (*.f64 x x)) (log.f64 #s(literal 1/2 binary64)))))
#s(approx (asinh x) #s(hole binary64 (- (+ (log 1/2) (+ (log (/ -1 x)) (/ 3/32 (pow x 4)))) (+ (* 1/4 (/ 1 (pow x 2))) (* 5/96 (/ 1 (pow x 6)))))))
#s(approx (asinh x) (-.f64 (+.f64 (+.f64 (log.f64 #s(literal 1/2 binary64)) (/.f64 #s(literal 3/32 binary64) (pow.f64 x #s(literal 4 binary64)))) (log.f64 (/.f64 #s(literal -1 binary64) x))) (-.f64 (/.f64 #s(literal 5/96 binary64) (pow.f64 x #s(literal 6 binary64))) (/.f64 #s(literal -1/4 binary64) (*.f64 x x)))))
#s(approx (+ x (sqrt (+ (* x x) 1))) #s(hole binary64 (/ -1/2 x)))
#s(approx (+ x (sqrt (+ (* x x) 1))) (/.f64 #s(literal -1/2 binary64) x))
#s(approx (+ x (sqrt (+ (* x x) 1))) #s(hole binary64 (* -1 (/ (- 1/2 (* 1/8 (/ 1 (pow x 2)))) x))))
#s(approx (+ x (sqrt (+ (* x x) 1))) (/.f64 (-.f64 (/.f64 #s(literal 1/8 binary64) (*.f64 x x)) #s(literal 1/2 binary64)) x))
#s(approx (+ x (sqrt (+ (* x x) 1))) #s(hole binary64 (* -1 (/ (- (+ 1/2 (/ 1/16 (pow x 4))) (* 1/8 (/ 1 (pow x 2)))) x))))
#s(approx (+ x (sqrt (+ (* x x) 1))) (/.f64 (+.f64 (/.f64 #s(literal -1/16 binary64) (pow.f64 x #s(literal 4 binary64))) (-.f64 (/.f64 #s(literal 1/8 binary64) (*.f64 x x)) #s(literal 1/2 binary64))) x))
#s(approx (+ x (sqrt (+ (* x x) 1))) #s(hole binary64 (* -1 (/ (- (+ 1/2 (/ 1/16 (pow x 4))) (+ (* 1/8 (/ 1 (pow x 2))) (* 5/128 (/ 1 (pow x 6))))) x))))
#s(approx (+ x (sqrt (+ (* x x) 1))) (/.f64 (+.f64 (+.f64 (/.f64 #s(literal -1/16 binary64) (pow.f64 x #s(literal 4 binary64))) (-.f64 (/.f64 #s(literal 1/8 binary64) (*.f64 x x)) #s(literal 1/2 binary64))) (/.f64 #s(literal 5/128 binary64) (pow.f64 x #s(literal 6 binary64)))) x))
#s(approx (sqrt (+ (* x x) 1)) #s(hole binary64 (* -1 x)))
#s(approx (sqrt (+ (* x x) 1)) (neg.f64 x))
#s(approx (sqrt (+ (* x x) 1)) #s(hole binary64 (* -1 (* x (+ 1 (* 1/2 (/ 1 (pow x 2))))))))
#s(approx (sqrt (+ (* x x) 1)) (*.f64 (+.f64 (/.f64 (/.f64 #s(literal -1/2 binary64) x) x) #s(literal -1 binary64)) x))
#s(approx (sqrt (+ (* x x) 1)) #s(hole binary64 (* -1 (* x (- (+ 1 (* 1/2 (/ 1 (pow x 2)))) (/ 1/8 (pow x 4)))))))
#s(approx (sqrt (+ (* x x) 1)) (*.f64 (+.f64 (+.f64 (/.f64 (/.f64 #s(literal -1/2 binary64) x) x) #s(literal -1 binary64)) (/.f64 #s(literal 1/8 binary64) (pow.f64 x #s(literal 4 binary64)))) x))
#s(approx (sqrt (+ (* x x) 1)) #s(hole binary64 (* -1 (* x (- (+ 1 (+ (* 1/2 (/ 1 (pow x 2))) (* 1/16 (/ 1 (pow x 6))))) (/ 1/8 (pow x 4)))))))
#s(approx (sqrt (+ (* x x) 1)) (*.f64 (+.f64 (-.f64 (/.f64 #s(literal -1/16 binary64) (pow.f64 x #s(literal 6 binary64))) (/.f64 #s(literal -1/8 binary64) (pow.f64 x #s(literal 4 binary64)))) (+.f64 (/.f64 (/.f64 #s(literal -1/2 binary64) x) x) #s(literal -1 binary64))) x))

rewrite49.0ms (1.2%)

Memory
-9.2MiB live, 37.5MiB allocated; 2ms collecting garbage
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01670
02148
17248
051848
Stop Event
iter limit
iter limit
node limit
iter limit
Counts
8 → 26
Calls
Call 1
Inputs
#s(approx (log (+ x (sqrt (+ (* x x) 1)))) x)
(asinh.f64 x)
(log.f64 #s(approx (+ x (sqrt (+ (* x x) 1))) (/.f64 #s(literal -1/2 binary64) x)))
#s(approx (+ x (sqrt (+ (* x x) 1))) (/.f64 #s(literal -1/2 binary64) x))
(/.f64 #s(literal -1/2 binary64) x)
(log.f64 (+.f64 x #s(approx (sqrt (+ (* x x) 1)) x)))
(+.f64 x #s(approx (sqrt (+ (* x x) 1)) x))
#s(approx (sqrt (+ (* x x) 1)) x)
Outputs
#s(approx (log (+ x (sqrt (+ (* x x) 1)))) x)
(asinh.f64 x)
(-.f64 (log.f64 (-.f64 (*.f64 x x) (fma.f64 x x #s(literal 1 binary64)))) (log.f64 (-.f64 x (cosh.f64 (asinh.f64 x)))))
(-.f64 (log.f64 (+.f64 (pow.f64 (cosh.f64 (asinh.f64 x)) #s(literal 3 binary64)) (pow.f64 x #s(literal 3 binary64)))) (log.f64 (fma.f64 (cosh.f64 (asinh.f64 x)) (-.f64 (cosh.f64 (asinh.f64 x)) x) (*.f64 x x))))
(log.f64 (+.f64 (cosh.f64 (asinh.f64 x)) x))
(log.f64 #s(approx (+ x (sqrt (+ (* x x) 1))) (/.f64 #s(literal -1/2 binary64) x)))
#s(approx (+ x (sqrt (+ (* x x) 1))) (/.f64 #s(literal -1/2 binary64) x))
(/.f64 #s(literal 1/2 binary64) (neg.f64 x))
(/.f64 #s(literal -1/2 binary64) (neg.f64 (neg.f64 x)))
(/.f64 #s(literal -1/2 binary64) x)
(neg.f64 (/.f64 #s(literal 1/2 binary64) x))
(neg.f64 (/.f64 #s(literal -1/2 binary64) (neg.f64 x)))
(-.f64 (log.f64 (*.f64 (+.f64 #s(approx (sqrt (+ (* x x) 1)) x) x) (-.f64 x #s(approx (sqrt (+ (* x x) 1)) x)))) (log.f64 (-.f64 x #s(approx (sqrt (+ (* x x) 1)) x))))
(-.f64 (log.f64 (+.f64 (pow.f64 #s(approx (sqrt (+ (* x x) 1)) x) #s(literal 3 binary64)) (pow.f64 x #s(literal 3 binary64)))) (log.f64 (fma.f64 #s(approx (sqrt (+ (* x x) 1)) x) (-.f64 #s(approx (sqrt (+ (* x x) 1)) x) x) (*.f64 x x))))
(log.f64 (+.f64 #s(approx (sqrt (+ (* x x) 1)) x) x))
(/.f64 (-.f64 (pow.f64 #s(approx (sqrt (+ (* x x) 1)) x) #s(literal 2 binary64)) (*.f64 x x)) (-.f64 #s(approx (sqrt (+ (* x x) 1)) x) x))
(/.f64 (neg.f64 (*.f64 (+.f64 #s(approx (sqrt (+ (* x x) 1)) x) x) (-.f64 x #s(approx (sqrt (+ (* x x) 1)) x)))) (neg.f64 (-.f64 x #s(approx (sqrt (+ (* x x) 1)) x))))
(/.f64 (neg.f64 (+.f64 (pow.f64 #s(approx (sqrt (+ (* x x) 1)) x) #s(literal 3 binary64)) (pow.f64 x #s(literal 3 binary64)))) (neg.f64 (fma.f64 #s(approx (sqrt (+ (* x x) 1)) x) (-.f64 #s(approx (sqrt (+ (* x x) 1)) x) x) (*.f64 x x))))
(/.f64 (*.f64 (+.f64 #s(approx (sqrt (+ (* x x) 1)) x) x) (-.f64 x #s(approx (sqrt (+ (* x x) 1)) x))) (-.f64 x #s(approx (sqrt (+ (* x x) 1)) x)))
(/.f64 (+.f64 (pow.f64 #s(approx (sqrt (+ (* x x) 1)) x) #s(literal 3 binary64)) (pow.f64 x #s(literal 3 binary64))) (fma.f64 #s(approx (sqrt (+ (* x x) 1)) x) #s(approx (sqrt (+ (* x x) 1)) x) (-.f64 (*.f64 x x) (*.f64 #s(approx (sqrt (+ (* x x) 1)) x) x))))
(/.f64 (+.f64 (pow.f64 #s(approx (sqrt (+ (* x x) 1)) x) #s(literal 3 binary64)) (pow.f64 x #s(literal 3 binary64))) (fma.f64 #s(approx (sqrt (+ (* x x) 1)) x) (-.f64 #s(approx (sqrt (+ (* x x) 1)) x) x) (*.f64 x x)))
(-.f64 (/.f64 (*.f64 x x) (-.f64 x #s(approx (sqrt (+ (* x x) 1)) x))) (/.f64 (pow.f64 #s(approx (sqrt (+ (* x x) 1)) x) #s(literal 2 binary64)) (-.f64 x #s(approx (sqrt (+ (* x x) 1)) x))))
(+.f64 (/.f64 (pow.f64 x #s(literal 3 binary64)) (fma.f64 #s(approx (sqrt (+ (* x x) 1)) x) (-.f64 #s(approx (sqrt (+ (* x x) 1)) x) x) (*.f64 x x))) (/.f64 (pow.f64 #s(approx (sqrt (+ (* x x) 1)) x) #s(literal 3 binary64)) (fma.f64 #s(approx (sqrt (+ (* x x) 1)) x) (-.f64 #s(approx (sqrt (+ (* x x) 1)) x) x) (*.f64 x x))))
(+.f64 #s(approx (sqrt (+ (* x x) 1)) x) x)
(+.f64 x #s(approx (sqrt (+ (* x x) 1)) x))
#s(approx (sqrt (+ (* x x) 1)) x)

eval6.0ms (0.2%)

Memory
6.9MiB live, 6.9MiB allocated; 0ms collecting garbage
Compiler

Compiled 1 523 to 281 computations (81.5% saved)

prune3.0ms (0.1%)

Memory
8.3MiB live, 8.3MiB allocated; 0ms collecting garbage
Pruning

4 alts after pruning (0 fresh and 4 done)

PrunedKeptTotal
New72072
Fresh000
Picked044
Done000
Total72476
Accuracy
100.0%
Counts
76 → 4
Alt Table
Click to see full alt table
StatusAccuracyProgram
25.0%
(log.f64 (+.f64 x #s(approx (sqrt (+ (* x x) 1)) x)))
23.6%
(log.f64 #s(approx (+ x (sqrt (+ (* x x) 1))) (/.f64 #s(literal -1/2 binary64) x)))
99.9%
(asinh.f64 x)
54.9%
#s(approx (log (+ x (sqrt (+ (* x x) 1)))) x)
Compiler

Compiled 83 to 50 computations (39.8% saved)

regimes6.0ms (0.1%)

Memory
9.5MiB live, 9.5MiB allocated; 0ms collecting garbage
Counts
5 → 1
Calls
Call 1
Inputs
#s(approx (log (+ x (sqrt (+ (* x x) 1)))) x)
(asinh.f64 x)
(log.f64 (+.f64 x #s(approx (sqrt (+ (* x x) 1)) x)))
(log.f64 #s(approx (+ x (sqrt (+ (* x x) 1))) (/.f64 #s(literal -1/2 binary64) x)))
(log.f64 (+.f64 x (sqrt.f64 (+.f64 (*.f64 x x) #s(literal 1 binary64)))))
Outputs
(asinh.f64 x)
Calls

3 calls:

2.0ms
x
2.0ms
(+.f64 x (sqrt.f64 (+.f64 (*.f64 x x) #s(literal 1 binary64))))
2.0ms
(log.f64 (+.f64 x (sqrt.f64 (+.f64 (*.f64 x x) #s(literal 1 binary64)))))
Results
AccuracySegmentsBranch
99.9%1(+.f64 x (sqrt.f64 (+.f64 (*.f64 x x) #s(literal 1 binary64))))
99.9%1(log.f64 (+.f64 x (sqrt.f64 (+.f64 (*.f64 x x) #s(literal 1 binary64)))))
99.9%1x
Compiler

Compiled 18 to 14 computations (22.2% saved)

regimes3.0ms (0.1%)

Memory
4.5MiB live, 4.5MiB allocated; 0ms collecting garbage
Accuracy

Total -0.0b remaining (-0%)

Threshold costs -0b (-0%)

Counts
1 → 1
Calls
Call 1
Inputs
#s(approx (log (+ x (sqrt (+ (* x x) 1)))) x)
Outputs
#s(approx (log (+ x (sqrt (+ (* x x) 1)))) x)
Calls

3 calls:

1.0ms
x
1.0ms
(log.f64 (+.f64 x (sqrt.f64 (+.f64 (*.f64 x x) #s(literal 1 binary64)))))
1.0ms
(+.f64 x (sqrt.f64 (+.f64 (*.f64 x x) #s(literal 1 binary64))))
Results
AccuracySegmentsBranch
54.9%1(+.f64 x (sqrt.f64 (+.f64 (*.f64 x x) #s(literal 1 binary64))))
54.9%1(log.f64 (+.f64 x (sqrt.f64 (+.f64 (*.f64 x x) #s(literal 1 binary64)))))
54.9%1x
Compiler

Compiled 18 to 14 computations (22.2% saved)

simplify78.0ms (1.9%)

Memory
-1.4MiB live, 45.0MiB allocated; 3ms collecting garbage
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0913
11713
23913
38013
413013
533413
6265913
7673213
Stop Event
node limit
Calls
Call 1
Inputs
(asinh.f64 x)
#s(approx (log (+ x (sqrt (+ (* x x) 1)))) x)
Outputs
(asinh.f64 x)
#s(approx (log (+ x (sqrt (+ (* x x) 1)))) x)

derivations37.0ms (0.9%)

Memory
-41.4MiB live, 11.0MiB allocated; 4ms collecting garbage
Stop Event
done
Compiler

Compiled 13 to 9 computations (30.8% saved)

preprocess20.0ms (0.5%)

Memory
41.4MiB live, 41.4MiB allocated; 0ms collecting garbage
Compiler

Compiled 92 to 60 computations (34.8% saved)

end0.0ms (0%)

Memory
0.0MiB live, 0.0MiB allocated; 0ms collecting garbage

Profiling

Loading profile data...