Trigonometry A

Time bar (total: 3.2s)

analyze26.0ms (0.8%)

Memory
-12.6MiB live, 8.0MiB allocated
Algorithm
search
Search
ProbabilityValidUnknownPreconditionInfiniteDomainCan'tIter
0%0%25%75%0%0%0%0
0%0%25%75%0%0%0%1
50%12.5%12.5%75%0%0%0%2
50%12.5%12.5%75%0%0%0%3
75%18.7%6.2%75%0%0%0%4
87.5%21.8%3.1%75%0%0%0%5
93.8%23.4%1.6%75%0%0%0%6
93.8%23.4%1.6%75%0%0%0%7
96.9%24.2%0.8%75%0%0%0%8
96.9%24.2%0.8%75%0%0%0%9
98.4%24.6%0.4%75%0%0%0%10
98.4%24.6%0.4%75%0%0%0%11
99.2%24.8%0.2%75%0%0%0%12
Compiler

Compiled 27 to 21 computations (22.2% saved)

sample2.9s (93%)

Memory
27.4MiB live, 807.6MiB allocated
Samples
773.0ms8 256×73valid-baseline
691.0ms8 256×73valid-rival
511.0ms8 256×73valid-sollya
Precisions
Click to see Rival histograms. Total time spent on operations: 534.0ms
ival-sin: 186.0ms (34.8% of total)
ival-cos: 153.0ms (28.6% of total)
ival-mult: 101.0ms (18.9% of total)
ival-div: 47.0ms (8.8% of total)
ival-add: 36.0ms (6.7% of total)
ival-true: 7.0ms (1.3% of total)
...in/eval/compile.rkt:110:19: 3.0ms (0.6% of total)
ival-assert: 3.0ms (0.6% of total)
Precisions
Click to see Base histograms. Total time spent on operations: 528.0ms
ival-sin: 166.0ms (31.4% of total)
ival-cos: 148.0ms (28% of total)
ival-mult: 115.0ms (21.8% of total)
ival-div: 49.0ms (9.3% of total)
ival-add: 40.0ms (7.6% of total)
const: 10.0ms (1.9% of total)
Bogosity

preprocess175.0ms (5.5%)

Memory
-9.5MiB live, 22.8MiB allocated
Algorithm
egg-herbie
Rules
772×fma-define
376×fmm-def
262×times-frac
160×distribute-lft-neg-in
154×distribute-rgt-in
Iterations

Useful iterations: 3 (0.0ms)

IterNodesCost
035339
181303
2174299
3431295
41104295
51875295
62350295
72557295
82792295
93326295
103521295
113711295
123808295
133831295
Stop Event
saturated
Calls
Call 1
Inputs
(/.f64 (*.f64 e (sin.f64 v)) (+.f64 #s(literal 1 binary64) (*.f64 e (cos.f64 v))))
(/.f64 (*.f64 e (sin.f64 v)) (+.f64 #s(literal 1 binary64) (*.f64 e (cos.f64 v))))
(/.f64 (*.f64 (neg.f64 e) (sin.f64 v)) (+.f64 #s(literal 1 binary64) (*.f64 (neg.f64 e) (cos.f64 v))))
(/.f64 (*.f64 e (sin.f64 (neg.f64 v))) (+.f64 #s(literal 1 binary64) (*.f64 e (cos.f64 (neg.f64 v)))))
(neg.f64 (/.f64 (*.f64 (neg.f64 e) (sin.f64 v)) (+.f64 #s(literal 1 binary64) (*.f64 (neg.f64 e) (cos.f64 v)))))
(neg.f64 (/.f64 (*.f64 e (sin.f64 (neg.f64 v))) (+.f64 #s(literal 1 binary64) (*.f64 e (cos.f64 (neg.f64 v))))))
(/.f64 (*.f64 v (sin.f64 e)) (+.f64 #s(literal 1 binary64) (*.f64 v (cos.f64 e))))
Outputs
(/.f64 (*.f64 e (sin.f64 v)) (+.f64 #s(literal 1 binary64) (*.f64 e (cos.f64 v))))
(*.f64 e (/.f64 (sin.f64 v) (fma.f64 e (cos.f64 v) #s(literal 1 binary64))))
(/.f64 (*.f64 e (sin.f64 v)) (+.f64 #s(literal 1 binary64) (*.f64 e (cos.f64 v))))
(*.f64 e (/.f64 (sin.f64 v) (fma.f64 e (cos.f64 v) #s(literal 1 binary64))))
(/.f64 (*.f64 (neg.f64 e) (sin.f64 v)) (+.f64 #s(literal 1 binary64) (*.f64 (neg.f64 e) (cos.f64 v))))
(/.f64 (*.f64 (sin.f64 v) (neg.f64 e)) (+.f64 #s(literal 1 binary64) (*.f64 (cos.f64 v) (neg.f64 e))))
(/.f64 (*.f64 e (neg.f64 (sin.f64 v))) (fma.f64 (cos.f64 v) (neg.f64 e) #s(literal 1 binary64)))
(/.f64 (*.f64 e (sin.f64 v)) (+.f64 (*.f64 e (cos.f64 v)) #s(literal -1 binary64)))
(*.f64 (sin.f64 v) (/.f64 e (fma.f64 e (cos.f64 v) #s(literal -1 binary64))))
(/.f64 (*.f64 e (sin.f64 (neg.f64 v))) (+.f64 #s(literal 1 binary64) (*.f64 e (cos.f64 (neg.f64 v)))))
(/.f64 (*.f64 e (neg.f64 (sin.f64 v))) (+.f64 #s(literal 1 binary64) (*.f64 e (cos.f64 v))))
(/.f64 (*.f64 e (neg.f64 (sin.f64 v))) (fma.f64 e (cos.f64 v) #s(literal 1 binary64)))
(*.f64 e (/.f64 (sin.f64 v) (neg.f64 (fma.f64 e (cos.f64 v) #s(literal 1 binary64)))))
(neg.f64 (/.f64 (*.f64 (neg.f64 e) (sin.f64 v)) (+.f64 #s(literal 1 binary64) (*.f64 (neg.f64 e) (cos.f64 v)))))
(/.f64 (*.f64 (sin.f64 v) (neg.f64 e)) (neg.f64 (+.f64 #s(literal 1 binary64) (*.f64 (cos.f64 v) (neg.f64 e)))))
(/.f64 (*.f64 e (sin.f64 v)) (fma.f64 (cos.f64 v) (neg.f64 e) #s(literal 1 binary64)))
(/.f64 (*.f64 e (sin.f64 v)) (-.f64 #s(literal 1 binary64) (*.f64 e (cos.f64 v))))
(*.f64 e (/.f64 (neg.f64 (sin.f64 v)) (fma.f64 e (cos.f64 v) #s(literal -1 binary64))))
(neg.f64 (/.f64 (*.f64 e (sin.f64 (neg.f64 v))) (+.f64 #s(literal 1 binary64) (*.f64 e (cos.f64 (neg.f64 v))))))
(/.f64 (*.f64 e (sin.f64 v)) (+.f64 #s(literal 1 binary64) (*.f64 e (cos.f64 v))))
(*.f64 e (/.f64 (sin.f64 v) (fma.f64 e (cos.f64 v) #s(literal 1 binary64))))
(/.f64 (*.f64 v (sin.f64 e)) (+.f64 #s(literal 1 binary64) (*.f64 v (cos.f64 e))))
(*.f64 v (/.f64 (sin.f64 e) (fma.f64 v (cos.f64 e) #s(literal 1 binary64))))
(*.f64 (sin.f64 e) (/.f64 v (fma.f64 v (cos.f64 e) #s(literal 1 binary64))))
Symmetry

(negabs v)

Compiler

Compiled 13 to 9 computations (30.8% saved)

eval0.0ms (0%)

Memory
0.2MiB live, 0.2MiB allocated
Compiler

Compiled 2 to 2 computations (0% saved)

prune1.0ms (0%)

Memory
0.9MiB live, 0.9MiB allocated
Alt Table
Click to see full alt table
StatusAccuracyProgram
99.7%
(/.f64 (*.f64 e (sin.f64 v)) (+.f64 #s(literal 1 binary64) (*.f64 e (cos.f64 v))))
Compiler

Compiled 26 to 18 computations (30.8% saved)

simplify2.0ms (0.1%)

Memory
0.3MiB live, 0.3MiB allocated
Algorithm
egg-herbie
Rules
1-exp
*-commutative
+-commutative
Iterations

Useful iterations: 0 (0.0ms)

IterNodesCost
01545
12345
Stop Event
saturated
Calls
Call 1
Inputs
(/.f64 (*.f64 e (sin.f64 v)) (+.f64 #s(literal 1 binary64) (*.f64 e (cos.f64 v))))
Outputs
(/.f64 (*.f64 e (sin.f64 v)) (+.f64 #s(literal 1 binary64) (*.f64 e (cos.f64 v))))

soundness0.0ms (0%)

Memory
0.4MiB live, 0.4MiB allocated
Stop Event
fuel
Compiler

Compiled 13 to 9 computations (30.8% saved)

preprocess19.0ms (0.6%)

Memory
7.3MiB live, 22.9MiB allocated
Remove

(negabs v)

Compiler

Compiled 104 to 72 computations (30.8% saved)

end0.0ms (0%)

Memory
0.0MiB live, 0.0MiB allocated

Profiling

Loading profile data...