Profiling results ----------------- Total cpu time observed: 142806ms (out of 143444ms) Number of samples taken: 427 (once every 334ms) (Hiding functions with self<1.0% and local<2.0%: 8 of 194 hidden) ========================================================================================= Caller Idx Total Self Name+src Local% ms(pct) ms(pct) Callee ========================================================================================= ??? [37] 100.0% [1] 124334(87.1%) 0(0.0%) profile-thunk16 ...t/pkgs/profile-lib/main.rkt:9:0 run [10] 100.0% ----------------------------------------------------------------------------------------- ??? [37] 100.0% [2] 117964(82.6%) 0(0.0%) run-improve50 ...ie/develop/src/mainloop.rkt:234:0 for-loop [11] 95.7% get-final-combination [13] 4.3% ----------------------------------------------------------------------------------------- ->flonum [67] 100.0% [3] 12646(8.9%) 0(0.0%) loop ...herbie/develop/src/core/simplify.rkt:237:2 pass [12] 100.0% ----------------------------------------------------------------------------------------- ??? [65] 100.0% [4] 1010(0.7%) 0(0.0%) approximate9 ...e/develop/src/core/taylor.rkt:12:0 loop [14] 100.0% ----------------------------------------------------------------------------------------- hash-ref! [68] 100.0% [5] 676(0.5%) 0(0.0%) ??? ...s/herbie/develop/src/core/taylor.rkt:295:23 for-loop [15] 100.0% ----------------------------------------------------------------------------------------- copying-mergesort [168] 100.0% [6] 672(0.5%) 0(0.0%) jloop ...t/collects/racket/private/sort.rkt:121:23 ??? [65] 53.6% ??? [176] 46.4% ----------------------------------------------------------------------------------------- loop [123] 100.0% [7] 664(0.5%) 0(0.0%) ??? ...ket/collects/racket/private/list.rkt:323:18 hash-ref! [68] 50.0% map [63] 50.0% ----------------------------------------------------------------------------------------- hash-ref! [68] 100.0% [8] 334(0.2%) 0(0.0%) ??? ...s/herbie/develop/src/core/taylor.rkt:338:33 hash-ref! [68] 50.0% for-loop [16] 50.0% ----------------------------------------------------------------------------------------- hash-ref! [68] 100.0% [9] 326(0.2%) 0(0.0%) ??? ...s/herbie/develop/src/core/taylor.rkt:392:23 for-loop [17] 100.0% ----------------------------------------------------------------------------------------- profile-thunk16 [1] 100.0% [10] 124334(87.1%) 0(0.0%) run ...share/racket/pkgs/profile-lib/main.rkt:39:2 ??? [37] 100.0% ----------------------------------------------------------------------------------------- run-improve50 [2] 100.0% [11] 112880(79.0%) 0(0.0%) for-loop ...herbie/develop/src/mainloop.rkt:249:10 run-iter! [18] 100.0% ----------------------------------------------------------------------------------------- loop [3] 100.0% [12] 12646(8.9%) 332(0.2%) pass ...herbie/develop/src/core/simplify.rkt:227:2 for-loop [19] 97.4% ----------------------------------------------------------------------------------------- run-improve50 [2] 100.0% [13] 5084(3.6%) 0(0.0%) get-final-combination ...op/src/mainloop.rkt:264:0 split-table [20] 94.2% extract-alt [22] 5.8% ----------------------------------------------------------------------------------------- approximate9 [4] 100.0% [14] 1010(0.7%) 0(0.0%) loop ...es/herbie/develop/src/core/taylor.rkt:86:4 ??? [65] 100.0% ----------------------------------------------------------------------------------------- ??? [5] 100.0% [15] 676(0.5%) 0(0.0%) for-loop ...bie/develop/src/core/taylor.rkt:298:27 hash-ref! [68] 100.0% ----------------------------------------------------------------------------------------- ??? [8] 100.0% [16] 334(0.2%) 0(0.0%) for-loop ...bie/develop/src/core/taylor.rkt:341:46 hash-ref! [68] 100.0% ----------------------------------------------------------------------------------------- ??? [9] 100.0% [17] 326(0.2%) 0(0.0%) for-loop ...bie/develop/src/core/taylor.rkt:396:33 for-loop [21] 100.0% ----------------------------------------------------------------------------------------- for-loop [11] 100.0% [18] 112880(79.0%) 0(0.0%) run-iter! ...herbie/develop/src/mainloop.rkt:215:0 simplify! [23] 86.8% finalize-iter! [24] 10.8% gen-series! [27] 1.2% localize-error [28] 0.6% gen-rewrites! [29] 0.3% ----------------------------------------------------------------------------------------- pass [12] 100.0% [19] 12314(8.6%) 646(0.5%) for-loop ...e/develop/src/core/simplify.rkt:230:29 argmin [25] 73.7% loop [26] 21.0% ----------------------------------------------------------------------------------------- get-final-combination [13] 100.0% [20] 4788(3.4%) 0(0.0%) split-table ...s/herbie/develop/src/glue.rkt:162:0 f137 [60] 100.0% ----------------------------------------------------------------------------------------- for-loop [17] 100.0% [21] 326(0.2%) 0(0.0%) for-loop ...bie/develop/src/core/taylor.rkt:398:39 hash-ref! [68] 100.0% ----------------------------------------------------------------------------------------- get-final-combination [13] 100.0% [22] 296(0.2%) 0(0.0%) extract-alt ...es/herbie/develop/src/glue.rkt:55:0 loop [30] 100.0% ----------------------------------------------------------------------------------------- run-iter! [18] 100.0% [23] 98028(68.6%) 0(0.0%) simplify! ...herbie/develop/src/mainloop.rkt:155:0 for-loop [31] 100.0% ----------------------------------------------------------------------------------------- run-iter! [18] 100.0% [24] 12202(8.5%) 0(0.0%) finalize-iter! ...e/develop/src/mainloop.rkt:169:0 ??? [32] 100.0% ----------------------------------------------------------------------------------------- for-loop [19] 100.0% [25] 9076(6.4%) 0(0.0%) argmin ...re/racket/collects/racket/list.rkt:743:0 for-loop [33] 92.6% expression-cost [35] 7.4% ----------------------------------------------------------------------------------------- for-loop [19] 100.0% [26] 2592(1.8%) 0(0.0%) loop ...hare/racket/collects/racket/list.rkt:729:4 for-loop [33] 100.0% ----------------------------------------------------------------------------------------- run-iter! [18] 100.0% [27] 1346(0.9%) 0(0.0%) gen-series! ...rbie/develop/src/mainloop.rkt:129:0 for-loop [34] 100.0% ----------------------------------------------------------------------------------------- run-iter! [18] 100.0% [28] 664(0.5%) 0(0.0%) localize-error ...velop/src/core/localize.rkt:47:0 hash-ref! [68] 100.0% ----------------------------------------------------------------------------------------- run-iter! [18] 100.0% [29] 320(0.2%) 0(0.0%) gen-rewrites! ...ie/develop/src/mainloop.rkt:142:0 for-loop [36] 100.0% ----------------------------------------------------------------------------------------- extract-alt [22] 100.0% [30] 296(0.2%) 0(0.0%) loop ...htlies/herbie/develop/src/common.rkt:153:2 composed [83] 100.0% ----------------------------------------------------------------------------------------- simplify! [23] 100.0% [31] 98028(68.6%) 0(0.0%) for-loop .../herbie/develop/src/mainloop.rkt:159:6 ??? [37] 100.0% ----------------------------------------------------------------------------------------- ??? [164] 0.7% substitute-e [95] 3.1% get-sigs [120] 6.2% variable? [102] 13.3% match-e [89] 19.8% finalize-iter! [24] 55.4% [32] 21742(15.2%) 4840(3.4%) ??? ...contract/private/arrow-val-first.rkt:357:18 for-loop [38] 55.4% hash-has-key? [39] 20.8% ??? [42] 1.5% ----------------------------------------------------------------------------------------- loop [26] 23.6% argmin [25] 76.4% [33] 11000(7.7%) 0(0.0%) for-loop .../herbie/develop/src/programs.rkt:210:2 ->flonum [67] 65.5% ...velop/src/common.rkt:47:2 [125] 31.2% ??? [124] 3.3% ----------------------------------------------------------------------------------------- gen-series! [27] 100.0% [34] 1346(0.9%) 0(0.0%) for-loop .../herbie/develop/src/mainloop.rkt:135:7 taylor-alt [40] 100.0% ----------------------------------------------------------------------------------------- argmin [25] 100.0% [35] 668(0.5%) 0(0.0%) expression-cost .../develop/src/programs.rkt:209:0 compile [41] 100.0% ----------------------------------------------------------------------------------------- gen-rewrites! [29] 100.0% [36] 320(0.2%) 0(0.0%) for-loop ...herbie/develop/src/mainloop.rkt:147:11 ??? [43] 100.0% ----------------------------------------------------------------------------------------- for-loop [31] 23.1% run [10] 32.4% [37] 141806(99.3%) 0(0.0%) ??? ...lects/racket/private/more-scheme.rkt:261:28 ->flonum [67] 35.0% profile-thunk16 [1] 32.4% run-improve50 [2] 30.2% prepare-points [45] 2.3% loop [48] 0.1% ----------------------------------------------------------------------------------------- ??? [32] 100.0% [38] 12202(8.5%) 0(0.0%) for-loop ...ie/develop/src/core/alt-table.rkt:51:2 atab-add-altn [44] 100.0% ----------------------------------------------------------------------------------------- mk-enode! [99] 11.9% ??? [32] 88.1% [39] 5316(3.7%) 3280(2.3%) hash-has-key? ...et/private/more-scheme.rkt:368:13 ??? [72] 38.3% ----------------------------------------------------------------------------------------- for-loop [34] 100.0% [40] 1346(0.9%) 0(0.0%) taylor-alt ...es/herbie/develop/src/glue.rkt:134:0 for-loop [46] 100.0% ----------------------------------------------------------------------------------------- expression-cost [35] 100.0% [41] 668(0.5%) 0(0.0%) compile ...s/herbie/develop/src/programs.rkt:186:0 hash-ref! [68] 100.0% ----------------------------------------------------------------------------------------- ??? [32] 100.0% [42] 320(0.2%) 0(0.0%) ??? .../herbie/develop/src/core/alt-table.rkt:54:0 ??? [65] 100.0% ----------------------------------------------------------------------------------------- for-loop [36] 100.0% [43] 320(0.2%) 0(0.0%) ??? ...ies/herbie/develop/src/alternative.rkt:88:0 rewriter [47] 100.0% ----------------------------------------------------------------------------------------- for-loop [38] 100.0% [44] 12202(8.5%) 0(0.0%) atab-add-altn ...elop/src/core/alt-table.rkt:208:0 best-and-tied-at-points [49] 97.3% override-at-pnts [51] 2.7% ----------------------------------------------------------------------------------------- ??? [37] 100.0% [45] 6664(4.7%) 0(0.0%) prepare-points ...bie/develop/src/points.rkt:214:0 loop [56] 34.6% make-exacts* [55] 33.2% loop [50] 32.2% ----------------------------------------------------------------------------------------- taylor-alt [40] 100.0% [46] 1346(0.9%) 0(0.0%) for-loop ...lies/herbie/develop/src/glue.rkt:139:6 ??? [65] 100.0% ----------------------------------------------------------------------------------------- matcher [57] 50.0% ??? [43] 50.0% [47] 320(0.2%) 0(0.0%) rewriter ...bie/develop/src/core/matcher.rkt:131:2 for-loop [53] 50.0% *rules* [52] 50.0% ----------------------------------------------------------------------------------------- ??? [37] 100.0% [48] 312(0.2%) 0(0.0%) loop ...htlies/herbie/develop/src/points.rkt:238:2 make-exacts* [55] 100.0% ----------------------------------------------------------------------------------------- atab-add-altn [44] 100.0% [49] 11868(8.3%) 326(0.2%) best-and-tied-at-points ...ore/alt-table.rkt:122:0 errors [54] 97.3% ----------------------------------------------------------------------------------------- prepare-points [45] 100.0% [50] 2146(1.5%) 0(0.0%) loop ...htlies/herbie/develop/src/points.rkt:158:2 make-exacts* [55] 54.1% loop [56] 45.9% ----------------------------------------------------------------------------------------- atab-add-altn [44] 100.0% [51] 334(0.2%) 334(0.2%) override-at-pnts ...p/src/core/alt-table.rkt:145:0 ----------------------------------------------------------------------------------------- rewriter [47] 100.0% [52] 320(0.2%) 0(0.0%) *rules* ...rbie/develop/src/syntax/rules.rkt:565:0 for-loop [108] 100.0% ----------------------------------------------------------------------------------------- rewriter [47] 100.0% [53] 320(0.2%) 0(0.0%) for-loop ...ie/develop/src/core/matcher.rkt:134:10 matcher [57] 100.0% ----------------------------------------------------------------------------------------- composed [83] 4.4% loop [123] 4.5% option-on-expr [130] 9.0% best-and-tied-at-points [49] 82.1% [54] 14056(9.8%) 0(0.0%) errors ...lies/herbie/develop/src/points.rkt:271:0 for-loop [58] 81.0% eval-prog [59] 19.0% ----------------------------------------------------------------------------------------- loop [48] 8.5% loop [50] 31.5% prepare-points [45] 60.0% [55] 3684(2.6%) 0(0.0%) make-exacts* ...erbie/develop/src/points.rkt:138:0 loop [123] 91.5% eval-prog [59] 8.5% ----------------------------------------------------------------------------------------- loop [50] 29.9% prepare-points [45] 70.1% [56] 3292(2.3%) 0(0.0%) loop ...htlies/herbie/develop/src/points.rkt:141:4 loop [123] 100.0% ----------------------------------------------------------------------------------------- matcher [57] 50.0% for-loop [53] 50.0% [57] 320(0.2%) 0(0.0%) matcher ...rbie/develop/src/core/matcher.rkt:167:2 matcher [57] 50.0% rewriter [47] 50.0% ----------------------------------------------------------------------------------------- errors [54] 100.0% [58] 11382(8.0%) 1290(0.9%) for-loop ...es/herbie/develop/src/points.rkt:274:4 ??? [176] 77.4% ??? [65] 5.7% ulp-difference [62] 5.6% ----------------------------------------------------------------------------------------- make-exacts* [55] 10.4% errors [54] 89.6% [59] 2986(2.1%) 680(0.5%) eval-prog ...herbie/develop/src/programs.rkt:150:0 f137 [60] 54.3% ??? [61] 22.9% ----------------------------------------------------------------------------------------- map [63] 2.1% simplify [73] 4.2% eval-prog [59] 5.6% parse-loop12 [122] 6.2% eval-const-expr [147] 8.2% f137 [60] 14.5% split-table [20] 59.2% [60] 8088(5.7%) 350(0.2%) f137 .../collects/racket/match/compiler.rkt:507:40 loop [123] 47.7% f137 [60] 14.5% option-on-expr [130] 11.4% map [63] 10.3% ??? [65] 5.6% ->flonum [67] 4.3% ...velop/src/common.rkt:47:2 [125] 4.0% ----------------------------------------------------------------------------------------- eval-prog [59] 100.0% [61] 684(0.5%) 0(0.0%) ??? ...cket/collects/racket/private/kw.rkt:1633:36 unpack245 [64] 100.0% ----------------------------------------------------------------------------------------- for-loop [58] 100.0% [62] 634(0.4%) 302(0.2%) ulp-difference ...erbie/develop/src/float.rkt:19:0 return/no-unsupplied [146] 52.4% ----------------------------------------------------------------------------------------- ??? [7] 24.7% f137 [60] 75.3% [63] 1344(0.9%) 0(0.0%) map ...acket/collects/racket/private/map.rkt:20:13 parse-loop12 [122] 62.8% ??? [65] 24.7% f137 [60] 12.5% ----------------------------------------------------------------------------------------- ??? [61] 100.0% [64] 684(0.5%) 0(0.0%) unpack245 ...private/arrow-higher-order.rkt:354:44 maybe-cons-kwd [66] 100.0% ----------------------------------------------------------------------------------------- ??? [42] 5.1% map [63] 5.3% loop [14] 5.4% jloop [6] 5.8% loop [123] 6.0% ->flonum [67] 8.1% for-loop [46] 8.1% for-loop [58] 10.4% ??? [176] 19.9% f137 [60] 26.0% [65] 6248(4.4%) 0(0.0%) ??? ...tract/private/arrow-higher-order.rkt:342:33 ->flonum [67] 60.8% ??? [124] 5.5% approximate9 [4] 5.4% hash-ref! [68] 5.4% ...velop/src/common.rkt:47:2 [125] 5.2% best-alt [69] 5.1% ??? [179] 5.0% ??? [164] 4.8% simplify [73] 2.7% ----------------------------------------------------------------------------------------- unpack245 [64] 100.0% [66] 684(0.5%) 0(0.0%) maybe-cons-kwd ...ate/arrow-higher-order.rkt:498:0 successfully-got-the-right-kind-of-function [87]100.0% ----------------------------------------------------------------------------------------- f137 [60] 0.1% get-sigs [120] 2.0% for-loop [33] 2.0% ??? [65] 3.4% ->flonum [67] 16.9% for-loop [71] 29.4% ??? [37] 46.3% [67] 119536(83.7%) 4624(3.2%) ->flonum ...s/racket/private/norm-define.rkt:53:83 iterate-egraph!13 [70] 41.2% for-loop [71] 29.6% ->flonum [67] 16.9% loop [3] 4.3% ??? [72] 2.7% ??? [144] 0.9% return/no-unsupplied [146] 0.6% ??? [65] 0.6% list-member? [96] 0.3% *simplify-rules* [78] 0.3% mk-egraph [76] 0.2% ----------------------------------------------------------------------------------------- for-loop [21] 3.0% for-loop [16] 3.1% ??? [8] 3.1% ??? [7] 6.2% for-loop [15] 7.4% compile [41] 8.5% ??? [74] 10.5% ??? [65] 10.5% simplify* [127] 12.5% ??? [75] 16.4% localize-error [28] 18.6% [68] 2678(1.9%) 690(0.5%) hash-ref! ...racket/private/more-scheme.rkt:373:13 parse-loop12 [122] 24.8% ??? [75] 22.3% ??? [74] 10.5% simplify [73] 10.5% ??? [5] 7.4% ??? [8] 6.2% ??? [9] 3.0% ----------------------------------------------------------------------------------------- ??? [65] 100.0% [69] 320(0.2%) 0(0.0%) best-alt ...tlies/herbie/develop/src/glue.rkt:71:0 argmins [77] 100.0% ----------------------------------------------------------------------------------------- ->flonum [67] 100.0% [70] 100994(70.7%) 0(0.0%) iterate-egraph!13 ...p/src/core/simplify.rkt:105:0 one-iter [79] 98.1% map-enodes [81] 1.6% ----------------------------------------------------------------------------------------- ->flonum [67] 100.0% [71] 73024(51.1%) 0(0.0%) for-loop ...ie/develop/src/core/simplify.rkt:66:12 ->flonum [67] 99.6% ??? [137] 0.4% ----------------------------------------------------------------------------------------- hash-has-key? [39] 17.3% ->flonum [67] 82.7% [72] 11736(8.2%) 3524(2.5%) ??? ...ects/racket/contract/private/list.rkt:737:4 for-loop [80] 47.4% ??? [86] 16.7% successfully-got-the-right-kind-of-function [87] 3.1% ??? [140] 2.8% ----------------------------------------------------------------------------------------- ??? [65] 25.0% hash-ref! [68] 75.0% [73] 1346(0.9%) 0(0.0%) simplify ...erbie/develop/src/core/reduce.rkt:16:0 f137 [60] 51.0% parse-loop12 [122] 49.0% ----------------------------------------------------------------------------------------- hash-ref! [68] 100.0% [74] 1010(0.7%) 0(0.0%) ??? ...es/herbie/develop/src/core/taylor.rkt:44:15 hash-ref! [68] 100.0% ----------------------------------------------------------------------------------------- hash-ref! [68] 100.0% [75] 668(0.5%) 314(0.2%) ??? ...tlies/herbie/develop/src/programs.rkt:194:5 hash-ref! [68] 76.5% ----------------------------------------------------------------------------------------- ->flonum [67] 100.0% [76] 630(0.4%) 0(0.0%) mk-egraph ...bie/develop/src/core/egraph.rkt:131:0 mk-enode-rec! [82] 100.0% ----------------------------------------------------------------------------------------- best-alt [69] 100.0% [77] 320(0.2%) 0(0.0%) argmins ...ies/herbie/develop/src/common.rkt:152:0 composed [83] 100.0% ----------------------------------------------------------------------------------------- ->flonum [67] 100.0% [78] 312(0.2%) 0(0.0%) *simplify-rules* ...lop/src/syntax/rules.rkt:570:0 for-loop [108] 100.0% ----------------------------------------------------------------------------------------- iterate-egraph!13 [70] 100.0% [79] 99040(69.4%) 2048(1.4%) one-iter ...ie/develop/src/core/simplify.rkt:116:0 for-loop [84] 58.2% for-loop [85] 39.4% ----------------------------------------------------------------------------------------- ??? [72] 100.0% [80] 5568(3.9%) 1322(0.9%) for-loop ...acket/contract/private/list.rkt:743:12 ??? [86] 53.3% for-loop [132] 16.9% successfully-got-the-right-kind-of-function [87] 6.0% ----------------------------------------------------------------------------------------- iterate-egraph!13 [70] 100.0% [81] 1654(1.2%) 0(0.0%) map-enodes ...ie/develop/src/core/egraph.rkt:140:0 loop [123] 100.0% ----------------------------------------------------------------------------------------- mk-enode-rec! [82] 24.4% mk-egraph [76] 75.6% [82] 630(0.4%) 0(0.0%) mk-enode-rec! ...develop/src/core/egraph.rkt:122:0 mk-enode! [99] 75.6% mk-enode-rec! [82] 24.4% ----------------------------------------------------------------------------------------- loop [30] 48.1% argmins [77] 51.9% [83] 616(0.4%) 0(0.0%) composed ...ollects/racket/private/list.rkt:321:16 errors [54] 100.0% ----------------------------------------------------------------------------------------- one-iter [79] 100.0% [84] 57622(40.3%) 0(0.0%) for-loop ...ie/develop/src/core/simplify.rkt:166:2 for-loop [88] 82.1% match-e [89] 13.2% update-leader! [101] 4.1% reduce-to-single! [92] 0.6% ----------------------------------------------------------------------------------------- for-loop [85] 48.4% one-iter [79] 51.6% [85] 39060(27.4%) 8156(5.7%) for-loop ...e/develop/src/core/simplify.rkt:126:12 for-loop [85] 48.4% match-e [89] 39.6% ----------------------------------------------------------------------------------------- ??? [72] 39.8% for-loop [80] 60.2% [86] 4930(3.5%) 2598(1.8%) ??? ...private/unconstrained-domain-arrow.rkt:74:4 make-keyword-procedure [90] 47.3% ----------------------------------------------------------------------------------------- for-loop [80] 24.4% ??? [72] 26.0% maybe-cons-kwd [66] 49.6% [87] 1378(1.0%) 1042(0.7%) successfully-got-the-right-kind-of-function ...9:4 arity-checking-wrapper [91] 24.4% ----------------------------------------------------------------------------------------- for-loop [84] 100.0% [88] 47334(33.1%) 344(0.2%) for-loop ...e/develop/src/core/simplify.rkt:148:10 mk-enode! [99] 29.8% merge-egraph-nodes! [94] 29.1% loop! [128] 23.2% substitute-e [95] 14.4% list-member? [96] 2.7% ----------------------------------------------------------------------------------------- for-loop [84] 12.5% for-loop [100] 22.9% for-loop [85] 64.6% [89] 38532(27.0%) 16068(11.3%) match-e ...herbie/develop/src/core/ematch.rkt:46:0 for-loop [93] 40.2% for-loop [100] 8.2% ??? [32] 5.3% list-cartesian-product [103] 4.0% variable? [102] 3.6% loop [123] 2.1% ----------------------------------------------------------------------------------------- ??? [86] 100.0% [90] 2332(1.6%) 2332(1.6%) make-keyword-procedure ...ket/private/kw.rkt:260:4 ----------------------------------------------------------------------------------------- successfully-got-the-right-kind-of-function [87]100.0% [91] 336(0.2%) 0(0.0%) arity-checking-wrapper ...w-higher-order.rkt:402:0 matches-arity-exactly? [97] 100.0% ----------------------------------------------------------------------------------------- for-loop [84] 100.0% [92] 326(0.2%) 0(0.0%) reduce-to-single! ...lop/src/core/egraph.rkt:325:0 filter-loop! [98] 100.0% ----------------------------------------------------------------------------------------- match-e [89] 100.0% [93] 20410(14.3%) 5974(4.2%) for-loop ...rbie/develop/src/core/ematch.rkt:59:11 for-loop [100] 58.7% list-cartesian-product [103] 7.1% loop [123] 5.1% curried [174] 1.6% foldl [136] 1.6% ----------------------------------------------------------------------------------------- merge-egraph-nodes! [94] 4.6% for-loop [104] 4.7% for-loop [88] 90.7% [94] 13786(9.7%) 322(0.2%) merge-egraph-nodes! ...p/src/core/egraph.rkt:153:0 update-leader! [101] 45.7% loop! [128] 18.9% for-loop [105] 10.6% for-loop [104] 8.2% enode-merge! [107] 7.1% merge-egraph-nodes! [94] 4.6% for-loop [108] 2.5% ----------------------------------------------------------------------------------------- substitute-e [95] 9.5% for-loop [88] 90.5% [95] 6828(4.8%) 312(0.2%) substitute-e ...e/develop/src/core/ematch.rkt:71:0 mk-enode! [99] 81.0% substitute-e [95] 9.5% ??? [32] 5.0% variable? [102] 2.2% ----------------------------------------------------------------------------------------- ->flonum [67] 20.7% for-loop [88] 79.3% [96] 1606(1.1%) 332(0.2%) list-member? ...llects/racket/private/set.rkt:24:0 loop [106] 79.3% ----------------------------------------------------------------------------------------- arity-checking-wrapper [91] 100.0% [97] 336(0.2%) 336(0.2%) matches-arity-exactly? ...te/arrow-common.rkt:70:0 ----------------------------------------------------------------------------------------- filter-loop! [98] 50.0% reduce-to-single! [92] 50.0% [98] 326(0.2%) 326(0.2%) filter-loop! ...e/develop/src/core/enode.rkt:143:2 filter-loop! [98] 50.0% ----------------------------------------------------------------------------------------- mk-enode-rec! [82] 3.1% substitute-e [95] 27.3% for-loop [88] 69.6% [99] 20264(14.2%) 670(0.5%) mk-enode! ...bie/develop/src/core/egraph.rkt:102:0 new-enode [109] 92.0% hash-has-key? [39] 3.1% mutable-set [115] 1.6% ----------------------------------------------------------------------------------------- match-e [89] 29.3% for-loop [93] 70.7% [100] 17712(12.4%) 1348(0.9%) for-loop ...rbie/develop/src/core/ematch.rkt:65:37 match-e [89] 90.3% ??? [112] 3.9% ----------------------------------------------------------------------------------------- for-loop [84] 26.0% merge-egraph-nodes! [94] 74.0% [101] 8962(6.3%) 1320(0.9%) update-leader! ...evelop/src/core/egraph.rkt:218:0 for-loop [110] 85.3% ----------------------------------------------------------------------------------------- substitute-e [95] 8.8% match-e [89] 91.2% [102] 3494(2.4%) 606(0.4%) variable? ...e/develop/src/syntax/syntax.rkt:665:0 ??? [32] 82.7% ----------------------------------------------------------------------------------------- list-cartesian-product [103] 30.0% match-e [89] 31.2% for-loop [93] 38.8% [103] 3296(2.3%) 1980(1.4%) list-cartesian-product ...src/core/ematch.rkt:20:0 for-loop [111] 34.5% list-cartesian-product [103] 30.0% ----------------------------------------------------------------------------------------- merge-egraph-nodes! [94] 100.0% [104] 1938(1.4%) 0(0.0%) for-loop ...bie/develop/src/core/egraph.rkt:201:10 merge-egraph-nodes! [94] 66.4% loop! [128] 33.6% ----------------------------------------------------------------------------------------- merge-egraph-nodes! [94] 100.0% [105] 1608(1.1%) 1608(1.1%) for-loop ...rbie/develop/src/core/egraph.rkt:233:6 ----------------------------------------------------------------------------------------- list-member? [96] 100.0% [106] 1274(0.9%) 1274(0.9%) loop (unknown source) ----------------------------------------------------------------------------------------- merge-egraph-nodes! [94] 100.0% [107] 982(0.7%) 306(0.2%) enode-merge! ...e/develop/src/core/enode.rkt:129:0 adopt-enode! [113] 68.8% ----------------------------------------------------------------------------------------- *simplify-rules* [78] 32.0% *rules* [52] 32.8% merge-egraph-nodes! [94] 35.2% [108] 976(0.7%) 656(0.5%) for-loop ...ies/herbie/develop/src/common.rkt:99:9 loop [114] 32.8% ----------------------------------------------------------------------------------------- mk-enode! [99] 100.0% [109] 18642(13.1%) 670(0.5%) new-enode ...erbie/develop/src/core/enode.rkt:97:0 type-of-enode-expr [116] 94.5% set [141] 1.9% ----------------------------------------------------------------------------------------- update-leader! [101] 100.0% [110] 7642(5.4%) 1308(0.9%) for-loop ...rbie/develop/src/core/egraph.rkt:223:6 for-loop [117] 82.9% ----------------------------------------------------------------------------------------- list-cartesian-product [103] 100.0% [111] 1316(0.9%) 1316(0.9%) for-loop ...erbie/develop/src/core/ematch.rkt:24:8 ----------------------------------------------------------------------------------------- for-loop [100] 100.0% [112] 696(0.5%) 696(0.5%) ??? ...ies/herbie/develop/src/core/ematch.rkt:50:5 ----------------------------------------------------------------------------------------- enode-merge! [107] 100.0% [113] 676(0.5%) 0(0.0%) adopt-enode! ...e/develop/src/core/enode.rkt:105:0 custom-set-union [139] 100.0% ----------------------------------------------------------------------------------------- for-loop [108] 100.0% [114] 320(0.2%) 0(0.0%) loop ...ket/collects/racket/private/map.rkt:112:23 flag-set? [118] 100.0% ----------------------------------------------------------------------------------------- mk-enode! [99] 100.0% [115] 318(0.2%) 0(0.0%) mutable-set .../racket/private/set-types.rkt:999:0 for-loop [119] 100.0% ----------------------------------------------------------------------------------------- new-enode [109] 100.0% [116] 17612(12.3%) 0(0.0%) type-of-enode-expr ...elop/src/core/enode.rkt:68:0 get-sigs [120] 98.1% parse-loop12 [122] 1.9% ----------------------------------------------------------------------------------------- for-loop [110] 100.0% [117] 6334(4.4%) 0(0.0%) for-loop ...rbie/develop/src/core/egraph.rkt:224:8 hash-update! [121] 100.0% ----------------------------------------------------------------------------------------- loop [114] 100.0% [118] 320(0.2%) 320(0.2%) flag-set? ...es/herbie/develop/src/config.rkt:34:0 ----------------------------------------------------------------------------------------- mutable-set [115] 100.0% [119] 318(0.2%) 318(0.2%) for-loop ...cts/racket/private/set-types.rkt:943:2 ----------------------------------------------------------------------------------------- type-of-enode-expr [116] 100.0% [120] 17278(12.1%) 308(0.2%) get-sigs .../herbie/develop/src/type-check.rkt:5:0 ->flonum [67] 41.2% ??? [124] 35.9% ...velop/src/common.rkt:47:2 [125] 13.3% ??? [32] 7.8% ----------------------------------------------------------------------------------------- for-loop [117] 100.0% [121] 6334(4.4%) 0(0.0%) hash-update! ...ket/private/more-scheme.rkt:362:13 ??? [126] 100.0% ----------------------------------------------------------------------------------------- parse-loop12 [122] 7.0% type-of-enode-expr [116] 14.2% simplify [73] 17.7% hash-ref! [68] 28.3% map [63] 32.7% [122] 2344(1.6%) 994(0.7%) parse-loop12 ...s/racket/match/compiler.rkt:418:15 loop [123] 28.3% f137 [60] 18.4% simplify* [127] 14.3% parse-loop12 [122] 7.0% ----------------------------------------------------------------------------------------- make-exacts* [55] 0.0% loop [56] 0.1% parse-loop12 [122] 0.1% option-on-expr [130] 2.0% map-enodes [81] 2.6% for-loop [93] 4.0% match-e [89] 4.1% loop! [128] 8.0% f137 [60] 16.0% loop [123] 63.0% [123] 23126(16.2%) 358(0.3%) loop ...cket/collects/racket/private/map.rkt:25:19 loop [123] 63.0% option-on-expr [130] 16.0% loop! [128] 8.0% foldl [136] 3.6% curried [174] 2.7% for-loop [135] 2.6% errors [54] 2.0% ??? [176] 0.1% ??? [7] 0.1% ??? [180] 0.0% ??? [65] 0.0% ??? [137] 0.0% ----------------------------------------------------------------------------------------- ??? [65] 5.0% for-loop [33] 5.3% get-sigs [120] 89.7% [124] 6922(4.8%) 1026(0.7%) ??? ...ts/racket/contract/private/arr-i.rkt:804:10 ??? [131] 56.9% for-loop [132] 28.3% ----------------------------------------------------------------------------------------- f137 [60] 5.0% ??? [65] 5.1% get-sigs [120] 36.0% for-loop [33] 53.8% [125] 6378(4.5%) 2328(1.6%) ...velop/src/common.rkt:47:2 ...e/arr-i.rkt:906:19 ??? [133] 36.1% ??? [134] 27.4% ----------------------------------------------------------------------------------------- hash-update! [121] 100.0% [126] 6334(4.4%) 0(0.0%) ??? ...s/herbie/develop/src/core/egraph.rkt:226:24 for-loop [129] 94.8% make-sequence [138] 5.2% ----------------------------------------------------------------------------------------- parse-loop12 [122] 100.0% [127] 336(0.2%) 0(0.0%) simplify* ...rbie/develop/src/core/reduce.rkt:31:0 hash-ref! [68] 100.0% ----------------------------------------------------------------------------------------- for-loop [104] 3.3% merge-egraph-nodes! [94] 18.2% loop [123] 26.7% for-loop [88] 51.8% [128] 14902(10.4%) 2672(1.9%) loop! ...s/herbie/develop/src/core/enode.rkt:192:2 custom-set-union [139] 49.9% loop [123] 26.7% set [141] 9.6% update-en-expr [143] 5.5% ----------------------------------------------------------------------------------------- ??? [126] 100.0% [129] 6002(4.2%) 4960(3.5%) for-loop ...bie/develop/src/core/egraph.rkt:227:26 update-en-expr [143] 17.4% ----------------------------------------------------------------------------------------- f137 [60] 19.3% loop [123] 80.7% [130] 4788(3.4%) 0(0.0%) option-on-expr ...evelop/src/core/regimes.rkt:83:0 sort-context-on-expr [145] 40.8% errors [54] 26.4% err-lsts->split-indices [148] 19.5% loop [123] 13.2% ----------------------------------------------------------------------------------------- ??? [124] 100.0% [131] 3936(2.8%) 666(0.5%) ??? ...ects/racket/contract/private/hash.rkt:217:4 ??? [142] 83.1% ----------------------------------------------------------------------------------------- for-loop [80] 32.5% ??? [124] 67.5% [132] 2902(2.0%) 964(0.7%) for-loop ...racket/contract/private/hash.rkt:239:6 ??? [140] 66.8% ----------------------------------------------------------------------------------------- ...velop/src/common.rkt:47:2 [125] 100.0% [133] 2302(1.6%) 360(0.3%) ??? ...s/racket/contract/private/arr-i.rkt:1268:39 ??? [144] 44.1% return/no-unsupplied [146] 26.3% assoc-ref [151] 13.9% ----------------------------------------------------------------------------------------- ??? [140] 40.2% ...velop/src/common.rkt:47:2 [125] 59.8% [134] 1748(1.2%) 348(0.2%) ??? ...ects/racket/contract/private/list.rkt:342:4 ??? [140] 59.8% ??? [164] 30.2% ----------------------------------------------------------------------------------------- loop [123] 100.0% [135] 1654(1.2%) 342(0.2%) for-loop ...ie/develop/src/core/simplify.rkt:195:2 eval-const-expr [147] 59.7% setfindf [150] 19.6% ----------------------------------------------------------------------------------------- for-loop [93] 24.3% loop [123] 75.7% [136] 1332(0.9%) 1008(0.7%) foldl ...et/collects/racket/private/list.rkt:229:4 merge2 [149] 24.3% ----------------------------------------------------------------------------------------- for-loop [71] 48.9% loop [123] 51.1% [137] 638(0.4%) 312(0.2%) ??? ...tract/private/arrow-higher-order.rkt:145:21 ??? [159] 51.1% ----------------------------------------------------------------------------------------- ??? [126] 100.0% [138] 332(0.2%) 332(0.2%) make-sequence ...ects/racket/private/for.rkt:509:2 ----------------------------------------------------------------------------------------- adopt-enode! [113] 8.2% loop! [128] 91.8% [139] 8282(5.8%) 2006(1.4%) custom-set-union ...et/private/set-types.rkt:168:0 for-loop [152] 64.1% for-loop [157] 11.7% ----------------------------------------------------------------------------------------- ??? [72] 8.1% ??? [134] 43.6% for-loop [132] 48.3% [140] 4010(2.8%) 310(0.2%) ??? ...cts/racket/contract/private/list.rkt:187:10 ??? [156] 40.6% ??? [134] 35.0% for-loop [160] 8.6% ??? [159] 8.1% ----------------------------------------------------------------------------------------- new-enode [109] 10.8% loop! [128] 89.2% [141] 3336(2.3%) 3336(2.3%) set ...collects/racket/private/set-types.rkt:981:0 ----------------------------------------------------------------------------------------- ??? [131] 100.0% [142] 3270(2.3%) 0(0.0%) ??? ...ects/racket/contract/private/list.rkt:169:2 ??? [153] 100.0% ----------------------------------------------------------------------------------------- for-loop [129] 38.7% loop! [128] 61.3% [143] 2690(1.9%) 2690(1.9%) update-en-expr ...evelop/src/core/egraph.rkt:212:0 ----------------------------------------------------------------------------------------- ??? [133] 43.3% ->flonum [67] 56.7% [144] 2344(1.6%) 0(0.0%) ??? ...racket/collects/racket/private/kw.rkt:761:9 ??? [154] 85.2% ??? [164] 14.8% ----------------------------------------------------------------------------------------- option-on-expr [130] 100.0% [145] 1954(1.4%) 0(0.0%) sort-context-on-expr ...velop/src/points.rkt:115:0 ??? [155] 100.0% ----------------------------------------------------------------------------------------- ulp-difference [62] 17.3% ??? [133] 31.6% ->flonum [67] 51.1% [146] 1920(1.3%) 1614(1.1%) return/no-unsupplied ...ct/private/arr-i.rkt:533:0 filter [162] 15.9% ----------------------------------------------------------------------------------------- for-loop [135] 100.0% [147] 988(0.7%) 322(0.2%) eval-const-expr .../develop/src/programs.rkt:168:0 f137 [60] 67.4% ----------------------------------------------------------------------------------------- option-on-expr [130] 100.0% [148] 936(0.7%) 0(0.0%) err-lsts->split-indices .../core/regimes.rkt:239:0 add-splitpoint [158] 100.0% ----------------------------------------------------------------------------------------- foldl [136] 100.0% [149] 324(0.2%) 324(0.2%) merge2 .../herbie/develop/src/core/ematch.rkt:31:0 ----------------------------------------------------------------------------------------- for-loop [135] 100.0% [150] 324(0.2%) 0(0.0%) setfindf ...es/herbie/develop/src/common.rkt:186:0 for-loop [161] 100.0% ----------------------------------------------------------------------------------------- ??? [133] 100.0% [151] 320(0.2%) 320(0.2%) assoc-ref ...collects/racket/private/dict.rkt:56:0 ----------------------------------------------------------------------------------------- custom-set-union [139] 100.0% [152] 5310(3.7%) 958(0.7%) for-loop ...cts/racket/private/set-types.rkt:174:3 for-loop [163] 82.0% ----------------------------------------------------------------------------------------- ??? [142] 100.0% [153] 3270(2.3%) 330(0.2%) ??? ...ects/racket/contract/private/list.rkt:678:5 for-loop [165] 89.9% ----------------------------------------------------------------------------------------- ??? [144] 100.0% [154] 1998(1.4%) 1998(1.4%) ??? ...s/racket/contract/private/arr-i.rkt:1233:27 ----------------------------------------------------------------------------------------- sort-context-on-expr [145] 100.0% [155] 1954(1.4%) 0(0.0%) ??? ...cket/collects/racket/private/sort.rkt:403:3 generic-sort/key [166] 84.5% loop [173] 15.5% ----------------------------------------------------------------------------------------- ??? [140] 100.0% [156] 1628(1.1%) 0(0.0%) ??? ...ects/racket/contract/private/list.rkt:686:7 ??? [164] 100.0% ----------------------------------------------------------------------------------------- custom-set-union [139] 100.0% [157] 966(0.7%) 966(0.7%) for-loop ...cts/racket/private/set-types.rkt:152:2 ----------------------------------------------------------------------------------------- err-lsts->split-indices [148] 100.0% [158] 936(0.7%) 0(0.0%) add-splitpoint ...velop/src/core/regimes.rkt:253:2 for-loop [167] 100.0% ----------------------------------------------------------------------------------------- ??? [140] 49.8% ??? [137] 50.2% [159] 650(0.5%) 650(0.5%) ??? ...ects/racket/contract/private/prop.rkt:493:4 ----------------------------------------------------------------------------------------- ??? [140] 100.0% [160] 344(0.2%) 344(0.2%) for-loop ...acket/contract/private/list.rkt:190:15 ----------------------------------------------------------------------------------------- setfindf [150] 100.0% [161] 324(0.2%) 324(0.2%) for-loop ...es/herbie/develop/src/common.rkt:187:2 ----------------------------------------------------------------------------------------- return/no-unsupplied [146] 100.0% [162] 306(0.2%) 306(0.2%) filter ...t/collects/racket/private/list.rkt:256:2 ----------------------------------------------------------------------------------------- for-loop [152] 100.0% [163] 4352(3.0%) 4352(3.0%) for-loop ...cts/racket/private/set-types.rkt:178:5 ----------------------------------------------------------------------------------------- ??? [65] 9.1% ??? [144] 10.4% ??? [134] 31.7% ??? [156] 48.9% [164] 3332(2.3%) 1974(1.4%) ??? ...ects/racket/contract/private/guts.rkt:644:8 contract? [169] 31.7% ??? [32] 9.1% ----------------------------------------------------------------------------------------- ??? [153] 100.0% [165] 2940(2.1%) 984(0.7%) for-loop ...racket/contract/private/list.rkt:680:9 add-list-context [170] 33.9% get/build-late-neg-projection [171] 32.6% ----------------------------------------------------------------------------------------- ??? [155] 100.0% [166] 1652(1.2%) 0(0.0%) generic-sort/key .../racket/private/sort.rkt:185:2 copying-mergesort [168] 79.8% loop [173] 20.2% ----------------------------------------------------------------------------------------- add-splitpoint [158] 100.0% [167] 936(0.7%) 0(0.0%) for-loop ...bie/develop/src/core/regimes.rkt:255:4 for-loop [172] 100.0% ----------------------------------------------------------------------------------------- generic-sort/key [166] 46.7% copying-mergesort [168] 53.3% [168] 1318(0.9%) 0(0.0%) copying-mergesort ...racket/private/sort.rkt:130:8 copying-mergesort [168] 53.3% loop [173] 33.9% jloop [6] 12.7% ----------------------------------------------------------------------------------------- ??? [164] 100.0% [169] 1056(0.7%) 1056(0.7%) contract? ...acket/contract/private/guts.rkt:109:0 ----------------------------------------------------------------------------------------- for-loop [165] 100.0% [170] 998(0.7%) 998(0.7%) add-list-context ...ontract/private/list.rkt:752:0 ----------------------------------------------------------------------------------------- for-loop [165] 100.0% [171] 958(0.7%) 324(0.2%) get/build-late-neg-projection ...te/guts.rkt:691:0 ??? [175] 66.2% ----------------------------------------------------------------------------------------- for-loop [167] 100.0% [172] 936(0.7%) 626(0.4%) for-loop ...bie/develop/src/core/regimes.rkt:259:8 curried [174] 33.1% ----------------------------------------------------------------------------------------- ??? [155] 23.6% generic-sort/key [166] 26.1% copying-mergesort [168] 50.4% [173] 1282(0.9%) 0(0.0%) loop ...ket/collects/racket/private/sort.rkt:97:12 ??? [176] 100.0% ----------------------------------------------------------------------------------------- for-loop [172] 24.4% for-loop [93] 25.8% loop [123] 49.8% [174] 1270(0.9%) 1270(0.9%) curried ...cket/collects/racket/function.rkt:71:18 ----------------------------------------------------------------------------------------- get/build-late-neg-projection [171] 100.0% [175] 634(0.4%) 0(0.0%) ??? ...cts/racket/contract/private/prop.rkt:314:12 build-compound-type-name [177] 100.0% ----------------------------------------------------------------------------------------- jloop [6] 1.9% loop [173] 7.8% loop [123] 36.4% for-loop [58] 53.8% [176] 16368(11.5%) 320(0.2%) ??? ...tlies/herbie/develop/src/programs.rkt:156:4 ??? [178] 86.5% ??? [65] 7.6% ??? [179] 3.9% ----------------------------------------------------------------------------------------- ??? [175] 100.0% [177] 634(0.4%) 634(0.4%) build-compound-type-name ...private/guts.rkt:448:0 ----------------------------------------------------------------------------------------- ??? [176] 100.0% [178] 14162(9.9%) 8578(6.0%) ??? ...acket/collects/racket/private/kw.rkt:444:14 ??? [180] 18.4% ??? [181] 11.8% ??? [182] 9.3% ----------------------------------------------------------------------------------------- ??? [65] 32.8% ??? [176] 67.2% [179] 952(0.7%) 0(0.0%) ??? ...contract/private/../../private/kw.rkt:761:9 real->bigfloat [183] 67.2% integer->bigfloat [184] 32.8% ----------------------------------------------------------------------------------------- loop [123] 11.3% ??? [178] 88.7% [180] 2934(2.1%) 1022(0.7%) ??? ...-racket/utils/simple-result-arrow.rkt:39:12 bfdiv [185] 65.2% ----------------------------------------------------------------------------------------- ??? [178] 100.0% [181] 1672(1.2%) 1672(1.2%) ??? ...herbie/develop/src/syntax/syntax.rkt:156:17 ----------------------------------------------------------------------------------------- ??? [178] 100.0% [182] 1310(0.9%) 1310(0.9%) ??? ...rivate/unconstrained-domain-arrow.rkt:40:13 ----------------------------------------------------------------------------------------- ??? [179] 100.0% [183] 640(0.4%) 640(0.4%) real->bigfloat .../private/bigfloat/mpfr.rkt:451:0 ----------------------------------------------------------------------------------------- ??? [179] 100.0% [184] 312(0.2%) 312(0.2%) integer->bigfloat ...ivate/bigfloat/mpfr.rkt:399:0 ----------------------------------------------------------------------------------------- ??? [180] 100.0% [185] 1912(1.3%) 1492(1.0%) bfdiv ...-lib/math/private/bigfloat/mpfr.rkt:819:4 ??? [186] 22.0% ----------------------------------------------------------------------------------------- bfdiv [185] 100.0% [186] 420(0.3%) 420(0.3%) ??? .../share/racket/collects/ffi/unsafe.rkt:861:4 -----------------------------------------------------------------------------------------