Profiling results ----------------- Total cpu time observed: 673890ms (out of 675604ms) Number of samples taken: 2029 (once every 332ms) (Hiding functions with self<1.0% and local<2.0%: 12 of 197 hidden) ======================================================================================== Caller Idx Total Self Name+src Local% ms(pct) ms(pct) Callee ======================================================================================== ??? [44] 100.0% [1] 521348(77.4%) 0(0.0%) profile-thunk16 ...t/pkgs/profile-lib/main.rkt:9:0 run [9] 100.0% ---------------------------------------------------------------------------------------- ??? [44] 100.0% [2] 492328(73.1%) 0(0.0%) run-improve50 ...ie/develop/src/mainloop.rkt:234:0 for-loop [10] 99.2% prepare-points [52] 0.3% setup-alt-simplified [14] 0.2% ??? [40] 0.1% get-final-combination [17] 0.1% ---------------------------------------------------------------------------------------- ??? [50] 100.0% [3] 153332(22.8%) 0(0.0%) loop ...herbie/develop/src/core/simplify.rkt:237:2 pass [11] 100.0% ---------------------------------------------------------------------------------------- rewriter [51] 100.0% [4] 29912(4.4%) 1242(0.2%) *rules* ...rbie/develop/src/syntax/rules.rkt:565:0 for-loop [12] 89.5% ormap [22] 6.4% ---------------------------------------------------------------------------------------- for-loop [13] 8.9% rewriter [51] 91.1% [5] 13136(1.9%) 0(0.0%) expression->type ...evelop/src/type-check.rkt:45:0 for-loop [13] 100.0% ---------------------------------------------------------------------------------------- matcher [63] 100.0% [6] 2024(0.3%) 0(0.0%) for-loop ...bie/develop/src/core/matcher.rkt:159:6 pattern-match [15] 50.3% pattern-substitute [16] 49.7% ---------------------------------------------------------------------------------------- loop [131] 100.0% [7] 1910(0.3%) 0(0.0%) ??? ...ket/collects/racket/private/list.rkt:323:18 hash-ref! [81] 98.3% map [35] 1.7% ---------------------------------------------------------------------------------------- parse-loop12 [128] 2.0% loop [8] 98.0% [8] 934(0.1%) 308(0.0%) loop ...cket/collects/racket/private/map.rkt:36:19 loop [8] 98.0% ??? [42] 1.1% ---------------------------------------------------------------------------------------- profile-thunk16 [1] 100.0% [9] 521348(77.4%) 0(0.0%) run ...share/racket/pkgs/profile-lib/main.rkt:39:2 ??? [44] 100.0% ---------------------------------------------------------------------------------------- run-improve50 [2] 100.0% [10] 488626(72.5%) 0(0.0%) for-loop ...herbie/develop/src/mainloop.rkt:249:10 run-iter! [18] 100.0% ---------------------------------------------------------------------------------------- loop [3] 100.0% [11] 153332(22.8%) 344(0.1%) pass ...herbie/develop/src/core/simplify.rkt:227:2 for-loop [19] 99.8% ---------------------------------------------------------------------------------------- merge-egraph-nodes! [86] 4.8% *rules* [4] 95.2% [12] 28130(4.2%) 5514(0.8%) for-loop ...ies/herbie/develop/src/common.rkt:99:9 loop [23] 32.8% ormap [22] 27.9% flag-set? [31] 17.4% curried [142] 1.2% curry* [104] 1.1% ---------------------------------------------------------------------------------------- expression->type [5] 100.0% [13] 13136(1.9%) 0(0.0%) for-loop ...herbie/develop/src/type-check.rkt:52:5 f176 [20] 91.1% expression->type [5] 8.9% ---------------------------------------------------------------------------------------- run-improve50 [2] 100.0% [14] 1020(0.2%) 0(0.0%) setup-alt-simplified .../develop/src/glue.rkt:49:0 simplify-alt [24] 100.0% ---------------------------------------------------------------------------------------- for-loop [25] 34.7% for-loop [6] 65.3% [15] 1018(0.2%) 0(0.0%) pattern-match ...develop/src/core/matcher.rkt:48:0 for-loop [25] 65.3% variable? [21] 17.5% ??? [40] 17.2% ---------------------------------------------------------------------------------------- pattern-substitute [16] 44.4% for-loop [6] 55.6% [16] 1006(0.1%) 336(0.0%) pattern-substitute ...op/src/core/matcher.rkt:73:0 pattern-substitute [16] 44.4% variable? [21] 22.2% ---------------------------------------------------------------------------------------- run-improve50 [2] 100.0% [17] 334(0.0%) 0(0.0%) get-final-combination ...op/src/mainloop.rkt:264:0 extract-alt [26] 100.0% ---------------------------------------------------------------------------------------- for-loop [10] 100.0% [18] 488626(72.5%) 0(0.0%) run-iter! ...herbie/develop/src/mainloop.rkt:215:0 simplify! [27] 78.0% gen-rewrites! [29] 16.0% finalize-iter! [30] 5.6% ---------------------------------------------------------------------------------------- pass [11] 100.0% [19] 152988(22.7%) 346(0.1%) for-loop ...e/develop/src/core/simplify.rkt:230:29 argmin [28] 83.4% loop [32] 12.2% for-loop [33] 3.7% filter [160] 0.2% ---------------------------------------------------------------------------------------- hash-ref! [81] 0.8% eval-prog [76] 1.9% eval-const-expr [150] 5.9% f176 [20] 10.6% for-loop [13] 29.5% rewriter [51] 51.3% [20] 44526(6.6%) 1650(0.2%) f176 .../collects/racket/match/compiler.rkt:507:40 ??? [130] 30.8% ??? [50] 21.5% ??? [40] 14.8% ...velop/src/common.rkt:47:2 [132] 13.7% f176 [20] 10.6% ??? [34] 2.2% ??? [42] 1.8% map [35] 0.8% curried [142] 0.7% ---------------------------------------------------------------------------------------- matcher [63] 3.0% pattern-match [15] 3.2% pattern-substitute [16] 6.0% substitute-e [85] 20.1% match-e [79] 67.8% [21] 11196(1.7%) 320(0.0%) variable? ...e/develop/src/syntax/syntax.rkt:665:0 ??? [40] 97.1% ---------------------------------------------------------------------------------------- *rules* [4] 19.5% for-loop [12] 80.5% [22] 9760(1.4%) 312(0.0%) ormap ...et/collects/racket/private/map.rkt:105:13 flag-set? [31] 90.2% curried [142] 6.6% ---------------------------------------------------------------------------------------- for-loop [12] 100.0% [23] 9222(1.4%) 1278(0.2%) loop ...ket/collects/racket/private/map.rkt:112:23 flag-set? [31] 79.1% curried [142] 3.5% list-member? [90] 3.5% ---------------------------------------------------------------------------------------- setup-alt-simplified [14] 100.0% [24] 1020(0.2%) 0(0.0%) simplify-alt ...s/herbie/develop/src/glue.rkt:76:0 ??? [50] 100.0% ---------------------------------------------------------------------------------------- pattern-match [15] 100.0% [25] 1018(0.2%) 312(0.0%) for-loop ...rbie/develop/src/core/matcher.rkt:66:9 pattern-match [15] 69.4% ---------------------------------------------------------------------------------------- get-final-combination [17] 100.0% [26] 334(0.0%) 0(0.0%) extract-alt ...es/herbie/develop/src/glue.rkt:55:0 argmins [36] 100.0% ---------------------------------------------------------------------------------------- run-iter! [18] 100.0% [27] 381248(56.6%) 0(0.0%) simplify! ...herbie/develop/src/mainloop.rkt:155:0 for-loop [37] 100.0% ---------------------------------------------------------------------------------------- for-loop [19] 100.0% [28] 127664(18.9%) 692(0.1%) argmin ...re/racket/collects/racket/list.rkt:743:0 for-loop [38] 87.1% expression-cost [41] 12.4% ---------------------------------------------------------------------------------------- run-iter! [18] 100.0% [29] 78098(11.6%) 0(0.0%) gen-rewrites! ...ie/develop/src/mainloop.rkt:142:0 for-loop [39] 100.0% ---------------------------------------------------------------------------------------- run-iter! [18] 100.0% [30] 27370(4.1%) 0(0.0%) finalize-iter! ...e/develop/src/mainloop.rkt:169:0 ??? [40] 100.0% ---------------------------------------------------------------------------------------- for-loop [12] 23.3% loop [23] 34.8% ormap [22] 41.9% [31] 20980(3.1%) 8432(1.3%) flag-set? ...es/herbie/develop/src/config.rkt:34:0 ??? [146] 37.8% return/no-unsupplied [147] 22.0% ---------------------------------------------------------------------------------------- for-loop [19] 100.0% [32] 18690(2.8%) 0(0.0%) loop ...hare/racket/collects/racket/list.rkt:729:4 for-loop [38] 91.5% expression-cost [41] 8.5% ---------------------------------------------------------------------------------------- for-loop [19] 100.0% [33] 5622(0.8%) 5622(0.8%) for-loop ...e/develop/src/core/simplify.rkt:217:13 ---------------------------------------------------------------------------------------- f176 [20] 100.0% [34] 996(0.1%) 0(0.0%) ??? ...tract/private/arrow-higher-order.rkt:336:46 ??? [168] 100.0% ---------------------------------------------------------------------------------------- ??? [7] 49.1% f176 [20] 50.9% [35] 656(0.1%) 0(0.0%) map ...acket/collects/racket/private/map.rkt:20:13 loop [131] 50.9% ??? [42] 49.1% ---------------------------------------------------------------------------------------- extract-alt [26] 100.0% [36] 334(0.0%) 0(0.0%) argmins ...ies/herbie/develop/src/common.rkt:152:0 composed [43] 100.0% ---------------------------------------------------------------------------------------- simplify! [27] 100.0% [37] 381248(56.6%) 0(0.0%) for-loop .../herbie/develop/src/mainloop.rkt:159:6 ??? [44] 100.0% ---------------------------------------------------------------------------------------- loop [32] 13.3% argmin [28] 86.7% [38] 128262(19.0%) 5876(0.9%) for-loop .../herbie/develop/src/programs.rkt:210:2 ??? [50] 66.5% ...velop/src/common.rkt:47:2 [132] 26.9% ??? [130] 2.0% ---------------------------------------------------------------------------------------- gen-rewrites! [29] 100.0% [39] 78098(11.6%) 0(0.0%) for-loop ...herbie/develop/src/mainloop.rkt:147:11 ??? [45] 100.0% ---------------------------------------------------------------------------------------- run-improve50 [2] 0.4% pattern-match [15] 0.5% ??? [168] 2.0% substitute-e [85] 3.0% f176 [20] 8.7% match-e [79] 12.7% variable? [21] 14.5% get-sigs [125] 22.0% finalize-iter! [30] 35.7% [40] 75228(11.2%) 17222(2.6%) ??? ...contract/private/arrow-val-first.rkt:357:18 hash-has-key? [46] 38.8% for-loop [47] 34.4% ??? [168] 1.8% atab-add-altns [49] 1.7% ---------------------------------------------------------------------------------------- loop [32] 9.1% argmin [28] 90.9% [41] 17400(2.6%) 0(0.0%) expression-cost .../develop/src/programs.rkt:209:0 compile [48] 100.0% ---------------------------------------------------------------------------------------- ??? [156] 2.8% map [35] 2.8% loop [8] 5.5% for-loop [75] 13.9% loop [131] 28.6% f176 [20] 46.3% [42] 11330(1.7%) 958(0.1%) ??? ...tract/private/arrow-higher-order.rkt:342:33 ??? [50] 74.4% ??? [168] 8.9% ...velop/src/common.rkt:47:2 [132] 8.3% ---------------------------------------------------------------------------------------- argmins [36] 100.0% [43] 334(0.0%) 0(0.0%) composed ...ollects/racket/private/list.rkt:321:16 errors [65] 100.0% ---------------------------------------------------------------------------------------- for-loop [37] 19.4% run [9] 30.1% [44] 655588(97.3%) 0(0.0%) ??? ...lects/racket/private/more-scheme.rkt:261:28 ??? [50] 39.6% profile-thunk16 [1] 30.1% run-improve50 [2] 28.0% prepare-points [52] 2.3% ---------------------------------------------------------------------------------------- for-loop [39] 100.0% [45] 78098(11.6%) 0(0.0%) ??? ...ies/herbie/develop/src/alternative.rkt:88:0 rewriter [51] 99.6% loop [131] 0.4% ---------------------------------------------------------------------------------------- mk-enode! [93] 6.2% ??? [40] 93.8% [46] 31620(4.7%) 7748(1.1%) hash-has-key? ...et/private/more-scheme.rkt:368:13 ??? [56] 73.4% ??? [61] 2.1% ---------------------------------------------------------------------------------------- ??? [40] 100.0% [47] 26414(3.9%) 0(0.0%) for-loop ...ie/develop/src/core/alt-table.rkt:51:2 atab-add-altn [53] 100.0% ---------------------------------------------------------------------------------------- expression-cost [41] 100.0% [48] 17400(2.6%) 636(0.1%) compile ...s/herbie/develop/src/programs.rkt:186:0 hash-ref! [81] 96.3% ---------------------------------------------------------------------------------------- ??? [40] 100.0% [49] 1292(0.2%) 0(0.0%) atab-add-altns ...elop/src/core/alt-table.rkt:50:0 atab-add-altn [53] 100.0% ---------------------------------------------------------------------------------------- simplify-alt [24] 0.1% ??? [42] 1.6% f176 [20] 1.7% get-sigs [125] 2.2% for-loop [38] 5.3% ??? [50] 14.9% for-loop [55] 29.8% ??? [44] 43.9% [50] 540084(80.1%) 40260(6.0%) ??? ...llects/racket/private/norm-define.rkt:53:83 iterate-egraph!13 [54] 32.9% for-loop [55] 29.8% ??? [50] 14.9% loop [3] 11.6% ??? [56] 5.9% ??? [146] 0.8% return/no-unsupplied [147] 0.3% mk-egraph [60] 0.3% ??? [144] 0.1% dict? [175] 0.1% list-member? [90] 0.1% ??? [61] 0.0% ---------------------------------------------------------------------------------------- ??? [45] 13.2% matcher [63] 86.8% [51] 77778(11.5%) 5962(0.9%) rewriter ...bie/develop/src/core/matcher.rkt:131:2 for-loop [57] 87.7% *rules* [4] 5.2% f176 [20] 3.5% expression->type [5] 2.5% ---------------------------------------------------------------------------------------- run-improve50 [2] 5.2% ??? [44] 94.8% [52] 32248(4.8%) 0(0.0%) prepare-points ...bie/develop/src/points.rkt:214:0 loop [66] 36.5% loop [59] 36.0% make-exacts* [67] 27.5% ---------------------------------------------------------------------------------------- atab-add-altns [49] 4.7% for-loop [47] 95.3% [53] 27706(4.1%) 0(0.0%) atab-add-altn ...elop/src/core/alt-table.rkt:208:0 best-and-tied-at-points [58] 100.0% ---------------------------------------------------------------------------------------- ??? [50] 100.0% [54] 366240(54.3%) 310(0.0%) iterate-egraph!13 ...p/src/core/simplify.rkt:105:0 one-iter [62] 97.2% map-enodes [68] 2.7% ---------------------------------------------------------------------------------------- ??? [50] 100.0% [55] 344708(51.2%) 0(0.0%) for-loop ...ie/develop/src/core/simplify.rkt:66:12 ??? [50] 100.0% ---------------------------------------------------------------------------------------- hash-has-key? [46] 22.2% ??? [50] 77.8% [56] 104588(15.5%) 40752(6.0%) ??? ...ects/racket/contract/private/list.rkt:737:4 for-loop [64] 46.5% ??? [74] 13.0% successfully-got-the-right-kind-of-function [70] 0.6% ??? [144] 0.6% arrow-higher-order:lnp [182] 0.3% ---------------------------------------------------------------------------------------- rewriter [51] 100.0% [57] 77778(11.5%) 634(0.1%) for-loop ...ie/develop/src/core/matcher.rkt:134:10 matcher [63] 99.9% ---------------------------------------------------------------------------------------- atab-add-altn [53] 100.0% [58] 27706(4.1%) 0(0.0%) best-and-tied-at-points ...ore/alt-table.rkt:122:0 errors [65] 100.0% ---------------------------------------------------------------------------------------- prepare-points [52] 100.0% [59] 11608(1.7%) 0(0.0%) loop ...htlies/herbie/develop/src/points.rkt:158:2 make-exacts* [67] 52.7% loop [66] 47.3% ---------------------------------------------------------------------------------------- ??? [50] 100.0% [60] 2828(0.4%) 0(0.0%) mk-egraph ...bie/develop/src/core/egraph.rkt:131:0 mk-enode-rec! [69] 89.4% mk-enode! [93] 10.6% ---------------------------------------------------------------------------------------- ??? [50] 33.1% hash-has-key? [46] 66.9% [61] 998(0.1%) 998(0.1%) ??? ...ects/racket/contract/private/hash.rkt:245:7 ---------------------------------------------------------------------------------------- iterate-egraph!13 [54] 100.0% [62] 356112(52.8%) 3242(0.5%) one-iter ...ie/develop/src/core/simplify.rkt:116:0 for-loop [71] 74.6% for-loop [72] 24.4% ---------------------------------------------------------------------------------------- for-loop [73] 25.0% matcher [63] 25.0% for-loop [57] 50.0% [63] 77778(11.5%) 1942(0.3%) matcher ...rbie/develop/src/core/matcher.rkt:167:2 rewriter [51] 49.5% matcher [63] 25.0% for-loop [73] 25.0% for-loop [6] 0.2% variable? [21] 0.0% ---------------------------------------------------------------------------------------- ??? [56] 100.0% [64] 48610(7.2%) 25350(3.8%) for-loop ...acket/contract/private/list.rkt:743:12 ??? [74] 25.4% for-loop [135] 20.5% ??? [151] 1.3% arrow-higher-order:lnp [182] 0.7% ---------------------------------------------------------------------------------------- composed [43] 1.2% best-and-tied-at-points [58] 97.7% [65] 28370(4.2%) 0(0.0%) errors ...lies/herbie/develop/src/points.rkt:271:0 for-loop [75] 73.4% eval-prog [76] 26.6% ---------------------------------------------------------------------------------------- loop [59] 31.8% prepare-points [52] 68.2% [66] 17260(2.6%) 0(0.0%) loop ...htlies/herbie/develop/src/points.rkt:141:4 loop [131] 100.0% ---------------------------------------------------------------------------------------- loop [59] 40.8% prepare-points [52] 59.2% [67] 14988(2.2%) 0(0.0%) make-exacts* ...erbie/develop/src/points.rkt:138:0 loop [131] 77.3% eval-prog [76] 22.7% ---------------------------------------------------------------------------------------- iterate-egraph!13 [54] 100.0% [68] 9818(1.5%) 0(0.0%) map-enodes ...ie/develop/src/core/egraph.rkt:140:0 loop [131] 90.2% for-loop [141] 9.8% ---------------------------------------------------------------------------------------- mk-enode-rec! [69] 38.9% mk-egraph [60] 61.1% [69] 2528(0.4%) 0(0.0%) mk-enode-rec! ...develop/src/core/egraph.rkt:122:0 mk-enode! [93] 61.1% mk-enode-rec! [69] 38.9% ---------------------------------------------------------------------------------------- ??? [56] 100.0% [70] 662(0.1%) 332(0.0%) successfully-got-the-right-kind-of-function ...9:4 arity-checking-wrapper [77] 49.8% ---------------------------------------------------------------------------------------- one-iter [62] 100.0% [71] 265814(39.4%) 314(0.0%) for-loop ...ie/develop/src/core/simplify.rkt:166:2 for-loop [78] 90.5% match-e [79] 9.3% ---------------------------------------------------------------------------------------- for-loop [72] 49.1% one-iter [62] 50.9% [72] 87056(12.9%) 17686(2.6%) for-loop ...e/develop/src/core/simplify.rkt:126:12 for-loop [72] 49.1% match-e [79] 39.7% ??? [114] 0.2% ---------------------------------------------------------------------------------------- matcher [63] 100.0% [73] 77122(11.4%) 324(0.0%) for-loop ...ie/develop/src/core/matcher.rkt:183:21 matcher [63] 99.9% ---------------------------------------------------------------------------------------- for-loop [64] 47.5% ??? [56] 52.5% [74] 25968(3.9%) 13616(2.0%) ??? ...private/unconstrained-domain-arrow.rkt:74:4 make-keyword-procedure [82] 47.6% ---------------------------------------------------------------------------------------- errors [65] 100.0% [75] 20822(3.1%) 314(0.0%) for-loop ...es/herbie/develop/src/points.rkt:274:4 ??? [80] 90.9% ??? [42] 7.5% ---------------------------------------------------------------------------------------- make-exacts* [67] 31.1% errors [65] 68.9% [76] 10952(1.6%) 640(0.1%) eval-prog ...herbie/develop/src/programs.rkt:150:0 f176 [20] 51.0% hash-ref! [81] 37.2% parse-lambda [83] 3.2% ??? [165] 2.8% ---------------------------------------------------------------------------------------- successfully-got-the-right-kind-of-function [70]100.0% [77] 330(0.0%) 0(0.0%) arity-checking-wrapper ...w-higher-order.rkt:402:0 matches-arity-exactly? [84] 100.0% ---------------------------------------------------------------------------------------- for-loop [71] 100.0% [78] 240502(35.7%) 1960(0.3%) for-loop ...e/develop/src/core/simplify.rkt:148:10 mk-enode! [93] 34.7% substitute-e [85] 28.2% merge-egraph-nodes! [86] 21.8% loop! [110] 11.0% list-member? [90] 3.6% ---------------------------------------------------------------------------------------- for-loop [71] 16.0% for-loop [94] 24.0% for-loop [72] 60.0% [79] 93752(13.9%) 36364(5.4%) match-e ...herbie/develop/src/core/ematch.rkt:46:0 for-loop [87] 42.2% for-loop [94] 10.2% ??? [40] 5.7% variable? [21] 3.4% loop [131] 3.1% list-cartesian-product [96] 2.2% ---------------------------------------------------------------------------------------- for-loop [75] 42.5% loop [131] 57.5% [80] 44536(6.6%) 326(0.0%) ??? ...tlies/herbie/develop/src/programs.rkt:156:4 ??? [88] 99.3% ---------------------------------------------------------------------------------------- eval-prog [76] 6.6% ??? [7] 7.1% loop [131] 11.4% compile [48] 31.4% ??? [89] 42.3% [81] 22748(3.4%) 15774(2.3%) hash-ref! ...racket/private/more-scheme.rkt:373:13 ??? [89] 57.3% parse-loop12 [128] 7.9% bigfloat-hash [91] 5.9% ??? [92] 0.4% f176 [20] 0.2% ---------------------------------------------------------------------------------------- ??? [74] 100.0% [82] 12352(1.8%) 12352(1.8%) make-keyword-procedure ...ket/private/kw.rkt:260:4 ---------------------------------------------------------------------------------------- eval-prog [76] 100.0% [83] 346(0.1%) 346(0.1%) parse-lambda ...llects/racket/private/kw.rkt:437:2 ---------------------------------------------------------------------------------------- arity-checking-wrapper [77] 100.0% [84] 330(0.0%) 330(0.0%) matches-arity-exactly? ...te/arrow-common.rkt:70:0 ---------------------------------------------------------------------------------------- substitute-e [85] 5.3% for-loop [78] 94.7% [85] 67714(10.0%) 2922(0.4%) substitute-e ...e/develop/src/core/ematch.rkt:71:0 mk-enode! [93] 89.0% substitute-e [85] 5.3% ??? [40] 1.3% variable? [21] 1.2% ---------------------------------------------------------------------------------------- for-loop [97] 4.4% merge-egraph-nodes! [86] 5.5% for-loop [78] 90.1% [86] 52380(7.8%) 1272(0.2%) merge-egraph-nodes! ...p/src/core/egraph.rkt:153:0 update-leader! [95] 58.0% for-loop [100] 8.0% enode-merge! [101] 7.6% for-loop [97] 7.6% loop! [110] 7.0% merge-egraph-nodes! [86] 5.5% for-loop [12] 2.6% ---------------------------------------------------------------------------------------- match-e [79] 100.0% [87] 50800(7.5%) 15458(2.3%) for-loop ...rbie/develop/src/core/ematch.rkt:59:11 for-loop [94] 53.0% list-cartesian-product [96] 10.1% loop [131] 4.5% curry* [104] 3.3% filter [160] 1.3% curried [142] 0.7% foldl [143] 0.3% ---------------------------------------------------------------------------------------- ??? [80] 100.0% [88] 44210(6.6%) 22342(3.3%) ??? ...acket/collects/racket/private/kw.rkt:444:14 ??? [140] 21.0% bf* [99] 10.9% ??? [102] 9.0% ??? [106] 3.6% parse-loop12 [128] 3.5% ??? [169] 1.5% ---------------------------------------------------------------------------------------- hash-ref! [81] 100.0% [89] 18242(2.7%) 1660(0.2%) ??? ...tlies/herbie/develop/src/programs.rkt:194:5 hash-ref! [81] 77.0% loop [131] 18.6% ---------------------------------------------------------------------------------------- ??? [50] 3.4% loop [23] 3.5% for-loop [78] 93.1% [90] 9262(1.4%) 958(0.1%) list-member? ...llects/racket/private/set.rkt:24:0 loop [98] 68.6% member [105] 21.0% ---------------------------------------------------------------------------------------- hash-ref! [81] 100.0% [91] 3404(0.5%) 0(0.0%) bigfloat-hash ...h/private/bigfloat/mpfr.rkt:165:0 bfcanonicalize [103] 90.1% sig+exp->bigfloat [107] 9.9% ---------------------------------------------------------------------------------------- hash-ref! [81] 100.0% [92] 320(0.0%) 0(0.0%) ??? .../herbie/develop/src/core/localize.rkt:22:13 repeat [108] 100.0% ---------------------------------------------------------------------------------------- mk-egraph [60] 0.2% mk-enode-rec! [69] 1.7% substitute-e [85] 41.1% for-loop [78] 56.9% [93] 146520(21.7%) 13592(2.0%) mk-enode! ...bie/develop/src/core/egraph.rkt:102:0 new-enode [109] 89.2% hash-has-key? [46] 1.3% mutable-set [123] 0.2% ---------------------------------------------------------------------------------------- match-e [79] 35.3% for-loop [87] 64.7% [94] 45106(6.7%) 4630(0.7%) for-loop ...rbie/develop/src/core/ematch.rkt:65:37 match-e [79] 90.2% ??? [114] 2.1% ---------------------------------------------------------------------------------------- merge-egraph-nodes! [86] 100.0% [95] 34000(5.0%) 4914(0.7%) update-leader! ...evelop/src/core/egraph.rkt:218:0 for-loop [111] 78.9% custom-set-union! [116] 2.7% mutable-set [123] 2.0% update-en-expr [149] 1.9% ---------------------------------------------------------------------------------------- match-e [79] 20.8% list-cartesian-product [96] 36.0% for-loop [87] 43.1% [96] 9670(1.4%) 8690(1.3%) list-cartesian-product ...src/core/ematch.rkt:20:0 list-cartesian-product [96] 36.0% for-loop [115] 5.1% ---------------------------------------------------------------------------------------- merge-egraph-nodes! [86] 100.0% [97] 6468(1.0%) 0(0.0%) for-loop ...bie/develop/src/core/egraph.rkt:201:10 merge-egraph-nodes! [86] 74.6% loop! [110] 25.4% ---------------------------------------------------------------------------------------- list-member? [90] 100.0% [98] 6358(0.9%) 6358(0.9%) loop (unknown source) ---------------------------------------------------------------------------------------- ??? [88] 100.0% [99] 4798(0.7%) 0(0.0%) bf* ...ath/private/bigfloat/bigfloat-mpfr.rkt:95:0 ??? [140] 100.0% ---------------------------------------------------------------------------------------- merge-egraph-nodes! [86] 100.0% [100] 4176(0.6%) 3834(0.6%) for-loop ...rbie/develop/src/core/egraph.rkt:233:6 update-en-expr [149] 8.2% ---------------------------------------------------------------------------------------- merge-egraph-nodes! [86] 100.0% [101] 4144(0.6%) 0(0.0%) enode-merge! ...e/develop/src/core/enode.rkt:129:0 adopt-enode! [112] 85.1% custom-set-intersect! [117] 14.9% ---------------------------------------------------------------------------------------- ??? [88] 100.0% [102] 3986(0.6%) 2670(0.4%) ??? ...herbie/develop/src/syntax/syntax.rkt:156:17 ??? [146] 25.0% return/no-unsupplied [147] 8.0% ---------------------------------------------------------------------------------------- bigfloat-hash [91] 100.0% [103] 3066(0.5%) 3066(0.5%) bfcanonicalize .../private/bigfloat/mpfr.rkt:155:0 ---------------------------------------------------------------------------------------- for-loop [12] 15.9% for-loop [87] 84.1% [104] 2006(0.3%) 634(0.1%) curry* ...racket/collects/racket/function.rkt:44:2 procedure-arity [113] 68.4% ---------------------------------------------------------------------------------------- list-member? [90] 100.0% [105] 1946(0.3%) 1946(0.3%) member (unknown source) ---------------------------------------------------------------------------------------- ??? [88] 100.0% [106] 1582(0.2%) 1582(0.2%) ??? ...rivate/unconstrained-domain-arrow.rkt:40:13 ---------------------------------------------------------------------------------------- bigfloat-hash [91] 100.0% [107] 338(0.1%) 338(0.1%) sig+exp->bigfloat ...ivate/bigfloat/mpfr.rkt:385:0 ---------------------------------------------------------------------------------------- ??? [92] 100.0% [108] 320(0.0%) 0(0.0%) repeat ...erbie/develop/src/core/localize.rkt:13:0 for-loop [118] 100.0% ---------------------------------------------------------------------------------------- mk-enode! [93] 100.0% [109] 130650(19.4%) 1280(0.2%) new-enode ...erbie/develop/src/core/enode.rkt:97:0 type-of-enode-expr [119] 97.7% mutable-set [123] 0.5% set [122] 0.5% ---------------------------------------------------------------------------------------- for-loop [97] 4.5% merge-egraph-nodes! [86] 10.4% loop [131] 29.8% for-loop [78] 55.4% [110] 33164(4.9%) 8080(1.2%) loop! ...s/herbie/develop/src/core/enode.rkt:192:2 custom-set-union [121] 35.2% loop [131] 33.7% set [122] 10.8% update-en-expr [149] 6.3% ---------------------------------------------------------------------------------------- update-leader! [95] 100.0% [111] 26820(4.0%) 1626(0.2%) for-loop ...rbie/develop/src/core/egraph.rkt:223:6 for-loop [120] 93.9% ---------------------------------------------------------------------------------------- enode-merge! [101] 100.0% [112] 3528(0.5%) 1624(0.2%) adopt-enode! ...e/develop/src/core/enode.rkt:105:0 custom-set-union [121] 54.0% ---------------------------------------------------------------------------------------- curry* [104] 100.0% [113] 1372(0.2%) 1372(0.2%) procedure-arity ...ket/private/norm-arity.rkt:7:27 ---------------------------------------------------------------------------------------- for-loop [72] 24.8% for-loop [94] 75.2% [114] 1256(0.2%) 612(0.1%) ??? ...ies/herbie/develop/src/core/ematch.rkt:50:5 for-loop [124] 51.3% ---------------------------------------------------------------------------------------- list-cartesian-product [96] 100.0% [115] 980(0.1%) 980(0.1%) for-loop ...erbie/develop/src/core/ematch.rkt:24:8 ---------------------------------------------------------------------------------------- update-leader! [95] 100.0% [116] 934(0.1%) 934(0.1%) custom-set-union! ...t/private/set-types.rkt:245:0 ---------------------------------------------------------------------------------------- enode-merge! [101] 100.0% [117] 616(0.1%) 616(0.1%) custom-set-intersect! ...ivate/set-types.rkt:269:0 ---------------------------------------------------------------------------------------- repeat [108] 100.0% [118] 320(0.0%) 320(0.0%) for-loop ...bie/develop/src/core/localize.rkt:14:2 ---------------------------------------------------------------------------------------- new-enode [109] 100.0% [119] 127686(18.9%) 1286(0.2%) type-of-enode-expr ...elop/src/core/enode.rkt:68:0 get-sigs [125] 98.7% parse-loop12 [128] 0.3% ---------------------------------------------------------------------------------------- for-loop [111] 100.0% [120] 25194(3.7%) 332(0.0%) for-loop ...rbie/develop/src/core/egraph.rkt:224:8 hash-update! [126] 98.7% ---------------------------------------------------------------------------------------- adopt-enode! [112] 12.7% loop! [110] 87.3% [121] 15008(2.2%) 4602(0.7%) custom-set-union ...et/private/set-types.rkt:168:0 for-loop [127] 49.9% for-loop [129] 19.4% ---------------------------------------------------------------------------------------- new-enode [109] 8.4% loop! [110] 91.6% [122] 7480(1.1%) 7480(1.1%) set ...collects/racket/private/set-types.rkt:981:0 ---------------------------------------------------------------------------------------- mk-enode! [93] 18.4% new-enode [109] 40.8% update-leader! [95] 40.8% [123] 1700(0.3%) 1700(0.3%) mutable-set .../racket/private/set-types.rkt:999:0 ---------------------------------------------------------------------------------------- ??? [114] 100.0% [124] 644(0.1%) 644(0.1%) for-loop ...erbie/develop/src/core/ematch.rkt:51:7 ---------------------------------------------------------------------------------------- type-of-enode-expr [119] 100.0% [125] 126064(18.7%) 3870(0.6%) get-sigs .../herbie/develop/src/type-check.rkt:5:0 ??? [130] 43.7% ??? [50] 27.6% ??? [40] 13.1% ...velop/src/common.rkt:47:2 [132] 12.5% ---------------------------------------------------------------------------------------- for-loop [120] 100.0% [126] 24862(3.7%) 640(0.1%) hash-update! ...ket/private/more-scheme.rkt:362:13 ??? [133] 97.4% ---------------------------------------------------------------------------------------- custom-set-union [121] 100.0% [127] 7496(1.1%) 2598(0.4%) for-loop ...cts/racket/private/set-types.rkt:174:3 for-loop [134] 65.3% ---------------------------------------------------------------------------------------- type-of-enode-expr [119] 8.9% ??? [88] 40.8% hash-ref! [81] 50.3% [128] 3794(0.6%) 1884(0.3%) parse-loop12 ...s/racket/match/compiler.rkt:418:15 loop [131] 46.5% loop [8] 3.8% ---------------------------------------------------------------------------------------- custom-set-union [121] 100.0% [129] 2910(0.4%) 2910(0.4%) for-loop ...cts/racket/private/set-types.rkt:152:2 ---------------------------------------------------------------------------------------- for-loop [38] 3.7% f176 [20] 19.2% get-sigs [125] 77.1% [130] 71458(10.6%) 4516(0.7%) ??? ...ts/racket/contract/private/arr-i.rkt:804:10 ??? [136] 49.4% for-loop [135] 37.7% get/build-late-neg-projection [174] 6.1% ??? [151] 0.4% ---------------------------------------------------------------------------------------- map [35] 0.0% loop [66] 0.1% make-exacts* [67] 0.1% ??? [45] 0.2% map-enodes [68] 1.1% for-loop [87] 1.7% parse-loop12 [128] 2.0% match-e [79] 4.1% ??? [89] 4.9% loop! [110] 8.9% loop [131] 77.0% [131] 69340(10.3%) 4212(0.6%) loop ...cket/collects/racket/private/map.rkt:25:19 loop [131] 77.0% loop! [110] 8.4% hash-ref! [81] 4.9% ??? [7] 2.0% foldl [143] 1.3% for-loop [141] 1.1% ??? [80] 0.2% curried [142] 0.1% ??? [140] 0.0% ??? [42] 0.0% ---------------------------------------------------------------------------------------- ??? [42] 1.6% f176 [20] 10.7% get-sigs [125] 27.4% for-loop [38] 60.3% [132] 57276(8.5%) 17668(2.6%) ...velop/src/common.rkt:47:2 ...e/arr-i.rkt:906:19 ??? [138] 35.9% ??? [139] 32.6% ---------------------------------------------------------------------------------------- hash-update! [126] 100.0% [133] 24222(3.6%) 334(0.0%) ??? ...s/herbie/develop/src/core/egraph.rkt:226:24 for-loop [137] 97.3% ---------------------------------------------------------------------------------------- for-loop [127] 100.0% [134] 4898(0.7%) 4898(0.7%) for-loop ...cts/racket/private/set-types.rkt:178:5 ---------------------------------------------------------------------------------------- for-loop [64] 26.9% ??? [130] 73.1% [135] 36908(5.5%) 7666(1.1%) for-loop ...racket/contract/private/hash.rkt:239:6 ??? [144] 76.5% ??? [169] 2.7% ---------------------------------------------------------------------------------------- ??? [130] 100.0% [136] 35328(5.2%) 1944(0.3%) ??? ...ects/racket/contract/private/hash.rkt:217:4 ??? [145] 94.5% ---------------------------------------------------------------------------------------- ??? [133] 100.0% [137] 23556(3.5%) 20932(3.1%) for-loop ...bie/develop/src/core/egraph.rkt:227:26 update-en-expr [149] 11.1% ---------------------------------------------------------------------------------------- for-loop [161] 3.3% ??? [144] 10.2% ...velop/src/common.rkt:47:2 [132] 86.5% [138] 20584(3.1%) 4246(0.6%) ??? ...ects/racket/contract/private/list.rkt:342:4 ??? [144] 65.6% ??? [151] 12.9% ??? [168] 7.2% ---------------------------------------------------------------------------------------- ...velop/src/common.rkt:47:2 [132] 100.0% [139] 18678(2.8%) 4806(0.7%) ??? ...s/racket/contract/private/arr-i.rkt:1268:39 ??? [146] 30.8% return/no-unsupplied [147] 26.1% assoc-ref [152] 17.4% ---------------------------------------------------------------------------------------- loop [131] 2.3% bf* [99] 33.3% ??? [88] 64.4% [140] 14404(2.1%) 3798(0.6%) ??? ...-racket/utils/simple-result-arrow.rkt:39:12 bfexpt [148] 73.6% ---------------------------------------------------------------------------------------- map-enodes [68] 9.8% loop [131] 90.2% [141] 9818(1.5%) 3212(0.5%) for-loop ...ie/develop/src/core/simplify.rkt:195:2 eval-const-expr [150] 39.8% setfindf [153] 20.6% compose [155] 6.9% ---------------------------------------------------------------------------------------- f176 [20] 13.4% loop [23] 14.0% for-loop [87] 14.4% for-loop [12] 14.5% loop [131] 15.6% ormap [22] 28.1% [142] 2310(0.3%) 2310(0.3%) curried ...cket/collects/racket/function.rkt:71:18 ---------------------------------------------------------------------------------------- for-loop [87] 14.9% loop [131] 85.1% [143] 2236(0.3%) 954(0.1%) foldl ...et/collects/racket/private/list.rkt:229:4 merge2 [154] 43.0% ??? [156] 14.3% ---------------------------------------------------------------------------------------- ??? [56] 1.4% ??? [50] 2.8% ??? [138] 35.0% for-loop [135] 60.8% [144] 46438(6.9%) 11616(1.7%) ??? ...cts/racket/contract/private/list.rkt:187:10 ??? [158] 56.8% ??? [138] 9.0% for-loop [161] 7.8% ??? [169] 1.4% ---------------------------------------------------------------------------------------- ??? [136] 100.0% [145] 33384(5.0%) 1600(0.2%) ??? ...ects/racket/contract/private/list.rkt:169:2 ??? [157] 95.2% ---------------------------------------------------------------------------------------- ??? [102] 4.7% ??? [139] 26.9% ??? [50] 31.2% flag-set? [31] 37.2% [146] 21328(3.2%) 7766(1.2%) ??? ...racket/collects/racket/private/kw.rkt:761:9 ??? [159] 54.5% ??? [168] 9.1% ---------------------------------------------------------------------------------------- ??? [102] 2.5% ??? [50] 23.0% flag-set? [31] 36.3% ??? [139] 38.2% [147] 12738(1.9%) 7920(1.2%) return/no-unsupplied ...ct/private/arr-i.rkt:533:0 filter [160] 37.8% ---------------------------------------------------------------------------------------- ??? [140] 100.0% [148] 10606(1.6%) 7504(1.1%) bfexpt ...lib/math/private/bigfloat/mpfr.rkt:819:4 ??? [162] 29.2% ---------------------------------------------------------------------------------------- for-loop [100] 4.6% update-leader! [95] 8.6% for-loop [137] 35.2% loop! [110] 51.6% [149] 7448(1.1%) 7448(1.1%) update-en-expr ...evelop/src/core/egraph.rkt:212:0 ---------------------------------------------------------------------------------------- for-loop [141] 100.0% [150] 3910(0.6%) 312(0.0%) eval-const-expr .../develop/src/programs.rkt:168:0 f176 [20] 67.4% ??? [165] 16.6% ??? [166] 8.0% ---------------------------------------------------------------------------------------- ??? [130] 8.4% for-loop [64] 17.6% ??? [138] 73.9% [151] 3600(0.5%) 1034(0.2%) ??? ...ects/racket/contract/private/hash.rkt:222:6 check-hash/c [163] 71.3% ---------------------------------------------------------------------------------------- ??? [139] 100.0% [152] 3258(0.5%) 3258(0.5%) assoc-ref ...collects/racket/private/dict.rkt:56:0 ---------------------------------------------------------------------------------------- for-loop [141] 100.0% [153] 2020(0.3%) 978(0.1%) setfindf ...es/herbie/develop/src/common.rkt:186:0 for-loop [164] 51.6% ---------------------------------------------------------------------------------------- foldl [143] 100.0% [154] 962(0.1%) 962(0.1%) merge2 .../herbie/develop/src/core/ematch.rkt:31:0 ---------------------------------------------------------------------------------------- for-loop [141] 100.0% [155] 676(0.1%) 676(0.1%) compose ...collects/racket/private/list.rkt:385:12 ---------------------------------------------------------------------------------------- foldl [143] 100.0% [156] 320(0.0%) 0(0.0%) ??? ...ies/herbie/develop/src/alternative.rkt:66:9 ??? [42] 100.0% ---------------------------------------------------------------------------------------- ??? [145] 100.0% [157] 31784(4.7%) 1356(0.2%) ??? ...ects/racket/contract/private/list.rkt:678:5 for-loop [167] 95.7% ---------------------------------------------------------------------------------------- ??? [144] 100.0% [158] 26358(3.9%) 2526(0.4%) ??? ...ects/racket/contract/private/list.rkt:686:7 ??? [168] 83.0% ??? [169] 7.4% ---------------------------------------------------------------------------------------- ??? [146] 100.0% [159] 11630(1.7%) 11302(1.7%) ??? ...s/racket/contract/private/arr-i.rkt:1233:27 ??? [172] 2.8% ---------------------------------------------------------------------------------------- for-loop [19] 5.3% for-loop [87] 11.7% return/no-unsupplied [147] 83.0% [160] 5808(0.9%) 5808(0.9%) filter ...t/collects/racket/private/list.rkt:256:2 ---------------------------------------------------------------------------------------- ??? [144] 100.0% [161] 3636(0.5%) 2272(0.3%) for-loop ...acket/contract/private/list.rkt:190:15 ??? [138] 37.5% ---------------------------------------------------------------------------------------- bfexpt [148] 100.0% [162] 3102(0.5%) 3102(0.5%) ??? .../share/racket/collects/ffi/unsafe.rkt:861:4 ---------------------------------------------------------------------------------------- ??? [151] 100.0% [163] 2566(0.4%) 1932(0.3%) check-hash/c ...ket/contract/private/hash.rkt:83:0 flat-contract? [171] 24.7% ---------------------------------------------------------------------------------------- setfindf [153] 100.0% [164] 1042(0.2%) 1042(0.2%) for-loop ...es/herbie/develop/src/common.rkt:187:2 ---------------------------------------------------------------------------------------- eval-prog [76] 32.3% eval-const-expr [150] 67.7% [165] 960(0.1%) 0(0.0%) ??? ...cket/collects/racket/private/kw.rkt:1633:36 unpack245 [170] 100.0% ---------------------------------------------------------------------------------------- eval-const-expr [150] 100.0% [166] 312(0.0%) 312(0.0%) ??? ...cket/collects/racket/private/kw.rkt:1635:39 ---------------------------------------------------------------------------------------- ??? [157] 100.0% [167] 30428(4.5%) 7240(1.1%) for-loop ...racket/contract/private/list.rkt:680:9 add-list-context [173] 51.7% get/build-late-neg-projection [174] 24.5% ---------------------------------------------------------------------------------------- ??? [34] 3.3% ??? [42] 3.3% ??? [40] 4.4% ??? [146] 6.4% ??? [138] 9.8% ??? [158] 72.7% [168] 30102(4.5%) 24496(3.6%) ??? ...ects/racket/contract/private/guts.rkt:644:8 contract? [177] 7.7% ??? [40] 6.7% dict? [175] 4.3% ---------------------------------------------------------------------------------------- ??? [144] 14.9% ??? [88] 16.0% for-loop [135] 23.3% ??? [158] 45.7% [169] 4256(0.6%) 1936(0.3%) ??? ...ects/racket/contract/private/prop.rkt:493:4 ??? [176] 54.5% ---------------------------------------------------------------------------------------- ??? [165] 100.0% [170] 960(0.1%) 648(0.1%) unpack245 ...private/arrow-higher-order.rkt:354:44 maybe-cons-kwd [178] 32.5% ---------------------------------------------------------------------------------------- check-hash/c [163] 100.0% [171] 634(0.1%) 634(0.1%) flat-contract? .../contract/private/guts.rkt:111:0 ---------------------------------------------------------------------------------------- ??? [159] 100.0% [172] 328(0.0%) 328(0.0%) ??? ...ects/racket/contract/private/prop.rkt:256:4 ---------------------------------------------------------------------------------------- for-loop [167] 100.0% [173] 15746(2.3%) 15746(2.3%) add-list-context ...ontract/private/list.rkt:752:0 ---------------------------------------------------------------------------------------- ??? [180] 11.3% ??? [130] 25.6% for-loop [167] 63.1% [174] 11788(1.7%) 2918(0.4%) get/build-late-neg-projection ...te/guts.rkt:691:0 ??? [179] 65.3% ??? [180] 11.3% ---------------------------------------------------------------------------------------- ??? [50] 44.3% ??? [168] 55.7% [175] 2324(0.3%) 2324(0.3%) dict? ...ollects/racket/private/generic.rkt:146:11 ---------------------------------------------------------------------------------------- ??? [169] 100.0% [176] 2320(0.3%) 682(0.1%) ??? ...lects/racket/contract/private/orc.rkt:83:14 ??? [181] 70.6% ---------------------------------------------------------------------------------------- ??? [168] 100.0% [177] 2310(0.3%) 2310(0.3%) contract? ...acket/contract/private/guts.rkt:109:0 ---------------------------------------------------------------------------------------- unpack245 [170] 100.0% [178] 312(0.0%) 0(0.0%) maybe-cons-kwd ...ate/arrow-higher-order.rkt:498:0 arrow-higher-order:lnp [182] 100.0% ---------------------------------------------------------------------------------------- get/build-late-neg-projection [174] 100.0% [179] 8870(1.3%) 958(0.1%) ??? ...cts/racket/contract/private/prop.rkt:314:12 build-compound-type-name [183] 89.2% ---------------------------------------------------------------------------------------- get/build-late-neg-projection [174] 100.0% [180] 2662(0.4%) 0(0.0%) ??? ...ects/racket/contract/private/hash.rkt:211:2 get/build-late-neg-projection [174] 100.0% ---------------------------------------------------------------------------------------- ??? [176] 100.0% [181] 1638(0.2%) 1638(0.2%) ??? ...ects/racket/contract/private/list.rkt:141:5 ---------------------------------------------------------------------------------------- ??? [56] 31.0% maybe-cons-kwd [178] 32.7% for-loop [64] 36.3% [182] 954(0.1%) 346(0.1%) arrow-higher-order:lnp ...w-higher-order.rkt:597:7 ??? [184] 63.7% ---------------------------------------------------------------------------------------- contract-struct-name [185] 12.7% ??? [179] 87.3% [183] 7912(1.2%) 4008(0.6%) build-compound-type-name ...private/guts.rkt:448:0 contract-struct-name [185] 57.9% ---------------------------------------------------------------------------------------- arrow-higher-order:lnp [182] 100.0% [184] 608(0.1%) 608(0.1%) ??? ...et/contract/private/arity-checking.rkt:19:2 ---------------------------------------------------------------------------------------- build-compound-type-name [183] 100.0% [185] 5252(0.8%) 3904(0.6%) contract-struct-name ...ract/private/prop.rkt:89:0 build-compound-type-name [183] 32.0% ----------------------------------------------------------------------------------------