Profiling results ----------------- Total cpu time observed: 117970ms (out of 118800ms) Number of samples taken: 339 (once every 348ms) (Hiding functions with self<1.0% and local<2.0%: 5 of 199 hidden) ======================================================================================== Caller Idx Total Self Name+src Local% ms(pct) ms(pct) Callee ======================================================================================== ??? [52] 100.0% [1] 98258(83.3%) 0(0.0%) profile-thunk16 ...t/pkgs/profile-lib/main.rkt:9:0 run [13] 100.0% ---------------------------------------------------------------------------------------- ??? [52] 100.0% [2] 84962(72.0%) 0(0.0%) run-improve50 ...ie/develop/src/mainloop.rkt:234:0 for-loop [14] 94.3% get-final-combination [17] 4.4% setup-prog [22] 0.4% setup-alt-simplified [23] 0.4% loop [65] 0.4% ---------------------------------------------------------------------------------------- table-ref [155] 100.0% [3] 80516(68.3%) 0(0.0%) iterate-egraph!13 ...p/src/core/simplify.rkt:102:0 one-iter [15] 99.2% map-enodes [21] 0.8% ---------------------------------------------------------------------------------------- table-ref [155] 100.0% [4] 8976(7.6%) 0(0.0%) loop ...herbie/develop/src/core/simplify.rkt:215:2 pass [16] 100.0% ---------------------------------------------------------------------------------------- ??? [154] 100.0% [5] 2970(2.5%) 0(0.0%) approximate9 ...e/develop/src/core/taylor.rkt:12:0 loop [18] 88.1% for-loop [25] 11.9% ---------------------------------------------------------------------------------------- hash-ref! [156] 100.0% [6] 1626(1.4%) 0(0.0%) ??? ...s/herbie/develop/src/core/taylor.rkt:285:26 for-loop [19] 100.0% ---------------------------------------------------------------------------------------- hash-ref! [156] 100.0% [7] 1278(1.1%) 0(0.0%) ??? ...s/herbie/develop/src/core/taylor.rkt:295:23 for-loop [20] 100.0% ---------------------------------------------------------------------------------------- substitute-e [54] 34.0% match-e [46] 66.0% [8] 1054(0.9%) 0(0.0%) variable? ...e/develop/src/syntax/syntax.rkt:660:0 ??? [47] 100.0% ---------------------------------------------------------------------------------------- f137 [177] 100.0% [9] 668(0.6%) 0(0.0%) append-map ...acket/collects/racket/list.rkt:565:2 f137 [177] 91.7% parse-loop12 [165] 8.3% ---------------------------------------------------------------------------------------- copying-mergesort [149] 100.0% [10] 368(0.3%) 0(0.0%) jloop ...t/collects/racket/private/sort.rkt:121:23 ??? [101] 100.0% ---------------------------------------------------------------------------------------- hash-ref! [156] 100.0% [11] 356(0.3%) 0(0.0%) ??? ...s/herbie/develop/src/core/taylor.rkt:392:23 for-loop [24] 100.0% ---------------------------------------------------------------------------------------- hash-ref! [156] 100.0% [12] 302(0.3%) 0(0.0%) ??? ...s/herbie/develop/src/core/taylor.rkt:322:33 for-loop [26] 100.0% ---------------------------------------------------------------------------------------- profile-thunk16 [1] 100.0% [13] 98258(83.3%) 0(0.0%) run ...share/racket/pkgs/profile-lib/main.rkt:39:2 ??? [52] 100.0% ---------------------------------------------------------------------------------------- run-improve50 [2] 100.0% [14] 80078(67.9%) 0(0.0%) for-loop ...herbie/develop/src/mainloop.rkt:249:10 run-iter! [27] 100.0% ---------------------------------------------------------------------------------------- iterate-egraph!13 [3] 100.0% [15] 79900(67.7%) 1354(1.1%) one-iter ...ie/develop/src/core/simplify.rkt:113:0 loop [28] 65.6% for-loop [29] 25.7% apply-match [35] 7.0% ---------------------------------------------------------------------------------------- loop [4] 100.0% [16] 8976(7.6%) 0(0.0%) pass ...herbie/develop/src/core/simplify.rkt:205:2 for-loop [30] 100.0% ---------------------------------------------------------------------------------------- run-improve50 [2] 100.0% [17] 3770(3.2%) 0(0.0%) get-final-combination ...op/src/mainloop.rkt:264:0 split-table [31] 100.0% ---------------------------------------------------------------------------------------- approximate9 [5] 100.0% [18] 2616(2.2%) 0(0.0%) loop ...es/herbie/develop/src/core/taylor.rkt:86:4 hash-ref! [156] 100.0% ---------------------------------------------------------------------------------------- ??? [6] 100.0% [19] 1626(1.4%) 0(0.0%) for-loop ...bie/develop/src/core/taylor.rkt:285:52 hash-ref! [156] 79.3% ??? [175] 20.7% ---------------------------------------------------------------------------------------- ??? [7] 100.0% [20] 1278(1.1%) 0(0.0%) for-loop ...bie/develop/src/core/taylor.rkt:298:27 hash-ref! [156] 100.0% ---------------------------------------------------------------------------------------- iterate-egraph!13 [3] 100.0% [21] 616(0.5%) 0(0.0%) map-enodes ...ie/develop/src/core/egraph.rkt:139:0 for-loop [109] 51.9% loop [95] 48.1% ---------------------------------------------------------------------------------------- run-improve50 [2] 100.0% [22] 382(0.3%) 0(0.0%) setup-prog ...ies/herbie/develop/src/glue.rkt:40:0 ??? [47] 100.0% ---------------------------------------------------------------------------------------- run-improve50 [2] 100.0% [23] 368(0.3%) 0(0.0%) setup-alt-simplified .../develop/src/glue.rkt:49:0 simplify-alt [32] 100.0% ---------------------------------------------------------------------------------------- ??? [11] 100.0% [24] 356(0.3%) 0(0.0%) for-loop ...bie/develop/src/core/taylor.rkt:396:33 for-loop [33] 100.0% ---------------------------------------------------------------------------------------- approximate9 [5] 100.0% [25] 354(0.3%) 0(0.0%) for-loop ...rbie/develop/src/core/taylor.rkt:29:18 f137 [177] 100.0% ---------------------------------------------------------------------------------------- ??? [12] 100.0% [26] 302(0.3%) 0(0.0%) for-loop ...bie/develop/src/core/taylor.rkt:324:46 simplify [162] 100.0% ---------------------------------------------------------------------------------------- for-loop [14] 100.0% [27] 80078(67.9%) 0(0.0%) run-iter! ...herbie/develop/src/mainloop.rkt:215:0 simplify! [34] 88.4% finalize-iter! [37] 6.6% gen-series! [38] 3.7% localize-error [41] 0.5% choose-best-alt! [42] 0.4% gen-rewrites! [43] 0.4% ---------------------------------------------------------------------------------------- one-iter [15] 100.0% [28] 52452(44.5%) 360(0.3%) loop ...cket/collects/racket/private/map.rkt:52:19 apply-match [35] 99.3% ---------------------------------------------------------------------------------------- for-loop [29] 49.2% one-iter [15] 50.8% [29] 20528(17.4%) 4432(3.8%) for-loop ...e/develop/src/core/simplify.rkt:123:12 for-loop [29] 49.2% match-e [46] 39.2% ---------------------------------------------------------------------------------------- pass [16] 100.0% [30] 8976(7.6%) 0(0.0%) for-loop ...e/develop/src/core/simplify.rkt:208:29 argmin [36] 61.5% loop [39] 26.8% for-loop [40] 11.7% ---------------------------------------------------------------------------------------- get-final-combination [17] 100.0% [31] 3770(3.2%) 0(0.0%) split-table ...s/herbie/develop/src/glue.rkt:162:0 f137 [177] 100.0% ---------------------------------------------------------------------------------------- setup-alt-simplified [23] 100.0% [32] 368(0.3%) 0(0.0%) simplify-alt ...s/herbie/develop/src/glue.rkt:76:0 table-ref [155] 100.0% ---------------------------------------------------------------------------------------- for-loop [24] 100.0% [33] 356(0.3%) 0(0.0%) for-loop ...bie/develop/src/core/taylor.rkt:398:39 hash-ref! [156] 100.0% ---------------------------------------------------------------------------------------- run-iter! [27] 100.0% [34] 70792(60.0%) 0(0.0%) simplify! ...herbie/develop/src/mainloop.rkt:155:0 for-loop [44] 100.0% ---------------------------------------------------------------------------------------- one-iter [15] 9.7% loop [28] 90.3% [35] 57658(48.9%) 0(0.0%) apply-match ...develop/src/core/simplify.rkt:130:2 for-loop [45] 94.5% match-e [46] 5.5% ---------------------------------------------------------------------------------------- for-loop [30] 100.0% [36] 5518(4.7%) 0(0.0%) argmin ...re/racket/collects/racket/list.rkt:743:0 for-loop [48] 87.5% expression-cost [50] 12.5% ---------------------------------------------------------------------------------------- run-iter! [27] 100.0% [37] 5260(4.5%) 0(0.0%) finalize-iter! ...e/develop/src/mainloop.rkt:169:0 ??? [47] 100.0% ---------------------------------------------------------------------------------------- run-iter! [27] 100.0% [38] 2970(2.5%) 0(0.0%) gen-series! ...rbie/develop/src/mainloop.rkt:129:0 for-loop [49] 100.0% ---------------------------------------------------------------------------------------- for-loop [30] 100.0% [39] 2404(2.0%) 0(0.0%) loop ...hare/racket/collects/racket/list.rkt:729:4 for-loop [48] 84.9% expression-cost [50] 15.1% ---------------------------------------------------------------------------------------- for-loop [30] 100.0% [40] 1054(0.9%) 1054(0.9%) for-loop ...e/develop/src/core/simplify.rkt:195:13 ---------------------------------------------------------------------------------------- run-iter! [27] 100.0% [41] 362(0.3%) 0(0.0%) localize-error ...velop/src/core/localize.rkt:47:0 hash-ref! [156] 100.0% ---------------------------------------------------------------------------------------- run-iter! [27] 100.0% [42] 360(0.3%) 0(0.0%) choose-best-alt! ...develop/src/mainloop.rkt:115:0 ??? [47] 100.0% ---------------------------------------------------------------------------------------- run-iter! [27] 100.0% [43] 334(0.3%) 0(0.0%) gen-rewrites! ...ie/develop/src/mainloop.rkt:142:0 for-loop [51] 100.0% ---------------------------------------------------------------------------------------- simplify! [34] 100.0% [44] 70792(60.0%) 0(0.0%) for-loop .../herbie/develop/src/mainloop.rkt:159:6 ??? [52] 100.0% ---------------------------------------------------------------------------------------- apply-match [35] 100.0% [45] 54512(46.2%) 684(0.6%) for-loop ...e/develop/src/core/simplify.rkt:145:10 merge-egraph-nodes! [53] 33.3% mk-enode! [64] 32.8% substitute-e [54] 17.7% loop! [102] 14.3% list-member? [61] 0.7% ---------------------------------------------------------------------------------------- apply-match [35] 10.7% for-loop [67] 17.6% for-loop [29] 71.7% [46] 19242(16.3%) 7450(6.3%) match-e ...herbie/develop/src/core/ematch.rkt:46:0 for-loop [55] 39.6% for-loop [67] 11.2% loop [95] 7.3% ??? [47] 4.6% list-cartesian-product [70] 2.7% variable? [8] 1.5% ---------------------------------------------------------------------------------------- debug7 [174] 3.0% choose-best-alt! [42] 3.1% for-loop [91] 3.1% setup-prog [22] 3.3% substitute-e [54] 6.2% variable? [8] 9.0% match-e [46] 12.2% get-sigs [96] 15.0% finalize-iter! [37] 45.1% [47] 11674(9.9%) 2490(2.1%) ??? ...contract/private/arrow-val-first.rkt:357:18 for-loop [56] 45.1% hash-has-key? [58] 24.2% make-alt-table [60] 3.3% ??? [62] 3.1% ??? [184] 3.0% ---------------------------------------------------------------------------------------- loop [39] 29.7% argmin [36] 70.3% [48] 6870(5.8%) 332(0.3%) for-loop .../herbie/develop/src/programs.rkt:199:2 table-ref [155] 76.1% ...velop/src/common.rkt:47:2 [105] 14.4% ??? [104] 4.7% ---------------------------------------------------------------------------------------- gen-series! [38] 100.0% [49] 2970(2.5%) 0(0.0%) for-loop .../herbie/develop/src/mainloop.rkt:135:7 taylor-alt [57] 100.0% ---------------------------------------------------------------------------------------- loop [39] 34.6% argmin [36] 65.4% [50] 1052(0.9%) 0(0.0%) expression-cost .../develop/src/programs.rkt:198:0 compile [59] 100.0% ---------------------------------------------------------------------------------------- gen-rewrites! [43] 100.0% [51] 334(0.3%) 0(0.0%) for-loop ...herbie/develop/src/mainloop.rkt:147:11 ??? [63] 100.0% ---------------------------------------------------------------------------------------- for-loop [44] 20.3% run [13] 32.2% [52] 116018(98.3%) 0(0.0%) ??? ...lects/racket/private/more-scheme.rkt:261:28 table-ref [155] 35.4% profile-thunk16 [1] 32.2% run-improve50 [2] 26.6% loop [65] 5.9% ---------------------------------------------------------------------------------------- merge-egraph-nodes! [53] 1.9% for-loop [71] 4.1% for-loop [45] 94.0% [53] 18136(15.4%) 328(0.3%) merge-egraph-nodes! ...p/src/core/egraph.rkt:152:0 update-leader! [66] 66.5% for-loop [72] 9.3% loop! [102] 9.0% for-loop [71] 5.9% enode-merge! [73] 5.6% merge-egraph-nodes! [53] 1.9% ---------------------------------------------------------------------------------------- substitute-e [54] 6.8% for-loop [45] 93.2% [54] 9666(8.2%) 0(0.0%) substitute-e ...e/develop/src/core/ematch.rkt:71:0 mk-enode! [64] 88.8% substitute-e [54] 6.8% ??? [47] 2.5% variable? [8] 1.9% ---------------------------------------------------------------------------------------- match-e [46] 100.0% [55] 9302(7.9%) 4094(3.5%) for-loop ...rbie/develop/src/core/ematch.rkt:59:11 for-loop [67] 42.7% list-cartesian-product [70] 13.4% loop [95] 3.5% ---------------------------------------------------------------------------------------- ??? [47] 100.0% [56] 5260(4.5%) 0(0.0%) for-loop ...ie/develop/src/core/alt-table.rkt:51:2 atab-add-altn [68] 100.0% ---------------------------------------------------------------------------------------- for-loop [49] 100.0% [57] 2970(2.5%) 0(0.0%) taylor-alt ...es/herbie/develop/src/glue.rkt:134:0 for-loop [69] 100.0% ---------------------------------------------------------------------------------------- ??? [47] 100.0% [58] 2828(2.4%) 722(0.6%) hash-has-key? ...et/private/more-scheme.rkt:368:13 ??? [159] 74.5% ---------------------------------------------------------------------------------------- expression-cost [50] 100.0% [59] 1052(0.9%) 0(0.0%) compile ...s/herbie/develop/src/programs.rkt:175:0 hash-ref! [156] 100.0% ---------------------------------------------------------------------------------------- ??? [47] 100.0% [60] 382(0.3%) 0(0.0%) make-alt-table ...elop/src/core/alt-table.rkt:32:0 errors [88] 100.0% ---------------------------------------------------------------------------------------- for-loop [45] 100.0% [61] 360(0.3%) 0(0.0%) list-member? ...llects/racket/private/set.rkt:24:0 member [74] 100.0% ---------------------------------------------------------------------------------------- ??? [47] 100.0% [62] 360(0.3%) 0(0.0%) ??? .../herbie/develop/src/core/alt-table.rkt:54:0 ??? [154] 100.0% ---------------------------------------------------------------------------------------- for-loop [51] 100.0% [63] 334(0.3%) 0(0.0%) ??? ...ies/herbie/develop/src/alternative.rkt:88:0 rewriter [75] 100.0% ---------------------------------------------------------------------------------------- expr->enode [173] 1.3% substitute-e [54] 32.0% for-loop [45] 66.7% [64] 26832(22.7%) 2648(2.2%) mk-enode! ...bie/develop/src/core/egraph.rkt:101:0 new-enode [76] 90.1% ---------------------------------------------------------------------------------------- run-improve50 [2] 2.6% ??? [52] 97.4% [65] 13984(11.9%) 0(0.0%) loop ...htlies/herbie/develop/src/points.rkt:205:2 loop [78] 42.6% make-exacts* [89] 26.4% loop [90] 25.9% for-loop [81] 5.2% ---------------------------------------------------------------------------------------- merge-egraph-nodes! [53] 100.0% [66] 12422(10.5%) 1680(1.4%) update-leader! ...evelop/src/core/egraph.rkt:217:0 for-loop [77] 83.8% update-en-expr [130] 2.7% ---------------------------------------------------------------------------------------- match-e [46] 39.1% for-loop [55] 60.9% [67] 7594(6.4%) 690(0.6%) for-loop ...rbie/develop/src/core/ematch.rkt:65:37 match-e [46] 83.8% ??? [80] 7.1% ---------------------------------------------------------------------------------------- for-loop [56] 100.0% [68] 5260(4.5%) 0(0.0%) atab-add-altn ...elop/src/core/alt-table.rkt:208:0 best-and-tied-at-points [79] 100.0% ---------------------------------------------------------------------------------------- taylor-alt [57] 100.0% [69] 2970(2.5%) 0(0.0%) for-loop ...lies/herbie/develop/src/glue.rkt:139:6 ??? [154] 100.0% ---------------------------------------------------------------------------------------- match-e [46] 24.5% list-cartesian-product [70] 25.7% for-loop [55] 49.9% [70] 2106(1.8%) 2106(1.8%) list-cartesian-product ...src/core/ematch.rkt:20:0 list-cartesian-product [70] 25.7% ---------------------------------------------------------------------------------------- merge-egraph-nodes! [53] 100.0% [71] 1724(1.5%) 0(0.0%) for-loop ...bie/develop/src/core/egraph.rkt:200:10 merge-egraph-nodes! [53] 80.7% loop! [102] 19.3% ---------------------------------------------------------------------------------------- merge-egraph-nodes! [53] 100.0% [72] 1686(1.4%) 1686(1.4%) for-loop ...rbie/develop/src/core/egraph.rkt:232:6 ---------------------------------------------------------------------------------------- merge-egraph-nodes! [53] 100.0% [73] 1010(0.9%) 332(0.3%) enode-merge! ...e/develop/src/core/enode.rkt:129:0 adopt-enode! [82] 34.1% custom-set-intersect! [83] 33.1% ---------------------------------------------------------------------------------------- list-member? [61] 100.0% [74] 360(0.3%) 360(0.3%) member (unknown source) ---------------------------------------------------------------------------------------- matcher [94] 50.0% ??? [63] 50.0% [75] 334(0.3%) 0(0.0%) rewriter ...bie/develop/src/core/matcher.rkt:131:2 for-loop [85] 50.0% *rules* [84] 50.0% ---------------------------------------------------------------------------------------- mk-enode! [64] 100.0% [76] 24184(20.5%) 0(0.0%) new-enode ...erbie/develop/src/core/enode.rkt:97:0 type-of-enode-expr [86] 95.5% set [118] 4.5% ---------------------------------------------------------------------------------------- update-leader! [66] 100.0% [77] 10410(8.8%) 0(0.0%) for-loop ...rbie/develop/src/core/egraph.rkt:222:6 for-loop [87] 100.0% ---------------------------------------------------------------------------------------- loop [65] 100.0% [78] 5956(5.0%) 0(0.0%) loop ...htlies/herbie/develop/src/points.rkt:158:2 make-exacts* [89] 59.6% loop [90] 40.4% ---------------------------------------------------------------------------------------- atab-add-altn [68] 100.0% [79] 5260(4.5%) 0(0.0%) best-and-tied-at-points ...ore/alt-table.rkt:122:0 errors [88] 100.0% ---------------------------------------------------------------------------------------- for-loop [67] 100.0% [80] 724(0.6%) 0(0.0%) ??? ...ies/herbie/develop/src/core/ematch.rkt:50:5 for-loop [91] 100.0% ---------------------------------------------------------------------------------------- loop [65] 100.0% [81] 722(0.6%) 0(0.0%) for-loop ...s/herbie/develop/src/points.rkt:222:26 for-loop [92] 100.0% ---------------------------------------------------------------------------------------- enode-merge! [73] 100.0% [82] 344(0.3%) 0(0.0%) adopt-enode! ...e/develop/src/core/enode.rkt:105:0 custom-set-union [115] 100.0% ---------------------------------------------------------------------------------------- enode-merge! [73] 100.0% [83] 334(0.3%) 334(0.3%) custom-set-intersect! ...ivate/set-types.rkt:269:0 ---------------------------------------------------------------------------------------- rewriter [75] 100.0% [84] 334(0.3%) 0(0.0%) *rules* ...rbie/develop/src/syntax/rules.rkt:514:0 for-loop [93] 100.0% ---------------------------------------------------------------------------------------- rewriter [75] 100.0% [85] 334(0.3%) 0(0.0%) for-loop ...ie/develop/src/core/matcher.rkt:134:10 matcher [94] 100.0% ---------------------------------------------------------------------------------------- new-enode [76] 100.0% [86] 23096(19.6%) 332(0.3%) type-of-enode-expr ...elop/src/core/enode.rkt:68:0 get-sigs [96] 98.6% ---------------------------------------------------------------------------------------- for-loop [77] 100.0% [87] 10410(8.8%) 0(0.0%) for-loop ...rbie/develop/src/core/egraph.rkt:223:8 hash-update! [97] 100.0% ---------------------------------------------------------------------------------------- composed [185] 4.9% make-alt-table [60] 5.2% option-on-expr [106] 18.5% best-and-tied-at-points [79] 71.4% [88] 7364(6.2%) 0(0.0%) errors ...lies/herbie/develop/src/points.rkt:241:0 for-loop [98] 75.3% eval-prog [99] 24.7% ---------------------------------------------------------------------------------------- loop [78] 49.0% loop [65] 51.0% [89] 7238(6.1%) 0(0.0%) make-exacts* ...erbie/develop/src/points.rkt:138:0 loop [95] 100.0% ---------------------------------------------------------------------------------------- loop [78] 40.0% loop [65] 60.0% [90] 6024(5.1%) 332(0.3%) loop ...htlies/herbie/develop/src/points.rkt:141:4 loop [95] 94.5% ---------------------------------------------------------------------------------------- ??? [80] 100.0% [91] 724(0.6%) 360(0.3%) for-loop ...erbie/develop/src/core/ematch.rkt:51:7 ??? [47] 50.3% ---------------------------------------------------------------------------------------- for-loop [81] 100.0% [92] 722(0.6%) 0(0.0%) for-loop ...s/herbie/develop/src/points.rkt:223:28 ??? [154] 100.0% ---------------------------------------------------------------------------------------- *rules* [84] 100.0% [93] 334(0.3%) 0(0.0%) for-loop ...ies/herbie/develop/src/common.rkt:99:9 ormap [100] 100.0% ---------------------------------------------------------------------------------------- matcher [94] 50.0% for-loop [85] 50.0% [94] 334(0.3%) 0(0.0%) matcher ...rbie/develop/src/core/matcher.rkt:167:2 matcher [94] 50.0% rewriter [75] 50.0% ---------------------------------------------------------------------------------------- parse-loop12 [165] 0.0% loop [90] 0.1% map-enodes [21] 1.2% for-loop [55] 1.3% ??? [101] 1.5% make-exacts* [89] 1.7% match-e [46] 5.7% loop! [102] 7.4% f137 [177] 11.2% loop [95] 69.9% [95] 24430(20.7%) 1430(1.2%) loop ...cket/collects/racket/private/map.rkt:25:19 loop [95] 69.9% option-on-expr [106] 11.2% loop! [102] 6.3% foldl [107] 5.7% ??? [101] 1.7% ??? [154] 1.5% curried [180] 1.3% for-loop [109] 1.2% ??? [111] 0.0% ??? [110] 0.0% ??? [117] 0.0% ---------------------------------------------------------------------------------------- type-of-enode-expr [86] 100.0% [96] 22764(19.3%) 1354(1.1%) get-sigs .../herbie/develop/src/type-check.rkt:5:0 ??? [104] 39.1% table-ref [155] 35.1% ...velop/src/common.rkt:47:2 [105] 12.2% ??? [47] 7.7% ---------------------------------------------------------------------------------------- for-loop [87] 100.0% [97] 10410(8.8%) 0(0.0%) hash-update! ...ket/private/more-scheme.rkt:362:13 ??? [103] 100.0% ---------------------------------------------------------------------------------------- errors [88] 100.0% [98] 5546(4.7%) 1048(0.9%) for-loop ...es/herbie/develop/src/points.rkt:244:4 ??? [101] 68.6% ulp-difference [108] 12.5% ---------------------------------------------------------------------------------------- errors [88] 100.0% [99] 1818(1.5%) 718(0.6%) eval-prog ...herbie/develop/src/programs.rkt:148:0 f137 [177] 60.5% ---------------------------------------------------------------------------------------- for-loop [93] 100.0% [100] 334(0.3%) 0(0.0%) ormap ...et/collects/racket/private/map.rkt:105:13 flag-set? [112] 100.0% ---------------------------------------------------------------------------------------- loop [151] 2.1% ??? [146] 2.1% jloop [10] 2.4% for-loop [98] 24.5% loop [95] 69.0% [101] 15546(13.2%) 1330(1.1%) ??? ...tlies/herbie/develop/src/programs.rkt:154:4 ??? [114] 47.9% ??? [117] 25.4% ??? [154] 10.8% loop [95] 7.4% ---------------------------------------------------------------------------------------- for-loop [71] 1.6% merge-egraph-nodes! [53] 14.8% loop [95] 25.7% for-loop [45] 57.9% [102] 10470(8.9%) 1644(1.4%) loop! ...s/herbie/develop/src/core/enode.rkt:192:2 custom-set-union [115] 42.5% loop [95] 32.7% set [118] 12.7% update-en-expr [130] 3.2% ---------------------------------------------------------------------------------------- hash-update! [97] 100.0% [103] 10410(8.8%) 334(0.3%) ??? ...s/herbie/develop/src/core/egraph.rkt:225:24 for-loop [113] 96.8% ---------------------------------------------------------------------------------------- for-loop [48] 3.3% ??? [154] 3.7% get-sigs [96] 92.9% [104] 9574(8.1%) 1036(0.9%) ??? ...ts/racket/contract/private/arr-i.rkt:804:10 for-loop [116] 50.8% ??? [119] 27.6% get/build-late-neg-projection [124] 10.7% ---------------------------------------------------------------------------------------- ??? [154] 8.7% for-loop [48] 24.0% get-sigs [96] 67.3% [105] 4120(3.5%) 358(0.3%) ...velop/src/common.rkt:47:2 ...e/arr-i.rkt:906:19 ??? [120] 58.6% ??? [123] 32.7% ---------------------------------------------------------------------------------------- f137 [177] 27.3% loop [95] 72.7% [106] 3770(3.2%) 0(0.0%) option-on-expr ...velop/src/core/regimes.rkt:103:0 sort-context-on-expr [122] 55.2% errors [88] 36.1% pick-errors [125] 8.6% ---------------------------------------------------------------------------------------- loop [95] 100.0% [107] 1396(1.2%) 1396(1.2%) foldl ...et/collects/racket/private/list.rkt:229:4 ---------------------------------------------------------------------------------------- for-loop [98] 100.0% [108] 694(0.6%) 0(0.0%) ulp-difference ...erbie/develop/src/float.rkt:19:0 ??? [161] 100.0% ---------------------------------------------------------------------------------------- loop [95] 48.1% map-enodes [21] 51.9% [109] 616(0.5%) 616(0.5%) for-loop ...ie/develop/src/core/simplify.rkt:173:2 ---------------------------------------------------------------------------------------- loop [95] 100.0% [110] 362(0.3%) 0(0.0%) ??? ...tract/private/arrow-higher-order.rkt:145:21 ??? [134] 100.0% ---------------------------------------------------------------------------------------- loop [95] 50.0% map [121] 50.0% [111] 362(0.3%) 0(0.0%) ??? ...ket/collects/racket/private/list.rkt:323:18 hash-ref! [156] 50.0% map [121] 50.0% ---------------------------------------------------------------------------------------- ormap [100] 100.0% [112] 334(0.3%) 0(0.0%) flag-set? ...es/herbie/develop/src/config.rkt:34:0 return/no-unsupplied [160] 100.0% ---------------------------------------------------------------------------------------- ??? [103] 100.0% [113] 10076(8.5%) 9448(8.0%) for-loop ...bie/develop/src/core/egraph.rkt:226:26 update-en-expr [130] 6.2% ---------------------------------------------------------------------------------------- ??? [101] 100.0% [114] 7452(6.3%) 3444(2.9%) ??? ...acket/collects/racket/private/kw.rkt:444:14 bf* [131] 14.3% ??? [132] 14.2% for-loop [133] 14.0% ??? [142] 11.2% ---------------------------------------------------------------------------------------- adopt-enode! [82] 6.7% loop! [102] 93.3% [115] 5114(4.3%) 2062(1.7%) custom-set-union ...et/private/set-types.rkt:168:0 for-loop [127] 59.7% ---------------------------------------------------------------------------------------- ??? [104] 100.0% [116] 4866(4.1%) 0(0.0%) for-loop ...racket/contract/private/hash.rkt:239:6 ??? [169] 92.6% ??? [134] 7.4% ---------------------------------------------------------------------------------------- loop [95] 16.5% ??? [101] 83.5% [117] 4722(4.0%) 0(0.0%) ??? ...contract/private/../../private/kw.rkt:761:9 real->bigfloat [126] 100.0% ---------------------------------------------------------------------------------------- new-enode [76] 29.0% loop! [102] 71.0% [118] 3748(3.2%) 3748(3.2%) set ...collects/racket/private/set-types.rkt:981:0 ---------------------------------------------------------------------------------------- ??? [104] 100.0% [119] 2644(2.2%) 334(0.3%) ??? ...ects/racket/contract/private/hash.rkt:217:4 ??? [128] 87.4% ---------------------------------------------------------------------------------------- ...velop/src/common.rkt:47:2 [105] 100.0% [120] 2414(2.0%) 366(0.3%) ??? ...s/racket/contract/private/arr-i.rkt:1268:39 return/no-unsupplied [160] 84.8% ---------------------------------------------------------------------------------------- ??? [111] 7.7% parse-loop12 [165] 7.7% f137 [177] 84.6% [121] 2356(2.0%) 0(0.0%) map ...acket/collects/racket/private/map.rkt:20:13 f137 [177] 60.7% parse-loop12 [165] 14.2% ??? [111] 7.7% ??? [154] 7.7% simplify-node [172] 6.6% simplify* [138] 3.2% ---------------------------------------------------------------------------------------- option-on-expr [106] 100.0% [122] 2082(1.8%) 0(0.0%) sort-context-on-expr ...velop/src/points.rkt:115:0 ??? [129] 100.0% ---------------------------------------------------------------------------------------- ??? [169] 23.4% ...velop/src/common.rkt:47:2 [105] 76.6% [123] 1348(1.1%) 298(0.3%) ??? ...ects/racket/contract/private/list.rkt:342:4 ??? [169] 76.6% ??? [184] 12.4% ---------------------------------------------------------------------------------------- ??? [136] 33.9% ??? [104] 66.1% [124] 1028(0.9%) 332(0.3%) get/build-late-neg-projection ...te/guts.rkt:691:0 ??? [136] 33.9% ??? [135] 33.9% ---------------------------------------------------------------------------------------- option-on-expr [106] 100.0% [125] 326(0.3%) 0(0.0%) pick-errors .../develop/src/core/regimes.rkt:184:0 for-loop [137] 100.0% ---------------------------------------------------------------------------------------- ??? [117] 100.0% [126] 4722(4.0%) 4000(3.4%) real->bigfloat .../private/bigfloat/mpfr.rkt:451:0 ??? [153] 15.3% ---------------------------------------------------------------------------------------- custom-set-union [115] 100.0% [127] 3052(2.6%) 344(0.3%) for-loop ...cts/racket/private/set-types.rkt:174:3 for-loop [139] 88.7% ---------------------------------------------------------------------------------------- ??? [119] 100.0% [128] 2310(2.0%) 0(0.0%) ??? ...ects/racket/contract/private/list.rkt:169:2 ??? [140] 100.0% ---------------------------------------------------------------------------------------- sort-context-on-expr [122] 100.0% [129] 2082(1.8%) 0(0.0%) ??? ...cket/collects/racket/private/sort.rkt:403:3 generic-sort/key [141] 100.0% ---------------------------------------------------------------------------------------- update-leader! [66] 20.4% for-loop [113] 38.6% loop! [102] 41.0% [130] 1626(1.4%) 1626(1.4%) update-en-expr ...evelop/src/core/egraph.rkt:211:0 ---------------------------------------------------------------------------------------- ??? [114] 100.0% [131] 1064(0.9%) 0(0.0%) bf* ...ath/private/bigfloat/bigfloat-mpfr.rkt:95:0 ??? [142] 100.0% ---------------------------------------------------------------------------------------- ??? [114] 100.0% [132] 1060(0.9%) 694(0.6%) ??? ...herbie/develop/src/syntax/syntax.rkt:153:17 ??? [161] 34.5% ---------------------------------------------------------------------------------------- ??? [114] 100.0% [133] 1046(0.9%) 0(0.0%) for-loop ...ie/develop/src/syntax/syntax.rkt:528:2 bf<= [143] 100.0% ---------------------------------------------------------------------------------------- for-loop [116] 49.7% ??? [110] 50.3% [134] 720(0.6%) 362(0.3%) ??? ...ects/racket/contract/private/prop.rkt:493:4 ??? [145] 49.7% ---------------------------------------------------------------------------------------- get/build-late-neg-projection [124] 100.0% [135] 696(0.6%) 0(0.0%) ??? ...cts/racket/contract/private/prop.rkt:314:12 build-compound-type-name [144] 100.0% ---------------------------------------------------------------------------------------- get/build-late-neg-projection [124] 100.0% [136] 696(0.6%) 0(0.0%) ??? ...ects/racket/contract/private/hash.rkt:211:2 get/build-late-neg-projection [124] 100.0% ---------------------------------------------------------------------------------------- pick-errors [125] 100.0% [137] 326(0.3%) 0(0.0%) for-loop ...bie/develop/src/core/regimes.rkt:186:2 ??? [146] 100.0% ---------------------------------------------------------------------------------------- map [121] 100.0% [138] 300(0.3%) 0(0.0%) simplify* ...rbie/develop/src/core/reduce.rkt:31:0 return/no-unsupplied [160] 100.0% ---------------------------------------------------------------------------------------- for-loop [127] 100.0% [139] 2708(2.3%) 2708(2.3%) for-loop ...cts/racket/private/set-types.rkt:178:5 ---------------------------------------------------------------------------------------- ??? [128] 100.0% [140] 2310(2.0%) 360(0.3%) ??? ...ects/racket/contract/private/list.rkt:678:5 for-loop [147] 84.4% ---------------------------------------------------------------------------------------- ??? [129] 100.0% [141] 2082(1.8%) 0(0.0%) generic-sort/key .../racket/private/sort.rkt:185:2 copying-mergesort [149] 84.3% loop [151] 15.7% ---------------------------------------------------------------------------------------- ??? [114] 44.1% bf* [131] 55.9% [142] 1902(1.6%) 0(0.0%) ??? ...-racket/utils/simple-result-arrow.rkt:39:12 bfmul [148] 100.0% ---------------------------------------------------------------------------------------- for-loop [133] 100.0% [143] 1046(0.9%) 0(0.0%) bf<= ...h/private/bigfloat/bigfloat-mpfr.rkt:127:4 ??? [150] 100.0% ---------------------------------------------------------------------------------------- ??? [135] 100.0% [144] 696(0.6%) 696(0.6%) build-compound-type-name ...private/guts.rkt:448:0 ---------------------------------------------------------------------------------------- ??? [134] 100.0% [145] 358(0.3%) 358(0.3%) ??? ...lects/racket/contract/private/orc.rkt:83:14 ---------------------------------------------------------------------------------------- for-loop [137] 100.0% [146] 326(0.3%) 0(0.0%) ??? ...s/herbie/develop/src/core/regimes.rkt:177:2 ??? [101] 100.0% ---------------------------------------------------------------------------------------- ??? [140] 100.0% [147] 1950(1.7%) 362(0.3%) for-loop ...racket/contract/private/list.rkt:680:9 add-list-context [152] 81.4% ---------------------------------------------------------------------------------------- ??? [142] 100.0% [148] 1902(1.6%) 1134(1.0%) bfmul ...-lib/math/private/bigfloat/mpfr.rkt:819:4 ??? [153] 40.4% ---------------------------------------------------------------------------------------- copying-mergesort [149] 26.0% generic-sort/key [141] 74.0% [149] 1756(1.5%) 0(0.0%) copying-mergesort ...racket/private/sort.rkt:130:8 loop [151] 68.8% copying-mergesort [149] 26.0% jloop [10] 5.2% ---------------------------------------------------------------------------------------- bf<= [143] 100.0% [150] 1046(0.9%) 1046(0.9%) ??? ...tract/private/arrow-higher-order.rkt:346:33 ---------------------------------------------------------------------------------------- generic-sort/key [141] 19.0% copying-mergesort [149] 81.0% [151] 1714(1.5%) 694(0.6%) loop ...ket/collects/racket/private/sort.rkt:97:12 ??? [154] 40.5% ??? [101] 19.0% ---------------------------------------------------------------------------------------- for-loop [147] 100.0% [152] 1588(1.3%) 1588(1.3%) add-list-context ...ontract/private/list.rkt:752:0 ---------------------------------------------------------------------------------------- real->bigfloat [126] 48.5% bfmul [148] 51.5% [153] 1490(1.3%) 1490(1.3%) ??? .../share/racket/collects/ffi/unsafe.rkt:861:4 ---------------------------------------------------------------------------------------- ??? [62] 3.8% map [121] 3.9% loop [151] 7.4% for-loop [92] 7.7% ??? [163] 9.3% table-ref [155] 11.2% for-loop [69] 11.2% f137 [177] 11.7% loop [95] 16.1% ??? [101] 17.8% [154] 9396(8.0%) 364(0.3%) ??? ...tract/private/arrow-higher-order.rkt:342:33 table-ref [155] 64.2% approximate9 [5] 11.2% hash-ref! [156] 9.3% ...velop/src/common.rkt:47:2 [105] 3.8% best-alt [157] 3.8% ??? [104] 3.8% ---------------------------------------------------------------------------------------- simplify-alt [32] 0.2% for-loop [48] 1.8% table-ref [155] 2.6% get-sigs [96] 2.7% ??? [154] 7.6% for-loop [158] 41.6% ??? [52] 42.7% [155] 98138(83.2%) 6102(5.2%) table-ref .../racket/private/norm-define.rkt:53:83 for-loop [158] 41.6% iterate-egraph!13 [3] 39.7% loop [4] 3.7% ??? [159] 2.8% table-ref [155] 2.6% ??? [154] 2.5% ??? [161] 2.2% return/no-unsupplied [160] 0.5% mk-egraph [167] 0.4% ---------------------------------------------------------------------------------------- for-loop [186] 1.2% for-loop [33] 1.2% first-nonzero-exp [191] 4.0% ??? [111] 4.1% localize-error [41] 4.1% ??? [175] 4.6% for-loop [20] 5.2% for-loop [19] 7.8% ??? [163] 9.6% ??? [166] 9.6% ??? [164] 9.9% ??? [154] 11.4% loop [18] 11.4% compile [59] 14.4% [156] 4384(3.7%) 1044(0.9%) hash-ref! ...racket/private/more-scheme.rkt:373:13 ??? [163] 21.0% simplify [162] 14.7% ??? [166] 12.4% ??? [164] 11.4% ??? [6] 10.9% parse-loop12 [165] 8.3% ??? [7] 5.2% ??? [11] 1.2% ??? [12] 0.7% ---------------------------------------------------------------------------------------- ??? [154] 100.0% [157] 360(0.3%) 0(0.0%) best-alt ...tlies/herbie/develop/src/glue.rkt:71:0 argmins [168] 100.0% ---------------------------------------------------------------------------------------- table-ref [155] 100.0% [158] 86004(72.9%) 0(0.0%) for-loop ...ie/develop/src/core/simplify.rkt:63:12 table-ref [155] 100.0% ---------------------------------------------------------------------------------------- hash-has-key? [58] 20.3% table-ref [155] 79.7% [159] 10350(8.8%) 6396(5.4%) ??? ...ects/racket/contract/private/list.rkt:737:4 for-loop [170] 31.8% ??? [179] 3.2% ??? [169] 3.1% ---------------------------------------------------------------------------------------- simplify* [138] 9.0% flag-set? [112] 10.0% table-ref [155] 19.9% ??? [120] 61.1% [160] 3350(2.8%) 3050(2.6%) return/no-unsupplied ...ct/private/arr-i.rkt:533:0 filter [176] 9.0% ---------------------------------------------------------------------------------------- ??? [132] 11.4% ulp-difference [108] 21.7% table-ref [155] 66.9% [161] 3204(2.7%) 720(0.6%) ??? ...racket/collects/racket/private/kw.rkt:761:9 ??? [171] 55.4% ??? [184] 22.2% ---------------------------------------------------------------------------------------- for-loop [26] 10.2% hash-ref! [156] 89.8% [162] 2970(2.5%) 302(0.3%) simplify ...erbie/develop/src/core/reduce.rkt:16:0 f137 [177] 67.1% debug7 [174] 11.9% simplify-node [172] 10.8% ---------------------------------------------------------------------------------------- hash-ref! [156] 100.0% [163] 2616(2.2%) 0(0.0%) ??? ...es/herbie/develop/src/core/taylor.rkt:67:15 ??? [154] 58.7% hash-ref! [156] 41.3% ---------------------------------------------------------------------------------------- hash-ref! [156] 100.0% [164] 2616(2.2%) 0(0.0%) ??? ...es/herbie/develop/src/core/taylor.rkt:44:15 hash-ref! [156] 87.2% ??? [175] 12.8% ---------------------------------------------------------------------------------------- append-map [9] 32.3% map [121] 32.5% hash-ref! [156] 35.2% [165] 1028(0.9%) 666(0.6%) parse-loop12 ...s/racket/match/compiler.rkt:418:15 map [121] 17.6% loop [95] 17.6% ---------------------------------------------------------------------------------------- hash-ref! [156] 100.0% [166] 724(0.6%) 364(0.3%) ??? ...tlies/herbie/develop/src/programs.rkt:183:5 hash-ref! [156] 83.2% ---------------------------------------------------------------------------------------- table-ref [155] 100.0% [167] 692(0.6%) 0(0.0%) mk-egraph ...bie/develop/src/core/egraph.rkt:123:0 expr->enode [173] 100.0% ---------------------------------------------------------------------------------------- best-alt [157] 100.0% [168] 360(0.3%) 0(0.0%) argmins ...ies/herbie/develop/src/common.rkt:150:0 composed [185] 100.0% ---------------------------------------------------------------------------------------- ??? [159] 5.2% ??? [123] 21.8% for-loop [116] 72.9% [169] 6180(5.2%) 1040(0.9%) ??? ...cts/racket/contract/private/list.rkt:187:10 ??? [178] 72.9% ??? [123] 10.2% ---------------------------------------------------------------------------------------- ??? [159] 100.0% [170] 3296(2.8%) 1590(1.3%) for-loop ...acket/contract/private/list.rkt:743:12 ??? [179] 31.2% successfully-got-the-right-kind-of-function [182] 10.7% ??? [184] 9.9% ---------------------------------------------------------------------------------------- ??? [161] 100.0% [171] 1774(1.5%) 1450(1.2%) ??? ...s/racket/contract/private/arr-i.rkt:1233:27 ??? [183] 18.3% ---------------------------------------------------------------------------------------- simplify [162] 23.8% map [121] 76.2% [172] 1344(1.1%) 320(0.3%) simplify-node .../develop/src/core/reduce.rkt:50:0 f137 [177] 49.7% combine-aterms [181] 26.5% ---------------------------------------------------------------------------------------- mk-egraph [167] 29.3% expr->enode [173] 70.7% [173] 692(0.6%) 0(0.0%) expr->enode ...e/develop/src/core/egraph.rkt:124:2 expr->enode [173] 70.7% mk-enode! [64] 17.3% curried [180] 12.0% ---------------------------------------------------------------------------------------- simplify [162] 100.0% [174] 354(0.3%) 0(0.0%) debug7 ...tlies/herbie/develop/src/debug.rkt:102:0 ??? [47] 100.0% ---------------------------------------------------------------------------------------- ??? [164] 33.3% for-loop [19] 66.7% [175] 336(0.3%) 0(0.0%) ??? ...s/herbie/develop/src/core/taylor.rkt:288:19 hash-ref! [156] 100.0% ---------------------------------------------------------------------------------------- return/no-unsupplied [160] 100.0% [176] 300(0.3%) 300(0.3%) filter ...t/collects/racket/private/list.rkt:256:2 ---------------------------------------------------------------------------------------- simplify-node [172] 0.6% f137 [177] 3.9% append-map [9] 4.3% for-loop [25] 4.9% simplify [162] 8.1% eval-prog [99] 11.9% map [121] 14.0% split-table [31] 52.2% [177] 7218(6.1%) 0(0.0%) f137 .../collects/racket/match/compiler.rkt:507:40 loop [95] 38.0% map [121] 20.9% option-on-expr [106] 14.2% ??? [154] 11.9% taylor-sqrt [187] 4.9% append-map [9] 4.7% f137 [177] 3.9% composed [185] 1.2% ---------------------------------------------------------------------------------------- ??? [169] 100.0% [178] 4508(3.8%) 0(0.0%) ??? ...ects/racket/contract/private/list.rkt:686:7 ??? [184] 100.0% ---------------------------------------------------------------------------------------- ??? [159] 24.5% for-loop [170] 75.5% [179] 1362(1.2%) 1036(0.9%) ??? ...private/unconstrained-domain-arrow.rkt:74:4 make-keyword-procedure [189] 23.9% ---------------------------------------------------------------------------------------- loop [95] 49.5% expr->enode [173] 50.5% [180] 658(0.6%) 658(0.6%) curried ...cket/collects/racket/function.rkt:71:18 ---------------------------------------------------------------------------------------- simplify-node [172] 100.0% [181] 356(0.3%) 0(0.0%) combine-aterms ...evelop/src/core/reduce.rkt:183:0 for-loop [186] 100.0% ---------------------------------------------------------------------------------------- for-loop [170] 100.0% [182] 352(0.3%) 0(0.0%) successfully-got-the-right-kind-of-function ...9:4 arity-checking-wrapper [188] 100.0% ---------------------------------------------------------------------------------------- ??? [171] 100.0% [183] 324(0.3%) 324(0.3%) ??? ...ects/racket/contract/private/prop.rkt:256:4 ---------------------------------------------------------------------------------------- for-loop [170] 5.2% ??? [123] 5.4% ??? [47] 5.7% ??? [161] 11.4% ??? [178] 72.3% [184] 6232(5.3%) 5544(4.7%) ??? ...ects/racket/contract/private/guts.rkt:644:8 dict? [190] 5.7% contract? [194] 5.4% ---------------------------------------------------------------------------------------- f137 [177] 48.3% argmins [168] 51.7% [185] 696(0.6%) 0(0.0%) composed ...ollects/racket/private/list.rkt:321:16 errors [88] 51.7% free-variables [193] 48.3% ---------------------------------------------------------------------------------------- combine-aterms [181] 100.0% [186] 356(0.3%) 0(0.0%) for-loop ...rbie/develop/src/core/reduce.rkt:185:4 hash-ref! [156] 100.0% ---------------------------------------------------------------------------------------- f137 [177] 100.0% [187] 354(0.3%) 0(0.0%) taylor-sqrt ...e/develop/src/core/taylor.rkt:346:0 first-nonzero-exp [191] 100.0% ---------------------------------------------------------------------------------------- successfully-got-the-right-kind-of-function [182]100.0% [188] 352(0.3%) 0(0.0%) arity-checking-wrapper ...w-higher-order.rkt:402:0 matches-arity-exactly? [192] 100.0% ---------------------------------------------------------------------------------------- ??? [179] 100.0% [189] 326(0.3%) 326(0.3%) make-keyword-procedure ...ket/private/kw.rkt:260:4 ---------------------------------------------------------------------------------------- ??? [184] 100.0% [190] 354(0.3%) 354(0.3%) dict? ...ollects/racket/private/generic.rkt:146:11 ---------------------------------------------------------------------------------------- taylor-sqrt [187] 100.0% [191] 354(0.3%) 0(0.0%) first-nonzero-exp ...lop/src/core/taylor.rkt:260:0 hash-ref! [156] 100.0% ---------------------------------------------------------------------------------------- arity-checking-wrapper [188] 100.0% [192] 352(0.3%) 352(0.3%) matches-arity-exactly? ...te/arrow-common.rkt:70:0 ---------------------------------------------------------------------------------------- composed [185] 100.0% [193] 336(0.3%) 336(0.3%) free-variables ...e/develop/src/programs.rkt:100:0 ---------------------------------------------------------------------------------------- ??? [184] 100.0% [194] 334(0.3%) 334(0.3%) contract? ...acket/contract/private/guts.rkt:109:0 ----------------------------------------------------------------------------------------