Profiling results ----------------- Total cpu time observed: 1660438ms (out of 1664568ms) Number of samples taken: 4836 (once every 343ms) (Hiding functions with self<1.0% and local<2.0%: 27 of 292 hidden) ================================================================================== Caller Idx Total Self Name+src Local% ms(pct) ms(pct) Callee ================================================================================== ??? [78] 100.0% [1] 1378136(83.0%) 0(0.0%) profile-thunk16 ...t/pkgs/profile-lib/main.rkt:9:0 run [25] 100.0% ---------------------------------------------------------------------------------- ??? [78] 100.0% [2] 1354524(81.6%) 0(0.0%) run-improve50 ...ie/develop/src/mainloop.rkt:234:0 for-loop [26] 95.6% get-final-combination [35] 4.1% setup-alt-simplified [45] 0.2% loop [96] 0.1% ??? [72] 0.0% ---------------------------------------------------------------------------------- ??? [233] 100.0% [3] 818672(49.3%) 0(0.0%) iterate-egraph!13 ...p/src/core/simplify.rkt:102:0 one-iter [27] 98.6% map-enodes [37] 1.4% ---------------------------------------------------------------------------------- ??? [138] 100.0% [4] 383330(23.1%) 0(0.0%) approximate9 ...e/develop/src/core/taylor.rkt:12:0 loop [28] 88.9% f176 [193] 10.4% taylor-quotient [14] 0.6% ---------------------------------------------------------------------------------- ??? [233] 100.0% [5] 242160(14.6%) 0(0.0%) loop ...herbie/develop/src/core/simplify.rkt:215:2 pass [29] 100.0% ---------------------------------------------------------------------------------- hash-ref! [161] 100.0% [6] 234614(14.1%) 0(0.0%) ??? ...s/herbie/develop/src/core/taylor.rkt:285:26 for-loop [30] 100.0% ---------------------------------------------------------------------------------- parse-loop12 [147] 0.2% simplify [164] 2.3% map [194] 97.5% [7] 201638(12.1%) 606(0.0%) simplify-node .../develop/src/core/reduce.rkt:50:0 append-map [31] 62.5% f176 [193] 32.9% combine-aterms [40] 3.8% ---------------------------------------------------------------------------------- hash-ref! [161] 100.0% [8] 154758(9.3%) 350(0.0%) ??? ...s/herbie/develop/src/core/taylor.rkt:295:23 for-loop [32] 99.9% ---------------------------------------------------------------------------------- hash-ref! [161] 100.0% [9] 66172(4.0%) 0(0.0%) ??? ...s/herbie/develop/src/core/taylor.rkt:392:23 for-loop [33] 99.5% simplify [164] 0.5% ---------------------------------------------------------------------------------- hash-ref! [161] 100.0% [10] 56764(3.4%) 0(0.0%) ??? ...s/herbie/develop/src/core/taylor.rkt:483:23 for-loop [34] 100.0% ---------------------------------------------------------------------------------- f176 [193] 100.0% [11] 44174(2.7%) 0(0.0%) loop ...es/herbie/develop/src/core/reduce.rkt:18:2 expression->type [190] 65.0% f176 [193] 31.9% type-of [191] 3.1% ---------------------------------------------------------------------------------- hash-ref! [161] 100.0% [12] 38226(2.3%) 0(0.0%) ??? ...s/herbie/develop/src/core/taylor.rkt:338:33 hash-ref! [161] 68.7% for-loop [38] 30.4% simplify [164] 0.9% ---------------------------------------------------------------------------------- f176 [193] 100.0% [13] 17718(1.1%) 0(0.0%) loop ...s/herbie/develop/src/core/taylor.rkt:262:2 hash-ref! [161] 100.0% ---------------------------------------------------------------------------------- approximate9 [4] 18.3% f176 [193] 81.7% [14] 13156(0.8%) 0(0.0%) taylor-quotient ...velop/src/core/taylor.rkt:328:0 simplify [164] 59.2% first-nonzero-exp [41] 40.8% ---------------------------------------------------------------------------------- map-enodes [37] 3.1% loop [196] 96.9% [15] 10602(0.6%) 3048(0.2%) for-loop ...ie/develop/src/core/simplify.rkt:173:2 eval-const-expr [42] 36.1% setfindf [44] 28.7% curried [205] 3.4% compose [203] 3.1% ---------------------------------------------------------------------------------- f176 [193] 100.0% [16] 9926(0.6%) 1688(0.1%) combine-mterms ...evelop/src/core/reduce.rkt:191:0 for-loop [39] 83.0% ---------------------------------------------------------------------------------- composed [195] 3.3% append-map [31] 96.7% [17] 9830(0.6%) 2788(0.2%) free-variables ...e/develop/src/programs.rkt:100:0 ??? [72] 54.4% variable? [36] 17.2% ---------------------------------------------------------------------------------- rewriter [94] 100.0% [18] 8548(0.5%) 332(0.0%) *rules* ...rbie/develop/src/syntax/rules.rkt:512:0 for-loop [100] 92.2% flag-set? [122] 3.9% ---------------------------------------------------------------------------------- copying-mergesort [234] 100.0% [19] 7204(0.4%) 0(0.0%) jloop ...t/collects/racket/private/sort.rkt:121:23 ??? [136] 100.0% ---------------------------------------------------------------------------------- parse-loop12 [147] 18.9% map [194] 81.1% [20] 3450(0.2%) 302(0.0%) ??? ...ies/herbie/develop/src/core/reduce.rkt:61:5 for-loop [43] 91.2% ---------------------------------------------------------------------------------- hash-ref! [161] 100.0% [21] 2062(0.1%) 0(0.0%) ??? ...s/herbie/develop/src/core/taylor.rkt:322:33 for-loop [46] 100.0% ---------------------------------------------------------------------------------- map [194] 25.3% f176 [193] 74.7% [22] 1422(0.1%) 0(0.0%) taylor ...herbie/develop/src/core/taylor.rkt:163:0 debug7 [180] 49.8% hash-ref! [161] 25.2% debug-print [175] 25.0% ---------------------------------------------------------------------------------- parse-loop12 [147] 1.8% loop [23] 98.2% [23] 714(0.0%) 0(0.0%) loop ...cket/collects/racket/private/map.rkt:36:19 loop [23] 98.2% ??? [138] 1.8% ---------------------------------------------------------------------------------- f176 [193] 100.0% [24] 692(0.0%) 0(0.0%) taylor-invert ...develop/src/core/taylor.rkt:312:0 first-nonzero-exp [41] 52.0% simplify [164] 48.0% ---------------------------------------------------------------------------------- profile-thunk16 [1] 100.0% [25] 1378136(83.0%) 0(0.0%) run ...share/racket/pkgs/profile-lib/main.rkt:39:2 ??? [78] 100.0% ---------------------------------------------------------------------------------- run-improve50 [2] 100.0% [26] 1294798(78.0%) 0(0.0%) for-loop ...herbie/develop/src/mainloop.rkt:249:10 run-iter! [47] 100.0% ---------------------------------------------------------------------------------- iterate-egraph!13 [3] 100.0% [27] 806982(48.6%) 4704(0.3%) one-iter ...ie/develop/src/core/simplify.rkt:113:0 loop [48] 81.6% for-loop [51] 16.7% apply-match [60] 1.1% ---------------------------------------------------------------------------------- approximate9 [4] 100.0% [28] 340920(20.5%) 0(0.0%) loop ...es/herbie/develop/src/core/taylor.rkt:86:4 ??? [138] 99.9% hash-ref! [161] 0.1% ---------------------------------------------------------------------------------- loop [5] 100.0% [29] 242160(14.6%) 1370(0.1%) pass ...herbie/develop/src/core/simplify.rkt:205:2 for-loop [49] 99.4% ---------------------------------------------------------------------------------- ??? [6] 100.0% [30] 234614(14.1%) 0(0.0%) for-loop ...bie/develop/src/core/taylor.rkt:285:52 ??? [50] 49.2% hash-ref! [161] 47.1% simplify [164] 3.6% ---------------------------------------------------------------------------------- parse-loop12 [147] 0.2% f176 [193] 23.5% simplify-node [7] 32.6% append-map [31] 43.7% [31] 209416(12.6%) 9436(0.6%) append-map ...acket/collects/racket/list.rkt:565:2 parse-loop12 [147] 45.7% append-map [31] 43.7% f176 [193] 8.1% free-variables [17] 0.9% loop [196] 0.1% ---------------------------------------------------------------------------------- ??? [8] 100.0% [32] 154758(9.3%) 0(0.0%) for-loop ...bie/develop/src/core/taylor.rkt:298:27 hash-ref! [161] 100.0% ---------------------------------------------------------------------------------- ??? [9] 100.0% [33] 65850(4.0%) 0(0.0%) for-loop ...bie/develop/src/core/taylor.rkt:396:33 for-loop [52] 100.0% ---------------------------------------------------------------------------------- ??? [10] 100.0% [34] 56764(3.4%) 0(0.0%) for-loop ...bie/develop/src/core/taylor.rkt:487:35 parse-loop12 [147] 100.0% ---------------------------------------------------------------------------------- run-improve50 [2] 100.0% [35] 55540(3.3%) 0(0.0%) get-final-combination ...op/src/mainloop.rkt:264:0 split-table [53] 96.9% extract-alt [57] 2.5% ??? [138] 0.6% ---------------------------------------------------------------------------------- expression->type [190] 1.3% matcher [118] 1.5% free-variables [17] 7.1% substitute-e [82] 14.8% match-e [74] 75.2% [36] 23664(1.4%) 1656(0.1%) variable? ...e/develop/src/syntax/syntax.rkt:660:0 ??? [72] 93.0% ---------------------------------------------------------------------------------- iterate-egraph!13 [3] 100.0% [37] 11690(0.7%) 0(0.0%) map-enodes ...ie/develop/src/core/egraph.rkt:139:0 loop [196] 97.2% for-loop [15] 2.8% ---------------------------------------------------------------------------------- ??? [12] 100.0% [38] 11610(0.7%) 0(0.0%) for-loop ...bie/develop/src/core/taylor.rkt:341:46 hash-ref! [161] 100.0% ---------------------------------------------------------------------------------- combine-mterms [16] 100.0% [39] 8238(0.5%) 2374(0.1%) for-loop ...rbie/develop/src/core/reduce.rkt:195:5 hash-ref! [161] 71.2% ---------------------------------------------------------------------------------- simplify-node [7] 100.0% [40] 7632(0.5%) 1434(0.1%) combine-aterms ...evelop/src/core/reduce.rkt:183:0 for-loop [54] 81.2% ---------------------------------------------------------------------------------- taylor-invert [24] 6.3% taylor-quotient [14] 93.7% [41] 5728(0.3%) 0(0.0%) first-nonzero-exp ...lop/src/core/taylor.rkt:260:0 hash-ref! [161] 100.0% ---------------------------------------------------------------------------------- for-loop [15] 100.0% [42] 3832(0.2%) 1052(0.1%) eval-const-expr .../develop/src/programs.rkt:166:0 f176 [193] 26.8% bf* [152] 18.7% ??? [249] 17.5% parse-loop12 [147] 9.6% ---------------------------------------------------------------------------------- ??? [20] 100.0% [43] 3148(0.2%) 1420(0.1%) for-loop ...erbie/develop/src/core/reduce.rkt:62:7 pattern-match [56] 44.3% foldl [204] 10.6% ---------------------------------------------------------------------------------- for-loop [15] 100.0% [44] 3040(0.2%) 2728(0.2%) setfindf ...es/herbie/develop/src/common.rkt:184:0 for-loop [58] 10.3% ---------------------------------------------------------------------------------- run-improve50 [2] 100.0% [45] 2408(0.1%) 0(0.0%) setup-alt-simplified .../develop/src/glue.rkt:49:0 simplify-alt [55] 100.0% ---------------------------------------------------------------------------------- ??? [21] 100.0% [46] 2062(0.1%) 0(0.0%) for-loop ...bie/develop/src/core/taylor.rkt:324:46 hash-ref! [161] 100.0% ---------------------------------------------------------------------------------- for-loop [26] 100.0% [47] 1294798(78.0%) 0(0.0%) run-iter! ...herbie/develop/src/mainloop.rkt:215:0 simplify! [59] 62.0% gen-series! [61] 30.6% gen-rewrites! [63] 3.7% finalize-iter! [65] 3.4% ---------------------------------------------------------------------------------- f176 [193] 1.0% one-iter [27] 99.0% [48] 665116(40.1%) 720(0.0%) loop ...cket/collects/racket/private/map.rkt:52:19 apply-match [60] 98.9% f176 [193] 1.0% ---------------------------------------------------------------------------------- pass [29] 100.0% [49] 240790(14.5%) 3684(0.2%) for-loop ...e/develop/src/core/simplify.rkt:208:29 argmin [62] 74.1% loop [64] 20.0% for-loop [66] 3.6% make-sequence [145] 0.8% ---------------------------------------------------------------------------------- for-loop [30] 100.0% [50] 143238(8.6%) 0(0.0%) ??? ...s/herbie/develop/src/core/taylor.rkt:288:19 hash-ref! [161] 100.0% ---------------------------------------------------------------------------------- for-loop [51] 49.1% one-iter [27] 50.9% [51] 134380(8.1%) 31528(1.9%) for-loop ...e/develop/src/core/simplify.rkt:123:12 for-loop [51] 49.1% match-e [74] 38.2% ??? [110] 0.1% ---------------------------------------------------------------------------------- for-loop [33] 100.0% [52] 65850(4.0%) 0(0.0%) for-loop ...bie/develop/src/core/taylor.rkt:398:39 hash-ref! [161] 100.0% ---------------------------------------------------------------------------------- get-final-combination [35] 100.0% [53] 53808(3.2%) 0(0.0%) split-table ...s/herbie/develop/src/glue.rkt:162:0 f176 [193] 100.0% ---------------------------------------------------------------------------------- combine-aterms [40] 100.0% [54] 6198(0.4%) 3764(0.2%) for-loop ...rbie/develop/src/core/reduce.rkt:185:4 hash-ref! [161] 39.3% ---------------------------------------------------------------------------------- setup-alt-simplified [45] 100.0% [55] 2408(0.1%) 0(0.0%) simplify-alt ...s/herbie/develop/src/glue.rkt:76:0 ??? [233] 100.0% ---------------------------------------------------------------------------------- for-loop [68] 25.5% for-loop [43] 74.5% [56] 1394(0.1%) 684(0.0%) pattern-match ...develop/src/core/matcher.rkt:48:0 for-loop [68] 25.5% ??? [72] 25.5% ---------------------------------------------------------------------------------- get-final-combination [35] 100.0% [57] 1386(0.1%) 0(0.0%) extract-alt ...es/herbie/develop/src/glue.rkt:55:0 loop [67] 74.0% argmins [160] 26.0% ---------------------------------------------------------------------------------- setfindf [44] 100.0% [58] 312(0.0%) 312(0.0%) for-loop ...es/herbie/develop/src/common.rkt:185:2 ---------------------------------------------------------------------------------- run-iter! [47] 100.0% [59] 802232(48.3%) 0(0.0%) simplify! ...herbie/develop/src/mainloop.rkt:155:0 for-loop [69] 100.0% ---------------------------------------------------------------------------------- one-iter [27] 1.3% loop [48] 98.7% [60] 666488(40.1%) 2060(0.1%) apply-match ...develop/src/core/simplify.rkt:130:2 for-loop [70] 81.8% match-e [74] 9.5% update-leader! [92] 8.0% reduce-to-single! [77] 0.4% ---------------------------------------------------------------------------------- run-iter! [47] 100.0% [61] 396168(23.9%) 0(0.0%) gen-series! ...rbie/develop/src/mainloop.rkt:129:0 for-loop [71] 100.0% ---------------------------------------------------------------------------------- for-loop [49] 100.0% [62] 178362(10.7%) 1050(0.1%) argmin ...re/racket/collects/racket/list.rkt:743:0 for-loop [73] 84.8% expression-cost [76] 14.6% ---------------------------------------------------------------------------------- run-iter! [47] 100.0% [63] 48332(2.9%) 0(0.0%) gen-rewrites! ...ie/develop/src/mainloop.rkt:142:0 for-loop [75] 100.0% ---------------------------------------------------------------------------------- for-loop [49] 100.0% [64] 48104(2.9%) 300(0.0%) loop ...hare/racket/collects/racket/list.rkt:729:4 for-loop [73] 78.6% expression-cost [76] 20.8% ---------------------------------------------------------------------------------- run-iter! [47] 100.0% [65] 44168(2.7%) 0(0.0%) finalize-iter! ...e/develop/src/mainloop.rkt:169:0 ??? [72] 100.0% ---------------------------------------------------------------------------------- for-loop [49] 100.0% [66] 8622(0.5%) 8622(0.5%) for-loop ...e/develop/src/core/simplify.rkt:195:13 ---------------------------------------------------------------------------------- extract-alt [57] 49.3% best-alt [153] 50.7% [67] 2080(0.1%) 0(0.0%) loop ...htlies/herbie/develop/src/common.rkt:151:2 composed [195] 100.0% ---------------------------------------------------------------------------------- pattern-match [56] 100.0% [68] 710(0.0%) 0(0.0%) for-loop ...rbie/develop/src/core/matcher.rkt:66:9 pattern-match [56] 100.0% ---------------------------------------------------------------------------------- simplify! [59] 97.7% [69] 821440(49.5%) 0(0.0%) for-loop .../herbie/develop/src/mainloop.rkt:159:6 ??? [78] 100.0% ---------------------------------------------------------------------------------- apply-match [60] 100.0% [70] 545118(32.8%) 622(0.0%) for-loop ...e/develop/src/core/simplify.rkt:145:10 merge-egraph-nodes! [80] 38.8% mk-enode! [91] 28.0% substitute-e [82] 20.5% loop! [200] 11.1% list-member? [120] 1.6% ---------------------------------------------------------------------------------- gen-series! [61] 100.0% [71] 396168(23.9%) 0(0.0%) for-loop .../herbie/develop/src/mainloop.rkt:135:7 taylor-alt [79] 100.0% ---------------------------------------------------------------------------------- run-improve50 [2] 0.2% simplify* [197] 0.3% pattern-match [56] 0.3% expression->type [190] 1.0% ??? [260] 1.4% substitute-e [82] 1.6% free-variables [17] 2.5% variable? [36] 10.4% match-e [74] 11.1% get-sigs [126] 14.6% finalize-iter! [65] 20.4% f176 [193] 35.5% [72] 212582(12.8%) 48460(2.9%) ??? ...contract/private/arrow-val-first.rkt:357:18 hash-has-key? [81] 55.2% for-loop [85] 20.1% ??? [260] 0.7% atab-add-altns [87] 0.5% ---------------------------------------------------------------------------------- loop [64] 20.0% argmin [62] 80.0% [73] 189040(11.4%) 4130(0.2%) for-loop .../herbie/develop/src/programs.rkt:199:2 ??? [233] 68.4% ...velop/src/common.rkt:47:2 [135] 26.7% ??? [134] 2.7% ---------------------------------------------------------------------------------- apply-match [60] 23.4% for-loop [93] 28.3% for-loop [51] 48.4% [74] 165570(10.0%) 54682(3.3%) match-e ...herbie/develop/src/core/ematch.rkt:46:0 for-loop [83] 47.5% for-loop [93] 10.6% ??? [72] 7.2% variable? [36] 4.3% list-cartesian-product [99] 1.9% loop [196] 1.0% curry* [206] 0.2% filter [246] 0.2% custom-in-set [159] 0.2% ---------------------------------------------------------------------------------- gen-rewrites! [63] 100.0% [75] 48332(2.9%) 0(0.0%) for-loop ...herbie/develop/src/mainloop.rkt:147:11 ??? [84] 100.0% ---------------------------------------------------------------------------------- loop [64] 27.8% argmin [62] 72.2% [76] 36076(2.2%) 704(0.0%) expression-cost .../develop/src/programs.rkt:198:0 compile [86] 98.0% ---------------------------------------------------------------------------------- apply-match [60] 100.0% [77] 2786(0.2%) 1732(0.1%) reduce-to-single! ...lop/src/core/egraph.rkt:324:0 for-loop [88] 25.1% for-loop [89] 12.8% ---------------------------------------------------------------------------------- for-loop [69] 17.6% run [25] 34.0% [78] 1632728(98.3%) 0(0.0%) ??? ...lects/racket/private/more-scheme.rkt:261:28 profile-thunk16 [1] 34.0% run-improve50 [2] 33.5% ??? [233] 31.6% loop [96] 0.9% ---------------------------------------------------------------------------------- for-loop [71] 100.0% [79] 396168(23.9%) 0(0.0%) taylor-alt ...es/herbie/develop/src/glue.rkt:134:0 for-loop [90] 99.8% expression->type [190] 0.2% ---------------------------------------------------------------------------------- for-loop [97] 2.9% merge-egraph-nodes! [80] 7.8% for-loop [70] 89.4% [80] 211276(12.7%) 3526(0.2%) merge-egraph-nodes! ...p/src/core/egraph.rkt:152:0 update-leader! [92] 69.9% merge-egraph-nodes! [80] 7.8% for-loop [98] 6.2% for-loop [97] 5.3% loop! [200] 5.1% enode-merge! [101] 2.9% for-loop [100] 1.0% make-sequence [145] 0.3% ---------------------------------------------------------------------------------- mk-enode! [91] 4.2% ??? [72] 95.8% [81] 123430(7.4%) 26518(1.6%) hash-has-key? ...et/private/more-scheme.rkt:368:13 ??? [237] 77.4% ---------------------------------------------------------------------------------- substitute-e [82] 4.6% for-loop [70] 95.4% [82] 111644(6.7%) 3094(0.2%) substitute-e ...e/develop/src/core/ematch.rkt:71:0 mk-enode! [91] 91.1% substitute-e [82] 4.6% ??? [72] 1.4% variable? [36] 1.1% ---------------------------------------------------------------------------------- match-e [74] 100.0% [83] 104042(6.3%) 33344(2.0%) for-loop ...rbie/develop/src/core/ematch.rkt:59:11 for-loop [93] 56.4% list-cartesian-product [99] 6.9% loop [196] 6.1% curry* [206] 1.0% foldl [204] 0.8% curried [205] 0.6% filter [246] 0.5% ---------------------------------------------------------------------------------- for-loop [75] 100.0% [84] 48332(2.9%) 0(0.0%) ??? ...ies/herbie/develop/src/alternative.rkt:88:0 rewriter [94] 100.0% ---------------------------------------------------------------------------------- ??? [72] 100.0% [85] 43498(2.6%) 0(0.0%) for-loop ...ie/develop/src/core/alt-table.rkt:51:2 atab-add-altn [95] 100.0% ---------------------------------------------------------------------------------- expression-cost [76] 100.0% [86] 35372(2.1%) 1046(0.1%) compile ...s/herbie/develop/src/programs.rkt:175:0 hash-ref! [161] 97.0% ---------------------------------------------------------------------------------- ??? [72] 100.0% [87] 1002(0.1%) 0(0.0%) atab-add-altns ...elop/src/core/alt-table.rkt:50:0 atab-add-altn [95] 100.0% ---------------------------------------------------------------------------------- reduce-to-single! [77] 100.0% [88] 698(0.0%) 698(0.0%) for-loop ...rbie/develop/src/core/egraph.rkt:325:8 ---------------------------------------------------------------------------------- reduce-to-single! [77] 100.0% [89] 356(0.0%) 356(0.0%) for-loop ...bie/develop/src/core/egraph.rkt:328:21 ---------------------------------------------------------------------------------- taylor-alt [79] 100.0% [90] 395506(23.8%) 0(0.0%) for-loop ...lies/herbie/develop/src/glue.rkt:139:6 ??? [138] 100.0% ---------------------------------------------------------------------------------- expr->enode [247] 1.8% substitute-e [82] 39.3% for-loop [70] 58.9% [91] 258722(15.6%) 16530(1.0%) mk-enode! ...bie/develop/src/core/egraph.rkt:101:0 new-enode [102] 91.2% hash-has-key? [81] 2.0% mutable-set [112] 0.4% ---------------------------------------------------------------------------------- apply-match [60] 24.6% merge-egraph-nodes! [80] 75.4% [92] 217070(13.1%) 7748(0.5%) update-leader! ...evelop/src/core/egraph.rkt:217:0 for-loop [103] 93.9% custom-set-union! [111] 1.1% hash-ref! [161] 0.5% update-en-expr [210] 0.3% mutable-set [112] 0.3% make-sequence [145] 0.3% ---------------------------------------------------------------------------------- match-e [74] 32.3% for-loop [83] 67.7% [93] 91136(5.5%) 6550(0.4%) for-loop ...rbie/develop/src/core/ematch.rkt:65:37 match-e [74] 92.6% ??? [110] 1.9% ---------------------------------------------------------------------------------- ??? [84] 17.3% matcher [118] 82.7% [94] 48332(2.9%) 2394(0.1%) rewriter ...bie/develop/src/core/matcher.rkt:131:2 for-loop [104] 83.3% expression->type [190] 10.4% f176 [193] 3.3% *rules* [18] 2.3% ---------------------------------------------------------------------------------- atab-add-altns [87] 2.3% for-loop [85] 97.7% [95] 44500(2.7%) 0(0.0%) atab-add-altn ...elop/src/core/alt-table.rkt:208:0 best-and-tied-at-points [105] 96.8% override-at-pnts [113] 3.2% ---------------------------------------------------------------------------------- run-improve50 [2] 4.6% ??? [78] 95.4% [96] 31264(1.9%) 0(0.0%) loop ...htlies/herbie/develop/src/points.rkt:193:2 make-exacts* [119] 51.2% loop [106] 47.5% loop [121] 1.2% ---------------------------------------------------------------------------------- merge-egraph-nodes! [80] 100.0% [97] 18712(1.1%) 334(0.0%) for-loop ...bie/develop/src/core/egraph.rkt:200:10 merge-egraph-nodes! [80] 68.2% loop! [200] 30.0% ---------------------------------------------------------------------------------- merge-egraph-nodes! [80] 100.0% [98] 13330(0.8%) 11024(0.7%) for-loop ...rbie/develop/src/core/egraph.rkt:232:6 update-en-expr [210] 17.3% ---------------------------------------------------------------------------------- match-e [74] 20.3% list-cartesian-product [99] 25.6% for-loop [83] 54.1% [99] 12914(0.8%) 10456(0.6%) list-cartesian-product ...src/core/ematch.rkt:20:0 list-cartesian-product [99] 25.6% for-loop [109] 14.8% ---------------------------------------------------------------------------------- merge-egraph-nodes! [80] 25.7% *rules* [18] 74.3% [100] 10616(0.6%) 5428(0.3%) for-loop ...ies/herbie/develop/src/common.rkt:99:9 ormap [108] 32.5% flag-set? [122] 6.5% update-en-expr [210] 6.5% curry* [206] 3.4% ---------------------------------------------------------------------------------- merge-egraph-nodes! [80] 100.0% [101] 6502(0.4%) 1030(0.1%) enode-merge! ...e/develop/src/core/enode.rkt:129:0 adopt-enode! [107] 63.2% custom-set-intersect! [114] 21.0% ---------------------------------------------------------------------------------- mk-enode! [91] 100.0% [102] 235928(14.2%) 2668(0.2%) new-enode ...erbie/develop/src/core/enode.rkt:97:0 type-of-enode-expr [115] 98.6% ---------------------------------------------------------------------------------- update-leader! [92] 100.0% [103] 203898(12.3%) 3104(0.2%) for-loop ...rbie/develop/src/core/egraph.rkt:222:6 for-loop [116] 98.3% update-en-expr [210] 0.2% ---------------------------------------------------------------------------------- rewriter [94] 100.0% [104] 48332(2.9%) 330(0.0%) for-loop ...ie/develop/src/core/matcher.rkt:134:10 matcher [118] 99.9% ---------------------------------------------------------------------------------- atab-add-altn [95] 100.0% [105] 43090(2.6%) 0(0.0%) best-and-tied-at-points ...ore/alt-table.rkt:122:0 errors [117] 100.0% ---------------------------------------------------------------------------------- loop [96] 100.0% [106] 14858(0.9%) 0(0.0%) loop ...htlies/herbie/develop/src/points.rkt:151:2 make-exacts* [119] 51.2% loop [121] 37.1% eval-prog [130] 11.7% ---------------------------------------------------------------------------------- enode-merge! [101] 100.0% [107] 4108(0.2%) 688(0.0%) adopt-enode! ...e/develop/src/core/enode.rkt:105:0 custom-set-union [209] 83.3% ---------------------------------------------------------------------------------- for-loop [100] 100.0% [108] 3450(0.2%) 0(0.0%) ormap ...et/collects/racket/private/map.rkt:105:13 flag-set? [122] 70.5% list-member? [120] 29.5% ---------------------------------------------------------------------------------- list-cartesian-product [99] 100.0% [109] 2458(0.1%) 2458(0.1%) for-loop ...erbie/develop/src/core/ematch.rkt:24:8 ---------------------------------------------------------------------------------- for-loop [51] 12.6% for-loop [93] 87.4% [110] 2382(0.1%) 1016(0.1%) ??? ...ies/herbie/develop/src/core/ematch.rkt:50:5 for-loop [124] 57.3% ---------------------------------------------------------------------------------- update-leader! [92] 100.0% [111] 2364(0.1%) 328(0.0%) custom-set-union! ...t/private/set-types.rkt:245:0 for-loop [123] 86.1% ---------------------------------------------------------------------------------- update-leader! [92] 40.8% mk-enode! [91] 59.2% [112] 1750(0.1%) 1390(0.1%) mutable-set .../racket/private/set-types.rkt:999:0 for-loop [125] 20.6% ---------------------------------------------------------------------------------- atab-add-altn [95] 100.0% [113] 1410(0.1%) 0(0.0%) override-at-pnts ...p/src/core/alt-table.rkt:145:0 errors [117] 100.0% ---------------------------------------------------------------------------------- enode-merge! [101] 100.0% [114] 1364(0.1%) 1364(0.1%) custom-set-intersect! ...ivate/set-types.rkt:269:0 ---------------------------------------------------------------------------------- new-enode [102] 100.0% [115] 232638(14.0%) 5396(0.3%) type-of-enode-expr ...elop/src/core/enode.rkt:68:0 get-sigs [126] 97.4% parse-loop12 [147] 0.3% ---------------------------------------------------------------------------------- for-loop [103] 100.0% [116] 200440(12.1%) 3132(0.2%) for-loop ...rbie/develop/src/core/egraph.rkt:223:8 hash-update! [127] 98.4% ---------------------------------------------------------------------------------- override-at-pnts [113] 1.9% composed [195] 4.2% option-on-expr [201] 13.4% loop [196] 22.7% best-and-tied-at-points [105] 57.8% [117] 74594(4.5%) 0(0.0%) errors ...lies/herbie/develop/src/points.rkt:218:0 for-loop [128] 71.4% eval-prog [130] 28.6% ---------------------------------------------------------------------------------- matcher [118] 14.4% for-loop [129] 36.1% for-loop [104] 49.5% [118] 48332(2.9%) 350(0.0%) matcher ...rbie/develop/src/core/matcher.rkt:167:2 rewriter [94] 49.2% for-loop [129] 36.1% matcher [118] 14.4% foldl [204] 0.1% variable? [36] 0.0% ---------------------------------------------------------------------------------- loop [106] 32.2% loop [96] 67.8% [119] 23622(1.4%) 0(0.0%) make-exacts* ...erbie/develop/src/points.rkt:138:0 map [194] 44.8% loop [196] 36.2% eval-prog [130] 19.0% ---------------------------------------------------------------------------------- ormap [108] 10.4% for-loop [70] 89.6% [120] 9804(0.6%) 1018(0.1%) list-member? ...llects/racket/private/set.rkt:24:0 loop [131] 59.2% member [132] 30.4% ---------------------------------------------------------------------------------- loop [96] 6.6% loop [106] 93.4% [121] 5900(0.4%) 0(0.0%) loop ...htlies/herbie/develop/src/points.rkt:141:4 map [194] 100.0% ---------------------------------------------------------------------------------- *rules* [18] 9.6% for-loop [100] 20.0% ormap [108] 70.4% [122] 3456(0.2%) 2048(0.1%) flag-set? ...es/herbie/develop/src/config.rkt:34:0 ??? [238] 20.4% return/no-unsupplied [239] 20.4% ---------------------------------------------------------------------------------- custom-set-union! [111] 100.0% [123] 2036(0.1%) 2036(0.1%) for-loop ...cts/racket/private/set-types.rkt:253:4 ---------------------------------------------------------------------------------- ??? [110] 100.0% [124] 1366(0.1%) 1366(0.1%) for-loop ...erbie/develop/src/core/ematch.rkt:51:7 ---------------------------------------------------------------------------------- mutable-set [112] 100.0% [125] 360(0.0%) 360(0.0%) for-loop ...cts/racket/private/set-types.rkt:943:2 ---------------------------------------------------------------------------------- type-of-enode-expr [115] 100.0% [126] 226560(13.6%) 3042(0.2%) get-sigs .../herbie/develop/src/type-check.rkt:5:0 ??? [134] 41.6% ??? [233] 31.8% ??? [72] 13.7% ...velop/src/common.rkt:47:2 [135] 11.5% ---------------------------------------------------------------------------------- for-loop [116] 100.0% [127] 197308(11.9%) 3068(0.2%) hash-update! ...ket/private/more-scheme.rkt:362:13 ??? [133] 98.4% ---------------------------------------------------------------------------------- errors [117] 100.0% [128] 53264(3.2%) 1668(0.1%) for-loop ...es/herbie/develop/src/points.rkt:221:4 ??? [136] 89.4% ulp-difference [137] 3.8% ??? [138] 3.1% ---------------------------------------------------------------------------------- matcher [118] 100.0% [129] 47648(2.9%) 0(0.0%) for-loop ...ie/develop/src/core/matcher.rkt:183:21 matcher [118] 100.0% ---------------------------------------------------------------------------------- sindices->spoints [218] 1.1% sort-context-on-expr [211] 1.2% point->alt [227] 1.2% loop [106] 6.1% make-exacts* [119] 15.7% errors [117] 74.7% [130] 28536(1.7%) 3838(0.2%) eval-prog ...herbie/develop/src/programs.rkt:148:0 f176 [193] 57.7% hash-ref! [161] 26.3% ---------------------------------------------------------------------------------- list-member? [120] 100.0% [131] 5808(0.3%) 5808(0.3%) loop (unknown source) ---------------------------------------------------------------------------------- list-member? [120] 100.0% [132] 2978(0.2%) 2978(0.2%) member (unknown source) ---------------------------------------------------------------------------------- hash-update! [127] 100.0% [133] 194240(11.7%) 2104(0.1%) ??? ...s/herbie/develop/src/core/egraph.rkt:225:24 for-loop [139] 98.7% make-sequence [145] 0.2% ---------------------------------------------------------------------------------- ??? [138] 0.9% for-loop [73] 2.7% f176 [193] 47.6% get-sigs [126] 48.8% [134] 193164(11.6%) 12838(0.8%) ??? ...ts/racket/contract/private/arr-i.rkt:804:10 ??? [140] 49.8% for-loop [142] 33.4% get/build-late-neg-projection [169] 7.7% ??? [251] 1.3% coerce-contract [185] 0.5% ??? [250] 0.4% ---------------------------------------------------------------------------------- ??? [138] 2.1% get-sigs [126] 23.4% f176 [193] 29.2% for-loop [73] 45.3% [135] 111548(6.7%) 34512(2.1%) ...velop/src/common.rkt:47:2 ...e/arr-i.rkt:906:19 ??? [143] 34.9% ??? [144] 33.9% coerce-contract [185] 0.3% ---------------------------------------------------------------------------------- ??? [230] 2.1% jloop [19] 7.6% loop [240] 15.1% loop [196] 25.1% for-loop [128] 50.1% [136] 95098(5.7%) 644(0.0%) ??? ...tlies/herbie/develop/src/programs.rkt:154:4 ??? [141] 96.3% ??? [138] 1.7% ??? [146] 1.3% ---------------------------------------------------------------------------------- for-loop [128] 100.0% [137] 2020(0.1%) 684(0.0%) ulp-difference ...erbie/develop/src/float.rkt:19:0 return/no-unsupplied [239] 49.6% ??? [238] 16.5% ---------------------------------------------------------------------------------- get-final-combination [35] 0.1% map [194] 0.1% loop [23] 0.2% loop [196] 0.4% for-loop [128] 0.4% ??? [136] 0.4% f176 [193] 3.5% loop [28] 27.2% ??? [233] 33.7% for-loop [90] 33.7% [138] 417828(25.2%) 1954(0.1%) ??? ...tract/private/arrow-higher-order.rkt:342:33 ??? [233] 36.4% approximate9 [4] 32.3% hash-ref! [161] 27.2% simplify [164] 1.5% ??? [260] 0.8% ...velop/src/common.rkt:47:2 [135] 0.6% ??? [134] 0.4% best-alt [153] 0.4% ---------------------------------------------------------------------------------- ??? [133] 100.0% [139] 191810(11.6%) 165532(10.0%) for-loop ...bie/develop/src/core/egraph.rkt:226:26 update-en-expr [210] 13.7% ---------------------------------------------------------------------------------- ??? [134] 100.0% [140] 96260(5.8%) 7260(0.4%) ??? ...ects/racket/contract/private/hash.rkt:217:4 ??? [148] 92.5% ---------------------------------------------------------------------------------- ??? [136] 100.0% [141] 91568(5.5%) 52418(3.2%) ??? ...acket/collects/racket/private/kw.rkt:444:14 ??? [149] 17.8% ??? [202] 9.3% ??? [150] 8.8% bf* [152] 4.6% ??? [261] 1.5% parse-loop12 [147] 0.4% ---------------------------------------------------------------------------------- for-loop [244] 27.3% ??? [134] 72.7% [142] 88804(5.3%) 15074(0.9%) for-loop ...racket/contract/private/hash.rkt:239:6 ??? [254] 78.9% ??? [261] 4.1% ---------------------------------------------------------------------------------- ??? [254] 9.3% for-loop [258] 10.0% ...velop/src/common.rkt:47:2 [135] 80.8% [143] 38930(2.3%) 9864(0.6%) ??? ...ects/racket/contract/private/list.rkt:342:4 ??? [254] 69.2% ??? [260] 10.6% ??? [251] 3.5% ---------------------------------------------------------------------------------- ...velop/src/common.rkt:47:2 [135] 100.0% [144] 37770(2.3%) 14248(0.9%) ??? ...s/racket/contract/private/arr-i.rkt:1268:39 ??? [238] 26.5% assoc-ref [151] 18.2% return/no-unsupplied [239] 17.5% ---------------------------------------------------------------------------------- ??? [133] 8.8% update-leader! [92] 17.1% merge-egraph-nodes! [80] 19.5% for-loop [49] 54.6% [145] 3698(0.2%) 2666(0.2%) make-sequence ...ects/racket/private/for.rkt:509:2 ??? [155] 27.9% ---------------------------------------------------------------------------------- ??? [136] 100.0% [146] 1234(0.1%) 0(0.0%) ??? ...contract/private/../../private/kw.rkt:761:9 real->bigfloat [154] 100.0% ---------------------------------------------------------------------------------- ??? [141] 0.1% eval-const-expr [42] 0.1% composed [195] 0.2% type-of-enode-expr [115] 0.2% loop [196] 0.4% hash-ref! [161] 0.6% f176 [193] 0.6% simplify [164] 2.1% for-loop [34] 13.0% parse-loop12 [147] 13.7% map [194] 27.8% append-map [31] 41.2% [147] 287552(17.3%) 22100(1.3%) parse-loop12 ...s/racket/match/compiler.rkt:418:15 for-loop [156] 19.3% make-multiplication-node [162] 18.3% parse-loop12 [147] 13.7% for-loop [158] 13.0% f176 [193] 10.9% loop [196] 10.5% map [194] 8.2% append-map [31] 0.4% simplify-node [7] 0.1% ??? [20] 0.1% ??? [233] 0.1% loop [23] 0.0% simplify* [197] 0.0% ---------------------------------------------------------------------------------- ??? [140] 100.0% [148] 89000(5.4%) 6936(0.4%) ??? ...ects/racket/contract/private/list.rkt:169:2 ??? [157] 92.2% ---------------------------------------------------------------------------------- ??? [141] 100.0% [149] 16298(1.0%) 8498(0.5%) ??? ...herbie/develop/src/syntax/syntax.rkt:153:17 ??? [238] 25.6% return/no-unsupplied [239] 22.2% ---------------------------------------------------------------------------------- ??? [141] 100.0% [150] 8082(0.5%) 8082(0.5%) ??? ...rivate/unconstrained-domain-arrow.rkt:40:13 ---------------------------------------------------------------------------------- ??? [144] 100.0% [151] 6880(0.4%) 6880(0.4%) assoc-ref ...collects/racket/private/dict.rkt:56:0 ---------------------------------------------------------------------------------- eval-const-expr [42] 14.5% ??? [141] 85.5% [152] 4940(0.3%) 0(0.0%) bf* ...ath/private/bigfloat/bigfloat-mpfr.rkt:95:0 ??? [202] 100.0% ---------------------------------------------------------------------------------- ??? [138] 100.0% [153] 1774(0.1%) 0(0.0%) best-alt ...tlies/herbie/develop/src/glue.rkt:71:0 loop [67] 59.4% argmins [160] 40.6% ---------------------------------------------------------------------------------- ??? [146] 100.0% [154] 1234(0.1%) 416(0.0%) real->bigfloat .../private/bigfloat/mpfr.rkt:451:0 ??? [248] 66.3% ---------------------------------------------------------------------------------- make-sequence [145] 100.0% [155] 1032(0.1%) 360(0.0%) ??? ...acket/collects/racket/private/for.rkt:429:7 custom-in-set [159] 65.1% ---------------------------------------------------------------------------------- parse-loop12 [147] 100.0% [156] 108006(6.5%) 974(0.1%) for-loop ...rbie/develop/src/core/reduce.rkt:99:13 make-multiplication-node [162] 94.0% f176 [193] 5.1% ---------------------------------------------------------------------------------- ??? [148] 100.0% [157] 82064(4.9%) 5226(0.3%) ??? ...ects/racket/contract/private/list.rkt:678:5 for-loop [163] 93.6% ---------------------------------------------------------------------------------- parse-loop12 [147] 100.0% [158] 56764(3.4%) 0(0.0%) for-loop ...bie/develop/src/core/taylor.rkt:490:59 hash-ref! [161] 100.0% ---------------------------------------------------------------------------------- match-e [74] 48.5% ??? [155] 51.5% [159] 1306(0.1%) 1306(0.1%) custom-in-set ...acket/private/set-types.rkt:577:0 ---------------------------------------------------------------------------------- extract-alt [57] 33.3% best-alt [153] 66.7% [160] 1080(0.1%) 0(0.0%) argmins ...ies/herbie/develop/src/common.rkt:150:0 composed [195] 100.0% ---------------------------------------------------------------------------------- for-loop [46] 0.0% loop [28] 0.1% taylor [22] 0.1% for-loop [54] 0.2% simplify* [197] 0.2% update-leader! [92] 0.2% for-loop [38] 0.3% for-loop [39] 0.4% eval-prog [130] 0.6% ??? [12] 0.8% first-nonzero-exp [41] 1.1% loop [196] 1.2% for-loop [52] 2.4% for-loop [158] 2.6% compile [86] 2.9% loop [13] 3.0% ??? [167] 5.5% ??? [50] 7.6% for-loop [30] 7.9% for-loop [32] 10.7% ??? [165] 24.3% ??? [138] 27.4% [161] 410340(24.7%) 46308(2.8%) hash-ref! ...racket/private/more-scheme.rkt:373:13 simplify [164] 29.7% ??? [165] 24.3% ??? [6] 17.0% ??? [8] 10.7% ??? [167] 6.9% ??? [10] 2.6% ??? [9] 2.5% ??? [12] 1.2% bigfloat-hash [170] 0.5% parse-loop12 [147] 0.4% f176 [193] 0.2% ??? [171] 0.1% ??? [21] 0.0% ---------------------------------------------------------------------------------- simplify [164] 0.5% parse-loop12 [147] 27.1% map [194] 31.3% for-loop [156] 40.5% [162] 250644(15.1%) 0(0.0%) make-multiplication-node .../core/reduce.rkt:230:0 make-multiplication-subnode [166] 100.0% ---------------------------------------------------------------------------------- ??? [157] 100.0% [163] 76838(4.6%) 18358(1.1%) for-loop ...racket/contract/private/list.rkt:680:9 add-list-context [168] 49.5% get/build-late-neg-projection [169] 26.6% ---------------------------------------------------------------------------------- ??? [9] 0.1% taylor-invert [24] 0.1% ??? [12] 0.1% taylor-quotient [14] 2.0% for-loop [30] 2.2% ??? [138] 3.1% hash-ref! [161] 90.1% [164] 393082(23.7%) 0(0.0%) simplify ...erbie/develop/src/core/reduce.rkt:16:0 f176 [193] 94.5% parse-loop12 [147] 2.9% simplify-node [7] 1.2% debug-print [175] 1.1% make-multiplication-node [162] 0.3% debug7 [180] 0.1% ---------------------------------------------------------------------------------- hash-ref! [161] 100.0% [165] 328018(19.8%) 0(0.0%) ??? ...es/herbie/develop/src/core/taylor.rkt:44:15 hash-ref! [161] 100.0% ---------------------------------------------------------------------------------- make-multiplication-node [162] 100.0% [166] 250644(15.1%) 2018(0.1%) make-multiplication-subnode ...re/reduce.rkt:240:0 for-loop [172] 97.3% group-by68 [177] 1.4% compose [203] 0.6% ---------------------------------------------------------------------------------- hash-ref! [161] 100.0% [167] 38548(2.3%) 2702(0.2%) ??? ...tlies/herbie/develop/src/programs.rkt:183:5 hash-ref! [161] 80.3% loop [196] 17.9% ---------------------------------------------------------------------------------- for-loop [163] 100.0% [168] 38046(2.3%) 38046(2.3%) add-list-context ...ontract/private/list.rkt:752:0 ---------------------------------------------------------------------------------- listof-late-neg-projection [179] 0.6% ??? [174] 16.0% ??? [134] 24.6% for-loop [163] 57.8% [169] 35380(2.1%) 7154(0.4%) get/build-late-neg-projection ...te/guts.rkt:691:0 ??? [173] 62.5% ??? [174] 18.8% listof-late-neg-projection [179] 2.1% ---------------------------------------------------------------------------------- hash-ref! [161] 100.0% [170] 5880(0.4%) 0(0.0%) bigfloat-hash ...h/private/bigfloat/mpfr.rkt:165:0 bfcanonicalize [176] 66.3% sig+exp->bigfloat [178] 33.7% ---------------------------------------------------------------------------------- hash-ref! [161] 100.0% [171] 326(0.0%) 0(0.0%) ??? ...es/herbie/develop/src/core/taylor.rkt:67:15 listof [181] 100.0% ---------------------------------------------------------------------------------- make-multiplication-subnode [166] 100.0% [172] 243774(14.7%) 664(0.0%) for-loop ...rbie/develop/src/core/reduce.rkt:242:3 mterm->expr [187] 56.1% make-multiplication-subsubsubnode [182] 42.7% compose [203] 0.1% ---------------------------------------------------------------------------------- get/build-late-neg-projection [169] 100.0% [173] 26178(1.6%) 6112(0.4%) ??? ...cts/racket/contract/private/prop.rkt:314:12 build-compound-type-name [183] 76.7% ---------------------------------------------------------------------------------- get/build-late-neg-projection [169] 100.0% [174] 12544(0.8%) 1010(0.1%) ??? ...ects/racket/contract/private/hash.rkt:211:2 get/build-late-neg-projection [169] 91.9% ---------------------------------------------------------------------------------- taylor [22] 7.9% simplify [164] 92.1% [175] 4492(0.3%) 0(0.0%) debug-print .../herbie/develop/src/debug.rkt:107:0 for-loop [184] 100.0% ---------------------------------------------------------------------------------- bigfloat-hash [170] 100.0% [176] 3896(0.2%) 3896(0.2%) bfcanonicalize .../private/bigfloat/mpfr.rkt:155:0 ---------------------------------------------------------------------------------- make-multiplication-subnode [166] 100.0% [177] 3440(0.2%) 2788(0.2%) group-by68 ...acket/collects/racket/list.rkt:749:0 hash-update [186] 19.0% ---------------------------------------------------------------------------------- bigfloat-hash [170] 100.0% [178] 1984(0.1%) 1984(0.1%) sig+exp->bigfloat ...ivate/bigfloat/mpfr.rkt:385:0 ---------------------------------------------------------------------------------- get/build-late-neg-projection [169] 100.0% [179] 1710(0.1%) 1038(0.1%) listof-late-neg-projection ...ivate/list.rkt:162:0 get/build-late-neg-projection [169] 39.3% ---------------------------------------------------------------------------------- simplify [164] 31.7% taylor [22] 68.3% [180] 1036(0.1%) 708(0.0%) debug7 ...tlies/herbie/develop/src/debug.rkt:102:0 ??? [238] 31.7% ---------------------------------------------------------------------------------- ??? [171] 100.0% [181] 326(0.0%) 0(0.0%) listof .../racket/contract/private/guts.rkt:411:15 coerce-contract [185] 100.0% ---------------------------------------------------------------------------------- make-multiplication-subsubsubnode [182] 0.8% for-loop [172] 99.2% [182] 104172(6.3%) 324(0.0%) make-multiplication-subsubsubnode ...uce.rkt:262:0 mterm->expr [187] 98.8% make-multiplication-subsubsubnode [182] 0.8% ---------------------------------------------------------------------------------- contract-struct-name [188] 18.0% ??? [173] 82.0% [183] 20066(1.2%) 13522(0.8%) build-compound-type-name ...private/guts.rkt:448:0 contract-struct-name [188] 46.4% ---------------------------------------------------------------------------------- debug-print [175] 100.0% [184] 4492(0.3%) 4492(0.3%) for-loop ...ies/herbie/develop/src/debug.rkt:113:2 ---------------------------------------------------------------------------------- listof [181] 19.5% ...velop/src/common.rkt:47:2 [135] 20.1% ??? [134] 60.4% [185] 1670(0.1%) 1344(0.1%) coerce-contract ...contract/private/guts.rkt:257:0 coerce-contract/f4 [189] 19.5% ---------------------------------------------------------------------------------- group-by68 [177] 100.0% [186] 652(0.0%) 652(0.0%) hash-update ...cket/private/more-scheme.rkt:356:13 ---------------------------------------------------------------------------------- make-multiplication-subsubsubnode [182] 43.2% for-loop [172] 56.8% [187] 240664(14.5%) 2116(0.1%) mterm->expr ...e/develop/src/core/reduce.rkt:270:0 expression->type [190] 92.2% f176 [193] 6.1% type-of [191] 0.9% ---------------------------------------------------------------------------------- build-compound-type-name [183] 100.0% [188] 12078(0.7%) 6544(0.4%) contract-struct-name ...ract/private/prop.rkt:89:0 build-compound-type-name [183] 52.8% ---------------------------------------------------------------------------------- coerce-contract [185] 100.0% [189] 326(0.0%) 326(0.0%) coerce-contract/f4 ...tract/private/guts.rkt:299:0 ---------------------------------------------------------------------------------- taylor-alt [79] 0.0% rewriter [94] 3.3% f176 [193] 3.5% loop [11] 4.5% mterm->expr [187] 36.1% for-loop [192] 52.6% [190] 304748(18.4%) 1686(0.1%) expression->type ...evelop/src/type-check.rkt:45:0 for-loop [192] 99.4% ??? [72] 0.2% variable? [36] 0.0% ---------------------------------------------------------------------------------- loop [11] 40.0% mterm->expr [187] 60.0% [191] 3436(0.2%) 3436(0.2%) type-of .../herbie/develop/src/type-check.rkt:38:0 ---------------------------------------------------------------------------------- expression->type [190] 100.0% [192] 303752(18.3%) 3610(0.2%) for-loop ...herbie/develop/src/type-check.rkt:52:5 expression->type [190] 52.9% f176 [193] 46.3% return/no-unsupplied [239] 0.1% ??? [238] 0.1% ---------------------------------------------------------------------------------- ??? [233] 0.0% for-loop [226] 0.0% for-loop [156] 0.1% eval-const-expr [42] 0.2% hash-ref! [161] 0.2% loop [48] 0.3% composed [195] 0.3% eval-prog [130] 0.4% loop [11] 0.5% mterm->expr [187] 0.6% approximate9 [4] 0.9% rewriter [94] 1.1% loop [196] 1.4% parse-loop12 [147] 1.5% append-map [31] 1.8% simplify-node [7] 1.9% split-table [53] 9.8% simplify [164] 10.5% f176 [193] 11.3% for-loop [192] 12.3% map [194] 44.6% [193] 481994(29.0%) 18824(1.1%) f176 .../collects/racket/match/compiler.rkt:507:40 map [194] 56.2% f176 [193] 11.3% loop [196] 8.9% append-map [31] 4.0% ??? [134] 3.6% ??? [233] 3.3% ??? [72] 3.0% expression->type [190] 2.9% ...velop/src/common.rkt:47:2 [135] 1.3% loop [11] 1.1% option-on-expr [201] 0.9% ??? [138] 0.4% composed [195] 0.4% loop [13] 0.4% taylor-quotient [14] 0.3% combine-mterms [16] 0.3% loop [48] 0.3% gather-multiplicative-terms [198] 0.2% parse-loop12 [147] 0.1% taylor [22] 0.0% compose [203] 0.0% taylor-invert [24] 0.0% return/no-unsupplied [239] 0.0% ??? [238] 0.0% curried [205] 0.0% ---------------------------------------------------------------------------------- gather-multiplicative-terms [198] 0.2% loop [121] 1.7% parse-loop12 [147] 2.1% make-exacts* [119] 3.0% f176 [193] 92.9% [194] 349970(21.1%) 2660(0.2%) map ...acket/collects/racket/private/map.rkt:20:13 f176 [193] 72.3% simplify-node [7] 9.1% parse-loop12 [147] 7.8% loop [196] 5.3% make-multiplication-node [162] 3.7% simplify* [197] 0.4% gather-multiplicative-terms [198] 0.2% ??? [20] 0.1% taylor [22] 0.0% ??? [138] 0.0% make-addition-node* [199] 0.0% ---------------------------------------------------------------------------------- argmins [160] 4.9% loop [67] 9.5% f176 [193] 85.6% [195] 21974(1.3%) 336(0.0%) composed ...ollects/racket/private/list.rkt:321:16 f176 [193] 79.4% errors [117] 14.4% parse-loop12 [147] 3.1% free-variables [17] 1.5% ---------------------------------------------------------------------------------- make-exacts* [119] 0.0% append-map [31] 0.2% map-enodes [37] 0.2% match-e [74] 1.0% option-on-expr [201] 2.9% for-loop [83] 3.1% ??? [167] 3.1% map [194] 4.4% loop! [200] 7.0% f176 [193] 12.9% parse-loop12 [147] 16.7% loop [196] 48.5% [196] 208774(12.6%) 13384(0.8%) loop ...cket/collects/racket/private/map.rkt:25:19 loop [196] 48.5% f176 [193] 19.0% option-on-expr [201] 12.8% loop! [200] 6.3% hash-ref! [161] 3.1% errors [117] 2.9% parse-loop12 [147] 1.5% foldl [204] 0.5% curried [205] 0.3% for-loop [15] 0.2% ??? [136] 0.1% ??? [202] 0.0% ??? [138] 0.0% ---------------------------------------------------------------------------------- parse-loop12 [147] 2.9% map [194] 97.1% [197] 12358(0.7%) 5498(0.3%) simplify* ...rbie/develop/src/core/reduce.rkt:31:0 hash-ref! [161] 24.9% ??? [207] 14.2% return/no-unsupplied [239] 11.1% ??? [72] 5.4% ---------------------------------------------------------------------------------- gather-multiplicative-terms [198] 1.8% map [194] 29.7% f176 [193] 68.5% [198] 9156(0.6%) 6808(0.4%) gather-multiplicative-terms ...re/reduce.rkt:116:0 map [194] 35.2% compose [203] 9.5% curried [205] 1.8% gather-multiplicative-terms [198] 1.8% curry* [206] 1.6% ---------------------------------------------------------------------------------- map [194] 100.0% [199] 326(0.0%) 0(0.0%) make-addition-node* ...p/src/core/reduce.rkt:222:0 make-addition-node [208] 100.0% ---------------------------------------------------------------------------------- for-loop [97] 5.2% merge-egraph-nodes! [80] 13.0% loop [196] 29.1% for-loop [70] 52.7% [200] 80970(4.9%) 15830(1.0%) loop! ...s/herbie/develop/src/core/enode.rkt:192:2 custom-set-union [209] 39.7% loop [196] 34.8% set [212] 9.0% update-en-expr [210] 5.5% ---------------------------------------------------------------------------------- f176 [193] 9.1% loop [196] 90.9% [201] 53808(3.2%) 0(0.0%) option-on-expr ...velop/src/core/regimes.rkt:103:0 sort-context-on-expr [211] 40.7% loop [196] 31.5% errors [117] 18.6% pick-errors [215] 4.4% err-lsts->split-indices [217] 3.1% sindices->spoints [218] 1.7% ---------------------------------------------------------------------------------- loop [196] 2.6% bf* [152] 35.8% ??? [141] 61.6% [202] 13792(0.8%) 3072(0.2%) ??? ...-racket/utils/simple-result-arrow.rkt:39:12 bfmul [213] 52.0% bfexp [214] 25.7% ---------------------------------------------------------------------------------- for-loop [15] 8.4% for-loop [172] 9.3% f176 [193] 18.9% gather-multiplicative-terms [198] 26.8% make-multiplication-subnode [166] 36.6% [203] 3860(0.2%) 3860(0.2%) compose ...collects/racket/private/list.rkt:385:12 ---------------------------------------------------------------------------------- matcher [118] 11.8% for-loop [43] 12.6% for-loop [83] 37.3% loop [196] 38.3% [204] 2658(0.2%) 648(0.0%) foldl ...et/collects/racket/private/list.rkt:229:4 merge2 [216] 75.6% ---------------------------------------------------------------------------------- f176 [193] 11.3% gather-multiplicative-terms [198] 12.5% for-loop [15] 13.5% for-loop [83] 24.9% loop [196] 37.8% [205] 2638(0.2%) 2638(0.2%) curried ...cket/collects/racket/function.rkt:71:18 ---------------------------------------------------------------------------------- gather-multiplicative-terms [198] 14.2% for-loop [100] 17.2% match-e [74] 17.2% for-loop [83] 51.5% [206] 2098(0.1%) 1380(0.1%) curry* ...racket/collects/racket/function.rkt:44:2 procedure-arity [219] 34.2% ---------------------------------------------------------------------------------- simplify* [197] 100.0% [207] 1750(0.1%) 360(0.0%) ??? ...racket/collects/racket/private/kw.rkt:762:9 ??? [245] 79.4% ---------------------------------------------------------------------------------- make-addition-node* [199] 100.0% [208] 326(0.0%) 326(0.0%) make-addition-node ...op/src/core/reduce.rkt:208:0 ---------------------------------------------------------------------------------- adopt-enode! [107] 8.5% loop! [200] 91.5% [209] 40246(2.4%) 13876(0.8%) custom-set-union ...et/private/set-types.rkt:168:0 for-loop [220] 53.7% for-loop [222] 11.8% ---------------------------------------------------------------------------------- for-loop [103] 0.9% for-loop [100] 1.7% update-leader! [92] 1.8% for-loop [98] 5.8% loop! [200] 23.3% for-loop [139] 66.5% [210] 39540(2.4%) 38214(2.3%) update-en-expr ...evelop/src/core/egraph.rkt:211:0 for-loop [225] 3.4% ---------------------------------------------------------------------------------- option-on-expr [201] 100.0% [211] 21926(1.3%) 0(0.0%) sort-context-on-expr ...velop/src/points.rkt:115:0 ??? [221] 98.5% eval-prog [130] 1.5% ---------------------------------------------------------------------------------- loop! [200] 100.0% [212] 14310(0.9%) 14310(0.9%) set ...collects/racket/private/set-types.rkt:981:0 ---------------------------------------------------------------------------------- ??? [202] 100.0% [213] 7178(0.4%) 5090(0.3%) bfmul ...-lib/math/private/bigfloat/mpfr.rkt:819:4 ??? [248] 29.1% ---------------------------------------------------------------------------------- ??? [202] 100.0% [214] 3542(0.2%) 3198(0.2%) bfexp ...-lib/math/private/bigfloat/mpfr.rkt:616:4 ??? [248] 9.7% ---------------------------------------------------------------------------------- option-on-expr [201] 100.0% [215] 2356(0.1%) 0(0.0%) pick-errors .../develop/src/core/regimes.rkt:184:0 for-loop [223] 85.1% point->alt [227] 14.9% ---------------------------------------------------------------------------------- foldl [204] 100.0% [216] 2010(0.1%) 2010(0.1%) merge2 .../herbie/develop/src/core/ematch.rkt:31:0 ---------------------------------------------------------------------------------- option-on-expr [201] 100.0% [217] 1660(0.1%) 0(0.0%) err-lsts->split-indices .../core/regimes.rkt:222:0 add-splitpoint [224] 100.0% ---------------------------------------------------------------------------------- option-on-expr [201] 100.0% [218] 932(0.1%) 0(0.0%) sindices->spoints ...op/src/core/regimes.rkt:116:0 for-loop [226] 67.8% eval-prog [130] 32.2% ---------------------------------------------------------------------------------- curry* [206] 100.0% [219] 718(0.0%) 718(0.0%) procedure-arity ...ket/private/norm-arity.rkt:7:27 ---------------------------------------------------------------------------------- custom-set-union [209] 100.0% [220] 21626(1.3%) 8092(0.5%) for-loop ...cts/racket/private/set-types.rkt:174:3 for-loop [229] 62.6% ---------------------------------------------------------------------------------- sort-context-on-expr [211] 100.0% [221] 21592(1.3%) 0(0.0%) ??? ...cket/collects/racket/private/sort.rkt:403:3 generic-sort/key [228] 87.4% loop [240] 12.6% ---------------------------------------------------------------------------------- custom-set-union [209] 100.0% [222] 4744(0.3%) 4744(0.3%) for-loop ...cts/racket/private/set-types.rkt:152:2 ---------------------------------------------------------------------------------- pick-errors [215] 100.0% [223] 2004(0.1%) 0(0.0%) for-loop ...bie/develop/src/core/regimes.rkt:186:2 ??? [230] 100.0% ---------------------------------------------------------------------------------- err-lsts->split-indices [217] 100.0% [224] 1660(0.1%) 0(0.0%) add-splitpoint ...velop/src/core/regimes.rkt:235:2 for-loop [231] 100.0% ---------------------------------------------------------------------------------- update-en-expr [210] 100.0% [225] 1326(0.1%) 1326(0.1%) for-loop ...rbie/develop/src/core/egraph.rkt:213:6 ---------------------------------------------------------------------------------- sindices->spoints [218] 100.0% [226] 632(0.0%) 0(0.0%) for-loop ...bie/develop/src/core/regimes.rkt:117:2 f176 [193] 52.8% ??? [232] 47.2% ---------------------------------------------------------------------------------- pick-errors [215] 100.0% [227] 352(0.0%) 0(0.0%) point->alt ...e/develop/src/core/regimes.rkt:171:0 eval-prog [130] 100.0% ---------------------------------------------------------------------------------- ??? [221] 100.0% [228] 18880(1.1%) 0(0.0%) generic-sort/key .../racket/private/sort.rkt:185:2 copying-mergesort [234] 90.7% loop [240] 9.3% ---------------------------------------------------------------------------------- for-loop [220] 100.0% [229] 13534(0.8%) 13534(0.8%) for-loop ...cts/racket/private/set-types.rkt:178:5 ---------------------------------------------------------------------------------- for-loop [223] 100.0% [230] 2004(0.1%) 0(0.0%) ??? ...s/herbie/develop/src/core/regimes.rkt:177:2 ??? [136] 100.0% ---------------------------------------------------------------------------------- add-splitpoint [224] 100.0% [231] 1660(0.1%) 0(0.0%) for-loop ...bie/develop/src/core/regimes.rkt:237:4 for-loop [235] 100.0% ---------------------------------------------------------------------------------- for-loop [226] 100.0% [232] 298(0.0%) 0(0.0%) ??? ...tract/private/arrow-higher-order.rkt:346:33 ??? [233] 100.0% ---------------------------------------------------------------------------------- loop [243] 0.0% ??? [232] 0.0% parse-loop12 [147] 0.0% simplify-alt [55] 0.1% get-sigs [126] 1.6% f176 [193] 2.8% for-loop [73] 2.9% ??? [233] 13.1% ??? [138] 17.1% for-loop [236] 28.7% ??? [78] 33.2% [233] 1482092(89.3%) 70868(4.3%) ??? ...llects/racket/private/norm-define.rkt:53:83 for-loop [236] 28.7% iterate-egraph!13 [3] 26.8% ??? [138] 16.4% ??? [233] 13.1% loop [5] 6.7% ??? [237] 5.3% ??? [238] 0.3% return/no-unsupplied [239] 0.2% mk-egraph [241] 0.2% ??? [254] 0.1% dict? [264] 0.1% ??? [242] 0.0% f176 [193] 0.0% loop [243] 0.0% ---------------------------------------------------------------------------------- generic-sort/key [228] 43.5% copying-mergesort [234] 56.5% [234] 17122(1.0%) 0(0.0%) copying-mergesort ...racket/private/sort.rkt:130:8 copying-mergesort [234] 56.5% loop [240] 33.0% jloop [19] 10.5% ---------------------------------------------------------------------------------- for-loop [231] 100.0% [235] 1660(0.1%) 1660(0.1%) for-loop ...bie/develop/src/core/regimes.rkt:241:8 ---------------------------------------------------------------------------------- ??? [233] 100.0% [236] 902046(54.3%) 0(0.0%) for-loop ...ie/develop/src/core/simplify.rkt:63:12 ??? [233] 100.0% ??? [249] 0.0% ---------------------------------------------------------------------------------- hash-has-key? [81] 31.9% ??? [233] 68.1% [237] 299262(18.0%) 122926(7.4%) ??? ...ects/racket/contract/private/list.rkt:737:4 for-loop [244] 42.2% ??? [250] 15.4% ??? [254] 0.9% ---------------------------------------------------------------------------------- debug7 [180] 1.3% ulp-difference [137] 1.3% f176 [193] 2.6% for-loop [192] 2.6% flag-set? [122] 2.8% ??? [149] 16.5% ??? [233] 33.2% ??? [144] 39.6% [238] 25292(1.5%) 7006(0.4%) ??? ...racket/collects/racket/private/kw.rkt:761:9 ??? [245] 57.5% ??? [260] 14.8% ---------------------------------------------------------------------------------- f176 [193] 1.5% flag-set? [122] 3.4% for-loop [192] 3.5% ulp-difference [137] 4.8% simplify* [197] 6.6% ??? [149] 17.4% ??? [233] 31.0% ??? [144] 31.9% [239] 20792(1.3%) 15680(0.9%) return/no-unsupplied ...ct/private/arr-i.rkt:533:0 filter [246] 24.6% ---------------------------------------------------------------------------------- generic-sort/key [228] 12.2% ??? [221] 18.8% copying-mergesort [234] 68.9% [240] 14388(0.9%) 0(0.0%) loop ...ket/collects/racket/private/sort.rkt:97:12 ??? [136] 100.0% ---------------------------------------------------------------------------------- ??? [233] 100.0% [241] 4678(0.3%) 0(0.0%) mk-egraph ...bie/develop/src/core/egraph.rkt:123:0 expr->enode [247] 100.0% ---------------------------------------------------------------------------------- ??? [233] 100.0% [242] 718(0.0%) 360(0.0%) ??? ...-racket/utils/simple-result-arrow.rkt:60:15 ??? [248] 49.9% ---------------------------------------------------------------------------------- loop [243] 50.0% ??? [233] 50.0% [243] 602(0.0%) 0(0.0%) loop ...lies/herbie/develop/src/programs.rkt:123:4 loop [243] 50.0% ??? [233] 50.0% ---------------------------------------------------------------------------------- ??? [237] 100.0% [244] 126220(7.6%) 60310(3.6%) for-loop ...acket/contract/private/list.rkt:743:12 ??? [250] 30.4% for-loop [142] 19.2% ??? [251] 2.6% ---------------------------------------------------------------------------------- ??? [207] 8.7% ??? [238] 91.3% [245] 15928(1.0%) 14948(0.9%) ??? ...s/racket/contract/private/arr-i.rkt:1233:27 ??? [252] 6.2% ---------------------------------------------------------------------------------- match-e [74] 5.3% for-loop [83] 11.3% return/no-unsupplied [239] 83.3% [246] 6134(0.4%) 6134(0.4%) filter ...t/collects/racket/private/list.rkt:256:2 ---------------------------------------------------------------------------------- mk-egraph [241] 18.5% expr->enode [247] 81.5% [247] 4678(0.3%) 0(0.0%) expr->enode ...e/develop/src/core/egraph.rkt:124:2 expr->enode [247] 81.5% mk-enode! [91] 18.5% ---------------------------------------------------------------------------------- bfexp [214] 9.5% ??? [242] 9.9% real->bigfloat [154] 22.7% bfmul [213] 57.9% [248] 3608(0.2%) 3608(0.2%) ??? .../share/racket/collects/ffi/unsafe.rkt:861:4 ---------------------------------------------------------------------------------- for-loop [236] 34.8% eval-const-expr [42] 65.2% [249] 1030(0.1%) 364(0.0%) ??? ...cket/collects/racket/private/kw.rkt:1633:36 unpack245 [253] 64.7% ---------------------------------------------------------------------------------- ??? [134] 0.8% for-loop [244] 45.0% ??? [237] 54.1% [250] 85194(5.1%) 42266(2.5%) ??? ...private/unconstrained-domain-arrow.rkt:74:4 make-keyword-procedure [255] 50.4% ---------------------------------------------------------------------------------- ??? [143] 18.9% ??? [134] 34.5% for-loop [244] 46.6% [251] 7146(0.4%) 2380(0.1%) ??? ...ects/racket/contract/private/hash.rkt:222:6 check-hash/c [256] 66.7% ---------------------------------------------------------------------------------- ??? [245] 100.0% [252] 980(0.1%) 980(0.1%) ??? ...ects/racket/contract/private/prop.rkt:256:4 ---------------------------------------------------------------------------------- ??? [249] 100.0% [253] 666(0.0%) 0(0.0%) unpack245 ...private/arrow-higher-order.rkt:354:44 ??? [254] 53.8% ??? [261] 46.2% ---------------------------------------------------------------------------------- unpack245 [253] 0.3% ??? [237] 2.4% ??? [233] 2.7% ??? [143] 31.1% for-loop [142] 63.2% [254] 110846(6.7%) 20702(1.2%) ??? ...cts/racket/contract/private/list.rkt:187:10 ??? [257] 61.1% for-loop [258] 12.3% ??? [143] 6.5% ??? [261] 1.2% ??? [260] 0.3% ---------------------------------------------------------------------------------- ??? [250] 100.0% [255] 42928(2.6%) 42928(2.6%) make-keyword-procedure ...ket/private/kw.rkt:260:4 ---------------------------------------------------------------------------------- ??? [251] 100.0% [256] 4766(0.3%) 1694(0.1%) check-hash/c ...ket/contract/private/hash.rkt:83:0 flat-contract? [259] 64.5% ---------------------------------------------------------------------------------- ??? [254] 100.0% [257] 67704(4.1%) 5640(0.3%) ??? ...ects/racket/contract/private/list.rkt:686:7 ??? [260] 85.2% ??? [261] 6.5% ---------------------------------------------------------------------------------- ??? [254] 100.0% [258] 13610(0.8%) 5826(0.4%) for-loop ...acket/contract/private/list.rkt:190:15 ??? [143] 57.2% ---------------------------------------------------------------------------------- check-hash/c [256] 100.0% [259] 3072(0.2%) 3072(0.2%) flat-contract? .../contract/private/guts.rkt:111:0 ---------------------------------------------------------------------------------- ??? [254] 0.4% ??? [72] 1.8% ??? [138] 4.6% ??? [238] 5.0% ??? [143] 11.0% ??? [257] 76.7% [260] 75174(4.5%) 62834(3.8%) ??? ...ects/racket/contract/private/guts.rkt:644:8 contract? [262] 8.7% ??? [72] 5.0% dict? [264] 2.7% ---------------------------------------------------------------------------------- unpack245 [253] 2.8% ??? [254] 11.8% ??? [141] 12.4% for-loop [142] 33.3% ??? [257] 39.7% [261] 11048(0.7%) 6348(0.4%) ??? ...ects/racket/contract/private/prop.rkt:493:4 ??? [263] 42.5% ---------------------------------------------------------------------------------- ??? [260] 100.0% [262] 6566(0.4%) 6566(0.4%) contract? ...acket/contract/private/guts.rkt:109:0 ---------------------------------------------------------------------------------- ??? [261] 100.0% [263] 4700(0.3%) 1634(0.1%) ??? ...lects/racket/contract/private/orc.rkt:83:14 ??? [265] 65.2% ---------------------------------------------------------------------------------- ??? [260] 44.9% ??? [233] 55.1% [264] 4500(0.3%) 4500(0.3%) dict? ...ollects/racket/private/generic.rkt:146:11 ---------------------------------------------------------------------------------- ??? [263] 100.0% [265] 3066(0.2%) 3066(0.2%) ??? ...ects/racket/contract/private/list.rkt:141:5 ----------------------------------------------------------------------------------