Rust f32::asinh

Time bar (total: 4.2s)

start0.0ms (0%)

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

analyze0.0ms (0%)

Memory
0.5MiB live, 0.6MiB allocated; 0ms collecting garbage
Algorithm
search
Search
ProbabilityValidUnknownPreconditionInfiniteDomainCan'tIter
0%0%99.6%0.4%0%0%0%0
100%99.6%0%0.4%0%0%0%1
Compiler

Compiled 4 to 4 computations (0% saved)

sample786.0ms (18.7%)

Memory
-37.6MiB live, 727.1MiB allocated; 187ms collecting garbage
Samples
572.0ms8 256×0valid
Precisions
Click to see histograms. Total time spent on operations: 362.0ms
ival-asinh: 352.0ms (97.2% of total)
ival-true: 6.0ms (1.7% of total)
ival-assert: 3.0ms (0.8% of total)
adjust: 2.0ms (0.6% of total)
Bogosity

explain227.0ms (5.4%)

Memory
33.3MiB live, 275.7MiB allocated; 87ms collecting garbage
FPErrors
Click to see full error table
Ground TruthOverpredictionsExampleUnderpredictionsExampleSubexpression
1101(-0.008958262391388416)0-(log.f32 (+.f32 (fabs.f32 x) (sqrt.f32 (+.f32 (*.f32 x x) #s(literal 1 binary32)))))
660-0-(sqrt.f32 (+.f32 (*.f32 x x) #s(literal 1 binary32)))
00-0-#s(literal 1 binary32)
00-0-(copysign.f32 (log.f32 (+.f32 (fabs.f32 x) (sqrt.f32 (+.f32 (*.f32 x x) #s(literal 1 binary32))))) x)
00-0-(*.f32 x x)
00-0-(+.f32 (*.f32 x x) #s(literal 1 binary32))
00-0-(+.f32 (fabs.f32 x) (sqrt.f32 (+.f32 (*.f32 x x) #s(literal 1 binary32))))
00-0-x
00-0-(fabs.f32 x)
Explanations
Click to see full explanations table
OperatorSubexpressionExplanationCount
log.f32(log.f32 (+.f32 (fabs.f32 x) (sqrt.f32 (+.f32 (*.f32 x x) #s(literal 1 binary32)))))sensitivity1111
sqrt.f32(sqrt.f32 (+.f32 (*.f32 x x) #s(literal 1 binary32)))oflow-rescue660
(+.f32 (*.f32 x x) #s(literal 1 binary32))overflow66
(*.f32 x x)overflow66
Confusion
Predicted +Predicted -
+1770
-079
Precision
1.0
Recall
1.0
Confusion?
Predicted +Predicted MaybePredicted -
+17700
-0178
Precision?
0.9943820224719101
Recall?
1.0
Freqs
test
numberfreq
079
1177
Total Confusion?
Predicted +Predicted MaybePredicted -
+100
-000
Precision?
1.0
Recall?
1.0
Samples
51.0ms162×1valid
35.0ms350×0valid
Compiler

Compiled 114 to 31 computations (72.8% saved)

Precisions
Click to see histograms. Total time spent on operations: 70.0ms
ival-mult: 23.0ms (32.7% of total)
ival-hypot: 13.0ms (18.5% of total)
ival-log: 11.0ms (15.6% of total)
ival-add: 10.0ms (14.2% of total)
adjust: 5.0ms (7.1% of total)
ival-copysign: 5.0ms (7.1% of total)
ival-fabs: 3.0ms (4.3% of total)
ival-assert: 0.0ms (0% of total)
ival-true: 0.0ms (0% of total)
exact: 0.0ms (0% of total)

preprocess233.0ms (5.6%)

Memory
-19.6MiB live, 211.2MiB allocated; 58ms collecting garbage
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
047
0912
01612
12412
24512
38512
414412
535112
6240112
7591412
0815311
Stop Event
iter limit
node limit
iter limit
saturated
Calls
Call 1
Inputs
(copysign.f32 (log.f32 (+.f32 (fabs.f32 x) (sqrt.f32 (+.f32 (*.f32 x x) #s(literal 1 binary32))))) x)
Outputs
(copysign.f32 (log.f32 (+.f32 (fabs.f32 x) (sqrt.f32 (+.f32 (*.f32 x x) #s(literal 1 binary32))))) x)
(copysign.f32 (log.f32 (+.f32 (sqrt.f32 (fma.f32 x x #s(literal 1 binary32))) (fabs.f32 x))) x)
Compiler

Compiled 12 to 9 computations (25% saved)

eval0.0ms (0%)

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

Compiled 0 to 1 computations (-∞% saved)

prune0.0ms (0%)

Memory
2.0MiB live, 2.0MiB allocated; 0ms collecting garbage
Alt Table
Click to see full alt table
StatusAccuracyProgram
41.1%
(copysign.f32 (log.f32 (+.f32 (fabs.f32 x) (sqrt.f32 (+.f32 (*.f32 x x) #s(literal 1 binary32))))) x)
Compiler

Compiled 12 to 9 computations (25% saved)

simplify259.0ms (6.2%)

Memory
24.9MiB live, 271.7MiB allocated; 30ms collecting garbage
Localize:

Found 4 expressions of interest:

NewMetricScoreProgram
cost-diff0
(+.f32 (fabs.f32 x) (sqrt.f32 (+.f32 (*.f32 x x) #s(literal 1 binary32))))
cost-diff0
(log.f32 (+.f32 (fabs.f32 x) (sqrt.f32 (+.f32 (*.f32 x x) #s(literal 1 binary32)))))
cost-diff0
(copysign.f32 (log.f32 (+.f32 (fabs.f32 x) (sqrt.f32 (+.f32 (*.f32 x x) #s(literal 1 binary32))))) x)
cost-diff1
(+.f32 (*.f32 x x) #s(literal 1 binary32))
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0949
01649
12449
24549
38549
414449
535149
6240149
7591449
0815344
Stop Event
iter limit
node limit
iter limit
Calls
Call 1
Inputs
(copysign.f32 (log.f32 (+.f32 (fabs.f32 x) (sqrt.f32 (+.f32 (*.f32 x x) #s(literal 1 binary32))))) x)
(log.f32 (+.f32 (fabs.f32 x) (sqrt.f32 (+.f32 (*.f32 x x) #s(literal 1 binary32)))))
(+.f32 (fabs.f32 x) (sqrt.f32 (+.f32 (*.f32 x x) #s(literal 1 binary32))))
(fabs.f32 x)
x
(sqrt.f32 (+.f32 (*.f32 x x) #s(literal 1 binary32)))
(+.f32 (*.f32 x x) #s(literal 1 binary32))
(*.f32 x x)
#s(literal 1 binary32)
Outputs
(copysign.f32 (log.f32 (+.f32 (fabs.f32 x) (sqrt.f32 (+.f32 (*.f32 x x) #s(literal 1 binary32))))) x)
(copysign.f32 (log.f32 (+.f32 (sqrt.f32 (fma.f32 x x #s(literal 1 binary32))) (fabs.f32 x))) x)
(log.f32 (+.f32 (fabs.f32 x) (sqrt.f32 (+.f32 (*.f32 x x) #s(literal 1 binary32)))))
(log.f32 (+.f32 (sqrt.f32 (fma.f32 x x #s(literal 1 binary32))) (fabs.f32 x)))
(+.f32 (fabs.f32 x) (sqrt.f32 (+.f32 (*.f32 x x) #s(literal 1 binary32))))
(+.f32 (sqrt.f32 (fma.f32 x x #s(literal 1 binary32))) (fabs.f32 x))
(fabs.f32 x)
x
(sqrt.f32 (+.f32 (*.f32 x x) #s(literal 1 binary32)))
(sqrt.f32 (fma.f32 x x #s(literal 1 binary32)))
(+.f32 (*.f32 x x) #s(literal 1 binary32))
(fma.f32 x x #s(literal 1 binary32))
(*.f32 x x)
#s(literal 1 binary32)

localize45.0ms (1.1%)

Memory
-28.6MiB live, 105.3MiB allocated; 16ms collecting garbage
Localize:

Found 4 expressions of interest:

NewMetricScoreProgram
accuracy0.00390625
(+.f32 (*.f32 x x) #s(literal 1 binary32))
accuracy0.0234375
(+.f32 (fabs.f32 x) (sqrt.f32 (+.f32 (*.f32 x x) #s(literal 1 binary32))))
accuracy7.177156074740872
(sqrt.f32 (+.f32 (*.f32 x x) #s(literal 1 binary32)))
accuracy11.097660503050301
(log.f32 (+.f32 (fabs.f32 x) (sqrt.f32 (+.f32 (*.f32 x x) #s(literal 1 binary32)))))
Samples
17.0ms81×1valid
15.0ms175×0valid
Compiler

Compiled 51 to 11 computations (78.4% saved)

Precisions
Click to see histograms. Total time spent on operations: 25.0ms
ival-hypot: 8.0ms (32.5% of total)
ival-log: 5.0ms (20.3% of total)
ival-copysign: 3.0ms (12.2% of total)
ival-add: 3.0ms (12.2% of total)
adjust: 2.0ms (8.1% of total)
ival-mult: 2.0ms (8.1% of total)
ival-fabs: 2.0ms (8.1% 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
11.5MiB live, 11.4MiB allocated; 0ms collecting garbage
Counts
5 → 38
Calls
Call 1
Inputs
(+.f32 (*.f32 x x) #s(literal 1 binary32))
(copysign.f32 (log.f32 (+.f32 (fabs.f32 x) (sqrt.f32 (+.f32 (*.f32 x x) #s(literal 1 binary32))))) x)
(log.f32 (+.f32 (fabs.f32 x) (sqrt.f32 (+.f32 (*.f32 x x) #s(literal 1 binary32)))))
(+.f32 (fabs.f32 x) (sqrt.f32 (+.f32 (*.f32 x x) #s(literal 1 binary32))))
(sqrt.f32 (+.f32 (*.f32 x x) #s(literal 1 binary32)))
Outputs
1
(+ 1 (pow x 2))
(copysign (log (+ (fabs x) (sqrt (+ 1 (pow x 2))))) x)
(log (+ 1 (fabs x)))
(+ (log (+ 1 (fabs x))) (* 1/2 (/ (pow x 2) (+ 1 (fabs x)))))
(+ (log (+ 1 (fabs x))) (* (pow x 2) (+ (* -1/24 (* (pow x 2) (+ (* 3 (/ 1 (+ 1 (fabs x)))) (* 3 (/ 1 (pow (+ 1 (fabs x)) 2)))))) (* 1/2 (/ 1 (+ 1 (fabs x)))))))
(+ (log (+ 1 (fabs x))) (* (pow x 2) (+ (* (pow x 2) (+ (* -1/24 (+ (* 3 (/ 1 (+ 1 (fabs x)))) (* 3 (/ 1 (pow (+ 1 (fabs x)) 2))))) (* 1/720 (* (pow x 2) (+ (* 45 (/ 1 (+ 1 (fabs x)))) (+ (* 45 (/ 1 (pow (+ 1 (fabs x)) 2))) (* 30 (/ 1 (pow (+ 1 (fabs x)) 3))))))))) (* 1/2 (/ 1 (+ 1 (fabs x)))))))
(+ 1 (fabs x))
(+ 1 (+ (fabs x) (* 1/2 (pow x 2))))
(+ 1 (+ (fabs x) (* (pow x 2) (+ 1/2 (* -1/8 (pow x 2))))))
(+ 1 (+ (fabs x) (* (pow x 2) (+ 1/2 (* (pow x 2) (- (* 1/16 (pow x 2)) 1/8))))))
(+ 1 (* 1/2 (pow x 2)))
(+ 1 (* (pow x 2) (+ 1/2 (* -1/8 (pow x 2)))))
(+ 1 (* (pow x 2) (+ 1/2 (* (pow x 2) (- (* 1/16 (pow x 2)) 1/8)))))
(pow x 2)
(* (pow x 2) (+ 1 (/ 1 (pow x 2))))
(* -1 (log (/ 1 x)))
(+ (* -1 (log (/ 1 x))) (/ (fabs x) x))
(+ (* -1 (log (/ 1 x))) (+ (* 1/2 (/ (+ 1 (* -1 (pow (fabs x) 2))) (pow x 2))) (/ (fabs x) x)))
(+ (* -1 (log (/ 1 x))) (+ (* 1/6 (/ (+ (* -3 (fabs x)) (* 2 (pow (fabs x) 3))) (pow x 3))) (+ (* 1/2 (/ (+ 1 (* -1 (pow (fabs x) 2))) (pow x 2))) (/ (fabs x) x))))
x
(* x (+ 1 (/ (fabs x) x)))
(* x (+ 1 (+ (/ 1/2 (pow x 2)) (/ (fabs x) x))))
(* x (- (+ 1 (+ (/ 1/2 (pow x 2)) (/ (fabs x) x))) (* 1/8 (/ 1 (pow x 4)))))
(* x (+ 1 (* 1/2 (/ 1 (pow x 2)))))
(* x (- (+ 1 (* 1/2 (/ 1 (pow x 2)))) (/ 1/8 (pow x 4))))
(* x (- (+ 1 (+ (* 1/2 (/ 1 (pow x 2))) (* 1/16 (/ 1 (pow x 6))))) (/ 1/8 (pow x 4))))
(* -1 (log (/ -1 x)))
(+ (* -1 (log (/ -1 x))) (* -1 (/ (fabs x) x)))
(+ (* -1 (log (/ -1 x))) (* -1 (/ (+ (fabs x) (* -1/2 (/ (+ 1 (* -1 (pow (fabs x) 2))) x))) x)))
(+ (* -1 (log (/ -1 x))) (* -1 (/ (+ (fabs x) (* -1 (/ (+ (* -1/6 (/ (+ (* -3 (fabs x)) (* 2 (pow (fabs x) 3))) x)) (* 1/2 (+ 1 (* -1 (pow (fabs x) 2))))) x))) x)))
(* -1 x)
(* -1 (* x (+ 1 (* -1 (/ (fabs x) x)))))
(* -1 (* x (+ 1 (* -1 (/ (- (fabs x) (* 1/2 (/ 1 x))) x)))))
(* -1 (* x (+ 1 (* -1 (/ (+ (fabs x) (* -1 (/ (- 1/2 (* 1/8 (/ 1 (pow x 2)))) x))) x)))))
(* -1 (* x (+ 1 (* 1/2 (/ 1 (pow x 2))))))
(* -1 (* x (- (+ 1 (* 1/2 (/ 1 (pow x 2)))) (/ 1/8 (pow x 4)))))
(* -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
@0
((+ (* x x) 1) (copysign (log (+ (fabs x) (sqrt (+ (* x x) 1)))) x) (log (+ (fabs x) (sqrt (+ (* x x) 1)))) (+ (fabs x) (sqrt (+ (* x x) 1))) (sqrt (+ (* x x) 1)))
1.0ms
x
@inf
((+ (* x x) 1) (copysign (log (+ (fabs x) (sqrt (+ (* x x) 1)))) x) (log (+ (fabs x) (sqrt (+ (* x x) 1)))) (+ (fabs x) (sqrt (+ (* x x) 1))) (sqrt (+ (* x x) 1)))
1.0ms
x
@-inf
((+ (* x x) 1) (copysign (log (+ (fabs x) (sqrt (+ (* x x) 1)))) x) (log (+ (fabs x) (sqrt (+ (* x x) 1)))) (+ (fabs x) (sqrt (+ (* x x) 1))) (sqrt (+ (* x x) 1)))

simplify208.0ms (5%)

Memory
-3.6MiB live, 250.2MiB allocated; 62ms collecting garbage
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0169584
1568546
22395525
08393485
Stop Event
iter limit
node limit
Counts
38 → 37
Calls
Call 1
Inputs
1
(+ 1 (pow x 2))
(copysign (log (+ (fabs x) (sqrt (+ 1 (pow x 2))))) x)
(log (+ 1 (fabs x)))
(+ (log (+ 1 (fabs x))) (* 1/2 (/ (pow x 2) (+ 1 (fabs x)))))
(+ (log (+ 1 (fabs x))) (* (pow x 2) (+ (* -1/24 (* (pow x 2) (+ (* 3 (/ 1 (+ 1 (fabs x)))) (* 3 (/ 1 (pow (+ 1 (fabs x)) 2)))))) (* 1/2 (/ 1 (+ 1 (fabs x)))))))
(+ (log (+ 1 (fabs x))) (* (pow x 2) (+ (* (pow x 2) (+ (* -1/24 (+ (* 3 (/ 1 (+ 1 (fabs x)))) (* 3 (/ 1 (pow (+ 1 (fabs x)) 2))))) (* 1/720 (* (pow x 2) (+ (* 45 (/ 1 (+ 1 (fabs x)))) (+ (* 45 (/ 1 (pow (+ 1 (fabs x)) 2))) (* 30 (/ 1 (pow (+ 1 (fabs x)) 3))))))))) (* 1/2 (/ 1 (+ 1 (fabs x)))))))
(+ 1 (fabs x))
(+ 1 (+ (fabs x) (* 1/2 (pow x 2))))
(+ 1 (+ (fabs x) (* (pow x 2) (+ 1/2 (* -1/8 (pow x 2))))))
(+ 1 (+ (fabs x) (* (pow x 2) (+ 1/2 (* (pow x 2) (- (* 1/16 (pow x 2)) 1/8))))))
(+ 1 (* 1/2 (pow x 2)))
(+ 1 (* (pow x 2) (+ 1/2 (* -1/8 (pow x 2)))))
(+ 1 (* (pow x 2) (+ 1/2 (* (pow x 2) (- (* 1/16 (pow x 2)) 1/8)))))
(pow x 2)
(* (pow x 2) (+ 1 (/ 1 (pow x 2))))
(* -1 (log (/ 1 x)))
(+ (* -1 (log (/ 1 x))) (/ (fabs x) x))
(+ (* -1 (log (/ 1 x))) (+ (* 1/2 (/ (+ 1 (* -1 (pow (fabs x) 2))) (pow x 2))) (/ (fabs x) x)))
(+ (* -1 (log (/ 1 x))) (+ (* 1/6 (/ (+ (* -3 (fabs x)) (* 2 (pow (fabs x) 3))) (pow x 3))) (+ (* 1/2 (/ (+ 1 (* -1 (pow (fabs x) 2))) (pow x 2))) (/ (fabs x) x))))
x
(* x (+ 1 (/ (fabs x) x)))
(* x (+ 1 (+ (/ 1/2 (pow x 2)) (/ (fabs x) x))))
(* x (- (+ 1 (+ (/ 1/2 (pow x 2)) (/ (fabs x) x))) (* 1/8 (/ 1 (pow x 4)))))
(* x (+ 1 (* 1/2 (/ 1 (pow x 2)))))
(* x (- (+ 1 (* 1/2 (/ 1 (pow x 2)))) (/ 1/8 (pow x 4))))
(* x (- (+ 1 (+ (* 1/2 (/ 1 (pow x 2))) (* 1/16 (/ 1 (pow x 6))))) (/ 1/8 (pow x 4))))
(* -1 (log (/ -1 x)))
(+ (* -1 (log (/ -1 x))) (* -1 (/ (fabs x) x)))
(+ (* -1 (log (/ -1 x))) (* -1 (/ (+ (fabs x) (* -1/2 (/ (+ 1 (* -1 (pow (fabs x) 2))) x))) x)))
(+ (* -1 (log (/ -1 x))) (* -1 (/ (+ (fabs x) (* -1 (/ (+ (* -1/6 (/ (+ (* -3 (fabs x)) (* 2 (pow (fabs x) 3))) x)) (* 1/2 (+ 1 (* -1 (pow (fabs x) 2))))) x))) x)))
(* -1 x)
(* -1 (* x (+ 1 (* -1 (/ (fabs x) x)))))
(* -1 (* x (+ 1 (* -1 (/ (- (fabs x) (* 1/2 (/ 1 x))) x)))))
(* -1 (* x (+ 1 (* -1 (/ (+ (fabs x) (* -1 (/ (- 1/2 (* 1/8 (/ 1 (pow x 2)))) x))) x)))))
(* -1 (* x (+ 1 (* 1/2 (/ 1 (pow x 2))))))
(* -1 (* x (- (+ 1 (* 1/2 (/ 1 (pow x 2)))) (/ 1/8 (pow x 4)))))
(* -1 (* x (- (+ 1 (+ (* 1/2 (/ 1 (pow x 2))) (* 1/16 (/ 1 (pow x 6))))) (/ 1/8 (pow x 4)))))
Outputs
1
#s(literal 1 binary32)
(+ 1 (pow x 2))
(fma.f32 x x #s(literal 1 binary32))
(copysign (log (+ (fabs x) (sqrt (+ 1 (pow x 2))))) x)
(copysign.f32 (log.f32 (+.f32 (sqrt.f32 (fma.f32 x x #s(literal 1 binary32))) (fabs.f32 x))) x)
(log (+ 1 (fabs x)))
(log1p.f32 (fabs.f32 x))
(+ (log (+ 1 (fabs x))) (* 1/2 (/ (pow x 2) (+ 1 (fabs x)))))
(fma.f32 (*.f32 (/.f32 #s(literal 1/2 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) x) x (log1p.f32 (fabs.f32 x)))
(+ (log (+ 1 (fabs x))) (* (pow x 2) (+ (* -1/24 (* (pow x 2) (+ (* 3 (/ 1 (+ 1 (fabs x)))) (* 3 (/ 1 (pow (+ 1 (fabs x)) 2)))))) (* 1/2 (/ 1 (+ 1 (fabs x)))))))
(fma.f32 (fma.f32 (*.f32 #s(literal -1/24 binary32) (*.f32 x x)) (/.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (/.f32 #s(literal 1/2 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32)))) (*.f32 x x) (log1p.f32 (fabs.f32 x)))
(+ (log (+ 1 (fabs x))) (* (pow x 2) (+ (* (pow x 2) (+ (* -1/24 (+ (* 3 (/ 1 (+ 1 (fabs x)))) (* 3 (/ 1 (pow (+ 1 (fabs x)) 2))))) (* 1/720 (* (pow x 2) (+ (* 45 (/ 1 (+ 1 (fabs x)))) (+ (* 45 (/ 1 (pow (+ 1 (fabs x)) 2))) (* 30 (/ 1 (pow (+ 1 (fabs x)) 3))))))))) (* 1/2 (/ 1 (+ 1 (fabs x)))))))
(fma.f32 (fma.f32 (fma.f32 (*.f32 #s(literal 1/720 binary32) (*.f32 x x)) (+.f32 (/.f32 (+.f32 (/.f32 #s(literal 30 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 45 binary32)) (pow.f32 (-.f32 (fabs.f32 x) #s(literal -1 binary32)) #s(literal 2 binary32))) (/.f32 #s(literal 45 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32)))) (*.f32 (/.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal -1/24 binary32))) (*.f32 x x) (/.f32 #s(literal 1/2 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32)))) (*.f32 x x) (log1p.f32 (fabs.f32 x)))
(+ 1 (fabs x))
(-.f32 (fabs.f32 x) #s(literal -1 binary32))
(+ 1 (+ (fabs x) (* 1/2 (pow x 2))))
(-.f32 (fma.f32 #s(literal 1/2 binary32) (*.f32 x x) (fabs.f32 x)) #s(literal -1 binary32))
(+ 1 (+ (fabs x) (* (pow x 2) (+ 1/2 (* -1/8 (pow x 2))))))
(-.f32 (fabs.f32 x) (fma.f32 (fma.f32 #s(literal 1/8 binary32) (*.f32 x x) #s(literal -1/2 binary32)) (*.f32 x x) #s(literal -1 binary32)))
(+ 1 (+ (fabs x) (* (pow x 2) (+ 1/2 (* (pow x 2) (- (* 1/16 (pow x 2)) 1/8))))))
(fma.f32 (*.f32 (fma.f32 (fma.f32 #s(literal 1/16 binary32) (*.f32 x x) #s(literal -1/8 binary32)) (*.f32 x x) #s(literal 1/2 binary32)) x) x (-.f32 (fabs.f32 x) #s(literal -1 binary32)))
(+ 1 (* 1/2 (pow x 2)))
(fma.f32 #s(literal 1/2 binary32) (*.f32 x x) #s(literal 1 binary32))
(+ 1 (* (pow x 2) (+ 1/2 (* -1/8 (pow x 2)))))
(fma.f32 (fma.f32 #s(literal -1/8 binary32) (*.f32 x x) #s(literal 1/2 binary32)) (*.f32 x x) #s(literal 1 binary32))
(+ 1 (* (pow x 2) (+ 1/2 (* (pow x 2) (- (* 1/16 (pow x 2)) 1/8)))))
(fma.f32 (fma.f32 (fma.f32 #s(literal 1/16 binary32) (*.f32 x x) #s(literal -1/8 binary32)) (*.f32 x x) #s(literal 1/2 binary32)) (*.f32 x x) #s(literal 1 binary32))
(pow x 2)
(*.f32 x x)
(* (pow x 2) (+ 1 (/ 1 (pow x 2))))
(fma.f32 x x #s(literal 1 binary32))
(* -1 (log (/ 1 x)))
(log.f32 x)
(+ (* -1 (log (/ 1 x))) (/ (fabs x) x))
(+.f32 (/.f32 (fabs.f32 x) x) (log.f32 x))
(+ (* -1 (log (/ 1 x))) (+ (* 1/2 (/ (+ 1 (* -1 (pow (fabs x) 2))) (pow x 2))) (/ (fabs x) x)))
(+.f32 (+.f32 (/.f32 (+.f32 (/.f32 #s(literal 1/2 binary32) x) (fabs.f32 x)) x) #s(literal -1/2 binary32)) (log.f32 x))
(+ (* -1 (log (/ 1 x))) (+ (* 1/6 (/ (+ (* -3 (fabs x)) (* 2 (pow (fabs x) 3))) (pow x 3))) (+ (* 1/2 (/ (+ 1 (* -1 (pow (fabs x) 2))) (pow x 2))) (/ (fabs x) x))))
(fma.f32 (/.f32 (*.f32 (fabs.f32 x) (fma.f32 (*.f32 x x) #s(literal 2 binary32) #s(literal -3 binary32))) (pow.f32 x #s(literal 3 binary32))) #s(literal 1/6 binary32) (+.f32 (+.f32 (/.f32 (+.f32 (/.f32 #s(literal 1/2 binary32) x) (fabs.f32 x)) x) #s(literal -1/2 binary32)) (log.f32 x)))
x
(* x (+ 1 (/ (fabs x) x)))
(fma.f32 (/.f32 (fabs.f32 x) x) x x)
(* x (+ 1 (+ (/ 1/2 (pow x 2)) (/ (fabs x) x))))
(fma.f32 (/.f32 (+.f32 (/.f32 #s(literal 1/2 binary32) x) (fabs.f32 x)) x) x x)
(* x (- (+ 1 (+ (/ 1/2 (pow x 2)) (/ (fabs x) x))) (* 1/8 (/ 1 (pow x 4)))))
(fma.f32 (-.f32 (/.f32 (+.f32 (/.f32 #s(literal 1/2 binary32) x) (fabs.f32 x)) x) (/.f32 #s(literal 1/8 binary32) (pow.f32 x #s(literal 4 binary32)))) x x)
(* x (+ 1 (* 1/2 (/ 1 (pow x 2)))))
(fma.f32 (/.f32 #s(literal 1/2 binary32) (*.f32 x x)) x x)
(* x (- (+ 1 (* 1/2 (/ 1 (pow x 2)))) (/ 1/8 (pow x 4))))
(fma.f32 (-.f32 (/.f32 #s(literal 1/2 binary32) (*.f32 x x)) (/.f32 #s(literal 1/8 binary32) (pow.f32 x #s(literal 4 binary32)))) x x)
(* x (- (+ 1 (+ (* 1/2 (/ 1 (pow x 2))) (* 1/16 (/ 1 (pow x 6))))) (/ 1/8 (pow x 4))))
(fma.f32 (-.f32 (-.f32 (/.f32 #s(literal 1/16 binary32) (pow.f32 x #s(literal 6 binary32))) (/.f32 #s(literal -1/2 binary32) (*.f32 x x))) (/.f32 #s(literal 1/8 binary32) (pow.f32 x #s(literal 4 binary32)))) x x)
(* -1 (log (/ -1 x)))
(neg.f32 (log.f32 (/.f32 #s(literal -1 binary32) x)))
(+ (* -1 (log (/ -1 x))) (* -1 (/ (fabs x) x)))
(-.f32 (/.f32 (fabs.f32 x) (neg.f32 x)) (log.f32 (/.f32 #s(literal -1 binary32) x)))
(+ (* -1 (log (/ -1 x))) (* -1 (/ (+ (fabs x) (* -1/2 (/ (+ 1 (* -1 (pow (fabs x) 2))) x))) x)))
(-.f32 (fma.f32 (/.f32 (-.f32 (fabs.f32 x) (/.f32 #s(literal 1/2 binary32) x)) x) #s(literal -1 binary32) #s(literal -1/2 binary32)) (log.f32 (/.f32 #s(literal -1 binary32) x)))
(+ (* -1 (log (/ -1 x))) (* -1 (/ (+ (fabs x) (* -1 (/ (+ (* -1/6 (/ (+ (* -3 (fabs x)) (* 2 (pow (fabs x) 3))) x)) (* 1/2 (+ 1 (* -1 (pow (fabs x) 2))))) x))) x)))
(-.f32 (/.f32 (-.f32 (/.f32 (fma.f32 (fma.f32 x x #s(literal -1 binary32)) #s(literal -1/2 binary32) (*.f32 (/.f32 (*.f32 (fabs.f32 x) (fma.f32 (*.f32 x x) #s(literal 2 binary32) #s(literal -3 binary32))) x) #s(literal -1/6 binary32))) x) (fabs.f32 x)) x) (log.f32 (/.f32 #s(literal -1 binary32) x)))
(* -1 x)
(neg.f32 x)
(* -1 (* x (+ 1 (* -1 (/ (fabs x) x)))))
(*.f32 (-.f32 (/.f32 (fabs.f32 x) x) #s(literal 1 binary32)) x)
(* -1 (* x (+ 1 (* -1 (/ (- (fabs x) (* 1/2 (/ 1 x))) x)))))
(*.f32 (-.f32 (/.f32 (-.f32 (fabs.f32 x) (/.f32 #s(literal 1/2 binary32) x)) x) #s(literal 1 binary32)) x)
(* -1 (* x (+ 1 (* -1 (/ (+ (fabs x) (* -1 (/ (- 1/2 (* 1/8 (/ 1 (pow x 2)))) x))) x)))))
(*.f32 (-.f32 (/.f32 (-.f32 (fabs.f32 x) (/.f32 (-.f32 #s(literal 1/2 binary32) (/.f32 #s(literal 1/8 binary32) (*.f32 x x))) x)) x) #s(literal 1 binary32)) x)
(* -1 (* x (+ 1 (* 1/2 (/ 1 (pow x 2))))))
(*.f32 (+.f32 (/.f32 #s(literal -1/2 binary32) (*.f32 x x)) #s(literal -1 binary32)) x)
(* -1 (* x (- (+ 1 (* 1/2 (/ 1 (pow x 2)))) (/ 1/8 (pow x 4)))))
(*.f32 (+.f32 (+.f32 (/.f32 #s(literal -1/2 binary32) (*.f32 x x)) #s(literal -1 binary32)) (/.f32 #s(literal 1/8 binary32) (pow.f32 x #s(literal 4 binary32)))) x)
(* -1 (* x (- (+ 1 (+ (* 1/2 (/ 1 (pow x 2))) (* 1/16 (/ 1 (pow x 6))))) (/ 1/8 (pow x 4)))))
(*.f32 (+.f32 (+.f32 (/.f32 #s(literal -1/2 binary32) (*.f32 x x)) #s(literal -1 binary32)) (-.f32 (/.f32 #s(literal -1/16 binary32) (pow.f32 x #s(literal 6 binary32))) (/.f32 #s(literal -1/8 binary32) (pow.f32 x #s(literal 4 binary32))))) x)

rewrite85.0ms (2%)

Memory
-13.5MiB live, 76.4MiB allocated; 19ms collecting garbage
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0942
01630
15622
040621
Stop Event
iter limit
iter limit
iter limit
unsound
iter limit
Counts
5 → 65
Calls
Call 1
Inputs
(+.f32 (*.f32 x x) #s(literal 1 binary32))
(copysign.f32 (log.f32 (+.f32 (fabs.f32 x) (sqrt.f32 (+.f32 (*.f32 x x) #s(literal 1 binary32))))) x)
(log.f32 (+.f32 (fabs.f32 x) (sqrt.f32 (+.f32 (*.f32 x x) #s(literal 1 binary32)))))
(+.f32 (fabs.f32 x) (sqrt.f32 (+.f32 (*.f32 x x) #s(literal 1 binary32))))
(sqrt.f32 (+.f32 (*.f32 x x) #s(literal 1 binary32)))
Outputs
(*.f32 (neg.f32 (cosh.f32 (asinh.f32 x))) (neg.f32 (cosh.f32 (asinh.f32 x))))
(*.f32 (fabs.f32 (cosh.f32 (asinh.f32 x))) (fabs.f32 (cosh.f32 (asinh.f32 x))))
(*.f32 (cosh.f32 (asinh.f32 x)) (cosh.f32 (asinh.f32 x)))
(sqrt.f32 (*.f32 (fma.f32 x x #s(literal 1 binary32)) (fma.f32 x x #s(literal 1 binary32))))
(/.f32 (-.f32 #s(literal 1 binary32) (pow.f32 x #s(literal 4 binary32))) (-.f32 #s(literal 1 binary32) (*.f32 x x)))
(/.f32 (neg.f32 (-.f32 (pow.f32 x #s(literal 4 binary32)) #s(literal 1 binary32))) (neg.f32 (fma.f32 x x #s(literal -1 binary32))))
(/.f32 (neg.f32 (-.f32 (pow.f32 x #s(literal 6 binary32)) #s(literal -1 binary32))) (neg.f32 (-.f32 (+.f32 (pow.f32 x #s(literal 4 binary32)) #s(literal 1 binary32)) (*.f32 x x))))
(/.f32 (-.f32 (pow.f32 x #s(literal 4 binary32)) #s(literal 1 binary32)) (fma.f32 x x #s(literal -1 binary32)))
(/.f32 (-.f32 (pow.f32 x #s(literal 6 binary32)) #s(literal -1 binary32)) (+.f32 #s(literal 1 binary32) (-.f32 (pow.f32 x #s(literal 4 binary32)) (*.f32 x x))))
(/.f32 (-.f32 (pow.f32 x #s(literal 6 binary32)) #s(literal -1 binary32)) (-.f32 (+.f32 (pow.f32 x #s(literal 4 binary32)) #s(literal 1 binary32)) (*.f32 x x)))
(-.f32 (/.f32 (pow.f32 x #s(literal 4 binary32)) (fma.f32 x x #s(literal -1 binary32))) (/.f32 #s(literal 1 binary32) (fma.f32 x x #s(literal -1 binary32))))
(-.f32 #s(literal 1 binary32) (*.f32 (neg.f32 (neg.f32 x)) (neg.f32 x)))
(-.f32 #s(literal 1 binary32) (*.f32 (neg.f32 (fabs.f32 x)) (fabs.f32 x)))
(-.f32 #s(literal 1 binary32) (*.f32 (neg.f32 x) x))
(-.f32 #s(literal 1 binary32) (*.f32 x (neg.f32 x)))
(-.f32 (*.f32 x x) #s(literal -1 binary32))
(fma.f32 (*.f32 (neg.f32 x) #s(literal 1 binary32)) (*.f32 (neg.f32 x) #s(literal 1 binary32)) #s(literal 1 binary32))
(fma.f32 (*.f32 (fabs.f32 x) #s(literal 1 binary32)) (*.f32 (fabs.f32 x) #s(literal 1 binary32)) #s(literal 1 binary32))
(fma.f32 (*.f32 x #s(literal 1 binary32)) (*.f32 x #s(literal 1 binary32)) #s(literal 1 binary32))
(fma.f32 (neg.f32 (fabs.f32 x)) (neg.f32 (fabs.f32 x)) #s(literal 1 binary32))
(fma.f32 (neg.f32 (neg.f32 x)) (neg.f32 (neg.f32 x)) #s(literal 1 binary32))
(fma.f32 (neg.f32 x) (*.f32 (neg.f32 x) #s(literal 1 binary32)) #s(literal 1 binary32))
(fma.f32 (neg.f32 x) (neg.f32 x) #s(literal 1 binary32))
(fma.f32 (fabs.f32 x) (*.f32 (fabs.f32 x) #s(literal 1 binary32)) #s(literal 1 binary32))
(fma.f32 (fabs.f32 x) (fabs.f32 x) #s(literal 1 binary32))
(fma.f32 #s(literal 1 binary32) (*.f32 x x) #s(literal 1 binary32))
(fma.f32 (*.f32 x x) #s(literal 1 binary32) #s(literal 1 binary32))
(fma.f32 x (*.f32 x #s(literal 1 binary32)) #s(literal 1 binary32))
(fma.f32 x x #s(literal 1 binary32))
(pow.f32 (*.f32 (fma.f32 x x #s(literal 1 binary32)) (fma.f32 x x #s(literal 1 binary32))) #s(literal 1/2 binary32))
(pow.f32 (cosh.f32 (asinh.f32 x)) #s(literal 2 binary32))
(pow.f32 (fma.f32 x x #s(literal 1 binary32)) #s(literal 1 binary32))
(+.f32 (/.f32 (pow.f32 x #s(literal 6 binary32)) (-.f32 (+.f32 (pow.f32 x #s(literal 4 binary32)) #s(literal 1 binary32)) (*.f32 x x))) (/.f32 #s(literal 1 binary32) (-.f32 (+.f32 (pow.f32 x #s(literal 4 binary32)) #s(literal 1 binary32)) (*.f32 x x))))
(+.f32 #s(literal 1 binary32) (*.f32 x x))
(+.f32 (*.f32 x x) #s(literal 1 binary32))
(copysign.f32 (asinh.f32 (fabs.f32 x)) x)
(log.f32 (+.f32 (cosh.f32 (asinh.f32 x)) (fabs.f32 x)))
(-.f32 (log.f32 (-.f32 (*.f32 x x) (fma.f32 x x #s(literal 1 binary32)))) (log.f32 (-.f32 (fabs.f32 x) (cosh.f32 (asinh.f32 x)))))
(-.f32 (log.f32 (+.f32 (pow.f32 (cosh.f32 (asinh.f32 x)) #s(literal 3 binary32)) (pow.f32 (fabs.f32 x) #s(literal 3 binary32)))) (log.f32 (fma.f32 (cosh.f32 (asinh.f32 x)) (-.f32 (cosh.f32 (asinh.f32 x)) (fabs.f32 x)) (*.f32 x x))))
(asinh.f32 (fabs.f32 x))
(/.f32 (-.f32 (fma.f32 x x #s(literal 1 binary32)) (*.f32 x x)) (-.f32 (cosh.f32 (asinh.f32 x)) (fabs.f32 x)))
(/.f32 (neg.f32 (-.f32 (*.f32 x x) (fma.f32 x x #s(literal 1 binary32)))) (neg.f32 (-.f32 (fabs.f32 x) (cosh.f32 (asinh.f32 x)))))
(/.f32 (neg.f32 (+.f32 (pow.f32 (cosh.f32 (asinh.f32 x)) #s(literal 3 binary32)) (pow.f32 (fabs.f32 x) #s(literal 3 binary32)))) (neg.f32 (fma.f32 (cosh.f32 (asinh.f32 x)) (-.f32 (cosh.f32 (asinh.f32 x)) (fabs.f32 x)) (*.f32 x x))))
(/.f32 (-.f32 (*.f32 x x) (fma.f32 x x #s(literal 1 binary32))) (-.f32 (fabs.f32 x) (cosh.f32 (asinh.f32 x))))
(/.f32 (+.f32 (pow.f32 (cosh.f32 (asinh.f32 x)) #s(literal 3 binary32)) (pow.f32 (fabs.f32 x) #s(literal 3 binary32))) (+.f32 (fma.f32 x x #s(literal 1 binary32)) (-.f32 (*.f32 x x) (*.f32 (cosh.f32 (asinh.f32 x)) (fabs.f32 x)))))
(/.f32 (+.f32 (pow.f32 (cosh.f32 (asinh.f32 x)) #s(literal 3 binary32)) (pow.f32 (fabs.f32 x) #s(literal 3 binary32))) (fma.f32 (cosh.f32 (asinh.f32 x)) (-.f32 (cosh.f32 (asinh.f32 x)) (fabs.f32 x)) (*.f32 x x)))
(-.f32 (/.f32 (*.f32 x x) (-.f32 (fabs.f32 x) (cosh.f32 (asinh.f32 x)))) (/.f32 (fma.f32 x x #s(literal 1 binary32)) (-.f32 (fabs.f32 x) (cosh.f32 (asinh.f32 x)))))
(fma.f32 (pow.f32 (fma.f32 x x #s(literal 1 binary32)) #s(literal 1/4 binary32)) (pow.f32 (fma.f32 x x #s(literal 1 binary32)) #s(literal 1/4 binary32)) (fabs.f32 x))
(fma.f32 (sqrt.f32 (neg.f32 x)) (sqrt.f32 (neg.f32 x)) (cosh.f32 (asinh.f32 x)))
(fma.f32 (sqrt.f32 (fabs.f32 x)) (sqrt.f32 (fabs.f32 x)) (cosh.f32 (asinh.f32 x)))
(fma.f32 (sqrt.f32 x) (sqrt.f32 x) (cosh.f32 (asinh.f32 x)))
(+.f32 (/.f32 (pow.f32 (fabs.f32 x) #s(literal 3 binary32)) (fma.f32 (cosh.f32 (asinh.f32 x)) (-.f32 (cosh.f32 (asinh.f32 x)) (fabs.f32 x)) (*.f32 x x))) (/.f32 (pow.f32 (cosh.f32 (asinh.f32 x)) #s(literal 3 binary32)) (fma.f32 (cosh.f32 (asinh.f32 x)) (-.f32 (cosh.f32 (asinh.f32 x)) (fabs.f32 x)) (*.f32 x x))))
(+.f32 (cosh.f32 (asinh.f32 x)) (fabs.f32 x))
(+.f32 (fabs.f32 x) (cosh.f32 (asinh.f32 x)))
(*.f32 (pow.f32 (fma.f32 x x #s(literal 1 binary32)) #s(literal 1/4 binary32)) (pow.f32 (fma.f32 x x #s(literal 1 binary32)) #s(literal 1/4 binary32)))
(sqrt.f32 (fma.f32 x x #s(literal 1 binary32)))
(/.f32 (sqrt.f32 (-.f32 (pow.f32 x #s(literal 4 binary32)) #s(literal 1 binary32))) (sqrt.f32 (fma.f32 x x #s(literal -1 binary32))))
(/.f32 (sqrt.f32 (-.f32 (pow.f32 x #s(literal 6 binary32)) #s(literal -1 binary32))) (sqrt.f32 (-.f32 (+.f32 (pow.f32 x #s(literal 4 binary32)) #s(literal 1 binary32)) (*.f32 x x))))
(/.f32 (+.f32 (exp.f32 (asinh.f32 x)) (exp.f32 (neg.f32 (asinh.f32 x)))) #s(literal 2 binary32))
(pow.f32 (fma.f32 x x #s(literal 1 binary32)) #s(literal 1/2 binary32))
(exp.f32 (*.f32 (log1p.f32 (*.f32 x x)) #s(literal 1/2 binary32)))
(cosh.f32 (neg.f32 (asinh.f32 x)))
(cosh.f32 (asinh.f32 (neg.f32 x)))
(cosh.f32 (asinh.f32 x))
(cosh.f32 (asinh.f32 (fabs.f32 x)))

eval12.0ms (0.3%)

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

Compiled 2 004 to 572 computations (71.5% saved)

prune6.0ms (0.1%)

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

6 alts after pruning (6 fresh and 0 done)

PrunedKeptTotal
New956101
Fresh000
Picked101
Done000
Total966102
Accuracy
100.0%
Counts
102 → 6
Alt Table
Click to see full alt table
StatusAccuracyProgram
33.9%
(copysign.f32 (log.f32 (+.f32 (fabs.f32 x) (sqrt.f32 #s(approx (+ (* x x) 1) (*.f32 x x))))) x)
34.0%
(copysign.f32 (log.f32 #s(approx (+ (fabs x) (sqrt (+ (* x x) 1))) (fma.f32 (/.f32 (fabs.f32 x) x) x x))) x)
29.5%
(copysign.f32 (log.f32 #s(approx (+ (fabs x) (sqrt (+ (* x x) 1))) (*.f32 (-.f32 (/.f32 (fabs.f32 x) x) #s(literal 1 binary32)) x))) x)
99.6%
(copysign.f32 (asinh.f32 (fabs.f32 x)) x)
49.6%
(copysign.f32 #s(approx (log (+ (fabs x) (sqrt (+ (* x x) 1)))) (fma.f32 (fma.f32 (*.f32 #s(literal -1/24 binary32) (*.f32 x x)) (/.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (/.f32 #s(literal 1/2 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32)))) (*.f32 x x) (log1p.f32 (fabs.f32 x)))) x)
15.2%
(copysign.f32 #s(approx (log (+ (fabs x) (sqrt (+ (* x x) 1)))) (log.f32 x)) x)
Compiler

Compiled 244 to 158 computations (35.2% saved)

simplify234.0ms (5.6%)

Memory
4.7MiB live, 181.4MiB allocated; 53ms collecting garbage
Localize:

Found 18 expressions of interest:

NewMetricScoreProgram
cost-diff0
(*.f32 (-.f32 (/.f32 (fabs.f32 x) x) #s(literal 1 binary32)) x)
cost-diff0
#s(approx (+ (fabs x) (sqrt (+ (* x x) 1))) (*.f32 (-.f32 (/.f32 (fabs.f32 x) x) #s(literal 1 binary32)) x))
cost-diff0
(log.f32 #s(approx (+ (fabs x) (sqrt (+ (* x x) 1))) (*.f32 (-.f32 (/.f32 (fabs.f32 x) x) #s(literal 1 binary32)) x)))
cost-diff0
(copysign.f32 (log.f32 #s(approx (+ (fabs x) (sqrt (+ (* x x) 1))) (*.f32 (-.f32 (/.f32 (fabs.f32 x) x) #s(literal 1 binary32)) x))) x)
cost-diff0
(fabs.f32 x)
cost-diff0
(+.f32 (fabs.f32 x) (sqrt.f32 #s(approx (+ (* x x) 1) (*.f32 x x))))
cost-diff0
(log.f32 (+.f32 (fabs.f32 x) (sqrt.f32 #s(approx (+ (* x x) 1) (*.f32 x x)))))
cost-diff0
(copysign.f32 (log.f32 (+.f32 (fabs.f32 x) (sqrt.f32 #s(approx (+ (* x x) 1) (*.f32 x x))))) x)
cost-diff0
#s(approx (+ (fabs x) (sqrt (+ (* x x) 1))) (fma.f32 (/.f32 (fabs.f32 x) x) x x))
cost-diff0
(log.f32 #s(approx (+ (fabs x) (sqrt (+ (* x x) 1))) (fma.f32 (/.f32 (fabs.f32 x) x) x x)))
cost-diff0
(copysign.f32 (log.f32 #s(approx (+ (fabs x) (sqrt (+ (* x x) 1))) (fma.f32 (/.f32 (fabs.f32 x) x) x x))) x)
cost-diff3
(fma.f32 (/.f32 (fabs.f32 x) x) x x)
cost-diff0
(log.f32 x)
cost-diff0
#s(approx (log (+ (fabs x) (sqrt (+ (* x x) 1)))) (log.f32 x))
cost-diff0
(copysign.f32 #s(approx (log (+ (fabs x) (sqrt (+ (* x x) 1)))) (log.f32 x)) x)
cost-diff0
(fabs.f32 x)
cost-diff0
(asinh.f32 (fabs.f32 x))
cost-diff0
(copysign.f32 (asinh.f32 (fabs.f32 x)) x)
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
030259
049259
165259
297255
3164247
4366247
52172247
08375234
Stop Event
iter limit
node limit
iter limit
Calls
Call 1
Inputs
(copysign.f32 (asinh.f32 (fabs.f32 x)) x)
(asinh.f32 (fabs.f32 x))
(fabs.f32 x)
x
(copysign.f32 #s(approx (log (+ (fabs x) (sqrt (+ (* x x) 1)))) (log.f32 x)) x)
#s(approx (log (+ (fabs x) (sqrt (+ (* x x) 1)))) (log.f32 x))
(log.f32 x)
x
(copysign.f32 (log.f32 #s(approx (+ (fabs x) (sqrt (+ (* x x) 1))) (fma.f32 (/.f32 (fabs.f32 x) x) x x))) x)
(log.f32 #s(approx (+ (fabs x) (sqrt (+ (* x x) 1))) (fma.f32 (/.f32 (fabs.f32 x) x) x x)))
#s(approx (+ (fabs x) (sqrt (+ (* x x) 1))) (fma.f32 (/.f32 (fabs.f32 x) x) x x))
(fma.f32 (/.f32 (fabs.f32 x) x) x x)
(/.f32 (fabs.f32 x) x)
(fabs.f32 x)
x
(copysign.f32 (log.f32 (+.f32 (fabs.f32 x) (sqrt.f32 #s(approx (+ (* x x) 1) (*.f32 x x))))) x)
(log.f32 (+.f32 (fabs.f32 x) (sqrt.f32 #s(approx (+ (* x x) 1) (*.f32 x x)))))
(+.f32 (fabs.f32 x) (sqrt.f32 #s(approx (+ (* x x) 1) (*.f32 x x))))
(fabs.f32 x)
x
(sqrt.f32 #s(approx (+ (* x x) 1) (*.f32 x x)))
#s(approx (+ (* x x) 1) (*.f32 x x))
(*.f32 x x)
(copysign.f32 (log.f32 #s(approx (+ (fabs x) (sqrt (+ (* x x) 1))) (*.f32 (-.f32 (/.f32 (fabs.f32 x) x) #s(literal 1 binary32)) x))) x)
(log.f32 #s(approx (+ (fabs x) (sqrt (+ (* x x) 1))) (*.f32 (-.f32 (/.f32 (fabs.f32 x) x) #s(literal 1 binary32)) x)))
#s(approx (+ (fabs x) (sqrt (+ (* x x) 1))) (*.f32 (-.f32 (/.f32 (fabs.f32 x) x) #s(literal 1 binary32)) x))
(*.f32 (-.f32 (/.f32 (fabs.f32 x) x) #s(literal 1 binary32)) x)
(-.f32 (/.f32 (fabs.f32 x) x) #s(literal 1 binary32))
(/.f32 (fabs.f32 x) x)
(fabs.f32 x)
x
#s(literal 1 binary32)
Outputs
(copysign.f32 (asinh.f32 (fabs.f32 x)) x)
(asinh.f32 (fabs.f32 x))
(fabs.f32 x)
x
(copysign.f32 #s(approx (log (+ (fabs x) (sqrt (+ (* x x) 1)))) (log.f32 x)) x)
#s(approx (log (+ (fabs x) (sqrt (+ (* x x) 1)))) (log.f32 x))
(log.f32 x)
x
(copysign.f32 (log.f32 #s(approx (+ (fabs x) (sqrt (+ (* x x) 1))) (fma.f32 (/.f32 (fabs.f32 x) x) x x))) x)
(copysign.f32 (log.f32 #s(approx (+ (fabs x) (sqrt (+ (* x x) 1))) (+.f32 (fabs.f32 x) x))) x)
(log.f32 #s(approx (+ (fabs x) (sqrt (+ (* x x) 1))) (fma.f32 (/.f32 (fabs.f32 x) x) x x)))
(log.f32 #s(approx (+ (fabs x) (sqrt (+ (* x x) 1))) (+.f32 (fabs.f32 x) x)))
#s(approx (+ (fabs x) (sqrt (+ (* x x) 1))) (fma.f32 (/.f32 (fabs.f32 x) x) x x))
#s(approx (+ (fabs x) (sqrt (+ (* x x) 1))) (+.f32 (fabs.f32 x) x))
(fma.f32 (/.f32 (fabs.f32 x) x) x x)
(+.f32 (fabs.f32 x) x)
(/.f32 (fabs.f32 x) x)
(fabs.f32 x)
x
(copysign.f32 (log.f32 (+.f32 (fabs.f32 x) (sqrt.f32 #s(approx (+ (* x x) 1) (*.f32 x x))))) x)
(copysign.f32 (log.f32 (+.f32 (sqrt.f32 #s(approx (+ (* x x) 1) (*.f32 x x))) (fabs.f32 x))) x)
(log.f32 (+.f32 (fabs.f32 x) (sqrt.f32 #s(approx (+ (* x x) 1) (*.f32 x x)))))
(log.f32 (+.f32 (sqrt.f32 #s(approx (+ (* x x) 1) (*.f32 x x))) (fabs.f32 x)))
(+.f32 (fabs.f32 x) (sqrt.f32 #s(approx (+ (* x x) 1) (*.f32 x x))))
(+.f32 (sqrt.f32 #s(approx (+ (* x x) 1) (*.f32 x x))) (fabs.f32 x))
(fabs.f32 x)
x
(sqrt.f32 #s(approx (+ (* x x) 1) (*.f32 x x)))
#s(approx (+ (* x x) 1) (*.f32 x x))
(*.f32 x x)
(copysign.f32 (log.f32 #s(approx (+ (fabs x) (sqrt (+ (* x x) 1))) (*.f32 (-.f32 (/.f32 (fabs.f32 x) x) #s(literal 1 binary32)) x))) x)
(log.f32 #s(approx (+ (fabs x) (sqrt (+ (* x x) 1))) (*.f32 (-.f32 (/.f32 (fabs.f32 x) x) #s(literal 1 binary32)) x)))
#s(approx (+ (fabs x) (sqrt (+ (* x x) 1))) (*.f32 (-.f32 (/.f32 (fabs.f32 x) x) #s(literal 1 binary32)) x))
(*.f32 (-.f32 (/.f32 (fabs.f32 x) x) #s(literal 1 binary32)) x)
(-.f32 (/.f32 (fabs.f32 x) x) #s(literal 1 binary32))
(/.f32 (fabs.f32 x) x)
(fabs.f32 x)
x
#s(literal 1 binary32)

localize105.0ms (2.5%)

Memory
-35.9MiB live, 116.5MiB allocated; 37ms collecting garbage
Localize:

Found 18 expressions of interest:

NewMetricScoreProgram
accuracy0.0
(*.f32 (-.f32 (/.f32 (fabs.f32 x) x) #s(literal 1 binary32)) x)
accuracy0.0
(fabs.f32 x)
accuracy5.475354725472433
(log.f32 #s(approx (+ (fabs x) (sqrt (+ (* x x) 1))) (*.f32 (-.f32 (/.f32 (fabs.f32 x) x) #s(literal 1 binary32)) x)))
accuracy15.745164196428242
#s(approx (+ (fabs x) (sqrt (+ (* x x) 1))) (*.f32 (-.f32 (/.f32 (fabs.f32 x) x) #s(literal 1 binary32)) x))
accuracy0.01171875
(+.f32 (fabs.f32 x) (sqrt.f32 #s(approx (+ (* x x) 1) (*.f32 x x))))
accuracy3.697382948117691
(sqrt.f32 #s(approx (+ (* x x) 1) (*.f32 x x)))
accuracy5.475354725472433
(log.f32 (+.f32 (fabs.f32 x) (sqrt.f32 #s(approx (+ (* x x) 1) (*.f32 x x)))))
accuracy6.759905633178002
#s(approx (+ (* x x) 1) (*.f32 x x))
accuracy0.0
(/.f32 (fabs.f32 x) x)
accuracy0.0
(fabs.f32 x)
accuracy5.475354725472433
(log.f32 #s(approx (+ (fabs x) (sqrt (+ (* x x) 1))) (fma.f32 (/.f32 (fabs.f32 x) x) x x)))
accuracy6.573025500876729
#s(approx (+ (fabs x) (sqrt (+ (* x x) 1))) (fma.f32 (/.f32 (fabs.f32 x) x) x x))
accuracy0.0
(copysign.f32 #s(approx (log (+ (fabs x) (sqrt (+ (* x x) 1)))) (log.f32 x)) x)
accuracy0.0
(log.f32 x)
accuracy12.184085959126042
#s(approx (log (+ (fabs x) (sqrt (+ (* x x) 1)))) (log.f32 x))
accuracy0.0
(copysign.f32 (asinh.f32 (fabs.f32 x)) x)
accuracy0.0
(fabs.f32 x)
accuracy0.0703125
(asinh.f32 (fabs.f32 x))
Samples
62.0ms123×0invalid
14.0ms93×0valid
11.0ms40×1valid
Compiler

Compiled 185 to 19 computations (89.7% saved)

Precisions
Click to see histograms. Total time spent on operations: 62.0ms
ival-hypot: 24.0ms (38.5% of total)
ival-fabs: 13.0ms (20.8% of total)
ival-log: 6.0ms (9.6% of total)
ival-copysign: 4.0ms (6.4% of total)
ival-add: 4.0ms (6.4% of total)
ival-mult: 4.0ms (6.4% of total)
ival-asinh: 3.0ms (4.8% of total)
ival-div: 2.0ms (3.2% of total)
adjust: 1.0ms (1.6% of total)
ival-sub: 1.0ms (1.6% of total)
ival-assert: 0.0ms (0% of total)
ival-true: 0.0ms (0% of total)
exact: 0.0ms (0% of total)

series274.0ms (6.5%)

Memory
33.2MiB live, 232.8MiB allocated; 165ms collecting garbage
Counts
20 → 48
Calls
Call 1
Inputs
(copysign.f32 (asinh.f32 (fabs.f32 x)) x)
(asinh.f32 (fabs.f32 x))
(fabs.f32 x)
(copysign.f32 #s(approx (log (+ (fabs x) (sqrt (+ (* x x) 1)))) (log.f32 x)) x)
#s(approx (log (+ (fabs x) (sqrt (+ (* x x) 1)))) (log.f32 x))
(log.f32 x)
(fma.f32 (/.f32 (fabs.f32 x) x) x x)
(copysign.f32 (log.f32 #s(approx (+ (fabs x) (sqrt (+ (* x x) 1))) (fma.f32 (/.f32 (fabs.f32 x) x) x x))) x)
(log.f32 #s(approx (+ (fabs x) (sqrt (+ (* x x) 1))) (fma.f32 (/.f32 (fabs.f32 x) x) x x)))
#s(approx (+ (fabs x) (sqrt (+ (* x x) 1))) (fma.f32 (/.f32 (fabs.f32 x) x) x x))
(copysign.f32 (log.f32 (+.f32 (fabs.f32 x) (sqrt.f32 #s(approx (+ (* x x) 1) (*.f32 x x))))) x)
(log.f32 (+.f32 (fabs.f32 x) (sqrt.f32 #s(approx (+ (* x x) 1) (*.f32 x x)))))
(+.f32 (fabs.f32 x) (sqrt.f32 #s(approx (+ (* x x) 1) (*.f32 x x))))
(copysign.f32 (log.f32 #s(approx (+ (fabs x) (sqrt (+ (* x x) 1))) (*.f32 (-.f32 (/.f32 (fabs.f32 x) x) #s(literal 1 binary32)) x))) x)
(log.f32 #s(approx (+ (fabs x) (sqrt (+ (* x x) 1))) (*.f32 (-.f32 (/.f32 (fabs.f32 x) x) #s(literal 1 binary32)) x)))
#s(approx (+ (fabs x) (sqrt (+ (* x x) 1))) (*.f32 (-.f32 (/.f32 (fabs.f32 x) x) #s(literal 1 binary32)) x))
(*.f32 (-.f32 (/.f32 (fabs.f32 x) x) #s(literal 1 binary32)) x)
(/.f32 (fabs.f32 x) x)
#s(approx (+ (* x x) 1) (*.f32 x x))
(sqrt.f32 #s(approx (+ (* x x) 1) (*.f32 x x)))
Outputs
(copysign (log (+ (fabs x) (sqrt (+ 1 (pow (fabs x) 2))))) x)
(log (+ (fabs x) (sqrt (+ 1 (pow (fabs x) 2)))))
(fabs x)
(copysign (log (+ (fabs x) (sqrt (+ 1 (pow x 2))))) x)
(log (+ 1 (fabs x)))
(+ (log (+ 1 (fabs x))) (* 1/2 (/ (pow x 2) (+ 1 (fabs x)))))
(+ (log (+ 1 (fabs x))) (* (pow x 2) (+ (* -1/24 (* (pow x 2) (+ (* 3 (/ 1 (+ 1 (fabs x)))) (* 3 (/ 1 (pow (+ 1 (fabs x)) 2)))))) (* 1/2 (/ 1 (+ 1 (fabs x)))))))
(+ (log (+ 1 (fabs x))) (* (pow x 2) (+ (* (pow x 2) (+ (* -1/24 (+ (* 3 (/ 1 (+ 1 (fabs x)))) (* 3 (/ 1 (pow (+ 1 (fabs x)) 2))))) (* 1/720 (* (pow x 2) (+ (* 45 (/ 1 (+ 1 (fabs x)))) (+ (* 45 (/ 1 (pow (+ 1 (fabs x)) 2))) (* 30 (/ 1 (pow (+ 1 (fabs x)) 3))))))))) (* 1/2 (/ 1 (+ 1 (fabs x)))))))
(log x)
(+ x (fabs x))
(+ 1 (fabs x))
(+ 1 (+ (fabs x) (* 1/2 (pow x 2))))
(+ 1 (+ (fabs x) (* (pow x 2) (+ 1/2 (* -1/8 (pow x 2))))))
(+ 1 (+ (fabs x) (* (pow x 2) (+ 1/2 (* (pow x 2) (- (* 1/16 (pow x 2)) 1/8))))))
(+ (fabs x) (* -1 x))
(/ (fabs x) x)
1
(+ 1 (pow x 2))
(+ 1 (* 1/2 (pow x 2)))
(+ 1 (* (pow x 2) (+ 1/2 (* -1/8 (pow x 2)))))
(+ 1 (* (pow x 2) (+ 1/2 (* (pow x 2) (- (* 1/16 (pow x 2)) 1/8)))))
(* -1 (log (/ 1 x)))
(+ (* -1 (log (/ 1 x))) (/ (fabs x) x))
(+ (* -1 (log (/ 1 x))) (+ (* 1/2 (/ (+ 1 (* -1 (pow (fabs x) 2))) (pow x 2))) (/ (fabs x) x)))
(+ (* -1 (log (/ 1 x))) (+ (* 1/6 (/ (+ (* -3 (fabs x)) (* 2 (pow (fabs x) 3))) (pow x 3))) (+ (* 1/2 (/ (+ 1 (* -1 (pow (fabs x) 2))) (pow x 2))) (/ (fabs x) x))))
x
(* x (+ 1 (/ (fabs x) x)))
(* x (+ 1 (+ (/ 1/2 (pow x 2)) (/ (fabs x) x))))
(* x (- (+ 1 (+ (/ 1/2 (pow x 2)) (/ (fabs x) x))) (* 1/8 (/ 1 (pow x 4)))))
(* -1 x)
(* x (- (/ (fabs x) x) 1))
(pow x 2)
(* (pow x 2) (+ 1 (/ 1 (pow x 2))))
(* x (+ 1 (* 1/2 (/ 1 (pow x 2)))))
(* x (- (+ 1 (* 1/2 (/ 1 (pow x 2)))) (/ 1/8 (pow x 4))))
(* x (- (+ 1 (+ (* 1/2 (/ 1 (pow x 2))) (* 1/16 (/ 1 (pow x 6))))) (/ 1/8 (pow x 4))))
(* -1 (log (/ -1 x)))
(+ (* -1 (log (/ -1 x))) (* -1 (/ (fabs x) x)))
(+ (* -1 (log (/ -1 x))) (* -1 (/ (+ (fabs x) (* -1/2 (/ (+ 1 (* -1 (pow (fabs x) 2))) x))) x)))
(+ (* -1 (log (/ -1 x))) (* -1 (/ (+ (fabs x) (* -1 (/ (+ (* -1/6 (/ (+ (* -3 (fabs x)) (* 2 (pow (fabs x) 3))) x)) (* 1/2 (+ 1 (* -1 (pow (fabs x) 2))))) x))) x)))
(+ (log -1) (* -1 (log (/ -1 x))))
(* -1 (* x (- (* -1 (/ (fabs x) x)) 1)))
(* -1 (* x (+ 1 (* -1 (/ (fabs x) x)))))
(* -1 (* x (+ 1 (* -1 (/ (- (fabs x) (* 1/2 (/ 1 x))) x)))))
(* -1 (* x (+ 1 (* -1 (/ (+ (fabs x) (* -1 (/ (- 1/2 (* 1/8 (/ 1 (pow x 2)))) x))) x)))))
(* -1 (* x (+ 1 (* 1/2 (/ 1 (pow x 2))))))
(* -1 (* x (- (+ 1 (* 1/2 (/ 1 (pow x 2)))) (/ 1/8 (pow x 4)))))
(* -1 (* x (- (+ 1 (+ (* 1/2 (/ 1 (pow x 2))) (* 1/16 (/ 1 (pow x 6))))) (/ 1/8 (pow x 4)))))
Calls

3 calls:

TimeVariablePointExpression
149.0ms
x
@-inf
((copysign (asinh (fabs x)) x) (asinh (fabs x)) (fabs x) (copysign (log (+ (fabs x) (sqrt (+ (* x x) 1)))) x) (log (+ (fabs x) (sqrt (+ (* x x) 1)))) (log x) (+ (* (/ (fabs x) x) x) x) (copysign (log (+ (fabs x) (sqrt (+ (* x x) 1)))) x) (log (+ (fabs x) (sqrt (+ (* x x) 1)))) (+ (fabs x) (sqrt (+ (* x x) 1))) (copysign (log (+ (fabs x) (sqrt (+ (* x x) 1)))) x) (log (+ (fabs x) (sqrt (+ (* x x) 1)))) (+ (fabs x) (sqrt (+ (* x x) 1))) (copysign (log (+ (fabs x) (sqrt (+ (* x x) 1)))) x) (log (+ (fabs x) (sqrt (+ (* x x) 1)))) (+ (fabs x) (sqrt (+ (* x x) 1))) (* (- (/ (fabs x) x) 1) x) (/ (fabs x) x) (+ (* x x) 1) (sqrt (+ (* x x) 1)))
74.0ms
x
@0
((copysign (asinh (fabs x)) x) (asinh (fabs x)) (fabs x) (copysign (log (+ (fabs x) (sqrt (+ (* x x) 1)))) x) (log (+ (fabs x) (sqrt (+ (* x x) 1)))) (log x) (+ (* (/ (fabs x) x) x) x) (copysign (log (+ (fabs x) (sqrt (+ (* x x) 1)))) x) (log (+ (fabs x) (sqrt (+ (* x x) 1)))) (+ (fabs x) (sqrt (+ (* x x) 1))) (copysign (log (+ (fabs x) (sqrt (+ (* x x) 1)))) x) (log (+ (fabs x) (sqrt (+ (* x x) 1)))) (+ (fabs x) (sqrt (+ (* x x) 1))) (copysign (log (+ (fabs x) (sqrt (+ (* x x) 1)))) x) (log (+ (fabs x) (sqrt (+ (* x x) 1)))) (+ (fabs x) (sqrt (+ (* x x) 1))) (* (- (/ (fabs x) x) 1) x) (/ (fabs x) x) (+ (* x x) 1) (sqrt (+ (* x x) 1)))
50.0ms
x
@inf
((copysign (asinh (fabs x)) x) (asinh (fabs x)) (fabs x) (copysign (log (+ (fabs x) (sqrt (+ (* x x) 1)))) x) (log (+ (fabs x) (sqrt (+ (* x x) 1)))) (log x) (+ (* (/ (fabs x) x) x) x) (copysign (log (+ (fabs x) (sqrt (+ (* x x) 1)))) x) (log (+ (fabs x) (sqrt (+ (* x x) 1)))) (+ (fabs x) (sqrt (+ (* x x) 1))) (copysign (log (+ (fabs x) (sqrt (+ (* x x) 1)))) x) (log (+ (fabs x) (sqrt (+ (* x x) 1)))) (+ (fabs x) (sqrt (+ (* x x) 1))) (copysign (log (+ (fabs x) (sqrt (+ (* x x) 1)))) x) (log (+ (fabs x) (sqrt (+ (* x x) 1)))) (+ (fabs x) (sqrt (+ (* x x) 1))) (* (- (/ (fabs x) x) 1) x) (/ (fabs x) x) (+ (* x x) 1) (sqrt (+ (* x x) 1)))

simplify157.0ms (3.7%)

Memory
4.0MiB live, 243.4MiB allocated; 23ms collecting garbage
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0184646
1595606
22437586
08448543
Stop Event
iter limit
node limit
Counts
48 → 47
Calls
Call 1
Inputs
(copysign (log (+ (fabs x) (sqrt (+ 1 (pow (fabs x) 2))))) x)
(log (+ (fabs x) (sqrt (+ 1 (pow (fabs x) 2)))))
(fabs x)
(copysign (log (+ (fabs x) (sqrt (+ 1 (pow x 2))))) x)
(log (+ 1 (fabs x)))
(+ (log (+ 1 (fabs x))) (* 1/2 (/ (pow x 2) (+ 1 (fabs x)))))
(+ (log (+ 1 (fabs x))) (* (pow x 2) (+ (* -1/24 (* (pow x 2) (+ (* 3 (/ 1 (+ 1 (fabs x)))) (* 3 (/ 1 (pow (+ 1 (fabs x)) 2)))))) (* 1/2 (/ 1 (+ 1 (fabs x)))))))
(+ (log (+ 1 (fabs x))) (* (pow x 2) (+ (* (pow x 2) (+ (* -1/24 (+ (* 3 (/ 1 (+ 1 (fabs x)))) (* 3 (/ 1 (pow (+ 1 (fabs x)) 2))))) (* 1/720 (* (pow x 2) (+ (* 45 (/ 1 (+ 1 (fabs x)))) (+ (* 45 (/ 1 (pow (+ 1 (fabs x)) 2))) (* 30 (/ 1 (pow (+ 1 (fabs x)) 3))))))))) (* 1/2 (/ 1 (+ 1 (fabs x)))))))
(log x)
(+ x (fabs x))
(+ 1 (fabs x))
(+ 1 (+ (fabs x) (* 1/2 (pow x 2))))
(+ 1 (+ (fabs x) (* (pow x 2) (+ 1/2 (* -1/8 (pow x 2))))))
(+ 1 (+ (fabs x) (* (pow x 2) (+ 1/2 (* (pow x 2) (- (* 1/16 (pow x 2)) 1/8))))))
(+ (fabs x) (* -1 x))
(/ (fabs x) x)
1
(+ 1 (pow x 2))
(+ 1 (* 1/2 (pow x 2)))
(+ 1 (* (pow x 2) (+ 1/2 (* -1/8 (pow x 2)))))
(+ 1 (* (pow x 2) (+ 1/2 (* (pow x 2) (- (* 1/16 (pow x 2)) 1/8)))))
(* -1 (log (/ 1 x)))
(+ (* -1 (log (/ 1 x))) (/ (fabs x) x))
(+ (* -1 (log (/ 1 x))) (+ (* 1/2 (/ (+ 1 (* -1 (pow (fabs x) 2))) (pow x 2))) (/ (fabs x) x)))
(+ (* -1 (log (/ 1 x))) (+ (* 1/6 (/ (+ (* -3 (fabs x)) (* 2 (pow (fabs x) 3))) (pow x 3))) (+ (* 1/2 (/ (+ 1 (* -1 (pow (fabs x) 2))) (pow x 2))) (/ (fabs x) x))))
x
(* x (+ 1 (/ (fabs x) x)))
(* x (+ 1 (+ (/ 1/2 (pow x 2)) (/ (fabs x) x))))
(* x (- (+ 1 (+ (/ 1/2 (pow x 2)) (/ (fabs x) x))) (* 1/8 (/ 1 (pow x 4)))))
(* -1 x)
(* x (- (/ (fabs x) x) 1))
(pow x 2)
(* (pow x 2) (+ 1 (/ 1 (pow x 2))))
(* x (+ 1 (* 1/2 (/ 1 (pow x 2)))))
(* x (- (+ 1 (* 1/2 (/ 1 (pow x 2)))) (/ 1/8 (pow x 4))))
(* x (- (+ 1 (+ (* 1/2 (/ 1 (pow x 2))) (* 1/16 (/ 1 (pow x 6))))) (/ 1/8 (pow x 4))))
(* -1 (log (/ -1 x)))
(+ (* -1 (log (/ -1 x))) (* -1 (/ (fabs x) x)))
(+ (* -1 (log (/ -1 x))) (* -1 (/ (+ (fabs x) (* -1/2 (/ (+ 1 (* -1 (pow (fabs x) 2))) x))) x)))
(+ (* -1 (log (/ -1 x))) (* -1 (/ (+ (fabs x) (* -1 (/ (+ (* -1/6 (/ (+ (* -3 (fabs x)) (* 2 (pow (fabs x) 3))) x)) (* 1/2 (+ 1 (* -1 (pow (fabs x) 2))))) x))) x)))
(+ (log -1) (* -1 (log (/ -1 x))))
(* -1 (* x (- (* -1 (/ (fabs x) x)) 1)))
(* -1 (* x (+ 1 (* -1 (/ (fabs x) x)))))
(* -1 (* x (+ 1 (* -1 (/ (- (fabs x) (* 1/2 (/ 1 x))) x)))))
(* -1 (* x (+ 1 (* -1 (/ (+ (fabs x) (* -1 (/ (- 1/2 (* 1/8 (/ 1 (pow x 2)))) x))) x)))))
(* -1 (* x (+ 1 (* 1/2 (/ 1 (pow x 2))))))
(* -1 (* x (- (+ 1 (* 1/2 (/ 1 (pow x 2)))) (/ 1/8 (pow x 4)))))
(* -1 (* x (- (+ 1 (+ (* 1/2 (/ 1 (pow x 2))) (* 1/16 (/ 1 (pow x 6))))) (/ 1/8 (pow x 4)))))
Outputs
(copysign (log (+ (fabs x) (sqrt (+ 1 (pow (fabs x) 2))))) x)
(copysign.f32 (log.f32 (+.f32 (sqrt.f32 (fma.f32 x x #s(literal 1 binary32))) (fabs.f32 x))) x)
(log (+ (fabs x) (sqrt (+ 1 (pow (fabs x) 2)))))
(log.f32 (+.f32 (sqrt.f32 (fma.f32 x x #s(literal 1 binary32))) (fabs.f32 x)))
(fabs x)
(fabs.f32 x)
(copysign (log (+ (fabs x) (sqrt (+ 1 (pow x 2))))) x)
(copysign.f32 (log.f32 (+.f32 (sqrt.f32 (fma.f32 x x #s(literal 1 binary32))) (fabs.f32 x))) x)
(log (+ 1 (fabs x)))
(log1p.f32 (fabs.f32 x))
(+ (log (+ 1 (fabs x))) (* 1/2 (/ (pow x 2) (+ 1 (fabs x)))))
(fma.f32 (*.f32 (/.f32 #s(literal 1/2 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) x) x (log1p.f32 (fabs.f32 x)))
(+ (log (+ 1 (fabs x))) (* (pow x 2) (+ (* -1/24 (* (pow x 2) (+ (* 3 (/ 1 (+ 1 (fabs x)))) (* 3 (/ 1 (pow (+ 1 (fabs x)) 2)))))) (* 1/2 (/ 1 (+ 1 (fabs x)))))))
(fma.f32 (fma.f32 (*.f32 #s(literal -1/24 binary32) (*.f32 x x)) (/.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (/.f32 #s(literal 1/2 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32)))) (*.f32 x x) (log1p.f32 (fabs.f32 x)))
(+ (log (+ 1 (fabs x))) (* (pow x 2) (+ (* (pow x 2) (+ (* -1/24 (+ (* 3 (/ 1 (+ 1 (fabs x)))) (* 3 (/ 1 (pow (+ 1 (fabs x)) 2))))) (* 1/720 (* (pow x 2) (+ (* 45 (/ 1 (+ 1 (fabs x)))) (+ (* 45 (/ 1 (pow (+ 1 (fabs x)) 2))) (* 30 (/ 1 (pow (+ 1 (fabs x)) 3))))))))) (* 1/2 (/ 1 (+ 1 (fabs x)))))))
(fma.f32 (fma.f32 (fma.f32 (*.f32 #s(literal 1/720 binary32) (*.f32 x x)) (+.f32 (/.f32 (+.f32 (/.f32 #s(literal 30 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 45 binary32)) (pow.f32 (-.f32 (fabs.f32 x) #s(literal -1 binary32)) #s(literal 2 binary32))) (/.f32 #s(literal 45 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32)))) (*.f32 (/.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal -1/24 binary32))) (*.f32 x x) (/.f32 #s(literal 1/2 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32)))) (*.f32 x x) (log1p.f32 (fabs.f32 x)))
(log x)
(log.f32 x)
(+ x (fabs x))
(+.f32 (fabs.f32 x) x)
(+ 1 (fabs x))
(-.f32 (fabs.f32 x) #s(literal -1 binary32))
(+ 1 (+ (fabs x) (* 1/2 (pow x 2))))
(-.f32 (fma.f32 #s(literal 1/2 binary32) (*.f32 x x) (fabs.f32 x)) #s(literal -1 binary32))
(+ 1 (+ (fabs x) (* (pow x 2) (+ 1/2 (* -1/8 (pow x 2))))))
(-.f32 (fabs.f32 x) (fma.f32 (fma.f32 #s(literal 1/8 binary32) (*.f32 x x) #s(literal -1/2 binary32)) (*.f32 x x) #s(literal -1 binary32)))
(+ 1 (+ (fabs x) (* (pow x 2) (+ 1/2 (* (pow x 2) (- (* 1/16 (pow x 2)) 1/8))))))
(fma.f32 (*.f32 (fma.f32 (fma.f32 #s(literal 1/16 binary32) (*.f32 x x) #s(literal -1/8 binary32)) (*.f32 x x) #s(literal 1/2 binary32)) x) x (-.f32 (fabs.f32 x) #s(literal -1 binary32)))
(+ (fabs x) (* -1 x))
(-.f32 (fabs.f32 x) x)
(/ (fabs x) x)
(/.f32 (fabs.f32 x) x)
1
#s(literal 1 binary32)
(+ 1 (pow x 2))
(fma.f32 x x #s(literal 1 binary32))
(+ 1 (* 1/2 (pow x 2)))
(fma.f32 #s(literal 1/2 binary32) (*.f32 x x) #s(literal 1 binary32))
(+ 1 (* (pow x 2) (+ 1/2 (* -1/8 (pow x 2)))))
(fma.f32 (fma.f32 #s(literal -1/8 binary32) (*.f32 x x) #s(literal 1/2 binary32)) (*.f32 x x) #s(literal 1 binary32))
(+ 1 (* (pow x 2) (+ 1/2 (* (pow x 2) (- (* 1/16 (pow x 2)) 1/8)))))
(fma.f32 (fma.f32 (fma.f32 #s(literal 1/16 binary32) (*.f32 x x) #s(literal -1/8 binary32)) (*.f32 x x) #s(literal 1/2 binary32)) (*.f32 x x) #s(literal 1 binary32))
(* -1 (log (/ 1 x)))
(log.f32 x)
(+ (* -1 (log (/ 1 x))) (/ (fabs x) x))
(+.f32 (log.f32 x) (/.f32 (fabs.f32 x) x))
(+ (* -1 (log (/ 1 x))) (+ (* 1/2 (/ (+ 1 (* -1 (pow (fabs x) 2))) (pow x 2))) (/ (fabs x) x)))
(+.f32 (+.f32 (/.f32 (+.f32 (/.f32 #s(literal 1/2 binary32) x) (fabs.f32 x)) x) #s(literal -1/2 binary32)) (log.f32 x))
(+ (* -1 (log (/ 1 x))) (+ (* 1/6 (/ (+ (* -3 (fabs x)) (* 2 (pow (fabs x) 3))) (pow x 3))) (+ (* 1/2 (/ (+ 1 (* -1 (pow (fabs x) 2))) (pow x 2))) (/ (fabs x) x))))
(fma.f32 (/.f32 (*.f32 (fabs.f32 x) (fma.f32 (*.f32 x x) #s(literal 2 binary32) #s(literal -3 binary32))) (pow.f32 x #s(literal 3 binary32))) #s(literal 1/6 binary32) (+.f32 (+.f32 (/.f32 (+.f32 (/.f32 #s(literal 1/2 binary32) x) (fabs.f32 x)) x) #s(literal -1/2 binary32)) (log.f32 x)))
x
(* x (+ 1 (/ (fabs x) x)))
(fma.f32 (/.f32 (fabs.f32 x) x) x x)
(* x (+ 1 (+ (/ 1/2 (pow x 2)) (/ (fabs x) x))))
(fma.f32 (/.f32 (+.f32 (/.f32 #s(literal 1/2 binary32) x) (fabs.f32 x)) x) x x)
(* x (- (+ 1 (+ (/ 1/2 (pow x 2)) (/ (fabs x) x))) (* 1/8 (/ 1 (pow x 4)))))
(fma.f32 (-.f32 (/.f32 (+.f32 (/.f32 #s(literal 1/2 binary32) x) (fabs.f32 x)) x) (/.f32 #s(literal 1/8 binary32) (pow.f32 x #s(literal 4 binary32)))) x x)
(* -1 x)
(neg.f32 x)
(* x (- (/ (fabs x) x) 1))
(*.f32 (-.f32 (/.f32 (fabs.f32 x) x) #s(literal 1 binary32)) x)
(pow x 2)
(*.f32 x x)
(* (pow x 2) (+ 1 (/ 1 (pow x 2))))
(fma.f32 x x #s(literal 1 binary32))
(* x (+ 1 (* 1/2 (/ 1 (pow x 2)))))
(fma.f32 (/.f32 #s(literal 1/2 binary32) (*.f32 x x)) x x)
(* x (- (+ 1 (* 1/2 (/ 1 (pow x 2)))) (/ 1/8 (pow x 4))))
(fma.f32 (-.f32 (/.f32 #s(literal 1/2 binary32) (*.f32 x x)) (/.f32 #s(literal 1/8 binary32) (pow.f32 x #s(literal 4 binary32)))) x x)
(* x (- (+ 1 (+ (* 1/2 (/ 1 (pow x 2))) (* 1/16 (/ 1 (pow x 6))))) (/ 1/8 (pow x 4))))
(fma.f32 (-.f32 (-.f32 (/.f32 #s(literal 1/16 binary32) (pow.f32 x #s(literal 6 binary32))) (/.f32 #s(literal -1/2 binary32) (*.f32 x x))) (/.f32 #s(literal 1/8 binary32) (pow.f32 x #s(literal 4 binary32)))) x x)
(* -1 (log (/ -1 x)))
(neg.f32 (log.f32 (/.f32 #s(literal -1 binary32) x)))
(+ (* -1 (log (/ -1 x))) (* -1 (/ (fabs x) x)))
(-.f32 (/.f32 (fabs.f32 x) (neg.f32 x)) (log.f32 (/.f32 #s(literal -1 binary32) x)))
(+ (* -1 (log (/ -1 x))) (* -1 (/ (+ (fabs x) (* -1/2 (/ (+ 1 (* -1 (pow (fabs x) 2))) x))) x)))
(-.f32 (fma.f32 (/.f32 (-.f32 (fabs.f32 x) (/.f32 #s(literal 1/2 binary32) x)) x) #s(literal -1 binary32) #s(literal -1/2 binary32)) (log.f32 (/.f32 #s(literal -1 binary32) x)))
(+ (* -1 (log (/ -1 x))) (* -1 (/ (+ (fabs x) (* -1 (/ (+ (* -1/6 (/ (+ (* -3 (fabs x)) (* 2 (pow (fabs x) 3))) x)) (* 1/2 (+ 1 (* -1 (pow (fabs x) 2))))) x))) x)))
(-.f32 (/.f32 (-.f32 (/.f32 (fma.f32 (fma.f32 x x #s(literal -1 binary32)) #s(literal -1/2 binary32) (*.f32 (/.f32 (*.f32 (fabs.f32 x) (fma.f32 (*.f32 x x) #s(literal 2 binary32) #s(literal -3 binary32))) x) #s(literal -1/6 binary32))) x) (fabs.f32 x)) x) (log.f32 (/.f32 #s(literal -1 binary32) x)))
(+ (log -1) (* -1 (log (/ -1 x))))
(-.f32 (log.f32 #s(literal -1 binary32)) (log.f32 (/.f32 #s(literal -1 binary32) x)))
(* -1 (* x (- (* -1 (/ (fabs x) x)) 1)))
(fma.f32 (/.f32 (fabs.f32 x) x) x x)
(* -1 (* x (+ 1 (* -1 (/ (fabs x) x)))))
(*.f32 (-.f32 (/.f32 (fabs.f32 x) x) #s(literal 1 binary32)) x)
(* -1 (* x (+ 1 (* -1 (/ (- (fabs x) (* 1/2 (/ 1 x))) x)))))
(*.f32 (-.f32 (/.f32 (-.f32 (fabs.f32 x) (/.f32 #s(literal 1/2 binary32) x)) x) #s(literal 1 binary32)) x)
(* -1 (* x (+ 1 (* -1 (/ (+ (fabs x) (* -1 (/ (- 1/2 (* 1/8 (/ 1 (pow x 2)))) x))) x)))))
(*.f32 (-.f32 (/.f32 (-.f32 (fabs.f32 x) (/.f32 (-.f32 #s(literal 1/2 binary32) (/.f32 #s(literal 1/8 binary32) (*.f32 x x))) x)) x) #s(literal 1 binary32)) x)
(* -1 (* x (+ 1 (* 1/2 (/ 1 (pow x 2))))))
(*.f32 (+.f32 (/.f32 #s(literal -1/2 binary32) (*.f32 x x)) #s(literal -1 binary32)) x)
(* -1 (* x (- (+ 1 (* 1/2 (/ 1 (pow x 2)))) (/ 1/8 (pow x 4)))))
(*.f32 (+.f32 (+.f32 (/.f32 #s(literal -1/2 binary32) (*.f32 x x)) #s(literal -1 binary32)) (/.f32 #s(literal 1/8 binary32) (pow.f32 x #s(literal 4 binary32)))) x)
(* -1 (* x (- (+ 1 (+ (* 1/2 (/ 1 (pow x 2))) (* 1/16 (/ 1 (pow x 6))))) (/ 1/8 (pow x 4)))))
(*.f32 (+.f32 (+.f32 (/.f32 #s(literal -1/2 binary32) (*.f32 x x)) #s(literal -1 binary32)) (-.f32 (/.f32 #s(literal -1/16 binary32) (pow.f32 x #s(literal 6 binary32))) (/.f32 #s(literal -1/8 binary32) (pow.f32 x #s(literal 4 binary32))))) x)

rewrite103.0ms (2.4%)

Memory
-14.5MiB live, 83.1MiB allocated; 8ms collecting garbage
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
030234
049202
1135202
0856197
Stop Event
iter limit
iter limit
node limit
iter limit
Counts
20 → 86
Calls
Call 1
Inputs
(copysign.f32 (asinh.f32 (fabs.f32 x)) x)
(asinh.f32 (fabs.f32 x))
(fabs.f32 x)
(copysign.f32 #s(approx (log (+ (fabs x) (sqrt (+ (* x x) 1)))) (log.f32 x)) x)
#s(approx (log (+ (fabs x) (sqrt (+ (* x x) 1)))) (log.f32 x))
(log.f32 x)
(fma.f32 (/.f32 (fabs.f32 x) x) x x)
(copysign.f32 (log.f32 #s(approx (+ (fabs x) (sqrt (+ (* x x) 1))) (fma.f32 (/.f32 (fabs.f32 x) x) x x))) x)
(log.f32 #s(approx (+ (fabs x) (sqrt (+ (* x x) 1))) (fma.f32 (/.f32 (fabs.f32 x) x) x x)))
#s(approx (+ (fabs x) (sqrt (+ (* x x) 1))) (fma.f32 (/.f32 (fabs.f32 x) x) x x))
(copysign.f32 (log.f32 (+.f32 (fabs.f32 x) (sqrt.f32 #s(approx (+ (* x x) 1) (*.f32 x x))))) x)
(log.f32 (+.f32 (fabs.f32 x) (sqrt.f32 #s(approx (+ (* x x) 1) (*.f32 x x)))))
(+.f32 (fabs.f32 x) (sqrt.f32 #s(approx (+ (* x x) 1) (*.f32 x x))))
(copysign.f32 (log.f32 #s(approx (+ (fabs x) (sqrt (+ (* x x) 1))) (*.f32 (-.f32 (/.f32 (fabs.f32 x) x) #s(literal 1 binary32)) x))) x)
(log.f32 #s(approx (+ (fabs x) (sqrt (+ (* x x) 1))) (*.f32 (-.f32 (/.f32 (fabs.f32 x) x) #s(literal 1 binary32)) x)))
#s(approx (+ (fabs x) (sqrt (+ (* x x) 1))) (*.f32 (-.f32 (/.f32 (fabs.f32 x) x) #s(literal 1 binary32)) x))
(*.f32 (-.f32 (/.f32 (fabs.f32 x) x) #s(literal 1 binary32)) x)
(/.f32 (fabs.f32 x) x)
#s(approx (+ (* x x) 1) (*.f32 x x))
(sqrt.f32 #s(approx (+ (* x x) 1) (*.f32 x x)))
Outputs
(copysign.f32 (asinh.f32 (fabs.f32 x)) x)
(log.f32 (+.f32 (cosh.f32 (asinh.f32 x)) (fabs.f32 x)))
(-.f32 (log.f32 (-.f32 (*.f32 x x) (fma.f32 x x #s(literal 1 binary32)))) (log.f32 (-.f32 (fabs.f32 x) (cosh.f32 (asinh.f32 x)))))
(-.f32 (log.f32 (+.f32 (pow.f32 (cosh.f32 (asinh.f32 x)) #s(literal 3 binary32)) (pow.f32 (fabs.f32 x) #s(literal 3 binary32)))) (log.f32 (fma.f32 (cosh.f32 (asinh.f32 x)) (-.f32 (cosh.f32 (asinh.f32 x)) (fabs.f32 x)) (*.f32 x x))))
(asinh.f32 (fabs.f32 x))
(*.f32 (sqrt.f32 (neg.f32 x)) (sqrt.f32 (neg.f32 x)))
(*.f32 (sqrt.f32 (fabs.f32 x)) (sqrt.f32 (fabs.f32 x)))
(*.f32 (sqrt.f32 x) (sqrt.f32 x))
(sqrt.f32 (*.f32 x x))
(pow.f32 (*.f32 x x) #s(literal 1/2 binary32))
(pow.f32 x #s(literal 1 binary32))
(fabs.f32 (neg.f32 (neg.f32 x)))
(fabs.f32 (neg.f32 x))
(fabs.f32 (fabs.f32 x))
(fabs.f32 x)
(copysign.f32 #s(approx (log (+ (fabs x) (sqrt (+ (* x x) 1)))) (log.f32 x)) x)
#s(approx (log (+ (fabs x) (sqrt (+ (* x x) 1)))) (log.f32 x))
(log.f32 x)
(*.f32 (-.f32 (/.f32 (fabs.f32 x) x) #s(literal -1 binary32)) x)
(*.f32 x (-.f32 (/.f32 (fabs.f32 x) x) #s(literal -1 binary32)))
(/.f32 (-.f32 (*.f32 x x) (/.f32 (pow.f32 x #s(literal 4 binary32)) (*.f32 x x))) (-.f32 x (*.f32 (/.f32 (fabs.f32 x) x) x)))
(/.f32 (neg.f32 (-.f32 (/.f32 (pow.f32 x #s(literal 4 binary32)) (*.f32 x x)) (*.f32 x x))) (neg.f32 (-.f32 (*.f32 (/.f32 (fabs.f32 x) x) x) x)))
(/.f32 (neg.f32 (+.f32 (pow.f32 x #s(literal 3 binary32)) (pow.f32 (*.f32 (/.f32 (fabs.f32 x) x) x) #s(literal 3 binary32)))) (neg.f32 (fma.f32 x (-.f32 x (*.f32 (/.f32 (fabs.f32 x) x) x)) (/.f32 (pow.f32 x #s(literal 4 binary32)) (*.f32 x x)))))
(/.f32 (-.f32 (/.f32 (pow.f32 x #s(literal 4 binary32)) (*.f32 x x)) (*.f32 x x)) (-.f32 (*.f32 (/.f32 (fabs.f32 x) x) x) x))
(/.f32 (+.f32 (pow.f32 x #s(literal 3 binary32)) (pow.f32 (*.f32 (/.f32 (fabs.f32 x) x) x) #s(literal 3 binary32))) (fma.f32 x x (-.f32 (/.f32 (pow.f32 x #s(literal 4 binary32)) (*.f32 x x)) (*.f32 (*.f32 (/.f32 (fabs.f32 x) x) x) x))))
(/.f32 (+.f32 (pow.f32 x #s(literal 3 binary32)) (pow.f32 (*.f32 (/.f32 (fabs.f32 x) x) x) #s(literal 3 binary32))) (fma.f32 x (-.f32 x (*.f32 (/.f32 (fabs.f32 x) x) x)) (/.f32 (pow.f32 x #s(literal 4 binary32)) (*.f32 x x))))
(-.f32 (/.f32 (/.f32 (pow.f32 x #s(literal 4 binary32)) (*.f32 x x)) (-.f32 (*.f32 (/.f32 (fabs.f32 x) x) x) x)) (/.f32 (*.f32 x x) (-.f32 (*.f32 (/.f32 (fabs.f32 x) x) x) x)))
(-.f32 x (*.f32 (neg.f32 (/.f32 (fabs.f32 x) x)) x))
(-.f32 x (*.f32 (neg.f32 x) (/.f32 (fabs.f32 x) x)))
(fma.f32 (/.f32 (fabs.f32 x) x) x x)
(fma.f32 (fabs.f32 x) (/.f32 x x) x)
(fma.f32 x (/.f32 (fabs.f32 x) x) x)
(+.f32 (/.f32 (pow.f32 (*.f32 (/.f32 (fabs.f32 x) x) x) #s(literal 3 binary32)) (fma.f32 x (-.f32 x (*.f32 (/.f32 (fabs.f32 x) x) x)) (/.f32 (pow.f32 x #s(literal 4 binary32)) (*.f32 x x)))) (/.f32 (pow.f32 x #s(literal 3 binary32)) (fma.f32 x (-.f32 x (*.f32 (/.f32 (fabs.f32 x) x) x)) (/.f32 (pow.f32 x #s(literal 4 binary32)) (*.f32 x x)))))
(+.f32 (*.f32 (/.f32 (fabs.f32 x) x) x) x)
(+.f32 x (*.f32 (/.f32 (fabs.f32 x) x) x))
(copysign.f32 (log.f32 #s(approx (+ (fabs x) (sqrt (+ (* x x) 1))) (fma.f32 (/.f32 (fabs.f32 x) x) x x))) x)
(log.f32 #s(approx (+ (fabs x) (sqrt (+ (* x x) 1))) (fma.f32 (/.f32 (fabs.f32 x) x) x x)))
#s(approx (+ (fabs x) (sqrt (+ (* x x) 1))) (fma.f32 (/.f32 (fabs.f32 x) x) x x))
(copysign.f32 (log.f32 (+.f32 (sqrt.f32 #s(approx (+ (* x x) 1) (*.f32 x x))) (fabs.f32 x))) x)
(log.f32 (+.f32 (sqrt.f32 #s(approx (+ (* x x) 1) (*.f32 x x))) (fabs.f32 x)))
(-.f32 (log.f32 (-.f32 (*.f32 x x) #s(approx (+ (* x x) 1) (*.f32 x x)))) (log.f32 (-.f32 (fabs.f32 x) (sqrt.f32 #s(approx (+ (* x x) 1) (*.f32 x x))))))
(-.f32 (log.f32 (+.f32 (pow.f32 #s(approx (+ (* x x) 1) (*.f32 x x)) #s(literal 3/2 binary32)) (pow.f32 (fabs.f32 x) #s(literal 3 binary32)))) (log.f32 (-.f32 (fma.f32 x x #s(approx (+ (* x x) 1) (*.f32 x x))) (*.f32 (sqrt.f32 #s(approx (+ (* x x) 1) (*.f32 x x))) (fabs.f32 x)))))
(/.f32 (-.f32 #s(approx (+ (* x x) 1) (*.f32 x x)) (*.f32 x x)) (-.f32 (sqrt.f32 #s(approx (+ (* x x) 1) (*.f32 x x))) (fabs.f32 x)))
(/.f32 (neg.f32 (-.f32 (*.f32 x x) #s(approx (+ (* x x) 1) (*.f32 x x)))) (neg.f32 (-.f32 (fabs.f32 x) (sqrt.f32 #s(approx (+ (* x x) 1) (*.f32 x x))))))
(/.f32 (neg.f32 (+.f32 (pow.f32 #s(approx (+ (* x x) 1) (*.f32 x x)) #s(literal 3/2 binary32)) (pow.f32 (fabs.f32 x) #s(literal 3 binary32)))) (neg.f32 (-.f32 (fma.f32 x x #s(approx (+ (* x x) 1) (*.f32 x x))) (*.f32 (sqrt.f32 #s(approx (+ (* x x) 1) (*.f32 x x))) (fabs.f32 x)))))
(/.f32 (-.f32 (*.f32 x x) #s(approx (+ (* x x) 1) (*.f32 x x))) (-.f32 (fabs.f32 x) (sqrt.f32 #s(approx (+ (* x x) 1) (*.f32 x x)))))
(/.f32 (+.f32 (pow.f32 #s(approx (+ (* x x) 1) (*.f32 x x)) #s(literal 3/2 binary32)) (pow.f32 (fabs.f32 x) #s(literal 3 binary32))) (+.f32 #s(approx (+ (* x x) 1) (*.f32 x x)) (-.f32 (*.f32 x x) (*.f32 (sqrt.f32 #s(approx (+ (* x x) 1) (*.f32 x x))) (fabs.f32 x)))))
(/.f32 (+.f32 (pow.f32 #s(approx (+ (* x x) 1) (*.f32 x x)) #s(literal 3/2 binary32)) (pow.f32 (fabs.f32 x) #s(literal 3 binary32))) (-.f32 (fma.f32 x x #s(approx (+ (* x x) 1) (*.f32 x x))) (*.f32 (sqrt.f32 #s(approx (+ (* x x) 1) (*.f32 x x))) (fabs.f32 x))))
(-.f32 (/.f32 (*.f32 x x) (-.f32 (fabs.f32 x) (sqrt.f32 #s(approx (+ (* x x) 1) (*.f32 x x))))) (/.f32 #s(approx (+ (* x x) 1) (*.f32 x x)) (-.f32 (fabs.f32 x) (sqrt.f32 #s(approx (+ (* x x) 1) (*.f32 x x))))))
(fma.f32 (pow.f32 #s(approx (+ (* x x) 1) (*.f32 x x)) #s(literal 1/4 binary32)) (pow.f32 #s(approx (+ (* x x) 1) (*.f32 x x)) #s(literal 1/4 binary32)) (fabs.f32 x))
(fma.f32 (sqrt.f32 (neg.f32 x)) (sqrt.f32 (neg.f32 x)) (sqrt.f32 #s(approx (+ (* x x) 1) (*.f32 x x))))
(fma.f32 (sqrt.f32 (fabs.f32 x)) (sqrt.f32 (fabs.f32 x)) (sqrt.f32 #s(approx (+ (* x x) 1) (*.f32 x x))))
(fma.f32 (sqrt.f32 x) (sqrt.f32 x) (sqrt.f32 #s(approx (+ (* x x) 1) (*.f32 x x))))
(+.f32 (/.f32 (pow.f32 (fabs.f32 x) #s(literal 3 binary32)) (-.f32 (fma.f32 x x #s(approx (+ (* x x) 1) (*.f32 x x))) (*.f32 (sqrt.f32 #s(approx (+ (* x x) 1) (*.f32 x x))) (fabs.f32 x)))) (/.f32 (pow.f32 #s(approx (+ (* x x) 1) (*.f32 x x)) #s(literal 3/2 binary32)) (-.f32 (fma.f32 x x #s(approx (+ (* x x) 1) (*.f32 x x))) (*.f32 (sqrt.f32 #s(approx (+ (* x x) 1) (*.f32 x x))) (fabs.f32 x)))))
(+.f32 (sqrt.f32 #s(approx (+ (* x x) 1) (*.f32 x x))) (fabs.f32 x))
(+.f32 (fabs.f32 x) (sqrt.f32 #s(approx (+ (* x x) 1) (*.f32 x x))))
(copysign.f32 (log.f32 #s(approx (+ (fabs x) (sqrt (+ (* x x) 1))) (*.f32 (-.f32 (/.f32 (fabs.f32 x) x) #s(literal 1 binary32)) x))) x)
(log.f32 #s(approx (+ (fabs x) (sqrt (+ (* x x) 1))) (*.f32 (-.f32 (/.f32 (fabs.f32 x) x) #s(literal 1 binary32)) x)))
#s(approx (+ (fabs x) (sqrt (+ (* x x) 1))) (*.f32 (-.f32 (/.f32 (fabs.f32 x) x) #s(literal 1 binary32)) x))
(*.f32 (-.f32 (/.f32 (fabs.f32 x) x) #s(literal 1 binary32)) x)
(*.f32 x (-.f32 (/.f32 (fabs.f32 x) x) #s(literal 1 binary32)))
(/.f32 (*.f32 (-.f32 (pow.f32 (/.f32 (fabs.f32 x) x) #s(literal 2 binary32)) #s(literal 1 binary32)) x) (-.f32 (/.f32 (fabs.f32 x) x) #s(literal -1 binary32)))
(/.f32 (*.f32 (-.f32 (pow.f32 (/.f32 (fabs.f32 x) x) #s(literal 3 binary32)) #s(literal 1 binary32)) x) (+.f32 (+.f32 (pow.f32 (/.f32 (fabs.f32 x) x) #s(literal 2 binary32)) #s(literal 1 binary32)) (/.f32 (fabs.f32 x) x)))
(/.f32 (*.f32 x (-.f32 (pow.f32 (/.f32 (fabs.f32 x) x) #s(literal 2 binary32)) #s(literal 1 binary32))) (-.f32 (/.f32 (fabs.f32 x) x) #s(literal -1 binary32)))
(/.f32 (*.f32 x (-.f32 (pow.f32 (/.f32 (fabs.f32 x) x) #s(literal 3 binary32)) #s(literal 1 binary32))) (+.f32 (+.f32 (pow.f32 (/.f32 (fabs.f32 x) x) #s(literal 2 binary32)) #s(literal 1 binary32)) (/.f32 (fabs.f32 x) x)))
(*.f32 (/.f32 (fabs.f32 x) x) #s(literal 1 binary32))
(*.f32 #s(literal 1 binary32) (/.f32 (fabs.f32 x) x))
(/.f32 (*.f32 (neg.f32 (fabs.f32 x)) #s(literal 1 binary32)) (neg.f32 x))
(/.f32 (*.f32 (fabs.f32 x) #s(literal 1 binary32)) x)
(/.f32 (neg.f32 (neg.f32 (fabs.f32 x))) (neg.f32 (neg.f32 x)))
(/.f32 (neg.f32 (fabs.f32 x)) (neg.f32 x))
(/.f32 (fabs.f32 x) x)
(neg.f32 (/.f32 (neg.f32 (fabs.f32 x)) x))
(neg.f32 (/.f32 (fabs.f32 x) (neg.f32 x)))
(*.f32 (neg.f32 (sqrt.f32 #s(approx (+ (* x x) 1) (*.f32 x x)))) (neg.f32 (sqrt.f32 #s(approx (+ (* x x) 1) (*.f32 x x)))))
(*.f32 (fabs.f32 (sqrt.f32 #s(approx (+ (* x x) 1) (*.f32 x x)))) (fabs.f32 (sqrt.f32 #s(approx (+ (* x x) 1) (*.f32 x x)))))
(*.f32 (sqrt.f32 #s(approx (+ (* x x) 1) (*.f32 x x))) (sqrt.f32 #s(approx (+ (* x x) 1) (*.f32 x x))))
#s(approx (+ (* x x) 1) (*.f32 x x))
(sqrt.f32 (*.f32 #s(approx (+ (* x x) 1) (*.f32 x x)) #s(approx (+ (* x x) 1) (*.f32 x x))))
(pow.f32 (*.f32 #s(approx (+ (* x x) 1) (*.f32 x x)) #s(approx (+ (* x x) 1) (*.f32 x x))) #s(literal 1/2 binary32))
(pow.f32 (sqrt.f32 #s(approx (+ (* x x) 1) (*.f32 x x))) #s(literal 2 binary32))
(pow.f32 #s(approx (+ (* x x) 1) (*.f32 x x)) #s(literal 1 binary32))
(*.f32 (pow.f32 #s(approx (+ (* x x) 1) (*.f32 x x)) #s(literal 1/4 binary32)) (pow.f32 #s(approx (+ (* x x) 1) (*.f32 x x)) #s(literal 1/4 binary32)))
(sqrt.f32 #s(approx (+ (* x x) 1) (*.f32 x x)))
(pow.f32 #s(approx (+ (* x x) 1) (*.f32 x x)) #s(literal 1/2 binary32))
(exp.f32 (*.f32 (log.f32 #s(approx (+ (* x x) 1) (*.f32 x x))) #s(literal 1/2 binary32)))

eval19.0ms (0.5%)

Memory
-4.4MiB live, 40.6MiB allocated; 5ms collecting garbage
Compiler

Compiled 4 105 to 805 computations (80.4% saved)

prune6.0ms (0.1%)

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

5 alts after pruning (3 fresh and 2 done)

PrunedKeptTotal
New1692171
Fresh011
Picked325
Done000
Total1725177
Accuracy
100.0%
Counts
177 → 5
Alt Table
Click to see full alt table
StatusAccuracyProgram
34.0%
(copysign.f32 (log.f32 #s(approx (+ (fabs x) (sqrt (+ (* x x) 1))) #s(approx (+ (* (/ (fabs x) x) x) x) (+.f32 (fabs.f32 x) x)))) x)
29.5%
(copysign.f32 (log.f32 #s(approx (+ (fabs x) (sqrt (+ (* x x) 1))) #s(approx (* (- (/ (fabs x) x) 1) x) (-.f32 (fabs.f32 x) x)))) x)
99.6%
(copysign.f32 (asinh.f32 (fabs.f32 x)) x)
49.6%
(copysign.f32 #s(approx (log (+ (fabs x) (sqrt (+ (* x x) 1)))) (fma.f32 (fma.f32 (*.f32 #s(literal -1/24 binary32) (*.f32 x x)) (/.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (/.f32 #s(literal 1/2 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32)))) (*.f32 x x) (log1p.f32 (fabs.f32 x)))) x)
15.2%
(copysign.f32 #s(approx (log (+ (fabs x) (sqrt (+ (* x x) 1)))) (log.f32 x)) x)
Compiler

Compiled 117 to 72 computations (38.5% saved)

simplify188.0ms (4.5%)

Memory
-8.1MiB live, 171.2MiB allocated; 41ms collecting garbage
Localize:

Found 12 expressions of interest:

NewMetricScoreProgram
cost-diff0
#s(approx (+ (* (/ (fabs x) x) x) x) (+.f32 (fabs.f32 x) x))
cost-diff0
#s(approx (+ (fabs x) (sqrt (+ (* x x) 1))) #s(approx (+ (* (/ (fabs x) x) x) x) (+.f32 (fabs.f32 x) x)))
cost-diff0
(log.f32 #s(approx (+ (fabs x) (sqrt (+ (* x x) 1))) #s(approx (+ (* (/ (fabs x) x) x) x) (+.f32 (fabs.f32 x) x))))
cost-diff0
(copysign.f32 (log.f32 #s(approx (+ (fabs x) (sqrt (+ (* x x) 1))) #s(approx (+ (* (/ (fabs x) x) x) x) (+.f32 (fabs.f32 x) x)))) x)
cost-diff0
#s(approx (* (- (/ (fabs x) x) 1) x) (-.f32 (fabs.f32 x) x))
cost-diff0
#s(approx (+ (fabs x) (sqrt (+ (* x x) 1))) #s(approx (* (- (/ (fabs x) x) 1) x) (-.f32 (fabs.f32 x) x)))
cost-diff0
(log.f32 #s(approx (+ (fabs x) (sqrt (+ (* x x) 1))) #s(approx (* (- (/ (fabs x) x) 1) x) (-.f32 (fabs.f32 x) x))))
cost-diff0
(copysign.f32 (log.f32 #s(approx (+ (fabs x) (sqrt (+ (* x x) 1))) #s(approx (* (- (/ (fabs x) x) 1) x) (-.f32 (fabs.f32 x) x)))) x)
cost-diff0
(fma.f32 (fma.f32 (*.f32 #s(literal -1/24 binary32) (*.f32 x x)) (/.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (/.f32 #s(literal 1/2 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32)))) (*.f32 x x) (log1p.f32 (fabs.f32 x)))
cost-diff0
#s(approx (log (+ (fabs x) (sqrt (+ (* x x) 1)))) (fma.f32 (fma.f32 (*.f32 #s(literal -1/24 binary32) (*.f32 x x)) (/.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (/.f32 #s(literal 1/2 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32)))) (*.f32 x x) (log1p.f32 (fabs.f32 x))))
cost-diff0
(copysign.f32 #s(approx (log (+ (fabs x) (sqrt (+ (* x x) 1)))) (fma.f32 (fma.f32 (*.f32 #s(literal -1/24 binary32) (*.f32 x x)) (/.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (/.f32 #s(literal 1/2 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32)))) (*.f32 x x) (log1p.f32 (fabs.f32 x)))) x)
cost-diff7
(fma.f32 (*.f32 #s(literal -1/24 binary32) (*.f32 x x)) (/.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (/.f32 #s(literal 1/2 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))))
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
040386
062386
195370
2226362
31071346
45154346
08239334
Stop Event
iter limit
node limit
iter limit
Calls
Call 1
Inputs
(copysign.f32 #s(approx (log (+ (fabs x) (sqrt (+ (* x x) 1)))) (fma.f32 (fma.f32 (*.f32 #s(literal -1/24 binary32) (*.f32 x x)) (/.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (/.f32 #s(literal 1/2 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32)))) (*.f32 x x) (log1p.f32 (fabs.f32 x)))) x)
#s(approx (log (+ (fabs x) (sqrt (+ (* x x) 1)))) (fma.f32 (fma.f32 (*.f32 #s(literal -1/24 binary32) (*.f32 x x)) (/.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (/.f32 #s(literal 1/2 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32)))) (*.f32 x x) (log1p.f32 (fabs.f32 x))))
(fma.f32 (fma.f32 (*.f32 #s(literal -1/24 binary32) (*.f32 x x)) (/.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (/.f32 #s(literal 1/2 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32)))) (*.f32 x x) (log1p.f32 (fabs.f32 x)))
(fma.f32 (*.f32 #s(literal -1/24 binary32) (*.f32 x x)) (/.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (/.f32 #s(literal 1/2 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))))
(*.f32 #s(literal -1/24 binary32) (*.f32 x x))
#s(literal -1/24 binary32)
(*.f32 x x)
x
(/.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32)))
(+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32))
(/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32)))
#s(literal 3 binary32)
(-.f32 (fabs.f32 x) #s(literal -1 binary32))
(fabs.f32 x)
#s(literal -1 binary32)
(/.f32 #s(literal 1/2 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32)))
#s(literal 1/2 binary32)
(log1p.f32 (fabs.f32 x))
(copysign.f32 (log.f32 #s(approx (+ (fabs x) (sqrt (+ (* x x) 1))) #s(approx (* (- (/ (fabs x) x) 1) x) (-.f32 (fabs.f32 x) x)))) x)
(log.f32 #s(approx (+ (fabs x) (sqrt (+ (* x x) 1))) #s(approx (* (- (/ (fabs x) x) 1) x) (-.f32 (fabs.f32 x) x))))
#s(approx (+ (fabs x) (sqrt (+ (* x x) 1))) #s(approx (* (- (/ (fabs x) x) 1) x) (-.f32 (fabs.f32 x) x)))
#s(approx (* (- (/ (fabs x) x) 1) x) (-.f32 (fabs.f32 x) x))
(-.f32 (fabs.f32 x) x)
(fabs.f32 x)
x
(copysign.f32 (log.f32 #s(approx (+ (fabs x) (sqrt (+ (* x x) 1))) #s(approx (+ (* (/ (fabs x) x) x) x) (+.f32 (fabs.f32 x) x)))) x)
(log.f32 #s(approx (+ (fabs x) (sqrt (+ (* x x) 1))) #s(approx (+ (* (/ (fabs x) x) x) x) (+.f32 (fabs.f32 x) x))))
#s(approx (+ (fabs x) (sqrt (+ (* x x) 1))) #s(approx (+ (* (/ (fabs x) x) x) x) (+.f32 (fabs.f32 x) x)))
#s(approx (+ (* (/ (fabs x) x) x) x) (+.f32 (fabs.f32 x) x))
(+.f32 (fabs.f32 x) x)
(fabs.f32 x)
x
Outputs
(copysign.f32 #s(approx (log (+ (fabs x) (sqrt (+ (* x x) 1)))) (fma.f32 (fma.f32 (*.f32 #s(literal -1/24 binary32) (*.f32 x x)) (/.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (/.f32 #s(literal 1/2 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32)))) (*.f32 x x) (log1p.f32 (fabs.f32 x)))) x)
(copysign.f32 #s(approx (log (+ (fabs x) (sqrt (+ (* x x) 1)))) (fma.f32 (*.f32 (fma.f32 (*.f32 (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) x) x #s(literal 1/2 binary32)) (/.f32 x (-.f32 (fabs.f32 x) #s(literal -1 binary32)))) x (log1p.f32 (fabs.f32 x)))) x)
#s(approx (log (+ (fabs x) (sqrt (+ (* x x) 1)))) (fma.f32 (fma.f32 (*.f32 #s(literal -1/24 binary32) (*.f32 x x)) (/.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (/.f32 #s(literal 1/2 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32)))) (*.f32 x x) (log1p.f32 (fabs.f32 x))))
#s(approx (log (+ (fabs x) (sqrt (+ (* x x) 1)))) (fma.f32 (*.f32 (fma.f32 (*.f32 (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) x) x #s(literal 1/2 binary32)) (/.f32 x (-.f32 (fabs.f32 x) #s(literal -1 binary32)))) x (log1p.f32 (fabs.f32 x))))
(fma.f32 (fma.f32 (*.f32 #s(literal -1/24 binary32) (*.f32 x x)) (/.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (/.f32 #s(literal 1/2 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32)))) (*.f32 x x) (log1p.f32 (fabs.f32 x)))
(fma.f32 (*.f32 (fma.f32 (*.f32 (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) x) x #s(literal 1/2 binary32)) (/.f32 x (-.f32 (fabs.f32 x) #s(literal -1 binary32)))) x (log1p.f32 (fabs.f32 x)))
(fma.f32 (*.f32 #s(literal -1/24 binary32) (*.f32 x x)) (/.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (/.f32 #s(literal 1/2 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))))
(/.f32 (fma.f32 (*.f32 (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) x) x #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32)))
(*.f32 #s(literal -1/24 binary32) (*.f32 x x))
(*.f32 (*.f32 x x) #s(literal -1/24 binary32))
#s(literal -1/24 binary32)
(*.f32 x x)
x
(/.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32)))
(+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32))
(/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32)))
#s(literal 3 binary32)
(-.f32 (fabs.f32 x) #s(literal -1 binary32))
(fabs.f32 x)
#s(literal -1 binary32)
(/.f32 #s(literal 1/2 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32)))
#s(literal 1/2 binary32)
(log1p.f32 (fabs.f32 x))
(copysign.f32 (log.f32 #s(approx (+ (fabs x) (sqrt (+ (* x x) 1))) #s(approx (* (- (/ (fabs x) x) 1) x) (-.f32 (fabs.f32 x) x)))) x)
(log.f32 #s(approx (+ (fabs x) (sqrt (+ (* x x) 1))) #s(approx (* (- (/ (fabs x) x) 1) x) (-.f32 (fabs.f32 x) x))))
#s(approx (+ (fabs x) (sqrt (+ (* x x) 1))) #s(approx (* (- (/ (fabs x) x) 1) x) (-.f32 (fabs.f32 x) x)))
#s(approx (* (- (/ (fabs x) x) 1) x) (-.f32 (fabs.f32 x) x))
(-.f32 (fabs.f32 x) x)
(fabs.f32 x)
x
(copysign.f32 (log.f32 #s(approx (+ (fabs x) (sqrt (+ (* x x) 1))) #s(approx (+ (* (/ (fabs x) x) x) x) (+.f32 (fabs.f32 x) x)))) x)
(log.f32 #s(approx (+ (fabs x) (sqrt (+ (* x x) 1))) #s(approx (+ (* (/ (fabs x) x) x) x) (+.f32 (fabs.f32 x) x))))
#s(approx (+ (fabs x) (sqrt (+ (* x x) 1))) #s(approx (+ (* (/ (fabs x) x) x) x) (+.f32 (fabs.f32 x) x)))
#s(approx (+ (* (/ (fabs x) x) x) x) (+.f32 (fabs.f32 x) x))
(+.f32 (fabs.f32 x) x)
(fabs.f32 x)
x

localize156.0ms (3.7%)

Memory
8.9MiB live, 160.4MiB allocated; 49ms collecting garbage
Localize:

Found 12 expressions of interest:

NewMetricScoreProgram
accuracy0.0
(fabs.f32 x)
accuracy0.0
#s(approx (+ (* (/ (fabs x) x) x) x) (+.f32 (fabs.f32 x) x))
accuracy11.097660503050301
(log.f32 #s(approx (+ (fabs x) (sqrt (+ (* x x) 1))) #s(approx (+ (* (/ (fabs x) x) x) x) (+.f32 (fabs.f32 x) x))))
accuracy21.119312323883808
#s(approx (+ (fabs x) (sqrt (+ (* x x) 1))) #s(approx (+ (* (/ (fabs x) x) x) x) (+.f32 (fabs.f32 x) x)))
accuracy0.0
(fabs.f32 x)
accuracy0.0
#s(approx (* (- (/ (fabs x) x) 1) x) (-.f32 (fabs.f32 x) x))
accuracy11.097660503050301
(log.f32 #s(approx (+ (fabs x) (sqrt (+ (* x x) 1))) #s(approx (* (- (/ (fabs x) x) 1) x) (-.f32 (fabs.f32 x) x))))
accuracy22.594307611973587
#s(approx (+ (fabs x) (sqrt (+ (* x x) 1))) #s(approx (* (- (/ (fabs x) x) 1) x) (-.f32 (fabs.f32 x) x)))
accuracy0.0546875
(/.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32)))
accuracy0.27817975959707264
(*.f32 #s(literal -1/24 binary32) (*.f32 x x))
accuracy7.2035006202930925
(fma.f32 (*.f32 #s(literal -1/24 binary32) (*.f32 x x)) (/.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (/.f32 #s(literal 1/2 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))))
accuracy17.232882982439897
#s(approx (log (+ (fabs x) (sqrt (+ (* x x) 1)))) (fma.f32 (fma.f32 (*.f32 #s(literal -1/24 binary32) (*.f32 x x)) (/.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (/.f32 #s(literal 1/2 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32)))) (*.f32 x x) (log1p.f32 (fabs.f32 x))))
Samples
67.0ms175×0valid
51.0ms81×1valid
Compiler

Compiled 235 to 32 computations (86.4% saved)

Precisions
Click to see histograms. Total time spent on operations: 88.0ms
ival-fabs: 25.0ms (28.5% of total)
const: 10.0ms (11.4% of total)
ival-mult: 9.0ms (10.3% of total)
ival-div: 8.0ms (9.1% of total)
ival-add: 8.0ms (9.1% of total)
ival-hypot: 7.0ms (8% of total)
adjust: 6.0ms (6.8% of total)
ival-log: 5.0ms (5.7% of total)
ival-sub: 4.0ms (4.6% of total)
ival-copysign: 3.0ms (3.4% of total)
ival-log1p: 3.0ms (3.4% of total)
exact: 1.0ms (1.1% of total)
ival-assert: 0.0ms (0% of total)
ival-true: 0.0ms (0% of total)

series61.0ms (1.5%)

Memory
-29.8MiB live, 14.2MiB allocated; 13ms collecting garbage
Counts
15 → 40
Calls
Call 1
Inputs
(fma.f32 (*.f32 #s(literal -1/24 binary32) (*.f32 x x)) (/.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (/.f32 #s(literal 1/2 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))))
(copysign.f32 #s(approx (log (+ (fabs x) (sqrt (+ (* x x) 1)))) (fma.f32 (fma.f32 (*.f32 #s(literal -1/24 binary32) (*.f32 x x)) (/.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (/.f32 #s(literal 1/2 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32)))) (*.f32 x x) (log1p.f32 (fabs.f32 x)))) x)
#s(approx (log (+ (fabs x) (sqrt (+ (* x x) 1)))) (fma.f32 (fma.f32 (*.f32 #s(literal -1/24 binary32) (*.f32 x x)) (/.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (/.f32 #s(literal 1/2 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32)))) (*.f32 x x) (log1p.f32 (fabs.f32 x))))
(fma.f32 (fma.f32 (*.f32 #s(literal -1/24 binary32) (*.f32 x x)) (/.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (/.f32 #s(literal 1/2 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32)))) (*.f32 x x) (log1p.f32 (fabs.f32 x)))
(copysign.f32 (log.f32 #s(approx (+ (fabs x) (sqrt (+ (* x x) 1))) #s(approx (* (- (/ (fabs x) x) 1) x) (-.f32 (fabs.f32 x) x)))) x)
(log.f32 #s(approx (+ (fabs x) (sqrt (+ (* x x) 1))) #s(approx (* (- (/ (fabs x) x) 1) x) (-.f32 (fabs.f32 x) x))))
#s(approx (+ (fabs x) (sqrt (+ (* x x) 1))) #s(approx (* (- (/ (fabs x) x) 1) x) (-.f32 (fabs.f32 x) x)))
#s(approx (* (- (/ (fabs x) x) 1) x) (-.f32 (fabs.f32 x) x))
(copysign.f32 (log.f32 #s(approx (+ (fabs x) (sqrt (+ (* x x) 1))) #s(approx (+ (* (/ (fabs x) x) x) x) (+.f32 (fabs.f32 x) x)))) x)
(log.f32 #s(approx (+ (fabs x) (sqrt (+ (* x x) 1))) #s(approx (+ (* (/ (fabs x) x) x) x) (+.f32 (fabs.f32 x) x))))
#s(approx (+ (fabs x) (sqrt (+ (* x x) 1))) #s(approx (+ (* (/ (fabs x) x) x) x) (+.f32 (fabs.f32 x) x)))
#s(approx (+ (* (/ (fabs x) x) x) x) (+.f32 (fabs.f32 x) x))
(*.f32 #s(literal -1/24 binary32) (*.f32 x x))
(/.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32)))
(fabs.f32 x)
Outputs
(/ 1/2 (+ 1 (fabs x)))
(+ (* -1/24 (/ (* (pow x 2) (+ 3 (* 3 (/ 1 (+ 1 (fabs x)))))) (+ 1 (fabs x)))) (* 1/2 (/ 1 (+ 1 (fabs x)))))
(copysign (log (+ (fabs x) (sqrt (+ 1 (pow x 2))))) x)
(log (+ 1 (fabs x)))
(+ (log (+ 1 (fabs x))) (* 1/2 (/ (pow x 2) (+ 1 (fabs x)))))
(+ (log (+ 1 (fabs x))) (* (pow x 2) (+ (* -1/24 (* (pow x 2) (+ (* 3 (/ 1 (+ 1 (fabs x)))) (* 3 (/ 1 (pow (+ 1 (fabs x)) 2)))))) (* 1/2 (/ 1 (+ 1 (fabs x)))))))
(+ (log (+ 1 (fabs x))) (* (pow x 2) (+ (* (pow x 2) (+ (* -1/24 (+ (* 3 (/ 1 (+ 1 (fabs x)))) (* 3 (/ 1 (pow (+ 1 (fabs x)) 2))))) (* 1/720 (* (pow x 2) (+ (* 45 (/ 1 (+ 1 (fabs x)))) (+ (* 45 (/ 1 (pow (+ 1 (fabs x)) 2))) (* 30 (/ 1 (pow (+ 1 (fabs x)) 3))))))))) (* 1/2 (/ 1 (+ 1 (fabs x)))))))
(+ (log (+ 1 (fabs x))) (* (pow x 2) (+ (* -1/24 (/ (* (pow x 2) (+ 3 (* 3 (/ 1 (+ 1 (fabs x)))))) (+ 1 (fabs x)))) (* 1/2 (/ 1 (+ 1 (fabs x)))))))
(+ 1 (fabs x))
(+ 1 (+ (fabs x) (* 1/2 (pow x 2))))
(+ 1 (+ (fabs x) (* (pow x 2) (+ 1/2 (* -1/8 (pow x 2))))))
(+ 1 (+ (fabs x) (* (pow x 2) (+ 1/2 (* (pow x 2) (- (* 1/16 (pow x 2)) 1/8))))))
(fabs x)
(+ (fabs x) (* -1 x))
(+ x (fabs x))
(* -1/24 (pow x 2))
(/ (+ 3 (* 3 (/ 1 (+ 1 (fabs x))))) (+ 1 (fabs x)))
(* -1/24 (/ (* (pow x 2) (+ 3 (* 3 (/ 1 (+ 1 (fabs x)))))) (+ 1 (fabs x))))
(* (pow x 2) (+ (* -1/24 (/ (+ 3 (* 3 (/ 1 (+ 1 (fabs x))))) (+ 1 (fabs x)))) (* 1/2 (/ 1 (* (pow x 2) (+ 1 (fabs x)))))))
(* -1 (log (/ 1 x)))
(+ (* -1 (log (/ 1 x))) (/ (fabs x) x))
(+ (* -1 (log (/ 1 x))) (+ (* 1/2 (/ (+ 1 (* -1 (pow (fabs x) 2))) (pow x 2))) (/ (fabs x) x)))
(+ (* -1 (log (/ 1 x))) (+ (* 1/6 (/ (+ (* -3 (fabs x)) (* 2 (pow (fabs x) 3))) (pow x 3))) (+ (* 1/2 (/ (+ 1 (* -1 (pow (fabs x) 2))) (pow x 2))) (/ (fabs x) x))))
(* -1/24 (/ (* (pow x 4) (+ 3 (* 3 (/ 1 (+ 1 (fabs x)))))) (+ 1 (fabs x))))
(* (pow x 4) (+ (* -1/24 (/ (+ 3 (* 3 (/ 1 (+ 1 (fabs x))))) (+ 1 (fabs x)))) (* 1/2 (/ 1 (* (pow x 2) (+ 1 (fabs x)))))))
(* (pow x 4) (+ (* -1/24 (/ (+ 3 (* 3 (/ 1 (+ 1 (fabs x))))) (+ 1 (fabs x)))) (+ (/ 1/2 (* (pow x 2) (+ 1 (fabs x)))) (/ (log (+ 1 (fabs x))) (pow x 4)))))
x
(* x (+ 1 (/ (fabs x) x)))
(* x (+ 1 (+ (/ 1/2 (pow x 2)) (/ (fabs x) x))))
(* x (- (+ 1 (+ (/ 1/2 (pow x 2)) (/ (fabs x) x))) (* 1/8 (/ 1 (pow x 4)))))
(* -1 x)
(* x (- (/ (fabs x) x) 1))
(* -1 (log (/ -1 x)))
(+ (* -1 (log (/ -1 x))) (* -1 (/ (fabs x) x)))
(+ (* -1 (log (/ -1 x))) (* -1 (/ (+ (fabs x) (* -1/2 (/ (+ 1 (* -1 (pow (fabs x) 2))) x))) x)))
(+ (* -1 (log (/ -1 x))) (* -1 (/ (+ (fabs x) (* -1 (/ (+ (* -1/6 (/ (+ (* -3 (fabs x)) (* 2 (pow (fabs x) 3))) x)) (* 1/2 (+ 1 (* -1 (pow (fabs x) 2))))) x))) x)))
(* -1 (* x (+ 1 (* -1 (/ (fabs x) x)))))
(* -1 (* x (+ 1 (* -1 (/ (- (fabs x) (* 1/2 (/ 1 x))) x)))))
(* -1 (* x (+ 1 (* -1 (/ (+ (fabs x) (* -1 (/ (- 1/2 (* 1/8 (/ 1 (pow x 2)))) x))) x)))))
(* -1 (* x (- (* -1 (/ (fabs x) x)) 1)))
Calls

3 calls:

TimeVariablePointExpression
52.0ms
x
@-inf
((+ (* (* -1/24 (* x x)) (/ (+ (/ 3 (- (fabs x) -1)) 3) (- (fabs x) -1))) (/ 1/2 (- (fabs x) -1))) (copysign (log (+ (fabs x) (sqrt (+ (* x x) 1)))) x) (log (+ (fabs x) (sqrt (+ (* x x) 1)))) (+ (* (+ (* (* -1/24 (* x x)) (/ (+ (/ 3 (- (fabs x) -1)) 3) (- (fabs x) -1))) (/ 1/2 (- (fabs x) -1))) (* x x)) (log (+ 1 (fabs x)))) (copysign (log (+ (fabs x) (sqrt (+ (* x x) 1)))) x) (log (+ (fabs x) (sqrt (+ (* x x) 1)))) (+ (fabs x) (sqrt (+ (* x x) 1))) (* (- (/ (fabs x) x) 1) x) (copysign (log (+ (fabs x) (sqrt (+ (* x x) 1)))) x) (log (+ (fabs x) (sqrt (+ (* x x) 1)))) (+ (fabs x) (sqrt (+ (* x x) 1))) (+ (* (/ (fabs x) x) x) x) (* -1/24 (* x x)) (/ (+ (/ 3 (- (fabs x) -1)) 3) (- (fabs x) -1)) (fabs x))
4.0ms
x
@inf
((+ (* (* -1/24 (* x x)) (/ (+ (/ 3 (- (fabs x) -1)) 3) (- (fabs x) -1))) (/ 1/2 (- (fabs x) -1))) (copysign (log (+ (fabs x) (sqrt (+ (* x x) 1)))) x) (log (+ (fabs x) (sqrt (+ (* x x) 1)))) (+ (* (+ (* (* -1/24 (* x x)) (/ (+ (/ 3 (- (fabs x) -1)) 3) (- (fabs x) -1))) (/ 1/2 (- (fabs x) -1))) (* x x)) (log (+ 1 (fabs x)))) (copysign (log (+ (fabs x) (sqrt (+ (* x x) 1)))) x) (log (+ (fabs x) (sqrt (+ (* x x) 1)))) (+ (fabs x) (sqrt (+ (* x x) 1))) (* (- (/ (fabs x) x) 1) x) (copysign (log (+ (fabs x) (sqrt (+ (* x x) 1)))) x) (log (+ (fabs x) (sqrt (+ (* x x) 1)))) (+ (fabs x) (sqrt (+ (* x x) 1))) (+ (* (/ (fabs x) x) x) x) (* -1/24 (* x x)) (/ (+ (/ 3 (- (fabs x) -1)) 3) (- (fabs x) -1)) (fabs x))
4.0ms
x
@0
((+ (* (* -1/24 (* x x)) (/ (+ (/ 3 (- (fabs x) -1)) 3) (- (fabs x) -1))) (/ 1/2 (- (fabs x) -1))) (copysign (log (+ (fabs x) (sqrt (+ (* x x) 1)))) x) (log (+ (fabs x) (sqrt (+ (* x x) 1)))) (+ (* (+ (* (* -1/24 (* x x)) (/ (+ (/ 3 (- (fabs x) -1)) 3) (- (fabs x) -1))) (/ 1/2 (- (fabs x) -1))) (* x x)) (log (+ 1 (fabs x)))) (copysign (log (+ (fabs x) (sqrt (+ (* x x) 1)))) x) (log (+ (fabs x) (sqrt (+ (* x x) 1)))) (+ (fabs x) (sqrt (+ (* x x) 1))) (* (- (/ (fabs x) x) 1) x) (copysign (log (+ (fabs x) (sqrt (+ (* x x) 1)))) x) (log (+ (fabs x) (sqrt (+ (* x x) 1)))) (+ (fabs x) (sqrt (+ (* x x) 1))) (+ (* (/ (fabs x) x) x) x) (* -1/24 (* x x)) (/ (+ (/ 3 (- (fabs x) -1)) 3) (- (fabs x) -1)) (fabs x))

simplify180.0ms (4.3%)

Memory
35.9MiB live, 176.2MiB allocated; 38ms collecting garbage
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0179689
1611610
22622583
08412547
Stop Event
iter limit
node limit
Counts
40 → 39
Calls
Call 1
Inputs
(/ 1/2 (+ 1 (fabs x)))
(+ (* -1/24 (/ (* (pow x 2) (+ 3 (* 3 (/ 1 (+ 1 (fabs x)))))) (+ 1 (fabs x)))) (* 1/2 (/ 1 (+ 1 (fabs x)))))
(copysign (log (+ (fabs x) (sqrt (+ 1 (pow x 2))))) x)
(log (+ 1 (fabs x)))
(+ (log (+ 1 (fabs x))) (* 1/2 (/ (pow x 2) (+ 1 (fabs x)))))
(+ (log (+ 1 (fabs x))) (* (pow x 2) (+ (* -1/24 (* (pow x 2) (+ (* 3 (/ 1 (+ 1 (fabs x)))) (* 3 (/ 1 (pow (+ 1 (fabs x)) 2)))))) (* 1/2 (/ 1 (+ 1 (fabs x)))))))
(+ (log (+ 1 (fabs x))) (* (pow x 2) (+ (* (pow x 2) (+ (* -1/24 (+ (* 3 (/ 1 (+ 1 (fabs x)))) (* 3 (/ 1 (pow (+ 1 (fabs x)) 2))))) (* 1/720 (* (pow x 2) (+ (* 45 (/ 1 (+ 1 (fabs x)))) (+ (* 45 (/ 1 (pow (+ 1 (fabs x)) 2))) (* 30 (/ 1 (pow (+ 1 (fabs x)) 3))))))))) (* 1/2 (/ 1 (+ 1 (fabs x)))))))
(+ (log (+ 1 (fabs x))) (* (pow x 2) (+ (* -1/24 (/ (* (pow x 2) (+ 3 (* 3 (/ 1 (+ 1 (fabs x)))))) (+ 1 (fabs x)))) (* 1/2 (/ 1 (+ 1 (fabs x)))))))
(+ 1 (fabs x))
(+ 1 (+ (fabs x) (* 1/2 (pow x 2))))
(+ 1 (+ (fabs x) (* (pow x 2) (+ 1/2 (* -1/8 (pow x 2))))))
(+ 1 (+ (fabs x) (* (pow x 2) (+ 1/2 (* (pow x 2) (- (* 1/16 (pow x 2)) 1/8))))))
(fabs x)
(+ (fabs x) (* -1 x))
(+ x (fabs x))
(* -1/24 (pow x 2))
(/ (+ 3 (* 3 (/ 1 (+ 1 (fabs x))))) (+ 1 (fabs x)))
(* -1/24 (/ (* (pow x 2) (+ 3 (* 3 (/ 1 (+ 1 (fabs x)))))) (+ 1 (fabs x))))
(* (pow x 2) (+ (* -1/24 (/ (+ 3 (* 3 (/ 1 (+ 1 (fabs x))))) (+ 1 (fabs x)))) (* 1/2 (/ 1 (* (pow x 2) (+ 1 (fabs x)))))))
(* -1 (log (/ 1 x)))
(+ (* -1 (log (/ 1 x))) (/ (fabs x) x))
(+ (* -1 (log (/ 1 x))) (+ (* 1/2 (/ (+ 1 (* -1 (pow (fabs x) 2))) (pow x 2))) (/ (fabs x) x)))
(+ (* -1 (log (/ 1 x))) (+ (* 1/6 (/ (+ (* -3 (fabs x)) (* 2 (pow (fabs x) 3))) (pow x 3))) (+ (* 1/2 (/ (+ 1 (* -1 (pow (fabs x) 2))) (pow x 2))) (/ (fabs x) x))))
(* -1/24 (/ (* (pow x 4) (+ 3 (* 3 (/ 1 (+ 1 (fabs x)))))) (+ 1 (fabs x))))
(* (pow x 4) (+ (* -1/24 (/ (+ 3 (* 3 (/ 1 (+ 1 (fabs x))))) (+ 1 (fabs x)))) (* 1/2 (/ 1 (* (pow x 2) (+ 1 (fabs x)))))))
(* (pow x 4) (+ (* -1/24 (/ (+ 3 (* 3 (/ 1 (+ 1 (fabs x))))) (+ 1 (fabs x)))) (+ (/ 1/2 (* (pow x 2) (+ 1 (fabs x)))) (/ (log (+ 1 (fabs x))) (pow x 4)))))
x
(* x (+ 1 (/ (fabs x) x)))
(* x (+ 1 (+ (/ 1/2 (pow x 2)) (/ (fabs x) x))))
(* x (- (+ 1 (+ (/ 1/2 (pow x 2)) (/ (fabs x) x))) (* 1/8 (/ 1 (pow x 4)))))
(* -1 x)
(* x (- (/ (fabs x) x) 1))
(* -1 (log (/ -1 x)))
(+ (* -1 (log (/ -1 x))) (* -1 (/ (fabs x) x)))
(+ (* -1 (log (/ -1 x))) (* -1 (/ (+ (fabs x) (* -1/2 (/ (+ 1 (* -1 (pow (fabs x) 2))) x))) x)))
(+ (* -1 (log (/ -1 x))) (* -1 (/ (+ (fabs x) (* -1 (/ (+ (* -1/6 (/ (+ (* -3 (fabs x)) (* 2 (pow (fabs x) 3))) x)) (* 1/2 (+ 1 (* -1 (pow (fabs x) 2))))) x))) x)))
(* -1 (* x (+ 1 (* -1 (/ (fabs x) x)))))
(* -1 (* x (+ 1 (* -1 (/ (- (fabs x) (* 1/2 (/ 1 x))) x)))))
(* -1 (* x (+ 1 (* -1 (/ (+ (fabs x) (* -1 (/ (- 1/2 (* 1/8 (/ 1 (pow x 2)))) x))) x)))))
(* -1 (* x (- (* -1 (/ (fabs x) x)) 1)))
Outputs
(/ 1/2 (+ 1 (fabs x)))
(/.f32 #s(literal 1/2 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32)))
(+ (* -1/24 (/ (* (pow x 2) (+ 3 (* 3 (/ 1 (+ 1 (fabs x)))))) (+ 1 (fabs x)))) (* 1/2 (/ 1 (+ 1 (fabs x)))))
(/.f32 (fma.f32 (*.f32 x x) (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32)))
(copysign (log (+ (fabs x) (sqrt (+ 1 (pow x 2))))) x)
(copysign.f32 (log.f32 (+.f32 (sqrt.f32 (fma.f32 x x #s(literal 1 binary32))) (fabs.f32 x))) x)
(log (+ 1 (fabs x)))
(log1p.f32 (fabs.f32 x))
(+ (log (+ 1 (fabs x))) (* 1/2 (/ (pow x 2) (+ 1 (fabs x)))))
(fma.f32 (*.f32 (/.f32 #s(literal 1/2 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) x) x (log1p.f32 (fabs.f32 x)))
(+ (log (+ 1 (fabs x))) (* (pow x 2) (+ (* -1/24 (* (pow x 2) (+ (* 3 (/ 1 (+ 1 (fabs x)))) (* 3 (/ 1 (pow (+ 1 (fabs x)) 2)))))) (* 1/2 (/ 1 (+ 1 (fabs x)))))))
(fma.f32 (/.f32 (fma.f32 (*.f32 x x) (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 x x) (log1p.f32 (fabs.f32 x)))
(+ (log (+ 1 (fabs x))) (* (pow x 2) (+ (* (pow x 2) (+ (* -1/24 (+ (* 3 (/ 1 (+ 1 (fabs x)))) (* 3 (/ 1 (pow (+ 1 (fabs x)) 2))))) (* 1/720 (* (pow x 2) (+ (* 45 (/ 1 (+ 1 (fabs x)))) (+ (* 45 (/ 1 (pow (+ 1 (fabs x)) 2))) (* 30 (/ 1 (pow (+ 1 (fabs x)) 3))))))))) (* 1/2 (/ 1 (+ 1 (fabs x)))))))
(fma.f32 (pow.f32 x #s(literal 4 binary32)) (fma.f32 (*.f32 #s(literal 1/720 binary32) (+.f32 (/.f32 (+.f32 (/.f32 #s(literal 30 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 45 binary32)) (pow.f32 (-.f32 (fabs.f32 x) #s(literal -1 binary32)) #s(literal 2 binary32))) (/.f32 #s(literal 45 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))))) (*.f32 x x) (/.f32 (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32)))) (fma.f32 (*.f32 (/.f32 #s(literal 1/2 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) x) x (log1p.f32 (fabs.f32 x))))
(+ (log (+ 1 (fabs x))) (* (pow x 2) (+ (* -1/24 (/ (* (pow x 2) (+ 3 (* 3 (/ 1 (+ 1 (fabs x)))))) (+ 1 (fabs x)))) (* 1/2 (/ 1 (+ 1 (fabs x)))))))
(fma.f32 (/.f32 (fma.f32 (*.f32 x x) (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 x x) (log1p.f32 (fabs.f32 x)))
(+ 1 (fabs x))
(-.f32 (fabs.f32 x) #s(literal -1 binary32))
(+ 1 (+ (fabs x) (* 1/2 (pow x 2))))
(-.f32 (fma.f32 (*.f32 x x) #s(literal 1/2 binary32) (fabs.f32 x)) #s(literal -1 binary32))
(+ 1 (+ (fabs x) (* (pow x 2) (+ 1/2 (* -1/8 (pow x 2))))))
(-.f32 (fabs.f32 x) (fma.f32 (fma.f32 #s(literal 1/8 binary32) (*.f32 x x) #s(literal -1/2 binary32)) (*.f32 x x) #s(literal -1 binary32)))
(+ 1 (+ (fabs x) (* (pow x 2) (+ 1/2 (* (pow x 2) (- (* 1/16 (pow x 2)) 1/8))))))
(fma.f32 (*.f32 (fma.f32 (fma.f32 #s(literal 1/16 binary32) (*.f32 x x) #s(literal -1/8 binary32)) (*.f32 x x) #s(literal 1/2 binary32)) x) x (-.f32 (fabs.f32 x) #s(literal -1 binary32)))
(fabs x)
(fabs.f32 x)
(+ (fabs x) (* -1 x))
(-.f32 (fabs.f32 x) x)
(+ x (fabs x))
(+.f32 (fabs.f32 x) x)
(* -1/24 (pow x 2))
(*.f32 (*.f32 x x) #s(literal -1/24 binary32))
(/ (+ 3 (* 3 (/ 1 (+ 1 (fabs x))))) (+ 1 (fabs x)))
(/.f32 (-.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal -3 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32)))
(* -1/24 (/ (* (pow x 2) (+ 3 (* 3 (/ 1 (+ 1 (fabs x)))))) (+ 1 (fabs x))))
(*.f32 (/.f32 (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 x x))
(* (pow x 2) (+ (* -1/24 (/ (+ 3 (* 3 (/ 1 (+ 1 (fabs x))))) (+ 1 (fabs x)))) (* 1/2 (/ 1 (* (pow x 2) (+ 1 (fabs x)))))))
(*.f32 (/.f32 (+.f32 (+.f32 (/.f32 #s(literal 1/2 binary32) (*.f32 x x)) #s(literal -1/8 binary32)) (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32)))) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 x x))
(* -1 (log (/ 1 x)))
(log.f32 x)
(+ (* -1 (log (/ 1 x))) (/ (fabs x) x))
(+.f32 (log.f32 x) (/.f32 (fabs.f32 x) x))
(+ (* -1 (log (/ 1 x))) (+ (* 1/2 (/ (+ 1 (* -1 (pow (fabs x) 2))) (pow x 2))) (/ (fabs x) x)))
(+.f32 (+.f32 (/.f32 (+.f32 (/.f32 #s(literal 1/2 binary32) x) (fabs.f32 x)) x) #s(literal -1/2 binary32)) (log.f32 x))
(+ (* -1 (log (/ 1 x))) (+ (* 1/6 (/ (+ (* -3 (fabs x)) (* 2 (pow (fabs x) 3))) (pow x 3))) (+ (* 1/2 (/ (+ 1 (* -1 (pow (fabs x) 2))) (pow x 2))) (/ (fabs x) x))))
(fma.f32 (/.f32 (*.f32 (fabs.f32 x) (fma.f32 (*.f32 x x) #s(literal 2 binary32) #s(literal -3 binary32))) (pow.f32 x #s(literal 3 binary32))) #s(literal 1/6 binary32) (+.f32 (+.f32 (/.f32 (+.f32 (/.f32 #s(literal 1/2 binary32) x) (fabs.f32 x)) x) #s(literal -1/2 binary32)) (log.f32 x)))
(* -1/24 (/ (* (pow x 4) (+ 3 (* 3 (/ 1 (+ 1 (fabs x)))))) (+ 1 (fabs x))))
(*.f32 (pow.f32 x #s(literal 4 binary32)) (/.f32 (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))))
(* (pow x 4) (+ (* -1/24 (/ (+ 3 (* 3 (/ 1 (+ 1 (fabs x))))) (+ 1 (fabs x)))) (* 1/2 (/ 1 (* (pow x 2) (+ 1 (fabs x)))))))
(*.f32 (pow.f32 x #s(literal 4 binary32)) (/.f32 (+.f32 (+.f32 (/.f32 #s(literal 1/2 binary32) (*.f32 x x)) #s(literal -1/8 binary32)) (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32)))) (-.f32 (fabs.f32 x) #s(literal -1 binary32))))
(* (pow x 4) (+ (* -1/24 (/ (+ 3 (* 3 (/ 1 (+ 1 (fabs x))))) (+ 1 (fabs x)))) (+ (/ 1/2 (* (pow x 2) (+ 1 (fabs x)))) (/ (log (+ 1 (fabs x))) (pow x 4)))))
(*.f32 (+.f32 (/.f32 (log1p.f32 (fabs.f32 x)) (pow.f32 x #s(literal 4 binary32))) (/.f32 (+.f32 (+.f32 (/.f32 #s(literal 1/2 binary32) (*.f32 x x)) #s(literal -1/8 binary32)) (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32)))) (-.f32 (fabs.f32 x) #s(literal -1 binary32)))) (pow.f32 x #s(literal 4 binary32)))
x
(* x (+ 1 (/ (fabs x) x)))
(fma.f32 (/.f32 (fabs.f32 x) x) x x)
(* x (+ 1 (+ (/ 1/2 (pow x 2)) (/ (fabs x) x))))
(fma.f32 (/.f32 (+.f32 (/.f32 #s(literal 1/2 binary32) x) (fabs.f32 x)) x) x x)
(* x (- (+ 1 (+ (/ 1/2 (pow x 2)) (/ (fabs x) x))) (* 1/8 (/ 1 (pow x 4)))))
(fma.f32 (-.f32 (/.f32 (+.f32 (/.f32 #s(literal 1/2 binary32) x) (fabs.f32 x)) x) (/.f32 #s(literal 1/8 binary32) (pow.f32 x #s(literal 4 binary32)))) x x)
(* -1 x)
(neg.f32 x)
(* x (- (/ (fabs x) x) 1))
(*.f32 (-.f32 (/.f32 (fabs.f32 x) x) #s(literal 1 binary32)) x)
(* -1 (log (/ -1 x)))
(neg.f32 (log.f32 (/.f32 #s(literal -1 binary32) x)))
(+ (* -1 (log (/ -1 x))) (* -1 (/ (fabs x) x)))
(-.f32 (/.f32 (fabs.f32 x) (neg.f32 x)) (log.f32 (/.f32 #s(literal -1 binary32) x)))
(+ (* -1 (log (/ -1 x))) (* -1 (/ (+ (fabs x) (* -1/2 (/ (+ 1 (* -1 (pow (fabs x) 2))) x))) x)))
(-.f32 (fma.f32 (/.f32 (-.f32 (fabs.f32 x) (/.f32 #s(literal 1/2 binary32) x)) x) #s(literal -1 binary32) #s(literal -1/2 binary32)) (log.f32 (/.f32 #s(literal -1 binary32) x)))
(+ (* -1 (log (/ -1 x))) (* -1 (/ (+ (fabs x) (* -1 (/ (+ (* -1/6 (/ (+ (* -3 (fabs x)) (* 2 (pow (fabs x) 3))) x)) (* 1/2 (+ 1 (* -1 (pow (fabs x) 2))))) x))) x)))
(-.f32 (/.f32 (-.f32 (/.f32 (fma.f32 (fma.f32 x x #s(literal -1 binary32)) #s(literal -1/2 binary32) (*.f32 (/.f32 (*.f32 (fabs.f32 x) (fma.f32 (*.f32 x x) #s(literal 2 binary32) #s(literal -3 binary32))) x) #s(literal -1/6 binary32))) x) (fabs.f32 x)) x) (log.f32 (/.f32 #s(literal -1 binary32) x)))
(* -1 (* x (+ 1 (* -1 (/ (fabs x) x)))))
(*.f32 (-.f32 (/.f32 (fabs.f32 x) x) #s(literal 1 binary32)) x)
(* -1 (* x (+ 1 (* -1 (/ (- (fabs x) (* 1/2 (/ 1 x))) x)))))
(*.f32 (+.f32 (/.f32 (-.f32 (fabs.f32 x) (/.f32 #s(literal 1/2 binary32) x)) x) #s(literal -1 binary32)) x)
(* -1 (* x (+ 1 (* -1 (/ (+ (fabs x) (* -1 (/ (- 1/2 (* 1/8 (/ 1 (pow x 2)))) x))) x)))))
(*.f32 (+.f32 (/.f32 (-.f32 (fabs.f32 x) (/.f32 (-.f32 #s(literal 1/2 binary32) (/.f32 #s(literal 1/8 binary32) (*.f32 x x))) x)) x) #s(literal -1 binary32)) x)
(* -1 (* x (- (* -1 (/ (fabs x) x)) 1)))
(fma.f32 (/.f32 (fabs.f32 x) x) x x)

rewrite121.0ms (2.9%)

Memory
3.4MiB live, 95.3MiB allocated; 7ms collecting garbage
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
040337
062313
1222289
01802281
Stop Event
iter limit
iter limit
node limit
iter limit
Counts
15 → 102
Calls
Call 1
Inputs
(fma.f32 (*.f32 #s(literal -1/24 binary32) (*.f32 x x)) (/.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (/.f32 #s(literal 1/2 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))))
(copysign.f32 #s(approx (log (+ (fabs x) (sqrt (+ (* x x) 1)))) (fma.f32 (fma.f32 (*.f32 #s(literal -1/24 binary32) (*.f32 x x)) (/.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (/.f32 #s(literal 1/2 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32)))) (*.f32 x x) (log1p.f32 (fabs.f32 x)))) x)
#s(approx (log (+ (fabs x) (sqrt (+ (* x x) 1)))) (fma.f32 (fma.f32 (*.f32 #s(literal -1/24 binary32) (*.f32 x x)) (/.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (/.f32 #s(literal 1/2 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32)))) (*.f32 x x) (log1p.f32 (fabs.f32 x))))
(fma.f32 (fma.f32 (*.f32 #s(literal -1/24 binary32) (*.f32 x x)) (/.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (/.f32 #s(literal 1/2 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32)))) (*.f32 x x) (log1p.f32 (fabs.f32 x)))
(copysign.f32 (log.f32 #s(approx (+ (fabs x) (sqrt (+ (* x x) 1))) #s(approx (* (- (/ (fabs x) x) 1) x) (-.f32 (fabs.f32 x) x)))) x)
(log.f32 #s(approx (+ (fabs x) (sqrt (+ (* x x) 1))) #s(approx (* (- (/ (fabs x) x) 1) x) (-.f32 (fabs.f32 x) x))))
#s(approx (+ (fabs x) (sqrt (+ (* x x) 1))) #s(approx (* (- (/ (fabs x) x) 1) x) (-.f32 (fabs.f32 x) x)))
#s(approx (* (- (/ (fabs x) x) 1) x) (-.f32 (fabs.f32 x) x))
(copysign.f32 (log.f32 #s(approx (+ (fabs x) (sqrt (+ (* x x) 1))) #s(approx (+ (* (/ (fabs x) x) x) x) (+.f32 (fabs.f32 x) x)))) x)
(log.f32 #s(approx (+ (fabs x) (sqrt (+ (* x x) 1))) #s(approx (+ (* (/ (fabs x) x) x) x) (+.f32 (fabs.f32 x) x))))
#s(approx (+ (fabs x) (sqrt (+ (* x x) 1))) #s(approx (+ (* (/ (fabs x) x) x) x) (+.f32 (fabs.f32 x) x)))
#s(approx (+ (* (/ (fabs x) x) x) x) (+.f32 (fabs.f32 x) x))
(*.f32 #s(literal -1/24 binary32) (*.f32 x x))
(/.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32)))
(fabs.f32 x)
Outputs
(/.f32 (-.f32 (pow.f32 (/.f32 #s(literal 1/2 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 2 binary32)) (pow.f32 (*.f32 (/.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 (*.f32 x x) #s(literal -1/24 binary32))) #s(literal 2 binary32))) (-.f32 (/.f32 #s(literal 1/2 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 (/.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 (*.f32 x x) #s(literal -1/24 binary32)))))
(/.f32 (fma.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (*.f32 (*.f32 x x) #s(literal -1/24 binary32)) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32)))
(/.f32 (+.f32 #s(literal 1/2 binary32) (*.f32 (*.f32 x #s(literal -1/24 binary32)) (*.f32 x (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32))))) (-.f32 (fabs.f32 x) #s(literal -1 binary32)))
(/.f32 (neg.f32 (-.f32 (pow.f32 (*.f32 (/.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 (*.f32 x x) #s(literal -1/24 binary32))) #s(literal 2 binary32)) (pow.f32 (/.f32 #s(literal 1/2 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 2 binary32)))) (neg.f32 (/.f32 (-.f32 (*.f32 (*.f32 x #s(literal -1/24 binary32)) (*.f32 x (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)))) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32)))))
(/.f32 (neg.f32 (fma.f32 #s(literal -1/13824 binary32) (pow.f32 (*.f32 (/.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 x x)) #s(literal 3 binary32)) (pow.f32 (/.f32 #s(literal 1/2 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)))) (neg.f32 (fma.f32 (/.f32 #s(literal 1/2 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (-.f32 (/.f32 #s(literal 1/2 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 (/.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 (*.f32 x x) #s(literal -1/24 binary32)))) (pow.f32 (*.f32 (/.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 (*.f32 x x) #s(literal -1/24 binary32))) #s(literal 2 binary32)))))
(/.f32 (fma.f32 (*.f32 (*.f32 x #s(literal -1/24 binary32)) (*.f32 x (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)))) (neg.f32 (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 (-.f32 (fabs.f32 x) #s(literal -1 binary32)) #s(literal -1/2 binary32))) (*.f32 (-.f32 (fabs.f32 x) #s(literal -1 binary32)) (neg.f32 (-.f32 (fabs.f32 x) #s(literal -1 binary32)))))
(/.f32 (fma.f32 (*.f32 (*.f32 x #s(literal -1/24 binary32)) (*.f32 x (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)))) (-.f32 (fabs.f32 x) #s(literal -1 binary32)) (*.f32 (-.f32 (fabs.f32 x) #s(literal -1 binary32)) #s(literal 1/2 binary32))) (*.f32 (-.f32 (fabs.f32 x) #s(literal -1 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))))
(/.f32 (fma.f32 #s(literal -1/2 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32)) (*.f32 (neg.f32 (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 (*.f32 x #s(literal -1/24 binary32)) (*.f32 x (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)))))) (*.f32 (neg.f32 (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (-.f32 (fabs.f32 x) #s(literal -1 binary32))))
(/.f32 (fma.f32 #s(literal 1/2 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32)) (*.f32 (-.f32 (fabs.f32 x) #s(literal -1 binary32)) (*.f32 (*.f32 x #s(literal -1/24 binary32)) (*.f32 x (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)))))) (*.f32 (-.f32 (fabs.f32 x) #s(literal -1 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))))
(/.f32 (-.f32 (pow.f32 (*.f32 (/.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 (*.f32 x x) #s(literal -1/24 binary32))) #s(literal 2 binary32)) (pow.f32 (/.f32 #s(literal 1/2 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 2 binary32))) (/.f32 (-.f32 (*.f32 (*.f32 x #s(literal -1/24 binary32)) (*.f32 x (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)))) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))))
(/.f32 (fma.f32 #s(literal -1/13824 binary32) (pow.f32 (*.f32 (/.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 x x)) #s(literal 3 binary32)) (pow.f32 (/.f32 #s(literal 1/2 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32))) (+.f32 (pow.f32 (/.f32 #s(literal 1/2 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 2 binary32)) (-.f32 (pow.f32 (*.f32 (/.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 (*.f32 x x) #s(literal -1/24 binary32))) #s(literal 2 binary32)) (*.f32 (*.f32 (/.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 (*.f32 x x) #s(literal -1/24 binary32))) (/.f32 #s(literal 1/2 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32)))))))
(/.f32 (fma.f32 #s(literal -1/13824 binary32) (pow.f32 (*.f32 (/.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 x x)) #s(literal 3 binary32)) (pow.f32 (/.f32 #s(literal 1/2 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32))) (fma.f32 (/.f32 #s(literal 1/2 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (-.f32 (/.f32 #s(literal 1/2 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 (/.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 (*.f32 x x) #s(literal -1/24 binary32)))) (pow.f32 (*.f32 (/.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 (*.f32 x x) #s(literal -1/24 binary32))) #s(literal 2 binary32))))
(-.f32 (/.f32 (pow.f32 (*.f32 (/.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 (*.f32 x x) #s(literal -1/24 binary32))) #s(literal 2 binary32)) (/.f32 (-.f32 (*.f32 (*.f32 x #s(literal -1/24 binary32)) (*.f32 x (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)))) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32)))) (/.f32 (pow.f32 (/.f32 #s(literal 1/2 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 2 binary32)) (/.f32 (-.f32 (*.f32 (*.f32 x #s(literal -1/24 binary32)) (*.f32 x (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)))) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32)))))
(-.f32 (/.f32 #s(literal 1/2 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 (neg.f32 (/.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32)))) (*.f32 (*.f32 x x) #s(literal -1/24 binary32))))
(-.f32 (/.f32 #s(literal 1/2 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 (neg.f32 (*.f32 (*.f32 x x) #s(literal -1/24 binary32))) (/.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32)))))
(-.f32 (/.f32 #s(literal 1/2 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 #s(literal 1/24 binary32) (*.f32 (/.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 x x))))
(fma.f32 (/.f32 #s(literal 1/2 binary32) (fma.f32 x x #s(literal -1 binary32))) (+.f32 #s(literal -1 binary32) (fabs.f32 x)) (*.f32 (/.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 (*.f32 x x) #s(literal -1/24 binary32))))
(fma.f32 (/.f32 #s(literal 1/2 binary32) (-.f32 (pow.f32 (fabs.f32 x) #s(literal 3 binary32)) #s(literal -1 binary32))) (fma.f32 x x (fma.f32 #s(literal -1 binary32) (fabs.f32 x) #s(literal 1 binary32))) (*.f32 (/.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 (*.f32 x x) #s(literal -1/24 binary32))))
(fma.f32 (/.f32 (*.f32 (*.f32 x #s(literal -1/24 binary32)) (*.f32 x (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)))) (fma.f32 x x #s(literal -1 binary32))) (+.f32 #s(literal -1 binary32) (fabs.f32 x)) (/.f32 #s(literal 1/2 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))))
(fma.f32 (/.f32 (*.f32 (*.f32 x #s(literal -1/24 binary32)) (*.f32 x (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)))) (-.f32 (pow.f32 (fabs.f32 x) #s(literal 3 binary32)) #s(literal -1 binary32))) (fma.f32 x x (fma.f32 #s(literal -1 binary32) (fabs.f32 x) #s(literal 1 binary32))) (/.f32 #s(literal 1/2 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))))
(fma.f32 (*.f32 (/.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 x #s(literal -1/24 binary32))) x (/.f32 #s(literal 1/2 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))))
(fma.f32 (*.f32 (/.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal -1/24 binary32)) (*.f32 x x) (/.f32 #s(literal 1/2 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))))
(fma.f32 (*.f32 (/.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 x x)) #s(literal -1/24 binary32) (/.f32 #s(literal 1/2 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))))
(fma.f32 (*.f32 x #s(literal -1/24 binary32)) (*.f32 x (/.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32)))) (/.f32 #s(literal 1/2 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))))
(fma.f32 (/.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 (*.f32 x x) #s(literal -1/24 binary32)) (/.f32 #s(literal 1/2 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))))
(fma.f32 (*.f32 (*.f32 x x) #s(literal -1/24 binary32)) (/.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (/.f32 #s(literal 1/2 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))))
(fma.f32 (*.f32 x x) (*.f32 #s(literal -1/24 binary32) (/.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32)))) (/.f32 #s(literal 1/2 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))))
(fma.f32 #s(literal -1/24 binary32) (*.f32 (/.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 x x)) (/.f32 #s(literal 1/2 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))))
(+.f32 (/.f32 (pow.f32 (*.f32 (/.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 (*.f32 x x) #s(literal -1/24 binary32))) #s(literal 3 binary32)) (fma.f32 (/.f32 #s(literal 1/2 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (-.f32 (/.f32 #s(literal 1/2 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 (/.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 (*.f32 x x) #s(literal -1/24 binary32)))) (pow.f32 (*.f32 (/.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 (*.f32 x x) #s(literal -1/24 binary32))) #s(literal 2 binary32)))) (/.f32 (pow.f32 (/.f32 #s(literal 1/2 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (fma.f32 (/.f32 #s(literal 1/2 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (-.f32 (/.f32 #s(literal 1/2 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 (/.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 (*.f32 x x) #s(literal -1/24 binary32)))) (pow.f32 (*.f32 (/.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 (*.f32 x x) #s(literal -1/24 binary32))) #s(literal 2 binary32)))))
(+.f32 (*.f32 (/.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 (*.f32 x x) #s(literal -1/24 binary32))) (/.f32 #s(literal 1/2 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))))
(+.f32 (/.f32 #s(literal 1/2 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 (/.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 (*.f32 x x) #s(literal -1/24 binary32))))
(copysign.f32 #s(approx (log (+ (fabs x) (sqrt (+ (* x x) 1)))) (fma.f32 (/.f32 (fma.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (*.f32 (*.f32 x x) #s(literal -1/24 binary32)) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 x x) (log1p.f32 (fabs.f32 x)))) x)
#s(approx (log (+ (fabs x) (sqrt (+ (* x x) 1)))) (fma.f32 (/.f32 (fma.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (*.f32 (*.f32 x x) #s(literal -1/24 binary32)) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 x x) (log1p.f32 (fabs.f32 x))))
(/.f32 (-.f32 (pow.f32 (log1p.f32 (fabs.f32 x)) #s(literal 2 binary32)) (pow.f32 (*.f32 (/.f32 (fma.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (*.f32 (*.f32 x x) #s(literal -1/24 binary32)) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 x x)) #s(literal 2 binary32))) (-.f32 (log1p.f32 (fabs.f32 x)) (*.f32 (/.f32 (fma.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (*.f32 (*.f32 x x) #s(literal -1/24 binary32)) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 x x))))
(/.f32 (neg.f32 (-.f32 (pow.f32 (*.f32 (/.f32 (fma.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (*.f32 (*.f32 x x) #s(literal -1/24 binary32)) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 x x)) #s(literal 2 binary32)) (pow.f32 (log1p.f32 (fabs.f32 x)) #s(literal 2 binary32)))) (neg.f32 (-.f32 (*.f32 (/.f32 (fma.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (*.f32 (*.f32 x x) #s(literal -1/24 binary32)) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 x x)) (log1p.f32 (fabs.f32 x)))))
(/.f32 (neg.f32 (fma.f32 (pow.f32 (/.f32 (fma.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (*.f32 (*.f32 x x) #s(literal -1/24 binary32)) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (pow.f32 x #s(literal 6 binary32)) (pow.f32 (log1p.f32 (fabs.f32 x)) #s(literal 3 binary32)))) (neg.f32 (fma.f32 (log1p.f32 (fabs.f32 x)) (-.f32 (log1p.f32 (fabs.f32 x)) (*.f32 (/.f32 (fma.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (*.f32 (*.f32 x x) #s(literal -1/24 binary32)) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 x x))) (pow.f32 (*.f32 (/.f32 (fma.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (*.f32 (*.f32 x x) #s(literal -1/24 binary32)) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 x x)) #s(literal 2 binary32)))))
(/.f32 (-.f32 (pow.f32 (*.f32 (/.f32 (fma.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (*.f32 (*.f32 x x) #s(literal -1/24 binary32)) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 x x)) #s(literal 2 binary32)) (pow.f32 (log1p.f32 (fabs.f32 x)) #s(literal 2 binary32))) (-.f32 (*.f32 (/.f32 (fma.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (*.f32 (*.f32 x x) #s(literal -1/24 binary32)) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 x x)) (log1p.f32 (fabs.f32 x))))
(/.f32 (fma.f32 (pow.f32 (/.f32 (fma.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (*.f32 (*.f32 x x) #s(literal -1/24 binary32)) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (pow.f32 x #s(literal 6 binary32)) (pow.f32 (log1p.f32 (fabs.f32 x)) #s(literal 3 binary32))) (+.f32 (pow.f32 (log1p.f32 (fabs.f32 x)) #s(literal 2 binary32)) (-.f32 (pow.f32 (*.f32 (/.f32 (fma.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (*.f32 (*.f32 x x) #s(literal -1/24 binary32)) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 x x)) #s(literal 2 binary32)) (*.f32 (*.f32 (/.f32 (fma.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (*.f32 (*.f32 x x) #s(literal -1/24 binary32)) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 x x)) (log1p.f32 (fabs.f32 x))))))
(/.f32 (fma.f32 (pow.f32 (/.f32 (fma.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (*.f32 (*.f32 x x) #s(literal -1/24 binary32)) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (pow.f32 x #s(literal 6 binary32)) (pow.f32 (log1p.f32 (fabs.f32 x)) #s(literal 3 binary32))) (fma.f32 (log1p.f32 (fabs.f32 x)) (-.f32 (log1p.f32 (fabs.f32 x)) (*.f32 (/.f32 (fma.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (*.f32 (*.f32 x x) #s(literal -1/24 binary32)) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 x x))) (pow.f32 (*.f32 (/.f32 (fma.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (*.f32 (*.f32 x x) #s(literal -1/24 binary32)) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 x x)) #s(literal 2 binary32))))
(-.f32 (/.f32 (pow.f32 (*.f32 (/.f32 (fma.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (*.f32 (*.f32 x x) #s(literal -1/24 binary32)) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 x x)) #s(literal 2 binary32)) (-.f32 (*.f32 (/.f32 (fma.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (*.f32 (*.f32 x x) #s(literal -1/24 binary32)) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 x x)) (log1p.f32 (fabs.f32 x)))) (/.f32 (pow.f32 (log1p.f32 (fabs.f32 x)) #s(literal 2 binary32)) (-.f32 (*.f32 (/.f32 (fma.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (*.f32 (*.f32 x x) #s(literal -1/24 binary32)) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 x x)) (log1p.f32 (fabs.f32 x)))))
(-.f32 (log1p.f32 (fabs.f32 x)) (*.f32 (neg.f32 (*.f32 (/.f32 (fma.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (*.f32 (*.f32 x x) #s(literal -1/24 binary32)) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) x)) x))
(-.f32 (log1p.f32 (fabs.f32 x)) (*.f32 (neg.f32 (/.f32 (fma.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (*.f32 (*.f32 x x) #s(literal -1/24 binary32)) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32)))) (*.f32 x x)))
(-.f32 (log1p.f32 (fabs.f32 x)) (*.f32 (neg.f32 (*.f32 x x)) (/.f32 (fma.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (*.f32 (*.f32 x x) #s(literal -1/24 binary32)) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32)))))
(fma.f32 (*.f32 (/.f32 (fma.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (*.f32 (*.f32 x x) #s(literal -1/24 binary32)) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (neg.f32 x)) (neg.f32 x) (log1p.f32 (fabs.f32 x)))
(fma.f32 (*.f32 (/.f32 (fma.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (*.f32 (*.f32 x x) #s(literal -1/24 binary32)) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (fabs.f32 x)) (fabs.f32 x) (log1p.f32 (fabs.f32 x)))
(fma.f32 (*.f32 (/.f32 (fma.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (*.f32 (*.f32 x x) #s(literal -1/24 binary32)) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) x) x (log1p.f32 (fabs.f32 x)))
(fma.f32 (neg.f32 x) (*.f32 (neg.f32 x) (/.f32 (fma.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (*.f32 (*.f32 x x) #s(literal -1/24 binary32)) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32)))) (log1p.f32 (fabs.f32 x)))
(fma.f32 (/.f32 (fma.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (*.f32 (*.f32 x x) #s(literal -1/24 binary32)) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 x x) (log1p.f32 (fabs.f32 x)))
(fma.f32 (fabs.f32 x) (*.f32 (fabs.f32 x) (/.f32 (fma.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (*.f32 (*.f32 x x) #s(literal -1/24 binary32)) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32)))) (log1p.f32 (fabs.f32 x)))
(fma.f32 (*.f32 x x) (/.f32 (fma.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (*.f32 (*.f32 x x) #s(literal -1/24 binary32)) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (log1p.f32 (fabs.f32 x)))
(fma.f32 x (*.f32 (/.f32 (fma.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (*.f32 (*.f32 x x) #s(literal -1/24 binary32)) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) x) (log1p.f32 (fabs.f32 x)))
(+.f32 (/.f32 (pow.f32 (*.f32 (/.f32 (fma.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (*.f32 (*.f32 x x) #s(literal -1/24 binary32)) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 x x)) #s(literal 3 binary32)) (fma.f32 (log1p.f32 (fabs.f32 x)) (-.f32 (log1p.f32 (fabs.f32 x)) (*.f32 (/.f32 (fma.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (*.f32 (*.f32 x x) #s(literal -1/24 binary32)) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 x x))) (pow.f32 (*.f32 (/.f32 (fma.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (*.f32 (*.f32 x x) #s(literal -1/24 binary32)) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 x x)) #s(literal 2 binary32)))) (/.f32 (pow.f32 (log1p.f32 (fabs.f32 x)) #s(literal 3 binary32)) (fma.f32 (log1p.f32 (fabs.f32 x)) (-.f32 (log1p.f32 (fabs.f32 x)) (*.f32 (/.f32 (fma.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (*.f32 (*.f32 x x) #s(literal -1/24 binary32)) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 x x))) (pow.f32 (*.f32 (/.f32 (fma.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (*.f32 (*.f32 x x) #s(literal -1/24 binary32)) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 x x)) #s(literal 2 binary32)))))
(+.f32 (*.f32 (/.f32 (fma.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (*.f32 (*.f32 x x) #s(literal -1/24 binary32)) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 x x)) (log1p.f32 (fabs.f32 x)))
(+.f32 (log1p.f32 (fabs.f32 x)) (*.f32 (/.f32 (fma.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (*.f32 (*.f32 x x) #s(literal -1/24 binary32)) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 x x)))
(copysign.f32 (log.f32 #s(approx (+ (fabs x) (sqrt (+ (* x x) 1))) #s(approx (* (- (/ (fabs x) x) 1) x) (-.f32 (fabs.f32 x) x)))) x)
(log.f32 #s(approx (+ (fabs x) (sqrt (+ (* x x) 1))) #s(approx (* (- (/ (fabs x) x) 1) x) (-.f32 (fabs.f32 x) x))))
#s(approx (+ (fabs x) (sqrt (+ (* x x) 1))) #s(approx (* (- (/ (fabs x) x) 1) x) (-.f32 (fabs.f32 x) x)))
#s(approx (* (- (/ (fabs x) x) 1) x) (-.f32 (fabs.f32 x) x))
(copysign.f32 (log.f32 #s(approx (+ (fabs x) (sqrt (+ (* x x) 1))) #s(approx (+ (* (/ (fabs x) x) x) x) (+.f32 (fabs.f32 x) x)))) x)
(log.f32 #s(approx (+ (fabs x) (sqrt (+ (* x x) 1))) #s(approx (+ (* (/ (fabs x) x) x) x) (+.f32 (fabs.f32 x) x))))
#s(approx (+ (fabs x) (sqrt (+ (* x x) 1))) #s(approx (+ (* (/ (fabs x) x) x) x) (+.f32 (fabs.f32 x) x)))
#s(approx (+ (* (/ (fabs x) x) x) x) (+.f32 (fabs.f32 x) x))
(*.f32 (*.f32 #s(literal -1/24 binary32) (neg.f32 x)) (neg.f32 x))
(*.f32 (*.f32 #s(literal -1/24 binary32) (fabs.f32 x)) (fabs.f32 x))
(*.f32 (*.f32 x #s(literal -1/24 binary32)) x)
(*.f32 (neg.f32 x) (*.f32 (neg.f32 x) #s(literal -1/24 binary32)))
(*.f32 (fabs.f32 x) (*.f32 (fabs.f32 x) #s(literal -1/24 binary32)))
(*.f32 (*.f32 x x) #s(literal -1/24 binary32))
(*.f32 x (*.f32 x #s(literal -1/24 binary32)))
(*.f32 #s(literal -1/24 binary32) (*.f32 x x))
(*.f32 (/.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (fma.f32 x x #s(literal -1 binary32))) (+.f32 #s(literal -1 binary32) (fabs.f32 x)))
(*.f32 (/.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (-.f32 (pow.f32 (fabs.f32 x) #s(literal 3 binary32)) #s(literal -1 binary32))) (fma.f32 x x (fma.f32 #s(literal -1 binary32) (fabs.f32 x) #s(literal 1 binary32))))
(/.f32 (-.f32 (*.f32 (/.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (/.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (-.f32 (fabs.f32 x) #s(literal -1 binary32)))) (pow.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 2 binary32))) (-.f32 (/.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32)))))
(/.f32 (+.f32 (pow.f32 (/.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (pow.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32))) (fma.f32 (/.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (/.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (-.f32 (pow.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 2 binary32)) (*.f32 (/.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32)))))))
(/.f32 (neg.f32 (neg.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)))) (neg.f32 (neg.f32 (-.f32 (fabs.f32 x) #s(literal -1 binary32)))))
(/.f32 (fma.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (neg.f32 (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 (-.f32 (fabs.f32 x) #s(literal -1 binary32)) #s(literal -3 binary32))) (*.f32 (-.f32 (fabs.f32 x) #s(literal -1 binary32)) (neg.f32 (-.f32 (fabs.f32 x) #s(literal -1 binary32)))))
(/.f32 (fma.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (-.f32 (fabs.f32 x) #s(literal -1 binary32)) (*.f32 (-.f32 (fabs.f32 x) #s(literal -1 binary32)) #s(literal 3 binary32))) (*.f32 (-.f32 (fabs.f32 x) #s(literal -1 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))))
(/.f32 (-.f32 (pow.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 2 binary32)) #s(literal 9 binary32)) (*.f32 (-.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))))
(/.f32 (+.f32 #s(literal 27 binary32) (pow.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32))) (*.f32 (-.f32 (+.f32 (pow.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 2 binary32)) #s(literal 9 binary32)) (/.f32 #s(literal 9 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32)))) (-.f32 (fabs.f32 x) #s(literal -1 binary32))))
(/.f32 (neg.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32))) (neg.f32 (-.f32 (fabs.f32 x) #s(literal -1 binary32))))
(/.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32)))
(fma.f32 (/.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (fma.f32 x x #s(literal -1 binary32))) (+.f32 #s(literal -1 binary32) (fabs.f32 x)) (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))))
(fma.f32 (/.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (-.f32 (pow.f32 (fabs.f32 x) #s(literal 3 binary32)) #s(literal -1 binary32))) (fma.f32 x x (fma.f32 #s(literal -1 binary32) (fabs.f32 x) #s(literal 1 binary32))) (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))))
(fma.f32 (/.f32 #s(literal 3 binary32) (fma.f32 x x #s(literal -1 binary32))) (+.f32 #s(literal -1 binary32) (fabs.f32 x)) (/.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (-.f32 (fabs.f32 x) #s(literal -1 binary32))))
(fma.f32 (/.f32 #s(literal 3 binary32) (-.f32 (pow.f32 (fabs.f32 x) #s(literal 3 binary32)) #s(literal -1 binary32))) (fma.f32 x x (fma.f32 #s(literal -1 binary32) (fabs.f32 x) #s(literal 1 binary32))) (/.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (-.f32 (fabs.f32 x) #s(literal -1 binary32))))
(+.f32 (/.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))))
(+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (/.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (-.f32 (fabs.f32 x) #s(literal -1 binary32))))
(neg.f32 (/.f32 (neg.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32))) (-.f32 (fabs.f32 x) #s(literal -1 binary32))))
(neg.f32 (/.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (neg.f32 (-.f32 (fabs.f32 x) #s(literal -1 binary32)))))
(*.f32 (sqrt.f32 (neg.f32 x)) (sqrt.f32 (neg.f32 x)))
(*.f32 (sqrt.f32 (fabs.f32 x)) (sqrt.f32 (fabs.f32 x)))
(*.f32 (sqrt.f32 x) (sqrt.f32 x))
(*.f32 #s(literal 1 binary32) (fabs.f32 x))
(*.f32 #s(literal -1 binary32) (*.f32 #s(literal -1 binary32) (fabs.f32 x)))
(*.f32 (fabs.f32 x) #s(literal 1 binary32))
(sqrt.f32 (*.f32 x x))
(pow.f32 (*.f32 x x) #s(literal 1/2 binary32))
(pow.f32 x #s(literal 1 binary32))
(fabs.f32 (neg.f32 (neg.f32 x)))
(fabs.f32 (neg.f32 x))
(fabs.f32 (fabs.f32 x))
(fabs.f32 x)

eval41.0ms (1%)

Memory
-28.6MiB live, 69.1MiB allocated; 14ms collecting garbage
Compiler

Compiled 9 604 to 1 115 computations (88.4% saved)

prune4.0ms (0.1%)

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

5 alts after pruning (1 fresh and 4 done)

PrunedKeptTotal
New2031204
Fresh000
Picked123
Done022
Total2045209
Accuracy
100.0%
Counts
209 → 5
Alt Table
Click to see full alt table
StatusAccuracyProgram
34.0%
(copysign.f32 (log.f32 #s(approx (+ (fabs x) (sqrt (+ (* x x) 1))) #s(approx (+ (* (/ (fabs x) x) x) x) (+.f32 (fabs.f32 x) x)))) x)
29.5%
(copysign.f32 (log.f32 #s(approx (+ (fabs x) (sqrt (+ (* x x) 1))) #s(approx (* (- (/ (fabs x) x) 1) x) (-.f32 (fabs.f32 x) x)))) x)
99.6%
(copysign.f32 (asinh.f32 (fabs.f32 x)) x)
49.6%
(copysign.f32 #s(approx (log (+ (fabs x) (sqrt (+ (* x x) 1)))) (fma.f32 (/.f32 (fma.f32 (*.f32 x x) (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 x x) (log1p.f32 (fabs.f32 x)))) x)
15.2%
(copysign.f32 #s(approx (log (+ (fabs x) (sqrt (+ (* x x) 1)))) (log.f32 x)) x)
Compiler

Compiled 110 to 70 computations (36.4% saved)

simplify187.0ms (4.5%)

Memory
21.4MiB live, 296.3MiB allocated; 40ms collecting garbage
Localize:

Found 4 expressions of interest:

NewMetricScoreProgram
cost-diff0
(/.f32 (fma.f32 (*.f32 x x) (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32)))
cost-diff0
(fma.f32 (/.f32 (fma.f32 (*.f32 x x) (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 x x) (log1p.f32 (fabs.f32 x)))
cost-diff0
#s(approx (log (+ (fabs x) (sqrt (+ (* x x) 1)))) (fma.f32 (/.f32 (fma.f32 (*.f32 x x) (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 x x) (log1p.f32 (fabs.f32 x))))
cost-diff0
(copysign.f32 #s(approx (log (+ (fabs x) (sqrt (+ (* x x) 1)))) (fma.f32 (/.f32 (fma.f32 (*.f32 x x) (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 x x) (log1p.f32 (fabs.f32 x)))) x)
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
023161
036161
158161
2140161
3488161
41648161
54756161
08065159
Stop Event
iter limit
node limit
iter limit
Calls
Call 1
Inputs
(copysign.f32 #s(approx (log (+ (fabs x) (sqrt (+ (* x x) 1)))) (fma.f32 (/.f32 (fma.f32 (*.f32 x x) (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 x x) (log1p.f32 (fabs.f32 x)))) x)
#s(approx (log (+ (fabs x) (sqrt (+ (* x x) 1)))) (fma.f32 (/.f32 (fma.f32 (*.f32 x x) (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 x x) (log1p.f32 (fabs.f32 x))))
(fma.f32 (/.f32 (fma.f32 (*.f32 x x) (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 x x) (log1p.f32 (fabs.f32 x)))
(/.f32 (fma.f32 (*.f32 x x) (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32)))
(fma.f32 (*.f32 x x) (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) #s(literal 1/2 binary32))
(*.f32 x x)
x
(-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32))
(/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32)))
#s(literal -1/8 binary32)
(-.f32 (fabs.f32 x) #s(literal -1 binary32))
(fabs.f32 x)
#s(literal -1 binary32)
#s(literal 1/8 binary32)
#s(literal 1/2 binary32)
(log1p.f32 (fabs.f32 x))
Outputs
(copysign.f32 #s(approx (log (+ (fabs x) (sqrt (+ (* x x) 1)))) (fma.f32 (/.f32 (fma.f32 (*.f32 x x) (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 x x) (log1p.f32 (fabs.f32 x)))) x)
(copysign.f32 #s(approx (log (+ (fabs x) (sqrt (+ (* x x) 1)))) (fma.f32 (/.f32 x (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 (fma.f32 (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) (*.f32 x x) #s(literal 1/2 binary32)) x) (log1p.f32 (fabs.f32 x)))) x)
#s(approx (log (+ (fabs x) (sqrt (+ (* x x) 1)))) (fma.f32 (/.f32 (fma.f32 (*.f32 x x) (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 x x) (log1p.f32 (fabs.f32 x))))
#s(approx (log (+ (fabs x) (sqrt (+ (* x x) 1)))) (fma.f32 (/.f32 x (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 (fma.f32 (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) (*.f32 x x) #s(literal 1/2 binary32)) x) (log1p.f32 (fabs.f32 x))))
(fma.f32 (/.f32 (fma.f32 (*.f32 x x) (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 x x) (log1p.f32 (fabs.f32 x)))
(fma.f32 (/.f32 x (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 (fma.f32 (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) (*.f32 x x) #s(literal 1/2 binary32)) x) (log1p.f32 (fabs.f32 x)))
(/.f32 (fma.f32 (*.f32 x x) (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32)))
(/.f32 (fma.f32 (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) (*.f32 x x) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32)))
(fma.f32 (*.f32 x x) (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) #s(literal 1/2 binary32))
(fma.f32 (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) (*.f32 x x) #s(literal 1/2 binary32))
(*.f32 x x)
x
(-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32))
(/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32)))
#s(literal -1/8 binary32)
(-.f32 (fabs.f32 x) #s(literal -1 binary32))
(fabs.f32 x)
#s(literal -1 binary32)
#s(literal 1/8 binary32)
#s(literal 1/2 binary32)
(log1p.f32 (fabs.f32 x))

localize124.0ms (3%)

Memory
6.0MiB live, 200.6MiB allocated; 74ms collecting garbage
Localize:

Found 4 expressions of interest:

NewMetricScoreProgram
accuracy0.04296875
(/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32)))
accuracy0.0546875
(fma.f32 (/.f32 (fma.f32 (*.f32 x x) (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 x x) (log1p.f32 (fabs.f32 x)))
accuracy7.305138996580943
(/.f32 (fma.f32 (*.f32 x x) (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32)))
accuracy17.232882982439897
#s(approx (log (+ (fabs x) (sqrt (+ (* x x) 1)))) (fma.f32 (/.f32 (fma.f32 (*.f32 x x) (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 x x) (log1p.f32 (fabs.f32 x))))
Samples
65.0ms175×0valid
45.0ms81×1valid
Compiler

Compiled 119 to 23 computations (80.7% saved)

Precisions
Click to see histograms. Total time spent on operations: 69.0ms
ival-hypot: 25.0ms (36.2% of total)
ival-mult: 11.0ms (15.9% of total)
ival-copysign: 6.0ms (8.7% of total)
adjust: 5.0ms (7.2% of total)
ival-add: 5.0ms (7.2% of total)
ival-log: 5.0ms (7.2% of total)
ival-div: 4.0ms (5.8% of total)
ival-sub: 3.0ms (4.3% of total)
ival-log1p: 3.0ms (4.3% of total)
ival-fabs: 2.0ms (2.9% of total)
exact: 1.0ms (1.4% of total)
ival-assert: 0.0ms (0% of total)
ival-true: 0.0ms (0% of total)

series14.0ms (0.3%)

Memory
-25.1MiB live, 19.9MiB allocated; 14ms collecting garbage
Counts
5 → 22
Calls
Call 1
Inputs
(copysign.f32 #s(approx (log (+ (fabs x) (sqrt (+ (* x x) 1)))) (fma.f32 (/.f32 (fma.f32 (*.f32 x x) (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 x x) (log1p.f32 (fabs.f32 x)))) x)
#s(approx (log (+ (fabs x) (sqrt (+ (* x x) 1)))) (fma.f32 (/.f32 (fma.f32 (*.f32 x x) (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 x x) (log1p.f32 (fabs.f32 x))))
(fma.f32 (/.f32 (fma.f32 (*.f32 x x) (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 x x) (log1p.f32 (fabs.f32 x)))
(/.f32 (fma.f32 (*.f32 x x) (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32)))
(/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32)))
Outputs
(copysign (log (+ (fabs x) (sqrt (+ 1 (pow x 2))))) x)
(log (+ 1 (fabs x)))
(+ (log (+ 1 (fabs x))) (* 1/2 (/ (pow x 2) (+ 1 (fabs x)))))
(+ (log (+ 1 (fabs x))) (* (pow x 2) (+ (* -1/24 (* (pow x 2) (+ (* 3 (/ 1 (+ 1 (fabs x)))) (* 3 (/ 1 (pow (+ 1 (fabs x)) 2)))))) (* 1/2 (/ 1 (+ 1 (fabs x)))))))
(+ (log (+ 1 (fabs x))) (* (pow x 2) (+ (* (pow x 2) (+ (* -1/24 (+ (* 3 (/ 1 (+ 1 (fabs x)))) (* 3 (/ 1 (pow (+ 1 (fabs x)) 2))))) (* 1/720 (* (pow x 2) (+ (* 45 (/ 1 (+ 1 (fabs x)))) (+ (* 45 (/ 1 (pow (+ 1 (fabs x)) 2))) (* 30 (/ 1 (pow (+ 1 (fabs x)) 3))))))))) (* 1/2 (/ 1 (+ 1 (fabs x)))))))
(+ (log (+ 1 (fabs x))) (* (pow x 2) (+ (* -1 (/ (* (pow x 2) (+ 1/8 (* 1/8 (/ 1 (+ 1 (fabs x)))))) (+ 1 (fabs x)))) (* 1/2 (/ 1 (+ 1 (fabs x)))))))
(/ 1/2 (+ 1 (fabs x)))
(+ (* -1 (/ (* (pow x 2) (+ 1/8 (* 1/8 (/ 1 (+ 1 (fabs x)))))) (+ 1 (fabs x)))) (* 1/2 (/ 1 (+ 1 (fabs x)))))
(/ -1/8 (+ 1 (fabs x)))
(* -1 (log (/ 1 x)))
(+ (* -1 (log (/ 1 x))) (/ (fabs x) x))
(+ (* -1 (log (/ 1 x))) (+ (* 1/2 (/ (+ 1 (* -1 (pow (fabs x) 2))) (pow x 2))) (/ (fabs x) x)))
(+ (* -1 (log (/ 1 x))) (+ (* 1/6 (/ (+ (* -3 (fabs x)) (* 2 (pow (fabs x) 3))) (pow x 3))) (+ (* 1/2 (/ (+ 1 (* -1 (pow (fabs x) 2))) (pow x 2))) (/ (fabs x) x))))
(* -1 (/ (* (pow x 4) (+ 1/8 (* 1/8 (/ 1 (+ 1 (fabs x)))))) (+ 1 (fabs x))))
(* (pow x 4) (+ (* -1 (/ (+ 1/8 (* 1/8 (/ 1 (+ 1 (fabs x))))) (+ 1 (fabs x)))) (* 1/2 (/ 1 (* (pow x 2) (+ 1 (fabs x)))))))
(* (pow x 4) (+ (* -1 (/ (+ 1/8 (* 1/8 (/ 1 (+ 1 (fabs x))))) (+ 1 (fabs x)))) (+ (/ 1/2 (* (pow x 2) (+ 1 (fabs x)))) (/ (log (+ 1 (fabs x))) (pow x 4)))))
(* -1 (/ (* (pow x 2) (+ 1/8 (* 1/8 (/ 1 (+ 1 (fabs x)))))) (+ 1 (fabs x))))
(* (pow x 2) (+ (* -1 (/ (+ 1/8 (* 1/8 (/ 1 (+ 1 (fabs x))))) (+ 1 (fabs x)))) (* 1/2 (/ 1 (* (pow x 2) (+ 1 (fabs x)))))))
(* -1 (log (/ -1 x)))
(+ (* -1 (log (/ -1 x))) (* -1 (/ (fabs x) x)))
(+ (* -1 (log (/ -1 x))) (* -1 (/ (+ (fabs x) (* -1/2 (/ (+ 1 (* -1 (pow (fabs x) 2))) x))) x)))
(+ (* -1 (log (/ -1 x))) (* -1 (/ (+ (fabs x) (* -1 (/ (+ (* -1/6 (/ (+ (* -3 (fabs x)) (* 2 (pow (fabs x) 3))) x)) (* 1/2 (+ 1 (* -1 (pow (fabs x) 2))))) x))) x)))
Calls

3 calls:

TimeVariablePointExpression
9.0ms
x
@inf
((copysign (log (+ (fabs x) (sqrt (+ (* x x) 1)))) x) (log (+ (fabs x) (sqrt (+ (* x x) 1)))) (+ (* (/ (+ (* (* x x) (- (/ -1/8 (- (fabs x) -1)) 1/8)) 1/2) (- (fabs x) -1)) (* x x)) (log (+ 1 (fabs x)))) (/ (+ (* (* x x) (- (/ -1/8 (- (fabs x) -1)) 1/8)) 1/2) (- (fabs x) -1)) (/ -1/8 (- (fabs x) -1)))
3.0ms
x
@-inf
((copysign (log (+ (fabs x) (sqrt (+ (* x x) 1)))) x) (log (+ (fabs x) (sqrt (+ (* x x) 1)))) (+ (* (/ (+ (* (* x x) (- (/ -1/8 (- (fabs x) -1)) 1/8)) 1/2) (- (fabs x) -1)) (* x x)) (log (+ 1 (fabs x)))) (/ (+ (* (* x x) (- (/ -1/8 (- (fabs x) -1)) 1/8)) 1/2) (- (fabs x) -1)) (/ -1/8 (- (fabs x) -1)))
2.0ms
x
@0
((copysign (log (+ (fabs x) (sqrt (+ (* x x) 1)))) x) (log (+ (fabs x) (sqrt (+ (* x x) 1)))) (+ (* (/ (+ (* (* x x) (- (/ -1/8 (- (fabs x) -1)) 1/8)) 1/2) (- (fabs x) -1)) (* x x)) (log (+ 1 (fabs x)))) (/ (+ (* (* x x) (- (/ -1/8 (- (fabs x) -1)) 1/8)) 1/2) (- (fabs x) -1)) (/ -1/8 (- (fabs x) -1)))

simplify134.0ms (3.2%)

Memory
30.4MiB live, 274.1MiB allocated; 32ms collecting garbage
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0125504
1433458
21957420
08485393
Stop Event
iter limit
node limit
Counts
22 → 22
Calls
Call 1
Inputs
(copysign (log (+ (fabs x) (sqrt (+ 1 (pow x 2))))) x)
(log (+ 1 (fabs x)))
(+ (log (+ 1 (fabs x))) (* 1/2 (/ (pow x 2) (+ 1 (fabs x)))))
(+ (log (+ 1 (fabs x))) (* (pow x 2) (+ (* -1/24 (* (pow x 2) (+ (* 3 (/ 1 (+ 1 (fabs x)))) (* 3 (/ 1 (pow (+ 1 (fabs x)) 2)))))) (* 1/2 (/ 1 (+ 1 (fabs x)))))))
(+ (log (+ 1 (fabs x))) (* (pow x 2) (+ (* (pow x 2) (+ (* -1/24 (+ (* 3 (/ 1 (+ 1 (fabs x)))) (* 3 (/ 1 (pow (+ 1 (fabs x)) 2))))) (* 1/720 (* (pow x 2) (+ (* 45 (/ 1 (+ 1 (fabs x)))) (+ (* 45 (/ 1 (pow (+ 1 (fabs x)) 2))) (* 30 (/ 1 (pow (+ 1 (fabs x)) 3))))))))) (* 1/2 (/ 1 (+ 1 (fabs x)))))))
(+ (log (+ 1 (fabs x))) (* (pow x 2) (+ (* -1 (/ (* (pow x 2) (+ 1/8 (* 1/8 (/ 1 (+ 1 (fabs x)))))) (+ 1 (fabs x)))) (* 1/2 (/ 1 (+ 1 (fabs x)))))))
(/ 1/2 (+ 1 (fabs x)))
(+ (* -1 (/ (* (pow x 2) (+ 1/8 (* 1/8 (/ 1 (+ 1 (fabs x)))))) (+ 1 (fabs x)))) (* 1/2 (/ 1 (+ 1 (fabs x)))))
(/ -1/8 (+ 1 (fabs x)))
(* -1 (log (/ 1 x)))
(+ (* -1 (log (/ 1 x))) (/ (fabs x) x))
(+ (* -1 (log (/ 1 x))) (+ (* 1/2 (/ (+ 1 (* -1 (pow (fabs x) 2))) (pow x 2))) (/ (fabs x) x)))
(+ (* -1 (log (/ 1 x))) (+ (* 1/6 (/ (+ (* -3 (fabs x)) (* 2 (pow (fabs x) 3))) (pow x 3))) (+ (* 1/2 (/ (+ 1 (* -1 (pow (fabs x) 2))) (pow x 2))) (/ (fabs x) x))))
(* -1 (/ (* (pow x 4) (+ 1/8 (* 1/8 (/ 1 (+ 1 (fabs x)))))) (+ 1 (fabs x))))
(* (pow x 4) (+ (* -1 (/ (+ 1/8 (* 1/8 (/ 1 (+ 1 (fabs x))))) (+ 1 (fabs x)))) (* 1/2 (/ 1 (* (pow x 2) (+ 1 (fabs x)))))))
(* (pow x 4) (+ (* -1 (/ (+ 1/8 (* 1/8 (/ 1 (+ 1 (fabs x))))) (+ 1 (fabs x)))) (+ (/ 1/2 (* (pow x 2) (+ 1 (fabs x)))) (/ (log (+ 1 (fabs x))) (pow x 4)))))
(* -1 (/ (* (pow x 2) (+ 1/8 (* 1/8 (/ 1 (+ 1 (fabs x)))))) (+ 1 (fabs x))))
(* (pow x 2) (+ (* -1 (/ (+ 1/8 (* 1/8 (/ 1 (+ 1 (fabs x))))) (+ 1 (fabs x)))) (* 1/2 (/ 1 (* (pow x 2) (+ 1 (fabs x)))))))
(* -1 (log (/ -1 x)))
(+ (* -1 (log (/ -1 x))) (* -1 (/ (fabs x) x)))
(+ (* -1 (log (/ -1 x))) (* -1 (/ (+ (fabs x) (* -1/2 (/ (+ 1 (* -1 (pow (fabs x) 2))) x))) x)))
(+ (* -1 (log (/ -1 x))) (* -1 (/ (+ (fabs x) (* -1 (/ (+ (* -1/6 (/ (+ (* -3 (fabs x)) (* 2 (pow (fabs x) 3))) x)) (* 1/2 (+ 1 (* -1 (pow (fabs x) 2))))) x))) x)))
Outputs
(copysign (log (+ (fabs x) (sqrt (+ 1 (pow x 2))))) x)
(copysign.f32 (log.f32 (+.f32 (sqrt.f32 (fma.f32 x x #s(literal 1 binary32))) (fabs.f32 x))) x)
(log (+ 1 (fabs x)))
(log1p.f32 (fabs.f32 x))
(+ (log (+ 1 (fabs x))) (* 1/2 (/ (pow x 2) (+ 1 (fabs x)))))
(fma.f32 (*.f32 (/.f32 #s(literal 1/2 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) x) x (log1p.f32 (fabs.f32 x)))
(+ (log (+ 1 (fabs x))) (* (pow x 2) (+ (* -1/24 (* (pow x 2) (+ (* 3 (/ 1 (+ 1 (fabs x)))) (* 3 (/ 1 (pow (+ 1 (fabs x)) 2)))))) (* 1/2 (/ 1 (+ 1 (fabs x)))))))
(fma.f32 (/.f32 (fma.f32 (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) (*.f32 x x) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 x x) (log1p.f32 (fabs.f32 x)))
(+ (log (+ 1 (fabs x))) (* (pow x 2) (+ (* (pow x 2) (+ (* -1/24 (+ (* 3 (/ 1 (+ 1 (fabs x)))) (* 3 (/ 1 (pow (+ 1 (fabs x)) 2))))) (* 1/720 (* (pow x 2) (+ (* 45 (/ 1 (+ 1 (fabs x)))) (+ (* 45 (/ 1 (pow (+ 1 (fabs x)) 2))) (* 30 (/ 1 (pow (+ 1 (fabs x)) 3))))))))) (* 1/2 (/ 1 (+ 1 (fabs x)))))))
(fma.f32 (fma.f32 (*.f32 #s(literal 1/720 binary32) (*.f32 x x)) (*.f32 (-.f32 (/.f32 (+.f32 (/.f32 #s(literal 30 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 45 binary32)) (pow.f32 (-.f32 (fabs.f32 x) #s(literal -1 binary32)) #s(literal 2 binary32))) (/.f32 #s(literal -45 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32)))) (*.f32 x x)) (/.f32 (fma.f32 (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) (*.f32 x x) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32)))) (*.f32 x x) (log1p.f32 (fabs.f32 x)))
(+ (log (+ 1 (fabs x))) (* (pow x 2) (+ (* -1 (/ (* (pow x 2) (+ 1/8 (* 1/8 (/ 1 (+ 1 (fabs x)))))) (+ 1 (fabs x)))) (* 1/2 (/ 1 (+ 1 (fabs x)))))))
(fma.f32 (/.f32 (fma.f32 (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) (*.f32 x x) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 x x) (log1p.f32 (fabs.f32 x)))
(/ 1/2 (+ 1 (fabs x)))
(/.f32 #s(literal 1/2 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32)))
(+ (* -1 (/ (* (pow x 2) (+ 1/8 (* 1/8 (/ 1 (+ 1 (fabs x)))))) (+ 1 (fabs x)))) (* 1/2 (/ 1 (+ 1 (fabs x)))))
(/.f32 (fma.f32 (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) (*.f32 x x) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32)))
(/ -1/8 (+ 1 (fabs x)))
(/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32)))
(* -1 (log (/ 1 x)))
(log.f32 x)
(+ (* -1 (log (/ 1 x))) (/ (fabs x) x))
(+.f32 (/.f32 (fabs.f32 x) x) (log.f32 x))
(+ (* -1 (log (/ 1 x))) (+ (* 1/2 (/ (+ 1 (* -1 (pow (fabs x) 2))) (pow x 2))) (/ (fabs x) x)))
(+.f32 (+.f32 (/.f32 #s(literal 1/2 binary32) (*.f32 x x)) (+.f32 #s(literal -1/2 binary32) (/.f32 (fabs.f32 x) x))) (log.f32 x))
(+ (* -1 (log (/ 1 x))) (+ (* 1/6 (/ (+ (* -3 (fabs x)) (* 2 (pow (fabs x) 3))) (pow x 3))) (+ (* 1/2 (/ (+ 1 (* -1 (pow (fabs x) 2))) (pow x 2))) (/ (fabs x) x))))
(-.f32 (fma.f32 (/.f32 (*.f32 (fabs.f32 x) (fma.f32 (*.f32 x x) #s(literal 2 binary32) #s(literal -3 binary32))) (pow.f32 x #s(literal 3 binary32))) #s(literal 1/6 binary32) (+.f32 (/.f32 (fabs.f32 x) x) (log.f32 x))) (+.f32 (/.f32 #s(literal -1/2 binary32) (*.f32 x x)) #s(literal 1/2 binary32)))
(* -1 (/ (* (pow x 4) (+ 1/8 (* 1/8 (/ 1 (+ 1 (fabs x)))))) (+ 1 (fabs x))))
(*.f32 (/.f32 (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (pow.f32 x #s(literal 4 binary32)))
(* (pow x 4) (+ (* -1 (/ (+ 1/8 (* 1/8 (/ 1 (+ 1 (fabs x))))) (+ 1 (fabs x)))) (* 1/2 (/ 1 (* (pow x 2) (+ 1 (fabs x)))))))
(*.f32 (/.f32 (-.f32 (/.f32 #s(literal 1/2 binary32) (*.f32 x x)) (-.f32 (/.f32 #s(literal 1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal -1/8 binary32))) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (pow.f32 x #s(literal 4 binary32)))
(* (pow x 4) (+ (* -1 (/ (+ 1/8 (* 1/8 (/ 1 (+ 1 (fabs x))))) (+ 1 (fabs x)))) (+ (/ 1/2 (* (pow x 2) (+ 1 (fabs x)))) (/ (log (+ 1 (fabs x))) (pow x 4)))))
(*.f32 (+.f32 (/.f32 (log1p.f32 (fabs.f32 x)) (pow.f32 x #s(literal 4 binary32))) (/.f32 (-.f32 (/.f32 #s(literal 1/2 binary32) (*.f32 x x)) (-.f32 (/.f32 #s(literal 1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal -1/8 binary32))) (-.f32 (fabs.f32 x) #s(literal -1 binary32)))) (pow.f32 x #s(literal 4 binary32)))
(* -1 (/ (* (pow x 2) (+ 1/8 (* 1/8 (/ 1 (+ 1 (fabs x)))))) (+ 1 (fabs x))))
(*.f32 (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) (*.f32 x (/.f32 x (-.f32 (fabs.f32 x) #s(literal -1 binary32)))))
(* (pow x 2) (+ (* -1 (/ (+ 1/8 (* 1/8 (/ 1 (+ 1 (fabs x))))) (+ 1 (fabs x)))) (* 1/2 (/ 1 (* (pow x 2) (+ 1 (fabs x)))))))
(*.f32 (*.f32 (/.f32 (-.f32 (/.f32 #s(literal 1/2 binary32) (*.f32 x x)) (-.f32 (/.f32 #s(literal 1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal -1/8 binary32))) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) x) x)
(* -1 (log (/ -1 x)))
(neg.f32 (log.f32 (/.f32 #s(literal -1 binary32) x)))
(+ (* -1 (log (/ -1 x))) (* -1 (/ (fabs x) x)))
(-.f32 (/.f32 (fabs.f32 x) (neg.f32 x)) (log.f32 (/.f32 #s(literal -1 binary32) x)))
(+ (* -1 (log (/ -1 x))) (* -1 (/ (+ (fabs x) (* -1/2 (/ (+ 1 (* -1 (pow (fabs x) 2))) x))) x)))
(-.f32 (/.f32 (fma.f32 (fma.f32 x x #s(literal -1 binary32)) (/.f32 #s(literal 1/2 binary32) x) (fabs.f32 x)) (neg.f32 x)) (log.f32 (/.f32 #s(literal -1 binary32) x)))
(+ (* -1 (log (/ -1 x))) (* -1 (/ (+ (fabs x) (* -1 (/ (+ (* -1/6 (/ (+ (* -3 (fabs x)) (* 2 (pow (fabs x) 3))) x)) (* 1/2 (+ 1 (* -1 (pow (fabs x) 2))))) x))) x)))
(-.f32 (/.f32 (-.f32 (/.f32 (fma.f32 (fma.f32 x x #s(literal -1 binary32)) #s(literal -1/2 binary32) (*.f32 (/.f32 (*.f32 (fabs.f32 x) (fma.f32 (*.f32 x x) #s(literal 2 binary32) #s(literal -3 binary32))) x) #s(literal -1/6 binary32))) x) (fabs.f32 x)) x) (log.f32 (/.f32 #s(literal -1 binary32) x)))

rewrite68.0ms (1.6%)

Memory
-28.1MiB live, 110.3MiB allocated; 10ms collecting garbage
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
023123
036117
1150109
01228109
Stop Event
iter limit
iter limit
node limit
iter limit
Counts
5 → 54
Calls
Call 1
Inputs
(copysign.f32 #s(approx (log (+ (fabs x) (sqrt (+ (* x x) 1)))) (fma.f32 (/.f32 (fma.f32 (*.f32 x x) (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 x x) (log1p.f32 (fabs.f32 x)))) x)
#s(approx (log (+ (fabs x) (sqrt (+ (* x x) 1)))) (fma.f32 (/.f32 (fma.f32 (*.f32 x x) (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 x x) (log1p.f32 (fabs.f32 x))))
(fma.f32 (/.f32 (fma.f32 (*.f32 x x) (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 x x) (log1p.f32 (fabs.f32 x)))
(/.f32 (fma.f32 (*.f32 x x) (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32)))
(/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32)))
Outputs
(copysign.f32 #s(approx (log (+ (fabs x) (sqrt (+ (* x x) 1)))) (fma.f32 (/.f32 (fma.f32 (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) (*.f32 x x) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 x x) (log1p.f32 (fabs.f32 x)))) x)
#s(approx (log (+ (fabs x) (sqrt (+ (* x x) 1)))) (fma.f32 (/.f32 (fma.f32 (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) (*.f32 x x) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 x x) (log1p.f32 (fabs.f32 x))))
(/.f32 (-.f32 (pow.f32 (log1p.f32 (fabs.f32 x)) #s(literal 2 binary32)) (pow.f32 (*.f32 (/.f32 (fma.f32 (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) (*.f32 x x) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 x x)) #s(literal 2 binary32))) (-.f32 (log1p.f32 (fabs.f32 x)) (*.f32 (/.f32 (fma.f32 (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) (*.f32 x x) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 x x))))
(/.f32 (neg.f32 (-.f32 (pow.f32 (*.f32 (/.f32 (fma.f32 (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) (*.f32 x x) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 x x)) #s(literal 2 binary32)) (pow.f32 (log1p.f32 (fabs.f32 x)) #s(literal 2 binary32)))) (neg.f32 (-.f32 (*.f32 (/.f32 (fma.f32 (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) (*.f32 x x) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 x x)) (log1p.f32 (fabs.f32 x)))))
(/.f32 (neg.f32 (fma.f32 (pow.f32 (/.f32 (fma.f32 (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) (*.f32 x x) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (pow.f32 x #s(literal 6 binary32)) (pow.f32 (log1p.f32 (fabs.f32 x)) #s(literal 3 binary32)))) (neg.f32 (fma.f32 (log1p.f32 (fabs.f32 x)) (-.f32 (log1p.f32 (fabs.f32 x)) (*.f32 (/.f32 (fma.f32 (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) (*.f32 x x) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 x x))) (pow.f32 (*.f32 (/.f32 (fma.f32 (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) (*.f32 x x) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 x x)) #s(literal 2 binary32)))))
(/.f32 (-.f32 (pow.f32 (*.f32 (/.f32 (fma.f32 (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) (*.f32 x x) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 x x)) #s(literal 2 binary32)) (pow.f32 (log1p.f32 (fabs.f32 x)) #s(literal 2 binary32))) (-.f32 (*.f32 (/.f32 (fma.f32 (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) (*.f32 x x) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 x x)) (log1p.f32 (fabs.f32 x))))
(/.f32 (fma.f32 (pow.f32 (/.f32 (fma.f32 (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) (*.f32 x x) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (pow.f32 x #s(literal 6 binary32)) (pow.f32 (log1p.f32 (fabs.f32 x)) #s(literal 3 binary32))) (+.f32 (pow.f32 (log1p.f32 (fabs.f32 x)) #s(literal 2 binary32)) (-.f32 (pow.f32 (*.f32 (/.f32 (fma.f32 (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) (*.f32 x x) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 x x)) #s(literal 2 binary32)) (*.f32 (*.f32 (/.f32 (fma.f32 (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) (*.f32 x x) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 x x)) (log1p.f32 (fabs.f32 x))))))
(/.f32 (fma.f32 (pow.f32 (/.f32 (fma.f32 (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) (*.f32 x x) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (pow.f32 x #s(literal 6 binary32)) (pow.f32 (log1p.f32 (fabs.f32 x)) #s(literal 3 binary32))) (fma.f32 (log1p.f32 (fabs.f32 x)) (-.f32 (log1p.f32 (fabs.f32 x)) (*.f32 (/.f32 (fma.f32 (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) (*.f32 x x) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 x x))) (pow.f32 (*.f32 (/.f32 (fma.f32 (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) (*.f32 x x) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 x x)) #s(literal 2 binary32))))
(-.f32 (/.f32 (pow.f32 (*.f32 (/.f32 (fma.f32 (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) (*.f32 x x) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 x x)) #s(literal 2 binary32)) (-.f32 (*.f32 (/.f32 (fma.f32 (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) (*.f32 x x) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 x x)) (log1p.f32 (fabs.f32 x)))) (/.f32 (pow.f32 (log1p.f32 (fabs.f32 x)) #s(literal 2 binary32)) (-.f32 (*.f32 (/.f32 (fma.f32 (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) (*.f32 x x) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 x x)) (log1p.f32 (fabs.f32 x)))))
(-.f32 (log1p.f32 (fabs.f32 x)) (*.f32 (neg.f32 (/.f32 (*.f32 (fma.f32 (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) (*.f32 x x) #s(literal 1/2 binary32)) x) (-.f32 (fabs.f32 x) #s(literal -1 binary32)))) x))
(-.f32 (log1p.f32 (fabs.f32 x)) (*.f32 (neg.f32 (/.f32 (fma.f32 (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) (*.f32 x x) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32)))) (*.f32 x x)))
(-.f32 (log1p.f32 (fabs.f32 x)) (*.f32 (neg.f32 (*.f32 x x)) (/.f32 (fma.f32 (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) (*.f32 x x) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32)))))
(fma.f32 (/.f32 (*.f32 (*.f32 (fma.f32 (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) (*.f32 x x) #s(literal 1/2 binary32)) x) x) (fma.f32 x x #s(literal -1 binary32))) (+.f32 #s(literal -1 binary32) (fabs.f32 x)) (log1p.f32 (fabs.f32 x)))
(fma.f32 (/.f32 (*.f32 (*.f32 (fma.f32 (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) (*.f32 x x) #s(literal 1/2 binary32)) x) x) (-.f32 (pow.f32 (fabs.f32 x) #s(literal 3 binary32)) #s(literal -1 binary32))) (fma.f32 x x (fma.f32 #s(literal -1 binary32) (fabs.f32 x) #s(literal 1 binary32))) (log1p.f32 (fabs.f32 x)))
(fma.f32 (*.f32 (/.f32 (fma.f32 (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) (*.f32 x x) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (neg.f32 x)) (neg.f32 x) (log1p.f32 (fabs.f32 x)))
(fma.f32 (*.f32 (/.f32 (fma.f32 (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) (*.f32 x x) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (fabs.f32 x)) (fabs.f32 x) (log1p.f32 (fabs.f32 x)))
(fma.f32 (/.f32 (*.f32 (fma.f32 (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) (*.f32 x x) #s(literal 1/2 binary32)) x) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) x (log1p.f32 (fabs.f32 x)))
(fma.f32 (neg.f32 x) (*.f32 (neg.f32 x) (/.f32 (fma.f32 (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) (*.f32 x x) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32)))) (log1p.f32 (fabs.f32 x)))
(fma.f32 (/.f32 (fma.f32 (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) (*.f32 x x) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 x x) (log1p.f32 (fabs.f32 x)))
(fma.f32 (fma.f32 (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) (*.f32 x x) #s(literal 1/2 binary32)) (/.f32 (*.f32 x x) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (log1p.f32 (fabs.f32 x)))
(fma.f32 (fabs.f32 x) (*.f32 (fabs.f32 x) (/.f32 (fma.f32 (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) (*.f32 x x) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32)))) (log1p.f32 (fabs.f32 x)))
(fma.f32 (*.f32 x x) (/.f32 (fma.f32 (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) (*.f32 x x) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (log1p.f32 (fabs.f32 x)))
(fma.f32 x (/.f32 (*.f32 (fma.f32 (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) (*.f32 x x) #s(literal 1/2 binary32)) x) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (log1p.f32 (fabs.f32 x)))
(+.f32 (/.f32 (pow.f32 (*.f32 (/.f32 (fma.f32 (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) (*.f32 x x) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 x x)) #s(literal 3 binary32)) (fma.f32 (log1p.f32 (fabs.f32 x)) (-.f32 (log1p.f32 (fabs.f32 x)) (*.f32 (/.f32 (fma.f32 (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) (*.f32 x x) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 x x))) (pow.f32 (*.f32 (/.f32 (fma.f32 (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) (*.f32 x x) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 x x)) #s(literal 2 binary32)))) (/.f32 (pow.f32 (log1p.f32 (fabs.f32 x)) #s(literal 3 binary32)) (fma.f32 (log1p.f32 (fabs.f32 x)) (-.f32 (log1p.f32 (fabs.f32 x)) (*.f32 (/.f32 (fma.f32 (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) (*.f32 x x) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 x x))) (pow.f32 (*.f32 (/.f32 (fma.f32 (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) (*.f32 x x) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 x x)) #s(literal 2 binary32)))))
(+.f32 (*.f32 (/.f32 (fma.f32 (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) (*.f32 x x) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 x x)) (log1p.f32 (fabs.f32 x)))
(+.f32 (log1p.f32 (fabs.f32 x)) (*.f32 (/.f32 (fma.f32 (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) (*.f32 x x) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 x x)))
(*.f32 (/.f32 (fma.f32 (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) (*.f32 x x) #s(literal 1/2 binary32)) (fma.f32 x x #s(literal -1 binary32))) (+.f32 #s(literal -1 binary32) (fabs.f32 x)))
(*.f32 (/.f32 (fma.f32 (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) (*.f32 x x) #s(literal 1/2 binary32)) (-.f32 (pow.f32 (fabs.f32 x) #s(literal 3 binary32)) #s(literal -1 binary32))) (fma.f32 x x (fma.f32 #s(literal -1 binary32) (fabs.f32 x) #s(literal 1 binary32))))
(/.f32 (-.f32 (*.f32 (/.f32 (*.f32 (*.f32 (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) x) x) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (/.f32 (*.f32 (*.f32 (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) x) x) (-.f32 (fabs.f32 x) #s(literal -1 binary32)))) (*.f32 (/.f32 #s(literal 1/2 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (/.f32 #s(literal 1/2 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))))) (-.f32 (/.f32 (*.f32 (*.f32 (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) x) x) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (/.f32 #s(literal 1/2 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32)))))
(/.f32 (+.f32 (pow.f32 (/.f32 (*.f32 (*.f32 (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) x) x) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (pow.f32 (/.f32 #s(literal 1/2 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32))) (fma.f32 (/.f32 (*.f32 (*.f32 (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) x) x) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (/.f32 (*.f32 (*.f32 (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) x) x) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (-.f32 (*.f32 (/.f32 #s(literal 1/2 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (/.f32 #s(literal 1/2 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32)))) (*.f32 (/.f32 (*.f32 (*.f32 (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) x) x) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (/.f32 #s(literal 1/2 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32)))))))
(/.f32 (neg.f32 (neg.f32 (fma.f32 (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) (*.f32 x x) #s(literal 1/2 binary32)))) (neg.f32 (neg.f32 (-.f32 (fabs.f32 x) #s(literal -1 binary32)))))
(/.f32 (fma.f32 (*.f32 (*.f32 (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) x) x) (-.f32 (fabs.f32 x) #s(literal -1 binary32)) (*.f32 (-.f32 (fabs.f32 x) #s(literal -1 binary32)) #s(literal 1/2 binary32))) (*.f32 (-.f32 (fabs.f32 x) #s(literal -1 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))))
(/.f32 (-.f32 (pow.f32 (*.f32 (*.f32 (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) x) x) #s(literal 2 binary32)) #s(literal 1/4 binary32)) (*.f32 (-.f32 (*.f32 (*.f32 (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) x) x) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))))
(/.f32 (fma.f32 (pow.f32 (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) #s(literal 3 binary32)) (pow.f32 x #s(literal 6 binary32)) #s(literal 1/8 binary32)) (*.f32 (fma.f32 #s(literal 1/2 binary32) (-.f32 #s(literal 1/2 binary32) (*.f32 (*.f32 (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) x) x)) (pow.f32 (*.f32 (*.f32 (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) x) x) #s(literal 2 binary32))) (-.f32 (fabs.f32 x) #s(literal -1 binary32))))
(/.f32 (neg.f32 (fma.f32 (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) (*.f32 x x) #s(literal 1/2 binary32))) (neg.f32 (-.f32 (fabs.f32 x) #s(literal -1 binary32))))
(/.f32 (fma.f32 (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) (*.f32 x x) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32)))
(fma.f32 (/.f32 #s(literal 1/2 binary32) (fma.f32 x x #s(literal -1 binary32))) (+.f32 #s(literal -1 binary32) (fabs.f32 x)) (/.f32 (*.f32 (*.f32 (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) x) x) (-.f32 (fabs.f32 x) #s(literal -1 binary32))))
(fma.f32 (/.f32 #s(literal 1/2 binary32) (-.f32 (pow.f32 (fabs.f32 x) #s(literal 3 binary32)) #s(literal -1 binary32))) (fma.f32 x x (fma.f32 #s(literal -1 binary32) (fabs.f32 x) #s(literal 1 binary32))) (/.f32 (*.f32 (*.f32 (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) x) x) (-.f32 (fabs.f32 x) #s(literal -1 binary32))))
(fma.f32 (/.f32 (*.f32 (*.f32 (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) x) x) (fma.f32 x x #s(literal -1 binary32))) (+.f32 #s(literal -1 binary32) (fabs.f32 x)) (/.f32 #s(literal 1/2 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))))
(fma.f32 (/.f32 (*.f32 (*.f32 (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) x) x) (-.f32 (pow.f32 (fabs.f32 x) #s(literal 3 binary32)) #s(literal -1 binary32))) (fma.f32 x x (fma.f32 #s(literal -1 binary32) (fabs.f32 x) #s(literal 1 binary32))) (/.f32 #s(literal 1/2 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))))
(fma.f32 (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) (/.f32 (*.f32 x x) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (/.f32 #s(literal 1/2 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))))
(fma.f32 (*.f32 x x) (/.f32 (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (/.f32 #s(literal 1/2 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))))
(fma.f32 x (/.f32 (*.f32 (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) x) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (/.f32 #s(literal 1/2 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))))
(+.f32 (/.f32 #s(literal 1/2 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (/.f32 (*.f32 (*.f32 (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) x) x) (-.f32 (fabs.f32 x) #s(literal -1 binary32))))
(+.f32 (/.f32 (*.f32 (*.f32 (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) x) x) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (/.f32 #s(literal 1/2 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))))
(neg.f32 (/.f32 (neg.f32 (fma.f32 (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) (*.f32 x x) #s(literal 1/2 binary32))) (-.f32 (fabs.f32 x) #s(literal -1 binary32))))
(neg.f32 (/.f32 (fma.f32 (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) (*.f32 x x) #s(literal 1/2 binary32)) (neg.f32 (-.f32 (fabs.f32 x) #s(literal -1 binary32)))))
(*.f32 (/.f32 #s(literal -1/8 binary32) (fma.f32 x x #s(literal -1 binary32))) (+.f32 #s(literal -1 binary32) (fabs.f32 x)))
(*.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (pow.f32 (fabs.f32 x) #s(literal 3 binary32)) #s(literal -1 binary32))) (fma.f32 x x (fma.f32 #s(literal -1 binary32) (fabs.f32 x) #s(literal 1 binary32))))
(/.f32 #s(literal 1/8 binary32) (neg.f32 (-.f32 (fabs.f32 x) #s(literal -1 binary32))))
(/.f32 #s(literal -1/8 binary32) (neg.f32 (neg.f32 (-.f32 (fabs.f32 x) #s(literal -1 binary32)))))
(/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32)))
(neg.f32 (/.f32 #s(literal 1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))))
(neg.f32 (/.f32 #s(literal -1/8 binary32) (neg.f32 (-.f32 (fabs.f32 x) #s(literal -1 binary32)))))

eval9.0ms (0.2%)

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

Compiled 3 766 to 459 computations (87.8% saved)

prune5.0ms (0.1%)

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

5 alts after pruning (0 fresh and 5 done)

PrunedKeptTotal
New75075
Fresh000
Picked011
Done044
Total75580
Accuracy
100.0%
Counts
80 → 5
Alt Table
Click to see full alt table
StatusAccuracyProgram
34.0%
(copysign.f32 (log.f32 #s(approx (+ (fabs x) (sqrt (+ (* x x) 1))) #s(approx (+ (* (/ (fabs x) x) x) x) (+.f32 (fabs.f32 x) x)))) x)
29.5%
(copysign.f32 (log.f32 #s(approx (+ (fabs x) (sqrt (+ (* x x) 1))) #s(approx (* (- (/ (fabs x) x) 1) x) (-.f32 (fabs.f32 x) x)))) x)
99.6%
(copysign.f32 (asinh.f32 (fabs.f32 x)) x)
49.6%
(copysign.f32 #s(approx (log (+ (fabs x) (sqrt (+ (* x x) 1)))) (fma.f32 (/.f32 (fma.f32 (*.f32 x x) (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 x x) (log1p.f32 (fabs.f32 x)))) x)
15.2%
(copysign.f32 #s(approx (log (+ (fabs x) (sqrt (+ (* x x) 1)))) (log.f32 x)) x)
Compiler

Compiled 334 to 145 computations (56.6% saved)

regimes18.0ms (0.4%)

Memory
-34.3MiB live, 15.9MiB allocated; 8ms collecting garbage
Counts
10 → 1
Calls
Call 1
Inputs
(copysign.f32 #s(approx (log (+ (fabs x) (sqrt (+ (* x x) 1)))) (log.f32 x)) x)
(copysign.f32 (asinh.f32 (fabs.f32 x)) x)
(copysign.f32 (log.f32 #s(approx (+ (fabs x) (sqrt (+ (* x x) 1))) #s(approx (* (- (/ (fabs x) x) 1) x) (-.f32 (fabs.f32 x) x)))) x)
(copysign.f32 (log.f32 #s(approx (+ (fabs x) (sqrt (+ (* x x) 1))) #s(approx (+ (* (/ (fabs x) x) x) x) (+.f32 (fabs.f32 x) x)))) x)
(copysign.f32 (log.f32 #s(approx (+ (fabs x) (sqrt (+ (* x x) 1))) (fma.f32 (/.f32 (fabs.f32 x) x) x x))) x)
(copysign.f32 (log.f32 (+.f32 (fabs.f32 x) (sqrt.f32 #s(approx (+ (* x x) 1) (*.f32 x x))))) x)
(copysign.f32 (log.f32 #s(approx (+ (fabs x) (sqrt (+ (* x x) 1))) (*.f32 (-.f32 (/.f32 (fabs.f32 x) x) #s(literal 1 binary32)) x))) x)
(copysign.f32 (log.f32 (+.f32 (fabs.f32 x) (sqrt.f32 (+.f32 (*.f32 x x) #s(literal 1 binary32))))) x)
(copysign.f32 #s(approx (log (+ (fabs x) (sqrt (+ (* x x) 1)))) (fma.f32 (/.f32 (fma.f32 (*.f32 x x) (-.f32 (/.f32 #s(literal -1/8 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 1/8 binary32)) #s(literal 1/2 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (*.f32 x x) (log1p.f32 (fabs.f32 x)))) x)
(copysign.f32 #s(approx (log (+ (fabs x) (sqrt (+ (* x x) 1)))) (fma.f32 (fma.f32 (*.f32 #s(literal -1/24 binary32) (*.f32 x x)) (/.f32 (+.f32 (/.f32 #s(literal 3 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) #s(literal 3 binary32)) (-.f32 (fabs.f32 x) #s(literal -1 binary32))) (/.f32 #s(literal 1/2 binary32) (-.f32 (fabs.f32 x) #s(literal -1 binary32)))) (*.f32 x x) (log1p.f32 (fabs.f32 x)))) x)
Outputs
(copysign.f32 (asinh.f32 (fabs.f32 x)) x)
Calls

2 calls:

14.0ms
(copysign.f32 (log.f32 (+.f32 (fabs.f32 x) (sqrt.f32 (+.f32 (*.f32 x x) #s(literal 1 binary32))))) x)
3.0ms
x
Results
AccuracySegmentsBranch
99.6%1(copysign.f32 (log.f32 (+.f32 (fabs.f32 x) (sqrt.f32 (+.f32 (*.f32 x x) #s(literal 1 binary32))))) x)
99.6%1x
Compiler

Compiled 13 to 10 computations (23.1% saved)

regimes2.0ms (0.1%)

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

Total 0.0b remaining (0%)

Threshold costs 0b (0%)

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

2 calls:

1.0ms
x
1.0ms
(copysign.f32 (log.f32 (+.f32 (fabs.f32 x) (sqrt.f32 (+.f32 (*.f32 x x) #s(literal 1 binary32))))) x)
Results
AccuracySegmentsBranch
15.2%1(copysign.f32 (log.f32 (+.f32 (fabs.f32 x) (sqrt.f32 (+.f32 (*.f32 x x) #s(literal 1 binary32))))) x)
15.2%1x
Compiler

Compiled 13 to 10 computations (23.1% saved)

simplify54.0ms (1.3%)

Memory
-1.0MiB live, 44.5MiB allocated; 8ms collecting garbage
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01420
12420
25120
38620
415520
540120
6304220
7732520
Stop Event
node limit
Calls
Call 1
Inputs
(copysign.f32 (asinh.f32 (fabs.f32 x)) x)
(copysign.f32 #s(approx (log (+ (fabs x) (sqrt (+ (* x x) 1)))) (log.f32 x)) x)
Outputs
(copysign.f32 (asinh.f32 (fabs.f32 x)) x)
(copysign.f32 #s(approx (log (+ (fabs x) (sqrt (+ (* x x) 1)))) (log.f32 x)) x)

derivations43.0ms (1%)

Memory
-1.0MiB live, 46.1MiB allocated; 2ms collecting garbage
Stop Event
done
Compiler

Compiled 20 to 14 computations (30% saved)

preprocess17.0ms (0.4%)

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

Compiled 104 to 66 computations (36.5% saved)

end0.0ms (0%)

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

Profiling

Loading profile data...