Profiling results ----------------- Total cpu time observed: 1314230ms (out of 1321592ms) Number of samples taken: 3880 (once every 339ms) (Hiding functions with self<1.0% and local<2.0%: 25 of 298 hidden) ============================================================================================ Caller Idx Total Self Name+src Local% ms(pct) ms(pct) Callee ============================================================================================ ??? [75] 100.0% [1] 1192262(90.7%) 0(0.0%) profile-thunk16 ...t/pkgs/profile-lib/main.rkt:9:0 run [18] 100.0% -------------------------------------------------------------------------------------------- ??? [75] 100.0% [2] 1159344(88.2%) 0(0.0%) run-improve50 ...ie/develop/src/mainloop.rkt:234:0 for-loop [19] 52.7% get-final-combination [21] 47.0% prepare-points [148] 0.1% loop [147] 0.1% setup-alt-simplified [35] 0.1% ??? [173] 0.0% -------------------------------------------------------------------------------------------- ??? [206] 100.0% [3] 599720(45.6%) 0(0.0%) iterate-egraph!13 ...p/src/core/simplify.rkt:105:0 one-iter [20] 98.6% map-enodes [28] 1.4% -------------------------------------------------------------------------------------------- ??? [206] 100.0% [4] 50428(3.8%) 0(0.0%) loop ...herbie/develop/src/core/simplify.rkt:237:2 pass [22] 100.0% -------------------------------------------------------------------------------------------- ??? [201] 100.0% [5] 39382(3.0%) 0(0.0%) approximate9 ...e/develop/src/core/taylor.rkt:12:0 loop [23] 97.5% f176 [51] 1.6% -------------------------------------------------------------------------------------------- hash-ref! [203] 100.0% [6] 34434(2.6%) 0(0.0%) ??? ...es/herbie/develop/src/core/taylor.rkt:44:15 ??? [42] 91.2% hash-ref! [203] 7.9% simplify [41] 1.0% -------------------------------------------------------------------------------------------- hash-ref! [203] 100.0% [7] 31104(2.4%) 0(0.0%) ??? ...s/herbie/develop/src/core/taylor.rkt:295:23 for-loop [24] 100.0% -------------------------------------------------------------------------------------------- hash-ref! [203] 100.0% [8] 30784(2.3%) 0(0.0%) ??? ...s/herbie/develop/src/core/taylor.rkt:285:26 for-loop [25] 100.0% -------------------------------------------------------------------------------------------- hash-ref! [203] 100.0% [9] 24806(1.9%) 0(0.0%) ??? ...s/herbie/develop/src/core/taylor.rkt:322:33 for-loop [26] 100.0% -------------------------------------------------------------------------------------------- hash-ref! [203] 100.0% [10] 22684(1.7%) 0(0.0%) ??? ...es/herbie/develop/src/core/taylor.rkt:67:15 ??? [201] 92.0% hash-ref! [203] 8.0% -------------------------------------------------------------------------------------------- hash-ref! [203] 100.0% [11] 16546(1.3%) 0(0.0%) ??? ...s/herbie/develop/src/core/taylor.rkt:392:23 for-loop [27] 100.0% -------------------------------------------------------------------------------------------- map-enodes [28] 3.8% loop [213] 96.2% [12] 8264(0.6%) 1892(0.1%) for-loop ...ie/develop/src/core/simplify.rkt:195:2 setfindf [29] 56.7% compose [124] 8.2% eval-const-expr [34] 8.0% curried [234] 4.2% -------------------------------------------------------------------------------------------- hash-ref! [203] 100.0% [13] 4396(0.3%) 0(0.0%) ??? ...s/herbie/develop/src/core/taylor.rkt:338:33 hash-ref! [203] 80.6% for-loop [32] 19.4% -------------------------------------------------------------------------------------------- f176 [51] 100.0% [14] 2328(0.2%) 0(0.0%) taylor-invert ...develop/src/core/taylor.rkt:312:0 first-nonzero-exp [31] 57.0% simplify [41] 43.0% -------------------------------------------------------------------------------------------- rewriter [105] 100.0% [15] 1994(0.2%) 0(0.0%) *rules* ...rbie/develop/src/syntax/rules.rkt:565:0 for-loop [30] 100.0% -------------------------------------------------------------------------------------------- copying-mergesort [134] 100.0% [16] 1740(0.1%) 0(0.0%) jloop ...t/collects/racket/private/sort.rkt:121:23 ??? [168] 60.5% ??? [201] 39.5% -------------------------------------------------------------------------------------------- hash-ref! [203] 100.0% [17] 968(0.1%) 0(0.0%) ??? ...s/herbie/develop/src/core/taylor.rkt:483:23 for-loop [33] 100.0% -------------------------------------------------------------------------------------------- profile-thunk16 [1] 100.0% [18] 1192262(90.7%) 0(0.0%) run ...share/racket/pkgs/profile-lib/main.rkt:39:2 ??? [75] 100.0% -------------------------------------------------------------------------------------------- run-improve50 [2] 100.0% [19] 611522(46.5%) 0(0.0%) for-loop ...herbie/develop/src/mainloop.rkt:249:10 run-iter! [36] 100.0% -------------------------------------------------------------------------------------------- iterate-egraph!13 [3] 100.0% [20] 591098(45.0%) 4448(0.3%) one-iter ...ie/develop/src/core/simplify.rkt:116:0 for-loop [38] 73.7% for-loop [39] 25.4% -------------------------------------------------------------------------------------------- run-improve50 [2] 100.0% [21] 544568(41.4%) 0(0.0%) get-final-combination ...op/src/mainloop.rkt:264:0 split-table [37] 99.9% extract-alt [50] 0.1% -------------------------------------------------------------------------------------------- loop [4] 100.0% [22] 50428(3.8%) 334(0.0%) pass ...herbie/develop/src/core/simplify.rkt:227:2 for-loop [40] 99.3% -------------------------------------------------------------------------------------------- approximate9 [5] 100.0% [23] 38414(2.9%) 0(0.0%) loop ...es/herbie/develop/src/core/taylor.rkt:86:4 hash-ref! [203] 59.1% ??? [201] 40.1% make-prod [48] 0.8% -------------------------------------------------------------------------------------------- ??? [7] 100.0% [24] 31104(2.4%) 652(0.0%) for-loop ...bie/develop/src/core/taylor.rkt:298:27 hash-ref! [203] 96.6% simplify [41] 2.0% -------------------------------------------------------------------------------------------- ??? [8] 100.0% [25] 30784(2.3%) 0(0.0%) for-loop ...bie/develop/src/core/taylor.rkt:285:52 ??? [42] 67.9% hash-ref! [203] 30.8% simplify [41] 1.2% -------------------------------------------------------------------------------------------- ??? [9] 100.0% [26] 24806(1.9%) 344(0.0%) for-loop ...bie/develop/src/core/taylor.rkt:324:46 hash-ref! [203] 98.6% -------------------------------------------------------------------------------------------- ??? [11] 100.0% [27] 16546(1.3%) 0(0.0%) for-loop ...bie/develop/src/core/taylor.rkt:396:33 for-loop [43] 100.0% -------------------------------------------------------------------------------------------- iterate-egraph!13 [3] 100.0% [28] 8622(0.7%) 0(0.0%) map-enodes ...ie/develop/src/core/egraph.rkt:140:0 loop [213] 92.2% curried [234] 4.2% for-loop [12] 3.6% -------------------------------------------------------------------------------------------- for-loop [12] 100.0% [29] 4688(0.4%) 3006(0.2%) setfindf ...es/herbie/develop/src/common.rkt:186:0 for-loop [45] 20.6% ??? [173] 15.2% -------------------------------------------------------------------------------------------- *simplify-rules* [228] 11.9% merge-egraph-nodes! [64] 21.3% *rules* [15] 66.8% [30] 2986(0.2%) 636(0.0%) for-loop ...ies/herbie/develop/src/common.rkt:99:9 loop [44] 57.3% flag-set? [61] 10.7% ormap [49] 10.6% -------------------------------------------------------------------------------------------- taylor-invert [14] 100.0% [31] 1326(0.1%) 0(0.0%) first-nonzero-exp ...lop/src/core/taylor.rkt:260:0 hash-ref! [203] 100.0% -------------------------------------------------------------------------------------------- ??? [13] 100.0% [32] 1024(0.1%) 0(0.0%) for-loop ...bie/develop/src/core/taylor.rkt:341:46 hash-ref! [203] 100.0% -------------------------------------------------------------------------------------------- ??? [17] 100.0% [33] 968(0.1%) 0(0.0%) for-loop ...bie/develop/src/core/taylor.rkt:487:35 parse-loop145 [209] 100.0% -------------------------------------------------------------------------------------------- for-loop [12] 100.0% [34] 660(0.1%) 0(0.0%) eval-const-expr .../develop/src/programs.rkt:168:0 keyword-procedure-extract/method [47] 54.5% f176 [51] 45.5% -------------------------------------------------------------------------------------------- run-improve50 [2] 100.0% [35] 644(0.0%) 0(0.0%) setup-alt-simplified .../develop/src/glue.rkt:49:0 simplify-alt [46] 100.0% -------------------------------------------------------------------------------------------- for-loop [19] 100.0% [36] 611522(46.5%) 0(0.0%) run-iter! ...herbie/develop/src/mainloop.rkt:215:0 simplify! [52] 89.4% gen-series! [55] 6.4% finalize-iter! [57] 3.5% gen-rewrites! [60] 0.4% -------------------------------------------------------------------------------------------- get-final-combination [21] 100.0% [37] 544270(41.4%) 0(0.0%) split-table ...s/herbie/develop/src/glue.rkt:162:0 f176 [51] 99.9% ??? [173] 0.1% -------------------------------------------------------------------------------------------- one-iter [20] 100.0% [38] 435558(33.1%) 2226(0.2%) for-loop ...ie/develop/src/core/simplify.rkt:166:2 for-loop [53] 85.4% match-e [54] 9.8% update-leader! [79] 4.2% -------------------------------------------------------------------------------------------- for-loop [39] 49.1% one-iter [20] 50.9% [39] 150082(11.4%) 31248(2.4%) for-loop ...e/develop/src/core/simplify.rkt:126:12 for-loop [39] 49.1% match-e [54] 39.4% ??? [102] 0.2% -------------------------------------------------------------------------------------------- pass [22] 100.0% [40] 50094(3.8%) 706(0.1%) for-loop ...e/develop/src/core/simplify.rkt:230:29 argmin [56] 71.6% loop [58] 21.6% for-loop [59] 5.4% -------------------------------------------------------------------------------------------- loop [213] 0.9% ??? [6] 0.9% for-loop [25] 1.6% for-loop [24] 1.7% taylor-invert [14] 2.7% hash-ref! [203] 91.4% [41] 37420(2.8%) 0(0.0%) simplify ...erbie/develop/src/core/reduce.rkt:16:0 f176 [51] 69.2% parse-loop145 [209] 21.3% debug-print [170] 4.4% simplify* [89] 1.7% debug7 [171] 1.7% simplify-node [221] 1.6% -------------------------------------------------------------------------------------------- ??? [6] 35.2% for-loop [25] 64.8% [42] 31402(2.4%) 0(0.0%) ??? ...s/herbie/develop/src/core/taylor.rkt:288:19 hash-ref! [203] 100.0% -------------------------------------------------------------------------------------------- for-loop [27] 100.0% [43] 16546(1.3%) 0(0.0%) for-loop ...bie/develop/src/core/taylor.rkt:398:39 hash-ref! [203] 100.0% -------------------------------------------------------------------------------------------- for-loop [30] 100.0% [44] 1712(0.1%) 0(0.0%) loop ...ket/collects/racket/private/map.rkt:112:23 flag-set? [61] 79.2% curried [234] 20.8% -------------------------------------------------------------------------------------------- setfindf [29] 100.0% [45] 968(0.1%) 968(0.1%) for-loop ...es/herbie/develop/src/common.rkt:187:2 -------------------------------------------------------------------------------------------- setup-alt-simplified [35] 100.0% [46] 644(0.0%) 0(0.0%) simplify-alt ...s/herbie/develop/src/glue.rkt:76:0 ??? [206] 100.0% -------------------------------------------------------------------------------------------- eval-const-expr [34] 100.0% [47] 360(0.0%) 360(0.0%) keyword-procedure-extract/method .../kw.rkt:1325:2 -------------------------------------------------------------------------------------------- make-prod [48] 50.0% loop [23] 50.0% [48] 326(0.0%) 326(0.0%) make-prod ...bie/develop/src/core/taylor.rkt:112:0 make-prod [48] 50.0% -------------------------------------------------------------------------------------------- for-loop [30] 100.0% [49] 318(0.0%) 318(0.0%) ormap ...et/collects/racket/private/map.rkt:105:13 -------------------------------------------------------------------------------------------- get-final-combination [21] 100.0% [50] 298(0.0%) 0(0.0%) extract-alt ...es/herbie/develop/src/glue.rkt:55:0 loop [211] 100.0% -------------------------------------------------------------------------------------------- for-loop [227] 0.0% approximate9 [5] 0.0% composed [220] 0.0% hash-ref! [203] 0.0% eval-const-expr [34] 0.1% simplify-node [221] 0.1% append-map [73] 0.1% loop [213] 0.1% for-loop [155] 0.2% parse-loop145 [209] 0.4% eval-prog [167] 0.6% f176 [51] 1.4% map [69] 1.8% simplify [41] 1.9% split-table [37] 93.3% [51] 575382(43.8%) 5856(0.4%) f176 .../collects/racket/match/compiler.rkt:507:40 loop [213] 84.0% option-on-expr [63] 9.3% map [69] 3.7% f176 [51] 1.4% ??? [201] 0.5% append-map [73] 0.1% ??? [206] 0.1% ??? [173] 0.1% composed [220] 0.1% parse-loop145 [209] 0.1% ...velop/src/common.rkt:47:2 [140] 0.1% loop [74] 0.0% taylor-invert [14] 0.0% ??? [139] 0.0% -------------------------------------------------------------------------------------------- run-iter! [36] 100.0% [52] 546576(41.6%) 0(0.0%) simplify! ...herbie/develop/src/mainloop.rkt:155:0 for-loop [62] 100.0% -------------------------------------------------------------------------------------------- for-loop [38] 100.0% [53] 372146(28.3%) 1952(0.1%) for-loop ...e/develop/src/core/simplify.rkt:148:10 merge-egraph-nodes! [64] 28.6% mk-enode! [77] 27.0% loop! [98] 20.6% substitute-e [66] 17.3% list-member? [70] 5.9% -------------------------------------------------------------------------------------------- for-loop [38] 16.9% for-loop [78] 24.0% for-loop [39] 59.1% [54] 161036(12.3%) 53660(4.1%) match-e ...herbie/develop/src/core/ematch.rkt:46:0 for-loop [65] 49.2% for-loop [78] 8.2% ??? [173] 6.3% variable? [151] 3.9% list-cartesian-product [83] 2.1% loop [213] 0.7% custom-in-set [166] 0.5% curry* [94] 0.2% -------------------------------------------------------------------------------------------- run-iter! [36] 100.0% [55] 39382(3.0%) 0(0.0%) gen-series! ...rbie/develop/src/mainloop.rkt:129:0 for-loop [68] 100.0% -------------------------------------------------------------------------------------------- for-loop [40] 100.0% [56] 35854(2.7%) 322(0.0%) argmin ...re/racket/collects/racket/list.rkt:743:0 for-loop [67] 90.9% expression-cost [71] 8.3% -------------------------------------------------------------------------------------------- run-iter! [36] 100.0% [57] 21216(1.6%) 0(0.0%) finalize-iter! ...e/develop/src/mainloop.rkt:169:0 ??? [173] 100.0% -------------------------------------------------------------------------------------------- for-loop [40] 100.0% [58] 10822(0.8%) 0(0.0%) loop ...hare/racket/collects/racket/list.rkt:729:4 for-loop [67] 96.9% expression-cost [71] 3.1% -------------------------------------------------------------------------------------------- for-loop [40] 100.0% [59] 2712(0.2%) 2712(0.2%) for-loop ...e/develop/src/core/simplify.rkt:217:13 -------------------------------------------------------------------------------------------- run-iter! [36] 100.0% [60] 2660(0.2%) 0(0.0%) gen-rewrites! ...ie/develop/src/mainloop.rkt:142:0 for-loop [72] 100.0% -------------------------------------------------------------------------------------------- for-loop [30] 19.1% loop [44] 80.9% [61] 1676(0.1%) 672(0.1%) flag-set? ...es/herbie/develop/src/config.rkt:34:0 return/no-unsupplied [217] 38.5% ??? [218] 21.4% -------------------------------------------------------------------------------------------- simplify! [52] 100.0% [62] 546576(41.6%) 0(0.0%) for-loop .../herbie/develop/src/mainloop.rkt:159:6 ??? [75] 100.0% -------------------------------------------------------------------------------------------- f176 [51] 10.0% loop [213] 90.0% [63] 543938(41.4%) 0(0.0%) option-on-expr ...evelop/src/core/regimes.rkt:83:0 sindices->spoints [76] 95.3% err-lsts->split-indices [85] 1.6% loop [213] 1.4% sort-context-on-expr [86] 1.2% errors [198] 0.4% pick-errors [93] 0.2% -------------------------------------------------------------------------------------------- for-loop [84] 3.0% merge-egraph-nodes! [64] 3.1% for-loop [53] 94.0% [64] 106456(8.1%) 3366(0.3%) merge-egraph-nodes! ...p/src/core/egraph.rkt:153:0 update-leader! [79] 49.0% loop! [98] 17.2% for-loop [82] 14.9% for-loop [84] 6.9% enode-merge! [87] 4.5% merge-egraph-nodes! [64] 3.1% make-sequence [154] 0.6% for-loop [30] 0.6% -------------------------------------------------------------------------------------------- match-e [54] 100.0% [65] 99968(7.6%) 31678(2.4%) for-loop ...rbie/develop/src/core/ematch.rkt:59:11 for-loop [78] 55.6% list-cartesian-product [83] 9.0% loop [213] 4.0% curried [234] 0.6% filter [236] 0.6% curry* [94] 0.6% foldl [238] 0.4% -------------------------------------------------------------------------------------------- substitute-e [66] 6.2% for-loop [53] 93.8% [66] 64386(4.9%) 2668(0.2%) substitute-e ...e/develop/src/core/ematch.rkt:71:0 mk-enode! [77] 88.6% substitute-e [66] 6.2% ??? [173] 1.7% variable? [151] 1.0% -------------------------------------------------------------------------------------------- loop [58] 24.4% argmin [56] 75.6% [67] 43062(3.3%) 2034(0.2%) for-loop .../herbie/develop/src/programs.rkt:210:2 ??? [206] 65.4% ...velop/src/common.rkt:47:2 [140] 27.6% ??? [139] 2.3% -------------------------------------------------------------------------------------------- gen-series! [55] 100.0% [68] 39382(3.0%) 0(0.0%) for-loop .../herbie/develop/src/mainloop.rkt:135:7 taylor-alt [80] 100.0% -------------------------------------------------------------------------------------------- parse-loop145 [209] 4.0% f176 [51] 95.6% [69] 25694(2.0%) 0(0.0%) map ...acket/collects/racket/private/map.rkt:20:13 f176 [51] 52.5% parse-loop145 [209] 35.3% make-multiplication-node [91] 4.4% simplify* [89] 2.7% simplify-node [221] 1.7% loop [213] 1.3% ??? [239] 1.1% -------------------------------------------------------------------------------------------- for-loop [53] 100.0% [70] 22132(1.7%) 0(0.0%) list-member? ...llects/racket/private/set.rkt:24:0 loop [81] 78.7% member [88] 21.3% -------------------------------------------------------------------------------------------- loop [58] 10.1% argmin [56] 89.9% [71] 3292(0.3%) 0(0.0%) expression-cost .../develop/src/programs.rkt:209:0 compile [90] 100.0% -------------------------------------------------------------------------------------------- gen-rewrites! [60] 100.0% [72] 2660(0.2%) 0(0.0%) for-loop ...herbie/develop/src/mainloop.rkt:147:11 ??? [92] 100.0% -------------------------------------------------------------------------------------------- simplify-node [221] 25.3% f176 [51] 74.7% [73] 2604(0.2%) 0(0.0%) append-map ...acket/collects/racket/list.rkt:565:2 f176 [51] 43.9% parse-loop145 [209] 28.3% free-variables [146] 25.7% loop [95] 2.1% -------------------------------------------------------------------------------------------- f176 [51] 100.0% [74] 1262(0.1%) 0(0.0%) loop ...es/herbie/develop/src/core/reduce.rkt:18:2 expression->type [145] 100.0% -------------------------------------------------------------------------------------------- for-loop [62] 14.0% run [18] 38.9% [75] 1298876(98.8%) 0(0.0%) ??? ...lects/racket/private/more-scheme.rkt:261:28 profile-thunk16 [1] 38.9% run-improve50 [2] 37.8% ??? [206] 21.9% prepare-points [148] 0.9% loop [147] 0.6% -------------------------------------------------------------------------------------------- option-on-expr [63] 100.0% [76] 518362(39.4%) 0(0.0%) sindices->spoints ...op/src/core/regimes.rkt:136:0 loop [96] 100.0% -------------------------------------------------------------------------------------------- mk-enode-rec! [237] 1.0% substitute-e [66] 35.9% for-loop [53] 63.1% [77] 159072(12.1%) 13402(1.0%) mk-enode! ...bie/develop/src/core/egraph.rkt:102:0 new-enode [97] 89.9% hash-has-key? [180] 1.6% -------------------------------------------------------------------------------------------- match-e [54] 26.0% for-loop [65] 74.0% [78] 80184(6.1%) 6954(0.5%) for-loop ...rbie/develop/src/core/ematch.rkt:65:37 match-e [54] 85.9% ??? [102] 6.2% -------------------------------------------------------------------------------------------- for-loop [38] 25.2% merge-egraph-nodes! [64] 74.8% [79] 72854(5.5%) 4706(0.4%) update-leader! ...evelop/src/core/egraph.rkt:218:0 for-loop [99] 88.9% custom-set-union! [107] 1.9% make-sequence [154] 1.4% hash-ref! [203] 0.9% update-en-expr [157] 0.5% -------------------------------------------------------------------------------------------- for-loop [68] 100.0% [80] 39382(3.0%) 0(0.0%) taylor-alt ...es/herbie/develop/src/glue.rkt:134:0 for-loop [100] 100.0% -------------------------------------------------------------------------------------------- list-member? [70] 100.0% [81] 17428(1.3%) 17428(1.3%) loop (unknown source) -------------------------------------------------------------------------------------------- merge-egraph-nodes! [64] 100.0% [82] 15876(1.2%) 13584(1.0%) for-loop ...rbie/develop/src/core/egraph.rkt:233:6 update-en-expr [157] 14.4% -------------------------------------------------------------------------------------------- match-e [54] 21.7% list-cartesian-product [83] 27.4% for-loop [65] 50.9% [83] 15828(1.2%) 13502(1.0%) list-cartesian-product ...src/core/ematch.rkt:20:0 list-cartesian-product [83] 27.4% for-loop [106] 10.4% -------------------------------------------------------------------------------------------- merge-egraph-nodes! [64] 100.0% [84] 10656(0.8%) 0(0.0%) for-loop ...bie/develop/src/core/egraph.rkt:201:10 merge-egraph-nodes! [64] 60.2% loop! [98] 39.8% -------------------------------------------------------------------------------------------- option-on-expr [63] 100.0% [85] 8446(0.6%) 0(0.0%) err-lsts->split-indices .../core/regimes.rkt:239:0 add-splitpoint [119] 96.4% loop [113] 3.6% -------------------------------------------------------------------------------------------- option-on-expr [63] 100.0% [86] 6438(0.5%) 0(0.0%) sort-context-on-expr ...velop/src/points.rkt:115:0 ??? [101] 100.0% -------------------------------------------------------------------------------------------- merge-egraph-nodes! [64] 100.0% [87] 4792(0.4%) 1008(0.1%) enode-merge! ...e/develop/src/core/enode.rkt:129:0 adopt-enode! [103] 71.9% custom-set-intersect! [111] 7.1% -------------------------------------------------------------------------------------------- list-member? [70] 100.0% [88] 4704(0.4%) 4704(0.4%) member (unknown source) -------------------------------------------------------------------------------------------- parse-loop145 [209] 10.7% simplify [41] 19.5% map [69] 69.8% [89] 3358(0.3%) 992(0.1%) simplify* ...rbie/develop/src/core/reduce.rkt:31:0 return/no-unsupplied [217] 31.3% hash-ref! [203] 28.5% ??? [110] 10.7% -------------------------------------------------------------------------------------------- expression-cost [71] 100.0% [90] 3292(0.3%) 334(0.0%) compile ...s/herbie/develop/src/programs.rkt:186:0 hash-ref! [203] 89.9% -------------------------------------------------------------------------------------------- for-loop [227] 10.4% parse-loop145 [209] 20.3% map [69] 69.3% [91] 2968(0.2%) 0(0.0%) make-multiplication-node .../core/reduce.rkt:230:0 make-multiplication-subnode [104] 100.0% -------------------------------------------------------------------------------------------- for-loop [72] 100.0% [92] 2660(0.2%) 0(0.0%) ??? ...ies/herbie/develop/src/alternative.rkt:88:0 rewriter [105] 100.0% -------------------------------------------------------------------------------------------- option-on-expr [63] 100.0% [93] 1296(0.1%) 0(0.0%) pick-errors .../develop/src/core/regimes.rkt:201:0 for-loop [108] 75.6% point->alt [112] 24.4% -------------------------------------------------------------------------------------------- match-e [54] 35.2% for-loop [65] 64.8% [94] 976(0.1%) 0(0.0%) curry* ...racket/collects/racket/function.rkt:44:2 procedure-arity [109] 100.0% -------------------------------------------------------------------------------------------- append-map [73] 100.0% [95] 324(0.0%) 324(0.0%) loop ...are/racket/collects/racket/list.rkt:414:34 -------------------------------------------------------------------------------------------- parse-loop145 [209] 0.0% loop [96] 21.0% sindices->spoints [76] 79.0% [96] 518698(39.5%) 0(0.0%) loop ...cket/collects/racket/private/map.rkt:36:19 sidx->spoint [114] 79.0% loop [96] 21.0% ulp-difference [202] 0.0% -------------------------------------------------------------------------------------------- mk-enode! [77] 100.0% [97] 143064(10.9%) 310(0.0%) new-enode ...erbie/develop/src/core/enode.rkt:97:0 type-of-enode-expr [115] 98.6% set [118] 0.5% -------------------------------------------------------------------------------------------- for-loop [84] 3.3% merge-egraph-nodes! [64] 16.2% loop [213] 25.8% for-loop [53] 54.7% [98] 103454(7.9%) 13264(1.0%) loop! ...s/herbie/develop/src/core/enode.rkt:192:2 custom-set-union [117] 44.7% loop [213] 30.4% set [118] 11.2% update-en-expr [157] 6.7% -------------------------------------------------------------------------------------------- update-leader! [79] 100.0% [99] 64772(4.9%) 2364(0.2%) for-loop ...rbie/develop/src/core/egraph.rkt:223:6 for-loop [116] 95.9% update-en-expr [157] 0.5% -------------------------------------------------------------------------------------------- taylor-alt [80] 100.0% [100] 39382(3.0%) 0(0.0%) for-loop ...lies/herbie/develop/src/glue.rkt:139:6 ??? [201] 100.0% -------------------------------------------------------------------------------------------- sort-context-on-expr [86] 100.0% [101] 6438(0.5%) 0(0.0%) ??? ...cket/collects/racket/private/sort.rkt:403:3 generic-sort/key [120] 74.3% loop [143] 25.7% -------------------------------------------------------------------------------------------- for-loop [39] 10.8% for-loop [78] 89.2% [102] 5972(0.5%) 2680(0.2%) ??? ...ies/herbie/develop/src/core/ematch.rkt:50:5 for-loop [121] 55.1% -------------------------------------------------------------------------------------------- enode-merge! [87] 100.0% [103] 3444(0.3%) 1214(0.1%) adopt-enode! ...e/develop/src/core/enode.rkt:105:0 custom-set-union [117] 64.8% -------------------------------------------------------------------------------------------- make-multiplication-node [91] 100.0% [104] 2968(0.2%) 994(0.1%) make-multiplication-subnode ...re/reduce.rkt:240:0 for-loop [123] 43.4% compose [124] 12.1% group-by68 [127] 11.0% -------------------------------------------------------------------------------------------- ??? [92] 29.3% matcher [135] 70.7% [105] 2660(0.2%) 0(0.0%) rewriter ...bie/develop/src/core/matcher.rkt:131:2 for-loop [122] 70.7% *rules* [15] 16.8% expression->type [145] 12.5% -------------------------------------------------------------------------------------------- list-cartesian-product [83] 100.0% [106] 2326(0.2%) 2326(0.2%) for-loop ...erbie/develop/src/core/ematch.rkt:24:8 -------------------------------------------------------------------------------------------- update-leader! [79] 100.0% [107] 1360(0.1%) 634(0.0%) custom-set-union! ...t/private/set-types.rkt:245:0 for-loop [126] 53.4% -------------------------------------------------------------------------------------------- pick-errors [93] 100.0% [108] 980(0.1%) 0(0.0%) for-loop ...bie/develop/src/core/regimes.rkt:203:2 ??? [125] 100.0% -------------------------------------------------------------------------------------------- curry* [94] 100.0% [109] 976(0.1%) 976(0.1%) procedure-arity ...ket/private/norm-arity.rkt:7:27 -------------------------------------------------------------------------------------------- simplify* [89] 100.0% [110] 360(0.0%) 0(0.0%) ??? ...racket/collects/racket/private/kw.rkt:762:9 ??? [269] 100.0% -------------------------------------------------------------------------------------------- enode-merge! [87] 100.0% [111] 340(0.0%) 340(0.0%) custom-set-intersect! ...ivate/set-types.rkt:269:0 -------------------------------------------------------------------------------------------- pick-errors [93] 100.0% [112] 316(0.0%) 0(0.0%) point->alt ...e/develop/src/core/regimes.rkt:188:0 eval-prog [167] 100.0% -------------------------------------------------------------------------------------------- err-lsts->split-indices [85] 100.0% [113] 304(0.0%) 0(0.0%) loop .../herbie/develop/src/core/regimes.rkt:290:4 add-splitpoint [119] 100.0% -------------------------------------------------------------------------------------------- loop [96] 100.0% [114] 518362(39.4%) 0(0.0%) sidx->spoint ...develop/src/core/regimes.rkt:146:2 binary-search-floats [128] 65.0% pred [137] 35.0% -------------------------------------------------------------------------------------------- new-enode [97] 100.0% [115] 141114(10.7%) 1982(0.2%) type-of-enode-expr ...elop/src/core/enode.rkt:68:0 get-sigs [129] 98.6% -------------------------------------------------------------------------------------------- for-loop [99] 100.0% [116] 62084(4.7%) 704(0.1%) for-loop ...rbie/develop/src/core/egraph.rkt:224:8 hash-update! [130] 98.9% -------------------------------------------------------------------------------------------- adopt-enode! [103] 4.3% loop! [98] 95.7% [117] 51436(3.9%) 15046(1.1%) custom-set-union ...et/private/set-types.rkt:168:0 for-loop [131] 59.9% for-loop [133] 10.8% -------------------------------------------------------------------------------------------- new-enode [97] 2.9% loop! [98] 97.1% [118] 23182(1.8%) 23182(1.8%) set ...collects/racket/private/set-types.rkt:981:0 -------------------------------------------------------------------------------------------- loop [113] 3.6% err-lsts->split-indices [85] 96.4% [119] 8446(0.6%) 0(0.0%) add-splitpoint ...velop/src/core/regimes.rkt:253:2 for-loop [132] 100.0% -------------------------------------------------------------------------------------------- ??? [101] 100.0% [120] 4784(0.4%) 0(0.0%) generic-sort/key .../racket/private/sort.rkt:185:2 copying-mergesort [134] 86.3% loop [143] 13.7% -------------------------------------------------------------------------------------------- ??? [102] 100.0% [121] 3292(0.3%) 2624(0.2%) for-loop ...erbie/develop/src/core/ematch.rkt:51:7 ??? [173] 20.3% -------------------------------------------------------------------------------------------- rewriter [105] 100.0% [122] 2660(0.2%) 0(0.0%) for-loop ...ie/develop/src/core/matcher.rkt:134:10 matcher [135] 100.0% -------------------------------------------------------------------------------------------- make-multiplication-subnode [104] 100.0% [123] 1288(0.1%) 352(0.0%) for-loop ...rbie/develop/src/core/reduce.rkt:242:3 mterm->expr [136] 72.7% -------------------------------------------------------------------------------------------- make-multiplication-subnode [104] 34.7% for-loop [12] 65.3% [124] 1036(0.1%) 1036(0.1%) compose ...collects/racket/private/list.rkt:385:12 -------------------------------------------------------------------------------------------- for-loop [108] 100.0% [125] 980(0.1%) 0(0.0%) ??? ...s/herbie/develop/src/core/regimes.rkt:194:2 ??? [168] 100.0% -------------------------------------------------------------------------------------------- custom-set-union! [107] 100.0% [126] 726(0.1%) 726(0.1%) for-loop ...cts/racket/private/set-types.rkt:253:4 -------------------------------------------------------------------------------------------- make-multiplication-subnode [104] 100.0% [127] 326(0.0%) 326(0.0%) group-by68 ...acket/collects/racket/list.rkt:749:0 -------------------------------------------------------------------------------------------- sidx->spoint [114] 100.0% [128] 336810(25.6%) 0(0.0%) binary-search-floats ...src/core/regimes.rkt:125:0 pred [137] 100.0% -------------------------------------------------------------------------------------------- type-of-enode-expr [115] 100.0% [129] 139132(10.6%) 3918(0.3%) get-sigs .../herbie/develop/src/type-check.rkt:5:0 ??? [139] 38.8% ??? [206] 30.8% ??? [173] 16.4% ...velop/src/common.rkt:47:2 [140] 11.2% -------------------------------------------------------------------------------------------- for-loop [116] 100.0% [130] 61380(4.7%) 986(0.1%) hash-update! ...ket/private/more-scheme.rkt:362:13 ??? [138] 98.4% -------------------------------------------------------------------------------------------- custom-set-union [117] 100.0% [131] 30820(2.3%) 10500(0.8%) for-loop ...cts/racket/private/set-types.rkt:174:3 for-loop [141] 65.9% -------------------------------------------------------------------------------------------- add-splitpoint [119] 100.0% [132] 8446(0.6%) 1650(0.1%) for-loop ...bie/develop/src/core/regimes.rkt:255:4 for-loop [142] 80.5% -------------------------------------------------------------------------------------------- custom-set-union [117] 100.0% [133] 5570(0.4%) 5570(0.4%) for-loop ...cts/racket/private/set-types.rkt:152:2 -------------------------------------------------------------------------------------------- copying-mergesort [134] 46.3% generic-sort/key [120] 53.7% [134] 4130(0.3%) 0(0.0%) copying-mergesort ...racket/private/sort.rkt:130:8 copying-mergesort [134] 46.3% loop [143] 43.2% jloop [16] 10.5% -------------------------------------------------------------------------------------------- for-loop [144] 23.4% matcher [135] 26.6% for-loop [122] 50.0% [135] 2660(0.2%) 0(0.0%) matcher ...rbie/develop/src/core/matcher.rkt:167:2 rewriter [105] 50.0% matcher [135] 26.6% for-loop [144] 23.4% -------------------------------------------------------------------------------------------- for-loop [123] 100.0% [136] 936(0.1%) 0(0.0%) mterm->expr ...e/develop/src/core/reduce.rkt:270:0 free-variables [146] 68.4% expression->type [145] 31.6% -------------------------------------------------------------------------------------------- sidx->spoint [114] 35.0% binary-search-floats [128] 65.0% [137] 518362(39.4%) 0(0.0%) pred ...herbie/develop/src/core/regimes.rkt:151:17 loop [147] 63.8% prepare-points [148] 34.0% errors [198] 2.2% -------------------------------------------------------------------------------------------- hash-update! [130] 100.0% [138] 60394(4.6%) 670(0.1%) ??? ...s/herbie/develop/src/core/egraph.rkt:226:24 for-loop [149] 97.8% make-sequence [154] 1.1% -------------------------------------------------------------------------------------------- f176 [51] 1.1% for-loop [67] 1.7% ??? [201] 1.8% get-sigs [129] 94.8% [139] 56988(4.3%) 3526(0.3%) ??? ...ts/racket/contract/private/arr-i.rkt:804:10 ??? [150] 48.3% for-loop [246] 37.3% get/build-late-neg-projection [175] 6.5% ??? [251] 1.1% -------------------------------------------------------------------------------------------- f176 [51] 1.0% ??? [201] 4.6% for-loop [67] 40.9% get-sigs [129] 53.5% [140] 29086(2.2%) 6518(0.5%) ...velop/src/common.rkt:47:2 ...e/arr-i.rkt:906:19 ??? [152] 39.3% ??? [153] 37.1% -------------------------------------------------------------------------------------------- for-loop [131] 100.0% [141] 20320(1.5%) 20320(1.5%) for-loop ...cts/racket/private/set-types.rkt:178:5 -------------------------------------------------------------------------------------------- for-loop [132] 100.0% [142] 6796(0.5%) 6116(0.5%) for-loop ...bie/develop/src/core/regimes.rkt:259:8 curried [234] 10.0% -------------------------------------------------------------------------------------------- generic-sort/key [120] 13.9% ??? [101] 35.2% copying-mergesort [134] 50.9% [143] 4698(0.4%) 0(0.0%) loop ...ket/collects/racket/private/sort.rkt:97:12 ??? [168] 100.0% -------------------------------------------------------------------------------------------- matcher [135] 100.0% [144] 2316(0.2%) 0(0.0%) for-loop ...ie/develop/src/core/matcher.rkt:183:21 matcher [135] 100.0% -------------------------------------------------------------------------------------------- mterm->expr [136] 13.3% loop [74] 18.9% rewriter [105] 22.7% for-loop [155] 45.1% [145] 2224(0.2%) 0(0.0%) expression->type ...evelop/src/type-check.rkt:45:0 for-loop [155] 86.7% variable? [151] 13.3% -------------------------------------------------------------------------------------------- composed [220] 20.9% mterm->expr [136] 38.6% append-map [73] 40.5% [146] 1656(0.1%) 346(0.0%) free-variables ...e/develop/src/programs.rkt:102:0 ??? [173] 59.7% variable? [151] 19.4% -------------------------------------------------------------------------------------------- run-improve50 [2] 0.3% ??? [75] 4.2% pred [137] 95.6% [147] 345984(26.3%) 362(0.0%) loop ...htlies/herbie/develop/src/points.rkt:238:2 make-exacts* [162] 95.4% loop [158] 2.2% loop [164] 1.7% ??? [165] 0.4% debug-print [170] 0.1% for-loop [160] 0.1% -------------------------------------------------------------------------------------------- run-improve50 [2] 0.7% ??? [75] 11.5% pred [137] 87.9% [148] 200862(15.3%) 0(0.0%) prepare-points ...bie/develop/src/points.rkt:214:0 make-exacts* [162] 88.1% loop [164] 6.9% loop [158] 3.7% for-loop [160] 0.8% debug7 [171] 0.2% ??? [165] 0.2% debug-print [170] 0.2% -------------------------------------------------------------------------------------------- ??? [138] 100.0% [149] 59064(4.5%) 53074(4.0%) for-loop ...bie/develop/src/core/egraph.rkt:227:26 update-en-expr [157] 10.1% -------------------------------------------------------------------------------------------- ??? [139] 100.0% [150] 27548(2.1%) 2686(0.2%) ??? ...ects/racket/contract/private/hash.rkt:217:4 ??? [156] 90.2% -------------------------------------------------------------------------------------------- expression->type [145] 1.7% free-variables [146] 1.8% substitute-e [66] 9.5% match-e [54] 87.0% [151] 17748(1.4%) 346(0.0%) variable? ...e/develop/src/syntax/syntax.rkt:665:0 ??? [173] 98.1% -------------------------------------------------------------------------------------------- for-loop [267] 2.9% ??? [260] 8.3% ...velop/src/common.rkt:47:2 [140] 88.8% [152] 11442(0.9%) 1850(0.1%) ??? ...ects/racket/contract/private/list.rkt:342:4 ??? [260] 80.2% ??? [269] 6.0% ??? [251] 2.9% -------------------------------------------------------------------------------------------- ...velop/src/common.rkt:47:2 [140] 100.0% [153] 10794(0.8%) 2940(0.2%) ??? ...s/racket/contract/private/arr-i.rkt:1268:39 assoc-ref [159] 25.2% return/no-unsupplied [217] 24.1% ??? [218] 23.5% -------------------------------------------------------------------------------------------- merge-egraph-nodes! [64] 27.9% ??? [138] 28.5% update-leader! [79] 43.7% [154] 2318(0.2%) 1952(0.1%) make-sequence ...ects/racket/private/for.rkt:509:2 ??? [161] 15.8% -------------------------------------------------------------------------------------------- expression->type [145] 100.0% [155] 1928(0.1%) 0(0.0%) for-loop ...herbie/develop/src/type-check.rkt:52:5 expression->type [145] 52.0% f176 [51] 48.0% -------------------------------------------------------------------------------------------- ??? [150] 100.0% [156] 24862(1.9%) 336(0.0%) ??? ...ects/racket/contract/private/list.rkt:169:2 ??? [163] 98.6% -------------------------------------------------------------------------------------------- for-loop [99] 1.4% update-leader! [79] 1.6% for-loop [82] 10.1% for-loop [149] 26.4% loop! [98] 60.6% [157] 22730(1.7%) 22730(1.7%) update-en-expr ...evelop/src/core/egraph.rkt:212:0 -------------------------------------------------------------------------------------------- prepare-points [148] 48.9% loop [147] 51.1% [158] 15228(1.2%) 0(0.0%) loop ...htlies/herbie/develop/src/points.rkt:158:2 make-exacts* [162] 71.4% loop [164] 28.6% -------------------------------------------------------------------------------------------- ??? [153] 100.0% [159] 2722(0.2%) 2722(0.2%) assoc-ref ...collects/racket/private/dict.rkt:56:0 -------------------------------------------------------------------------------------------- loop [147] 17.0% prepare-points [148] 83.0% [160] 1932(0.1%) 0(0.0%) for-loop ...s/herbie/develop/src/points.rkt:255:26 ??? [165] 100.0% -------------------------------------------------------------------------------------------- make-sequence [154] 100.0% [161] 366(0.0%) 0(0.0%) ??? ...acket/collects/racket/private/for.rkt:429:7 custom-in-set [166] 100.0% -------------------------------------------------------------------------------------------- loop [158] 2.1% prepare-points [148] 34.2% loop [147] 63.7% [162] 517768(39.4%) 970(0.1%) make-exacts* ...erbie/develop/src/points.rkt:138:0 eval-prog [167] 94.2% loop [213] 5.3% debug-print [170] 0.2% debug7 [171] 0.1% -------------------------------------------------------------------------------------------- ??? [156] 100.0% [163] 24526(1.9%) 718(0.1%) ??? ...ects/racket/contract/private/list.rkt:678:5 for-loop [169] 97.1% -------------------------------------------------------------------------------------------- loop [158] 18.2% loop [147] 24.0% prepare-points [148] 57.8% [164] 23998(1.8%) 0(0.0%) loop ...htlies/herbie/develop/src/points.rkt:141:4 loop [213] 82.4% ??? [168] 16.2% debug7 [171] 1.4% -------------------------------------------------------------------------------------------- prepare-points [148] 10.1% loop [147] 37.1% for-loop [160] 52.8% [165] 3662(0.3%) 330(0.0%) ??? ...ghtlies/herbie/develop/src/points.rkt:230:7 for-loop [172] 45.7% ??? [201] 35.6% ??? [178] 9.7% -------------------------------------------------------------------------------------------- ??? [161] 27.1% match-e [54] 72.9% [166] 1352(0.1%) 1352(0.1%) custom-in-set ...acket/private/set-types.rkt:577:0 -------------------------------------------------------------------------------------------- point->alt [112] 0.1% errors [198] 2.3% make-exacts* [162] 97.6% [167] 499248(38.0%) 14474(1.1%) eval-prog ...herbie/develop/src/programs.rkt:150:0 hash-ref! [203] 94.1% f176 [51] 2.3% ??? [201] 0.2% ??? [179] 0.1% ??? [178] 0.1% parse-app [224] 0.1% -------------------------------------------------------------------------------------------- ??? [125] 1.2% jloop [16] 1.3% loop [164] 4.8% loop [143] 5.8% for-loop [200] 31.0% loop [213] 55.9% [168] 81210(6.2%) 2678(0.2%) ??? ...tlies/herbie/develop/src/programs.rkt:156:4 ??? [174] 66.9% ??? [204] 18.6% ??? [201] 11.3% -------------------------------------------------------------------------------------------- ??? [163] 100.0% [169] 23808(1.8%) 8644(0.7%) for-loop ...racket/contract/private/list.rkt:680:9 add-list-context [176] 36.4% get/build-late-neg-projection [175] 27.3% -------------------------------------------------------------------------------------------- prepare-points [148] 9.8% loop [147] 10.8% make-exacts* [162] 29.8% simplify [41] 49.6% [170] 3300(0.3%) 1308(0.1%) debug-print .../herbie/develop/src/debug.rkt:107:0 for-loop [177] 60.4% -------------------------------------------------------------------------------------------- loop [164] 13.9% prepare-points [148] 15.5% ??? [206] 15.7% simplify [41] 26.6% make-exacts* [162] 28.3% [171] 2432(0.2%) 986(0.1%) debug7 ...tlies/herbie/develop/src/debug.rkt:102:0 ??? [173] 29.9% ??? [218] 29.6% -------------------------------------------------------------------------------------------- ??? [165] 100.0% [172] 1674(0.1%) 698(0.1%) for-loop ...es/herbie/develop/src/points.rkt:231:9 ??? [201] 38.5% parse-loop145 [209] 19.8% -------------------------------------------------------------------------------------------- split-table [37] 0.4% run-improve50 [2] 0.4% for-loop [121] 0.7% setfindf [29] 0.8% debug7 [171] 0.8% f176 [51] 1.0% free-variables [146] 1.0% substitute-e [66] 3.2% ??? [269] 4.1% variable? [151] 18.5% match-e [54] 22.0% finalize-iter! [57] 22.4% get-sigs [129] 24.2% [173] 94228(7.2%) 32078(2.4%) ??? ...contract/private/arrow-val-first.rkt:357:18 hash-has-key? [180] 40.8% for-loop [181] 21.6% atab-add-altns [186] 1.1% ??? [269] 1.0% split-atab [189] 0.4% -------------------------------------------------------------------------------------------- ??? [168] 100.0% [174] 54324(4.1%) 28204(2.1%) ??? ...acket/collects/racket/private/kw.rkt:444:14 ??? [230] 19.9% bf* [182] 15.4% ??? [233] 6.8% ??? [185] 3.0% ??? [270] 1.8% parse-loop145 [209] 1.2% -------------------------------------------------------------------------------------------- ??? [184] 14.8% ??? [139] 19.7% for-loop [169] 63.8% [175] 10202(0.8%) 2284(0.2%) get/build-late-neg-projection ...te/guts.rkt:691:0 ??? [183] 62.6% ??? [184] 14.8% listof-late-neg-projection [188] 3.4% -------------------------------------------------------------------------------------------- for-loop [169] 100.0% [176] 8658(0.7%) 8658(0.7%) add-list-context ...ontract/private/list.rkt:752:0 -------------------------------------------------------------------------------------------- debug-print [170] 100.0% [177] 1992(0.2%) 1992(0.2%) for-loop ...ies/herbie/develop/src/debug.rkt:113:2 -------------------------------------------------------------------------------------------- ??? [165] 34.5% eval-prog [167] 65.5% [178] 1032(0.1%) 356(0.0%) ??? ...tract/private/arrow-higher-order.rkt:346:33 ??? [270] 65.5% -------------------------------------------------------------------------------------------- eval-prog [167] 100.0% [179] 710(0.1%) 0(0.0%) ??? ...cket/collects/racket/private/kw.rkt:1633:36 unpack245 [187] 100.0% -------------------------------------------------------------------------------------------- mk-enode! [77] 6.3% ??? [173] 93.7% [180] 41192(3.1%) 16414(1.2%) hash-has-key? ...et/private/more-scheme.rkt:368:13 ??? [216] 57.8% ??? [223] 2.3% -------------------------------------------------------------------------------------------- ??? [173] 100.0% [181] 20548(1.6%) 0(0.0%) for-loop ...ie/develop/src/core/alt-table.rkt:51:2 atab-add-altn [190] 100.0% -------------------------------------------------------------------------------------------- ??? [174] 100.0% [182] 8382(0.6%) 0(0.0%) bf* ...ath/private/bigfloat/bigfloat-mpfr.rkt:95:0 ??? [230] 100.0% -------------------------------------------------------------------------------------------- get/build-late-neg-projection [175] 100.0% [183] 7226(0.5%) 2218(0.2%) ??? ...cts/racket/contract/private/prop.rkt:314:12 build-compound-type-name [191] 69.3% -------------------------------------------------------------------------------------------- get/build-late-neg-projection [175] 100.0% [184] 3016(0.2%) 0(0.0%) ??? ...ects/racket/contract/private/hash.rkt:211:2 get/build-late-neg-projection [175] 100.0% -------------------------------------------------------------------------------------------- ??? [174] 100.0% [185] 1642(0.1%) 984(0.1%) ??? ...herbie/develop/src/syntax/syntax.rkt:156:17 ??? [218] 40.1% -------------------------------------------------------------------------------------------- ??? [173] 100.0% [186] 1006(0.1%) 0(0.0%) atab-add-altns ...elop/src/core/alt-table.rkt:50:0 atab-add-altn [190] 100.0% -------------------------------------------------------------------------------------------- ??? [179] 100.0% [187] 710(0.1%) 338(0.0%) unpack245 ...private/arrow-higher-order.rkt:354:44 maybe-cons-kwd [192] 52.4% -------------------------------------------------------------------------------------------- get/build-late-neg-projection [175] 100.0% [188] 692(0.1%) 692(0.1%) listof-late-neg-projection ...ivate/list.rkt:162:0 -------------------------------------------------------------------------------------------- ??? [173] 100.0% [189] 332(0.0%) 0(0.0%) split-atab .../develop/src/core/alt-table.rkt:74:0 for-loop [193] 100.0% -------------------------------------------------------------------------------------------- atab-add-altns [186] 4.7% for-loop [181] 95.3% [190] 21554(1.6%) 0(0.0%) atab-add-altn ...elop/src/core/alt-table.rkt:208:0 best-and-tied-at-points [194] 92.4% override-at-pnts [196] 7.6% -------------------------------------------------------------------------------------------- contract-struct-name [195] 23.4% ??? [183] 76.6% [191] 5008(0.4%) 2964(0.2%) build-compound-type-name ...private/guts.rkt:448:0 contract-struct-name [195] 57.5% -------------------------------------------------------------------------------------------- unpack245 [187] 100.0% [192] 372(0.0%) 0(0.0%) maybe-cons-kwd ...ate/arrow-higher-order.rkt:498:0 arrow-higher-order:lnp [240] 100.0% -------------------------------------------------------------------------------------------- split-atab [189] 100.0% [193] 332(0.0%) 0(0.0%) for-loop ...ie/develop/src/core/alt-table.rkt:75:2 for-loop [197] 100.0% -------------------------------------------------------------------------------------------- atab-add-altn [190] 100.0% [194] 19910(1.5%) 0(0.0%) best-and-tied-at-points ...ore/alt-table.rkt:122:0 errors [198] 96.8% for-loop [199] 3.2% -------------------------------------------------------------------------------------------- build-compound-type-name [191] 100.0% [195] 3716(0.3%) 2044(0.2%) contract-struct-name ...ract/private/prop.rkt:89:0 build-compound-type-name [191] 54.0% -------------------------------------------------------------------------------------------- atab-add-altn [190] 100.0% [196] 1644(0.1%) 0(0.0%) override-at-pnts ...p/src/core/alt-table.rkt:145:0 errors [198] 100.0% -------------------------------------------------------------------------------------------- for-loop [193] 100.0% [197] 332(0.0%) 0(0.0%) for-loop ...e/develop/src/core/alt-table.rkt:80:53 filter [236] 100.0% -------------------------------------------------------------------------------------------- composed [220] 2.3% override-at-pnts [196] 3.9% option-on-expr [63] 4.7% loop [213] 17.4% pred [137] 26.5% best-and-tied-at-points [194] 45.3% [198] 42548(3.2%) 344(0.0%) errors ...lies/herbie/develop/src/points.rkt:271:0 for-loop [200] 72.3% eval-prog [167] 26.8% -------------------------------------------------------------------------------------------- best-and-tied-at-points [194] 100.0% [199] 646(0.0%) 646(0.0%) for-loop .../develop/src/core/alt-table.rkt:124:16 -------------------------------------------------------------------------------------------- errors [198] 100.0% [200] 30782(2.3%) 2272(0.2%) for-loop ...es/herbie/develop/src/points.rkt:274:4 ??? [168] 81.8% ??? [201] 5.3% ulp-difference [202] 4.4% -------------------------------------------------------------------------------------------- for-loop [172] 1.0% jloop [16] 1.0% eval-prog [167] 1.5% ??? [165] 2.0% for-loop [200] 2.3% loop [213] 3.0% loop [23] 7.8% ??? [10] 11.5% ??? [168] 13.9% f176 [51] 14.7% ??? [206] 20.3% for-loop [100] 20.3% [201] 65602(5.0%) 3010(0.2%) ??? ...tract/private/arrow-higher-order.rkt:342:33 ??? [206] 44.0% approximate9 [5] 20.3% hash-ref! [203] 19.4% ??? [269] 6.1% ...velop/src/common.rkt:47:2 [140] 2.0% ??? [139] 1.5% best-alt [205] 0.5% ??? [204] 0.5% -------------------------------------------------------------------------------------------- loop [96] 19.9% for-loop [200] 80.1% [202] 1688(0.1%) 1352(0.1%) ulp-difference ...erbie/develop/src/float.rkt:19:0 return/no-unsupplied [217] 19.9% -------------------------------------------------------------------------------------------- for-loop [225] 0.0% simplify* [89] 0.0% for-loop [32] 0.0% first-nonzero-exp [31] 0.0% ??? [6] 0.1% ??? [13] 0.1% update-leader! [79] 0.1% ??? [10] 0.1% ??? [208] 0.2% for-loop [43] 0.3% compile [90] 0.4% for-loop [26] 0.4% for-loop [25] 0.5% loop [23] 0.7% ??? [201] 1.0% for-loop [24] 1.3% ??? [42] 2.7% eval-prog [167] 35.1% loop [213] 56.6% [203] 512714(39.0%) 5580(0.4%) hash-ref! ...racket/private/more-scheme.rkt:373:13 ??? [208] 56.9% bigfloat-hash [207] 34.9% ??? [8] 2.6% ??? [7] 1.4% ??? [10] 0.8% ??? [6] 0.8% simplify [41] 0.8% ??? [9] 0.4% ??? [11] 0.3% f176 [51] 0.2% parse-loop145 [209] 0.2% ??? [13] 0.2% ??? [17] 0.0% -------------------------------------------------------------------------------------------- ??? [201] 2.1% ??? [168] 97.9% [204] 15390(1.2%) 332(0.0%) ??? ...contract/private/../../private/kw.rkt:761:9 real->bigfloat [210] 95.8% integer->bigfloat [212] 2.1% -------------------------------------------------------------------------------------------- ??? [201] 100.0% [205] 664(0.1%) 0(0.0%) best-alt ...tlies/herbie/develop/src/glue.rkt:71:0 loop [211] 100.0% -------------------------------------------------------------------------------------------- simplify-alt [46] 0.0% f176 [51] 0.1% for-loop [67] 1.3% get-sigs [129] 2.0% ??? [206] 4.5% ??? [201] 7.4% for-loop [214] 40.2% ??? [75] 44.1% [206] 709410(54.0%) 27138(2.1%) ??? ...llects/racket/private/norm-define.rkt:53:83 iterate-egraph!13 [3] 41.3% for-loop [214] 40.2% ??? [201] 5.1% ??? [206] 4.5% loop [4] 2.9% ??? [216] 2.4% ??? [218] 0.7% return/no-unsupplied [217] 0.5% mk-egraph [222] 0.1% loop [226] 0.1% *simplify-rules* [228] 0.1% ??? [260] 0.0% ??? [223] 0.0% debug7 [171] 0.0% -------------------------------------------------------------------------------------------- hash-ref! [203] 100.0% [207] 468620(35.7%) 1330(0.1%) bigfloat-hash ...h/private/bigfloat/mpfr.rkt:165:0 bfcanonicalize [215] 97.7% sig+exp->bigfloat [219] 1.9% bigfloat->sig+exp [231] 0.1% -------------------------------------------------------------------------------------------- hash-ref! [203] 100.0% [208] 435038(33.1%) 664(0.1%) ??? ...tlies/herbie/develop/src/programs.rkt:194:5 loop [213] 99.6% hash-ref! [203] 0.3% -------------------------------------------------------------------------------------------- for-loop [172] 1.3% f176 [51] 2.3% ??? [174] 2.5% for-loop [33] 3.7% append-map [73] 3.8% hash-ref! [203] 4.0% loop [213] 5.4% simplify [41] 16.5% parse-loop145 [209] 21.1% map [69] 39.5% [209] 25914(2.0%) 16270(1.2%) parse-loop145 .../racket/match/compiler.rkt:418:15 parse-loop145 [209] 21.1% loop [213] 13.8% f176 [51] 13.1% map [69] 5.1% for-loop [225] 3.7% for-loop [227] 2.4% make-multiplication-node [91] 2.3% parse-app [224] 1.8% simplify-node [221] 1.4% simplify* [89] 0.7% loop [96] 0.6% -------------------------------------------------------------------------------------------- ??? [204] 100.0% [210] 14738(1.1%) 10294(0.8%) real->bigfloat .../private/bigfloat/mpfr.rkt:451:0 ??? [261] 30.2% -------------------------------------------------------------------------------------------- extract-alt [50] 31.0% best-alt [205] 69.0% [211] 962(0.1%) 0(0.0%) loop ...htlies/herbie/develop/src/common.rkt:153:2 composed [220] 100.0% -------------------------------------------------------------------------------------------- ??? [204] 100.0% [212] 320(0.0%) 320(0.0%) integer->bigfloat ...ivate/bigfloat/mpfr.rkt:399:0 -------------------------------------------------------------------------------------------- match-e [54] 0.1% map [69] 0.1% map-enodes [28] 0.2% loop [164] 0.3% for-loop [65] 0.4% option-on-expr [63] 0.4% make-exacts* [162] 0.6% parse-loop145 [209] 0.7% loop! [98] 1.5% loop [213] 24.4% f176 [51] 28.2% ??? [208] 43.1% [213] 652004(49.6%) 7948(0.6%) loop ...cket/collects/racket/private/map.rkt:25:19 hash-ref! [203] 43.1% option-on-expr [63] 28.2% loop [213] 24.4% loop! [98] 1.5% ??? [168] 0.8% parse-loop145 [209] 0.5% errors [198] 0.4% f176 [51] 0.2% for-loop [12] 0.2% foldl [238] 0.1% curried [234] 0.1% simplify [41] 0.0% ??? [201] 0.0% ??? [239] 0.0% ??? [230] 0.0% ??? [233] 0.0% -------------------------------------------------------------------------------------------- ??? [206] 100.0% [214] 592096(45.1%) 0(0.0%) for-loop ...ie/develop/src/core/simplify.rkt:66:12 ??? [206] 100.0% -------------------------------------------------------------------------------------------- bigfloat-hash [207] 100.0% [215] 457718(34.8%) 452656(34.4%) bfcanonicalize .../private/bigfloat/mpfr.rkt:155:0 bigfloat->sig+exp [231] 1.1% -------------------------------------------------------------------------------------------- hash-has-key? [180] 34.0% ??? [206] 66.0% [216] 69978(5.3%) 23946(1.8%) ??? ...ects/racket/contract/private/list.rkt:737:4 for-loop [229] 46.5% ??? [247] 15.1% ??? [260] 2.2% arrow-higher-order:lnp [240] 1.0% successfully-got-the-right-kind-of-function [242] 1.0% -------------------------------------------------------------------------------------------- ulp-difference [202] 3.4% flag-set? [61] 6.5% simplify* [89] 10.5% ??? [153] 26.1% ??? [206] 53.5% [217] 9962(0.8%) 8550(0.7%) return/no-unsupplied ...ct/private/arr-i.rkt:533:0 filter [236] 14.2% -------------------------------------------------------------------------------------------- flag-set? [61] 3.6% ??? [185] 6.7% debug7 [171] 7.3% ??? [153] 25.7% ??? [206] 56.7% [218] 9858(0.8%) 3660(0.3%) ??? ...racket/collects/racket/private/kw.rkt:761:9 ??? [232] 56.4% ??? [269] 6.5% -------------------------------------------------------------------------------------------- bigfloat-hash [207] 100.0% [219] 8892(0.7%) 5118(0.4%) sig+exp->bigfloat ...ivate/bigfloat/mpfr.rkt:385:0 integer->mpz [235] 34.5% ??? [261] 7.9% -------------------------------------------------------------------------------------------- loop [211] 32.3% f176 [51] 67.7% [220] 2974(0.2%) 350(0.0%) composed ...ollects/racket/private/list.rkt:321:16 f176 [51] 44.3% errors [198] 32.3% free-variables [146] 11.6% -------------------------------------------------------------------------------------------- parse-loop145 [209] 12.4% simplify [41] 20.8% map [69] 66.8% [221] 2894(0.2%) 0(0.0%) simplify-node .../develop/src/core/reduce.rkt:50:0 f176 [51] 42.5% combine-aterms [243] 23.3% append-map [73] 22.8% gather-additive-terms6 [245] 11.4% -------------------------------------------------------------------------------------------- ??? [206] 100.0% [222] 1946(0.1%) 0(0.0%) mk-egraph ...bie/develop/src/core/egraph.rkt:131:0 mk-enode-rec! [237] 100.0% -------------------------------------------------------------------------------------------- ??? [206] 40.3% hash-has-key? [180] 59.7% [223] 1602(0.1%) 1602(0.1%) ??? ...ects/racket/contract/private/hash.rkt:245:7 -------------------------------------------------------------------------------------------- eval-prog [167] 33.5% parse-loop145 [209] 66.5% [224] 1028(0.1%) 690(0.1%) parse-app .../collects/racket/private/kw.rkt:951:2 loop [244] 32.9% -------------------------------------------------------------------------------------------- parse-loop145 [209] 100.0% [225] 968(0.1%) 0(0.0%) for-loop ...bie/develop/src/core/taylor.rkt:490:59 hash-ref! [203] 100.0% -------------------------------------------------------------------------------------------- ??? [206] 100.0% [226] 946(0.1%) 0(0.0%) loop ...ghtlies/herbie/develop/src/points.rkt:66:6 random-exp [241] 100.0% -------------------------------------------------------------------------------------------- parse-loop145 [209] 100.0% [227] 936(0.1%) 0(0.0%) for-loop ...rbie/develop/src/core/reduce.rkt:99:13 f176 [51] 66.9% make-multiplication-node [91] 33.1% -------------------------------------------------------------------------------------------- ??? [206] 100.0% [228] 356(0.0%) 0(0.0%) *simplify-rules* ...lop/src/syntax/rules.rkt:570:0 for-loop [30] 100.0% -------------------------------------------------------------------------------------------- ??? [216] 100.0% [229] 32556(2.5%) 14090(1.1%) for-loop ...acket/contract/private/list.rkt:743:12 ??? [247] 35.1% for-loop [246] 18.7% ??? [251] 2.0% ??? [269] 1.0% -------------------------------------------------------------------------------------------- loop [213] 1.8% bf* [182] 42.9% ??? [174] 55.3% [230] 19542(1.5%) 5340(0.4%) ??? ...-racket/utils/simple-result-arrow.rkt:39:12 bfdiv [248] 64.0% bfsqrt [250] 8.6% -------------------------------------------------------------------------------------------- bigfloat-hash [207] 11.8% bfcanonicalize [215] 88.2% [231] 5742(0.4%) 1306(0.1%) bigfloat->sig+exp ...ivate/bigfloat/mpfr.rkt:370:0 size+limbs->integer [249] 52.6% new-mpz [253] 18.2% mpz->integer [257] 6.4% -------------------------------------------------------------------------------------------- ??? [218] 100.0% [232] 5562(0.4%) 5260(0.4%) ??? ...s/racket/contract/private/arr-i.rkt:1233:27 ??? [259] 5.4% -------------------------------------------------------------------------------------------- loop [213] 8.3% ??? [174] 91.7% [233] 4014(0.3%) 4014(0.3%) ??? ...rivate/unconstrained-domain-arrow.rkt:40:13 -------------------------------------------------------------------------------------------- for-loop [12] 9.3% loop [44] 9.5% map-enodes [28] 9.6% for-loop [142] 18.2% for-loop [65] 25.8% loop [213] 27.6% [234] 3734(0.3%) 3734(0.3%) curried ...cket/collects/racket/function.rkt:71:18 -------------------------------------------------------------------------------------------- sig+exp->bigfloat [219] 100.0% [235] 3068(0.2%) 3068(0.2%) integer->mpz ...math/private/bigfloat/gmp.rkt:87:0 -------------------------------------------------------------------------------------------- for-loop [197] 12.3% for-loop [65] 35.6% return/no-unsupplied [217] 52.1% [236] 2708(0.2%) 2708(0.2%) filter ...t/collects/racket/private/list.rkt:256:2 -------------------------------------------------------------------------------------------- mk-egraph [222] 49.9% mk-enode-rec! [237] 50.1% [237] 1946(0.1%) 304(0.0%) mk-enode-rec! ...develop/src/core/egraph.rkt:122:0 mk-enode-rec! [237] 50.1% mk-enode! [77] 34.3% -------------------------------------------------------------------------------------------- for-loop [65] 37.4% loop [213] 62.6% [238] 1626(0.1%) 610(0.0%) foldl ...et/collects/racket/private/list.rkt:229:4 merge2 [254] 62.5% -------------------------------------------------------------------------------------------- loop [213] 22.8% map [69] 77.2% [239] 1324(0.1%) 0(0.0%) ??? ...ies/herbie/develop/src/core/reduce.rkt:61:5 for-loop [252] 100.0% -------------------------------------------------------------------------------------------- maybe-cons-kwd [192] 35.4% ??? [216] 64.6% [240] 1052(0.1%) 356(0.0%) arrow-higher-order:lnp ...w-higher-order.rkt:597:7 ??? [255] 66.2% -------------------------------------------------------------------------------------------- loop [226] 100.0% [241] 946(0.1%) 946(0.1%) random-exp .../herbie/develop/src/common.rkt:253:0 -------------------------------------------------------------------------------------------- ??? [216] 100.0% [242] 678(0.1%) 354(0.0%) successfully-got-the-right-kind-of-function ...9:4 arity-checking-wrapper [258] 47.8% -------------------------------------------------------------------------------------------- simplify-node [221] 100.0% [243] 674(0.1%) 0(0.0%) combine-aterms ...evelop/src/core/reduce.rkt:183:0 for-loop [256] 100.0% -------------------------------------------------------------------------------------------- parse-app [224] 100.0% [244] 338(0.0%) 338(0.0%) loop .../collects/racket/private/stxcase.rkt:112:7 -------------------------------------------------------------------------------------------- simplify-node [221] 100.0% [245] 330(0.0%) 330(0.0%) gather-additive-terms6 ...src/core/reduce.rkt:72:0 -------------------------------------------------------------------------------------------- for-loop [229] 22.2% ??? [139] 77.8% [246] 27352(2.1%) 5192(0.4%) for-loop ...racket/contract/private/hash.rkt:239:6 ??? [260] 79.9% ??? [270] 1.1% -------------------------------------------------------------------------------------------- ??? [216] 48.0% for-loop [229] 52.0% [247] 21984(1.7%) 11204(0.9%) ??? ...private/unconstrained-domain-arrow.rkt:74:4 make-keyword-procedure [262] 49.0% -------------------------------------------------------------------------------------------- ??? [230] 100.0% [248] 12512(1.0%) 7122(0.5%) bfdiv ...-lib/math/private/bigfloat/mpfr.rkt:819:4 ??? [261] 43.1% -------------------------------------------------------------------------------------------- bigfloat->sig+exp [231] 100.0% [249] 3022(0.2%) 3022(0.2%) size+limbs->integer ...vate/bigfloat/gmp.rkt:103:0 -------------------------------------------------------------------------------------------- ??? [230] 100.0% [250] 1690(0.1%) 1342(0.1%) bfsqrt ...lib/math/private/bigfloat/mpfr.rkt:616:4 ??? [261] 20.6% -------------------------------------------------------------------------------------------- ??? [152] 20.8% ??? [139] 39.4% for-loop [229] 39.8% [251] 1598(0.1%) 364(0.0%) ??? ...ects/racket/contract/private/hash.rkt:222:6 check-hash/c [263] 77.2% -------------------------------------------------------------------------------------------- ??? [239] 100.0% [252] 1324(0.1%) 682(0.1%) for-loop ...erbie/develop/src/core/reduce.rkt:62:7 pattern-match [264] 48.5% -------------------------------------------------------------------------------------------- bigfloat->sig+exp [231] 100.0% [253] 1046(0.1%) 1046(0.1%) new-mpz ...-lib/math/private/bigfloat/gmp.rkt:73:0 -------------------------------------------------------------------------------------------- foldl [238] 100.0% [254] 1016(0.1%) 1016(0.1%) merge2 .../herbie/develop/src/core/ematch.rkt:31:0 -------------------------------------------------------------------------------------------- arrow-higher-order:lnp [240] 100.0% [255] 696(0.1%) 696(0.1%) ??? ...et/contract/private/arity-checking.rkt:19:2 -------------------------------------------------------------------------------------------- combine-aterms [243] 100.0% [256] 674(0.1%) 674(0.1%) for-loop ...rbie/develop/src/core/reduce.rkt:185:4 -------------------------------------------------------------------------------------------- bigfloat->sig+exp [231] 100.0% [257] 368(0.0%) 368(0.0%) mpz->integer ...ath/private/bigfloat/gmp.rkt:115:0 -------------------------------------------------------------------------------------------- successfully-got-the-right-kind-of-function [242]100.0% [258] 324(0.0%) 0(0.0%) arity-checking-wrapper ...w-higher-order.rkt:402:0 matches-arity-exactly? [265] 100.0% -------------------------------------------------------------------------------------------- ??? [232] 100.0% [259] 302(0.0%) 302(0.0%) ??? ...ects/racket/contract/private/prop.rkt:256:4 -------------------------------------------------------------------------------------------- ??? [206] 2.8% ??? [216] 4.5% ??? [152] 30.0% for-loop [246] 62.7% [260] 34868(2.7%) 6896(0.5%) ??? ...cts/racket/contract/private/list.rkt:187:10 ??? [266] 60.8% for-loop [267] 11.2% ??? [152] 5.5% ??? [270] 2.7% -------------------------------------------------------------------------------------------- bfsqrt [250] 3.2% sig+exp->bigfloat [219] 6.5% real->bigfloat [210] 40.8% bfdiv [248] 49.5% [261] 10888(0.8%) 10888(0.8%) ??? .../share/racket/collects/ffi/unsafe.rkt:861:4 -------------------------------------------------------------------------------------------- ??? [247] 100.0% [262] 10780(0.8%) 10780(0.8%) make-keyword-procedure ...ket/private/kw.rkt:260:4 -------------------------------------------------------------------------------------------- ??? [251] 100.0% [263] 1234(0.1%) 332(0.0%) check-hash/c ...ket/contract/private/hash.rkt:83:0 flat-contract? [268] 73.1% -------------------------------------------------------------------------------------------- for-loop [252] 100.0% [264] 642(0.0%) 642(0.0%) pattern-match ...develop/src/core/matcher.rkt:48:0 -------------------------------------------------------------------------------------------- arity-checking-wrapper [258] 100.0% [265] 324(0.0%) 324(0.0%) matches-arity-exactly? ...te/arrow-common.rkt:70:0 -------------------------------------------------------------------------------------------- ??? [260] 100.0% [266] 21202(1.6%) 972(0.1%) ??? ...ects/racket/contract/private/list.rkt:686:7 ??? [269] 94.0% ??? [270] 1.5% -------------------------------------------------------------------------------------------- ??? [260] 100.0% [267] 3920(0.3%) 3262(0.2%) for-loop ...acket/contract/private/list.rkt:190:15 ??? [152] 16.8% -------------------------------------------------------------------------------------------- check-hash/c [263] 100.0% [268] 902(0.1%) 902(0.1%) flat-contract? .../contract/private/guts.rkt:111:0 -------------------------------------------------------------------------------------------- for-loop [229] 1.1% ??? [110] 1.3% ??? [218] 2.3% ??? [173] 3.6% ??? [152] 5.0% ??? [201] 14.5% ??? [266] 72.2% [269] 27592(2.1%) 21908(1.7%) ??? ...ects/racket/contract/private/guts.rkt:644:8 ??? [173] 14.5% contract? [272] 5.0% -------------------------------------------------------------------------------------------- for-loop [246] 9.4% ??? [266] 9.7% ??? [178] 21.1% ??? [260] 29.4% ??? [174] 30.4% [270] 3206(0.2%) 1216(0.1%) ??? ...ects/racket/contract/private/prop.rkt:493:4 ??? [271] 62.1% -------------------------------------------------------------------------------------------- ??? [270] 100.0% [271] 1990(0.2%) 1004(0.1%) ??? ...lects/racket/contract/private/orc.rkt:83:14 ??? [273] 49.5% -------------------------------------------------------------------------------------------- ??? [269] 100.0% [272] 1368(0.1%) 1368(0.1%) contract? ...acket/contract/private/guts.rkt:109:0 -------------------------------------------------------------------------------------------- ??? [271] 100.0% [273] 986(0.1%) 986(0.1%) ??? ...ects/racket/contract/private/list.rkt:141:5 --------------------------------------------------------------------------------------------