Profiling results ----------------- Total cpu time observed: 127060ms (out of 131520ms) Number of samples taken: 306 (once every 415ms) (Hiding functions with self<1.0% and local<2.0%: 1 of 103 hidden) ========================================================================== Caller Idx Total Self Name+src Local% ms(pct) ms(pct) Callee ========================================================================== run [13] 49.8% [1] 125278(98.6%) 0(0.0%) ??? ...lects/racket/private/more-scheme.rkt:261:28 profile-thunk16 [6] 49.8% prepare-points [14] 44.5% run-improve50 [8] 5.8% -------------------------------------------------------------------------- for-loop [101] 0.3% loop [68] 99.7% [2] 109122(85.9%) 0(0.0%) ??? ...tlies/herbie/develop/src/programs.rkt:156:4 ??? [7] 100.0% -------------------------------------------------------------------------- ??? [74] 100.0% [3] 6574(5.2%) 0(0.0%) iterate-egraph!13 ...p/src/core/simplify.rkt:105:0 one-iter [9] 95.4% map-enodes [11] 4.6% -------------------------------------------------------------------------- ??? [74] 100.0% [4] 1674(1.3%) 0(0.0%) loop ...herbie/develop/src/core/simplify.rkt:237:2 pass [10] 100.0% -------------------------------------------------------------------------- loop [68] 100.0% [5] 302(0.2%) 0(0.0%) for-loop ...ie/develop/src/core/simplify.rkt:195:2 eval-const-expr [12] 100.0% -------------------------------------------------------------------------- ??? [1] 100.0% [6] 124656(98.1%) 0(0.0%) profile-thunk16 ...t/pkgs/profile-lib/main.rkt:9:0 run [13] 100.0% -------------------------------------------------------------------------- ??? [2] 100.0% [7] 109122(85.9%) 9856(7.8%) ??? ...acket/collects/racket/private/kw.rkt:444:14 bf-complex-mult [15] 75.4% bf-complex-add [16] 13.3% ??? [24] 0.9% ??? [20] 0.3% -------------------------------------------------------------------------- ??? [1] 100.0% [8] 13826(10.9%) 0(0.0%) run-improve50 ...ie/develop/src/mainloop.rkt:234:0 setup-alt-simplified [17] 47.4% prepare-points [14] 29.3% for-loop [22] 18.0% setup-prog [25] 2.6% get-final-combination [26] 2.6% -------------------------------------------------------------------------- iterate-egraph!13 [3] 100.0% [9] 6272(4.9%) 0(0.0%) one-iter ...ie/develop/src/core/simplify.rkt:116:0 for-loop [18] 52.9% for-loop [21] 47.1% -------------------------------------------------------------------------- loop [4] 100.0% [10] 1674(1.3%) 0(0.0%) pass ...herbie/develop/src/core/simplify.rkt:227:2 for-loop [23] 100.0% -------------------------------------------------------------------------- iterate-egraph!13 [3] 100.0% [11] 302(0.2%) 0(0.0%) map-enodes ...ie/develop/src/core/egraph.rkt:140:0 loop [68] 100.0% -------------------------------------------------------------------------- for-loop [5] 100.0% [12] 302(0.2%) 0(0.0%) eval-const-expr .../develop/src/programs.rkt:168:0 f137 [19] 100.0% -------------------------------------------------------------------------- profile-thunk16 [6] 100.0% [13] 124656(98.1%) 0(0.0%) run ...share/racket/pkgs/profile-lib/main.rkt:39:2 ??? [1] 100.0% -------------------------------------------------------------------------- run-improve50 [8] 3.5% ??? [1] 96.5% [14] 115506(90.9%) 0(0.0%) prepare-points ...bie/develop/src/points.rkt:214:0 loop [41] 34.4% loop [28] 33.3% make-exacts* [42] 32.4% -------------------------------------------------------------------------- loop [68] 1.7% ??? [7] 98.3% [15] 83712(65.9%) 4248(3.3%) bf-complex-mult ...develop/src/bigcomplex.rkt:33:0 bf* [27] 57.2% ??? [40] 34.9% ...higher-order.rkt:346:33 [30] 2.9% -------------------------------------------------------------------------- parse-loop12 [65] 2.5% ??? [7] 97.5% [16] 14832(11.7%) 0(0.0%) bf-complex-add .../develop/src/bigcomplex.rkt:22:0 ??? [40] 86.8% ...higher-order.rkt:346:33 [30] 13.2% -------------------------------------------------------------------------- run-improve50 [8] 100.0% [17] 6560(5.2%) 0(0.0%) setup-alt-simplified .../develop/src/glue.rkt:49:0 simplify-alt [29] 100.0% -------------------------------------------------------------------------- for-loop [18] 50.0% one-iter [9] 50.0% [18] 3318(2.6%) 320(0.3%) for-loop ...e/develop/src/core/simplify.rkt:126:12 for-loop [18] 50.0% rule-valid-at-type? [31] 39.8% match-e [37] 5.4% -------------------------------------------------------------------------- eval-prog [54] 1.0% loop [73] 6.0% eval-const-expr [12] 9.6% f137 [19] 9.8% hash-ref! [60] 73.5% [19] 3130(2.5%) 378(0.3%) f137 .../collects/racket/match/compiler.rkt:507:40 map [33] 73.5% f137 [19] 9.8% ??? [39] 9.6% ??? [20] 1.0% -------------------------------------------------------------------------- ??? [7] 9.9% f137 [19] 10.8% map [33] 11.1% get-final-combination [26] 11.4% loop [68] 56.8% [20] 3120(2.5%) 308(0.2%) ??? ...tract/private/arrow-higher-order.rkt:342:33 ??? [74] 79.3% ??? [38] 10.8% -------------------------------------------------------------------------- one-iter [9] 100.0% [21] 2954(2.3%) 0(0.0%) for-loop ...ie/develop/src/core/simplify.rkt:166:2 for-loop [34] 78.1% update-leader! [56] 21.9% -------------------------------------------------------------------------- run-improve50 [8] 100.0% [22] 2490(2.0%) 0(0.0%) for-loop ...herbie/develop/src/mainloop.rkt:249:10 run-iter! [32] 100.0% -------------------------------------------------------------------------- pass [10] 100.0% [23] 1674(1.3%) 0(0.0%) for-loop ...e/develop/src/core/simplify.rkt:230:29 argmin [35] 100.0% -------------------------------------------------------------------------- ??? [7] 100.0% [24] 1022(0.8%) 644(0.5%) ??? ...ects/racket/contract/private/prop.rkt:493:4 ??? [36] 37.0% -------------------------------------------------------------------------- run-improve50 [8] 100.0% [25] 366(0.3%) 0(0.0%) setup-prog ...ies/herbie/develop/src/glue.rkt:40:0 ??? [92] 100.0% -------------------------------------------------------------------------- run-improve50 [8] 100.0% [26] 356(0.3%) 0(0.0%) get-final-combination ...op/src/mainloop.rkt:264:0 ??? [20] 100.0% -------------------------------------------------------------------------- bf-complex-mult [15] 100.0% [27] 47856(37.7%) 336(0.3%) bf* ...ath/private/bigfloat/bigfloat-mpfr.rkt:95:0 ??? [40] 99.3% -------------------------------------------------------------------------- prepare-points [14] 100.0% [28] 38416(30.2%) 0(0.0%) loop ...htlies/herbie/develop/src/points.rkt:158:2 make-exacts* [42] 51.8% loop [41] 48.2% -------------------------------------------------------------------------- setup-alt-simplified [17] 100.0% [29] 6560(5.2%) 0(0.0%) simplify-alt ...s/herbie/develop/src/glue.rkt:76:0 ??? [74] 100.0% -------------------------------------------------------------------------- bf-complex-add [16] 44.7% bf-complex-mult [15] 55.3% [30] 4374(3.4%) 972(0.8%) ...higher-order.rkt:346:33 (unknown source) ??? [43] 77.8% -------------------------------------------------------------------------- for-loop [18] 100.0% [31] 2640(2.1%) 2018(1.6%) rule-valid-at-type? .../src/syntax/rules.rkt:548:0 *complex-rules* [48] 23.6% -------------------------------------------------------------------------- for-loop [22] 100.0% [32] 2490(2.0%) 0(0.0%) run-iter! ...herbie/develop/src/mainloop.rkt:215:0 localize-error [44] 100.0% -------------------------------------------------------------------------- ??? [45] 6.9% f137 [19] 93.1% [33] 2490(2.0%) 0(0.0%) map ...acket/collects/racket/private/map.rkt:20:13 ??? [45] 93.1% ??? [20] 6.9% -------------------------------------------------------------------------- for-loop [21] 100.0% [34] 2308(1.8%) 0(0.0%) for-loop ...e/develop/src/core/simplify.rkt:148:10 substitute-e [46] 57.1% mk-enode! [55] 14.5% merge-egraph-nodes! [51] 14.4% loop! [78] 14.0% -------------------------------------------------------------------------- for-loop [23] 100.0% [35] 1674(1.3%) 0(0.0%) argmin ...re/racket/collects/racket/list.rkt:743:0 for-loop [47] 78.1% expression-cost [49] 21.9% -------------------------------------------------------------------------- ??? [24] 100.0% [36] 378(0.3%) 378(0.3%) ??? ...lects/racket/contract/private/orc.rkt:83:14 -------------------------------------------------------------------------- for-loop [18] 100.0% [37] 358(0.3%) 358(0.3%) match-e ...herbie/develop/src/core/ematch.rkt:46:0 -------------------------------------------------------------------------- ??? [20] 100.0% [38] 338(0.3%) 0(0.0%) ??? ...contract/private/../../private/kw.rkt:761:9 integer->bigfloat [50] 100.0% -------------------------------------------------------------------------- f137 [19] 100.0% [39] 302(0.2%) 0(0.0%) ??? ...tract/private/arrow-higher-order.rkt:336:46 ??? [88] 100.0% -------------------------------------------------------------------------- bf-complex-add [16] 14.4% bf-complex-mult [15] 32.6% bf* [27] 53.0% [40] 89586(70.5%) 7716(6.1%) ??? ...-racket/utils/simple-result-arrow.rkt:39:12 bfmul [52] 80.1% bfneg [53] 11.3% -------------------------------------------------------------------------- loop [28] 31.8% prepare-points [14] 68.2% [41] 58194(45.8%) 0(0.0%) loop ...htlies/herbie/develop/src/points.rkt:141:4 loop [68] 100.0% -------------------------------------------------------------------------- loop [28] 34.7% prepare-points [14] 65.3% [42] 57312(45.1%) 0(0.0%) make-exacts* ...erbie/develop/src/points.rkt:138:0 loop [68] 91.1% eval-prog [54] 8.9% -------------------------------------------------------------------------- ??? [84] 9.2% ...higher-order.rkt:346:33 [30] 90.8% [43] 3746(2.9%) 2698(2.1%) ??? ...cts/racket/contract/private/list.rkt:187:10 ??? [88] 18.8% ??? [84] 9.2% -------------------------------------------------------------------------- run-iter! [32] 100.0% [44] 2490(2.0%) 0(0.0%) localize-error ...velop/src/core/localize.rkt:47:0 hash-ref! [60] 100.0% -------------------------------------------------------------------------- map [33] 26.5% loop [68] 73.5% [45] 2490(2.0%) 0(0.0%) ??? ...ket/collects/racket/private/list.rkt:323:18 hash-ref! [60] 98.8% map [33] 1.2% -------------------------------------------------------------------------- for-loop [34] 100.0% [46] 1318(1.0%) 0(0.0%) substitute-e ...e/develop/src/core/ematch.rkt:71:0 mk-enode! [55] 100.0% -------------------------------------------------------------------------- argmin [35] 100.0% [47] 1308(1.0%) 0(0.0%) for-loop .../herbie/develop/src/programs.rkt:210:2 ??? [74] 76.3% ...velop/src/common.rkt:47:2 [77] 23.7% -------------------------------------------------------------------------- rule-valid-at-type? [31] 100.0% [48] 622(0.5%) 0(0.0%) *complex-rules* ...elop/src/syntax/rules.rkt:560:0 for-loop [57] 100.0% -------------------------------------------------------------------------- argmin [35] 100.0% [49] 366(0.3%) 0(0.0%) expression-cost .../develop/src/programs.rkt:209:0 compile [58] 100.0% -------------------------------------------------------------------------- ??? [38] 100.0% [50] 338(0.3%) 338(0.3%) integer->bigfloat ...ivate/bigfloat/mpfr.rkt:399:0 -------------------------------------------------------------------------- merge-egraph-nodes! [51] 50.0% for-loop [34] 50.0% [51] 332(0.3%) 0(0.0%) merge-egraph-nodes! ...p/src/core/egraph.rkt:153:0 merge-egraph-nodes! [51] 50.0% update-leader! [56] 50.0% -------------------------------------------------------------------------- ??? [40] 100.0% [52] 71750(56.5%) 48410(38.1%) bfmul ...-lib/math/private/bigfloat/mpfr.rkt:819:4 ??? [59] 32.5% -------------------------------------------------------------------------- ??? [40] 100.0% [53] 10120(8.0%) 7166(5.6%) bfneg ...-lib/math/private/bigfloat/mpfr.rkt:616:4 ??? [59] 29.2% -------------------------------------------------------------------------- make-exacts* [42] 100.0% [54] 5086(4.0%) 0(0.0%) eval-prog ...herbie/develop/src/programs.rkt:150:0 hash-ref! [60] 93.4% f137 [19] 6.6% -------------------------------------------------------------------------- for-loop [34] 20.2% substitute-e [46] 79.8% [55] 1652(1.3%) 0(0.0%) mk-enode! ...bie/develop/src/core/egraph.rkt:102:0 new-enode [61] 100.0% -------------------------------------------------------------------------- merge-egraph-nodes! [51] 33.9% for-loop [21] 66.1% [56] 978(0.8%) 0(0.0%) update-leader! ...evelop/src/core/egraph.rkt:218:0 for-loop [62] 100.0% -------------------------------------------------------------------------- *complex-rules* [48] 100.0% [57] 622(0.5%) 622(0.5%) for-loop ...ies/herbie/develop/src/common.rkt:99:9 -------------------------------------------------------------------------- expression-cost [49] 100.0% [58] 366(0.3%) 366(0.3%) compile ...s/herbie/develop/src/programs.rkt:186:0 -------------------------------------------------------------------------- bfneg [53] 11.2% bfmul [52] 88.8% [59] 26294(20.7%) 26294(20.7%) ??? .../share/racket/collects/ffi/unsafe.rkt:861:4 -------------------------------------------------------------------------- localize-error [44] 6.0% eval-prog [54] 16.8% ??? [45] 28.4% loop [68] 48.8% [60] 7238(5.7%) 0(0.0%) hash-ref! ...racket/private/more-scheme.rkt:373:13 ??? [64] 49.4% parse-loop12 [65] 28.4% bigfloat-hash [63] 16.2% f137 [19] 6.0% -------------------------------------------------------------------------- mk-enode! [55] 100.0% [61] 1652(1.3%) 0(0.0%) new-enode ...erbie/develop/src/core/enode.rkt:97:0 type-of-enode-expr [66] 100.0% -------------------------------------------------------------------------- update-leader! [56] 100.0% [62] 978(0.8%) 0(0.0%) for-loop ...rbie/develop/src/core/egraph.rkt:223:6 for-loop [67] 100.0% -------------------------------------------------------------------------- hash-ref! [60] 100.0% [63] 4432(3.5%) 0(0.0%) bigfloat-hash ...h/private/bigfloat/mpfr.rkt:165:0 bfcanonicalize [69] 75.7% sig+exp->bigfloat [72] 16.0% bigfloat->sig+exp [76] 8.3% -------------------------------------------------------------------------- hash-ref! [60] 100.0% [64] 4432(3.5%) 0(0.0%) ??? ...tlies/herbie/develop/src/programs.rkt:194:5 loop [68] 100.0% -------------------------------------------------------------------------- hash-ref! [60] 100.0% [65] 2490(2.0%) 0(0.0%) parse-loop12 ...s/racket/match/compiler.rkt:418:15 loop [68] 81.8% loop [73] 15.2% bf-complex-add [16] 3.0% -------------------------------------------------------------------------- new-enode [61] 100.0% [66] 1652(1.3%) 0(0.0%) type-of-enode-expr ...elop/src/core/enode.rkt:68:0 get-sigs [70] 100.0% -------------------------------------------------------------------------- for-loop [62] 100.0% [67] 978(0.8%) 0(0.0%) for-loop ...rbie/develop/src/core/egraph.rkt:224:8 hash-update! [71] 100.0% -------------------------------------------------------------------------- map-enodes [11] 0.0% loop! [78] 0.1% loop [41] 0.4% make-exacts* [42] 0.6% parse-loop12 [65] 0.7% ??? [64] 3.8% loop [68] 94.4% [68] 118040(92.9%) 658(0.5%) loop ...cket/collects/racket/private/map.rkt:25:19 loop [68] 94.4% hash-ref! [60] 3.7% ??? [2] 1.0% ??? [45] 0.7% loop! [78] 0.1% bf-complex-mult [15] 0.0% for-loop [5] 0.0% ??? [20] 0.0% -------------------------------------------------------------------------- bigfloat-hash [63] 100.0% [69] 3354(2.6%) 3030(2.4%) bfcanonicalize .../private/bigfloat/mpfr.rkt:155:0 bigfloat->sig+exp [76] 9.7% -------------------------------------------------------------------------- type-of-enode-expr [66] 100.0% [70] 1652(1.3%) 0(0.0%) get-sigs .../herbie/develop/src/type-check.rkt:5:0 ??? [74] 40.2% ...velop/src/common.rkt:47:2 [77] 20.8% ??? [92] 20.2% ??? [79] 18.8% -------------------------------------------------------------------------- for-loop [67] 100.0% [71] 978(0.8%) 0(0.0%) hash-update! ...ket/private/more-scheme.rkt:362:13 ??? [75] 100.0% -------------------------------------------------------------------------- bigfloat-hash [63] 100.0% [72] 710(0.6%) 710(0.6%) sig+exp->bigfloat ...ivate/bigfloat/mpfr.rkt:385:0 -------------------------------------------------------------------------- parse-loop12 [65] 4.8% loop [73] 95.2% [73] 378(0.3%) 0(0.0%) loop ...cket/collects/racket/private/map.rkt:36:19 loop [73] 95.2% f137 [19] 4.8% -------------------------------------------------------------------------- get-sigs [70] 2.1% for-loop [47] 3.2% ??? [20] 22.1% simplify-alt [29] 30.6% ??? [74] 37.1% [74] 10366(8.2%) 1126(0.9%) ??? ...llects/racket/private/norm-define.rkt:53:83 ??? [74] 37.1% iterate-egraph!13 [3] 30.6% loop [4] 6.5% return/no-unsupplied [81] 5.4% ??? [98] 5.3% ??? [82] 4.2% -------------------------------------------------------------------------- hash-update! [71] 100.0% [75] 978(0.8%) 0(0.0%) ??? ...s/herbie/develop/src/core/egraph.rkt:226:24 for-loop [80] 100.0% -------------------------------------------------------------------------- bfcanonicalize [69] 46.8% bigfloat-hash [63] 53.2% [76] 692(0.5%) 0(0.0%) bigfloat->sig+exp ...ivate/bigfloat/mpfr.rkt:370:0 new-mpz [83] 53.2% mpz->integer [85] 46.8% -------------------------------------------------------------------------- for-loop [47] 47.4% get-sigs [70] 52.6% [77] 654(0.5%) 0(0.0%) ...velop/src/common.rkt:47:2 ...e/arr-i.rkt:906:19 ??? [84] 52.6% ??? [86] 47.4% -------------------------------------------------------------------------- loop [68] 50.0% for-loop [34] 50.0% [78] 324(0.3%) 324(0.3%) loop! ...s/herbie/develop/src/core/enode.rkt:192:2 loop [68] 50.0% -------------------------------------------------------------------------- get-sigs [70] 100.0% [79] 310(0.2%) 0(0.0%) ??? ...ts/racket/contract/private/arr-i.rkt:804:10 ??? [87] 100.0% -------------------------------------------------------------------------- ??? [75] 100.0% [80] 978(0.8%) 646(0.5%) for-loop ...bie/develop/src/core/egraph.rkt:227:26 update-en-expr [89] 33.9% -------------------------------------------------------------------------- ??? [74] 100.0% [81] 556(0.4%) 556(0.4%) return/no-unsupplied ...ct/private/arr-i.rkt:533:0 -------------------------------------------------------------------------- ??? [74] 100.0% [82] 436(0.3%) 436(0.3%) ??? ...racket/collects/racket/private/kw.rkt:761:9 -------------------------------------------------------------------------- bigfloat->sig+exp [76] 100.0% [83] 368(0.3%) 368(0.3%) new-mpz ...-lib/math/private/bigfloat/gmp.rkt:73:0 -------------------------------------------------------------------------- ??? [43] 50.0% ...velop/src/common.rkt:47:2 [77] 50.0% [84] 344(0.3%) 0(0.0%) ??? ...ects/racket/contract/private/list.rkt:342:4 ??? [43] 50.0% ??? [88] 50.0% -------------------------------------------------------------------------- bigfloat->sig+exp [76] 100.0% [85] 324(0.3%) 324(0.3%) mpz->integer ...ath/private/bigfloat/gmp.rkt:115:0 -------------------------------------------------------------------------- ...velop/src/common.rkt:47:2 [77]100.0% [86] 310(0.2%) 0(0.0%) ??? ...s/racket/contract/private/arr-i.rkt:1268:39 assoc-ref [90] 100.0% -------------------------------------------------------------------------- ??? [79] 100.0% [87] 310(0.2%) 0(0.0%) ??? ...ects/racket/contract/private/hash.rkt:217:4 ??? [91] 100.0% -------------------------------------------------------------------------- ??? [39] 22.4% ??? [84] 25.5% ??? [43] 52.1% [88] 1350(1.1%) 704(0.6%) ??? ...ects/racket/contract/private/guts.rkt:644:8 contract? [93] 25.5% ??? [92] 22.4% -------------------------------------------------------------------------- for-loop [80] 100.0% [89] 332(0.3%) 332(0.3%) update-en-expr ...evelop/src/core/egraph.rkt:212:0 -------------------------------------------------------------------------- ??? [86] 100.0% [90] 310(0.2%) 310(0.2%) assoc-ref ...collects/racket/private/dict.rkt:56:0 -------------------------------------------------------------------------- ??? [87] 100.0% [91] 310(0.2%) 0(0.0%) ??? ...ects/racket/contract/private/list.rkt:169:2 ??? [94] 100.0% -------------------------------------------------------------------------- ??? [88] 30.1% get-sigs [70] 33.3% setup-prog [25] 36.5% [92] 1002(0.8%) 0(0.0%) ??? ...contract/private/arrow-val-first.rkt:357:18 hash-has-key? [95] 63.5% make-alt-table [96] 36.5% -------------------------------------------------------------------------- ??? [88] 100.0% [93] 344(0.3%) 344(0.3%) contract? ...acket/contract/private/guts.rkt:109:0 -------------------------------------------------------------------------- ??? [91] 100.0% [94] 310(0.2%) 0(0.0%) ??? ...ects/racket/contract/private/list.rkt:678:5 for-loop [97] 100.0% -------------------------------------------------------------------------- ??? [92] 100.0% [95] 636(0.5%) 334(0.3%) hash-has-key? ...et/private/more-scheme.rkt:368:13 ??? [98] 47.5% -------------------------------------------------------------------------- ??? [92] 100.0% [96] 366(0.3%) 0(0.0%) make-alt-table ...elop/src/core/alt-table.rkt:32:0 errors [99] 100.0% -------------------------------------------------------------------------- ??? [94] 100.0% [97] 310(0.2%) 310(0.2%) for-loop ...racket/contract/private/list.rkt:680:9 -------------------------------------------------------------------------- hash-has-key? [95] 15.4% ??? [74] 84.6% [98] 1964(1.5%) 968(0.8%) ??? ...ects/racket/contract/private/list.rkt:737:4 for-loop [100] 50.7% -------------------------------------------------------------------------- make-alt-table [96] 100.0% [99] 366(0.3%) 0(0.0%) errors ...lies/herbie/develop/src/points.rkt:271:0 for-loop [101] 100.0% -------------------------------------------------------------------------- ??? [98] 100.0% [100] 996(0.8%) 668(0.5%) for-loop ...acket/contract/private/list.rkt:743:12 ??? [102] 32.9% -------------------------------------------------------------------------- errors [99] 100.0% [101] 366(0.3%) 0(0.0%) for-loop ...es/herbie/develop/src/points.rkt:274:4 ??? [2] 100.0% -------------------------------------------------------------------------- for-loop [100] 100.0% [102] 328(0.3%) 328(0.3%) ??? ...private/unconstrained-domain-arrow.rkt:74:4 --------------------------------------------------------------------------