Profiling results ----------------- Total cpu time observed: 148138ms (out of 149216ms) Number of samples taken: 422 (once every 351ms) (Hiding functions with self<1.0% and local<2.0%: 5 of 203 hidden) ================================================================================ Caller Idx Total Self Name+src Local% ms(pct) ms(pct) Callee ================================================================================ ??? [24] 100.0% [1] 136424(92.1%) 0(0.0%) profile-thunk16 ...t/pkgs/profile-lib/main.rkt:9:0 run [13] 100.0% -------------------------------------------------------------------------------- location-do [132] 100.0% [2] 34566(23.3%) 328(0.2%) iterate-egraph!13 ...p/src/core/simplify.rkt:102:0 one-iter [14] 91.3% map-enodes [22] 7.8% -------------------------------------------------------------------------------- ??? [127] 100.0% [3] 13910(9.4%) 0(0.0%) approximate9 ...e/develop/src/core/taylor.rkt:12:0 loop [15] 100.0% -------------------------------------------------------------------------------- hash-ref! [148] 100.0% [4] 10092(6.8%) 0(0.0%) ??? ...s/herbie/develop/src/core/taylor.rkt:295:23 for-loop [16] 100.0% -------------------------------------------------------------------------------- hash-ref! [148] 100.0% [5] 9558(6.5%) 0(0.0%) ??? ...s/herbie/develop/src/core/taylor.rkt:285:26 for-loop [17] 100.0% -------------------------------------------------------------------------------- hash-ref! [148] 100.0% [6] 9406(6.3%) 0(0.0%) ??? ...s/herbie/develop/src/core/taylor.rkt:392:23 for-loop [18] 100.0% -------------------------------------------------------------------------------- location-do [132] 100.0% [7] 4866(3.3%) 0(0.0%) loop ...herbie/develop/src/core/simplify.rkt:210:2 pass [19] 100.0% -------------------------------------------------------------------------------- hash-ref! [148] 100.0% [8] 2794(1.9%) 0(0.0%) ??? ...s/herbie/develop/src/core/taylor.rkt:483:23 for-loop [20] 100.0% -------------------------------------------------------------------------------- hash-ref! [148] 100.0% [9] 2788(1.9%) 0(0.0%) ??? ...s/herbie/develop/src/core/taylor.rkt:338:33 for-loop [21] 100.0% -------------------------------------------------------------------------------- map [128] 6.2% loop [164] 93.8% [10] 1784(1.2%) 0(0.0%) ??? ...ket/collects/racket/private/list.rkt:323:18 hash-ref! [148] 68.8% map [128] 31.2% -------------------------------------------------------------------------------- match-e [37] 100.0% [11] 1020(0.7%) 0(0.0%) variable? ...e/develop/src/syntax/syntax.rkt:529:0 ??? [63] 100.0% -------------------------------------------------------------------------------- hash-ref! [148] 100.0% [12] 368(0.2%) 0(0.0%) ??? ...s/herbie/develop/src/core/taylor.rkt:322:33 for-loop [23] 100.0% -------------------------------------------------------------------------------- profile-thunk16 [1] 99.2% [13] 137466(92.8%) 0(0.0%) run ...share/racket/pkgs/profile-lib/main.rkt:39:2 ??? [24] 100.0% -------------------------------------------------------------------------------- iterate-egraph!13 [2] 100.0% [14] 31554(21.3%) 1334(0.9%) one-iter ...ie/develop/src/core/simplify.rkt:113:0 for-loop [25] 66.8% loop [28] 24.6% apply-match [32] 4.4% -------------------------------------------------------------------------------- approximate9 [3] 100.0% [15] 13910(9.4%) 0(0.0%) loop ...es/herbie/develop/src/core/taylor.rkt:86:4 ??? [127] 100.0% -------------------------------------------------------------------------------- ??? [4] 100.0% [16] 10092(6.8%) 0(0.0%) for-loop ...bie/develop/src/core/taylor.rkt:298:27 hash-ref! [148] 100.0% -------------------------------------------------------------------------------- ??? [5] 100.0% [17] 9558(6.5%) 0(0.0%) for-loop ...bie/develop/src/core/taylor.rkt:285:52 hash-ref! [148] 83.0% ??? [30] 17.0% -------------------------------------------------------------------------------- ??? [6] 100.0% [18] 9406(6.3%) 0(0.0%) for-loop ...bie/develop/src/core/taylor.rkt:396:33 for-loop [27] 100.0% -------------------------------------------------------------------------------- loop [7] 100.0% [19] 4866(3.3%) 0(0.0%) pass ...herbie/develop/src/core/simplify.rkt:200:2 for-loop [29] 100.0% -------------------------------------------------------------------------------- ??? [8] 100.0% [20] 2794(1.9%) 0(0.0%) for-loop ...bie/develop/src/core/taylor.rkt:487:35 parse-loop12 [133] 100.0% -------------------------------------------------------------------------------- ??? [9] 100.0% [21] 2788(1.9%) 0(0.0%) for-loop ...bie/develop/src/core/taylor.rkt:341:46 hash-ref! [148] 100.0% -------------------------------------------------------------------------------- iterate-egraph!13 [2] 100.0% [22] 2684(1.8%) 0(0.0%) map-enodes ...ie/develop/src/core/egraph.rkt:139:0 loop [164] 86.7% for-loop [173] 13.3% -------------------------------------------------------------------------------- ??? [12] 100.0% [23] 368(0.2%) 0(0.0%) for-loop ...bie/develop/src/core/taylor.rkt:324:46 simplify [26] 100.0% -------------------------------------------------------------------------------- for-loop [62] 8.3% run [13] 44.0% [24] 143934(97.2%) 0(0.0%) ??? ...lects/racket/private/more-scheme.rkt:261:28 profile-thunk16 [1] 43.3% run-improve50 [31] 39.7% location-do [132] 11.2% loop [115] 5.8% -------------------------------------------------------------------------------- for-loop [25] 49.2% one-iter [14] 50.8% [25] 21068(14.2%) 7210(4.9%) for-loop ...e/develop/src/core/simplify.rkt:123:12 for-loop [25] 49.2% match-e [37] 32.9% -------------------------------------------------------------------------------- for-loop [23] 2.6% hash-ref! [148] 97.4% [26] 13910(9.4%) 0(0.0%) simplify ...erbie/develop/src/core/reduce.rkt:15:0 parse-loop12 [133] 53.1% f37 [49] 44.2% simplify* [142] 2.6% -------------------------------------------------------------------------------- for-loop [18] 100.0% [27] 9406(6.3%) 0(0.0%) for-loop ...bie/develop/src/core/taylor.rkt:398:39 hash-ref! [148] 100.0% -------------------------------------------------------------------------------- one-iter [14] 100.0% [28] 7766(5.2%) 0(0.0%) loop ...cket/collects/racket/private/map.rkt:52:19 apply-match [32] 100.0% -------------------------------------------------------------------------------- pass [19] 100.0% [29] 4866(3.3%) 0(0.0%) for-loop ...e/develop/src/core/simplify.rkt:203:29 argmin [33] 86.4% loop [34] 13.6% -------------------------------------------------------------------------------- for-loop [17] 100.0% [30] 1626(1.1%) 0(0.0%) ??? ...s/herbie/develop/src/core/taylor.rkt:288:19 hash-ref! [148] 100.0% -------------------------------------------------------------------------------- ??? [24] 100.0% [31] 123976(83.7%) 0(0.0%) run-improve50 ...ie/develop/src/mainloop.rkt:234:0 for-loop [35] 50.7% get-final-combination [36] 49.1% loop [115] 0.2% -------------------------------------------------------------------------------- one-iter [14] 15.1% loop [28] 84.9% [32] 9152(6.2%) 324(0.2%) apply-match ...develop/src/core/simplify.rkt:129:2 merge-egraph-nodes! [39] 22.4% mk-enode! [159] 15.7% for-loop [40] 15.4% match-e [37] 15.3% loop! [46] 11.9% substitute-e [42] 7.9% update-leader! [47] 7.9% -------------------------------------------------------------------------------- for-loop [29] 100.0% [33] 4202(2.8%) 0(0.0%) argmin ...re/racket/collects/racket/list.rkt:743:0 for-loop [38] 69.0% expression-cost [41] 31.0% -------------------------------------------------------------------------------- for-loop [29] 100.0% [34] 664(0.4%) 0(0.0%) loop ...hare/racket/collects/racket/list.rkt:729:4 for-loop [38] 100.0% -------------------------------------------------------------------------------- run-improve50 [31] 100.0% [35] 62822(42.4%) 0(0.0%) for-loop ...herbie/develop/src/mainloop.rkt:249:10 run-iter! [43] 100.0% -------------------------------------------------------------------------------- run-improve50 [31] 100.0% [36] 60862(41.1%) 0(0.0%) get-final-combination ...op/src/mainloop.rkt:264:0 split-table [44] 100.0% -------------------------------------------------------------------------------- apply-match [32] 3.8% for-loop [53] 20.0% for-loop [25] 76.1% [37] 15262(10.3%) 6914(4.7%) match-e ...herbie/develop/src/core/ematch.rkt:46:0 for-loop [45] 40.8% for-loop [53] 7.8% ??? [63] 6.7% variable? [11] 2.6% list-cartesian-product [58] 2.4% -------------------------------------------------------------------------------- loop [34] 18.6% argmin [33] 81.4% [38] 3564(2.4%) 0(0.0%) for-loop .../herbie/develop/src/programs.rkt:200:2 location-do [132] 100.0% -------------------------------------------------------------------------------- merge-egraph-nodes! [39] 8.8% apply-match [32] 91.2% [39] 2046(1.4%) 0(0.0%) merge-egraph-nodes! ...p/src/core/egraph.rkt:152:0 update-leader! [47] 74.9% loop! [46] 16.2% merge-egraph-nodes! [39] 8.8% -------------------------------------------------------------------------------- apply-match [32] 100.0% [40] 1408(1.0%) 0(0.0%) for-loop ...e/develop/src/core/simplify.rkt:143:10 loop! [46] 100.0% -------------------------------------------------------------------------------- argmin [33] 100.0% [41] 1302(0.9%) 328(0.2%) expression-cost .../develop/src/programs.rkt:199:0 compile [48] 74.8% -------------------------------------------------------------------------------- apply-match [32] 100.0% [42] 720(0.5%) 360(0.2%) substitute-e ...e/develop/src/core/ematch.rkt:71:0 mk-enode! [159] 50.0% -------------------------------------------------------------------------------- for-loop [35] 100.0% [43] 62822(42.4%) 0(0.0%) run-iter! ...herbie/develop/src/mainloop.rkt:215:0 simplify! [50] 56.5% gen-series! [51] 22.1% finalize-iter! [52] 18.0% localize-error [55] 2.8% gen-rewrites! [60] 0.5% -------------------------------------------------------------------------------- get-final-combination [36] 100.0% [44] 60862(41.1%) 0(0.0%) split-table ...s/herbie/develop/src/glue.rkt:162:0 f37 [49] 88.8% ??? [63] 11.2% -------------------------------------------------------------------------------- match-e [37] 100.0% [45] 8356(5.6%) 3208(2.2%) for-loop ...rbie/develop/src/core/ematch.rkt:59:11 for-loop [53] 55.6% foldl [59] 4.0% list-cartesian-product [58] 2.0% -------------------------------------------------------------------------------- merge-egraph-nodes! [39] 11.7% loop [164] 21.7% apply-match [32] 32.0% for-loop [40] 34.5% [46] 2832(1.9%) 370(0.2%) loop! ...s/herbie/develop/src/core/enode.rkt:163:2 custom-set-union [56] 48.2% loop [164] 34.4% set [57] 10.9% -------------------------------------------------------------------------------- apply-match [32] 29.6% merge-egraph-nodes! [39] 70.4% [47] 2434(1.6%) 0(0.0%) update-leader! ...evelop/src/core/egraph.rkt:217:0 for-loop [54] 100.0% -------------------------------------------------------------------------------- expression-cost [41] 100.0% [48] 974(0.7%) 0(0.0%) compile ...s/herbie/develop/src/programs.rkt:176:0 hash-ref! [148] 100.0% -------------------------------------------------------------------------------- map [128] 0.4% hash-ref! [148] 0.5% parse-loop12 [133] 0.7% loop [164] 1.4% eval-prog [121] 5.2% simplify [26] 7.5% f37 [49] 8.8% split-table [44] 75.5% [49] 64862(43.8%) 692(0.5%) f37 ...t/collects/racket/match/compiler.rkt:507:40 loop [164] 67.5% map [128] 9.7% f37 [49] 8.8% option-on-expr [61] 8.0% ??? [127] 5.2% -------------------------------------------------------------------------------- run-iter! [43] 100.0% [50] 35500(24.0%) 0(0.0%) simplify! ...herbie/develop/src/mainloop.rkt:155:0 for-loop [62] 100.0% -------------------------------------------------------------------------------- run-iter! [43] 100.0% [51] 13910(9.4%) 0(0.0%) gen-series! ...rbie/develop/src/mainloop.rkt:129:0 for-loop [64] 100.0% -------------------------------------------------------------------------------- run-iter! [43] 100.0% [52] 11298(7.6%) 0(0.0%) finalize-iter! ...e/develop/src/mainloop.rkt:169:0 ??? [63] 100.0% -------------------------------------------------------------------------------- match-e [37] 25.0% for-loop [45] 75.0% [53] 6182(4.2%) 632(0.4%) for-loop ...rbie/develop/src/core/ematch.rkt:65:37 match-e [37] 86.7% ??? [68] 5.8% -------------------------------------------------------------------------------- update-leader! [47] 100.0% [54] 2434(1.6%) 722(0.5%) for-loop ...rbie/develop/src/core/egraph.rkt:222:6 for-loop [65] 70.3% -------------------------------------------------------------------------------- run-iter! [43] 100.0% [55] 1784(1.2%) 0(0.0%) localize-error ...velop/src/core/localize.rkt:47:0 hash-ref! [148] 100.0% -------------------------------------------------------------------------------- loop! [46] 100.0% [56] 1364(0.9%) 362(0.2%) custom-set-union ...et/private/set-types.rkt:168:0 for-loop [67] 49.4% for-loop [71] 24.0% -------------------------------------------------------------------------------- loop! [46] 100.0% [57] 738(0.5%) 738(0.5%) set ...collects/racket/private/set-types.rkt:981:0 -------------------------------------------------------------------------------- list-cartesian-product [58] 26.1% match-e [37] 26.1% for-loop [45] 47.8% [58] 690(0.5%) 0(0.0%) list-cartesian-product ...src/core/ematch.rkt:20:0 for-loop [66] 73.9% list-cartesian-product [58] 26.1% -------------------------------------------------------------------------------- for-loop [45] 100.0% [59] 336(0.2%) 0(0.0%) foldl ...et/collects/racket/private/list.rkt:229:4 merge2 [69] 100.0% -------------------------------------------------------------------------------- run-iter! [43] 100.0% [60] 330(0.2%) 0(0.0%) gen-rewrites! ...ie/develop/src/mainloop.rkt:142:0 for-loop [70] 100.0% -------------------------------------------------------------------------------- f37 [49] 10.1% loop [164] 89.9% [61] 54052(36.5%) 0(0.0%) option-on-expr ...evelop/src/core/regimes.rkt:92:0 sindices->spoints [72] 65.7% pick-errors [74] 23.7% sort-context-on-expr [78] 5.7% err-lsts->split-indices [80] 3.1% errors [116] 1.9% -------------------------------------------------------------------------------- simplify! [50] 100.0% [62] 35500(24.0%) 0(0.0%) for-loop .../herbie/develop/src/mainloop.rkt:159:6 ??? [24] 100.0% -------------------------------------------------------------------------------- variable? [11] 4.2% match-e [37] 8.7% ??? [191] 17.2% split-table [44] 24.7% finalize-iter! [52] 45.2% [63] 24240(16.4%) 2398(1.6%) ??? ...contract/private/arrow-val-first.rkt:357:18 for-loop [75] 42.6% split-atab [76] 24.7% hash-has-key? [77] 18.7% atab-add-altns [81] 2.6% ??? [191] 1.5% -------------------------------------------------------------------------------- gen-series! [51] 100.0% [64] 13910(9.4%) 0(0.0%) for-loop .../herbie/develop/src/mainloop.rkt:135:7 taylor-alt [73] 100.0% -------------------------------------------------------------------------------- for-loop [54] 100.0% [65] 1712(1.2%) 0(0.0%) for-loop ...rbie/develop/src/core/egraph.rkt:223:8 hash-update! [79] 100.0% -------------------------------------------------------------------------------- list-cartesian-product [58] 100.0% [66] 690(0.5%) 690(0.5%) for-loop ...erbie/develop/src/core/ematch.rkt:24:8 -------------------------------------------------------------------------------- custom-set-union [56] 100.0% [67] 674(0.5%) 332(0.2%) for-loop ...cts/racket/private/set-types.rkt:174:3 for-loop [82] 50.7% -------------------------------------------------------------------------------- for-loop [53] 100.0% [68] 358(0.2%) 358(0.2%) ??? ...ies/herbie/develop/src/core/ematch.rkt:50:5 -------------------------------------------------------------------------------- foldl [59] 100.0% [69] 336(0.2%) 336(0.2%) merge2 .../herbie/develop/src/core/ematch.rkt:31:0 -------------------------------------------------------------------------------- gen-rewrites! [60] 100.0% [70] 330(0.2%) 0(0.0%) for-loop ...herbie/develop/src/mainloop.rkt:147:11 ??? [83] 100.0% -------------------------------------------------------------------------------- custom-set-union [56] 100.0% [71] 328(0.2%) 328(0.2%) for-loop ...cts/racket/private/set-types.rkt:152:2 -------------------------------------------------------------------------------- option-on-expr [61] 100.0% [72] 35494(24.0%) 0(0.0%) sindices->spoints ...op/src/core/regimes.rkt:105:0 loop [84] 99.0% eval-prog [121] 1.0% -------------------------------------------------------------------------------- for-loop [64] 100.0% [73] 13910(9.4%) 0(0.0%) taylor-alt ...es/herbie/develop/src/glue.rkt:139:0 for-loop [85] 100.0% -------------------------------------------------------------------------------- option-on-expr [61] 100.0% [74] 12792(8.6%) 0(0.0%) pick-errors .../develop/src/core/regimes.rkt:160:0 for-loop [86] 100.0% -------------------------------------------------------------------------------- ??? [63] 100.0% [75] 10668(7.2%) 0(0.0%) for-loop ...ie/develop/src/core/alt-table.rkt:51:2 atab-add-altn [87] 100.0% -------------------------------------------------------------------------------- ??? [63] 100.0% [76] 6810(4.6%) 0(0.0%) split-atab .../develop/src/core/alt-table.rkt:74:0 for-loop [88] 100.0% -------------------------------------------------------------------------------- ??? [63] 100.0% [77] 5684(3.8%) 1054(0.7%) hash-has-key? ...et/private/more-scheme.rkt:368:13 ??? [140] 75.7% ??? [93] 5.7% -------------------------------------------------------------------------------- option-on-expr [61] 100.0% [78] 3102(2.1%) 0(0.0%) sort-context-on-expr ...velop/src/points.rkt:115:0 ??? [89] 100.0% -------------------------------------------------------------------------------- for-loop [65] 100.0% [79] 1712(1.2%) 0(0.0%) hash-update! ...ket/private/more-scheme.rkt:362:13 ??? [90] 100.0% -------------------------------------------------------------------------------- option-on-expr [61] 100.0% [80] 1650(1.1%) 0(0.0%) err-lsts->split-indices .../core/regimes.rkt:214:0 add-splitpoint [91] 100.0% -------------------------------------------------------------------------------- ??? [63] 100.0% [81] 630(0.4%) 0(0.0%) atab-add-altns ...elop/src/core/alt-table.rkt:50:0 atab-add-altn [87] 100.0% -------------------------------------------------------------------------------- for-loop [67] 100.0% [82] 342(0.2%) 342(0.2%) for-loop ...cts/racket/private/set-types.rkt:178:5 -------------------------------------------------------------------------------- for-loop [70] 100.0% [83] 330(0.2%) 0(0.0%) ??? ...ies/herbie/develop/src/alternative.rkt:88:0 rewriter [92] 100.0% -------------------------------------------------------------------------------- parse-loop12 [133] 0.0% loop [84] 0.9% sindices->spoints [72] 99.1% [84] 35470(23.9%) 0(0.0%) loop ...cket/collects/racket/private/map.rkt:36:19 sidx->spoint [94] 99.1% loop [84] 0.9% ->flonum [176] 0.0% -------------------------------------------------------------------------------- taylor-alt [73] 100.0% [85] 13910(9.4%) 0(0.0%) for-loop ...lies/herbie/develop/src/glue.rkt:141:2 ??? [127] 100.0% -------------------------------------------------------------------------------- pick-errors [74] 100.0% [86] 12792(8.6%) 0(0.0%) for-loop ...bie/develop/src/core/regimes.rkt:163:6 eval-prog [121] 89.4% ??? [172] 10.6% -------------------------------------------------------------------------------- atab-add-altns [81] 5.6% for-loop [75] 94.4% [87] 11298(7.6%) 0(0.0%) atab-add-altn ...elop/src/core/alt-table.rkt:208:0 best-and-tied-at-points [95] 93.6% override-at-pnts [102] 6.4% -------------------------------------------------------------------------------- split-atab [76] 100.0% [88] 6810(4.6%) 0(0.0%) for-loop ...ie/develop/src/core/alt-table.rkt:75:2 for-loop [96] 41.3% for-loop [98] 29.5% for-loop [99] 29.2% -------------------------------------------------------------------------------- sort-context-on-expr [78] 100.0% [89] 3102(2.1%) 0(0.0%) ??? ...cket/collects/racket/private/sort.rkt:403:3 generic-sort/key [97] 77.6% loop [113] 22.4% -------------------------------------------------------------------------------- hash-update! [79] 100.0% [90] 1712(1.2%) 0(0.0%) ??? ...s/herbie/develop/src/core/egraph.rkt:225:24 for-loop [100] 100.0% -------------------------------------------------------------------------------- err-lsts->split-indices [80] 100.0% [91] 1650(1.1%) 0(0.0%) add-splitpoint ...velop/src/core/regimes.rkt:227:2 for-loop [101] 100.0% -------------------------------------------------------------------------------- matcher [110] 50.0% ??? [83] 50.0% [92] 330(0.2%) 0(0.0%) rewriter ...bie/develop/src/core/matcher.rkt:127:2 for-loop [103] 100.0% -------------------------------------------------------------------------------- hash-has-key? [77] 100.0% [93] 326(0.2%) 326(0.2%) ??? ...ects/racket/contract/private/hash.rkt:245:7 -------------------------------------------------------------------------------- loop [84] 100.0% [94] 35134(23.7%) 0(0.0%) sidx->spoint ...develop/src/core/regimes.rkt:115:2 binary-search [104] 83.1% binary-search-floats [105] 16.9% -------------------------------------------------------------------------------- atab-add-altn [87] 100.0% [95] 10570(7.1%) 0(0.0%) best-and-tied-at-points ...ore/alt-table.rkt:122:0 errors [116] 100.0% -------------------------------------------------------------------------------- for-loop [88] 100.0% [96] 2814(1.9%) 0(0.0%) for-loop ...e/develop/src/core/alt-table.rkt:80:53 loop [106] 100.0% -------------------------------------------------------------------------------- ??? [89] 100.0% [97] 2406(1.6%) 0(0.0%) generic-sort/key .../racket/private/sort.rkt:185:2 copying-mergesort [107] 73.6% loop [113] 26.4% -------------------------------------------------------------------------------- for-loop [88] 100.0% [98] 2008(1.4%) 0(0.0%) for-loop ...e/develop/src/core/alt-table.rkt:86:30 ??? [112] 100.0% -------------------------------------------------------------------------------- for-loop [88] 100.0% [99] 1988(1.3%) 0(0.0%) for-loop ...e/develop/src/core/alt-table.rkt:76:45 ??? [112] 100.0% -------------------------------------------------------------------------------- ??? [90] 100.0% [100] 1712(1.2%) 1050(0.7%) for-loop ...bie/develop/src/core/egraph.rkt:226:26 update-en-expr [109] 38.7% -------------------------------------------------------------------------------- add-splitpoint [91] 100.0% [101] 1650(1.1%) 652(0.4%) for-loop ...bie/develop/src/core/regimes.rkt:229:4 for-loop [108] 60.5% -------------------------------------------------------------------------------- atab-add-altn [87] 100.0% [102] 728(0.5%) 0(0.0%) override-at-pnts ...p/src/core/alt-table.rkt:145:0 errors [116] 100.0% -------------------------------------------------------------------------------- rewriter [92] 100.0% [103] 330(0.2%) 0(0.0%) for-loop ...ie/develop/src/core/matcher.rkt:130:10 matcher [110] 100.0% -------------------------------------------------------------------------------- sidx->spoint [94] 100.0% [104] 29200(19.7%) 0(0.0%) binary-search ...rbie/develop/src/common.rkt:212:0 pred [111] 100.0% -------------------------------------------------------------------------------- sidx->spoint [94] 100.0% [105] 5934(4.0%) 0(0.0%) binary-search-floats ...velop/src/common.rkt:227:0 pred [111] 100.0% -------------------------------------------------------------------------------- for-loop [96] 100.0% [106] 2814(1.9%) 0(0.0%) loop ...ket/collects/racket/private/list.rkt:264:4 ??? [112] 100.0% -------------------------------------------------------------------------------- generic-sort/key [97] 42.3% copying-mergesort [107] 57.7% [107] 1770(1.2%) 0(0.0%) copying-mergesort ...racket/private/sort.rkt:130:8 copying-mergesort [107] 57.7% loop [113] 27.2% jloop [114] 15.1% -------------------------------------------------------------------------------- for-loop [101] 100.0% [108] 998(0.7%) 998(0.7%) for-loop ...bie/develop/src/core/regimes.rkt:233:8 -------------------------------------------------------------------------------- for-loop [100] 100.0% [109] 662(0.4%) 662(0.4%) update-en-expr ...evelop/src/core/egraph.rkt:211:0 -------------------------------------------------------------------------------- matcher [110] 33.3% for-loop [103] 66.7% [110] 330(0.2%) 330(0.2%) matcher ...rbie/develop/src/core/matcher.rkt:163:2 matcher [110] 33.3% rewriter [92] 33.3% -------------------------------------------------------------------------------- binary-search-floats [105] 16.9% binary-search [104] 83.1% [111] 35134(23.7%) 0(0.0%) pred ...herbie/develop/src/core/regimes.rkt:121:17 loop [115] 82.5% errors [116] 17.5% -------------------------------------------------------------------------------- for-loop [99] 29.2% for-loop [98] 29.5% loop [106] 41.3% [112] 6810(4.6%) 0(0.0%) ??? ...s/herbie/develop/src/core/regimes.rkt:281:8 eval-prog [121] 94.7% ->flonum [176] 5.3% -------------------------------------------------------------------------------- generic-sort/key [97] 31.2% ??? [89] 34.2% copying-mergesort [107] 34.6% [113] 2036(1.4%) 0(0.0%) loop ...ket/collects/racket/private/sort.rkt:97:12 ??? [172] 85.2% ->flonum [176] 14.8% -------------------------------------------------------------------------------- copying-mergesort [107] 100.0% [114] 1066(0.7%) 0(0.0%) jloop ...t/collects/racket/private/sort.rkt:121:23 ->flonum [176] 66.2% ??? [172] 33.8% -------------------------------------------------------------------------------- run-improve50 [31] 0.6% ??? [24] 35.0% pred [111] 64.3% [115] 45038(30.4%) 0(0.0%) loop ...htlies/herbie/develop/src/points.rkt:193:2 loop [117] 72.2% make-exacts* [122] 14.6% loop [123] 10.2% for-loop [119] 1.5% filter-exacts [120] 1.5% -------------------------------------------------------------------------------- override-at-pnts [102] 3.9% option-on-expr [61] 5.5% pred [111] 33.3% best-and-tied-at-points [95] 57.2% [116] 18466(12.5%) 0(0.0%) errors ...lies/herbie/develop/src/points.rkt:218:0 for-loop [118] 75.7% eval-prog [121] 24.3% -------------------------------------------------------------------------------- loop [115] 100.0% [117] 32530(22.0%) 0(0.0%) loop ...htlies/herbie/develop/src/points.rkt:151:2 eval-prog [121] 74.9% make-exacts* [122] 14.6% loop [123] 10.5% -------------------------------------------------------------------------------- errors [116] 100.0% [118] 13978(9.4%) 1714(1.2%) for-loop ...es/herbie/develop/src/points.rkt:221:4 ??? [172] 82.5% ulp-difference [125] 2.6% ->flonum [176] 2.6% -------------------------------------------------------------------------------- loop [115] 100.0% [119] 668(0.5%) 312(0.2%) for-loop ...s/herbie/develop/src/points.rkt:200:24 for-loop [126] 53.3% -------------------------------------------------------------------------------- loop [115] 100.0% [120] 656(0.4%) 0(0.0%) filter-exacts ...rbie/develop/src/points.rkt:166:0 for-loop [124] 100.0% -------------------------------------------------------------------------------- sindices->spoints [72] 0.8% errors [116] 9.5% ??? [112] 13.7% for-loop [86] 24.3% loop [117] 51.7% [121] 47088(31.8%) 8618(5.8%) eval-prog ...herbie/develop/src/programs.rkt:149:0 hash-ref! [148] 50.3% f37 [49] 23.2% ??? [129] 2.3% go [130] 2.2% parse-app [181] 1.5% ??? [127] 1.4% ??? [131] 0.8% -------------------------------------------------------------------------------- loop [117] 41.8% loop [115] 58.2% [122] 11346(7.7%) 0(0.0%) make-exacts* ...erbie/develop/src/points.rkt:138:0 map [128] 52.9% loop [164] 47.1% -------------------------------------------------------------------------------- loop [117] 42.8% loop [115] 57.2% [123] 8016(5.4%) 0(0.0%) loop ...htlies/herbie/develop/src/points.rkt:141:4 map [128] 100.0% -------------------------------------------------------------------------------- filter-exacts [120] 100.0% [124] 656(0.4%) 656(0.4%) for-loop ...es/herbie/develop/src/points.rkt:169:4 -------------------------------------------------------------------------------- for-loop [118] 100.0% [125] 368(0.2%) 368(0.2%) ulp-difference ...erbie/develop/src/float.rkt:19:0 -------------------------------------------------------------------------------- for-loop [119] 100.0% [126] 356(0.2%) 0(0.0%) for-loop ...s/herbie/develop/src/points.rkt:201:26 ??? [127] 100.0% -------------------------------------------------------------------------------- for-loop [126] 1.4% eval-prog [121] 2.6% loop [15] 17.9% location-do [132] 17.9% for-loop [85] 17.9% f37 [49] 42.2% [127] 25864(17.5%) 0(0.0%) ??? ...tract/private/arrow-higher-order.rkt:342:33 location-do [132] 30.3% ??? [191] 20.6% approximate9 [3] 17.9% hash-ref! [148] 17.9% ...velop/src/common.rkt:47:2 [134] 5.3% ??? [136] 4.1% ->flonum [176] 2.7% -------------------------------------------------------------------------------- ??? [10] 4.6% parse-loop12 [133] 11.6% make-exacts* [122] 24.7% f37 [49] 26.1% loop [123] 33.0% [128] 24290(16.4%) 0(0.0%) map ...acket/collects/racket/private/map.rkt:20:13 loop [164] 62.4% parse-loop12 [133] 27.4% ->flonum [176] 4.6% ??? [172] 4.0% f37 [49] 0.9% ??? [10] 0.7% -------------------------------------------------------------------------------- eval-prog [121] 100.0% [129] 1060(0.7%) 0(0.0%) ??? ...collects/racket/private/qq-and-or.rkt:155:9 ??? [135] 100.0% -------------------------------------------------------------------------------- eval-prog [121] 100.0% [130] 1032(0.7%) 358(0.2%) go .../collects/racket/private/qq-and-or.rkt:50:20 loop [137] 65.3% -------------------------------------------------------------------------------- eval-prog [121] 100.0% [131] 360(0.2%) 0(0.0%) ??? ...cket/collects/racket/private/kw.rkt:1633:36 unpack242 [138] 100.0% -------------------------------------------------------------------------------- for-loop [38] 2.1% location-do [132] 17.7% for-loop [139] 21.5% ??? [127] 24.4% ??? [24] 34.0% [132] 57162(38.6%) 1384(0.9%) location-do ...acket/private/norm-define.rkt:53:83 iterate-egraph!13 [2] 30.2% for-loop [139] 21.5% ??? [127] 18.8% location-do [132] 17.7% ??? [140] 5.9% loop [7] 3.2% *simplify-rules* [145] 0.6% mk-egraph [147] 0.3% return/no-unsupplied [187] 0.2% -------------------------------------------------------------------------------- for-loop [20] 7.6% hash-ref! [148] 11.4% loop [164] 14.5% simplify [26] 19.8% map [128] 21.0% parse-loop12 [133] 25.7% [133] 15694(10.6%) 9182(6.2%) parse-loop12 ...s/racket/match/compiler.rkt:418:15 loop [164] 28.0% parse-loop12 [133] 25.7% for-loop [141] 7.6% map [128] 5.5% parse-app [181] 4.2% simplify* [142] 2.2% f37 [49] 1.6% loop [84] 0.7% -------------------------------------------------------------------------------- ??? [127] 100.0% [134] 1368(0.9%) 0(0.0%) ...velop/src/common.rkt:47:2 ...e/arr-i.rkt:906:19 ??? [143] 76.2% ??? [146] 23.8% -------------------------------------------------------------------------------- ??? [129] 100.0% [135] 1060(0.7%) 1060(0.7%) ??? ...ollects/racket/private/qq-and-or.rkt:164:21 -------------------------------------------------------------------------------- ??? [127] 100.0% [136] 1048(0.7%) 338(0.2%) ??? ...ts/racket/contract/private/arr-i.rkt:804:10 get/build-late-neg-projection [144] 67.7% -------------------------------------------------------------------------------- go [130] 41.3% loop [137] 58.7% [137] 674(0.5%) 674(0.5%) loop ...llects/racket/private/qq-and-or.rkt:101:61 loop [137] 58.7% -------------------------------------------------------------------------------- ??? [131] 100.0% [138] 360(0.2%) 360(0.2%) unpack242 ...private/arrow-higher-order.rkt:354:44 -------------------------------------------------------------------------------- location-do [132] 100.0% [139] 25430(17.2%) 0(0.0%) for-loop ...ie/develop/src/core/simplify.rkt:63:12 location-do [132] 100.0% -------------------------------------------------------------------------------- hash-has-key? [77] 46.0% location-do [132] 54.0% [140] 9366(6.3%) 3424(2.3%) ??? ...ects/racket/contract/private/list.rkt:737:4 for-loop [149] 49.2% ??? [158] 14.2% -------------------------------------------------------------------------------- parse-loop12 [133] 100.0% [141] 2794(1.9%) 0(0.0%) for-loop ...bie/develop/src/core/taylor.rkt:490:59 hash-ref! [148] 100.0% -------------------------------------------------------------------------------- simplify [26] 21.8% parse-loop12 [133] 78.2% [142] 1688(1.1%) 322(0.2%) simplify* ...rbie/develop/src/core/reduce.rkt:20:0 return/no-unsupplied [187] 37.8% hash-ref! [148] 21.8% ??? [152] 21.3% -------------------------------------------------------------------------------- ...velop/src/common.rkt:47:2 [134] 100.0% [143] 1042(0.7%) 360(0.2%) ??? ...s/racket/contract/private/arr-i.rkt:1268:39 return/no-unsupplied [187] 33.6% ??? [188] 31.9% -------------------------------------------------------------------------------- unconstrained-domain->-projection [151] 50.0% ??? [136] 50.0% [144] 710(0.5%) 0(0.0%) get/build-late-neg-projection ...te/guts.rkt:691:0 unconstrained-domain->-projection [151] 50.0% ??? [150] 50.0% -------------------------------------------------------------------------------- location-do [132] 100.0% [145] 326(0.2%) 0(0.0%) *simplify-rules* ...lop/src/syntax/rules.rkt:459:0 for-loop [153] 100.0% -------------------------------------------------------------------------------- ...velop/src/common.rkt:47:2 [134] 100.0% [146] 326(0.2%) 0(0.0%) ??? ...ects/racket/contract/private/list.rkt:342:4 ??? [189] 100.0% -------------------------------------------------------------------------------- location-do [132] 100.0% [147] 292(0.2%) 0(0.0%) mk-egraph ...bie/develop/src/core/egraph.rkt:123:0 expr->enode [154] 100.0% -------------------------------------------------------------------------------- simplify* [142] 0.1% ??? [156] 0.4% for-loop [141] 0.7% ??? [30] 0.9% for-loop [21] 1.5% localize-error [55] 1.9% compile [48] 2.0% ??? [10] 2.6% for-loop [27] 4.1% for-loop [17] 4.5% ??? [157] 7.2% ??? [127] 7.2% for-loop [16] 8.4% eval-prog [121] 25.3% loop [164] 33.4% [148] 40370(27.3%) 2060(1.4%) hash-ref! ...racket/private/more-scheme.rkt:373:13 ??? [156] 33.8% bigfloat-hash [155] 24.7% ??? [4] 8.4% ??? [157] 7.2% simplify [26] 7.1% ??? [5] 5.4% ??? [6] 4.1% parse-loop12 [133] 4.0% ??? [9] 1.5% ??? [8] 0.7% f37 [49] 0.4% ??? [12] 0.1% -------------------------------------------------------------------------------- ??? [140] 100.0% [149] 4610(3.1%) 2360(1.6%) for-loop ...acket/contract/private/list.rkt:743:12 ??? [158] 27.9% for-loop [161] 7.2% ??? [162] 7.1% arrow-higher-order:lnp [163] 6.6% -------------------------------------------------------------------------------- get/build-late-neg-projection [144] 100.0% [150] 710(0.5%) 356(0.2%) ??? ...cts/racket/contract/private/prop.rkt:314:12 build-compound-type-name [160] 49.9% -------------------------------------------------------------------------------- get/build-late-neg-projection [144] 100.0% [151] 710(0.5%) 0(0.0%) unconstrained-domain->-projection ...rrow.rkt:60:0 get/build-late-neg-projection [144] 100.0% -------------------------------------------------------------------------------- simplify* [142] 100.0% [152] 360(0.2%) 360(0.2%) ??? ...racket/collects/racket/private/kw.rkt:762:9 -------------------------------------------------------------------------------- *simplify-rules* [145] 100.0% [153] 326(0.2%) 326(0.2%) for-loop ...ies/herbie/develop/src/common.rkt:94:9 -------------------------------------------------------------------------------- mk-egraph [147] 25.0% expr->enode [154] 75.0% [154] 292(0.2%) 0(0.0%) expr->enode ...e/develop/src/core/egraph.rkt:124:2 expr->enode [154] 75.0% mk-enode! [159] 25.0% -------------------------------------------------------------------------------- hash-ref! [148] 100.0% [155] 22984(15.5%) 0(0.0%) bigfloat-hash ...h/private/bigfloat/mpfr.rkt:165:0 bfcanonicalize [165] 100.0% -------------------------------------------------------------------------------- hash-ref! [148] 100.0% [156] 19954(13.5%) 0(0.0%) ??? ...tlies/herbie/develop/src/programs.rkt:184:5 loop [164] 98.4% hash-ref! [148] 1.6% -------------------------------------------------------------------------------- hash-ref! [148] 100.0% [157] 13910(9.4%) 0(0.0%) ??? ...es/herbie/develop/src/core/taylor.rkt:44:15 hash-ref! [148] 100.0% -------------------------------------------------------------------------------- for-loop [149] 49.2% ??? [140] 50.8% [158] 2620(1.8%) 1324(0.9%) ??? ...private/unconstrained-domain-arrow.rkt:74:4 make-keyword-procedure [166] 49.5% -------------------------------------------------------------------------------- expr->enode [154] 14.0% substitute-e [42] 17.2% apply-match [32] 68.8% [159] 2090(1.4%) 1798(1.2%) mk-enode! ...bie/develop/src/core/egraph.rkt:101:0 new-enode [171] 14.0% -------------------------------------------------------------------------------- ??? [150] 100.0% [160] 354(0.2%) 0(0.0%) build-compound-type-name ...private/guts.rkt:448:0 contract-struct-name [167] 100.0% -------------------------------------------------------------------------------- for-loop [149] 100.0% [161] 334(0.2%) 0(0.0%) for-loop ...racket/contract/private/hash.rkt:239:6 ??? [168] 100.0% -------------------------------------------------------------------------------- for-loop [149] 100.0% [162] 326(0.2%) 0(0.0%) ??? ...ects/racket/contract/private/hash.rkt:222:6 check-hash/c [169] 100.0% -------------------------------------------------------------------------------- for-loop [149] 100.0% [163] 302(0.2%) 0(0.0%) arrow-higher-order:lnp ...w-higher-order.rkt:597:7 ??? [170] 100.0% -------------------------------------------------------------------------------- make-exacts* [122] 0.6% map-enodes [22] 1.1% loop! [46] 1.3% map [128] 3.9% parse-loop12 [133] 6.0% ??? [156] 17.2% loop [164] 28.9% f37 [49] 41.0% [164] 77660(52.4%) 770(0.5%) loop ...cket/collects/racket/private/map.rkt:25:19 option-on-expr [61] 41.0% loop [164] 28.9% hash-ref! [148] 17.2% parse-loop12 [133] 5.9% ??? [172] 2.0% f37 [49] 1.5% for-loop [173] 1.1% loop! [46] 0.8% ??? [10] 0.6% ->flonum [176] 0.0% -------------------------------------------------------------------------------- bigfloat-hash [155] 100.0% [165] 22984(15.5%) 22984(15.5%) bfcanonicalize .../private/bigfloat/mpfr.rkt:155:0 -------------------------------------------------------------------------------- ??? [158] 100.0% [166] 1296(0.9%) 1296(0.9%) make-keyword-procedure ...ket/private/kw.rkt:260:4 -------------------------------------------------------------------------------- build-compound-type-name [160] 100.0% [167] 354(0.2%) 354(0.2%) contract-struct-name ...ract/private/prop.rkt:89:0 -------------------------------------------------------------------------------- for-loop [161] 100.0% [168] 334(0.2%) 334(0.2%) ??? ...ects/racket/contract/private/list.rkt:686:7 -------------------------------------------------------------------------------- ??? [162] 100.0% [169] 326(0.2%) 326(0.2%) check-hash/c ...ket/contract/private/hash.rkt:83:0 -------------------------------------------------------------------------------- arrow-higher-order:lnp [163] 100.0% [170] 302(0.2%) 302(0.2%) ??? ...et/contract/private/arity-checking.rkt:19:2 -------------------------------------------------------------------------------- mk-enode! [159] 100.0% [171] 292(0.2%) 0(0.0%) new-enode ...erbie/develop/src/core/enode.rkt:68:0 mutable-set [174] 100.0% -------------------------------------------------------------------------------- jloop [114] 1.1% map [128] 2.9% for-loop [86] 4.1% loop [113] 5.3% for-loop [118] 35.1% loop [164] 51.5% [172] 32892(22.2%) 1664(1.1%) ??? ...tlies/herbie/develop/src/programs.rkt:155:4 ??? [175] 80.3% ??? [177] 7.3% ->flonum [176] 6.3% -------------------------------------------------------------------------------- map-enodes [22] 13.3% loop [164] 86.7% [173] 2684(1.8%) 1692(1.1%) for-loop ...ie/develop/src/core/simplify.rkt:168:2 eval-const-expr [178] 25.9% curry* [179] 11.1% -------------------------------------------------------------------------------- new-enode [171] 100.0% [174] 292(0.2%) 292(0.2%) mutable-set .../racket/private/set-types.rkt:999:0 -------------------------------------------------------------------------------- ??? [172] 100.0% [175] 26428(17.8%) 10654(7.2%) ??? ...acket/collects/racket/private/kw.rkt:444:14 ??? [186] 38.8% ??? [180] 10.7% ??? [183] 6.3% ...higher-order.rkt:346:33 [184] 1.4% bf* [185] 1.2% -------------------------------------------------------------------------------- loop [113] 4.3% loop [84] 4.8% ??? [112] 5.1% for-loop [118] 5.2% ??? [127] 9.9% jloop [114] 10.1% loop [164] 14.9% map [128] 15.9% ??? [172] 29.8% [176] 6996(4.7%) 2840(1.9%) ->flonum ...s/herbie/develop/src/programs.rkt:37:0 return/no-unsupplied [187] 35.4% ??? [188] 24.0% -------------------------------------------------------------------------------- ??? [172] 100.0% [177] 2414(1.6%) 364(0.2%) ??? ...contract/private/../../private/kw.rkt:761:9 real->bigfloat [182] 84.9% -------------------------------------------------------------------------------- for-loop [173] 100.0% [178] 694(0.5%) 336(0.2%) eval-const-expr .../develop/src/programs.rkt:167:0 parse-app [181] 51.6% -------------------------------------------------------------------------------- for-loop [173] 100.0% [179] 298(0.2%) 298(0.2%) curry* ...racket/collects/racket/function.rkt:44:2 -------------------------------------------------------------------------------- ??? [175] 100.0% [180] 2816(1.9%) 1416(1.0%) ??? ...herbie/develop/src/syntax/syntax.rkt:118:17 ??? [188] 36.9% return/no-unsupplied [187] 12.8% -------------------------------------------------------------------------------- eval-const-expr [178] 12.9% eval-prog [121] 25.8% parse-loop12 [133] 61.3% [181] 2782(1.9%) 2450(1.7%) parse-app .../collects/racket/private/kw.rkt:951:2 loop [190] 11.9% -------------------------------------------------------------------------------- ??? [177] 100.0% [182] 2050(1.4%) 732(0.5%) real->bigfloat .../private/bigfloat/mpfr.rkt:451:0 ??? [197] 64.3% -------------------------------------------------------------------------------- ??? [175] 100.0% [183] 1676(1.1%) 1676(1.1%) ??? ...rivate/unconstrained-domain-arrow.rkt:40:13 -------------------------------------------------------------------------------- ??? [175] 100.0% [184] 358(0.2%) 0(0.0%) ...higher-order.rkt:346:33 (unknown source) ??? [189] 100.0% -------------------------------------------------------------------------------- ??? [175] 100.0% [185] 320(0.2%) 0(0.0%) bf* ...ath/private/bigfloat/bigfloat-mpfr.rkt:95:0 ??? [186] 100.0% -------------------------------------------------------------------------------- bf* [185] 3.0% ??? [175] 97.0% [186] 10566(7.1%) 6738(4.5%) ??? ...-racket/utils/simple-result-arrow.rkt:39:12 bfadd [192] 26.1% bfexp [194] 10.1% -------------------------------------------------------------------------------- location-do [132] 7.7% ??? [143] 8.5% ??? [180] 8.7% simplify* [142] 15.4% ->flonum [176] 59.7% [187] 4142(2.8%) 3792(2.6%) return/no-unsupplied ...ct/private/arr-i.rkt:533:0 filter [195] 8.5% -------------------------------------------------------------------------------- ??? [143] 10.9% ??? [180] 34.1% ->flonum [176] 55.1% [188] 3054(2.1%) 1688(1.1%) ??? ...racket/collects/racket/private/kw.rkt:761:9 ??? [193] 44.7% -------------------------------------------------------------------------------- ??? [146] 47.7% ...higher-order.rkt:346:33 [184] 52.3% [189] 684(0.5%) 0(0.0%) ??? ...cts/racket/contract/private/list.rkt:187:10 ??? [191] 52.3% for-loop [196] 47.7% -------------------------------------------------------------------------------- parse-app [181] 100.0% [190] 332(0.2%) 332(0.2%) loop .../collects/racket/private/stxcase.rkt:112:7 -------------------------------------------------------------------------------- ??? [189] 5.9% ??? [63] 6.1% ??? [127] 88.0% [191] 6048(4.1%) 724(0.5%) ??? ...ects/racket/contract/private/guts.rkt:644:8 ??? [63] 88.0% -------------------------------------------------------------------------------- ??? [186] 100.0% [192] 2762(1.9%) 2076(1.4%) bfadd ...-lib/math/private/bigfloat/mpfr.rkt:819:4 ??? [197] 24.8% -------------------------------------------------------------------------------- ??? [188] 100.0% [193] 1366(0.9%) 660(0.4%) ??? ...s/racket/contract/private/arr-i.rkt:1233:27 ??? [198] 51.7% -------------------------------------------------------------------------------- ??? [186] 100.0% [194] 1066(0.7%) 0(0.0%) bfexp ...-lib/math/private/bigfloat/mpfr.rkt:616:4 ??? [197] 100.0% -------------------------------------------------------------------------------- return/no-unsupplied [187] 100.0% [195] 350(0.2%) 350(0.2%) filter ...t/collects/racket/private/list.rkt:256:2 -------------------------------------------------------------------------------- ??? [189] 100.0% [196] 326(0.2%) 326(0.2%) for-loop ...acket/contract/private/list.rkt:190:15 -------------------------------------------------------------------------------- bfadd [192] 22.3% bfexp [194] 34.7% real->bigfloat [182] 42.9% [197] 3070(2.1%) 3070(2.1%) ??? .../share/racket/collects/ffi/unsafe.rkt:861:4 -------------------------------------------------------------------------------- ??? [193] 100.0% [198] 706(0.5%) 706(0.5%) ??? ...ects/racket/contract/private/prop.rkt:256:4 --------------------------------------------------------------------------------