Diagrams.TwoD.Apollonian:initialConfig from diagrams-contrib-1.3.0.5, B

Time bar (total: 1.6s)

start0.0ms (0%)

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

analyze126.0ms (7.8%)

Memory
-33.8MiB live, 208.5MiB allocated; 45ms collecting garbage
Algorithm
search
Search
ProbabilityValidUnknownPreconditionInfiniteDomainCan'tIter
0%0%99.9%0.1%0%0%0%0
0%0%99.9%0.1%0%0%0%1
0%0%99.9%0.1%0%0%0%2
0%0%99.9%0.1%0%0%0%3
0%0%99.9%0.1%0%0%0%4
0%0%99.9%0.1%0%0%0%5
0%0%99.9%0.1%0%0%0%6
30.8%25%56.2%0.1%0%18.7%0%7
30.8%25%56.2%0.1%0%18.7%0%8
32%25%53%0.1%0%21.8%0%9
55.8%37.4%29.6%0.1%0%32.8%0%10
55.8%37.4%29.6%0.1%0%32.8%0%11
57.8%37.4%27.3%0.1%0%35.1%0%12
Compiler

Compiled 12 to 10 computations (16.7% saved)

sample1.0s (63%)

Memory
3.3MiB live, 1 766.5MiB allocated; 175ms collecting garbage
Samples
526.0ms8 256×0valid
156.0ms2 417×0invalid
Precisions
Click to see histograms. Total time spent on operations: 343.0ms
ival-mult!: 214.0ms (62.4% of total)
ival-sqrt: 86.0ms (25.1% of total)
ival-sub!: 41.0ms (12% of total)
adjust: 2.0ms (0.6% of total)
Bogosity

explain85.0ms (5.3%)

Memory
20.9MiB live, 218.3MiB allocated; 7ms collecting garbage
FPErrors
Click to see full error table
Ground TruthOverpredictionsExampleUnderpredictionsExampleSubexpression
1320-2(2.2997044489147206e+138 4.268491333916188e-159 7.100194543064951e-210)(sqrt.f64 (-.f64 (*.f64 y y) (*.f64 z z)))
170-0-(-.f64 (*.f64 y y) (*.f64 z z))
00-0-(*.f64 x (sqrt.f64 (-.f64 (*.f64 y y) (*.f64 z z))))
00-0-y
00-0-(*.f64 z z)
00-0-(*.f64 y y)
00-0-z
00-0-x
Explanations
Click to see full explanations table
OperatorSubexpressionExplanationCount
sqrt.f64(sqrt.f64 (-.f64 (*.f64 y y) (*.f64 z z)))oflow-rescue1110
(*.f64 y y)overflow111
(-.f64 (*.f64 y y) (*.f64 z z))overflow111
(*.f64 z z)overflow17
sqrt.f64(sqrt.f64 (-.f64 (*.f64 y y) (*.f64 z z)))uflow-rescue190
(*.f64 y y)underflow19
(-.f64 (*.f64 y y) (*.f64 z z))underflow19
(*.f64 z z)underflow112
-.f64(-.f64 (*.f64 y y) (*.f64 z z))nan-rescue170
(*.f64 y y)overflow111
(*.f64 z z)overflow17
Confusion
Predicted +Predicted -
+861
-44125
Precision
0.6615384615384615
Recall
0.9885057471264368
Confusion?
Predicted +Predicted MaybePredicted -
+8601
-440125
Precision?
0.6615384615384615
Recall?
0.9885057471264368
Freqs
test
numberfreq
0126
1113
217
Total Confusion?
Predicted +Predicted MaybePredicted -
+100
-000
Precision?
1.0
Recall?
1.0
Samples
28.0ms512×0valid
Compiler

Compiled 82 to 28 computations (65.9% saved)

Precisions
Click to see histograms. Total time spent on operations: 14.0ms
ival-mult!: 8.0ms (58.9% of total)
ival-sqrt: 4.0ms (29.4% of total)
ival-sub!: 1.0ms (7.4% of total)
adjust: 0.0ms (0% of total)

preprocess120.0ms (7.5%)

Memory
-5.3MiB live, 138.5MiB allocated; 6ms collecting garbage
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
033103
1101103
2364103
3641103
41529103
53400103
65521103
77433103
0810
01310
12710
28710
322910
440710
584010
6138910
7207310
8290010
9321010
10327210
11327210
12335010
0335010
Stop Event
iter-limit
saturated
iter-limit
node-limit
Calls
Call 1
Inputs
(*.f64 x (sqrt.f64 (-.f64 (*.f64 y y) (*.f64 z z))))
Outputs
(*.f64 x (sqrt.f64 (-.f64 (*.f64 y y) (*.f64 z z))))
(*.f64 (sqrt.f64 (*.f64 (-.f64 y z) (+.f64 z y))) x)
Symmetry

(abs y)

(abs z)

(negabs x)

Compiler

Compiled 10 to 8 computations (20% saved)

eval0.0ms (0%)

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

Compiled 0 to 3 computations (-∞% saved)

prune0.0ms (0%)

Memory
1.0MiB live, 1.0MiB allocated; 0ms collecting garbage
Alt Table
Click to see full alt table
StatusAccuracyProgram
67.6%
(*.f64 x (sqrt.f64 (-.f64 (*.f64 y y) (*.f64 z z))))
Compiler

Compiled 10 to 8 computations (20% saved)

series14.0ms (0.9%)

Memory
-12.9MiB live, 34.3MiB allocated; 2ms collecting garbage
Counts
8 → 56
Calls
Call 1
Inputs
(*.f64 x (sqrt.f64 (-.f64 (*.f64 y y) (*.f64 z z))))
x
(sqrt.f64 (-.f64 (*.f64 y y) (*.f64 z z)))
(-.f64 (*.f64 y y) (*.f64 z z))
(*.f64 y y)
y
(*.f64 z z)
z
Outputs
#s(approx (* x (sqrt (- (* y y) (* z z)))) #s(hole binary64 (* x (sqrt (- (pow y 2) (pow z 2))))))
#s(approx x #s(hole binary64 x))
#s(approx (* x (sqrt (- (* y y) (* z z)))) #s(hole binary64 (* x (* z (sqrt -1)))))
#s(approx (* x (sqrt (- (* y y) (* z z)))) #s(hole binary64 (+ (* 1/2 (/ (* x (pow y 2)) (* z (sqrt -1)))) (* x (* z (sqrt -1))))))
#s(approx (* x (sqrt (- (* y y) (* z z)))) #s(hole binary64 (+ (* x (* z (sqrt -1))) (* (pow y 2) (+ (* -1/8 (/ (* x (pow y 2)) (* (pow z 3) (pow (sqrt -1) 3)))) (* 1/2 (/ x (* z (sqrt -1)))))))))
#s(approx (* x (sqrt (- (* y y) (* z z)))) #s(hole binary64 (+ (* x (* z (sqrt -1))) (* (pow y 2) (+ (* 1/2 (/ x (* z (sqrt -1)))) (* (pow y 2) (+ (* -1/8 (/ x (* (pow z 3) (pow (sqrt -1) 3)))) (* 1/16 (/ (* x (pow y 2)) (* (pow z 5) (pow (sqrt -1) 5)))))))))))
#s(approx (sqrt (- (* y y) (* z z))) #s(hole binary64 (* z (sqrt -1))))
#s(approx (sqrt (- (* y y) (* z z))) #s(hole binary64 (+ (* 1/2 (/ (pow y 2) (* z (sqrt -1)))) (* z (sqrt -1)))))
#s(approx (sqrt (- (* y y) (* z z))) #s(hole binary64 (+ (* z (sqrt -1)) (* (pow y 2) (+ (* -1/8 (/ (pow y 2) (* (pow z 3) (pow (sqrt -1) 3)))) (* 1/2 (/ 1 (* z (sqrt -1)))))))))
#s(approx (sqrt (- (* y y) (* z z))) #s(hole binary64 (+ (* z (sqrt -1)) (* (pow y 2) (+ (* (pow y 2) (- (* 1/16 (/ (pow y 2) (* (pow z 5) (pow (sqrt -1) 5)))) (* 1/8 (/ 1 (* (pow z 3) (pow (sqrt -1) 3)))))) (* 1/2 (/ 1 (* z (sqrt -1)))))))))
#s(approx (- (* y y) (* z z)) #s(hole binary64 (* -1 (pow z 2))))
#s(approx (- (* y y) (* z z)) #s(hole binary64 (- (pow y 2) (pow z 2))))
#s(approx (* y y) #s(hole binary64 (pow y 2)))
#s(approx y #s(hole binary64 y))
#s(approx (* x (sqrt (- (* y y) (* z z)))) #s(hole binary64 (* x y)))
#s(approx (* x (sqrt (- (* y y) (* z z)))) #s(hole binary64 (* y (+ x (* -1/2 (/ (* x (pow z 2)) (pow y 2)))))))
#s(approx (* x (sqrt (- (* y y) (* z z)))) #s(hole binary64 (* y (+ x (+ (* -1/2 (/ (* x (pow z 2)) (pow y 2))) (* -1/8 (/ (* x (pow z 4)) (pow y 4))))))))
#s(approx (* x (sqrt (- (* y y) (* z z)))) #s(hole binary64 (* y (+ x (+ (* -1/2 (/ (* x (pow z 2)) (pow y 2))) (+ (* -1/8 (/ (* x (pow z 4)) (pow y 4))) (* -1/16 (/ (* x (pow z 6)) (pow y 6)))))))))
#s(approx (sqrt (- (* y y) (* z z))) #s(hole binary64 y))
#s(approx (sqrt (- (* y y) (* z z))) #s(hole binary64 (* y (+ 1 (* -1/2 (/ (pow z 2) (pow y 2)))))))
#s(approx (sqrt (- (* y y) (* z z))) #s(hole binary64 (* y (+ 1 (+ (* -1/2 (/ (pow z 2) (pow y 2))) (* -1/8 (/ (pow z 4) (pow y 4))))))))
#s(approx (sqrt (- (* y y) (* z z))) #s(hole binary64 (* y (+ 1 (+ (* -1/2 (/ (pow z 2) (pow y 2))) (+ (* -1/8 (/ (pow z 4) (pow y 4))) (* -1/16 (/ (pow z 6) (pow y 6)))))))))
#s(approx (- (* y y) (* z z)) #s(hole binary64 (pow y 2)))
#s(approx (- (* y y) (* z z)) #s(hole binary64 (* (pow y 2) (+ 1 (* -1 (/ (pow z 2) (pow y 2)))))))
#s(approx (* x (sqrt (- (* y y) (* z z)))) #s(hole binary64 (* -1 (* x y))))
#s(approx (* x (sqrt (- (* y y) (* z z)))) #s(hole binary64 (* -1 (* y (+ x (* -1/2 (/ (* x (pow z 2)) (pow y 2))))))))
#s(approx (* x (sqrt (- (* y y) (* z z)))) #s(hole binary64 (* -1 (* y (+ x (+ (* -1/2 (/ (* x (pow z 2)) (pow y 2))) (* -1/8 (/ (* x (pow z 4)) (pow y 4)))))))))
#s(approx (* x (sqrt (- (* y y) (* z z)))) #s(hole binary64 (* -1 (* y (+ x (+ (* -1/2 (/ (* x (pow z 2)) (pow y 2))) (+ (* -1/8 (/ (* x (pow z 4)) (pow y 4))) (* -1/16 (/ (* x (pow z 6)) (pow y 6))))))))))
#s(approx (sqrt (- (* y y) (* z z))) #s(hole binary64 (* -1 y)))
#s(approx (sqrt (- (* y y) (* z z))) #s(hole binary64 (* -1 (* y (+ 1 (* -1/2 (/ (pow z 2) (pow y 2))))))))
#s(approx (sqrt (- (* y y) (* z z))) #s(hole binary64 (* -1 (* y (+ 1 (+ (* -1/2 (/ (pow z 2) (pow y 2))) (* -1/8 (/ (pow z 4) (pow y 4)))))))))
#s(approx (sqrt (- (* y y) (* z z))) #s(hole binary64 (* -1 (* y (+ 1 (+ (* -1/2 (/ (pow z 2) (pow y 2))) (+ (* -1/8 (/ (pow z 4) (pow y 4))) (* -1/16 (/ (pow z 6) (pow y 6))))))))))
#s(approx (* x (sqrt (- (* y y) (* z z)))) #s(hole binary64 (+ (* -1/2 (/ (* x (pow z 2)) y)) (* x y))))
#s(approx (* x (sqrt (- (* y y) (* z z)))) #s(hole binary64 (+ (* x y) (* (pow z 2) (+ (* -1/2 (/ x y)) (* -1/8 (/ (* x (pow z 2)) (pow y 3))))))))
#s(approx (* x (sqrt (- (* y y) (* z z)))) #s(hole binary64 (+ (* x y) (* (pow z 2) (+ (* -1/2 (/ x y)) (* (pow z 2) (+ (* -1/8 (/ x (pow y 3))) (* -1/16 (/ (* x (pow z 2)) (pow y 5))))))))))
#s(approx (sqrt (- (* y y) (* z z))) #s(hole binary64 (+ y (* -1/2 (/ (pow z 2) y)))))
#s(approx (sqrt (- (* y y) (* z z))) #s(hole binary64 (+ y (* (pow z 2) (- (* -1/8 (/ (pow z 2) (pow y 3))) (* 1/2 (/ 1 y)))))))
#s(approx (sqrt (- (* y y) (* z z))) #s(hole binary64 (+ y (* (pow z 2) (- (* (pow z 2) (- (* -1/16 (/ (pow z 2) (pow y 5))) (* 1/8 (/ 1 (pow y 3))))) (* 1/2 (/ 1 y)))))))
#s(approx (- (* y y) (* z z)) #s(hole binary64 (+ (* -1 (pow z 2)) (pow y 2))))
#s(approx (* z z) #s(hole binary64 (pow z 2)))
#s(approx z #s(hole binary64 z))
#s(approx (* x (sqrt (- (* y y) (* z z)))) #s(hole binary64 (* z (+ (* 1/2 (/ (* x (pow y 2)) (* (pow z 2) (sqrt -1)))) (* x (sqrt -1))))))
#s(approx (* x (sqrt (- (* y y) (* z z)))) #s(hole binary64 (* z (+ (* -1/8 (/ (* x (pow y 4)) (* (pow z 4) (pow (sqrt -1) 3)))) (+ (* 1/2 (/ (* x (pow y 2)) (* (pow z 2) (sqrt -1)))) (* x (sqrt -1)))))))
#s(approx (* x (sqrt (- (* y y) (* z z)))) #s(hole binary64 (* z (+ (* -1/8 (/ (* x (pow y 4)) (* (pow z 4) (pow (sqrt -1) 3)))) (+ (* 1/16 (/ (* x (pow y 6)) (* (pow z 6) (pow (sqrt -1) 5)))) (+ (* 1/2 (/ (* x (pow y 2)) (* (pow z 2) (sqrt -1)))) (* x (sqrt -1))))))))
#s(approx (sqrt (- (* y y) (* z z))) #s(hole binary64 (* z (+ (sqrt -1) (* 1/2 (/ (pow y 2) (* (pow z 2) (sqrt -1))))))))
#s(approx (sqrt (- (* y y) (* z z))) #s(hole binary64 (* z (+ (sqrt -1) (+ (* -1/8 (/ (pow y 4) (* (pow z 4) (pow (sqrt -1) 3)))) (* 1/2 (/ (pow y 2) (* (pow z 2) (sqrt -1)))))))))
#s(approx (sqrt (- (* y y) (* z z))) #s(hole binary64 (* z (+ (sqrt -1) (+ (* -1/8 (/ (pow y 4) (* (pow z 4) (pow (sqrt -1) 3)))) (+ (* 1/16 (/ (pow y 6) (* (pow z 6) (pow (sqrt -1) 5)))) (* 1/2 (/ (pow y 2) (* (pow z 2) (sqrt -1))))))))))
#s(approx (- (* y y) (* z z)) #s(hole binary64 (* (pow z 2) (- (/ (pow y 2) (pow z 2)) 1))))
#s(approx (* x (sqrt (- (* y y) (* z z)))) #s(hole binary64 (* -1 (* x (* z (sqrt -1))))))
#s(approx (* x (sqrt (- (* y y) (* z z)))) #s(hole binary64 (* -1 (* z (+ (* 1/2 (/ (* x (pow y 2)) (* (pow z 2) (sqrt -1)))) (* x (sqrt -1)))))))
#s(approx (* x (sqrt (- (* y y) (* z z)))) #s(hole binary64 (* -1 (* z (+ (* -1/8 (/ (* x (pow y 4)) (* (pow z 4) (pow (sqrt -1) 3)))) (+ (* 1/2 (/ (* x (pow y 2)) (* (pow z 2) (sqrt -1)))) (* x (sqrt -1))))))))
#s(approx (* x (sqrt (- (* y y) (* z z)))) #s(hole binary64 (* -1 (* z (+ (* -1/8 (/ (* x (pow y 4)) (* (pow z 4) (pow (sqrt -1) 3)))) (+ (* 1/16 (/ (* x (pow y 6)) (* (pow z 6) (pow (sqrt -1) 5)))) (+ (* 1/2 (/ (* x (pow y 2)) (* (pow z 2) (sqrt -1)))) (* x (sqrt -1)))))))))
#s(approx (sqrt (- (* y y) (* z z))) #s(hole binary64 (* -1 (* z (sqrt -1)))))
#s(approx (sqrt (- (* y y) (* z z))) #s(hole binary64 (* -1 (* z (+ (sqrt -1) (* 1/2 (/ (pow y 2) (* (pow z 2) (sqrt -1)))))))))
#s(approx (sqrt (- (* y y) (* z z))) #s(hole binary64 (* -1 (* z (+ (sqrt -1) (+ (* -1/8 (/ (pow y 4) (* (pow z 4) (pow (sqrt -1) 3)))) (* 1/2 (/ (pow y 2) (* (pow z 2) (sqrt -1))))))))))
#s(approx (sqrt (- (* y y) (* z z))) #s(hole binary64 (* -1 (* z (+ (sqrt -1) (+ (* -1/8 (/ (pow y 4) (* (pow z 4) (pow (sqrt -1) 3)))) (+ (* 1/16 (/ (pow y 6) (* (pow z 6) (pow (sqrt -1) 5)))) (* 1/2 (/ (pow y 2) (* (pow z 2) (sqrt -1)))))))))))
Calls

9 calls:

TimeVariablePointExpression
3.0ms
z
@inf
((* x (sqrt (- (* y y) (* z z)))) x (sqrt (- (* y y) (* z z))) (- (* y y) (* z z)) (* y y) y (* z z) z)
2.0ms
y
@inf
((* x (sqrt (- (* y y) (* z z)))) x (sqrt (- (* y y) (* z z))) (- (* y y) (* z z)) (* y y) y (* z z) z)
1.0ms
x
@-inf
((* x (sqrt (- (* y y) (* z z)))) x (sqrt (- (* y y) (* z z))) (- (* y y) (* z z)) (* y y) y (* z z) z)
1.0ms
y
@0
((* x (sqrt (- (* y y) (* z z)))) x (sqrt (- (* y y) (* z z))) (- (* y y) (* z z)) (* y y) y (* z z) z)
1.0ms
x
@0
((* x (sqrt (- (* y y) (* z z)))) x (sqrt (- (* y y) (* z z))) (- (* y y) (* z z)) (* y y) y (* z z) z)

rewrite66.0ms (4.1%)

Memory
31.4MiB live, 123.4MiB allocated; 6ms collecting garbage
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
02711740
02781685
014561627
Stop Event
iter-limit
iter-limit
node-limit
iter-limit
Counts
64 → 84
Calls
Call 1
Inputs
(*.f64 x (sqrt.f64 (-.f64 (*.f64 y y) (*.f64 z z))))
x
(sqrt.f64 (-.f64 (*.f64 y y) (*.f64 z z)))
(-.f64 (*.f64 y y) (*.f64 z z))
(*.f64 y y)
y
(*.f64 z z)
z
#s(approx (* x (sqrt (- (* y y) (* z z)))) #s(hole binary64 (* x (sqrt (- (pow y 2) (pow z 2))))))
#s(approx x #s(hole binary64 x))
#s(approx (* x (sqrt (- (* y y) (* z z)))) #s(hole binary64 (* x (* z (sqrt -1)))))
#s(approx (* x (sqrt (- (* y y) (* z z)))) #s(hole binary64 (+ (* 1/2 (/ (* x (pow y 2)) (* z (sqrt -1)))) (* x (* z (sqrt -1))))))
#s(approx (* x (sqrt (- (* y y) (* z z)))) #s(hole binary64 (+ (* x (* z (sqrt -1))) (* (pow y 2) (+ (* -1/8 (/ (* x (pow y 2)) (* (pow z 3) (pow (sqrt -1) 3)))) (* 1/2 (/ x (* z (sqrt -1)))))))))
#s(approx (* x (sqrt (- (* y y) (* z z)))) #s(hole binary64 (+ (* x (* z (sqrt -1))) (* (pow y 2) (+ (* 1/2 (/ x (* z (sqrt -1)))) (* (pow y 2) (+ (* -1/8 (/ x (* (pow z 3) (pow (sqrt -1) 3)))) (* 1/16 (/ (* x (pow y 2)) (* (pow z 5) (pow (sqrt -1) 5)))))))))))
#s(approx (sqrt (- (* y y) (* z z))) #s(hole binary64 (* z (sqrt -1))))
#s(approx (sqrt (- (* y y) (* z z))) #s(hole binary64 (+ (* 1/2 (/ (pow y 2) (* z (sqrt -1)))) (* z (sqrt -1)))))
#s(approx (sqrt (- (* y y) (* z z))) #s(hole binary64 (+ (* z (sqrt -1)) (* (pow y 2) (+ (* -1/8 (/ (pow y 2) (* (pow z 3) (pow (sqrt -1) 3)))) (* 1/2 (/ 1 (* z (sqrt -1)))))))))
#s(approx (sqrt (- (* y y) (* z z))) #s(hole binary64 (+ (* z (sqrt -1)) (* (pow y 2) (+ (* (pow y 2) (- (* 1/16 (/ (pow y 2) (* (pow z 5) (pow (sqrt -1) 5)))) (* 1/8 (/ 1 (* (pow z 3) (pow (sqrt -1) 3)))))) (* 1/2 (/ 1 (* z (sqrt -1)))))))))
#s(approx (- (* y y) (* z z)) #s(hole binary64 (* -1 (pow z 2))))
#s(approx (- (* y y) (* z z)) #s(hole binary64 (- (pow y 2) (pow z 2))))
#s(approx (* y y) #s(hole binary64 (pow y 2)))
#s(approx y #s(hole binary64 y))
#s(approx (* x (sqrt (- (* y y) (* z z)))) #s(hole binary64 (* x y)))
#s(approx (* x (sqrt (- (* y y) (* z z)))) #s(hole binary64 (* y (+ x (* -1/2 (/ (* x (pow z 2)) (pow y 2)))))))
#s(approx (* x (sqrt (- (* y y) (* z z)))) #s(hole binary64 (* y (+ x (+ (* -1/2 (/ (* x (pow z 2)) (pow y 2))) (* -1/8 (/ (* x (pow z 4)) (pow y 4))))))))
#s(approx (* x (sqrt (- (* y y) (* z z)))) #s(hole binary64 (* y (+ x (+ (* -1/2 (/ (* x (pow z 2)) (pow y 2))) (+ (* -1/8 (/ (* x (pow z 4)) (pow y 4))) (* -1/16 (/ (* x (pow z 6)) (pow y 6)))))))))
#s(approx (sqrt (- (* y y) (* z z))) #s(hole binary64 y))
#s(approx (sqrt (- (* y y) (* z z))) #s(hole binary64 (* y (+ 1 (* -1/2 (/ (pow z 2) (pow y 2)))))))
#s(approx (sqrt (- (* y y) (* z z))) #s(hole binary64 (* y (+ 1 (+ (* -1/2 (/ (pow z 2) (pow y 2))) (* -1/8 (/ (pow z 4) (pow y 4))))))))
#s(approx (sqrt (- (* y y) (* z z))) #s(hole binary64 (* y (+ 1 (+ (* -1/2 (/ (pow z 2) (pow y 2))) (+ (* -1/8 (/ (pow z 4) (pow y 4))) (* -1/16 (/ (pow z 6) (pow y 6)))))))))
#s(approx (- (* y y) (* z z)) #s(hole binary64 (pow y 2)))
#s(approx (- (* y y) (* z z)) #s(hole binary64 (* (pow y 2) (+ 1 (* -1 (/ (pow z 2) (pow y 2)))))))
#s(approx (* x (sqrt (- (* y y) (* z z)))) #s(hole binary64 (* -1 (* x y))))
#s(approx (* x (sqrt (- (* y y) (* z z)))) #s(hole binary64 (* -1 (* y (+ x (* -1/2 (/ (* x (pow z 2)) (pow y 2))))))))
#s(approx (* x (sqrt (- (* y y) (* z z)))) #s(hole binary64 (* -1 (* y (+ x (+ (* -1/2 (/ (* x (pow z 2)) (pow y 2))) (* -1/8 (/ (* x (pow z 4)) (pow y 4)))))))))
#s(approx (* x (sqrt (- (* y y) (* z z)))) #s(hole binary64 (* -1 (* y (+ x (+ (* -1/2 (/ (* x (pow z 2)) (pow y 2))) (+ (* -1/8 (/ (* x (pow z 4)) (pow y 4))) (* -1/16 (/ (* x (pow z 6)) (pow y 6))))))))))
#s(approx (sqrt (- (* y y) (* z z))) #s(hole binary64 (* -1 y)))
#s(approx (sqrt (- (* y y) (* z z))) #s(hole binary64 (* -1 (* y (+ 1 (* -1/2 (/ (pow z 2) (pow y 2))))))))
#s(approx (sqrt (- (* y y) (* z z))) #s(hole binary64 (* -1 (* y (+ 1 (+ (* -1/2 (/ (pow z 2) (pow y 2))) (* -1/8 (/ (pow z 4) (pow y 4)))))))))
#s(approx (sqrt (- (* y y) (* z z))) #s(hole binary64 (* -1 (* y (+ 1 (+ (* -1/2 (/ (pow z 2) (pow y 2))) (+ (* -1/8 (/ (pow z 4) (pow y 4))) (* -1/16 (/ (pow z 6) (pow y 6))))))))))
#s(approx (* x (sqrt (- (* y y) (* z z)))) #s(hole binary64 (+ (* -1/2 (/ (* x (pow z 2)) y)) (* x y))))
#s(approx (* x (sqrt (- (* y y) (* z z)))) #s(hole binary64 (+ (* x y) (* (pow z 2) (+ (* -1/2 (/ x y)) (* -1/8 (/ (* x (pow z 2)) (pow y 3))))))))
#s(approx (* x (sqrt (- (* y y) (* z z)))) #s(hole binary64 (+ (* x y) (* (pow z 2) (+ (* -1/2 (/ x y)) (* (pow z 2) (+ (* -1/8 (/ x (pow y 3))) (* -1/16 (/ (* x (pow z 2)) (pow y 5))))))))))
#s(approx (sqrt (- (* y y) (* z z))) #s(hole binary64 (+ y (* -1/2 (/ (pow z 2) y)))))
#s(approx (sqrt (- (* y y) (* z z))) #s(hole binary64 (+ y (* (pow z 2) (- (* -1/8 (/ (pow z 2) (pow y 3))) (* 1/2 (/ 1 y)))))))
#s(approx (sqrt (- (* y y) (* z z))) #s(hole binary64 (+ y (* (pow z 2) (- (* (pow z 2) (- (* -1/16 (/ (pow z 2) (pow y 5))) (* 1/8 (/ 1 (pow y 3))))) (* 1/2 (/ 1 y)))))))
#s(approx (- (* y y) (* z z)) #s(hole binary64 (+ (* -1 (pow z 2)) (pow y 2))))
#s(approx (* z z) #s(hole binary64 (pow z 2)))
#s(approx z #s(hole binary64 z))
#s(approx (* x (sqrt (- (* y y) (* z z)))) #s(hole binary64 (* z (+ (* 1/2 (/ (* x (pow y 2)) (* (pow z 2) (sqrt -1)))) (* x (sqrt -1))))))
#s(approx (* x (sqrt (- (* y y) (* z z)))) #s(hole binary64 (* z (+ (* -1/8 (/ (* x (pow y 4)) (* (pow z 4) (pow (sqrt -1) 3)))) (+ (* 1/2 (/ (* x (pow y 2)) (* (pow z 2) (sqrt -1)))) (* x (sqrt -1)))))))
#s(approx (* x (sqrt (- (* y y) (* z z)))) #s(hole binary64 (* z (+ (* -1/8 (/ (* x (pow y 4)) (* (pow z 4) (pow (sqrt -1) 3)))) (+ (* 1/16 (/ (* x (pow y 6)) (* (pow z 6) (pow (sqrt -1) 5)))) (+ (* 1/2 (/ (* x (pow y 2)) (* (pow z 2) (sqrt -1)))) (* x (sqrt -1))))))))
#s(approx (sqrt (- (* y y) (* z z))) #s(hole binary64 (* z (+ (sqrt -1) (* 1/2 (/ (pow y 2) (* (pow z 2) (sqrt -1))))))))
#s(approx (sqrt (- (* y y) (* z z))) #s(hole binary64 (* z (+ (sqrt -1) (+ (* -1/8 (/ (pow y 4) (* (pow z 4) (pow (sqrt -1) 3)))) (* 1/2 (/ (pow y 2) (* (pow z 2) (sqrt -1)))))))))
#s(approx (sqrt (- (* y y) (* z z))) #s(hole binary64 (* z (+ (sqrt -1) (+ (* -1/8 (/ (pow y 4) (* (pow z 4) (pow (sqrt -1) 3)))) (+ (* 1/16 (/ (pow y 6) (* (pow z 6) (pow (sqrt -1) 5)))) (* 1/2 (/ (pow y 2) (* (pow z 2) (sqrt -1))))))))))
#s(approx (- (* y y) (* z z)) #s(hole binary64 (* (pow z 2) (- (/ (pow y 2) (pow z 2)) 1))))
#s(approx (* x (sqrt (- (* y y) (* z z)))) #s(hole binary64 (* -1 (* x (* z (sqrt -1))))))
#s(approx (* x (sqrt (- (* y y) (* z z)))) #s(hole binary64 (* -1 (* z (+ (* 1/2 (/ (* x (pow y 2)) (* (pow z 2) (sqrt -1)))) (* x (sqrt -1)))))))
#s(approx (* x (sqrt (- (* y y) (* z z)))) #s(hole binary64 (* -1 (* z (+ (* -1/8 (/ (* x (pow y 4)) (* (pow z 4) (pow (sqrt -1) 3)))) (+ (* 1/2 (/ (* x (pow y 2)) (* (pow z 2) (sqrt -1)))) (* x (sqrt -1))))))))
#s(approx (* x (sqrt (- (* y y) (* z z)))) #s(hole binary64 (* -1 (* z (+ (* -1/8 (/ (* x (pow y 4)) (* (pow z 4) (pow (sqrt -1) 3)))) (+ (* 1/16 (/ (* x (pow y 6)) (* (pow z 6) (pow (sqrt -1) 5)))) (+ (* 1/2 (/ (* x (pow y 2)) (* (pow z 2) (sqrt -1)))) (* x (sqrt -1)))))))))
#s(approx (sqrt (- (* y y) (* z z))) #s(hole binary64 (* -1 (* z (sqrt -1)))))
#s(approx (sqrt (- (* y y) (* z z))) #s(hole binary64 (* -1 (* z (+ (sqrt -1) (* 1/2 (/ (pow y 2) (* (pow z 2) (sqrt -1)))))))))
#s(approx (sqrt (- (* y y) (* z z))) #s(hole binary64 (* -1 (* z (+ (sqrt -1) (+ (* -1/8 (/ (pow y 4) (* (pow z 4) (pow (sqrt -1) 3)))) (* 1/2 (/ (pow y 2) (* (pow z 2) (sqrt -1))))))))))
#s(approx (sqrt (- (* y y) (* z z))) #s(hole binary64 (* -1 (* z (+ (sqrt -1) (+ (* -1/8 (/ (pow y 4) (* (pow z 4) (pow (sqrt -1) 3)))) (+ (* 1/16 (/ (pow y 6) (* (pow z 6) (pow (sqrt -1) 5)))) (* 1/2 (/ (pow y 2) (* (pow z 2) (sqrt -1)))))))))))
Outputs
(*.f64 (sqrt.f64 (*.f64 (+.f64 y z) (-.f64 y z))) x)
(*.f64 x (sqrt.f64 (*.f64 (+.f64 y z) (-.f64 y z))))
x
(pow.f64 (*.f64 (+.f64 y z) (-.f64 y z)) #s(literal 1/2 binary64))
(sqrt.f64 (*.f64 (+.f64 y z) (-.f64 y z)))
(*.f64 (+.f64 y z) (-.f64 y z))
(/.f64 (-.f64 (pow.f64 y #s(literal 4 binary64)) (pow.f64 z #s(literal 4 binary64))) (fma.f64 y y (*.f64 z z)))
(/.f64 (-.f64 (pow.f64 (*.f64 y y) #s(literal 3 binary64)) (pow.f64 (*.f64 z z) #s(literal 3 binary64))) (+.f64 (pow.f64 y #s(literal 4 binary64)) (+.f64 (pow.f64 z #s(literal 4 binary64)) (*.f64 (*.f64 y y) (*.f64 z z)))))
(fma.f64 (pow.f64 y #s(literal 1 binary64)) (pow.f64 y #s(literal 1 binary64)) (*.f64 (neg.f64 z) z))
(fma.f64 (neg.f64 y) (neg.f64 y) (*.f64 (neg.f64 z) z))
(fma.f64 (fabs.f64 y) (fabs.f64 y) (*.f64 (neg.f64 z) z))
(fma.f64 y y (*.f64 (neg.f64 z) z))
(-.f64 (*.f64 y y) (*.f64 z z))
(+.f64 (*.f64 y y) (*.f64 (neg.f64 z) z))
(*.f64 (pow.f64 y #s(literal 1 binary64)) (pow.f64 y #s(literal 1 binary64)))
(*.f64 (neg.f64 y) (neg.f64 y))
(*.f64 (fabs.f64 y) (fabs.f64 y))
(*.f64 y y)
(pow.f64 y #s(literal 2 binary64))
(exp.f64 (*.f64 (log.f64 y) #s(literal 2 binary64)))
y
(*.f64 (pow.f64 z #s(literal 1 binary64)) (pow.f64 z #s(literal 1 binary64)))
(*.f64 (neg.f64 z) (neg.f64 z))
(*.f64 (fabs.f64 z) (fabs.f64 z))
(*.f64 z z)
(pow.f64 z #s(literal 2 binary64))
(exp.f64 (*.f64 (log.f64 z) #s(literal 2 binary64)))
z
#s(approx (* x (sqrt (- (* y y) (* z z)))) (*.f64 (sqrt.f64 (*.f64 (+.f64 y z) (-.f64 y z))) x))
#s(approx x x)
#s(approx (* x (sqrt (- (* y y) (* z z)))) (*.f64 (*.f64 (sqrt.f64 #s(literal -1 binary64)) z) x))
#s(approx (* x (sqrt (- (* y y) (* z z)))) (fma.f64 (*.f64 x z) (sqrt.f64 #s(literal -1 binary64)) (/.f64 (*.f64 #s(literal 1/2 binary64) (*.f64 (*.f64 y y) x)) (*.f64 (sqrt.f64 #s(literal -1 binary64)) z))))
#s(approx (* x (sqrt (- (* y y) (* z z)))) (fma.f64 (*.f64 x z) (sqrt.f64 #s(literal -1 binary64)) (*.f64 (fma.f64 (/.f64 x (*.f64 (sqrt.f64 #s(literal -1 binary64)) z)) #s(literal 1/2 binary64) (/.f64 (*.f64 #s(literal -1/8 binary64) (*.f64 (*.f64 y y) x)) (pow.f64 (*.f64 (sqrt.f64 #s(literal -1 binary64)) z) #s(literal 3 binary64)))) (*.f64 y y))))
#s(approx (* x (sqrt (- (* y y) (* z z)))) (fma.f64 (*.f64 x z) (sqrt.f64 #s(literal -1 binary64)) (*.f64 (fma.f64 (fma.f64 (/.f64 (*.f64 (*.f64 y y) x) (pow.f64 (*.f64 (sqrt.f64 #s(literal -1 binary64)) z) #s(literal 5 binary64))) #s(literal 1/16 binary64) (*.f64 (/.f64 x (pow.f64 (*.f64 (sqrt.f64 #s(literal -1 binary64)) z) #s(literal 3 binary64))) #s(literal -1/8 binary64))) (*.f64 y y) (*.f64 (/.f64 x (*.f64 (sqrt.f64 #s(literal -1 binary64)) z)) #s(literal 1/2 binary64))) (*.f64 y y))))
#s(approx (sqrt (- (* y y) (* z z))) (*.f64 (sqrt.f64 #s(literal -1 binary64)) z))
#s(approx (sqrt (- (* y y) (* z z))) (fma.f64 (/.f64 (/.f64 (*.f64 y y) z) (sqrt.f64 #s(literal -1 binary64))) #s(literal 1/2 binary64) (*.f64 (sqrt.f64 #s(literal -1 binary64)) z)))
#s(approx (sqrt (- (* y y) (* z z))) (fma.f64 (fma.f64 (/.f64 (*.f64 y y) (pow.f64 (*.f64 (sqrt.f64 #s(literal -1 binary64)) z) #s(literal 3 binary64))) #s(literal -1/8 binary64) (/.f64 #s(literal 1/2 binary64) (*.f64 (sqrt.f64 #s(literal -1 binary64)) z))) (*.f64 y y) (*.f64 (sqrt.f64 #s(literal -1 binary64)) z)))
#s(approx (sqrt (- (* y y) (* z z))) (fma.f64 (fma.f64 (-.f64 (/.f64 (*.f64 #s(literal 1/16 binary64) (*.f64 y y)) (pow.f64 (*.f64 (sqrt.f64 #s(literal -1 binary64)) z) #s(literal 5 binary64))) (/.f64 #s(literal 1/8 binary64) (pow.f64 (*.f64 (sqrt.f64 #s(literal -1 binary64)) z) #s(literal 3 binary64)))) (*.f64 y y) (/.f64 #s(literal 1/2 binary64) (*.f64 (sqrt.f64 #s(literal -1 binary64)) z))) (*.f64 y y) (*.f64 (sqrt.f64 #s(literal -1 binary64)) z)))
#s(approx (- (* y y) (* z z)) (neg.f64 (*.f64 z z)))
#s(approx (- (* y y) (* z z)) (*.f64 (+.f64 y z) (-.f64 y z)))
#s(approx (* y y) (*.f64 y y))
#s(approx y y)
#s(approx (* x (sqrt (- (* y y) (* z z)))) (*.f64 y x))
#s(approx (* x (sqrt (- (* y y) (* z z)))) (*.f64 (fma.f64 (/.f64 (*.f64 (*.f64 z z) x) (*.f64 y y)) #s(literal -1/2 binary64) x) y))
#s(approx (* x (sqrt (- (* y y) (* z z)))) (*.f64 (+.f64 (fma.f64 (/.f64 (*.f64 (*.f64 z z) x) (*.f64 y y)) #s(literal -1/2 binary64) x) (/.f64 (*.f64 #s(literal -1/8 binary64) (*.f64 (pow.f64 z #s(literal 4 binary64)) x)) (pow.f64 y #s(literal 4 binary64)))) y))
#s(approx (* x (sqrt (- (* y y) (* z z)))) (*.f64 (+.f64 (fma.f64 (/.f64 (*.f64 (*.f64 z z) x) (*.f64 y y)) #s(literal -1/2 binary64) (fma.f64 (/.f64 (*.f64 (pow.f64 z #s(literal 6 binary64)) x) (pow.f64 y #s(literal 6 binary64))) #s(literal -1/16 binary64) (/.f64 (*.f64 #s(literal -1/8 binary64) (*.f64 (pow.f64 z #s(literal 4 binary64)) x)) (pow.f64 y #s(literal 4 binary64))))) x) y))
#s(approx (sqrt (- (* y y) (* z z))) y)
#s(approx (sqrt (- (* y y) (* z z))) (*.f64 (fma.f64 (/.f64 (*.f64 z z) (*.f64 y y)) #s(literal -1/2 binary64) #s(literal 1 binary64)) y))
#s(approx (sqrt (- (* y y) (* z z))) (*.f64 (+.f64 (fma.f64 (/.f64 (*.f64 z z) (*.f64 y y)) #s(literal -1/2 binary64) #s(literal 1 binary64)) (/.f64 (*.f64 #s(literal -1/8 binary64) (pow.f64 z #s(literal 4 binary64))) (pow.f64 y #s(literal 4 binary64)))) y))
#s(approx (sqrt (- (* y y) (* z z))) (*.f64 (+.f64 (fma.f64 (/.f64 (*.f64 z z) (*.f64 y y)) #s(literal -1/2 binary64) (fma.f64 (/.f64 (pow.f64 z #s(literal 6 binary64)) (pow.f64 y #s(literal 6 binary64))) #s(literal -1/16 binary64) (/.f64 (*.f64 #s(literal -1/8 binary64) (pow.f64 z #s(literal 4 binary64))) (pow.f64 y #s(literal 4 binary64))))) #s(literal 1 binary64)) y))
#s(approx (- (* y y) (* z z)) (*.f64 y y))
#s(approx (- (* y y) (* z z)) (*.f64 (fma.f64 (/.f64 (*.f64 z z) (*.f64 y y)) #s(literal -1 binary64) #s(literal 1 binary64)) (*.f64 y y)))
#s(approx (* x (sqrt (- (* y y) (* z z)))) (neg.f64 (*.f64 y x)))
#s(approx (* x (sqrt (- (* y y) (* z z)))) (*.f64 (neg.f64 y) (fma.f64 (/.f64 (*.f64 (*.f64 z z) x) (*.f64 y y)) #s(literal -1/2 binary64) x)))
#s(approx (* x (sqrt (- (* y y) (* z z)))) (*.f64 (neg.f64 y) (+.f64 (fma.f64 (/.f64 (*.f64 (*.f64 z z) x) (*.f64 y y)) #s(literal -1/2 binary64) x) (/.f64 (*.f64 #s(literal -1/8 binary64) (*.f64 (pow.f64 z #s(literal 4 binary64)) x)) (pow.f64 y #s(literal 4 binary64))))))
#s(approx (* x (sqrt (- (* y y) (* z z)))) (*.f64 (neg.f64 y) (+.f64 (fma.f64 (/.f64 (*.f64 (*.f64 z z) x) (*.f64 y y)) #s(literal -1/2 binary64) (fma.f64 (/.f64 (*.f64 (pow.f64 z #s(literal 6 binary64)) x) (pow.f64 y #s(literal 6 binary64))) #s(literal -1/16 binary64) (/.f64 (*.f64 #s(literal -1/8 binary64) (*.f64 (pow.f64 z #s(literal 4 binary64)) x)) (pow.f64 y #s(literal 4 binary64))))) x)))
#s(approx (sqrt (- (* y y) (* z z))) (neg.f64 y))
#s(approx (sqrt (- (* y y) (* z z))) (*.f64 (neg.f64 y) (fma.f64 (/.f64 (*.f64 z z) (*.f64 y y)) #s(literal -1/2 binary64) #s(literal 1 binary64))))
#s(approx (sqrt (- (* y y) (* z z))) (*.f64 (neg.f64 y) (+.f64 (fma.f64 (/.f64 (*.f64 z z) (*.f64 y y)) #s(literal -1/2 binary64) #s(literal 1 binary64)) (/.f64 (*.f64 #s(literal -1/8 binary64) (pow.f64 z #s(literal 4 binary64))) (pow.f64 y #s(literal 4 binary64))))))
#s(approx (sqrt (- (* y y) (* z z))) (*.f64 (neg.f64 y) (+.f64 (fma.f64 (/.f64 (*.f64 z z) (*.f64 y y)) #s(literal -1/2 binary64) (fma.f64 (/.f64 (pow.f64 z #s(literal 6 binary64)) (pow.f64 y #s(literal 6 binary64))) #s(literal -1/16 binary64) (/.f64 (*.f64 #s(literal -1/8 binary64) (pow.f64 z #s(literal 4 binary64))) (pow.f64 y #s(literal 4 binary64))))) #s(literal 1 binary64))))
#s(approx (* x (sqrt (- (* y y) (* z z)))) (fma.f64 (/.f64 (*.f64 (*.f64 z z) x) y) #s(literal -1/2 binary64) (*.f64 y x)))
#s(approx (* x (sqrt (- (* y y) (* z z)))) (fma.f64 (fma.f64 (/.f64 (*.f64 (*.f64 z z) x) (pow.f64 y #s(literal 3 binary64))) #s(literal -1/8 binary64) (*.f64 (/.f64 x y) #s(literal -1/2 binary64))) (*.f64 z z) (*.f64 y x)))
#s(approx (* x (sqrt (- (* y y) (* z z)))) (fma.f64 (fma.f64 (fma.f64 (/.f64 (*.f64 (*.f64 z z) x) (pow.f64 y #s(literal 5 binary64))) #s(literal -1/16 binary64) (*.f64 (/.f64 x (pow.f64 y #s(literal 3 binary64))) #s(literal -1/8 binary64))) (*.f64 z z) (*.f64 (/.f64 x y) #s(literal -1/2 binary64))) (*.f64 z z) (*.f64 y x)))
#s(approx (sqrt (- (* y y) (* z z))) (fma.f64 (/.f64 (*.f64 z z) y) #s(literal -1/2 binary64) y))
#s(approx (sqrt (- (* y y) (* z z))) (fma.f64 (-.f64 (/.f64 (*.f64 #s(literal -1/8 binary64) (*.f64 z z)) (pow.f64 y #s(literal 3 binary64))) (/.f64 #s(literal 1/2 binary64) y)) (*.f64 z z) y))
#s(approx (sqrt (- (* y y) (* z z))) (fma.f64 (-.f64 (*.f64 (fma.f64 (/.f64 (*.f64 z z) (pow.f64 y #s(literal 5 binary64))) #s(literal -1/16 binary64) (*.f64 #s(literal -1/8 binary64) (pow.f64 y #s(literal -3 binary64)))) (*.f64 z z)) (/.f64 #s(literal 1/2 binary64) y)) (*.f64 z z) y))
#s(approx (- (* y y) (* z z)) (fma.f64 y y (neg.f64 (*.f64 z z))))
#s(approx (* z z) (*.f64 z z))
#s(approx z z)
#s(approx (* x (sqrt (- (* y y) (* z z)))) (*.f64 (fma.f64 (/.f64 (*.f64 (*.f64 y y) x) (*.f64 (sqrt.f64 #s(literal -1 binary64)) (*.f64 z z))) #s(literal 1/2 binary64) (*.f64 (sqrt.f64 #s(literal -1 binary64)) x)) z))
#s(approx (* x (sqrt (- (* y y) (* z z)))) (*.f64 (fma.f64 (/.f64 (*.f64 (pow.f64 y #s(literal 4 binary64)) x) (*.f64 (pow.f64 z #s(literal 4 binary64)) (pow.f64 #s(literal -1 binary64) #s(literal 3/2 binary64)))) #s(literal -1/8 binary64) (fma.f64 (/.f64 (*.f64 (*.f64 y y) x) (*.f64 (sqrt.f64 #s(literal -1 binary64)) (*.f64 z z))) #s(literal 1/2 binary64) (*.f64 (sqrt.f64 #s(literal -1 binary64)) x))) z))
#s(approx (* x (sqrt (- (* y y) (* z z)))) (*.f64 (fma.f64 (/.f64 (*.f64 (pow.f64 y #s(literal 4 binary64)) x) (*.f64 (pow.f64 z #s(literal 4 binary64)) (pow.f64 #s(literal -1 binary64) #s(literal 3/2 binary64)))) #s(literal -1/8 binary64) (fma.f64 (/.f64 (*.f64 (pow.f64 y #s(literal 6 binary64)) x) (*.f64 (pow.f64 z #s(literal 6 binary64)) (pow.f64 #s(literal -1 binary64) #s(literal 5/2 binary64)))) #s(literal 1/16 binary64) (fma.f64 (/.f64 (*.f64 (*.f64 y y) x) (*.f64 (sqrt.f64 #s(literal -1 binary64)) (*.f64 z z))) #s(literal 1/2 binary64) (*.f64 (sqrt.f64 #s(literal -1 binary64)) x)))) z))
#s(approx (sqrt (- (* y y) (* z z))) (*.f64 (fma.f64 (/.f64 (*.f64 y y) (*.f64 (sqrt.f64 #s(literal -1 binary64)) (*.f64 z z))) #s(literal 1/2 binary64) (sqrt.f64 #s(literal -1 binary64))) z))
#s(approx (sqrt (- (* y y) (* z z))) (*.f64 (+.f64 (fma.f64 (/.f64 (pow.f64 y #s(literal 4 binary64)) (*.f64 (pow.f64 z #s(literal 4 binary64)) (pow.f64 #s(literal -1 binary64) #s(literal 3/2 binary64)))) #s(literal -1/8 binary64) (/.f64 (*.f64 #s(literal 1/2 binary64) (*.f64 y y)) (*.f64 (sqrt.f64 #s(literal -1 binary64)) (*.f64 z z)))) (sqrt.f64 #s(literal -1 binary64))) z))
#s(approx (sqrt (- (* y y) (* z z))) (*.f64 (+.f64 (fma.f64 (/.f64 (pow.f64 y #s(literal 4 binary64)) (*.f64 (pow.f64 z #s(literal 4 binary64)) (pow.f64 #s(literal -1 binary64) #s(literal 3/2 binary64)))) #s(literal -1/8 binary64) (fma.f64 (/.f64 (pow.f64 y #s(literal 6 binary64)) (*.f64 (pow.f64 z #s(literal 6 binary64)) (pow.f64 #s(literal -1 binary64) #s(literal 5/2 binary64)))) #s(literal 1/16 binary64) (/.f64 (*.f64 #s(literal 1/2 binary64) (*.f64 y y)) (*.f64 (sqrt.f64 #s(literal -1 binary64)) (*.f64 z z))))) (sqrt.f64 #s(literal -1 binary64))) z))
#s(approx (- (* y y) (* z z)) (*.f64 (-.f64 (/.f64 (*.f64 y y) (*.f64 z z)) #s(literal 1 binary64)) (*.f64 z z)))
#s(approx (* x (sqrt (- (* y y) (* z z)))) (neg.f64 (*.f64 (*.f64 (sqrt.f64 #s(literal -1 binary64)) z) x)))
#s(approx (* x (sqrt (- (* y y) (* z z)))) (neg.f64 (*.f64 (fma.f64 (/.f64 (*.f64 (*.f64 y y) x) (*.f64 (sqrt.f64 #s(literal -1 binary64)) (*.f64 z z))) #s(literal 1/2 binary64) (*.f64 (sqrt.f64 #s(literal -1 binary64)) x)) z)))
#s(approx (* x (sqrt (- (* y y) (* z z)))) (neg.f64 (*.f64 (fma.f64 (/.f64 (*.f64 (pow.f64 y #s(literal 4 binary64)) x) (*.f64 (pow.f64 z #s(literal 4 binary64)) (pow.f64 #s(literal -1 binary64) #s(literal 3/2 binary64)))) #s(literal -1/8 binary64) (fma.f64 (/.f64 (*.f64 (*.f64 y y) x) (*.f64 (sqrt.f64 #s(literal -1 binary64)) (*.f64 z z))) #s(literal 1/2 binary64) (*.f64 (sqrt.f64 #s(literal -1 binary64)) x))) z)))
#s(approx (* x (sqrt (- (* y y) (* z z)))) (neg.f64 (*.f64 (fma.f64 (/.f64 (*.f64 (pow.f64 y #s(literal 4 binary64)) x) (*.f64 (pow.f64 z #s(literal 4 binary64)) (pow.f64 #s(literal -1 binary64) #s(literal 3/2 binary64)))) #s(literal -1/8 binary64) (fma.f64 (/.f64 (*.f64 (pow.f64 y #s(literal 6 binary64)) x) (*.f64 (pow.f64 z #s(literal 6 binary64)) (pow.f64 #s(literal -1 binary64) #s(literal 5/2 binary64)))) #s(literal 1/16 binary64) (fma.f64 (/.f64 (*.f64 (*.f64 y y) x) (*.f64 (sqrt.f64 #s(literal -1 binary64)) (*.f64 z z))) #s(literal 1/2 binary64) (*.f64 (sqrt.f64 #s(literal -1 binary64)) x)))) z)))
#s(approx (sqrt (- (* y y) (* z z))) (neg.f64 (*.f64 (sqrt.f64 #s(literal -1 binary64)) z)))
#s(approx (sqrt (- (* y y) (* z z))) (neg.f64 (*.f64 (fma.f64 (/.f64 (*.f64 y y) (*.f64 (sqrt.f64 #s(literal -1 binary64)) (*.f64 z z))) #s(literal 1/2 binary64) (sqrt.f64 #s(literal -1 binary64))) z)))
#s(approx (sqrt (- (* y y) (* z z))) (neg.f64 (*.f64 (+.f64 (fma.f64 (/.f64 (pow.f64 y #s(literal 4 binary64)) (*.f64 (pow.f64 z #s(literal 4 binary64)) (pow.f64 #s(literal -1 binary64) #s(literal 3/2 binary64)))) #s(literal -1/8 binary64) (/.f64 (*.f64 #s(literal 1/2 binary64) (*.f64 y y)) (*.f64 (sqrt.f64 #s(literal -1 binary64)) (*.f64 z z)))) (sqrt.f64 #s(literal -1 binary64))) z)))
#s(approx (sqrt (- (* y y) (* z z))) (neg.f64 (*.f64 (+.f64 (fma.f64 (/.f64 (pow.f64 y #s(literal 4 binary64)) (*.f64 (pow.f64 z #s(literal 4 binary64)) (pow.f64 #s(literal -1 binary64) #s(literal 3/2 binary64)))) #s(literal -1/8 binary64) (fma.f64 (/.f64 (pow.f64 y #s(literal 6 binary64)) (*.f64 (pow.f64 z #s(literal 6 binary64)) (pow.f64 #s(literal -1 binary64) #s(literal 5/2 binary64)))) #s(literal 1/16 binary64) (/.f64 (*.f64 #s(literal 1/2 binary64) (*.f64 y y)) (*.f64 (sqrt.f64 #s(literal -1 binary64)) (*.f64 z z))))) (sqrt.f64 #s(literal -1 binary64))) z)))

eval26.0ms (1.6%)

Memory
5.5MiB live, 48.8MiB allocated; 13ms collecting garbage
Compiler

Compiled 2 077 to 382 computations (81.6% saved)

prune13.0ms (0.8%)

Memory
-26.4MiB live, 13.2MiB allocated; 11ms collecting garbage
Pruning

1 alts after pruning (1 fresh and 0 done)

PrunedKeptTotal
New87188
Fresh000
Picked101
Done000
Total88189
Accuracy
99.5%
Counts
89 → 1
Alt Table
Click to see full alt table
StatusAccuracyProgram
99.5%
(*.f64 x #s(approx (sqrt (- (* y y) (* z z))) y))
Compiler

Compiled 12 to 9 computations (25% saved)

series5.0ms (0.3%)

Memory
21.2MiB live, 21.2MiB allocated; 0ms collecting garbage
Counts
4 → 47
Calls
Call 1
Inputs
(*.f64 x #s(approx (sqrt (- (* y y) (* z z))) y))
x
#s(approx (sqrt (- (* y y) (* z z))) y)
y
Outputs
#s(approx (* x (sqrt (- (* y y) (* z z)))) #s(hole binary64 (* x (sqrt (- (pow y 2) (pow z 2))))))
#s(approx x #s(hole binary64 x))
#s(approx (* x (sqrt (- (* y y) (* z z)))) #s(hole binary64 (* x (* z (sqrt -1)))))
#s(approx (* x (sqrt (- (* y y) (* z z)))) #s(hole binary64 (+ (* 1/2 (/ (* x (pow y 2)) (* z (sqrt -1)))) (* x (* z (sqrt -1))))))
#s(approx (* x (sqrt (- (* y y) (* z z)))) #s(hole binary64 (+ (* x (* z (sqrt -1))) (* (pow y 2) (+ (* -1/8 (/ (* x (pow y 2)) (* (pow z 3) (pow (sqrt -1) 3)))) (* 1/2 (/ x (* z (sqrt -1)))))))))
#s(approx (* x (sqrt (- (* y y) (* z z)))) #s(hole binary64 (+ (* x (* z (sqrt -1))) (* (pow y 2) (+ (* 1/2 (/ x (* z (sqrt -1)))) (* (pow y 2) (+ (* -1/8 (/ x (* (pow z 3) (pow (sqrt -1) 3)))) (* 1/16 (/ (* x (pow y 2)) (* (pow z 5) (pow (sqrt -1) 5)))))))))))
#s(approx (sqrt (- (* y y) (* z z))) #s(hole binary64 (* z (sqrt -1))))
#s(approx (sqrt (- (* y y) (* z z))) #s(hole binary64 (+ (* 1/2 (/ (pow y 2) (* z (sqrt -1)))) (* z (sqrt -1)))))
#s(approx (sqrt (- (* y y) (* z z))) #s(hole binary64 (+ (* z (sqrt -1)) (* (pow y 2) (+ (* -1/8 (/ (pow y 2) (* (pow z 3) (pow (sqrt -1) 3)))) (* 1/2 (/ 1 (* z (sqrt -1)))))))))
#s(approx (sqrt (- (* y y) (* z z))) #s(hole binary64 (+ (* z (sqrt -1)) (* (pow y 2) (+ (* (pow y 2) (- (* 1/16 (/ (pow y 2) (* (pow z 5) (pow (sqrt -1) 5)))) (* 1/8 (/ 1 (* (pow z 3) (pow (sqrt -1) 3)))))) (* 1/2 (/ 1 (* z (sqrt -1)))))))))
#s(approx y #s(hole binary64 y))
#s(approx (* x (sqrt (- (* y y) (* z z)))) #s(hole binary64 (* x y)))
#s(approx (* x (sqrt (- (* y y) (* z z)))) #s(hole binary64 (* y (+ x (* -1/2 (/ (* x (pow z 2)) (pow y 2)))))))
#s(approx (* x (sqrt (- (* y y) (* z z)))) #s(hole binary64 (* y (+ x (+ (* -1/2 (/ (* x (pow z 2)) (pow y 2))) (* -1/8 (/ (* x (pow z 4)) (pow y 4))))))))
#s(approx (* x (sqrt (- (* y y) (* z z)))) #s(hole binary64 (* y (+ x (+ (* -1/2 (/ (* x (pow z 2)) (pow y 2))) (+ (* -1/8 (/ (* x (pow z 4)) (pow y 4))) (* -1/16 (/ (* x (pow z 6)) (pow y 6)))))))))
#s(approx (sqrt (- (* y y) (* z z))) #s(hole binary64 y))
#s(approx (sqrt (- (* y y) (* z z))) #s(hole binary64 (* y (+ 1 (* -1/2 (/ (pow z 2) (pow y 2)))))))
#s(approx (sqrt (- (* y y) (* z z))) #s(hole binary64 (* y (+ 1 (+ (* -1/2 (/ (pow z 2) (pow y 2))) (* -1/8 (/ (pow z 4) (pow y 4))))))))
#s(approx (sqrt (- (* y y) (* z z))) #s(hole binary64 (* y (+ 1 (+ (* -1/2 (/ (pow z 2) (pow y 2))) (+ (* -1/8 (/ (pow z 4) (pow y 4))) (* -1/16 (/ (pow z 6) (pow y 6)))))))))
#s(approx (* x (sqrt (- (* y y) (* z z)))) #s(hole binary64 (* -1 (* x y))))
#s(approx (* x (sqrt (- (* y y) (* z z)))) #s(hole binary64 (* -1 (* y (+ x (* -1/2 (/ (* x (pow z 2)) (pow y 2))))))))
#s(approx (* x (sqrt (- (* y y) (* z z)))) #s(hole binary64 (* -1 (* y (+ x (+ (* -1/2 (/ (* x (pow z 2)) (pow y 2))) (* -1/8 (/ (* x (pow z 4)) (pow y 4)))))))))
#s(approx (* x (sqrt (- (* y y) (* z z)))) #s(hole binary64 (* -1 (* y (+ x (+ (* -1/2 (/ (* x (pow z 2)) (pow y 2))) (+ (* -1/8 (/ (* x (pow z 4)) (pow y 4))) (* -1/16 (/ (* x (pow z 6)) (pow y 6))))))))))
#s(approx (sqrt (- (* y y) (* z z))) #s(hole binary64 (* -1 y)))
#s(approx (sqrt (- (* y y) (* z z))) #s(hole binary64 (* -1 (* y (+ 1 (* -1/2 (/ (pow z 2) (pow y 2))))))))
#s(approx (sqrt (- (* y y) (* z z))) #s(hole binary64 (* -1 (* y (+ 1 (+ (* -1/2 (/ (pow z 2) (pow y 2))) (* -1/8 (/ (pow z 4) (pow y 4)))))))))
#s(approx (sqrt (- (* y y) (* z z))) #s(hole binary64 (* -1 (* y (+ 1 (+ (* -1/2 (/ (pow z 2) (pow y 2))) (+ (* -1/8 (/ (pow z 4) (pow y 4))) (* -1/16 (/ (pow z 6) (pow y 6))))))))))
#s(approx (* x (sqrt (- (* y y) (* z z)))) #s(hole binary64 (+ (* -1/2 (/ (* x (pow z 2)) y)) (* x y))))
#s(approx (* x (sqrt (- (* y y) (* z z)))) #s(hole binary64 (+ (* x y) (* (pow z 2) (+ (* -1/2 (/ x y)) (* -1/8 (/ (* x (pow z 2)) (pow y 3))))))))
#s(approx (* x (sqrt (- (* y y) (* z z)))) #s(hole binary64 (+ (* x y) (* (pow z 2) (+ (* -1/2 (/ x y)) (* (pow z 2) (+ (* -1/8 (/ x (pow y 3))) (* -1/16 (/ (* x (pow z 2)) (pow y 5))))))))))
#s(approx (sqrt (- (* y y) (* z z))) #s(hole binary64 (+ y (* -1/2 (/ (pow z 2) y)))))
#s(approx (sqrt (- (* y y) (* z z))) #s(hole binary64 (+ y (* (pow z 2) (- (* -1/8 (/ (pow z 2) (pow y 3))) (* 1/2 (/ 1 y)))))))
#s(approx (sqrt (- (* y y) (* z z))) #s(hole binary64 (+ y (* (pow z 2) (- (* (pow z 2) (- (* -1/16 (/ (pow z 2) (pow y 5))) (* 1/8 (/ 1 (pow y 3))))) (* 1/2 (/ 1 y)))))))
#s(approx (* x (sqrt (- (* y y) (* z z)))) #s(hole binary64 (* z (+ (* 1/2 (/ (* x (pow y 2)) (* (pow z 2) (sqrt -1)))) (* x (sqrt -1))))))
#s(approx (* x (sqrt (- (* y y) (* z z)))) #s(hole binary64 (* z (+ (* -1/8 (/ (* x (pow y 4)) (* (pow z 4) (pow (sqrt -1) 3)))) (+ (* 1/2 (/ (* x (pow y 2)) (* (pow z 2) (sqrt -1)))) (* x (sqrt -1)))))))
#s(approx (* x (sqrt (- (* y y) (* z z)))) #s(hole binary64 (* z (+ (* -1/8 (/ (* x (pow y 4)) (* (pow z 4) (pow (sqrt -1) 3)))) (+ (* 1/16 (/ (* x (pow y 6)) (* (pow z 6) (pow (sqrt -1) 5)))) (+ (* 1/2 (/ (* x (pow y 2)) (* (pow z 2) (sqrt -1)))) (* x (sqrt -1))))))))
#s(approx (sqrt (- (* y y) (* z z))) #s(hole binary64 (* z (+ (sqrt -1) (* 1/2 (/ (pow y 2) (* (pow z 2) (sqrt -1))))))))
#s(approx (sqrt (- (* y y) (* z z))) #s(hole binary64 (* z (+ (sqrt -1) (+ (* -1/8 (/ (pow y 4) (* (pow z 4) (pow (sqrt -1) 3)))) (* 1/2 (/ (pow y 2) (* (pow z 2) (sqrt -1)))))))))
#s(approx (sqrt (- (* y y) (* z z))) #s(hole binary64 (* z (+ (sqrt -1) (+ (* -1/8 (/ (pow y 4) (* (pow z 4) (pow (sqrt -1) 3)))) (+ (* 1/16 (/ (pow y 6) (* (pow z 6) (pow (sqrt -1) 5)))) (* 1/2 (/ (pow y 2) (* (pow z 2) (sqrt -1))))))))))
#s(approx (* x (sqrt (- (* y y) (* z z)))) #s(hole binary64 (* -1 (* x (* z (sqrt -1))))))
#s(approx (* x (sqrt (- (* y y) (* z z)))) #s(hole binary64 (* -1 (* z (+ (* 1/2 (/ (* x (pow y 2)) (* (pow z 2) (sqrt -1)))) (* x (sqrt -1)))))))
#s(approx (* x (sqrt (- (* y y) (* z z)))) #s(hole binary64 (* -1 (* z (+ (* -1/8 (/ (* x (pow y 4)) (* (pow z 4) (pow (sqrt -1) 3)))) (+ (* 1/2 (/ (* x (pow y 2)) (* (pow z 2) (sqrt -1)))) (* x (sqrt -1))))))))
#s(approx (* x (sqrt (- (* y y) (* z z)))) #s(hole binary64 (* -1 (* z (+ (* -1/8 (/ (* x (pow y 4)) (* (pow z 4) (pow (sqrt -1) 3)))) (+ (* 1/16 (/ (* x (pow y 6)) (* (pow z 6) (pow (sqrt -1) 5)))) (+ (* 1/2 (/ (* x (pow y 2)) (* (pow z 2) (sqrt -1)))) (* x (sqrt -1)))))))))
#s(approx (sqrt (- (* y y) (* z z))) #s(hole binary64 (* -1 (* z (sqrt -1)))))
#s(approx (sqrt (- (* y y) (* z z))) #s(hole binary64 (* -1 (* z (+ (sqrt -1) (* 1/2 (/ (pow y 2) (* (pow z 2) (sqrt -1)))))))))
#s(approx (sqrt (- (* y y) (* z z))) #s(hole binary64 (* -1 (* z (+ (sqrt -1) (+ (* -1/8 (/ (pow y 4) (* (pow z 4) (pow (sqrt -1) 3)))) (* 1/2 (/ (pow y 2) (* (pow z 2) (sqrt -1))))))))))
#s(approx (sqrt (- (* y y) (* z z))) #s(hole binary64 (* -1 (* z (+ (sqrt -1) (+ (* -1/8 (/ (pow y 4) (* (pow z 4) (pow (sqrt -1) 3)))) (+ (* 1/16 (/ (pow y 6) (* (pow z 6) (pow (sqrt -1) 5)))) (* 1/2 (/ (pow y 2) (* (pow z 2) (sqrt -1)))))))))))
Calls

9 calls:

TimeVariablePointExpression
1.0ms
x
@-inf
((* x (sqrt (- (* y y) (* z z)))) x (sqrt (- (* y y) (* z z))) y)
1.0ms
x
@0
((* x (sqrt (- (* y y) (* z z)))) x (sqrt (- (* y y) (* z z))) y)
1.0ms
x
@inf
((* x (sqrt (- (* y y) (* z z)))) x (sqrt (- (* y y) (* z z))) y)
0.0ms
y
@-inf
((* x (sqrt (- (* y y) (* z z)))) x (sqrt (- (* y y) (* z z))) y)
0.0ms
y
@inf
((* x (sqrt (- (* y y) (* z z)))) x (sqrt (- (* y y) (* z z))) y)

rewrite67.0ms (4.2%)

Memory
13.2MiB live, 100.7MiB allocated; 15ms collecting garbage
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
02501613
02511561
013711504
Stop Event
iter-limit
iter-limit
node-limit
iter-limit
Counts
51 → 52
Calls
Call 1
Inputs
(*.f64 x #s(approx (sqrt (- (* y y) (* z z))) y))
x
#s(approx (sqrt (- (* y y) (* z z))) y)
y
#s(approx (* x (sqrt (- (* y y) (* z z)))) #s(hole binary64 (* x (sqrt (- (pow y 2) (pow z 2))))))
#s(approx x #s(hole binary64 x))
#s(approx (* x (sqrt (- (* y y) (* z z)))) #s(hole binary64 (* x (* z (sqrt -1)))))
#s(approx (* x (sqrt (- (* y y) (* z z)))) #s(hole binary64 (+ (* 1/2 (/ (* x (pow y 2)) (* z (sqrt -1)))) (* x (* z (sqrt -1))))))
#s(approx (* x (sqrt (- (* y y) (* z z)))) #s(hole binary64 (+ (* x (* z (sqrt -1))) (* (pow y 2) (+ (* -1/8 (/ (* x (pow y 2)) (* (pow z 3) (pow (sqrt -1) 3)))) (* 1/2 (/ x (* z (sqrt -1)))))))))
#s(approx (* x (sqrt (- (* y y) (* z z)))) #s(hole binary64 (+ (* x (* z (sqrt -1))) (* (pow y 2) (+ (* 1/2 (/ x (* z (sqrt -1)))) (* (pow y 2) (+ (* -1/8 (/ x (* (pow z 3) (pow (sqrt -1) 3)))) (* 1/16 (/ (* x (pow y 2)) (* (pow z 5) (pow (sqrt -1) 5)))))))))))
#s(approx (sqrt (- (* y y) (* z z))) #s(hole binary64 (* z (sqrt -1))))
#s(approx (sqrt (- (* y y) (* z z))) #s(hole binary64 (+ (* 1/2 (/ (pow y 2) (* z (sqrt -1)))) (* z (sqrt -1)))))
#s(approx (sqrt (- (* y y) (* z z))) #s(hole binary64 (+ (* z (sqrt -1)) (* (pow y 2) (+ (* -1/8 (/ (pow y 2) (* (pow z 3) (pow (sqrt -1) 3)))) (* 1/2 (/ 1 (* z (sqrt -1)))))))))
#s(approx (sqrt (- (* y y) (* z z))) #s(hole binary64 (+ (* z (sqrt -1)) (* (pow y 2) (+ (* (pow y 2) (- (* 1/16 (/ (pow y 2) (* (pow z 5) (pow (sqrt -1) 5)))) (* 1/8 (/ 1 (* (pow z 3) (pow (sqrt -1) 3)))))) (* 1/2 (/ 1 (* z (sqrt -1)))))))))
#s(approx y #s(hole binary64 y))
#s(approx (* x (sqrt (- (* y y) (* z z)))) #s(hole binary64 (* x y)))
#s(approx (* x (sqrt (- (* y y) (* z z)))) #s(hole binary64 (* y (+ x (* -1/2 (/ (* x (pow z 2)) (pow y 2)))))))
#s(approx (* x (sqrt (- (* y y) (* z z)))) #s(hole binary64 (* y (+ x (+ (* -1/2 (/ (* x (pow z 2)) (pow y 2))) (* -1/8 (/ (* x (pow z 4)) (pow y 4))))))))
#s(approx (* x (sqrt (- (* y y) (* z z)))) #s(hole binary64 (* y (+ x (+ (* -1/2 (/ (* x (pow z 2)) (pow y 2))) (+ (* -1/8 (/ (* x (pow z 4)) (pow y 4))) (* -1/16 (/ (* x (pow z 6)) (pow y 6)))))))))
#s(approx (sqrt (- (* y y) (* z z))) #s(hole binary64 y))
#s(approx (sqrt (- (* y y) (* z z))) #s(hole binary64 (* y (+ 1 (* -1/2 (/ (pow z 2) (pow y 2)))))))
#s(approx (sqrt (- (* y y) (* z z))) #s(hole binary64 (* y (+ 1 (+ (* -1/2 (/ (pow z 2) (pow y 2))) (* -1/8 (/ (pow z 4) (pow y 4))))))))
#s(approx (sqrt (- (* y y) (* z z))) #s(hole binary64 (* y (+ 1 (+ (* -1/2 (/ (pow z 2) (pow y 2))) (+ (* -1/8 (/ (pow z 4) (pow y 4))) (* -1/16 (/ (pow z 6) (pow y 6)))))))))
#s(approx (* x (sqrt (- (* y y) (* z z)))) #s(hole binary64 (* -1 (* x y))))
#s(approx (* x (sqrt (- (* y y) (* z z)))) #s(hole binary64 (* -1 (* y (+ x (* -1/2 (/ (* x (pow z 2)) (pow y 2))))))))
#s(approx (* x (sqrt (- (* y y) (* z z)))) #s(hole binary64 (* -1 (* y (+ x (+ (* -1/2 (/ (* x (pow z 2)) (pow y 2))) (* -1/8 (/ (* x (pow z 4)) (pow y 4)))))))))
#s(approx (* x (sqrt (- (* y y) (* z z)))) #s(hole binary64 (* -1 (* y (+ x (+ (* -1/2 (/ (* x (pow z 2)) (pow y 2))) (+ (* -1/8 (/ (* x (pow z 4)) (pow y 4))) (* -1/16 (/ (* x (pow z 6)) (pow y 6))))))))))
#s(approx (sqrt (- (* y y) (* z z))) #s(hole binary64 (* -1 y)))
#s(approx (sqrt (- (* y y) (* z z))) #s(hole binary64 (* -1 (* y (+ 1 (* -1/2 (/ (pow z 2) (pow y 2))))))))
#s(approx (sqrt (- (* y y) (* z z))) #s(hole binary64 (* -1 (* y (+ 1 (+ (* -1/2 (/ (pow z 2) (pow y 2))) (* -1/8 (/ (pow z 4) (pow y 4)))))))))
#s(approx (sqrt (- (* y y) (* z z))) #s(hole binary64 (* -1 (* y (+ 1 (+ (* -1/2 (/ (pow z 2) (pow y 2))) (+ (* -1/8 (/ (pow z 4) (pow y 4))) (* -1/16 (/ (pow z 6) (pow y 6))))))))))
#s(approx (* x (sqrt (- (* y y) (* z z)))) #s(hole binary64 (+ (* -1/2 (/ (* x (pow z 2)) y)) (* x y))))
#s(approx (* x (sqrt (- (* y y) (* z z)))) #s(hole binary64 (+ (* x y) (* (pow z 2) (+ (* -1/2 (/ x y)) (* -1/8 (/ (* x (pow z 2)) (pow y 3))))))))
#s(approx (* x (sqrt (- (* y y) (* z z)))) #s(hole binary64 (+ (* x y) (* (pow z 2) (+ (* -1/2 (/ x y)) (* (pow z 2) (+ (* -1/8 (/ x (pow y 3))) (* -1/16 (/ (* x (pow z 2)) (pow y 5))))))))))
#s(approx (sqrt (- (* y y) (* z z))) #s(hole binary64 (+ y (* -1/2 (/ (pow z 2) y)))))
#s(approx (sqrt (- (* y y) (* z z))) #s(hole binary64 (+ y (* (pow z 2) (- (* -1/8 (/ (pow z 2) (pow y 3))) (* 1/2 (/ 1 y)))))))
#s(approx (sqrt (- (* y y) (* z z))) #s(hole binary64 (+ y (* (pow z 2) (- (* (pow z 2) (- (* -1/16 (/ (pow z 2) (pow y 5))) (* 1/8 (/ 1 (pow y 3))))) (* 1/2 (/ 1 y)))))))
#s(approx (* x (sqrt (- (* y y) (* z z)))) #s(hole binary64 (* z (+ (* 1/2 (/ (* x (pow y 2)) (* (pow z 2) (sqrt -1)))) (* x (sqrt -1))))))
#s(approx (* x (sqrt (- (* y y) (* z z)))) #s(hole binary64 (* z (+ (* -1/8 (/ (* x (pow y 4)) (* (pow z 4) (pow (sqrt -1) 3)))) (+ (* 1/2 (/ (* x (pow y 2)) (* (pow z 2) (sqrt -1)))) (* x (sqrt -1)))))))
#s(approx (* x (sqrt (- (* y y) (* z z)))) #s(hole binary64 (* z (+ (* -1/8 (/ (* x (pow y 4)) (* (pow z 4) (pow (sqrt -1) 3)))) (+ (* 1/16 (/ (* x (pow y 6)) (* (pow z 6) (pow (sqrt -1) 5)))) (+ (* 1/2 (/ (* x (pow y 2)) (* (pow z 2) (sqrt -1)))) (* x (sqrt -1))))))))
#s(approx (sqrt (- (* y y) (* z z))) #s(hole binary64 (* z (+ (sqrt -1) (* 1/2 (/ (pow y 2) (* (pow z 2) (sqrt -1))))))))
#s(approx (sqrt (- (* y y) (* z z))) #s(hole binary64 (* z (+ (sqrt -1) (+ (* -1/8 (/ (pow y 4) (* (pow z 4) (pow (sqrt -1) 3)))) (* 1/2 (/ (pow y 2) (* (pow z 2) (sqrt -1)))))))))
#s(approx (sqrt (- (* y y) (* z z))) #s(hole binary64 (* z (+ (sqrt -1) (+ (* -1/8 (/ (pow y 4) (* (pow z 4) (pow (sqrt -1) 3)))) (+ (* 1/16 (/ (pow y 6) (* (pow z 6) (pow (sqrt -1) 5)))) (* 1/2 (/ (pow y 2) (* (pow z 2) (sqrt -1))))))))))
#s(approx (* x (sqrt (- (* y y) (* z z)))) #s(hole binary64 (* -1 (* x (* z (sqrt -1))))))
#s(approx (* x (sqrt (- (* y y) (* z z)))) #s(hole binary64 (* -1 (* z (+ (* 1/2 (/ (* x (pow y 2)) (* (pow z 2) (sqrt -1)))) (* x (sqrt -1)))))))
#s(approx (* x (sqrt (- (* y y) (* z z)))) #s(hole binary64 (* -1 (* z (+ (* -1/8 (/ (* x (pow y 4)) (* (pow z 4) (pow (sqrt -1) 3)))) (+ (* 1/2 (/ (* x (pow y 2)) (* (pow z 2) (sqrt -1)))) (* x (sqrt -1))))))))
#s(approx (* x (sqrt (- (* y y) (* z z)))) #s(hole binary64 (* -1 (* z (+ (* -1/8 (/ (* x (pow y 4)) (* (pow z 4) (pow (sqrt -1) 3)))) (+ (* 1/16 (/ (* x (pow y 6)) (* (pow z 6) (pow (sqrt -1) 5)))) (+ (* 1/2 (/ (* x (pow y 2)) (* (pow z 2) (sqrt -1)))) (* x (sqrt -1)))))))))
#s(approx (sqrt (- (* y y) (* z z))) #s(hole binary64 (* -1 (* z (sqrt -1)))))
#s(approx (sqrt (- (* y y) (* z z))) #s(hole binary64 (* -1 (* z (+ (sqrt -1) (* 1/2 (/ (pow y 2) (* (pow z 2) (sqrt -1)))))))))
#s(approx (sqrt (- (* y y) (* z z))) #s(hole binary64 (* -1 (* z (+ (sqrt -1) (+ (* -1/8 (/ (pow y 4) (* (pow z 4) (pow (sqrt -1) 3)))) (* 1/2 (/ (pow y 2) (* (pow z 2) (sqrt -1))))))))))
#s(approx (sqrt (- (* y y) (* z z))) #s(hole binary64 (* -1 (* z (+ (sqrt -1) (+ (* -1/8 (/ (pow y 4) (* (pow z 4) (pow (sqrt -1) 3)))) (+ (* 1/16 (/ (pow y 6) (* (pow z 6) (pow (sqrt -1) 5)))) (* 1/2 (/ (pow y 2) (* (pow z 2) (sqrt -1)))))))))))
Outputs
(*.f64 #s(approx (sqrt (- (* y y) (* z z))) y) x)
(*.f64 x #s(approx (sqrt (- (* y y) (* z z))) y))
x
#s(approx (sqrt (- (* y y) (* z z))) y)
y
#s(approx (* x (sqrt (- (* y y) (* z z)))) (*.f64 (sqrt.f64 (*.f64 (+.f64 y z) (-.f64 y z))) x))
#s(approx x x)
#s(approx (* x (sqrt (- (* y y) (* z z)))) (*.f64 (*.f64 (sqrt.f64 #s(literal -1 binary64)) z) x))
#s(approx (* x (sqrt (- (* y y) (* z z)))) (fma.f64 (*.f64 x z) (sqrt.f64 #s(literal -1 binary64)) (/.f64 (*.f64 #s(literal 1/2 binary64) (*.f64 (*.f64 y y) x)) (*.f64 (sqrt.f64 #s(literal -1 binary64)) z))))
#s(approx (* x (sqrt (- (* y y) (* z z)))) (fma.f64 (*.f64 x z) (sqrt.f64 #s(literal -1 binary64)) (*.f64 (fma.f64 (/.f64 x (*.f64 (sqrt.f64 #s(literal -1 binary64)) z)) #s(literal 1/2 binary64) (/.f64 (*.f64 #s(literal -1/8 binary64) (*.f64 (*.f64 y y) x)) (pow.f64 (*.f64 (sqrt.f64 #s(literal -1 binary64)) z) #s(literal 3 binary64)))) (*.f64 y y))))
#s(approx (* x (sqrt (- (* y y) (* z z)))) (fma.f64 (*.f64 x z) (sqrt.f64 #s(literal -1 binary64)) (*.f64 (fma.f64 (fma.f64 (/.f64 (*.f64 (*.f64 y y) x) (pow.f64 (*.f64 (sqrt.f64 #s(literal -1 binary64)) z) #s(literal 5 binary64))) #s(literal 1/16 binary64) (*.f64 (/.f64 x (pow.f64 (*.f64 (sqrt.f64 #s(literal -1 binary64)) z) #s(literal 3 binary64))) #s(literal -1/8 binary64))) (*.f64 y y) (*.f64 (/.f64 x (*.f64 (sqrt.f64 #s(literal -1 binary64)) z)) #s(literal 1/2 binary64))) (*.f64 y y))))
#s(approx (sqrt (- (* y y) (* z z))) (*.f64 (sqrt.f64 #s(literal -1 binary64)) z))
#s(approx (sqrt (- (* y y) (* z z))) (fma.f64 (/.f64 (/.f64 (*.f64 y y) z) (sqrt.f64 #s(literal -1 binary64))) #s(literal 1/2 binary64) (*.f64 (sqrt.f64 #s(literal -1 binary64)) z)))
#s(approx (sqrt (- (* y y) (* z z))) (fma.f64 (fma.f64 (/.f64 (*.f64 y y) (pow.f64 (*.f64 (sqrt.f64 #s(literal -1 binary64)) z) #s(literal 3 binary64))) #s(literal -1/8 binary64) (/.f64 #s(literal 1/2 binary64) (*.f64 (sqrt.f64 #s(literal -1 binary64)) z))) (*.f64 y y) (*.f64 (sqrt.f64 #s(literal -1 binary64)) z)))
#s(approx (sqrt (- (* y y) (* z z))) (fma.f64 (fma.f64 (-.f64 (/.f64 (*.f64 #s(literal 1/16 binary64) (*.f64 y y)) (pow.f64 (*.f64 (sqrt.f64 #s(literal -1 binary64)) z) #s(literal 5 binary64))) (/.f64 #s(literal 1/8 binary64) (pow.f64 (*.f64 (sqrt.f64 #s(literal -1 binary64)) z) #s(literal 3 binary64)))) (*.f64 y y) (/.f64 #s(literal 1/2 binary64) (*.f64 (sqrt.f64 #s(literal -1 binary64)) z))) (*.f64 y y) (*.f64 (sqrt.f64 #s(literal -1 binary64)) z)))
#s(approx y y)
#s(approx (* x (sqrt (- (* y y) (* z z)))) (*.f64 y x))
#s(approx (* x (sqrt (- (* y y) (* z z)))) (*.f64 (fma.f64 (/.f64 (*.f64 (*.f64 z z) x) (*.f64 y y)) #s(literal -1/2 binary64) x) y))
#s(approx (* x (sqrt (- (* y y) (* z z)))) (*.f64 (+.f64 (fma.f64 (/.f64 (*.f64 (*.f64 z z) x) (*.f64 y y)) #s(literal -1/2 binary64) x) (/.f64 (*.f64 #s(literal -1/8 binary64) (*.f64 (pow.f64 z #s(literal 4 binary64)) x)) (pow.f64 y #s(literal 4 binary64)))) y))
#s(approx (* x (sqrt (- (* y y) (* z z)))) (*.f64 (+.f64 (fma.f64 (/.f64 (*.f64 (*.f64 z z) x) (*.f64 y y)) #s(literal -1/2 binary64) (fma.f64 (/.f64 (*.f64 (pow.f64 z #s(literal 6 binary64)) x) (pow.f64 y #s(literal 6 binary64))) #s(literal -1/16 binary64) (/.f64 (*.f64 #s(literal -1/8 binary64) (*.f64 (pow.f64 z #s(literal 4 binary64)) x)) (pow.f64 y #s(literal 4 binary64))))) x) y))
#s(approx (sqrt (- (* y y) (* z z))) y)
#s(approx (sqrt (- (* y y) (* z z))) (*.f64 (fma.f64 (/.f64 (*.f64 z z) (*.f64 y y)) #s(literal -1/2 binary64) #s(literal 1 binary64)) y))
#s(approx (sqrt (- (* y y) (* z z))) (*.f64 (+.f64 (fma.f64 (/.f64 (*.f64 z z) (*.f64 y y)) #s(literal -1/2 binary64) #s(literal 1 binary64)) (/.f64 (*.f64 #s(literal -1/8 binary64) (pow.f64 z #s(literal 4 binary64))) (pow.f64 y #s(literal 4 binary64)))) y))
#s(approx (sqrt (- (* y y) (* z z))) (*.f64 (+.f64 (fma.f64 (/.f64 (*.f64 z z) (*.f64 y y)) #s(literal -1/2 binary64) (fma.f64 (/.f64 (pow.f64 z #s(literal 6 binary64)) (pow.f64 y #s(literal 6 binary64))) #s(literal -1/16 binary64) (/.f64 (*.f64 #s(literal -1/8 binary64) (pow.f64 z #s(literal 4 binary64))) (pow.f64 y #s(literal 4 binary64))))) #s(literal 1 binary64)) y))
#s(approx (* x (sqrt (- (* y y) (* z z)))) (neg.f64 (*.f64 y x)))
#s(approx (* x (sqrt (- (* y y) (* z z)))) (*.f64 (neg.f64 y) (fma.f64 (/.f64 (*.f64 (*.f64 z z) x) (*.f64 y y)) #s(literal -1/2 binary64) x)))
#s(approx (* x (sqrt (- (* y y) (* z z)))) (*.f64 (neg.f64 y) (+.f64 (fma.f64 (/.f64 (*.f64 (*.f64 z z) x) (*.f64 y y)) #s(literal -1/2 binary64) x) (/.f64 (*.f64 #s(literal -1/8 binary64) (*.f64 (pow.f64 z #s(literal 4 binary64)) x)) (pow.f64 y #s(literal 4 binary64))))))
#s(approx (* x (sqrt (- (* y y) (* z z)))) (*.f64 (neg.f64 y) (+.f64 (fma.f64 (/.f64 (*.f64 (*.f64 z z) x) (*.f64 y y)) #s(literal -1/2 binary64) (fma.f64 (/.f64 (*.f64 (pow.f64 z #s(literal 6 binary64)) x) (pow.f64 y #s(literal 6 binary64))) #s(literal -1/16 binary64) (/.f64 (*.f64 #s(literal -1/8 binary64) (*.f64 (pow.f64 z #s(literal 4 binary64)) x)) (pow.f64 y #s(literal 4 binary64))))) x)))
#s(approx (sqrt (- (* y y) (* z z))) (neg.f64 y))
#s(approx (sqrt (- (* y y) (* z z))) (*.f64 (neg.f64 y) (fma.f64 (/.f64 (*.f64 z z) (*.f64 y y)) #s(literal -1/2 binary64) #s(literal 1 binary64))))
#s(approx (sqrt (- (* y y) (* z z))) (*.f64 (neg.f64 y) (+.f64 (fma.f64 (/.f64 (*.f64 z z) (*.f64 y y)) #s(literal -1/2 binary64) #s(literal 1 binary64)) (/.f64 (*.f64 #s(literal -1/8 binary64) (pow.f64 z #s(literal 4 binary64))) (pow.f64 y #s(literal 4 binary64))))))
#s(approx (sqrt (- (* y y) (* z z))) (*.f64 (neg.f64 y) (+.f64 (fma.f64 (/.f64 (*.f64 z z) (*.f64 y y)) #s(literal -1/2 binary64) (fma.f64 (/.f64 (pow.f64 z #s(literal 6 binary64)) (pow.f64 y #s(literal 6 binary64))) #s(literal -1/16 binary64) (/.f64 (*.f64 #s(literal -1/8 binary64) (pow.f64 z #s(literal 4 binary64))) (pow.f64 y #s(literal 4 binary64))))) #s(literal 1 binary64))))
#s(approx (* x (sqrt (- (* y y) (* z z)))) (fma.f64 (/.f64 (*.f64 (*.f64 z z) x) y) #s(literal -1/2 binary64) (*.f64 y x)))
#s(approx (* x (sqrt (- (* y y) (* z z)))) (fma.f64 (fma.f64 (/.f64 (*.f64 (*.f64 z z) x) (pow.f64 y #s(literal 3 binary64))) #s(literal -1/8 binary64) (*.f64 (/.f64 x y) #s(literal -1/2 binary64))) (*.f64 z z) (*.f64 y x)))
#s(approx (* x (sqrt (- (* y y) (* z z)))) (fma.f64 (fma.f64 (fma.f64 (/.f64 (*.f64 (*.f64 z z) x) (pow.f64 y #s(literal 5 binary64))) #s(literal -1/16 binary64) (*.f64 (/.f64 x (pow.f64 y #s(literal 3 binary64))) #s(literal -1/8 binary64))) (*.f64 z z) (*.f64 (/.f64 x y) #s(literal -1/2 binary64))) (*.f64 z z) (*.f64 y x)))
#s(approx (sqrt (- (* y y) (* z z))) (fma.f64 (/.f64 (*.f64 z z) y) #s(literal -1/2 binary64) y))
#s(approx (sqrt (- (* y y) (* z z))) (fma.f64 (-.f64 (/.f64 (*.f64 #s(literal -1/8 binary64) (*.f64 z z)) (pow.f64 y #s(literal 3 binary64))) (/.f64 #s(literal 1/2 binary64) y)) (*.f64 z z) y))
#s(approx (sqrt (- (* y y) (* z z))) (fma.f64 (-.f64 (*.f64 (fma.f64 (/.f64 (*.f64 z z) (pow.f64 y #s(literal 5 binary64))) #s(literal -1/16 binary64) (*.f64 #s(literal -1/8 binary64) (pow.f64 y #s(literal -3 binary64)))) (*.f64 z z)) (/.f64 #s(literal 1/2 binary64) y)) (*.f64 z z) y))
#s(approx (* x (sqrt (- (* y y) (* z z)))) (*.f64 (fma.f64 (/.f64 (*.f64 (*.f64 y y) x) (*.f64 (sqrt.f64 #s(literal -1 binary64)) (*.f64 z z))) #s(literal 1/2 binary64) (*.f64 (sqrt.f64 #s(literal -1 binary64)) x)) z))
#s(approx (* x (sqrt (- (* y y) (* z z)))) (*.f64 (fma.f64 (/.f64 (*.f64 (pow.f64 y #s(literal 4 binary64)) x) (*.f64 (pow.f64 z #s(literal 4 binary64)) (pow.f64 #s(literal -1 binary64) #s(literal 3/2 binary64)))) #s(literal -1/8 binary64) (fma.f64 (/.f64 (*.f64 (*.f64 y y) x) (*.f64 (sqrt.f64 #s(literal -1 binary64)) (*.f64 z z))) #s(literal 1/2 binary64) (*.f64 (sqrt.f64 #s(literal -1 binary64)) x))) z))
#s(approx (* x (sqrt (- (* y y) (* z z)))) (*.f64 (fma.f64 (/.f64 (*.f64 (pow.f64 y #s(literal 4 binary64)) x) (*.f64 (pow.f64 z #s(literal 4 binary64)) (pow.f64 #s(literal -1 binary64) #s(literal 3/2 binary64)))) #s(literal -1/8 binary64) (fma.f64 (/.f64 (*.f64 (pow.f64 y #s(literal 6 binary64)) x) (*.f64 (pow.f64 z #s(literal 6 binary64)) (pow.f64 #s(literal -1 binary64) #s(literal 5/2 binary64)))) #s(literal 1/16 binary64) (fma.f64 (/.f64 (*.f64 (*.f64 y y) x) (*.f64 (sqrt.f64 #s(literal -1 binary64)) (*.f64 z z))) #s(literal 1/2 binary64) (*.f64 (sqrt.f64 #s(literal -1 binary64)) x)))) z))
#s(approx (sqrt (- (* y y) (* z z))) (*.f64 (fma.f64 (/.f64 (*.f64 y y) (*.f64 (sqrt.f64 #s(literal -1 binary64)) (*.f64 z z))) #s(literal 1/2 binary64) (sqrt.f64 #s(literal -1 binary64))) z))
#s(approx (sqrt (- (* y y) (* z z))) (*.f64 (+.f64 (fma.f64 (/.f64 (pow.f64 y #s(literal 4 binary64)) (*.f64 (pow.f64 z #s(literal 4 binary64)) (pow.f64 #s(literal -1 binary64) #s(literal 3/2 binary64)))) #s(literal -1/8 binary64) (/.f64 (*.f64 #s(literal 1/2 binary64) (*.f64 y y)) (*.f64 (sqrt.f64 #s(literal -1 binary64)) (*.f64 z z)))) (sqrt.f64 #s(literal -1 binary64))) z))
#s(approx (sqrt (- (* y y) (* z z))) (*.f64 (+.f64 (fma.f64 (/.f64 (pow.f64 y #s(literal 4 binary64)) (*.f64 (pow.f64 z #s(literal 4 binary64)) (pow.f64 #s(literal -1 binary64) #s(literal 3/2 binary64)))) #s(literal -1/8 binary64) (fma.f64 (/.f64 (pow.f64 y #s(literal 6 binary64)) (*.f64 (pow.f64 z #s(literal 6 binary64)) (pow.f64 #s(literal -1 binary64) #s(literal 5/2 binary64)))) #s(literal 1/16 binary64) (/.f64 (*.f64 #s(literal 1/2 binary64) (*.f64 y y)) (*.f64 (sqrt.f64 #s(literal -1 binary64)) (*.f64 z z))))) (sqrt.f64 #s(literal -1 binary64))) z))
#s(approx (* x (sqrt (- (* y y) (* z z)))) (neg.f64 (*.f64 (*.f64 (sqrt.f64 #s(literal -1 binary64)) z) x)))
#s(approx (* x (sqrt (- (* y y) (* z z)))) (neg.f64 (*.f64 (fma.f64 (/.f64 (*.f64 (*.f64 y y) x) (*.f64 (sqrt.f64 #s(literal -1 binary64)) (*.f64 z z))) #s(literal 1/2 binary64) (*.f64 (sqrt.f64 #s(literal -1 binary64)) x)) z)))
#s(approx (* x (sqrt (- (* y y) (* z z)))) (neg.f64 (*.f64 (fma.f64 (/.f64 (*.f64 (pow.f64 y #s(literal 4 binary64)) x) (*.f64 (pow.f64 z #s(literal 4 binary64)) (pow.f64 #s(literal -1 binary64) #s(literal 3/2 binary64)))) #s(literal -1/8 binary64) (fma.f64 (/.f64 (*.f64 (*.f64 y y) x) (*.f64 (sqrt.f64 #s(literal -1 binary64)) (*.f64 z z))) #s(literal 1/2 binary64) (*.f64 (sqrt.f64 #s(literal -1 binary64)) x))) z)))
#s(approx (* x (sqrt (- (* y y) (* z z)))) (neg.f64 (*.f64 (fma.f64 (/.f64 (*.f64 (pow.f64 y #s(literal 4 binary64)) x) (*.f64 (pow.f64 z #s(literal 4 binary64)) (pow.f64 #s(literal -1 binary64) #s(literal 3/2 binary64)))) #s(literal -1/8 binary64) (fma.f64 (/.f64 (*.f64 (pow.f64 y #s(literal 6 binary64)) x) (*.f64 (pow.f64 z #s(literal 6 binary64)) (pow.f64 #s(literal -1 binary64) #s(literal 5/2 binary64)))) #s(literal 1/16 binary64) (fma.f64 (/.f64 (*.f64 (*.f64 y y) x) (*.f64 (sqrt.f64 #s(literal -1 binary64)) (*.f64 z z))) #s(literal 1/2 binary64) (*.f64 (sqrt.f64 #s(literal -1 binary64)) x)))) z)))
#s(approx (sqrt (- (* y y) (* z z))) (neg.f64 (*.f64 (sqrt.f64 #s(literal -1 binary64)) z)))
#s(approx (sqrt (- (* y y) (* z z))) (neg.f64 (*.f64 (fma.f64 (/.f64 (*.f64 y y) (*.f64 (sqrt.f64 #s(literal -1 binary64)) (*.f64 z z))) #s(literal 1/2 binary64) (sqrt.f64 #s(literal -1 binary64))) z)))
#s(approx (sqrt (- (* y y) (* z z))) (neg.f64 (*.f64 (+.f64 (fma.f64 (/.f64 (pow.f64 y #s(literal 4 binary64)) (*.f64 (pow.f64 z #s(literal 4 binary64)) (pow.f64 #s(literal -1 binary64) #s(literal 3/2 binary64)))) #s(literal -1/8 binary64) (/.f64 (*.f64 #s(literal 1/2 binary64) (*.f64 y y)) (*.f64 (sqrt.f64 #s(literal -1 binary64)) (*.f64 z z)))) (sqrt.f64 #s(literal -1 binary64))) z)))
#s(approx (sqrt (- (* y y) (* z z))) (neg.f64 (*.f64 (+.f64 (fma.f64 (/.f64 (pow.f64 y #s(literal 4 binary64)) (*.f64 (pow.f64 z #s(literal 4 binary64)) (pow.f64 #s(literal -1 binary64) #s(literal 3/2 binary64)))) #s(literal -1/8 binary64) (fma.f64 (/.f64 (pow.f64 y #s(literal 6 binary64)) (*.f64 (pow.f64 z #s(literal 6 binary64)) (pow.f64 #s(literal -1 binary64) #s(literal 5/2 binary64)))) #s(literal 1/16 binary64) (/.f64 (*.f64 #s(literal 1/2 binary64) (*.f64 y y)) (*.f64 (sqrt.f64 #s(literal -1 binary64)) (*.f64 z z))))) (sqrt.f64 #s(literal -1 binary64))) z)))

eval5.0ms (0.3%)

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

Compiled 1 594 to 249 computations (84.4% saved)

prune2.0ms (0.1%)

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

1 alts after pruning (0 fresh and 1 done)

PrunedKeptTotal
New51051
Fresh000
Picked011
Done000
Total51152
Accuracy
99.5%
Counts
52 → 1
Alt Table
Click to see full alt table
StatusAccuracyProgram
99.5%
(*.f64 x #s(approx (sqrt (- (* y y) (* z z))) y))
Compiler

Compiled 34 to 23 computations (32.4% saved)

regimes28.0ms (1.7%)

Memory
-28.4MiB live, 33.4MiB allocated; 19ms collecting garbage
Accuracy

Total -20.4b remaining (-6081.8%)

Threshold costs -20.4b (-6081.8%)

Counts
2 → 1
Calls
Call 1
Inputs
(*.f64 x #s(approx (sqrt (- (* y y) (* z z))) y))
(*.f64 x (sqrt.f64 (-.f64 (*.f64 y y) (*.f64 z z))))
Outputs
(*.f64 x #s(approx (sqrt (- (* y y) (* z z))) y))
Calls

8 calls:

19.0ms
z
1.0ms
y
1.0ms
x
1.0ms
(-.f64 (*.f64 y y) (*.f64 z z))
1.0ms
(*.f64 x (sqrt.f64 (-.f64 (*.f64 y y) (*.f64 z z))))
Results
AccuracySegmentsBranch
99.5%1(*.f64 z z)
99.5%1(*.f64 y y)
99.5%1(-.f64 (*.f64 y y) (*.f64 z z))
99.5%1(sqrt.f64 (-.f64 (*.f64 y y) (*.f64 z z)))
99.5%1(*.f64 x (sqrt.f64 (-.f64 (*.f64 y y) (*.f64 z z))))
99.5%1x
99.5%1y
99.5%1z
Compiler

Compiled 34 to 38 computations (-11.8% saved)

derivations3.0ms (0.2%)

Memory
6.0MiB live, 6.0MiB allocated; 0ms collecting garbage
Stop Event
done
Compiler

Compiled 12 to 9 computations (25% saved)

preprocess32.0ms (2%)

Memory
-27.7MiB live, 68.3MiB allocated; 6ms collecting garbage
Remove

(negabs x)

(abs z)

Compiler

Compiled 178 to 134 computations (24.7% saved)

end0.0ms (0%)

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

Profiling

Loading profile data...