Time bar (total: 6.3s)
| 1× | search |
| 2× | egg-herbie |
| 883× | associate-+l-_binary64_2059 |
| 655× | sub-neg_binary64_2117 |
| 596× | associate--r-_binary64_2063 |
| 477× | unsub-neg_binary64_2118 |
| 368× | distribute-neg-in_binary64_2085 |
| 361× | neg-sub0_binary64_2119 |
| 351× | neg-mul-1_binary64_2120 |
| 328× | associate-*r*_binary64_2064 |
| 295× | cancel-sign-sub-inv_binary64_2090 |
| 280× | distribute-lft-neg-out_binary64_2083 |
| 269× | +-commutative_binary64_2054 |
| 267× | distribute-lft-neg-in_binary64_2081 |
| 263× | distribute-rgt-out--_binary64_2078 |
| 262× | distribute-rgt-neg-in_binary64_2082 |
| 261× | associate-+l+_binary64_2057 |
| 233× | remove-double-neg_binary64_2112 |
| 223× | associate-+r+_binary64_2056 |
| 222× | distribute-rgt-out_binary64_2077 |
| 221× | distribute-rgt-neg-out_binary64_2084 |
| 219× | *-commutative_binary64_2055 |
| 214× | associate-+r-_binary64_2058 |
| 211× | associate--l+_binary64_2061 |
| 170× | distribute-neg-out_binary64_2086 |
| 163× | distribute-lft-out--_binary64_2076 |
| 147× | associate--r+_binary64_2060 |
| 137× | associate--l-_binary64_2062 |
| 124× | distribute-lft-out_binary64_2075 |
| 79× | sub0-neg_binary64_2111 |
| 55× | +-rgt-identity_binary64_2109 |
| 45× | *-rgt-identity_binary64_2114 |
| 41× | distribute-rgt-in_binary64_2074 |
| 32× | distribute-lft-in_binary64_2073 |
| 28× | --rgt-identity_binary64_2110 |
| 23× | *-lft-identity_binary64_2113 |
| 12× | mul0-rgt_binary64_2107 |
| 11× | mul0-lft_binary64_2106 |
| 7× | cancel-sign-sub_binary64_2089 |
| 5× | mul-1-neg_binary64_2116 |
| 4× | sqr-neg_binary64_2138 swap-sqr_binary64_2091 |
| 3× | +-lft-identity_binary64_2108 associate-*l*_binary64_2065 |
| 1× | 1-exp_binary64_2168 swap-d2-d4 |
| 0× | not-true not-false not-not not-and not-or and-true-l and-true-r and-false-l and-false-r and-same or-true-l or-true-r or-false-l or-false-r or-same erfc-erf_binary64_2387 erf-erfc_binary64_2386 erf-odd_binary64_2385 if-if-and-not_binary64_2384 if-if-and_binary64_2383 if-if-or-not_binary64_2382 if-if-or_binary64_2381 if-not_binary64_2380 if-same_binary64_2379 if-false_binary64_2378 if-true_binary64_2377 not-gte_binary64_2376 not-lte_binary64_2375 not-gt_binary64_2374 not-lt_binary64_2373 gte-same_binary64_2372 lte-same_binary64_2371 gt-same_binary64_2370 lt-same_binary64_2369 sinh---cosh_binary64_2316 sinh-+-cosh_binary64_2315 sinh-cosh_binary64_2314 tanh-def-c_binary64_2313 tanh-def-b_binary64_2312 tanh-def-a_binary64_2311 cosh-def_binary64_2310 sinh-def_binary64_2309 tan-neg_binary64_2256 cos-neg_binary64_2255 sin-neg_binary64_2254 tan-0_binary64_2253 cos-0_binary64_2252 sin-0_binary64_2251 hang-m-tan_binary64_2250 hang-p-tan_binary64_2249 hang-m0-tan_binary64_2248 hang-p0-tan_binary64_2247 hang-0m-tan_binary64_2246 hang-0p-tan_binary64_2245 tan-+PI/2_binary64_2244 tan-+PI_binary64_2243 tan-PI_binary64_2242 tan-PI/3_binary64_2241 tan-PI/4_binary64_2240 tan-PI/6_binary64_2239 cos-+PI/2_binary64_2238 cos-+PI_binary64_2237 cos-PI_binary64_2236 cos-PI/2_binary64_2235 cos-PI/3_binary64_2234 cos-PI/4_binary64_2233 cos-PI/6_binary64_2232 sin-+PI/2_binary64_2231 sin-+PI_binary64_2230 sin-PI_binary64_2229 sin-PI/2_binary64_2228 sin-PI/3_binary64_2227 sin-PI/4_binary64_2226 sin-PI/6_binary64_2225 sub-1-sin_binary64_2224 sub-1-cos_binary64_2223 -1-add-sin_binary64_2222 -1-add-cos_binary64_2221 1-sub-sin_binary64_2220 1-sub-cos_binary64_2219 cos-sin-sum_binary64_2218 log-E_binary64_2214 log-pow_binary64_2213 log-rec_binary64_2212 log-div_binary64_2211 log-prod_binary64_2210 pow-base-0_binary64_2208 unpow1/3_binary64_2191 unpow3_binary64_2190 unpow2_binary64_2189 unpow1/2_binary64_2188 pow-plus_binary64_2187 exp-to-pow_binary64_2186 pow-base-1_binary64_2184 unpow0_binary64_2183 unpow1_binary64_2182 unpow-1_binary64_2181 exp-lft-cube_binary64_2180 exp-lft-sqr_binary64_2179 exp-cbrt_binary64_2178 exp-sqrt_binary64_2177 exp-prod_binary64_2176 div-exp_binary64_2175 rec-exp_binary64_2174 prod-exp_binary64_2173 exp-diff_binary64_2172 exp-neg_binary64_2171 exp-sum_binary64_2170 e-exp-1_binary64_2169 exp-1-e_binary64_2167 exp-0_binary64_2166 rem-log-exp_binary64_2165 rem-exp-log_binary64_2164 cube-unmult_binary64_2161 cube-mult_binary64_2154 cube-div_binary64_2153 cube-prod_binary64_2152 cube-neg_binary64_2151 rem-3cbrt-rft_binary64_2150 rem-3cbrt-lft_binary64_2149 rem-cbrt-cube_binary64_2148 rem-cube-cbrt_binary64_2147 sqr-abs_binary64_2139 rem-sqrt-square_binary64_2137 rem-square-sqrt_binary64_2136 times-frac_binary64_2130 div-sub_binary64_2129 /-rgt-identity_binary64_2115 div0_binary64_2105 *-inverses_binary64_2104 +-inverses_binary64_2103 lft-mult-inverse_binary64_2102 rgt-mult-inverse_binary64_2101 remove-double-div_binary64_2100 pow-sqr_binary64_2097 sqr-pow_binary64_2096 difference-of-sqr--1_binary64_2095 difference-of-sqr-1_binary64_2094 difference-of-squares_binary64_2093 unswap-sqr_binary64_2092 distribute-neg-frac_binary64_2088 distribute-frac-neg_binary64_2087 distribute-rgt1-in_binary64_2080 distribute-lft1-in_binary64_2079 count-2_binary64_2072 associate-/l/_binary64_2071 associate-/r/_binary64_2070 associate-/l*_binary64_2069 associate-/r*_binary64_2068 associate-*l/_binary64_2067 associate-*r/_binary64_2066 |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 40 | 133 |
| 1 | 139 | 112 |
| 2 | 407 | 91 |
| 3 | 1212 | 91 |
| 4 | 2605 | 91 |
| 5 | 3554 | 91 |
| 6 | 3756 | 91 |
| 7 | 3656 | 91 |
| 8 | 3659 | 91 |
| 9 | 3659 | 91 |
| 10 | 3928 | 91 |
| 11 | 3949 | 91 |
| 12 | 3949 | 91 |
| 13 | 3949 | 91 |
| 14 | 5233 | 91 |
| 0 | 4 | 4 |
| 1 | 4 | 4 |
| True | Other | False | Iter |
|---|---|---|---|
| 0% | 99.8% | 0.2% | 0 |
| 0% | 99.8% | 0.2% | 1 |
| 0% | 99.8% | 0.2% | 2 |
| 0% | 99.8% | 0.2% | 3 |
| 0% | 99.8% | 0.2% | 4 |
| 0% | 99.8% | 0.2% | 5 |
| 0% | 99.8% | 0.2% | 6 |
| 0% | 99.8% | 0.2% | 7 |
| 0% | 99.8% | 0.2% | 8 |
| 6.2% | 93.6% | 0.2% | 9 |
| 28.1% | 68.6% | 3.3% | 10 |
| 29.6% | 65.5% | 4.9% | 11 |
| 32% | 61.7% | 6.3% | 12 |
| 35.5% | 56.9% | 7.6% | 13 |
| 48% | 38.7% | 13.4% | 14 |
(sort d2 d4)
Compiled 16 to 12 computations (25% saved)
| 1× | intervals |
| 13.0ms | 256× | body | 128 | valid |
| 3.0ms | 66× | body | 128 | invalid |
Compiled 31 to 27 computations (12.9% saved)
| 1× | egg-herbie |
| 235× | sub-neg_binary64_2117 |
| 222× | unsub-neg_binary64_2118 |
| 158× | cancel-sign-sub-inv_binary64_2090 |
| 141× | associate-*l*_binary64_2065 |
| 140× | associate-*r*_binary64_2064 |
| 129× | associate-+l-_binary64_2059 |
| 125× | distribute-rgt-out--_binary64_2078 |
| 115× | associate--r-_binary64_2063 |
| 94× | distribute-rgt-neg-in_binary64_2082 |
| 92× | associate--r+_binary64_2060 |
| 87× | distribute-lft-neg-out_binary64_2083 distribute-rgt-out_binary64_2077 |
| 83× | associate--l+_binary64_2061 |
| 82× | distribute-rgt-in_binary64_2074 |
| 81× | distribute-lft-out_binary64_2075 |
| 79× | distribute-lft-out--_binary64_2076 |
| 78× | distribute-neg-in_binary64_2085 |
| 75× | associate-+r-_binary64_2058 |
| 72× | associate-+r+_binary64_2056 *-commutative_binary64_2055 |
| 65× | distribute-lft-in_binary64_2073 |
| 63× | associate-+l+_binary64_2057 |
| 60× | cancel-sign-sub_binary64_2089 |
| 58× | +-commutative_binary64_2054 |
| 54× | distribute-lft-neg-in_binary64_2081 associate--l-_binary64_2062 |
| 51× | neg-mul-1_binary64_2120 neg-sub0_binary64_2119 distribute-rgt-neg-out_binary64_2084 |
| 38× | sub0-neg_binary64_2111 |
| 31× | distribute-neg-out_binary64_2086 |
| 30× | mul0-rgt_binary64_2107 mul0-lft_binary64_2106 |
| 28× | *-lft-identity_binary64_2113 |
| 22× | remove-double-neg_binary64_2112 |
| 20× | *-rgt-identity_binary64_2114 |
| 16× | +-rgt-identity_binary64_2109 |
| 10× | --rgt-identity_binary64_2110 |
| 6× | mul-1-neg_binary64_2116 |
| 1× | 1-exp_binary64_2168 sqr-neg_binary64_2138 +-lft-identity_binary64_2108 swap-sqr_binary64_2091 |
| 0× | not-true not-false not-not not-and not-or and-true-l and-true-r and-false-l and-false-r and-same or-true-l or-true-r or-false-l or-false-r or-same erfc-erf_binary64_2387 erf-erfc_binary64_2386 erf-odd_binary64_2385 if-if-and-not_binary64_2384 if-if-and_binary64_2383 if-if-or-not_binary64_2382 if-if-or_binary64_2381 if-not_binary64_2380 if-same_binary64_2379 if-false_binary64_2378 if-true_binary64_2377 not-gte_binary64_2376 not-lte_binary64_2375 not-gt_binary64_2374 not-lt_binary64_2373 gte-same_binary64_2372 lte-same_binary64_2371 gt-same_binary64_2370 lt-same_binary64_2369 sinh---cosh_binary64_2316 sinh-+-cosh_binary64_2315 sinh-cosh_binary64_2314 tanh-def-c_binary64_2313 tanh-def-b_binary64_2312 tanh-def-a_binary64_2311 cosh-def_binary64_2310 sinh-def_binary64_2309 tan-neg_binary64_2256 cos-neg_binary64_2255 sin-neg_binary64_2254 tan-0_binary64_2253 cos-0_binary64_2252 sin-0_binary64_2251 hang-m-tan_binary64_2250 hang-p-tan_binary64_2249 hang-m0-tan_binary64_2248 hang-p0-tan_binary64_2247 hang-0m-tan_binary64_2246 hang-0p-tan_binary64_2245 tan-+PI/2_binary64_2244 tan-+PI_binary64_2243 tan-PI_binary64_2242 tan-PI/3_binary64_2241 tan-PI/4_binary64_2240 tan-PI/6_binary64_2239 cos-+PI/2_binary64_2238 cos-+PI_binary64_2237 cos-PI_binary64_2236 cos-PI/2_binary64_2235 cos-PI/3_binary64_2234 cos-PI/4_binary64_2233 cos-PI/6_binary64_2232 sin-+PI/2_binary64_2231 sin-+PI_binary64_2230 sin-PI_binary64_2229 sin-PI/2_binary64_2228 sin-PI/3_binary64_2227 sin-PI/4_binary64_2226 sin-PI/6_binary64_2225 sub-1-sin_binary64_2224 sub-1-cos_binary64_2223 -1-add-sin_binary64_2222 -1-add-cos_binary64_2221 1-sub-sin_binary64_2220 1-sub-cos_binary64_2219 cos-sin-sum_binary64_2218 log-E_binary64_2214 log-pow_binary64_2213 log-rec_binary64_2212 log-div_binary64_2211 log-prod_binary64_2210 pow-base-0_binary64_2208 unpow1/3_binary64_2191 unpow3_binary64_2190 unpow2_binary64_2189 unpow1/2_binary64_2188 pow-plus_binary64_2187 exp-to-pow_binary64_2186 pow-base-1_binary64_2184 unpow0_binary64_2183 unpow1_binary64_2182 unpow-1_binary64_2181 exp-lft-cube_binary64_2180 exp-lft-sqr_binary64_2179 exp-cbrt_binary64_2178 exp-sqrt_binary64_2177 exp-prod_binary64_2176 div-exp_binary64_2175 rec-exp_binary64_2174 prod-exp_binary64_2173 exp-diff_binary64_2172 exp-neg_binary64_2171 exp-sum_binary64_2170 e-exp-1_binary64_2169 exp-1-e_binary64_2167 exp-0_binary64_2166 rem-log-exp_binary64_2165 rem-exp-log_binary64_2164 cube-unmult_binary64_2161 cube-mult_binary64_2154 cube-div_binary64_2153 cube-prod_binary64_2152 cube-neg_binary64_2151 rem-3cbrt-rft_binary64_2150 rem-3cbrt-lft_binary64_2149 rem-cbrt-cube_binary64_2148 rem-cube-cbrt_binary64_2147 sqr-abs_binary64_2139 rem-sqrt-square_binary64_2137 rem-square-sqrt_binary64_2136 times-frac_binary64_2130 div-sub_binary64_2129 /-rgt-identity_binary64_2115 div0_binary64_2105 *-inverses_binary64_2104 +-inverses_binary64_2103 lft-mult-inverse_binary64_2102 rgt-mult-inverse_binary64_2101 remove-double-div_binary64_2100 pow-sqr_binary64_2097 sqr-pow_binary64_2096 difference-of-sqr--1_binary64_2095 difference-of-sqr-1_binary64_2094 difference-of-squares_binary64_2093 unswap-sqr_binary64_2092 distribute-neg-frac_binary64_2088 distribute-frac-neg_binary64_2087 distribute-rgt1-in_binary64_2080 distribute-lft1-in_binary64_2079 count-2_binary64_2072 associate-/l/_binary64_2071 associate-/r/_binary64_2070 associate-/l*_binary64_2069 associate-/r*_binary64_2068 associate-*l/_binary64_2067 associate-*r/_binary64_2066 |
Useful iterations: 2 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 12 | 19 |
| 1 | 31 | 16 |
| 2 | 82 | 13 |
| 3 | 215 | 13 |
| 4 | 504 | 13 |
| 5 | 1179 | 13 |
| 6 | 1314 | 13 |
| 7 | 1123 | 13 |
| 8 | 1123 | 13 |
| 9 | 1203 | 13 |
| 10 | 1139 | 13 |
| 11 | 1139 | 13 |
| 12 | 1064 | 13 |
2 alts after pruning (2 fresh and 0 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 0 | 1 | 1 |
| Fresh | 0 | 1 | 1 |
| Picked | 0 | 0 | 0 |
| Done | 0 | 0 | 0 |
| Total | 0 | 2 | 2 |
Compiled 33 to 27 computations (18.2% saved)
Found 2 expressions with local error:
| 0.0b | (-.f64 (*.f64 d1 d2) (*.f64 d1 d3)) |
| 0.0b | (+.f64 (-.f64 (*.f64 d1 d2) (*.f64 d1 d3)) (*.f64 d4 d1)) |
| 1× | rewrite-expression-head |
| 9× | add-log-exp_binary64_2163 |
| 2× | diff-log_binary64_2216 sum-log_binary64_2215 pow1_binary64_2185 add-exp-log_binary64_2162 add-cbrt-cube_binary64_2160 add-cube-cbrt_binary64_2159 add-sqr-sqrt_binary64_2146 *-un-lft-identity_binary64_2124 sub-neg_binary64_2117 associate-+l+_binary64_2057 cancel-sign-sub-inv_binary64_2090 |
| 1× | flip3-+_binary64_2127 flip-+_binary64_2098 associate-+l-_binary64_2059 +-commutative_binary64_2054 flip3--_binary64_2128 flip--_binary64_2099 distribute-lft-out--_binary64_2076 |
2 calls:
| 7.0ms | (+.f64 (-.f64 (*.f64 d1 d2) (*.f64 d1 d3)) (*.f64 d4 d1)) |
| 4.0ms | (-.f64 (*.f64 d1 d2) (*.f64 d1 d3)) |
Compiled 668 to 133 computations (80.1% saved)
2 calls:
| 289.0ms | (+.f64 (-.f64 (*.f64 d1 d2) (*.f64 d1 d3)) (*.f64 d4 d1)) |
| 164.0ms | (-.f64 (*.f64 d1 d2) (*.f64 d1 d3)) |
Compiled 1205 to 646 computations (46.4% saved)
| 1× | egg-herbie |
| 460× | associate-*l*_binary64_2065 |
| 431× | cancel-sign-sub-inv_binary64_2090 |
| 383× | times-frac_binary64_2130 |
| 377× | associate-*r*_binary64_2064 |
| 283× | distribute-rgt-neg-out_binary64_2084 |
| 282× | distribute-lft-neg-out_binary64_2083 |
| 240× | distribute-rgt-in_binary64_2074 |
| 221× | distribute-lft-in_binary64_2073 |
| 154× | exp-sum_binary64_2170 |
| 152× | unsub-neg_binary64_2118 |
| 136× | sub-neg_binary64_2117 |
| 112× | *-commutative_binary64_2055 |
| 107× | exp-prod_binary64_2176 |
| 93× | distribute-rgt-out_binary64_2077 |
| 88× | unswap-sqr_binary64_2092 distribute-neg-in_binary64_2085 |
| 86× | distribute-rgt-neg-in_binary64_2082 |
| 73× | exp-diff_binary64_2172 |
| 71× | neg-sub0_binary64_2119 distribute-lft-neg-in_binary64_2081 |
| 68× | cube-prod_binary64_2152 |
| 66× | sqr-pow_binary64_2096 |
| 61× | distribute-lft-out_binary64_2075 |
| 57× | neg-mul-1_binary64_2120 |
| 47× | +-commutative_binary64_2054 |
| 43× | associate-+l+_binary64_2057 |
| 34× | associate-+r+_binary64_2056 |
| 33× | log-prod_binary64_2210 |
| 30× | swap-sqr_binary64_2091 |
| 28× | difference-of-squares_binary64_2093 |
| 27× | distribute-rgt-out--_binary64_2078 associate-+l-_binary64_2059 |
| 23× | distribute-lft-out--_binary64_2076 associate--r+_binary64_2060 associate-+r-_binary64_2058 |
| 21× | unpow3_binary64_2190 |
| 19× | cube-neg_binary64_2151 |
| 17× | mul0-rgt_binary64_2107 mul0-lft_binary64_2106 associate--l+_binary64_2061 |
| 16× | +-rgt-identity_binary64_2109 |
| 15× | exp-neg_binary64_2171 sqr-neg_binary64_2138 distribute-neg-out_binary64_2086 |
| 13× | cube-mult_binary64_2154 |
| 12× | cube-unmult_binary64_2161 sub0-neg_binary64_2111 |
| 11× | remove-double-neg_binary64_2112 pow-sqr_binary64_2097 |
| 8× | cancel-sign-sub_binary64_2089 |
| 5× | mul-1-neg_binary64_2116 associate-/l*_binary64_2069 associate--r-_binary64_2063 |
| 3× | div-exp_binary64_2175 prod-exp_binary64_2173 div-sub_binary64_2129 --rgt-identity_binary64_2110 associate-/r*_binary64_2068 |
| 2× | associate--l-_binary64_2062 |
| 1× | 1-exp_binary64_2168 exp-1-e_binary64_2167 *-lft-identity_binary64_2113 distribute-frac-neg_binary64_2087 associate-*l/_binary64_2067 associate-*r/_binary64_2066 |
| 0× | not-true not-false not-not not-and not-or and-true-l and-true-r and-false-l and-false-r and-same or-true-l or-true-r or-false-l or-false-r or-same erfc-erf_binary64_2387 erf-erfc_binary64_2386 erf-odd_binary64_2385 if-if-and-not_binary64_2384 if-if-and_binary64_2383 if-if-or-not_binary64_2382 if-if-or_binary64_2381 if-not_binary64_2380 if-same_binary64_2379 if-false_binary64_2378 if-true_binary64_2377 not-gte_binary64_2376 not-lte_binary64_2375 not-gt_binary64_2374 not-lt_binary64_2373 gte-same_binary64_2372 lte-same_binary64_2371 gt-same_binary64_2370 lt-same_binary64_2369 sinh---cosh_binary64_2316 sinh-+-cosh_binary64_2315 sinh-cosh_binary64_2314 tanh-def-c_binary64_2313 tanh-def-b_binary64_2312 tanh-def-a_binary64_2311 cosh-def_binary64_2310 sinh-def_binary64_2309 tan-neg_binary64_2256 cos-neg_binary64_2255 sin-neg_binary64_2254 tan-0_binary64_2253 cos-0_binary64_2252 sin-0_binary64_2251 hang-m-tan_binary64_2250 hang-p-tan_binary64_2249 hang-m0-tan_binary64_2248 hang-p0-tan_binary64_2247 hang-0m-tan_binary64_2246 hang-0p-tan_binary64_2245 tan-+PI/2_binary64_2244 tan-+PI_binary64_2243 tan-PI_binary64_2242 tan-PI/3_binary64_2241 tan-PI/4_binary64_2240 tan-PI/6_binary64_2239 cos-+PI/2_binary64_2238 cos-+PI_binary64_2237 cos-PI_binary64_2236 cos-PI/2_binary64_2235 cos-PI/3_binary64_2234 cos-PI/4_binary64_2233 cos-PI/6_binary64_2232 sin-+PI/2_binary64_2231 sin-+PI_binary64_2230 sin-PI_binary64_2229 sin-PI/2_binary64_2228 sin-PI/3_binary64_2227 sin-PI/4_binary64_2226 sin-PI/6_binary64_2225 sub-1-sin_binary64_2224 sub-1-cos_binary64_2223 -1-add-sin_binary64_2222 -1-add-cos_binary64_2221 1-sub-sin_binary64_2220 1-sub-cos_binary64_2219 cos-sin-sum_binary64_2218 log-E_binary64_2214 log-pow_binary64_2213 log-rec_binary64_2212 log-div_binary64_2211 pow-base-0_binary64_2208 unpow1/3_binary64_2191 unpow2_binary64_2189 unpow1/2_binary64_2188 pow-plus_binary64_2187 exp-to-pow_binary64_2186 pow-base-1_binary64_2184 unpow0_binary64_2183 unpow1_binary64_2182 unpow-1_binary64_2181 exp-lft-cube_binary64_2180 exp-lft-sqr_binary64_2179 exp-cbrt_binary64_2178 exp-sqrt_binary64_2177 rec-exp_binary64_2174 e-exp-1_binary64_2169 exp-0_binary64_2166 rem-log-exp_binary64_2165 rem-exp-log_binary64_2164 cube-div_binary64_2153 rem-3cbrt-rft_binary64_2150 rem-3cbrt-lft_binary64_2149 rem-cbrt-cube_binary64_2148 rem-cube-cbrt_binary64_2147 sqr-abs_binary64_2139 rem-sqrt-square_binary64_2137 rem-square-sqrt_binary64_2136 /-rgt-identity_binary64_2115 *-rgt-identity_binary64_2114 +-lft-identity_binary64_2108 div0_binary64_2105 *-inverses_binary64_2104 +-inverses_binary64_2103 lft-mult-inverse_binary64_2102 rgt-mult-inverse_binary64_2101 remove-double-div_binary64_2100 difference-of-sqr--1_binary64_2095 difference-of-sqr-1_binary64_2094 distribute-neg-frac_binary64_2088 distribute-rgt1-in_binary64_2080 distribute-lft1-in_binary64_2079 count-2_binary64_2072 associate-/l/_binary64_2071 associate-/r/_binary64_2070 |
Useful iterations: 2 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 74 | 727 |
| 1 | 222 | 655 |
| 2 | 735 | 649 |
| 3 | 2599 | 649 |
| 4 | 4399 | 649 |
| 5 | 5234 | 649 |
3 alts after pruning (2 fresh and 1 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 53 | 1 | 54 |
| Fresh | 0 | 1 | 1 |
| Picked | 0 | 1 | 1 |
| Done | 0 | 0 | 0 |
| Total | 53 | 3 | 56 |
Compiled 802 to 139 computations (82.7% saved)
Found 2 expressions with local error:
| 0.0b | (-.f64 (-.f64 d2 d3) d1) |
| 0.0b | (*.f64 d1 (+.f64 d4 (-.f64 (-.f64 d2 d3) d1))) |
| 1× | rewrite-expression-head |
| 20× | *-un-lft-identity_binary64_2124 |
| 10× | add-sqr-sqrt_binary64_2146 |
| 7× | add-log-exp_binary64_2163 |
| 6× | add-cube-cbrt_binary64_2159 associate-*r*_binary64_2064 distribute-lft-out--_binary64_2076 cancel-sign-sub-inv_binary64_2090 |
| 4× | pow1_binary64_2185 add-exp-log_binary64_2162 add-cbrt-cube_binary64_2160 associate--l+_binary64_2061 |
| 3× | associate-*l*_binary64_2065 distribute-lft-out_binary64_2075 diff-log_binary64_2216 |
| 2× | associate-*r/_binary64_2066 sub-neg_binary64_2117 |
| 1× | pow-prod-down_binary64_2195 prod-exp_binary64_2173 cbrt-unprod_binary64_2157 unswap-sqr_binary64_2092 distribute-rgt-in_binary64_2074 distribute-lft-in_binary64_2073 flip3-+_binary64_2127 flip-+_binary64_2098 *-commutative_binary64_2055 flip3--_binary64_2128 flip--_binary64_2099 difference-of-squares_binary64_2093 associate--l-_binary64_2062 |
2 calls:
| 12.0ms | (*.f64 d1 (+.f64 d4 (-.f64 (-.f64 d2 d3) d1))) |
| 8.0ms | (-.f64 (-.f64 d2 d3) d1) |
Compiled 767 to 213 computations (72.2% saved)
2 calls:
| 275.0ms | (*.f64 d1 (+.f64 d4 (-.f64 (-.f64 d2 d3) d1))) |
| 105.0ms | (-.f64 (-.f64 d2 d3) d1) |
Compiled 1025 to 685 computations (33.2% saved)
| 1× | egg-herbie |
| 680× | distribute-rgt-in_binary64_2074 |
| 658× | distribute-lft-in_binary64_2073 |
| 354× | exp-sum_binary64_2170 |
| 228× | unsub-neg_binary64_2118 |
| 220× | exp-prod_binary64_2176 |
| 183× | *-commutative_binary64_2055 |
| 170× | cancel-sign-sub-inv_binary64_2090 |
| 162× | sub-neg_binary64_2117 |
| 145× | distribute-neg-in_binary64_2085 |
| 139× | exp-diff_binary64_2172 |
| 96× | unswap-sqr_binary64_2092 |
| 85× | associate-+l+_binary64_2057 |
| 80× | associate-+r+_binary64_2056 |
| 79× | associate-*l*_binary64_2065 |
| 74× | sqr-pow_binary64_2096 |
| 69× | neg-mul-1_binary64_2120 |
| 67× | neg-sub0_binary64_2119 |
| 65× | associate-*r*_binary64_2064 |
| 53× | +-commutative_binary64_2054 |
| 51× | log-prod_binary64_2210 |
| 47× | *-rgt-identity_binary64_2114 *-lft-identity_binary64_2113 |
| 37× | associate--r+_binary64_2060 |
| 36× | associate-+l-_binary64_2059 |
| 35× | div-sub_binary64_2129 associate-+r-_binary64_2058 |
| 32× | swap-sqr_binary64_2091 |
| 30× | distribute-lft-neg-out_binary64_2083 |
| 26× | distribute-rgt-neg-out_binary64_2084 distribute-rgt-neg-in_binary64_2082 associate--l+_binary64_2061 |
| 23× | cube-prod_binary64_2152 |
| 21× | +-rgt-identity_binary64_2109 |
| 17× | distribute-lft-neg-in_binary64_2081 |
| 16× | sub0-neg_binary64_2111 |
| 15× | mul0-rgt_binary64_2107 mul0-lft_binary64_2106 distribute-neg-out_binary64_2086 |
| 12× | remove-double-neg_binary64_2112 associate--r-_binary64_2063 |
| 11× | unpow3_binary64_2190 |
| 10× | difference-of-squares_binary64_2093 |
| 8× | times-frac_binary64_2130 distribute-rgt-out--_binary64_2078 distribute-rgt-out_binary64_2077 |
| 6× | unpow1/2_binary64_2188 pow-sqr_binary64_2097 |
| 5× | cube-unmult_binary64_2161 |
| 4× | log-pow_binary64_2213 div-exp_binary64_2175 cube-mult_binary64_2154 sqr-neg_binary64_2138 --rgt-identity_binary64_2110 |
| 3× | rem-sqrt-square_binary64_2137 mul-1-neg_binary64_2116 distribute-lft-out--_binary64_2076 associate--l-_binary64_2062 |
| 2× | pow-plus_binary64_2187 exp-neg_binary64_2171 rem-3cbrt-lft_binary64_2149 rem-square-sqrt_binary64_2136 distribute-frac-neg_binary64_2087 |
| 1× | unpow2_binary64_2189 unpow1_binary64_2182 prod-exp_binary64_2173 1-exp_binary64_2168 exp-1-e_binary64_2167 cube-neg_binary64_2151 distribute-lft-out_binary64_2075 associate-/l/_binary64_2071 associate-/l*_binary64_2069 associate-/r*_binary64_2068 |
| 0× | not-true not-false not-not not-and not-or and-true-l and-true-r and-false-l and-false-r and-same or-true-l or-true-r or-false-l or-false-r or-same erfc-erf_binary64_2387 erf-erfc_binary64_2386 erf-odd_binary64_2385 if-if-and-not_binary64_2384 if-if-and_binary64_2383 if-if-or-not_binary64_2382 if-if-or_binary64_2381 if-not_binary64_2380 if-same_binary64_2379 if-false_binary64_2378 if-true_binary64_2377 not-gte_binary64_2376 not-lte_binary64_2375 not-gt_binary64_2374 not-lt_binary64_2373 gte-same_binary64_2372 lte-same_binary64_2371 gt-same_binary64_2370 lt-same_binary64_2369 sinh---cosh_binary64_2316 sinh-+-cosh_binary64_2315 sinh-cosh_binary64_2314 tanh-def-c_binary64_2313 tanh-def-b_binary64_2312 tanh-def-a_binary64_2311 cosh-def_binary64_2310 sinh-def_binary64_2309 tan-neg_binary64_2256 cos-neg_binary64_2255 sin-neg_binary64_2254 tan-0_binary64_2253 cos-0_binary64_2252 sin-0_binary64_2251 hang-m-tan_binary64_2250 hang-p-tan_binary64_2249 hang-m0-tan_binary64_2248 hang-p0-tan_binary64_2247 hang-0m-tan_binary64_2246 hang-0p-tan_binary64_2245 tan-+PI/2_binary64_2244 tan-+PI_binary64_2243 tan-PI_binary64_2242 tan-PI/3_binary64_2241 tan-PI/4_binary64_2240 tan-PI/6_binary64_2239 cos-+PI/2_binary64_2238 cos-+PI_binary64_2237 cos-PI_binary64_2236 cos-PI/2_binary64_2235 cos-PI/3_binary64_2234 cos-PI/4_binary64_2233 cos-PI/6_binary64_2232 sin-+PI/2_binary64_2231 sin-+PI_binary64_2230 sin-PI_binary64_2229 sin-PI/2_binary64_2228 sin-PI/3_binary64_2227 sin-PI/4_binary64_2226 sin-PI/6_binary64_2225 sub-1-sin_binary64_2224 sub-1-cos_binary64_2223 -1-add-sin_binary64_2222 -1-add-cos_binary64_2221 1-sub-sin_binary64_2220 1-sub-cos_binary64_2219 cos-sin-sum_binary64_2218 log-E_binary64_2214 log-rec_binary64_2212 log-div_binary64_2211 pow-base-0_binary64_2208 unpow1/3_binary64_2191 exp-to-pow_binary64_2186 pow-base-1_binary64_2184 unpow0_binary64_2183 unpow-1_binary64_2181 exp-lft-cube_binary64_2180 exp-lft-sqr_binary64_2179 exp-cbrt_binary64_2178 exp-sqrt_binary64_2177 rec-exp_binary64_2174 e-exp-1_binary64_2169 exp-0_binary64_2166 rem-log-exp_binary64_2165 rem-exp-log_binary64_2164 cube-div_binary64_2153 rem-3cbrt-rft_binary64_2150 rem-cbrt-cube_binary64_2148 rem-cube-cbrt_binary64_2147 sqr-abs_binary64_2139 /-rgt-identity_binary64_2115 +-lft-identity_binary64_2108 div0_binary64_2105 *-inverses_binary64_2104 +-inverses_binary64_2103 lft-mult-inverse_binary64_2102 rgt-mult-inverse_binary64_2101 remove-double-div_binary64_2100 difference-of-sqr--1_binary64_2095 difference-of-sqr-1_binary64_2094 cancel-sign-sub_binary64_2089 distribute-neg-frac_binary64_2088 distribute-rgt1-in_binary64_2080 distribute-lft1-in_binary64_2079 count-2_binary64_2072 associate-/r/_binary64_2070 associate-*l/_binary64_2067 associate-*r/_binary64_2066 |
Useful iterations: 2 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 119 | 1056 |
| 1 | 293 | 960 |
| 2 | 894 | 915 |
| 3 | 3442 | 915 |
| 4 | 4576 | 915 |
| 5 | 4928 | 915 |
3 alts after pruning (1 fresh and 2 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 64 | 0 | 64 |
| Fresh | 0 | 1 | 1 |
| Picked | 0 | 1 | 1 |
| Done | 0 | 1 | 1 |
| Total | 64 | 3 | 67 |
Compiled 807 to 160 computations (80.2% saved)
Found 4 expressions with local error:
| 0.5b | (*.f64 (cbrt.f64 (*.f64 d1 (-.f64 d2 d3))) (cbrt.f64 (*.f64 d1 (-.f64 d2 d3)))) |
| 3.4b | (cbrt.f64 (*.f64 d1 (-.f64 d2 d3))) |
| 3.4b | (cbrt.f64 (*.f64 d1 (-.f64 d2 d3))) |
| 3.4b | (cbrt.f64 (*.f64 d1 (-.f64 d2 d3))) |
| 1× | rewrite-expression-head |
| 20× | associate-*r/_binary64_2066 |
| 18× | cbrt-div_binary64_2156 |
| 11× | pow1_binary64_2185 |
| 10× | add-sqr-sqrt_binary64_2146 |
| 9× | pow1/3_binary64_2206 flip3--_binary64_2128 flip--_binary64_2099 |
| 8× | add-cube-cbrt_binary64_2159 *-un-lft-identity_binary64_2124 |
| 7× | cbrt-prod_binary64_2155 |
| 6× | add-exp-log_binary64_2162 |
| 4× | add-log-exp_binary64_2163 add-cbrt-cube_binary64_2160 frac-times_binary64_2134 swap-sqr_binary64_2091 associate-*l*_binary64_2065 associate-*r*_binary64_2064 |
| 2× | pow-prod-down_binary64_2195 pow-prod-up_binary64_2194 pow-sqr_binary64_2097 associate-*l/_binary64_2067 |
| 1× | pow2_binary64_2205 pow-plus_binary64_2187 prod-exp_binary64_2173 cbrt-unprod_binary64_2157 unswap-sqr_binary64_2092 *-commutative_binary64_2055 |
4 calls:
| 7.0ms | (*.f64 (cbrt.f64 (*.f64 d1 (-.f64 d2 d3))) (cbrt.f64 (*.f64 d1 (-.f64 d2 d3)))) |
| 5.0ms | (cbrt.f64 (*.f64 d1 (-.f64 d2 d3))) |
| 5.0ms | (cbrt.f64 (*.f64 d1 (-.f64 d2 d3))) |
| 5.0ms | (cbrt.f64 (*.f64 d1 (-.f64 d2 d3))) |
Compiled 2603 to 447 computations (82.8% saved)
4 calls:
| 524.0ms | (*.f64 (cbrt.f64 (*.f64 d1 (-.f64 d2 d3))) (cbrt.f64 (*.f64 d1 (-.f64 d2 d3)))) |
| 373.0ms | (cbrt.f64 (*.f64 d1 (-.f64 d2 d3))) |
| 365.0ms | (cbrt.f64 (*.f64 d1 (-.f64 d2 d3))) |
| 365.0ms | (cbrt.f64 (*.f64 d1 (-.f64 d2 d3))) |
Compiled 7171 to 4563 computations (36.4% saved)
| 1× | egg-herbie |
| 718× | times-frac_binary64_2130 |
| 530× | associate-/l*_binary64_2069 |
| 159× | distribute-rgt-neg-in_binary64_2082 |
| 155× | distribute-lft-neg-in_binary64_2081 |
| 133× | associate-/r/_binary64_2070 |
| 129× | associate-*r*_binary64_2064 |
| 127× | distribute-rgt-in_binary64_2074 |
| 126× | cancel-sign-sub-inv_binary64_2090 |
| 124× | unswap-sqr_binary64_2092 |
| 110× | *-commutative_binary64_2055 |
| 108× | distribute-lft-in_binary64_2073 |
| 103× | distribute-neg-frac_binary64_2088 |
| 99× | sub-neg_binary64_2117 |
| 97× | associate-*l*_binary64_2065 |
| 89× | sqr-pow_binary64_2096 |
| 73× | neg-sub0_binary64_2119 |
| 71× | neg-mul-1_binary64_2120 |
| 60× | exp-prod_binary64_2176 |
| 58× | exp-sum_binary64_2170 |
| 43× | +-commutative_binary64_2054 |
| 36× | associate-*r/_binary64_2066 |
| 34× | unsub-neg_binary64_2118 |
| 29× | associate-/r*_binary64_2068 |
| 28× | distribute-lft-neg-out_binary64_2083 |
| 27× | distribute-neg-in_binary64_2085 |
| 24× | distribute-rgt-neg-out_binary64_2084 |
| 22× | log-prod_binary64_2210 associate-/l/_binary64_2071 associate-*l/_binary64_2067 |
| 19× | unpow1/3_binary64_2191 distribute-lft-out_binary64_2075 |
| 16× | pow-sqr_binary64_2097 distribute-neg-out_binary64_2086 |
| 14× | div-sub_binary64_2129 associate--r+_binary64_2060 |
| 12× | exp-diff_binary64_2172 distribute-rgt-out_binary64_2077 |
| 9× | cube-prod_binary64_2152 |
| 8× | *-rgt-identity_binary64_2114 |
| 7× | log-pow_binary64_2213 *-lft-identity_binary64_2113 associate-+l+_binary64_2057 |
| 6× | log-div_binary64_2211 remove-double-neg_binary64_2112 swap-sqr_binary64_2091 associate--r-_binary64_2063 associate-+r+_binary64_2056 |
| 5× | unpow2_binary64_2189 unpow1/2_binary64_2188 exp-to-pow_binary64_2186 unpow1_binary64_2182 |
| 4× | cube-unmult_binary64_2161 difference-of-squares_binary64_2093 distribute-rgt-out--_binary64_2078 distribute-lft-out--_binary64_2076 |
| 3× | log-rec_binary64_2212 pow-plus_binary64_2187 associate--l+_binary64_2061 |
| 2× | unpow3_binary64_2190 cube-mult_binary64_2154 rem-3cbrt-lft_binary64_2149 rem-sqrt-square_binary64_2137 mul-1-neg_binary64_2116 distribute-frac-neg_binary64_2087 count-2_binary64_2072 |
| 1× | exp-lft-sqr_binary64_2179 1-exp_binary64_2168 exp-1-e_binary64_2167 rem-3cbrt-rft_binary64_2150 rem-square-sqrt_binary64_2136 |
| 0× | not-true not-false not-not not-and not-or and-true-l and-true-r and-false-l and-false-r and-same or-true-l or-true-r or-false-l or-false-r or-same erfc-erf_binary64_2387 erf-erfc_binary64_2386 erf-odd_binary64_2385 if-if-and-not_binary64_2384 if-if-and_binary64_2383 if-if-or-not_binary64_2382 if-if-or_binary64_2381 if-not_binary64_2380 if-same_binary64_2379 if-false_binary64_2378 if-true_binary64_2377 not-gte_binary64_2376 not-lte_binary64_2375 not-gt_binary64_2374 not-lt_binary64_2373 gte-same_binary64_2372 lte-same_binary64_2371 gt-same_binary64_2370 lt-same_binary64_2369 sinh---cosh_binary64_2316 sinh-+-cosh_binary64_2315 sinh-cosh_binary64_2314 tanh-def-c_binary64_2313 tanh-def-b_binary64_2312 tanh-def-a_binary64_2311 cosh-def_binary64_2310 sinh-def_binary64_2309 tan-neg_binary64_2256 cos-neg_binary64_2255 sin-neg_binary64_2254 tan-0_binary64_2253 cos-0_binary64_2252 sin-0_binary64_2251 hang-m-tan_binary64_2250 hang-p-tan_binary64_2249 hang-m0-tan_binary64_2248 hang-p0-tan_binary64_2247 hang-0m-tan_binary64_2246 hang-0p-tan_binary64_2245 tan-+PI/2_binary64_2244 tan-+PI_binary64_2243 tan-PI_binary64_2242 tan-PI/3_binary64_2241 tan-PI/4_binary64_2240 tan-PI/6_binary64_2239 cos-+PI/2_binary64_2238 cos-+PI_binary64_2237 cos-PI_binary64_2236 cos-PI/2_binary64_2235 cos-PI/3_binary64_2234 cos-PI/4_binary64_2233 cos-PI/6_binary64_2232 sin-+PI/2_binary64_2231 sin-+PI_binary64_2230 sin-PI_binary64_2229 sin-PI/2_binary64_2228 sin-PI/3_binary64_2227 sin-PI/4_binary64_2226 sin-PI/6_binary64_2225 sub-1-sin_binary64_2224 sub-1-cos_binary64_2223 -1-add-sin_binary64_2222 -1-add-cos_binary64_2221 1-sub-sin_binary64_2220 1-sub-cos_binary64_2219 cos-sin-sum_binary64_2218 log-E_binary64_2214 pow-base-0_binary64_2208 pow-base-1_binary64_2184 unpow0_binary64_2183 unpow-1_binary64_2181 exp-lft-cube_binary64_2180 exp-cbrt_binary64_2178 exp-sqrt_binary64_2177 div-exp_binary64_2175 rec-exp_binary64_2174 prod-exp_binary64_2173 exp-neg_binary64_2171 e-exp-1_binary64_2169 exp-0_binary64_2166 rem-log-exp_binary64_2165 rem-exp-log_binary64_2164 cube-div_binary64_2153 cube-neg_binary64_2151 rem-cbrt-cube_binary64_2148 rem-cube-cbrt_binary64_2147 sqr-abs_binary64_2139 sqr-neg_binary64_2138 /-rgt-identity_binary64_2115 sub0-neg_binary64_2111 --rgt-identity_binary64_2110 +-rgt-identity_binary64_2109 +-lft-identity_binary64_2108 mul0-rgt_binary64_2107 mul0-lft_binary64_2106 div0_binary64_2105 *-inverses_binary64_2104 +-inverses_binary64_2103 lft-mult-inverse_binary64_2102 rgt-mult-inverse_binary64_2101 remove-double-div_binary64_2100 difference-of-sqr--1_binary64_2095 difference-of-sqr-1_binary64_2094 cancel-sign-sub_binary64_2089 distribute-rgt1-in_binary64_2080 distribute-lft1-in_binary64_2079 associate--l-_binary64_2062 associate-+l-_binary64_2059 associate-+r-_binary64_2058 |
Useful iterations: 2 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 230 | 3657 |
| 1 | 596 | 3489 |
| 2 | 1706 | 3316 |
| 3 | 5281 | 3316 |
3 alts after pruning (0 fresh and 3 done)
| Pruned | Kept | Total | |
|---|---|---|---|
| New | 98 | 0 | 98 |
| Fresh | 0 | 0 | 0 |
| Picked | 0 | 1 | 1 |
| Done | 0 | 2 | 2 |
| Total | 98 | 3 | 101 |
Compiled 3744 to 1282 computations (65.8% saved)
Total 0.0b remaining (74.1%)
Threshold costs 0.0b (74.1%)
Compiled 2343 to 1754 computations (25.1% saved)
| 1× | egg-herbie |
| 6× | +-commutative_binary64_2054 |
| 5× | *-commutative_binary64_2055 |
| 4× | sub-neg_binary64_2117 |
| 3× | neg-mul-1_binary64_2120 neg-sub0_binary64_2119 |
| 2× | unsub-neg_binary64_2118 distribute-neg-in_binary64_2085 |
| 0× | not-true not-false not-not not-and not-or and-true-l and-true-r and-false-l and-false-r and-same or-true-l or-true-r or-false-l or-false-r or-same if-if-and-not_binary64_2384 if-if-and_binary64_2383 if-if-or-not_binary64_2382 if-if-or_binary64_2381 if-not_binary64_2380 if-same_binary64_2379 if-false_binary64_2378 if-true_binary64_2377 tan-0_binary64_2253 cos-0_binary64_2252 sin-0_binary64_2251 unpow1_binary64_2182 e-exp-1_binary64_2169 1-exp_binary64_2168 exp-1-e_binary64_2167 exp-0_binary64_2166 sqr-abs_binary64_2139 sqr-neg_binary64_2138 mul-1-neg_binary64_2116 /-rgt-identity_binary64_2115 *-rgt-identity_binary64_2114 *-lft-identity_binary64_2113 remove-double-neg_binary64_2112 sub0-neg_binary64_2111 --rgt-identity_binary64_2110 +-rgt-identity_binary64_2109 +-lft-identity_binary64_2108 cancel-sign-sub-inv_binary64_2090 cancel-sign-sub_binary64_2089 distribute-neg-frac_binary64_2088 distribute-frac-neg_binary64_2087 distribute-neg-out_binary64_2086 distribute-rgt-neg-out_binary64_2084 distribute-lft-neg-out_binary64_2083 distribute-rgt-neg-in_binary64_2082 distribute-lft-neg-in_binary64_2081 |
Useful iterations: 0 (0.0ms)
| Iter | Nodes | Cost |
|---|---|---|
| 0 | 10 | 16 |
| 1 | 16 | 16 |
| 2 | 25 | 16 |
| 3 | 33 | 16 |
| 4 | 38 | 16 |
| 5 | 40 | 16 |
| 6 | 40 | 16 |
(sort d2 d4)
Compiled 22 to 18 computations (18.2% saved)
| 1× | intervals |
| 314.0ms | 8000× | body | 128 | valid |
| 87.0ms | 2307× | body | 128 | invalid |
Compiled 497 to 373 computations (24.9% saved)
Loading profile data...