Profiling results ----------------- Total cpu time observed: 1953428ms (out of 1958260ms) Number of samples taken: 10349 (once every 189ms) (Hiding functions with self<1.0% and local<2.0%: 33 of 304 hidden) =========================================================================================== Caller Idx Total Self Name+src Local% ms(pct) ms(pct) Callee =========================================================================================== ??? [85] 100.0% [1] 1436120(73.5%) 0(0.0%) profile-thunk16 ...t/pkgs/profile-lib/main.rkt:9:0 run [21] 100.0% ------------------------------------------------------------------------------------------- ??? [85] 100.0% [2] 1436094(73.5%) 0(0.0%) run-improve50 ...ie/develop/src/mainloop.rkt:234:0 for-loop [22] 99.1% get-final-combination [33] 0.7% setup-alt-simplified [41] 0.1% loop [103] 0.1% ------------------------------------------------------------------------------------------- table-ref [226] 100.0% [3] 1310438(67.1%) 398(0.0%) iterate-egraph!13 ...p/src/core/simplify.rkt:105:0 one-iter [23] 98.3% map-enodes [28] 1.7% debug-print [179] 0.0% ------------------------------------------------------------------------------------------- table-ref [226] 100.0% [4] 434326(22.2%) 332(0.0%) loop ...herbie/develop/src/core/simplify.rkt:237:2 pass [24] 99.9% ------------------------------------------------------------------------------------------- ??? [166] 100.0% [5] 39210(2.0%) 0(0.0%) approximate9 ...e/develop/src/core/taylor.rkt:12:0 loop [25] 78.1% f137 [177] 21.1% taylor-quotient [42] 0.8% ------------------------------------------------------------------------------------------- hash-ref! [206] 100.0% [6] 22246(1.1%) 0(0.0%) ??? ...s/herbie/develop/src/core/taylor.rkt:295:23 for-loop [27] 99.6% parse-loop12 [197] 0.4% ------------------------------------------------------------------------------------------- map-enodes [28] 2.7% loop [215] 97.3% [7] 20968(1.1%) 4712(0.2%) for-loop ...ie/develop/src/core/simplify.rkt:195:2 setfindf [32] 50.1% eval-const-expr [37] 12.6% compose [38] 9.1% parse-app [203] 3.7% curry* [97] 0.5% ------------------------------------------------------------------------------------------- hash-ref! [206] 100.0% [8] 15016(0.8%) 0(0.0%) ??? ...s/herbie/develop/src/core/taylor.rkt:338:33 hash-ref! [206] 59.0% for-loop [36] 41.0% ------------------------------------------------------------------------------------------- rewriter [102] 100.0% [9] 12538(0.6%) 668(0.0%) *rules* ...rbie/develop/src/syntax/rules.rkt:519:0 for-loop [30] 94.7% ------------------------------------------------------------------------------------------- hash-ref! [206] 100.0% [10] 11734(0.6%) 0(0.0%) ??? ...s/herbie/develop/src/core/taylor.rkt:285:26 for-loop [31] 100.0% ------------------------------------------------------------------------------------------- hash-ref! [206] 100.0% [11] 9016(0.5%) 296(0.0%) ??? ...s/herbie/develop/src/core/taylor.rkt:392:23 for-loop [34] 98.4% ------------------------------------------------------------------------------------------- hash-ref! [206] 100.0% [12] 8114(0.4%) 0(0.0%) ??? ...s/herbie/develop/src/core/taylor.rkt:483:23 for-loop [35] 100.0% ------------------------------------------------------------------------------------------- f137 [177] 100.0% [13] 3584(0.2%) 306(0.0%) taylor-invert ...develop/src/core/taylor.rkt:312:0 simplify [171] 62.3% first-nonzero-exp [40] 29.1% ------------------------------------------------------------------------------------------- parse-loop12 [197] 100.0% [14] 3242(0.2%) 0(0.0%) for-loop ...rbie/develop/src/core/reduce.rkt:99:13 make-multiplication-node [29] 100.0% ------------------------------------------------------------------------------------------- hash-ref! [206] 100.0% [15] 1708(0.1%) 0(0.0%) ??? ...s/herbie/develop/src/core/taylor.rkt:322:33 for-loop [39] 100.0% ------------------------------------------------------------------------------------------- map [182] 24.9% f137 [177] 75.1% [16] 1334(0.1%) 0(0.0%) taylor ...herbie/develop/src/core/taylor.rkt:163:0 loop [215] 50.7% debug7 [238] 49.3% ------------------------------------------------------------------------------------------- loop [17] 24.1% table-ref [226] 75.9% [17] 692(0.0%) 0(0.0%) loop ...lies/herbie/develop/src/programs.rkt:123:4 ??? [166] 75.9% loop [17] 24.1% ------------------------------------------------------------------------------------------- copying-mergesort [204] 100.0% [18] 638(0.0%) 0(0.0%) jloop ...t/collects/racket/private/sort.rkt:121:23 errors-score [43] 48.9% ??? [162] 42.3% ??? [166] 8.8% ------------------------------------------------------------------------------------------- f137 [177] 100.0% [19] 310(0.0%) 0(0.0%) combine-mterms ...evelop/src/core/reduce.rkt:191:0 for-loop [44] 100.0% ------------------------------------------------------------------------------------------- f137 [177] 100.0% [20] 58(0.0%) 0(0.0%) exprs-to-branch-on ...op/src/core/regimes.rkt:42:0 all-critical-subexpressions [45] 100.0% ------------------------------------------------------------------------------------------- profile-thunk16 [1] 100.0% [21] 1436120(73.5%) 0(0.0%) run ...share/racket/pkgs/profile-lib/main.rkt:39:2 ??? [85] 100.0% ------------------------------------------------------------------------------------------- run-improve50 [2] 100.0% [22] 1423264(72.9%) 0(0.0%) for-loop ...herbie/develop/src/mainloop.rkt:249:10 run-iter! [46] 100.0% ------------------------------------------------------------------------------------------- iterate-egraph!13 [3] 100.0% [23] 1287788(65.9%) 17260(0.9%) one-iter ...ie/develop/src/core/simplify.rkt:116:0 for-loop [47] 79.4% for-loop [49] 19.2% filter [256] 0.0% ------------------------------------------------------------------------------------------- loop [4] 100.0% [24] 433994(22.2%) 1126(0.1%) pass ...herbie/develop/src/core/simplify.rkt:227:2 for-loop [48] 99.6% ------------------------------------------------------------------------------------------- approximate9 [5] 100.0% [25] 30626(1.6%) 0(0.0%) loop ...es/herbie/develop/src/core/taylor.rkt:86:4 ??? [166] 98.8% ------------------------------------------------------------------------------------------- matcher [123] 2.1% substitute-e [77] 20.9% match-e [63] 75.7% [26] 30582(1.6%) 1280(0.1%) variable? ...e/develop/src/syntax/syntax.rkt:662:0 ??? [131] 95.8% ------------------------------------------------------------------------------------------- ??? [6] 100.0% [27] 22246(1.1%) 328(0.0%) for-loop ...bie/develop/src/core/taylor.rkt:298:27 hash-ref! [206] 99.3% ------------------------------------------------------------------------------------------- iterate-egraph!13 [3] 100.0% [28] 22004(1.1%) 0(0.0%) map-enodes ...ie/develop/src/core/egraph.rkt:140:0 loop [215] 96.0% for-loop [7] 2.5% set-precompute! [222] 1.4% ------------------------------------------------------------------------------------------- simplify [171] 2.0% for-loop [14] 18.2% map [182] 18.7% parse-loop12 [197] 61.1% [29] 17850(0.9%) 0(0.0%) make-multiplication-node .../core/reduce.rkt:230:0 make-multiplication-subnode [50] 100.0% ------------------------------------------------------------------------------------------- merge-egraph-nodes! [76] 11.3% *rules* [9] 88.7% [30] 13382(0.7%) 5830(0.3%) for-loop ...ies/herbie/develop/src/common.rkt:99:9 ormap [53] 41.8% flag-set? [70] 14.7% ------------------------------------------------------------------------------------------- ??? [10] 100.0% [31] 11734(0.6%) 0(0.0%) for-loop ...bie/develop/src/core/taylor.rkt:285:52 hash-ref! [206] 100.0% ------------------------------------------------------------------------------------------- for-loop [7] 100.0% [32] 10498(0.5%) 4262(0.2%) setfindf ...es/herbie/develop/src/common.rkt:184:0 for-loop [54] 47.7% custom-in-set [247] 9.7% ??? [131] 1.9% ------------------------------------------------------------------------------------------- run-improve50 [2] 100.0% [33] 10486(0.5%) 0(0.0%) get-final-combination ...op/src/mainloop.rkt:264:0 split-table [51] 99.5% extract-alt [59] 0.5% ------------------------------------------------------------------------------------------- ??? [11] 100.0% [34] 9016(0.5%) 0(0.0%) for-loop ...bie/develop/src/core/taylor.rkt:396:33 for-loop [52] 100.0% ------------------------------------------------------------------------------------------- ??? [12] 100.0% [35] 8114(0.4%) 0(0.0%) for-loop ...bie/develop/src/core/taylor.rkt:487:35 parse-loop12 [197] 100.0% ------------------------------------------------------------------------------------------- ??? [8] 100.0% [36] 6308(0.3%) 0(0.0%) for-loop ...bie/develop/src/core/taylor.rkt:341:46 hash-ref! [206] 100.0% ------------------------------------------------------------------------------------------- for-loop [7] 100.0% [37] 2642(0.1%) 0(0.0%) eval-const-expr .../develop/src/programs.rkt:166:0 f137 [177] 82.7% ??? [56] 11.3% ??? [57] 6.0% ------------------------------------------------------------------------------------------- for-loop [7] 100.0% [38] 1902(0.1%) 1902(0.1%) compose ...collects/racket/private/list.rkt:385:12 ------------------------------------------------------------------------------------------- ??? [15] 100.0% [39] 1708(0.1%) 0(0.0%) for-loop ...bie/develop/src/core/taylor.rkt:324:46 simplify [171] 100.0% ------------------------------------------------------------------------------------------- taylor-quotient [42] 24.0% taylor-invert [13] 76.0% [40] 1374(0.1%) 0(0.0%) first-nonzero-exp ...lop/src/core/taylor.rkt:260:0 simplify [171] 76.0% hash-ref! [206] 24.0% ------------------------------------------------------------------------------------------- run-improve50 [2] 100.0% [41] 1298(0.1%) 0(0.0%) setup-alt-simplified .../develop/src/glue.rkt:49:0 simplify-alt [55] 100.0% ------------------------------------------------------------------------------------------- approximate9 [5] 100.0% [42] 330(0.0%) 0(0.0%) taylor-quotient ...velop/src/core/taylor.rkt:328:0 first-nonzero-exp [40] 100.0% ------------------------------------------------------------------------------------------- jloop [18] 100.0% [43] 312(0.0%) 0(0.0%) errors-score ...erbie/develop/src/points.rkt:251:0 loop [215] 100.0% ------------------------------------------------------------------------------------------- combine-mterms [19] 100.0% [44] 310(0.0%) 0(0.0%) for-loop ...rbie/develop/src/core/reduce.rkt:195:5 hash-ref! [206] 100.0% ------------------------------------------------------------------------------------------- exprs-to-branch-on [20] 100.0% [45] 58(0.0%) 0(0.0%) all-critical-subexpressions ...re/regimes.rkt:58:0 for-loop [58] 100.0% ------------------------------------------------------------------------------------------- for-loop [22] 100.0% [46] 1423264(72.9%) 0(0.0%) run-iter! ...herbie/develop/src/mainloop.rkt:215:0 simplify! [60] 89.6% finalize-iter! [65] 5.2% gen-series! [66] 3.2% gen-rewrites! [67] 1.7% localize-error [72] 0.2% ------------------------------------------------------------------------------------------- one-iter [23] 100.0% [47] 1022688(52.4%) 5978(0.3%) for-loop ...ie/develop/src/core/simplify.rkt:166:2 for-loop [61] 91.7% match-e [63] 7.1% reduce-to-single! [71] 0.4% update-leader! [87] 0.2% ------------------------------------------------------------------------------------------- pass [24] 100.0% [48] 432448(22.1%) 2498(0.1%) for-loop ...e/develop/src/core/simplify.rkt:230:29 argmin [62] 69.3% loop [64] 26.1% for-loop [69] 3.6% make-sequence [227] 0.4% ------------------------------------------------------------------------------------------- for-loop [49] 49.2% one-iter [23] 50.8% [49] 247092(12.6%) 53140(2.7%) for-loop ...e/develop/src/core/simplify.rkt:126:12 for-loop [49] 49.2% match-e [63] 39.2% ??? [104] 0.1% ------------------------------------------------------------------------------------------- make-multiplication-node [29] 100.0% [50] 17850(0.9%) 0(0.0%) make-multiplication-subnode ...re/reduce.rkt:240:0 for-loop [68] 98.2% ------------------------------------------------------------------------------------------- get-final-combination [33] 100.0% [51] 10434(0.5%) 0(0.0%) split-table ...s/herbie/develop/src/glue.rkt:162:0 f137 [177] 100.0% ------------------------------------------------------------------------------------------- for-loop [34] 100.0% [52] 9016(0.5%) 0(0.0%) for-loop ...bie/develop/src/core/taylor.rkt:398:39 hash-ref! [206] 100.0% ------------------------------------------------------------------------------------------- for-loop [30] 100.0% [53] 5588(0.3%) 300(0.0%) ormap ...et/collects/racket/private/map.rkt:105:13 flag-set? [70] 94.6% ------------------------------------------------------------------------------------------- setfindf [32] 100.0% [54] 5012(0.3%) 5012(0.3%) for-loop ...es/herbie/develop/src/common.rkt:185:2 ------------------------------------------------------------------------------------------- setup-alt-simplified [41] 100.0% [55] 1298(0.1%) 0(0.0%) simplify-alt ...s/herbie/develop/src/glue.rkt:76:0 table-ref [226] 100.0% ------------------------------------------------------------------------------------------- eval-const-expr [37] 100.0% [56] 298(0.0%) 298(0.0%) ??? ...cket/collects/racket/private/kw.rkt:1635:39 ------------------------------------------------------------------------------------------- eval-const-expr [37] 100.0% [57] 158(0.0%) 0(0.0%) ??? ...cket/collects/racket/private/kw.rkt:1633:36 unpack245 [73] 100.0% ------------------------------------------------------------------------------------------- all-critical-subexpressions [45] 100.0% [58] 58(0.0%) 0(0.0%) for-loop ...rbie/develop/src/core/regimes.rkt:62:2 f137 [177] 100.0% ------------------------------------------------------------------------------------------- get-final-combination [33] 100.0% [59] 52(0.0%) 0(0.0%) extract-alt ...es/herbie/develop/src/glue.rkt:55:0 argmins [180] 100.0% ------------------------------------------------------------------------------------------- run-iter! [46] 100.0% [60] 1275532(65.3%) 0(0.0%) simplify! ...herbie/develop/src/mainloop.rkt:155:0 for-loop [74] 100.0% ------------------------------------------------------------------------------------------- for-loop [47] 100.0% [61] 938010(48.0%) 3858(0.2%) for-loop ...e/develop/src/core/simplify.rkt:148:10 mk-enode! [86] 37.8% merge-egraph-nodes! [76] 32.5% substitute-e [77] 21.0% loop! [100] 6.6% list-member? [234] 1.7% ------------------------------------------------------------------------------------------- for-loop [48] 100.0% [62] 299898(15.4%) 1148(0.1%) argmin ...re/racket/collects/racket/list.rkt:743:0 for-loop [75] 87.9% expression-cost [79] 11.8% ------------------------------------------------------------------------------------------- for-loop [47] 17.2% for-loop [88] 25.6% for-loop [49] 57.2% [63] 266210(13.6%) 83398(4.3%) match-e ...herbie/develop/src/core/ematch.rkt:46:0 for-loop [78] 44.0% for-loop [88] 11.9% ??? [131] 6.9% variable? [26] 3.5% list-cartesian-product [91] 2.8% loop [215] 1.8% custom-in-set [247] 1.7% curry* [97] 0.4% filter [256] 0.2% ------------------------------------------------------------------------------------------- for-loop [48] 100.0% [64] 112722(5.8%) 0(0.0%) loop ...hare/racket/collects/racket/list.rkt:729:4 for-loop [75] 90.0% expression-cost [79] 10.0% ------------------------------------------------------------------------------------------- run-iter! [46] 100.0% [65] 73578(3.8%) 0(0.0%) finalize-iter! ...e/develop/src/mainloop.rkt:169:0 ??? [131] 100.0% ------------------------------------------------------------------------------------------- run-iter! [46] 100.0% [66] 46162(2.4%) 0(0.0%) gen-series! ...rbie/develop/src/mainloop.rkt:129:0 for-loop [80] 100.0% ------------------------------------------------------------------------------------------- run-iter! [46] 100.0% [67] 23598(1.2%) 0(0.0%) gen-rewrites! ...ie/develop/src/mainloop.rkt:142:0 for-loop [81] 100.0% ------------------------------------------------------------------------------------------- make-multiplication-subnode [50] 100.0% [68] 17522(0.9%) 664(0.0%) for-loop ...rbie/develop/src/core/reduce.rkt:242:3 mterm->expr [95] 62.7% make-multiplication-subsubsubnode [82] 33.5% ------------------------------------------------------------------------------------------- for-loop [48] 100.0% [69] 15534(0.8%) 15534(0.8%) for-loop ...e/develop/src/core/simplify.rkt:217:13 ------------------------------------------------------------------------------------------- for-loop [30] 27.1% ormap [53] 72.9% [70] 7252(0.4%) 2564(0.1%) flag-set? ...es/herbie/develop/src/config.rkt:34:0 ??? [243] 33.0% return/no-unsupplied [244] 31.6% ------------------------------------------------------------------------------------------- for-loop [47] 100.0% [71] 4072(0.2%) 1444(0.1%) reduce-to-single! ...lop/src/core/egraph.rkt:325:0 for-loop [83] 53.9% make-sequence [227] 10.7% ------------------------------------------------------------------------------------------- run-iter! [46] 100.0% [72] 3384(0.2%) 0(0.0%) localize-error ...velop/src/core/localize.rkt:47:0 hash-ref! [206] 90.8% ??? [193] 9.2% ------------------------------------------------------------------------------------------- ??? [57] 100.0% [73] 158(0.0%) 0(0.0%) unpack245 ...private/arrow-higher-order.rkt:354:44 maybe-cons-kwd [84] 100.0% ------------------------------------------------------------------------------------------- simplify! [60] 97.8% [74] 1304442(66.8%) 0(0.0%) for-loop .../herbie/develop/src/mainloop.rkt:159:6 ??? [85] 100.0% ------------------------------------------------------------------------------------------- loop [64] 27.8% argmin [62] 72.2% [75] 364912(18.7%) 9930(0.5%) for-loop .../herbie/develop/src/programs.rkt:208:2 table-ref [226] 71.1% ...velop/src/common.rkt:47:2 [134] 23.4% ??? [132] 2.7% ------------------------------------------------------------------------------------------- for-loop [94] 2.6% merge-egraph-nodes! [76] 5.7% for-loop [61] 91.7% [76] 304848(15.6%) 6696(0.3%) merge-egraph-nodes! ...p/src/core/egraph.rkt:153:0 update-leader! [87] 68.9% for-loop [92] 9.2% loop! [100] 5.7% merge-egraph-nodes! [76] 5.7% for-loop [94] 3.9% enode-merge! [96] 3.5% make-sequence [227] 0.5% for-loop [30] 0.5% ------------------------------------------------------------------------------------------- substitute-e [77] 5.1% for-loop [61] 94.9% [77] 197124(10.1%) 7568(0.4%) substitute-e ...e/develop/src/core/ematch.rkt:71:0 mk-enode! [86] 88.9% substitute-e [77] 5.1% ??? [131] 1.6% variable? [26] 1.2% ------------------------------------------------------------------------------------------- match-e [63] 100.0% [78] 153890(7.9%) 51724(2.6%) for-loop ...rbie/develop/src/core/ematch.rkt:59:11 for-loop [88] 51.3% list-cartesian-product [91] 11.0% loop [215] 5.8% foldl [220] 1.2% filter [256] 0.6% curry* [97] 0.3% ------------------------------------------------------------------------------------------- loop [64] 24.3% argmin [62] 75.7% [79] 46560(2.4%) 448(0.0%) expression-cost .../develop/src/programs.rkt:207:0 compile [90] 99.0% ------------------------------------------------------------------------------------------- gen-series! [66] 100.0% [80] 46162(2.4%) 0(0.0%) for-loop .../herbie/develop/src/mainloop.rkt:135:7 taylor-alt [89] 100.0% ------------------------------------------------------------------------------------------- gen-rewrites! [67] 100.0% [81] 23598(1.2%) 0(0.0%) for-loop ...herbie/develop/src/mainloop.rkt:147:11 ??? [93] 100.0% ------------------------------------------------------------------------------------------- make-multiplication-subsubsubnode [82] 5.7% for-loop [68] 94.3% [82] 5878(0.3%) 0(0.0%) make-multiplication-subsubsubnode ...uce.rkt:262:0 mterm->expr [95] 94.3% make-multiplication-subsubsubnode [82] 5.7% ------------------------------------------------------------------------------------------- reduce-to-single! [71] 100.0% [83] 2194(0.1%) 2194(0.1%) for-loop ...rbie/develop/src/core/egraph.rkt:326:8 ------------------------------------------------------------------------------------------- unpack245 [73] 100.0% [84] 158(0.0%) 0(0.0%) maybe-cons-kwd ...ate/arrow-higher-order.rkt:498:0 successfully-got-the-right-kind-of-function [249] 64.6% arrow-higher-order:lnp [258] 35.4% ------------------------------------------------------------------------------------------- for-loop [74] 23.7% run [21] 26.4% [85] 1913274(97.9%) 0(0.0%) ??? ...lects/racket/private/more-scheme.rkt:261:28 table-ref [226] 47.0% run-improve50 [2] 26.5% profile-thunk16 [1] 26.4% loop [103] 0.1% ------------------------------------------------------------------------------------------- mk-egraph [235] 0.0% mk-enode-rec! [245] 2.0% substitute-e [77] 32.4% for-loop [61] 65.6% [86] 540838(27.7%) 47554(2.4%) mk-enode! ...bie/develop/src/core/egraph.rkt:102:0 new-enode [98] 90.0% hash-has-key? [142] 1.1% mutable-set [117] 0.1% ------------------------------------------------------------------------------------------- for-loop [47] 0.9% merge-egraph-nodes! [76] 99.1% [87] 233548(12.0%) 19662(1.0%) update-leader! ...evelop/src/core/egraph.rkt:218:0 for-loop [99] 87.8% custom-set-union! [108] 1.4% update-en-expr [152] 1.2% mutable-set [117] 0.7% make-sequence [227] 0.4% hash-ref! [206] 0.2% ------------------------------------------------------------------------------------------- match-e [63] 39.1% for-loop [78] 60.9% [88] 136396(7.0%) 7256(0.4%) for-loop ...rbie/develop/src/core/ematch.rkt:65:37 match-e [63] 90.5% ??? [104] 4.6% ------------------------------------------------------------------------------------------- for-loop [80] 100.0% [89] 46162(2.4%) 0(0.0%) taylor-alt ...es/herbie/develop/src/glue.rkt:134:0 for-loop [101] 99.3% expression->type [115] 0.7% ------------------------------------------------------------------------------------------- expression-cost [79] 100.0% [90] 46112(2.4%) 1842(0.1%) compile ...s/herbie/develop/src/programs.rkt:184:0 hash-ref! [206] 96.0% ------------------------------------------------------------------------------------------- match-e [63] 23.0% list-cartesian-product [91] 25.7% for-loop [78] 51.3% [91] 29230(1.5%) 24598(1.3%) list-cartesian-product ...src/core/ematch.rkt:20:0 list-cartesian-product [91] 25.7% for-loop [106] 12.5% ------------------------------------------------------------------------------------------- merge-egraph-nodes! [76] 100.0% [92] 28196(1.4%) 22206(1.1%) for-loop ...rbie/develop/src/core/egraph.rkt:233:6 update-en-expr [152] 21.2% ------------------------------------------------------------------------------------------- for-loop [81] 100.0% [93] 23598(1.2%) 0(0.0%) ??? ...ies/herbie/develop/src/alternative.rkt:88:0 rewriter [102] 100.0% ------------------------------------------------------------------------------------------- merge-egraph-nodes! [76] 100.0% [94] 21084(1.1%) 0(0.0%) for-loop ...bie/develop/src/core/egraph.rkt:201:10 merge-egraph-nodes! [76] 80.0% loop! [100] 20.0% ------------------------------------------------------------------------------------------- make-multiplication-subsubsubnode [82] 34.9% for-loop [68] 65.1% [95] 16858(0.9%) 0(0.0%) mterm->expr ...e/develop/src/core/reduce.rkt:270:0 f137 [177] 52.5% expression->type [115] 47.5% ------------------------------------------------------------------------------------------- merge-egraph-nodes! [76] 100.0% [96] 10986(0.6%) 1198(0.1%) enode-merge! ...e/develop/src/core/enode.rkt:129:0 adopt-enode! [105] 57.8% custom-set-intersect! [107] 31.3% ------------------------------------------------------------------------------------------- for-loop [7] 5.8% for-loop [78] 27.1% match-e [63] 67.1% [97] 1712(0.1%) 202(0.0%) curry* ...racket/collects/racket/function.rkt:44:2 procedure-arity [109] 88.2% ------------------------------------------------------------------------------------------- mk-enode! [86] 100.0% [98] 486644(24.9%) 2644(0.1%) new-enode ...erbie/develop/src/core/enode.rkt:97:0 type-of-enode-expr [110] 98.9% set [114] 0.4% mutable-set [117] 0.1% ------------------------------------------------------------------------------------------- update-leader! [87] 100.0% [99] 205112(10.5%) 2606(0.1%) for-loop ...rbie/develop/src/core/egraph.rkt:223:6 for-loop [111] 98.6% update-en-expr [152] 0.2% ------------------------------------------------------------------------------------------- for-loop [94] 3.8% merge-egraph-nodes! [76] 17.8% loop [215] 27.5% for-loop [61] 50.9% [100] 86368(4.4%) 19852(1.0%) loop! ...s/herbie/develop/src/core/enode.rkt:192:2 custom-set-union [112] 35.6% loop [215] 30.9% set [114] 11.9% update-en-expr [152] 6.7% ------------------------------------------------------------------------------------------- taylor-alt [89] 100.0% [101] 45828(2.3%) 0(0.0%) for-loop ...lies/herbie/develop/src/glue.rkt:139:6 ??? [166] 100.0% ------------------------------------------------------------------------------------------- ??? [93] 19.6% matcher [123] 80.4% [102] 23598(1.2%) 3876(0.2%) rewriter ...bie/develop/src/core/matcher.rkt:131:2 for-loop [113] 82.5% *rules* [9] 9.2% f137 [177] 3.6% expression->type [115] 2.2% ------------------------------------------------------------------------------------------- run-improve50 [2] 9.7% ??? [85] 36.8% pred [216] 53.5% [103] 10748(0.6%) 0(0.0%) loop ...htlies/herbie/develop/src/points.rkt:205:2 make-exacts* [126] 58.4% loop [128] 21.0% loop [118] 20.1% for-loop [120] 0.5% ------------------------------------------------------------------------------------------- for-loop [49] 4.4% for-loop [88] 95.6% [104] 6618(0.3%) 3412(0.2%) ??? ...ies/herbie/develop/src/core/ematch.rkt:50:5 for-loop [116] 46.9% custom-in-set [247] 1.5% ------------------------------------------------------------------------------------------- enode-merge! [96] 100.0% [105] 6348(0.3%) 2378(0.1%) adopt-enode! ...e/develop/src/core/enode.rkt:105:0 custom-set-union [112] 62.5% ------------------------------------------------------------------------------------------- list-cartesian-product [91] 100.0% [106] 4632(0.2%) 4632(0.2%) for-loop ...erbie/develop/src/core/ematch.rkt:24:8 ------------------------------------------------------------------------------------------- enode-merge! [96] 100.0% [107] 3440(0.2%) 3440(0.2%) custom-set-intersect! ...ivate/set-types.rkt:269:0 ------------------------------------------------------------------------------------------- update-leader! [87] 100.0% [108] 3216(0.2%) 3064(0.2%) custom-set-union! ...t/private/set-types.rkt:245:0 for-loop [119] 4.7% ------------------------------------------------------------------------------------------- curry* [97] 100.0% [109] 1510(0.1%) 1510(0.1%) procedure-arity ...ket/private/norm-arity.rkt:7:27 ------------------------------------------------------------------------------------------- new-enode [98] 100.0% [110] 481496(24.6%) 9484(0.5%) type-of-enode-expr ...elop/src/core/enode.rkt:68:0 get-sigs [121] 98.0% ------------------------------------------------------------------------------------------- for-loop [99] 100.0% [111] 202158(10.3%) 102(0.0%) for-loop ...rbie/develop/src/core/egraph.rkt:224:8 hash-update! [122] 99.9% ------------------------------------------------------------------------------------------- adopt-enode! [105] 11.0% loop! [100] 89.0% [112] 35942(1.8%) 13636(0.7%) custom-set-union ...et/private/set-types.rkt:168:0 for-loop [124] 49.2% for-loop [127] 12.9% ------------------------------------------------------------------------------------------- rewriter [102] 100.0% [113] 23296(1.2%) 364(0.0%) for-loop ...ie/develop/src/core/matcher.rkt:134:10 matcher [123] 99.8% ------------------------------------------------------------------------------------------- new-enode [98] 8.2% loop! [100] 91.8% [114] 21768(1.1%) 21768(1.1%) set ...collects/racket/private/set-types.rkt:981:0 ------------------------------------------------------------------------------------------- taylor-alt [89] 0.6% rewriter [102] 5.0% mterm->expr [95] 24.6% f137 [177] 32.4% for-loop [125] 35.8% [115] 17146(0.9%) 0(0.0%) expression->type ...evelop/src/type-check.rkt:45:0 for-loop [125] 100.0% ------------------------------------------------------------------------------------------- ??? [104] 100.0% [116] 3106(0.2%) 2036(0.1%) for-loop ...erbie/develop/src/core/ematch.rkt:51:7 ??? [131] 34.4% ------------------------------------------------------------------------------------------- new-enode [98] 15.7% mk-enode! [86] 25.2% update-leader! [87] 59.2% [117] 2630(0.1%) 2086(0.1%) mutable-set .../racket/private/set-types.rkt:999:0 for-loop [129] 20.7% ------------------------------------------------------------------------------------------- loop [103] 100.0% [118] 2158(0.1%) 0(0.0%) loop ...htlies/herbie/develop/src/points.rkt:158:2 make-exacts* [126] 73.6% loop [128] 26.4% ------------------------------------------------------------------------------------------- custom-set-union! [108] 100.0% [119] 152(0.0%) 152(0.0%) for-loop ...cts/racket/private/set-types.rkt:253:4 ------------------------------------------------------------------------------------------- loop [103] 100.0% [120] 50(0.0%) 0(0.0%) for-loop ...s/herbie/develop/src/points.rkt:222:26 for-loop [130] 100.0% ------------------------------------------------------------------------------------------- type-of-enode-expr [110] 100.0% [121] 472012(24.2%) 9234(0.5%) get-sigs .../herbie/develop/src/type-check.rkt:5:0 ??? [132] 39.9% table-ref [226] 31.7% ??? [131] 13.6% ...velop/src/common.rkt:47:2 [134] 12.8% ------------------------------------------------------------------------------------------- for-loop [111] 100.0% [122] 202056(10.3%) 1930(0.1%) hash-update! ...ket/private/more-scheme.rkt:362:13 ??? [133] 99.0% ------------------------------------------------------------------------------------------- for-loop [135] 20.0% matcher [123] 29.9% for-loop [113] 50.1% [123] 23296(1.2%) 346(0.0%) matcher ...rbie/develop/src/core/matcher.rkt:167:2 rewriter [102] 49.1% matcher [123] 29.9% for-loop [135] 20.0% for-loop [137] 0.5% variable? [26] 0.3% foldr [138] 0.1% ------------------------------------------------------------------------------------------- custom-set-union [112] 100.0% [124] 17666(0.9%) 5440(0.3%) for-loop ...cts/racket/private/set-types.rkt:174:3 for-loop [136] 69.2% ------------------------------------------------------------------------------------------- expression->type [115] 100.0% [125] 17146(0.9%) 330(0.0%) for-loop ...herbie/develop/src/type-check.rkt:52:5 f137 [177] 63.3% expression->type [115] 35.8% ------------------------------------------------------------------------------------------- loop [118] 20.2% loop [103] 79.8% [126] 7866(0.4%) 0(0.0%) make-exacts* ...erbie/develop/src/points.rkt:138:0 eval-prog [161] 63.3% loop [215] 36.7% ------------------------------------------------------------------------------------------- custom-set-union [112] 100.0% [127] 4640(0.2%) 4640(0.2%) for-loop ...cts/racket/private/set-types.rkt:152:2 ------------------------------------------------------------------------------------------- loop [118] 20.1% loop [103] 79.9% [128] 2832(0.1%) 0(0.0%) loop ...htlies/herbie/develop/src/points.rkt:141:4 loop [215] 95.9% ??? [162] 4.1% ------------------------------------------------------------------------------------------- mutable-set [117] 100.0% [129] 544(0.0%) 544(0.0%) for-loop ...cts/racket/private/set-types.rkt:943:2 ------------------------------------------------------------------------------------------- for-loop [120] 100.0% [130] 50(0.0%) 0(0.0%) for-loop ...s/herbie/develop/src/points.rkt:223:28 ??? [166] 100.0% ------------------------------------------------------------------------------------------- setfindf [32] 0.1% pattern-substitute [149] 0.1% debug7 [238] 0.3% for-loop [116] 0.5% f137 [177] 1.5% ??? [260] 1.8% substitute-e [77] 3.6% variable? [26] 13.3% match-e [63] 16.3% get-sigs [121] 29.3% finalize-iter! [65] 32.6% [131] 219996(11.3%) 55318(2.8%) ??? ...contract/private/arrow-val-first.rkt:357:18 hash-has-key? [142] 40.9% for-loop [143] 31.8% ??? [260] 0.9% atab-add-altns [146] 0.8% ------------------------------------------------------------------------------------------- ??? [166] 0.7% f137 [177] 4.0% for-loop [75] 4.8% get-sigs [121] 90.6% [132] 208104(10.7%) 17102(0.9%) ??? ...ts/racket/contract/private/arr-i.rkt:804:10 ??? [140] 50.4% for-loop [141] 34.0% get/build-late-neg-projection [160] 6.2% ??? [257] 0.5% ??? [264] 0.2% ------------------------------------------------------------------------------------------- hash-update! [122] 100.0% [133] 200126(10.2%) 1538(0.1%) ??? ...s/herbie/develop/src/core/egraph.rkt:226:24 for-loop [139] 99.0% make-sequence [227] 0.2% ------------------------------------------------------------------------------------------- f137 [177] 1.7% ??? [166] 3.4% get-sigs [121] 39.2% for-loop [75] 55.7% [134] 153572(7.9%) 48570(2.5%) ...velop/src/common.rkt:47:2 ...e/arr-i.rkt:906:19 ??? [144] 34.0% ??? [145] 33.8% ------------------------------------------------------------------------------------------- matcher [123] 100.0% [135] 21024(1.1%) 0(0.0%) for-loop ...ie/develop/src/core/matcher.rkt:183:21 matcher [123] 100.0% ------------------------------------------------------------------------------------------- for-loop [124] 100.0% [136] 12226(0.6%) 12226(0.6%) for-loop ...cts/racket/private/set-types.rkt:178:5 ------------------------------------------------------------------------------------------- matcher [123] 100.0% [137] 636(0.0%) 0(0.0%) for-loop ...bie/develop/src/core/matcher.rkt:159:6 pattern-match [147] 52.8% pattern-substitute [149] 47.2% ------------------------------------------------------------------------------------------- matcher [123] 100.0% [138] 334(0.0%) 0(0.0%) foldr ...et/collects/racket/private/list.rkt:242:4 cp-2 [148] 100.0% ------------------------------------------------------------------------------------------- ??? [133] 100.0% [139] 198202(10.1%) 175236(9.0%) for-loop ...bie/develop/src/core/egraph.rkt:227:26 update-en-expr [152] 11.6% ------------------------------------------------------------------------------------------- ??? [132] 100.0% [140] 104892(5.4%) 5592(0.3%) ??? ...ects/racket/contract/private/hash.rkt:217:4 ??? [150] 94.7% ------------------------------------------------------------------------------------------- for-loop [241] 29.0% ??? [132] 71.0% [141] 99696(5.1%) 19092(1.0%) for-loop ...racket/contract/private/hash.rkt:239:6 ??? [242] 79.4% ??? [262] 1.4% ------------------------------------------------------------------------------------------- mk-enode! [86] 6.1% ??? [131] 93.9% [142] 97872(5.0%) 28400(1.5%) hash-has-key? ...et/private/more-scheme.rkt:368:13 ??? [233] 68.3% ??? [237] 2.7% ------------------------------------------------------------------------------------------- ??? [131] 100.0% [143] 71854(3.7%) 0(0.0%) for-loop ...ie/develop/src/core/alt-table.rkt:51:2 atab-add-altn [151] 100.0% ------------------------------------------------------------------------------------------- ...velop/src/common.rkt:47:2 [134] 100.0% [144] 52238(2.7%) 17996(0.9%) ??? ...s/racket/contract/private/arr-i.rkt:1268:39 ??? [243] 30.8% return/no-unsupplied [244] 20.8% assoc-ref [153] 14.0% ------------------------------------------------------------------------------------------- for-loop [255] 5.2% ??? [242] 13.9% ...velop/src/common.rkt:47:2 [134] 81.0% [145] 51916(2.7%) 13396(0.7%) ??? ...ects/racket/contract/private/list.rkt:342:4 ??? [242] 69.1% ??? [260] 9.1% ??? [257] 5.9% ------------------------------------------------------------------------------------------- ??? [131] 100.0% [146] 1724(0.1%) 0(0.0%) atab-add-altns ...elop/src/core/alt-table.rkt:50:0 atab-add-altn [151] 100.0% ------------------------------------------------------------------------------------------- for-loop [137] 100.0% [147] 336(0.0%) 336(0.0%) pattern-match ...develop/src/core/matcher.rkt:48:0 ------------------------------------------------------------------------------------------- foldr [138] 100.0% [148] 334(0.0%) 334(0.0%) cp-2 ...hare/racket/collects/racket/list.rkt:804:2 ------------------------------------------------------------------------------------------- for-loop [137] 33.3% pattern-substitute [149] 66.7% [149] 300(0.0%) 0(0.0%) pattern-substitute ...op/src/core/matcher.rkt:73:0 pattern-substitute [149] 66.7% ??? [131] 33.3% ------------------------------------------------------------------------------------------- ??? [140] 100.0% [150] 99300(5.1%) 3436(0.2%) ??? ...ects/racket/contract/private/list.rkt:169:2 ??? [154] 96.5% ------------------------------------------------------------------------------------------- atab-add-altns [146] 2.3% for-loop [143] 97.7% [151] 73578(3.8%) 0(0.0%) atab-add-altn ...elop/src/core/alt-table.rkt:208:0 best-and-tied-at-points [155] 99.1% ------------------------------------------------------------------------------------------- for-loop [99] 0.8% update-leader! [87] 6.3% for-loop [92] 13.8% loop! [100] 26.3% for-loop [139] 52.8% [152] 43498(2.2%) 42650(2.2%) update-en-expr ...evelop/src/core/egraph.rkt:212:0 ------------------------------------------------------------------------------------------- ??? [144] 100.0% [153] 7288(0.4%) 7288(0.4%) assoc-ref ...collects/racket/private/dict.rkt:56:0 ------------------------------------------------------------------------------------------- ??? [150] 100.0% [154] 95864(4.9%) 4362(0.2%) ??? ...ects/racket/contract/private/list.rkt:678:5 for-loop [156] 95.4% ------------------------------------------------------------------------------------------- atab-add-altn [151] 100.0% [155] 72946(3.7%) 0(0.0%) best-and-tied-at-points ...ore/alt-table.rkt:122:0 errors [157] 99.1% ------------------------------------------------------------------------------------------- ??? [154] 100.0% [156] 91502(4.7%) 27938(1.4%) for-loop ...racket/contract/private/list.rkt:680:9 add-list-context [159] 46.1% get/build-late-neg-projection [160] 23.4% ------------------------------------------------------------------------------------------- loop [215] 0.1% option-on-expr [183] 0.5% composed [184] 1.4% pred [216] 3.9% best-and-tied-at-points [155] 93.4% [157] 77390(4.0%) 0(0.0%) errors ...lies/herbie/develop/src/points.rkt:241:0 for-loop [158] 68.8% eval-prog [161] 31.2% ------------------------------------------------------------------------------------------- errors [157] 100.0% [158] 53272(2.7%) 1764(0.1%) for-loop ...es/herbie/develop/src/points.rkt:244:4 ??? [162] 93.8% ??? [166] 1.2% ulp-difference [225] 0.3% ------------------------------------------------------------------------------------------- for-loop [156] 100.0% [159] 42186(2.2%) 42186(2.2%) add-list-context ...ontract/private/list.rkt:752:0 ------------------------------------------------------------------------------------------- ??? [164] 13.4% ??? [132] 23.0% for-loop [156] 62.5% [160] 34224(1.8%) 6058(0.3%) get/build-late-neg-projection ...te/guts.rkt:691:0 ??? [163] 66.4% ??? [164] 15.5% ------------------------------------------------------------------------------------------- sort-context-on-expr [189] 0.2% point->alt [195] 0.2% sindices->spoints [187] 0.2% make-exacts* [126] 17.0% errors [157] 82.4% [161] 29270(1.5%) 3062(0.2%) eval-prog ...herbie/develop/src/programs.rkt:148:0 f137 [177] 72.0% hash-ref! [206] 14.9% parse-app [203] 1.2% ??? [165] 0.2% ------------------------------------------------------------------------------------------- loop [128] 0.2% ??? [199] 0.3% loop [209] 0.5% jloop [18] 0.5% loop [215] 9.6% for-loop [158] 88.9% [162] 56216(2.9%) 0(0.0%) ??? ...tlies/herbie/develop/src/programs.rkt:154:4 ??? [167] 97.1% ??? [166] 2.6% ??? [169] 0.2% ------------------------------------------------------------------------------------------- get/build-late-neg-projection [160] 100.0% [163] 26300(1.3%) 7754(0.4%) ??? ...cts/racket/contract/private/prop.rkt:314:12 build-compound-type-name [168] 70.5% ------------------------------------------------------------------------------------------- get/build-late-neg-projection [160] 100.0% [164] 10058(0.5%) 724(0.0%) ??? ...ects/racket/contract/private/hash.rkt:211:2 get/build-late-neg-projection [160] 92.8% ------------------------------------------------------------------------------------------- eval-prog [161] 100.0% [165] 66(0.0%) 0(0.0%) ??? ...collects/racket/private/qq-and-or.rkt:155:9 ??? [170] 100.0% ------------------------------------------------------------------------------------------- for-loop [130] 0.1% jloop [18] 0.1% loop [215] 0.3% loop [17] 0.4% loop [201] 0.5% for-loop [158] 0.9% map [182] 1.0% ??? [162] 2.1% loop [25] 14.4% table-ref [226] 25.1% for-loop [101] 25.6% f137 [177] 28.0% [166] 69908(3.6%) 970(0.0%) ??? ...tract/private/arrow-higher-order.rkt:342:33 table-ref [226] 39.7% approximate9 [5] 20.8% hash-ref! [206] 14.4% ??? [260] 7.9% ...velop/src/common.rkt:47:2 [134] 7.5% simplify [171] 4.7% ??? [132] 2.0% best-alt [175] 1.4% ------------------------------------------------------------------------------------------- ??? [162] 100.0% [167] 54582(2.8%) 29970(1.5%) ??? ...acket/collects/racket/private/kw.rkt:444:14 ??? [172] 28.9% ??? [174] 8.4% ??? [229] 3.1% bf* [221] 3.0% ??? [262] 0.8% ------------------------------------------------------------------------------------------- contract-struct-name [173] 19.2% ??? [163] 80.8% [168] 18546(0.9%) 11254(0.6%) build-compound-type-name ...private/guts.rkt:448:0 contract-struct-name [173] 53.0% ------------------------------------------------------------------------------------------- ??? [162] 100.0% [169] 140(0.0%) 0(0.0%) ??? ...contract/private/../../private/kw.rkt:761:9 real->bigfloat [176] 100.0% ------------------------------------------------------------------------------------------- ??? [165] 100.0% [170] 66(0.0%) 66(0.0%) ??? ...ollects/racket/private/qq-and-or.rkt:164:21 ------------------------------------------------------------------------------------------- loop [215] 1.6% first-nonzero-exp [40] 2.4% for-loop [39] 3.9% taylor-invert [13] 5.1% ??? [166] 15.2% hash-ref! [206] 71.1% [171] 43584(2.2%) 0(0.0%) simplify ...erbie/develop/src/core/reduce.rkt:16:0 f137 [177] 56.1% parse-loop12 [197] 24.4% simplify-node [186] 8.9% simplify* [178] 3.8% debug7 [238] 3.7% debug-print [179] 2.3% make-multiplication-node [29] 0.8% ------------------------------------------------------------------------------------------- ??? [167] 100.0% [172] 15790(0.8%) 9100(0.5%) ??? ...herbie/develop/src/syntax/syntax.rkt:155:17 ??? [243] 23.3% return/no-unsupplied [244] 16.8% list-member? [234] 2.3% ------------------------------------------------------------------------------------------- build-compound-type-name [168] 100.0% [173] 12362(0.6%) 7292(0.4%) contract-struct-name ...ract/private/prop.rkt:89:0 build-compound-type-name [168] 49.3% ------------------------------------------------------------------------------------------- ??? [167] 100.0% [174] 4566(0.2%) 4566(0.2%) ??? ...rivate/unconstrained-domain-arrow.rkt:40:13 ------------------------------------------------------------------------------------------- ??? [166] 100.0% [175] 1010(0.1%) 0(0.0%) best-alt ...tlies/herbie/develop/src/glue.rkt:71:0 argmins [180] 65.0% loop [181] 35.0% ------------------------------------------------------------------------------------------- ??? [169] 100.0% [176] 140(0.0%) 140(0.0%) real->bigfloat .../private/bigfloat/mpfr.rkt:451:0 ------------------------------------------------------------------------------------------- for-loop [58] 0.0% table-ref [226] 0.0% composed [184] 0.1% loop [215] 0.9% append-map [192] 1.2% parse-loop12 [197] 1.6% rewriter [102] 2.0% simplify-node [186] 2.3% approximate9 [5] 2.3% hash-ref! [206] 2.4% eval-const-expr [37] 3.1% mterm->expr [95] 3.3% eval-prog [161] 4.6% for-loop [125] 9.1% split-table [51] 10.0% simplify [171] 11.7% map [182] 11.9% f137 [177] 33.0% [177] 71670(3.7%) 8418(0.4%) f137 .../collects/racket/match/compiler.rkt:507:40 f137 [177] 33.0% map [182] 22.7% loop [215] 8.0% expression->type [115] 4.8% ??? [166] 4.4% table-ref [226] 4.0% ??? [132] 3.7% append-map [192] 3.5% option-on-expr [183] 2.0% ??? [131] 1.6% ...velop/src/common.rkt:47:2 [134] 1.3% taylor-invert [13] 0.5% parse-app [203] 0.4% taylor [16] 0.2% composed [184] 0.1% parse-loop12 [197] 0.1% combine-mterms [19] 0.1% exprs-to-branch-on [20] 0.0% ------------------------------------------------------------------------------------------- parse-loop12 [197] 28.8% simplify [171] 71.2% [178] 2312(0.1%) 1374(0.1%) simplify* ...rbie/develop/src/core/reduce.rkt:31:0 hash-ref! [206] 27.6% return/no-unsupplied [244] 13.0% ------------------------------------------------------------------------------------------- iterate-egraph!13 [3] 19.8% simplify [171] 80.2% [179] 1252(0.1%) 582(0.0%) debug-print .../herbie/develop/src/debug.rkt:107:0 for-loop [185] 53.5% ------------------------------------------------------------------------------------------- extract-alt [59] 7.3% best-alt [175] 92.7% [180] 708(0.0%) 0(0.0%) argmins ...ies/herbie/develop/src/common.rkt:150:0 composed [184] 100.0% ------------------------------------------------------------------------------------------- best-alt [175] 100.0% [181] 354(0.0%) 0(0.0%) loop ...htlies/herbie/develop/src/common.rkt:151:2 composed [184] 100.0% ------------------------------------------------------------------------------------------- ??? [188] 1.9% parse-loop12 [197] 6.9% f137 [177] 91.2% [182] 28376(1.5%) 0(0.0%) map ...acket/collects/racket/private/map.rkt:20:13 f137 [177] 52.8% simplify-node [186] 18.3% parse-loop12 [197] 13.8% ??? [188] 6.7% make-multiplication-node [29] 3.4% loop [215] 2.6% ??? [166] 1.9% taylor [16] 0.6% ------------------------------------------------------------------------------------------- f137 [177] 16.1% loop [215] 83.9% [183] 10376(0.5%) 0(0.0%) option-on-expr ...evelop/src/core/regimes.rkt:90:0 sindices->spoints [187] 86.6% sort-context-on-expr [189] 6.2% errors [157] 3.5% pick-errors [190] 2.1% loop [215] 1.0% err-lsts->split-indices [191] 0.5% ------------------------------------------------------------------------------------------- loop [181] 17.2% argmins [180] 34.4% f137 [177] 48.3% [184] 2056(0.1%) 322(0.0%) composed ...ollects/racket/private/list.rkt:321:16 errors [157] 51.7% f137 [177] 32.7% ------------------------------------------------------------------------------------------- debug-print [179] 100.0% [185] 670(0.0%) 670(0.0%) for-loop ...ies/herbie/develop/src/debug.rkt:113:2 ------------------------------------------------------------------------------------------- simplify [171] 25.0% map [182] 75.0% [186] 15424(0.8%) 0(0.0%) simplify-node .../develop/src/core/reduce.rkt:50:0 append-map [192] 70.3% f137 [177] 27.7% ------------------------------------------------------------------------------------------- option-on-expr [183] 100.0% [187] 8986(0.5%) 0(0.0%) sindices->spoints ...op/src/core/regimes.rkt:129:0 loop [201] 99.3% eval-prog [161] 0.7% ------------------------------------------------------------------------------------------- map [182] 26.2% loop [215] 73.8% [188] 2772(0.1%) 0(0.0%) ??? ...ket/collects/racket/private/list.rkt:323:18 hash-ref! [206] 95.3% map [182] 4.7% ------------------------------------------------------------------------------------------- option-on-expr [183] 100.0% [189] 646(0.0%) 0(0.0%) sort-context-on-expr ...velop/src/points.rkt:115:0 ??? [193] 91.3% eval-prog [161] 8.7% ------------------------------------------------------------------------------------------- option-on-expr [183] 100.0% [190] 220(0.0%) 0(0.0%) pick-errors .../develop/src/core/regimes.rkt:197:0 for-loop [194] 74.5% point->alt [195] 25.5% ------------------------------------------------------------------------------------------- option-on-expr [183] 100.0% [191] 52(0.0%) 0(0.0%) err-lsts->split-indices .../core/regimes.rkt:235:0 add-splitpoint [196] 100.0% ------------------------------------------------------------------------------------------- f137 [177] 25.2% append-map [192] 33.5% simplify-node [186] 41.3% [192] 15502(0.8%) 670(0.0%) append-map ...acket/collects/racket/list.rkt:565:2 parse-loop12 [197] 53.3% append-map [192] 33.5% f137 [177] 10.2% ------------------------------------------------------------------------------------------- localize-error [72] 34.6% sort-context-on-expr [189] 65.4% [193] 902(0.0%) 0(0.0%) ??? ...cket/collects/racket/private/sort.rkt:403:3 generic-sort/key [198] 94.5% loop [209] 5.5% ------------------------------------------------------------------------------------------- pick-errors [190] 100.0% [194] 164(0.0%) 0(0.0%) for-loop ...bie/develop/src/core/regimes.rkt:199:2 ??? [199] 100.0% ------------------------------------------------------------------------------------------- pick-errors [190] 100.0% [195] 56(0.0%) 0(0.0%) point->alt ...e/develop/src/core/regimes.rkt:184:0 eval-prog [161] 100.0% ------------------------------------------------------------------------------------------- err-lsts->split-indices [191] 100.0% [196] 52(0.0%) 0(0.0%) add-splitpoint ...velop/src/core/regimes.rkt:252:2 for-loop [200] 100.0% ------------------------------------------------------------------------------------------- ??? [6] 0.4% f137 [177] 0.5% loop [215] 1.1% map [182] 8.2% hash-ref! [206] 8.7% for-loop [35] 15.4% simplify [171] 16.2% parse-loop12 [197] 23.3% append-map [192] 26.3% [197] 35250(1.8%) 10322(0.5%) parse-loop12 ...s/racket/match/compiler.rkt:418:15 parse-loop12 [197] 23.3% make-multiplication-node [29] 19.4% for-loop [202] 15.4% loop [215] 10.6% for-loop [14] 5.3% f137 [177] 4.2% map [182] 3.1% parse-app [203] 2.7% simplify* [178] 0.4% loop [201] 0.3% table-ref [226] 0.2% ------------------------------------------------------------------------------------------- ??? [193] 100.0% [198] 852(0.0%) 0(0.0%) generic-sort/key .../racket/private/sort.rkt:185:2 copying-mergesort [204] 100.0% ------------------------------------------------------------------------------------------- for-loop [194] 100.0% [199] 164(0.0%) 0(0.0%) ??? ...s/herbie/develop/src/core/regimes.rkt:190:2 ??? [162] 100.0% ------------------------------------------------------------------------------------------- add-splitpoint [196] 100.0% [200] 52(0.0%) 0(0.0%) for-loop ...bie/develop/src/core/regimes.rkt:254:4 for-loop [205] 100.0% ------------------------------------------------------------------------------------------- parse-loop12 [197] 0.7% loop [201] 6.2% sindices->spoints [187] 93.1% [201] 9588(0.5%) 330(0.0%) loop ...cket/collects/racket/private/map.rkt:36:19 sidx->spoint [207] 93.1% loop [201] 6.2% ??? [166] 0.1% ------------------------------------------------------------------------------------------- parse-loop12 [197] 100.0% [202] 8114(0.4%) 0(0.0%) for-loop ...bie/develop/src/core/taylor.rkt:490:59 hash-ref! [206] 100.0% ------------------------------------------------------------------------------------------- f137 [177] 10.2% eval-prog [161] 11.5% for-loop [7] 24.7% parse-loop12 [197] 42.9% [203] 3112(0.2%) 1780(0.1%) parse-app .../collects/racket/private/kw.rkt:951:2 loop [208] 42.8% ------------------------------------------------------------------------------------------- generic-sort/key [198] 46.9% copying-mergesort [204] 53.1% [204] 852(0.0%) 0(0.0%) copying-mergesort ...racket/private/sort.rkt:130:8 copying-mergesort [204] 53.1% jloop [18] 27.9% loop [209] 19.0% ------------------------------------------------------------------------------------------- for-loop [200] 100.0% [205] 52(0.0%) 52(0.0%) for-loop ...bie/develop/src/core/regimes.rkt:258:8 ------------------------------------------------------------------------------------------- for-loop [44] 0.4% first-nonzero-exp [40] 0.4% simplify* [178] 0.4% update-leader! [87] 0.5% localize-error [72] 0.9% for-loop [36] 1.0% for-loop [202] 1.2% eval-prog [161] 1.4% ??? [8] 1.5% for-loop [52] 1.7% ??? [188] 2.7% for-loop [31] 2.8% loop [215] 3.6% ??? [211] 7.4% for-loop [27] 9.0% ??? [166] 12.4% compile [90] 23.5% ??? [210] 27.8% [206] 86352(4.4%) 39534(2.0%) hash-ref! ...racket/private/more-scheme.rkt:373:13 ??? [210] 34.6% simplify [171] 13.6% ??? [6] 9.1% ??? [211] 7.4% parse-loop12 [197] 3.2% ??? [10] 2.8% ??? [8] 2.5% ??? [11] 1.7% ??? [12] 1.2% bigfloat-hash [213] 1.1% f137 [177] 0.3% ??? [15] 0.2% ------------------------------------------------------------------------------------------- loop [201] 100.0% [207] 8926(0.5%) 0(0.0%) sidx->spoint ...develop/src/core/regimes.rkt:139:2 binary-search [212] 90.5% binary-search-floats [214] 9.5% ------------------------------------------------------------------------------------------- loop [208] 28.7% parse-app [203] 71.3% [208] 1332(0.1%) 1332(0.1%) loop .../collects/racket/private/stxcase.rkt:112:7 loop [208] 28.7% ------------------------------------------------------------------------------------------- ??? [193] 18.9% copying-mergesort [204] 81.1% [209] 264(0.0%) 0(0.0%) loop ...ket/collects/racket/private/sort.rkt:97:12 ??? [162] 100.0% ------------------------------------------------------------------------------------------- hash-ref! [206] 100.0% [210] 40430(2.1%) 6752(0.3%) ??? ...tlies/herbie/develop/src/programs.rkt:192:5 hash-ref! [206] 83.4% loop [215] 9.6% ------------------------------------------------------------------------------------------- hash-ref! [206] 100.0% [211] 26004(1.3%) 0(0.0%) ??? ...es/herbie/develop/src/core/taylor.rkt:44:15 hash-ref! [206] 100.0% ------------------------------------------------------------------------------------------- sidx->spoint [207] 100.0% [212] 8074(0.4%) 0(0.0%) binary-search ...rbie/develop/src/common.rkt:226:0 pred [216] 100.0% ------------------------------------------------------------------------------------------- hash-ref! [206] 100.0% [213] 3650(0.2%) 150(0.0%) bigfloat-hash ...h/private/bigfloat/mpfr.rkt:165:0 bfcanonicalize [217] 83.0% sig+exp->bigfloat [218] 10.1% bigfloat->sig+exp [223] 2.8% ------------------------------------------------------------------------------------------- sidx->spoint [207] 100.0% [214] 852(0.0%) 0(0.0%) binary-search-floats ...velop/src/common.rkt:241:0 pred [216] 94.4% close-enough [219] 5.6% ------------------------------------------------------------------------------------------- errors-score [43] 0.0% option-on-expr [183] 0.0% loop [128] 0.1% make-exacts* [126] 0.3% taylor [16] 0.6% map [182] 1.0% map-enodes [28] 2.3% ??? [210] 3.2% parse-loop12 [197] 3.6% match-e [63] 4.4% f137 [177] 5.3% for-loop [78] 6.4% loop! [100] 14.6% loop [215] 58.1% [215] 109126(5.6%) 12892(0.7%) loop ...cket/collects/racket/private/map.rkt:25:19 loop [215] 58.1% loop! [100] 13.4% option-on-expr [183] 5.2% hash-ref! [206] 3.2% foldl [220] 2.5% for-loop [7] 2.3% f137 [177] 1.7% parse-loop12 [197] 1.6% ??? [188] 1.1% simplify [171] 0.6% ??? [162] 0.3% ??? [166] 0.0% set-precompute! [222] 0.0% errors [157] 0.0% bf* [221] 0.0% ??? [229] 0.0% ------------------------------------------------------------------------------------------- binary-search-floats [214] 9.1% binary-search [212] 90.9% [216] 8878(0.5%) 0(0.0%) pred ...herbie/develop/src/core/regimes.rkt:145:17 loop [103] 64.7% errors [157] 34.0% ------------------------------------------------------------------------------------------- bigfloat-hash [213] 100.0% [217] 3028(0.2%) 2758(0.1%) bfcanonicalize .../private/bigfloat/mpfr.rkt:155:0 bigfloat->sig+exp [223] 8.9% ------------------------------------------------------------------------------------------- bigfloat-hash [213] 100.0% [218] 370(0.0%) 162(0.0%) sig+exp->bigfloat ...ivate/bigfloat/mpfr.rkt:385:0 integer->mpz [224] 56.2% ------------------------------------------------------------------------------------------- binary-search-floats [214] 100.0% [219] 48(0.0%) 0(0.0%) close-enough ...develop/src/core/regimes.rkt:155:6 ulp-difference [225] 100.0% ------------------------------------------------------------------------------------------- for-loop [78] 37.6% loop [215] 62.4% [220] 7344(0.4%) 2798(0.1%) foldl ...et/collects/racket/private/list.rkt:229:4 merge2 [228] 61.9% ------------------------------------------------------------------------------------------- loop [215] 17.1% ??? [167] 82.9% [221] 1956(0.1%) 0(0.0%) bf* ...ath/private/bigfloat/bigfloat-mpfr.rkt:95:0 ??? [229] 100.0% ------------------------------------------------------------------------------------------- map-enodes [28] 30.5% loop [215] 69.5% [222] 1036(0.1%) 740(0.0%) set-precompute! ...lop/src/core/simplify.rkt:193:0 make-sequence [227] 28.6% ------------------------------------------------------------------------------------------- bigfloat-hash [213] 27.4% bfcanonicalize [217] 72.6% [223] 372(0.0%) 260(0.0%) bigfloat->sig+exp ...ivate/bigfloat/mpfr.rkt:370:0 new-mpz [230] 16.7% mpz->integer [231] 13.4% ------------------------------------------------------------------------------------------- sig+exp->bigfloat [218] 100.0% [224] 208(0.0%) 208(0.0%) integer->mpz ...math/private/bigfloat/gmp.rkt:87:0 ------------------------------------------------------------------------------------------- close-enough [219] 23.5% for-loop [158] 76.5% [225] 204(0.0%) 50(0.0%) ulp-difference ...erbie/develop/src/float.rkt:19:0 return/no-unsupplied [244] 75.5% ------------------------------------------------------------------------------------------- parse-loop12 [197] 0.0% simplify-alt [55] 0.0% f137 [177] 0.2% ??? [166] 2.2% get-sigs [121] 2.7% table-ref [226] 3.5% for-loop [75] 4.8% for-loop [232] 41.8% ??? [85] 44.5% [226] 1813636(92.8%) 109744(5.6%) table-ref .../racket/private/norm-define.rkt:53:83 for-loop [232] 41.8% iterate-egraph!13 [3] 34.8% loop [4] 9.6% ??? [233] 5.3% table-ref [226] 3.5% ??? [166] 1.7% mk-egraph [235] 0.3% ??? [243] 0.3% return/no-unsupplied [244] 0.2% ??? [242] 0.1% dict? [268] 0.0% list-member? [234] 0.0% ??? [237] 0.0% loop [17] 0.0% f137 [177] 0.0% debug7 [238] 0.0% loop [240] 0.0% ------------------------------------------------------------------------------------------- set-precompute! [222] 5.5% ??? [133] 7.2% reduce-to-single! [71] 8.0% update-leader! [87] 15.6% merge-egraph-nodes! [76] 30.4% for-loop [48] 33.3% [227] 5398(0.3%) 4892(0.3%) make-sequence ...ects/racket/private/for.rkt:509:2 ??? [239] 9.4% ------------------------------------------------------------------------------------------- foldl [220] 100.0% [228] 4546(0.2%) 4546(0.2%) merge2 .../herbie/develop/src/core/ematch.rkt:31:0 ------------------------------------------------------------------------------------------- loop [215] 8.1% ??? [167] 42.7% bf* [221] 49.1% [229] 3982(0.2%) 216(0.0%) ??? ...-racket/utils/simple-result-arrow.rkt:39:12 bfadd [236] 94.6% ------------------------------------------------------------------------------------------- bigfloat->sig+exp [223] 100.0% [230] 62(0.0%) 62(0.0%) new-mpz ...-lib/math/private/bigfloat/gmp.rkt:73:0 ------------------------------------------------------------------------------------------- bigfloat->sig+exp [223] 100.0% [231] 50(0.0%) 50(0.0%) mpz->integer ...ath/private/bigfloat/gmp.rkt:115:0 ------------------------------------------------------------------------------------------- table-ref [226] 100.0% [232] 1643444(84.1%) 206(0.0%) for-loop ...ie/develop/src/core/simplify.rkt:66:12 table-ref [226] 100.0% ------------------------------------------------------------------------------------------- hash-has-key? [142] 19.3% table-ref [226] 80.7% [233] 345570(17.7%) 139766(7.2%) ??? ...ects/racket/contract/private/list.rkt:737:4 for-loop [241] 43.7% ??? [252] 14.0% ??? [242] 1.1% arrow-higher-order:lnp [258] 0.4% successfully-got-the-right-kind-of-function [249] 0.3% ??? [260] 0.1% ------------------------------------------------------------------------------------------- ??? [172] 2.2% table-ref [226] 2.2% for-loop [61] 95.6% [234] 16334(0.8%) 1294(0.1%) list-member? ...llects/racket/private/set.rkt:24:0 loop [246] 60.8% member [248] 31.2% ------------------------------------------------------------------------------------------- table-ref [226] 100.0% [235] 11042(0.6%) 0(0.0%) mk-egraph ...bie/develop/src/core/egraph.rkt:131:0 mk-enode-rec! [245] 99.1% mk-enode! [86] 0.9% ------------------------------------------------------------------------------------------- ??? [229] 100.0% [236] 3766(0.2%) 3102(0.2%) bfadd ...-lib/math/private/bigfloat/mpfr.rkt:819:4 ??? [250] 17.6% ------------------------------------------------------------------------------------------- table-ref [226] 20.2% hash-has-key? [142] 79.8% [237] 3332(0.2%) 3332(0.2%) ??? ...ects/racket/contract/private/hash.rkt:245:7 ------------------------------------------------------------------------------------------- table-ref [226] 6.2% taylor [16] 27.3% simplify [171] 66.4% [238] 2406(0.1%) 788(0.0%) debug7 ...tlies/herbie/develop/src/debug.rkt:102:0 ??? [131] 27.0% return/no-unsupplied [244] 26.8% ??? [243] 13.5% ------------------------------------------------------------------------------------------- make-sequence [227] 100.0% [239] 506(0.0%) 256(0.0%) ??? ...acket/collects/racket/private/for.rkt:429:7 custom-in-set [247] 49.4% ------------------------------------------------------------------------------------------- table-ref [226] 100.0% [240] 50(0.0%) 0(0.0%) loop ...ghtlies/herbie/develop/src/points.rkt:66:6 random-exp [251] 100.0% ------------------------------------------------------------------------------------------- ??? [233] 100.0% [241] 151162(7.7%) 75240(3.9%) for-loop ...acket/contract/private/list.rkt:743:12 ??? [252] 27.2% for-loop [141] 19.1% ??? [257] 1.8% ??? [260] 1.5% arrow-higher-order:lnp [258] 0.6% ------------------------------------------------------------------------------------------- ??? [233] 2.8% table-ref [226] 4.0% ??? [145] 33.9% for-loop [141] 58.6% [242] 134984(6.9%) 27854(1.4%) ??? ...cts/racket/contract/private/list.rkt:187:10 ??? [253] 56.1% ??? [145] 10.7% for-loop [255] 10.6% ??? [262] 2.0% ------------------------------------------------------------------------------------------- debug7 [238] 0.9% flag-set? [70] 7.0% ??? [172] 10.7% table-ref [226] 34.6% ??? [144] 46.8% [243] 34378(1.8%) 7900(0.4%) ??? ...racket/collects/racket/private/kw.rkt:761:9 ??? [254] 52.2% ??? [260] 24.8% ------------------------------------------------------------------------------------------- ulp-difference [225] 0.6% simplify* [178] 1.2% debug7 [238] 2.6% flag-set? [70] 9.2% ??? [172] 10.6% table-ref [226] 32.3% ??? [144] 43.5% [244] 24968(1.3%) 17964(0.9%) return/no-unsupplied ...ct/private/arr-i.rkt:533:0 filter [256] 28.1% ------------------------------------------------------------------------------------------- mk-egraph [235] 23.1% mk-enode-rec! [245] 76.9% [245] 10942(0.6%) 0(0.0%) mk-enode-rec! ...develop/src/core/egraph.rkt:122:0 mk-enode-rec! [245] 76.9% mk-enode! [86] 23.1% ------------------------------------------------------------------------------------------- list-member? [234] 100.0% [246] 9936(0.5%) 9936(0.5%) loop (unknown source) ------------------------------------------------------------------------------------------- ??? [104] 1.5% ??? [239] 3.8% setfindf [32] 15.7% match-e [63] 78.9% [247] 6504(0.3%) 6504(0.3%) custom-in-set ...acket/private/set-types.rkt:577:0 ------------------------------------------------------------------------------------------- list-member? [234] 100.0% [248] 5104(0.3%) 5104(0.3%) member (unknown source) ------------------------------------------------------------------------------------------- maybe-cons-kwd [84] 9.9% ??? [233] 90.1% [249] 1028(0.1%) 718(0.0%) successfully-got-the-right-kind-of-function ...9:4 arity-checking-wrapper [259] 30.2% ------------------------------------------------------------------------------------------- bfadd [236] 100.0% [250] 664(0.0%) 664(0.0%) ??? .../share/racket/collects/ffi/unsafe.rkt:861:4 ------------------------------------------------------------------------------------------- loop [240] 100.0% [251] 50(0.0%) 50(0.0%) random-exp .../herbie/develop/src/common.rkt:251:0 ------------------------------------------------------------------------------------------- for-loop [241] 46.0% ??? [233] 54.0% [252] 89440(4.6%) 43772(2.2%) ??? ...private/unconstrained-domain-arrow.rkt:74:4 make-keyword-procedure [261] 51.1% ------------------------------------------------------------------------------------------- ??? [242] 100.0% [253] 75726(3.9%) 7084(0.4%) ??? ...ects/racket/contract/private/list.rkt:686:7 ??? [260] 83.8% ??? [262] 6.8% ------------------------------------------------------------------------------------------- ??? [243] 100.0% [254] 17936(0.9%) 16376(0.8%) ??? ...s/racket/contract/private/arr-i.rkt:1233:27 ??? [264] 8.7% ------------------------------------------------------------------------------------------- ??? [242] 100.0% [255] 14304(0.7%) 8936(0.5%) for-loop ...acket/contract/private/list.rkt:190:15 ??? [145] 37.5% ------------------------------------------------------------------------------------------- one-iter [23] 3.3% match-e [63] 6.6% for-loop [78] 13.2% return/no-unsupplied [244] 77.0% [256] 9096(0.5%) 9096(0.5%) filter ...t/collects/racket/private/list.rkt:256:2 ------------------------------------------------------------------------------------------- ??? [132] 15.6% for-loop [241] 39.3% ??? [145] 45.1% [257] 6806(0.3%) 2362(0.1%) ??? ...ects/racket/contract/private/hash.rkt:222:6 check-hash/c [263] 65.3% ------------------------------------------------------------------------------------------- maybe-cons-kwd [84] 2.4% for-loop [241] 40.2% ??? [233] 57.4% [258] 2358(0.1%) 1346(0.1%) arrow-higher-order:lnp ...w-higher-order.rkt:597:7 ??? [265] 42.9% ------------------------------------------------------------------------------------------- successfully-got-the-right-kind-of-function [249]100.0% [259] 310(0.0%) 108(0.0%) arity-checking-wrapper ...w-higher-order.rkt:402:0 matches-arity-exactly? [266] 65.2% ------------------------------------------------------------------------------------------- ??? [233] 0.3% ??? [131] 2.2% for-loop [241] 2.4% ??? [166] 5.9% ??? [243] 9.2% ??? [145] 10.2% ??? [253] 68.5% [260] 92714(4.7%) 74234(3.8%) ??? ...ects/racket/contract/private/guts.rkt:644:8 contract? [267] 8.6% ??? [131] 6.4% dict? [268] 5.0% ------------------------------------------------------------------------------------------- ??? [252] 100.0% [261] 45668(2.3%) 45668(2.3%) make-keyword-procedure ...ket/private/kw.rkt:260:4 ------------------------------------------------------------------------------------------- ??? [167] 4.3% for-loop [141] 14.8% ??? [242] 27.6% ??? [253] 52.9% [262] 9780(0.5%) 4438(0.2%) ??? ...ects/racket/contract/private/prop.rkt:493:4 ??? [269] 54.6% ------------------------------------------------------------------------------------------- ??? [257] 100.0% [263] 4444(0.2%) 2280(0.1%) check-hash/c ...ket/contract/private/hash.rkt:83:0 flat-contract? [270] 48.7% ------------------------------------------------------------------------------------------- ??? [132] 22.5% ??? [254] 77.5% [264] 2012(0.1%) 2012(0.1%) ??? ...ects/racket/contract/private/prop.rkt:256:4 ------------------------------------------------------------------------------------------- arrow-higher-order:lnp [258] 100.0% [265] 1012(0.1%) 1012(0.1%) ??? ...et/contract/private/arity-checking.rkt:19:2 ------------------------------------------------------------------------------------------- arity-checking-wrapper [259] 100.0% [266] 202(0.0%) 202(0.0%) matches-arity-exactly? ...te/arrow-common.rkt:70:0 ------------------------------------------------------------------------------------------- ??? [260] 100.0% [267] 7932(0.4%) 7932(0.4%) contract? ...acket/contract/private/guts.rkt:109:0 ------------------------------------------------------------------------------------------- table-ref [226] 36.4% ??? [260] 63.6% [268] 7270(0.4%) 7270(0.4%) dict? ...ollects/racket/private/generic.rkt:146:11 ------------------------------------------------------------------------------------------- ??? [262] 100.0% [269] 5342(0.3%) 2286(0.1%) ??? ...lects/racket/contract/private/orc.rkt:83:14 ??? [271] 57.2% ------------------------------------------------------------------------------------------- check-hash/c [263] 100.0% [270] 2164(0.1%) 2164(0.1%) flat-contract? .../contract/private/guts.rkt:111:0 ------------------------------------------------------------------------------------------- ??? [269] 100.0% [271] 3056(0.2%) 3056(0.2%) ??? ...ects/racket/contract/private/list.rkt:141:5 -------------------------------------------------------------------------------------------