Profiling results ----------------- Total cpu time observed: 370568ms (out of 373700ms) Number of samples taken: 3565 (once every 104ms) (Hiding functions with self<1.0% and local<2.0%: 23 of 291 hidden) ========================================================================================= Caller Idx Total Self Name+src Local% ms(pct) ms(pct) Callee ========================================================================================= ??? [64] 100.0% [1] 344356(92.9%) 0(0.0%) run-improve50 ...ock/herbie/src/mainloop.rkt:234:0 for-loop [20] 87.7% get-final-combination [23] 11.8% setup-prog [30] 0.4% loop [75] 0.2% ----------------------------------------------------------------------------------------- ??? [64] 100.0% [2] 333764(90.1%) 0(0.0%) profile-thunk16 ...t/pkgs/profile-lib/main.rkt:9:0 run [19] 100.0% ----------------------------------------------------------------------------------------- simplify-alt [42] 0.4% loop [238] 3.4% ??? [64] 96.2% [3] 291920(78.8%) 168(0.0%) simplify ...lock/herbie/src/core/simplify.rkt:39:0 simplify-expr [21] 58.1% for-loop [22] 25.6% iterate-egraph!5 [36] 12.9% loop [37] 3.3% ----------------------------------------------------------------------------------------- copying-mergesort [183] 100.0% [4] 8998(2.4%) 0(0.0%) jloop ...t/collects/racket/private/sort.rkt:121:23 ??? [185] 99.1% ??? [186] 0.9% ----------------------------------------------------------------------------------------- hash-ref! [221] 100.0% [5] 5528(1.5%) 0(0.0%) ??? .../ztatlock/herbie/src/core/taylor.rkt:281:26 for-loop [24] 100.0% ----------------------------------------------------------------------------------------- loop [238] 100.0% [6] 4584(1.2%) 1034(0.3%) for-loop ...ock/herbie/src/core/simplify.rkt:161:2 eval-const-expr [29] 32.8% setfindf [31] 29.7% compose [161] 9.2% ->flonum [188] 2.1% curried [247] 2.1% curry* [105] 1.6% ----------------------------------------------------------------------------------------- hash-ref! [221] 100.0% [7] 4366(1.2%) 0(0.0%) ??? .../ztatlock/herbie/src/core/taylor.rkt:291:23 for-loop [25] 100.0% ----------------------------------------------------------------------------------------- hash-ref! [221] 100.0% [8] 3250(0.9%) 0(0.0%) ??? .../ztatlock/herbie/src/core/taylor.rkt:388:23 for-loop [26] 100.0% ----------------------------------------------------------------------------------------- hash-ref! [221] 100.0% [9] 1970(0.5%) 0(0.0%) ??? .../ztatlock/herbie/src/core/taylor.rkt:479:23 for-loop [27] 100.0% ----------------------------------------------------------------------------------------- hash-ref! [221] 100.0% [10] 1766(0.5%) 0(0.0%) ??? .../ztatlock/herbie/src/core/taylor.rkt:334:33 for-loop [28] 94.0% hash-ref! [221] 6.0% ----------------------------------------------------------------------------------------- f6 [149] 100.0% [11] 494(0.1%) 0(0.0%) taylor-quotient ...erbie/src/core/taylor.rkt:324:0 first-nonzero-exp [169] 57.1% simplify [242] 42.9% ----------------------------------------------------------------------------------------- hash-ref! [221] 17.7% f6 [149] 82.3% [12] 406(0.1%) 0(0.0%) taylor ...tatlock/herbie/src/core/taylor.rkt:159:0 loop [238] 46.3% curry* [105] 31.0% debug-print [252] 22.7% ----------------------------------------------------------------------------------------- rewriter [78] 100.0% [13] 370(0.1%) 0(0.0%) *rules* ...tlock/herbie/src/syntax/rules.rkt:411:0 for-loop [107] 74.6% ??? [198] 25.4% ----------------------------------------------------------------------------------------- hash-ref! [221] 100.0% [14] 212(0.1%) 0(0.0%) ??? .../ztatlock/herbie/src/core/taylor.rkt:404:23 for-loop [32] 100.0% ----------------------------------------------------------------------------------------- append-map [162] 100.0% [15] 196(0.1%) 0(0.0%) free-variables ...ock/herbie/src/programs.rkt:98:0 ??? [207] 100.0% ----------------------------------------------------------------------------------------- f6 [149] 100.0% [16] 196(0.1%) 0(0.0%) taylor-log ...ock/herbie/src/core/taylor.rkt:472:0 simplify [242] 100.0% ----------------------------------------------------------------------------------------- f6 [149] 100.0% [17] 132(0.0%) 0(0.0%) combine-mterms ...herbie/src/core/reduce.rkt:180:0 for-loop [33] 100.0% ----------------------------------------------------------------------------------------- hash-ref! [221] 100.0% [18] 94(0.0%) 0(0.0%) ??? .../ztatlock/herbie/src/core/taylor.rkt:318:33 for-loop [34] 100.0% ----------------------------------------------------------------------------------------- profile-thunk16 [2] 99.9% [19] 333986(90.1%) 0(0.0%) run ...share/racket/pkgs/profile-lib/main.rkt:39:2 ??? [64] 100.0% ----------------------------------------------------------------------------------------- run-improve50 [1] 100.0% [20] 301844(81.5%) 0(0.0%) for-loop ...ztatlock/herbie/src/mainloop.rkt:245:8 run-iter! [35] 100.0% ----------------------------------------------------------------------------------------- simplify [3] 100.0% [21] 169654(45.8%) 94(0.0%) simplify-expr ...herbie/src/core/simplify.rkt:68:0 iterate-egraph!5 [36] 83.0% loop [37] 16.8% mk-egraph [45] 0.1% ----------------------------------------------------------------------------------------- simplify [3] 100.0% [22] 74780(20.2%) 186(0.1%) for-loop ...ock/herbie/src/core/simplify.rkt:61:12 iterate-egraph!5 [36] 84.2% loop [37] 15.6% ----------------------------------------------------------------------------------------- run-improve50 [1] 100.0% [23] 40512(10.9%) 0(0.0%) get-final-combination ...ie/src/mainloop.rkt:260:0 split-table [38] 75.6% extract-alt [39] 24.4% ----------------------------------------------------------------------------------------- ??? [5] 100.0% [24] 5528(1.5%) 182(0.0%) for-loop ...lock/herbie/src/core/taylor.rkt:281:52 hash-ref! [221] 65.6% ??? [41] 30.6% simplify [242] 2.4% ----------------------------------------------------------------------------------------- ??? [7] 100.0% [25] 4366(1.2%) 0(0.0%) for-loop ...lock/herbie/src/core/taylor.rkt:294:27 hash-ref! [221] 97.5% simplify [242] 2.5% ----------------------------------------------------------------------------------------- ??? [8] 100.0% [26] 3250(0.9%) 0(0.0%) for-loop ...lock/herbie/src/core/taylor.rkt:392:33 for-loop [40] 100.0% ----------------------------------------------------------------------------------------- ??? [9] 100.0% [27] 1970(0.5%) 0(0.0%) for-loop ...lock/herbie/src/core/taylor.rkt:483:35 parse-loop12 [166] 100.0% ----------------------------------------------------------------------------------------- ??? [10] 100.0% [28] 1766(0.5%) 94(0.0%) for-loop ...lock/herbie/src/core/taylor.rkt:337:46 hash-ref! [221] 94.7% ----------------------------------------------------------------------------------------- for-loop [6] 100.0% [29] 1502(0.4%) 518(0.1%) eval-const-expr ...k/herbie/src/programs.rkt:164:0 f6 [149] 51.4% ??? [197] 7.9% bf* [190] 6.3% ----------------------------------------------------------------------------------------- run-improve50 [1] 100.0% [30] 1424(0.4%) 0(0.0%) setup-prog /home/ztatlock/herbie/src/glue.rkt:45:0 simplify-alt [42] 91.9% ??? [207] 8.1% ----------------------------------------------------------------------------------------- for-loop [6] 100.0% [31] 1360(0.4%) 886(0.2%) setfindf ...e/ztatlock/herbie/src/common.rkt:168:0 for-loop [43] 28.7% ??? [207] 6.2% ----------------------------------------------------------------------------------------- ??? [14] 100.0% [32] 212(0.1%) 0(0.0%) for-loop ...lock/herbie/src/core/taylor.rkt:407:30 for-loop [44] 100.0% ----------------------------------------------------------------------------------------- combine-mterms [17] 100.0% [33] 132(0.0%) 0(0.0%) for-loop ...tlock/herbie/src/core/reduce.rkt:184:5 hash-ref! [221] 100.0% ----------------------------------------------------------------------------------------- ??? [18] 100.0% [34] 94(0.0%) 0(0.0%) for-loop ...lock/herbie/src/core/taylor.rkt:320:46 simplify [242] 100.0% ----------------------------------------------------------------------------------------- for-loop [20] 100.0% [35] 301844(81.5%) 0(0.0%) run-iter! ...tatlock/herbie/src/mainloop.rkt:215:0 simplify! [46] 92.1% finalize-iter! [49] 4.6% gen-series! [50] 2.6% gen-rewrites! [52] 0.4% localize-error [53] 0.1% ----------------------------------------------------------------------------------------- simplify [3] 15.6% for-loop [22] 26.1% simplify-expr [21] 58.3% [36] 241502(65.2%) 618(0.2%) iterate-egraph!5 ...bie/src/core/simplify.rkt:95:0 one-iter [47] 97.3% map-enodes [51] 2.2% debug7 [253] 0.1% *simplify-rules* [55] 0.0% ----------------------------------------------------------------------------------------- simplify [3] 19.3% for-loop [22] 23.4% simplify-expr [21] 57.3% [37] 49676(13.4%) 0(0.0%) loop ...tatlock/herbie/src/core/simplify.rkt:203:2 pass [48] 100.0% ----------------------------------------------------------------------------------------- get-final-combination [23] 100.0% [38] 30638(8.3%) 0(0.0%) split-table .../ztatlock/herbie/src/glue.rkt:164:0 f6 [149] 100.0% ----------------------------------------------------------------------------------------- get-final-combination [23] 100.0% [39] 9874(2.7%) 0(0.0%) extract-alt ...e/ztatlock/herbie/src/glue.rkt:56:0 loop [238] 100.0% ----------------------------------------------------------------------------------------- for-loop [26] 100.0% [40] 3250(0.9%) 0(0.0%) for-loop ...lock/herbie/src/core/taylor.rkt:394:39 hash-ref! [221] 100.0% ----------------------------------------------------------------------------------------- for-loop [24] 100.0% [41] 2214(0.6%) 0(0.0%) ??? .../ztatlock/herbie/src/core/taylor.rkt:284:19 hash-ref! [221] 100.0% ----------------------------------------------------------------------------------------- setup-prog [30] 100.0% [42] 1308(0.4%) 0(0.0%) simplify-alt .../ztatlock/herbie/src/glue.rkt:83:0 simplify [3] 100.0% ----------------------------------------------------------------------------------------- setfindf [31] 100.0% [43] 390(0.1%) 390(0.1%) for-loop ...e/ztatlock/herbie/src/common.rkt:169:2 ----------------------------------------------------------------------------------------- for-loop [32] 100.0% [44] 212(0.1%) 0(0.0%) for-loop ...lock/herbie/src/core/taylor.rkt:410:42 hash-ref! [221] 100.0% ----------------------------------------------------------------------------------------- simplify-expr [21] 100.0% [45] 198(0.1%) 0(0.0%) mk-egraph ...lock/herbie/src/core/egraph.rkt:123:0 expr->enode [54] 100.0% ----------------------------------------------------------------------------------------- run-iter! [35] 100.0% [46] 277940(75.0%) 78(0.0%) simplify! ...tatlock/herbie/src/mainloop.rkt:155:0 for-loop [56] 100.0% ----------------------------------------------------------------------------------------- iterate-egraph!5 [36] 100.0% [47] 235052(63.4%) 4274(1.2%) one-iter ...ock/herbie/src/core/simplify.rkt:106:0 loop [57] 55.6% for-loop [58] 38.2% apply-match [65] 4.2% ----------------------------------------------------------------------------------------- loop [37] 100.0% [48] 49676(13.4%) 278(0.1%) pass ...tatlock/herbie/src/core/simplify.rkt:193:2 for-loop [59] 99.4% ----------------------------------------------------------------------------------------- run-iter! [35] 100.0% [49] 13760(3.7%) 0(0.0%) finalize-iter! ...ck/herbie/src/mainloop.rkt:169:0 ??? [207] 100.0% ----------------------------------------------------------------------------------------- run-iter! [35] 100.0% [50] 7946(2.1%) 0(0.0%) gen-series! ...tlock/herbie/src/mainloop.rkt:129:0 for-loop [60] 100.0% ----------------------------------------------------------------------------------------- iterate-egraph!5 [36] 100.0% [51] 5394(1.5%) 0(0.0%) map-enodes ...ock/herbie/src/core/egraph.rkt:139:0 loop [238] 91.0% hash-keys [62] 6.8% set-precompute! [249] 2.2% ----------------------------------------------------------------------------------------- run-iter! [35] 100.0% [52] 1158(0.3%) 0(0.0%) gen-rewrites! ...ock/herbie/src/mainloop.rkt:142:0 for-loop [61] 100.0% ----------------------------------------------------------------------------------------- critical-subexpression [168] 23.0% run-iter! [35] 77.0% [53] 540(0.1%) 0(0.0%) localize-error ...erbie/src/core/localize.rkt:47:0 hash-ref! [221] 61.1% for-loop [63] 23.0% ??? [173] 15.9% ----------------------------------------------------------------------------------------- mk-egraph [45] 21.7% expr->enode [54] 78.3% [54] 198(0.1%) 104(0.0%) expr->enode ...ck/herbie/src/core/egraph.rkt:124:2 expr->enode [54] 78.3% mk-enode! [100] 15.8% ----------------------------------------------------------------------------------------- iterate-egraph!5 [36] 100.0% [55] 90(0.0%) 0(0.0%) *simplify-rules* ...bie/src/syntax/rules.rkt:415:0 for-loop [107] 100.0% ----------------------------------------------------------------------------------------- simplify! [46] 99.1% [56] 280470(75.7%) 0(0.0%) for-loop ...ztatlock/herbie/src/mainloop.rkt:159:6 ??? [64] 99.9% debug-print [252] 0.1% ----------------------------------------------------------------------------------------- one-iter [47] 100.0% [57] 130772(35.3%) 482(0.1%) loop ...cket/collects/racket/private/map.rkt:52:19 apply-match [65] 99.6% ----------------------------------------------------------------------------------------- for-loop [58] 49.3% one-iter [47] 50.7% [58] 89878(24.3%) 15798(4.3%) for-loop ...ck/herbie/src/core/simplify.rkt:116:12 for-loop [58] 49.3% match-e [72] 41.0% ??? [114] 0.2% ----------------------------------------------------------------------------------------- pass [48] 100.0% [59] 49398(13.3%) 926(0.2%) for-loop ...ck/herbie/src/core/simplify.rkt:196:29 argmin [66] 69.9% loop [67] 22.9% for-loop [69] 5.2% make-sequence [250] 0.2% ----------------------------------------------------------------------------------------- gen-series! [50] 100.0% [60] 7946(2.1%) 0(0.0%) for-loop ...ztatlock/herbie/src/mainloop.rkt:135:7 taylor-alt [68] 100.0% ----------------------------------------------------------------------------------------- gen-rewrites! [52] 100.0% [61] 1158(0.3%) 0(0.0%) for-loop ...tatlock/herbie/src/mainloop.rkt:147:11 ??? [70] 100.0% ----------------------------------------------------------------------------------------- map-enodes [51] 100.0% [62] 368(0.1%) 82(0.0%) hash-keys .../collects/racket/private/hash.rkt:2:2 loop [71] 77.7% ----------------------------------------------------------------------------------------- localize-error [53] 100.0% [63] 124(0.0%) 0(0.0%) for-loop ...ock/herbie/src/core/localize.rkt:61:10 ormap [123] 100.0% ----------------------------------------------------------------------------------------- for-loop [56] 27.2% run [19] 34.2% [64] 367662(99.2%) 0(0.0%) ??? ...lects/racket/private/more-scheme.rkt:261:28 run-improve50 [1] 35.8% profile-thunk16 [2] 34.1% simplify [3] 27.3% loop [75] 2.8% ----------------------------------------------------------------------------------------- one-iter [47] 7.1% loop [57] 92.9% [65] 140254(37.8%) 6374(1.7%) apply-match .../herbie/src/core/simplify.rkt:122:2 for-loop [73] 36.2% merge-egraph-nodes! [81] 30.6% match-e [72] 17.8% loop! [110] 4.7% substitute-e [84] 2.8% mk-enode! [100] 2.5% reduce-to-single! [79] 0.4% update-leader! [93] 0.4% ----------------------------------------------------------------------------------------- ??? [94] 0.3% for-loop [59] 99.7% [66] 34606(9.3%) 300(0.1%) argmin ...re/racket/collects/racket/list.rkt:743:0 for-loop [74] 89.8% expression-cost [77] 9.3% ----------------------------------------------------------------------------------------- for-loop [59] 100.0% [67] 11306(3.1%) 0(0.0%) loop ...hare/racket/collects/racket/list.rkt:729:4 for-loop [74] 90.5% expression-cost [77] 9.5% ----------------------------------------------------------------------------------------- for-loop [60] 100.0% [68] 7946(2.1%) 0(0.0%) taylor-alt ...e/ztatlock/herbie/src/glue.rkt:141:0 for-loop [76] 100.0% ----------------------------------------------------------------------------------------- for-loop [59] 100.0% [69] 2580(0.7%) 2580(0.7%) for-loop ...ck/herbie/src/core/simplify.rkt:183:13 ----------------------------------------------------------------------------------------- for-loop [61] 100.0% [70] 1158(0.3%) 0(0.0%) ??? /home/ztatlock/herbie/src/alternative.rkt:88:0 rewriter [78] 100.0% ----------------------------------------------------------------------------------------- hash-keys [62] 3.1% loop [71] 96.9% [71] 286(0.1%) 286(0.1%) loop ...acket/collects/racket/private/hash.rkt:3:4 loop [71] 96.9% ----------------------------------------------------------------------------------------- apply-match [65] 14.9% for-loop [91] 27.1% for-loop [58] 58.0% [72] 98652(26.6%) 30108(8.1%) match-e ...tatlock/herbie/src/core/ematch.rkt:46:0 for-loop [80] 46.9% for-loop [91] 9.5% ??? [207] 7.6% variable? [97] 4.4% list-cartesian-product [98] 3.1% loop [238] 1.6% curry* [105] 0.4% filter [266] 0.1% ----------------------------------------------------------------------------------------- apply-match [65] 100.0% [73] 50790(13.7%) 96(0.0%) for-loop ...ck/herbie/src/core/simplify.rkt:136:10 loop! [110] 50.9% merge-egraph-nodes! [81] 31.2% substitute-e [84] 11.8% mk-enode! [100] 5.9% ----------------------------------------------------------------------------------------- loop [67] 24.8% argmin [66] 75.2% [74] 41308(11.1%) 2212(0.6%) for-loop ...ztatlock/herbie/src/programs.rkt:197:2 table-ref [82] 65.2% ...erbie/src/common.rkt:46:2 [83] 27.1% ??? [131] 2.3% ----------------------------------------------------------------------------------------- run-improve50 [1] 2.8% ??? [64] 97.2% [75] 20616(5.6%) 0(0.0%) loop /home/ztatlock/herbie/src/points.rkt:159:2 make-exacts* [95] 61.9% loop [85] 35.2% loop [102] 1.2% for-loop [88] 1.1% filter-exacts [90] 0.6% ----------------------------------------------------------------------------------------- taylor-alt [68] 100.0% [76] 7946(2.1%) 0(0.0%) for-loop /home/ztatlock/herbie/src/glue.rkt:143:2 ??? [94] 100.0% ----------------------------------------------------------------------------------------- loop [67] 25.0% argmin [66] 75.0% [77] 4304(1.2%) 0(0.0%) expression-cost ...k/herbie/src/programs.rkt:196:0 compile [86] 100.0% ----------------------------------------------------------------------------------------- ??? [70] 22.4% matcher [106] 77.6% [78] 1158(0.3%) 370(0.1%) rewriter ...lock/herbie/src/core/matcher.rkt:127:2 for-loop [87] 84.6% *rules* [13] 7.5% ----------------------------------------------------------------------------------------- apply-match [65] 100.0% [79] 628(0.2%) 270(0.1%) reduce-to-single! ...bie/src/core/egraph.rkt:324:0 make-sequence [250] 32.2% for-loop [89] 24.8% ----------------------------------------------------------------------------------------- match-e [72] 100.0% [80] 61104(16.5%) 17434(4.7%) for-loop ...tlock/herbie/src/core/ematch.rkt:59:11 for-loop [91] 58.8% list-cartesian-product [98] 10.6% loop [238] 3.2% curry* [105] 1.7% foldl [244] 0.3% curried [247] 0.3% filter [266] 0.2% ----------------------------------------------------------------------------------------- merge-egraph-nodes! [81] 5.3% for-loop [99] 7.0% for-loop [73] 26.8% apply-match [65] 60.9% [81] 58746(15.9%) 1228(0.3%) merge-egraph-nodes! ...e/src/core/egraph.rkt:152:0 update-leader! [93] 30.4% loop! [110] 23.3% for-loop [96] 21.4% for-loop [99] 12.9% merge-egraph-nodes! [81] 5.3% enode-merge! [104] 4.2% for-loop [107] 0.5% make-sequence [250] 0.2% ----------------------------------------------------------------------------------------- f6 [149] 0.3% table-ref [82] 11.6% ??? [94] 17.7% for-loop [74] 70.5% [82] 38210(10.3%) 7392(2.0%) table-ref .../racket/private/norm-define.rkt:53:83 ??? [92] 54.1% table-ref [82] 11.6% ??? [94] 9.2% ??? [201] 1.6% ??? [199] 1.2% return/no-unsupplied [260] 1.0% ??? [215] 0.3% dict? [208] 0.2% ----------------------------------------------------------------------------------------- f6 [149] 1.7% ??? [94] 5.2% for-loop [74] 93.1% [83] 12032(3.2%) 3706(1.0%) ...erbie/src/common.rkt:46:2 ...e/arr-i.rkt:906:19 ??? [101] 39.8% ??? [103] 28.4% ----------------------------------------------------------------------------------------- apply-match [65] 26.4% substitute-e [84] 29.8% for-loop [73] 43.7% [84] 9894(2.7%) 1214(0.3%) substitute-e ...ck/herbie/src/core/ematch.rkt:71:0 mk-enode! [100] 49.0% substitute-e [84] 29.8% ??? [207] 7.8% variable? [97] 6.1% ----------------------------------------------------------------------------------------- loop [75] 100.0% [85] 7266(2.0%) 0(0.0%) loop /home/ztatlock/herbie/src/points.rkt:119:2 loop [102] 60.9% make-exacts* [95] 35.6% eval-prog [219] 3.5% ----------------------------------------------------------------------------------------- expression-cost [77] 100.0% [86] 4304(1.2%) 182(0.0%) compile .../ztatlock/herbie/src/programs.rkt:173:0 hash-ref! [221] 95.8% ----------------------------------------------------------------------------------------- rewriter [78] 100.0% [87] 1158(0.3%) 0(0.0%) for-loop ...ock/herbie/src/core/matcher.rkt:130:10 matcher [106] 100.0% ----------------------------------------------------------------------------------------- loop [75] 100.0% [88] 222(0.1%) 112(0.0%) for-loop .../ztatlock/herbie/src/points.rkt:166:24 for-loop [109] 49.5% ----------------------------------------------------------------------------------------- reduce-to-single! [79] 100.0% [89] 156(0.0%) 156(0.0%) for-loop ...tlock/herbie/src/core/egraph.rkt:325:8 ----------------------------------------------------------------------------------------- loop [75] 100.0% [90] 122(0.0%) 0(0.0%) filter-exacts ...tlock/herbie/src/points.rkt:134:0 for-loop [108] 100.0% ----------------------------------------------------------------------------------------- match-e [72] 29.6% for-loop [80] 70.4% [91] 53646(14.5%) 2938(0.8%) for-loop ...tlock/herbie/src/core/ematch.rkt:65:37 match-e [72] 90.5% ??? [114] 4.9% ----------------------------------------------------------------------------------------- hash-has-key? [211] 17.9% table-ref [82] 82.1% [92] 25162(6.8%) 9058(2.4%) ??? ...ects/racket/contract/private/list.rkt:737:4 for-loop [112] 50.2% ??? [142] 7.6% ??? [199] 2.8% successfully-got-the-right-kind-of-function [245] 2.1% arrow-higher-order:lnp [246] 1.3% ----------------------------------------------------------------------------------------- apply-match [65] 2.7% merge-egraph-nodes! [81] 97.3% [93] 20658(5.6%) 2514(0.7%) update-leader! ...herbie/src/core/egraph.rkt:217:0 for-loop [111] 79.4% update-en-expr [165] 3.6% custom-set-union! [122] 2.4% make-sequence [250] 2.0% mutable-set [136] 0.5% ----------------------------------------------------------------------------------------- eval-prog [219] 0.7% ??? [212] 3.9% table-ref [82] 24.9% for-loop [76] 24.9% f6 [149] 45.6% [94] 15964(4.3%) 84(0.0%) ??? ...tract/private/arrow-higher-order.rkt:342:33 table-ref [82] 45.1% approximate9 [113] 24.5% ??? [205] 12.5% ??? [131] 5.7% ...erbie/src/common.rkt:46:2 [83] 3.9% best-alt [121] 3.3% ??? [189] 2.3% ->bf [125] 0.7% argmin [66] 0.6% ->flonum [188] 0.6% simplify [242] 0.4% ----------------------------------------------------------------------------------------- loop [85] 16.9% loop [75] 83.1% [95] 15358(4.1%) 0(0.0%) make-exacts* ...atlock/herbie/src/points.rkt:106:0 loop [238] 55.2% map [157] 41.0% eval-prog [219] 3.9% ----------------------------------------------------------------------------------------- merge-egraph-nodes! [81] 100.0% [96] 12718(3.4%) 10566(2.9%) for-loop ...tlock/herbie/src/core/egraph.rkt:232:6 update-en-expr [165] 16.9% ----------------------------------------------------------------------------------------- f6 [149] 0.8% simplify* [251] 0.9% matcher [106] 1.6% substitute-e [84] 13.0% match-e [72] 83.7% [97] 12444(3.4%) 302(0.1%) variable? ...ck/herbie/src/syntax/syntax.rkt:529:0 ??? [207] 97.6% ----------------------------------------------------------------------------------------- match-e [72] 21.2% list-cartesian-product [98] 24.5% for-loop [80] 54.3% [98] 11968(3.2%) 9862(2.7%) list-cartesian-product ...src/core/ematch.rkt:20:0 list-cartesian-product [98] 24.5% for-loop [116] 13.7% ----------------------------------------------------------------------------------------- merge-egraph-nodes! [81] 100.0% [99] 11562(3.1%) 0(0.0%) for-loop ...lock/herbie/src/core/egraph.rkt:200:10 merge-egraph-nodes! [81] 69.9% loop! [110] 30.1% ----------------------------------------------------------------------------------------- expr->enode [54] 0.8% for-loop [73] 26.1% apply-match [65] 30.8% substitute-e [84] 42.3% [100] 11458(3.1%) 8526(2.3%) mk-enode! ...lock/herbie/src/core/egraph.rkt:101:0 hash-has-key? [211] 17.3% new-enode [119] 6.5% mutable-set [136] 1.8% ----------------------------------------------------------------------------------------- for-loop [203] 5.4% ??? [199] 9.5% ...erbie/src/common.rkt:46:2 [83] 85.1% [101] 4790(1.3%) 732(0.2%) ??? ...ects/racket/contract/private/list.rkt:342:4 ??? [199] 68.2% ??? [133] 14.9% ??? [205] 8.3% ----------------------------------------------------------------------------------------- loop [75] 5.1% loop [85] 94.9% [102] 4662(1.3%) 0(0.0%) loop /home/ztatlock/herbie/src/points.rkt:109:4 map [157] 100.0% ----------------------------------------------------------------------------------------- ...erbie/src/common.rkt:46:2 [83] 100.0% [103] 3422(0.9%) 1322(0.4%) ??? ...s/racket/contract/private/arr-i.rkt:1268:39 ??? [201] 44.2% return/no-unsupplied [260] 15.0% assoc-ref [126] 2.2% ----------------------------------------------------------------------------------------- merge-egraph-nodes! [81] 100.0% [104] 3060(0.8%) 274(0.1%) enode-merge! ...ck/herbie/src/core/enode.rkt:100:0 adopt-enode! [115] 73.6% custom-set-intersect! [120] 17.5% ----------------------------------------------------------------------------------------- for-loop [6] 4.0% taylor [12] 6.8% match-e [72] 28.9% for-loop [80] 60.3% [105] 1860(0.5%) 844(0.2%) curry* ...racket/collects/racket/function.rkt:44:2 procedure-arity [118] 54.6% ----------------------------------------------------------------------------------------- for-loop [117] 24.7% matcher [106] 25.4% for-loop [87] 49.9% [106] 1158(0.3%) 214(0.1%) matcher ...tlock/herbie/src/core/matcher.rkt:163:2 rewriter [78] 46.4% matcher [106] 25.4% for-loop [117] 24.7% variable? [97] 1.1% ----------------------------------------------------------------------------------------- *simplify-rules* [55] 13.0% *rules* [13] 40.0% merge-egraph-nodes! [81] 47.0% [107] 690(0.2%) 304(0.1%) for-loop /home/ztatlock/herbie/src/common.rkt:93:9 ??? [198] 25.8% ormap [123] 15.9% update-en-expr [165] 14.2% ----------------------------------------------------------------------------------------- filter-exacts [90] 100.0% [108] 122(0.0%) 0(0.0%) for-loop ...e/ztatlock/herbie/src/points.rkt:137:4 andmap [124] 100.0% ----------------------------------------------------------------------------------------- for-loop [88] 100.0% [109] 110(0.0%) 110(0.0%) for-loop .../ztatlock/herbie/src/points.rkt:167:26 ----------------------------------------------------------------------------------------- for-loop [99] 4.9% apply-match [65] 9.6% merge-egraph-nodes! [81] 24.4% loop [238] 26.7% for-loop [73] 34.4% [110] 53670(14.5%) 10314(2.8%) loop! .../ztatlock/herbie/src/core/enode.rkt:163:2 custom-set-union [127] 41.5% loop [238] 30.1% set [129] 12.2% update-en-expr [165] 5.3% ----------------------------------------------------------------------------------------- update-leader! [93] 100.0% [111] 16406(4.4%) 640(0.2%) for-loop ...tlock/herbie/src/core/egraph.rkt:222:6 for-loop [128] 95.4% update-en-expr [165] 0.7% ----------------------------------------------------------------------------------------- ??? [92] 100.0% [112] 12638(3.4%) 7336(2.0%) for-loop ...acket/contract/private/list.rkt:743:12 ??? [142] 27.8% for-loop [134] 6.9% ??? [133] 3.7% successfully-got-the-right-kind-of-function [245] 2.1% arrow-higher-order:lnp [246] 1.6% ----------------------------------------------------------------------------------------- ??? [94] 100.0% [113] 7834(2.1%) 0(0.0%) approximate9 ...ck/herbie/src/core/taylor.rkt:12:0 loop [130] 58.5% f6 [149] 23.4% taylor-sqrt [159] 18.1% ----------------------------------------------------------------------------------------- for-loop [58] 12.4% for-loop [91] 87.6% [114] 3340(0.9%) 2014(0.5%) ??? /home/ztatlock/herbie/src/core/ematch.rkt:50:5 for-loop [132] 39.7% ----------------------------------------------------------------------------------------- enode-merge! [104] 100.0% [115] 2252(0.6%) 1302(0.4%) adopt-enode! ...ock/herbie/src/core/enode.rkt:76:0 custom-set-union [127] 42.2% ----------------------------------------------------------------------------------------- list-cartesian-product [98] 100.0% [116] 2106(0.6%) 2106(0.6%) for-loop ...atlock/herbie/src/core/ematch.rkt:24:8 ----------------------------------------------------------------------------------------- matcher [106] 100.0% [117] 1158(0.3%) 0(0.0%) for-loop ...ock/herbie/src/core/matcher.rkt:179:21 matcher [106] 100.0% ----------------------------------------------------------------------------------------- curry* [105] 100.0% [118] 1016(0.3%) 1016(0.3%) procedure-arity ...ket/private/norm-arity.rkt:7:27 ----------------------------------------------------------------------------------------- mk-enode! [100] 100.0% [119] 744(0.2%) 196(0.1%) new-enode ...atlock/herbie/src/core/enode.rkt:68:0 set [129] 48.1% check-valid-enode5 [139] 12.9% mutable-set [136] 12.6% ----------------------------------------------------------------------------------------- enode-merge! [104] 100.0% [120] 534(0.1%) 534(0.1%) custom-set-intersect! ...ivate/set-types.rkt:269:0 ----------------------------------------------------------------------------------------- ??? [94] 100.0% [121] 528(0.1%) 0(0.0%) best-alt /home/ztatlock/herbie/src/glue.rkt:78:0 argmins [135] 81.1% loop [138] 18.9% ----------------------------------------------------------------------------------------- update-leader! [93] 100.0% [122] 486(0.1%) 380(0.1%) custom-set-union! ...t/private/set-types.rkt:245:0 for-loop [137] 21.8% ----------------------------------------------------------------------------------------- for-loop [107] 47.0% for-loop [63] 53.0% [123] 234(0.1%) 124(0.0%) ormap ...et/collects/racket/private/map.rkt:105:13 ??? [198] 47.0% ----------------------------------------------------------------------------------------- for-loop [108] 100.0% [124] 122(0.0%) 122(0.0%) andmap ...et/collects/racket/private/map.rkt:74:13 ----------------------------------------------------------------------------------------- ??? [94] 100.0% [125] 110(0.0%) 0(0.0%) ->bf /home/ztatlock/herbie/src/programs.rkt:49:0 ??? [131] 100.0% ----------------------------------------------------------------------------------------- ??? [103] 100.0% [126] 76(0.0%) 76(0.0%) assoc-ref ...collects/racket/private/dict.rkt:56:0 ----------------------------------------------------------------------------------------- adopt-enode! [115] 3.9% loop! [110] 96.1% [127] 24288(6.6%) 7942(2.1%) custom-set-union ...et/private/set-types.rkt:168:0 for-loop [141] 57.8% for-loop [143] 9.5% ----------------------------------------------------------------------------------------- for-loop [111] 100.0% [128] 15644(4.2%) 270(0.1%) for-loop ...tlock/herbie/src/core/egraph.rkt:223:8 hash-update! [140] 98.3% ----------------------------------------------------------------------------------------- new-enode [119] 2.7% loop! [110] 97.3% [129] 13150(3.5%) 13150(3.5%) set ...collects/racket/private/set-types.rkt:981:0 ----------------------------------------------------------------------------------------- approximate9 [113] 100.0% [130] 4580(1.2%) 0(0.0%) loop ...e/ztatlock/herbie/src/core/taylor.rkt:83:4 hash-ref! [221] 100.0% ----------------------------------------------------------------------------------------- f6 [149] 4.0% ->bf [125] 5.4% ??? [94] 44.4% for-loop [74] 46.2% [131] 2052(0.6%) 1220(0.3%) ??? ...ts/racket/contract/private/arr-i.rkt:804:10 get/build-late-neg-projection [145] 26.2% ??? [142] 9.4% ??? [148] 5.0% ----------------------------------------------------------------------------------------- ??? [114] 100.0% [132] 1326(0.4%) 1016(0.3%) for-loop ...atlock/herbie/src/core/ematch.rkt:51:7 ??? [207] 23.4% ----------------------------------------------------------------------------------------- for-loop [112] 39.4% ??? [101] 60.6% [133] 1174(0.3%) 962(0.3%) ??? ...ects/racket/contract/private/hash.rkt:222:6 check-hash/c [146] 18.1% ----------------------------------------------------------------------------------------- for-loop [112] 100.0% [134] 868(0.2%) 680(0.2%) for-loop ...racket/contract/private/hash.rkt:239:6 ??? [147] 21.7% ----------------------------------------------------------------------------------------- best-alt [121] 100.0% [135] 428(0.1%) 0(0.0%) argmins /home/ztatlock/herbie/src/common.rkt:134:0 composed [144] 100.0% ----------------------------------------------------------------------------------------- new-enode [119] 23.5% update-leader! [93] 24.5% mk-enode! [100] 52.0% [136] 400(0.1%) 400(0.1%) mutable-set .../racket/private/set-types.rkt:999:0 ----------------------------------------------------------------------------------------- custom-set-union! [122] 100.0% [137] 106(0.0%) 106(0.0%) for-loop ...cts/racket/private/set-types.rkt:253:4 ----------------------------------------------------------------------------------------- best-alt [121] 100.0% [138] 100(0.0%) 0(0.0%) loop /home/ztatlock/herbie/src/common.rkt:135:2 composed [144] 100.0% ----------------------------------------------------------------------------------------- new-enode [119] 100.0% [139] 96(0.0%) 96(0.0%) check-valid-enode5 ...bie/src/core/enode.rkt:177:0 ----------------------------------------------------------------------------------------- for-loop [128] 100.0% [140] 15374(4.1%) 64(0.0%) hash-update! ...ket/private/more-scheme.rkt:362:13 ??? [150] 99.6% ----------------------------------------------------------------------------------------- custom-set-union [127] 100.0% [141] 14046(3.8%) 4138(1.1%) for-loop ...cts/racket/private/set-types.rkt:174:3 for-loop [151] 70.5% ----------------------------------------------------------------------------------------- ??? [131] 3.4% ??? [92] 34.0% for-loop [112] 62.6% [142] 5604(1.5%) 3030(0.8%) ??? ...private/unconstrained-domain-arrow.rkt:74:4 make-keyword-procedure [152] 45.9% ----------------------------------------------------------------------------------------- custom-set-union [127] 100.0% [143] 2300(0.6%) 2300(0.6%) for-loop ...cts/racket/private/set-types.rkt:152:2 ----------------------------------------------------------------------------------------- loop [138] 10.6% f6 [149] 43.9% argmins [135] 45.4% [144] 942(0.3%) 0(0.0%) composed ...ollects/racket/private/list.rkt:321:16 errors [217] 56.1% f6 [149] 43.9% ----------------------------------------------------------------------------------------- unconstrained-domain->-projection [153] 50.0% ??? [131] 50.0% [145] 538(0.1%) 94(0.0%) get/build-late-neg-projection ...te/guts.rkt:691:0 unconstrained-domain->-projection [153] 50.0% ??? [154] 41.3% ----------------------------------------------------------------------------------------- ??? [133] 100.0% [146] 212(0.1%) 110(0.0%) check-hash/c ...ket/contract/private/hash.rkt:83:0 flat-contract? [155] 48.1% ----------------------------------------------------------------------------------------- for-loop [134] 100.0% [147] 188(0.1%) 92(0.0%) ??? ...ects/racket/contract/private/list.rkt:686:7 ??? [205] 51.1% ----------------------------------------------------------------------------------------- ??? [131] 100.0% [148] 102(0.0%) 102(0.0%) ??? ...private/unconstrained-domain-arrow.rkt:69:2 ----------------------------------------------------------------------------------------- composed [144] 0.1% simplify-node [257] 0.2% parse-loop12 [166] 0.3% append-map [162] 0.3% hash-ref! [221] 0.9% approximate9 [113] 1.3% eval-const-expr [29] 2.0% simplify [242] 4.9% map [157] 5.5% eval-prog [219] 6.3% f6 [149] 11.0% split-table [38] 67.3% [149] 38972(10.5%) 2374(0.6%) f6 ...et/collects/racket/match/compiler.rkt:507:40 option-on-expr [156] 58.1% f6 [149] 11.0% map [157] 8.8% loop [238] 6.8% ??? [94] 6.2% exprs-to-branch-on [160] 2.4% taylor-sqrt [159] 1.3% ...erbie/src/common.rkt:46:2 [83] 0.5% append-map [162] 0.3% table-ref [82] 0.3% ??? [131] 0.2% taylor-quotient [11] 0.2% ??? [207] 0.2% composed [144] 0.1% compose [161] 0.1% taylor [12] 0.1% variable? [97] 0.1% combine-mterms [17] 0.1% taylor-log [16] 0.0% ----------------------------------------------------------------------------------------- hash-update! [140] 100.0% [150] 15310(4.1%) 228(0.1%) ??? .../ztatlock/herbie/src/core/egraph.rkt:225:24 for-loop [158] 98.0% make-sequence [250] 0.5% ----------------------------------------------------------------------------------------- for-loop [141] 100.0% [151] 9908(2.7%) 9908(2.7%) for-loop ...cts/racket/private/set-types.rkt:178:5 ----------------------------------------------------------------------------------------- ??? [142] 100.0% [152] 2574(0.7%) 2574(0.7%) make-keyword-procedure ...ket/private/kw.rkt:260:4 ----------------------------------------------------------------------------------------- get/build-late-neg-projection [145] 100.0% [153] 538(0.1%) 0(0.0%) unconstrained-domain->-projection ...rrow.rkt:60:0 get/build-late-neg-projection [145] 100.0% ----------------------------------------------------------------------------------------- get/build-late-neg-projection [145] 100.0% [154] 444(0.1%) 170(0.0%) ??? ...cts/racket/contract/private/prop.rkt:314:12 build-compound-type-name [163] 61.7% ----------------------------------------------------------------------------------------- check-hash/c [146] 100.0% [155] 102(0.0%) 102(0.0%) flat-contract? .../contract/private/guts.rkt:111:0 ----------------------------------------------------------------------------------------- loop [238] 8.9% f6 [149] 91.1% [156] 29712(8.0%) 0(0.0%) option-on-expr ...erbie/src/core/regimes.rkt:115:0 sort-context-on-expr [164] 87.8% pick-errors [167] 7.8% errors [217] 2.2% loop [238] 1.7% err-lsts->split-indices [170] 0.4% ----------------------------------------------------------------------------------------- loop [102] 28.6% f6 [149] 32.7% make-exacts* [95] 38.6% [157] 16280(4.4%) 96(0.0%) map ...acket/collects/racket/private/map.rkt:20:13 loop [238] 67.3% f6 [149] 23.8% parse-loop12 [166] 5.9% simplify* [251] 1.3% ??? [171] 0.2% ----------------------------------------------------------------------------------------- ??? [150] 100.0% [158] 15006(4.0%) 12562(3.4%) for-loop ...lock/herbie/src/core/egraph.rkt:226:26 update-en-expr [165] 16.3% ----------------------------------------------------------------------------------------- hash-ref! [221] 14.4% f6 [149] 42.2% approximate9 [113] 43.4% [159] 3268(0.9%) 94(0.0%) taylor-sqrt ...ck/herbie/src/core/taylor.rkt:342:0 hash-ref! [221] 90.6% first-nonzero-exp [169] 3.5% simplify [242] 3.1% ----------------------------------------------------------------------------------------- f6 [149] 100.0% [160] 926(0.2%) 0(0.0%) exprs-to-branch-on ...ie/src/core/regimes.rkt:44:0 critical-subexpression [168] 100.0% ----------------------------------------------------------------------------------------- f6 [149] 34.7% for-loop [6] 65.3% [161] 646(0.2%) 646(0.2%) compose ...collects/racket/private/list.rkt:385:12 ----------------------------------------------------------------------------------------- f6 [149] 100.0% [162] 310(0.1%) 114(0.0%) append-map ...acket/collects/racket/list.rkt:565:2 f6 [149] 52.9% free-variables [15] 10.4% ----------------------------------------------------------------------------------------- ??? [154] 100.0% [163] 274(0.1%) 196(0.1%) build-compound-type-name ...private/guts.rkt:448:0 contract-struct-name [172] 28.5% ----------------------------------------------------------------------------------------- option-on-expr [156] 100.0% [164] 26088(7.0%) 0(0.0%) sort-context-on-expr ...herbie/src/points.rkt:79:0 ??? [173] 100.0% ----------------------------------------------------------------------------------------- for-loop [107] 0.9% for-loop [111] 1.1% update-leader! [93] 6.8% for-loop [96] 19.6% for-loop [158] 22.3% loop! [110] 49.3% [165] 10970(3.0%) 10970(3.0%) update-en-expr ...herbie/src/core/egraph.rkt:211:0 ----------------------------------------------------------------------------------------- loop [238] 0.4% hash-ref! [221] 9.1% simplify [242] 9.4% parse-loop12 [166] 16.9% map [157] 25.0% for-loop [27] 39.2% [166] 3636(1.0%) 2044(0.6%) parse-loop12 ...s/racket/match/compiler.rkt:418:15 for-loop [175] 39.2% parse-loop12 [166] 16.9% loop [238] 7.1% loop [179] 2.4% f6 [149] 2.3% parse-app [224] 0.9% simplify* [251] 0.4% ----------------------------------------------------------------------------------------- option-on-expr [156] 100.0% [167] 2330(0.6%) 0(0.0%) pick-errors ...k/herbie/src/core/regimes.rkt:187:0 for-loop [174] 100.0% ----------------------------------------------------------------------------------------- exprs-to-branch-on [160] 100.0% [168] 926(0.2%) 0(0.0%) critical-subexpression ...rc/core/regimes.rkt:52:0 for-loop [176] 86.6% localize-error [53] 13.4% ----------------------------------------------------------------------------------------- taylor-sqrt [159] 28.8% taylor-quotient [11] 71.2% [169] 396(0.1%) 0(0.0%) first-nonzero-exp ...bie/src/core/taylor.rkt:256:0 hash-ref! [221] 100.0% ----------------------------------------------------------------------------------------- option-on-expr [156] 100.0% [170] 130(0.0%) 0(0.0%) err-lsts->split-indices .../core/regimes.rkt:238:0 add-splitpoint [177] 100.0% ----------------------------------------------------------------------------------------- map [157] 100.0% [171] 114(0.0%) 0(0.0%) ??? /home/ztatlock/herbie/src/core/reduce.rkt:50:5 for-loop [178] 100.0% ----------------------------------------------------------------------------------------- build-compound-type-name [163] 100.0% [172] 78(0.0%) 78(0.0%) contract-struct-name ...ract/private/prop.rkt:89:0 ----------------------------------------------------------------------------------------- localize-error [53] 0.3% sort-context-on-expr [164] 99.7% [173] 26174(7.1%) 90(0.0%) ??? ...cket/collects/racket/private/sort.rkt:403:3 generic-sort/key [180] 85.0% loop [184] 14.2% ??? [185] 0.5% ----------------------------------------------------------------------------------------- pick-errors [167] 100.0% [174] 2330(0.6%) 0(0.0%) for-loop ...lock/herbie/src/core/regimes.rkt:190:4 eval-prog [219] 94.6% ??? [186] 5.4% ----------------------------------------------------------------------------------------- parse-loop12 [166] 100.0% [175] 1970(0.5%) 0(0.0%) for-loop ...lock/herbie/src/core/taylor.rkt:486:59 hash-ref! [221] 100.0% ----------------------------------------------------------------------------------------- critical-subexpression [168] 100.0% [176] 802(0.2%) 0(0.0%) for-loop ...lock/herbie/src/core/regimes.rkt:87:19 eval-prog [219] 74.1% ??? [186] 25.9% ----------------------------------------------------------------------------------------- err-lsts->split-indices [170] 100.0% [177] 130(0.0%) 0(0.0%) add-splitpoint ...erbie/src/core/regimes.rkt:251:2 for-loop [181] 100.0% ----------------------------------------------------------------------------------------- ??? [171] 100.0% [178] 114(0.0%) 0(0.0%) for-loop ...atlock/herbie/src/core/reduce.rkt:51:7 pattern-match [182] 100.0% ----------------------------------------------------------------------------------------- parse-loop12 [166] 1.7% loop [179] 98.3% [179] 86(0.0%) 0(0.0%) loop ...cket/collects/racket/private/map.rkt:36:19 loop [179] 98.3% ->flonum [188] 1.7% ----------------------------------------------------------------------------------------- ??? [173] 100.0% [180] 22246(6.0%) 0(0.0%) generic-sort/key .../racket/private/sort.rkt:185:2 copying-mergesort [183] 84.2% loop [184] 15.8% ----------------------------------------------------------------------------------------- add-splitpoint [177] 100.0% [181] 130(0.0%) 130(0.0%) for-loop ...lock/herbie/src/core/regimes.rkt:253:4 ----------------------------------------------------------------------------------------- for-loop [178] 100.0% [182] 114(0.0%) 114(0.0%) pattern-match .../herbie/src/core/matcher.rkt:47:0 ----------------------------------------------------------------------------------------- generic-sort/key [180] 44.5% copying-mergesort [183] 55.3% [183] 18838(5.1%) 88(0.0%) copying-mergesort ...racket/private/sort.rkt:130:8 copying-mergesort [183] 55.3% loop [184] 32.6% jloop [4] 12.0% ----------------------------------------------------------------------------------------- generic-sort/key [180] 20.7% ??? [173] 21.9% copying-mergesort [183] 57.4% [184] 16980(4.6%) 0(0.0%) loop ...ket/collects/racket/private/sort.rkt:97:12 ??? [185] 99.5% ----------------------------------------------------------------------------------------- ??? [173] 0.5% jloop [4] 34.4% loop [184] 65.2% [185] 25928(7.0%) 950(0.3%) ??? /home/ztatlock/herbie/src/points.rkt:81:27 eval-prog [219] 86.6% ??? [186] 9.1% ->flonum [188] 0.7% ----------------------------------------------------------------------------------------- jloop [4] 0.3% for-loop [174] 0.4% for-loop [176] 0.7% ??? [185] 7.4% for-loop [220] 34.7% loop [238] 56.6% [186] 31918(8.6%) 1150(0.3%) ??? /home/ztatlock/herbie/src/programs.rkt:152:4 ??? [187] 84.0% ??? [189] 8.8% ->flonum [188] 3.6% ----------------------------------------------------------------------------------------- ??? [186] 100.0% [187] 26812(7.2%) 12246(3.3%) ??? ...acket/collects/racket/private/kw.rkt:444:14 ??? [197] 24.4% bf* [190] 16.4% ??? [191] 10.0% ??? [193] 2.1% ...higher-order.rkt:346:33 [196] 0.7% ??? [204] 0.6% ----------------------------------------------------------------------------------------- loop [179] 2.6% ??? [94] 2.7% for-loop [6] 3.0% ??? [185] 5.3% for-loop [220] 9.7% ??? [186] 35.1% loop [238] 41.5% [188] 3262(0.9%) 182(0.0%) ->flonum .../ztatlock/herbie/src/programs.rkt:34:0 ??? [198] 85.0% ??? [194] 9.4% ----------------------------------------------------------------------------------------- ??? [94] 11.5% ??? [186] 88.5% [189] 3176(0.9%) 422(0.1%) ??? ...contract/private/../../private/kw.rkt:761:9 real->bigfloat [192] 78.4% integer->bigfloat [195] 8.3% ----------------------------------------------------------------------------------------- eval-const-expr [29] 2.1% ??? [187] 97.9% [190] 4496(1.2%) 0(0.0%) bf* ...ath/private/bigfloat/bigfloat-mpfr.rkt:95:0 ??? [197] 100.0% ----------------------------------------------------------------------------------------- ??? [187] 100.0% [191] 2690(0.7%) 0(0.0%) ??? ...tatlock/herbie/src/syntax/syntax.rkt:118:17 ??? [198] 100.0% ----------------------------------------------------------------------------------------- ??? [189] 100.0% [192] 2490(0.7%) 1730(0.5%) real->bigfloat .../private/bigfloat/mpfr.rkt:451:0 ??? [243] 30.5% ----------------------------------------------------------------------------------------- ??? [187] 100.0% [193] 570(0.2%) 570(0.2%) ??? ...rivate/unconstrained-domain-arrow.rkt:40:13 ----------------------------------------------------------------------------------------- ->flonum [188] 100.0% [194] 306(0.1%) 0(0.0%) ??? ...-racket/utils/simple-result-arrow.rkt:60:15 ??? [243] 100.0% ----------------------------------------------------------------------------------------- ??? [189] 100.0% [195] 264(0.1%) 264(0.1%) integer->bigfloat ...ivate/bigfloat/mpfr.rkt:399:0 ----------------------------------------------------------------------------------------- ??? [187] 100.0% [196] 194(0.1%) 0(0.0%) ...higher-order.rkt:346:33 (unknown source) ??? [199] 100.0% ----------------------------------------------------------------------------------------- eval-const-expr [29] 1.1% bf* [190] 40.3% ??? [187] 58.6% [197] 11154(3.0%) 2680(0.7%) ??? ...-racket/utils/simple-result-arrow.rkt:39:12 bfdiv [200] 64.8% bfsqrt [202] 11.1% ----------------------------------------------------------------------------------------- *rules* [13] 1.5% ormap [123] 1.7% for-loop [107] 2.8% ulp-difference [226] 7.6% ??? [191] 42.5% ->flonum [188] 43.9% [198] 6326(1.7%) 3046(0.8%) ??? /home/ztatlock/herbie/src/config.rkt:48:0 ??? [201] 30.7% return/no-unsupplied [260] 19.7% ----------------------------------------------------------------------------------------- ...higher-order.rkt:346:33 [196] 3.6% table-ref [82] 8.6% ??? [92] 13.1% ??? [101] 74.7% [199] 5328(1.4%) 2452(0.7%) ??? ...cts/racket/contract/private/list.rkt:187:10 for-loop [203] 22.3% ??? [101] 17.1% ??? [204] 13.1% ??? [205] 1.5% ----------------------------------------------------------------------------------------- ??? [197] 100.0% [200] 7232(2.0%) 4892(1.3%) bfdiv ...-lib/math/private/bigfloat/mpfr.rkt:819:4 ??? [243] 32.4% ----------------------------------------------------------------------------------------- debug7 [253] 6.1% table-ref [82] 14.4% ??? [103] 34.8% ??? [198] 44.7% [201] 4342(1.2%) 1038(0.3%) ??? ...racket/collects/racket/private/kw.rkt:761:9 ??? [265] 51.3% ??? [205] 24.8% ----------------------------------------------------------------------------------------- ??? [197] 100.0% [202] 1242(0.3%) 890(0.2%) bfsqrt ...lib/math/private/bigfloat/mpfr.rkt:616:4 ??? [243] 28.3% ----------------------------------------------------------------------------------------- ??? [199] 100.0% [203] 1190(0.3%) 674(0.2%) for-loop ...acket/contract/private/list.rkt:190:15 ??? [101] 43.4% ----------------------------------------------------------------------------------------- ??? [187] 19.6% ??? [199] 80.4% [204] 866(0.2%) 754(0.2%) ??? ...ects/racket/contract/private/prop.rkt:493:4 ??? [206] 12.9% ----------------------------------------------------------------------------------------- ??? [199] 1.7% ??? [147] 2.0% ??? [207] 13.9% ??? [101] 16.6% ??? [201] 22.4% ??? [94] 41.5% [205] 4796(1.3%) 1340(0.4%) ??? ...ects/racket/contract/private/guts.rkt:644:8 ??? [207] 43.5% dict? [208] 17.0% contract? [209] 11.6% ----------------------------------------------------------------------------------------- ??? [204] 100.0% [206] 112(0.0%) 112(0.0%) ??? ...lects/racket/contract/private/orc.rkt:83:14 ----------------------------------------------------------------------------------------- setfindf [31] 0.2% setup-prog [30] 0.2% free-variables [15] 0.4% for-loop [132] 0.7% f6 [149] 0.7% debug7 [253] 0.7% ??? [205] 4.1% substitute-e [84] 4.7% variable? [97] 25.7% finalize-iter! [49] 28.9% match-e [72] 32.2% [207] 47228(12.7%) 22050(6.0%) ??? ...contract/private/arrow-val-first.rkt:357:18 for-loop [210] 27.6% hash-has-key? [211] 21.0% ??? [205] 1.4% ??? [212] 1.3% atab-add-altns [213] 1.3% ----------------------------------------------------------------------------------------- table-ref [82] 10.4% ??? [205] 89.6% [208] 908(0.2%) 908(0.2%) dict? ...ollects/racket/private/generic.rkt:146:11 ----------------------------------------------------------------------------------------- ??? [205] 100.0% [209] 558(0.2%) 558(0.2%) contract? ...acket/contract/private/guts.rkt:109:0 ----------------------------------------------------------------------------------------- ??? [207] 100.0% [210] 13154(3.5%) 0(0.0%) for-loop ...ock/herbie/src/core/alt-table.rkt:51:2 atab-add-altn [214] 100.0% ----------------------------------------------------------------------------------------- mk-enode! [100] 16.5% ??? [207] 83.5% [211] 12030(3.2%) 6424(1.7%) hash-has-key? ...et/private/more-scheme.rkt:368:13 ??? [92] 37.4% ??? [215] 9.2% ----------------------------------------------------------------------------------------- ??? [207] 100.0% [212] 624(0.2%) 0(0.0%) ??? ...ztatlock/herbie/src/core/alt-table.rkt:54:0 ??? [94] 100.0% ----------------------------------------------------------------------------------------- ??? [207] 100.0% [213] 606(0.2%) 0(0.0%) atab-add-altns ...rbie/src/core/alt-table.rkt:50:0 atab-add-altn [214] 100.0% ----------------------------------------------------------------------------------------- atab-add-altns [213] 4.4% for-loop [210] 95.6% [214] 13760(3.7%) 0(0.0%) atab-add-altn ...rbie/src/core/alt-table.rkt:208:0 best-and-tied-at-points [216] 98.4% ----------------------------------------------------------------------------------------- table-ref [82] 8.2% hash-has-key? [211] 91.8% [215] 1202(0.3%) 1202(0.3%) ??? ...ects/racket/contract/private/hash.rkt:245:7 ----------------------------------------------------------------------------------------- atab-add-altn [214] 100.0% [216] 13534(3.7%) 0(0.0%) best-and-tied-at-points ...ore/alt-table.rkt:122:0 errors [217] 97.0% for-loop [218] 3.0% ----------------------------------------------------------------------------------------- loop [238] 3.3% composed [144] 3.5% option-on-expr [156] 4.4% best-and-tied-at-points [216] 86.6% [217] 15166(4.1%) 0(0.0%) errors /home/ztatlock/herbie/src/points.rkt:184:0 for-loop [220] 82.8% eval-prog [219] 17.2% ----------------------------------------------------------------------------------------- best-and-tied-at-points [216] 100.0% [218] 402(0.1%) 402(0.1%) for-loop ...k/herbie/src/core/alt-table.rkt:124:16 ----------------------------------------------------------------------------------------- loop [85] 0.9% make-exacts* [95] 2.1% for-loop [176] 2.1% for-loop [174] 7.7% errors [217] 9.1% ??? [185] 78.2% [219] 28696(7.7%) 12758(3.4%) eval-prog ...tatlock/herbie/src/programs.rkt:146:0 f6 [149] 27.3% hash-ref! [221] 15.5% ??? [222] 5.0% ??? [223] 2.2% go [225] 1.7% parse-app [224] 1.4% parse-lambda [227] 1.0% ??? [94] 0.4% new-lambda [228] 0.4% ----------------------------------------------------------------------------------------- errors [217] 100.0% [220] 12564(3.4%) 592(0.2%) for-loop ...e/ztatlock/herbie/src/points.rkt:187:4 ??? [186] 88.1% ulp-difference [226] 3.8% ->flonum [188] 2.5% ----------------------------------------------------------------------------------------- ??? [10] 0.1% for-loop [44] 0.1% for-loop [33] 0.3% simplify* [251] 1.1% for-loop [28] 1.1% localize-error [53] 1.2% first-nonzero-exp [169] 1.2% for-loop [175] 1.3% ??? [41] 1.7% ??? [232] 2.5% for-loop [40] 2.6% taylor-sqrt [159] 4.4% for-loop [24] 5.9% loop [130] 6.4% for-loop [25] 6.6% ??? [230] 7.2% eval-prog [219] 9.6% compile [86] 11.2% ??? [229] 14.7% loop [238] 18.4% [221] 15906(4.3%) 4520(1.2%) hash-ref! ...racket/private/more-scheme.rkt:373:13 ??? [229] 35.5% simplify [242] 8.3% ??? [5] 8.0% bigfloat-hash [231] 7.7% ??? [7] 7.3% ??? [230] 7.2% ??? [8] 2.6% ??? [232] 2.5% f6 [149] 1.9% parse-loop12 [166] 1.8% ??? [9] 1.3% ??? [10] 1.3% taylor-sqrt [159] 0.5% taylor [12] 0.2% ??? [14] 0.1% ??? [18] 0.0% ----------------------------------------------------------------------------------------- eval-prog [219] 100.0% [222] 1422(0.4%) 314(0.1%) ??? ...cket/collects/racket/private/kw.rkt:1633:36 unpack242 [233] 77.9% ----------------------------------------------------------------------------------------- eval-prog [219] 100.0% [223] 644(0.2%) 94(0.0%) ??? ...collects/racket/private/qq-and-or.rkt:155:9 ??? [234] 85.4% ----------------------------------------------------------------------------------------- parse-loop12 [166] 20.3% eval-prog [219] 79.7% [224] 492(0.1%) 392(0.1%) parse-app .../collects/racket/private/kw.rkt:951:2 loop [236] 20.3% ----------------------------------------------------------------------------------------- eval-prog [219] 100.0% [225] 492(0.1%) 118(0.0%) go .../collects/racket/private/qq-and-or.rkt:50:20 loop [235] 76.0% ----------------------------------------------------------------------------------------- for-loop [220] 100.0% [226] 480(0.1%) 0(0.0%) ulp-difference ...atlock/herbie/src/float.rkt:19:0 ??? [198] 100.0% ----------------------------------------------------------------------------------------- eval-prog [219] 100.0% [227] 292(0.1%) 104(0.0%) parse-lambda ...llects/racket/private/kw.rkt:437:2 loop [236] 35.6% simple-args? [237] 28.8% ----------------------------------------------------------------------------------------- eval-prog [219] 100.0% [228] 106(0.0%) 0(0.0%) new-lambda ...ollects/racket/private/kw.rkt:679:11 loop [236] 100.0% ----------------------------------------------------------------------------------------- hash-ref! [221] 100.0% [229] 7978(2.2%) 978(0.3%) ??? /home/ztatlock/herbie/src/programs.rkt:181:5 loop [238] 54.6% hash-ref! [221] 40.5% ----------------------------------------------------------------------------------------- hash-ref! [221] 100.0% [230] 4260(1.1%) 0(0.0%) ??? ...e/ztatlock/herbie/src/core/taylor.rkt:64:15 hash-ref! [221] 100.0% ----------------------------------------------------------------------------------------- hash-ref! [221] 100.0% [231] 3674(1.0%) 126(0.0%) bigfloat-hash ...h/private/bigfloat/mpfr.rkt:165:0 bfcanonicalize [239] 77.1% sig+exp->bigfloat [241] 16.5% bigfloat->sig+exp [248] 2.9% ----------------------------------------------------------------------------------------- hash-ref! [221] 100.0% [232] 2680(0.7%) 0(0.0%) ??? ...e/ztatlock/herbie/src/core/taylor.rkt:43:15 hash-ref! [221] 100.0% ----------------------------------------------------------------------------------------- ??? [222] 100.0% [233] 1108(0.3%) 462(0.1%) unpack242 ...private/arrow-higher-order.rkt:354:44 maybe-cons-kwd [240] 58.3% ----------------------------------------------------------------------------------------- ??? [223] 100.0% [234] 550(0.1%) 550(0.1%) ??? ...ollects/racket/private/qq-and-or.rkt:164:21 ----------------------------------------------------------------------------------------- loop [235] 45.1% go [225] 54.9% [235] 374(0.1%) 374(0.1%) loop ...llects/racket/private/qq-and-or.rkt:101:61 loop [235] 45.1% ----------------------------------------------------------------------------------------- parse-lambda [227] 11.2% loop [236] 22.4% parse-app [224] 32.3% new-lambda [228] 34.2% [236] 310(0.1%) 310(0.1%) loop .../collects/racket/private/stxcase.rkt:112:7 loop [236] 22.4% ----------------------------------------------------------------------------------------- parse-lambda [227] 100.0% [237] 84(0.0%) 84(0.0%) simple-args? ...llects/racket/private/kw.rkt:350:2 ----------------------------------------------------------------------------------------- make-exacts* [95] 0.0% parse-loop12 [166] 0.1% taylor [12] 0.2% map [157] 0.4% option-on-expr [156] 0.5% map-enodes [51] 1.1% for-loop [80] 2.1% match-e [72] 2.2% f6 [149] 3.6% ??? [229] 5.8% loop! [110] 8.0% extract-alt [39] 8.8% loop [238] 67.2% [238] 75390(20.3%) 4650(1.3%) loop ...cket/collects/racket/private/map.rkt:25:19 loop [238] 67.2% simplify [3] 8.8% loop! [110] 7.8% hash-ref! [221] 5.8% option-on-expr [156] 3.4% foldl [244] 1.1% for-loop [6] 1.0% errors [217] 0.5% simplify [242] 0.5% ??? [186] 0.3% curried [247] 0.3% parse-loop12 [166] 0.0% set-precompute! [249] 0.0% ->flonum [188] 0.0% ----------------------------------------------------------------------------------------- bigfloat-hash [231] 100.0% [239] 2834(0.8%) 2562(0.7%) bfcanonicalize .../private/bigfloat/mpfr.rkt:155:0 bigfloat->sig+exp [248] 9.6% ----------------------------------------------------------------------------------------- unpack242 [233] 100.0% [240] 646(0.2%) 82(0.0%) maybe-cons-kwd ...ate/arrow-higher-order.rkt:498:0 arrow-higher-order:lnp [246] 47.7% successfully-got-the-right-kind-of-function [245] 39.6% ----------------------------------------------------------------------------------------- bigfloat-hash [231] 100.0% [241] 608(0.2%) 472(0.1%) sig+exp->bigfloat ...ivate/bigfloat/mpfr.rkt:385:0 ??? [243] 22.4% ----------------------------------------------------------------------------------------- for-loop [34] 1.3% taylor-sqrt [159] 1.4% for-loop [25] 1.6% ??? [94] 1.6% for-loop [24] 2.6% taylor-log [16] 2.8% taylor-quotient [11] 3.0% loop [238] 4.9% hash-ref! [221] 79.4% [242] 7046(1.9%) 0(0.0%) simplify ...atlock/herbie/src/core/reduce.rkt:15:0 f6 [149] 70.7% parse-loop12 [166] 10.8% debug-print [252] 5.7% debug7 [253] 5.0% simplify* [251] 3.8% simplify-node [257] 2.4% make-multiplication-node [258] 1.6% ----------------------------------------------------------------------------------------- sig+exp->bigfloat [241] 3.5% ??? [194] 7.9% bfsqrt [202] 9.0% real->bigfloat [192] 19.5% bfdiv [200] 60.1% [243] 3894(1.1%) 3894(1.1%) ??? .../share/racket/collects/ffi/unsafe.rkt:861:4 ----------------------------------------------------------------------------------------- for-loop [80] 15.8% loop [238] 84.2% [244] 1352(0.4%) 858(0.2%) foldl ...et/collects/racket/private/list.rkt:229:4 merge2 [255] 36.5% ----------------------------------------------------------------------------------------- maybe-cons-kwd [240] 24.2% for-loop [112] 25.1% ??? [92] 50.8% [245] 1060(0.3%) 428(0.1%) successfully-got-the-right-kind-of-function ...9:4 arity-checking-wrapper [254] 59.6% ----------------------------------------------------------------------------------------- for-loop [112] 23.7% maybe-cons-kwd [240] 36.9% ??? [92] 39.3% [246] 834(0.2%) 398(0.1%) arrow-higher-order:lnp ...w-higher-order.rkt:597:7 ??? [256] 52.3% ----------------------------------------------------------------------------------------- for-loop [6] 12.1% for-loop [80] 29.3% loop [238] 58.6% [247] 778(0.2%) 778(0.2%) curried ...cket/collects/racket/function.rkt:71:18 ----------------------------------------------------------------------------------------- bigfloat-hash [231] 28.0% bfcanonicalize [239] 72.0% [248] 378(0.1%) 292(0.1%) bigfloat->sig+exp ...ivate/bigfloat/mpfr.rkt:370:0 size+limbs->integer [259] 22.8% ----------------------------------------------------------------------------------------- loop [238] 43.1% map-enodes [51] 56.9% [249] 204(0.1%) 0(0.0%) set-precompute! ...bie/src/core/simplify.rkt:160:0 make-sequence [250] 100.0% ----------------------------------------------------------------------------------------- for-loop [59] 7.1% ??? [150] 7.1% merge-egraph-nodes! [81] 9.4% reduce-to-single! [79] 18.9% set-precompute! [249] 19.1% update-leader! [93] 38.4% [250] 1068(0.3%) 1068(0.3%) make-sequence ...ects/racket/private/for.rkt:509:2 ----------------------------------------------------------------------------------------- parse-loop12 [166] 6.0% simplify [242] 25.5% map [157] 68.4% [251] 1058(0.3%) 312(0.1%) simplify* ...tlock/herbie/src/core/reduce.rkt:20:0 hash-ref! [221] 23.6% ??? [263] 20.4% return/no-unsupplied [260] 15.7% variable? [97] 10.8% ----------------------------------------------------------------------------------------- taylor [12] 10.4% for-loop [56] 44.1% simplify [242] 45.5% [252] 884(0.2%) 72(0.0%) debug-print ...ztatlock/herbie/src/debug.rkt:107:0 for-loop [261] 91.9% ----------------------------------------------------------------------------------------- iterate-egraph!5 [36] 49.9% simplify [242] 50.1% [253] 698(0.2%) 104(0.0%) debug7 /home/ztatlock/herbie/src/debug.rkt:102:0 ??? [207] 47.0% ??? [201] 38.1% ----------------------------------------------------------------------------------------- successfully-got-the-right-kind-of-function [245]100.0% [254] 632(0.2%) 228(0.1%) arity-checking-wrapper ...w-higher-order.rkt:402:0 matches-arity-exactly? [262] 63.9% ----------------------------------------------------------------------------------------- foldl [244] 100.0% [255] 494(0.1%) 494(0.1%) merge2 ...ztatlock/herbie/src/core/ematch.rkt:31:0 ----------------------------------------------------------------------------------------- arrow-higher-order:lnp [246] 100.0% [256] 436(0.1%) 436(0.1%) ??? ...et/contract/private/arity-checking.rkt:19:2 ----------------------------------------------------------------------------------------- simplify [242] 100.0% [257] 168(0.0%) 74(0.0%) simplify-node ...k/herbie/src/core/reduce.rkt:39:0 f6 [149] 56.0% ----------------------------------------------------------------------------------------- simplify [242] 100.0% [258] 116(0.0%) 0(0.0%) make-multiplication-node .../core/reduce.rkt:219:0 make-multiplication-subnode [264] 100.0% ----------------------------------------------------------------------------------------- bigfloat->sig+exp [248] 100.0% [259] 86(0.0%) 86(0.0%) size+limbs->integer ...vate/bigfloat/gmp.rkt:103:0 ----------------------------------------------------------------------------------------- simplify* [251] 7.2% table-ref [82] 17.1% ??? [103] 22.1% ??? [198] 53.7% [260] 2318(0.6%) 1090(0.3%) return/no-unsupplied ...ct/private/arr-i.rkt:533:0 filter [266] 53.0% ----------------------------------------------------------------------------------------- debug-print [252] 100.0% [261] 812(0.2%) 812(0.2%) for-loop /home/ztatlock/herbie/src/debug.rkt:113:2 ----------------------------------------------------------------------------------------- arity-checking-wrapper [254] 100.0% [262] 404(0.1%) 404(0.1%) matches-arity-exactly? ...te/arrow-common.rkt:70:0 ----------------------------------------------------------------------------------------- simplify* [251] 100.0% [263] 216(0.1%) 0(0.0%) ??? ...racket/collects/racket/private/kw.rkt:762:9 ??? [265] 100.0% ----------------------------------------------------------------------------------------- make-multiplication-node [258] 100.0% [264] 116(0.0%) 0(0.0%) make-multiplication-subnode ...re/reduce.rkt:229:0 for-loop [267] 100.0% ----------------------------------------------------------------------------------------- ??? [263] 8.8% ??? [201] 91.2% [265] 2444(0.7%) 2200(0.6%) ??? ...s/racket/contract/private/arr-i.rkt:1233:27 ??? [268] 10.0% ----------------------------------------------------------------------------------------- for-loop [80] 6.6% match-e [72] 11.7% return/no-unsupplied [260] 81.6% [266] 1504(0.4%) 1504(0.4%) filter ...t/collects/racket/private/list.rkt:256:2 ----------------------------------------------------------------------------------------- make-multiplication-subnode [264] 100.0% [267] 116(0.0%) 116(0.0%) for-loop ...tlock/herbie/src/core/reduce.rkt:231:3 ----------------------------------------------------------------------------------------- ??? [265] 100.0% [268] 244(0.1%) 244(0.1%) ??? ...ects/racket/contract/private/prop.rkt:256:4 -----------------------------------------------------------------------------------------