Profiling results ----------------- Total cpu time observed: 129256ms (out of 129220ms) Number of samples taken: 360 (once every 359ms) (Hiding functions with self<1.0% and local<2.0%: 5 of 204 hidden) ========================================================================== Caller Idx Total Self Name+src Local% ms(pct) ms(pct) Callee ========================================================================== ??? [30] 100.0% [1] 106504(82.4%) 0(0.0%) profile-thunk16 ...t/pkgs/profile-lib/main.rkt:9:0 run [8] 100.0% -------------------------------------------------------------------------- ??? [30] 100.0% [2] 91266(70.6%) 0(0.0%) run-improve50 ...ie/develop/src/mainloop.rkt:234:0 for-loop [9] 96.7% get-final-combination [11] 3.0% loop [37] 0.3% -------------------------------------------------------------------------- ??? [80] 100.0% [3] 4048(3.1%) 0(0.0%) approximate9 ...e/develop/src/core/taylor.rkt:12:0 loop [10] 75.3% f6 [71] 17.0% taylor [14] 7.7% -------------------------------------------------------------------------- hash-ref! [98] 100.0% [4] 2054(1.6%) 0(0.0%) ??? ...s/herbie/develop/src/core/taylor.rkt:295:23 for-loop [12] 100.0% -------------------------------------------------------------------------- hash-ref! [98] 100.0% [5] 1694(1.3%) 0(0.0%) ??? ...s/herbie/develop/src/core/taylor.rkt:392:23 for-loop [13] 100.0% -------------------------------------------------------------------------- copying-mergesort [194] 100.0% [6] 664(0.5%) 0(0.0%) jloop ...t/collects/racket/private/sort.rkt:121:23 ??? [80] 50.6% ??? [69] 49.4% -------------------------------------------------------------------------- parse-loop12 [141] 1.6% loop [7] 98.4% [7] 332(0.3%) 0(0.0%) loop ...cket/collects/racket/private/map.rkt:36:19 loop [7] 98.4% ??? [80] 1.6% -------------------------------------------------------------------------- profile-thunk16 [1] 100.0% [8] 106504(82.4%) 0(0.0%) run ...share/racket/pkgs/profile-lib/main.rkt:39:2 ??? [30] 100.0% -------------------------------------------------------------------------- run-improve50 [2] 100.0% [9] 88216(68.2%) 0(0.0%) for-loop ...herbie/develop/src/mainloop.rkt:249:10 run-iter! [15] 100.0% -------------------------------------------------------------------------- approximate9 [3] 100.0% [10] 3048(2.4%) 0(0.0%) loop ...es/herbie/develop/src/core/taylor.rkt:86:4 ??? [80] 100.0% -------------------------------------------------------------------------- run-improve50 [2] 100.0% [11] 2742(2.1%) 0(0.0%) get-final-combination ...op/src/mainloop.rkt:264:0 split-table [16] 86.9% extract-alt [18] 13.1% -------------------------------------------------------------------------- ??? [4] 100.0% [12] 2054(1.6%) 0(0.0%) for-loop ...bie/develop/src/core/taylor.rkt:298:27 hash-ref! [98] 83.8% simplify [113] 16.2% -------------------------------------------------------------------------- ??? [5] 100.0% [13] 1694(1.3%) 0(0.0%) for-loop ...bie/develop/src/core/taylor.rkt:396:33 for-loop [17] 100.0% -------------------------------------------------------------------------- approximate9 [3] 46.4% f6 [71] 53.6% [14] 672(0.5%) 0(0.0%) taylor ...herbie/develop/src/core/taylor.rkt:163:0 loop [143] 53.6% debug-print [127] 46.4% -------------------------------------------------------------------------- for-loop [9] 100.0% [15] 88216(68.2%) 0(0.0%) run-iter! ...herbie/develop/src/mainloop.rkt:215:0 simplify! [19] 80.4% finalize-iter! [20] 13.1% gen-series! [21] 4.6% localize-error [22] 1.5% gen-rewrites! [23] 0.4% -------------------------------------------------------------------------- get-final-combination [11] 100.0% [16] 2384(1.8%) 0(0.0%) split-table ...s/herbie/develop/src/glue.rkt:162:0 f6 [71] 100.0% -------------------------------------------------------------------------- for-loop [13] 100.0% [17] 1694(1.3%) 0(0.0%) for-loop ...bie/develop/src/core/taylor.rkt:398:39 hash-ref! [98] 100.0% -------------------------------------------------------------------------- get-final-combination [11] 100.0% [18] 358(0.3%) 0(0.0%) extract-alt ...es/herbie/develop/src/glue.rkt:55:0 argmins [24] 100.0% -------------------------------------------------------------------------- run-iter! [15] 100.0% [19] 70888(54.8%) 0(0.0%) simplify! ...herbie/develop/src/mainloop.rkt:155:0 for-loop [25] 100.0% -------------------------------------------------------------------------- run-iter! [15] 100.0% [20] 11562(8.9%) 0(0.0%) finalize-iter! ...e/develop/src/mainloop.rkt:169:0 ??? [26] 100.0% -------------------------------------------------------------------------- run-iter! [15] 100.0% [21] 4048(3.1%) 0(0.0%) gen-series! ...rbie/develop/src/mainloop.rkt:129:0 for-loop [27] 100.0% -------------------------------------------------------------------------- run-iter! [15] 100.0% [22] 1360(1.1%) 0(0.0%) localize-error ...velop/src/core/localize.rkt:47:0 hash-ref! [98] 100.0% -------------------------------------------------------------------------- run-iter! [15] 100.0% [23] 358(0.3%) 0(0.0%) gen-rewrites! ...ie/develop/src/mainloop.rkt:142:0 for-loop [28] 100.0% -------------------------------------------------------------------------- extract-alt [18] 100.0% [24] 358(0.3%) 0(0.0%) argmins ...ies/herbie/develop/src/common.rkt:150:0 composed [29] 100.0% -------------------------------------------------------------------------- simplify! [19] 100.0% [25] 70888(54.8%) 350(0.3%) for-loop .../herbie/develop/src/mainloop.rkt:159:6 ??? [30] 99.5% -------------------------------------------------------------------------- ??? [178] 1.9% f6 [71] 2.0% substitute-e [86] 2.0% variable? [91] 4.0% match-e [78] 9.3% get-sigs [132] 19.1% finalize-iter! [20] 61.8% [26] 18138(14.0%) 1686(1.3%) ??? ...contract/private/arrow-val-first.rkt:357:18 for-loop [31] 59.8% hash-has-key? [32] 26.9% ??? [178] 2.0% atab-add-altns [35] 2.0% -------------------------------------------------------------------------- gen-series! [21] 100.0% [27] 4048(3.1%) 0(0.0%) for-loop .../herbie/develop/src/mainloop.rkt:135:7 taylor-alt [33] 100.0% -------------------------------------------------------------------------- gen-rewrites! [23] 100.0% [28] 358(0.3%) 0(0.0%) for-loop ...herbie/develop/src/mainloop.rkt:147:11 ??? [34] 100.0% -------------------------------------------------------------------------- argmins [24] 100.0% [29] 358(0.3%) 0(0.0%) composed ...ollects/racket/private/list.rkt:321:16 errors [53] 100.0% -------------------------------------------------------------------------- for-loop [25] 18.3% run [8] 32.3% [30] 128560(99.5%) 0(0.0%) ??? ...lects/racket/private/more-scheme.rkt:261:28 location-do [36] 34.7% profile-thunk16 [1] 32.3% run-improve50 [2] 26.7% loop [37] 6.3% -------------------------------------------------------------------------- ??? [26] 100.0% [31] 11206(8.7%) 0(0.0%) for-loop ...ie/develop/src/core/alt-table.rkt:51:2 atab-add-altn [38] 100.0% -------------------------------------------------------------------------- mk-enode! [97] 6.6% ??? [26] 93.4% [32] 5604(4.3%) 2086(1.6%) hash-has-key? ...et/private/more-scheme.rkt:368:13 ??? [44] 62.8% -------------------------------------------------------------------------- for-loop [27] 100.0% [33] 4048(3.1%) 0(0.0%) taylor-alt ...es/herbie/develop/src/glue.rkt:134:0 for-loop [39] 100.0% -------------------------------------------------------------------------- for-loop [28] 100.0% [34] 358(0.3%) 0(0.0%) ??? ...ies/herbie/develop/src/alternative.rkt:88:0 rewriter [40] 100.0% -------------------------------------------------------------------------- ??? [26] 100.0% [35] 356(0.3%) 0(0.0%) atab-add-altns ...elop/src/core/alt-table.rkt:50:0 atab-add-altn [38] 100.0% -------------------------------------------------------------------------- get-sigs [132] 2.1% for-loop [79] 3.2% ??? [80] 5.4% for-loop [42] 12.7% location-do [36] 33.1% ??? [30] 43.4% [36] 99780(77.2%) 5048(3.9%) location-do ...acket/private/norm-define.rkt:53:83 iterate-egraph!13 [41] 36.1% location-do [36] 33.1% for-loop [42] 12.7% loop [43] 6.9% ??? [44] 3.7% ??? [80] 1.3% ??? [153] 1.2% return/no-unsupplied [154] 1.1% *simplify-rules* [50] 0.4% loop [47] 0.2% mk-egraph [48] 0.2% -------------------------------------------------------------------------- run-improve50 [2] 1.9% ??? [30] 98.1% [37] 16558(12.8%) 0(0.0%) loop ...htlies/herbie/develop/src/points.rkt:205:2 make-exacts* [54] 49.5% loop [46] 27.6% loop [56] 22.9% -------------------------------------------------------------------------- atab-add-altns [35] 3.1% for-loop [31] 96.9% [38] 11562(8.9%) 0(0.0%) atab-add-altn ...elop/src/core/alt-table.rkt:208:0 best-and-tied-at-points [45] 100.0% -------------------------------------------------------------------------- taylor-alt [33] 100.0% [39] 4048(3.1%) 0(0.0%) for-loop ...lies/herbie/develop/src/glue.rkt:139:6 ??? [80] 100.0% -------------------------------------------------------------------------- ??? [34] 100.0% [40] 358(0.3%) 0(0.0%) rewriter ...bie/develop/src/core/matcher.rkt:131:2 for-loop [49] 100.0% -------------------------------------------------------------------------- location-do [36] 100.0% [41] 74152(57.4%) 0(0.0%) iterate-egraph!13 ...p/src/core/simplify.rkt:102:0 one-iter [51] 97.2% map-enodes [57] 2.8% -------------------------------------------------------------------------- location-do [36] 100.0% [42] 26282(20.3%) 0(0.0%) for-loop ...ie/develop/src/core/simplify.rkt:63:12 location-do [36] 100.0% -------------------------------------------------------------------------- location-do [36] 100.0% [43] 17048(13.2%) 0(0.0%) loop ...herbie/develop/src/core/simplify.rkt:215:2 pass [52] 100.0% -------------------------------------------------------------------------- hash-has-key? [32] 23.9% location-do [36] 76.1% [44] 14716(11.4%) 6622(5.1%) ??? ...ects/racket/contract/private/list.rkt:737:4 for-loop [55] 37.2% ??? [67] 13.1% arrow-higher-order:lnp [60] 2.4% ??? [151] 2.3% -------------------------------------------------------------------------- atab-add-altn [38] 100.0% [45] 11562(8.9%) 0(0.0%) best-and-tied-at-points ...ore/alt-table.rkt:122:0 errors [53] 100.0% -------------------------------------------------------------------------- loop [37] 100.0% [46] 4574(3.5%) 0(0.0%) loop ...htlies/herbie/develop/src/points.rkt:158:2 make-exacts* [54] 69.3% loop [56] 30.7% -------------------------------------------------------------------------- loop [47] 50.0% location-do [36] 50.0% [47] 666(0.5%) 0(0.0%) loop ...lies/herbie/develop/src/programs.rkt:123:4 loop [47] 50.0% ??? [80] 50.0% -------------------------------------------------------------------------- location-do [36] 100.0% [48] 366(0.3%) 0(0.0%) mk-egraph ...bie/develop/src/core/egraph.rkt:123:0 expr->enode [58] 100.0% -------------------------------------------------------------------------- rewriter [40] 100.0% [49] 358(0.3%) 0(0.0%) for-loop ...ie/develop/src/core/matcher.rkt:134:10 matcher [59] 100.0% -------------------------------------------------------------------------- location-do [36] 100.0% [50] 350(0.3%) 0(0.0%) *simplify-rules* ...lop/src/syntax/rules.rkt:518:0 for-loop [61] 100.0% -------------------------------------------------------------------------- iterate-egraph!13 [41] 100.0% [51] 72112(55.8%) 2074(1.6%) one-iter ...ie/develop/src/core/simplify.rkt:113:0 loop [62] 71.4% for-loop [64] 23.3% apply-match [68] 2.4% -------------------------------------------------------------------------- loop [43] 100.0% [52] 17048(13.2%) 0(0.0%) pass ...herbie/develop/src/core/simplify.rkt:205:2 for-loop [63] 100.0% -------------------------------------------------------------------------- composed [29] 2.8% option-on-expr [155] 5.4% best-and-tied-at-points [45] 91.7% [53] 12606(9.8%) 0(0.0%) errors ...lies/herbie/develop/src/points.rkt:241:0 for-loop [65] 86.1% eval-prog [66] 13.9% -------------------------------------------------------------------------- loop [46] 27.9% loop [37] 72.1% [54] 11366(8.8%) 0(0.0%) make-exacts* ...erbie/develop/src/points.rkt:138:0 loop [143] 79.5% eval-prog [66] 20.5% -------------------------------------------------------------------------- ??? [44] 100.0% [55] 5474(4.2%) 2428(1.9%) for-loop ...acket/contract/private/list.rkt:743:12 ??? [67] 30.5% for-loop [145] 19.1% ??? [160] 6.0% -------------------------------------------------------------------------- loop [46] 27.0% loop [37] 73.0% [56] 5192(4.0%) 0(0.0%) loop ...htlies/herbie/develop/src/points.rkt:141:4 loop [143] 100.0% -------------------------------------------------------------------------- iterate-egraph!13 [41] 100.0% [57] 2040(1.6%) 0(0.0%) map-enodes ...ie/develop/src/core/egraph.rkt:139:0 loop [143] 100.0% -------------------------------------------------------------------------- expr->enode [58] 50.0% mk-egraph [48] 50.0% [58] 366(0.3%) 0(0.0%) expr->enode ...e/develop/src/core/egraph.rkt:124:2 expr->enode [58] 50.0% mk-enode! [97] 50.0% -------------------------------------------------------------------------- for-loop [49] 100.0% [59] 358(0.3%) 358(0.3%) matcher ...rbie/develop/src/core/matcher.rkt:167:2 -------------------------------------------------------------------------- ??? [44] 100.0% [60] 356(0.3%) 356(0.3%) arrow-higher-order:lnp ...w-higher-order.rkt:597:7 -------------------------------------------------------------------------- *simplify-rules* [50] 100.0% [61] 350(0.3%) 350(0.3%) for-loop ...ies/herbie/develop/src/common.rkt:99:9 -------------------------------------------------------------------------- one-iter [51] 100.0% [62] 51520(39.9%) 0(0.0%) loop ...cket/collects/racket/private/map.rkt:52:19 apply-match [68] 100.0% -------------------------------------------------------------------------- pass [52] 100.0% [63] 17048(13.2%) 0(0.0%) for-loop ...e/develop/src/core/simplify.rkt:208:29 argmin [70] 62.7% loop [72] 31.0% for-loop [74] 4.2% make-sequence [75] 2.1% -------------------------------------------------------------------------- for-loop [64] 49.0% one-iter [51] 51.0% [64] 16786(13.0%) 2042(1.6%) for-loop ...e/develop/src/core/simplify.rkt:123:12 for-loop [64] 49.0% match-e [78] 43.9% -------------------------------------------------------------------------- errors [53] 100.0% [65] 10856(8.4%) 1028(0.8%) for-loop ...es/herbie/develop/src/points.rkt:244:4 ??? [69] 80.5% ??? [80] 10.0% -------------------------------------------------------------------------- errors [53] 42.9% make-exacts* [54] 57.1% [66] 4080(3.2%) 1038(0.8%) eval-prog ...herbie/develop/src/programs.rkt:148:0 f6 [71] 42.9% hash-ref! [98] 31.7% -------------------------------------------------------------------------- for-loop [55] 46.4% ??? [44] 53.6% [67] 3602(2.8%) 1660(1.3%) ??? ...private/unconstrained-domain-arrow.rkt:74:4 make-keyword-procedure [73] 53.9% -------------------------------------------------------------------------- one-iter [51] 3.3% loop [62] 96.7% [68] 53252(41.2%) 328(0.3%) apply-match ...develop/src/core/simplify.rkt:130:2 for-loop [76] 91.0% match-e [78] 7.1% update-leader! [99] 0.7% reduce-to-single! [83] 0.6% -------------------------------------------------------------------------- jloop [6] 1.5% loop [198] 3.0% for-loop [65] 38.9% loop [143] 56.7% [69] 22500(17.4%) 1148(0.9%) ??? ...tlies/herbie/develop/src/programs.rkt:154:4 ??? [77] 88.8% ??? [80] 4.6% ??? [92] 1.5% -------------------------------------------------------------------------- for-loop [63] 100.0% [70] 10692(8.3%) 0(0.0%) argmin ...re/racket/collects/racket/list.rkt:743:0 for-loop [79] 87.2% expression-cost [81] 12.8% -------------------------------------------------------------------------- simplify [113] 1.5% for-loop [95] 2.5% mterm->expr [182] 2.5% map [165] 3.1% loop [131] 4.2% parse-loop12 [141] 4.7% eval-const-expr [174] 5.0% approximate9 [3] 5.8% eval-prog [66] 8.1% hash-ref! [98] 9.7% f6 [71] 19.9% split-table [16] 33.1% [71] 7202(5.6%) 332(0.3%) f6 ...et/collects/racket/match/compiler.rkt:507:40 loop [143] 23.4% f6 [71] 19.9% map [165] 17.4% ??? [80] 13.1% option-on-expr [155] 9.7% loop [84] 4.6% ??? [139] 4.2% expression->type [82] 2.5% ??? [26] 2.5% taylor [14] 1.2% -------------------------------------------------------------------------- for-loop [63] 100.0% [72] 5282(4.1%) 0(0.0%) loop ...hare/racket/collects/racket/list.rkt:729:4 for-loop [79] 93.2% expression-cost [81] 6.8% -------------------------------------------------------------------------- ??? [67] 100.0% [73] 1942(1.5%) 1942(1.5%) make-keyword-procedure ...ket/private/kw.rkt:260:4 -------------------------------------------------------------------------- for-loop [63] 100.0% [74] 714(0.6%) 714(0.6%) for-loop ...e/develop/src/core/simplify.rkt:195:13 -------------------------------------------------------------------------- for-loop [63] 100.0% [75] 360(0.3%) 360(0.3%) make-sequence ...ects/racket/private/for.rkt:509:2 -------------------------------------------------------------------------- apply-match [68] 100.0% [76] 48472(37.5%) 0(0.0%) for-loop ...e/develop/src/core/simplify.rkt:145:10 mk-enode! [97] 34.9% merge-egraph-nodes! [85] 27.4% substitute-e [86] 21.0% loop! [111] 15.2% list-member? [90] 1.5% -------------------------------------------------------------------------- ??? [69] 100.0% [77] 19974(15.5%) 5998(4.6%) ??? ...acket/collects/racket/private/kw.rkt:444:14 ??? [177] 50.9% ??? [88] 15.6% ...higher-order.rkt:346:33 [93] 1.8% -------------------------------------------------------------------------- apply-match [68] 14.4% for-loop [100] 16.1% for-loop [64] 69.5% [78] 18500(14.3%) 8194(6.3%) match-e ...herbie/develop/src/core/ematch.rkt:46:0 for-loop [87] 39.0% for-loop [100] 7.6% ??? [26] 6.1% list-cartesian-product [103] 2.7% curry* [94] 1.9% variable? [91] 1.6% filter [168] 1.0% -------------------------------------------------------------------------- loop [72] 34.6% argmin [70] 65.4% [79] 14244(11.0%) 632(0.5%) for-loop .../herbie/develop/src/programs.rkt:199:2 location-do [36] 67.2% ...velop/src/common.rkt:47:2 [138] 28.3% -------------------------------------------------------------------------- loop [47] 2.2% map [165] 3.3% loop [7] 3.3% jloop [6] 3.4% loop [143] 6.9% loop [10] 10.2% ??? [69] 10.5% for-loop [65] 10.9% location-do [36] 13.0% for-loop [39] 15.2% f6 [71] 21.1% [80] 9970(7.7%) 688(0.5%) ??? ...tract/private/arrow-higher-order.rkt:342:33 location-do [36] 53.5% approximate9 [3] 15.2% hash-ref! [98] 10.2% ??? [178] 7.0% ...velop/src/common.rkt:47:2 [138] 3.6% ??? [92] 3.6% -------------------------------------------------------------------------- loop [72] 20.8% argmin [70] 79.2% [81] 1730(1.3%) 0(0.0%) expression-cost .../develop/src/programs.rkt:198:0 compile [89] 100.0% -------------------------------------------------------------------------- for-loop [95] 50.0% f6 [71] 50.0% [82] 358(0.3%) 0(0.0%) expression->type ...evelop/src/type-check.rkt:45:0 for-loop [95] 100.0% -------------------------------------------------------------------------- apply-match [68] 100.0% [83] 336(0.3%) 0(0.0%) reduce-to-single! ...lop/src/core/egraph.rkt:324:0 for-loop [96] 100.0% -------------------------------------------------------------------------- f6 [71] 100.0% [84] 328(0.3%) 0(0.0%) loop ...s/herbie/develop/src/core/taylor.rkt:262:2 hash-ref! [98] 100.0% -------------------------------------------------------------------------- for-loop [102] 5.6% merge-egraph-nodes! [85] 6.6% for-loop [76] 87.8% [85] 13286(10.3%) 330(0.3%) merge-egraph-nodes! ...p/src/core/egraph.rkt:152:0 update-leader! [99] 51.5% for-loop [101] 13.1% loop! [111] 9.1% enode-merge! [104] 8.9% for-loop [102] 8.3% merge-egraph-nodes! [85] 6.6% -------------------------------------------------------------------------- substitute-e [86] 3.5% for-loop [76] 96.5% [86] 10172(7.9%) 1052(0.8%) substitute-e ...e/develop/src/core/ematch.rkt:71:0 mk-enode! [97] 86.1% substitute-e [86] 3.5% ??? [26] 1.8% -------------------------------------------------------------------------- match-e [78] 100.0% [87] 8176(6.3%) 3412(2.6%) for-loop ...rbie/develop/src/core/ematch.rkt:59:11 for-loop [100] 39.8% list-cartesian-product [103] 10.3% foldl [159] 4.3% loop [143] 3.8% -------------------------------------------------------------------------- ??? [77] 100.0% [88] 3116(2.4%) 1704(1.3%) ??? ...herbie/develop/src/syntax/syntax.rkt:153:17 ??? [153] 23.0% return/no-unsupplied [154] 22.3% -------------------------------------------------------------------------- expression-cost [81] 100.0% [89] 1730(1.3%) 0(0.0%) compile ...s/herbie/develop/src/programs.rkt:175:0 hash-ref! [98] 100.0% -------------------------------------------------------------------------- for-loop [76] 100.0% [90] 726(0.6%) 0(0.0%) list-member? ...llects/racket/private/set.rkt:24:0 member [105] 50.4% loop [106] 49.6% -------------------------------------------------------------------------- match-e [78] 100.0% [91] 718(0.6%) 0(0.0%) variable? ...e/develop/src/syntax/syntax.rkt:660:0 ??? [26] 100.0% -------------------------------------------------------------------------- ??? [69] 48.4% ??? [80] 51.6% [92] 694(0.5%) 0(0.0%) ??? ...contract/private/../../private/kw.rkt:761:9 loop [108] 51.6% real->bigfloat [109] 48.4% -------------------------------------------------------------------------- ??? [77] 100.0% [93] 360(0.3%) 0(0.0%) ...higher-order.rkt:346:33 (unknown source) ??? [151] 100.0% -------------------------------------------------------------------------- match-e [78] 100.0% [94] 358(0.3%) 0(0.0%) curry* ...racket/collects/racket/function.rkt:44:2 procedure-arity [107] 100.0% -------------------------------------------------------------------------- expression->type [82] 100.0% [95] 358(0.3%) 0(0.0%) for-loop ...herbie/develop/src/type-check.rkt:52:5 expression->type [82] 50.0% f6 [71] 50.0% -------------------------------------------------------------------------- reduce-to-single! [83] 100.0% [96] 336(0.3%) 336(0.3%) for-loop ...rbie/develop/src/core/egraph.rkt:325:8 -------------------------------------------------------------------------- expr->enode [58] 1.4% substitute-e [86] 33.6% for-loop [76] 65.0% [97] 26050(20.2%) 1744(1.3%) mk-enode! ...bie/develop/src/core/egraph.rkt:101:0 new-enode [110] 90.5% hash-has-key? [32] 1.4% -------------------------------------------------------------------------- loop [84] 4.0% simplify* [129] 4.4% eval-prog [66] 5.3% for-loop [17] 5.6% for-loop [12] 5.7% localize-error [22] 6.0% ??? [115] 9.8% loop [143] 10.6% ??? [158] 10.7% ??? [114] 11.3% compile [89] 11.5% ??? [80] 15.0% [98] 8118(6.3%) 1730(1.3%) hash-ref! ...racket/private/more-scheme.rkt:373:13 ??? [115] 24.9% simplify [113] 17.7% parse-loop12 [141] 13.6% ??? [114] 11.3% ??? [4] 7.0% ??? [5] 5.6% bigfloat-hash [116] 5.3% f6 [71] 3.2% -------------------------------------------------------------------------- apply-match [68] 4.7% merge-egraph-nodes! [85] 95.3% [99] 7720(6.0%) 1088(0.8%) update-leader! ...evelop/src/core/egraph.rkt:217:0 for-loop [112] 81.3% custom-set-union! [119] 4.6% -------------------------------------------------------------------------- match-e [78] 39.5% for-loop [87] 60.5% [100] 6240(4.8%) 718(0.6%) for-loop ...rbie/develop/src/core/ematch.rkt:65:37 match-e [78] 88.5% -------------------------------------------------------------------------- merge-egraph-nodes! [85] 100.0% [101] 1746(1.4%) 1746(1.4%) for-loop ...rbie/develop/src/core/egraph.rkt:232:6 -------------------------------------------------------------------------- merge-egraph-nodes! [85] 100.0% [102] 1740(1.3%) 0(0.0%) for-loop ...bie/develop/src/core/egraph.rkt:200:10 merge-egraph-nodes! [85] 79.2% loop! [111] 20.8% -------------------------------------------------------------------------- list-cartesian-product [103] 23.1% for-loop [87] 37.1% match-e [78] 39.7% [103] 1686(1.3%) 1338(1.0%) list-cartesian-product ...src/core/ematch.rkt:20:0 list-cartesian-product [103] 23.1% for-loop [121] 10.3% -------------------------------------------------------------------------- merge-egraph-nodes! [85] 100.0% [104] 1418(1.1%) 0(0.0%) enode-merge! ...e/develop/src/core/enode.rkt:129:0 adopt-enode! [117] 74.8% custom-set-intersect! [120] 25.2% -------------------------------------------------------------------------- list-member? [90] 100.0% [105] 366(0.3%) 366(0.3%) member (unknown source) -------------------------------------------------------------------------- list-member? [90] 100.0% [106] 360(0.3%) 360(0.3%) loop (unknown source) -------------------------------------------------------------------------- curry* [94] 100.0% [107] 358(0.3%) 358(0.3%) procedure-arity ...ket/private/norm-arity.rkt:7:27 -------------------------------------------------------------------------- ??? [92] 100.0% [108] 358(0.3%) 0(0.0%) loop ...h-lib/math/private/bigfloat/mpfr.rkt:435:9 integer->mpz [118] 100.0% -------------------------------------------------------------------------- ??? [92] 100.0% [109] 336(0.3%) 336(0.3%) real->bigfloat .../private/bigfloat/mpfr.rkt:451:0 -------------------------------------------------------------------------- mk-enode! [97] 100.0% [110] 23574(18.2%) 366(0.3%) new-enode ...erbie/develop/src/core/enode.rkt:97:0 type-of-enode-expr [122] 98.4% -------------------------------------------------------------------------- for-loop [102] 1.8% merge-egraph-nodes! [85] 17.7% loop [143] 24.9% for-loop [76] 55.5% [111] 9796(7.6%) 1390(1.1%) loop! ...s/herbie/develop/src/core/enode.rkt:192:2 custom-set-union [124] 39.2% loop [143] 33.9% set [125] 10.9% update-en-expr [156] 7.1% -------------------------------------------------------------------------- update-leader! [99] 100.0% [112] 6274(4.9%) 354(0.3%) for-loop ...rbie/develop/src/core/egraph.rkt:222:6 for-loop [123] 94.4% -------------------------------------------------------------------------- for-loop [12] 8.9% loop [143] 9.6% hash-ref! [98] 81.5% [113] 3736(2.9%) 0(0.0%) simplify ...erbie/develop/src/core/reduce.rkt:16:0 parse-loop12 [141] 45.4% debug7 [128] 9.6% simplify* [129] 9.6% simplify-node [130] 9.6% f6 [71] 8.9% debug-print [127] 8.8% loop [131] 8.0% -------------------------------------------------------------------------- hash-ref! [98] 100.0% [114] 2748(2.1%) 0(0.0%) ??? ...es/herbie/develop/src/core/taylor.rkt:44:15 hash-ref! [98] 100.0% -------------------------------------------------------------------------- hash-ref! [98] 100.0% [115] 2674(2.1%) 360(0.3%) ??? ...tlies/herbie/develop/src/programs.rkt:183:5 loop [143] 48.3% hash-ref! [98] 38.2% -------------------------------------------------------------------------- hash-ref! [98] 100.0% [116] 1292(1.0%) 0(0.0%) bigfloat-hash ...h/private/bigfloat/mpfr.rkt:165:0 bfcanonicalize [126] 100.0% -------------------------------------------------------------------------- enode-merge! [104] 100.0% [117] 1060(0.8%) 344(0.3%) adopt-enode! ...e/develop/src/core/enode.rkt:105:0 custom-set-union [124] 67.5% -------------------------------------------------------------------------- loop [108] 100.0% [118] 358(0.3%) 358(0.3%) integer->mpz ...math/private/bigfloat/gmp.rkt:87:0 -------------------------------------------------------------------------- update-leader! [99] 100.0% [119] 358(0.3%) 358(0.3%) custom-set-union! ...t/private/set-types.rkt:245:0 -------------------------------------------------------------------------- enode-merge! [104] 100.0% [120] 358(0.3%) 358(0.3%) custom-set-intersect! ...ivate/set-types.rkt:269:0 -------------------------------------------------------------------------- list-cartesian-product [103] 100.0% [121] 348(0.3%) 348(0.3%) for-loop ...erbie/develop/src/core/ematch.rkt:24:8 -------------------------------------------------------------------------- new-enode [110] 100.0% [122] 23208(18.0%) 336(0.3%) type-of-enode-expr ...elop/src/core/enode.rkt:68:0 get-sigs [132] 98.6% -------------------------------------------------------------------------- for-loop [112] 100.0% [123] 5920(4.6%) 702(0.5%) for-loop ...rbie/develop/src/core/egraph.rkt:223:8 hash-update! [133] 88.1% -------------------------------------------------------------------------- adopt-enode! [117] 15.7% loop! [111] 84.3% [124] 4556(3.5%) 1770(1.4%) custom-set-union ...et/private/set-types.rkt:168:0 for-loop [134] 53.3% for-loop [135] 7.9% -------------------------------------------------------------------------- loop! [111] 100.0% [125] 2132(1.6%) 2132(1.6%) set ...collects/racket/private/set-types.rkt:981:0 -------------------------------------------------------------------------- bigfloat-hash [116] 100.0% [126] 1292(1.0%) 1292(1.0%) bfcanonicalize .../private/bigfloat/mpfr.rkt:155:0 -------------------------------------------------------------------------- taylor [14] 48.8% simplify [113] 51.2% [127] 640(0.5%) 328(0.3%) debug-print .../herbie/develop/src/debug.rkt:107:0 for-loop [137] 48.8% -------------------------------------------------------------------------- simplify [113] 100.0% [128] 360(0.3%) 0(0.0%) debug7 ...tlies/herbie/develop/src/debug.rkt:102:0 return/no-unsupplied [154] 100.0% -------------------------------------------------------------------------- simplify [113] 100.0% [129] 360(0.3%) 0(0.0%) simplify* ...rbie/develop/src/core/reduce.rkt:31:0 hash-ref! [98] 100.0% -------------------------------------------------------------------------- simplify [113] 100.0% [130] 358(0.3%) 0(0.0%) simplify-node .../develop/src/core/reduce.rkt:50:0 append-map [136] 100.0% -------------------------------------------------------------------------- simplify [113] 100.0% [131] 300(0.2%) 0(0.0%) loop ...es/herbie/develop/src/core/reduce.rkt:18:2 f6 [71] 100.0% -------------------------------------------------------------------------- type-of-enode-expr [122] 100.0% [132] 22872(17.7%) 348(0.3%) get-sigs .../herbie/develop/src/type-check.rkt:5:0 ??? [139] 36.0% location-do [36] 27.4% ...velop/src/common.rkt:47:2 [138] 19.9% ??? [26] 15.1% -------------------------------------------------------------------------- for-loop [123] 100.0% [133] 5218(4.0%) 334(0.3%) hash-update! ...ket/private/more-scheme.rkt:362:13 ??? [140] 93.6% -------------------------------------------------------------------------- custom-set-union [124] 100.0% [134] 2428(1.9%) 1378(1.1%) for-loop ...cts/racket/private/set-types.rkt:174:3 for-loop [142] 43.2% -------------------------------------------------------------------------- custom-set-union [124] 100.0% [135] 358(0.3%) 358(0.3%) for-loop ...cts/racket/private/set-types.rkt:152:2 -------------------------------------------------------------------------- simplify-node [130] 100.0% [136] 358(0.3%) 0(0.0%) append-map ...acket/collects/racket/list.rkt:565:2 parse-loop12 [141] 100.0% -------------------------------------------------------------------------- debug-print [127] 100.0% [137] 312(0.2%) 312(0.2%) for-loop ...ies/herbie/develop/src/debug.rkt:113:2 -------------------------------------------------------------------------- ??? [80] 4.0% for-loop [79] 45.1% get-sigs [132] 50.9% [138] 8944(6.9%) 2794(2.2%) ...velop/src/common.rkt:47:2 ...e/arr-i.rkt:906:19 ??? [147] 37.0% ??? [148] 31.8% -------------------------------------------------------------------------- f6 [71] 3.5% get-sigs [132] 96.5% [139] 8544(6.6%) 682(0.5%) ??? ...ts/racket/contract/private/arr-i.rkt:804:10 for-loop [145] 44.1% ??? [146] 43.7% get/build-late-neg-projection [186] 4.2% -------------------------------------------------------------------------- hash-update! [133] 100.0% [140] 4884(3.8%) 0(0.0%) ??? ...s/herbie/develop/src/core/egraph.rkt:225:24 for-loop [144] 100.0% -------------------------------------------------------------------------- loop [143] 3.3% map [165] 3.3% append-map [136] 10.5% parse-loop12 [141] 19.1% simplify [113] 24.0% hash-ref! [98] 39.8% [141] 3416(2.6%) 1364(1.1%) parse-loop12 ...s/racket/match/compiler.rkt:418:15 loop [143] 37.2% parse-loop12 [141] 19.1% make-multiplication-node [149] 10.5% parse-app [150] 9.8% map [165] 3.9% f6 [71] 3.3% loop [7] 1.9% -------------------------------------------------------------------------- for-loop [134] 100.0% [142] 1050(0.8%) 1050(0.8%) for-loop ...cts/racket/private/set-types.rkt:178:5 -------------------------------------------------------------------------- map [165] 0.0% for-loop [87] 0.0% loop [56] 0.1% make-exacts* [54] 1.1% taylor [14] 1.3% map-enodes [57] 2.4% parse-loop12 [141] 3.9% ??? [115] 4.7% loop! [111] 5.1% f6 [71] 6.2% loop [143] 75.0% [143] 27206(21.0%) 1486(1.1%) loop ...cket/collects/racket/private/map.rkt:25:19 loop [143] 75.0% option-on-expr [155] 6.2% hash-ref! [98] 4.7% loop! [111] 4.4% ??? [158] 2.7% for-loop [157] 2.4% simplify [113] 1.3% parse-loop12 [141] 1.2% ??? [69] 1.2% ??? [80] 0.0% foldl [159] 0.0% ??? [161] 0.0% -------------------------------------------------------------------------- ??? [140] 100.0% [144] 4884(3.8%) 4188(3.2%) for-loop ...bie/develop/src/core/egraph.rkt:226:26 update-en-expr [156] 14.3% -------------------------------------------------------------------------- for-loop [55] 21.7% ??? [139] 78.3% [145] 4812(3.7%) 1046(0.8%) for-loop ...racket/contract/private/hash.rkt:239:6 ??? [151] 78.3% -------------------------------------------------------------------------- ??? [139] 100.0% [146] 3736(2.9%) 356(0.3%) ??? ...ects/racket/contract/private/hash.rkt:217:4 ??? [152] 90.5% -------------------------------------------------------------------------- ...velop/src/common.rkt:47:2 [138] 100.0% [147] 3308(2.6%) 1400(1.1%) ??? ...s/racket/contract/private/arr-i.rkt:1268:39 ??? [153] 38.3% return/no-unsupplied [154] 19.4% -------------------------------------------------------------------------- ??? [151] 19.0% ...velop/src/common.rkt:47:2 [138] 81.0% [148] 2842(2.2%) 0(0.0%) ??? ...ects/racket/contract/private/list.rkt:342:4 ??? [151] 68.2% ??? [178] 19.0% ??? [160] 12.8% -------------------------------------------------------------------------- parse-loop12 [141] 100.0% [149] 358(0.3%) 0(0.0%) make-multiplication-node .../core/reduce.rkt:230:0 make-multiplication-subnode [162] 100.0% -------------------------------------------------------------------------- parse-loop12 [141] 100.0% [150] 334(0.3%) 334(0.3%) parse-app .../collects/racket/private/kw.rkt:951:2 -------------------------------------------------------------------------- ??? [44] 4.8% ...higher-order.rkt:346:33 [93] 5.2% ??? [148] 35.7% for-loop [145] 54.3% [151] 6936(5.4%) 1046(0.8%) ??? ...cts/racket/contract/private/list.rkt:187:10 ??? [163] 54.3% ??? [148] 15.6% for-loop [169] 10.3% ??? [172] 4.8% -------------------------------------------------------------------------- ??? [146] 100.0% [152] 3380(2.6%) 0(0.0%) ??? ...ects/racket/contract/private/list.rkt:169:2 ??? [164] 100.0% -------------------------------------------------------------------------- ??? [88] 21.3% ??? [147] 37.5% location-do [36] 41.2% [153] 3376(2.6%) 692(0.5%) ??? ...racket/collects/racket/private/kw.rkt:761:9 ??? [166] 58.0% ??? [178] 21.5% -------------------------------------------------------------------------- debug7 [128] 11.7% ??? [147] 20.9% ??? [88] 22.6% location-do [36] 44.7% [154] 3068(2.4%) 2708(2.1%) return/no-unsupplied ...ct/private/arr-i.rkt:533:0 filter [168] 11.7% -------------------------------------------------------------------------- f6 [71] 29.3% loop [143] 70.7% [155] 2384(1.8%) 0(0.0%) option-on-expr ...velop/src/core/regimes.rkt:103:0 sort-context-on-expr [167] 56.5% errors [53] 28.8% err-lsts->split-indices [176] 14.8% -------------------------------------------------------------------------- for-loop [144] 33.5% loop! [111] 66.5% [156] 2080(1.6%) 2080(1.6%) update-en-expr ...evelop/src/core/egraph.rkt:211:0 -------------------------------------------------------------------------- loop [143] 100.0% [157] 2040(1.6%) 992(0.8%) for-loop ...ie/develop/src/core/simplify.rkt:173:2 setfindf [171] 33.8% eval-const-expr [174] 17.5% -------------------------------------------------------------------------- map [165] 12.2% loop [143] 87.8% [158] 1360(1.1%) 0(0.0%) ??? ...ket/collects/racket/private/list.rkt:323:18 hash-ref! [98] 87.8% map [165] 12.2% -------------------------------------------------------------------------- loop [143] 31.0% for-loop [87] 69.0% [159] 1012(0.8%) 332(0.3%) foldl ...et/collects/racket/private/list.rkt:229:4 merge2 [173] 67.2% -------------------------------------------------------------------------- for-loop [55] 47.6% ??? [148] 52.4% [160] 694(0.5%) 0(0.0%) ??? ...ects/racket/contract/private/hash.rkt:222:6 check-hash/c [170] 100.0% -------------------------------------------------------------------------- loop [143] 100.0% [161] 358(0.3%) 0(0.0%) ??? ...tract/private/arrow-higher-order.rkt:145:21 ??? [172] 100.0% -------------------------------------------------------------------------- make-multiplication-node [149] 100.0% [162] 358(0.3%) 0(0.0%) make-multiplication-subnode ...re/reduce.rkt:240:0 for-loop [175] 100.0% -------------------------------------------------------------------------- ??? [151] 100.0% [163] 3766(2.9%) 0(0.0%) ??? ...ects/racket/contract/private/list.rkt:686:7 ??? [178] 100.0% -------------------------------------------------------------------------- ??? [152] 100.0% [164] 3380(2.6%) 0(0.0%) ??? ...ects/racket/contract/private/list.rkt:678:5 for-loop [179] 100.0% -------------------------------------------------------------------------- ??? [158] 16.4% parse-loop12 [141] 16.4% f6 [71] 67.3% [165] 2028(1.6%) 0(0.0%) map ...acket/collects/racket/private/map.rkt:20:13 loop [143] 17.9% parse-loop12 [141] 16.6% ??? [177] 16.5% f6 [71] 16.4% ??? [158] 16.4% ??? [80] 16.4% -------------------------------------------------------------------------- ??? [153] 100.0% [166] 1958(1.5%) 1958(1.5%) ??? ...s/racket/contract/private/arr-i.rkt:1233:27 -------------------------------------------------------------------------- option-on-expr [155] 100.0% [167] 1346(1.0%) 0(0.0%) sort-context-on-expr ...velop/src/points.rkt:115:0 ??? [180] 100.0% -------------------------------------------------------------------------- match-e [78] 50.0% return/no-unsupplied [154] 50.0% [168] 720(0.6%) 720(0.6%) filter ...t/collects/racket/private/list.rkt:256:2 -------------------------------------------------------------------------- ??? [151] 100.0% [169] 712(0.6%) 712(0.6%) for-loop ...acket/contract/private/list.rkt:190:15 -------------------------------------------------------------------------- ??? [160] 100.0% [170] 694(0.5%) 0(0.0%) check-hash/c ...ket/contract/private/hash.rkt:83:0 flat-contract? [181] 100.0% -------------------------------------------------------------------------- for-loop [157] 100.0% [171] 690(0.5%) 690(0.5%) setfindf ...es/herbie/develop/src/common.rkt:184:0 -------------------------------------------------------------------------- ??? [151] 48.1% ??? [161] 51.9% [172] 690(0.5%) 358(0.3%) ??? ...ects/racket/contract/private/prop.rkt:493:4 ??? [184] 48.1% -------------------------------------------------------------------------- foldl [159] 100.0% [173] 680(0.5%) 680(0.5%) merge2 .../herbie/develop/src/core/ematch.rkt:31:0 -------------------------------------------------------------------------- for-loop [157] 100.0% [174] 358(0.3%) 0(0.0%) eval-const-expr .../develop/src/programs.rkt:166:0 f6 [71] 100.0% -------------------------------------------------------------------------- make-multiplication-subnode [162] 100.0% [175] 358(0.3%) 0(0.0%) for-loop ...rbie/develop/src/core/reduce.rkt:242:3 mterm->expr [182] 100.0% -------------------------------------------------------------------------- option-on-expr [155] 100.0% [176] 352(0.3%) 0(0.0%) err-lsts->split-indices .../core/regimes.rkt:222:0 add-splitpoint [183] 100.0% -------------------------------------------------------------------------- map [165] 3.2% ??? [77] 96.8% [177] 10506(8.1%) 5640(4.4%) ??? ...-racket/utils/simple-result-arrow.rkt:39:12 bfdiv [185] 38.8% bfexp [189] 7.5% -------------------------------------------------------------------------- ??? [26] 5.4% ??? [80] 10.6% ??? [153] 10.9% ??? [148] 16.3% ??? [163] 56.8% [178] 6634(5.1%) 5216(4.0%) ??? ...ects/racket/contract/private/guts.rkt:644:8 contract? [190] 10.8% ??? [26] 10.6% -------------------------------------------------------------------------- ??? [164] 100.0% [179] 3380(2.6%) 1024(0.8%) for-loop ...racket/contract/private/list.rkt:680:9 add-list-context [188] 39.3% get/build-late-neg-projection [186] 30.4% -------------------------------------------------------------------------- sort-context-on-expr [167] 100.0% [180] 1346(1.0%) 0(0.0%) ??? ...cket/collects/racket/private/sort.rkt:403:3 generic-sort/key [187] 100.0% -------------------------------------------------------------------------- check-hash/c [170] 100.0% [181] 694(0.5%) 694(0.5%) flat-contract? .../contract/private/guts.rkt:111:0 -------------------------------------------------------------------------- for-loop [175] 100.0% [182] 358(0.3%) 0(0.0%) mterm->expr ...e/develop/src/core/reduce.rkt:270:0 f6 [71] 100.0% -------------------------------------------------------------------------- err-lsts->split-indices [176] 100.0% [183] 352(0.3%) 0(0.0%) add-splitpoint ...velop/src/core/regimes.rkt:235:2 for-loop [191] 100.0% -------------------------------------------------------------------------- ??? [172] 100.0% [184] 332(0.3%) 332(0.3%) ??? ...lects/racket/contract/private/orc.rkt:83:14 -------------------------------------------------------------------------- ??? [177] 100.0% [185] 4080(3.2%) 3372(2.6%) bfdiv ...-lib/math/private/bigfloat/mpfr.rkt:819:4 ??? [192] 17.4% -------------------------------------------------------------------------- ??? [195] 13.0% ??? [139] 13.0% for-loop [179] 74.0% [186] 1386(1.1%) 360(0.3%) get/build-late-neg-projection ...te/guts.rkt:691:0 ??? [193] 74.0% ??? [195] 13.0% -------------------------------------------------------------------------- ??? [180] 100.0% [187] 1346(1.0%) 0(0.0%) generic-sort/key .../racket/private/sort.rkt:185:2 copying-mergesort [194] 76.1% loop [198] 23.9% -------------------------------------------------------------------------- for-loop [179] 100.0% [188] 1330(1.0%) 1330(1.0%) add-list-context ...ontract/private/list.rkt:752:0 -------------------------------------------------------------------------- ??? [177] 100.0% [189] 786(0.6%) 450(0.3%) bfexp ...-lib/math/private/bigfloat/mpfr.rkt:616:4 ??? [192] 42.7% -------------------------------------------------------------------------- ??? [178] 100.0% [190] 716(0.6%) 716(0.6%) contract? ...acket/contract/private/guts.rkt:109:0 -------------------------------------------------------------------------- add-splitpoint [183] 100.0% [191] 352(0.3%) 0(0.0%) for-loop ...bie/develop/src/core/regimes.rkt:237:4 for-loop [196] 100.0% -------------------------------------------------------------------------- bfexp [189] 32.2% bfdiv [185] 67.8% [192] 1044(0.8%) 1044(0.8%) ??? .../share/racket/collects/ffi/unsafe.rkt:861:4 -------------------------------------------------------------------------- get/build-late-neg-projection [186]100.0% [193] 1026(0.8%) 0(0.0%) ??? ...cts/racket/contract/private/prop.rkt:314:12 build-compound-type-name [197] 100.0% -------------------------------------------------------------------------- generic-sort/key [187] 33.8% copying-mergesort [194] 66.2% [194] 1024(0.8%) 0(0.0%) copying-mergesort ...racket/private/sort.rkt:130:8 copying-mergesort [194] 66.2% loop [198] 17.6% jloop [6] 16.2% -------------------------------------------------------------------------- get/build-late-neg-projection [186]100.0% [195] 360(0.3%) 0(0.0%) ??? ...ects/racket/contract/private/hash.rkt:211:2 get/build-late-neg-projection [186]100.0% -------------------------------------------------------------------------- for-loop [191] 100.0% [196] 352(0.3%) 352(0.3%) for-loop ...bie/develop/src/core/regimes.rkt:241:8 -------------------------------------------------------------------------- ??? [193] 100.0% [197] 1026(0.8%) 0(0.0%) build-compound-type-name ...private/guts.rkt:448:0 contract-struct-name [199] 100.0% -------------------------------------------------------------------------- generic-sort/key [187] 47.2% copying-mergesort [194] 52.8% [198] 682(0.5%) 0(0.0%) loop ...ket/collects/racket/private/sort.rkt:97:12 ??? [69] 100.0% -------------------------------------------------------------------------- build-compound-type-name [197] 100.0% [199] 1026(0.8%) 1026(0.8%) contract-struct-name ...ract/private/prop.rkt:89:0 --------------------------------------------------------------------------