Linear.Quaternion:$clog from linear-1.19.1.3

Time bar (total: 4.5s)

start0.0ms (0%)

Memory
0.1MiB live, 0.1MiB allocated

analyze20.0ms (0.4%)

Memory
-20.8MiB live, 59.5MiB allocated
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
50%50%50%0.1%0%0%0%3
50%50%50%0.1%0%0%0%4
62.5%62.4%37.5%0.1%0%0%0%5
66.7%62.4%31.2%0.1%0%6.2%0%6
75%65.6%21.9%0.1%0%12.5%0%7
80%68.7%17.2%0.1%0%14%0%8
85.7%70.2%11.7%0.1%0%18%0%9
88.9%71.8%9%0.1%0%19.1%0%10
92.3%72.6%6%0.1%0%21.3%0%11
94.1%73.4%4.6%0.1%0%22%0%12
Compiler

Compiled 8 to 7 computations (12.5% saved)

sample1.2s (26.2%)

Memory
45.4MiB live, 1 153.5MiB allocated
Samples
962.0ms8 256×0valid
17.0ms306×0invalid
Precisions
Click to see histograms. Total time spent on operations: 231.0ms
ival-mult: 110.0ms (47.6% of total)
ival-sqrt: 72.0ms (31.1% of total)
ival-add: 40.0ms (17.3% of total)
ival-true: 7.0ms (3% of total)
ival-assert: 3.0ms (1.3% of total)
Bogosity

explain64.0ms (1.4%)

Memory
-20.8MiB live, 140.5MiB allocated
FPErrors
Click to see full error table
Ground TruthOverpredictionsExampleUnderpredictionsExampleSubexpression
910-0-(sqrt.f64 (+.f64 (*.f64 x x) y))
00-0-(+.f64 (*.f64 x x) y)
00-0-y
00-0-(*.f64 x x)
00-0-x
Explanations
Click to see full explanations table
OperatorSubexpressionExplanationCount
sqrt.f64(sqrt.f64 (+.f64 (*.f64 x x) y))oflow-rescue910
(+.f64 (*.f64 x x) y)overflow91
(*.f64 x x)overflow91
Confusion
Predicted +Predicted -
+910
-0165
Precision
1.0
Recall
1.0
Confusion?
Predicted +Predicted MaybePredicted -
+9100
-00165
Precision?
1.0
Recall?
1.0
Freqs
test
numberfreq
0165
191
Total Confusion?
Predicted +Predicted MaybePredicted -
+100
-000
Precision?
1.0
Recall?
1.0
Samples
27.0ms512×0valid
Compiler

Compiled 42 to 19 computations (54.8% saved)

Precisions
Click to see histograms. Total time spent on operations: 11.0ms
ival-mult: 4.0ms (37.2% of total)
ival-sqrt: 4.0ms (37.2% of total)
ival-add: 2.0ms (18.6% of total)
ival-true: 0.0ms (0% of total)
ival-assert: 0.0ms (0% of total)

preprocess21.0ms (0.5%)

Memory
0.1MiB live, 37.8MiB allocated
Algorithm
egg-herbie
Rules
64×sub-neg
34×distribute-lft-neg-in
34×associate-+l-
32×associate--r+
32×cancel-sign-sub-inv
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01532
13432
26932
312432
418832
525032
631232
732432
833032
056
086
196
095
Stop Event
iter limit
saturated
iter limit
saturated
Calls
Call 1
Inputs
(sqrt.f64 (+.f64 (*.f64 x x) y))
Outputs
(sqrt.f64 (+.f64 (*.f64 x x) y))
(sqrt.f64 (fma.f64 x x y))
Symmetry

(abs x)

Compiler

Compiled 6 to 5 computations (16.7% saved)

eval0.0ms (0%)

Memory
0.4MiB live, 0.4MiB allocated
Compiler

Compiled 0 to 2 computations (-∞% saved)

prune0.0ms (0%)

Memory
1.2MiB live, 1.2MiB allocated
Alt Table
Click to see full alt table
StatusAccuracyProgram
66.8%
(sqrt.f64 (+.f64 (*.f64 x x) y))
Compiler

Compiled 6 to 5 computations (16.7% saved)

simplify3.0ms (0.1%)

Memory
7.8MiB live, 7.8MiB allocated
Algorithm
egg-herbie
Localize:

Found 3 expressions of interest:

NewMetricScoreProgram
cost-diff0
(*.f64 x x)
cost-diff0
(sqrt.f64 (+.f64 (*.f64 x x) y))
cost-diff128
(+.f64 (*.f64 x x) y)
Rules
lower-+.f32
lift-sqrt.f64
lift-+.f64
lower-fma.f64
lower-+.f64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0516
0816
1916
0914
Stop Event
iter limit
saturated
iter limit
Calls
Call 1
Inputs
(sqrt.f64 (+.f64 (*.f64 x x) y))
(+.f64 (*.f64 x x) y)
(*.f64 x x)
x
y
Outputs
(sqrt.f64 (+.f64 (*.f64 x x) y))
(sqrt.f64 (fma.f64 x x y))
(+.f64 (*.f64 x x) y)
(fma.f64 x x y)
(*.f64 x x)
x
y

localize18.0ms (0.4%)

Memory
2.1MiB live, 40.0MiB allocated
Localize:

Found 3 expressions of interest:

NewMetricScoreProgram
accuracy0
(*.f64 x x)
accuracy0.00390625
(+.f64 (*.f64 x x) y)
accuracy21.258855872636012
(sqrt.f64 (+.f64 (*.f64 x x) y))
Samples
13.0ms256×0valid
Compiler

Compiled 18 to 7 computations (61.1% saved)

Precisions
Click to see histograms. Total time spent on operations: 5.0ms
ival-mult: 2.0ms (39.5% of total)
ival-sqrt: 2.0ms (39.5% of total)
ival-add: 1.0ms (19.8% of total)
ival-true: 0.0ms (0% of total)
ival-assert: 0.0ms (0% of total)

series13.0ms (0.3%)

Memory
-29.1MiB live, 21.0MiB allocated
Counts
3 → 60
Calls
Call 1
Inputs
#s(alt (+.f64 (*.f64 x x) y) (patch (+.f64 (*.f64 x x) y) #<representation binary64>) () ())
#s(alt (sqrt.f64 (+.f64 (*.f64 x x) y)) (patch (sqrt.f64 (+.f64 (*.f64 x x) y)) #<representation binary64>) () ())
#s(alt (*.f64 x x) (patch (*.f64 x x) #<representation binary64>) () ())
Outputs
#s(alt (pow x 2) (taylor 0 y) (#s(alt (+.f64 (*.f64 x x) y) (patch (+.f64 (*.f64 x x) y) #<representation binary64>) () ())) ())
#s(alt (+ y (pow x 2)) (taylor 0 y) (#s(alt (+.f64 (*.f64 x x) y) (patch (+.f64 (*.f64 x x) y) #<representation binary64>) () ())) ())
#s(alt (+ y (pow x 2)) (taylor 0 y) (#s(alt (+.f64 (*.f64 x x) y) (patch (+.f64 (*.f64 x x) y) #<representation binary64>) () ())) ())
#s(alt (+ y (pow x 2)) (taylor 0 y) (#s(alt (+.f64 (*.f64 x x) y) (patch (+.f64 (*.f64 x x) y) #<representation binary64>) () ())) ())
#s(alt x (taylor 0 y) (#s(alt (sqrt.f64 (+.f64 (*.f64 x x) y)) (patch (sqrt.f64 (+.f64 (*.f64 x x) y)) #<representation binary64>) () ())) ())
#s(alt (+ x (* 1/2 (/ y x))) (taylor 0 y) (#s(alt (sqrt.f64 (+.f64 (*.f64 x x) y)) (patch (sqrt.f64 (+.f64 (*.f64 x x) y)) #<representation binary64>) () ())) ())
#s(alt (+ x (* y (+ (* -1/8 (/ y (pow x 3))) (* 1/2 (/ 1 x))))) (taylor 0 y) (#s(alt (sqrt.f64 (+.f64 (*.f64 x x) y)) (patch (sqrt.f64 (+.f64 (*.f64 x x) y)) #<representation binary64>) () ())) ())
#s(alt (+ x (* y (+ (* y (- (* 1/16 (/ y (pow x 5))) (* 1/8 (/ 1 (pow x 3))))) (* 1/2 (/ 1 x))))) (taylor 0 y) (#s(alt (sqrt.f64 (+.f64 (*.f64 x x) y)) (patch (sqrt.f64 (+.f64 (*.f64 x x) y)) #<representation binary64>) () ())) ())
#s(alt y (taylor inf y) (#s(alt (+.f64 (*.f64 x x) y) (patch (+.f64 (*.f64 x x) y) #<representation binary64>) () ())) ())
#s(alt (* y (+ 1 (/ (pow x 2) y))) (taylor inf y) (#s(alt (+.f64 (*.f64 x x) y) (patch (+.f64 (*.f64 x x) y) #<representation binary64>) () ())) ())
#s(alt (* y (+ 1 (/ (pow x 2) y))) (taylor inf y) (#s(alt (+.f64 (*.f64 x x) y) (patch (+.f64 (*.f64 x x) y) #<representation binary64>) () ())) ())
#s(alt (* y (+ 1 (/ (pow x 2) y))) (taylor inf y) (#s(alt (+.f64 (*.f64 x x) y) (patch (+.f64 (*.f64 x x) y) #<representation binary64>) () ())) ())
#s(alt (sqrt y) (taylor inf y) (#s(alt (sqrt.f64 (+.f64 (*.f64 x x) y)) (patch (sqrt.f64 (+.f64 (*.f64 x x) y)) #<representation binary64>) () ())) ())
#s(alt (* y (+ (sqrt (/ 1 y)) (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))))) (taylor inf y) (#s(alt (sqrt.f64 (+.f64 (*.f64 x x) y)) (patch (sqrt.f64 (+.f64 (*.f64 x x) y)) #<representation binary64>) () ())) ())
#s(alt (* y (+ (sqrt (/ 1 y)) (+ (* -1/8 (* (pow x 4) (sqrt (/ 1 (pow y 5))))) (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3)))))))) (taylor inf y) (#s(alt (sqrt.f64 (+.f64 (*.f64 x x) y)) (patch (sqrt.f64 (+.f64 (*.f64 x x) y)) #<representation binary64>) () ())) ())
#s(alt (* y (+ (sqrt (/ 1 y)) (+ (* -1/8 (* (pow x 4) (sqrt (/ 1 (pow y 5))))) (+ (* 1/16 (* (pow x 6) (sqrt (/ 1 (pow y 7))))) (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))))))) (taylor inf y) (#s(alt (sqrt.f64 (+.f64 (*.f64 x x) y)) (patch (sqrt.f64 (+.f64 (*.f64 x x) y)) #<representation binary64>) () ())) ())
#s(alt y (taylor -inf y) (#s(alt (+.f64 (*.f64 x x) y) (patch (+.f64 (*.f64 x x) y) #<representation binary64>) () ())) ())
#s(alt (* -1 (* y (- (* -1 (/ (pow x 2) y)) 1))) (taylor -inf y) (#s(alt (+.f64 (*.f64 x x) y) (patch (+.f64 (*.f64 x x) y) #<representation binary64>) () ())) ())
#s(alt (* -1 (* y (- (* -1 (/ (pow x 2) y)) 1))) (taylor -inf y) (#s(alt (+.f64 (*.f64 x x) y) (patch (+.f64 (*.f64 x x) y) #<representation binary64>) () ())) ())
#s(alt (* -1 (* y (- (* -1 (/ (pow x 2) y)) 1))) (taylor -inf y) (#s(alt (+.f64 (*.f64 x x) y) (patch (+.f64 (*.f64 x x) y) #<representation binary64>) () ())) ())
#s(alt (* -1 (* (sqrt y) (pow (sqrt -1) 2))) (taylor -inf y) (#s(alt (sqrt.f64 (+.f64 (*.f64 x x) y)) (patch (sqrt.f64 (+.f64 (*.f64 x x) y)) #<representation binary64>) () ())) ())
#s(alt (* -1 (* y (+ (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* (sqrt (/ 1 y)) (pow (sqrt -1) 2))))) (taylor -inf y) (#s(alt (sqrt.f64 (+.f64 (*.f64 x x) y)) (patch (sqrt.f64 (+.f64 (*.f64 x x) y)) #<representation binary64>) () ())) ())
#s(alt (* -1 (* y (+ (* -1/8 (* (/ (pow x 4) (pow (sqrt -1) 2)) (sqrt (/ 1 (pow y 5))))) (+ (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* (sqrt (/ 1 y)) (pow (sqrt -1) 2)))))) (taylor -inf y) (#s(alt (sqrt.f64 (+.f64 (*.f64 x x) y)) (patch (sqrt.f64 (+.f64 (*.f64 x x) y)) #<representation binary64>) () ())) ())
#s(alt (* -1 (* y (+ (* -1/8 (* (/ (pow x 4) (pow (sqrt -1) 2)) (sqrt (/ 1 (pow y 5))))) (+ (* 1/16 (* (/ (pow x 6) (pow (sqrt -1) 4)) (sqrt (/ 1 (pow y 7))))) (+ (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* (sqrt (/ 1 y)) (pow (sqrt -1) 2))))))) (taylor -inf y) (#s(alt (sqrt.f64 (+.f64 (*.f64 x x) y)) (patch (sqrt.f64 (+.f64 (*.f64 x x) y)) #<representation binary64>) () ())) ())
#s(alt y (taylor 0 x) (#s(alt (+.f64 (*.f64 x x) y) (patch (+.f64 (*.f64 x x) y) #<representation binary64>) () ())) ())
#s(alt (+ y (pow x 2)) (taylor 0 x) (#s(alt (+.f64 (*.f64 x x) y) (patch (+.f64 (*.f64 x x) y) #<representation binary64>) () ())) ())
#s(alt (+ y (pow x 2)) (taylor 0 x) (#s(alt (+.f64 (*.f64 x x) y) (patch (+.f64 (*.f64 x x) y) #<representation binary64>) () ())) ())
#s(alt (+ y (pow x 2)) (taylor 0 x) (#s(alt (+.f64 (*.f64 x x) y) (patch (+.f64 (*.f64 x x) y) #<representation binary64>) () ())) ())
#s(alt (sqrt y) (taylor 0 x) (#s(alt (sqrt.f64 (+.f64 (*.f64 x x) y)) (patch (sqrt.f64 (+.f64 (*.f64 x x) y)) #<representation binary64>) () ())) ())
#s(alt (+ (sqrt y) (* 1/2 (* (pow x 2) (sqrt (/ 1 y))))) (taylor 0 x) (#s(alt (sqrt.f64 (+.f64 (*.f64 x x) y)) (patch (sqrt.f64 (+.f64 (*.f64 x x) y)) #<representation binary64>) () ())) ())
#s(alt (+ (sqrt y) (* (pow x 2) (+ (* -1/8 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* 1/2 (sqrt (/ 1 y)))))) (taylor 0 x) (#s(alt (sqrt.f64 (+.f64 (*.f64 x x) y)) (patch (sqrt.f64 (+.f64 (*.f64 x x) y)) #<representation binary64>) () ())) ())
#s(alt (+ (sqrt y) (* (pow x 2) (+ (* 1/2 (sqrt (/ 1 y))) (* (pow x 2) (+ (* -1/8 (sqrt (/ 1 (pow y 3)))) (* 1/16 (* (pow x 2) (sqrt (/ 1 (pow y 5)))))))))) (taylor 0 x) (#s(alt (sqrt.f64 (+.f64 (*.f64 x x) y)) (patch (sqrt.f64 (+.f64 (*.f64 x x) y)) #<representation binary64>) () ())) ())
#s(alt (pow x 2) (taylor 0 x) (#s(alt (*.f64 x x) (patch (*.f64 x x) #<representation binary64>) () ())) ())
#s(alt (pow x 2) (taylor 0 x) (#s(alt (*.f64 x x) (patch (*.f64 x x) #<representation binary64>) () ())) ())
#s(alt (pow x 2) (taylor 0 x) (#s(alt (*.f64 x x) (patch (*.f64 x x) #<representation binary64>) () ())) ())
#s(alt (pow x 2) (taylor 0 x) (#s(alt (*.f64 x x) (patch (*.f64 x x) #<representation binary64>) () ())) ())
#s(alt (pow x 2) (taylor inf x) (#s(alt (+.f64 (*.f64 x x) y) (patch (+.f64 (*.f64 x x) y) #<representation binary64>) () ())) ())
#s(alt (* (pow x 2) (+ 1 (/ y (pow x 2)))) (taylor inf x) (#s(alt (+.f64 (*.f64 x x) y) (patch (+.f64 (*.f64 x x) y) #<representation binary64>) () ())) ())
#s(alt (* (pow x 2) (+ 1 (/ y (pow x 2)))) (taylor inf x) (#s(alt (+.f64 (*.f64 x x) y) (patch (+.f64 (*.f64 x x) y) #<representation binary64>) () ())) ())
#s(alt (* (pow x 2) (+ 1 (/ y (pow x 2)))) (taylor inf x) (#s(alt (+.f64 (*.f64 x x) y) (patch (+.f64 (*.f64 x x) y) #<representation binary64>) () ())) ())
#s(alt x (taylor inf x) (#s(alt (sqrt.f64 (+.f64 (*.f64 x x) y)) (patch (sqrt.f64 (+.f64 (*.f64 x x) y)) #<representation binary64>) () ())) ())
#s(alt (* x (+ 1 (* 1/2 (/ y (pow x 2))))) (taylor inf x) (#s(alt (sqrt.f64 (+.f64 (*.f64 x x) y)) (patch (sqrt.f64 (+.f64 (*.f64 x x) y)) #<representation binary64>) () ())) ())
#s(alt (* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (* 1/2 (/ y (pow x 2)))))) (taylor inf x) (#s(alt (sqrt.f64 (+.f64 (*.f64 x x) y)) (patch (sqrt.f64 (+.f64 (*.f64 x x) y)) #<representation binary64>) () ())) ())
#s(alt (* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (+ (* 1/16 (/ (pow y 3) (pow x 6))) (* 1/2 (/ y (pow x 2))))))) (taylor inf x) (#s(alt (sqrt.f64 (+.f64 (*.f64 x x) y)) (patch (sqrt.f64 (+.f64 (*.f64 x x) y)) #<representation binary64>) () ())) ())
#s(alt (pow x 2) (taylor inf x) (#s(alt (*.f64 x x) (patch (*.f64 x x) #<representation binary64>) () ())) ())
#s(alt (pow x 2) (taylor inf x) (#s(alt (*.f64 x x) (patch (*.f64 x x) #<representation binary64>) () ())) ())
#s(alt (pow x 2) (taylor inf x) (#s(alt (*.f64 x x) (patch (*.f64 x x) #<representation binary64>) () ())) ())
#s(alt (pow x 2) (taylor inf x) (#s(alt (*.f64 x x) (patch (*.f64 x x) #<representation binary64>) () ())) ())
#s(alt (pow x 2) (taylor -inf x) (#s(alt (+.f64 (*.f64 x x) y) (patch (+.f64 (*.f64 x x) y) #<representation binary64>) () ())) ())
#s(alt (* (pow x 2) (+ 1 (/ y (pow x 2)))) (taylor -inf x) (#s(alt (+.f64 (*.f64 x x) y) (patch (+.f64 (*.f64 x x) y) #<representation binary64>) () ())) ())
#s(alt (* (pow x 2) (+ 1 (/ y (pow x 2)))) (taylor -inf x) (#s(alt (+.f64 (*.f64 x x) y) (patch (+.f64 (*.f64 x x) y) #<representation binary64>) () ())) ())
#s(alt (* (pow x 2) (+ 1 (/ y (pow x 2)))) (taylor -inf x) (#s(alt (+.f64 (*.f64 x x) y) (patch (+.f64 (*.f64 x x) y) #<representation binary64>) () ())) ())
#s(alt (* -1 x) (taylor -inf x) (#s(alt (sqrt.f64 (+.f64 (*.f64 x x) y)) (patch (sqrt.f64 (+.f64 (*.f64 x x) y)) #<representation binary64>) () ())) ())
#s(alt (* -1 (* x (+ 1 (* 1/2 (/ y (pow x 2)))))) (taylor -inf x) (#s(alt (sqrt.f64 (+.f64 (*.f64 x x) y)) (patch (sqrt.f64 (+.f64 (*.f64 x x) y)) #<representation binary64>) () ())) ())
#s(alt (* -1 (* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (* 1/2 (/ y (pow x 2))))))) (taylor -inf x) (#s(alt (sqrt.f64 (+.f64 (*.f64 x x) y)) (patch (sqrt.f64 (+.f64 (*.f64 x x) y)) #<representation binary64>) () ())) ())
#s(alt (* -1 (* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (+ (* 1/16 (/ (pow y 3) (pow x 6))) (* 1/2 (/ y (pow x 2)))))))) (taylor -inf x) (#s(alt (sqrt.f64 (+.f64 (*.f64 x x) y)) (patch (sqrt.f64 (+.f64 (*.f64 x x) y)) #<representation binary64>) () ())) ())
#s(alt (pow x 2) (taylor -inf x) (#s(alt (*.f64 x x) (patch (*.f64 x x) #<representation binary64>) () ())) ())
#s(alt (pow x 2) (taylor -inf x) (#s(alt (*.f64 x x) (patch (*.f64 x x) #<representation binary64>) () ())) ())
#s(alt (pow x 2) (taylor -inf x) (#s(alt (*.f64 x x) (patch (*.f64 x x) #<representation binary64>) () ())) ())
#s(alt (pow x 2) (taylor -inf x) (#s(alt (*.f64 x x) (patch (*.f64 x x) #<representation binary64>) () ())) ())
Calls

6 calls:

TimeVariablePointExpression
7.0ms
x
@0
((+ (* x x) y) (sqrt (+ (* x x) y)) (* x x))
1.0ms
y
@-inf
((+ (* x x) y) (sqrt (+ (* x x) y)) (* x x))
1.0ms
y
@inf
((+ (* x x) y) (sqrt (+ (* x x) y)) (* x x))
1.0ms
x
@inf
((+ (* x x) y) (sqrt (+ (* x x) y)) (* x x))
1.0ms
y
@0
((+ (* x x) y) (sqrt (+ (* x x) y)) (* x x))

simplify264.0ms (5.8%)

Memory
26.4MiB live, 257.1MiB allocated
Algorithm
egg-herbie
Rules
23 502×lower-fma.f64
23 502×lower-fma.f32
5 416×lower-*.f64
5 416×lower-*.f32
2 450×lower-+.f64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0133615
1383600
21202592
34035567
08298515
Stop Event
iter limit
node limit
Counts
60 → 55
Calls
Call 1
Inputs
(pow x 2)
(+ y (pow x 2))
(+ y (pow x 2))
(+ y (pow x 2))
x
(+ x (* 1/2 (/ y x)))
(+ x (* y (+ (* -1/8 (/ y (pow x 3))) (* 1/2 (/ 1 x)))))
(+ x (* y (+ (* y (- (* 1/16 (/ y (pow x 5))) (* 1/8 (/ 1 (pow x 3))))) (* 1/2 (/ 1 x)))))
y
(* y (+ 1 (/ (pow x 2) y)))
(* y (+ 1 (/ (pow x 2) y)))
(* y (+ 1 (/ (pow x 2) y)))
(sqrt y)
(* y (+ (sqrt (/ 1 y)) (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3)))))))
(* y (+ (sqrt (/ 1 y)) (+ (* -1/8 (* (pow x 4) (sqrt (/ 1 (pow y 5))))) (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))))))
(* y (+ (sqrt (/ 1 y)) (+ (* -1/8 (* (pow x 4) (sqrt (/ 1 (pow y 5))))) (+ (* 1/16 (* (pow x 6) (sqrt (/ 1 (pow y 7))))) (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3)))))))))
y
(* -1 (* y (- (* -1 (/ (pow x 2) y)) 1)))
(* -1 (* y (- (* -1 (/ (pow x 2) y)) 1)))
(* -1 (* y (- (* -1 (/ (pow x 2) y)) 1)))
(* -1 (* (sqrt y) (pow (sqrt -1) 2)))
(* -1 (* y (+ (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* (sqrt (/ 1 y)) (pow (sqrt -1) 2)))))
(* -1 (* y (+ (* -1/8 (* (/ (pow x 4) (pow (sqrt -1) 2)) (sqrt (/ 1 (pow y 5))))) (+ (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* (sqrt (/ 1 y)) (pow (sqrt -1) 2))))))
(* -1 (* y (+ (* -1/8 (* (/ (pow x 4) (pow (sqrt -1) 2)) (sqrt (/ 1 (pow y 5))))) (+ (* 1/16 (* (/ (pow x 6) (pow (sqrt -1) 4)) (sqrt (/ 1 (pow y 7))))) (+ (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* (sqrt (/ 1 y)) (pow (sqrt -1) 2)))))))
y
(+ y (pow x 2))
(+ y (pow x 2))
(+ y (pow x 2))
(sqrt y)
(+ (sqrt y) (* 1/2 (* (pow x 2) (sqrt (/ 1 y)))))
(+ (sqrt y) (* (pow x 2) (+ (* -1/8 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* 1/2 (sqrt (/ 1 y))))))
(+ (sqrt y) (* (pow x 2) (+ (* 1/2 (sqrt (/ 1 y))) (* (pow x 2) (+ (* -1/8 (sqrt (/ 1 (pow y 3)))) (* 1/16 (* (pow x 2) (sqrt (/ 1 (pow y 5))))))))))
(pow x 2)
(pow x 2)
(pow x 2)
(pow x 2)
(pow x 2)
(* (pow x 2) (+ 1 (/ y (pow x 2))))
(* (pow x 2) (+ 1 (/ y (pow x 2))))
(* (pow x 2) (+ 1 (/ y (pow x 2))))
x
(* x (+ 1 (* 1/2 (/ y (pow x 2)))))
(* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (* 1/2 (/ y (pow x 2))))))
(* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (+ (* 1/16 (/ (pow y 3) (pow x 6))) (* 1/2 (/ y (pow x 2)))))))
(pow x 2)
(pow x 2)
(pow x 2)
(pow x 2)
(pow x 2)
(* (pow x 2) (+ 1 (/ y (pow x 2))))
(* (pow x 2) (+ 1 (/ y (pow x 2))))
(* (pow x 2) (+ 1 (/ y (pow x 2))))
(* -1 x)
(* -1 (* x (+ 1 (* 1/2 (/ y (pow x 2))))))
(* -1 (* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (* 1/2 (/ y (pow x 2)))))))
(* -1 (* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (+ (* 1/16 (/ (pow y 3) (pow x 6))) (* 1/2 (/ y (pow x 2))))))))
(pow x 2)
(pow x 2)
(pow x 2)
(pow x 2)
Outputs
(pow x 2)
(*.f64 x x)
(+ y (pow x 2))
(fma.f64 x x y)
(+ y (pow x 2))
(fma.f64 x x y)
(+ y (pow x 2))
(fma.f64 x x y)
x
(+ x (* 1/2 (/ y x)))
(fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x)
(+ x (* y (+ (* -1/8 (/ y (pow x 3))) (* 1/2 (/ 1 x)))))
(fma.f64 (fma.f64 (/.f64 y (pow.f64 x #s(literal 3 binary64))) #s(literal -1/8 binary64) (/.f64 #s(literal 1/2 binary64) x)) y x)
(+ x (* y (+ (* y (- (* 1/16 (/ y (pow x 5))) (* 1/8 (/ 1 (pow x 3))))) (* 1/2 (/ 1 x)))))
(fma.f64 (fma.f64 (fma.f64 (/.f64 y (pow.f64 x #s(literal 5 binary64))) #s(literal 1/16 binary64) (/.f64 #s(literal -1/8 binary64) (pow.f64 x #s(literal 3 binary64)))) y (/.f64 #s(literal 1/2 binary64) x)) y x)
y
(* y (+ 1 (/ (pow x 2) y)))
(fma.f64 x x y)
(* y (+ 1 (/ (pow x 2) y)))
(fma.f64 x x y)
(* y (+ 1 (/ (pow x 2) y)))
(fma.f64 x x y)
(sqrt y)
(sqrt.f64 y)
(* y (+ (sqrt (/ 1 y)) (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3)))))))
(*.f64 (fma.f64 (*.f64 #s(literal 1/2 binary64) (*.f64 x x)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 3 binary64)))) (sqrt.f64 (/.f64 #s(literal 1 binary64) y))) y)
(* y (+ (sqrt (/ 1 y)) (+ (* -1/8 (* (pow x 4) (sqrt (/ 1 (pow y 5))))) (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))))))
(*.f64 (fma.f64 (*.f64 (pow.f64 x #s(literal 4 binary64)) #s(literal -1/8 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 5 binary64)))) (fma.f64 (*.f64 #s(literal 1/2 binary64) (*.f64 x x)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 3 binary64)))) (sqrt.f64 (/.f64 #s(literal 1 binary64) y)))) y)
(* y (+ (sqrt (/ 1 y)) (+ (* -1/8 (* (pow x 4) (sqrt (/ 1 (pow y 5))))) (+ (* 1/16 (* (pow x 6) (sqrt (/ 1 (pow y 7))))) (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3)))))))))
(*.f64 (fma.f64 (*.f64 (pow.f64 x #s(literal 6 binary64)) #s(literal 1/16 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 7 binary64)))) (fma.f64 (*.f64 (pow.f64 x #s(literal 4 binary64)) #s(literal -1/8 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 5 binary64)))) (fma.f64 (*.f64 #s(literal 1/2 binary64) (*.f64 x x)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 3 binary64)))) (sqrt.f64 (/.f64 #s(literal 1 binary64) y))))) y)
y
(* -1 (* y (- (* -1 (/ (pow x 2) y)) 1)))
(fma.f64 x x y)
(* -1 (* y (- (* -1 (/ (pow x 2) y)) 1)))
(fma.f64 x x y)
(* -1 (* y (- (* -1 (/ (pow x 2) y)) 1)))
(fma.f64 x x y)
(* -1 (* (sqrt y) (pow (sqrt -1) 2)))
(sqrt.f64 y)
(* -1 (* y (+ (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* (sqrt (/ 1 y)) (pow (sqrt -1) 2)))))
(*.f64 (fma.f64 (*.f64 #s(literal -1/2 binary64) (*.f64 x x)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 3 binary64)))) (sqrt.f64 (/.f64 #s(literal 1 binary64) y))) y)
(* -1 (* y (+ (* -1/8 (* (/ (pow x 4) (pow (sqrt -1) 2)) (sqrt (/ 1 (pow y 5))))) (+ (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* (sqrt (/ 1 y)) (pow (sqrt -1) 2))))))
(*.f64 (fma.f64 (*.f64 #s(literal -1/2 binary64) (*.f64 x x)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 3 binary64)))) (fma.f64 (*.f64 (pow.f64 x #s(literal 4 binary64)) #s(literal -1/8 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 5 binary64)))) (sqrt.f64 (/.f64 #s(literal 1 binary64) y)))) y)
(* -1 (* y (+ (* -1/8 (* (/ (pow x 4) (pow (sqrt -1) 2)) (sqrt (/ 1 (pow y 5))))) (+ (* 1/16 (* (/ (pow x 6) (pow (sqrt -1) 4)) (sqrt (/ 1 (pow y 7))))) (+ (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* (sqrt (/ 1 y)) (pow (sqrt -1) 2)))))))
(*.f64 (fma.f64 #s(literal -1/16 binary64) (/.f64 (*.f64 (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 7 binary64)))) (pow.f64 x #s(literal 6 binary64))) (pow.f64 (sqrt.f64 #s(literal -1 binary64)) #s(literal 4 binary64))) (fma.f64 (*.f64 #s(literal -1/2 binary64) (*.f64 x x)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 3 binary64)))) (fma.f64 (*.f64 (pow.f64 x #s(literal 4 binary64)) #s(literal -1/8 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 5 binary64)))) (sqrt.f64 (/.f64 #s(literal 1 binary64) y))))) y)
y
(+ y (pow x 2))
(fma.f64 x x y)
(+ y (pow x 2))
(fma.f64 x x y)
(+ y (pow x 2))
(fma.f64 x x y)
(sqrt y)
(sqrt.f64 y)
(+ (sqrt y) (* 1/2 (* (pow x 2) (sqrt (/ 1 y)))))
(fma.f64 (*.f64 #s(literal 1/2 binary64) (*.f64 x x)) (sqrt.f64 (/.f64 #s(literal 1 binary64) y)) (sqrt.f64 y))
(+ (sqrt y) (* (pow x 2) (+ (* -1/8 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* 1/2 (sqrt (/ 1 y))))))
(fma.f64 (*.f64 #s(literal 1/2 binary64) (*.f64 x x)) (sqrt.f64 (/.f64 #s(literal 1 binary64) y)) (fma.f64 (*.f64 (pow.f64 x #s(literal 4 binary64)) #s(literal -1/8 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 3 binary64)))) (sqrt.f64 y)))
(+ (sqrt y) (* (pow x 2) (+ (* 1/2 (sqrt (/ 1 y))) (* (pow x 2) (+ (* -1/8 (sqrt (/ 1 (pow y 3)))) (* 1/16 (* (pow x 2) (sqrt (/ 1 (pow y 5))))))))))
(fma.f64 (fma.f64 (*.f64 (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 5 binary64)))) (*.f64 #s(literal 1/16 binary64) x)) x (*.f64 (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 3 binary64)))) #s(literal -1/8 binary64))) (pow.f64 x #s(literal 4 binary64)) (fma.f64 (*.f64 #s(literal 1/2 binary64) (*.f64 x x)) (sqrt.f64 (/.f64 #s(literal 1 binary64) y)) (sqrt.f64 y)))
(pow x 2)
(*.f64 x x)
(pow x 2)
(*.f64 x x)
(pow x 2)
(*.f64 x x)
(pow x 2)
(*.f64 x x)
(pow x 2)
(*.f64 x x)
(* (pow x 2) (+ 1 (/ y (pow x 2))))
(fma.f64 x x y)
(* (pow x 2) (+ 1 (/ y (pow x 2))))
(fma.f64 x x y)
(* (pow x 2) (+ 1 (/ y (pow x 2))))
(fma.f64 x x y)
x
(* x (+ 1 (* 1/2 (/ y (pow x 2)))))
(fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x)
(* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (* 1/2 (/ y (pow x 2))))))
(fma.f64 (fma.f64 (/.f64 y (pow.f64 x #s(literal 3 binary64))) #s(literal -1/8 binary64) (/.f64 #s(literal 1/2 binary64) x)) y x)
(* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (+ (* 1/16 (/ (pow y 3) (pow x 6))) (* 1/2 (/ y (pow x 2)))))))
(fma.f64 (*.f64 (pow.f64 y #s(literal 3 binary64)) (/.f64 #s(literal 1/16 binary64) (pow.f64 x #s(literal 6 binary64)))) x (fma.f64 (fma.f64 (/.f64 y (pow.f64 x #s(literal 3 binary64))) #s(literal -1/8 binary64) (/.f64 #s(literal 1/2 binary64) x)) y x))
(pow x 2)
(*.f64 x x)
(pow x 2)
(*.f64 x x)
(pow x 2)
(*.f64 x x)
(pow x 2)
(*.f64 x x)
(pow x 2)
(*.f64 x x)
(* (pow x 2) (+ 1 (/ y (pow x 2))))
(fma.f64 x x y)
(* (pow x 2) (+ 1 (/ y (pow x 2))))
(fma.f64 x x y)
(* (pow x 2) (+ 1 (/ y (pow x 2))))
(fma.f64 x x y)
(* -1 x)
(neg.f64 x)
(* -1 (* x (+ 1 (* 1/2 (/ y (pow x 2))))))
(fma.f64 #s(literal -1/2 binary64) (/.f64 y x) (neg.f64 x))
(* -1 (* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (* 1/2 (/ y (pow x 2)))))))
(neg.f64 (fma.f64 (fma.f64 (/.f64 y (pow.f64 x #s(literal 3 binary64))) #s(literal -1/8 binary64) (/.f64 #s(literal 1/2 binary64) x)) y x))
(* -1 (* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (+ (* 1/16 (/ (pow y 3) (pow x 6))) (* 1/2 (/ y (pow x 2))))))))
(neg.f64 (fma.f64 (*.f64 (pow.f64 y #s(literal 3 binary64)) (/.f64 #s(literal 1/16 binary64) (pow.f64 x #s(literal 6 binary64)))) x (fma.f64 (fma.f64 (/.f64 y (pow.f64 x #s(literal 3 binary64))) #s(literal -1/8 binary64) (/.f64 #s(literal 1/2 binary64) x)) y x)))
(pow x 2)
(*.f64 x x)
(pow x 2)
(*.f64 x x)
(pow x 2)
(*.f64 x x)
(pow x 2)
(*.f64 x x)

rewrite189.0ms (4.2%)

Memory
-14.5MiB live, 266.9MiB allocated
Rules
5 034×lower-fma.f64
5 034×lower-fma.f32
4 204×lower-/.f64
4 204×lower-/.f32
3 240×lower-*.f32
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0514
0814
12614
216914
3152114
0848912
Stop Event
iter limit
node limit
iter limit
Counts
3 → 228
Calls
Call 1
Inputs
(+.f64 (*.f64 x x) y)
(sqrt.f64 (+.f64 (*.f64 x x) y))
(*.f64 x x)
Outputs
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>

eval53.0ms (1.2%)

Memory
-3.3MiB live, 70.7MiB allocated
Compiler

Compiled 6 400 to 869 computations (86.4% saved)

prune8.0ms (0.2%)

Memory
29.8MiB live, 29.8MiB allocated
Pruning

6 alts after pruning (6 fresh and 0 done)

PrunedKeptTotal
New2776283
Fresh000
Picked101
Done000
Total2786284
Accuracy
100.0%
Counts
284 → 6
Alt Table
Click to see full alt table
StatusAccuracyProgram
66.6%
(/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y))))
66.8%
(sqrt.f64 (fma.f64 x x y))
35.1%
(sqrt.f64 #s(approx (+ (* x x) y) (*.f64 x x)))
69.1%
#s(approx (sqrt (+ (* x x) y)) (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x))
34.2%
#s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y))
1.1%
#s(approx (sqrt (+ (* x x) y)) (neg.f64 x))
Compiler

Compiled 64 to 60 computations (6.3% saved)

simplify61.0ms (1.3%)

Memory
-35.2MiB live, 52.9MiB allocated
Algorithm
egg-herbie
Localize:

Found 12 expressions of interest:

NewMetricScoreProgram
cost-diff0
(fma.f64 x x y)
cost-diff0
(sqrt.f64 (fma.f64 x x y))
cost-diff0
(*.f64 x x)
cost-diff0
#s(approx (+ (* x x) y) (*.f64 x x))
cost-diff0
(sqrt.f64 #s(approx (+ (* x x) y) (*.f64 x x)))
cost-diff0
(sqrt.f64 y)
cost-diff0
#s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y))
cost-diff0
(neg.f64 x)
cost-diff0
#s(approx (sqrt (+ (* x x) y)) (neg.f64 x))
cost-diff0
(/.f64 #s(literal 1/2 binary64) x)
cost-diff0
(fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x)
cost-diff0
#s(approx (sqrt (+ (* x x) y)) (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x))
Rules
384×lower-fma.f32
380×lower-fma.f64
264×lower-*.f32
262×lower-*.f64
162×associate-*r*
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01878
02778
13678
24278
34578
44778
55178
66678
710378
813378
924278
1039178
1167678
1295778
13101378
14102778
15103978
0103978
Stop Event
iter limit
saturated
iter limit
Calls
Call 1
Inputs
#s(approx (sqrt (+ (* x x) y)) (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x))
(fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x)
(/.f64 #s(literal 1/2 binary64) x)
#s(literal 1/2 binary64)
x
y
#s(approx (sqrt (+ (* x x) y)) (neg.f64 x))
(neg.f64 x)
x
#s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y))
(sqrt.f64 y)
y
(sqrt.f64 #s(approx (+ (* x x) y) (*.f64 x x)))
#s(approx (+ (* x x) y) (*.f64 x x))
(*.f64 x x)
x
(sqrt.f64 (fma.f64 x x y))
(fma.f64 x x y)
x
y
Outputs
#s(approx (sqrt (+ (* x x) y)) (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x))
(fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x)
(/.f64 #s(literal 1/2 binary64) x)
#s(literal 1/2 binary64)
x
y
#s(approx (sqrt (+ (* x x) y)) (neg.f64 x))
(neg.f64 x)
x
#s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y))
(sqrt.f64 y)
y
(sqrt.f64 #s(approx (+ (* x x) y) (*.f64 x x)))
#s(approx (+ (* x x) y) (*.f64 x x))
(*.f64 x x)
x
(sqrt.f64 (fma.f64 x x y))
(fma.f64 x x y)
x
y

localize32.0ms (0.7%)

Memory
30.4MiB live, 69.1MiB allocated
Localize:

Found 12 expressions of interest:

NewMetricScoreProgram
accuracy0
(fma.f64 x x y)
accuracy11.220352668232248
(sqrt.f64 (fma.f64 x x y))
accuracy0
(*.f64 x x)
accuracy11.220352668232248
(sqrt.f64 #s(approx (+ (* x x) y) (*.f64 x x)))
accuracy20.12109367031704
#s(approx (+ (* x x) y) (*.f64 x x))
accuracy0
(sqrt.f64 y)
accuracy21.115880168227264
#s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y))
accuracy0
(neg.f64 x)
accuracy42.434094481925285
#s(approx (sqrt (+ (* x x) y)) (neg.f64 x))
accuracy0
(/.f64 #s(literal 1/2 binary64) x)
accuracy0.0546875
(fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x)
accuracy19.77837236986095
#s(approx (sqrt (+ (* x x) y)) (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x))
Samples
16.0ms172×0valid
8.0ms84×0invalid
Compiler

Compiled 67 to 13 computations (80.6% saved)

Precisions
Click to see histograms. Total time spent on operations: 12.0ms
ival-mult: 3.0ms (24.9% of total)
ival-sqrt: 3.0ms (24.9% of total)
ival-div: 2.0ms (16.6% of total)
ival-add: 2.0ms (16.6% of total)
ival-neg: 1.0ms (8.3% of total)
ival-true: 0.0ms (0% of total)
exact: 0.0ms (0% of total)
ival-assert: 0.0ms (0% of total)

series34.0ms (0.7%)

Memory
-16.7MiB live, 22.4MiB allocated
Counts
12 → 240
Calls
Call 1
Inputs
#s(alt #s(approx (sqrt (+ (* x x) y)) (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x)) (patch #s(approx (sqrt (+ (* x x) y)) (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x)) #<representation binary64>) () ())
#s(alt (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x) (patch (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x) #<representation binary64>) () ())
#s(alt (/.f64 #s(literal 1/2 binary64) x) (patch (/.f64 #s(literal 1/2 binary64) x) #<representation binary64>) () ())
#s(alt #s(approx (sqrt (+ (* x x) y)) (neg.f64 x)) (patch #s(approx (sqrt (+ (* x x) y)) (neg.f64 x)) #<representation binary64>) () ())
#s(alt (neg.f64 x) (patch (neg.f64 x) #<representation binary64>) () ())
#s(alt #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)) (patch #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)) #<representation binary64>) () ())
#s(alt (sqrt.f64 y) (patch (sqrt.f64 y) #<representation binary64>) () ())
#s(alt (sqrt.f64 #s(approx (+ (* x x) y) (*.f64 x x))) (patch (sqrt.f64 #s(approx (+ (* x x) y) (*.f64 x x))) #<representation binary64>) () ())
#s(alt #s(approx (+ (* x x) y) (*.f64 x x)) (patch #s(approx (+ (* x x) y) (*.f64 x x)) #<representation binary64>) () ())
#s(alt (*.f64 x x) (patch (*.f64 x x) #<representation binary64>) () ())
#s(alt (sqrt.f64 (fma.f64 x x y)) (patch (sqrt.f64 (fma.f64 x x y)) #<representation binary64>) () ())
#s(alt (fma.f64 x x y) (patch (fma.f64 x x y) #<representation binary64>) () ())
Outputs
#s(alt x (taylor 0 y) (#s(alt #s(approx (sqrt (+ (* x x) y)) (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x)) (patch #s(approx (sqrt (+ (* x x) y)) (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x)) #<representation binary64>) () ())) ())
#s(alt (+ x (* 1/2 (/ y x))) (taylor 0 y) (#s(alt #s(approx (sqrt (+ (* x x) y)) (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x)) (patch #s(approx (sqrt (+ (* x x) y)) (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x)) #<representation binary64>) () ())) ())
#s(alt (+ x (* y (+ (* -1/8 (/ y (pow x 3))) (* 1/2 (/ 1 x))))) (taylor 0 y) (#s(alt #s(approx (sqrt (+ (* x x) y)) (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x)) (patch #s(approx (sqrt (+ (* x x) y)) (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x)) #<representation binary64>) () ())) ())
#s(alt (+ x (* y (+ (* y (- (* 1/16 (/ y (pow x 5))) (* 1/8 (/ 1 (pow x 3))))) (* 1/2 (/ 1 x))))) (taylor 0 y) (#s(alt #s(approx (sqrt (+ (* x x) y)) (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x)) (patch #s(approx (sqrt (+ (* x x) y)) (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x)) #<representation binary64>) () ())) ())
#s(alt x (taylor 0 y) (#s(alt (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x) (patch (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x) #<representation binary64>) () ())) ())
#s(alt (+ x (* 1/2 (/ y x))) (taylor 0 y) (#s(alt (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x) (patch (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x) #<representation binary64>) () ())) ())
#s(alt (+ x (* 1/2 (/ y x))) (taylor 0 y) (#s(alt (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x) (patch (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x) #<representation binary64>) () ())) ())
#s(alt (+ x (* 1/2 (/ y x))) (taylor 0 y) (#s(alt (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x) (patch (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x) #<representation binary64>) () ())) ())
#s(alt x (taylor 0 y) (#s(alt #s(approx (sqrt (+ (* x x) y)) (neg.f64 x)) (patch #s(approx (sqrt (+ (* x x) y)) (neg.f64 x)) #<representation binary64>) () ())) ())
#s(alt (+ x (* 1/2 (/ y x))) (taylor 0 y) (#s(alt #s(approx (sqrt (+ (* x x) y)) (neg.f64 x)) (patch #s(approx (sqrt (+ (* x x) y)) (neg.f64 x)) #<representation binary64>) () ())) ())
#s(alt (+ x (* y (+ (* -1/8 (/ y (pow x 3))) (* 1/2 (/ 1 x))))) (taylor 0 y) (#s(alt #s(approx (sqrt (+ (* x x) y)) (neg.f64 x)) (patch #s(approx (sqrt (+ (* x x) y)) (neg.f64 x)) #<representation binary64>) () ())) ())
#s(alt (+ x (* y (+ (* y (- (* 1/16 (/ y (pow x 5))) (* 1/8 (/ 1 (pow x 3))))) (* 1/2 (/ 1 x))))) (taylor 0 y) (#s(alt #s(approx (sqrt (+ (* x x) y)) (neg.f64 x)) (patch #s(approx (sqrt (+ (* x x) y)) (neg.f64 x)) #<representation binary64>) () ())) ())
#s(alt x (taylor 0 y) (#s(alt #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)) (patch #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)) #<representation binary64>) () ())) ())
#s(alt (+ x (* 1/2 (/ y x))) (taylor 0 y) (#s(alt #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)) (patch #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)) #<representation binary64>) () ())) ())
#s(alt (+ x (* y (+ (* -1/8 (/ y (pow x 3))) (* 1/2 (/ 1 x))))) (taylor 0 y) (#s(alt #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)) (patch #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)) #<representation binary64>) () ())) ())
#s(alt (+ x (* y (+ (* y (- (* 1/16 (/ y (pow x 5))) (* 1/8 (/ 1 (pow x 3))))) (* 1/2 (/ 1 x))))) (taylor 0 y) (#s(alt #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)) (patch #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)) #<representation binary64>) () ())) ())
#s(alt (sqrt y) (taylor 0 y) (#s(alt (sqrt.f64 y) (patch (sqrt.f64 y) #<representation binary64>) () ())) ())
#s(alt (sqrt y) (taylor 0 y) (#s(alt (sqrt.f64 y) (patch (sqrt.f64 y) #<representation binary64>) () ())) ())
#s(alt (sqrt y) (taylor 0 y) (#s(alt (sqrt.f64 y) (patch (sqrt.f64 y) #<representation binary64>) () ())) ())
#s(alt (sqrt y) (taylor 0 y) (#s(alt (sqrt.f64 y) (patch (sqrt.f64 y) #<representation binary64>) () ())) ())
#s(alt x (taylor 0 y) (#s(alt (sqrt.f64 #s(approx (+ (* x x) y) (*.f64 x x))) (patch (sqrt.f64 #s(approx (+ (* x x) y) (*.f64 x x))) #<representation binary64>) () ())) ())
#s(alt (+ x (* 1/2 (/ y x))) (taylor 0 y) (#s(alt (sqrt.f64 #s(approx (+ (* x x) y) (*.f64 x x))) (patch (sqrt.f64 #s(approx (+ (* x x) y) (*.f64 x x))) #<representation binary64>) () ())) ())
#s(alt (+ x (* y (+ (* -1/8 (/ y (pow x 3))) (* 1/2 (/ 1 x))))) (taylor 0 y) (#s(alt (sqrt.f64 #s(approx (+ (* x x) y) (*.f64 x x))) (patch (sqrt.f64 #s(approx (+ (* x x) y) (*.f64 x x))) #<representation binary64>) () ())) ())
#s(alt (+ x (* y (+ (* y (- (* 1/16 (/ y (pow x 5))) (* 1/8 (/ 1 (pow x 3))))) (* 1/2 (/ 1 x))))) (taylor 0 y) (#s(alt (sqrt.f64 #s(approx (+ (* x x) y) (*.f64 x x))) (patch (sqrt.f64 #s(approx (+ (* x x) y) (*.f64 x x))) #<representation binary64>) () ())) ())
#s(alt (pow x 2) (taylor 0 y) (#s(alt #s(approx (+ (* x x) y) (*.f64 x x)) (patch #s(approx (+ (* x x) y) (*.f64 x x)) #<representation binary64>) () ())) ())
#s(alt (+ y (pow x 2)) (taylor 0 y) (#s(alt #s(approx (+ (* x x) y) (*.f64 x x)) (patch #s(approx (+ (* x x) y) (*.f64 x x)) #<representation binary64>) () ())) ())
#s(alt (+ y (pow x 2)) (taylor 0 y) (#s(alt #s(approx (+ (* x x) y) (*.f64 x x)) (patch #s(approx (+ (* x x) y) (*.f64 x x)) #<representation binary64>) () ())) ())
#s(alt (+ y (pow x 2)) (taylor 0 y) (#s(alt #s(approx (+ (* x x) y) (*.f64 x x)) (patch #s(approx (+ (* x x) y) (*.f64 x x)) #<representation binary64>) () ())) ())
#s(alt x (taylor 0 y) (#s(alt (sqrt.f64 (fma.f64 x x y)) (patch (sqrt.f64 (fma.f64 x x y)) #<representation binary64>) () ())) ())
#s(alt (+ x (* 1/2 (/ y x))) (taylor 0 y) (#s(alt (sqrt.f64 (fma.f64 x x y)) (patch (sqrt.f64 (fma.f64 x x y)) #<representation binary64>) () ())) ())
#s(alt (+ x (* y (+ (* -1/8 (/ y (pow x 3))) (* 1/2 (/ 1 x))))) (taylor 0 y) (#s(alt (sqrt.f64 (fma.f64 x x y)) (patch (sqrt.f64 (fma.f64 x x y)) #<representation binary64>) () ())) ())
#s(alt (+ x (* y (+ (* y (- (* 1/16 (/ y (pow x 5))) (* 1/8 (/ 1 (pow x 3))))) (* 1/2 (/ 1 x))))) (taylor 0 y) (#s(alt (sqrt.f64 (fma.f64 x x y)) (patch (sqrt.f64 (fma.f64 x x y)) #<representation binary64>) () ())) ())
#s(alt (pow x 2) (taylor 0 y) (#s(alt (fma.f64 x x y) (patch (fma.f64 x x y) #<representation binary64>) () ())) ())
#s(alt (+ y (pow x 2)) (taylor 0 y) (#s(alt (fma.f64 x x y) (patch (fma.f64 x x y) #<representation binary64>) () ())) ())
#s(alt (+ y (pow x 2)) (taylor 0 y) (#s(alt (fma.f64 x x y) (patch (fma.f64 x x y) #<representation binary64>) () ())) ())
#s(alt (+ y (pow x 2)) (taylor 0 y) (#s(alt (fma.f64 x x y) (patch (fma.f64 x x y) #<representation binary64>) () ())) ())
#s(alt (sqrt y) (taylor inf y) (#s(alt #s(approx (sqrt (+ (* x x) y)) (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x)) (patch #s(approx (sqrt (+ (* x x) y)) (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x)) #<representation binary64>) () ())) ())
#s(alt (* y (+ (sqrt (/ 1 y)) (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))))) (taylor inf y) (#s(alt #s(approx (sqrt (+ (* x x) y)) (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x)) (patch #s(approx (sqrt (+ (* x x) y)) (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x)) #<representation binary64>) () ())) ())
#s(alt (* y (+ (sqrt (/ 1 y)) (+ (* -1/8 (* (pow x 4) (sqrt (/ 1 (pow y 5))))) (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3)))))))) (taylor inf y) (#s(alt #s(approx (sqrt (+ (* x x) y)) (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x)) (patch #s(approx (sqrt (+ (* x x) y)) (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x)) #<representation binary64>) () ())) ())
#s(alt (* y (+ (sqrt (/ 1 y)) (+ (* -1/8 (* (pow x 4) (sqrt (/ 1 (pow y 5))))) (+ (* 1/16 (* (pow x 6) (sqrt (/ 1 (pow y 7))))) (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))))))) (taylor inf y) (#s(alt #s(approx (sqrt (+ (* x x) y)) (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x)) (patch #s(approx (sqrt (+ (* x x) y)) (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x)) #<representation binary64>) () ())) ())
#s(alt (* 1/2 (/ y x)) (taylor inf y) (#s(alt (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x) (patch (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x) #<representation binary64>) () ())) ())
#s(alt (* y (+ (* 1/2 (/ 1 x)) (/ x y))) (taylor inf y) (#s(alt (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x) (patch (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x) #<representation binary64>) () ())) ())
#s(alt (* y (+ (* 1/2 (/ 1 x)) (/ x y))) (taylor inf y) (#s(alt (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x) (patch (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x) #<representation binary64>) () ())) ())
#s(alt (* y (+ (* 1/2 (/ 1 x)) (/ x y))) (taylor inf y) (#s(alt (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x) (patch (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x) #<representation binary64>) () ())) ())
#s(alt (sqrt y) (taylor inf y) (#s(alt #s(approx (sqrt (+ (* x x) y)) (neg.f64 x)) (patch #s(approx (sqrt (+ (* x x) y)) (neg.f64 x)) #<representation binary64>) () ())) ())
#s(alt (* y (+ (sqrt (/ 1 y)) (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))))) (taylor inf y) (#s(alt #s(approx (sqrt (+ (* x x) y)) (neg.f64 x)) (patch #s(approx (sqrt (+ (* x x) y)) (neg.f64 x)) #<representation binary64>) () ())) ())
#s(alt (* y (+ (sqrt (/ 1 y)) (+ (* -1/8 (* (pow x 4) (sqrt (/ 1 (pow y 5))))) (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3)))))))) (taylor inf y) (#s(alt #s(approx (sqrt (+ (* x x) y)) (neg.f64 x)) (patch #s(approx (sqrt (+ (* x x) y)) (neg.f64 x)) #<representation binary64>) () ())) ())
#s(alt (* y (+ (sqrt (/ 1 y)) (+ (* -1/8 (* (pow x 4) (sqrt (/ 1 (pow y 5))))) (+ (* 1/16 (* (pow x 6) (sqrt (/ 1 (pow y 7))))) (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))))))) (taylor inf y) (#s(alt #s(approx (sqrt (+ (* x x) y)) (neg.f64 x)) (patch #s(approx (sqrt (+ (* x x) y)) (neg.f64 x)) #<representation binary64>) () ())) ())
#s(alt (sqrt y) (taylor inf y) (#s(alt #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)) (patch #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)) #<representation binary64>) () ())) ())
#s(alt (* y (+ (sqrt (/ 1 y)) (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))))) (taylor inf y) (#s(alt #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)) (patch #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)) #<representation binary64>) () ())) ())
#s(alt (* y (+ (sqrt (/ 1 y)) (+ (* -1/8 (* (pow x 4) (sqrt (/ 1 (pow y 5))))) (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3)))))))) (taylor inf y) (#s(alt #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)) (patch #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)) #<representation binary64>) () ())) ())
#s(alt (* y (+ (sqrt (/ 1 y)) (+ (* -1/8 (* (pow x 4) (sqrt (/ 1 (pow y 5))))) (+ (* 1/16 (* (pow x 6) (sqrt (/ 1 (pow y 7))))) (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))))))) (taylor inf y) (#s(alt #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)) (patch #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)) #<representation binary64>) () ())) ())
#s(alt (sqrt y) (taylor inf y) (#s(alt (sqrt.f64 y) (patch (sqrt.f64 y) #<representation binary64>) () ())) ())
#s(alt (sqrt y) (taylor inf y) (#s(alt (sqrt.f64 y) (patch (sqrt.f64 y) #<representation binary64>) () ())) ())
#s(alt (sqrt y) (taylor inf y) (#s(alt (sqrt.f64 y) (patch (sqrt.f64 y) #<representation binary64>) () ())) ())
#s(alt (sqrt y) (taylor inf y) (#s(alt (sqrt.f64 y) (patch (sqrt.f64 y) #<representation binary64>) () ())) ())
#s(alt (sqrt y) (taylor inf y) (#s(alt (sqrt.f64 #s(approx (+ (* x x) y) (*.f64 x x))) (patch (sqrt.f64 #s(approx (+ (* x x) y) (*.f64 x x))) #<representation binary64>) () ())) ())
#s(alt (* y (+ (sqrt (/ 1 y)) (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))))) (taylor inf y) (#s(alt (sqrt.f64 #s(approx (+ (* x x) y) (*.f64 x x))) (patch (sqrt.f64 #s(approx (+ (* x x) y) (*.f64 x x))) #<representation binary64>) () ())) ())
#s(alt (* y (+ (sqrt (/ 1 y)) (+ (* -1/8 (* (pow x 4) (sqrt (/ 1 (pow y 5))))) (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3)))))))) (taylor inf y) (#s(alt (sqrt.f64 #s(approx (+ (* x x) y) (*.f64 x x))) (patch (sqrt.f64 #s(approx (+ (* x x) y) (*.f64 x x))) #<representation binary64>) () ())) ())
#s(alt (* y (+ (sqrt (/ 1 y)) (+ (* -1/8 (* (pow x 4) (sqrt (/ 1 (pow y 5))))) (+ (* 1/16 (* (pow x 6) (sqrt (/ 1 (pow y 7))))) (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))))))) (taylor inf y) (#s(alt (sqrt.f64 #s(approx (+ (* x x) y) (*.f64 x x))) (patch (sqrt.f64 #s(approx (+ (* x x) y) (*.f64 x x))) #<representation binary64>) () ())) ())
#s(alt y (taylor inf y) (#s(alt #s(approx (+ (* x x) y) (*.f64 x x)) (patch #s(approx (+ (* x x) y) (*.f64 x x)) #<representation binary64>) () ())) ())
#s(alt (* y (+ 1 (/ (pow x 2) y))) (taylor inf y) (#s(alt #s(approx (+ (* x x) y) (*.f64 x x)) (patch #s(approx (+ (* x x) y) (*.f64 x x)) #<representation binary64>) () ())) ())
#s(alt (* y (+ 1 (/ (pow x 2) y))) (taylor inf y) (#s(alt #s(approx (+ (* x x) y) (*.f64 x x)) (patch #s(approx (+ (* x x) y) (*.f64 x x)) #<representation binary64>) () ())) ())
#s(alt (* y (+ 1 (/ (pow x 2) y))) (taylor inf y) (#s(alt #s(approx (+ (* x x) y) (*.f64 x x)) (patch #s(approx (+ (* x x) y) (*.f64 x x)) #<representation binary64>) () ())) ())
#s(alt (sqrt y) (taylor inf y) (#s(alt (sqrt.f64 (fma.f64 x x y)) (patch (sqrt.f64 (fma.f64 x x y)) #<representation binary64>) () ())) ())
#s(alt (* y (+ (sqrt (/ 1 y)) (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))))) (taylor inf y) (#s(alt (sqrt.f64 (fma.f64 x x y)) (patch (sqrt.f64 (fma.f64 x x y)) #<representation binary64>) () ())) ())
#s(alt (* y (+ (sqrt (/ 1 y)) (+ (* -1/8 (* (pow x 4) (sqrt (/ 1 (pow y 5))))) (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3)))))))) (taylor inf y) (#s(alt (sqrt.f64 (fma.f64 x x y)) (patch (sqrt.f64 (fma.f64 x x y)) #<representation binary64>) () ())) ())
#s(alt (* y (+ (sqrt (/ 1 y)) (+ (* -1/8 (* (pow x 4) (sqrt (/ 1 (pow y 5))))) (+ (* 1/16 (* (pow x 6) (sqrt (/ 1 (pow y 7))))) (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))))))) (taylor inf y) (#s(alt (sqrt.f64 (fma.f64 x x y)) (patch (sqrt.f64 (fma.f64 x x y)) #<representation binary64>) () ())) ())
#s(alt y (taylor inf y) (#s(alt (fma.f64 x x y) (patch (fma.f64 x x y) #<representation binary64>) () ())) ())
#s(alt (* y (+ 1 (/ (pow x 2) y))) (taylor inf y) (#s(alt (fma.f64 x x y) (patch (fma.f64 x x y) #<representation binary64>) () ())) ())
#s(alt (* y (+ 1 (/ (pow x 2) y))) (taylor inf y) (#s(alt (fma.f64 x x y) (patch (fma.f64 x x y) #<representation binary64>) () ())) ())
#s(alt (* y (+ 1 (/ (pow x 2) y))) (taylor inf y) (#s(alt (fma.f64 x x y) (patch (fma.f64 x x y) #<representation binary64>) () ())) ())
#s(alt (* -1 (* (sqrt y) (pow (sqrt -1) 2))) (taylor -inf y) (#s(alt #s(approx (sqrt (+ (* x x) y)) (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x)) (patch #s(approx (sqrt (+ (* x x) y)) (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x)) #<representation binary64>) () ())) ())
#s(alt (* -1 (* y (+ (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* (sqrt (/ 1 y)) (pow (sqrt -1) 2))))) (taylor -inf y) (#s(alt #s(approx (sqrt (+ (* x x) y)) (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x)) (patch #s(approx (sqrt (+ (* x x) y)) (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x)) #<representation binary64>) () ())) ())
#s(alt (* -1 (* y (+ (* -1/8 (* (/ (pow x 4) (pow (sqrt -1) 2)) (sqrt (/ 1 (pow y 5))))) (+ (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* (sqrt (/ 1 y)) (pow (sqrt -1) 2)))))) (taylor -inf y) (#s(alt #s(approx (sqrt (+ (* x x) y)) (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x)) (patch #s(approx (sqrt (+ (* x x) y)) (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x)) #<representation binary64>) () ())) ())
#s(alt (* -1 (* y (+ (* -1/8 (* (/ (pow x 4) (pow (sqrt -1) 2)) (sqrt (/ 1 (pow y 5))))) (+ (* 1/16 (* (/ (pow x 6) (pow (sqrt -1) 4)) (sqrt (/ 1 (pow y 7))))) (+ (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* (sqrt (/ 1 y)) (pow (sqrt -1) 2))))))) (taylor -inf y) (#s(alt #s(approx (sqrt (+ (* x x) y)) (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x)) (patch #s(approx (sqrt (+ (* x x) y)) (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x)) #<representation binary64>) () ())) ())
#s(alt (* 1/2 (/ y x)) (taylor -inf y) (#s(alt (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x) (patch (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x) #<representation binary64>) () ())) ())
#s(alt (* -1 (* y (- (* -1 (/ x y)) (* 1/2 (/ 1 x))))) (taylor -inf y) (#s(alt (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x) (patch (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x) #<representation binary64>) () ())) ())
#s(alt (* -1 (* y (- (* -1 (/ x y)) (* 1/2 (/ 1 x))))) (taylor -inf y) (#s(alt (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x) (patch (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x) #<representation binary64>) () ())) ())
#s(alt (* -1 (* y (- (* -1 (/ x y)) (* 1/2 (/ 1 x))))) (taylor -inf y) (#s(alt (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x) (patch (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x) #<representation binary64>) () ())) ())
#s(alt (* -1 (* (sqrt y) (pow (sqrt -1) 2))) (taylor -inf y) (#s(alt #s(approx (sqrt (+ (* x x) y)) (neg.f64 x)) (patch #s(approx (sqrt (+ (* x x) y)) (neg.f64 x)) #<representation binary64>) () ())) ())
#s(alt (* -1 (* y (+ (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* (sqrt (/ 1 y)) (pow (sqrt -1) 2))))) (taylor -inf y) (#s(alt #s(approx (sqrt (+ (* x x) y)) (neg.f64 x)) (patch #s(approx (sqrt (+ (* x x) y)) (neg.f64 x)) #<representation binary64>) () ())) ())
#s(alt (* -1 (* y (+ (* -1/8 (* (/ (pow x 4) (pow (sqrt -1) 2)) (sqrt (/ 1 (pow y 5))))) (+ (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* (sqrt (/ 1 y)) (pow (sqrt -1) 2)))))) (taylor -inf y) (#s(alt #s(approx (sqrt (+ (* x x) y)) (neg.f64 x)) (patch #s(approx (sqrt (+ (* x x) y)) (neg.f64 x)) #<representation binary64>) () ())) ())
#s(alt (* -1 (* y (+ (* -1/8 (* (/ (pow x 4) (pow (sqrt -1) 2)) (sqrt (/ 1 (pow y 5))))) (+ (* 1/16 (* (/ (pow x 6) (pow (sqrt -1) 4)) (sqrt (/ 1 (pow y 7))))) (+ (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* (sqrt (/ 1 y)) (pow (sqrt -1) 2))))))) (taylor -inf y) (#s(alt #s(approx (sqrt (+ (* x x) y)) (neg.f64 x)) (patch #s(approx (sqrt (+ (* x x) y)) (neg.f64 x)) #<representation binary64>) () ())) ())
#s(alt (* -1 (* (sqrt y) (pow (sqrt -1) 2))) (taylor -inf y) (#s(alt #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)) (patch #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)) #<representation binary64>) () ())) ())
#s(alt (* -1 (* y (+ (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* (sqrt (/ 1 y)) (pow (sqrt -1) 2))))) (taylor -inf y) (#s(alt #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)) (patch #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)) #<representation binary64>) () ())) ())
#s(alt (* -1 (* y (+ (* -1/8 (* (/ (pow x 4) (pow (sqrt -1) 2)) (sqrt (/ 1 (pow y 5))))) (+ (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* (sqrt (/ 1 y)) (pow (sqrt -1) 2)))))) (taylor -inf y) (#s(alt #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)) (patch #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)) #<representation binary64>) () ())) ())
#s(alt (* -1 (* y (+ (* -1/8 (* (/ (pow x 4) (pow (sqrt -1) 2)) (sqrt (/ 1 (pow y 5))))) (+ (* 1/16 (* (/ (pow x 6) (pow (sqrt -1) 4)) (sqrt (/ 1 (pow y 7))))) (+ (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* (sqrt (/ 1 y)) (pow (sqrt -1) 2))))))) (taylor -inf y) (#s(alt #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)) (patch #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)) #<representation binary64>) () ())) ())
#s(alt (* -1 (* (sqrt y) (pow (sqrt -1) 2))) (taylor -inf y) (#s(alt (sqrt.f64 y) (patch (sqrt.f64 y) #<representation binary64>) () ())) ())
#s(alt (* -1 (* (sqrt y) (pow (sqrt -1) 2))) (taylor -inf y) (#s(alt (sqrt.f64 y) (patch (sqrt.f64 y) #<representation binary64>) () ())) ())
#s(alt (* -1 (* (sqrt y) (pow (sqrt -1) 2))) (taylor -inf y) (#s(alt (sqrt.f64 y) (patch (sqrt.f64 y) #<representation binary64>) () ())) ())
#s(alt (* -1 (* (sqrt y) (pow (sqrt -1) 2))) (taylor -inf y) (#s(alt (sqrt.f64 y) (patch (sqrt.f64 y) #<representation binary64>) () ())) ())
#s(alt (* -1 (* (sqrt y) (pow (sqrt -1) 2))) (taylor -inf y) (#s(alt (sqrt.f64 #s(approx (+ (* x x) y) (*.f64 x x))) (patch (sqrt.f64 #s(approx (+ (* x x) y) (*.f64 x x))) #<representation binary64>) () ())) ())
#s(alt (* -1 (* y (+ (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* (sqrt (/ 1 y)) (pow (sqrt -1) 2))))) (taylor -inf y) (#s(alt (sqrt.f64 #s(approx (+ (* x x) y) (*.f64 x x))) (patch (sqrt.f64 #s(approx (+ (* x x) y) (*.f64 x x))) #<representation binary64>) () ())) ())
#s(alt (* -1 (* y (+ (* -1/8 (* (/ (pow x 4) (pow (sqrt -1) 2)) (sqrt (/ 1 (pow y 5))))) (+ (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* (sqrt (/ 1 y)) (pow (sqrt -1) 2)))))) (taylor -inf y) (#s(alt (sqrt.f64 #s(approx (+ (* x x) y) (*.f64 x x))) (patch (sqrt.f64 #s(approx (+ (* x x) y) (*.f64 x x))) #<representation binary64>) () ())) ())
#s(alt (* -1 (* y (+ (* -1/8 (* (/ (pow x 4) (pow (sqrt -1) 2)) (sqrt (/ 1 (pow y 5))))) (+ (* 1/16 (* (/ (pow x 6) (pow (sqrt -1) 4)) (sqrt (/ 1 (pow y 7))))) (+ (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* (sqrt (/ 1 y)) (pow (sqrt -1) 2))))))) (taylor -inf y) (#s(alt (sqrt.f64 #s(approx (+ (* x x) y) (*.f64 x x))) (patch (sqrt.f64 #s(approx (+ (* x x) y) (*.f64 x x))) #<representation binary64>) () ())) ())
#s(alt y (taylor -inf y) (#s(alt #s(approx (+ (* x x) y) (*.f64 x x)) (patch #s(approx (+ (* x x) y) (*.f64 x x)) #<representation binary64>) () ())) ())
#s(alt (* -1 (* y (- (* -1 (/ (pow x 2) y)) 1))) (taylor -inf y) (#s(alt #s(approx (+ (* x x) y) (*.f64 x x)) (patch #s(approx (+ (* x x) y) (*.f64 x x)) #<representation binary64>) () ())) ())
#s(alt (* -1 (* y (- (* -1 (/ (pow x 2) y)) 1))) (taylor -inf y) (#s(alt #s(approx (+ (* x x) y) (*.f64 x x)) (patch #s(approx (+ (* x x) y) (*.f64 x x)) #<representation binary64>) () ())) ())
#s(alt (* -1 (* y (- (* -1 (/ (pow x 2) y)) 1))) (taylor -inf y) (#s(alt #s(approx (+ (* x x) y) (*.f64 x x)) (patch #s(approx (+ (* x x) y) (*.f64 x x)) #<representation binary64>) () ())) ())
#s(alt (* -1 (* (sqrt y) (pow (sqrt -1) 2))) (taylor -inf y) (#s(alt (sqrt.f64 (fma.f64 x x y)) (patch (sqrt.f64 (fma.f64 x x y)) #<representation binary64>) () ())) ())
#s(alt (* -1 (* y (+ (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* (sqrt (/ 1 y)) (pow (sqrt -1) 2))))) (taylor -inf y) (#s(alt (sqrt.f64 (fma.f64 x x y)) (patch (sqrt.f64 (fma.f64 x x y)) #<representation binary64>) () ())) ())
#s(alt (* -1 (* y (+ (* -1/8 (* (/ (pow x 4) (pow (sqrt -1) 2)) (sqrt (/ 1 (pow y 5))))) (+ (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* (sqrt (/ 1 y)) (pow (sqrt -1) 2)))))) (taylor -inf y) (#s(alt (sqrt.f64 (fma.f64 x x y)) (patch (sqrt.f64 (fma.f64 x x y)) #<representation binary64>) () ())) ())
#s(alt (* -1 (* y (+ (* -1/8 (* (/ (pow x 4) (pow (sqrt -1) 2)) (sqrt (/ 1 (pow y 5))))) (+ (* 1/16 (* (/ (pow x 6) (pow (sqrt -1) 4)) (sqrt (/ 1 (pow y 7))))) (+ (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* (sqrt (/ 1 y)) (pow (sqrt -1) 2))))))) (taylor -inf y) (#s(alt (sqrt.f64 (fma.f64 x x y)) (patch (sqrt.f64 (fma.f64 x x y)) #<representation binary64>) () ())) ())
#s(alt y (taylor -inf y) (#s(alt (fma.f64 x x y) (patch (fma.f64 x x y) #<representation binary64>) () ())) ())
#s(alt (* -1 (* y (- (* -1 (/ (pow x 2) y)) 1))) (taylor -inf y) (#s(alt (fma.f64 x x y) (patch (fma.f64 x x y) #<representation binary64>) () ())) ())
#s(alt (* -1 (* y (- (* -1 (/ (pow x 2) y)) 1))) (taylor -inf y) (#s(alt (fma.f64 x x y) (patch (fma.f64 x x y) #<representation binary64>) () ())) ())
#s(alt (* -1 (* y (- (* -1 (/ (pow x 2) y)) 1))) (taylor -inf y) (#s(alt (fma.f64 x x y) (patch (fma.f64 x x y) #<representation binary64>) () ())) ())
#s(alt (sqrt y) (taylor 0 x) (#s(alt #s(approx (sqrt (+ (* x x) y)) (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x)) (patch #s(approx (sqrt (+ (* x x) y)) (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x)) #<representation binary64>) () ())) ())
#s(alt (+ (sqrt y) (* 1/2 (* (pow x 2) (sqrt (/ 1 y))))) (taylor 0 x) (#s(alt #s(approx (sqrt (+ (* x x) y)) (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x)) (patch #s(approx (sqrt (+ (* x x) y)) (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x)) #<representation binary64>) () ())) ())
#s(alt (+ (sqrt y) (* (pow x 2) (+ (* -1/8 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* 1/2 (sqrt (/ 1 y)))))) (taylor 0 x) (#s(alt #s(approx (sqrt (+ (* x x) y)) (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x)) (patch #s(approx (sqrt (+ (* x x) y)) (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x)) #<representation binary64>) () ())) ())
#s(alt (+ (sqrt y) (* (pow x 2) (+ (* 1/2 (sqrt (/ 1 y))) (* (pow x 2) (+ (* -1/8 (sqrt (/ 1 (pow y 3)))) (* 1/16 (* (pow x 2) (sqrt (/ 1 (pow y 5)))))))))) (taylor 0 x) (#s(alt #s(approx (sqrt (+ (* x x) y)) (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x)) (patch #s(approx (sqrt (+ (* x x) y)) (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x)) #<representation binary64>) () ())) ())
#s(alt (* 1/2 (/ y x)) (taylor 0 x) (#s(alt (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x) (patch (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x) #<representation binary64>) () ())) ())
#s(alt (/ (+ (* 1/2 y) (pow x 2)) x) (taylor 0 x) (#s(alt (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x) (patch (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x) #<representation binary64>) () ())) ())
#s(alt (/ (+ (* 1/2 y) (pow x 2)) x) (taylor 0 x) (#s(alt (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x) (patch (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x) #<representation binary64>) () ())) ())
#s(alt (/ (+ (* 1/2 y) (pow x 2)) x) (taylor 0 x) (#s(alt (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x) (patch (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x) #<representation binary64>) () ())) ())
#s(alt (/ 1/2 x) (taylor 0 x) (#s(alt (/.f64 #s(literal 1/2 binary64) x) (patch (/.f64 #s(literal 1/2 binary64) x) #<representation binary64>) () ())) ())
#s(alt (/ 1/2 x) (taylor 0 x) (#s(alt (/.f64 #s(literal 1/2 binary64) x) (patch (/.f64 #s(literal 1/2 binary64) x) #<representation binary64>) () ())) ())
#s(alt (/ 1/2 x) (taylor 0 x) (#s(alt (/.f64 #s(literal 1/2 binary64) x) (patch (/.f64 #s(literal 1/2 binary64) x) #<representation binary64>) () ())) ())
#s(alt (/ 1/2 x) (taylor 0 x) (#s(alt (/.f64 #s(literal 1/2 binary64) x) (patch (/.f64 #s(literal 1/2 binary64) x) #<representation binary64>) () ())) ())
#s(alt (sqrt y) (taylor 0 x) (#s(alt #s(approx (sqrt (+ (* x x) y)) (neg.f64 x)) (patch #s(approx (sqrt (+ (* x x) y)) (neg.f64 x)) #<representation binary64>) () ())) ())
#s(alt (+ (sqrt y) (* 1/2 (* (pow x 2) (sqrt (/ 1 y))))) (taylor 0 x) (#s(alt #s(approx (sqrt (+ (* x x) y)) (neg.f64 x)) (patch #s(approx (sqrt (+ (* x x) y)) (neg.f64 x)) #<representation binary64>) () ())) ())
#s(alt (+ (sqrt y) (* (pow x 2) (+ (* -1/8 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* 1/2 (sqrt (/ 1 y)))))) (taylor 0 x) (#s(alt #s(approx (sqrt (+ (* x x) y)) (neg.f64 x)) (patch #s(approx (sqrt (+ (* x x) y)) (neg.f64 x)) #<representation binary64>) () ())) ())
#s(alt (+ (sqrt y) (* (pow x 2) (+ (* 1/2 (sqrt (/ 1 y))) (* (pow x 2) (+ (* -1/8 (sqrt (/ 1 (pow y 3)))) (* 1/16 (* (pow x 2) (sqrt (/ 1 (pow y 5)))))))))) (taylor 0 x) (#s(alt #s(approx (sqrt (+ (* x x) y)) (neg.f64 x)) (patch #s(approx (sqrt (+ (* x x) y)) (neg.f64 x)) #<representation binary64>) () ())) ())
#s(alt (* -1 x) (taylor 0 x) (#s(alt (neg.f64 x) (patch (neg.f64 x) #<representation binary64>) () ())) ())
#s(alt (* -1 x) (taylor 0 x) (#s(alt (neg.f64 x) (patch (neg.f64 x) #<representation binary64>) () ())) ())
#s(alt (* -1 x) (taylor 0 x) (#s(alt (neg.f64 x) (patch (neg.f64 x) #<representation binary64>) () ())) ())
#s(alt (* -1 x) (taylor 0 x) (#s(alt (neg.f64 x) (patch (neg.f64 x) #<representation binary64>) () ())) ())
#s(alt (sqrt y) (taylor 0 x) (#s(alt #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)) (patch #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)) #<representation binary64>) () ())) ())
#s(alt (+ (sqrt y) (* 1/2 (* (pow x 2) (sqrt (/ 1 y))))) (taylor 0 x) (#s(alt #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)) (patch #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)) #<representation binary64>) () ())) ())
#s(alt (+ (sqrt y) (* (pow x 2) (+ (* -1/8 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* 1/2 (sqrt (/ 1 y)))))) (taylor 0 x) (#s(alt #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)) (patch #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)) #<representation binary64>) () ())) ())
#s(alt (+ (sqrt y) (* (pow x 2) (+ (* 1/2 (sqrt (/ 1 y))) (* (pow x 2) (+ (* -1/8 (sqrt (/ 1 (pow y 3)))) (* 1/16 (* (pow x 2) (sqrt (/ 1 (pow y 5)))))))))) (taylor 0 x) (#s(alt #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)) (patch #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)) #<representation binary64>) () ())) ())
#s(alt (sqrt y) (taylor 0 x) (#s(alt (sqrt.f64 #s(approx (+ (* x x) y) (*.f64 x x))) (patch (sqrt.f64 #s(approx (+ (* x x) y) (*.f64 x x))) #<representation binary64>) () ())) ())
#s(alt (+ (sqrt y) (* 1/2 (* (pow x 2) (sqrt (/ 1 y))))) (taylor 0 x) (#s(alt (sqrt.f64 #s(approx (+ (* x x) y) (*.f64 x x))) (patch (sqrt.f64 #s(approx (+ (* x x) y) (*.f64 x x))) #<representation binary64>) () ())) ())
#s(alt (+ (sqrt y) (* (pow x 2) (+ (* -1/8 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* 1/2 (sqrt (/ 1 y)))))) (taylor 0 x) (#s(alt (sqrt.f64 #s(approx (+ (* x x) y) (*.f64 x x))) (patch (sqrt.f64 #s(approx (+ (* x x) y) (*.f64 x x))) #<representation binary64>) () ())) ())
#s(alt (+ (sqrt y) (* (pow x 2) (+ (* 1/2 (sqrt (/ 1 y))) (* (pow x 2) (+ (* -1/8 (sqrt (/ 1 (pow y 3)))) (* 1/16 (* (pow x 2) (sqrt (/ 1 (pow y 5)))))))))) (taylor 0 x) (#s(alt (sqrt.f64 #s(approx (+ (* x x) y) (*.f64 x x))) (patch (sqrt.f64 #s(approx (+ (* x x) y) (*.f64 x x))) #<representation binary64>) () ())) ())
#s(alt y (taylor 0 x) (#s(alt #s(approx (+ (* x x) y) (*.f64 x x)) (patch #s(approx (+ (* x x) y) (*.f64 x x)) #<representation binary64>) () ())) ())
#s(alt (+ y (pow x 2)) (taylor 0 x) (#s(alt #s(approx (+ (* x x) y) (*.f64 x x)) (patch #s(approx (+ (* x x) y) (*.f64 x x)) #<representation binary64>) () ())) ())
#s(alt (+ y (pow x 2)) (taylor 0 x) (#s(alt #s(approx (+ (* x x) y) (*.f64 x x)) (patch #s(approx (+ (* x x) y) (*.f64 x x)) #<representation binary64>) () ())) ())
#s(alt (+ y (pow x 2)) (taylor 0 x) (#s(alt #s(approx (+ (* x x) y) (*.f64 x x)) (patch #s(approx (+ (* x x) y) (*.f64 x x)) #<representation binary64>) () ())) ())
#s(alt (pow x 2) (taylor 0 x) (#s(alt (*.f64 x x) (patch (*.f64 x x) #<representation binary64>) () ())) ())
#s(alt (pow x 2) (taylor 0 x) (#s(alt (*.f64 x x) (patch (*.f64 x x) #<representation binary64>) () ())) ())
#s(alt (pow x 2) (taylor 0 x) (#s(alt (*.f64 x x) (patch (*.f64 x x) #<representation binary64>) () ())) ())
#s(alt (pow x 2) (taylor 0 x) (#s(alt (*.f64 x x) (patch (*.f64 x x) #<representation binary64>) () ())) ())
#s(alt (sqrt y) (taylor 0 x) (#s(alt (sqrt.f64 (fma.f64 x x y)) (patch (sqrt.f64 (fma.f64 x x y)) #<representation binary64>) () ())) ())
#s(alt (+ (sqrt y) (* 1/2 (* (pow x 2) (sqrt (/ 1 y))))) (taylor 0 x) (#s(alt (sqrt.f64 (fma.f64 x x y)) (patch (sqrt.f64 (fma.f64 x x y)) #<representation binary64>) () ())) ())
#s(alt (+ (sqrt y) (* (pow x 2) (+ (* -1/8 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* 1/2 (sqrt (/ 1 y)))))) (taylor 0 x) (#s(alt (sqrt.f64 (fma.f64 x x y)) (patch (sqrt.f64 (fma.f64 x x y)) #<representation binary64>) () ())) ())
#s(alt (+ (sqrt y) (* (pow x 2) (+ (* 1/2 (sqrt (/ 1 y))) (* (pow x 2) (+ (* -1/8 (sqrt (/ 1 (pow y 3)))) (* 1/16 (* (pow x 2) (sqrt (/ 1 (pow y 5)))))))))) (taylor 0 x) (#s(alt (sqrt.f64 (fma.f64 x x y)) (patch (sqrt.f64 (fma.f64 x x y)) #<representation binary64>) () ())) ())
#s(alt y (taylor 0 x) (#s(alt (fma.f64 x x y) (patch (fma.f64 x x y) #<representation binary64>) () ())) ())
#s(alt (+ y (pow x 2)) (taylor 0 x) (#s(alt (fma.f64 x x y) (patch (fma.f64 x x y) #<representation binary64>) () ())) ())
#s(alt (+ y (pow x 2)) (taylor 0 x) (#s(alt (fma.f64 x x y) (patch (fma.f64 x x y) #<representation binary64>) () ())) ())
#s(alt (+ y (pow x 2)) (taylor 0 x) (#s(alt (fma.f64 x x y) (patch (fma.f64 x x y) #<representation binary64>) () ())) ())
#s(alt x (taylor inf x) (#s(alt #s(approx (sqrt (+ (* x x) y)) (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x)) (patch #s(approx (sqrt (+ (* x x) y)) (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x)) #<representation binary64>) () ())) ())
#s(alt (* x (+ 1 (* 1/2 (/ y (pow x 2))))) (taylor inf x) (#s(alt #s(approx (sqrt (+ (* x x) y)) (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x)) (patch #s(approx (sqrt (+ (* x x) y)) (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x)) #<representation binary64>) () ())) ())
#s(alt (* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (* 1/2 (/ y (pow x 2)))))) (taylor inf x) (#s(alt #s(approx (sqrt (+ (* x x) y)) (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x)) (patch #s(approx (sqrt (+ (* x x) y)) (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x)) #<representation binary64>) () ())) ())
#s(alt (* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (+ (* 1/16 (/ (pow y 3) (pow x 6))) (* 1/2 (/ y (pow x 2))))))) (taylor inf x) (#s(alt #s(approx (sqrt (+ (* x x) y)) (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x)) (patch #s(approx (sqrt (+ (* x x) y)) (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x)) #<representation binary64>) () ())) ())
#s(alt x (taylor inf x) (#s(alt (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x) (patch (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x) #<representation binary64>) () ())) ())
#s(alt (* x (+ 1 (* 1/2 (/ y (pow x 2))))) (taylor inf x) (#s(alt (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x) (patch (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x) #<representation binary64>) () ())) ())
#s(alt (* x (+ 1 (* 1/2 (/ y (pow x 2))))) (taylor inf x) (#s(alt (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x) (patch (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x) #<representation binary64>) () ())) ())
#s(alt (* x (+ 1 (* 1/2 (/ y (pow x 2))))) (taylor inf x) (#s(alt (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x) (patch (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x) #<representation binary64>) () ())) ())
#s(alt (/ 1/2 x) (taylor inf x) (#s(alt (/.f64 #s(literal 1/2 binary64) x) (patch (/.f64 #s(literal 1/2 binary64) x) #<representation binary64>) () ())) ())
#s(alt (/ 1/2 x) (taylor inf x) (#s(alt (/.f64 #s(literal 1/2 binary64) x) (patch (/.f64 #s(literal 1/2 binary64) x) #<representation binary64>) () ())) ())
#s(alt (/ 1/2 x) (taylor inf x) (#s(alt (/.f64 #s(literal 1/2 binary64) x) (patch (/.f64 #s(literal 1/2 binary64) x) #<representation binary64>) () ())) ())
#s(alt (/ 1/2 x) (taylor inf x) (#s(alt (/.f64 #s(literal 1/2 binary64) x) (patch (/.f64 #s(literal 1/2 binary64) x) #<representation binary64>) () ())) ())
#s(alt x (taylor inf x) (#s(alt #s(approx (sqrt (+ (* x x) y)) (neg.f64 x)) (patch #s(approx (sqrt (+ (* x x) y)) (neg.f64 x)) #<representation binary64>) () ())) ())
#s(alt (* x (+ 1 (* 1/2 (/ y (pow x 2))))) (taylor inf x) (#s(alt #s(approx (sqrt (+ (* x x) y)) (neg.f64 x)) (patch #s(approx (sqrt (+ (* x x) y)) (neg.f64 x)) #<representation binary64>) () ())) ())
#s(alt (* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (* 1/2 (/ y (pow x 2)))))) (taylor inf x) (#s(alt #s(approx (sqrt (+ (* x x) y)) (neg.f64 x)) (patch #s(approx (sqrt (+ (* x x) y)) (neg.f64 x)) #<representation binary64>) () ())) ())
#s(alt (* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (+ (* 1/16 (/ (pow y 3) (pow x 6))) (* 1/2 (/ y (pow x 2))))))) (taylor inf x) (#s(alt #s(approx (sqrt (+ (* x x) y)) (neg.f64 x)) (patch #s(approx (sqrt (+ (* x x) y)) (neg.f64 x)) #<representation binary64>) () ())) ())
#s(alt (* -1 x) (taylor inf x) (#s(alt (neg.f64 x) (patch (neg.f64 x) #<representation binary64>) () ())) ())
#s(alt (* -1 x) (taylor inf x) (#s(alt (neg.f64 x) (patch (neg.f64 x) #<representation binary64>) () ())) ())
#s(alt (* -1 x) (taylor inf x) (#s(alt (neg.f64 x) (patch (neg.f64 x) #<representation binary64>) () ())) ())
#s(alt (* -1 x) (taylor inf x) (#s(alt (neg.f64 x) (patch (neg.f64 x) #<representation binary64>) () ())) ())
#s(alt x (taylor inf x) (#s(alt #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)) (patch #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)) #<representation binary64>) () ())) ())
#s(alt (* x (+ 1 (* 1/2 (/ y (pow x 2))))) (taylor inf x) (#s(alt #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)) (patch #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)) #<representation binary64>) () ())) ())
#s(alt (* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (* 1/2 (/ y (pow x 2)))))) (taylor inf x) (#s(alt #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)) (patch #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)) #<representation binary64>) () ())) ())
#s(alt (* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (+ (* 1/16 (/ (pow y 3) (pow x 6))) (* 1/2 (/ y (pow x 2))))))) (taylor inf x) (#s(alt #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)) (patch #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)) #<representation binary64>) () ())) ())
#s(alt x (taylor inf x) (#s(alt (sqrt.f64 #s(approx (+ (* x x) y) (*.f64 x x))) (patch (sqrt.f64 #s(approx (+ (* x x) y) (*.f64 x x))) #<representation binary64>) () ())) ())
#s(alt (* x (+ 1 (* 1/2 (/ y (pow x 2))))) (taylor inf x) (#s(alt (sqrt.f64 #s(approx (+ (* x x) y) (*.f64 x x))) (patch (sqrt.f64 #s(approx (+ (* x x) y) (*.f64 x x))) #<representation binary64>) () ())) ())
#s(alt (* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (* 1/2 (/ y (pow x 2)))))) (taylor inf x) (#s(alt (sqrt.f64 #s(approx (+ (* x x) y) (*.f64 x x))) (patch (sqrt.f64 #s(approx (+ (* x x) y) (*.f64 x x))) #<representation binary64>) () ())) ())
#s(alt (* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (+ (* 1/16 (/ (pow y 3) (pow x 6))) (* 1/2 (/ y (pow x 2))))))) (taylor inf x) (#s(alt (sqrt.f64 #s(approx (+ (* x x) y) (*.f64 x x))) (patch (sqrt.f64 #s(approx (+ (* x x) y) (*.f64 x x))) #<representation binary64>) () ())) ())
#s(alt (pow x 2) (taylor inf x) (#s(alt #s(approx (+ (* x x) y) (*.f64 x x)) (patch #s(approx (+ (* x x) y) (*.f64 x x)) #<representation binary64>) () ())) ())
#s(alt (* (pow x 2) (+ 1 (/ y (pow x 2)))) (taylor inf x) (#s(alt #s(approx (+ (* x x) y) (*.f64 x x)) (patch #s(approx (+ (* x x) y) (*.f64 x x)) #<representation binary64>) () ())) ())
#s(alt (* (pow x 2) (+ 1 (/ y (pow x 2)))) (taylor inf x) (#s(alt #s(approx (+ (* x x) y) (*.f64 x x)) (patch #s(approx (+ (* x x) y) (*.f64 x x)) #<representation binary64>) () ())) ())
#s(alt (* (pow x 2) (+ 1 (/ y (pow x 2)))) (taylor inf x) (#s(alt #s(approx (+ (* x x) y) (*.f64 x x)) (patch #s(approx (+ (* x x) y) (*.f64 x x)) #<representation binary64>) () ())) ())
#s(alt (pow x 2) (taylor inf x) (#s(alt (*.f64 x x) (patch (*.f64 x x) #<representation binary64>) () ())) ())
#s(alt (pow x 2) (taylor inf x) (#s(alt (*.f64 x x) (patch (*.f64 x x) #<representation binary64>) () ())) ())
#s(alt (pow x 2) (taylor inf x) (#s(alt (*.f64 x x) (patch (*.f64 x x) #<representation binary64>) () ())) ())
#s(alt (pow x 2) (taylor inf x) (#s(alt (*.f64 x x) (patch (*.f64 x x) #<representation binary64>) () ())) ())
#s(alt x (taylor inf x) (#s(alt (sqrt.f64 (fma.f64 x x y)) (patch (sqrt.f64 (fma.f64 x x y)) #<representation binary64>) () ())) ())
#s(alt (* x (+ 1 (* 1/2 (/ y (pow x 2))))) (taylor inf x) (#s(alt (sqrt.f64 (fma.f64 x x y)) (patch (sqrt.f64 (fma.f64 x x y)) #<representation binary64>) () ())) ())
#s(alt (* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (* 1/2 (/ y (pow x 2)))))) (taylor inf x) (#s(alt (sqrt.f64 (fma.f64 x x y)) (patch (sqrt.f64 (fma.f64 x x y)) #<representation binary64>) () ())) ())
#s(alt (* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (+ (* 1/16 (/ (pow y 3) (pow x 6))) (* 1/2 (/ y (pow x 2))))))) (taylor inf x) (#s(alt (sqrt.f64 (fma.f64 x x y)) (patch (sqrt.f64 (fma.f64 x x y)) #<representation binary64>) () ())) ())
#s(alt (pow x 2) (taylor inf x) (#s(alt (fma.f64 x x y) (patch (fma.f64 x x y) #<representation binary64>) () ())) ())
#s(alt (* (pow x 2) (+ 1 (/ y (pow x 2)))) (taylor inf x) (#s(alt (fma.f64 x x y) (patch (fma.f64 x x y) #<representation binary64>) () ())) ())
#s(alt (* (pow x 2) (+ 1 (/ y (pow x 2)))) (taylor inf x) (#s(alt (fma.f64 x x y) (patch (fma.f64 x x y) #<representation binary64>) () ())) ())
#s(alt (* (pow x 2) (+ 1 (/ y (pow x 2)))) (taylor inf x) (#s(alt (fma.f64 x x y) (patch (fma.f64 x x y) #<representation binary64>) () ())) ())
#s(alt (* -1 x) (taylor -inf x) (#s(alt #s(approx (sqrt (+ (* x x) y)) (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x)) (patch #s(approx (sqrt (+ (* x x) y)) (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x)) #<representation binary64>) () ())) ())
#s(alt (* -1 (* x (+ 1 (* 1/2 (/ y (pow x 2)))))) (taylor -inf x) (#s(alt #s(approx (sqrt (+ (* x x) y)) (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x)) (patch #s(approx (sqrt (+ (* x x) y)) (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x)) #<representation binary64>) () ())) ())
#s(alt (* -1 (* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (* 1/2 (/ y (pow x 2))))))) (taylor -inf x) (#s(alt #s(approx (sqrt (+ (* x x) y)) (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x)) (patch #s(approx (sqrt (+ (* x x) y)) (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x)) #<representation binary64>) () ())) ())
#s(alt (* -1 (* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (+ (* 1/16 (/ (pow y 3) (pow x 6))) (* 1/2 (/ y (pow x 2)))))))) (taylor -inf x) (#s(alt #s(approx (sqrt (+ (* x x) y)) (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x)) (patch #s(approx (sqrt (+ (* x x) y)) (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x)) #<representation binary64>) () ())) ())
#s(alt x (taylor -inf x) (#s(alt (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x) (patch (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x) #<representation binary64>) () ())) ())
#s(alt (* -1 (* x (- (* -1/2 (/ y (pow x 2))) 1))) (taylor -inf x) (#s(alt (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x) (patch (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x) #<representation binary64>) () ())) ())
#s(alt (* -1 (* x (- (* -1/2 (/ y (pow x 2))) 1))) (taylor -inf x) (#s(alt (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x) (patch (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x) #<representation binary64>) () ())) ())
#s(alt (* -1 (* x (- (* -1/2 (/ y (pow x 2))) 1))) (taylor -inf x) (#s(alt (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x) (patch (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x) #<representation binary64>) () ())) ())
#s(alt (/ 1/2 x) (taylor -inf x) (#s(alt (/.f64 #s(literal 1/2 binary64) x) (patch (/.f64 #s(literal 1/2 binary64) x) #<representation binary64>) () ())) ())
#s(alt (/ 1/2 x) (taylor -inf x) (#s(alt (/.f64 #s(literal 1/2 binary64) x) (patch (/.f64 #s(literal 1/2 binary64) x) #<representation binary64>) () ())) ())
#s(alt (/ 1/2 x) (taylor -inf x) (#s(alt (/.f64 #s(literal 1/2 binary64) x) (patch (/.f64 #s(literal 1/2 binary64) x) #<representation binary64>) () ())) ())
#s(alt (/ 1/2 x) (taylor -inf x) (#s(alt (/.f64 #s(literal 1/2 binary64) x) (patch (/.f64 #s(literal 1/2 binary64) x) #<representation binary64>) () ())) ())
#s(alt (* -1 x) (taylor -inf x) (#s(alt #s(approx (sqrt (+ (* x x) y)) (neg.f64 x)) (patch #s(approx (sqrt (+ (* x x) y)) (neg.f64 x)) #<representation binary64>) () ())) ())
#s(alt (* -1 (* x (+ 1 (* 1/2 (/ y (pow x 2)))))) (taylor -inf x) (#s(alt #s(approx (sqrt (+ (* x x) y)) (neg.f64 x)) (patch #s(approx (sqrt (+ (* x x) y)) (neg.f64 x)) #<representation binary64>) () ())) ())
#s(alt (* -1 (* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (* 1/2 (/ y (pow x 2))))))) (taylor -inf x) (#s(alt #s(approx (sqrt (+ (* x x) y)) (neg.f64 x)) (patch #s(approx (sqrt (+ (* x x) y)) (neg.f64 x)) #<representation binary64>) () ())) ())
#s(alt (* -1 (* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (+ (* 1/16 (/ (pow y 3) (pow x 6))) (* 1/2 (/ y (pow x 2)))))))) (taylor -inf x) (#s(alt #s(approx (sqrt (+ (* x x) y)) (neg.f64 x)) (patch #s(approx (sqrt (+ (* x x) y)) (neg.f64 x)) #<representation binary64>) () ())) ())
#s(alt (* -1 x) (taylor -inf x) (#s(alt (neg.f64 x) (patch (neg.f64 x) #<representation binary64>) () ())) ())
#s(alt (* -1 x) (taylor -inf x) (#s(alt (neg.f64 x) (patch (neg.f64 x) #<representation binary64>) () ())) ())
#s(alt (* -1 x) (taylor -inf x) (#s(alt (neg.f64 x) (patch (neg.f64 x) #<representation binary64>) () ())) ())
#s(alt (* -1 x) (taylor -inf x) (#s(alt (neg.f64 x) (patch (neg.f64 x) #<representation binary64>) () ())) ())
#s(alt (* -1 x) (taylor -inf x) (#s(alt #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)) (patch #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)) #<representation binary64>) () ())) ())
#s(alt (* -1 (* x (+ 1 (* 1/2 (/ y (pow x 2)))))) (taylor -inf x) (#s(alt #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)) (patch #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)) #<representation binary64>) () ())) ())
#s(alt (* -1 (* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (* 1/2 (/ y (pow x 2))))))) (taylor -inf x) (#s(alt #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)) (patch #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)) #<representation binary64>) () ())) ())
#s(alt (* -1 (* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (+ (* 1/16 (/ (pow y 3) (pow x 6))) (* 1/2 (/ y (pow x 2)))))))) (taylor -inf x) (#s(alt #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)) (patch #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)) #<representation binary64>) () ())) ())
#s(alt (* -1 x) (taylor -inf x) (#s(alt (sqrt.f64 #s(approx (+ (* x x) y) (*.f64 x x))) (patch (sqrt.f64 #s(approx (+ (* x x) y) (*.f64 x x))) #<representation binary64>) () ())) ())
#s(alt (* -1 (* x (+ 1 (* 1/2 (/ y (pow x 2)))))) (taylor -inf x) (#s(alt (sqrt.f64 #s(approx (+ (* x x) y) (*.f64 x x))) (patch (sqrt.f64 #s(approx (+ (* x x) y) (*.f64 x x))) #<representation binary64>) () ())) ())
#s(alt (* -1 (* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (* 1/2 (/ y (pow x 2))))))) (taylor -inf x) (#s(alt (sqrt.f64 #s(approx (+ (* x x) y) (*.f64 x x))) (patch (sqrt.f64 #s(approx (+ (* x x) y) (*.f64 x x))) #<representation binary64>) () ())) ())
#s(alt (* -1 (* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (+ (* 1/16 (/ (pow y 3) (pow x 6))) (* 1/2 (/ y (pow x 2)))))))) (taylor -inf x) (#s(alt (sqrt.f64 #s(approx (+ (* x x) y) (*.f64 x x))) (patch (sqrt.f64 #s(approx (+ (* x x) y) (*.f64 x x))) #<representation binary64>) () ())) ())
#s(alt (pow x 2) (taylor -inf x) (#s(alt #s(approx (+ (* x x) y) (*.f64 x x)) (patch #s(approx (+ (* x x) y) (*.f64 x x)) #<representation binary64>) () ())) ())
#s(alt (* (pow x 2) (+ 1 (/ y (pow x 2)))) (taylor -inf x) (#s(alt #s(approx (+ (* x x) y) (*.f64 x x)) (patch #s(approx (+ (* x x) y) (*.f64 x x)) #<representation binary64>) () ())) ())
#s(alt (* (pow x 2) (+ 1 (/ y (pow x 2)))) (taylor -inf x) (#s(alt #s(approx (+ (* x x) y) (*.f64 x x)) (patch #s(approx (+ (* x x) y) (*.f64 x x)) #<representation binary64>) () ())) ())
#s(alt (* (pow x 2) (+ 1 (/ y (pow x 2)))) (taylor -inf x) (#s(alt #s(approx (+ (* x x) y) (*.f64 x x)) (patch #s(approx (+ (* x x) y) (*.f64 x x)) #<representation binary64>) () ())) ())
#s(alt (pow x 2) (taylor -inf x) (#s(alt (*.f64 x x) (patch (*.f64 x x) #<representation binary64>) () ())) ())
#s(alt (pow x 2) (taylor -inf x) (#s(alt (*.f64 x x) (patch (*.f64 x x) #<representation binary64>) () ())) ())
#s(alt (pow x 2) (taylor -inf x) (#s(alt (*.f64 x x) (patch (*.f64 x x) #<representation binary64>) () ())) ())
#s(alt (pow x 2) (taylor -inf x) (#s(alt (*.f64 x x) (patch (*.f64 x x) #<representation binary64>) () ())) ())
#s(alt (* -1 x) (taylor -inf x) (#s(alt (sqrt.f64 (fma.f64 x x y)) (patch (sqrt.f64 (fma.f64 x x y)) #<representation binary64>) () ())) ())
#s(alt (* -1 (* x (+ 1 (* 1/2 (/ y (pow x 2)))))) (taylor -inf x) (#s(alt (sqrt.f64 (fma.f64 x x y)) (patch (sqrt.f64 (fma.f64 x x y)) #<representation binary64>) () ())) ())
#s(alt (* -1 (* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (* 1/2 (/ y (pow x 2))))))) (taylor -inf x) (#s(alt (sqrt.f64 (fma.f64 x x y)) (patch (sqrt.f64 (fma.f64 x x y)) #<representation binary64>) () ())) ())
#s(alt (* -1 (* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (+ (* 1/16 (/ (pow y 3) (pow x 6))) (* 1/2 (/ y (pow x 2)))))))) (taylor -inf x) (#s(alt (sqrt.f64 (fma.f64 x x y)) (patch (sqrt.f64 (fma.f64 x x y)) #<representation binary64>) () ())) ())
#s(alt (pow x 2) (taylor -inf x) (#s(alt (fma.f64 x x y) (patch (fma.f64 x x y) #<representation binary64>) () ())) ())
#s(alt (* (pow x 2) (+ 1 (/ y (pow x 2)))) (taylor -inf x) (#s(alt (fma.f64 x x y) (patch (fma.f64 x x y) #<representation binary64>) () ())) ())
#s(alt (* (pow x 2) (+ 1 (/ y (pow x 2)))) (taylor -inf x) (#s(alt (fma.f64 x x y) (patch (fma.f64 x x y) #<representation binary64>) () ())) ())
#s(alt (* (pow x 2) (+ 1 (/ y (pow x 2)))) (taylor -inf x) (#s(alt (fma.f64 x x y) (patch (fma.f64 x x y) #<representation binary64>) () ())) ())
Calls

6 calls:

TimeVariablePointExpression
23.0ms
x
@0
((sqrt (+ (* x x) y)) (+ (* (/ 1/2 x) y) x) (/ 1/2 x) (sqrt (+ (* x x) y)) (neg x) (sqrt (+ (* x x) y)) (sqrt y) (sqrt (+ (* x x) y)) (+ (* x x) y) (* x x) (sqrt (+ (* x x) y)) (+ (* x x) y))
1.0ms
y
@-inf
((sqrt (+ (* x x) y)) (+ (* (/ 1/2 x) y) x) (/ 1/2 x) (sqrt (+ (* x x) y)) (neg x) (sqrt (+ (* x x) y)) (sqrt y) (sqrt (+ (* x x) y)) (+ (* x x) y) (* x x) (sqrt (+ (* x x) y)) (+ (* x x) y))
1.0ms
x
@inf
((sqrt (+ (* x x) y)) (+ (* (/ 1/2 x) y) x) (/ 1/2 x) (sqrt (+ (* x x) y)) (neg x) (sqrt (+ (* x x) y)) (sqrt y) (sqrt (+ (* x x) y)) (+ (* x x) y) (* x x) (sqrt (+ (* x x) y)) (+ (* x x) y))
1.0ms
y
@0
((sqrt (+ (* x x) y)) (+ (* (/ 1/2 x) y) x) (/ 1/2 x) (sqrt (+ (* x x) y)) (neg x) (sqrt (+ (* x x) y)) (sqrt y) (sqrt (+ (* x x) y)) (+ (* x x) y) (* x x) (sqrt (+ (* x x) y)) (+ (* x x) y))
1.0ms
x
@-inf
((sqrt (+ (* x x) y)) (+ (* (/ 1/2 x) y) x) (/ 1/2 x) (sqrt (+ (* x x) y)) (neg x) (sqrt (+ (* x x) y)) (sqrt y) (sqrt (+ (* x x) y)) (+ (* x x) y) (* x x) (sqrt (+ (* x x) y)) (+ (* x x) y))

simplify199.0ms (4.4%)

Memory
9.6MiB live, 281.4MiB allocated
Algorithm
egg-herbie
Rules
23 474×lower-fma.f64
23 474×lower-fma.f32
5 372×lower-*.f64
5 372×lower-*.f32
2 410×lower-+.f64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01492889
14252814
213182774
344672654
086752430
Stop Event
iter limit
node limit
Counts
240 → 221
Calls
Call 1
Inputs
x
(+ x (* 1/2 (/ y x)))
(+ x (* y (+ (* -1/8 (/ y (pow x 3))) (* 1/2 (/ 1 x)))))
(+ x (* y (+ (* y (- (* 1/16 (/ y (pow x 5))) (* 1/8 (/ 1 (pow x 3))))) (* 1/2 (/ 1 x)))))
x
(+ x (* 1/2 (/ y x)))
(+ x (* 1/2 (/ y x)))
(+ x (* 1/2 (/ y x)))
x
(+ x (* 1/2 (/ y x)))
(+ x (* y (+ (* -1/8 (/ y (pow x 3))) (* 1/2 (/ 1 x)))))
(+ x (* y (+ (* y (- (* 1/16 (/ y (pow x 5))) (* 1/8 (/ 1 (pow x 3))))) (* 1/2 (/ 1 x)))))
x
(+ x (* 1/2 (/ y x)))
(+ x (* y (+ (* -1/8 (/ y (pow x 3))) (* 1/2 (/ 1 x)))))
(+ x (* y (+ (* y (- (* 1/16 (/ y (pow x 5))) (* 1/8 (/ 1 (pow x 3))))) (* 1/2 (/ 1 x)))))
(sqrt y)
(sqrt y)
(sqrt y)
(sqrt y)
x
(+ x (* 1/2 (/ y x)))
(+ x (* y (+ (* -1/8 (/ y (pow x 3))) (* 1/2 (/ 1 x)))))
(+ x (* y (+ (* y (- (* 1/16 (/ y (pow x 5))) (* 1/8 (/ 1 (pow x 3))))) (* 1/2 (/ 1 x)))))
(pow x 2)
(+ y (pow x 2))
(+ y (pow x 2))
(+ y (pow x 2))
x
(+ x (* 1/2 (/ y x)))
(+ x (* y (+ (* -1/8 (/ y (pow x 3))) (* 1/2 (/ 1 x)))))
(+ x (* y (+ (* y (- (* 1/16 (/ y (pow x 5))) (* 1/8 (/ 1 (pow x 3))))) (* 1/2 (/ 1 x)))))
(pow x 2)
(+ y (pow x 2))
(+ y (pow x 2))
(+ y (pow x 2))
(sqrt y)
(* y (+ (sqrt (/ 1 y)) (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3)))))))
(* y (+ (sqrt (/ 1 y)) (+ (* -1/8 (* (pow x 4) (sqrt (/ 1 (pow y 5))))) (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))))))
(* y (+ (sqrt (/ 1 y)) (+ (* -1/8 (* (pow x 4) (sqrt (/ 1 (pow y 5))))) (+ (* 1/16 (* (pow x 6) (sqrt (/ 1 (pow y 7))))) (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3)))))))))
(* 1/2 (/ y x))
(* y (+ (* 1/2 (/ 1 x)) (/ x y)))
(* y (+ (* 1/2 (/ 1 x)) (/ x y)))
(* y (+ (* 1/2 (/ 1 x)) (/ x y)))
(sqrt y)
(* y (+ (sqrt (/ 1 y)) (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3)))))))
(* y (+ (sqrt (/ 1 y)) (+ (* -1/8 (* (pow x 4) (sqrt (/ 1 (pow y 5))))) (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))))))
(* y (+ (sqrt (/ 1 y)) (+ (* -1/8 (* (pow x 4) (sqrt (/ 1 (pow y 5))))) (+ (* 1/16 (* (pow x 6) (sqrt (/ 1 (pow y 7))))) (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3)))))))))
(sqrt y)
(* y (+ (sqrt (/ 1 y)) (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3)))))))
(* y (+ (sqrt (/ 1 y)) (+ (* -1/8 (* (pow x 4) (sqrt (/ 1 (pow y 5))))) (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))))))
(* y (+ (sqrt (/ 1 y)) (+ (* -1/8 (* (pow x 4) (sqrt (/ 1 (pow y 5))))) (+ (* 1/16 (* (pow x 6) (sqrt (/ 1 (pow y 7))))) (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3)))))))))
(sqrt y)
(sqrt y)
(sqrt y)
(sqrt y)
(sqrt y)
(* y (+ (sqrt (/ 1 y)) (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3)))))))
(* y (+ (sqrt (/ 1 y)) (+ (* -1/8 (* (pow x 4) (sqrt (/ 1 (pow y 5))))) (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))))))
(* y (+ (sqrt (/ 1 y)) (+ (* -1/8 (* (pow x 4) (sqrt (/ 1 (pow y 5))))) (+ (* 1/16 (* (pow x 6) (sqrt (/ 1 (pow y 7))))) (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3)))))))))
y
(* y (+ 1 (/ (pow x 2) y)))
(* y (+ 1 (/ (pow x 2) y)))
(* y (+ 1 (/ (pow x 2) y)))
(sqrt y)
(* y (+ (sqrt (/ 1 y)) (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3)))))))
(* y (+ (sqrt (/ 1 y)) (+ (* -1/8 (* (pow x 4) (sqrt (/ 1 (pow y 5))))) (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))))))
(* y (+ (sqrt (/ 1 y)) (+ (* -1/8 (* (pow x 4) (sqrt (/ 1 (pow y 5))))) (+ (* 1/16 (* (pow x 6) (sqrt (/ 1 (pow y 7))))) (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3)))))))))
y
(* y (+ 1 (/ (pow x 2) y)))
(* y (+ 1 (/ (pow x 2) y)))
(* y (+ 1 (/ (pow x 2) y)))
(* -1 (* (sqrt y) (pow (sqrt -1) 2)))
(* -1 (* y (+ (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* (sqrt (/ 1 y)) (pow (sqrt -1) 2)))))
(* -1 (* y (+ (* -1/8 (* (/ (pow x 4) (pow (sqrt -1) 2)) (sqrt (/ 1 (pow y 5))))) (+ (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* (sqrt (/ 1 y)) (pow (sqrt -1) 2))))))
(* -1 (* y (+ (* -1/8 (* (/ (pow x 4) (pow (sqrt -1) 2)) (sqrt (/ 1 (pow y 5))))) (+ (* 1/16 (* (/ (pow x 6) (pow (sqrt -1) 4)) (sqrt (/ 1 (pow y 7))))) (+ (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* (sqrt (/ 1 y)) (pow (sqrt -1) 2)))))))
(* 1/2 (/ y x))
(* -1 (* y (- (* -1 (/ x y)) (* 1/2 (/ 1 x)))))
(* -1 (* y (- (* -1 (/ x y)) (* 1/2 (/ 1 x)))))
(* -1 (* y (- (* -1 (/ x y)) (* 1/2 (/ 1 x)))))
(* -1 (* (sqrt y) (pow (sqrt -1) 2)))
(* -1 (* y (+ (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* (sqrt (/ 1 y)) (pow (sqrt -1) 2)))))
(* -1 (* y (+ (* -1/8 (* (/ (pow x 4) (pow (sqrt -1) 2)) (sqrt (/ 1 (pow y 5))))) (+ (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* (sqrt (/ 1 y)) (pow (sqrt -1) 2))))))
(* -1 (* y (+ (* -1/8 (* (/ (pow x 4) (pow (sqrt -1) 2)) (sqrt (/ 1 (pow y 5))))) (+ (* 1/16 (* (/ (pow x 6) (pow (sqrt -1) 4)) (sqrt (/ 1 (pow y 7))))) (+ (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* (sqrt (/ 1 y)) (pow (sqrt -1) 2)))))))
(* -1 (* (sqrt y) (pow (sqrt -1) 2)))
(* -1 (* y (+ (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* (sqrt (/ 1 y)) (pow (sqrt -1) 2)))))
(* -1 (* y (+ (* -1/8 (* (/ (pow x 4) (pow (sqrt -1) 2)) (sqrt (/ 1 (pow y 5))))) (+ (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* (sqrt (/ 1 y)) (pow (sqrt -1) 2))))))
(* -1 (* y (+ (* -1/8 (* (/ (pow x 4) (pow (sqrt -1) 2)) (sqrt (/ 1 (pow y 5))))) (+ (* 1/16 (* (/ (pow x 6) (pow (sqrt -1) 4)) (sqrt (/ 1 (pow y 7))))) (+ (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* (sqrt (/ 1 y)) (pow (sqrt -1) 2)))))))
(* -1 (* (sqrt y) (pow (sqrt -1) 2)))
(* -1 (* (sqrt y) (pow (sqrt -1) 2)))
(* -1 (* (sqrt y) (pow (sqrt -1) 2)))
(* -1 (* (sqrt y) (pow (sqrt -1) 2)))
(* -1 (* (sqrt y) (pow (sqrt -1) 2)))
(* -1 (* y (+ (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* (sqrt (/ 1 y)) (pow (sqrt -1) 2)))))
(* -1 (* y (+ (* -1/8 (* (/ (pow x 4) (pow (sqrt -1) 2)) (sqrt (/ 1 (pow y 5))))) (+ (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* (sqrt (/ 1 y)) (pow (sqrt -1) 2))))))
(* -1 (* y (+ (* -1/8 (* (/ (pow x 4) (pow (sqrt -1) 2)) (sqrt (/ 1 (pow y 5))))) (+ (* 1/16 (* (/ (pow x 6) (pow (sqrt -1) 4)) (sqrt (/ 1 (pow y 7))))) (+ (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* (sqrt (/ 1 y)) (pow (sqrt -1) 2)))))))
y
(* -1 (* y (- (* -1 (/ (pow x 2) y)) 1)))
(* -1 (* y (- (* -1 (/ (pow x 2) y)) 1)))
(* -1 (* y (- (* -1 (/ (pow x 2) y)) 1)))
(* -1 (* (sqrt y) (pow (sqrt -1) 2)))
(* -1 (* y (+ (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* (sqrt (/ 1 y)) (pow (sqrt -1) 2)))))
(* -1 (* y (+ (* -1/8 (* (/ (pow x 4) (pow (sqrt -1) 2)) (sqrt (/ 1 (pow y 5))))) (+ (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* (sqrt (/ 1 y)) (pow (sqrt -1) 2))))))
(* -1 (* y (+ (* -1/8 (* (/ (pow x 4) (pow (sqrt -1) 2)) (sqrt (/ 1 (pow y 5))))) (+ (* 1/16 (* (/ (pow x 6) (pow (sqrt -1) 4)) (sqrt (/ 1 (pow y 7))))) (+ (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* (sqrt (/ 1 y)) (pow (sqrt -1) 2)))))))
y
(* -1 (* y (- (* -1 (/ (pow x 2) y)) 1)))
(* -1 (* y (- (* -1 (/ (pow x 2) y)) 1)))
(* -1 (* y (- (* -1 (/ (pow x 2) y)) 1)))
(sqrt y)
(+ (sqrt y) (* 1/2 (* (pow x 2) (sqrt (/ 1 y)))))
(+ (sqrt y) (* (pow x 2) (+ (* -1/8 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* 1/2 (sqrt (/ 1 y))))))
(+ (sqrt y) (* (pow x 2) (+ (* 1/2 (sqrt (/ 1 y))) (* (pow x 2) (+ (* -1/8 (sqrt (/ 1 (pow y 3)))) (* 1/16 (* (pow x 2) (sqrt (/ 1 (pow y 5))))))))))
(* 1/2 (/ y x))
(/ (+ (* 1/2 y) (pow x 2)) x)
(/ (+ (* 1/2 y) (pow x 2)) x)
(/ (+ (* 1/2 y) (pow x 2)) x)
(/ 1/2 x)
(/ 1/2 x)
(/ 1/2 x)
(/ 1/2 x)
(sqrt y)
(+ (sqrt y) (* 1/2 (* (pow x 2) (sqrt (/ 1 y)))))
(+ (sqrt y) (* (pow x 2) (+ (* -1/8 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* 1/2 (sqrt (/ 1 y))))))
(+ (sqrt y) (* (pow x 2) (+ (* 1/2 (sqrt (/ 1 y))) (* (pow x 2) (+ (* -1/8 (sqrt (/ 1 (pow y 3)))) (* 1/16 (* (pow x 2) (sqrt (/ 1 (pow y 5))))))))))
(* -1 x)
(* -1 x)
(* -1 x)
(* -1 x)
(sqrt y)
(+ (sqrt y) (* 1/2 (* (pow x 2) (sqrt (/ 1 y)))))
(+ (sqrt y) (* (pow x 2) (+ (* -1/8 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* 1/2 (sqrt (/ 1 y))))))
(+ (sqrt y) (* (pow x 2) (+ (* 1/2 (sqrt (/ 1 y))) (* (pow x 2) (+ (* -1/8 (sqrt (/ 1 (pow y 3)))) (* 1/16 (* (pow x 2) (sqrt (/ 1 (pow y 5))))))))))
(sqrt y)
(+ (sqrt y) (* 1/2 (* (pow x 2) (sqrt (/ 1 y)))))
(+ (sqrt y) (* (pow x 2) (+ (* -1/8 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* 1/2 (sqrt (/ 1 y))))))
(+ (sqrt y) (* (pow x 2) (+ (* 1/2 (sqrt (/ 1 y))) (* (pow x 2) (+ (* -1/8 (sqrt (/ 1 (pow y 3)))) (* 1/16 (* (pow x 2) (sqrt (/ 1 (pow y 5))))))))))
y
(+ y (pow x 2))
(+ y (pow x 2))
(+ y (pow x 2))
(pow x 2)
(pow x 2)
(pow x 2)
(pow x 2)
(sqrt y)
(+ (sqrt y) (* 1/2 (* (pow x 2) (sqrt (/ 1 y)))))
(+ (sqrt y) (* (pow x 2) (+ (* -1/8 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* 1/2 (sqrt (/ 1 y))))))
(+ (sqrt y) (* (pow x 2) (+ (* 1/2 (sqrt (/ 1 y))) (* (pow x 2) (+ (* -1/8 (sqrt (/ 1 (pow y 3)))) (* 1/16 (* (pow x 2) (sqrt (/ 1 (pow y 5))))))))))
y
(+ y (pow x 2))
(+ y (pow x 2))
(+ y (pow x 2))
x
(* x (+ 1 (* 1/2 (/ y (pow x 2)))))
(* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (* 1/2 (/ y (pow x 2))))))
(* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (+ (* 1/16 (/ (pow y 3) (pow x 6))) (* 1/2 (/ y (pow x 2)))))))
x
(* x (+ 1 (* 1/2 (/ y (pow x 2)))))
(* x (+ 1 (* 1/2 (/ y (pow x 2)))))
(* x (+ 1 (* 1/2 (/ y (pow x 2)))))
(/ 1/2 x)
(/ 1/2 x)
(/ 1/2 x)
(/ 1/2 x)
x
(* x (+ 1 (* 1/2 (/ y (pow x 2)))))
(* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (* 1/2 (/ y (pow x 2))))))
(* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (+ (* 1/16 (/ (pow y 3) (pow x 6))) (* 1/2 (/ y (pow x 2)))))))
(* -1 x)
(* -1 x)
(* -1 x)
(* -1 x)
x
(* x (+ 1 (* 1/2 (/ y (pow x 2)))))
(* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (* 1/2 (/ y (pow x 2))))))
(* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (+ (* 1/16 (/ (pow y 3) (pow x 6))) (* 1/2 (/ y (pow x 2)))))))
x
(* x (+ 1 (* 1/2 (/ y (pow x 2)))))
(* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (* 1/2 (/ y (pow x 2))))))
(* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (+ (* 1/16 (/ (pow y 3) (pow x 6))) (* 1/2 (/ y (pow x 2)))))))
(pow x 2)
(* (pow x 2) (+ 1 (/ y (pow x 2))))
(* (pow x 2) (+ 1 (/ y (pow x 2))))
(* (pow x 2) (+ 1 (/ y (pow x 2))))
(pow x 2)
(pow x 2)
(pow x 2)
(pow x 2)
x
(* x (+ 1 (* 1/2 (/ y (pow x 2)))))
(* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (* 1/2 (/ y (pow x 2))))))
(* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (+ (* 1/16 (/ (pow y 3) (pow x 6))) (* 1/2 (/ y (pow x 2)))))))
(pow x 2)
(* (pow x 2) (+ 1 (/ y (pow x 2))))
(* (pow x 2) (+ 1 (/ y (pow x 2))))
(* (pow x 2) (+ 1 (/ y (pow x 2))))
(* -1 x)
(* -1 (* x (+ 1 (* 1/2 (/ y (pow x 2))))))
(* -1 (* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (* 1/2 (/ y (pow x 2)))))))
(* -1 (* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (+ (* 1/16 (/ (pow y 3) (pow x 6))) (* 1/2 (/ y (pow x 2))))))))
x
(* -1 (* x (- (* -1/2 (/ y (pow x 2))) 1)))
(* -1 (* x (- (* -1/2 (/ y (pow x 2))) 1)))
(* -1 (* x (- (* -1/2 (/ y (pow x 2))) 1)))
(/ 1/2 x)
(/ 1/2 x)
(/ 1/2 x)
(/ 1/2 x)
(* -1 x)
(* -1 (* x (+ 1 (* 1/2 (/ y (pow x 2))))))
(* -1 (* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (* 1/2 (/ y (pow x 2)))))))
(* -1 (* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (+ (* 1/16 (/ (pow y 3) (pow x 6))) (* 1/2 (/ y (pow x 2))))))))
(* -1 x)
(* -1 x)
(* -1 x)
(* -1 x)
(* -1 x)
(* -1 (* x (+ 1 (* 1/2 (/ y (pow x 2))))))
(* -1 (* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (* 1/2 (/ y (pow x 2)))))))
(* -1 (* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (+ (* 1/16 (/ (pow y 3) (pow x 6))) (* 1/2 (/ y (pow x 2))))))))
(* -1 x)
(* -1 (* x (+ 1 (* 1/2 (/ y (pow x 2))))))
(* -1 (* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (* 1/2 (/ y (pow x 2)))))))
(* -1 (* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (+ (* 1/16 (/ (pow y 3) (pow x 6))) (* 1/2 (/ y (pow x 2))))))))
(pow x 2)
(* (pow x 2) (+ 1 (/ y (pow x 2))))
(* (pow x 2) (+ 1 (/ y (pow x 2))))
(* (pow x 2) (+ 1 (/ y (pow x 2))))
(pow x 2)
(pow x 2)
(pow x 2)
(pow x 2)
(* -1 x)
(* -1 (* x (+ 1 (* 1/2 (/ y (pow x 2))))))
(* -1 (* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (* 1/2 (/ y (pow x 2)))))))
(* -1 (* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (+ (* 1/16 (/ (pow y 3) (pow x 6))) (* 1/2 (/ y (pow x 2))))))))
(pow x 2)
(* (pow x 2) (+ 1 (/ y (pow x 2))))
(* (pow x 2) (+ 1 (/ y (pow x 2))))
(* (pow x 2) (+ 1 (/ y (pow x 2))))
Outputs
x
(+ x (* 1/2 (/ y x)))
(fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x)
(+ x (* y (+ (* -1/8 (/ y (pow x 3))) (* 1/2 (/ 1 x)))))
(fma.f64 (fma.f64 (/.f64 y (pow.f64 x #s(literal 3 binary64))) #s(literal -1/8 binary64) (/.f64 #s(literal 1/2 binary64) x)) y x)
(+ x (* y (+ (* y (- (* 1/16 (/ y (pow x 5))) (* 1/8 (/ 1 (pow x 3))))) (* 1/2 (/ 1 x)))))
(fma.f64 (fma.f64 (fma.f64 (/.f64 y (pow.f64 x #s(literal 5 binary64))) #s(literal 1/16 binary64) (/.f64 #s(literal -1/8 binary64) (pow.f64 x #s(literal 3 binary64)))) y (/.f64 #s(literal 1/2 binary64) x)) y x)
x
(+ x (* 1/2 (/ y x)))
(fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x)
(+ x (* 1/2 (/ y x)))
(fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x)
(+ x (* 1/2 (/ y x)))
(fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x)
x
(+ x (* 1/2 (/ y x)))
(fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x)
(+ x (* y (+ (* -1/8 (/ y (pow x 3))) (* 1/2 (/ 1 x)))))
(fma.f64 (fma.f64 (/.f64 y (pow.f64 x #s(literal 3 binary64))) #s(literal -1/8 binary64) (/.f64 #s(literal 1/2 binary64) x)) y x)
(+ x (* y (+ (* y (- (* 1/16 (/ y (pow x 5))) (* 1/8 (/ 1 (pow x 3))))) (* 1/2 (/ 1 x)))))
(fma.f64 (fma.f64 (fma.f64 (/.f64 y (pow.f64 x #s(literal 5 binary64))) #s(literal 1/16 binary64) (/.f64 #s(literal -1/8 binary64) (pow.f64 x #s(literal 3 binary64)))) y (/.f64 #s(literal 1/2 binary64) x)) y x)
x
(+ x (* 1/2 (/ y x)))
(fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x)
(+ x (* y (+ (* -1/8 (/ y (pow x 3))) (* 1/2 (/ 1 x)))))
(fma.f64 (fma.f64 (/.f64 y (pow.f64 x #s(literal 3 binary64))) #s(literal -1/8 binary64) (/.f64 #s(literal 1/2 binary64) x)) y x)
(+ x (* y (+ (* y (- (* 1/16 (/ y (pow x 5))) (* 1/8 (/ 1 (pow x 3))))) (* 1/2 (/ 1 x)))))
(fma.f64 (fma.f64 (fma.f64 (/.f64 y (pow.f64 x #s(literal 5 binary64))) #s(literal 1/16 binary64) (/.f64 #s(literal -1/8 binary64) (pow.f64 x #s(literal 3 binary64)))) y (/.f64 #s(literal 1/2 binary64) x)) y x)
(sqrt y)
(sqrt.f64 y)
(sqrt y)
(sqrt.f64 y)
(sqrt y)
(sqrt.f64 y)
(sqrt y)
(sqrt.f64 y)
x
(+ x (* 1/2 (/ y x)))
(fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x)
(+ x (* y (+ (* -1/8 (/ y (pow x 3))) (* 1/2 (/ 1 x)))))
(fma.f64 (fma.f64 (/.f64 y (pow.f64 x #s(literal 3 binary64))) #s(literal -1/8 binary64) (/.f64 #s(literal 1/2 binary64) x)) y x)
(+ x (* y (+ (* y (- (* 1/16 (/ y (pow x 5))) (* 1/8 (/ 1 (pow x 3))))) (* 1/2 (/ 1 x)))))
(fma.f64 (fma.f64 (fma.f64 (/.f64 y (pow.f64 x #s(literal 5 binary64))) #s(literal 1/16 binary64) (/.f64 #s(literal -1/8 binary64) (pow.f64 x #s(literal 3 binary64)))) y (/.f64 #s(literal 1/2 binary64) x)) y x)
(pow x 2)
(*.f64 x x)
(+ y (pow x 2))
(fma.f64 x x y)
(+ y (pow x 2))
(fma.f64 x x y)
(+ y (pow x 2))
(fma.f64 x x y)
x
(+ x (* 1/2 (/ y x)))
(fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x)
(+ x (* y (+ (* -1/8 (/ y (pow x 3))) (* 1/2 (/ 1 x)))))
(fma.f64 (fma.f64 (/.f64 y (pow.f64 x #s(literal 3 binary64))) #s(literal -1/8 binary64) (/.f64 #s(literal 1/2 binary64) x)) y x)
(+ x (* y (+ (* y (- (* 1/16 (/ y (pow x 5))) (* 1/8 (/ 1 (pow x 3))))) (* 1/2 (/ 1 x)))))
(fma.f64 (fma.f64 (fma.f64 (/.f64 y (pow.f64 x #s(literal 5 binary64))) #s(literal 1/16 binary64) (/.f64 #s(literal -1/8 binary64) (pow.f64 x #s(literal 3 binary64)))) y (/.f64 #s(literal 1/2 binary64) x)) y x)
(pow x 2)
(*.f64 x x)
(+ y (pow x 2))
(fma.f64 x x y)
(+ y (pow x 2))
(fma.f64 x x y)
(+ y (pow x 2))
(fma.f64 x x y)
(sqrt y)
(sqrt.f64 y)
(* y (+ (sqrt (/ 1 y)) (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3)))))))
(*.f64 (fma.f64 (*.f64 (*.f64 x x) #s(literal 1/2 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 3 binary64)))) (sqrt.f64 (/.f64 #s(literal 1 binary64) y))) y)
(* y (+ (sqrt (/ 1 y)) (+ (* -1/8 (* (pow x 4) (sqrt (/ 1 (pow y 5))))) (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))))))
(*.f64 (fma.f64 (*.f64 (pow.f64 x #s(literal 4 binary64)) #s(literal -1/8 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 5 binary64)))) (fma.f64 (*.f64 (*.f64 x x) #s(literal 1/2 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 3 binary64)))) (sqrt.f64 (/.f64 #s(literal 1 binary64) y)))) y)
(* y (+ (sqrt (/ 1 y)) (+ (* -1/8 (* (pow x 4) (sqrt (/ 1 (pow y 5))))) (+ (* 1/16 (* (pow x 6) (sqrt (/ 1 (pow y 7))))) (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3)))))))))
(*.f64 (fma.f64 (*.f64 (pow.f64 x #s(literal 6 binary64)) #s(literal 1/16 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 7 binary64)))) (fma.f64 (*.f64 (pow.f64 x #s(literal 4 binary64)) #s(literal -1/8 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 5 binary64)))) (fma.f64 (*.f64 (*.f64 x x) #s(literal 1/2 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 3 binary64)))) (sqrt.f64 (/.f64 #s(literal 1 binary64) y))))) y)
(* 1/2 (/ y x))
(*.f64 (/.f64 #s(literal 1/2 binary64) x) y)
(* y (+ (* 1/2 (/ 1 x)) (/ x y)))
(fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x)
(* y (+ (* 1/2 (/ 1 x)) (/ x y)))
(fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x)
(* y (+ (* 1/2 (/ 1 x)) (/ x y)))
(fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x)
(sqrt y)
(sqrt.f64 y)
(* y (+ (sqrt (/ 1 y)) (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3)))))))
(*.f64 (fma.f64 (*.f64 (*.f64 x x) #s(literal 1/2 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 3 binary64)))) (sqrt.f64 (/.f64 #s(literal 1 binary64) y))) y)
(* y (+ (sqrt (/ 1 y)) (+ (* -1/8 (* (pow x 4) (sqrt (/ 1 (pow y 5))))) (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))))))
(*.f64 (fma.f64 (*.f64 (pow.f64 x #s(literal 4 binary64)) #s(literal -1/8 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 5 binary64)))) (fma.f64 (*.f64 (*.f64 x x) #s(literal 1/2 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 3 binary64)))) (sqrt.f64 (/.f64 #s(literal 1 binary64) y)))) y)
(* y (+ (sqrt (/ 1 y)) (+ (* -1/8 (* (pow x 4) (sqrt (/ 1 (pow y 5))))) (+ (* 1/16 (* (pow x 6) (sqrt (/ 1 (pow y 7))))) (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3)))))))))
(*.f64 (fma.f64 (*.f64 (pow.f64 x #s(literal 6 binary64)) #s(literal 1/16 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 7 binary64)))) (fma.f64 (*.f64 (pow.f64 x #s(literal 4 binary64)) #s(literal -1/8 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 5 binary64)))) (fma.f64 (*.f64 (*.f64 x x) #s(literal 1/2 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 3 binary64)))) (sqrt.f64 (/.f64 #s(literal 1 binary64) y))))) y)
(sqrt y)
(sqrt.f64 y)
(* y (+ (sqrt (/ 1 y)) (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3)))))))
(*.f64 (fma.f64 (*.f64 (*.f64 x x) #s(literal 1/2 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 3 binary64)))) (sqrt.f64 (/.f64 #s(literal 1 binary64) y))) y)
(* y (+ (sqrt (/ 1 y)) (+ (* -1/8 (* (pow x 4) (sqrt (/ 1 (pow y 5))))) (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))))))
(*.f64 (fma.f64 (*.f64 (pow.f64 x #s(literal 4 binary64)) #s(literal -1/8 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 5 binary64)))) (fma.f64 (*.f64 (*.f64 x x) #s(literal 1/2 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 3 binary64)))) (sqrt.f64 (/.f64 #s(literal 1 binary64) y)))) y)
(* y (+ (sqrt (/ 1 y)) (+ (* -1/8 (* (pow x 4) (sqrt (/ 1 (pow y 5))))) (+ (* 1/16 (* (pow x 6) (sqrt (/ 1 (pow y 7))))) (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3)))))))))
(*.f64 (fma.f64 (*.f64 (pow.f64 x #s(literal 6 binary64)) #s(literal 1/16 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 7 binary64)))) (fma.f64 (*.f64 (pow.f64 x #s(literal 4 binary64)) #s(literal -1/8 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 5 binary64)))) (fma.f64 (*.f64 (*.f64 x x) #s(literal 1/2 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 3 binary64)))) (sqrt.f64 (/.f64 #s(literal 1 binary64) y))))) y)
(sqrt y)
(sqrt.f64 y)
(sqrt y)
(sqrt.f64 y)
(sqrt y)
(sqrt.f64 y)
(sqrt y)
(sqrt.f64 y)
(sqrt y)
(sqrt.f64 y)
(* y (+ (sqrt (/ 1 y)) (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3)))))))
(*.f64 (fma.f64 (*.f64 (*.f64 x x) #s(literal 1/2 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 3 binary64)))) (sqrt.f64 (/.f64 #s(literal 1 binary64) y))) y)
(* y (+ (sqrt (/ 1 y)) (+ (* -1/8 (* (pow x 4) (sqrt (/ 1 (pow y 5))))) (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))))))
(*.f64 (fma.f64 (*.f64 (pow.f64 x #s(literal 4 binary64)) #s(literal -1/8 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 5 binary64)))) (fma.f64 (*.f64 (*.f64 x x) #s(literal 1/2 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 3 binary64)))) (sqrt.f64 (/.f64 #s(literal 1 binary64) y)))) y)
(* y (+ (sqrt (/ 1 y)) (+ (* -1/8 (* (pow x 4) (sqrt (/ 1 (pow y 5))))) (+ (* 1/16 (* (pow x 6) (sqrt (/ 1 (pow y 7))))) (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3)))))))))
(*.f64 (fma.f64 (*.f64 (pow.f64 x #s(literal 6 binary64)) #s(literal 1/16 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 7 binary64)))) (fma.f64 (*.f64 (pow.f64 x #s(literal 4 binary64)) #s(literal -1/8 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 5 binary64)))) (fma.f64 (*.f64 (*.f64 x x) #s(literal 1/2 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 3 binary64)))) (sqrt.f64 (/.f64 #s(literal 1 binary64) y))))) y)
y
(* y (+ 1 (/ (pow x 2) y)))
(fma.f64 x x y)
(* y (+ 1 (/ (pow x 2) y)))
(fma.f64 x x y)
(* y (+ 1 (/ (pow x 2) y)))
(fma.f64 x x y)
(sqrt y)
(sqrt.f64 y)
(* y (+ (sqrt (/ 1 y)) (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3)))))))
(*.f64 (fma.f64 (*.f64 (*.f64 x x) #s(literal 1/2 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 3 binary64)))) (sqrt.f64 (/.f64 #s(literal 1 binary64) y))) y)
(* y (+ (sqrt (/ 1 y)) (+ (* -1/8 (* (pow x 4) (sqrt (/ 1 (pow y 5))))) (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))))))
(*.f64 (fma.f64 (*.f64 (pow.f64 x #s(literal 4 binary64)) #s(literal -1/8 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 5 binary64)))) (fma.f64 (*.f64 (*.f64 x x) #s(literal 1/2 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 3 binary64)))) (sqrt.f64 (/.f64 #s(literal 1 binary64) y)))) y)
(* y (+ (sqrt (/ 1 y)) (+ (* -1/8 (* (pow x 4) (sqrt (/ 1 (pow y 5))))) (+ (* 1/16 (* (pow x 6) (sqrt (/ 1 (pow y 7))))) (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3)))))))))
(*.f64 (fma.f64 (*.f64 (pow.f64 x #s(literal 6 binary64)) #s(literal 1/16 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 7 binary64)))) (fma.f64 (*.f64 (pow.f64 x #s(literal 4 binary64)) #s(literal -1/8 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 5 binary64)))) (fma.f64 (*.f64 (*.f64 x x) #s(literal 1/2 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 3 binary64)))) (sqrt.f64 (/.f64 #s(literal 1 binary64) y))))) y)
y
(* y (+ 1 (/ (pow x 2) y)))
(fma.f64 x x y)
(* y (+ 1 (/ (pow x 2) y)))
(fma.f64 x x y)
(* y (+ 1 (/ (pow x 2) y)))
(fma.f64 x x y)
(* -1 (* (sqrt y) (pow (sqrt -1) 2)))
(sqrt.f64 y)
(* -1 (* y (+ (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* (sqrt (/ 1 y)) (pow (sqrt -1) 2)))))
(*.f64 (fma.f64 (*.f64 #s(literal -1/2 binary64) (*.f64 x x)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 3 binary64)))) (sqrt.f64 (/.f64 #s(literal 1 binary64) y))) y)
(* -1 (* y (+ (* -1/8 (* (/ (pow x 4) (pow (sqrt -1) 2)) (sqrt (/ 1 (pow y 5))))) (+ (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* (sqrt (/ 1 y)) (pow (sqrt -1) 2))))))
(*.f64 (fma.f64 (*.f64 #s(literal -1/2 binary64) (*.f64 x x)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 3 binary64)))) (fma.f64 (*.f64 (pow.f64 x #s(literal 4 binary64)) #s(literal -1/8 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 5 binary64)))) (sqrt.f64 (/.f64 #s(literal 1 binary64) y)))) y)
(* -1 (* y (+ (* -1/8 (* (/ (pow x 4) (pow (sqrt -1) 2)) (sqrt (/ 1 (pow y 5))))) (+ (* 1/16 (* (/ (pow x 6) (pow (sqrt -1) 4)) (sqrt (/ 1 (pow y 7))))) (+ (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* (sqrt (/ 1 y)) (pow (sqrt -1) 2)))))))
(*.f64 (fma.f64 #s(literal -1/16 binary64) (/.f64 (*.f64 (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 7 binary64)))) (pow.f64 x #s(literal 6 binary64))) (pow.f64 (sqrt.f64 #s(literal -1 binary64)) #s(literal 4 binary64))) (fma.f64 (*.f64 #s(literal -1/2 binary64) (*.f64 x x)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 3 binary64)))) (fma.f64 (*.f64 (pow.f64 x #s(literal 4 binary64)) #s(literal -1/8 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 5 binary64)))) (sqrt.f64 (/.f64 #s(literal 1 binary64) y))))) y)
(* 1/2 (/ y x))
(*.f64 (/.f64 #s(literal 1/2 binary64) x) y)
(* -1 (* y (- (* -1 (/ x y)) (* 1/2 (/ 1 x)))))
(fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x)
(* -1 (* y (- (* -1 (/ x y)) (* 1/2 (/ 1 x)))))
(fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x)
(* -1 (* y (- (* -1 (/ x y)) (* 1/2 (/ 1 x)))))
(fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x)
(* -1 (* (sqrt y) (pow (sqrt -1) 2)))
(sqrt.f64 y)
(* -1 (* y (+ (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* (sqrt (/ 1 y)) (pow (sqrt -1) 2)))))
(*.f64 (fma.f64 (*.f64 #s(literal -1/2 binary64) (*.f64 x x)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 3 binary64)))) (sqrt.f64 (/.f64 #s(literal 1 binary64) y))) y)
(* -1 (* y (+ (* -1/8 (* (/ (pow x 4) (pow (sqrt -1) 2)) (sqrt (/ 1 (pow y 5))))) (+ (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* (sqrt (/ 1 y)) (pow (sqrt -1) 2))))))
(*.f64 (fma.f64 (*.f64 #s(literal -1/2 binary64) (*.f64 x x)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 3 binary64)))) (fma.f64 (*.f64 (pow.f64 x #s(literal 4 binary64)) #s(literal -1/8 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 5 binary64)))) (sqrt.f64 (/.f64 #s(literal 1 binary64) y)))) y)
(* -1 (* y (+ (* -1/8 (* (/ (pow x 4) (pow (sqrt -1) 2)) (sqrt (/ 1 (pow y 5))))) (+ (* 1/16 (* (/ (pow x 6) (pow (sqrt -1) 4)) (sqrt (/ 1 (pow y 7))))) (+ (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* (sqrt (/ 1 y)) (pow (sqrt -1) 2)))))))
(*.f64 (fma.f64 #s(literal -1/16 binary64) (/.f64 (*.f64 (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 7 binary64)))) (pow.f64 x #s(literal 6 binary64))) (pow.f64 (sqrt.f64 #s(literal -1 binary64)) #s(literal 4 binary64))) (fma.f64 (*.f64 #s(literal -1/2 binary64) (*.f64 x x)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 3 binary64)))) (fma.f64 (*.f64 (pow.f64 x #s(literal 4 binary64)) #s(literal -1/8 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 5 binary64)))) (sqrt.f64 (/.f64 #s(literal 1 binary64) y))))) y)
(* -1 (* (sqrt y) (pow (sqrt -1) 2)))
(sqrt.f64 y)
(* -1 (* y (+ (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* (sqrt (/ 1 y)) (pow (sqrt -1) 2)))))
(*.f64 (fma.f64 (*.f64 #s(literal -1/2 binary64) (*.f64 x x)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 3 binary64)))) (sqrt.f64 (/.f64 #s(literal 1 binary64) y))) y)
(* -1 (* y (+ (* -1/8 (* (/ (pow x 4) (pow (sqrt -1) 2)) (sqrt (/ 1 (pow y 5))))) (+ (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* (sqrt (/ 1 y)) (pow (sqrt -1) 2))))))
(*.f64 (fma.f64 (*.f64 #s(literal -1/2 binary64) (*.f64 x x)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 3 binary64)))) (fma.f64 (*.f64 (pow.f64 x #s(literal 4 binary64)) #s(literal -1/8 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 5 binary64)))) (sqrt.f64 (/.f64 #s(literal 1 binary64) y)))) y)
(* -1 (* y (+ (* -1/8 (* (/ (pow x 4) (pow (sqrt -1) 2)) (sqrt (/ 1 (pow y 5))))) (+ (* 1/16 (* (/ (pow x 6) (pow (sqrt -1) 4)) (sqrt (/ 1 (pow y 7))))) (+ (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* (sqrt (/ 1 y)) (pow (sqrt -1) 2)))))))
(*.f64 (fma.f64 #s(literal -1/16 binary64) (/.f64 (*.f64 (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 7 binary64)))) (pow.f64 x #s(literal 6 binary64))) (pow.f64 (sqrt.f64 #s(literal -1 binary64)) #s(literal 4 binary64))) (fma.f64 (*.f64 #s(literal -1/2 binary64) (*.f64 x x)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 3 binary64)))) (fma.f64 (*.f64 (pow.f64 x #s(literal 4 binary64)) #s(literal -1/8 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 5 binary64)))) (sqrt.f64 (/.f64 #s(literal 1 binary64) y))))) y)
(* -1 (* (sqrt y) (pow (sqrt -1) 2)))
(sqrt.f64 y)
(* -1 (* (sqrt y) (pow (sqrt -1) 2)))
(sqrt.f64 y)
(* -1 (* (sqrt y) (pow (sqrt -1) 2)))
(sqrt.f64 y)
(* -1 (* (sqrt y) (pow (sqrt -1) 2)))
(sqrt.f64 y)
(* -1 (* (sqrt y) (pow (sqrt -1) 2)))
(sqrt.f64 y)
(* -1 (* y (+ (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* (sqrt (/ 1 y)) (pow (sqrt -1) 2)))))
(*.f64 (fma.f64 (*.f64 #s(literal -1/2 binary64) (*.f64 x x)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 3 binary64)))) (sqrt.f64 (/.f64 #s(literal 1 binary64) y))) y)
(* -1 (* y (+ (* -1/8 (* (/ (pow x 4) (pow (sqrt -1) 2)) (sqrt (/ 1 (pow y 5))))) (+ (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* (sqrt (/ 1 y)) (pow (sqrt -1) 2))))))
(*.f64 (fma.f64 (*.f64 #s(literal -1/2 binary64) (*.f64 x x)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 3 binary64)))) (fma.f64 (*.f64 (pow.f64 x #s(literal 4 binary64)) #s(literal -1/8 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 5 binary64)))) (sqrt.f64 (/.f64 #s(literal 1 binary64) y)))) y)
(* -1 (* y (+ (* -1/8 (* (/ (pow x 4) (pow (sqrt -1) 2)) (sqrt (/ 1 (pow y 5))))) (+ (* 1/16 (* (/ (pow x 6) (pow (sqrt -1) 4)) (sqrt (/ 1 (pow y 7))))) (+ (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* (sqrt (/ 1 y)) (pow (sqrt -1) 2)))))))
(*.f64 (fma.f64 #s(literal -1/16 binary64) (/.f64 (*.f64 (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 7 binary64)))) (pow.f64 x #s(literal 6 binary64))) (pow.f64 (sqrt.f64 #s(literal -1 binary64)) #s(literal 4 binary64))) (fma.f64 (*.f64 #s(literal -1/2 binary64) (*.f64 x x)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 3 binary64)))) (fma.f64 (*.f64 (pow.f64 x #s(literal 4 binary64)) #s(literal -1/8 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 5 binary64)))) (sqrt.f64 (/.f64 #s(literal 1 binary64) y))))) y)
y
(* -1 (* y (- (* -1 (/ (pow x 2) y)) 1)))
(fma.f64 x x y)
(* -1 (* y (- (* -1 (/ (pow x 2) y)) 1)))
(fma.f64 x x y)
(* -1 (* y (- (* -1 (/ (pow x 2) y)) 1)))
(fma.f64 x x y)
(* -1 (* (sqrt y) (pow (sqrt -1) 2)))
(sqrt.f64 y)
(* -1 (* y (+ (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* (sqrt (/ 1 y)) (pow (sqrt -1) 2)))))
(*.f64 (fma.f64 (*.f64 #s(literal -1/2 binary64) (*.f64 x x)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 3 binary64)))) (sqrt.f64 (/.f64 #s(literal 1 binary64) y))) y)
(* -1 (* y (+ (* -1/8 (* (/ (pow x 4) (pow (sqrt -1) 2)) (sqrt (/ 1 (pow y 5))))) (+ (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* (sqrt (/ 1 y)) (pow (sqrt -1) 2))))))
(*.f64 (fma.f64 (*.f64 #s(literal -1/2 binary64) (*.f64 x x)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 3 binary64)))) (fma.f64 (*.f64 (pow.f64 x #s(literal 4 binary64)) #s(literal -1/8 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 5 binary64)))) (sqrt.f64 (/.f64 #s(literal 1 binary64) y)))) y)
(* -1 (* y (+ (* -1/8 (* (/ (pow x 4) (pow (sqrt -1) 2)) (sqrt (/ 1 (pow y 5))))) (+ (* 1/16 (* (/ (pow x 6) (pow (sqrt -1) 4)) (sqrt (/ 1 (pow y 7))))) (+ (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* (sqrt (/ 1 y)) (pow (sqrt -1) 2)))))))
(*.f64 (fma.f64 #s(literal -1/16 binary64) (/.f64 (*.f64 (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 7 binary64)))) (pow.f64 x #s(literal 6 binary64))) (pow.f64 (sqrt.f64 #s(literal -1 binary64)) #s(literal 4 binary64))) (fma.f64 (*.f64 #s(literal -1/2 binary64) (*.f64 x x)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 3 binary64)))) (fma.f64 (*.f64 (pow.f64 x #s(literal 4 binary64)) #s(literal -1/8 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 5 binary64)))) (sqrt.f64 (/.f64 #s(literal 1 binary64) y))))) y)
y
(* -1 (* y (- (* -1 (/ (pow x 2) y)) 1)))
(fma.f64 x x y)
(* -1 (* y (- (* -1 (/ (pow x 2) y)) 1)))
(fma.f64 x x y)
(* -1 (* y (- (* -1 (/ (pow x 2) y)) 1)))
(fma.f64 x x y)
(sqrt y)
(sqrt.f64 y)
(+ (sqrt y) (* 1/2 (* (pow x 2) (sqrt (/ 1 y)))))
(fma.f64 (*.f64 (*.f64 x x) #s(literal 1/2 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) y)) (sqrt.f64 y))
(+ (sqrt y) (* (pow x 2) (+ (* -1/8 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* 1/2 (sqrt (/ 1 y))))))
(fma.f64 (*.f64 (*.f64 x x) #s(literal 1/2 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) y)) (fma.f64 (*.f64 (pow.f64 x #s(literal 4 binary64)) #s(literal -1/8 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 3 binary64)))) (sqrt.f64 y)))
(+ (sqrt y) (* (pow x 2) (+ (* 1/2 (sqrt (/ 1 y))) (* (pow x 2) (+ (* -1/8 (sqrt (/ 1 (pow y 3)))) (* 1/16 (* (pow x 2) (sqrt (/ 1 (pow y 5))))))))))
(fma.f64 (fma.f64 (*.f64 (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 5 binary64)))) (*.f64 #s(literal 1/16 binary64) x)) x (*.f64 (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 3 binary64)))) #s(literal -1/8 binary64))) (pow.f64 x #s(literal 4 binary64)) (fma.f64 (*.f64 (*.f64 x x) #s(literal 1/2 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) y)) (sqrt.f64 y)))
(* 1/2 (/ y x))
(*.f64 (/.f64 #s(literal 1/2 binary64) x) y)
(/ (+ (* 1/2 y) (pow x 2)) x)
(/.f64 (fma.f64 y #s(literal 1/2 binary64) (*.f64 x x)) x)
(/ (+ (* 1/2 y) (pow x 2)) x)
(/.f64 (fma.f64 y #s(literal 1/2 binary64) (*.f64 x x)) x)
(/ (+ (* 1/2 y) (pow x 2)) x)
(/.f64 (fma.f64 y #s(literal 1/2 binary64) (*.f64 x x)) x)
(/ 1/2 x)
(/.f64 #s(literal 1/2 binary64) x)
(/ 1/2 x)
(/.f64 #s(literal 1/2 binary64) x)
(/ 1/2 x)
(/.f64 #s(literal 1/2 binary64) x)
(/ 1/2 x)
(/.f64 #s(literal 1/2 binary64) x)
(sqrt y)
(sqrt.f64 y)
(+ (sqrt y) (* 1/2 (* (pow x 2) (sqrt (/ 1 y)))))
(fma.f64 (*.f64 (*.f64 x x) #s(literal 1/2 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) y)) (sqrt.f64 y))
(+ (sqrt y) (* (pow x 2) (+ (* -1/8 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* 1/2 (sqrt (/ 1 y))))))
(fma.f64 (*.f64 (*.f64 x x) #s(literal 1/2 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) y)) (fma.f64 (*.f64 (pow.f64 x #s(literal 4 binary64)) #s(literal -1/8 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 3 binary64)))) (sqrt.f64 y)))
(+ (sqrt y) (* (pow x 2) (+ (* 1/2 (sqrt (/ 1 y))) (* (pow x 2) (+ (* -1/8 (sqrt (/ 1 (pow y 3)))) (* 1/16 (* (pow x 2) (sqrt (/ 1 (pow y 5))))))))))
(fma.f64 (fma.f64 (*.f64 (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 5 binary64)))) (*.f64 #s(literal 1/16 binary64) x)) x (*.f64 (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 3 binary64)))) #s(literal -1/8 binary64))) (pow.f64 x #s(literal 4 binary64)) (fma.f64 (*.f64 (*.f64 x x) #s(literal 1/2 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) y)) (sqrt.f64 y)))
(* -1 x)
(neg.f64 x)
(* -1 x)
(neg.f64 x)
(* -1 x)
(neg.f64 x)
(* -1 x)
(neg.f64 x)
(sqrt y)
(sqrt.f64 y)
(+ (sqrt y) (* 1/2 (* (pow x 2) (sqrt (/ 1 y)))))
(fma.f64 (*.f64 (*.f64 x x) #s(literal 1/2 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) y)) (sqrt.f64 y))
(+ (sqrt y) (* (pow x 2) (+ (* -1/8 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* 1/2 (sqrt (/ 1 y))))))
(fma.f64 (*.f64 (*.f64 x x) #s(literal 1/2 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) y)) (fma.f64 (*.f64 (pow.f64 x #s(literal 4 binary64)) #s(literal -1/8 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 3 binary64)))) (sqrt.f64 y)))
(+ (sqrt y) (* (pow x 2) (+ (* 1/2 (sqrt (/ 1 y))) (* (pow x 2) (+ (* -1/8 (sqrt (/ 1 (pow y 3)))) (* 1/16 (* (pow x 2) (sqrt (/ 1 (pow y 5))))))))))
(fma.f64 (fma.f64 (*.f64 (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 5 binary64)))) (*.f64 #s(literal 1/16 binary64) x)) x (*.f64 (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 3 binary64)))) #s(literal -1/8 binary64))) (pow.f64 x #s(literal 4 binary64)) (fma.f64 (*.f64 (*.f64 x x) #s(literal 1/2 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) y)) (sqrt.f64 y)))
(sqrt y)
(sqrt.f64 y)
(+ (sqrt y) (* 1/2 (* (pow x 2) (sqrt (/ 1 y)))))
(fma.f64 (*.f64 (*.f64 x x) #s(literal 1/2 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) y)) (sqrt.f64 y))
(+ (sqrt y) (* (pow x 2) (+ (* -1/8 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* 1/2 (sqrt (/ 1 y))))))
(fma.f64 (*.f64 (*.f64 x x) #s(literal 1/2 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) y)) (fma.f64 (*.f64 (pow.f64 x #s(literal 4 binary64)) #s(literal -1/8 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 3 binary64)))) (sqrt.f64 y)))
(+ (sqrt y) (* (pow x 2) (+ (* 1/2 (sqrt (/ 1 y))) (* (pow x 2) (+ (* -1/8 (sqrt (/ 1 (pow y 3)))) (* 1/16 (* (pow x 2) (sqrt (/ 1 (pow y 5))))))))))
(fma.f64 (fma.f64 (*.f64 (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 5 binary64)))) (*.f64 #s(literal 1/16 binary64) x)) x (*.f64 (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 3 binary64)))) #s(literal -1/8 binary64))) (pow.f64 x #s(literal 4 binary64)) (fma.f64 (*.f64 (*.f64 x x) #s(literal 1/2 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) y)) (sqrt.f64 y)))
y
(+ y (pow x 2))
(fma.f64 x x y)
(+ y (pow x 2))
(fma.f64 x x y)
(+ y (pow x 2))
(fma.f64 x x y)
(pow x 2)
(*.f64 x x)
(pow x 2)
(*.f64 x x)
(pow x 2)
(*.f64 x x)
(pow x 2)
(*.f64 x x)
(sqrt y)
(sqrt.f64 y)
(+ (sqrt y) (* 1/2 (* (pow x 2) (sqrt (/ 1 y)))))
(fma.f64 (*.f64 (*.f64 x x) #s(literal 1/2 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) y)) (sqrt.f64 y))
(+ (sqrt y) (* (pow x 2) (+ (* -1/8 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* 1/2 (sqrt (/ 1 y))))))
(fma.f64 (*.f64 (*.f64 x x) #s(literal 1/2 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) y)) (fma.f64 (*.f64 (pow.f64 x #s(literal 4 binary64)) #s(literal -1/8 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 3 binary64)))) (sqrt.f64 y)))
(+ (sqrt y) (* (pow x 2) (+ (* 1/2 (sqrt (/ 1 y))) (* (pow x 2) (+ (* -1/8 (sqrt (/ 1 (pow y 3)))) (* 1/16 (* (pow x 2) (sqrt (/ 1 (pow y 5))))))))))
(fma.f64 (fma.f64 (*.f64 (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 5 binary64)))) (*.f64 #s(literal 1/16 binary64) x)) x (*.f64 (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 3 binary64)))) #s(literal -1/8 binary64))) (pow.f64 x #s(literal 4 binary64)) (fma.f64 (*.f64 (*.f64 x x) #s(literal 1/2 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) y)) (sqrt.f64 y)))
y
(+ y (pow x 2))
(fma.f64 x x y)
(+ y (pow x 2))
(fma.f64 x x y)
(+ y (pow x 2))
(fma.f64 x x y)
x
(* x (+ 1 (* 1/2 (/ y (pow x 2)))))
(fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x)
(* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (* 1/2 (/ y (pow x 2))))))
(fma.f64 (*.f64 #s(literal -1/8 binary64) x) (*.f64 (/.f64 y (pow.f64 x #s(literal 4 binary64))) y) (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x))
(* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (+ (* 1/16 (/ (pow y 3) (pow x 6))) (* 1/2 (/ y (pow x 2)))))))
(fma.f64 (fma.f64 (*.f64 y y) (fma.f64 (/.f64 y (pow.f64 x #s(literal 6 binary64))) #s(literal 1/16 binary64) (/.f64 #s(literal -1/8 binary64) (pow.f64 x #s(literal 4 binary64)))) #s(literal 1 binary64)) x (*.f64 (/.f64 #s(literal 1/2 binary64) x) y))
x
(* x (+ 1 (* 1/2 (/ y (pow x 2)))))
(fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x)
(* x (+ 1 (* 1/2 (/ y (pow x 2)))))
(fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x)
(* x (+ 1 (* 1/2 (/ y (pow x 2)))))
(fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x)
(/ 1/2 x)
(/.f64 #s(literal 1/2 binary64) x)
(/ 1/2 x)
(/.f64 #s(literal 1/2 binary64) x)
(/ 1/2 x)
(/.f64 #s(literal 1/2 binary64) x)
(/ 1/2 x)
(/.f64 #s(literal 1/2 binary64) x)
x
(* x (+ 1 (* 1/2 (/ y (pow x 2)))))
(fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x)
(* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (* 1/2 (/ y (pow x 2))))))
(fma.f64 (*.f64 #s(literal -1/8 binary64) x) (*.f64 (/.f64 y (pow.f64 x #s(literal 4 binary64))) y) (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x))
(* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (+ (* 1/16 (/ (pow y 3) (pow x 6))) (* 1/2 (/ y (pow x 2)))))))
(fma.f64 (fma.f64 (*.f64 y y) (fma.f64 (/.f64 y (pow.f64 x #s(literal 6 binary64))) #s(literal 1/16 binary64) (/.f64 #s(literal -1/8 binary64) (pow.f64 x #s(literal 4 binary64)))) #s(literal 1 binary64)) x (*.f64 (/.f64 #s(literal 1/2 binary64) x) y))
(* -1 x)
(neg.f64 x)
(* -1 x)
(neg.f64 x)
(* -1 x)
(neg.f64 x)
(* -1 x)
(neg.f64 x)
x
(* x (+ 1 (* 1/2 (/ y (pow x 2)))))
(fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x)
(* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (* 1/2 (/ y (pow x 2))))))
(fma.f64 (*.f64 #s(literal -1/8 binary64) x) (*.f64 (/.f64 y (pow.f64 x #s(literal 4 binary64))) y) (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x))
(* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (+ (* 1/16 (/ (pow y 3) (pow x 6))) (* 1/2 (/ y (pow x 2)))))))
(fma.f64 (fma.f64 (*.f64 y y) (fma.f64 (/.f64 y (pow.f64 x #s(literal 6 binary64))) #s(literal 1/16 binary64) (/.f64 #s(literal -1/8 binary64) (pow.f64 x #s(literal 4 binary64)))) #s(literal 1 binary64)) x (*.f64 (/.f64 #s(literal 1/2 binary64) x) y))
x
(* x (+ 1 (* 1/2 (/ y (pow x 2)))))
(fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x)
(* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (* 1/2 (/ y (pow x 2))))))
(fma.f64 (*.f64 #s(literal -1/8 binary64) x) (*.f64 (/.f64 y (pow.f64 x #s(literal 4 binary64))) y) (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x))
(* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (+ (* 1/16 (/ (pow y 3) (pow x 6))) (* 1/2 (/ y (pow x 2)))))))
(fma.f64 (fma.f64 (*.f64 y y) (fma.f64 (/.f64 y (pow.f64 x #s(literal 6 binary64))) #s(literal 1/16 binary64) (/.f64 #s(literal -1/8 binary64) (pow.f64 x #s(literal 4 binary64)))) #s(literal 1 binary64)) x (*.f64 (/.f64 #s(literal 1/2 binary64) x) y))
(pow x 2)
(*.f64 x x)
(* (pow x 2) (+ 1 (/ y (pow x 2))))
(fma.f64 x x y)
(* (pow x 2) (+ 1 (/ y (pow x 2))))
(fma.f64 x x y)
(* (pow x 2) (+ 1 (/ y (pow x 2))))
(fma.f64 x x y)
(pow x 2)
(*.f64 x x)
(pow x 2)
(*.f64 x x)
(pow x 2)
(*.f64 x x)
(pow x 2)
(*.f64 x x)
x
(* x (+ 1 (* 1/2 (/ y (pow x 2)))))
(fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x)
(* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (* 1/2 (/ y (pow x 2))))))
(fma.f64 (*.f64 #s(literal -1/8 binary64) x) (*.f64 (/.f64 y (pow.f64 x #s(literal 4 binary64))) y) (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x))
(* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (+ (* 1/16 (/ (pow y 3) (pow x 6))) (* 1/2 (/ y (pow x 2)))))))
(fma.f64 (fma.f64 (*.f64 y y) (fma.f64 (/.f64 y (pow.f64 x #s(literal 6 binary64))) #s(literal 1/16 binary64) (/.f64 #s(literal -1/8 binary64) (pow.f64 x #s(literal 4 binary64)))) #s(literal 1 binary64)) x (*.f64 (/.f64 #s(literal 1/2 binary64) x) y))
(pow x 2)
(*.f64 x x)
(* (pow x 2) (+ 1 (/ y (pow x 2))))
(fma.f64 x x y)
(* (pow x 2) (+ 1 (/ y (pow x 2))))
(fma.f64 x x y)
(* (pow x 2) (+ 1 (/ y (pow x 2))))
(fma.f64 x x y)
(* -1 x)
(neg.f64 x)
(* -1 (* x (+ 1 (* 1/2 (/ y (pow x 2))))))
(fma.f64 #s(literal -1/2 binary64) (/.f64 y x) (neg.f64 x))
(* -1 (* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (* 1/2 (/ y (pow x 2)))))))
(fma.f64 (fma.f64 (*.f64 #s(literal 1/8 binary64) y) (/.f64 y (pow.f64 x #s(literal 4 binary64))) #s(literal -1 binary64)) x (*.f64 (/.f64 #s(literal -1/2 binary64) x) y))
(* -1 (* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (+ (* 1/16 (/ (pow y 3) (pow x 6))) (* 1/2 (/ y (pow x 2))))))))
(fma.f64 (fma.f64 (*.f64 y y) (fma.f64 (/.f64 y (pow.f64 x #s(literal 6 binary64))) #s(literal 1/16 binary64) (/.f64 #s(literal -1/8 binary64) (pow.f64 x #s(literal 4 binary64)))) #s(literal 1 binary64)) (neg.f64 x) (*.f64 (/.f64 #s(literal -1/2 binary64) x) y))
x
(* -1 (* x (- (* -1/2 (/ y (pow x 2))) 1)))
(fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x)
(* -1 (* x (- (* -1/2 (/ y (pow x 2))) 1)))
(fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x)
(* -1 (* x (- (* -1/2 (/ y (pow x 2))) 1)))
(fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x)
(/ 1/2 x)
(/.f64 #s(literal 1/2 binary64) x)
(/ 1/2 x)
(/.f64 #s(literal 1/2 binary64) x)
(/ 1/2 x)
(/.f64 #s(literal 1/2 binary64) x)
(/ 1/2 x)
(/.f64 #s(literal 1/2 binary64) x)
(* -1 x)
(neg.f64 x)
(* -1 (* x (+ 1 (* 1/2 (/ y (pow x 2))))))
(fma.f64 #s(literal -1/2 binary64) (/.f64 y x) (neg.f64 x))
(* -1 (* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (* 1/2 (/ y (pow x 2)))))))
(fma.f64 (fma.f64 (*.f64 #s(literal 1/8 binary64) y) (/.f64 y (pow.f64 x #s(literal 4 binary64))) #s(literal -1 binary64)) x (*.f64 (/.f64 #s(literal -1/2 binary64) x) y))
(* -1 (* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (+ (* 1/16 (/ (pow y 3) (pow x 6))) (* 1/2 (/ y (pow x 2))))))))
(fma.f64 (fma.f64 (*.f64 y y) (fma.f64 (/.f64 y (pow.f64 x #s(literal 6 binary64))) #s(literal 1/16 binary64) (/.f64 #s(literal -1/8 binary64) (pow.f64 x #s(literal 4 binary64)))) #s(literal 1 binary64)) (neg.f64 x) (*.f64 (/.f64 #s(literal -1/2 binary64) x) y))
(* -1 x)
(neg.f64 x)
(* -1 x)
(neg.f64 x)
(* -1 x)
(neg.f64 x)
(* -1 x)
(neg.f64 x)
(* -1 x)
(neg.f64 x)
(* -1 (* x (+ 1 (* 1/2 (/ y (pow x 2))))))
(fma.f64 #s(literal -1/2 binary64) (/.f64 y x) (neg.f64 x))
(* -1 (* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (* 1/2 (/ y (pow x 2)))))))
(fma.f64 (fma.f64 (*.f64 #s(literal 1/8 binary64) y) (/.f64 y (pow.f64 x #s(literal 4 binary64))) #s(literal -1 binary64)) x (*.f64 (/.f64 #s(literal -1/2 binary64) x) y))
(* -1 (* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (+ (* 1/16 (/ (pow y 3) (pow x 6))) (* 1/2 (/ y (pow x 2))))))))
(fma.f64 (fma.f64 (*.f64 y y) (fma.f64 (/.f64 y (pow.f64 x #s(literal 6 binary64))) #s(literal 1/16 binary64) (/.f64 #s(literal -1/8 binary64) (pow.f64 x #s(literal 4 binary64)))) #s(literal 1 binary64)) (neg.f64 x) (*.f64 (/.f64 #s(literal -1/2 binary64) x) y))
(* -1 x)
(neg.f64 x)
(* -1 (* x (+ 1 (* 1/2 (/ y (pow x 2))))))
(fma.f64 #s(literal -1/2 binary64) (/.f64 y x) (neg.f64 x))
(* -1 (* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (* 1/2 (/ y (pow x 2)))))))
(fma.f64 (fma.f64 (*.f64 #s(literal 1/8 binary64) y) (/.f64 y (pow.f64 x #s(literal 4 binary64))) #s(literal -1 binary64)) x (*.f64 (/.f64 #s(literal -1/2 binary64) x) y))
(* -1 (* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (+ (* 1/16 (/ (pow y 3) (pow x 6))) (* 1/2 (/ y (pow x 2))))))))
(fma.f64 (fma.f64 (*.f64 y y) (fma.f64 (/.f64 y (pow.f64 x #s(literal 6 binary64))) #s(literal 1/16 binary64) (/.f64 #s(literal -1/8 binary64) (pow.f64 x #s(literal 4 binary64)))) #s(literal 1 binary64)) (neg.f64 x) (*.f64 (/.f64 #s(literal -1/2 binary64) x) y))
(pow x 2)
(*.f64 x x)
(* (pow x 2) (+ 1 (/ y (pow x 2))))
(fma.f64 x x y)
(* (pow x 2) (+ 1 (/ y (pow x 2))))
(fma.f64 x x y)
(* (pow x 2) (+ 1 (/ y (pow x 2))))
(fma.f64 x x y)
(pow x 2)
(*.f64 x x)
(pow x 2)
(*.f64 x x)
(pow x 2)
(*.f64 x x)
(pow x 2)
(*.f64 x x)
(* -1 x)
(neg.f64 x)
(* -1 (* x (+ 1 (* 1/2 (/ y (pow x 2))))))
(fma.f64 #s(literal -1/2 binary64) (/.f64 y x) (neg.f64 x))
(* -1 (* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (* 1/2 (/ y (pow x 2)))))))
(fma.f64 (fma.f64 (*.f64 #s(literal 1/8 binary64) y) (/.f64 y (pow.f64 x #s(literal 4 binary64))) #s(literal -1 binary64)) x (*.f64 (/.f64 #s(literal -1/2 binary64) x) y))
(* -1 (* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (+ (* 1/16 (/ (pow y 3) (pow x 6))) (* 1/2 (/ y (pow x 2))))))))
(fma.f64 (fma.f64 (*.f64 y y) (fma.f64 (/.f64 y (pow.f64 x #s(literal 6 binary64))) #s(literal 1/16 binary64) (/.f64 #s(literal -1/8 binary64) (pow.f64 x #s(literal 4 binary64)))) #s(literal 1 binary64)) (neg.f64 x) (*.f64 (/.f64 #s(literal -1/2 binary64) x) y))
(pow x 2)
(*.f64 x x)
(* (pow x 2) (+ 1 (/ y (pow x 2))))
(fma.f64 x x y)
(* (pow x 2) (+ 1 (/ y (pow x 2))))
(fma.f64 x x y)
(* (pow x 2) (+ 1 (/ y (pow x 2))))
(fma.f64 x x y)

rewrite193.0ms (4.2%)

Memory
-15.1MiB live, 281.8MiB allocated
Rules
5 804×lower-fma.f32
5 800×lower-fma.f64
4 018×lower-*.f32
4 016×lower-*.f64
1 916×lower-/.f32
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01870
02770
17370
240870
3449770
0836470
Stop Event
iter limit
node limit
iter limit
Counts
12 → 282
Calls
Call 1
Inputs
#s(approx (sqrt (+ (* x x) y)) (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x))
(fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x)
(/.f64 #s(literal 1/2 binary64) x)
#s(approx (sqrt (+ (* x x) y)) (neg.f64 x))
(neg.f64 x)
#s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y))
(sqrt.f64 y)
(sqrt.f64 #s(approx (+ (* x x) y) (*.f64 x x)))
#s(approx (+ (* x x) y) (*.f64 x x))
(*.f64 x x)
(sqrt.f64 (fma.f64 x x y))
(fma.f64 x x y)
Outputs
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>

eval109.0ms (2.4%)

Memory
1.0MiB live, 119.0MiB allocated
Compiler

Compiled 7 683 to 1 037 computations (86.5% saved)

prune26.0ms (0.6%)

Memory
4.2MiB live, 42.7MiB allocated
Pruning

6 alts after pruning (1 fresh and 5 done)

PrunedKeptTotal
New5030503
Fresh011
Picked055
Done000
Total5036509
Accuracy
100.0%
Counts
509 → 6
Alt Table
Click to see full alt table
StatusAccuracyProgram
66.6%
(/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y))))
66.8%
(sqrt.f64 (fma.f64 x x y))
35.1%
(sqrt.f64 #s(approx (+ (* x x) y) (*.f64 x x)))
69.1%
#s(approx (sqrt (+ (* x x) y)) (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x))
34.2%
#s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y))
1.1%
#s(approx (sqrt (+ (* x x) y)) (neg.f64 x))
Compiler

Compiled 32 to 30 computations (6.3% saved)

simplify4.0ms (0.1%)

Memory
7.2MiB live, 7.2MiB allocated
Algorithm
egg-herbie
Localize:

Found 4 expressions of interest:

NewMetricScoreProgram
cost-diff0
(fma.f64 x x y)
cost-diff0
(sqrt.f64 (fma.f64 x x y))
cost-diff0
(/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y)))
cost-diff1408
(/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y))))
Rules
10×lower-*.f64
10×lower-*.f32
lower-/.f32
*-commutative
lift-/.f64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0728
01224
11724
22024
32224
42324
02324
Stop Event
iter limit
saturated
iter limit
Calls
Call 1
Inputs
(/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y))))
#s(literal 1 binary64)
(/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y)))
(sqrt.f64 (fma.f64 x x y))
(fma.f64 x x y)
x
y
Outputs
(/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y))))
(sqrt.f64 (fma.f64 x x y))
#s(literal 1 binary64)
(/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y)))
(sqrt.f64 (fma.f64 x x y))
(fma.f64 x x y)
x
y

localize23.0ms (0.5%)

Memory
6.0MiB live, 43.7MiB allocated
Localize:

Found 4 expressions of interest:

NewMetricScoreProgram
accuracy0
(fma.f64 x x y)
accuracy0.125
(/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y)))
accuracy0.25390625
(/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y))))
accuracy21.258855872636012
(sqrt.f64 (fma.f64 x x y))
Samples
18.0ms256×0valid
Compiler

Compiled 34 to 10 computations (70.6% saved)

Precisions
Click to see histograms. Total time spent on operations: 11.0ms
ival-sqrt: 4.0ms (36.2% of total)
ival-div: 3.0ms (27.1% of total)
ival-mult: 2.0ms (18.1% of total)
ival-add: 1.0ms (9% of total)
ival-true: 0.0ms (0% of total)
exact: 0.0ms (0% of total)
ival-assert: 0.0ms (0% of total)

series53.0ms (1.2%)

Memory
-26.3MiB live, 12.1MiB allocated
Counts
4 → 96
Calls
Call 1
Inputs
#s(alt (/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y)))) (patch (/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y)))) #<representation binary64>) () ())
#s(alt (/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y))) (patch (/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y))) #<representation binary64>) () ())
#s(alt (sqrt.f64 (fma.f64 x x y)) (patch (sqrt.f64 (fma.f64 x x y)) #<representation binary64>) () ())
#s(alt (fma.f64 x x y) (patch (fma.f64 x x y) #<representation binary64>) () ())
Outputs
#s(alt x (taylor 0 y) (#s(alt (/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y)))) (patch (/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y)))) #<representation binary64>) () ())) ())
#s(alt (+ x (* 1/2 (/ y x))) (taylor 0 y) (#s(alt (/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y)))) (patch (/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y)))) #<representation binary64>) () ())) ())
#s(alt (+ x (* y (+ (* -1/8 (/ y (pow x 3))) (* 1/2 (/ 1 x))))) (taylor 0 y) (#s(alt (/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y)))) (patch (/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y)))) #<representation binary64>) () ())) ())
#s(alt (+ x (* y (+ (* y (- (* 1/16 (/ y (pow x 5))) (* 1/8 (/ 1 (pow x 3))))) (* 1/2 (/ 1 x))))) (taylor 0 y) (#s(alt (/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y)))) (patch (/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y)))) #<representation binary64>) () ())) ())
#s(alt (/ 1 x) (taylor 0 y) (#s(alt (/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y))) (patch (/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y))) #<representation binary64>) () ())) ())
#s(alt (+ (* -1/2 (/ y (pow x 3))) (/ 1 x)) (taylor 0 y) (#s(alt (/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y))) (patch (/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y))) #<representation binary64>) () ())) ())
#s(alt (+ (* y (- (* 3/8 (/ y (pow x 5))) (* 1/2 (/ 1 (pow x 3))))) (/ 1 x)) (taylor 0 y) (#s(alt (/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y))) (patch (/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y))) #<representation binary64>) () ())) ())
#s(alt (+ (* y (- (* y (+ (* -5/16 (/ y (pow x 7))) (* 3/8 (/ 1 (pow x 5))))) (* 1/2 (/ 1 (pow x 3))))) (/ 1 x)) (taylor 0 y) (#s(alt (/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y))) (patch (/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y))) #<representation binary64>) () ())) ())
#s(alt x (taylor 0 y) (#s(alt (sqrt.f64 (fma.f64 x x y)) (patch (sqrt.f64 (fma.f64 x x y)) #<representation binary64>) () ())) ())
#s(alt (+ x (* 1/2 (/ y x))) (taylor 0 y) (#s(alt (sqrt.f64 (fma.f64 x x y)) (patch (sqrt.f64 (fma.f64 x x y)) #<representation binary64>) () ())) ())
#s(alt (+ x (* y (+ (* -1/8 (/ y (pow x 3))) (* 1/2 (/ 1 x))))) (taylor 0 y) (#s(alt (sqrt.f64 (fma.f64 x x y)) (patch (sqrt.f64 (fma.f64 x x y)) #<representation binary64>) () ())) ())
#s(alt (+ x (* y (+ (* y (- (* 1/16 (/ y (pow x 5))) (* 1/8 (/ 1 (pow x 3))))) (* 1/2 (/ 1 x))))) (taylor 0 y) (#s(alt (sqrt.f64 (fma.f64 x x y)) (patch (sqrt.f64 (fma.f64 x x y)) #<representation binary64>) () ())) ())
#s(alt (pow x 2) (taylor 0 y) (#s(alt (fma.f64 x x y) (patch (fma.f64 x x y) #<representation binary64>) () ())) ())
#s(alt (+ y (pow x 2)) (taylor 0 y) (#s(alt (fma.f64 x x y) (patch (fma.f64 x x y) #<representation binary64>) () ())) ())
#s(alt (+ y (pow x 2)) (taylor 0 y) (#s(alt (fma.f64 x x y) (patch (fma.f64 x x y) #<representation binary64>) () ())) ())
#s(alt (+ y (pow x 2)) (taylor 0 y) (#s(alt (fma.f64 x x y) (patch (fma.f64 x x y) #<representation binary64>) () ())) ())
#s(alt (sqrt y) (taylor inf y) (#s(alt (/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y)))) (patch (/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y)))) #<representation binary64>) () ())) ())
#s(alt (* y (+ (sqrt (/ 1 y)) (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))))) (taylor inf y) (#s(alt (/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y)))) (patch (/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y)))) #<representation binary64>) () ())) ())
#s(alt (* y (+ (sqrt (/ 1 y)) (+ (* -1/8 (* (pow x 4) (sqrt (/ 1 (pow y 5))))) (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3)))))))) (taylor inf y) (#s(alt (/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y)))) (patch (/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y)))) #<representation binary64>) () ())) ())
#s(alt (* y (+ (sqrt (/ 1 y)) (+ (* -1/8 (* (pow x 4) (sqrt (/ 1 (pow y 5))))) (+ (* 1/16 (* (pow x 6) (sqrt (/ 1 (pow y 7))))) (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))))))) (taylor inf y) (#s(alt (/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y)))) (patch (/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y)))) #<representation binary64>) () ())) ())
#s(alt (sqrt (/ 1 y)) (taylor inf y) (#s(alt (/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y))) (patch (/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y))) #<representation binary64>) () ())) ())
#s(alt (+ (sqrt (/ 1 y)) (* -1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3)))))) (taylor inf y) (#s(alt (/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y))) (patch (/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y))) #<representation binary64>) () ())) ())
#s(alt (+ (sqrt (/ 1 y)) (+ (* -1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* 1/2 (* (pow x 4) (sqrt (/ 1 (pow y 5))))))) (taylor inf y) (#s(alt (/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y))) (patch (/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y))) #<representation binary64>) () ())) ())
#s(alt (+ (sqrt (/ 1 y)) (+ (* -1/2 (* (sqrt (/ 1 (pow y 7))) (+ (* 1/4 (* (pow x 4) y)) (pow x 6)))) (+ (* -1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* 1/2 (* (pow x 4) (sqrt (/ 1 (pow y 5)))))))) (taylor inf y) (#s(alt (/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y))) (patch (/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y))) #<representation binary64>) () ())) ())
#s(alt (sqrt y) (taylor inf y) (#s(alt (sqrt.f64 (fma.f64 x x y)) (patch (sqrt.f64 (fma.f64 x x y)) #<representation binary64>) () ())) ())
#s(alt (* y (+ (sqrt (/ 1 y)) (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))))) (taylor inf y) (#s(alt (sqrt.f64 (fma.f64 x x y)) (patch (sqrt.f64 (fma.f64 x x y)) #<representation binary64>) () ())) ())
#s(alt (* y (+ (sqrt (/ 1 y)) (+ (* -1/8 (* (pow x 4) (sqrt (/ 1 (pow y 5))))) (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3)))))))) (taylor inf y) (#s(alt (sqrt.f64 (fma.f64 x x y)) (patch (sqrt.f64 (fma.f64 x x y)) #<representation binary64>) () ())) ())
#s(alt (* y (+ (sqrt (/ 1 y)) (+ (* -1/8 (* (pow x 4) (sqrt (/ 1 (pow y 5))))) (+ (* 1/16 (* (pow x 6) (sqrt (/ 1 (pow y 7))))) (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))))))) (taylor inf y) (#s(alt (sqrt.f64 (fma.f64 x x y)) (patch (sqrt.f64 (fma.f64 x x y)) #<representation binary64>) () ())) ())
#s(alt y (taylor inf y) (#s(alt (fma.f64 x x y) (patch (fma.f64 x x y) #<representation binary64>) () ())) ())
#s(alt (* y (+ 1 (/ (pow x 2) y))) (taylor inf y) (#s(alt (fma.f64 x x y) (patch (fma.f64 x x y) #<representation binary64>) () ())) ())
#s(alt (* y (+ 1 (/ (pow x 2) y))) (taylor inf y) (#s(alt (fma.f64 x x y) (patch (fma.f64 x x y) #<representation binary64>) () ())) ())
#s(alt (* y (+ 1 (/ (pow x 2) y))) (taylor inf y) (#s(alt (fma.f64 x x y) (patch (fma.f64 x x y) #<representation binary64>) () ())) ())
#s(alt (* -1 (* (sqrt y) (pow (sqrt -1) 2))) (taylor -inf y) (#s(alt (/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y)))) (patch (/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y)))) #<representation binary64>) () ())) ())
#s(alt (* -1 (* y (+ (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* (sqrt (/ 1 y)) (pow (sqrt -1) 2))))) (taylor -inf y) (#s(alt (/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y)))) (patch (/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y)))) #<representation binary64>) () ())) ())
#s(alt (* -1 (* y (+ (* -1/8 (* (/ (pow x 4) (pow (sqrt -1) 2)) (sqrt (/ 1 (pow y 5))))) (+ (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* (sqrt (/ 1 y)) (pow (sqrt -1) 2)))))) (taylor -inf y) (#s(alt (/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y)))) (patch (/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y)))) #<representation binary64>) () ())) ())
#s(alt (* -1 (* y (+ (* -1/8 (* (/ (pow x 4) (pow (sqrt -1) 2)) (sqrt (/ 1 (pow y 5))))) (+ (* 1/16 (* (/ (pow x 6) (pow (sqrt -1) 4)) (sqrt (/ 1 (pow y 7))))) (+ (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* (sqrt (/ 1 y)) (pow (sqrt -1) 2))))))) (taylor -inf y) (#s(alt (/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y)))) (patch (/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y)))) #<representation binary64>) () ())) ())
#s(alt (* (sqrt (/ 1 y)) (pow (sqrt -1) 2)) (taylor -inf y) (#s(alt (/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y))) (patch (/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y))) #<representation binary64>) () ())) ())
#s(alt (+ (* -1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* (sqrt (/ 1 y)) (pow (sqrt -1) 2))) (taylor -inf y) (#s(alt (/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y))) (patch (/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y))) #<representation binary64>) () ())) ())
#s(alt (+ (* -1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (+ (* 1/2 (* (pow x 4) (sqrt (/ 1 (pow y 5))))) (* (sqrt (/ 1 y)) (pow (sqrt -1) 2)))) (taylor -inf y) (#s(alt (/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y))) (patch (/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y))) #<representation binary64>) () ())) ())
#s(alt (+ (* -1 (/ (+ (* -1/2 (* (pow x 4) (sqrt y))) (* 1/2 (* (sqrt (/ 1 y)) (+ (* -1/4 (/ (* (pow x 4) y) (pow (sqrt -1) 2))) (pow x 6))))) (pow y 3))) (+ (* -1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* (sqrt (/ 1 y)) (pow (sqrt -1) 2)))) (taylor -inf y) (#s(alt (/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y))) (patch (/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y))) #<representation binary64>) () ())) ())
#s(alt (* -1 (* (sqrt y) (pow (sqrt -1) 2))) (taylor -inf y) (#s(alt (sqrt.f64 (fma.f64 x x y)) (patch (sqrt.f64 (fma.f64 x x y)) #<representation binary64>) () ())) ())
#s(alt (* -1 (* y (+ (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* (sqrt (/ 1 y)) (pow (sqrt -1) 2))))) (taylor -inf y) (#s(alt (sqrt.f64 (fma.f64 x x y)) (patch (sqrt.f64 (fma.f64 x x y)) #<representation binary64>) () ())) ())
#s(alt (* -1 (* y (+ (* -1/8 (* (/ (pow x 4) (pow (sqrt -1) 2)) (sqrt (/ 1 (pow y 5))))) (+ (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* (sqrt (/ 1 y)) (pow (sqrt -1) 2)))))) (taylor -inf y) (#s(alt (sqrt.f64 (fma.f64 x x y)) (patch (sqrt.f64 (fma.f64 x x y)) #<representation binary64>) () ())) ())
#s(alt (* -1 (* y (+ (* -1/8 (* (/ (pow x 4) (pow (sqrt -1) 2)) (sqrt (/ 1 (pow y 5))))) (+ (* 1/16 (* (/ (pow x 6) (pow (sqrt -1) 4)) (sqrt (/ 1 (pow y 7))))) (+ (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* (sqrt (/ 1 y)) (pow (sqrt -1) 2))))))) (taylor -inf y) (#s(alt (sqrt.f64 (fma.f64 x x y)) (patch (sqrt.f64 (fma.f64 x x y)) #<representation binary64>) () ())) ())
#s(alt y (taylor -inf y) (#s(alt (fma.f64 x x y) (patch (fma.f64 x x y) #<representation binary64>) () ())) ())
#s(alt (* -1 (* y (- (* -1 (/ (pow x 2) y)) 1))) (taylor -inf y) (#s(alt (fma.f64 x x y) (patch (fma.f64 x x y) #<representation binary64>) () ())) ())
#s(alt (* -1 (* y (- (* -1 (/ (pow x 2) y)) 1))) (taylor -inf y) (#s(alt (fma.f64 x x y) (patch (fma.f64 x x y) #<representation binary64>) () ())) ())
#s(alt (* -1 (* y (- (* -1 (/ (pow x 2) y)) 1))) (taylor -inf y) (#s(alt (fma.f64 x x y) (patch (fma.f64 x x y) #<representation binary64>) () ())) ())
#s(alt (sqrt y) (taylor 0 x) (#s(alt (/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y)))) (patch (/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y)))) #<representation binary64>) () ())) ())
#s(alt (+ (sqrt y) (* 1/2 (* (pow x 2) (sqrt (/ 1 y))))) (taylor 0 x) (#s(alt (/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y)))) (patch (/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y)))) #<representation binary64>) () ())) ())
#s(alt (+ (sqrt y) (* (pow x 2) (+ (* -1/8 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* 1/2 (sqrt (/ 1 y)))))) (taylor 0 x) (#s(alt (/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y)))) (patch (/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y)))) #<representation binary64>) () ())) ())
#s(alt (+ (sqrt y) (* (pow x 2) (+ (* 1/2 (sqrt (/ 1 y))) (* (pow x 2) (+ (* -1/8 (sqrt (/ 1 (pow y 3)))) (* 1/16 (* (pow x 2) (sqrt (/ 1 (pow y 5)))))))))) (taylor 0 x) (#s(alt (/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y)))) (patch (/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y)))) #<representation binary64>) () ())) ())
#s(alt (sqrt (/ 1 y)) (taylor 0 x) (#s(alt (/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y))) (patch (/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y))) #<representation binary64>) () ())) ())
#s(alt (+ (sqrt (/ 1 y)) (* -1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3)))))) (taylor 0 x) (#s(alt (/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y))) (patch (/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y))) #<representation binary64>) () ())) ())
#s(alt (+ (sqrt (/ 1 y)) (* (pow x 2) (+ (* -1/2 (sqrt (/ 1 (pow y 3)))) (* 3/8 (* (pow x 2) (sqrt (/ 1 (pow y 5)))))))) (taylor 0 x) (#s(alt (/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y))) (patch (/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y))) #<representation binary64>) () ())) ())
#s(alt (+ (sqrt (/ 1 y)) (* (pow x 2) (+ (* -1/2 (sqrt (/ 1 (pow y 3)))) (* (pow x 2) (+ (* -5/16 (* (pow x 2) (sqrt (/ 1 (pow y 7))))) (* 3/8 (sqrt (/ 1 (pow y 5))))))))) (taylor 0 x) (#s(alt (/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y))) (patch (/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y))) #<representation binary64>) () ())) ())
#s(alt (sqrt y) (taylor 0 x) (#s(alt (sqrt.f64 (fma.f64 x x y)) (patch (sqrt.f64 (fma.f64 x x y)) #<representation binary64>) () ())) ())
#s(alt (+ (sqrt y) (* 1/2 (* (pow x 2) (sqrt (/ 1 y))))) (taylor 0 x) (#s(alt (sqrt.f64 (fma.f64 x x y)) (patch (sqrt.f64 (fma.f64 x x y)) #<representation binary64>) () ())) ())
#s(alt (+ (sqrt y) (* (pow x 2) (+ (* -1/8 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* 1/2 (sqrt (/ 1 y)))))) (taylor 0 x) (#s(alt (sqrt.f64 (fma.f64 x x y)) (patch (sqrt.f64 (fma.f64 x x y)) #<representation binary64>) () ())) ())
#s(alt (+ (sqrt y) (* (pow x 2) (+ (* 1/2 (sqrt (/ 1 y))) (* (pow x 2) (+ (* -1/8 (sqrt (/ 1 (pow y 3)))) (* 1/16 (* (pow x 2) (sqrt (/ 1 (pow y 5)))))))))) (taylor 0 x) (#s(alt (sqrt.f64 (fma.f64 x x y)) (patch (sqrt.f64 (fma.f64 x x y)) #<representation binary64>) () ())) ())
#s(alt y (taylor 0 x) (#s(alt (fma.f64 x x y) (patch (fma.f64 x x y) #<representation binary64>) () ())) ())
#s(alt (+ y (pow x 2)) (taylor 0 x) (#s(alt (fma.f64 x x y) (patch (fma.f64 x x y) #<representation binary64>) () ())) ())
#s(alt (+ y (pow x 2)) (taylor 0 x) (#s(alt (fma.f64 x x y) (patch (fma.f64 x x y) #<representation binary64>) () ())) ())
#s(alt (+ y (pow x 2)) (taylor 0 x) (#s(alt (fma.f64 x x y) (patch (fma.f64 x x y) #<representation binary64>) () ())) ())
#s(alt x (taylor inf x) (#s(alt (/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y)))) (patch (/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y)))) #<representation binary64>) () ())) ())
#s(alt (* x (+ 1 (* 1/2 (/ y (pow x 2))))) (taylor inf x) (#s(alt (/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y)))) (patch (/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y)))) #<representation binary64>) () ())) ())
#s(alt (* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (* 1/2 (/ y (pow x 2)))))) (taylor inf x) (#s(alt (/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y)))) (patch (/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y)))) #<representation binary64>) () ())) ())
#s(alt (* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (+ (* 1/16 (/ (pow y 3) (pow x 6))) (* 1/2 (/ y (pow x 2))))))) (taylor inf x) (#s(alt (/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y)))) (patch (/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y)))) #<representation binary64>) () ())) ())
#s(alt (/ 1 x) (taylor inf x) (#s(alt (/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y))) (patch (/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y))) #<representation binary64>) () ())) ())
#s(alt (/ (+ 1 (* -1/2 (/ y (pow x 2)))) x) (taylor inf x) (#s(alt (/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y))) (patch (/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y))) #<representation binary64>) () ())) ())
#s(alt (/ (+ 1 (+ (* -1/2 (/ y (pow x 2))) (* -1/2 (/ (+ (* -1 (pow y 2)) (* 1/4 (pow y 2))) (pow x 4))))) x) (taylor inf x) (#s(alt (/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y))) (patch (/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y))) #<representation binary64>) () ())) ())
#s(alt (/ (+ 1 (+ (* -1/2 (/ y (pow x 2))) (+ (* -1/2 (/ (+ (* -1 (pow y 2)) (* 1/4 (pow y 2))) (pow x 4))) (* -1/2 (/ (+ (* 1/2 (* y (+ (* -1 (pow y 2)) (* 1/4 (pow y 2))))) (pow y 3)) (pow x 6)))))) x) (taylor inf x) (#s(alt (/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y))) (patch (/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y))) #<representation binary64>) () ())) ())
#s(alt x (taylor inf x) (#s(alt (sqrt.f64 (fma.f64 x x y)) (patch (sqrt.f64 (fma.f64 x x y)) #<representation binary64>) () ())) ())
#s(alt (* x (+ 1 (* 1/2 (/ y (pow x 2))))) (taylor inf x) (#s(alt (sqrt.f64 (fma.f64 x x y)) (patch (sqrt.f64 (fma.f64 x x y)) #<representation binary64>) () ())) ())
#s(alt (* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (* 1/2 (/ y (pow x 2)))))) (taylor inf x) (#s(alt (sqrt.f64 (fma.f64 x x y)) (patch (sqrt.f64 (fma.f64 x x y)) #<representation binary64>) () ())) ())
#s(alt (* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (+ (* 1/16 (/ (pow y 3) (pow x 6))) (* 1/2 (/ y (pow x 2))))))) (taylor inf x) (#s(alt (sqrt.f64 (fma.f64 x x y)) (patch (sqrt.f64 (fma.f64 x x y)) #<representation binary64>) () ())) ())
#s(alt (pow x 2) (taylor inf x) (#s(alt (fma.f64 x x y) (patch (fma.f64 x x y) #<representation binary64>) () ())) ())
#s(alt (* (pow x 2) (+ 1 (/ y (pow x 2)))) (taylor inf x) (#s(alt (fma.f64 x x y) (patch (fma.f64 x x y) #<representation binary64>) () ())) ())
#s(alt (* (pow x 2) (+ 1 (/ y (pow x 2)))) (taylor inf x) (#s(alt (fma.f64 x x y) (patch (fma.f64 x x y) #<representation binary64>) () ())) ())
#s(alt (* (pow x 2) (+ 1 (/ y (pow x 2)))) (taylor inf x) (#s(alt (fma.f64 x x y) (patch (fma.f64 x x y) #<representation binary64>) () ())) ())
#s(alt (* -1 x) (taylor -inf x) (#s(alt (/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y)))) (patch (/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y)))) #<representation binary64>) () ())) ())
#s(alt (* -1 (* x (+ 1 (* 1/2 (/ y (pow x 2)))))) (taylor -inf x) (#s(alt (/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y)))) (patch (/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y)))) #<representation binary64>) () ())) ())
#s(alt (* -1 (* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (* 1/2 (/ y (pow x 2))))))) (taylor -inf x) (#s(alt (/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y)))) (patch (/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y)))) #<representation binary64>) () ())) ())
#s(alt (* -1 (* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (+ (* 1/16 (/ (pow y 3) (pow x 6))) (* 1/2 (/ y (pow x 2)))))))) (taylor -inf x) (#s(alt (/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y)))) (patch (/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y)))) #<representation binary64>) () ())) ())
#s(alt (/ -1 x) (taylor -inf x) (#s(alt (/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y))) (patch (/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y))) #<representation binary64>) () ())) ())
#s(alt (* -1 (/ (+ 1 (* -1/2 (/ y (pow x 2)))) x)) (taylor -inf x) (#s(alt (/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y))) (patch (/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y))) #<representation binary64>) () ())) ())
#s(alt (* -1 (/ (+ 1 (+ (* -1/2 (/ y (pow x 2))) (* -1/2 (/ (+ (* -1 (pow y 2)) (* 1/4 (pow y 2))) (pow x 4))))) x)) (taylor -inf x) (#s(alt (/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y))) (patch (/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y))) #<representation binary64>) () ())) ())
#s(alt (* -1 (/ (+ 1 (+ (* -1/2 (/ y (pow x 2))) (+ (* -1/2 (/ (+ (* -1 (pow y 2)) (* 1/4 (pow y 2))) (pow x 4))) (* -1/2 (/ (+ (* 1/2 (* y (+ (* -1 (pow y 2)) (* 1/4 (pow y 2))))) (pow y 3)) (pow x 6)))))) x)) (taylor -inf x) (#s(alt (/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y))) (patch (/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y))) #<representation binary64>) () ())) ())
#s(alt (* -1 x) (taylor -inf x) (#s(alt (sqrt.f64 (fma.f64 x x y)) (patch (sqrt.f64 (fma.f64 x x y)) #<representation binary64>) () ())) ())
#s(alt (* -1 (* x (+ 1 (* 1/2 (/ y (pow x 2)))))) (taylor -inf x) (#s(alt (sqrt.f64 (fma.f64 x x y)) (patch (sqrt.f64 (fma.f64 x x y)) #<representation binary64>) () ())) ())
#s(alt (* -1 (* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (* 1/2 (/ y (pow x 2))))))) (taylor -inf x) (#s(alt (sqrt.f64 (fma.f64 x x y)) (patch (sqrt.f64 (fma.f64 x x y)) #<representation binary64>) () ())) ())
#s(alt (* -1 (* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (+ (* 1/16 (/ (pow y 3) (pow x 6))) (* 1/2 (/ y (pow x 2)))))))) (taylor -inf x) (#s(alt (sqrt.f64 (fma.f64 x x y)) (patch (sqrt.f64 (fma.f64 x x y)) #<representation binary64>) () ())) ())
#s(alt (pow x 2) (taylor -inf x) (#s(alt (fma.f64 x x y) (patch (fma.f64 x x y) #<representation binary64>) () ())) ())
#s(alt (* (pow x 2) (+ 1 (/ y (pow x 2)))) (taylor -inf x) (#s(alt (fma.f64 x x y) (patch (fma.f64 x x y) #<representation binary64>) () ())) ())
#s(alt (* (pow x 2) (+ 1 (/ y (pow x 2)))) (taylor -inf x) (#s(alt (fma.f64 x x y) (patch (fma.f64 x x y) #<representation binary64>) () ())) ())
#s(alt (* (pow x 2) (+ 1 (/ y (pow x 2)))) (taylor -inf x) (#s(alt (fma.f64 x x y) (patch (fma.f64 x x y) #<representation binary64>) () ())) ())
Calls

6 calls:

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

simplify164.0ms (3.6%)

Memory
45.8MiB live, 196.4MiB allocated
Algorithm
egg-herbie
Rules
18 000×lower-fma.f64
18 000×lower-fma.f32
4 634×lower-*.f64
4 634×lower-*.f32
3 734×lower-+.f64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
02181605
16461549
220351527
347581481
084131356
Stop Event
iter limit
node limit
Counts
96 → 89
Calls
Call 1
Inputs
x
(+ x (* 1/2 (/ y x)))
(+ x (* y (+ (* -1/8 (/ y (pow x 3))) (* 1/2 (/ 1 x)))))
(+ x (* y (+ (* y (- (* 1/16 (/ y (pow x 5))) (* 1/8 (/ 1 (pow x 3))))) (* 1/2 (/ 1 x)))))
(/ 1 x)
(+ (* -1/2 (/ y (pow x 3))) (/ 1 x))
(+ (* y (- (* 3/8 (/ y (pow x 5))) (* 1/2 (/ 1 (pow x 3))))) (/ 1 x))
(+ (* y (- (* y (+ (* -5/16 (/ y (pow x 7))) (* 3/8 (/ 1 (pow x 5))))) (* 1/2 (/ 1 (pow x 3))))) (/ 1 x))
x
(+ x (* 1/2 (/ y x)))
(+ x (* y (+ (* -1/8 (/ y (pow x 3))) (* 1/2 (/ 1 x)))))
(+ x (* y (+ (* y (- (* 1/16 (/ y (pow x 5))) (* 1/8 (/ 1 (pow x 3))))) (* 1/2 (/ 1 x)))))
(pow x 2)
(+ y (pow x 2))
(+ y (pow x 2))
(+ y (pow x 2))
(sqrt y)
(* y (+ (sqrt (/ 1 y)) (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3)))))))
(* y (+ (sqrt (/ 1 y)) (+ (* -1/8 (* (pow x 4) (sqrt (/ 1 (pow y 5))))) (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))))))
(* y (+ (sqrt (/ 1 y)) (+ (* -1/8 (* (pow x 4) (sqrt (/ 1 (pow y 5))))) (+ (* 1/16 (* (pow x 6) (sqrt (/ 1 (pow y 7))))) (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3)))))))))
(sqrt (/ 1 y))
(+ (sqrt (/ 1 y)) (* -1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))))
(+ (sqrt (/ 1 y)) (+ (* -1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* 1/2 (* (pow x 4) (sqrt (/ 1 (pow y 5)))))))
(+ (sqrt (/ 1 y)) (+ (* -1/2 (* (sqrt (/ 1 (pow y 7))) (+ (* 1/4 (* (pow x 4) y)) (pow x 6)))) (+ (* -1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* 1/2 (* (pow x 4) (sqrt (/ 1 (pow y 5))))))))
(sqrt y)
(* y (+ (sqrt (/ 1 y)) (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3)))))))
(* y (+ (sqrt (/ 1 y)) (+ (* -1/8 (* (pow x 4) (sqrt (/ 1 (pow y 5))))) (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))))))
(* y (+ (sqrt (/ 1 y)) (+ (* -1/8 (* (pow x 4) (sqrt (/ 1 (pow y 5))))) (+ (* 1/16 (* (pow x 6) (sqrt (/ 1 (pow y 7))))) (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3)))))))))
y
(* y (+ 1 (/ (pow x 2) y)))
(* y (+ 1 (/ (pow x 2) y)))
(* y (+ 1 (/ (pow x 2) y)))
(* -1 (* (sqrt y) (pow (sqrt -1) 2)))
(* -1 (* y (+ (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* (sqrt (/ 1 y)) (pow (sqrt -1) 2)))))
(* -1 (* y (+ (* -1/8 (* (/ (pow x 4) (pow (sqrt -1) 2)) (sqrt (/ 1 (pow y 5))))) (+ (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* (sqrt (/ 1 y)) (pow (sqrt -1) 2))))))
(* -1 (* y (+ (* -1/8 (* (/ (pow x 4) (pow (sqrt -1) 2)) (sqrt (/ 1 (pow y 5))))) (+ (* 1/16 (* (/ (pow x 6) (pow (sqrt -1) 4)) (sqrt (/ 1 (pow y 7))))) (+ (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* (sqrt (/ 1 y)) (pow (sqrt -1) 2)))))))
(* (sqrt (/ 1 y)) (pow (sqrt -1) 2))
(+ (* -1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* (sqrt (/ 1 y)) (pow (sqrt -1) 2)))
(+ (* -1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (+ (* 1/2 (* (pow x 4) (sqrt (/ 1 (pow y 5))))) (* (sqrt (/ 1 y)) (pow (sqrt -1) 2))))
(+ (* -1 (/ (+ (* -1/2 (* (pow x 4) (sqrt y))) (* 1/2 (* (sqrt (/ 1 y)) (+ (* -1/4 (/ (* (pow x 4) y) (pow (sqrt -1) 2))) (pow x 6))))) (pow y 3))) (+ (* -1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* (sqrt (/ 1 y)) (pow (sqrt -1) 2))))
(* -1 (* (sqrt y) (pow (sqrt -1) 2)))
(* -1 (* y (+ (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* (sqrt (/ 1 y)) (pow (sqrt -1) 2)))))
(* -1 (* y (+ (* -1/8 (* (/ (pow x 4) (pow (sqrt -1) 2)) (sqrt (/ 1 (pow y 5))))) (+ (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* (sqrt (/ 1 y)) (pow (sqrt -1) 2))))))
(* -1 (* y (+ (* -1/8 (* (/ (pow x 4) (pow (sqrt -1) 2)) (sqrt (/ 1 (pow y 5))))) (+ (* 1/16 (* (/ (pow x 6) (pow (sqrt -1) 4)) (sqrt (/ 1 (pow y 7))))) (+ (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* (sqrt (/ 1 y)) (pow (sqrt -1) 2)))))))
y
(* -1 (* y (- (* -1 (/ (pow x 2) y)) 1)))
(* -1 (* y (- (* -1 (/ (pow x 2) y)) 1)))
(* -1 (* y (- (* -1 (/ (pow x 2) y)) 1)))
(sqrt y)
(+ (sqrt y) (* 1/2 (* (pow x 2) (sqrt (/ 1 y)))))
(+ (sqrt y) (* (pow x 2) (+ (* -1/8 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* 1/2 (sqrt (/ 1 y))))))
(+ (sqrt y) (* (pow x 2) (+ (* 1/2 (sqrt (/ 1 y))) (* (pow x 2) (+ (* -1/8 (sqrt (/ 1 (pow y 3)))) (* 1/16 (* (pow x 2) (sqrt (/ 1 (pow y 5))))))))))
(sqrt (/ 1 y))
(+ (sqrt (/ 1 y)) (* -1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))))
(+ (sqrt (/ 1 y)) (* (pow x 2) (+ (* -1/2 (sqrt (/ 1 (pow y 3)))) (* 3/8 (* (pow x 2) (sqrt (/ 1 (pow y 5))))))))
(+ (sqrt (/ 1 y)) (* (pow x 2) (+ (* -1/2 (sqrt (/ 1 (pow y 3)))) (* (pow x 2) (+ (* -5/16 (* (pow x 2) (sqrt (/ 1 (pow y 7))))) (* 3/8 (sqrt (/ 1 (pow y 5)))))))))
(sqrt y)
(+ (sqrt y) (* 1/2 (* (pow x 2) (sqrt (/ 1 y)))))
(+ (sqrt y) (* (pow x 2) (+ (* -1/8 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* 1/2 (sqrt (/ 1 y))))))
(+ (sqrt y) (* (pow x 2) (+ (* 1/2 (sqrt (/ 1 y))) (* (pow x 2) (+ (* -1/8 (sqrt (/ 1 (pow y 3)))) (* 1/16 (* (pow x 2) (sqrt (/ 1 (pow y 5))))))))))
y
(+ y (pow x 2))
(+ y (pow x 2))
(+ y (pow x 2))
x
(* x (+ 1 (* 1/2 (/ y (pow x 2)))))
(* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (* 1/2 (/ y (pow x 2))))))
(* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (+ (* 1/16 (/ (pow y 3) (pow x 6))) (* 1/2 (/ y (pow x 2)))))))
(/ 1 x)
(/ (+ 1 (* -1/2 (/ y (pow x 2)))) x)
(/ (+ 1 (+ (* -1/2 (/ y (pow x 2))) (* -1/2 (/ (+ (* -1 (pow y 2)) (* 1/4 (pow y 2))) (pow x 4))))) x)
(/ (+ 1 (+ (* -1/2 (/ y (pow x 2))) (+ (* -1/2 (/ (+ (* -1 (pow y 2)) (* 1/4 (pow y 2))) (pow x 4))) (* -1/2 (/ (+ (* 1/2 (* y (+ (* -1 (pow y 2)) (* 1/4 (pow y 2))))) (pow y 3)) (pow x 6)))))) x)
x
(* x (+ 1 (* 1/2 (/ y (pow x 2)))))
(* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (* 1/2 (/ y (pow x 2))))))
(* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (+ (* 1/16 (/ (pow y 3) (pow x 6))) (* 1/2 (/ y (pow x 2)))))))
(pow x 2)
(* (pow x 2) (+ 1 (/ y (pow x 2))))
(* (pow x 2) (+ 1 (/ y (pow x 2))))
(* (pow x 2) (+ 1 (/ y (pow x 2))))
(* -1 x)
(* -1 (* x (+ 1 (* 1/2 (/ y (pow x 2))))))
(* -1 (* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (* 1/2 (/ y (pow x 2)))))))
(* -1 (* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (+ (* 1/16 (/ (pow y 3) (pow x 6))) (* 1/2 (/ y (pow x 2))))))))
(/ -1 x)
(* -1 (/ (+ 1 (* -1/2 (/ y (pow x 2)))) x))
(* -1 (/ (+ 1 (+ (* -1/2 (/ y (pow x 2))) (* -1/2 (/ (+ (* -1 (pow y 2)) (* 1/4 (pow y 2))) (pow x 4))))) x))
(* -1 (/ (+ 1 (+ (* -1/2 (/ y (pow x 2))) (+ (* -1/2 (/ (+ (* -1 (pow y 2)) (* 1/4 (pow y 2))) (pow x 4))) (* -1/2 (/ (+ (* 1/2 (* y (+ (* -1 (pow y 2)) (* 1/4 (pow y 2))))) (pow y 3)) (pow x 6)))))) x))
(* -1 x)
(* -1 (* x (+ 1 (* 1/2 (/ y (pow x 2))))))
(* -1 (* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (* 1/2 (/ y (pow x 2)))))))
(* -1 (* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (+ (* 1/16 (/ (pow y 3) (pow x 6))) (* 1/2 (/ y (pow x 2))))))))
(pow x 2)
(* (pow x 2) (+ 1 (/ y (pow x 2))))
(* (pow x 2) (+ 1 (/ y (pow x 2))))
(* (pow x 2) (+ 1 (/ y (pow x 2))))
Outputs
x
(+ x (* 1/2 (/ y x)))
(fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x)
(+ x (* y (+ (* -1/8 (/ y (pow x 3))) (* 1/2 (/ 1 x)))))
(fma.f64 (fma.f64 (/.f64 #s(literal -1/8 binary64) (pow.f64 x #s(literal 3 binary64))) y (/.f64 #s(literal 1/2 binary64) x)) y x)
(+ x (* y (+ (* y (- (* 1/16 (/ y (pow x 5))) (* 1/8 (/ 1 (pow x 3))))) (* 1/2 (/ 1 x)))))
(fma.f64 (fma.f64 (fma.f64 (/.f64 y (pow.f64 x #s(literal 5 binary64))) #s(literal 1/16 binary64) (/.f64 #s(literal -1/8 binary64) (pow.f64 x #s(literal 3 binary64)))) y (/.f64 #s(literal 1/2 binary64) x)) y x)
(/ 1 x)
(/.f64 #s(literal 1 binary64) x)
(+ (* -1/2 (/ y (pow x 3))) (/ 1 x))
(fma.f64 (/.f64 #s(literal -1/2 binary64) (pow.f64 x #s(literal 3 binary64))) y (/.f64 #s(literal 1 binary64) x))
(+ (* y (- (* 3/8 (/ y (pow x 5))) (* 1/2 (/ 1 (pow x 3))))) (/ 1 x))
(fma.f64 (fma.f64 (/.f64 #s(literal 3/8 binary64) (pow.f64 x #s(literal 5 binary64))) y (/.f64 #s(literal -1/2 binary64) (pow.f64 x #s(literal 3 binary64)))) y (/.f64 #s(literal 1 binary64) x))
(+ (* y (- (* y (+ (* -5/16 (/ y (pow x 7))) (* 3/8 (/ 1 (pow x 5))))) (* 1/2 (/ 1 (pow x 3))))) (/ 1 x))
(fma.f64 (fma.f64 (fma.f64 (/.f64 y (pow.f64 x #s(literal 7 binary64))) #s(literal -5/16 binary64) (/.f64 #s(literal 3/8 binary64) (pow.f64 x #s(literal 5 binary64)))) y (/.f64 #s(literal -1/2 binary64) (pow.f64 x #s(literal 3 binary64)))) y (/.f64 #s(literal 1 binary64) x))
x
(+ x (* 1/2 (/ y x)))
(fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x)
(+ x (* y (+ (* -1/8 (/ y (pow x 3))) (* 1/2 (/ 1 x)))))
(fma.f64 (fma.f64 (/.f64 #s(literal -1/8 binary64) (pow.f64 x #s(literal 3 binary64))) y (/.f64 #s(literal 1/2 binary64) x)) y x)
(+ x (* y (+ (* y (- (* 1/16 (/ y (pow x 5))) (* 1/8 (/ 1 (pow x 3))))) (* 1/2 (/ 1 x)))))
(fma.f64 (fma.f64 (fma.f64 (/.f64 y (pow.f64 x #s(literal 5 binary64))) #s(literal 1/16 binary64) (/.f64 #s(literal -1/8 binary64) (pow.f64 x #s(literal 3 binary64)))) y (/.f64 #s(literal 1/2 binary64) x)) y x)
(pow x 2)
(*.f64 x x)
(+ y (pow x 2))
(fma.f64 x x y)
(+ y (pow x 2))
(fma.f64 x x y)
(+ y (pow x 2))
(fma.f64 x x y)
(sqrt y)
(sqrt.f64 y)
(* y (+ (sqrt (/ 1 y)) (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3)))))))
(*.f64 (fma.f64 (*.f64 (*.f64 x x) #s(literal 1/2 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 3 binary64)))) (sqrt.f64 (/.f64 #s(literal 1 binary64) y))) y)
(* y (+ (sqrt (/ 1 y)) (+ (* -1/8 (* (pow x 4) (sqrt (/ 1 (pow y 5))))) (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))))))
(*.f64 (fma.f64 (*.f64 (pow.f64 x #s(literal 4 binary64)) #s(literal -1/8 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 5 binary64)))) (fma.f64 (*.f64 (*.f64 x x) #s(literal 1/2 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 3 binary64)))) (sqrt.f64 (/.f64 #s(literal 1 binary64) y)))) y)
(* y (+ (sqrt (/ 1 y)) (+ (* -1/8 (* (pow x 4) (sqrt (/ 1 (pow y 5))))) (+ (* 1/16 (* (pow x 6) (sqrt (/ 1 (pow y 7))))) (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3)))))))))
(*.f64 (fma.f64 (*.f64 (pow.f64 x #s(literal 6 binary64)) #s(literal 1/16 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 7 binary64)))) (fma.f64 (*.f64 (pow.f64 x #s(literal 4 binary64)) #s(literal -1/8 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 5 binary64)))) (fma.f64 (*.f64 (*.f64 x x) #s(literal 1/2 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 3 binary64)))) (sqrt.f64 (/.f64 #s(literal 1 binary64) y))))) y)
(sqrt (/ 1 y))
(sqrt.f64 (/.f64 #s(literal 1 binary64) y))
(+ (sqrt (/ 1 y)) (* -1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))))
(fma.f64 (*.f64 (*.f64 x x) #s(literal -1/2 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 3 binary64)))) (sqrt.f64 (/.f64 #s(literal 1 binary64) y)))
(+ (sqrt (/ 1 y)) (+ (* -1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* 1/2 (* (pow x 4) (sqrt (/ 1 (pow y 5)))))))
(fma.f64 (*.f64 (*.f64 x x) #s(literal -1/2 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 3 binary64)))) (fma.f64 (*.f64 (pow.f64 x #s(literal 4 binary64)) #s(literal 1/2 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 5 binary64)))) (sqrt.f64 (/.f64 #s(literal 1 binary64) y))))
(+ (sqrt (/ 1 y)) (+ (* -1/2 (* (sqrt (/ 1 (pow y 7))) (+ (* 1/4 (* (pow x 4) y)) (pow x 6)))) (+ (* -1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* 1/2 (* (pow x 4) (sqrt (/ 1 (pow y 5))))))))
(fma.f64 (fma.f64 (fma.f64 (*.f64 (pow.f64 x #s(literal 4 binary64)) y) #s(literal 1/4 binary64) (pow.f64 x #s(literal 6 binary64))) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 7 binary64)))) (*.f64 (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 3 binary64)))) (*.f64 x x))) #s(literal -1/2 binary64) (fma.f64 (*.f64 (pow.f64 x #s(literal 4 binary64)) #s(literal 1/2 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 5 binary64)))) (sqrt.f64 (/.f64 #s(literal 1 binary64) y))))
(sqrt y)
(sqrt.f64 y)
(* y (+ (sqrt (/ 1 y)) (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3)))))))
(*.f64 (fma.f64 (*.f64 (*.f64 x x) #s(literal 1/2 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 3 binary64)))) (sqrt.f64 (/.f64 #s(literal 1 binary64) y))) y)
(* y (+ (sqrt (/ 1 y)) (+ (* -1/8 (* (pow x 4) (sqrt (/ 1 (pow y 5))))) (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))))))
(*.f64 (fma.f64 (*.f64 (pow.f64 x #s(literal 4 binary64)) #s(literal -1/8 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 5 binary64)))) (fma.f64 (*.f64 (*.f64 x x) #s(literal 1/2 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 3 binary64)))) (sqrt.f64 (/.f64 #s(literal 1 binary64) y)))) y)
(* y (+ (sqrt (/ 1 y)) (+ (* -1/8 (* (pow x 4) (sqrt (/ 1 (pow y 5))))) (+ (* 1/16 (* (pow x 6) (sqrt (/ 1 (pow y 7))))) (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3)))))))))
(*.f64 (fma.f64 (*.f64 (pow.f64 x #s(literal 6 binary64)) #s(literal 1/16 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 7 binary64)))) (fma.f64 (*.f64 (pow.f64 x #s(literal 4 binary64)) #s(literal -1/8 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 5 binary64)))) (fma.f64 (*.f64 (*.f64 x x) #s(literal 1/2 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 3 binary64)))) (sqrt.f64 (/.f64 #s(literal 1 binary64) y))))) y)
y
(* y (+ 1 (/ (pow x 2) y)))
(fma.f64 x x y)
(* y (+ 1 (/ (pow x 2) y)))
(fma.f64 x x y)
(* y (+ 1 (/ (pow x 2) y)))
(fma.f64 x x y)
(* -1 (* (sqrt y) (pow (sqrt -1) 2)))
(sqrt.f64 y)
(* -1 (* y (+ (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* (sqrt (/ 1 y)) (pow (sqrt -1) 2)))))
(*.f64 (fma.f64 (*.f64 (*.f64 x x) #s(literal -1/2 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 3 binary64)))) (sqrt.f64 (/.f64 #s(literal 1 binary64) y))) y)
(* -1 (* y (+ (* -1/8 (* (/ (pow x 4) (pow (sqrt -1) 2)) (sqrt (/ 1 (pow y 5))))) (+ (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* (sqrt (/ 1 y)) (pow (sqrt -1) 2))))))
(*.f64 (fma.f64 (*.f64 (*.f64 x x) #s(literal -1/2 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 3 binary64)))) (fma.f64 (*.f64 (pow.f64 x #s(literal 4 binary64)) #s(literal -1/8 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 5 binary64)))) (sqrt.f64 (/.f64 #s(literal 1 binary64) y)))) y)
(* -1 (* y (+ (* -1/8 (* (/ (pow x 4) (pow (sqrt -1) 2)) (sqrt (/ 1 (pow y 5))))) (+ (* 1/16 (* (/ (pow x 6) (pow (sqrt -1) 4)) (sqrt (/ 1 (pow y 7))))) (+ (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* (sqrt (/ 1 y)) (pow (sqrt -1) 2)))))))
(*.f64 (fma.f64 #s(literal -1/16 binary64) (/.f64 (*.f64 (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 7 binary64)))) (pow.f64 x #s(literal 6 binary64))) (pow.f64 (sqrt.f64 #s(literal -1 binary64)) #s(literal 4 binary64))) (fma.f64 (*.f64 (*.f64 x x) #s(literal -1/2 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 3 binary64)))) (fma.f64 (*.f64 (pow.f64 x #s(literal 4 binary64)) #s(literal -1/8 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 5 binary64)))) (sqrt.f64 (/.f64 #s(literal 1 binary64) y))))) y)
(* (sqrt (/ 1 y)) (pow (sqrt -1) 2))
(neg.f64 (sqrt.f64 (/.f64 #s(literal 1 binary64) y)))
(+ (* -1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* (sqrt (/ 1 y)) (pow (sqrt -1) 2)))
(fma.f64 (*.f64 (*.f64 x x) #s(literal -1/2 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 3 binary64)))) (neg.f64 (sqrt.f64 (/.f64 #s(literal 1 binary64) y))))
(+ (* -1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (+ (* 1/2 (* (pow x 4) (sqrt (/ 1 (pow y 5))))) (* (sqrt (/ 1 y)) (pow (sqrt -1) 2))))
(fma.f64 (*.f64 (*.f64 x x) #s(literal -1/2 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 3 binary64)))) (fma.f64 (*.f64 (pow.f64 x #s(literal 4 binary64)) #s(literal 1/2 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 5 binary64)))) (neg.f64 (sqrt.f64 (/.f64 #s(literal 1 binary64) y)))))
(+ (* -1 (/ (+ (* -1/2 (* (pow x 4) (sqrt y))) (* 1/2 (* (sqrt (/ 1 y)) (+ (* -1/4 (/ (* (pow x 4) y) (pow (sqrt -1) 2))) (pow x 6))))) (pow y 3))) (+ (* -1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* (sqrt (/ 1 y)) (pow (sqrt -1) 2))))
(-.f64 (fma.f64 (*.f64 (*.f64 (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 3 binary64)))) #s(literal -1/2 binary64)) x) x (/.f64 (fma.f64 (*.f64 (fma.f64 (*.f64 (pow.f64 x #s(literal 4 binary64)) y) #s(literal 1/4 binary64) (pow.f64 x #s(literal 6 binary64))) (sqrt.f64 (/.f64 #s(literal 1 binary64) y))) #s(literal -1/2 binary64) (*.f64 (*.f64 (pow.f64 x #s(literal 4 binary64)) (sqrt.f64 y)) #s(literal 1/2 binary64))) (pow.f64 y #s(literal 3 binary64)))) (sqrt.f64 (/.f64 #s(literal 1 binary64) y)))
(* -1 (* (sqrt y) (pow (sqrt -1) 2)))
(sqrt.f64 y)
(* -1 (* y (+ (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* (sqrt (/ 1 y)) (pow (sqrt -1) 2)))))
(*.f64 (fma.f64 (*.f64 (*.f64 x x) #s(literal -1/2 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 3 binary64)))) (sqrt.f64 (/.f64 #s(literal 1 binary64) y))) y)
(* -1 (* y (+ (* -1/8 (* (/ (pow x 4) (pow (sqrt -1) 2)) (sqrt (/ 1 (pow y 5))))) (+ (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* (sqrt (/ 1 y)) (pow (sqrt -1) 2))))))
(*.f64 (fma.f64 (*.f64 (*.f64 x x) #s(literal -1/2 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 3 binary64)))) (fma.f64 (*.f64 (pow.f64 x #s(literal 4 binary64)) #s(literal -1/8 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 5 binary64)))) (sqrt.f64 (/.f64 #s(literal 1 binary64) y)))) y)
(* -1 (* y (+ (* -1/8 (* (/ (pow x 4) (pow (sqrt -1) 2)) (sqrt (/ 1 (pow y 5))))) (+ (* 1/16 (* (/ (pow x 6) (pow (sqrt -1) 4)) (sqrt (/ 1 (pow y 7))))) (+ (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* (sqrt (/ 1 y)) (pow (sqrt -1) 2)))))))
(*.f64 (fma.f64 #s(literal -1/16 binary64) (/.f64 (*.f64 (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 7 binary64)))) (pow.f64 x #s(literal 6 binary64))) (pow.f64 (sqrt.f64 #s(literal -1 binary64)) #s(literal 4 binary64))) (fma.f64 (*.f64 (*.f64 x x) #s(literal -1/2 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 3 binary64)))) (fma.f64 (*.f64 (pow.f64 x #s(literal 4 binary64)) #s(literal -1/8 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 5 binary64)))) (sqrt.f64 (/.f64 #s(literal 1 binary64) y))))) y)
y
(* -1 (* y (- (* -1 (/ (pow x 2) y)) 1)))
(fma.f64 x x y)
(* -1 (* y (- (* -1 (/ (pow x 2) y)) 1)))
(fma.f64 x x y)
(* -1 (* y (- (* -1 (/ (pow x 2) y)) 1)))
(fma.f64 x x y)
(sqrt y)
(sqrt.f64 y)
(+ (sqrt y) (* 1/2 (* (pow x 2) (sqrt (/ 1 y)))))
(fma.f64 (*.f64 (*.f64 x x) #s(literal 1/2 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) y)) (sqrt.f64 y))
(+ (sqrt y) (* (pow x 2) (+ (* -1/8 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* 1/2 (sqrt (/ 1 y))))))
(fma.f64 (fma.f64 (*.f64 (*.f64 x x) #s(literal -1/8 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 3 binary64)))) (*.f64 (sqrt.f64 (/.f64 #s(literal 1 binary64) y)) #s(literal 1/2 binary64))) (*.f64 x x) (sqrt.f64 y))
(+ (sqrt y) (* (pow x 2) (+ (* 1/2 (sqrt (/ 1 y))) (* (pow x 2) (+ (* -1/8 (sqrt (/ 1 (pow y 3)))) (* 1/16 (* (pow x 2) (sqrt (/ 1 (pow y 5))))))))))
(fma.f64 (fma.f64 (*.f64 (*.f64 x x) #s(literal 1/16 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 5 binary64)))) (*.f64 (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 3 binary64)))) #s(literal -1/8 binary64))) (pow.f64 x #s(literal 4 binary64)) (fma.f64 (*.f64 (*.f64 x x) #s(literal 1/2 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) y)) (sqrt.f64 y)))
(sqrt (/ 1 y))
(sqrt.f64 (/.f64 #s(literal 1 binary64) y))
(+ (sqrt (/ 1 y)) (* -1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))))
(fma.f64 (*.f64 (*.f64 x x) #s(literal -1/2 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 3 binary64)))) (sqrt.f64 (/.f64 #s(literal 1 binary64) y)))
(+ (sqrt (/ 1 y)) (* (pow x 2) (+ (* -1/2 (sqrt (/ 1 (pow y 3)))) (* 3/8 (* (pow x 2) (sqrt (/ 1 (pow y 5))))))))
(fma.f64 (fma.f64 (*.f64 (*.f64 x x) #s(literal 3/8 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 5 binary64)))) (*.f64 (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 3 binary64)))) #s(literal -1/2 binary64))) (*.f64 x x) (sqrt.f64 (/.f64 #s(literal 1 binary64) y)))
(+ (sqrt (/ 1 y)) (* (pow x 2) (+ (* -1/2 (sqrt (/ 1 (pow y 3)))) (* (pow x 2) (+ (* -5/16 (* (pow x 2) (sqrt (/ 1 (pow y 7))))) (* 3/8 (sqrt (/ 1 (pow y 5)))))))))
(fma.f64 (fma.f64 (*.f64 (*.f64 x x) #s(literal -5/16 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 7 binary64)))) (*.f64 (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 5 binary64)))) #s(literal 3/8 binary64))) (pow.f64 x #s(literal 4 binary64)) (fma.f64 (*.f64 (*.f64 x x) #s(literal -1/2 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 3 binary64)))) (sqrt.f64 (/.f64 #s(literal 1 binary64) y))))
(sqrt y)
(sqrt.f64 y)
(+ (sqrt y) (* 1/2 (* (pow x 2) (sqrt (/ 1 y)))))
(fma.f64 (*.f64 (*.f64 x x) #s(literal 1/2 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) y)) (sqrt.f64 y))
(+ (sqrt y) (* (pow x 2) (+ (* -1/8 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* 1/2 (sqrt (/ 1 y))))))
(fma.f64 (fma.f64 (*.f64 (*.f64 x x) #s(literal -1/8 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 3 binary64)))) (*.f64 (sqrt.f64 (/.f64 #s(literal 1 binary64) y)) #s(literal 1/2 binary64))) (*.f64 x x) (sqrt.f64 y))
(+ (sqrt y) (* (pow x 2) (+ (* 1/2 (sqrt (/ 1 y))) (* (pow x 2) (+ (* -1/8 (sqrt (/ 1 (pow y 3)))) (* 1/16 (* (pow x 2) (sqrt (/ 1 (pow y 5))))))))))
(fma.f64 (fma.f64 (*.f64 (*.f64 x x) #s(literal 1/16 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 5 binary64)))) (*.f64 (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 3 binary64)))) #s(literal -1/8 binary64))) (pow.f64 x #s(literal 4 binary64)) (fma.f64 (*.f64 (*.f64 x x) #s(literal 1/2 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) y)) (sqrt.f64 y)))
y
(+ y (pow x 2))
(fma.f64 x x y)
(+ y (pow x 2))
(fma.f64 x x y)
(+ y (pow x 2))
(fma.f64 x x y)
x
(* x (+ 1 (* 1/2 (/ y (pow x 2)))))
(fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x)
(* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (* 1/2 (/ y (pow x 2))))))
(fma.f64 (*.f64 (/.f64 y (pow.f64 x #s(literal 4 binary64))) (*.f64 #s(literal -1/8 binary64) y)) x (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x))
(* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (+ (* 1/16 (/ (pow y 3) (pow x 6))) (* 1/2 (/ y (pow x 2)))))))
(fma.f64 (fma.f64 (pow.f64 y #s(literal 3 binary64)) (/.f64 #s(literal 1/16 binary64) (pow.f64 x #s(literal 6 binary64))) (fma.f64 (/.f64 y (pow.f64 x #s(literal 4 binary64))) (*.f64 #s(literal -1/8 binary64) y) #s(literal 1 binary64))) x (*.f64 (/.f64 #s(literal 1/2 binary64) x) y))
(/ 1 x)
(/.f64 #s(literal 1 binary64) x)
(/ (+ 1 (* -1/2 (/ y (pow x 2)))) x)
(/.f64 (fma.f64 (/.f64 (/.f64 y x) x) #s(literal -1/2 binary64) #s(literal 1 binary64)) x)
(/ (+ 1 (+ (* -1/2 (/ y (pow x 2))) (* -1/2 (/ (+ (* -1 (pow y 2)) (* 1/4 (pow y 2))) (pow x 4))))) x)
(/.f64 (fma.f64 (*.f64 y (fma.f64 (/.f64 #s(literal -3/4 binary64) (pow.f64 x #s(literal 4 binary64))) y (/.f64 (/.f64 #s(literal 1 binary64) x) x))) #s(literal -1/2 binary64) #s(literal 1 binary64)) x)
(/ (+ 1 (+ (* -1/2 (/ y (pow x 2))) (+ (* -1/2 (/ (+ (* -1 (pow y 2)) (* 1/4 (pow y 2))) (pow x 4))) (* -1/2 (/ (+ (* 1/2 (* y (+ (* -1 (pow y 2)) (* 1/4 (pow y 2))))) (pow y 3)) (pow x 6)))))) x)
(/.f64 (fma.f64 (fma.f64 y (fma.f64 (/.f64 #s(literal -3/4 binary64) (pow.f64 x #s(literal 4 binary64))) y (/.f64 (/.f64 #s(literal 1 binary64) x) x)) (/.f64 (fma.f64 (*.f64 #s(literal -3/4 binary64) (pow.f64 y #s(literal 3 binary64))) #s(literal 1/2 binary64) (pow.f64 y #s(literal 3 binary64))) (pow.f64 x #s(literal 6 binary64)))) #s(literal -1/2 binary64) #s(literal 1 binary64)) x)
x
(* x (+ 1 (* 1/2 (/ y (pow x 2)))))
(fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x)
(* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (* 1/2 (/ y (pow x 2))))))
(fma.f64 (*.f64 (/.f64 y (pow.f64 x #s(literal 4 binary64))) (*.f64 #s(literal -1/8 binary64) y)) x (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x))
(* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (+ (* 1/16 (/ (pow y 3) (pow x 6))) (* 1/2 (/ y (pow x 2)))))))
(fma.f64 (fma.f64 (pow.f64 y #s(literal 3 binary64)) (/.f64 #s(literal 1/16 binary64) (pow.f64 x #s(literal 6 binary64))) (fma.f64 (/.f64 y (pow.f64 x #s(literal 4 binary64))) (*.f64 #s(literal -1/8 binary64) y) #s(literal 1 binary64))) x (*.f64 (/.f64 #s(literal 1/2 binary64) x) y))
(pow x 2)
(*.f64 x x)
(* (pow x 2) (+ 1 (/ y (pow x 2))))
(fma.f64 x x y)
(* (pow x 2) (+ 1 (/ y (pow x 2))))
(fma.f64 x x y)
(* (pow x 2) (+ 1 (/ y (pow x 2))))
(fma.f64 x x y)
(* -1 x)
(neg.f64 x)
(* -1 (* x (+ 1 (* 1/2 (/ y (pow x 2))))))
(fma.f64 #s(literal -1/2 binary64) (/.f64 y x) (neg.f64 x))
(* -1 (* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (* 1/2 (/ y (pow x 2)))))))
(fma.f64 (fma.f64 (*.f64 #s(literal 1/8 binary64) y) (/.f64 y (pow.f64 x #s(literal 4 binary64))) #s(literal -1 binary64)) x (*.f64 (/.f64 #s(literal -1/2 binary64) x) y))
(* -1 (* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (+ (* 1/16 (/ (pow y 3) (pow x 6))) (* 1/2 (/ y (pow x 2))))))))
(fma.f64 (fma.f64 #s(literal -1/16 binary64) (/.f64 (pow.f64 y #s(literal 3 binary64)) (pow.f64 x #s(literal 6 binary64))) (fma.f64 (*.f64 #s(literal 1/8 binary64) y) (/.f64 y (pow.f64 x #s(literal 4 binary64))) #s(literal -1 binary64))) x (*.f64 (/.f64 #s(literal -1/2 binary64) x) y))
(/ -1 x)
(/.f64 #s(literal -1 binary64) x)
(* -1 (/ (+ 1 (* -1/2 (/ y (pow x 2)))) x))
(/.f64 (fma.f64 (/.f64 (/.f64 y x) x) #s(literal 1/2 binary64) #s(literal -1 binary64)) x)
(* -1 (/ (+ 1 (+ (* -1/2 (/ y (pow x 2))) (* -1/2 (/ (+ (* -1 (pow y 2)) (* 1/4 (pow y 2))) (pow x 4))))) x))
(/.f64 (fma.f64 (*.f64 y (fma.f64 (/.f64 #s(literal -3/4 binary64) (pow.f64 x #s(literal 4 binary64))) y (/.f64 (/.f64 #s(literal 1 binary64) x) x))) #s(literal 1/2 binary64) #s(literal -1 binary64)) x)
(* -1 (/ (+ 1 (+ (* -1/2 (/ y (pow x 2))) (+ (* -1/2 (/ (+ (* -1 (pow y 2)) (* 1/4 (pow y 2))) (pow x 4))) (* -1/2 (/ (+ (* 1/2 (* y (+ (* -1 (pow y 2)) (* 1/4 (pow y 2))))) (pow y 3)) (pow x 6)))))) x))
(/.f64 (fma.f64 (fma.f64 y (fma.f64 (/.f64 #s(literal -3/4 binary64) (pow.f64 x #s(literal 4 binary64))) y (/.f64 (/.f64 #s(literal 1 binary64) x) x)) (/.f64 (fma.f64 (*.f64 #s(literal -3/4 binary64) (pow.f64 y #s(literal 3 binary64))) #s(literal 1/2 binary64) (pow.f64 y #s(literal 3 binary64))) (pow.f64 x #s(literal 6 binary64)))) #s(literal 1/2 binary64) #s(literal -1 binary64)) x)
(* -1 x)
(neg.f64 x)
(* -1 (* x (+ 1 (* 1/2 (/ y (pow x 2))))))
(fma.f64 #s(literal -1/2 binary64) (/.f64 y x) (neg.f64 x))
(* -1 (* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (* 1/2 (/ y (pow x 2)))))))
(fma.f64 (fma.f64 (*.f64 #s(literal 1/8 binary64) y) (/.f64 y (pow.f64 x #s(literal 4 binary64))) #s(literal -1 binary64)) x (*.f64 (/.f64 #s(literal -1/2 binary64) x) y))
(* -1 (* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (+ (* 1/16 (/ (pow y 3) (pow x 6))) (* 1/2 (/ y (pow x 2))))))))
(fma.f64 (fma.f64 #s(literal -1/16 binary64) (/.f64 (pow.f64 y #s(literal 3 binary64)) (pow.f64 x #s(literal 6 binary64))) (fma.f64 (*.f64 #s(literal 1/8 binary64) y) (/.f64 y (pow.f64 x #s(literal 4 binary64))) #s(literal -1 binary64))) x (*.f64 (/.f64 #s(literal -1/2 binary64) x) y))
(pow x 2)
(*.f64 x x)
(* (pow x 2) (+ 1 (/ y (pow x 2))))
(fma.f64 x x y)
(* (pow x 2) (+ 1 (/ y (pow x 2))))
(fma.f64 x x y)
(* (pow x 2) (+ 1 (/ y (pow x 2))))
(fma.f64 x x y)

rewrite249.0ms (5.5%)

Memory
-43.0MiB live, 207.9MiB allocated
Rules
4 610×lower-fma.f32
4 608×lower-fma.f64
3 334×lower-*.f64
3 334×lower-*.f32
3 054×lower-/.f32
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
0725
01221
14820
224920
3183820
0837120
Stop Event
iter limit
node limit
iter limit
Counts
4 → 428
Calls
Call 1
Inputs
(/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y))))
(/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y)))
(sqrt.f64 (fma.f64 x x y))
(fma.f64 x x y)
Outputs
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>

eval81.0ms (1.8%)

Memory
17.5MiB live, 88.4MiB allocated
Compiler

Compiled 11 964 to 1 786 computations (85.1% saved)

prune13.0ms (0.3%)

Memory
-22.0MiB live, 29.3MiB allocated
Pruning

6 alts after pruning (1 fresh and 5 done)

PrunedKeptTotal
New5161517
Fresh000
Picked101
Done055
Total5176523
Accuracy
100.0%
Counts
523 → 6
Alt Table
Click to see full alt table
StatusAccuracyProgram
34.1%
(/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y))))
66.8%
(sqrt.f64 (fma.f64 x x y))
35.1%
(sqrt.f64 #s(approx (+ (* x x) y) (*.f64 x x)))
69.1%
#s(approx (sqrt (+ (* x x) y)) (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x))
34.2%
#s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y))
1.1%
#s(approx (sqrt (+ (* x x) y)) (neg.f64 x))
Compiler

Compiled 30 to 30 computations (0% saved)

simplify4.0ms (0.1%)

Memory
4.4MiB live, 4.4MiB allocated
Algorithm
egg-herbie
Localize:

Found 4 expressions of interest:

NewMetricScoreProgram
cost-diff0
(sqrt.f64 y)
cost-diff0
#s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y))
cost-diff0
(/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)))
cost-diff1408
(/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y))))
Rules
10×lower-*.f64
10×lower-*.f32
lower-/.f32
*-commutative
lift-/.f64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01037
01333
11833
22133
32333
42433
02430
Stop Event
iter limit
saturated
iter limit
Calls
Call 1
Inputs
(/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y))))
#s(literal 1 binary64)
(/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)))
#s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y))
(sqrt.f64 y)
y
Outputs
(/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y))))
#s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y))
#s(literal 1 binary64)
(/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)))
#s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y))
(sqrt.f64 y)
y

localize26.0ms (0.6%)

Memory
2.7MiB live, 38.8MiB allocated
Localize:

Found 4 expressions of interest:

NewMetricScoreProgram
accuracy0
(sqrt.f64 y)
accuracy0.11328125
(/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)))
accuracy0.17578125
(/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y))))
accuracy21.115880168227264
#s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y))
Samples
11.0ms172×0valid
9.0ms84×0invalid
Compiler

Compiled 30 to 11 computations (63.3% saved)

Precisions
Click to see histograms. Total time spent on operations: 10.0ms
ival-div: 3.0ms (29.4% of total)
ival-sqrt: 3.0ms (29.4% of total)
ival-mult: 2.0ms (19.6% of total)
ival-add: 1.0ms (9.8% of total)
ival-true: 0.0ms (0% of total)
exact: 0.0ms (0% of total)
ival-assert: 0.0ms (0% of total)

series5.0ms (0.1%)

Memory
8.9MiB live, 8.9MiB allocated
Counts
4 → 84
Calls
Call 1
Inputs
#s(alt (/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)))) (patch (/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)))) #<representation binary64>) () ())
#s(alt (/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y))) (patch (/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y))) #<representation binary64>) () ())
#s(alt #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)) (patch #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)) #<representation binary64>) () ())
#s(alt (sqrt.f64 y) (patch (sqrt.f64 y) #<representation binary64>) () ())
Outputs
#s(alt x (taylor 0 y) (#s(alt (/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)))) (patch (/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)))) #<representation binary64>) () ())) ())
#s(alt (+ x (* 1/2 (/ y x))) (taylor 0 y) (#s(alt (/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)))) (patch (/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)))) #<representation binary64>) () ())) ())
#s(alt (+ x (* y (+ (* -1/8 (/ y (pow x 3))) (* 1/2 (/ 1 x))))) (taylor 0 y) (#s(alt (/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)))) (patch (/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)))) #<representation binary64>) () ())) ())
#s(alt (+ x (* y (+ (* y (- (* 1/16 (/ y (pow x 5))) (* 1/8 (/ 1 (pow x 3))))) (* 1/2 (/ 1 x))))) (taylor 0 y) (#s(alt (/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)))) (patch (/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)))) #<representation binary64>) () ())) ())
#s(alt (/ 1 x) (taylor 0 y) (#s(alt (/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y))) (patch (/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y))) #<representation binary64>) () ())) ())
#s(alt (+ (* -1/2 (/ y (pow x 3))) (/ 1 x)) (taylor 0 y) (#s(alt (/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y))) (patch (/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y))) #<representation binary64>) () ())) ())
#s(alt (+ (* y (- (* 3/8 (/ y (pow x 5))) (* 1/2 (/ 1 (pow x 3))))) (/ 1 x)) (taylor 0 y) (#s(alt (/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y))) (patch (/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y))) #<representation binary64>) () ())) ())
#s(alt (+ (* y (- (* y (+ (* -5/16 (/ y (pow x 7))) (* 3/8 (/ 1 (pow x 5))))) (* 1/2 (/ 1 (pow x 3))))) (/ 1 x)) (taylor 0 y) (#s(alt (/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y))) (patch (/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y))) #<representation binary64>) () ())) ())
#s(alt x (taylor 0 y) (#s(alt #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)) (patch #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)) #<representation binary64>) () ())) ())
#s(alt (+ x (* 1/2 (/ y x))) (taylor 0 y) (#s(alt #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)) (patch #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)) #<representation binary64>) () ())) ())
#s(alt (+ x (* y (+ (* -1/8 (/ y (pow x 3))) (* 1/2 (/ 1 x))))) (taylor 0 y) (#s(alt #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)) (patch #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)) #<representation binary64>) () ())) ())
#s(alt (+ x (* y (+ (* y (- (* 1/16 (/ y (pow x 5))) (* 1/8 (/ 1 (pow x 3))))) (* 1/2 (/ 1 x))))) (taylor 0 y) (#s(alt #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)) (patch #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)) #<representation binary64>) () ())) ())
#s(alt (sqrt y) (taylor 0 y) (#s(alt (sqrt.f64 y) (patch (sqrt.f64 y) #<representation binary64>) () ())) ())
#s(alt (sqrt y) (taylor 0 y) (#s(alt (sqrt.f64 y) (patch (sqrt.f64 y) #<representation binary64>) () ())) ())
#s(alt (sqrt y) (taylor 0 y) (#s(alt (sqrt.f64 y) (patch (sqrt.f64 y) #<representation binary64>) () ())) ())
#s(alt (sqrt y) (taylor 0 y) (#s(alt (sqrt.f64 y) (patch (sqrt.f64 y) #<representation binary64>) () ())) ())
#s(alt (sqrt y) (taylor inf y) (#s(alt (/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)))) (patch (/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)))) #<representation binary64>) () ())) ())
#s(alt (* y (+ (sqrt (/ 1 y)) (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))))) (taylor inf y) (#s(alt (/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)))) (patch (/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)))) #<representation binary64>) () ())) ())
#s(alt (* y (+ (sqrt (/ 1 y)) (+ (* -1/8 (* (pow x 4) (sqrt (/ 1 (pow y 5))))) (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3)))))))) (taylor inf y) (#s(alt (/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)))) (patch (/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)))) #<representation binary64>) () ())) ())
#s(alt (* y (+ (sqrt (/ 1 y)) (+ (* -1/8 (* (pow x 4) (sqrt (/ 1 (pow y 5))))) (+ (* 1/16 (* (pow x 6) (sqrt (/ 1 (pow y 7))))) (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))))))) (taylor inf y) (#s(alt (/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)))) (patch (/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)))) #<representation binary64>) () ())) ())
#s(alt (sqrt (/ 1 y)) (taylor inf y) (#s(alt (/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y))) (patch (/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y))) #<representation binary64>) () ())) ())
#s(alt (+ (sqrt (/ 1 y)) (* -1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3)))))) (taylor inf y) (#s(alt (/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y))) (patch (/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y))) #<representation binary64>) () ())) ())
#s(alt (+ (sqrt (/ 1 y)) (+ (* -1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* 1/2 (* (pow x 4) (sqrt (/ 1 (pow y 5))))))) (taylor inf y) (#s(alt (/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y))) (patch (/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y))) #<representation binary64>) () ())) ())
#s(alt (+ (sqrt (/ 1 y)) (+ (* -1/2 (* (sqrt (/ 1 (pow y 7))) (+ (* 1/4 (* (pow x 4) y)) (pow x 6)))) (+ (* -1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* 1/2 (* (pow x 4) (sqrt (/ 1 (pow y 5)))))))) (taylor inf y) (#s(alt (/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y))) (patch (/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y))) #<representation binary64>) () ())) ())
#s(alt (sqrt y) (taylor inf y) (#s(alt #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)) (patch #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)) #<representation binary64>) () ())) ())
#s(alt (* y (+ (sqrt (/ 1 y)) (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))))) (taylor inf y) (#s(alt #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)) (patch #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)) #<representation binary64>) () ())) ())
#s(alt (* y (+ (sqrt (/ 1 y)) (+ (* -1/8 (* (pow x 4) (sqrt (/ 1 (pow y 5))))) (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3)))))))) (taylor inf y) (#s(alt #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)) (patch #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)) #<representation binary64>) () ())) ())
#s(alt (* y (+ (sqrt (/ 1 y)) (+ (* -1/8 (* (pow x 4) (sqrt (/ 1 (pow y 5))))) (+ (* 1/16 (* (pow x 6) (sqrt (/ 1 (pow y 7))))) (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))))))) (taylor inf y) (#s(alt #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)) (patch #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)) #<representation binary64>) () ())) ())
#s(alt (sqrt y) (taylor inf y) (#s(alt (sqrt.f64 y) (patch (sqrt.f64 y) #<representation binary64>) () ())) ())
#s(alt (sqrt y) (taylor inf y) (#s(alt (sqrt.f64 y) (patch (sqrt.f64 y) #<representation binary64>) () ())) ())
#s(alt (sqrt y) (taylor inf y) (#s(alt (sqrt.f64 y) (patch (sqrt.f64 y) #<representation binary64>) () ())) ())
#s(alt (sqrt y) (taylor inf y) (#s(alt (sqrt.f64 y) (patch (sqrt.f64 y) #<representation binary64>) () ())) ())
#s(alt (* -1 (* (sqrt y) (pow (sqrt -1) 2))) (taylor -inf y) (#s(alt (/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)))) (patch (/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)))) #<representation binary64>) () ())) ())
#s(alt (* -1 (* y (+ (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* (sqrt (/ 1 y)) (pow (sqrt -1) 2))))) (taylor -inf y) (#s(alt (/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)))) (patch (/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)))) #<representation binary64>) () ())) ())
#s(alt (* -1 (* y (+ (* -1/8 (* (/ (pow x 4) (pow (sqrt -1) 2)) (sqrt (/ 1 (pow y 5))))) (+ (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* (sqrt (/ 1 y)) (pow (sqrt -1) 2)))))) (taylor -inf y) (#s(alt (/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)))) (patch (/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)))) #<representation binary64>) () ())) ())
#s(alt (* -1 (* y (+ (* -1/8 (* (/ (pow x 4) (pow (sqrt -1) 2)) (sqrt (/ 1 (pow y 5))))) (+ (* 1/16 (* (/ (pow x 6) (pow (sqrt -1) 4)) (sqrt (/ 1 (pow y 7))))) (+ (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* (sqrt (/ 1 y)) (pow (sqrt -1) 2))))))) (taylor -inf y) (#s(alt (/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)))) (patch (/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)))) #<representation binary64>) () ())) ())
#s(alt (* (sqrt (/ 1 y)) (pow (sqrt -1) 2)) (taylor -inf y) (#s(alt (/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y))) (patch (/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y))) #<representation binary64>) () ())) ())
#s(alt (+ (* -1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* (sqrt (/ 1 y)) (pow (sqrt -1) 2))) (taylor -inf y) (#s(alt (/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y))) (patch (/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y))) #<representation binary64>) () ())) ())
#s(alt (+ (* -1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (+ (* 1/2 (* (pow x 4) (sqrt (/ 1 (pow y 5))))) (* (sqrt (/ 1 y)) (pow (sqrt -1) 2)))) (taylor -inf y) (#s(alt (/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y))) (patch (/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y))) #<representation binary64>) () ())) ())
#s(alt (+ (* -1 (/ (+ (* -1/2 (* (pow x 4) (sqrt y))) (* 1/2 (* (sqrt (/ 1 y)) (+ (* -1/4 (/ (* (pow x 4) y) (pow (sqrt -1) 2))) (pow x 6))))) (pow y 3))) (+ (* -1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* (sqrt (/ 1 y)) (pow (sqrt -1) 2)))) (taylor -inf y) (#s(alt (/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y))) (patch (/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y))) #<representation binary64>) () ())) ())
#s(alt (* -1 (* (sqrt y) (pow (sqrt -1) 2))) (taylor -inf y) (#s(alt #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)) (patch #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)) #<representation binary64>) () ())) ())
#s(alt (* -1 (* y (+ (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* (sqrt (/ 1 y)) (pow (sqrt -1) 2))))) (taylor -inf y) (#s(alt #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)) (patch #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)) #<representation binary64>) () ())) ())
#s(alt (* -1 (* y (+ (* -1/8 (* (/ (pow x 4) (pow (sqrt -1) 2)) (sqrt (/ 1 (pow y 5))))) (+ (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* (sqrt (/ 1 y)) (pow (sqrt -1) 2)))))) (taylor -inf y) (#s(alt #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)) (patch #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)) #<representation binary64>) () ())) ())
#s(alt (* -1 (* y (+ (* -1/8 (* (/ (pow x 4) (pow (sqrt -1) 2)) (sqrt (/ 1 (pow y 5))))) (+ (* 1/16 (* (/ (pow x 6) (pow (sqrt -1) 4)) (sqrt (/ 1 (pow y 7))))) (+ (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* (sqrt (/ 1 y)) (pow (sqrt -1) 2))))))) (taylor -inf y) (#s(alt #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)) (patch #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)) #<representation binary64>) () ())) ())
#s(alt (* -1 (* (sqrt y) (pow (sqrt -1) 2))) (taylor -inf y) (#s(alt (sqrt.f64 y) (patch (sqrt.f64 y) #<representation binary64>) () ())) ())
#s(alt (* -1 (* (sqrt y) (pow (sqrt -1) 2))) (taylor -inf y) (#s(alt (sqrt.f64 y) (patch (sqrt.f64 y) #<representation binary64>) () ())) ())
#s(alt (* -1 (* (sqrt y) (pow (sqrt -1) 2))) (taylor -inf y) (#s(alt (sqrt.f64 y) (patch (sqrt.f64 y) #<representation binary64>) () ())) ())
#s(alt (* -1 (* (sqrt y) (pow (sqrt -1) 2))) (taylor -inf y) (#s(alt (sqrt.f64 y) (patch (sqrt.f64 y) #<representation binary64>) () ())) ())
#s(alt (sqrt y) (taylor 0 x) (#s(alt (/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)))) (patch (/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)))) #<representation binary64>) () ())) ())
#s(alt (+ (sqrt y) (* 1/2 (* (pow x 2) (sqrt (/ 1 y))))) (taylor 0 x) (#s(alt (/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)))) (patch (/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)))) #<representation binary64>) () ())) ())
#s(alt (+ (sqrt y) (* (pow x 2) (+ (* -1/8 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* 1/2 (sqrt (/ 1 y)))))) (taylor 0 x) (#s(alt (/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)))) (patch (/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)))) #<representation binary64>) () ())) ())
#s(alt (+ (sqrt y) (* (pow x 2) (+ (* 1/2 (sqrt (/ 1 y))) (* (pow x 2) (+ (* -1/8 (sqrt (/ 1 (pow y 3)))) (* 1/16 (* (pow x 2) (sqrt (/ 1 (pow y 5)))))))))) (taylor 0 x) (#s(alt (/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)))) (patch (/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)))) #<representation binary64>) () ())) ())
#s(alt (sqrt (/ 1 y)) (taylor 0 x) (#s(alt (/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y))) (patch (/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y))) #<representation binary64>) () ())) ())
#s(alt (+ (sqrt (/ 1 y)) (* -1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3)))))) (taylor 0 x) (#s(alt (/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y))) (patch (/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y))) #<representation binary64>) () ())) ())
#s(alt (+ (sqrt (/ 1 y)) (* (pow x 2) (+ (* -1/2 (sqrt (/ 1 (pow y 3)))) (* 3/8 (* (pow x 2) (sqrt (/ 1 (pow y 5)))))))) (taylor 0 x) (#s(alt (/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y))) (patch (/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y))) #<representation binary64>) () ())) ())
#s(alt (+ (sqrt (/ 1 y)) (* (pow x 2) (+ (* -1/2 (sqrt (/ 1 (pow y 3)))) (* (pow x 2) (+ (* -5/16 (* (pow x 2) (sqrt (/ 1 (pow y 7))))) (* 3/8 (sqrt (/ 1 (pow y 5))))))))) (taylor 0 x) (#s(alt (/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y))) (patch (/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y))) #<representation binary64>) () ())) ())
#s(alt (sqrt y) (taylor 0 x) (#s(alt #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)) (patch #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)) #<representation binary64>) () ())) ())
#s(alt (+ (sqrt y) (* 1/2 (* (pow x 2) (sqrt (/ 1 y))))) (taylor 0 x) (#s(alt #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)) (patch #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)) #<representation binary64>) () ())) ())
#s(alt (+ (sqrt y) (* (pow x 2) (+ (* -1/8 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* 1/2 (sqrt (/ 1 y)))))) (taylor 0 x) (#s(alt #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)) (patch #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)) #<representation binary64>) () ())) ())
#s(alt (+ (sqrt y) (* (pow x 2) (+ (* 1/2 (sqrt (/ 1 y))) (* (pow x 2) (+ (* -1/8 (sqrt (/ 1 (pow y 3)))) (* 1/16 (* (pow x 2) (sqrt (/ 1 (pow y 5)))))))))) (taylor 0 x) (#s(alt #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)) (patch #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)) #<representation binary64>) () ())) ())
#s(alt x (taylor inf x) (#s(alt (/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)))) (patch (/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)))) #<representation binary64>) () ())) ())
#s(alt (* x (+ 1 (* 1/2 (/ y (pow x 2))))) (taylor inf x) (#s(alt (/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)))) (patch (/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)))) #<representation binary64>) () ())) ())
#s(alt (* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (* 1/2 (/ y (pow x 2)))))) (taylor inf x) (#s(alt (/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)))) (patch (/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)))) #<representation binary64>) () ())) ())
#s(alt (* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (+ (* 1/16 (/ (pow y 3) (pow x 6))) (* 1/2 (/ y (pow x 2))))))) (taylor inf x) (#s(alt (/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)))) (patch (/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)))) #<representation binary64>) () ())) ())
#s(alt (/ 1 x) (taylor inf x) (#s(alt (/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y))) (patch (/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y))) #<representation binary64>) () ())) ())
#s(alt (/ (+ 1 (* -1/2 (/ y (pow x 2)))) x) (taylor inf x) (#s(alt (/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y))) (patch (/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y))) #<representation binary64>) () ())) ())
#s(alt (/ (+ 1 (+ (* -1/2 (/ y (pow x 2))) (* -1/2 (/ (+ (* -1 (pow y 2)) (* 1/4 (pow y 2))) (pow x 4))))) x) (taylor inf x) (#s(alt (/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y))) (patch (/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y))) #<representation binary64>) () ())) ())
#s(alt (/ (+ 1 (+ (* -1/2 (/ y (pow x 2))) (+ (* -1/2 (/ (+ (* -1 (pow y 2)) (* 1/4 (pow y 2))) (pow x 4))) (* -1/2 (/ (+ (* 1/2 (* y (+ (* -1 (pow y 2)) (* 1/4 (pow y 2))))) (pow y 3)) (pow x 6)))))) x) (taylor inf x) (#s(alt (/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y))) (patch (/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y))) #<representation binary64>) () ())) ())
#s(alt x (taylor inf x) (#s(alt #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)) (patch #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)) #<representation binary64>) () ())) ())
#s(alt (* x (+ 1 (* 1/2 (/ y (pow x 2))))) (taylor inf x) (#s(alt #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)) (patch #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)) #<representation binary64>) () ())) ())
#s(alt (* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (* 1/2 (/ y (pow x 2)))))) (taylor inf x) (#s(alt #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)) (patch #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)) #<representation binary64>) () ())) ())
#s(alt (* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (+ (* 1/16 (/ (pow y 3) (pow x 6))) (* 1/2 (/ y (pow x 2))))))) (taylor inf x) (#s(alt #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)) (patch #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)) #<representation binary64>) () ())) ())
#s(alt (* -1 x) (taylor -inf x) (#s(alt (/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)))) (patch (/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)))) #<representation binary64>) () ())) ())
#s(alt (* -1 (* x (+ 1 (* 1/2 (/ y (pow x 2)))))) (taylor -inf x) (#s(alt (/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)))) (patch (/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)))) #<representation binary64>) () ())) ())
#s(alt (* -1 (* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (* 1/2 (/ y (pow x 2))))))) (taylor -inf x) (#s(alt (/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)))) (patch (/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)))) #<representation binary64>) () ())) ())
#s(alt (* -1 (* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (+ (* 1/16 (/ (pow y 3) (pow x 6))) (* 1/2 (/ y (pow x 2)))))))) (taylor -inf x) (#s(alt (/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)))) (patch (/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)))) #<representation binary64>) () ())) ())
#s(alt (/ -1 x) (taylor -inf x) (#s(alt (/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y))) (patch (/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y))) #<representation binary64>) () ())) ())
#s(alt (* -1 (/ (+ 1 (* -1/2 (/ y (pow x 2)))) x)) (taylor -inf x) (#s(alt (/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y))) (patch (/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y))) #<representation binary64>) () ())) ())
#s(alt (* -1 (/ (+ 1 (+ (* -1/2 (/ y (pow x 2))) (* -1/2 (/ (+ (* -1 (pow y 2)) (* 1/4 (pow y 2))) (pow x 4))))) x)) (taylor -inf x) (#s(alt (/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y))) (patch (/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y))) #<representation binary64>) () ())) ())
#s(alt (* -1 (/ (+ 1 (+ (* -1/2 (/ y (pow x 2))) (+ (* -1/2 (/ (+ (* -1 (pow y 2)) (* 1/4 (pow y 2))) (pow x 4))) (* -1/2 (/ (+ (* 1/2 (* y (+ (* -1 (pow y 2)) (* 1/4 (pow y 2))))) (pow y 3)) (pow x 6)))))) x)) (taylor -inf x) (#s(alt (/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y))) (patch (/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y))) #<representation binary64>) () ())) ())
#s(alt (* -1 x) (taylor -inf x) (#s(alt #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)) (patch #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)) #<representation binary64>) () ())) ())
#s(alt (* -1 (* x (+ 1 (* 1/2 (/ y (pow x 2)))))) (taylor -inf x) (#s(alt #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)) (patch #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)) #<representation binary64>) () ())) ())
#s(alt (* -1 (* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (* 1/2 (/ y (pow x 2))))))) (taylor -inf x) (#s(alt #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)) (patch #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)) #<representation binary64>) () ())) ())
#s(alt (* -1 (* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (+ (* 1/16 (/ (pow y 3) (pow x 6))) (* 1/2 (/ y (pow x 2)))))))) (taylor -inf x) (#s(alt #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)) (patch #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)) #<representation binary64>) () ())) ())
Calls

6 calls:

TimeVariablePointExpression
1.0ms
y
@-inf
((/ 1 (/ 1 (sqrt (+ (* x x) y)))) (/ 1 (sqrt (+ (* x x) y))) (sqrt (+ (* x x) y)) (sqrt y))
0.0ms
y
@inf
((/ 1 (/ 1 (sqrt (+ (* x x) y)))) (/ 1 (sqrt (+ (* x x) y))) (sqrt (+ (* x x) y)) (sqrt y))
0.0ms
x
@inf
((/ 1 (/ 1 (sqrt (+ (* x x) y)))) (/ 1 (sqrt (+ (* x x) y))) (sqrt (+ (* x x) y)) (sqrt y))
0.0ms
y
@0
((/ 1 (/ 1 (sqrt (+ (* x x) y)))) (/ 1 (sqrt (+ (* x x) y))) (sqrt (+ (* x x) y)) (sqrt y))
0.0ms
x
@-inf
((/ 1 (/ 1 (sqrt (+ (* x x) y)))) (/ 1 (sqrt (+ (* x x) y))) (sqrt (+ (* x x) y)) (sqrt y))

simplify208.0ms (4.6%)

Memory
14.1MiB live, 331.0MiB allocated
Algorithm
egg-herbie
Rules
21 888×lower-fma.f64
21 888×lower-fma.f32
6 416×lower-*.f64
6 416×lower-*.f32
2 352×lower-+.f64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
02081527
16091471
219481442
360091399
083191296
Stop Event
iter limit
node limit
Counts
84 → 80
Calls
Call 1
Inputs
x
(+ x (* 1/2 (/ y x)))
(+ x (* y (+ (* -1/8 (/ y (pow x 3))) (* 1/2 (/ 1 x)))))
(+ x (* y (+ (* y (- (* 1/16 (/ y (pow x 5))) (* 1/8 (/ 1 (pow x 3))))) (* 1/2 (/ 1 x)))))
(/ 1 x)
(+ (* -1/2 (/ y (pow x 3))) (/ 1 x))
(+ (* y (- (* 3/8 (/ y (pow x 5))) (* 1/2 (/ 1 (pow x 3))))) (/ 1 x))
(+ (* y (- (* y (+ (* -5/16 (/ y (pow x 7))) (* 3/8 (/ 1 (pow x 5))))) (* 1/2 (/ 1 (pow x 3))))) (/ 1 x))
x
(+ x (* 1/2 (/ y x)))
(+ x (* y (+ (* -1/8 (/ y (pow x 3))) (* 1/2 (/ 1 x)))))
(+ x (* y (+ (* y (- (* 1/16 (/ y (pow x 5))) (* 1/8 (/ 1 (pow x 3))))) (* 1/2 (/ 1 x)))))
(sqrt y)
(sqrt y)
(sqrt y)
(sqrt y)
(sqrt y)
(* y (+ (sqrt (/ 1 y)) (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3)))))))
(* y (+ (sqrt (/ 1 y)) (+ (* -1/8 (* (pow x 4) (sqrt (/ 1 (pow y 5))))) (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))))))
(* y (+ (sqrt (/ 1 y)) (+ (* -1/8 (* (pow x 4) (sqrt (/ 1 (pow y 5))))) (+ (* 1/16 (* (pow x 6) (sqrt (/ 1 (pow y 7))))) (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3)))))))))
(sqrt (/ 1 y))
(+ (sqrt (/ 1 y)) (* -1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))))
(+ (sqrt (/ 1 y)) (+ (* -1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* 1/2 (* (pow x 4) (sqrt (/ 1 (pow y 5)))))))
(+ (sqrt (/ 1 y)) (+ (* -1/2 (* (sqrt (/ 1 (pow y 7))) (+ (* 1/4 (* (pow x 4) y)) (pow x 6)))) (+ (* -1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* 1/2 (* (pow x 4) (sqrt (/ 1 (pow y 5))))))))
(sqrt y)
(* y (+ (sqrt (/ 1 y)) (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3)))))))
(* y (+ (sqrt (/ 1 y)) (+ (* -1/8 (* (pow x 4) (sqrt (/ 1 (pow y 5))))) (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))))))
(* y (+ (sqrt (/ 1 y)) (+ (* -1/8 (* (pow x 4) (sqrt (/ 1 (pow y 5))))) (+ (* 1/16 (* (pow x 6) (sqrt (/ 1 (pow y 7))))) (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3)))))))))
(sqrt y)
(sqrt y)
(sqrt y)
(sqrt y)
(* -1 (* (sqrt y) (pow (sqrt -1) 2)))
(* -1 (* y (+ (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* (sqrt (/ 1 y)) (pow (sqrt -1) 2)))))
(* -1 (* y (+ (* -1/8 (* (/ (pow x 4) (pow (sqrt -1) 2)) (sqrt (/ 1 (pow y 5))))) (+ (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* (sqrt (/ 1 y)) (pow (sqrt -1) 2))))))
(* -1 (* y (+ (* -1/8 (* (/ (pow x 4) (pow (sqrt -1) 2)) (sqrt (/ 1 (pow y 5))))) (+ (* 1/16 (* (/ (pow x 6) (pow (sqrt -1) 4)) (sqrt (/ 1 (pow y 7))))) (+ (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* (sqrt (/ 1 y)) (pow (sqrt -1) 2)))))))
(* (sqrt (/ 1 y)) (pow (sqrt -1) 2))
(+ (* -1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* (sqrt (/ 1 y)) (pow (sqrt -1) 2)))
(+ (* -1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (+ (* 1/2 (* (pow x 4) (sqrt (/ 1 (pow y 5))))) (* (sqrt (/ 1 y)) (pow (sqrt -1) 2))))
(+ (* -1 (/ (+ (* -1/2 (* (pow x 4) (sqrt y))) (* 1/2 (* (sqrt (/ 1 y)) (+ (* -1/4 (/ (* (pow x 4) y) (pow (sqrt -1) 2))) (pow x 6))))) (pow y 3))) (+ (* -1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* (sqrt (/ 1 y)) (pow (sqrt -1) 2))))
(* -1 (* (sqrt y) (pow (sqrt -1) 2)))
(* -1 (* y (+ (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* (sqrt (/ 1 y)) (pow (sqrt -1) 2)))))
(* -1 (* y (+ (* -1/8 (* (/ (pow x 4) (pow (sqrt -1) 2)) (sqrt (/ 1 (pow y 5))))) (+ (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* (sqrt (/ 1 y)) (pow (sqrt -1) 2))))))
(* -1 (* y (+ (* -1/8 (* (/ (pow x 4) (pow (sqrt -1) 2)) (sqrt (/ 1 (pow y 5))))) (+ (* 1/16 (* (/ (pow x 6) (pow (sqrt -1) 4)) (sqrt (/ 1 (pow y 7))))) (+ (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* (sqrt (/ 1 y)) (pow (sqrt -1) 2)))))))
(* -1 (* (sqrt y) (pow (sqrt -1) 2)))
(* -1 (* (sqrt y) (pow (sqrt -1) 2)))
(* -1 (* (sqrt y) (pow (sqrt -1) 2)))
(* -1 (* (sqrt y) (pow (sqrt -1) 2)))
(sqrt y)
(+ (sqrt y) (* 1/2 (* (pow x 2) (sqrt (/ 1 y)))))
(+ (sqrt y) (* (pow x 2) (+ (* -1/8 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* 1/2 (sqrt (/ 1 y))))))
(+ (sqrt y) (* (pow x 2) (+ (* 1/2 (sqrt (/ 1 y))) (* (pow x 2) (+ (* -1/8 (sqrt (/ 1 (pow y 3)))) (* 1/16 (* (pow x 2) (sqrt (/ 1 (pow y 5))))))))))
(sqrt (/ 1 y))
(+ (sqrt (/ 1 y)) (* -1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))))
(+ (sqrt (/ 1 y)) (* (pow x 2) (+ (* -1/2 (sqrt (/ 1 (pow y 3)))) (* 3/8 (* (pow x 2) (sqrt (/ 1 (pow y 5))))))))
(+ (sqrt (/ 1 y)) (* (pow x 2) (+ (* -1/2 (sqrt (/ 1 (pow y 3)))) (* (pow x 2) (+ (* -5/16 (* (pow x 2) (sqrt (/ 1 (pow y 7))))) (* 3/8 (sqrt (/ 1 (pow y 5)))))))))
(sqrt y)
(+ (sqrt y) (* 1/2 (* (pow x 2) (sqrt (/ 1 y)))))
(+ (sqrt y) (* (pow x 2) (+ (* -1/8 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* 1/2 (sqrt (/ 1 y))))))
(+ (sqrt y) (* (pow x 2) (+ (* 1/2 (sqrt (/ 1 y))) (* (pow x 2) (+ (* -1/8 (sqrt (/ 1 (pow y 3)))) (* 1/16 (* (pow x 2) (sqrt (/ 1 (pow y 5))))))))))
x
(* x (+ 1 (* 1/2 (/ y (pow x 2)))))
(* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (* 1/2 (/ y (pow x 2))))))
(* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (+ (* 1/16 (/ (pow y 3) (pow x 6))) (* 1/2 (/ y (pow x 2)))))))
(/ 1 x)
(/ (+ 1 (* -1/2 (/ y (pow x 2)))) x)
(/ (+ 1 (+ (* -1/2 (/ y (pow x 2))) (* -1/2 (/ (+ (* -1 (pow y 2)) (* 1/4 (pow y 2))) (pow x 4))))) x)
(/ (+ 1 (+ (* -1/2 (/ y (pow x 2))) (+ (* -1/2 (/ (+ (* -1 (pow y 2)) (* 1/4 (pow y 2))) (pow x 4))) (* -1/2 (/ (+ (* 1/2 (* y (+ (* -1 (pow y 2)) (* 1/4 (pow y 2))))) (pow y 3)) (pow x 6)))))) x)
x
(* x (+ 1 (* 1/2 (/ y (pow x 2)))))
(* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (* 1/2 (/ y (pow x 2))))))
(* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (+ (* 1/16 (/ (pow y 3) (pow x 6))) (* 1/2 (/ y (pow x 2)))))))
(* -1 x)
(* -1 (* x (+ 1 (* 1/2 (/ y (pow x 2))))))
(* -1 (* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (* 1/2 (/ y (pow x 2)))))))
(* -1 (* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (+ (* 1/16 (/ (pow y 3) (pow x 6))) (* 1/2 (/ y (pow x 2))))))))
(/ -1 x)
(* -1 (/ (+ 1 (* -1/2 (/ y (pow x 2)))) x))
(* -1 (/ (+ 1 (+ (* -1/2 (/ y (pow x 2))) (* -1/2 (/ (+ (* -1 (pow y 2)) (* 1/4 (pow y 2))) (pow x 4))))) x))
(* -1 (/ (+ 1 (+ (* -1/2 (/ y (pow x 2))) (+ (* -1/2 (/ (+ (* -1 (pow y 2)) (* 1/4 (pow y 2))) (pow x 4))) (* -1/2 (/ (+ (* 1/2 (* y (+ (* -1 (pow y 2)) (* 1/4 (pow y 2))))) (pow y 3)) (pow x 6)))))) x))
(* -1 x)
(* -1 (* x (+ 1 (* 1/2 (/ y (pow x 2))))))
(* -1 (* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (* 1/2 (/ y (pow x 2)))))))
(* -1 (* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (+ (* 1/16 (/ (pow y 3) (pow x 6))) (* 1/2 (/ y (pow x 2))))))))
Outputs
x
(+ x (* 1/2 (/ y x)))
(fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x)
(+ x (* y (+ (* -1/8 (/ y (pow x 3))) (* 1/2 (/ 1 x)))))
(fma.f64 (fma.f64 (/.f64 #s(literal -1/8 binary64) (pow.f64 x #s(literal 3 binary64))) y (/.f64 #s(literal 1/2 binary64) x)) y x)
(+ x (* y (+ (* y (- (* 1/16 (/ y (pow x 5))) (* 1/8 (/ 1 (pow x 3))))) (* 1/2 (/ 1 x)))))
(fma.f64 (fma.f64 (fma.f64 (/.f64 y (pow.f64 x #s(literal 5 binary64))) #s(literal 1/16 binary64) (/.f64 #s(literal -1/8 binary64) (pow.f64 x #s(literal 3 binary64)))) y (/.f64 #s(literal 1/2 binary64) x)) y x)
(/ 1 x)
(/.f64 #s(literal 1 binary64) x)
(+ (* -1/2 (/ y (pow x 3))) (/ 1 x))
(fma.f64 (/.f64 #s(literal -1/2 binary64) (pow.f64 x #s(literal 3 binary64))) y (/.f64 #s(literal 1 binary64) x))
(+ (* y (- (* 3/8 (/ y (pow x 5))) (* 1/2 (/ 1 (pow x 3))))) (/ 1 x))
(fma.f64 (fma.f64 (/.f64 #s(literal 3/8 binary64) (pow.f64 x #s(literal 5 binary64))) y (/.f64 #s(literal -1/2 binary64) (pow.f64 x #s(literal 3 binary64)))) y (/.f64 #s(literal 1 binary64) x))
(+ (* y (- (* y (+ (* -5/16 (/ y (pow x 7))) (* 3/8 (/ 1 (pow x 5))))) (* 1/2 (/ 1 (pow x 3))))) (/ 1 x))
(fma.f64 (fma.f64 (fma.f64 (/.f64 y (pow.f64 x #s(literal 7 binary64))) #s(literal -5/16 binary64) (/.f64 #s(literal 3/8 binary64) (pow.f64 x #s(literal 5 binary64)))) y (/.f64 #s(literal -1/2 binary64) (pow.f64 x #s(literal 3 binary64)))) y (/.f64 #s(literal 1 binary64) x))
x
(+ x (* 1/2 (/ y x)))
(fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x)
(+ x (* y (+ (* -1/8 (/ y (pow x 3))) (* 1/2 (/ 1 x)))))
(fma.f64 (fma.f64 (/.f64 #s(literal -1/8 binary64) (pow.f64 x #s(literal 3 binary64))) y (/.f64 #s(literal 1/2 binary64) x)) y x)
(+ x (* y (+ (* y (- (* 1/16 (/ y (pow x 5))) (* 1/8 (/ 1 (pow x 3))))) (* 1/2 (/ 1 x)))))
(fma.f64 (fma.f64 (fma.f64 (/.f64 y (pow.f64 x #s(literal 5 binary64))) #s(literal 1/16 binary64) (/.f64 #s(literal -1/8 binary64) (pow.f64 x #s(literal 3 binary64)))) y (/.f64 #s(literal 1/2 binary64) x)) y x)
(sqrt y)
(sqrt.f64 y)
(sqrt y)
(sqrt.f64 y)
(sqrt y)
(sqrt.f64 y)
(sqrt y)
(sqrt.f64 y)
(sqrt y)
(sqrt.f64 y)
(* y (+ (sqrt (/ 1 y)) (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3)))))))
(*.f64 (fma.f64 (*.f64 (*.f64 x x) #s(literal 1/2 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 3 binary64)))) (sqrt.f64 (/.f64 #s(literal 1 binary64) y))) y)
(* y (+ (sqrt (/ 1 y)) (+ (* -1/8 (* (pow x 4) (sqrt (/ 1 (pow y 5))))) (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))))))
(*.f64 (fma.f64 (*.f64 (pow.f64 x #s(literal 4 binary64)) #s(literal -1/8 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 5 binary64)))) (fma.f64 (*.f64 (*.f64 x x) #s(literal 1/2 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 3 binary64)))) (sqrt.f64 (/.f64 #s(literal 1 binary64) y)))) y)
(* y (+ (sqrt (/ 1 y)) (+ (* -1/8 (* (pow x 4) (sqrt (/ 1 (pow y 5))))) (+ (* 1/16 (* (pow x 6) (sqrt (/ 1 (pow y 7))))) (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3)))))))))
(*.f64 (fma.f64 (*.f64 (pow.f64 x #s(literal 6 binary64)) #s(literal 1/16 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 7 binary64)))) (fma.f64 (*.f64 (pow.f64 x #s(literal 4 binary64)) #s(literal -1/8 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 5 binary64)))) (fma.f64 (*.f64 (*.f64 x x) #s(literal 1/2 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 3 binary64)))) (sqrt.f64 (/.f64 #s(literal 1 binary64) y))))) y)
(sqrt (/ 1 y))
(sqrt.f64 (/.f64 #s(literal 1 binary64) y))
(+ (sqrt (/ 1 y)) (* -1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))))
(fma.f64 (*.f64 (*.f64 x x) #s(literal -1/2 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 3 binary64)))) (sqrt.f64 (/.f64 #s(literal 1 binary64) y)))
(+ (sqrt (/ 1 y)) (+ (* -1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* 1/2 (* (pow x 4) (sqrt (/ 1 (pow y 5)))))))
(fma.f64 (*.f64 (*.f64 #s(literal -1/2 binary64) x) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 3 binary64))))) x (fma.f64 (*.f64 (pow.f64 x #s(literal 4 binary64)) #s(literal 1/2 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 5 binary64)))) (sqrt.f64 (/.f64 #s(literal 1 binary64) y))))
(+ (sqrt (/ 1 y)) (+ (* -1/2 (* (sqrt (/ 1 (pow y 7))) (+ (* 1/4 (* (pow x 4) y)) (pow x 6)))) (+ (* -1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* 1/2 (* (pow x 4) (sqrt (/ 1 (pow y 5))))))))
(fma.f64 (fma.f64 (fma.f64 (*.f64 (pow.f64 x #s(literal 4 binary64)) y) #s(literal 1/4 binary64) (pow.f64 x #s(literal 6 binary64))) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 7 binary64)))) (*.f64 (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 3 binary64)))) (*.f64 x x))) #s(literal -1/2 binary64) (fma.f64 (*.f64 (pow.f64 x #s(literal 4 binary64)) #s(literal 1/2 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 5 binary64)))) (sqrt.f64 (/.f64 #s(literal 1 binary64) y))))
(sqrt y)
(sqrt.f64 y)
(* y (+ (sqrt (/ 1 y)) (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3)))))))
(*.f64 (fma.f64 (*.f64 (*.f64 x x) #s(literal 1/2 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 3 binary64)))) (sqrt.f64 (/.f64 #s(literal 1 binary64) y))) y)
(* y (+ (sqrt (/ 1 y)) (+ (* -1/8 (* (pow x 4) (sqrt (/ 1 (pow y 5))))) (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))))))
(*.f64 (fma.f64 (*.f64 (pow.f64 x #s(literal 4 binary64)) #s(literal -1/8 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 5 binary64)))) (fma.f64 (*.f64 (*.f64 x x) #s(literal 1/2 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 3 binary64)))) (sqrt.f64 (/.f64 #s(literal 1 binary64) y)))) y)
(* y (+ (sqrt (/ 1 y)) (+ (* -1/8 (* (pow x 4) (sqrt (/ 1 (pow y 5))))) (+ (* 1/16 (* (pow x 6) (sqrt (/ 1 (pow y 7))))) (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3)))))))))
(*.f64 (fma.f64 (*.f64 (pow.f64 x #s(literal 6 binary64)) #s(literal 1/16 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 7 binary64)))) (fma.f64 (*.f64 (pow.f64 x #s(literal 4 binary64)) #s(literal -1/8 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 5 binary64)))) (fma.f64 (*.f64 (*.f64 x x) #s(literal 1/2 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 3 binary64)))) (sqrt.f64 (/.f64 #s(literal 1 binary64) y))))) y)
(sqrt y)
(sqrt.f64 y)
(sqrt y)
(sqrt.f64 y)
(sqrt y)
(sqrt.f64 y)
(sqrt y)
(sqrt.f64 y)
(* -1 (* (sqrt y) (pow (sqrt -1) 2)))
(sqrt.f64 y)
(* -1 (* y (+ (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* (sqrt (/ 1 y)) (pow (sqrt -1) 2)))))
(*.f64 (fma.f64 (*.f64 (*.f64 x x) #s(literal -1/2 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 3 binary64)))) (sqrt.f64 (/.f64 #s(literal 1 binary64) y))) y)
(* -1 (* y (+ (* -1/8 (* (/ (pow x 4) (pow (sqrt -1) 2)) (sqrt (/ 1 (pow y 5))))) (+ (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* (sqrt (/ 1 y)) (pow (sqrt -1) 2))))))
(*.f64 (fma.f64 (*.f64 (*.f64 x x) #s(literal -1/2 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 3 binary64)))) (fma.f64 (*.f64 (pow.f64 x #s(literal 4 binary64)) #s(literal -1/8 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 5 binary64)))) (sqrt.f64 (/.f64 #s(literal 1 binary64) y)))) y)
(* -1 (* y (+ (* -1/8 (* (/ (pow x 4) (pow (sqrt -1) 2)) (sqrt (/ 1 (pow y 5))))) (+ (* 1/16 (* (/ (pow x 6) (pow (sqrt -1) 4)) (sqrt (/ 1 (pow y 7))))) (+ (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* (sqrt (/ 1 y)) (pow (sqrt -1) 2)))))))
(*.f64 (fma.f64 #s(literal -1/16 binary64) (/.f64 (*.f64 (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 7 binary64)))) (pow.f64 x #s(literal 6 binary64))) (pow.f64 (sqrt.f64 #s(literal -1 binary64)) #s(literal 4 binary64))) (fma.f64 (*.f64 (*.f64 x x) #s(literal -1/2 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 3 binary64)))) (fma.f64 (*.f64 (pow.f64 x #s(literal 4 binary64)) #s(literal -1/8 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 5 binary64)))) (sqrt.f64 (/.f64 #s(literal 1 binary64) y))))) y)
(* (sqrt (/ 1 y)) (pow (sqrt -1) 2))
(neg.f64 (sqrt.f64 (/.f64 #s(literal 1 binary64) y)))
(+ (* -1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* (sqrt (/ 1 y)) (pow (sqrt -1) 2)))
(fma.f64 (*.f64 (*.f64 #s(literal -1/2 binary64) x) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 3 binary64))))) x (neg.f64 (sqrt.f64 (/.f64 #s(literal 1 binary64) y))))
(+ (* -1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (+ (* 1/2 (* (pow x 4) (sqrt (/ 1 (pow y 5))))) (* (sqrt (/ 1 y)) (pow (sqrt -1) 2))))
(fma.f64 (*.f64 (*.f64 #s(literal -1/2 binary64) x) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 3 binary64))))) x (fma.f64 (*.f64 (pow.f64 x #s(literal 4 binary64)) #s(literal 1/2 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 5 binary64)))) (neg.f64 (sqrt.f64 (/.f64 #s(literal 1 binary64) y)))))
(+ (* -1 (/ (+ (* -1/2 (* (pow x 4) (sqrt y))) (* 1/2 (* (sqrt (/ 1 y)) (+ (* -1/4 (/ (* (pow x 4) y) (pow (sqrt -1) 2))) (pow x 6))))) (pow y 3))) (+ (* -1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* (sqrt (/ 1 y)) (pow (sqrt -1) 2))))
(fma.f64 (*.f64 #s(literal -1/2 binary64) x) (*.f64 (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 3 binary64)))) x) (-.f64 (/.f64 (fma.f64 (*.f64 (fma.f64 (*.f64 (pow.f64 x #s(literal 4 binary64)) y) #s(literal 1/4 binary64) (pow.f64 x #s(literal 6 binary64))) (sqrt.f64 (/.f64 #s(literal 1 binary64) y))) #s(literal -1/2 binary64) (*.f64 (*.f64 (pow.f64 x #s(literal 4 binary64)) (sqrt.f64 y)) #s(literal 1/2 binary64))) (pow.f64 y #s(literal 3 binary64))) (sqrt.f64 (/.f64 #s(literal 1 binary64) y))))
(* -1 (* (sqrt y) (pow (sqrt -1) 2)))
(sqrt.f64 y)
(* -1 (* y (+ (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* (sqrt (/ 1 y)) (pow (sqrt -1) 2)))))
(*.f64 (fma.f64 (*.f64 (*.f64 x x) #s(literal -1/2 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 3 binary64)))) (sqrt.f64 (/.f64 #s(literal 1 binary64) y))) y)
(* -1 (* y (+ (* -1/8 (* (/ (pow x 4) (pow (sqrt -1) 2)) (sqrt (/ 1 (pow y 5))))) (+ (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* (sqrt (/ 1 y)) (pow (sqrt -1) 2))))))
(*.f64 (fma.f64 (*.f64 (*.f64 x x) #s(literal -1/2 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 3 binary64)))) (fma.f64 (*.f64 (pow.f64 x #s(literal 4 binary64)) #s(literal -1/8 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 5 binary64)))) (sqrt.f64 (/.f64 #s(literal 1 binary64) y)))) y)
(* -1 (* y (+ (* -1/8 (* (/ (pow x 4) (pow (sqrt -1) 2)) (sqrt (/ 1 (pow y 5))))) (+ (* 1/16 (* (/ (pow x 6) (pow (sqrt -1) 4)) (sqrt (/ 1 (pow y 7))))) (+ (* 1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* (sqrt (/ 1 y)) (pow (sqrt -1) 2)))))))
(*.f64 (fma.f64 #s(literal -1/16 binary64) (/.f64 (*.f64 (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 7 binary64)))) (pow.f64 x #s(literal 6 binary64))) (pow.f64 (sqrt.f64 #s(literal -1 binary64)) #s(literal 4 binary64))) (fma.f64 (*.f64 (*.f64 x x) #s(literal -1/2 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 3 binary64)))) (fma.f64 (*.f64 (pow.f64 x #s(literal 4 binary64)) #s(literal -1/8 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 5 binary64)))) (sqrt.f64 (/.f64 #s(literal 1 binary64) y))))) y)
(* -1 (* (sqrt y) (pow (sqrt -1) 2)))
(sqrt.f64 y)
(* -1 (* (sqrt y) (pow (sqrt -1) 2)))
(sqrt.f64 y)
(* -1 (* (sqrt y) (pow (sqrt -1) 2)))
(sqrt.f64 y)
(* -1 (* (sqrt y) (pow (sqrt -1) 2)))
(sqrt.f64 y)
(sqrt y)
(sqrt.f64 y)
(+ (sqrt y) (* 1/2 (* (pow x 2) (sqrt (/ 1 y)))))
(fma.f64 (*.f64 (*.f64 x x) #s(literal 1/2 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) y)) (sqrt.f64 y))
(+ (sqrt y) (* (pow x 2) (+ (* -1/8 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* 1/2 (sqrt (/ 1 y))))))
(fma.f64 (*.f64 (pow.f64 x #s(literal 4 binary64)) #s(literal -1/8 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 3 binary64)))) (fma.f64 (*.f64 (*.f64 x x) #s(literal 1/2 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) y)) (sqrt.f64 y)))
(+ (sqrt y) (* (pow x 2) (+ (* 1/2 (sqrt (/ 1 y))) (* (pow x 2) (+ (* -1/8 (sqrt (/ 1 (pow y 3)))) (* 1/16 (* (pow x 2) (sqrt (/ 1 (pow y 5))))))))))
(fma.f64 (fma.f64 (*.f64 (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 5 binary64)))) (*.f64 #s(literal 1/16 binary64) x)) x (*.f64 (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 3 binary64)))) #s(literal -1/8 binary64))) (pow.f64 x #s(literal 4 binary64)) (fma.f64 (*.f64 (*.f64 x x) #s(literal 1/2 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) y)) (sqrt.f64 y)))
(sqrt (/ 1 y))
(sqrt.f64 (/.f64 #s(literal 1 binary64) y))
(+ (sqrt (/ 1 y)) (* -1/2 (* (pow x 2) (sqrt (/ 1 (pow y 3))))))
(fma.f64 (*.f64 (*.f64 x x) #s(literal -1/2 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 3 binary64)))) (sqrt.f64 (/.f64 #s(literal 1 binary64) y)))
(+ (sqrt (/ 1 y)) (* (pow x 2) (+ (* -1/2 (sqrt (/ 1 (pow y 3)))) (* 3/8 (* (pow x 2) (sqrt (/ 1 (pow y 5))))))))
(fma.f64 (*.f64 (*.f64 #s(literal -1/2 binary64) x) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 3 binary64))))) x (fma.f64 (*.f64 (pow.f64 x #s(literal 4 binary64)) #s(literal 3/8 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 5 binary64)))) (sqrt.f64 (/.f64 #s(literal 1 binary64) y))))
(+ (sqrt (/ 1 y)) (* (pow x 2) (+ (* -1/2 (sqrt (/ 1 (pow y 3)))) (* (pow x 2) (+ (* -5/16 (* (pow x 2) (sqrt (/ 1 (pow y 7))))) (* 3/8 (sqrt (/ 1 (pow y 5)))))))))
(fma.f64 (fma.f64 (*.f64 (pow.f64 x #s(literal 4 binary64)) #s(literal -5/16 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 7 binary64)))) (fma.f64 (*.f64 (*.f64 #s(literal 3/8 binary64) x) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 5 binary64))))) x (*.f64 (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 3 binary64)))) #s(literal -1/2 binary64)))) (*.f64 x x) (sqrt.f64 (/.f64 #s(literal 1 binary64) y)))
(sqrt y)
(sqrt.f64 y)
(+ (sqrt y) (* 1/2 (* (pow x 2) (sqrt (/ 1 y)))))
(fma.f64 (*.f64 (*.f64 x x) #s(literal 1/2 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) y)) (sqrt.f64 y))
(+ (sqrt y) (* (pow x 2) (+ (* -1/8 (* (pow x 2) (sqrt (/ 1 (pow y 3))))) (* 1/2 (sqrt (/ 1 y))))))
(fma.f64 (*.f64 (pow.f64 x #s(literal 4 binary64)) #s(literal -1/8 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 3 binary64)))) (fma.f64 (*.f64 (*.f64 x x) #s(literal 1/2 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) y)) (sqrt.f64 y)))
(+ (sqrt y) (* (pow x 2) (+ (* 1/2 (sqrt (/ 1 y))) (* (pow x 2) (+ (* -1/8 (sqrt (/ 1 (pow y 3)))) (* 1/16 (* (pow x 2) (sqrt (/ 1 (pow y 5))))))))))
(fma.f64 (fma.f64 (*.f64 (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 5 binary64)))) (*.f64 #s(literal 1/16 binary64) x)) x (*.f64 (sqrt.f64 (/.f64 #s(literal 1 binary64) (pow.f64 y #s(literal 3 binary64)))) #s(literal -1/8 binary64))) (pow.f64 x #s(literal 4 binary64)) (fma.f64 (*.f64 (*.f64 x x) #s(literal 1/2 binary64)) (sqrt.f64 (/.f64 #s(literal 1 binary64) y)) (sqrt.f64 y)))
x
(* x (+ 1 (* 1/2 (/ y (pow x 2)))))
(fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x)
(* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (* 1/2 (/ y (pow x 2))))))
(fma.f64 (*.f64 #s(literal -1/8 binary64) x) (*.f64 (/.f64 y (pow.f64 x #s(literal 4 binary64))) y) (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x))
(* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (+ (* 1/16 (/ (pow y 3) (pow x 6))) (* 1/2 (/ y (pow x 2)))))))
(fma.f64 (fma.f64 (pow.f64 y #s(literal 3 binary64)) (/.f64 #s(literal 1/16 binary64) (pow.f64 x #s(literal 6 binary64))) (fma.f64 (*.f64 #s(literal -1/8 binary64) y) (/.f64 y (pow.f64 x #s(literal 4 binary64))) #s(literal 1 binary64))) x (*.f64 (/.f64 #s(literal 1/2 binary64) x) y))
(/ 1 x)
(/.f64 #s(literal 1 binary64) x)
(/ (+ 1 (* -1/2 (/ y (pow x 2)))) x)
(/.f64 (fma.f64 (/.f64 (/.f64 y x) x) #s(literal -1/2 binary64) #s(literal 1 binary64)) x)
(/ (+ 1 (+ (* -1/2 (/ y (pow x 2))) (* -1/2 (/ (+ (* -1 (pow y 2)) (* 1/4 (pow y 2))) (pow x 4))))) x)
(/.f64 (fma.f64 (fma.f64 (/.f64 #s(literal -3/4 binary64) (pow.f64 x #s(literal 4 binary64))) (*.f64 y y) (/.f64 (/.f64 y x) x)) #s(literal -1/2 binary64) #s(literal 1 binary64)) x)
(/ (+ 1 (+ (* -1/2 (/ y (pow x 2))) (+ (* -1/2 (/ (+ (* -1 (pow y 2)) (* 1/4 (pow y 2))) (pow x 4))) (* -1/2 (/ (+ (* 1/2 (* y (+ (* -1 (pow y 2)) (* 1/4 (pow y 2))))) (pow y 3)) (pow x 6)))))) x)
(/.f64 (fma.f64 (+.f64 (fma.f64 (/.f64 #s(literal -3/4 binary64) (pow.f64 x #s(literal 4 binary64))) (*.f64 y y) (/.f64 (fma.f64 (pow.f64 y #s(literal 3 binary64)) #s(literal -3/8 binary64) (pow.f64 y #s(literal 3 binary64))) (pow.f64 x #s(literal 6 binary64)))) (/.f64 (/.f64 y x) x)) #s(literal -1/2 binary64) #s(literal 1 binary64)) x)
x
(* x (+ 1 (* 1/2 (/ y (pow x 2)))))
(fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x)
(* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (* 1/2 (/ y (pow x 2))))))
(fma.f64 (*.f64 #s(literal -1/8 binary64) x) (*.f64 (/.f64 y (pow.f64 x #s(literal 4 binary64))) y) (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x))
(* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (+ (* 1/16 (/ (pow y 3) (pow x 6))) (* 1/2 (/ y (pow x 2)))))))
(fma.f64 (fma.f64 (pow.f64 y #s(literal 3 binary64)) (/.f64 #s(literal 1/16 binary64) (pow.f64 x #s(literal 6 binary64))) (fma.f64 (*.f64 #s(literal -1/8 binary64) y) (/.f64 y (pow.f64 x #s(literal 4 binary64))) #s(literal 1 binary64))) x (*.f64 (/.f64 #s(literal 1/2 binary64) x) y))
(* -1 x)
(neg.f64 x)
(* -1 (* x (+ 1 (* 1/2 (/ y (pow x 2))))))
(fma.f64 #s(literal -1/2 binary64) (/.f64 y x) (neg.f64 x))
(* -1 (* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (* 1/2 (/ y (pow x 2)))))))
(fma.f64 (fma.f64 (*.f64 #s(literal 1/8 binary64) y) (/.f64 y (pow.f64 x #s(literal 4 binary64))) #s(literal -1 binary64)) x (*.f64 (/.f64 #s(literal -1/2 binary64) x) y))
(* -1 (* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (+ (* 1/16 (/ (pow y 3) (pow x 6))) (* 1/2 (/ y (pow x 2))))))))
(fma.f64 (fma.f64 (pow.f64 y #s(literal 3 binary64)) (/.f64 #s(literal 1/16 binary64) (pow.f64 x #s(literal 6 binary64))) (fma.f64 (*.f64 #s(literal -1/8 binary64) y) (/.f64 y (pow.f64 x #s(literal 4 binary64))) #s(literal 1 binary64))) (neg.f64 x) (*.f64 (/.f64 #s(literal -1/2 binary64) x) y))
(/ -1 x)
(/.f64 #s(literal -1 binary64) x)
(* -1 (/ (+ 1 (* -1/2 (/ y (pow x 2)))) x))
(/.f64 (fma.f64 (/.f64 (/.f64 y x) x) #s(literal 1/2 binary64) #s(literal -1 binary64)) x)
(* -1 (/ (+ 1 (+ (* -1/2 (/ y (pow x 2))) (* -1/2 (/ (+ (* -1 (pow y 2)) (* 1/4 (pow y 2))) (pow x 4))))) x))
(/.f64 (fma.f64 (fma.f64 (/.f64 #s(literal -3/4 binary64) (pow.f64 x #s(literal 4 binary64))) (*.f64 y y) (/.f64 (/.f64 y x) x)) #s(literal 1/2 binary64) #s(literal -1 binary64)) x)
(* -1 (/ (+ 1 (+ (* -1/2 (/ y (pow x 2))) (+ (* -1/2 (/ (+ (* -1 (pow y 2)) (* 1/4 (pow y 2))) (pow x 4))) (* -1/2 (/ (+ (* 1/2 (* y (+ (* -1 (pow y 2)) (* 1/4 (pow y 2))))) (pow y 3)) (pow x 6)))))) x))
(/.f64 (fma.f64 (+.f64 (fma.f64 (/.f64 #s(literal -3/4 binary64) (pow.f64 x #s(literal 4 binary64))) (*.f64 y y) (/.f64 (fma.f64 (pow.f64 y #s(literal 3 binary64)) #s(literal -3/8 binary64) (pow.f64 y #s(literal 3 binary64))) (pow.f64 x #s(literal 6 binary64)))) (/.f64 (/.f64 y x) x)) #s(literal 1/2 binary64) #s(literal -1 binary64)) x)
(* -1 x)
(neg.f64 x)
(* -1 (* x (+ 1 (* 1/2 (/ y (pow x 2))))))
(fma.f64 #s(literal -1/2 binary64) (/.f64 y x) (neg.f64 x))
(* -1 (* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (* 1/2 (/ y (pow x 2)))))))
(fma.f64 (fma.f64 (*.f64 #s(literal 1/8 binary64) y) (/.f64 y (pow.f64 x #s(literal 4 binary64))) #s(literal -1 binary64)) x (*.f64 (/.f64 #s(literal -1/2 binary64) x) y))
(* -1 (* x (+ 1 (+ (* -1/8 (/ (pow y 2) (pow x 4))) (+ (* 1/16 (/ (pow y 3) (pow x 6))) (* 1/2 (/ y (pow x 2))))))))
(fma.f64 (fma.f64 (pow.f64 y #s(literal 3 binary64)) (/.f64 #s(literal 1/16 binary64) (pow.f64 x #s(literal 6 binary64))) (fma.f64 (*.f64 #s(literal -1/8 binary64) y) (/.f64 y (pow.f64 x #s(literal 4 binary64))) #s(literal 1 binary64))) (neg.f64 x) (*.f64 (/.f64 #s(literal -1/2 binary64) x) y))

rewrite289.0ms (6.4%)

Memory
-20.5MiB live, 177.9MiB allocated
Rules
4 388×lower-fma.f64
4 388×lower-fma.f32
3 916×lower-/.f32
3 912×lower-/.f64
3 104×lower-*.f64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01035
01331
15031
225031
3179431
0834728
Stop Event
iter limit
node limit
iter limit
Counts
4 → 100
Calls
Call 1
Inputs
(/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y))))
(/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)))
#s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y))
(sqrt.f64 y)
Outputs
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>
#<batchref>

eval20.0ms (0.4%)

Memory
2.5MiB live, 39.1MiB allocated
Compiler

Compiled 2 583 to 517 computations (80% saved)

prune6.0ms (0.1%)

Memory
18.2MiB live, 18.2MiB allocated
Pruning

6 alts after pruning (0 fresh and 6 done)

PrunedKeptTotal
New1800180
Fresh000
Picked011
Done055
Total1806186
Accuracy
100.0%
Counts
186 → 6
Alt Table
Click to see full alt table
StatusAccuracyProgram
34.1%
(/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y))))
66.8%
(sqrt.f64 (fma.f64 x x y))
35.1%
(sqrt.f64 #s(approx (+ (* x x) y) (*.f64 x x)))
69.1%
#s(approx (sqrt (+ (* x x) y)) (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x))
34.2%
#s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y))
1.1%
#s(approx (sqrt (+ (* x x) y)) (neg.f64 x))
Compiler

Compiled 75 to 52 computations (30.7% saved)

regimes21.0ms (0.5%)

Memory
-13.6MiB live, 33.8MiB allocated
Counts
8 → 2
Calls
Call 1
Inputs
#s(approx (sqrt (+ (* x x) y)) (neg.f64 x))
#s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y))
(sqrt.f64 #s(approx (+ (* x x) y) (*.f64 x x)))
(sqrt.f64 (fma.f64 x x y))
#s(approx (sqrt (+ (* x x) y)) (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x))
(sqrt.f64 (+.f64 (*.f64 x x) y))
(/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y))))
(/.f64 #s(literal 1 binary64) (/.f64 #s(literal 1 binary64) (sqrt.f64 (fma.f64 x x y))))
Outputs
(sqrt.f64 (fma.f64 x x y))
#s(approx (sqrt (+ (* x x) y)) (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x))
Calls

5 calls:

8.0ms
(sqrt.f64 (+.f64 (*.f64 x x) y))
3.0ms
y
3.0ms
x
3.0ms
(+.f64 (*.f64 x x) y)
3.0ms
(*.f64 x x)
Results
AccuracySegmentsBranch
100.0%2x
85.1%2y
100.0%2(sqrt.f64 (+.f64 (*.f64 x x) y))
100.0%2(+.f64 (*.f64 x x) y)
100.0%2(*.f64 x x)
Compiler

Compiled 16 to 16 computations (0% saved)

regimes13.0ms (0.3%)

Memory
-11.0MiB live, 26.7MiB allocated
Counts
4 → 1
Calls
Call 1
Inputs
#s(approx (sqrt (+ (* x x) y)) (neg.f64 x))
#s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y))
(sqrt.f64 #s(approx (+ (* x x) y) (*.f64 x x)))
(sqrt.f64 (fma.f64 x x y))
Outputs
(sqrt.f64 (fma.f64 x x y))
Calls

5 calls:

4.0ms
y
2.0ms
x
2.0ms
(sqrt.f64 (+.f64 (*.f64 x x) y))
2.0ms
(+.f64 (*.f64 x x) y)
2.0ms
(*.f64 x x)
Results
AccuracySegmentsBranch
66.8%1y
66.8%1x
66.8%1(sqrt.f64 (+.f64 (*.f64 x x) y))
66.8%1(+.f64 (*.f64 x x) y)
66.8%1(*.f64 x x)
Compiler

Compiled 16 to 16 computations (0% saved)

regimes10.0ms (0.2%)

Memory
24.7MiB live, 24.7MiB allocated
Counts
3 → 2
Calls
Call 1
Inputs
#s(approx (sqrt (+ (* x x) y)) (neg.f64 x))
#s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y))
(sqrt.f64 #s(approx (+ (* x x) y) (*.f64 x x)))
Outputs
#s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y))
(sqrt.f64 #s(approx (+ (* x x) y) (*.f64 x x)))
Calls

5 calls:

2.0ms
y
2.0ms
x
2.0ms
(sqrt.f64 (+.f64 (*.f64 x x) y))
2.0ms
(+.f64 (*.f64 x x) y)
2.0ms
(*.f64 x x)
Results
AccuracySegmentsBranch
43.0%2(sqrt.f64 (+.f64 (*.f64 x x) y))
43.0%2(+.f64 (*.f64 x x) y)
56.7%2(*.f64 x x)
56.7%2x
54.6%2y
Compiler

Compiled 16 to 16 computations (0% saved)

regimes10.0ms (0.2%)

Memory
-17.5MiB live, 20.2MiB allocated
Counts
2 → 1
Calls
Call 1
Inputs
#s(approx (sqrt (+ (* x x) y)) (neg.f64 x))
#s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y))
Outputs
#s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y))
Calls

5 calls:

4.0ms
(+.f64 (*.f64 x x) y)
2.0ms
x
2.0ms
(sqrt.f64 (+.f64 (*.f64 x x) y))
2.0ms
y
1.0ms
(*.f64 x x)
Results
AccuracySegmentsBranch
34.2%1(sqrt.f64 (+.f64 (*.f64 x x) y))
34.2%1(+.f64 (*.f64 x x) y)
34.2%1y
34.2%1(*.f64 x x)
34.2%1x
Compiler

Compiled 16 to 16 computations (0% saved)

regimes7.0ms (0.1%)

Memory
18.6MiB live, 18.6MiB allocated
Accuracy

Total -0.0b remaining (-0%)

Threshold costs -0b (-0%)

Counts
1 → 1
Calls
Call 1
Inputs
#s(approx (sqrt (+ (* x x) y)) (neg.f64 x))
Outputs
#s(approx (sqrt (+ (* x x) y)) (neg.f64 x))
Calls

5 calls:

1.0ms
x
1.0ms
(sqrt.f64 (+.f64 (*.f64 x x) y))
1.0ms
y
1.0ms
(+.f64 (*.f64 x x) y)
1.0ms
(*.f64 x x)
Results
AccuracySegmentsBranch
1.1%1(sqrt.f64 (+.f64 (*.f64 x x) y))
1.1%1(+.f64 (*.f64 x x) y)
1.1%1(*.f64 x x)
1.1%1x
1.1%1y
Compiler

Compiled 16 to 16 computations (0% saved)

bsearch0.0ms (0%)

Memory
0.8MiB live, 0.8MiB allocated
Algorithm
left-value
Steps
TimeLeftRight
0.0ms
3.3866844960016003e+213
3.7176116369904275e+221
Compiler

Compiled 9 to 10 computations (-11.1% saved)

bsearch16.0ms (0.4%)

Memory
-2.5MiB live, 34.4MiB allocated
Algorithm
binary-search
Stop Event
narrow-enough
Steps
TimeLeftRight
15.0ms
1.1029127808224465e-26
2.4539229005384456e-21
Samples
8.0ms144×0valid
1.0ms22×0invalid
Compiler

Compiled 81 to 109 computations (-34.6% saved)

Precisions
Click to see histograms. Total time spent on operations: 6.0ms
ival-add: 3.0ms (53.8% of total)
ival-mult: 1.0ms (17.9% of total)
ival-sqrt: 1.0ms (17.9% of total)
ival-true: 0.0ms (0% of total)
ival-assert: 0.0ms (0% of total)

simplify90.0ms (2%)

Memory
-14.9MiB live, 68.1MiB allocated
Algorithm
egg-herbie
Rules
*-commutative-binary64-*.f64
neg-sub0-binary64--.f64-neg.f64
+-commutative-binary64-+.f64
neg-mul-1-binary64-*.f64-neg.f64
sub-neg-binary64-neg.f64-+.f64--.f64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
02470
12870
23070
33170
Stop Event
saturated
Calls
Call 1
Inputs
(if (<=.f64 (*.f64 x x) #s(literal 4999999999999999772223133475743019061733712700409539130496607211544840259226135691611880105565210303017104153796972357853870064153456670293082673807209411155434429495479368482882719667688996710696271289138913738752 binary64)) (sqrt.f64 (fma.f64 x x y)) #s(approx (sqrt (+ (* x x) y)) (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x)))
(sqrt.f64 (fma.f64 x x y))
(if (<=.f64 x #s(literal 1388352057037429/5444517870735015415413993718908291383296 binary64)) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)) (sqrt.f64 #s(approx (+ (* x x) y) (*.f64 x x))))
#s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y))
#s(approx (sqrt (+ (* x x) y)) (neg.f64 x))
Outputs
(if (<=.f64 (*.f64 x x) #s(literal 4999999999999999772223133475743019061733712700409539130496607211544840259226135691611880105565210303017104153796972357853870064153456670293082673807209411155434429495479368482882719667688996710696271289138913738752 binary64)) (sqrt.f64 (fma.f64 x x y)) #s(approx (sqrt (+ (* x x) y)) (fma.f64 (/.f64 #s(literal 1/2 binary64) x) y x)))
(sqrt.f64 (fma.f64 x x y))
(if (<=.f64 x #s(literal 1388352057037429/5444517870735015415413993718908291383296 binary64)) #s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y)) (sqrt.f64 #s(approx (+ (* x x) y) (*.f64 x x))))
#s(approx (sqrt (+ (* x x) y)) (sqrt.f64 y))
#s(approx (sqrt (+ (* x x) y)) (neg.f64 x))

soundness684.0ms (15.1%)

Memory
18.4MiB live, 337.7MiB allocated
Rules
23 502×lower-fma.f64
23 502×lower-fma.f32
5 416×lower-*.f64
5 416×lower-*.f32
5 034×lower-fma.f64
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
0514
0814
12614
216914
3152114
0848912
0133615
1383600
21202592
34035567
08298515
Stop Event
done
iter limit
node limit
iter limit
node limit
iter limit
Compiler

Compiled 79 to 53 computations (32.9% saved)

preprocess52.0ms (1.2%)

Memory
1.7MiB live, 119.5MiB allocated
Compiler

Compiled 188 to 108 computations (42.6% saved)

end0.0ms (0%)

Memory
0.0MiB live, 0.0MiB allocated

Profiling

Loading profile data...