Profiling results ----------------- Total cpu time observed: 411342ms (out of 415140ms) Number of samples taken: 3790 (once every 109ms) (Hiding functions with self<1.0% and local<2.0%: 21 of 279 hidden) ========================================================================================= Caller Idx Total Self Name+src Local% ms(pct) ms(pct) Callee ========================================================================================= ??? [72] 100.0% [1] 390338(94.9%) 0(0.0%) profile-thunk16 ...t/pkgs/profile-lib/main.rkt:9:0 run [19] 100.0% ----------------------------------------------------------------------------------------- ??? [72] 100.0% [2] 287182(69.8%) 0(0.0%) run-improve50 ...ock/herbie/src/mainloop.rkt:234:0 for-loop [20] 87.0% get-final-combination [24] 8.7% loop [80] 4.0% setup-prog [33] 0.2% errors [167] 0.0% ----------------------------------------------------------------------------------------- simplify-alt [47] 0.3% loop [199] 8.9% ??? [72] 90.8% [3] 221304(53.8%) 286(0.1%) simplify ...lock/herbie/src/core/simplify.rkt:39:0 simplify-expr [21] 45.9% for-loop [23] 30.4% iterate-egraph!5 [37] 16.2% loop [38] 7.3% ??? [100] 0.0% loop [199] 0.0% ----------------------------------------------------------------------------------------- map [180] 0.5% for-loop [172] 23.0% loop [199] 76.5% [4] 110368(26.8%) 2254(0.5%) ??? /home/ztatlock/herbie/src/programs.rkt:152:4 ??? [22] 91.3% ??? [116] 5.6% ->flonum [26] 0.6% ----------------------------------------------------------------------------------------- hash-ref! [224] 100.0% [5] 36330(8.8%) 1004(0.2%) ??? /home/ztatlock/herbie/src/programs.rkt:181:5 loop [199] 88.5% hash-ref! [224] 10.5% ----------------------------------------------------------------------------------------- map-enodes [58] 8.7% loop [199] 91.3% [6] 7788(1.9%) 852(0.2%) for-loop ...ock/herbie/src/core/simplify.rkt:161:2 setfindf [28] 47.1% eval-const-expr [30] 33.6% compose [251] 5.9% ->flonum [26] 1.4% curry* [205] 1.0% ----------------------------------------------------------------------------------------- hash-ref! [224] 100.0% [7] 7566(1.8%) 0(0.0%) ??? .../ztatlock/herbie/src/core/taylor.rkt:291:23 for-loop [25] 100.0% ----------------------------------------------------------------------------------------- hash-ref! [224] 100.0% [8] 5888(1.4%) 0(0.0%) ??? .../ztatlock/herbie/src/core/taylor.rkt:281:26 for-loop [27] 100.0% ----------------------------------------------------------------------------------------- hash-ref! [224] 100.0% [9] 3512(0.9%) 0(0.0%) ??? .../ztatlock/herbie/src/core/taylor.rkt:388:23 for-loop [29] 100.0% ----------------------------------------------------------------------------------------- hash-ref! [224] 100.0% [10] 1768(0.4%) 90(0.0%) ??? .../ztatlock/herbie/src/core/taylor.rkt:479:23 for-loop [31] 94.9% ----------------------------------------------------------------------------------------- hash-ref! [224] 100.0% [11] 1582(0.4%) 0(0.0%) ??? .../ztatlock/herbie/src/core/taylor.rkt:334:33 for-loop [32] 66.8% hash-ref! [224] 33.2% ----------------------------------------------------------------------------------------- rewriter [86] 100.0% [12] 1138(0.3%) 104(0.0%) *rules* ...tlock/herbie/src/syntax/rules.rkt:411:0 for-loop [108] 73.6% ormap [124] 9.7% ??? [131] 7.6% ----------------------------------------------------------------------------------------- f134 [175] 100.0% [13] 784(0.2%) 0(0.0%) append-map ...acket/collects/racket/list.rkt:565:2 f134 [175] 56.2% free-variables [152] 43.8% ----------------------------------------------------------------------------------------- copying-mergesort [230] 100.0% [14] 670(0.2%) 0(0.0%) jloop ...t/collects/racket/private/sort.rkt:121:23 ??? [247] 100.0% ----------------------------------------------------------------------------------------- f134 [175] 100.0% [15] 504(0.1%) 0(0.0%) exprs-to-branch-on ...ie/src/core/regimes.rkt:44:0 critical-subexpression [34] 100.0% ----------------------------------------------------------------------------------------- parse-loop12 [189] 2.5% loop [16] 97.5% [16] 456(0.1%) 90(0.0%) loop ...cket/collects/racket/private/map.rkt:36:19 loop [16] 97.5% ->flonum [26] 2.0% ulp-difference [176] 0.2% ----------------------------------------------------------------------------------------- map [180] 29.5% parse-loop12 [189] 70.5% [17] 346(0.1%) 0(0.0%) ??? /home/ztatlock/herbie/src/core/reduce.rkt:50:5 for-loop [35] 100.0% ----------------------------------------------------------------------------------------- matcher [107] 100.0% [18] 94(0.0%) 0(0.0%) for-loop ...lock/herbie/src/core/matcher.rkt:155:6 pattern-match [49] 100.0% ----------------------------------------------------------------------------------------- profile-thunk16 [1] 99.8% [19] 391226(95.1%) 0(0.0%) run ...share/racket/pkgs/profile-lib/main.rkt:39:2 ??? [72] 100.0% ----------------------------------------------------------------------------------------- run-improve50 [2] 100.0% [20] 249960(60.8%) 88(0.0%) for-loop ...ztatlock/herbie/src/mainloop.rkt:245:8 run-iter! [36] 100.0% ----------------------------------------------------------------------------------------- simplify [3] 100.0% [21] 101578(24.7%) 0(0.0%) simplify-expr ...herbie/src/core/simplify.rkt:68:0 iterate-egraph!5 [37] 76.5% loop [38] 22.6% mk-egraph [46] 0.6% debug-print [194] 0.2% ----------------------------------------------------------------------------------------- ??? [4] 100.0% [22] 100776(24.5%) 31390(7.6%) ??? ...acket/collects/racket/private/kw.rkt:444:14 ??? [212] 50.1% bf* [200] 7.4% ??? [40] 4.9% ??? [42] 3.7% ...higher-order.rkt:346:33 [45] 2.1% ??? [182] 0.7% ----------------------------------------------------------------------------------------- simplify [3] 100.0% [23] 67242(16.3%) 274(0.1%) for-loop ...ock/herbie/src/core/simplify.rkt:61:12 iterate-egraph!5 [37] 83.1% loop [38] 15.7% debug-print [194] 0.3% loop [199] 0.2% mk-egraph [46] 0.2% extract-smallest [52] 0.2% ----------------------------------------------------------------------------------------- run-improve50 [2] 100.0% [24] 25022(6.1%) 0(0.0%) get-final-combination ...ie/src/mainloop.rkt:260:0 extract-alt [39] 84.0% split-table [41] 16.0% ----------------------------------------------------------------------------------------- ??? [7] 100.0% [25] 7566(1.8%) 0(0.0%) for-loop ...lock/herbie/src/core/taylor.rkt:294:27 hash-ref! [224] 100.0% ----------------------------------------------------------------------------------------- for-loop [6] 1.6% map [180] 2.9% loop [16] 4.1% ??? [4] 9.6% ??? [100] 10.6% for-loop [172] 12.6% loop [199] 58.6% [26] 6926(1.7%) 1244(0.3%) ->flonum .../ztatlock/herbie/src/programs.rkt:34:0 ??? [131] 71.0% ??? [48] 6.6% ??? [183] 1.7% ...erbie/src/common.rkt:46:2 [91] 1.4% ??? [154] 1.4% ----------------------------------------------------------------------------------------- ??? [8] 100.0% [27] 5888(1.4%) 0(0.0%) for-loop ...lock/herbie/src/core/taylor.rkt:281:52 hash-ref! [224] 67.8% ??? [44] 30.4% simplify [144] 1.8% ----------------------------------------------------------------------------------------- for-loop [6] 100.0% [28] 3668(0.9%) 750(0.2%) setfindf ...e/ztatlock/herbie/src/common.rkt:168:0 ??? [154] 70.0% for-loop [50] 9.5% ----------------------------------------------------------------------------------------- ??? [9] 100.0% [29] 3512(0.9%) 0(0.0%) for-loop ...lock/herbie/src/core/taylor.rkt:392:33 for-loop [43] 100.0% ----------------------------------------------------------------------------------------- for-loop [6] 100.0% [30] 2620(0.6%) 900(0.2%) eval-const-expr ...k/herbie/src/programs.rkt:164:0 f134 [175] 58.6% ??? [212] 3.7% parse-app [207] 3.4% ----------------------------------------------------------------------------------------- ??? [10] 100.0% [31] 1678(0.4%) 0(0.0%) for-loop ...lock/herbie/src/core/taylor.rkt:483:35 parse-loop12 [189] 100.0% ----------------------------------------------------------------------------------------- ??? [11] 100.0% [32] 1056(0.3%) 0(0.0%) for-loop ...lock/herbie/src/core/taylor.rkt:337:46 hash-ref! [224] 100.0% ----------------------------------------------------------------------------------------- run-improve50 [2] 100.0% [33] 612(0.1%) 0(0.0%) setup-prog /home/ztatlock/herbie/src/glue.rkt:45:0 simplify-alt [47] 100.0% ----------------------------------------------------------------------------------------- exprs-to-branch-on [15] 100.0% [34] 504(0.1%) 0(0.0%) critical-subexpression ...rc/core/regimes.rkt:52:0 localize-error [60] 77.4% for-loop [51] 22.6% ----------------------------------------------------------------------------------------- ??? [17] 100.0% [35] 346(0.1%) 0(0.0%) for-loop ...atlock/herbie/src/core/reduce.rkt:51:7 pattern-match [49] 100.0% ----------------------------------------------------------------------------------------- for-loop [20] 100.0% [36] 249872(60.7%) 0(0.0%) run-iter! ...tatlock/herbie/src/mainloop.rkt:215:0 simplify! [53] 80.1% finalize-iter! [56] 13.1% gen-series! [57] 4.4% choose-best-alt! [59] 0.9% gen-rewrites! [61] 0.8% localize-error [60] 0.7% ----------------------------------------------------------------------------------------- simplify [3] 21.2% for-loop [23] 33.0% simplify-expr [21] 45.9% [37] 169562(41.2%) 776(0.2%) iterate-egraph!5 ...bie/src/core/simplify.rkt:95:0 one-iter [54] 94.3% map-enodes [58] 5.0% debug-print [194] 0.1% debug7 [153] 0.1% *simplify-rules* [64] 0.1% ----------------------------------------------------------------------------------------- for-loop [23] 21.3% simplify [3] 32.4% simplify-expr [21] 46.3% [38] 49636(12.1%) 122(0.0%) loop ...tatlock/herbie/src/core/simplify.rkt:203:2 pass [55] 99.8% ----------------------------------------------------------------------------------------- get-final-combination [24] 100.0% [39] 21018(5.1%) 0(0.0%) extract-alt ...e/ztatlock/herbie/src/glue.rkt:56:0 loop [199] 93.8% loop [136] 5.7% argmins [138] 0.5% ----------------------------------------------------------------------------------------- ??? [22] 100.0% [40] 4924(1.2%) 784(0.2%) ??? ...tatlock/herbie/src/syntax/syntax.rkt:118:17 ??? [131] 84.1% ----------------------------------------------------------------------------------------- get-final-combination [24] 100.0% [41] 4004(1.0%) 0(0.0%) split-table .../ztatlock/herbie/src/glue.rkt:164:0 f134 [175] 100.0% ----------------------------------------------------------------------------------------- ??? [22] 100.0% [42] 3700(0.9%) 3700(0.9%) ??? ...rivate/unconstrained-domain-arrow.rkt:40:13 ----------------------------------------------------------------------------------------- for-loop [29] 100.0% [43] 3512(0.9%) 0(0.0%) for-loop ...lock/herbie/src/core/taylor.rkt:394:39 hash-ref! [224] 100.0% ----------------------------------------------------------------------------------------- for-loop [27] 100.0% [44] 2806(0.7%) 0(0.0%) ??? .../ztatlock/herbie/src/core/taylor.rkt:284:19 hash-ref! [224] 100.0% ----------------------------------------------------------------------------------------- ??? [22] 100.0% [45] 2084(0.5%) 524(0.1%) ...higher-order.rkt:346:33 (unknown source) ??? [115] 74.9% ----------------------------------------------------------------------------------------- for-loop [23] 15.2% simplify-expr [21] 84.8% [46] 724(0.2%) 0(0.0%) mk-egraph ...lock/herbie/src/core/egraph.rkt:123:0 expr->enode [62] 100.0% ----------------------------------------------------------------------------------------- setup-prog [33] 100.0% [47] 612(0.1%) 0(0.0%) simplify-alt .../ztatlock/herbie/src/glue.rkt:83:0 simplify [3] 100.0% ----------------------------------------------------------------------------------------- ->flonum [26] 100.0% [48] 454(0.1%) 104(0.0%) ??? ...-racket/utils/simple-result-arrow.rkt:60:15 ??? [254] 77.1% ----------------------------------------------------------------------------------------- for-loop [18] 10.7% for-loop [63] 24.3% for-loop [35] 65.0% [49] 440(0.1%) 124(0.0%) pattern-match .../herbie/src/core/matcher.rkt:47:0 for-loop [63] 47.5% variable? [102] 13.6% ??? [154] 10.7% ----------------------------------------------------------------------------------------- setfindf [28] 100.0% [50] 350(0.1%) 350(0.1%) for-loop ...e/ztatlock/herbie/src/common.rkt:169:2 ----------------------------------------------------------------------------------------- critical-subexpression [34] 100.0% [51] 114(0.0%) 0(0.0%) for-loop ...lock/herbie/src/core/regimes.rkt:87:19 eval-prog [171] 100.0% ----------------------------------------------------------------------------------------- for-loop [23] 100.0% [52] 104(0.0%) 0(0.0%) extract-smallest ...ie/src/core/simplify.rkt:179:0 hash-keys [71] 100.0% ----------------------------------------------------------------------------------------- run-iter! [36] 100.0% [53] 200108(48.6%) 208(0.1%) simplify! ...tatlock/herbie/src/mainloop.rkt:155:0 for-loop [65] 99.9% ----------------------------------------------------------------------------------------- iterate-egraph!5 [37] 100.0% [54] 159840(38.9%) 5230(1.3%) one-iter ...ock/herbie/src/core/simplify.rkt:106:0 for-loop [66] 68.2% loop [68] 25.6% apply-match [73] 1.9% filter [151] 0.1% ----------------------------------------------------------------------------------------- loop [38] 100.0% [55] 49514(12.0%) 534(0.1%) pass ...tatlock/herbie/src/core/simplify.rkt:193:2 for-loop [67] 98.7% ----------------------------------------------------------------------------------------- run-iter! [36] 100.0% [56] 32610(7.9%) 0(0.0%) finalize-iter! ...ck/herbie/src/mainloop.rkt:169:0 ??? [154] 100.0% ----------------------------------------------------------------------------------------- run-iter! [36] 100.0% [57] 11090(2.7%) 0(0.0%) gen-series! ...tlock/herbie/src/mainloop.rkt:129:0 for-loop [69] 100.0% ----------------------------------------------------------------------------------------- iterate-egraph!5 [37] 100.0% [58] 8534(2.1%) 88(0.0%) map-enodes ...ock/herbie/src/core/egraph.rkt:139:0 loop [199] 85.8% for-loop [6] 7.9% set-precompute! [221] 2.5% hash-keys [71] 1.4% ----------------------------------------------------------------------------------------- run-iter! [36] 100.0% [59] 2362(0.6%) 0(0.0%) choose-best-alt! .../herbie/src/mainloop.rkt:115:0 ??? [154] 100.0% ----------------------------------------------------------------------------------------- critical-subexpression [34] 18.3% run-iter! [36] 81.7% [60] 2130(0.5%) 0(0.0%) localize-error ...erbie/src/core/localize.rkt:47:0 hash-ref! [224] 95.8% ??? [202] 4.2% ----------------------------------------------------------------------------------------- run-iter! [36] 100.0% [61] 1962(0.5%) 0(0.0%) gen-rewrites! ...ock/herbie/src/mainloop.rkt:142:0 for-loop [70] 100.0% ----------------------------------------------------------------------------------------- mk-egraph [46] 38.9% expr->enode [62] 61.1% [62] 724(0.2%) 0(0.0%) expr->enode ...ck/herbie/src/core/egraph.rkt:124:2 expr->enode [62] 61.1% mk-enode! [105] 38.9% ----------------------------------------------------------------------------------------- pattern-match [49] 100.0% [63] 316(0.1%) 102(0.0%) for-loop ...tlock/herbie/src/core/matcher.rkt:65:9 pattern-match [49] 67.7% ----------------------------------------------------------------------------------------- iterate-egraph!5 [37] 100.0% [64] 98(0.0%) 0(0.0%) *simplify-rules* ...bie/src/syntax/rules.rkt:415:0 for-loop [108] 100.0% ----------------------------------------------------------------------------------------- simplify! [53] 99.0% [65] 201830(49.1%) 332(0.1%) for-loop ...ztatlock/herbie/src/mainloop.rkt:159:6 ??? [72] 99.5% debug-print [194] 0.2% foldl [214] 0.1% ----------------------------------------------------------------------------------------- for-loop [66] 48.9% one-iter [54] 51.1% [66] 109056(26.5%) 23716(5.8%) for-loop ...ck/herbie/src/core/simplify.rkt:116:12 for-loop [66] 48.9% match-e [81] 38.7% ??? [117] 0.4% ----------------------------------------------------------------------------------------- pass [55] 100.0% [67] 48876(11.9%) 678(0.2%) for-loop ...ck/herbie/src/core/simplify.rkt:196:29 argmin [74] 74.6% loop [76] 18.3% for-loop [77] 4.4% make-sequence [232] 1.3% ----------------------------------------------------------------------------------------- one-iter [54] 100.0% [68] 40904(9.9%) 612(0.1%) loop ...cket/collects/racket/private/map.rkt:52:19 apply-match [73] 98.5% ----------------------------------------------------------------------------------------- gen-series! [57] 100.0% [69] 11090(2.7%) 0(0.0%) for-loop ...ztatlock/herbie/src/mainloop.rkt:135:7 taylor-alt [75] 100.0% ----------------------------------------------------------------------------------------- gen-rewrites! [61] 100.0% [70] 1962(0.5%) 0(0.0%) for-loop ...tatlock/herbie/src/mainloop.rkt:147:11 ??? [78] 100.0% ----------------------------------------------------------------------------------------- extract-smallest [52] 46.4% map-enodes [58] 53.6% [71] 224(0.1%) 120(0.0%) hash-keys .../collects/racket/private/hash.rkt:2:2 loop [79] 46.4% ----------------------------------------------------------------------------------------- for-loop [65] 17.1% run [19] 40.5% [72] 404696(98.4%) 0(0.0%) ??? ...lects/racket/private/more-scheme.rkt:261:28 profile-thunk16 [1] 40.3% run-improve50 [2] 28.0% simplify [3] 17.2% loop [80] 14.5% ----------------------------------------------------------------------------------------- one-iter [54] 7.2% loop [68] 92.8% [73] 43396(10.5%) 1188(0.3%) apply-match .../herbie/src/core/simplify.rkt:122:2 match-e [81] 31.4% merge-egraph-nodes! [92] 21.7% for-loop [84] 14.6% loop! [213] 14.4% substitute-e [94] 9.5% mk-enode! [105] 4.1% reduce-to-single! [87] 1.1% update-leader! [103] 0.5% ----------------------------------------------------------------------------------------- ??? [100] 0.2% for-loop [67] 99.8% [74] 36536(8.9%) 0(0.0%) argmin ...re/racket/collects/racket/list.rkt:743:0 for-loop [82] 87.1% expression-cost [85] 12.9% ----------------------------------------------------------------------------------------- for-loop [69] 100.0% [75] 11090(2.7%) 0(0.0%) taylor-alt ...e/ztatlock/herbie/src/glue.rkt:141:0 for-loop [83] 100.0% ----------------------------------------------------------------------------------------- for-loop [67] 100.0% [76] 8960(2.2%) 98(0.0%) loop ...hare/racket/collects/racket/list.rkt:729:4 for-loop [82] 93.2% expression-cost [85] 5.7% ----------------------------------------------------------------------------------------- for-loop [67] 100.0% [77] 2162(0.5%) 2162(0.5%) for-loop ...ck/herbie/src/core/simplify.rkt:183:13 ----------------------------------------------------------------------------------------- for-loop [70] 100.0% [78] 1962(0.5%) 0(0.0%) ??? /home/ztatlock/herbie/src/alternative.rkt:88:0 rewriter [86] 93.6% loop [199] 6.4% ----------------------------------------------------------------------------------------- hash-keys [71] 20.0% loop [79] 80.0% [79] 104(0.0%) 104(0.0%) loop ...acket/collects/racket/private/hash.rkt:3:4 loop [79] 80.0% ----------------------------------------------------------------------------------------- run-improve50 [2] 9.1% ??? [72] 90.9% [80] 126910(30.9%) 0(0.0%) loop /home/ztatlock/herbie/src/points.rkt:159:2 loop [88] 60.6% make-exacts* [97] 29.7% loop [99] 9.5% for-loop [96] 0.3% ----------------------------------------------------------------------------------------- apply-match [73] 9.1% for-loop [98] 20.7% for-loop [66] 70.2% [81] 98020(23.8%) 37540(9.1%) match-e ...tatlock/herbie/src/core/ematch.rkt:46:0 for-loop [89] 40.1% for-loop [98] 10.8% ??? [154] 7.6% variable? [102] 2.8% list-cartesian-product [101] 2.1% loop [199] 1.2% custom-in-set [249] 1.1% curry* [205] 0.1% ----------------------------------------------------------------------------------------- loop [76] 20.8% argmin [74] 79.2% [82] 40176(9.8%) 864(0.2%) for-loop ...ztatlock/herbie/src/programs.rkt:197:2 location-do [90] 68.1% ...erbie/src/common.rkt:46:2 [91] 28.2% ??? [183] 1.5% ----------------------------------------------------------------------------------------- taylor-alt [75] 100.0% [83] 11090(2.7%) 0(0.0%) for-loop /home/ztatlock/herbie/src/glue.rkt:143:2 ??? [100] 100.0% ----------------------------------------------------------------------------------------- apply-match [73] 100.0% [84] 6336(1.5%) 84(0.0%) for-loop ...ck/herbie/src/core/simplify.rkt:136:10 loop! [213] 61.1% mk-enode! [105] 14.7% substitute-e [94] 12.5% merge-egraph-nodes! [92] 10.4% ----------------------------------------------------------------------------------------- loop [76] 9.8% argmin [74] 90.2% [85] 5222(1.3%) 0(0.0%) expression-cost ...k/herbie/src/programs.rkt:196:0 compile [93] 100.0% ----------------------------------------------------------------------------------------- ??? [78] 26.3% matcher [107] 73.7% [86] 1836(0.4%) 426(0.1%) rewriter ...lock/herbie/src/core/matcher.rkt:127:2 for-loop [95] 78.2% *rules* [12] 13.2% ----------------------------------------------------------------------------------------- apply-match [73] 100.0% [87] 458(0.1%) 360(0.1%) reduce-to-single! ...bie/src/core/egraph.rkt:324:0 make-sequence [232] 21.4% ----------------------------------------------------------------------------------------- loop [80] 100.0% [88] 76922(18.7%) 0(0.0%) loop /home/ztatlock/herbie/src/points.rkt:119:2 make-exacts* [97] 37.2% loop [99] 32.1% eval-prog [171] 30.6% loop [113] 0.1% ----------------------------------------------------------------------------------------- match-e [81] 100.0% [89] 50880(12.4%) 17312(4.2%) for-loop ...tlock/herbie/src/core/ematch.rkt:59:11 for-loop [98] 53.1% list-cartesian-product [101] 9.5% loop [199] 2.9% curry* [205] 1.2% foldl [214] 1.1% filter [151] 0.1% ----------------------------------------------------------------------------------------- f134 [175] 0.9% location-do [90] 8.4% ??? [100] 22.3% for-loop [82] 68.4% [90] 40040(9.7%) 6976(1.7%) location-do ...acket/private/norm-define.rkt:53:83 ??? [162] 48.2% ??? [100] 19.5% location-do [90] 8.4% ??? [155] 2.1% return/no-unsupplied [147] 1.9% ??? [115] 1.3% ??? [163] 0.3% ??? [177] 0.2% ----------------------------------------------------------------------------------------- ->flonum [26] 0.7% ->bf [127] 0.7% f134 [175] 2.5% ??? [100] 7.7% for-loop [82] 88.3% [91] 12824(3.1%) 3592(0.9%) ...erbie/src/common.rkt:46:2 ...e/arr-i.rkt:906:19 ??? [104] 43.8% ??? [106] 28.2% ----------------------------------------------------------------------------------------- for-loop [111] 1.6% merge-egraph-nodes! [92] 4.9% for-loop [84] 5.7% apply-match [73] 87.7% [92] 10086(2.5%) 592(0.1%) merge-egraph-nodes! ...e/src/core/egraph.rkt:152:0 update-leader! [103] 58.6% enode-merge! [109] 11.3% loop! [213] 8.2% for-loop [110] 5.4% merge-egraph-nodes! [92] 4.9% for-loop [108] 3.0% for-loop [111] 2.7% ----------------------------------------------------------------------------------------- expression-cost [85] 100.0% [93] 5222(1.3%) 98(0.0%) compile .../ztatlock/herbie/src/programs.rkt:173:0 hash-ref! [224] 98.1% ----------------------------------------------------------------------------------------- for-loop [84] 9.8% substitute-e [94] 33.5% apply-match [73] 56.7% [94] 4896(1.2%) 826(0.2%) substitute-e ...ck/herbie/src/core/ematch.rkt:71:0 mk-enode! [105] 37.8% substitute-e [94] 33.5% ??? [154] 12.8% variable? [102] 4.5% ----------------------------------------------------------------------------------------- rewriter [86] 100.0% [95] 1836(0.4%) 92(0.0%) for-loop ...ock/herbie/src/core/matcher.rkt:130:10 matcher [107] 98.7% ----------------------------------------------------------------------------------------- loop [80] 100.0% [96] 336(0.1%) 0(0.0%) for-loop .../ztatlock/herbie/src/points.rkt:166:24 for-loop [112] 100.0% ----------------------------------------------------------------------------------------- loop [88] 43.2% loop [80] 56.8% [97] 66252(16.1%) 0(0.0%) make-exacts* ...atlock/herbie/src/points.rkt:106:0 loop [199] 39.9% map [180] 39.1% eval-prog [171] 21.1% ----------------------------------------------------------------------------------------- match-e [81] 38.3% for-loop [89] 61.7% [98] 44542(10.8%) 2870(0.7%) for-loop ...tlock/herbie/src/core/ematch.rkt:65:37 match-e [81] 82.8% ??? [117] 11.4% ----------------------------------------------------------------------------------------- loop [80] 32.7% loop [88] 67.3% [99] 36702(8.9%) 64(0.0%) loop /home/ztatlock/herbie/src/points.rkt:109:4 map [180] 99.8% ----------------------------------------------------------------------------------------- ??? [100] 0.3% simplify [3] 0.5% eval-prog [171] 0.9% ??? [234] 1.7% ??? [159] 10.5% location-do [90] 28.3% for-loop [83] 28.3% f134 [175] 29.5% [100] 19604(4.8%) 312(0.1%) ??? ...tract/private/arrow-higher-order.rkt:342:33 location-do [90] 33.9% approximate9 [114] 28.3% ??? [190] 11.7% best-alt [119] 10.1% ...erbie/src/common.rkt:46:2 [91] 5.0% ->flonum [26] 3.2% ->bf [127] 2.1% ??? [116] 1.5% ??? [183] 0.5% successfully-got-the-right-kind-of-function [191] 0.5% ??? [184] 0.5% argmin [74] 0.4% ??? [100] 0.3% ??? [212] 0.3% ----------------------------------------------------------------------------------------- match-e [81] 20.8% list-cartesian-product [101] 24.1% for-loop [89] 55.1% [101] 8052(2.0%) 6970(1.7%) list-cartesian-product ...src/core/ematch.rkt:20:0 list-cartesian-product [101] 24.1% for-loop [121] 10.2% ----------------------------------------------------------------------------------------- pattern-match [49] 1.6% substitute-e [94] 8.1% match-e [81] 90.2% [102] 7366(1.8%) 88(0.0%) variable? ...ck/herbie/src/syntax/syntax.rkt:529:0 ??? [154] 98.8% ----------------------------------------------------------------------------------------- apply-match [73] 3.3% merge-egraph-nodes! [92] 96.7% [103] 6622(1.6%) 1674(0.4%) update-leader! ...herbie/src/core/egraph.rkt:217:0 for-loop [118] 68.1% update-en-expr [229] 2.7% custom-set-union! [129] 2.7% hash-ref! [224] 1.3% ----------------------------------------------------------------------------------------- for-loop [137] 5.8% ??? [115] 12.7% ...erbie/src/common.rkt:46:2 [91] 81.5% [104] 5622(1.4%) 1408(0.3%) ??? ...ects/racket/contract/private/list.rkt:342:4 ??? [115] 70.2% ??? [125] 8.6% ??? [190] 7.3% ----------------------------------------------------------------------------------------- expr->enode [62] 13.7% for-loop [84] 17.7% apply-match [73] 33.5% substitute-e [94] 35.1% [105] 5268(1.3%) 3912(1.0%) mk-enode! ...lock/herbie/src/core/egraph.rkt:101:0 hash-has-key? [158] 15.4% new-enode [123] 10.3% ----------------------------------------------------------------------------------------- ...erbie/src/common.rkt:46:2 [91] 100.0% [106] 3610(0.9%) 1156(0.3%) ??? ...s/racket/contract/private/arr-i.rkt:1268:39 ??? [155] 35.0% return/no-unsupplied [147] 16.7% assoc-ref [122] 16.3% ----------------------------------------------------------------------------------------- for-loop [120] 24.3% matcher [107] 25.5% for-loop [95] 50.2% [107] 1836(0.4%) 86(0.0%) matcher ...tlock/herbie/src/core/matcher.rkt:163:2 rewriter [86] 48.4% matcher [107] 25.5% for-loop [120] 24.3% for-loop [18] 0.9% ----------------------------------------------------------------------------------------- *simplify-rules* [64] 7.9% merge-egraph-nodes! [92] 24.5% *rules* [12] 67.6% [108] 1240(0.3%) 356(0.1%) for-loop /home/ztatlock/herbie/src/common.rkt:93:9 ormap [124] 35.0% ??? [131] 18.7% update-en-expr [229] 17.6% ----------------------------------------------------------------------------------------- merge-egraph-nodes! [92] 100.0% [109] 1142(0.3%) 604(0.1%) enode-merge! ...ck/herbie/src/core/enode.rkt:100:0 adopt-enode! [126] 39.1% custom-set-intersect! [130] 8.1% ----------------------------------------------------------------------------------------- merge-egraph-nodes! [92] 100.0% [110] 602(0.1%) 368(0.1%) for-loop ...tlock/herbie/src/core/egraph.rkt:232:6 update-en-expr [229] 38.9% ----------------------------------------------------------------------------------------- merge-egraph-nodes! [92] 100.0% [111] 436(0.1%) 0(0.0%) for-loop ...lock/herbie/src/core/egraph.rkt:200:10 merge-egraph-nodes! [92] 76.1% loop! [213] 23.9% ----------------------------------------------------------------------------------------- for-loop [96] 100.0% [112] 336(0.1%) 0(0.0%) for-loop .../ztatlock/herbie/src/points.rkt:167:26 ??? [128] 100.0% ----------------------------------------------------------------------------------------- loop [88] 2.6% loop [113] 97.4% [113] 106(0.0%) 106(0.0%) loop /home/ztatlock/herbie/src/points.rkt:98:2 loop [113] 97.4% ----------------------------------------------------------------------------------------- ??? [100] 100.0% [114] 11090(2.7%) 0(0.0%) approximate9 ...ck/herbie/src/core/taylor.rkt:12:0 loop [132] 92.3% f134 [175] 5.8% taylor-quotient [139] 1.0% taylor [185] 0.9% ----------------------------------------------------------------------------------------- ??? [162] 1.1% location-do [90] 7.2% ...higher-order.rkt:346:33 [45] 21.8% ??? [104] 69.8% [115] 7146(1.7%) 3512(0.9%) ??? ...cts/racket/contract/private/list.rkt:187:10 ??? [104] 20.0% ??? [190] 16.0% for-loop [137] 13.7% ??? [182] 1.1% ----------------------------------------------------------------------------------------- ??? [100] 4.6% ??? [4] 95.4% [116] 6474(1.6%) 504(0.1%) ??? ...contract/private/../../private/kw.rkt:761:9 real->bigfloat [133] 90.4% ----------------------------------------------------------------------------------------- for-loop [66] 14.9% for-loop [98] 85.1% [117] 6396(1.6%) 1474(0.4%) ??? /home/ztatlock/herbie/src/core/ematch.rkt:50:5 for-loop [134] 75.2% custom-in-set [249] 1.8% ----------------------------------------------------------------------------------------- update-leader! [103] 100.0% [118] 4508(1.1%) 200(0.0%) for-loop ...tlock/herbie/src/core/egraph.rkt:222:6 for-loop [135] 95.6% ----------------------------------------------------------------------------------------- ??? [100] 100.0% [119] 2276(0.6%) 0(0.0%) best-alt /home/ztatlock/herbie/src/glue.rkt:78:0 loop [136] 79.9% argmins [138] 20.1% ----------------------------------------------------------------------------------------- matcher [107] 100.0% [120] 1290(0.3%) 0(0.0%) for-loop ...ock/herbie/src/core/matcher.rkt:179:21 matcher [107] 100.0% ----------------------------------------------------------------------------------------- list-cartesian-product [101] 100.0% [121] 1082(0.3%) 1082(0.3%) for-loop ...atlock/herbie/src/core/ematch.rkt:24:8 ----------------------------------------------------------------------------------------- ??? [106] 100.0% [122] 590(0.1%) 590(0.1%) assoc-ref ...collects/racket/private/dict.rkt:56:0 ----------------------------------------------------------------------------------------- mk-enode! [105] 100.0% [123] 544(0.1%) 122(0.0%) new-enode ...atlock/herbie/src/core/enode.rkt:68:0 set [228] 60.3% check-valid-enode5 [143] 17.3% ----------------------------------------------------------------------------------------- *rules* [12] 20.2% for-loop [108] 79.8% [124] 544(0.1%) 0(0.0%) ormap ...et/collects/racket/private/map.rkt:105:13 ??? [131] 82.0% ??? [142] 18.0% ----------------------------------------------------------------------------------------- ??? [104] 100.0% [125] 484(0.1%) 202(0.0%) ??? ...ects/racket/contract/private/hash.rkt:222:6 check-hash/c [140] 58.3% ----------------------------------------------------------------------------------------- enode-merge! [109] 100.0% [126] 446(0.1%) 192(0.0%) adopt-enode! ...ock/herbie/src/core/enode.rkt:76:0 custom-set-union [227] 57.0% ----------------------------------------------------------------------------------------- ??? [100] 100.0% [127] 418(0.1%) 0(0.0%) ->bf /home/ztatlock/herbie/src/programs.rkt:49:0 ??? [154] 77.0% ...erbie/src/common.rkt:46:2 [91] 23.0% ----------------------------------------------------------------------------------------- for-loop [112] 100.0% [128] 336(0.1%) 162(0.0%) ??? /home/ztatlock/herbie/src/points.rkt:156:9 random-exp [141] 51.8% ----------------------------------------------------------------------------------------- update-leader! [103] 100.0% [129] 176(0.0%) 176(0.0%) custom-set-union! ...t/private/set-types.rkt:245:0 ----------------------------------------------------------------------------------------- enode-merge! [109] 100.0% [130] 92(0.0%) 92(0.0%) custom-set-intersect! ...ivate/set-types.rkt:269:0 ----------------------------------------------------------------------------------------- *rules* [12] 0.8% errors [167] 0.9% for-loop [108] 2.1% ormap [124] 4.1% ulp-difference [176] 8.6% ??? [40] 38.1% ->flonum [26] 45.3% [131] 10852(2.6%) 4656(1.1%) ??? /home/ztatlock/herbie/src/config.rkt:48:0 ??? [155] 35.9% return/no-unsupplied [147] 20.2% ----------------------------------------------------------------------------------------- approximate9 [114] 100.0% [132] 10238(2.5%) 0(0.0%) loop ...e/ztatlock/herbie/src/core/taylor.rkt:83:4 hash-ref! [224] 100.0% ----------------------------------------------------------------------------------------- ??? [116] 100.0% [133] 5850(1.4%) 4390(1.1%) real->bigfloat .../private/bigfloat/mpfr.rkt:451:0 ??? [254] 25.0% ----------------------------------------------------------------------------------------- ??? [117] 100.0% [134] 4808(1.2%) 1036(0.3%) for-loop ...atlock/herbie/src/core/ematch.rkt:51:7 ??? [154] 78.5% ----------------------------------------------------------------------------------------- for-loop [118] 100.0% [135] 4308(1.0%) 232(0.1%) for-loop ...tlock/herbie/src/core/egraph.rkt:223:8 hash-update! [146] 94.6% ----------------------------------------------------------------------------------------- extract-alt [39] 39.6% best-alt [119] 60.4% [136] 3012(0.7%) 0(0.0%) loop /home/ztatlock/herbie/src/common.rkt:135:2 composed [145] 100.0% ----------------------------------------------------------------------------------------- ??? [115] 100.0% [137] 982(0.2%) 332(0.1%) for-loop ...acket/contract/private/list.rkt:190:15 ??? [104] 66.2% ----------------------------------------------------------------------------------------- extract-alt [39] 19.1% best-alt [119] 80.9% [138] 566(0.1%) 0(0.0%) argmins /home/ztatlock/herbie/src/common.rkt:134:0 composed [145] 100.0% ----------------------------------------------------------------------------------------- approximate9 [114] 33.9% f134 [175] 66.1% [139] 336(0.1%) 0(0.0%) taylor-quotient ...erbie/src/core/taylor.rkt:324:0 simplify [144] 66.1% first-nonzero-exp [148] 33.9% ----------------------------------------------------------------------------------------- ??? [125] 100.0% [140] 282(0.1%) 200(0.0%) check-hash/c ...ket/contract/private/hash.rkt:83:0 flat-contract? [149] 29.1% ----------------------------------------------------------------------------------------- ??? [128] 100.0% [141] 174(0.0%) 174(0.0%) random-exp ...ztatlock/herbie/src/common.rkt:222:0 ----------------------------------------------------------------------------------------- ormap [124] 100.0% [142] 98(0.0%) 98(0.0%) ??? ...ztatlock/herbie/src/syntax/rules.rkt:417:20 ----------------------------------------------------------------------------------------- new-enode [123] 100.0% [143] 94(0.0%) 94(0.0%) check-valid-enode5 ...bie/src/core/enode.rkt:177:0 ----------------------------------------------------------------------------------------- for-loop [27] 1.0% taylor-quotient [139] 2.1% hash-ref! [224] 96.0% [144] 10792(2.6%) 0(0.0%) simplify ...atlock/herbie/src/core/reduce.rkt:15:0 parse-loop12 [189] 75.4% f134 [175] 22.3% debug7 [153] 2.3% ----------------------------------------------------------------------------------------- argmins [138] 12.7% f134 [175] 19.7% loop [136] 67.6% [145] 4456(1.1%) 0(0.0%) composed ...ollects/racket/private/list.rkt:321:16 errors [167] 80.3% f134 [175] 17.6% free-variables [152] 2.1% ----------------------------------------------------------------------------------------- for-loop [135] 100.0% [146] 4076(1.0%) 0(0.0%) hash-update! ...ket/private/more-scheme.rkt:362:13 ??? [150] 100.0% ----------------------------------------------------------------------------------------- ??? [106] 16.9% location-do [90] 21.8% ??? [131] 61.3% [147] 3568(0.9%) 2764(0.7%) return/no-unsupplied ...ct/private/arr-i.rkt:533:0 filter [151] 22.5% ----------------------------------------------------------------------------------------- taylor-quotient [139] 100.0% [148] 114(0.0%) 0(0.0%) first-nonzero-exp ...bie/src/core/taylor.rkt:256:0 hash-ref! [224] 100.0% ----------------------------------------------------------------------------------------- check-hash/c [140] 100.0% [149] 82(0.0%) 82(0.0%) flat-contract? .../contract/private/guts.rkt:111:0 ----------------------------------------------------------------------------------------- hash-update! [146] 100.0% [150] 4076(1.0%) 218(0.1%) ??? .../ztatlock/herbie/src/core/egraph.rkt:225:24 for-loop [156] 91.7% make-sequence [232] 2.9% ----------------------------------------------------------------------------------------- one-iter [54] 9.1% for-loop [89] 11.3% return/no-unsupplied [147] 79.6% [151] 1010(0.2%) 1010(0.2%) filter ...t/collects/racket/private/list.rkt:256:2 ----------------------------------------------------------------------------------------- composed [145] 10.7% append-map [13] 89.3% [152] 878(0.2%) 310(0.1%) free-variables ...ock/herbie/src/programs.rkt:98:0 ??? [154] 64.7% ----------------------------------------------------------------------------------------- iterate-egraph!5 [37] 32.6% simplify [144] 67.4% [153] 368(0.1%) 0(0.0%) debug7 /home/ztatlock/herbie/src/debug.rkt:102:0 ??? [155] 67.4% ??? [154] 32.6% ----------------------------------------------------------------------------------------- ->flonum [26] 0.1% pattern-match [49] 0.1% debug7 [153] 0.2% pattern-substitute [186] 0.3% simplify* [217] 0.3% ->bf [127] 0.5% f134 [175] 0.8% free-variables [152] 0.9% substitute-e [94] 2.5% ??? [190] 2.6% choose-best-alt! [59] 3.5% setfindf [28] 3.9% for-loop [134] 5.7% variable? [102] 11.1% match-e [81] 20.1% finalize-iter! [56] 47.4% [154] 65626(16.0%) 17196(4.2%) ??? ...contract/private/arrow-val-first.rkt:357:18 for-loop [157] 45.0% hash-has-key? [158] 22.7% ??? [159] 3.5% atab-add-altns [160] 2.4% ??? [190] 0.3% ----------------------------------------------------------------------------------------- debug7 [153] 4.0% location-do [90] 13.5% ??? [106] 20.2% ??? [131] 62.4% [155] 6248(1.5%) 1546(0.4%) ??? ...racket/collects/racket/private/kw.rkt:761:9 ??? [238] 67.9% ??? [190] 7.4% ----------------------------------------------------------------------------------------- ??? [150] 100.0% [156] 3738(0.9%) 2984(0.7%) for-loop ...lock/herbie/src/core/egraph.rkt:226:26 update-en-expr [229] 20.2% ----------------------------------------------------------------------------------------- ??? [154] 100.0% [157] 31034(7.5%) 0(0.0%) for-loop ...ock/herbie/src/core/alt-table.rkt:51:2 atab-add-altn [161] 100.0% ----------------------------------------------------------------------------------------- mk-enode! [105] 4.7% ??? [154] 95.3% [158] 17226(4.2%) 3742(0.9%) hash-has-key? ...et/private/more-scheme.rkt:368:13 ??? [162] 74.3% ??? [163] 4.0% ----------------------------------------------------------------------------------------- ??? [154] 100.0% [159] 2362(0.6%) 0(0.0%) ??? ...ztatlock/herbie/src/core/alt-table.rkt:54:0 ??? [100] 100.0% ----------------------------------------------------------------------------------------- ??? [154] 100.0% [160] 1576(0.4%) 0(0.0%) atab-add-altns ...rbie/src/core/alt-table.rkt:50:0 atab-add-altn [161] 100.0% ----------------------------------------------------------------------------------------- atab-add-altns [160] 4.8% for-loop [157] 95.2% [161] 32610(7.9%) 0(0.0%) atab-add-altn ...rbie/src/core/alt-table.rkt:208:0 best-and-tied-at-points [164] 88.9% override-at-pnts [166] 9.6% loop [199] 0.3% ----------------------------------------------------------------------------------------- hash-has-key? [158] 39.9% location-do [90] 60.1% [162] 32108(7.8%) 9776(2.4%) ??? ...ects/racket/contract/private/list.rkt:737:4 for-loop [165] 51.0% ??? [168] 8.2% arrow-higher-order:lnp [169] 7.6% successfully-got-the-right-kind-of-function [191] 2.5% ??? [115] 0.2% ----------------------------------------------------------------------------------------- location-do [90] 13.0% hash-has-key? [158] 87.0% [163] 786(0.2%) 786(0.2%) ??? ...ects/racket/contract/private/hash.rkt:245:7 ----------------------------------------------------------------------------------------- atab-add-altn [161] 100.0% [164] 29006(7.1%) 0(0.0%) best-and-tied-at-points ...ore/alt-table.rkt:122:0 errors [167] 98.3% ----------------------------------------------------------------------------------------- ??? [162] 100.0% [165] 16382(4.0%) 9460(2.3%) for-loop ...acket/contract/private/list.rkt:743:12 ??? [168] 23.8% for-loop [170] 7.1% successfully-got-the-right-kind-of-function [191] 5.8% arrow-higher-order:lnp [169] 5.5% ----------------------------------------------------------------------------------------- atab-add-altn [161] 100.0% [166] 3126(0.8%) 130(0.0%) override-at-pnts ...e/src/core/alt-table.rkt:145:0 errors [167] 95.8% ----------------------------------------------------------------------------------------- run-improve50 [2] 0.2% option-on-expr [181] 0.9% loop [199] 2.8% override-at-pnts [166] 8.2% composed [145] 9.8% best-and-tied-at-points [164] 78.1% [167] 36508(8.9%) 238(0.1%) errors /home/ztatlock/herbie/src/points.rkt:184:0 for-loop [172] 77.3% eval-prog [171] 21.8% ??? [131] 0.3% ----------------------------------------------------------------------------------------- ??? [162] 40.4% for-loop [165] 59.6% [168] 6532(1.6%) 3118(0.8%) ??? ...private/unconstrained-domain-arrow.rkt:74:4 make-keyword-procedure [201] 52.3% ----------------------------------------------------------------------------------------- for-loop [165] 27.2% ??? [162] 72.8% [169] 3336(0.8%) 1662(0.4%) arrow-higher-order:lnp ...w-higher-order.rkt:597:7 ??? [173] 50.2% ----------------------------------------------------------------------------------------- for-loop [165] 100.0% [170] 1168(0.3%) 518(0.1%) for-loop ...racket/contract/private/hash.rkt:239:6 ??? [174] 38.2% ??? [182] 17.5% ----------------------------------------------------------------------------------------- for-loop [51] 0.2% for-loop [210] 0.4% ??? [247] 3.3% errors [167] 16.8% make-exacts* [97] 29.5% loop [88] 49.8% [171] 47264(11.5%) 3804(0.9%) eval-prog ...tatlock/herbie/src/programs.rkt:146:0 hash-ref! [224] 74.4% f134 [175] 14.9% ??? [178] 0.6% ??? [177] 0.5% ??? [179] 0.4% ??? [100] 0.4% ----------------------------------------------------------------------------------------- errors [167] 100.0% [172] 28214(6.9%) 950(0.2%) for-loop ...e/ztatlock/herbie/src/points.rkt:187:4 ??? [4] 89.9% ulp-difference [176] 3.3% ->flonum [26] 3.1% ----------------------------------------------------------------------------------------- arrow-higher-order:lnp [169] 100.0% [173] 1674(0.4%) 1674(0.4%) ??? ...et/contract/private/arity-checking.rkt:19:2 ----------------------------------------------------------------------------------------- for-loop [170] 100.0% [174] 446(0.1%) 178(0.0%) ??? ...ects/racket/contract/private/list.rkt:686:7 ??? [182] 60.1% ----------------------------------------------------------------------------------------- composed [145] 1.0% approximate9 [114] 1.0% append-map [13] 1.4% loop [199] 2.6% map [180] 5.4% parse-loop12 [189] 5.4% hash-ref! [224] 5.5% simplify [144] 5.9% eval-const-expr [30] 8.5% eval-prog [171] 10.5% split-table [41] 20.9% f134 [175] 31.7% [175] 17558(4.3%) 760(0.2%) f134 .../collects/racket/match/compiler.rkt:507:40 f134 [175] 31.7% map [180] 20.4% option-on-expr [181] 19.4% ??? [100] 10.6% ??? [184] 2.6% append-map [13] 2.4% location-do [90] 2.1% ...erbie/src/common.rkt:46:2 [91] 1.8% composed [145] 1.5% exprs-to-branch-on [15] 1.5% ??? [154] 0.8% ??? [183] 0.6% taylor-quotient [139] 0.4% taylor [185] 0.3% parse-loop12 [189] 0.3% gather-multiplicative-terms [196] 0.2% ----------------------------------------------------------------------------------------- loop [16] 8.1% for-loop [172] 91.9% [176] 1018(0.2%) 88(0.0%) ulp-difference ...atlock/herbie/src/float.rkt:19:0 ??? [131] 91.4% ----------------------------------------------------------------------------------------- location-do [90] 47.8% eval-prog [171] 52.2% [177] 414(0.1%) 114(0.0%) ??? ...tract/private/arrow-higher-order.rkt:346:33 pattern-substitute [186] 47.8% ??? [182] 24.6% ----------------------------------------------------------------------------------------- eval-prog [171] 100.0% [178] 284(0.1%) 92(0.0%) ??? ...collects/racket/private/qq-and-or.rkt:155:9 ??? [187] 67.6% ----------------------------------------------------------------------------------------- eval-prog [171] 100.0% [179] 196(0.0%) 88(0.0%) ??? ...cket/collects/racket/private/kw.rkt:1633:36 unpack242 [188] 55.1% ----------------------------------------------------------------------------------------- gather-multiplicative-terms [196] 0.0% loop [199] 0.2% ??? [192] 0.2% parse-loop12 [189] 2.7% f134 [175] 5.9% make-exacts* [97] 37.7% loop [99] 53.4% [180] 68670(16.7%) 112(0.0%) map ...acket/collects/racket/private/map.rkt:20:13 loop [199] 91.7% parse-loop12 [189] 4.2% f134 [175] 2.0% ??? [192] 0.8% ??? [4] 0.7% ->flonum [26] 0.2% simplify* [217] 0.1% make-multiplication-node [219] 0.1% ??? [17] 0.0% gather-multiplicative-terms [196] 0.0% ----------------------------------------------------------------------------------------- f134 [175] 100.0% [181] 3500(0.9%) 112(0.0%) option-on-expr ...erbie/src/core/regimes.rkt:115:0 sort-context-on-expr [193] 50.1% loop [199] 31.8% errors [167] 9.5% pick-errors [197] 5.4% ----------------------------------------------------------------------------------------- ??? [115] 5.8% ??? [177] 7.4% for-loop [170] 14.8% ??? [174] 19.5% ??? [22] 52.4% [182] 1374(0.3%) 454(0.1%) ??? ...ects/racket/contract/private/prop.rkt:493:4 ??? [195] 67.0% ----------------------------------------------------------------------------------------- ??? [100] 10.9% f134 [175] 11.8% ->flonum [26] 12.4% for-loop [82] 64.8% [183] 950(0.2%) 610(0.1%) ??? ...ts/racket/contract/private/arr-i.rkt:804:10 successfully-got-the-right-kind-of-function [191] 12.4% get/build-late-neg-projection [198] 11.8% ??? [250] 11.6% ----------------------------------------------------------------------------------------- ??? [100] 16.4% f134 [175] 83.6% [184] 548(0.1%) 90(0.0%) ??? ...tract/private/arrow-higher-order.rkt:336:46 ??? [190] 83.6% ----------------------------------------------------------------------------------------- approximate9 [114] 48.1% f134 [175] 51.9% [185] 208(0.1%) 108(0.0%) taylor ...tatlock/herbie/src/core/taylor.rkt:159:0 debug-print [194] 48.1% ----------------------------------------------------------------------------------------- ??? [177] 11.2% pattern-substitute [186] 88.8% [186] 198(0.0%) 0(0.0%) pattern-substitute ...ie/src/core/matcher.rkt:72:0 pattern-substitute [186] 88.8% ??? [154] 11.2% ----------------------------------------------------------------------------------------- ??? [178] 100.0% [187] 192(0.0%) 192(0.0%) ??? ...ollects/racket/private/qq-and-or.rkt:164:21 ----------------------------------------------------------------------------------------- ??? [179] 100.0% [188] 108(0.0%) 108(0.0%) unpack242 ...private/arrow-higher-order.rkt:354:44 ----------------------------------------------------------------------------------------- f134 [175] 0.3% loop [199] 5.6% for-loop [31] 6.0% map [180] 12.3% hash-ref! [224] 17.2% simplify [144] 28.1% parse-loop12 [189] 30.5% [189] 11862(2.9%) 6544(1.6%) parse-loop12 ...s/racket/match/compiler.rkt:418:15 parse-loop12 [189] 30.5% loop [199] 21.6% for-loop [203] 6.0% map [180] 6.0% f134 [175] 5.7% parse-app [207] 1.6% simplify* [217] 1.5% bf* [200] 0.8% ??? [17] 0.8% loop [16] 0.7% curry* [205] 0.6% make-multiplication-node [219] 0.3% make-keyword-procedure [201] 0.2% ----------------------------------------------------------------------------------------- ??? [154] 3.8% ??? [184] 8.2% ??? [155] 8.2% ??? [104] 14.7% ??? [115] 20.5% ??? [100] 42.7% [190] 5580(1.4%) 1928(0.5%) ??? ...ects/racket/contract/private/guts.rkt:644:8 ??? [154] 50.9% contract? [206] 12.7% ----------------------------------------------------------------------------------------- ??? [100] 5.2% ??? [183] 6.0% ??? [162] 40.6% for-loop [165] 48.3% [191] 1976(0.5%) 756(0.2%) successfully-got-the-right-kind-of-function ...9:4 arity-checking-wrapper [204] 61.7% ----------------------------------------------------------------------------------------- map [180] 13.9% loop [199] 86.1% [192] 1940(0.5%) 0(0.0%) ??? ...ket/collects/racket/private/list.rkt:323:18 hash-ref! [224] 97.1% map [180] 2.9% ----------------------------------------------------------------------------------------- option-on-expr [181] 100.0% [193] 1752(0.4%) 0(0.0%) sort-context-on-expr ...herbie/src/points.rkt:79:0 ??? [202] 100.0% ----------------------------------------------------------------------------------------- taylor [185] 8.3% iterate-egraph!5 [37] 16.1% for-loop [23] 16.7% simplify-expr [21] 17.4% for-loop [65] 41.5% [194] 1206(0.3%) 606(0.1%) debug-print ...ztatlock/herbie/src/debug.rkt:107:0 for-loop [208] 49.8% ----------------------------------------------------------------------------------------- ??? [182] 100.0% [195] 920(0.2%) 550(0.1%) ??? ...lects/racket/contract/private/orc.rkt:83:14 ??? [209] 40.2% ----------------------------------------------------------------------------------------- map [180] 24.8% f134 [175] 75.2% [196] 222(0.1%) 0(0.0%) gather-multiplicative-terms ...re/reduce.rkt:105:0 map [180] 75.2% compose [251] 24.8% ----------------------------------------------------------------------------------------- option-on-expr [181] 100.0% [197] 188(0.0%) 0(0.0%) pick-errors ...k/herbie/src/core/regimes.rkt:187:0 for-loop [210] 100.0% ----------------------------------------------------------------------------------------- unconstrained-domain->-projection [211] 50.0% ??? [183] 50.0% [198] 112(0.0%) 112(0.0%) get/build-late-neg-projection ...te/guts.rkt:691:0 unconstrained-domain->-projection [211] 50.0% ----------------------------------------------------------------------------------------- ??? [78] 0.0% atab-add-altn [161] 0.0% for-loop [23] 0.0% simplify [3] 0.1% option-on-expr [181] 0.3% make-exacts* [97] 0.3% for-loop [89] 0.7% match-e [81] 0.9% map-enodes [58] 1.0% map [180] 1.4% loop! [213] 1.7% parse-loop12 [189] 1.9% extract-alt [39] 4.6% ??? [5] 19.6% loop [199] 67.3% [199] 163718(39.8%) 3094(0.8%) loop ...cket/collects/racket/private/map.rkt:25:19 loop [199] 67.3% hash-ref! [224] 19.6% simplify [3] 4.6% loop! [213] 1.5% parse-loop12 [189] 1.4% ??? [4] 1.3% for-loop [6] 0.9% ??? [192] 0.5% errors [167] 0.3% f134 [175] 0.3% foldl [214] 0.2% ->flonum [26] 0.1% loop [220] 0.1% make-multiplication-node [219] 0.1% simplify* [217] 0.0% map [180] 0.0% ??? [212] 0.0% set-precompute! [221] 0.0% ----------------------------------------------------------------------------------------- parse-loop12 [189] 1.3% ??? [22] 98.7% [200] 7554(1.8%) 0(0.0%) bf* ...ath/private/bigfloat/bigfloat-mpfr.rkt:95:0 ??? [212] 100.0% ----------------------------------------------------------------------------------------- parse-loop12 [189] 3.1% ??? [168] 96.9% [201] 3522(0.9%) 3522(0.9%) make-keyword-procedure ...ket/private/kw.rkt:260:4 ----------------------------------------------------------------------------------------- localize-error [60] 4.9% sort-context-on-expr [193] 95.1% [202] 1842(0.4%) 0(0.0%) ??? ...cket/collects/racket/private/sort.rkt:403:3 generic-sort/key [215] 82.4% loop [240] 17.6% ----------------------------------------------------------------------------------------- parse-loop12 [189] 100.0% [203] 1678(0.4%) 0(0.0%) for-loop ...lock/herbie/src/core/taylor.rkt:486:59 hash-ref! [224] 100.0% ----------------------------------------------------------------------------------------- successfully-got-the-right-kind-of-function [191]100.0% [204] 1220(0.3%) 80(0.0%) arity-checking-wrapper ...w-higher-order.rkt:402:0 matches-arity-exactly? [216] 93.4% ----------------------------------------------------------------------------------------- for-loop [6] 7.8% match-e [81] 10.9% parse-loop12 [189] 14.7% for-loop [89] 66.6% [205] 994(0.2%) 176(0.0%) curry* ...racket/collects/racket/function.rkt:44:2 procedure-arity [218] 82.3% ----------------------------------------------------------------------------------------- ??? [190] 100.0% [206] 706(0.2%) 706(0.2%) contract? ...acket/contract/private/guts.rkt:109:0 ----------------------------------------------------------------------------------------- eval-const-expr [30] 12.8% parse-loop12 [189] 67.3% [207] 686(0.2%) 444(0.1%) parse-app .../collects/racket/private/kw.rkt:951:2 loop [222] 35.3% ----------------------------------------------------------------------------------------- debug-print [194] 100.0% [208] 600(0.1%) 494(0.1%) for-loop /home/ztatlock/herbie/src/debug.rkt:113:2 write-proc [223] 17.7% ----------------------------------------------------------------------------------------- ??? [195] 100.0% [209] 370(0.1%) 370(0.1%) ??? ...ects/racket/contract/private/list.rkt:141:5 ----------------------------------------------------------------------------------------- pick-errors [197] 100.0% [210] 188(0.0%) 0(0.0%) for-loop ...lock/herbie/src/core/regimes.rkt:190:4 eval-prog [171] 100.0% ----------------------------------------------------------------------------------------- get/build-late-neg-projection [198] 100.0% [211] 112(0.0%) 0(0.0%) unconstrained-domain->-projection ...rrow.rkt:60:0 get/build-late-neg-projection [198] 100.0% ----------------------------------------------------------------------------------------- eval-const-expr [30] 0.2% ??? [100] 0.2% loop [199] 1.6% bf* [200] 12.8% ??? [22] 85.3% [212] 59210(14.4%) 26470(6.4%) ??? ...-racket/utils/simple-result-arrow.rkt:39:12 bfmul [225] 32.8% bfneg [226] 22.5% ----------------------------------------------------------------------------------------- for-loop [111] 0.9% merge-egraph-nodes! [92] 5.4% for-loop [84] 25.0% loop [199] 28.9% apply-match [73] 39.8% [213] 11178(2.7%) 2482(0.6%) loop! .../ztatlock/herbie/src/core/enode.rkt:163:2 custom-set-union [227] 38.3% loop [199] 33.4% set [228] 11.3% update-en-expr [229] 4.9% ----------------------------------------------------------------------------------------- for-loop [65] 12.0% for-loop [89] 37.5% loop [199] 50.5% [214] 1654(0.4%) 210(0.1%) foldl ...et/collects/racket/private/list.rkt:229:4 merge2 [231] 67.7% ??? [234] 19.6% ----------------------------------------------------------------------------------------- ??? [202] 100.0% [215] 1518(0.4%) 0(0.0%) generic-sort/key .../racket/private/sort.rkt:185:2 copying-mergesort [230] 80.4% loop [240] 19.6% ----------------------------------------------------------------------------------------- arity-checking-wrapper [204] 100.0% [216] 1140(0.3%) 1140(0.3%) matches-arity-exactly? ...te/arrow-common.rkt:70:0 ----------------------------------------------------------------------------------------- loop [199] 11.5% map [180] 18.5% parse-loop12 [189] 70.0% [217] 994(0.2%) 340(0.1%) simplify* ...tlock/herbie/src/core/reduce.rkt:20:0 ??? [235] 22.9% hash-ref! [224] 22.1% ??? [154] 20.7% ----------------------------------------------------------------------------------------- curry* [205] 100.0% [218] 818(0.2%) 818(0.2%) procedure-arity ...ket/private/norm-arity.rkt:7:27 ----------------------------------------------------------------------------------------- loop [199] 25.2% parse-loop12 [189] 26.6% map [180] 48.2% [219] 444(0.1%) 112(0.0%) make-multiplication-node .../core/reduce.rkt:219:0 make-multiplication-subnode [233] 74.8% ----------------------------------------------------------------------------------------- loop [220] 16.4% loop [199] 83.6% [220] 362(0.1%) 362(0.1%) loop ...ket/collects/racket/private/list.rkt:82:16 loop [220] 16.4% ----------------------------------------------------------------------------------------- loop [199] 30.5% map-enodes [58] 69.5% [221] 302(0.1%) 180(0.0%) set-precompute! ...bie/src/core/simplify.rkt:160:0 make-sequence [232] 40.4% ----------------------------------------------------------------------------------------- parse-app [207] 100.0% [222] 242(0.1%) 242(0.1%) loop .../collects/racket/private/stxcase.rkt:112:7 ----------------------------------------------------------------------------------------- for-loop [208] 100.0% [223] 106(0.0%) 106(0.0%) write-proc ...lock/herbie/src/alternative.rkt:22:9 ----------------------------------------------------------------------------------------- simplify* [217] 0.1% update-leader! [103] 0.2% ??? [11] 0.2% first-nonzero-exp [148] 0.2% for-loop [32] 0.4% for-loop [203] 0.6% ??? [44] 0.9% for-loop [43] 1.1% localize-error [60] 1.2% for-loop [27] 1.9% ??? [192] 2.7% compile [93] 4.2% ??? [237] 4.6% loop [132] 4.6% for-loop [25] 4.8% ??? [5] 5.5% eval-prog [171] 19.8% loop [199] 46.6% [224] 52956(12.9%) 5048(1.2%) hash-ref! ...racket/private/more-scheme.rkt:373:13 ??? [5] 52.8% bigfloat-hash [236] 19.5% simplify [144] 5.1% ??? [7] 4.8% ??? [237] 4.6% parse-loop12 [189] 3.1% ??? [8] 2.9% ??? [9] 1.1% f134 [175] 0.7% ??? [10] 0.6% ??? [11] 0.6% ----------------------------------------------------------------------------------------- ??? [212] 100.0% [225] 19438(4.7%) 12394(3.0%) bfmul ...-lib/math/private/bigfloat/mpfr.rkt:819:4 ??? [254] 36.2% ----------------------------------------------------------------------------------------- ??? [212] 100.0% [226] 13302(3.2%) 9226(2.2%) bfneg ...-lib/math/private/bigfloat/mpfr.rkt:616:4 ??? [254] 30.6% ----------------------------------------------------------------------------------------- adopt-enode! [126] 5.1% loop! [213] 94.9% [227] 4950(1.2%) 1772(0.4%) custom-set-union ...et/private/set-types.rkt:168:0 for-loop [239] 48.2% for-loop [241] 16.0% ----------------------------------------------------------------------------------------- new-enode [123] 11.9% loop! [213] 88.1% [228] 2752(0.7%) 2752(0.7%) set ...collects/racket/private/set-types.rkt:981:0 ----------------------------------------------------------------------------------------- update-leader! [103] 7.4% for-loop [108] 9.0% for-loop [110] 9.7% for-loop [156] 31.2% loop! [213] 42.8% [229] 2420(0.6%) 2420(0.6%) update-en-expr ...herbie/src/core/egraph.rkt:211:0 ----------------------------------------------------------------------------------------- generic-sort/key [215] 43.8% copying-mergesort [230] 56.2% [230] 1220(0.3%) 0(0.0%) copying-mergesort ...racket/private/sort.rkt:130:8 copying-mergesort [230] 56.2% loop [240] 30.1% jloop [14] 13.7% ----------------------------------------------------------------------------------------- foldl [214] 100.0% [231] 1120(0.3%) 1120(0.3%) merge2 ...ztatlock/herbie/src/core/ematch.rkt:31:0 ----------------------------------------------------------------------------------------- reduce-to-single! [87] 10.1% ??? [150] 12.4% set-precompute! [221] 12.6% for-loop [67] 64.8% [232] 966(0.2%) 786(0.2%) make-sequence ...ects/racket/private/for.rkt:509:2 ??? [243] 18.6% ----------------------------------------------------------------------------------------- make-multiplication-node [219] 100.0% [233] 332(0.1%) 0(0.0%) make-multiplication-subnode ...re/reduce.rkt:229:0 group-by68 [242] 66.9% for-loop [244] 33.1% ----------------------------------------------------------------------------------------- foldl [214] 100.0% [234] 324(0.1%) 0(0.0%) ??? /home/ztatlock/herbie/src/alternative.rkt:66:9 ??? [100] 100.0% ----------------------------------------------------------------------------------------- simplify* [217] 100.0% [235] 228(0.1%) 118(0.0%) ??? ...racket/collects/racket/private/kw.rkt:762:9 ??? [238] 48.2% ----------------------------------------------------------------------------------------- hash-ref! [224] 100.0% [236] 34534(8.4%) 302(0.1%) bigfloat-hash ...h/private/bigfloat/mpfr.rkt:165:0 bfcanonicalize [245] 74.5% sig+exp->bigfloat [246] 23.2% bigfloat->sig+exp [255] 1.4% ----------------------------------------------------------------------------------------- hash-ref! [224] 100.0% [237] 10238(2.5%) 0(0.0%) ??? ...e/ztatlock/herbie/src/core/taylor.rkt:43:15 hash-ref! [224] 100.0% ----------------------------------------------------------------------------------------- ??? [235] 2.5% ??? [155] 97.5% [238] 4352(1.1%) 3594(0.9%) ??? ...s/racket/contract/private/arr-i.rkt:1233:27 ??? [250] 17.4% ----------------------------------------------------------------------------------------- custom-set-union [227] 100.0% [239] 2388(0.6%) 848(0.2%) for-loop ...cts/racket/private/set-types.rkt:174:3 for-loop [248] 64.5% ----------------------------------------------------------------------------------------- generic-sort/key [215] 25.4% ??? [202] 27.6% copying-mergesort [230] 46.9% [240] 1172(0.3%) 0(0.0%) loop ...ket/collects/racket/private/sort.rkt:97:12 ??? [247] 92.3% errors-score [253] 7.7% ----------------------------------------------------------------------------------------- custom-set-union [227] 100.0% [241] 790(0.2%) 790(0.2%) for-loop ...cts/racket/private/set-types.rkt:152:2 ----------------------------------------------------------------------------------------- make-multiplication-subnode [233] 100.0% [242] 222(0.1%) 104(0.0%) group-by68 ...acket/collects/racket/list.rkt:749:0 hash-update [252] 53.2% ----------------------------------------------------------------------------------------- make-sequence [232] 100.0% [243] 180(0.0%) 0(0.0%) ??? ...acket/collects/racket/private/for.rkt:429:7 custom-in-set [249] 100.0% ----------------------------------------------------------------------------------------- make-multiplication-subnode [233] 100.0% [244] 110(0.0%) 0(0.0%) for-loop ...tlock/herbie/src/core/reduce.rkt:231:3 compose [251] 100.0% ----------------------------------------------------------------------------------------- bigfloat-hash [236] 100.0% [245] 25728(6.3%) 23962(5.8%) bfcanonicalize .../private/bigfloat/mpfr.rkt:155:0 bigfloat->sig+exp [255] 6.9% ----------------------------------------------------------------------------------------- bigfloat-hash [236] 100.0% [246] 8004(1.9%) 6220(1.5%) sig+exp->bigfloat ...ivate/bigfloat/mpfr.rkt:385:0 integer->mpz [256] 19.7% ??? [254] 2.5% ----------------------------------------------------------------------------------------- jloop [14] 38.2% loop [240] 61.8% [247] 1752(0.4%) 214(0.1%) ??? /home/ztatlock/herbie/src/points.rkt:81:27 eval-prog [171] 87.8% ----------------------------------------------------------------------------------------- for-loop [239] 100.0% [248] 1540(0.4%) 1540(0.4%) for-loop ...cts/racket/private/set-types.rkt:178:5 ----------------------------------------------------------------------------------------- ??? [117] 7.7% ??? [243] 12.2% match-e [81] 80.1% [249] 1474(0.4%) 1474(0.4%) custom-in-set ...acket/private/set-types.rkt:577:0 ----------------------------------------------------------------------------------------- ??? [183] 12.7% ??? [238] 87.3% [250] 868(0.2%) 868(0.2%) ??? ...ects/racket/contract/private/prop.rkt:256:4 ----------------------------------------------------------------------------------------- for-loop [244] 16.2% gather-multiplicative-terms [196] 16.2% for-loop [6] 67.6% [251] 678(0.2%) 678(0.2%) compose ...collects/racket/private/list.rkt:385:12 ----------------------------------------------------------------------------------------- group-by68 [242] 100.0% [252] 118(0.0%) 118(0.0%) hash-update ...cket/private/more-scheme.rkt:356:13 ----------------------------------------------------------------------------------------- loop [240] 100.0% [253] 90(0.0%) 90(0.0%) errors-score ...atlock/herbie/src/points.rkt:194:0 ----------------------------------------------------------------------------------------- sig+exp->bigfloat [246] 1.6% ??? [48] 2.7% real->bigfloat [133] 11.1% bfneg [226] 31.0% bfmul [225] 53.6% [254] 13134(3.2%) 13134(3.2%) ??? .../share/racket/collects/ffi/unsafe.rkt:861:4 ----------------------------------------------------------------------------------------- bigfloat-hash [236] 22.1% bfcanonicalize [245] 77.9% [255] 2266(0.6%) 562(0.1%) bigfloat->sig+exp ...ivate/bigfloat/mpfr.rkt:370:0 size+limbs->integer [257] 63.8% new-mpz [258] 11.4% ----------------------------------------------------------------------------------------- sig+exp->bigfloat [246] 100.0% [256] 1580(0.4%) 1580(0.4%) integer->mpz ...math/private/bigfloat/gmp.rkt:87:0 ----------------------------------------------------------------------------------------- bigfloat->sig+exp [255] 100.0% [257] 1446(0.4%) 1446(0.4%) size+limbs->integer ...vate/bigfloat/gmp.rkt:103:0 ----------------------------------------------------------------------------------------- bigfloat->sig+exp [255] 100.0% [258] 258(0.1%) 258(0.1%) new-mpz ...-lib/math/private/bigfloat/gmp.rkt:73:0 -----------------------------------------------------------------------------------------