Profiling results ----------------- Total cpu time observed: 115638ms (out of 116544ms) Number of samples taken: 331 (once every 349ms) (Hiding functions with self<1.0% and local<2.0%: 6 of 197 hidden) ============================================================================ Caller Idx Total Self Name+src Local% ms(pct) ms(pct) Callee ============================================================================ ??? [30] 100.0% [1] 105198(91.0%) 0(0.0%) profile-thunk16 ...t/pkgs/profile-lib/main.rkt:9:0 run [8] 100.0% ---------------------------------------------------------------------------- ??? [30] 100.0% [2] 80756(69.8%) 0(0.0%) run-improve50 ...ie/develop/src/mainloop.rkt:234:0 for-loop [9] 90.3% get-final-combination [11] 9.2% loop [38] 0.5% ---------------------------------------------------------------------------- loop [45] 1.2% loop [186] 1.9% for-loop [49] 21.9% loop [125] 75.0% [3] 34808(30.1%) 0(0.0%) ??? ...tlies/herbie/develop/src/programs.rkt:154:4 ??? [10] 89.8% ??? [56] 9.2% ??? [51] 1.0% ---------------------------------------------------------------------------- substitute-e [97] 17.7% match-e [92] 82.3% [4] 2068(1.8%) 0(0.0%) variable? ...e/develop/src/syntax/syntax.rkt:660:0 ??? [26] 100.0% ---------------------------------------------------------------------------- hash-ref! [103] 100.0% [5] 692(0.6%) 0(0.0%) ??? ...s/herbie/develop/src/core/taylor.rkt:285:26 for-loop [12] 100.0% ---------------------------------------------------------------------------- hash-ref! [103] 100.0% [6] 690(0.6%) 0(0.0%) ??? ...s/herbie/develop/src/core/taylor.rkt:483:23 for-loop [13] 100.0% ---------------------------------------------------------------------------- parse-loop12 [121] 100.0% [7] 300(0.3%) 0(0.0%) simplify-node .../develop/src/core/reduce.rkt:50:0 append-map [14] 100.0% ---------------------------------------------------------------------------- profile-thunk16 [1] 100.0% [8] 105198(91.0%) 0(0.0%) run ...share/racket/pkgs/profile-lib/main.rkt:39:2 ??? [30] 100.0% ---------------------------------------------------------------------------- run-improve50 [2] 100.0% [9] 72946(63.1%) 0(0.0%) for-loop ...herbie/develop/src/mainloop.rkt:249:10 run-iter! [15] 100.0% ---------------------------------------------------------------------------- ??? [3] 100.0% [10] 31258(27.0%) 5906(5.1%) ??? ...acket/collects/racket/private/kw.rkt:444:14 ??? [131] 71.3% ??? [17] 8.9% ---------------------------------------------------------------------------- run-improve50 [2] 100.0% [11] 7402(6.4%) 0(0.0%) get-final-combination ...op/src/mainloop.rkt:264:0 split-table [16] 100.0% ---------------------------------------------------------------------------- ??? [5] 100.0% [12] 692(0.6%) 0(0.0%) for-loop ...bie/develop/src/core/taylor.rkt:285:52 ??? [18] 51.7% hash-ref! [103] 48.3% ---------------------------------------------------------------------------- ??? [6] 100.0% [13] 690(0.6%) 0(0.0%) for-loop ...bie/develop/src/core/taylor.rkt:487:35 parse-loop12 [121] 100.0% ---------------------------------------------------------------------------- simplify-node [7] 100.0% [14] 300(0.3%) 0(0.0%) append-map ...acket/collects/racket/list.rkt:565:2 parse-loop12 [121] 100.0% ---------------------------------------------------------------------------- for-loop [9] 100.0% [15] 72946(63.1%) 0(0.0%) run-iter! ...herbie/develop/src/mainloop.rkt:215:0 simplify! [19] 81.1% finalize-iter! [21] 13.3% gen-series! [22] 3.2% localize-error [23] 1.5% choose-best-alt! [24] 0.9% ---------------------------------------------------------------------------- get-final-combination [11] 100.0% [16] 7402(6.4%) 0(0.0%) split-table ...s/herbie/develop/src/glue.rkt:162:0 f6 [20] 100.0% ---------------------------------------------------------------------------- ??? [10] 100.0% [17] 2772(2.4%) 2082(1.8%) ??? ...herbie/develop/src/syntax/syntax.rkt:153:17 ??? [158] 24.9% ---------------------------------------------------------------------------- for-loop [12] 100.0% [18] 358(0.3%) 0(0.0%) ??? ...s/herbie/develop/src/core/taylor.rkt:288:19 hash-ref! [103] 100.0% ---------------------------------------------------------------------------- run-iter! [15] 100.0% [19] 59164(51.2%) 0(0.0%) simplify! ...herbie/develop/src/mainloop.rkt:155:0 for-loop [25] 100.0% ---------------------------------------------------------------------------- simplify [114] 1.5% approximate9 [57] 1.5% mterm->expr [177] 2.8% parse-loop12 [121] 3.0% eval-const-expr [154] 3.1% f6 [20] 5.1% hash-ref! [103] 6.7% eval-prog [50] 9.2% split-table [16] 67.0% [20] 10780(9.3%) 650(0.6%) f6 ...et/collects/racket/match/compiler.rkt:507:40 loop [125] 36.8% option-on-expr [133] 30.2% ??? [51] 12.3% map [28] 6.7% f6 [20] 5.1% location-do [55] 2.8% taylor-invert [29] 1.5% ---------------------------------------------------------------------------- run-iter! [15] 100.0% [21] 9700(8.4%) 0(0.0%) finalize-iter! ...e/develop/src/mainloop.rkt:169:0 ??? [26] 100.0% ---------------------------------------------------------------------------- run-iter! [15] 100.0% [22] 2308(2.0%) 0(0.0%) gen-series! ...rbie/develop/src/mainloop.rkt:129:0 for-loop [27] 100.0% ---------------------------------------------------------------------------- run-iter! [15] 100.0% [23] 1086(0.9%) 0(0.0%) localize-error ...velop/src/core/localize.rkt:47:0 hash-ref! [103] 100.0% ---------------------------------------------------------------------------- run-iter! [15] 100.0% [24] 688(0.6%) 0(0.0%) choose-best-alt! ...develop/src/mainloop.rkt:115:0 ??? [26] 100.0% ---------------------------------------------------------------------------- simplify! [19] 100.0% [25] 59164(51.2%) 0(0.0%) for-loop .../herbie/develop/src/mainloop.rkt:159:6 ??? [30] 100.0% ---------------------------------------------------------------------------- ??? [179] 1.8% choose-best-alt! [24] 2.6% variable? [4] 10.5% get-sigs [126] 14.0% match-e [92] 22.8% finalize-iter! [21] 48.3% [26] 19702(17.0%) 4898(4.2%) ??? ...contract/private/arrow-val-first.rkt:357:18 for-loop [31] 44.8% hash-has-key? [32] 24.2% atab-add-altns [35] 3.5% ??? [36] 2.6% ---------------------------------------------------------------------------- gen-series! [22] 100.0% [27] 2308(2.0%) 0(0.0%) for-loop .../herbie/develop/src/mainloop.rkt:135:7 taylor-alt [33] 100.0% ---------------------------------------------------------------------------- f6 [20] 100.0% [28] 726(0.6%) 0(0.0%) map ...acket/collects/racket/private/map.rkt:20:13 loop [125] 51.0% ??? [34] 49.0% ---------------------------------------------------------------------------- f6 [20] 100.0% [29] 324(0.3%) 0(0.0%) taylor-invert ...develop/src/core/taylor.rkt:312:0 first-nonzero-exp [37] 100.0% ---------------------------------------------------------------------------- for-loop [25] 17.4% run [8] 37.7% [30] 113270(98.0%) 0(0.0%) ??? ...lects/racket/private/more-scheme.rkt:261:28 profile-thunk16 [1] 37.7% run-improve50 [2] 26.9% location-do [55] 24.5% loop [38] 10.8% ---------------------------------------------------------------------------- ??? [26] 100.0% [31] 9006(7.8%) 0(0.0%) for-loop ...ie/develop/src/core/alt-table.rkt:51:2 atab-add-altn [39] 100.0% ---------------------------------------------------------------------------- ??? [26] 100.0% [32] 5112(4.4%) 1030(0.9%) hash-has-key? ...et/private/more-scheme.rkt:368:13 ??? [61] 67.4% ??? [41] 12.5% ---------------------------------------------------------------------------- for-loop [27] 100.0% [33] 2308(2.0%) 0(0.0%) taylor-alt ...es/herbie/develop/src/glue.rkt:134:0 for-loop [40] 100.0% ---------------------------------------------------------------------------- map [28] 49.0% loop [125] 51.0% [34] 726(0.6%) 0(0.0%) ??? ...ket/collects/racket/private/list.rkt:323:18 hash-ref! [103] 100.0% ---------------------------------------------------------------------------- ??? [26] 100.0% [35] 694(0.6%) 0(0.0%) atab-add-altns ...elop/src/core/alt-table.rkt:50:0 atab-add-altn [39] 100.0% ---------------------------------------------------------------------------- ??? [26] 100.0% [36] 688(0.6%) 0(0.0%) ??? .../herbie/develop/src/core/alt-table.rkt:54:0 ??? [51] 100.0% ---------------------------------------------------------------------------- taylor-invert [29] 100.0% [37] 324(0.3%) 0(0.0%) first-nonzero-exp ...lop/src/core/taylor.rkt:260:0 simplify [114] 100.0% ---------------------------------------------------------------------------- run-improve50 [2] 1.4% pred [185] 13.0% ??? [30] 85.6% [38] 28560(24.7%) 0(0.0%) loop ...htlies/herbie/develop/src/points.rkt:205:2 loop [42] 36.3% make-exacts* [46] 32.8% loop [45] 29.8% for-loop [44] 1.2% ---------------------------------------------------------------------------- atab-add-altns [35] 7.2% for-loop [31] 92.8% [39] 9700(8.4%) 0(0.0%) atab-add-altn ...elop/src/core/alt-table.rkt:208:0 best-and-tied-at-points [43] 100.0% ---------------------------------------------------------------------------- taylor-alt [33] 100.0% [40] 2308(2.0%) 0(0.0%) for-loop ...lies/herbie/develop/src/glue.rkt:139:6 ??? [51] 100.0% ---------------------------------------------------------------------------- hash-has-key? [32] 100.0% [41] 638(0.6%) 638(0.6%) ??? ...ects/racket/contract/private/hash.rkt:245:7 ---------------------------------------------------------------------------- loop [38] 100.0% [42] 10372(9.0%) 0(0.0%) loop ...htlies/herbie/develop/src/points.rkt:158:2 loop [45] 54.7% make-exacts* [46] 45.3% ---------------------------------------------------------------------------- atab-add-altn [39] 100.0% [43] 9700(8.4%) 0(0.0%) best-and-tied-at-points ...ore/alt-table.rkt:122:0 errors [47] 100.0% ---------------------------------------------------------------------------- loop [38] 100.0% [44] 334(0.3%) 0(0.0%) for-loop ...s/herbie/develop/src/points.rkt:222:26 for-loop [48] 100.0% ---------------------------------------------------------------------------- loop [42] 40.1% loop [38] 59.9% [45] 14176(12.3%) 0(0.0%) loop ...htlies/herbie/develop/src/points.rkt:141:4 loop [125] 97.1% ??? [3] 2.9% ---------------------------------------------------------------------------- loop [42] 33.4% loop [38] 66.6% [46] 14050(12.1%) 0(0.0%) make-exacts* ...erbie/develop/src/points.rkt:138:0 loop [125] 95.5% eval-prog [50] 4.5% ---------------------------------------------------------------------------- composed [74] 5.4% option-on-expr [133] 5.4% pred [185] 13.1% best-and-tied-at-points [43] 76.1% [47] 12746(11.0%) 0(0.0%) errors ...lies/herbie/develop/src/points.rkt:241:0 for-loop [49] 75.7% eval-prog [50] 24.3% ---------------------------------------------------------------------------- for-loop [44] 100.0% [48] 334(0.3%) 0(0.0%) for-loop ...s/herbie/develop/src/points.rkt:223:28 ??? [51] 100.0% ---------------------------------------------------------------------------- errors [47] 100.0% [49] 9652(8.3%) 298(0.3%) for-loop ...es/herbie/develop/src/points.rkt:244:4 ??? [3] 79.1% ??? [51] 14.0% ulp-difference [52] 3.7% ---------------------------------------------------------------------------- make-exacts* [46] 16.9% errors [47] 83.1% [50] 3722(3.2%) 714(0.6%) eval-prog ...herbie/develop/src/programs.rkt:148:0 f6 [20] 46.3% hash-ref! [103] 16.9% ??? [53] 9.1% go [54] 8.6% ---------------------------------------------------------------------------- ??? [3] 2.2% for-loop [48] 4.3% ??? [36] 4.4% loop [156] 4.6% loop [64] 7.0% location-do [55] 11.2% for-loop [40] 11.2% loop [125] 13.5% for-loop [49] 17.3% f6 [20] 24.1% [51] 7816(6.8%) 334(0.3%) ??? ...tract/private/arrow-higher-order.rkt:342:33 location-do [55] 57.6% approximate9 [57] 11.2% hash-ref! [103] 7.0% ??? [179] 6.7% ...velop/src/common.rkt:47:2 [135] 4.5% best-alt [58] 4.4% ??? [56] 4.2% ---------------------------------------------------------------------------- for-loop [49] 100.0% [52] 360(0.3%) 360(0.3%) ulp-difference ...erbie/develop/src/float.rkt:19:0 ---------------------------------------------------------------------------- eval-prog [50] 100.0% [53] 338(0.3%) 338(0.3%) ??? ...collects/racket/private/qq-and-or.rkt:155:9 ---------------------------------------------------------------------------- eval-prog [50] 100.0% [54] 320(0.3%) 320(0.3%) go .../collects/racket/private/qq-and-or.rkt:50:20 ---------------------------------------------------------------------------- f6 [20] 0.1% for-loop [93] 1.2% get-sigs [126] 1.6% ??? [51] 6.6% for-loop [60] 20.5% location-do [55] 25.2% ??? [30] 44.3% [55] 73992(64.0%) 2364(2.0%) location-do ...acket/private/norm-define.rkt:53:83 iterate-egraph!13 [59] 40.4% location-do [55] 25.2% for-loop [60] 21.0% loop [62] 3.2% ??? [61] 2.9% ??? [51] 1.5% ??? [158] 1.1% mk-egraph [65] 0.7% list-member? [98] 0.5% return/no-unsupplied [163] 0.5% ??? [67] 0.5% dict? [188] 0.2% ---------------------------------------------------------------------------- ??? [51] 9.4% ??? [3] 90.6% [56] 3534(3.1%) 332(0.3%) ??? ...contract/private/../../private/kw.rkt:761:9 real->bigfloat [63] 90.6% ---------------------------------------------------------------------------- ??? [51] 100.0% [57] 2308(2.0%) 0(0.0%) approximate9 ...e/develop/src/core/taylor.rkt:12:0 loop [64] 71.5% apply-contract [68] 14.5% f6 [20] 14.0% ---------------------------------------------------------------------------- ??? [51] 100.0% [58] 688(0.6%) 0(0.0%) best-alt ...tlies/herbie/develop/src/glue.rkt:71:0 argmins [66] 100.0% ---------------------------------------------------------------------------- location-do [55] 100.0% [59] 60966(52.7%) 0(0.0%) iterate-egraph!13 ...p/src/core/simplify.rkt:102:0 one-iter [69] 98.3% map-enodes [72] 1.7% ---------------------------------------------------------------------------- location-do [55] 100.0% [60] 31372(27.1%) 0(0.0%) for-loop ...ie/develop/src/core/simplify.rkt:63:12 location-do [55] 99.0% ---------------------------------------------------------------------------- hash-has-key? [32] 40.0% location-do [55] 60.0% [61] 8600(7.4%) 3642(3.1%) ??? ...ects/racket/contract/private/list.rkt:737:4 for-loop [71] 31.1% ??? [80] 22.2% arrow-higher-order:lnp [75] 4.3% ---------------------------------------------------------------------------- location-do [55] 100.0% [62] 5558(4.8%) 0(0.0%) loop ...herbie/develop/src/core/simplify.rkt:215:2 pass [70] 100.0% ---------------------------------------------------------------------------- ??? [56] 100.0% [63] 3202(2.8%) 3202(2.8%) real->bigfloat .../private/bigfloat/mpfr.rkt:451:0 ---------------------------------------------------------------------------- approximate9 [57] 100.0% [64] 1650(1.4%) 0(0.0%) loop ...es/herbie/develop/src/core/taylor.rkt:86:4 ??? [51] 100.0% ---------------------------------------------------------------------------- location-do [55] 100.0% [65] 1044(0.9%) 0(0.0%) mk-egraph ...bie/develop/src/core/egraph.rkt:123:0 expr->enode [73] 69.2% mk-enode! [100] 30.8% ---------------------------------------------------------------------------- best-alt [58] 100.0% [66] 688(0.6%) 0(0.0%) argmins ...ies/herbie/develop/src/common.rkt:150:0 composed [74] 100.0% ---------------------------------------------------------------------------- location-do [55] 100.0% [67] 340(0.3%) 0(0.0%) ??? ...-racket/utils/simple-result-arrow.rkt:60:15 ??? [164] 100.0% ---------------------------------------------------------------------------- approximate9 [57] 100.0% [68] 334(0.3%) 0(0.0%) apply-contract ...t/contract/private/base.rkt:57:0 ??? [76] 100.0% ---------------------------------------------------------------------------- iterate-egraph!13 [59] 100.0% [69] 59926(51.8%) 348(0.3%) one-iter ...ie/develop/src/core/simplify.rkt:113:0 loop [77] 60.6% for-loop [78] 33.9% apply-match [84] 4.4% filter [175] 0.5% ---------------------------------------------------------------------------- loop [62] 100.0% [70] 5558(4.8%) 0(0.0%) pass ...herbie/develop/src/core/simplify.rkt:205:2 for-loop [79] 100.0% ---------------------------------------------------------------------------- ??? [61] 100.0% [71] 2678(2.3%) 1026(0.9%) for-loop ...acket/contract/private/list.rkt:743:12 ??? [80] 24.6% for-loop [143] 23.7% ??? [83] 13.4% ---------------------------------------------------------------------------- iterate-egraph!13 [59] 100.0% [72] 1040(0.9%) 0(0.0%) map-enodes ...ie/develop/src/core/egraph.rkt:139:0 loop [125] 64.6% set-precompute! [82] 35.4% ---------------------------------------------------------------------------- mk-egraph [65] 41.8% expr->enode [73] 58.2% [73] 722(0.6%) 0(0.0%) expr->enode ...e/develop/src/core/egraph.rkt:124:2 expr->enode [73] 58.2% mk-enode! [100] 41.8% ---------------------------------------------------------------------------- argmins [66] 100.0% [74] 688(0.6%) 0(0.0%) composed ...ollects/racket/private/list.rkt:321:16 errors [47] 100.0% ---------------------------------------------------------------------------- ??? [61] 100.0% [75] 368(0.3%) 0(0.0%) arrow-higher-order:lnp ...w-higher-order.rkt:597:7 ??? [81] 100.0% ---------------------------------------------------------------------------- apply-contract [68] 100.0% [76] 334(0.3%) 334(0.3%) ??? ...ntract/private/arrow-higher-order.rkt:518:2 ---------------------------------------------------------------------------- one-iter [69] 100.0% [77] 36316(31.4%) 0(0.0%) loop ...cket/collects/racket/private/map.rkt:52:19 apply-match [84] 100.0% ---------------------------------------------------------------------------- for-loop [78] 48.3% one-iter [69] 51.7% [78] 20298(17.6%) 4840(4.2%) for-loop ...e/develop/src/core/simplify.rkt:123:12 for-loop [78] 48.3% match-e [92] 38.1% ---------------------------------------------------------------------------- pass [70] 100.0% [79] 5558(4.8%) 0(0.0%) for-loop ...e/develop/src/core/simplify.rkt:208:29 argmin [85] 70.6% loop [86] 23.4% for-loop [90] 6.0% ---------------------------------------------------------------------------- for-loop [71] 25.6% ??? [61] 74.4% [80] 2570(2.2%) 1610(1.4%) ??? ...private/unconstrained-domain-arrow.rkt:74:4 make-keyword-procedure [87] 37.4% ---------------------------------------------------------------------------- arrow-higher-order:lnp [75] 100.0% [81] 368(0.3%) 368(0.3%) ??? ...et/contract/private/arity-checking.rkt:19:2 ---------------------------------------------------------------------------- map-enodes [72] 100.0% [82] 368(0.3%) 0(0.0%) set-precompute! ...lop/src/core/simplify.rkt:172:0 make-sequence [88] 100.0% ---------------------------------------------------------------------------- for-loop [71] 100.0% [83] 360(0.3%) 0(0.0%) ??? ...ects/racket/contract/private/hash.rkt:222:6 check-hash/c [89] 100.0% ---------------------------------------------------------------------------- one-iter [69] 6.8% loop [77] 93.2% [84] 38982(33.7%) 326(0.3%) apply-match ...develop/src/core/simplify.rkt:130:2 for-loop [91] 84.9% match-e [92] 11.6% update-leader! [102] 1.8% ---------------------------------------------------------------------------- for-loop [79] 100.0% [85] 3924(3.4%) 0(0.0%) argmin ...re/racket/collects/racket/list.rkt:743:0 for-loop [93] 100.0% ---------------------------------------------------------------------------- for-loop [79] 100.0% [86] 1300(1.1%) 0(0.0%) loop ...hare/racket/collects/racket/list.rkt:729:4 for-loop [93] 77.2% expression-cost [94] 22.8% ---------------------------------------------------------------------------- ??? [80] 100.0% [87] 960(0.8%) 960(0.8%) make-keyword-procedure ...ket/private/kw.rkt:260:4 ---------------------------------------------------------------------------- set-precompute! [82] 100.0% [88] 368(0.3%) 368(0.3%) make-sequence ...ects/racket/private/for.rkt:509:2 ---------------------------------------------------------------------------- ??? [83] 100.0% [89] 360(0.3%) 360(0.3%) check-hash/c ...ket/contract/private/hash.rkt:83:0 ---------------------------------------------------------------------------- for-loop [79] 100.0% [90] 334(0.3%) 334(0.3%) for-loop ...e/develop/src/core/simplify.rkt:195:13 ---------------------------------------------------------------------------- apply-match [84] 100.0% [91] 33092(28.6%) 380(0.3%) for-loop ...e/develop/src/core/simplify.rkt:145:10 merge-egraph-nodes! [96] 30.8% mk-enode! [100] 25.5% substitute-e [97] 17.3% loop! [132] 16.7% list-member? [98] 8.4% ---------------------------------------------------------------------------- apply-match [84] 14.8% for-loop [101] 27.9% for-loop [78] 57.3% [92] 19970(17.3%) 5152(4.5%) match-e ...herbie/develop/src/core/ematch.rkt:46:0 for-loop [95] 48.6% ??? [26] 12.0% for-loop [101] 10.3% variable? [4] 3.1% list-cartesian-product [106] 2.6% loop [125] 1.9% ---------------------------------------------------------------------------- loop [86] 20.4% argmin [85] 79.6% [93] 4928(4.3%) 308(0.3%) for-loop .../herbie/develop/src/programs.rkt:199:2 location-do [55] 54.0% ...velop/src/common.rkt:47:2 [135] 33.2% ??? [134] 6.6% ---------------------------------------------------------------------------- loop [86] 100.0% [94] 296(0.3%) 0(0.0%) expression-cost .../develop/src/programs.rkt:198:0 compile [99] 100.0% ---------------------------------------------------------------------------- match-e [92] 100.0% [95] 13744(11.9%) 4806(4.2%) for-loop ...rbie/develop/src/core/ematch.rkt:59:11 for-loop [101] 49.8% loop [125] 9.0% list-cartesian-product [106] 3.7% curry* [109] 2.5% ---------------------------------------------------------------------------- for-loop [107] 1.6% merge-egraph-nodes! [96] 3.8% for-loop [91] 94.6% [96] 10202(8.8%) 360(0.3%) merge-egraph-nodes! ...p/src/core/egraph.rkt:152:0 update-leader! [102] 47.6% for-loop [104] 23.2% loop! [132] 10.1% for-loop [107] 8.4% merge-egraph-nodes! [96] 3.8% enode-merge! [110] 3.4% ---------------------------------------------------------------------------- substitute-e [97] 4.3% for-loop [91] 95.7% [97] 5740(5.0%) 0(0.0%) substitute-e ...e/develop/src/core/ematch.rkt:71:0 mk-enode! [100] 93.6% substitute-e [97] 4.3% variable? [4] 2.1% ---------------------------------------------------------------------------- location-do [55] 11.6% for-loop [91] 88.4% [98] 3146(2.7%) 366(0.3%) list-member? ...llects/racket/private/set.rkt:24:0 loop [105] 66.9% member [108] 21.5% ---------------------------------------------------------------------------- expression-cost [94] 100.0% [99] 296(0.3%) 0(0.0%) compile ...s/herbie/develop/src/programs.rkt:175:0 hash-ref! [103] 100.0% ---------------------------------------------------------------------------- mk-egraph [65] 2.2% expr->enode [73] 4.9% substitute-e [97] 36.1% for-loop [91] 56.8% [100] 14868(12.9%) 704(0.6%) mk-enode! ...bie/develop/src/core/egraph.rkt:101:0 new-enode [111] 95.3% ---------------------------------------------------------------------------- match-e [92] 36.6% for-loop [95] 63.4% [101] 10304(8.9%) 320(0.3%) for-loop ...rbie/develop/src/core/ematch.rkt:65:37 match-e [92] 96.9% ---------------------------------------------------------------------------- apply-match [84] 11.9% merge-egraph-nodes! [96] 88.1% [102] 5766(5.0%) 648(0.6%) update-leader! ...evelop/src/core/egraph.rkt:217:0 for-loop [112] 71.2% custom-set-union! [115] 12.3% update-en-expr [160] 5.2% ---------------------------------------------------------------------------- simplify* [129] 2.0% for-loop [128] 2.0% ??? [18] 2.0% compile [99] 2.0% for-loop [12] 3.0% ??? [118] 6.1% ??? [34] 11.6% eval-prog [50] 17.2% localize-error [23] 18.1% ??? [113] 18.1% ??? [51] 18.1% [103] 3660(3.2%) 654(0.6%) hash-ref! ...racket/private/more-scheme.rkt:373:13 parse-loop12 [121] 21.4% ??? [113] 18.1% bigfloat-hash [116] 17.2% simplify [114] 13.6% f6 [20] 8.2% ??? [6] 6.5% ??? [118] 6.1% ??? [5] 5.0% ---------------------------------------------------------------------------- merge-egraph-nodes! [96] 100.0% [104] 2362(2.0%) 2064(1.8%) for-loop ...rbie/develop/src/core/egraph.rkt:232:6 update-en-expr [160] 12.6% ---------------------------------------------------------------------------- list-member? [98] 100.0% [105] 2104(1.8%) 2104(1.8%) loop (unknown source) ---------------------------------------------------------------------------- for-loop [95] 49.6% match-e [92] 50.4% [106] 1368(1.2%) 1368(1.2%) list-cartesian-product ...src/core/ematch.rkt:20:0 ---------------------------------------------------------------------------- merge-egraph-nodes! [96] 100.0% [107] 1024(0.9%) 0(0.0%) for-loop ...bie/develop/src/core/egraph.rkt:200:10 loop! [132] 68.2% merge-egraph-nodes! [96] 31.8% ---------------------------------------------------------------------------- list-member? [98] 100.0% [108] 676(0.6%) 676(0.6%) member (unknown source) ---------------------------------------------------------------------------- for-loop [95] 100.0% [109] 348(0.3%) 348(0.3%) curry* ...racket/collects/racket/function.rkt:44:2 ---------------------------------------------------------------------------- merge-egraph-nodes! [96] 100.0% [110] 346(0.3%) 0(0.0%) enode-merge! ...e/develop/src/core/enode.rkt:129:0 adopt-enode! [117] 100.0% ---------------------------------------------------------------------------- mk-enode! [100] 100.0% [111] 14164(12.2%) 0(0.0%) new-enode ...erbie/develop/src/core/enode.rkt:97:0 type-of-enode-expr [119] 100.0% ---------------------------------------------------------------------------- update-leader! [102] 100.0% [112] 4108(3.6%) 360(0.3%) for-loop ...rbie/develop/src/core/egraph.rkt:222:6 for-loop [120] 91.2% ---------------------------------------------------------------------------- hash-ref! [103] 100.0% [113] 1650(1.4%) 0(0.0%) ??? ...es/herbie/develop/src/core/taylor.rkt:44:15 hash-ref! [103] 100.0% ---------------------------------------------------------------------------- first-nonzero-exp [37] 19.7% hash-ref! [103] 80.3% [114] 1642(1.4%) 0(0.0%) simplify ...erbie/develop/src/core/reduce.rkt:16:0 parse-loop12 [121] 80.3% f6 [20] 19.7% ---------------------------------------------------------------------------- update-leader! [102] 100.0% [115] 712(0.6%) 354(0.3%) custom-set-union! ...t/private/set-types.rkt:245:0 for-loop [122] 50.3% ---------------------------------------------------------------------------- hash-ref! [103] 100.0% [116] 628(0.5%) 0(0.0%) bigfloat-hash ...h/private/bigfloat/mpfr.rkt:165:0 sig+exp->bigfloat [123] 52.2% bfcanonicalize [124] 47.8% ---------------------------------------------------------------------------- enode-merge! [110] 100.0% [117] 346(0.3%) 0(0.0%) adopt-enode! ...e/develop/src/core/enode.rkt:105:0 custom-set-union [141] 100.0% ---------------------------------------------------------------------------- hash-ref! [103] 100.0% [118] 296(0.3%) 0(0.0%) ??? ...tlies/herbie/develop/src/programs.rkt:183:5 hash-ref! [103] 100.0% ---------------------------------------------------------------------------- new-enode [111] 100.0% [119] 14164(12.2%) 312(0.3%) type-of-enode-expr ...elop/src/core/enode.rkt:68:0 get-sigs [126] 97.8% ---------------------------------------------------------------------------- for-loop [112] 100.0% [120] 3748(3.2%) 0(0.0%) for-loop ...rbie/develop/src/core/egraph.rkt:223:8 hash-update! [127] 100.0% ---------------------------------------------------------------------------- append-map [14] 5.5% loop [125] 6.2% parse-loop12 [121] 9.2% for-loop [13] 15.4% simplify [114] 23.9% hash-ref! [103] 39.7% [121] 2736(2.4%) 334(0.3%) parse-loop12 ...s/racket/match/compiler.rkt:418:15 loop [125] 19.8% for-loop [128] 15.4% loop [156] 13.2% ??? [131] 13.0% parse-loop12 [121] 9.2% simplify-node [7] 5.5% for-loop [130] 5.5% simplify* [129] 3.3% f6 [20] 3.0% ---------------------------------------------------------------------------- custom-set-union! [115] 100.0% [122] 358(0.3%) 358(0.3%) for-loop ...cts/racket/private/set-types.rkt:253:4 ---------------------------------------------------------------------------- bigfloat-hash [116] 100.0% [123] 328(0.3%) 328(0.3%) sig+exp->bigfloat ...ivate/bigfloat/mpfr.rkt:385:0 ---------------------------------------------------------------------------- bigfloat-hash [116] 100.0% [124] 300(0.3%) 300(0.3%) bfcanonicalize .../private/bigfloat/mpfr.rkt:155:0 ---------------------------------------------------------------------------- map [28] 0.0% match-e [92] 0.0% map-enodes [72] 0.4% make-exacts* [46] 1.2% parse-loop12 [121] 1.9% loop [45] 2.1% loop! [132] 2.6% for-loop [95] 3.1% f6 [20] 7.3% loop [125] 81.3% [125] 37768(32.7%) 1062(0.9%) loop ...cket/collects/racket/private/map.rkt:25:19 loop [125] 81.3% option-on-expr [133] 7.3% ??? [3] 3.1% loop! [132] 2.6% parse-loop12 [121] 1.8% foldl [138] 1.0% for-loop [137] 0.4% ??? [34] 0.1% ??? [131] 0.0% ??? [51] 0.0% ---------------------------------------------------------------------------- type-of-enode-expr [119] 100.0% [126] 13852(12.0%) 0(0.0%) get-sigs .../herbie/develop/src/type-check.rkt:5:0 ??? [134] 37.2% location-do [55] 25.7% ??? [26] 19.9% ...velop/src/common.rkt:47:2 [135] 17.3% ---------------------------------------------------------------------------- for-loop [120] 100.0% [127] 3748(3.2%) 0(0.0%) hash-update! ...ket/private/more-scheme.rkt:362:13 ??? [136] 100.0% ---------------------------------------------------------------------------- parse-loop12 [121] 100.0% [128] 690(0.6%) 332(0.3%) for-loop ...bie/develop/src/core/taylor.rkt:490:59 hash-ref! [103] 51.9% ---------------------------------------------------------------------------- parse-loop12 [121] 100.0% [129] 358(0.3%) 0(0.0%) simplify* ...rbie/develop/src/core/reduce.rkt:31:0 hash-ref! [103] 100.0% ---------------------------------------------------------------------------- parse-loop12 [121] 100.0% [130] 300(0.3%) 0(0.0%) for-loop ...rbie/develop/src/core/reduce.rkt:99:13 make-multiplication-node [139] 100.0% ---------------------------------------------------------------------------- parse-loop12 [121] 1.5% loop [125] 1.6% ??? [10] 96.8% [131] 23008(19.9%) 20506(17.7%) ??? ...-racket/utils/simple-result-arrow.rkt:39:12 bflog [148] 6.0% bfadd [149] 4.9% ---------------------------------------------------------------------------- for-loop [107] 7.0% merge-egraph-nodes! [96] 13.4% loop [125] 27.0% for-loop [91] 52.6% [132] 7594(6.6%) 1380(1.2%) loop! ...s/herbie/develop/src/core/enode.rkt:192:2 custom-set-union [141] 48.3% loop [125] 27.0% set [147] 9.1% update-en-expr [160] 6.5% ---------------------------------------------------------------------------- f6 [20] 46.4% loop [125] 53.6% [133] 7402(6.4%) 0(0.0%) option-on-expr ...velop/src/core/regimes.rkt:103:0 sindices->spoints [140] 72.6% sort-context-on-expr [150] 13.5% errors [47] 9.3% err-lsts->split-indices [153] 4.6% ---------------------------------------------------------------------------- for-loop [93] 6.0% get-sigs [126] 94.0% [134] 5476(4.7%) 326(0.3%) ??? ...ts/racket/contract/private/arr-i.rkt:804:10 for-loop [143] 50.7% ??? [144] 43.3% ---------------------------------------------------------------------------- ??? [51] 8.0% for-loop [93] 37.3% get-sigs [126] 54.6% [135] 4378(3.8%) 1016(0.9%) ...velop/src/common.rkt:47:2 ...e/arr-i.rkt:906:19 ??? [145] 39.7% ??? [146] 37.1% ---------------------------------------------------------------------------- hash-update! [127] 100.0% [136] 3748(3.2%) 0(0.0%) ??? ...s/herbie/develop/src/core/egraph.rkt:225:24 for-loop [142] 100.0% ---------------------------------------------------------------------------- loop [125] 100.0% [137] 672(0.6%) 0(0.0%) for-loop ...ie/develop/src/core/simplify.rkt:173:2 setfindf [152] 50.6% eval-const-expr [154] 49.4% ---------------------------------------------------------------------------- loop [125] 100.0% [138] 360(0.3%) 0(0.0%) foldl ...et/collects/racket/private/list.rkt:229:4 merge2 [151] 100.0% ---------------------------------------------------------------------------- for-loop [130] 100.0% [139] 300(0.3%) 0(0.0%) make-multiplication-node .../core/reduce.rkt:230:0 make-multiplication-subnode [155] 100.0% ---------------------------------------------------------------------------- option-on-expr [133] 100.0% [140] 5376(4.6%) 0(0.0%) sindices->spoints ...op/src/core/regimes.rkt:116:0 loop [156] 100.0% ---------------------------------------------------------------------------- adopt-enode! [117] 8.3% loop! [132] 91.7% [141] 4180(3.6%) 1776(1.5%) custom-set-union ...et/private/set-types.rkt:168:0 for-loop [161] 48.9% for-loop [165] 8.6% ---------------------------------------------------------------------------- ??? [136] 100.0% [142] 3748(3.2%) 3088(2.7%) for-loop ...bie/develop/src/core/egraph.rkt:226:26 update-en-expr [160] 17.6% ---------------------------------------------------------------------------- for-loop [71] 18.6% ??? [134] 81.4% [143] 3412(3.0%) 634(0.5%) for-loop ...racket/contract/private/hash.rkt:239:6 ??? [157] 81.4% ---------------------------------------------------------------------------- ??? [134] 100.0% [144] 2372(2.1%) 0(0.0%) ??? ...ects/racket/contract/private/hash.rkt:217:4 ??? [159] 100.0% ---------------------------------------------------------------------------- ??? [157] 20.6% ...velop/src/common.rkt:47:2 [135] 79.4% [145] 1736(1.5%) 0(0.0%) ??? ...ects/racket/contract/private/list.rkt:342:4 ??? [157] 79.4% ??? [179] 20.6% ---------------------------------------------------------------------------- ...velop/src/common.rkt:47:2 [135] 100.0% [146] 1626(1.4%) 0(0.0%) ??? ...s/racket/contract/private/arr-i.rkt:1268:39 ??? [158] 61.9% return/no-unsupplied [163] 38.1% ---------------------------------------------------------------------------- loop! [132] 100.0% [147] 1388(1.2%) 1388(1.2%) set ...collects/racket/private/set-types.rkt:981:0 ---------------------------------------------------------------------------- ??? [131] 100.0% [148] 1384(1.2%) 1034(0.9%) bflog ...-lib/math/private/bigfloat/mpfr.rkt:616:4 ??? [164] 25.3% ---------------------------------------------------------------------------- ??? [131] 100.0% [149] 1118(1.0%) 1118(1.0%) bfadd ...-lib/math/private/bigfloat/mpfr.rkt:819:4 ---------------------------------------------------------------------------- option-on-expr [133] 100.0% [150] 996(0.9%) 0(0.0%) sort-context-on-expr ...velop/src/points.rkt:115:0 ??? [162] 100.0% ---------------------------------------------------------------------------- foldl [138] 100.0% [151] 360(0.3%) 360(0.3%) merge2 .../herbie/develop/src/core/ematch.rkt:31:0 ---------------------------------------------------------------------------- for-loop [137] 100.0% [152] 340(0.3%) 0(0.0%) setfindf ...es/herbie/develop/src/common.rkt:184:0 for-loop [166] 100.0% ---------------------------------------------------------------------------- option-on-expr [133] 100.0% [153] 338(0.3%) 0(0.0%) err-lsts->split-indices .../core/regimes.rkt:222:0 add-splitpoint [167] 100.0% ---------------------------------------------------------------------------- for-loop [137] 100.0% [154] 332(0.3%) 0(0.0%) eval-const-expr .../develop/src/programs.rkt:166:0 f6 [20] 100.0% ---------------------------------------------------------------------------- make-multiplication-node [139] 100.0% [155] 300(0.3%) 0(0.0%) make-multiplication-subnode ...re/reduce.rkt:240:0 for-loop [168] 100.0% ---------------------------------------------------------------------------- parse-loop12 [121] 0.1% loop [156] 6.2% sindices->spoints [140] 93.7% [156] 5736(5.0%) 0(0.0%) loop ...cket/collects/racket/private/map.rkt:36:19 sidx->spoint [169] 93.7% loop [156] 6.2% ??? [51] 0.1% ---------------------------------------------------------------------------- ??? [145] 38.5% for-loop [143] 61.5% [157] 4514(3.9%) 1020(0.9%) ??? ...cts/racket/contract/private/list.rkt:187:10 ??? [170] 61.5% ??? [145] 15.9% ---------------------------------------------------------------------------- ??? [17] 25.1% ??? [146] 36.6% location-do [55] 38.2% [158] 2746(2.4%) 358(0.3%) ??? ...racket/collects/racket/private/kw.rkt:761:9 ??? [172] 60.5% ??? [179] 26.5% ---------------------------------------------------------------------------- ??? [144] 100.0% [159] 2372(2.1%) 0(0.0%) ??? ...ects/racket/contract/private/list.rkt:169:2 ??? [171] 100.0% ---------------------------------------------------------------------------- for-loop [104] 13.3% update-leader! [102] 13.3% for-loop [142] 29.4% loop! [132] 44.1% [160] 2248(1.9%) 2248(1.9%) update-en-expr ...evelop/src/core/egraph.rkt:211:0 ---------------------------------------------------------------------------- custom-set-union [141] 100.0% [161] 2044(1.8%) 678(0.6%) for-loop ...cts/racket/private/set-types.rkt:174:3 for-loop [173] 66.8% ---------------------------------------------------------------------------- sort-context-on-expr [150] 100.0% [162] 996(0.9%) 0(0.0%) ??? ...cket/collects/racket/private/sort.rkt:403:3 generic-sort/key [174] 100.0% ---------------------------------------------------------------------------- location-do [55] 36.0% ??? [146] 64.0% [163] 968(0.8%) 670(0.6%) return/no-unsupplied ...ct/private/arr-i.rkt:533:0 filter [175] 30.8% ---------------------------------------------------------------------------- ??? [67] 49.3% bflog [148] 50.7% [164] 690(0.6%) 690(0.6%) ??? .../share/racket/collects/ffi/unsafe.rkt:861:4 ---------------------------------------------------------------------------- custom-set-union [141] 100.0% [165] 360(0.3%) 360(0.3%) for-loop ...cts/racket/private/set-types.rkt:152:2 ---------------------------------------------------------------------------- setfindf [152] 100.0% [166] 340(0.3%) 340(0.3%) for-loop ...es/herbie/develop/src/common.rkt:185:2 ---------------------------------------------------------------------------- err-lsts->split-indices [153] 100.0% [167] 338(0.3%) 0(0.0%) add-splitpoint ...velop/src/core/regimes.rkt:235:2 for-loop [176] 100.0% ---------------------------------------------------------------------------- make-multiplication-subnode [155] 100.0% [168] 300(0.3%) 0(0.0%) for-loop ...rbie/develop/src/core/reduce.rkt:242:3 mterm->expr [177] 100.0% ---------------------------------------------------------------------------- loop [156] 100.0% [169] 5376(4.6%) 0(0.0%) sidx->spoint ...develop/src/core/regimes.rkt:126:2 binary-search [178] 93.3% binary-search-floats [183] 6.7% ---------------------------------------------------------------------------- ??? [157] 100.0% [170] 2778(2.4%) 0(0.0%) ??? ...ects/racket/contract/private/list.rkt:686:7 ??? [179] 100.0% ---------------------------------------------------------------------------- ??? [159] 100.0% [171] 2372(2.1%) 712(0.6%) ??? ...ects/racket/contract/private/list.rkt:678:5 for-loop [180] 70.0% ---------------------------------------------------------------------------- ??? [158] 100.0% [172] 1660(1.4%) 1300(1.1%) ??? ...s/racket/contract/private/arr-i.rkt:1233:27 ??? [182] 21.7% ---------------------------------------------------------------------------- for-loop [161] 100.0% [173] 1366(1.2%) 1366(1.2%) for-loop ...cts/racket/private/set-types.rkt:178:5 ---------------------------------------------------------------------------- ??? [162] 100.0% [174] 996(0.9%) 0(0.0%) generic-sort/key .../racket/private/sort.rkt:185:2 copying-mergesort [181] 66.9% loop [186] 33.1% ---------------------------------------------------------------------------- return/no-unsupplied [163] 50.0% one-iter [69] 50.0% [175] 596(0.5%) 596(0.5%) filter ...t/collects/racket/private/list.rkt:256:2 ---------------------------------------------------------------------------- add-splitpoint [167] 100.0% [176] 338(0.3%) 0(0.0%) for-loop ...bie/develop/src/core/regimes.rkt:237:4 for-loop [184] 100.0% ---------------------------------------------------------------------------- for-loop [168] 100.0% [177] 300(0.3%) 0(0.0%) mterm->expr ...e/develop/src/core/reduce.rkt:270:0 f6 [20] 100.0% ---------------------------------------------------------------------------- sidx->spoint [169] 100.0% [178] 5016(4.3%) 0(0.0%) binary-search ...rbie/develop/src/common.rkt:226:0 pred [185] 100.0% ---------------------------------------------------------------------------- ??? [51] 14.2% ??? [145] 14.6% ??? [158] 14.8% ??? [170] 56.5% [179] 4918(4.3%) 3510(3.0%) ??? ...ects/racket/contract/private/guts.rkt:644:8 ??? [26] 14.2% contract? [189] 7.3% dict? [188] 7.2% ---------------------------------------------------------------------------- ??? [171] 100.0% [180] 1660(1.4%) 326(0.3%) for-loop ...racket/contract/private/list.rkt:680:9 add-list-context [187] 58.8% get/build-late-neg-projection [190] 21.6% ---------------------------------------------------------------------------- copying-mergesort [181] 25.1% generic-sort/key [174] 74.9% [181] 666(0.6%) 0(0.0%) copying-mergesort ...racket/private/sort.rkt:130:8 loop [186] 74.9% copying-mergesort [181] 25.1% ---------------------------------------------------------------------------- ??? [172] 100.0% [182] 360(0.3%) 360(0.3%) ??? ...ects/racket/contract/private/prop.rkt:256:4 ---------------------------------------------------------------------------- sidx->spoint [169] 100.0% [183] 360(0.3%) 0(0.0%) binary-search-floats ...velop/src/common.rkt:241:0 pred [185] 100.0% ---------------------------------------------------------------------------- for-loop [176] 100.0% [184] 338(0.3%) 338(0.3%) for-loop ...bie/develop/src/core/regimes.rkt:241:8 ---------------------------------------------------------------------------- binary-search-floats [183] 6.7% binary-search [178] 93.3% [185] 5376(4.6%) 0(0.0%) pred ...herbie/develop/src/core/regimes.rkt:132:17 loop [38] 69.0% errors [47] 31.0% ---------------------------------------------------------------------------- generic-sort/key [174] 33.1% copying-mergesort [181] 66.9% [186] 996(0.9%) 0(0.0%) loop ...ket/collects/racket/private/sort.rkt:97:12 ??? [3] 66.5% ??? [191] 33.5% ---------------------------------------------------------------------------- for-loop [180] 100.0% [187] 976(0.8%) 976(0.8%) add-list-context ...ontract/private/list.rkt:752:0 ---------------------------------------------------------------------------- ??? [179] 49.7% location-do [55] 50.3% [188] 712(0.6%) 712(0.6%) dict? ...ollects/racket/private/generic.rkt:146:11 ---------------------------------------------------------------------------- ??? [179] 100.0% [189] 358(0.3%) 358(0.3%) contract? ...acket/contract/private/guts.rkt:109:0 ---------------------------------------------------------------------------- for-loop [180] 100.0% [190] 358(0.3%) 358(0.3%) get/build-late-neg-projection ...te/guts.rkt:691:0 ---------------------------------------------------------------------------- loop [186] 100.0% [191] 334(0.3%) 334(0.3%) ??? ...tract/private/arrow-higher-order.rkt:145:21 ----------------------------------------------------------------------------