Data.Random.Distribution.T:$ccdf from random-fu-0.2.6.2

Time bar (total: 2.2s)

analyze11.0ms (0.5%)

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
75%74.9%25%0.1%0%0%0%5
75%74.9%25%0.1%0%0%0%6
87.5%87.4%12.5%0.1%0%0%0%7
87.5%87.4%12.5%0.1%0%0%0%8
93.8%93.7%6.2%0.1%0%0%0%9
93.8%93.7%6.2%0.1%0%0%0%10
96.9%96.8%3.1%0.1%0%0%0%11
96.9%96.8%3.1%0.1%0%0%0%12
Compiler

Compiled 10 to 6 computations (40% saved)

sample846.0ms (39.1%)

Results
739.0ms7245×256valid
97.0ms1011×256infinite
Bogosity

preprocess171.0ms (7.9%)

Algorithm
egg-herbie
Rules
1932×fma-def
1642×div-sub
1492×fma-neg
662×distribute-rgt-in
652×associate-/r*
FPErrors
Click to see full error table
Ground TruthOverpredictionsExampleUnderpredictionsExampleSubexpression
10-0-(/.f64 (+.f64 x y) (+.f64 y y))
00-0-x
00-0-(+.f64 x y)
00-0-y
00-0-(+.f64 y y)
Explanations
Click to see full explanations table
OperatorSubexpressionExplanationCount
/.f64(/.f64 (+.f64 x y) (+.f64 y y))n/o1
Confusion
10
0255
Precision
1.0
Recall
1.0
Iterations

Useful iterations: 5 (0.0ms)

IterNodesCost
023220
147196
2103196
3289184
41295162
53738151
66374151
77852151
Stop Event
node limit
Calls
Call 1
Inputs
(/.f64 (+.f64 x y) (+.f64 y y))
(/.f64 (+.f64 x y) (+.f64 y y))
(/.f64 (+.f64 (neg.f64 x) y) (+.f64 y y))
(/.f64 (+.f64 x (neg.f64 y)) (+.f64 (neg.f64 y) (neg.f64 y)))
(neg.f64 (/.f64 (+.f64 (neg.f64 x) y) (+.f64 y y)))
(neg.f64 (/.f64 (+.f64 x (neg.f64 y)) (+.f64 (neg.f64 y) (neg.f64 y))))
(/.f64 (+.f64 y x) (+.f64 x x))
Outputs
(/.f64 (+.f64 x y) (+.f64 y y))
(/.f64 (+.f64 x y) (*.f64 2 y))
(/.f64 (+.f64 x y) (*.f64 y 2))
(-.f64 (*.f64 x (/.f64 1/2 y)) -1/2)
(fma.f64 x (/.f64 1/2 y) 1/2)
(/.f64 (+.f64 x y) (+.f64 y y))
(/.f64 (+.f64 x y) (*.f64 2 y))
(/.f64 (+.f64 x y) (*.f64 y 2))
(-.f64 (*.f64 x (/.f64 1/2 y)) -1/2)
(fma.f64 x (/.f64 1/2 y) 1/2)
(/.f64 (+.f64 (neg.f64 x) y) (+.f64 y y))
(/.f64 (+.f64 y (neg.f64 x)) (*.f64 2 y))
(/.f64 (-.f64 y x) (*.f64 y 2))
(-.f64 1/2 (/.f64 x (*.f64 y 2)))
(fma.f64 x (/.f64 -1/2 y) 1/2)
(/.f64 (+.f64 x (neg.f64 y)) (+.f64 (neg.f64 y) (neg.f64 y)))
(/.f64 (+.f64 y (neg.f64 x)) (*.f64 2 y))
(/.f64 (-.f64 y x) (*.f64 y 2))
(-.f64 1/2 (/.f64 x (*.f64 y 2)))
(fma.f64 x (/.f64 -1/2 y) 1/2)
(neg.f64 (/.f64 (+.f64 (neg.f64 x) y) (+.f64 y y)))
(/.f64 (neg.f64 (+.f64 y (neg.f64 x))) (*.f64 2 y))
(/.f64 (-.f64 x y) (*.f64 y 2))
(+.f64 (/.f64 x (*.f64 y 2)) -1/2)
(fma.f64 1/2 (/.f64 x y) -1/2)
(fma.f64 x (/.f64 1/2 y) -1/2)
(neg.f64 (/.f64 (+.f64 x (neg.f64 y)) (+.f64 (neg.f64 y) (neg.f64 y))))
(/.f64 (neg.f64 (+.f64 y (neg.f64 x))) (*.f64 2 y))
(/.f64 (-.f64 x y) (*.f64 y 2))
(+.f64 (/.f64 x (*.f64 y 2)) -1/2)
(fma.f64 1/2 (/.f64 x y) -1/2)
(fma.f64 x (/.f64 1/2 y) -1/2)
(/.f64 (+.f64 y x) (+.f64 x x))
(/.f64 (+.f64 x y) (*.f64 2 x))
(/.f64 (+.f64 x y) (*.f64 x 2))
(-.f64 1/2 (/.f64 (/.f64 y x) -2))
Compiler

Compiled 54 to 22 computations (59.3% saved)

eval1.0ms (0%)

Compiler

Compiled 29 to 18 computations (37.9% saved)

prune2.0ms (0.1%)

Alt Table
Click to see full alt table
StatusAccuracyProgram
99.6%
(/.f64 (+.f64 x y) (+.f64 y y))
99.9%
(-.f64 (*.f64 x (/.f64 1/2 y)) -1/2)
Compiler

Compiled 18 to 12 computations (33.3% saved)

localize55.0ms (2.5%)

Localize:

Found 2 expressions with local error:

NewAccuracyProgram
99.6%
(/.f64 (+.f64 x y) (+.f64 y y))
99.7%
(*.f64 x (/.f64 1/2 y))
Compiler

Compiled 37 to 18 computations (51.4% saved)

series7.0ms (0.3%)

Counts
2 → 48
Calls

12 calls:

TimeVariablePointExpression
1.0ms
x
@inf
(/.f64 (+.f64 x y) (+.f64 y y))
1.0ms
y
@0
(*.f64 x (/.f64 1/2 y))
1.0ms
x
@inf
(*.f64 x (/.f64 1/2 y))
1.0ms
x
@0
(*.f64 x (/.f64 1/2 y))
1.0ms
y
@inf
(*.f64 x (/.f64 1/2 y))

rewrite207.0ms (9.6%)

Algorithm
batch-egg-rewrite
Rules
1326×prod-diff
806×log1p-expm1-u
806×expm1-log1p-u
790×log-prod
478×fma-def
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
01347
117941
2291041
Stop Event
node limit
Counts
2 → 67
Calls
Call 1
Inputs
(*.f64 x (/.f64 1/2 y))
(/.f64 (+.f64 x y) (+.f64 y y))
Outputs
(+.f64 0 (*.f64 x (/.f64 0 0)))
(+.f64 (log.f64 (*.f64 (cbrt.f64 (pow.f64 (exp.f64 (/.f64 0 0)) x)) (cbrt.f64 (pow.f64 (exp.f64 (/.f64 0 0)) x)))) (log.f64 (cbrt.f64 (pow.f64 (exp.f64 (/.f64 0 0)) x))))
(+.f64 (log.f64 (sqrt.f64 (pow.f64 (exp.f64 (/.f64 0 0)) x))) (log.f64 (sqrt.f64 (pow.f64 (exp.f64 (/.f64 0 0)) x))))
(-.f64 (exp.f64 (log1p.f64 (*.f64 x (/.f64 0 0)))) 1)
(/.f64 x (/.f64 0 0))
(/.f64 1 (/.f64 y (*.f64 x 1/2)))
(/.f64 (*.f64 x 1/2) y)
(/.f64 (neg.f64 (*.f64 x 1/2)) (neg.f64 y))
(/.f64 (*.f64 x -1/2) (neg.f64 y))
(/.f64 (*.f64 -1/2 x) (neg.f64 y))
(/.f64 (/.f64 (*.f64 x 1/2) 1) y)
(/.f64 (/.f64 (*.f64 x 1/2) (pow.f64 (cbrt.f64 y) 2)) (cbrt.f64 y))
(/.f64 (/.f64 (*.f64 x 1/2) (sqrt.f64 y)) (sqrt.f64 y))
(pow.f64 (*.f64 x (/.f64 0 0)) 1)
(pow.f64 (*.f64 (/.f64 0 0) (cbrt.f64 x)) 3)
(pow.f64 (pow.f64 (*.f64 x (/.f64 0 0)) 3) 1/3)
(pow.f64 (*.f64 (/.f64 0 0) (sqrt.f64 x)) 2)
(sqrt.f64 (*.f64 (/.f64 0 0) (pow.f64 x 2)))
(log.f64 (pow.f64 (exp.f64 (/.f64 0 0)) x))
(log.f64 (+.f64 1 (expm1.f64 (*.f64 x (/.f64 0 0)))))
(cbrt.f64 (pow.f64 (*.f64 x (/.f64 0 0)) 3))
(cbrt.f64 (*.f64 (pow.f64 x 3) (/.f64 0 0)))
(cbrt.f64 (*.f64 (/.f64 0 0) (pow.f64 x 3)))
(expm1.f64 (log1p.f64 (*.f64 x (/.f64 0 0))))
(exp.f64 (log.f64 (*.f64 x (/.f64 0 0))))
(exp.f64 (*.f64 (log.f64 (*.f64 x (/.f64 0 0))) 1))
(log1p.f64 (expm1.f64 (*.f64 x (/.f64 0 0))))
(+.f64 0 (*.f64 (+.f64 x y) (/.f64 0 0)))
(+.f64 (log.f64 (*.f64 (cbrt.f64 (pow.f64 (exp.f64 (+.f64 x y)) (/.f64 0 0))) (cbrt.f64 (pow.f64 (exp.f64 (+.f64 x y)) (/.f64 0 0))))) (log.f64 (cbrt.f64 (pow.f64 (exp.f64 (+.f64 x y)) (/.f64 0 0)))))
(+.f64 (log.f64 (sqrt.f64 (pow.f64 (exp.f64 (+.f64 x y)) (/.f64 0 0)))) (log.f64 (sqrt.f64 (pow.f64 (exp.f64 (+.f64 x y)) (/.f64 0 0)))))
(-.f64 (exp.f64 (log1p.f64 (*.f64 (+.f64 x y) (/.f64 0 0)))) 1)
(*.f64 1/2 (/.f64 (+.f64 x y) y))
(*.f64 (+.f64 x y) (/.f64 0 0))
(*.f64 (/.f64 0 0) (+.f64 x y))
(*.f64 (/.f64 0 0) (*.f64 (+.f64 x y) (/.f64 0 0)))
(*.f64 (*.f64 (+.f64 x y) (/.f64 0 0)) 1)
(*.f64 1 (*.f64 (+.f64 x y) (/.f64 0 0)))
(*.f64 (*.f64 (cbrt.f64 (+.f64 x y)) (/.f64 0 0)) (pow.f64 (*.f64 (cbrt.f64 (+.f64 x y)) (/.f64 0 0)) 2))
(*.f64 (pow.f64 (*.f64 (cbrt.f64 (+.f64 x y)) (/.f64 0 0)) 2) (*.f64 (cbrt.f64 (+.f64 x y)) (/.f64 0 0)))
(*.f64 (pow.f64 (cbrt.f64 (+.f64 x y)) 2) (*.f64 (cbrt.f64 (+.f64 x y)) (/.f64 0 0)))
(*.f64 (*.f64 (sqrt.f64 (+.f64 x y)) (/.f64 0 0)) (*.f64 (sqrt.f64 (+.f64 x y)) (/.f64 0 0)))
(*.f64 (sqrt.f64 (+.f64 x y)) (*.f64 (sqrt.f64 (+.f64 x y)) (/.f64 0 0)))
(*.f64 (neg.f64 (+.f64 x y)) (/.f64 0 0))
(*.f64 (/.f64 (pow.f64 (cbrt.f64 (+.f64 x y)) 2) 1) (*.f64 (cbrt.f64 (+.f64 x y)) (/.f64 0 0)))
(*.f64 (/.f64 (pow.f64 (cbrt.f64 (+.f64 x y)) 2) (/.f64 0 0)) (*.f64 (cbrt.f64 (+.f64 x y)) (/.f64 0 0)))
(*.f64 (/.f64 (pow.f64 (cbrt.f64 (+.f64 x y)) 2) 2) (/.f64 (cbrt.f64 (+.f64 x y)) y))
(*.f64 (/.f64 (sqrt.f64 (+.f64 x y)) 1) (*.f64 (sqrt.f64 (+.f64 x y)) (/.f64 0 0)))
(*.f64 (/.f64 (sqrt.f64 (+.f64 x y)) 2) (/.f64 (sqrt.f64 (+.f64 x y)) y))
(*.f64 (/.f64 (+.f64 x y) (*.f64 2 (pow.f64 y 3))) (fma.f64 y y 0))
(*.f64 (/.f64 (+.f64 x y) 0) 0)
(pow.f64 (*.f64 (+.f64 x y) (/.f64 0 0)) 1)
(pow.f64 (*.f64 (cbrt.f64 (+.f64 x y)) (/.f64 0 0)) 3)
(pow.f64 (pow.f64 (*.f64 (+.f64 x y) (/.f64 0 0)) 3) 1/3)
(pow.f64 (*.f64 (sqrt.f64 (+.f64 x y)) (/.f64 0 0)) 2)
(pow.f64 (/.f64 (/.f64 0 0) (+.f64 x y)) -1)
(neg.f64 (*.f64 (+.f64 x y) (/.f64 0 0)))
(sqrt.f64 (*.f64 (pow.f64 (+.f64 x y) 2) (/.f64 0 0)))
(log.f64 (pow.f64 (exp.f64 (+.f64 x y)) (/.f64 0 0)))
(log.f64 (+.f64 1 (expm1.f64 (*.f64 (+.f64 x y) (/.f64 0 0)))))
(log.f64 (/.f64 1 (pow.f64 (exp.f64 (+.f64 x y)) (/.f64 0 0))))
(log.f64 (/.f64 1 (+.f64 1 (expm1.f64 (*.f64 (+.f64 x y) (/.f64 0 0))))))
(cbrt.f64 (pow.f64 (*.f64 (+.f64 x y) (/.f64 0 0)) 3))
(cbrt.f64 (/.f64 (pow.f64 (+.f64 x y) 3) (/.f64 0 0)))
(expm1.f64 (log1p.f64 (*.f64 (+.f64 x y) (/.f64 0 0))))
(exp.f64 (log.f64 (*.f64 (+.f64 x y) (/.f64 0 0))))
(exp.f64 (*.f64 (log.f64 (*.f64 (+.f64 x y) (/.f64 0 0))) 1))
(log1p.f64 (expm1.f64 (*.f64 (+.f64 x y) (/.f64 0 0))))

simplify23.0ms (1.1%)

Algorithm
egg-herbie
Rules
50×*-commutative
42×sqr-pow
24×associate-*l/
22×associate-*r/
16×+-commutative
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01682284
14622284
Stop Event
unsound
Counts
115 → 93
Calls
Call 1
Inputs
(*.f64 1/2 (/.f64 x y))
(*.f64 1/2 (/.f64 x y))
(*.f64 1/2 (/.f64 x y))
(*.f64 1/2 (/.f64 x y))
(*.f64 1/2 (/.f64 x y))
(*.f64 1/2 (/.f64 x y))
(*.f64 1/2 (/.f64 x y))
(*.f64 1/2 (/.f64 x y))
(*.f64 1/2 (/.f64 x y))
(*.f64 1/2 (/.f64 x y))
(*.f64 1/2 (/.f64 x y))
(*.f64 1/2 (/.f64 x y))
(*.f64 1/2 (/.f64 x y))
(*.f64 1/2 (/.f64 x y))
(*.f64 1/2 (/.f64 x y))
(*.f64 1/2 (/.f64 x y))
(*.f64 1/2 (/.f64 x y))
(*.f64 1/2 (/.f64 x y))
(*.f64 1/2 (/.f64 x y))
(*.f64 1/2 (/.f64 x y))
(*.f64 1/2 (/.f64 x y))
(*.f64 1/2 (/.f64 x y))
(*.f64 1/2 (/.f64 x y))
(*.f64 1/2 (/.f64 x y))
1/2
(+.f64 1/2 (*.f64 1/2 (/.f64 x y)))
(+.f64 1/2 (*.f64 1/2 (/.f64 x y)))
(+.f64 1/2 (*.f64 1/2 (/.f64 x y)))
(*.f64 1/2 (/.f64 x y))
(+.f64 1/2 (*.f64 1/2 (/.f64 x y)))
(+.f64 1/2 (*.f64 1/2 (/.f64 x y)))
(+.f64 1/2 (*.f64 1/2 (/.f64 x y)))
(*.f64 1/2 (/.f64 x y))
(+.f64 1/2 (*.f64 1/2 (/.f64 x y)))
(+.f64 1/2 (*.f64 1/2 (/.f64 x y)))
(+.f64 1/2 (*.f64 1/2 (/.f64 x y)))
(*.f64 1/2 (/.f64 x y))
(+.f64 1/2 (*.f64 1/2 (/.f64 x y)))
(+.f64 1/2 (*.f64 1/2 (/.f64 x y)))
(+.f64 1/2 (*.f64 1/2 (/.f64 x y)))
1/2
(+.f64 1/2 (*.f64 1/2 (/.f64 x y)))
(+.f64 1/2 (*.f64 1/2 (/.f64 x y)))
(+.f64 1/2 (*.f64 1/2 (/.f64 x y)))
1/2
(+.f64 1/2 (*.f64 1/2 (/.f64 x y)))
(+.f64 1/2 (*.f64 1/2 (/.f64 x y)))
(+.f64 1/2 (*.f64 1/2 (/.f64 x y)))
(+.f64 0 (*.f64 x (/.f64 0 0)))
(+.f64 (log.f64 (*.f64 (cbrt.f64 (pow.f64 (exp.f64 (/.f64 0 0)) x)) (cbrt.f64 (pow.f64 (exp.f64 (/.f64 0 0)) x)))) (log.f64 (cbrt.f64 (pow.f64 (exp.f64 (/.f64 0 0)) x))))
(+.f64 (log.f64 (sqrt.f64 (pow.f64 (exp.f64 (/.f64 0 0)) x))) (log.f64 (sqrt.f64 (pow.f64 (exp.f64 (/.f64 0 0)) x))))
(-.f64 (exp.f64 (log1p.f64 (*.f64 x (/.f64 0 0)))) 1)
(/.f64 x (/.f64 0 0))
(/.f64 1 (/.f64 y (*.f64 x 1/2)))
(/.f64 (*.f64 x 1/2) y)
(/.f64 (neg.f64 (*.f64 x 1/2)) (neg.f64 y))
(/.f64 (*.f64 x -1/2) (neg.f64 y))
(/.f64 (*.f64 -1/2 x) (neg.f64 y))
(/.f64 (/.f64 (*.f64 x 1/2) 1) y)
(/.f64 (/.f64 (*.f64 x 1/2) (pow.f64 (cbrt.f64 y) 2)) (cbrt.f64 y))
(/.f64 (/.f64 (*.f64 x 1/2) (sqrt.f64 y)) (sqrt.f64 y))
(pow.f64 (*.f64 x (/.f64 0 0)) 1)
(pow.f64 (*.f64 (/.f64 0 0) (cbrt.f64 x)) 3)
(pow.f64 (pow.f64 (*.f64 x (/.f64 0 0)) 3) 1/3)
(pow.f64 (*.f64 (/.f64 0 0) (sqrt.f64 x)) 2)
(sqrt.f64 (*.f64 (/.f64 0 0) (pow.f64 x 2)))
(log.f64 (pow.f64 (exp.f64 (/.f64 0 0)) x))
(log.f64 (+.f64 1 (expm1.f64 (*.f64 x (/.f64 0 0)))))
(cbrt.f64 (pow.f64 (*.f64 x (/.f64 0 0)) 3))
(cbrt.f64 (*.f64 (pow.f64 x 3) (/.f64 0 0)))
(cbrt.f64 (*.f64 (/.f64 0 0) (pow.f64 x 3)))
(expm1.f64 (log1p.f64 (*.f64 x (/.f64 0 0))))
(exp.f64 (log.f64 (*.f64 x (/.f64 0 0))))
(exp.f64 (*.f64 (log.f64 (*.f64 x (/.f64 0 0))) 1))
(log1p.f64 (expm1.f64 (*.f64 x (/.f64 0 0))))
(+.f64 0 (*.f64 (+.f64 x y) (/.f64 0 0)))
(+.f64 (log.f64 (*.f64 (cbrt.f64 (pow.f64 (exp.f64 (+.f64 x y)) (/.f64 0 0))) (cbrt.f64 (pow.f64 (exp.f64 (+.f64 x y)) (/.f64 0 0))))) (log.f64 (cbrt.f64 (pow.f64 (exp.f64 (+.f64 x y)) (/.f64 0 0)))))
(+.f64 (log.f64 (sqrt.f64 (pow.f64 (exp.f64 (+.f64 x y)) (/.f64 0 0)))) (log.f64 (sqrt.f64 (pow.f64 (exp.f64 (+.f64 x y)) (/.f64 0 0)))))
(-.f64 (exp.f64 (log1p.f64 (*.f64 (+.f64 x y) (/.f64 0 0)))) 1)
(*.f64 1/2 (/.f64 (+.f64 x y) y))
(*.f64 (+.f64 x y) (/.f64 0 0))
(*.f64 (/.f64 0 0) (+.f64 x y))
(*.f64 (/.f64 0 0) (*.f64 (+.f64 x y) (/.f64 0 0)))
(*.f64 (*.f64 (+.f64 x y) (/.f64 0 0)) 1)
(*.f64 1 (*.f64 (+.f64 x y) (/.f64 0 0)))
(*.f64 (*.f64 (cbrt.f64 (+.f64 x y)) (/.f64 0 0)) (pow.f64 (*.f64 (cbrt.f64 (+.f64 x y)) (/.f64 0 0)) 2))
(*.f64 (pow.f64 (*.f64 (cbrt.f64 (+.f64 x y)) (/.f64 0 0)) 2) (*.f64 (cbrt.f64 (+.f64 x y)) (/.f64 0 0)))
(*.f64 (pow.f64 (cbrt.f64 (+.f64 x y)) 2) (*.f64 (cbrt.f64 (+.f64 x y)) (/.f64 0 0)))
(*.f64 (*.f64 (sqrt.f64 (+.f64 x y)) (/.f64 0 0)) (*.f64 (sqrt.f64 (+.f64 x y)) (/.f64 0 0)))
(*.f64 (sqrt.f64 (+.f64 x y)) (*.f64 (sqrt.f64 (+.f64 x y)) (/.f64 0 0)))
(*.f64 (neg.f64 (+.f64 x y)) (/.f64 0 0))
(*.f64 (/.f64 (pow.f64 (cbrt.f64 (+.f64 x y)) 2) 1) (*.f64 (cbrt.f64 (+.f64 x y)) (/.f64 0 0)))
(*.f64 (/.f64 (pow.f64 (cbrt.f64 (+.f64 x y)) 2) (/.f64 0 0)) (*.f64 (cbrt.f64 (+.f64 x y)) (/.f64 0 0)))
(*.f64 (/.f64 (pow.f64 (cbrt.f64 (+.f64 x y)) 2) 2) (/.f64 (cbrt.f64 (+.f64 x y)) y))
(*.f64 (/.f64 (sqrt.f64 (+.f64 x y)) 1) (*.f64 (sqrt.f64 (+.f64 x y)) (/.f64 0 0)))
(*.f64 (/.f64 (sqrt.f64 (+.f64 x y)) 2) (/.f64 (sqrt.f64 (+.f64 x y)) y))
(*.f64 (/.f64 (+.f64 x y) (*.f64 2 (pow.f64 y 3))) (fma.f64 y y 0))
(*.f64 (/.f64 (+.f64 x y) 0) 0)
(pow.f64 (*.f64 (+.f64 x y) (/.f64 0 0)) 1)
(pow.f64 (*.f64 (cbrt.f64 (+.f64 x y)) (/.f64 0 0)) 3)
(pow.f64 (pow.f64 (*.f64 (+.f64 x y) (/.f64 0 0)) 3) 1/3)
(pow.f64 (*.f64 (sqrt.f64 (+.f64 x y)) (/.f64 0 0)) 2)
(pow.f64 (/.f64 (/.f64 0 0) (+.f64 x y)) -1)
(neg.f64 (*.f64 (+.f64 x y) (/.f64 0 0)))
(sqrt.f64 (*.f64 (pow.f64 (+.f64 x y) 2) (/.f64 0 0)))
(log.f64 (pow.f64 (exp.f64 (+.f64 x y)) (/.f64 0 0)))
(log.f64 (+.f64 1 (expm1.f64 (*.f64 (+.f64 x y) (/.f64 0 0)))))
(log.f64 (/.f64 1 (pow.f64 (exp.f64 (+.f64 x y)) (/.f64 0 0))))
(log.f64 (/.f64 1 (+.f64 1 (expm1.f64 (*.f64 (+.f64 x y) (/.f64 0 0))))))
(cbrt.f64 (pow.f64 (*.f64 (+.f64 x y) (/.f64 0 0)) 3))
(cbrt.f64 (/.f64 (pow.f64 (+.f64 x y) 3) (/.f64 0 0)))
(expm1.f64 (log1p.f64 (*.f64 (+.f64 x y) (/.f64 0 0))))
(exp.f64 (log.f64 (*.f64 (+.f64 x y) (/.f64 0 0))))
(exp.f64 (*.f64 (log.f64 (*.f64 (+.f64 x y) (/.f64 0 0))) 1))
(log1p.f64 (expm1.f64 (*.f64 (+.f64 x y) (/.f64 0 0))))
Outputs
(*.f64 1/2 (/.f64 x y))
(*.f64 1/2 (/.f64 x y))
(*.f64 1/2 (/.f64 x y))
(*.f64 1/2 (/.f64 x y))
(*.f64 1/2 (/.f64 x y))
(*.f64 1/2 (/.f64 x y))
(*.f64 1/2 (/.f64 x y))
(*.f64 1/2 (/.f64 x y))
(*.f64 1/2 (/.f64 x y))
(*.f64 1/2 (/.f64 x y))
(*.f64 1/2 (/.f64 x y))
(*.f64 1/2 (/.f64 x y))
(*.f64 1/2 (/.f64 x y))
(*.f64 1/2 (/.f64 x y))
(*.f64 1/2 (/.f64 x y))
(*.f64 1/2 (/.f64 x y))
(*.f64 1/2 (/.f64 x y))
(*.f64 1/2 (/.f64 x y))
(*.f64 1/2 (/.f64 x y))
(*.f64 1/2 (/.f64 x y))
(*.f64 1/2 (/.f64 x y))
(*.f64 1/2 (/.f64 x y))
(*.f64 1/2 (/.f64 x y))
(*.f64 1/2 (/.f64 x y))
1/2
(+.f64 1/2 (*.f64 1/2 (/.f64 x y)))
(+.f64 1/2 (*.f64 1/2 (/.f64 x y)))
(+.f64 1/2 (*.f64 1/2 (/.f64 x y)))
(*.f64 1/2 (/.f64 x y))
(+.f64 1/2 (*.f64 1/2 (/.f64 x y)))
(+.f64 1/2 (*.f64 1/2 (/.f64 x y)))
(+.f64 1/2 (*.f64 1/2 (/.f64 x y)))
(*.f64 1/2 (/.f64 x y))
(+.f64 1/2 (*.f64 1/2 (/.f64 x y)))
(+.f64 1/2 (*.f64 1/2 (/.f64 x y)))
(+.f64 1/2 (*.f64 1/2 (/.f64 x y)))
(*.f64 1/2 (/.f64 x y))
(+.f64 1/2 (*.f64 1/2 (/.f64 x y)))
(+.f64 1/2 (*.f64 1/2 (/.f64 x y)))
(+.f64 1/2 (*.f64 1/2 (/.f64 x y)))
1/2
(+.f64 1/2 (*.f64 1/2 (/.f64 x y)))
(+.f64 1/2 (*.f64 1/2 (/.f64 x y)))
(+.f64 1/2 (*.f64 1/2 (/.f64 x y)))
1/2
(+.f64 1/2 (*.f64 1/2 (/.f64 x y)))
(+.f64 1/2 (*.f64 1/2 (/.f64 x y)))
(+.f64 1/2 (*.f64 1/2 (/.f64 x y)))
(+.f64 0 (*.f64 x (/.f64 0 0)))
(*.f64 x 0)
(+.f64 (log.f64 (*.f64 (cbrt.f64 (pow.f64 (exp.f64 (/.f64 0 0)) x)) (cbrt.f64 (pow.f64 (exp.f64 (/.f64 0 0)) x)))) (log.f64 (cbrt.f64 (pow.f64 (exp.f64 (/.f64 0 0)) x))))
(+.f64 (log.f64 (*.f64 (cbrt.f64 (pow.f64 0 x)) (cbrt.f64 (pow.f64 0 x)))) (log.f64 (cbrt.f64 (pow.f64 0 x))))
(+.f64 (log.f64 (sqrt.f64 (pow.f64 (exp.f64 (/.f64 0 0)) x))) (log.f64 (sqrt.f64 (pow.f64 (exp.f64 (/.f64 0 0)) x))))
(*.f64 2 (log.f64 (sqrt.f64 (pow.f64 0 x))))
(-.f64 (exp.f64 (log1p.f64 (*.f64 x (/.f64 0 0)))) 1)
(*.f64 x 0)
(/.f64 x (/.f64 0 0))
(/.f64 x 0)
(/.f64 1 (/.f64 y (*.f64 x 1/2)))
(*.f64 (/.f64 0 y) (*.f64 1/2 x))
(/.f64 (*.f64 x 1/2) y)
(*.f64 1/2 (/.f64 x y))
(/.f64 (neg.f64 (*.f64 x 1/2)) (neg.f64 y))
(/.f64 x (/.f64 (neg.f64 y) -1/2))
(/.f64 (*.f64 x -1/2) (neg.f64 y))
(/.f64 x (/.f64 (neg.f64 y) -1/2))
(/.f64 (*.f64 -1/2 x) (neg.f64 y))
(/.f64 x (/.f64 (neg.f64 y) -1/2))
(/.f64 (/.f64 (*.f64 x 1/2) 1) y)
(*.f64 1/2 (/.f64 x y))
(/.f64 (/.f64 (*.f64 x 1/2) (pow.f64 (cbrt.f64 y) 2)) (cbrt.f64 y))
(/.f64 (*.f64 1/2 x) (*.f64 (cbrt.f64 y) (pow.f64 (cbrt.f64 y) 2)))
(/.f64 (/.f64 (*.f64 x 1/2) (sqrt.f64 y)) (sqrt.f64 y))
(/.f64 (*.f64 1/2 x) (*.f64 (sqrt.f64 y) (sqrt.f64 y)))
(pow.f64 (*.f64 x (/.f64 0 0)) 1)
(*.f64 x 0)
(pow.f64 (*.f64 (/.f64 0 0) (cbrt.f64 x)) 3)
(*.f64 0 (pow.f64 (cbrt.f64 x) 3))
(pow.f64 (pow.f64 (*.f64 x (/.f64 0 0)) 3) 1/3)
(*.f64 x 0)
(pow.f64 (*.f64 (/.f64 0 0) (sqrt.f64 x)) 2)
(pow.f64 (*.f64 0 (sqrt.f64 x)) 2)
(sqrt.f64 (*.f64 (/.f64 0 0) (pow.f64 x 2)))
(sqrt.f64 (*.f64 0 (pow.f64 x 2)))
(log.f64 (pow.f64 (exp.f64 (/.f64 0 0)) x))
(*.f64 x 0)
(log.f64 (+.f64 1 (expm1.f64 (*.f64 x (/.f64 0 0)))))
(*.f64 x 0)
(cbrt.f64 (pow.f64 (*.f64 x (/.f64 0 0)) 3))
(*.f64 x 0)
(cbrt.f64 (*.f64 (pow.f64 x 3) (/.f64 0 0)))
(*.f64 x 0)
(cbrt.f64 (*.f64 (/.f64 0 0) (pow.f64 x 3)))
(*.f64 x 0)
(expm1.f64 (log1p.f64 (*.f64 x (/.f64 0 0))))
(*.f64 x 0)
(exp.f64 (log.f64 (*.f64 x (/.f64 0 0))))
(*.f64 x 0)
(exp.f64 (*.f64 (log.f64 (*.f64 x (/.f64 0 0))) 1))
(*.f64 x 0)
(log1p.f64 (expm1.f64 (*.f64 x (/.f64 0 0))))
(*.f64 x 0)
(+.f64 0 (*.f64 (+.f64 x y) (/.f64 0 0)))
0
(+.f64 (log.f64 (*.f64 (cbrt.f64 (pow.f64 (exp.f64 (+.f64 x y)) (/.f64 0 0))) (cbrt.f64 (pow.f64 (exp.f64 (+.f64 x y)) (/.f64 0 0))))) (log.f64 (cbrt.f64 (pow.f64 (exp.f64 (+.f64 x y)) (/.f64 0 0)))))
(+.f64 (log.f64 (*.f64 (cbrt.f64 (pow.f64 (exp.f64 (+.f64 x y)) 0)) (cbrt.f64 (pow.f64 (exp.f64 (+.f64 x y)) 0)))) (log.f64 (cbrt.f64 (pow.f64 (exp.f64 (+.f64 x y)) 0))))
(+.f64 (log.f64 (sqrt.f64 (pow.f64 (exp.f64 (+.f64 x y)) (/.f64 0 0)))) (log.f64 (sqrt.f64 (pow.f64 (exp.f64 (+.f64 x y)) (/.f64 0 0)))))
(*.f64 2 (log.f64 (sqrt.f64 (pow.f64 (exp.f64 (+.f64 x y)) 0))))
(-.f64 (exp.f64 (log1p.f64 (*.f64 (+.f64 x y) (/.f64 0 0)))) 1)
0
(*.f64 1/2 (/.f64 (+.f64 x y) y))
(*.f64 (+.f64 x y) (/.f64 0 0))
0
(*.f64 (/.f64 0 0) (+.f64 x y))
0
(*.f64 (/.f64 0 0) (*.f64 (+.f64 x y) (/.f64 0 0)))
0
(*.f64 (*.f64 (+.f64 x y) (/.f64 0 0)) 1)
0
(*.f64 1 (*.f64 (+.f64 x y) (/.f64 0 0)))
0
(*.f64 (*.f64 (cbrt.f64 (+.f64 x y)) (/.f64 0 0)) (pow.f64 (*.f64 (cbrt.f64 (+.f64 x y)) (/.f64 0 0)) 2))
(*.f64 (pow.f64 (cbrt.f64 (+.f64 x y)) 3) 0)
(*.f64 (pow.f64 (*.f64 (cbrt.f64 (+.f64 x y)) (/.f64 0 0)) 2) (*.f64 (cbrt.f64 (+.f64 x y)) (/.f64 0 0)))
(*.f64 (pow.f64 (cbrt.f64 (+.f64 x y)) 3) 0)
(*.f64 (pow.f64 (cbrt.f64 (+.f64 x y)) 2) (*.f64 (cbrt.f64 (+.f64 x y)) (/.f64 0 0)))
(*.f64 (*.f64 0 (cbrt.f64 (+.f64 x y))) (pow.f64 (cbrt.f64 (+.f64 x y)) 2))
(*.f64 (*.f64 (sqrt.f64 (+.f64 x y)) (/.f64 0 0)) (*.f64 (sqrt.f64 (+.f64 x y)) (/.f64 0 0)))
(pow.f64 (*.f64 0 (sqrt.f64 (+.f64 x y))) 2)
(*.f64 (sqrt.f64 (+.f64 x y)) (*.f64 (sqrt.f64 (+.f64 x y)) (/.f64 0 0)))
(pow.f64 (*.f64 0 (sqrt.f64 (+.f64 x y))) 2)
(*.f64 (neg.f64 (+.f64 x y)) (/.f64 0 0))
-1
(*.f64 (/.f64 (pow.f64 (cbrt.f64 (+.f64 x y)) 2) 1) (*.f64 (cbrt.f64 (+.f64 x y)) (/.f64 0 0)))
(*.f64 (*.f64 0 (cbrt.f64 (+.f64 x y))) (pow.f64 (cbrt.f64 (+.f64 x y)) 2))
(*.f64 (/.f64 (pow.f64 (cbrt.f64 (+.f64 x y)) 2) (/.f64 0 0)) (*.f64 (cbrt.f64 (+.f64 x y)) (/.f64 0 0)))
(*.f64 (*.f64 0 (cbrt.f64 (+.f64 x y))) (pow.f64 (cbrt.f64 (+.f64 x y)) 2))
(*.f64 (/.f64 (pow.f64 (cbrt.f64 (+.f64 x y)) 2) 2) (/.f64 (cbrt.f64 (+.f64 x y)) y))
(*.f64 (/.f64 (sqrt.f64 (+.f64 x y)) 1) (*.f64 (sqrt.f64 (+.f64 x y)) (/.f64 0 0)))
(pow.f64 (*.f64 0 (sqrt.f64 (+.f64 x y))) 2)
(*.f64 (/.f64 (sqrt.f64 (+.f64 x y)) 2) (/.f64 (sqrt.f64 (+.f64 x y)) y))
(*.f64 (/.f64 (+.f64 x y) (*.f64 2 (pow.f64 y 3))) (fma.f64 y y 0))
(/.f64 (*.f64 (+.f64 x y) (fma.f64 y y 0)) (*.f64 2 (pow.f64 y 3)))
(*.f64 (/.f64 (+.f64 x y) 0) 0)
0
(pow.f64 (*.f64 (+.f64 x y) (/.f64 0 0)) 1)
0
(pow.f64 (*.f64 (cbrt.f64 (+.f64 x y)) (/.f64 0 0)) 3)
(*.f64 (pow.f64 (cbrt.f64 (+.f64 x y)) 3) 0)
(pow.f64 (pow.f64 (*.f64 (+.f64 x y) (/.f64 0 0)) 3) 1/3)
0
(pow.f64 (*.f64 (sqrt.f64 (+.f64 x y)) (/.f64 0 0)) 2)
(pow.f64 (*.f64 0 (sqrt.f64 (+.f64 x y))) 2)
(pow.f64 (/.f64 (/.f64 0 0) (+.f64 x y)) -1)
0
(neg.f64 (*.f64 (+.f64 x y) (/.f64 0 0)))
-1
(sqrt.f64 (*.f64 (pow.f64 (+.f64 x y) 2) (/.f64 0 0)))
(sqrt.f64 (*.f64 0 (pow.f64 (+.f64 x y) 2)))
(log.f64 (pow.f64 (exp.f64 (+.f64 x y)) (/.f64 0 0)))
(*.f64 0 (log.f64 (exp.f64 (+.f64 x y))))
(log.f64 (+.f64 1 (expm1.f64 (*.f64 (+.f64 x y) (/.f64 0 0)))))
0
(log.f64 (/.f64 1 (pow.f64 (exp.f64 (+.f64 x y)) (/.f64 0 0))))
(neg.f64 (*.f64 0 (log.f64 (exp.f64 (+.f64 x y)))))
(log.f64 (/.f64 1 (+.f64 1 (expm1.f64 (*.f64 (+.f64 x y) (/.f64 0 0))))))
-1
(cbrt.f64 (pow.f64 (*.f64 (+.f64 x y) (/.f64 0 0)) 3))
0
(cbrt.f64 (/.f64 (pow.f64 (+.f64 x y) 3) (/.f64 0 0)))
(cbrt.f64 (/.f64 (pow.f64 (+.f64 x y) 3) 0))
(expm1.f64 (log1p.f64 (*.f64 (+.f64 x y) (/.f64 0 0))))
0
(exp.f64 (log.f64 (*.f64 (+.f64 x y) (/.f64 0 0))))
0
(exp.f64 (*.f64 (log.f64 (*.f64 (+.f64 x y) (/.f64 0 0))) 1))
0
(log1p.f64 (expm1.f64 (*.f64 (+.f64 x y) (/.f64 0 0))))
0

eval20.0ms (0.9%)

Compiler

Compiled 997 to 679 computations (31.9% saved)

prune22.0ms (1%)

Pruning

5 alts after pruning (3 fresh and 2 done)

PrunedKeptTotal
New90393
Fresh000
Picked022
Done000
Total90595
Accuracy
100.0%
Counts
95 → 5
Alt Table
Click to see full alt table
StatusAccuracyProgram
99.6%
(/.f64 (+.f64 x y) (+.f64 y y))
8.8%
(-.f64 (/.f64 x 0) -1/2)
99.9%
(-.f64 (*.f64 x (/.f64 1/2 y)) -1/2)
54.4%
1/2
2.2%
-1
Compiler

Compiled 31 to 24 computations (22.6% saved)

localize21.0ms (1%)

Compiler

Compiled 16 to 13 computations (18.8% saved)

eval0.0ms (0%)

Compiler

Compiled 2 to 2 computations (0% saved)

prune3.0ms (0.1%)

Pruning

5 alts after pruning (0 fresh and 5 done)

PrunedKeptTotal
New000
Fresh000
Picked033
Done022
Total055
Accuracy
100.0%
Counts
5 → 5
Alt Table
Click to see full alt table
StatusAccuracyProgram
99.6%
(/.f64 (+.f64 x y) (+.f64 y y))
8.8%
(-.f64 (/.f64 x 0) -1/2)
99.9%
(-.f64 (*.f64 x (/.f64 1/2 y)) -1/2)
54.4%
1/2
2.2%
-1
Compiler

Compiled 54 to 40 computations (25.9% saved)

regimes15.0ms (0.7%)

Counts
5 → 1
Calls
Call 1
Inputs
-1
1/2
(-.f64 (/.f64 x 0) -1/2)
(-.f64 (*.f64 x (/.f64 1/2 y)) -1/2)
(/.f64 (+.f64 x y) (+.f64 y y))
Outputs
(-.f64 (*.f64 x (/.f64 1/2 y)) -1/2)
Calls

3 calls:

6.0ms
x
5.0ms
y
4.0ms
(/.f64 (+.f64 x y) (+.f64 y y))
Results
AccuracySegmentsBranch
99.9%1x
99.9%1y
99.9%1(/.f64 (+.f64 x y) (+.f64 y y))
Compiler

Compiled 15 to 9 computations (40% saved)

regimes18.0ms (0.8%)

Counts
3 → 3
Calls
Call 1
Inputs
-1
1/2
(-.f64 (/.f64 x 0) -1/2)
Outputs
1/2
(-.f64 (/.f64 x 0) -1/2)
1/2
Calls

2 calls:

14.0ms
y
4.0ms
x
Results
AccuracySegmentsBranch
54.4%1x
58.8%3y
Compiler

Compiled 6 to 4 computations (33.3% saved)

regimes4.0ms (0.2%)

Counts
2 → 1
Calls
Call 1
Inputs
-1
1/2
Outputs
1/2
Calls

1 calls:

3.0ms
y
Results
AccuracySegmentsBranch
54.4%1y
Compiler

Compiled 3 to 2 computations (33.3% saved)

regimes7.0ms (0.3%)

Accuracy

Total -0.0b remaining (-0%)

Threshold costs -0b (-0%)

Counts
1 → 1
Calls
Call 1
Inputs
-1
Outputs
-1
Calls

2 calls:

3.0ms
x
3.0ms
y
Results
AccuracySegmentsBranch
2.2%1x
2.2%1y
Compiler

Compiled 6 to 4 computations (33.3% saved)

bsearch27.0ms (1.2%)

Algorithm
binary-search
Stop Event
narrow-enough
narrow-enough
Steps
TimeLeftRight
12.0ms
9.473687158550883e-146
3.5224599321678643e-144
14.0ms
-6.386033086887842e-305
3.337469573985255e-308
Results
15.0ms154×256valid
8.0ms86×256infinite
Compiler

Compiled 194 to 174 computations (10.3% saved)

simplify6.0ms (0.3%)

Algorithm
egg-herbie
Rules
sub-neg
+-commutative
*-commutative
neg-mul-1
if-if-or-not
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
02569
13569
23969
34169
44269
Stop Event
done
saturated
Calls
Call 1
Inputs
(-.f64 (*.f64 x (/.f64 1/2 y)) -1/2)
(if (<=.f64 y -20240225330731/50600563326827654588123836679729326762389162441035529589225339506857584891998836722990095925359281123796769466079202977847452184346448369216753349985184627480379356069141590341116726935523304085309941919618186267140501870856173174654525838912289889085202514128089692388083353653807625633046581877161501565826926935273373696) 1/2 (if (<=.f64 y 5736115088042575/56236422431789954785131731346074773235871213978773957913759444657647969758393598378988008576298635714374011382919011189040103325693678746112606439760814548189184) (-.f64 (/.f64 x 0) -1/2) 1/2))
1/2
-1
Outputs
(-.f64 (*.f64 x (/.f64 1/2 y)) -1/2)
(if (<=.f64 y -20240225330731/50600563326827654588123836679729326762389162441035529589225339506857584891998836722990095925359281123796769466079202977847452184346448369216753349985184627480379356069141590341116726935523304085309941919618186267140501870856173174654525838912289889085202514128089692388083353653807625633046581877161501565826926935273373696) 1/2 (if (<=.f64 y 5736115088042575/56236422431789954785131731346074773235871213978773957913759444657647969758393598378988008576298635714374011382919011189040103325693678746112606439760814548189184) (-.f64 (/.f64 x 0) -1/2) 1/2))
1/2
-1
Compiler

Compiled 32 to 27 computations (15.6% saved)

soundness650.0ms (30%)

Rules
1932×fma-def
1642×div-sub
1492×fma-neg
1326×prod-diff
1326×prod-diff
Iterations

Useful iterations: 1 (0.0ms)

IterNodesCost
023220
147196
2103196
3289184
41295162
53738151
66374151
77852151
01347
117941
2291041
01682284
14622284
01347
117941
2291041
01682284
14622284
Stop Event
unsound
node limit
unsound
node limit
node limit
Compiler

Compiled 410 to 147 computations (64.1% saved)

end0.0ms (0%)

preprocess48.0ms (2.2%)

Compiler

Compiled 88 to 66 computations (25% saved)

Profiling

Loading profile data...