Profiling results ----------------- Total cpu time observed: 1074174ms (out of 1079224ms) Number of samples taken: 3172 (once every 339ms) (Hiding functions with self<1.0% and local<2.0%: 18 of 284 hidden) ========================================================================================== Caller Idx Total Self Name+src Local% ms(pct) ms(pct) Callee ========================================================================================== ??? [88] 100.0% [1] 925736(86.2%) 0(0.0%) profile-thunk16 ...t/pkgs/profile-lib/main.rkt:9:0 run [21] 100.0% ------------------------------------------------------------------------------------------ ??? [88] 100.0% [2] 826968(77.0%) 0(0.0%) run-improve50 ...ie/develop/src/mainloop.rkt:234:0 for-loop [22] 89.0% get-final-combination [25] 10.0% loop [103] 0.8% prepare-points [105] 0.2% ------------------------------------------------------------------------------------------ table-ref [181] 100.0% [3] 706914(65.8%) 630(0.1%) iterate-egraph!13 ...p/src/core/simplify.rkt:105:0 one-iter [23] 97.8% map-enodes [27] 2.0% ------------------------------------------------------------------------------------------ table-ref [181] 100.0% [4] 95182(8.9%) 0(0.0%) loop ...herbie/develop/src/core/simplify.rkt:237:2 pass [24] 100.0% ------------------------------------------------------------------------------------------ f6 [175] 5.9% loop [191] 94.1% [5] 81372(7.6%) 328(0.0%) option-on-expr ...evelop/src/core/regimes.rkt:90:0 loop [191] 45.4% sort-context-on-expr [26] 34.3% errors [168] 14.0% err-lsts->split-indices [34] 2.7% pick-errors [35] 2.0% eval-prog [173] 0.8% map [183] 0.4% ------------------------------------------------------------------------------------------ hash-ref! [205] 100.0% [6] 31966(3.0%) 626(0.1%) ??? ...tlies/herbie/develop/src/programs.rkt:194:5 loop [191] 80.3% hash-ref! [205] 18.7% ------------------------------------------------------------------------------------------ map-enodes [27] 4.9% loop [191] 95.1% [7] 14092(1.3%) 2294(0.2%) for-loop ...ie/develop/src/core/simplify.rkt:195:2 setfindf [30] 52.9% eval-const-expr [32] 26.0% compose [39] 4.9% ------------------------------------------------------------------------------------------ ??? [136] 100.0% [8] 13652(1.3%) 0(0.0%) approximate9 ...e/develop/src/core/taylor.rkt:12:0 loop [28] 95.1% f6 [175] 4.9% ------------------------------------------------------------------------------------------ hash-ref! [205] 100.0% [9] 8316(0.8%) 0(0.0%) ??? ...s/herbie/develop/src/core/taylor.rkt:295:23 for-loop [29] 100.0% ------------------------------------------------------------------------------------------ copying-mergesort [80] 100.0% [10] 8216(0.8%) 0(0.0%) jloop ...t/collects/racket/private/sort.rkt:121:23 ??? [127] 92.3% ??? [136] 7.7% ------------------------------------------------------------------------------------------ hash-ref! [205] 100.0% [11] 6908(0.6%) 0(0.0%) ??? ...s/herbie/develop/src/core/taylor.rkt:285:26 for-loop [31] 100.0% ------------------------------------------------------------------------------------------ hash-ref! [205] 100.0% [12] 3710(0.3%) 0(0.0%) ??? ...s/herbie/develop/src/core/taylor.rkt:338:33 hash-ref! [205] 63.3% for-loop [36] 36.7% ------------------------------------------------------------------------------------------ hash-ref! [205] 100.0% [13] 2432(0.2%) 0(0.0%) ??? ...s/herbie/develop/src/core/taylor.rkt:483:23 for-loop [33] 100.0% ------------------------------------------------------------------------------------------ hash-ref! [205] 100.0% [14] 1264(0.1%) 0(0.0%) ??? ...s/herbie/develop/src/core/taylor.rkt:392:23 for-loop [37] 100.0% ------------------------------------------------------------------------------------------ hash-ref! [205] 100.0% [15] 704(0.1%) 0(0.0%) ??? ...s/herbie/develop/src/core/taylor.rkt:322:33 for-loop [38] 100.0% ------------------------------------------------------------------------------------------ loop [203] 100.0% [16] 344(0.0%) 0(0.0%) ??? .../herbie/develop/src/core/localize.rkt:43:32 ??? [136] 100.0% ------------------------------------------------------------------------------------------ matcher [124] 100.0% [17] 334(0.0%) 0(0.0%) for-loop ...bie/develop/src/core/matcher.rkt:159:6 pattern-substitute [40] 100.0% ------------------------------------------------------------------------------------------ f6 [175] 100.0% [18] 334(0.0%) 0(0.0%) exprs-to-branch-on ...op/src/core/regimes.rkt:42:0 for-loop [41] 100.0% ------------------------------------------------------------------------------------------ f6 [175] 100.0% [19] 326(0.0%) 0(0.0%) loop ...es/herbie/develop/src/core/reduce.rkt:18:2 expression->type [186] 100.0% ------------------------------------------------------------------------------------------ map [183] 100.0% [20] 302(0.0%) 0(0.0%) make-multiplication-node .../core/reduce.rkt:230:0 make-multiplication-subnode [42] 100.0% ------------------------------------------------------------------------------------------ profile-thunk16 [1] 99.8% [21] 927980(86.4%) 0(0.0%) run ...share/racket/pkgs/profile-lib/main.rkt:39:2 ??? [88] 100.0% ------------------------------------------------------------------------------------------ run-improve50 [2] 100.0% [22] 735986(68.5%) 0(0.0%) for-loop ...herbie/develop/src/mainloop.rkt:249:10 run-iter! [43] 100.0% ------------------------------------------------------------------------------------------ iterate-egraph!13 [3] 100.0% [23] 691506(64.4%) 5336(0.5%) one-iter ...ie/develop/src/core/simplify.rkt:116:0 for-loop [44] 72.9% for-loop [45] 26.2% ------------------------------------------------------------------------------------------ loop [4] 100.0% [24] 95182(8.9%) 0(0.0%) pass ...herbie/develop/src/core/simplify.rkt:227:2 for-loop [46] 99.0% ------------------------------------------------------------------------------------------ run-improve50 [2] 100.0% [25] 83046(7.7%) 0(0.0%) get-final-combination ...op/src/mainloop.rkt:264:0 split-table [47] 98.4% extract-alt [52] 1.6% ------------------------------------------------------------------------------------------ option-on-expr [5] 100.0% [26] 27900(2.6%) 0(0.0%) sort-context-on-expr ...velop/src/points.rkt:115:0 ??? [48] 98.8% eval-prog [173] 1.2% ------------------------------------------------------------------------------------------ iterate-egraph!13 [3] 100.0% [27] 14432(1.3%) 0(0.0%) map-enodes ...ie/develop/src/core/egraph.rkt:140:0 loop [191] 95.3% for-loop [7] 4.7% ------------------------------------------------------------------------------------------ approximate9 [8] 100.0% [28] 12978(1.2%) 0(0.0%) loop ...es/herbie/develop/src/core/taylor.rkt:86:4 ??? [136] 100.0% ------------------------------------------------------------------------------------------ ??? [9] 100.0% [29] 8316(0.8%) 0(0.0%) for-loop ...bie/develop/src/core/taylor.rkt:298:27 hash-ref! [205] 100.0% ------------------------------------------------------------------------------------------ for-loop [7] 100.0% [30] 7450(0.7%) 2940(0.3%) setfindf ...es/herbie/develop/src/common.rkt:186:0 ??? [128] 47.6% for-loop [55] 12.9% ------------------------------------------------------------------------------------------ ??? [11] 100.0% [31] 6908(0.6%) 0(0.0%) for-loop ...bie/develop/src/core/taylor.rkt:285:52 hash-ref! [205] 65.8% ??? [49] 34.2% ------------------------------------------------------------------------------------------ for-loop [7] 100.0% [32] 3658(0.3%) 316(0.0%) eval-const-expr .../develop/src/programs.rkt:168:0 f6 [175] 54.9% ??? [51] 36.5% ------------------------------------------------------------------------------------------ ??? [13] 100.0% [33] 2432(0.2%) 0(0.0%) for-loop ...bie/develop/src/core/taylor.rkt:487:35 parse-loop12 [235] 100.0% ------------------------------------------------------------------------------------------ option-on-expr [5] 100.0% [34] 2180(0.2%) 0(0.0%) err-lsts->split-indices .../core/regimes.rkt:235:0 add-splitpoint [50] 100.0% ------------------------------------------------------------------------------------------ option-on-expr [5] 100.0% [35] 1644(0.2%) 0(0.0%) pick-errors .../develop/src/core/regimes.rkt:197:0 point->alt [54] 60.8% for-loop [56] 39.2% ------------------------------------------------------------------------------------------ ??? [12] 100.0% [36] 1362(0.1%) 0(0.0%) for-loop ...bie/develop/src/core/taylor.rkt:341:46 hash-ref! [205] 100.0% ------------------------------------------------------------------------------------------ ??? [14] 100.0% [37] 1264(0.1%) 0(0.0%) for-loop ...bie/develop/src/core/taylor.rkt:396:33 for-loop [53] 100.0% ------------------------------------------------------------------------------------------ ??? [15] 100.0% [38] 704(0.1%) 0(0.0%) for-loop ...bie/develop/src/core/taylor.rkt:324:46 hash-ref! [205] 51.1% simplify [223] 48.9% ------------------------------------------------------------------------------------------ for-loop [7] 100.0% [39] 690(0.1%) 690(0.1%) compose ...collects/racket/private/list.rkt:385:12 ------------------------------------------------------------------------------------------ pattern-substitute [40] 50.0% for-loop [17] 50.0% [40] 334(0.0%) 0(0.0%) pattern-substitute ...op/src/core/matcher.rkt:73:0 pattern-substitute [40] 50.0% ??? [128] 50.0% ------------------------------------------------------------------------------------------ exprs-to-branch-on [18] 100.0% [41] 334(0.0%) 0(0.0%) for-loop ...bie/develop/src/core/regimes.rkt:44:27 all-critical-subexpressions [57] 100.0% ------------------------------------------------------------------------------------------ make-multiplication-node [20] 100.0% [42] 302(0.0%) 0(0.0%) make-multiplication-subnode ...re/reduce.rkt:240:0 for-loop [58] 100.0% ------------------------------------------------------------------------------------------ for-loop [22] 100.0% [43] 735986(68.5%) 0(0.0%) run-iter! ...herbie/develop/src/mainloop.rkt:215:0 simplify! [59] 92.6% finalize-iter! [64] 4.3% gen-series! [66] 1.9% gen-rewrites! [67] 0.7% ------------------------------------------------------------------------------------------ one-iter [23] 100.0% [44] 503954(46.9%) 3218(0.3%) for-loop ...ie/develop/src/core/simplify.rkt:166:2 for-loop [60] 86.6% match-e [61] 10.2% update-leader! [91] 2.1% reduce-to-single! [69] 0.5% ------------------------------------------------------------------------------------------ for-loop [45] 48.7% one-iter [23] 51.3% [45] 181188(16.9%) 39204(3.6%) for-loop ...e/develop/src/core/simplify.rkt:126:12 for-loop [45] 48.7% match-e [61] 39.0% ??? [107] 0.2% ------------------------------------------------------------------------------------------ pass [24] 100.0% [46] 94224(8.8%) 1716(0.2%) for-loop ...e/develop/src/core/simplify.rkt:230:29 argmin [62] 52.3% loop [63] 41.6% for-loop [68] 3.6% make-sequence [138] 0.7% ------------------------------------------------------------------------------------------ get-final-combination [25] 100.0% [47] 81706(7.6%) 0(0.0%) split-table ...s/herbie/develop/src/glue.rkt:162:0 f6 [175] 100.0% ------------------------------------------------------------------------------------------ sort-context-on-expr [26] 100.0% [48] 27574(2.6%) 0(0.0%) ??? ...cket/collects/racket/private/sort.rkt:403:3 generic-sort/key [65] 82.4% loop [93] 16.5% ??? [127] 1.1% ------------------------------------------------------------------------------------------ for-loop [31] 100.0% [49] 3320(0.3%) 0(0.0%) ??? ...s/herbie/develop/src/core/taylor.rkt:288:19 hash-ref! [205] 100.0% ------------------------------------------------------------------------------------------ err-lsts->split-indices [34] 100.0% [50] 2180(0.2%) 0(0.0%) add-splitpoint ...velop/src/core/regimes.rkt:252:2 for-loop [70] 100.0% ------------------------------------------------------------------------------------------ for-loop [190] 20.6% eval-const-expr [32] 79.4% [51] 1680(0.2%) 314(0.0%) ??? ...cket/collects/racket/private/kw.rkt:1633:36 unpack245 [71] 81.3% ------------------------------------------------------------------------------------------ get-final-combination [25] 100.0% [52] 1340(0.1%) 0(0.0%) extract-alt ...es/herbie/develop/src/glue.rkt:55:0 loop [157] 76.0% argmins [159] 24.0% ------------------------------------------------------------------------------------------ for-loop [37] 100.0% [53] 1264(0.1%) 0(0.0%) for-loop ...bie/develop/src/core/taylor.rkt:398:39 hash-ref! [205] 100.0% ------------------------------------------------------------------------------------------ pick-errors [35] 100.0% [54] 1000(0.1%) 0(0.0%) point->alt ...e/develop/src/core/regimes.rkt:184:0 eval-prog [173] 100.0% ------------------------------------------------------------------------------------------ setfindf [30] 100.0% [55] 964(0.1%) 964(0.1%) for-loop ...es/herbie/develop/src/common.rkt:187:2 ------------------------------------------------------------------------------------------ pick-errors [35] 100.0% [56] 644(0.1%) 0(0.0%) for-loop ...bie/develop/src/core/regimes.rkt:199:2 ??? [72] 100.0% ------------------------------------------------------------------------------------------ for-loop [41] 100.0% [57] 334(0.0%) 0(0.0%) all-critical-subexpressions ...re/regimes.rkt:58:0 for-loop [73] 100.0% ------------------------------------------------------------------------------------------ make-multiplication-subnode [42] 100.0% [58] 302(0.0%) 0(0.0%) for-loop ...rbie/develop/src/core/reduce.rkt:242:3 mterm->expr [74] 100.0% ------------------------------------------------------------------------------------------ run-iter! [43] 100.0% [59] 681464(63.4%) 312(0.0%) simplify! ...herbie/develop/src/mainloop.rkt:155:0 for-loop [75] 100.0% ------------------------------------------------------------------------------------------ for-loop [44] 100.0% [60] 436468(40.6%) 1332(0.1%) for-loop ...e/develop/src/core/simplify.rkt:148:10 mk-enode! [89] 26.7% loop! [204] 25.8% merge-egraph-nodes! [77] 25.6% substitute-e [79] 16.1% list-member? [193] 5.5% ------------------------------------------------------------------------------------------ for-loop [44] 16.4% for-loop [90] 24.6% for-loop [45] 59.0% [61] 192684(17.9%) 60514(5.6%) match-e ...herbie/develop/src/core/ematch.rkt:46:0 for-loop [76] 50.6% for-loop [90] 8.3% ??? [128] 6.9% variable? [92] 4.0% list-cartesian-product [94] 1.7% loop [191] 0.7% custom-in-set [158] 0.3% ------------------------------------------------------------------------------------------ for-loop [46] 100.0% [62] 49308(4.6%) 0(0.0%) argmin ...re/racket/collects/racket/list.rkt:743:0 for-loop [78] 88.8% expression-cost [82] 11.2% ------------------------------------------------------------------------------------------ for-loop [46] 100.0% [63] 39154(3.6%) 344(0.0%) loop ...hare/racket/collects/racket/list.rkt:729:4 for-loop [78] 94.8% expression-cost [82] 4.3% ------------------------------------------------------------------------------------------ run-iter! [43] 100.0% [64] 31702(3.0%) 0(0.0%) finalize-iter! ...e/develop/src/mainloop.rkt:169:0 ??? [128] 100.0% ------------------------------------------------------------------------------------------ ??? [48] 100.0% [65] 22728(2.1%) 0(0.0%) generic-sort/key .../racket/private/sort.rkt:185:2 copying-mergesort [80] 80.9% loop [93] 19.1% ------------------------------------------------------------------------------------------ run-iter! [43] 100.0% [66] 13652(1.3%) 0(0.0%) gen-series! ...rbie/develop/src/mainloop.rkt:129:0 for-loop [81] 100.0% ------------------------------------------------------------------------------------------ run-iter! [43] 100.0% [67] 4938(0.5%) 0(0.0%) gen-rewrites! ...ie/develop/src/mainloop.rkt:142:0 for-loop [83] 100.0% ------------------------------------------------------------------------------------------ for-loop [46] 100.0% [68] 3368(0.3%) 3368(0.3%) for-loop ...e/develop/src/core/simplify.rkt:217:13 ------------------------------------------------------------------------------------------ for-loop [44] 100.0% [69] 2454(0.2%) 1394(0.1%) reduce-to-single! ...lop/src/core/egraph.rkt:325:0 make-sequence [138] 28.5% for-loop [87] 14.7% ------------------------------------------------------------------------------------------ add-splitpoint [50] 100.0% [70] 2180(0.2%) 0(0.0%) for-loop ...bie/develop/src/core/regimes.rkt:254:4 for-loop [84] 100.0% ------------------------------------------------------------------------------------------ ??? [51] 100.0% [71] 1366(0.1%) 0(0.0%) unpack245 ...private/arrow-higher-order.rkt:354:44 maybe-cons-kwd [86] 74.7% ??? [207] 25.3% ------------------------------------------------------------------------------------------ for-loop [56] 100.0% [72] 644(0.1%) 0(0.0%) ??? ...s/herbie/develop/src/core/regimes.rkt:190:2 ??? [127] 100.0% ------------------------------------------------------------------------------------------ all-critical-subexpressions [57] 100.0% [73] 334(0.0%) 0(0.0%) for-loop ...rbie/develop/src/core/regimes.rkt:62:2 f6 [175] 100.0% ------------------------------------------------------------------------------------------ for-loop [58] 100.0% [74] 302(0.0%) 0(0.0%) mterm->expr ...e/develop/src/core/reduce.rkt:270:0 free-variables [85] 100.0% ------------------------------------------------------------------------------------------ simplify! [59] 98.4% [75] 692074(64.4%) 0(0.0%) for-loop .../herbie/develop/src/mainloop.rkt:159:6 ??? [88] 100.0% ------------------------------------------------------------------------------------------ match-e [61] 100.0% [76] 122896(11.4%) 43384(4.0%) for-loop ...rbie/develop/src/core/ematch.rkt:59:11 for-loop [90] 53.4% list-cartesian-product [94] 7.6% loop [191] 4.9% curry* [101] 1.6% filter [266] 0.8% foldl [210] 0.5% ------------------------------------------------------------------------------------------ for-loop [97] 2.1% merge-egraph-nodes! [77] 6.0% for-loop [60] 91.9% [77] 111808(10.4%) 2044(0.2%) merge-egraph-nodes! ...p/src/core/egraph.rkt:153:0 update-leader! [91] 52.8% loop! [204] 14.5% for-loop [95] 12.7% enode-merge! [99] 6.1% merge-egraph-nodes! [77] 6.0% for-loop [97] 4.9% for-loop [123] 1.2% ------------------------------------------------------------------------------------------ loop [63] 45.9% argmin [62] 54.1% [78] 80922(7.5%) 360(0.0%) for-loop .../herbie/develop/src/programs.rkt:210:2 table-ref [181] 71.7% ...velop/src/common.rkt:47:2 [151] 23.7% ??? [142] 4.1% ------------------------------------------------------------------------------------------ substitute-e [79] 6.4% for-loop [60] 93.6% [79] 70064(6.5%) 2610(0.2%) substitute-e ...e/develop/src/core/ematch.rkt:71:0 mk-enode! [89] 86.8% substitute-e [79] 6.4% variable? [92] 2.1% ??? [128] 2.0% ------------------------------------------------------------------------------------------ generic-sort/key [65] 42.1% copying-mergesort [80] 57.9% [80] 18388(1.7%) 0(0.0%) copying-mergesort ...racket/private/sort.rkt:130:8 copying-mergesort [80] 57.9% loop [93] 31.0% jloop [10] 11.2% ------------------------------------------------------------------------------------------ gen-series! [66] 100.0% [81] 13652(1.3%) 0(0.0%) for-loop .../herbie/develop/src/mainloop.rkt:135:7 taylor-alt [96] 100.0% ------------------------------------------------------------------------------------------ loop [63] 23.3% argmin [62] 76.7% [82] 7196(0.7%) 0(0.0%) expression-cost .../develop/src/programs.rkt:209:0 compile [98] 100.0% ------------------------------------------------------------------------------------------ gen-rewrites! [67] 100.0% [83] 4938(0.5%) 0(0.0%) for-loop ...herbie/develop/src/mainloop.rkt:147:11 ??? [100] 100.0% ------------------------------------------------------------------------------------------ for-loop [70] 100.0% [84] 2180(0.2%) 2180(0.2%) for-loop ...bie/develop/src/core/regimes.rkt:258:8 ------------------------------------------------------------------------------------------ mterm->expr [74] 14.9% append-map [252] 85.1% [85] 2022(0.2%) 0(0.0%) free-variables ...e/develop/src/programs.rkt:102:0 ??? [128] 85.1% variable? [92] 14.9% ------------------------------------------------------------------------------------------ unpack245 [71] 100.0% [86] 1020(0.1%) 312(0.0%) maybe-cons-kwd ...ate/arrow-higher-order.rkt:498:0 arrow-higher-order:lnp [225] 69.4% ------------------------------------------------------------------------------------------ reduce-to-single! [69] 100.0% [87] 360(0.0%) 360(0.0%) for-loop ...rbie/develop/src/core/egraph.rkt:326:8 ------------------------------------------------------------------------------------------ for-loop [75] 22.5% run [21] 33.3% [88] 1055694(98.3%) 0(0.0%) ??? ...lects/racket/private/more-scheme.rkt:261:28 profile-thunk16 [1] 33.1% table-ref [181] 33.0% run-improve50 [2] 28.7% loop [103] 4.2% prepare-points [105] 1.1% ------------------------------------------------------------------------------------------ mk-enode-rec! [213] 0.9% substitute-e [79] 34.0% for-loop [60] 65.1% [89] 178852(16.7%) 12898(1.2%) mk-enode! ...bie/develop/src/core/egraph.rkt:102:0 new-enode [102] 89.8% hash-has-key? [135] 2.4% ------------------------------------------------------------------------------------------ match-e [61] 26.4% for-loop [76] 73.6% [90] 96728(9.0%) 3666(0.3%) for-loop ...rbie/develop/src/core/ematch.rkt:65:37 match-e [61] 88.1% ??? [107] 8.5% ------------------------------------------------------------------------------------------ for-loop [44] 14.2% merge-egraph-nodes! [77] 85.8% [91] 73682(6.9%) 7294(0.7%) update-leader! ...evelop/src/core/egraph.rkt:218:0 for-loop [104] 87.4% update-en-expr [219] 1.8% hash-ref! [205] 0.5% make-sequence [138] 0.4% ------------------------------------------------------------------------------------------ free-variables [85] 1.3% substitute-e [79] 14.5% match-e [61] 84.2% [92] 23068(2.1%) 360(0.0%) variable? ...e/develop/src/syntax/syntax.rkt:665:0 ??? [128] 98.4% ------------------------------------------------------------------------------------------ generic-sort/key [65] 22.8% ??? [48] 23.9% copying-mergesort [80] 53.4% [93] 19058(1.8%) 656(0.1%) loop ...ket/collects/racket/private/sort.rkt:97:12 ??? [127] 93.0% ??? [136] 3.5% ------------------------------------------------------------------------------------------ match-e [61] 18.7% list-cartesian-product [94] 18.9% for-loop [76] 62.4% [94] 14902(1.4%) 12648(1.2%) list-cartesian-product ...src/core/ematch.rkt:20:0 list-cartesian-product [94] 18.9% for-loop [110] 10.8% ------------------------------------------------------------------------------------------ merge-egraph-nodes! [77] 100.0% [95] 14242(1.3%) 11264(1.0%) for-loop ...rbie/develop/src/core/egraph.rkt:233:6 update-en-expr [219] 20.9% ------------------------------------------------------------------------------------------ for-loop [81] 100.0% [96] 13652(1.3%) 0(0.0%) taylor-alt ...es/herbie/develop/src/glue.rkt:134:0 for-loop [106] 100.0% ------------------------------------------------------------------------------------------ merge-egraph-nodes! [77] 100.0% [97] 9250(0.9%) 0(0.0%) for-loop ...bie/develop/src/core/egraph.rkt:201:10 merge-egraph-nodes! [77] 53.5% loop! [204] 46.5% ------------------------------------------------------------------------------------------ expression-cost [82] 100.0% [98] 7196(0.7%) 336(0.0%) compile ...s/herbie/develop/src/programs.rkt:186:0 hash-ref! [205] 95.3% ------------------------------------------------------------------------------------------ merge-egraph-nodes! [77] 100.0% [99] 6968(0.6%) 1328(0.1%) enode-merge! ...e/develop/src/core/enode.rkt:129:0 adopt-enode! [109] 66.6% custom-set-intersect! [111] 14.3% ------------------------------------------------------------------------------------------ for-loop [83] 100.0% [100] 4938(0.5%) 0(0.0%) ??? ...ies/herbie/develop/src/alternative.rkt:88:0 rewriter [108] 100.0% ------------------------------------------------------------------------------------------ for-loop [76] 100.0% [101] 2644(0.2%) 1004(0.1%) curry* ...racket/collects/racket/function.rkt:44:2 procedure-arity [262] 62.0% ------------------------------------------------------------------------------------------ mk-enode! [89] 100.0% [102] 160664(15.0%) 360(0.0%) new-enode ...erbie/develop/src/core/enode.rkt:97:0 type-of-enode-expr [112] 99.1% set [218] 0.6% ------------------------------------------------------------------------------------------ run-improve50 [2] 6.8% ??? [88] 93.2% [103] 91558(8.5%) 0(0.0%) loop ...htlies/herbie/develop/src/points.rkt:238:2 loop [114] 45.3% make-exacts* [120] 29.9% loop [122] 24.1% for-loop [118] 0.7% ------------------------------------------------------------------------------------------ update-leader! [91] 100.0% [104] 64398(6.0%) 1368(0.1%) for-loop ...rbie/develop/src/core/egraph.rkt:223:6 for-loop [113] 96.8% update-en-expr [219] 1.1% ------------------------------------------------------------------------------------------ run-improve50 [2] 6.9% ??? [88] 93.1% [105] 24154(2.2%) 0(0.0%) prepare-points ...bie/develop/src/points.rkt:214:0 make-exacts* [120] 37.4% loop [114] 36.3% loop [122] 26.3% ------------------------------------------------------------------------------------------ taylor-alt [96] 100.0% [106] 13652(1.3%) 0(0.0%) for-loop ...lies/herbie/develop/src/glue.rkt:139:6 ??? [136] 100.0% ------------------------------------------------------------------------------------------ for-loop [45] 7.2% for-loop [90] 92.8% [107] 9174(0.9%) 2026(0.2%) ??? ...ies/herbie/develop/src/core/ematch.rkt:50:5 for-loop [115] 77.9% ------------------------------------------------------------------------------------------ matcher [124] 46.2% ??? [100] 53.8% [108] 4938(0.5%) 0(0.0%) rewriter ...bie/develop/src/core/matcher.rkt:131:2 *rules* [116] 48.2% for-loop [117] 47.9% expression->type [186] 3.9% ------------------------------------------------------------------------------------------ enode-merge! [99] 100.0% [109] 4642(0.4%) 2036(0.2%) adopt-enode! ...e/develop/src/core/enode.rkt:105:0 custom-set-union [217] 56.1% ------------------------------------------------------------------------------------------ list-cartesian-product [94] 100.0% [110] 2254(0.2%) 2254(0.2%) for-loop ...erbie/develop/src/core/ematch.rkt:24:8 ------------------------------------------------------------------------------------------ enode-merge! [99] 100.0% [111] 998(0.1%) 998(0.1%) custom-set-intersect! ...ivate/set-types.rkt:269:0 ------------------------------------------------------------------------------------------ new-enode [102] 100.0% [112] 159288(14.8%) 3230(0.3%) type-of-enode-expr ...elop/src/core/enode.rkt:68:0 get-sigs [119] 98.0% ------------------------------------------------------------------------------------------ for-loop [104] 100.0% [113] 62308(5.8%) 678(0.1%) for-loop ...rbie/develop/src/core/egraph.rkt:224:8 hash-update! [121] 98.9% ------------------------------------------------------------------------------------------ prepare-points [105] 17.5% loop [103] 82.5% [114] 50236(4.7%) 0(0.0%) loop ...htlies/herbie/develop/src/points.rkt:158:2 make-exacts* [120] 67.5% loop [122] 31.8% loop [126] 0.7% ------------------------------------------------------------------------------------------ ??? [107] 100.0% [115] 7148(0.7%) 1956(0.2%) for-loop ...erbie/develop/src/core/ematch.rkt:51:7 ??? [128] 72.6% ------------------------------------------------------------------------------------------ rewriter [108] 100.0% [116] 3954(0.4%) 1318(0.1%) *rules* ...rbie/develop/src/syntax/rules.rkt:565:0 for-loop [123] 66.7% ------------------------------------------------------------------------------------------ rewriter [108] 100.0% [117] 3620(0.3%) 0(0.0%) for-loop ...ie/develop/src/core/matcher.rkt:134:10 matcher [124] 100.0% ------------------------------------------------------------------------------------------ loop [103] 100.0% [118] 672(0.1%) 0(0.0%) for-loop ...s/herbie/develop/src/points.rkt:255:26 ??? [125] 100.0% ------------------------------------------------------------------------------------------ type-of-enode-expr [112] 100.0% [119] 156058(14.5%) 4168(0.4%) get-sigs .../herbie/develop/src/type-check.rkt:5:0 ??? [142] 38.8% table-ref [181] 30.9% ...velop/src/common.rkt:47:2 [151] 14.0% ??? [128] 13.7% ------------------------------------------------------------------------------------------ prepare-points [105] 12.8% loop [103] 38.9% loop [114] 48.2% [120] 70264(6.5%) 0(0.0%) make-exacts* ...erbie/develop/src/points.rkt:138:0 loop [191] 57.2% eval-prog [173] 42.8% ------------------------------------------------------------------------------------------ for-loop [113] 100.0% [121] 61630(5.7%) 314(0.0%) hash-update! ...ket/private/more-scheme.rkt:362:13 ??? [129] 99.5% ------------------------------------------------------------------------------------------ prepare-points [105] 14.3% loop [114] 36.0% loop [103] 49.7% [122] 44436(4.1%) 0(0.0%) loop ...htlies/herbie/develop/src/points.rkt:141:4 loop [191] 98.5% ??? [127] 1.5% ------------------------------------------------------------------------------------------ merge-egraph-nodes! [77] 33.5% *rules* [116] 66.5% [123] 3966(0.4%) 1364(0.1%) for-loop ...ies/herbie/develop/src/common.rkt:99:9 loop [131] 41.4% ormap [132] 16.0% update-en-expr [219] 8.2% ------------------------------------------------------------------------------------------ matcher [124] 17.0% for-loop [130] 33.0% for-loop [117] 50.0% [124] 3620(0.3%) 0(0.0%) matcher ...rbie/develop/src/core/matcher.rkt:167:2 rewriter [108] 48.8% for-loop [130] 33.0% matcher [124] 17.0% for-loop [17] 1.2% ------------------------------------------------------------------------------------------ for-loop [118] 100.0% [125] 672(0.1%) 314(0.0%) ??? ...ghtlies/herbie/develop/src/points.rkt:230:7 parse-loop12 [235] 53.3% ------------------------------------------------------------------------------------------ loop [114] 12.5% loop [126] 87.5% [126] 340(0.0%) 340(0.0%) loop ...htlies/herbie/develop/src/points.rkt:130:2 loop [126] 87.5% ------------------------------------------------------------------------------------------ ??? [48] 0.2% ??? [72] 0.4% loop [122] 0.4% jloop [10] 4.7% loop [93] 10.9% for-loop [172] 34.0% loop [191] 49.3% [127] 162192(15.1%) 1758(0.2%) ??? ...tlies/herbie/develop/src/programs.rkt:156:4 ??? [133] 95.2% ??? [147] 2.6% ??? [136] 1.2% ------------------------------------------------------------------------------------------ expression->type [186] 0.3% pattern-substitute [40] 0.3% table-ref [181] 0.6% f6 [175] 0.8% free-variables [85] 1.4% substitute-e [79] 2.7% ??? [233] 2.7% setfindf [30] 2.9% for-loop [115] 4.2% get-sigs [119] 17.3% variable? [92] 18.4% match-e [61] 21.9% finalize-iter! [64] 24.9% [128] 123464(11.5%) 40232(3.7%) ??? ...contract/private/arrow-val-first.rkt:357:18 hash-has-key? [135] 40.5% for-loop [137] 24.4% ??? [140] 1.8% atab-add-altns [141] 0.5% ??? [233] 0.3% ------------------------------------------------------------------------------------------ hash-update! [121] 100.0% [129] 61316(5.7%) 1338(0.1%) ??? ...s/herbie/develop/src/core/egraph.rkt:226:24 for-loop [134] 96.8% make-sequence [138] 1.0% ------------------------------------------------------------------------------------------ matcher [124] 100.0% [130] 3308(0.3%) 0(0.0%) for-loop ...ie/develop/src/core/matcher.rkt:183:21 matcher [124] 100.0% ------------------------------------------------------------------------------------------ for-loop [123] 100.0% [131] 1642(0.2%) 0(0.0%) loop ...ket/collects/racket/private/map.rkt:112:23 flag-set? [139] 100.0% ------------------------------------------------------------------------------------------ for-loop [123] 100.0% [132] 634(0.1%) 0(0.0%) ormap ...et/collects/racket/private/map.rkt:105:13 flag-set? [139] 100.0% ------------------------------------------------------------------------------------------ ??? [127] 100.0% [133] 154364(14.4%) 69262(6.4%) ??? ...acket/collects/racket/private/kw.rkt:444:14 ??? [245] 28.2% ??? [144] 12.9% ??? [145] 6.9% bf* [146] 3.6% ...higher-order.rkt:346:33 [149] 1.6% ??? [240] 1.1% parse-loop12 [235] 0.7% ------------------------------------------------------------------------------------------ ??? [129] 100.0% [134] 59364(5.5%) 47926(4.5%) for-loop ...bie/develop/src/core/egraph.rkt:227:26 update-en-expr [219] 19.3% ------------------------------------------------------------------------------------------ mk-enode! [89] 7.7% ??? [128] 92.3% [135] 55180(5.1%) 15210(1.4%) hash-has-key? ...et/private/more-scheme.rkt:368:13 ??? [192] 65.9% ??? [196] 6.6% ------------------------------------------------------------------------------------------ ??? [16] 0.8% ??? [136] 0.9% jloop [10] 1.5% loop [93] 1.6% ??? [127] 4.6% ??? [140] 5.4% for-loop [172] 8.0% loop [191] 10.2% loop [28] 10.5% table-ref [181] 11.0% for-loop [106] 11.3% f6 [175] 33.4% [136] 41250(3.8%) 324(0.0%) ??? ...tract/private/arrow-higher-order.rkt:342:33 table-ref [181] 54.0% approximate9 [8] 11.3% hash-ref! [205] 10.5% ??? [233] 7.2% best-alt [148] 5.8% ...velop/src/common.rkt:47:2 [151] 5.4% ??? [142] 1.5% ??? [147] 0.9% ??? [136] 0.9% ??? [245] 0.9% ------------------------------------------------------------------------------------------ ??? [128] 100.0% [137] 31066(2.9%) 0(0.0%) for-loop ...ie/develop/src/core/alt-table.rkt:51:2 atab-add-altn [143] 100.0% ------------------------------------------------------------------------------------------ update-leader! [91] 14.1% ??? [129] 26.5% for-loop [46] 29.2% reduce-to-single! [69] 30.2% [138] 2320(0.2%) 1986(0.2%) make-sequence ...ects/racket/private/for.rkt:509:2 ??? [150] 14.4% ------------------------------------------------------------------------------------------ ormap [132] 27.9% loop [131] 72.1% [139] 2276(0.2%) 646(0.1%) flag-set? ...es/herbie/develop/src/config.rkt:34:0 return/no-unsupplied [260] 57.9% ??? [194] 13.7% ------------------------------------------------------------------------------------------ ??? [128] 100.0% [140] 2232(0.2%) 0(0.0%) ??? .../herbie/develop/src/core/alt-table.rkt:54:0 ??? [136] 100.0% ------------------------------------------------------------------------------------------ ??? [128] 100.0% [141] 636(0.1%) 0(0.0%) atab-add-altns ...elop/src/core/alt-table.rkt:50:0 atab-add-altn [143] 100.0% ------------------------------------------------------------------------------------------ f6 [175] 0.5% ??? [136] 1.0% for-loop [78] 5.1% get-sigs [119] 93.5% [142] 64870(6.0%) 6654(0.6%) ??? ...ts/racket/contract/private/arr-i.rkt:804:10 ??? [154] 39.6% for-loop [152] 38.0% get/build-late-neg-projection [176] 11.0% ------------------------------------------------------------------------------------------ atab-add-altns [141] 2.0% for-loop [137] 98.0% [143] 31702(3.0%) 0(0.0%) atab-add-altn ...elop/src/core/alt-table.rkt:208:0 best-and-tied-at-points [153] 84.1% override-at-pnts [155] 14.8% hash-set-lsts [161] 1.1% ------------------------------------------------------------------------------------------ loop [191] 3.1% ??? [133] 96.9% [144] 20494(1.9%) 13304(1.2%) ??? ...herbie/develop/src/syntax/syntax.rkt:156:17 ??? [194] 19.4% return/no-unsupplied [260] 15.7% ------------------------------------------------------------------------------------------ ??? [133] 100.0% [145] 10640(1.0%) 10640(1.0%) ??? ...rivate/unconstrained-domain-arrow.rkt:40:13 ------------------------------------------------------------------------------------------ ??? [133] 100.0% [146] 5572(0.5%) 0(0.0%) bf* ...ath/private/bigfloat/bigfloat-mpfr.rkt:95:0 ??? [245] 100.0% ------------------------------------------------------------------------------------------ ??? [136] 8.6% ??? [127] 91.4% [147] 4542(0.4%) 330(0.0%) ??? ...contract/private/../../private/kw.rkt:761:9 real->bigfloat [156] 84.1% integer->bigfloat [160] 8.6% ------------------------------------------------------------------------------------------ ??? [136] 100.0% [148] 2530(0.2%) 0(0.0%) best-alt ...tlies/herbie/develop/src/glue.rkt:71:0 loop [157] 76.1% argmins [159] 23.9% ------------------------------------------------------------------------------------------ ??? [133] 100.0% [149] 2424(0.2%) 1354(0.1%) ...higher-order.rkt:346:33 (unknown source) ??? [207] 44.1% ------------------------------------------------------------------------------------------ make-sequence [138] 100.0% [150] 334(0.0%) 0(0.0%) ??? ...acket/collects/racket/private/for.rkt:429:7 custom-in-set [158] 100.0% ------------------------------------------------------------------------------------------ table-ref [181] 2.2% ??? [136] 5.0% for-loop [78] 43.1% get-sigs [119] 49.0% [151] 44514(4.1%) 15816(1.5%) ...velop/src/common.rkt:47:2 ...e/arr-i.rkt:906:19 ??? [163] 33.0% ??? [164] 30.7% ------------------------------------------------------------------------------------------ for-loop [206] 19.2% ??? [142] 80.8% [152] 30522(2.8%) 4540(0.4%) for-loop ...racket/contract/private/hash.rkt:239:6 ??? [207] 84.0% ??? [240] 1.1% ------------------------------------------------------------------------------------------ atab-add-altn [143] 100.0% [153] 26652(2.5%) 0(0.0%) best-and-tied-at-points ...ore/alt-table.rkt:122:0 errors [168] 96.1% for-loop [166] 3.9% ------------------------------------------------------------------------------------------ ??? [142] 100.0% [154] 25694(2.4%) 670(0.1%) ??? ...ects/racket/contract/private/hash.rkt:217:4 ??? [162] 97.4% ------------------------------------------------------------------------------------------ atab-add-altn [143] 100.0% [155] 4692(0.4%) 0(0.0%) override-at-pnts ...p/src/core/alt-table.rkt:145:0 errors [168] 92.5% loop [167] 7.5% ------------------------------------------------------------------------------------------ ??? [147] 100.0% [156] 3822(0.4%) 3138(0.3%) real->bigfloat .../private/bigfloat/mpfr.rkt:451:0 ??? [265] 17.9% ------------------------------------------------------------------------------------------ extract-alt [52] 34.6% best-alt [148] 65.4% [157] 2944(0.3%) 0(0.0%) loop ...htlies/herbie/develop/src/common.rkt:153:2 composed [165] 100.0% ------------------------------------------------------------------------------------------ ??? [150] 31.9% match-e [61] 68.1% [158] 1048(0.1%) 1048(0.1%) custom-in-set ...acket/private/set-types.rkt:577:0 ------------------------------------------------------------------------------------------ extract-alt [52] 34.8% best-alt [148] 65.2% [159] 926(0.1%) 0(0.0%) argmins ...ies/herbie/develop/src/common.rkt:152:0 composed [165] 100.0% ------------------------------------------------------------------------------------------ ??? [147] 100.0% [160] 390(0.0%) 390(0.0%) integer->bigfloat ...ivate/bigfloat/mpfr.rkt:399:0 ------------------------------------------------------------------------------------------ atab-add-altn [143] 100.0% [161] 358(0.0%) 0(0.0%) hash-set-lsts ...elop/src/core/alt-table.rkt:111:0 loop [167] 100.0% ------------------------------------------------------------------------------------------ ??? [154] 100.0% [162] 25024(2.3%) 1000(0.1%) ??? ...ects/racket/contract/private/list.rkt:169:2 ??? [169] 96.0% ------------------------------------------------------------------------------------------ ...velop/src/common.rkt:47:2 [151] 100.0% [163] 14706(1.4%) 3072(0.3%) ??? ...s/racket/contract/private/arr-i.rkt:1268:39 ??? [194] 43.4% return/no-unsupplied [260] 22.2% assoc-ref [170] 13.5% ------------------------------------------------------------------------------------------ for-loop [226] 6.4% ??? [207] 14.7% ...velop/src/common.rkt:47:2 [151] 78.9% [164] 13686(1.3%) 2348(0.2%) ??? ...ects/racket/contract/private/list.rkt:342:4 ??? [207] 69.1% ??? [233] 12.5% ??? [229] 9.8% ------------------------------------------------------------------------------------------ argmins [159] 17.6% f6 [175] 26.4% loop [157] 56.0% [165] 5256(0.5%) 0(0.0%) composed ...ollects/racket/private/list.rkt:321:16 errors [168] 73.6% f6 [175] 20.0% parse-loop12 [235] 6.4% ------------------------------------------------------------------------------------------ best-and-tied-at-points [153] 100.0% [166] 1034(0.1%) 360(0.0%) for-loop .../develop/src/core/alt-table.rkt:124:16 ??? [171] 65.2% ------------------------------------------------------------------------------------------ override-at-pnts [155] 49.7% hash-set-lsts [161] 50.3% [167] 712(0.1%) 712(0.1%) loop ...erbie/develop/src/core/alt-table.rkt:106:2 ------------------------------------------------------------------------------------------ composed [165] 4.7% override-at-pnts [155] 5.3% option-on-expr [5] 14.0% best-and-tied-at-points [153] 31.4% loop [191] 44.5% [168] 81548(7.6%) 0(0.0%) errors ...lies/herbie/develop/src/points.rkt:271:0 for-loop [172] 79.3% eval-prog [173] 20.7% ------------------------------------------------------------------------------------------ ??? [162] 100.0% [169] 24024(2.2%) 0(0.0%) ??? ...ects/racket/contract/private/list.rkt:678:5 for-loop [174] 100.0% ------------------------------------------------------------------------------------------ ??? [163] 100.0% [170] 1988(0.2%) 1988(0.2%) assoc-ref ...collects/racket/private/dict.rkt:56:0 ------------------------------------------------------------------------------------------ for-loop [166] 100.0% [171] 674(0.1%) 674(0.1%) ??? ...ket/collects/racket/private/for.rkt:1151:14 ------------------------------------------------------------------------------------------ errors [168] 100.0% [172] 64700(6.0%) 3886(0.4%) for-loop ...es/herbie/develop/src/points.rkt:274:4 ??? [127] 85.4% ??? [136] 5.1% ulp-difference [178] 3.0% ??? [214] 0.5% ------------------------------------------------------------------------------------------ sort-context-on-expr [26] 0.7% option-on-expr [5] 1.3% point->alt [54] 2.0% errors [168] 34.4% make-exacts* [120] 61.5% [173] 48914(4.6%) 3374(0.3%) eval-prog ...herbie/develop/src/programs.rkt:150:0 hash-ref! [205] 57.1% f6 [175] 33.2% ??? [179] 2.0% go [180] 0.7% ------------------------------------------------------------------------------------------ ??? [169] 100.0% [174] 24024(2.2%) 7580(0.7%) for-loop ...racket/contract/private/list.rkt:680:9 add-list-context [177] 47.9% get/build-late-neg-projection [176] 20.5% ------------------------------------------------------------------------------------------ for-loop [73] 0.1% ??? [197] 0.1% parse-loop12 [235] 0.1% approximate9 [8] 0.2% composed [165] 0.2% for-loop [199] 0.7% append-map [252] 0.9% map [183] 1.5% hash-ref! [205] 2.0% eval-const-expr [32] 2.0% eval-prog [173] 2.6% simplify [223] 3.1% f6 [175] 13.0% split-table [47] 73.6% [175] 99976(9.3%) 956(0.1%) f6 ...et/collects/racket/match/compiler.rkt:507:40 loop [191] 70.0% f6 [175] 13.0% map [183] 5.6% option-on-expr [5] 3.6% ??? [136] 2.3% ??? [185] 1.4% append-map [252] 1.2% table-ref [181] 0.4% ??? [128] 0.4% make-keyword-procedure [236] 0.3% expression->type [186] 0.3% composed [165] 0.3% ??? [142] 0.3% loop [19] 0.1% exprs-to-branch-on [18] 0.1% ??? [214] 0.0% ------------------------------------------------------------------------------------------ unconstrained-domain->-projection [188] 2.5% ??? [184] 20.8% ??? [142] 34.0% for-loop [174] 40.8% [176] 12080(1.1%) 2886(0.3%) get/build-late-neg-projection ...te/guts.rkt:691:0 ??? [182] 51.8% ??? [184] 28.9% unconstrained-domain->-projection [188] 2.5% ------------------------------------------------------------------------------------------ for-loop [174] 100.0% [177] 11514(1.1%) 11514(1.1%) add-list-context ...ontract/private/list.rkt:752:0 ------------------------------------------------------------------------------------------ for-loop [172] 100.0% [178] 1962(0.2%) 1962(0.2%) ulp-difference ...erbie/develop/src/float.rkt:19:0 ------------------------------------------------------------------------------------------ eval-prog [173] 100.0% [179] 1002(0.1%) 332(0.0%) ??? ...collects/racket/private/qq-and-or.rkt:155:9 ??? [187] 66.9% ------------------------------------------------------------------------------------------ eval-prog [173] 100.0% [180] 360(0.0%) 0(0.0%) go .../collects/racket/private/qq-and-or.rkt:50:20 loop [189] 100.0% ------------------------------------------------------------------------------------------ f6 [175] 0.0% get-sigs [119] 1.9% for-loop [78] 2.3% ??? [136] 2.8% table-ref [181] 8.5% for-loop [190] 38.5% ??? [88] 45.9% [181] 836808(77.9%) 39666(3.7%) table-ref .../racket/private/norm-define.rkt:53:83 iterate-egraph!13 [3] 41.3% for-loop [190] 38.5% table-ref [181] 8.5% loop [4] 4.5% ??? [192] 3.0% ??? [136] 0.7% ??? [194] 0.4% return/no-unsupplied [260] 0.2% ...velop/src/common.rkt:47:2 [151] 0.1% mk-egraph [198] 0.1% ??? [128] 0.1% list-member? [193] 0.0% ??? [201] 0.0% dict? [247] 0.0% ??? [196] 0.0% ??? [207] 0.0% ------------------------------------------------------------------------------------------ get/build-late-neg-projection [176] 100.0% [182] 8216(0.8%) 1328(0.1%) ??? ...cts/racket/contract/private/prop.rkt:314:12 build-compound-type-name [195] 83.8% ------------------------------------------------------------------------------------------ option-on-expr [5] 4.2% parse-loop12 [235] 19.6% f6 [175] 76.2% [183] 7348(0.7%) 310(0.0%) map ...acket/collects/racket/private/map.rkt:20:13 parse-loop12 [235] 26.4% f6 [175] 22.7% ??? [197] 19.2% loop [191] 13.8% simplify* [251] 8.2% simplify-node [200] 2.5% loop [203] 1.2% ??? [202] 1.0% make-multiplication-node [20] 0.8% ------------------------------------------------------------------------------------------ get/build-late-neg-projection [176] 100.0% [184] 6222(0.6%) 978(0.1%) ??? ...ects/racket/contract/private/hash.rkt:211:2 get/build-late-neg-projection [176] 84.3% ------------------------------------------------------------------------------------------ f6 [175] 100.0% [185] 1658(0.2%) 328(0.0%) ??? ...tract/private/arrow-higher-order.rkt:336:46 ??? [233] 80.2% ------------------------------------------------------------------------------------------ f6 [175] 11.3% loop [19] 16.7% for-loop [199] 28.0% rewriter [108] 43.9% [186] 976(0.1%) 0(0.0%) expression->type ...evelop/src/type-check.rkt:45:0 for-loop [199] 88.7% ??? [128] 11.3% ------------------------------------------------------------------------------------------ ??? [179] 100.0% [187] 670(0.1%) 670(0.1%) ??? ...ollects/racket/private/qq-and-or.rkt:164:21 ------------------------------------------------------------------------------------------ get/build-late-neg-projection [176] 100.0% [188] 614(0.1%) 0(0.0%) unconstrained-domain->-projection ...rrow.rkt:60:0 get/build-late-neg-projection [176] 100.0% ------------------------------------------------------------------------------------------ go [180] 25.0% loop [189] 75.0% [189] 360(0.0%) 360(0.0%) loop ...llects/racket/private/qq-and-or.rkt:101:61 loop [189] 75.0% ------------------------------------------------------------------------------------------ table-ref [181] 100.0% [190] 671436(62.5%) 0(0.0%) for-loop ...ie/develop/src/core/simplify.rkt:66:12 table-ref [181] 99.9% ??? [51] 0.1% ??? [214] 0.0% ------------------------------------------------------------------------------------------ make-exacts* [120] 0.2% map [183] 0.2% loop [122] 0.2% match-e [61] 0.4% parse-loop12 [235] 0.5% map-enodes [27] 0.8% for-loop [76] 1.6% option-on-expr [5] 3.2% loop! [204] 5.7% ??? [6] 8.8% f6 [175] 9.1% loop [191] 69.3% [191] 292924(27.3%) 7834(0.7%) loop ...cket/collects/racket/private/map.rkt:25:19 loop [191] 69.3% option-on-expr [5] 9.1% hash-ref! [205] 8.8% loop! [204] 5.4% errors [168] 3.2% for-loop [7] 0.8% foldl [210] 0.6% parse-loop12 [235] 0.5% ??? [127] 0.4% ??? [197] 0.3% ??? [136] 0.1% ??? [245] 0.0% ??? [144] 0.0% ------------------------------------------------------------------------------------------ hash-has-key? [135] 33.8% table-ref [181] 66.2% [192] 107452(10.0%) 46534(4.3%) ??? ...ects/racket/contract/private/list.rkt:737:4 for-loop [206] 38.8% ??? [221] 10.9% arrow-higher-order:lnp [225] 3.6% successfully-got-the-right-kind-of-function [227] 1.9% ??? [207] 1.5% ------------------------------------------------------------------------------------------ table-ref [181] 1.5% for-loop [60] 98.5% [193] 24414(2.3%) 684(0.1%) list-member? ...llects/racket/private/set.rkt:24:0 loop [208] 89.4% member [212] 7.8% ------------------------------------------------------------------------------------------ flag-set? [139] 2.0% ??? [144] 25.8% table-ref [181] 30.9% ??? [163] 41.3% [194] 15444(1.4%) 2928(0.3%) ??? ...racket/collects/racket/private/kw.rkt:761:9 ??? [209] 58.7% ??? [233] 22.3% ------------------------------------------------------------------------------------------ contract-struct-name [211] 7.2% ??? [182] 92.8% [195] 6888(0.6%) 3588(0.3%) build-compound-type-name ...private/guts.rkt:448:0 contract-struct-name [211] 52.7% ------------------------------------------------------------------------------------------ table-ref [181] 14.6% hash-has-key? [135] 85.4% [196] 4252(0.4%) 4252(0.4%) ??? ...ects/racket/contract/private/hash.rkt:245:7 ------------------------------------------------------------------------------------------ map [183] 41.9% loop [191] 58.1% [197] 2350(0.2%) 0(0.0%) ??? ...ket/collects/racket/private/list.rkt:323:18 hash-ref! [205] 85.0% f6 [175] 15.0% ------------------------------------------------------------------------------------------ table-ref [181] 100.0% [198] 1624(0.2%) 0(0.0%) mk-egraph ...bie/develop/src/core/egraph.rkt:131:0 mk-enode-rec! [213] 100.0% ------------------------------------------------------------------------------------------ expression->type [186] 100.0% [199] 976(0.1%) 0(0.0%) for-loop ...herbie/develop/src/type-check.rkt:52:5 f6 [175] 66.3% expression->type [186] 33.7% ------------------------------------------------------------------------------------------ map [183] 100.0% [200] 362(0.0%) 0(0.0%) simplify-node .../develop/src/core/reduce.rkt:50:0 gather-additive-terms6 [215] 100.0% ------------------------------------------------------------------------------------------ table-ref [181] 100.0% [201] 358(0.0%) 0(0.0%) ??? ...-racket/utils/simple-result-arrow.rkt:60:15 ??? [265] 100.0% ------------------------------------------------------------------------------------------ map [183] 100.0% [202] 358(0.0%) 0(0.0%) ??? ...ies/herbie/develop/src/core/reduce.rkt:61:5 for-loop [216] 100.0% ------------------------------------------------------------------------------------------ map [183] 12.5% loop [203] 87.5% [203] 344(0.0%) 0(0.0%) loop ...cket/collects/racket/private/map.rkt:36:19 loop [203] 87.5% ??? [16] 12.5% ------------------------------------------------------------------------------------------ for-loop [97] 2.0% merge-egraph-nodes! [77] 10.2% loop [191] 27.5% for-loop [60] 60.3% [204] 136780(12.7%) 23374(2.2%) loop! ...s/herbie/develop/src/core/enode.rkt:192:2 custom-set-union [217] 42.4% loop [191] 30.6% set [218] 12.7% update-en-expr [219] 4.8% ------------------------------------------------------------------------------------------ simplify* [251] 0.2% for-loop [38] 0.2% for-loop [53] 0.3% for-loop [36] 0.5% update-leader! [91] 0.7% for-loop [249] 0.9% ??? [49] 1.2% ??? [12] 1.3% for-loop [31] 2.8% ??? [197] 2.8% for-loop [29] 4.7% compile [98] 5.7% ??? [224] 6.9% ??? [136] 6.9% ??? [6] 7.8% eval-prog [173] 18.0% loop [191] 37.0% [205] 50832(4.7%) 7624(0.7%) hash-ref! ...racket/private/more-scheme.rkt:373:13 ??? [6] 45.5% bigfloat-hash [220] 17.6% simplify [223] 7.7% ??? [224] 6.9% ??? [9] 4.7% ??? [11] 4.0% parse-loop12 [235] 2.2% ??? [12] 1.8% f6 [175] 1.7% ??? [13] 0.9% ??? [15] 0.3% ??? [14] 0.3% ------------------------------------------------------------------------------------------ ??? [192] 100.0% [206] 41720(3.9%) 19952(1.9%) for-loop ...acket/contract/private/list.rkt:743:12 ??? [221] 29.6% for-loop [152] 14.0% successfully-got-the-right-kind-of-function [227] 3.9% ??? [229] 1.6% ??? [233] 1.5% arrow-higher-order:lnp [225] 1.5% ------------------------------------------------------------------------------------------ table-ref [181] 0.8% unpack245 [71] 0.8% ...higher-order.rkt:346:33 [149] 2.6% ??? [192] 3.9% ??? [164] 29.9% for-loop [152] 62.0% [207] 41344(3.8%) 8584(0.8%) ??? ...cts/racket/contract/private/list.rkt:187:10 ??? [222] 56.5% ??? [164] 9.7% for-loop [226] 9.1% ??? [240] 2.3% ??? [233] 1.7% ------------------------------------------------------------------------------------------ list-member? [193] 100.0% [208] 21834(2.0%) 21834(2.0%) loop (unknown source) ------------------------------------------------------------------------------------------ ??? [194] 100.0% [209] 9070(0.8%) 7758(0.7%) ??? ...s/racket/contract/private/arr-i.rkt:1233:27 ??? [230] 14.5% ------------------------------------------------------------------------------------------ for-loop [76] 16.6% loop [191] 83.4% [210] 4022(0.4%) 1358(0.1%) foldl ...et/collects/racket/private/list.rkt:229:4 merge2 [228] 66.2% ------------------------------------------------------------------------------------------ build-compound-type-name [195] 100.0% [211] 3960(0.4%) 3300(0.3%) contract-struct-name ...ract/private/prop.rkt:89:0 build-compound-type-name [195] 20.8% ------------------------------------------------------------------------------------------ list-member? [193] 100.0% [212] 1896(0.2%) 1896(0.2%) member (unknown source) ------------------------------------------------------------------------------------------ mk-egraph [198] 31.8% mk-enode-rec! [213] 68.2% [213] 1624(0.2%) 0(0.0%) mk-enode-rec! ...develop/src/core/egraph.rkt:122:0 mk-enode-rec! [213] 68.2% mk-enode! [89] 31.8% ------------------------------------------------------------------------------------------ f6 [175] 31.9% for-loop [190] 33.5% for-loop [172] 34.6% [214] 960(0.1%) 628(0.1%) ??? ...tract/private/arrow-higher-order.rkt:145:21 ??? [240] 34.6% ------------------------------------------------------------------------------------------ simplify-node [200] 100.0% [215] 362(0.0%) 362(0.0%) gather-additive-terms6 ...src/core/reduce.rkt:72:0 ------------------------------------------------------------------------------------------ ??? [202] 100.0% [216] 358(0.0%) 0(0.0%) for-loop ...erbie/develop/src/core/reduce.rkt:62:7 pattern-match [231] 100.0% ------------------------------------------------------------------------------------------ adopt-enode! [109] 4.1% loop! [204] 95.9% [217] 64028(6.0%) 17506(1.6%) custom-set-union ...et/private/set-types.rkt:168:0 for-loop [232] 63.5% for-loop [238] 9.2% ------------------------------------------------------------------------------------------ new-enode [102] 2.9% loop! [204] 97.1% [218] 35068(3.3%) 35068(3.3%) set ...collects/racket/private/set-types.rkt:981:0 ------------------------------------------------------------------------------------------ for-loop [123] 1.1% for-loop [104] 2.4% update-leader! [91] 4.2% for-loop [95] 9.8% for-loop [134] 37.6% loop! [204] 44.9% [219] 30400(2.8%) 29404(2.7%) update-en-expr ...evelop/src/core/egraph.rkt:212:0 for-loop [243] 3.3% ------------------------------------------------------------------------------------------ hash-ref! [205] 100.0% [220] 27262(2.5%) 326(0.0%) bigfloat-hash ...h/private/bigfloat/mpfr.rkt:165:0 bfcanonicalize [234] 57.2% sig+exp->bigfloat [237] 37.6% bigfloat->sig+exp [250] 3.9% ------------------------------------------------------------------------------------------ ??? [192] 48.6% for-loop [206] 51.4% [221] 24062(2.2%) 13024(1.2%) ??? ...private/unconstrained-domain-arrow.rkt:74:4 make-keyword-procedure [236] 45.9% ------------------------------------------------------------------------------------------ ??? [207] 100.0% [222] 23352(2.2%) 944(0.1%) ??? ...ects/racket/contract/private/list.rkt:686:7 ??? [233] 94.6% ??? [240] 1.4% ------------------------------------------------------------------------------------------ for-loop [38] 2.5% hash-ref! [205] 97.5% [223] 13652(1.3%) 0(0.0%) simplify ...erbie/develop/src/core/reduce.rkt:16:0 parse-loop12 [235] 53.4% f6 [175] 41.7% debug-print [244] 2.5% simplify* [251] 2.4% ------------------------------------------------------------------------------------------ hash-ref! [205] 100.0% [224] 12978(1.2%) 0(0.0%) ??? ...es/herbie/develop/src/core/taylor.rkt:44:15 hash-ref! [205] 100.0% ------------------------------------------------------------------------------------------ for-loop [206] 12.2% maybe-cons-kwd [86] 13.5% ??? [192] 74.3% [225] 5230(0.5%) 1302(0.1%) arrow-higher-order:lnp ...w-higher-order.rkt:597:7 ??? [239] 75.1% ------------------------------------------------------------------------------------------ ??? [207] 100.0% [226] 3744(0.3%) 2002(0.2%) for-loop ...acket/contract/private/list.rkt:190:15 ??? [164] 46.5% ------------------------------------------------------------------------------------------ for-loop [206] 44.5% ??? [192] 55.5% [227] 3618(0.3%) 2316(0.2%) successfully-got-the-right-kind-of-function ...9:4 arity-checking-wrapper [242] 36.0% ------------------------------------------------------------------------------------------ foldl [210] 100.0% [228] 2664(0.2%) 2664(0.2%) merge2 .../herbie/develop/src/core/ematch.rkt:31:0 ------------------------------------------------------------------------------------------ for-loop [206] 33.5% ??? [164] 66.5% [229] 2014(0.2%) 334(0.0%) ??? ...ects/racket/contract/private/hash.rkt:222:6 check-hash/c [241] 83.4% ------------------------------------------------------------------------------------------ ??? [209] 100.0% [230] 1312(0.1%) 1312(0.1%) ??? ...ects/racket/contract/private/prop.rkt:256:4 ------------------------------------------------------------------------------------------ for-loop [216] 100.0% [231] 358(0.0%) 358(0.0%) pattern-match ...develop/src/core/matcher.rkt:48:0 ------------------------------------------------------------------------------------------ custom-set-union [217] 100.0% [232] 40636(3.8%) 12638(1.2%) for-loop ...cts/racket/private/set-types.rkt:174:3 for-loop [246] 68.9% ------------------------------------------------------------------------------------------ ??? [128] 1.0% for-loop [206] 1.8% ??? [207] 2.0% ??? [185] 3.8% ??? [136] 8.1% ??? [164] 9.9% ??? [194] 10.0% ??? [222] 63.4% [233] 34586(3.2%) 25080(2.3%) ??? ...ects/racket/contract/private/guts.rkt:644:8 ??? [128] 12.0% contract? [248] 8.8% dict? [247] 7.2% ------------------------------------------------------------------------------------------ bigfloat-hash [220] 100.0% [234] 15602(1.5%) 14280(1.3%) bfcanonicalize .../private/bigfloat/mpfr.rkt:155:0 bigfloat->sig+exp [250] 8.5% ------------------------------------------------------------------------------------------ composed [165] 1.2% ??? [125] 2.6% loop [191] 4.1% ??? [133] 8.0% for-loop [33] 9.1% map [183] 10.5% hash-ref! [205] 14.5% simplify [223] 23.9% parse-loop12 [235] 26.0% [235] 13776(1.3%) 8730(0.8%) parse-loop12 ...s/racket/match/compiler.rkt:418:15 parse-loop12 [235] 26.0% loop [191] 15.8% for-loop [249] 9.1% map [183] 6.3% f6 [175] 3.8% parse-app [257] 2.5% simplify* [251] 1.4% ??? [245] 1.2% append-map [252] 1.2% ------------------------------------------------------------------------------------------ f6 [175] 3.0% ??? [221] 97.0% [236] 11382(1.1%) 11382(1.1%) make-keyword-procedure ...ket/private/kw.rkt:260:4 ------------------------------------------------------------------------------------------ bigfloat-hash [220] 100.0% [237] 10258(1.0%) 9286(0.9%) sig+exp->bigfloat ...ivate/bigfloat/mpfr.rkt:385:0 integer->mpz [255] 9.5% ------------------------------------------------------------------------------------------ custom-set-union [217] 100.0% [238] 5886(0.5%) 5886(0.5%) for-loop ...cts/racket/private/set-types.rkt:152:2 ------------------------------------------------------------------------------------------ arrow-higher-order:lnp [225] 100.0% [239] 3928(0.4%) 3928(0.4%) ??? ...et/contract/private/arity-checking.rkt:19:2 ------------------------------------------------------------------------------------------ ??? [222] 8.9% ??? [214] 9.3% for-loop [152] 9.7% ??? [207] 26.5% ??? [133] 45.6% [240] 3582(0.3%) 2336(0.2%) ??? ...ects/racket/contract/private/prop.rkt:493:4 ??? [253] 34.8% ------------------------------------------------------------------------------------------ ??? [229] 100.0% [241] 1680(0.2%) 648(0.1%) check-hash/c ...ket/contract/private/hash.rkt:83:0 flat-contract? [254] 61.4% ------------------------------------------------------------------------------------------ successfully-got-the-right-kind-of-function [227]100.0% [242] 1302(0.1%) 334(0.0%) arity-checking-wrapper ...w-higher-order.rkt:402:0 matches-arity-exactly? [256] 74.3% ------------------------------------------------------------------------------------------ update-en-expr [219] 100.0% [243] 996(0.1%) 996(0.1%) for-loop ...rbie/develop/src/core/egraph.rkt:214:6 ------------------------------------------------------------------------------------------ simplify [223] 100.0% [244] 336(0.0%) 336(0.0%) debug-print .../herbie/develop/src/debug.rkt:107:0 ------------------------------------------------------------------------------------------ parse-loop12 [235] 0.7% loop [191] 1.3% ??? [136] 1.5% bf* [146] 11.0% ??? [133] 85.6% [245] 50884(4.7%) 21516(2.0%) ??? ...-racket/utils/simple-result-arrow.rkt:39:12 bfsub [258] 30.0% bfexp [259] 26.2% ------------------------------------------------------------------------------------------ for-loop [232] 100.0% [246] 27998(2.6%) 27998(2.6%) for-loop ...cts/racket/private/set-types.rkt:178:5 ------------------------------------------------------------------------------------------ table-ref [181] 21.0% ??? [233] 79.0% [247] 3140(0.3%) 3140(0.3%) dict? ...ollects/racket/private/generic.rkt:146:11 ------------------------------------------------------------------------------------------ ??? [233] 100.0% [248] 3058(0.3%) 2392(0.2%) contract? ...acket/contract/private/guts.rkt:109:0 coerce-contract/f4 [263] 21.8% ------------------------------------------------------------------------------------------ parse-loop12 [235] 100.0% [249] 2432(0.2%) 0(0.0%) for-loop ...bie/develop/src/core/taylor.rkt:490:59 hash-ref! [205] 100.0% ------------------------------------------------------------------------------------------ bigfloat-hash [220] 44.9% bfcanonicalize [234] 55.1% [250] 2398(0.2%) 352(0.0%) bigfloat->sig+exp ...ivate/bigfloat/mpfr.rkt:370:0 size+limbs->integer [261] 85.3% ------------------------------------------------------------------------------------------ simplify [223] 16.6% parse-loop12 [235] 33.4% map [183] 50.1% [251] 1966(0.2%) 982(0.1%) simplify* ...rbie/develop/src/core/reduce.rkt:31:0 return/no-unsupplied [260] 33.3% hash-ref! [205] 16.8% ------------------------------------------------------------------------------------------ parse-loop12 [235] 6.5% f6 [175] 93.5% [252] 1720(0.2%) 0(0.0%) append-map ...acket/collects/racket/list.rkt:565:2 f6 [175] 69.5% free-variables [85] 30.5% ------------------------------------------------------------------------------------------ ??? [240] 100.0% [253] 1246(0.1%) 926(0.1%) ??? ...lects/racket/contract/private/orc.rkt:83:14 ??? [264] 25.7% ------------------------------------------------------------------------------------------ check-hash/c [241] 100.0% [254] 1032(0.1%) 1032(0.1%) flat-contract? .../contract/private/guts.rkt:111:0 ------------------------------------------------------------------------------------------ sig+exp->bigfloat [237] 100.0% [255] 972(0.1%) 972(0.1%) integer->mpz ...math/private/bigfloat/gmp.rkt:87:0 ------------------------------------------------------------------------------------------ arity-checking-wrapper [242] 100.0% [256] 968(0.1%) 658(0.1%) matches-arity-exactly? ...te/arrow-common.rkt:70:0 procedure-arity [262] 32.0% ------------------------------------------------------------------------------------------ parse-loop12 [235] 48.7% [257] 714(0.1%) 714(0.1%) parse-app .../collects/racket/private/kw.rkt:951:2 ------------------------------------------------------------------------------------------ ??? [245] 100.0% [258] 15254(1.4%) 10854(1.0%) bfsub ...-lib/math/private/bigfloat/mpfr.rkt:819:4 ??? [265] 28.8% ------------------------------------------------------------------------------------------ ??? [245] 100.0% [259] 13354(1.2%) 8642(0.8%) bfexp ...-lib/math/private/bigfloat/mpfr.rkt:616:4 ??? [265] 35.3% ------------------------------------------------------------------------------------------ simplify* [251] 5.4% flag-set? [139] 10.9% ??? [144] 26.5% ??? [163] 26.9% table-ref [181] 30.3% [260] 12130(1.1%) 8584(0.8%) return/no-unsupplied ...ct/private/arr-i.rkt:533:0 filter [266] 29.2% ------------------------------------------------------------------------------------------ bigfloat->sig+exp [250] 100.0% [261] 2046(0.2%) 2046(0.2%) size+limbs->integer ...vate/bigfloat/gmp.rkt:103:0 ------------------------------------------------------------------------------------------ matches-arity-exactly? [256] 15.9% curry* [101] 84.1% [262] 1950(0.2%) 1950(0.2%) procedure-arity ...ket/private/norm-arity.rkt:7:27 ------------------------------------------------------------------------------------------ contract? [248] 100.0% [263] 666(0.1%) 666(0.1%) coerce-contract/f4 ...tract/private/guts.rkt:299:0 ------------------------------------------------------------------------------------------ ??? [253] 100.0% [264] 320(0.0%) 320(0.0%) ??? ...ects/racket/contract/private/list.rkt:141:5 ------------------------------------------------------------------------------------------ ??? [201] 3.5% real->bigfloat [156] 6.7% bfsub [258] 43.3% bfexp [259] 46.4% [265] 10154(0.9%) 10154(0.9%) ??? .../share/racket/collects/ffi/unsafe.rkt:861:4 ------------------------------------------------------------------------------------------ for-loop [76] 28.0% return/no-unsupplied [260] 72.0% [266] 4928(0.5%) 4928(0.5%) filter ...t/collects/racket/private/list.rkt:256:2 ------------------------------------------------------------------------------------------