Profiling results ----------------- Total cpu time observed: 116060ms (out of 118604ms) Number of samples taken: 280 (once every 414ms) (Hiding functions with self<1.0% and local<2.0%: 2 of 105 hidden) =========================================================================== Caller Idx Total Self Name+src Local% ms(pct) ms(pct) Callee =========================================================================== ??? [11] 100.0% [1] 113144(97.5%) 0(0.0%) profile-thunk16 ...t/pkgs/profile-lib/main.rkt:9:0 run [7] 100.0% --------------------------------------------------------------------------- ??? [57] 100.0% [2] 5560(4.8%) 0(0.0%) iterate-egraph!13 ...r/src/core/simplify.rkt:105:0 one-iter [8] 100.0% --------------------------------------------------------------------------- eval-prog [50] 1.2% f6 [3] 14.4% hash-ref! [54] 84.4% [3] 2156(1.9%) 0(0.0%) f6 ...et/collects/racket/match/compiler.rkt:507:40 map [10] 84.4% f6 [3] 14.4% ??? [13] 1.2% --------------------------------------------------------------------------- ??? [57] 100.0% [4] 1986(1.7%) 0(0.0%) loop .../herbie/master/src/core/simplify.rkt:237:2 pass [9] 100.0% --------------------------------------------------------------------------- parse-loop12 [60] 1.8% loop [5] 98.2% [5] 712(0.6%) 352(0.3%) loop ...cket/collects/racket/private/map.rkt:36:19 loop [5] 98.2% ??? [13] 0.7% --------------------------------------------------------------------------- match-e [24] 100.0% [6] 312(0.3%) 0(0.0%) variable? ...ie/master/src/syntax/syntax.rkt:665:0 ??? [67] 100.0% --------------------------------------------------------------------------- profile-thunk16 [1] 100.0% [7] 113144(97.5%) 0(0.0%) run ...share/racket/pkgs/profile-lib/main.rkt:39:2 ??? [11] 100.0% --------------------------------------------------------------------------- iterate-egraph!13 [2] 100.0% [8] 5560(4.8%) 0(0.0%) one-iter ...bie/master/src/core/simplify.rkt:116:0 for-loop [12] 58.9% for-loop [14] 41.1% --------------------------------------------------------------------------- loop [4] 100.0% [9] 1986(1.7%) 0(0.0%) pass .../herbie/master/src/core/simplify.rkt:227:2 for-loop [15] 100.0% --------------------------------------------------------------------------- ??? [16] 20.7% f6 [3] 79.3% [10] 1820(1.6%) 0(0.0%) map ...acket/collects/racket/private/map.rkt:20:13 ??? [16] 79.3% ??? [13] 20.7% --------------------------------------------------------------------------- run [7] 49.9% [11] 113454(97.8%) 0(0.0%) ??? ...lects/racket/private/more-scheme.rkt:261:28 profile-thunk16 [1] 49.9% prepare-points [25] 43.7% run-improve50 [17] 5.3% loop [19] 1.1% --------------------------------------------------------------------------- for-loop [12] 50.0% one-iter [8] 50.0% [12] 3276(2.8%) 316(0.3%) for-loop ...ie/master/src/core/simplify.rkt:126:12 for-loop [12] 50.0% rule-valid-at-type? [18] 40.4% match-e [24] 4.8% --------------------------------------------------------------------------- ??? [74] 11.0% f6 [3] 11.1% get-final-combination [31] 11.3% loop [5] 11.9% map [10] 24.8% loop [64] 29.9% [13] 3036(2.6%) 800(0.7%) ??? ...tract/private/arrow-higher-order.rkt:342:33 ??? [57] 62.6% best-alt [22] 11.0% --------------------------------------------------------------------------- one-iter [8] 100.0% [14] 2284(2.0%) 0(0.0%) for-loop ...bie/master/src/core/simplify.rkt:166:2 for-loop [20] 100.0% --------------------------------------------------------------------------- pass [9] 100.0% [15] 1986(1.7%) 0(0.0%) for-loop ...ie/master/src/core/simplify.rkt:230:29 argmin [21] 83.2% loop [23] 16.8% --------------------------------------------------------------------------- map [10] 19.6% loop [64] 80.4% [16] 1820(1.6%) 0(0.0%) ??? ...ket/collects/racket/private/list.rkt:323:18 hash-ref! [54] 87.2% map [10] 12.8% --------------------------------------------------------------------------- ??? [11] 100.0% [17] 11728(10.1%) 0(0.0%) run-improve50 ...bie/master/src/mainloop.rkt:234:0 setup-alt-simplified [26] 47.5% prepare-points [25] 31.2% for-loop [27] 18.4% get-final-combination [31] 2.9% --------------------------------------------------------------------------- for-loop [12] 100.0% [18] 2648(2.3%) 2338(2.0%) rule-valid-at-type? .../src/syntax/rules.rkt:548:0 *complex-rules* [34] 11.7% --------------------------------------------------------------------------- ??? [11] 100.0% [19] 2460(2.1%) 2460(2.1%) loop ...ghtlies/herbie/master/src/points.rkt:238:2 --------------------------------------------------------------------------- for-loop [14] 100.0% [20] 2284(2.0%) 0(0.0%) for-loop ...ie/master/src/core/simplify.rkt:148:10 substitute-e [29] 55.6% merge-egraph-nodes! [30] 29.3% mk-enode! [38] 15.1% --------------------------------------------------------------------------- for-loop [15] 100.0% [21] 1652(1.4%) 0(0.0%) argmin ...re/racket/collects/racket/list.rkt:743:0 for-loop [28] 100.0% --------------------------------------------------------------------------- ??? [13] 100.0% [22] 334(0.3%) 0(0.0%) best-alt ...htlies/herbie/master/src/glue.rkt:71:0 argmins [32] 100.0% --------------------------------------------------------------------------- for-loop [15] 100.0% [23] 334(0.3%) 0(0.0%) loop ...hare/racket/collects/racket/list.rkt:729:4 for-loop [28] 100.0% --------------------------------------------------------------------------- for-loop [12] 33.3% for-loop [41] 66.7% [24] 312(0.3%) 0(0.0%) match-e .../herbie/master/src/core/ematch.rkt:46:0 for-loop [41] 33.3% for-loop [33] 33.3% variable? [6] 33.3% --------------------------------------------------------------------------- run-improve50 [17] 3.6% ??? [11] 96.4% [25] 102928(88.7%) 0(0.0%) prepare-points ...rbie/master/src/points.rkt:214:0 loop [35] 37.8% loop [44] 31.1% make-exacts* [43] 31.0% --------------------------------------------------------------------------- run-improve50 [17] 100.0% [26] 5568(4.8%) 0(0.0%) setup-alt-simplified ...e/master/src/glue.rkt:49:0 simplify-alt [36] 100.0% --------------------------------------------------------------------------- run-improve50 [17] 100.0% [27] 2154(1.9%) 0(0.0%) for-loop .../herbie/master/src/mainloop.rkt:249:10 run-iter! [37] 100.0% --------------------------------------------------------------------------- loop [23] 16.8% argmin [21] 83.2% [28] 1986(1.7%) 0(0.0%) for-loop ...s/herbie/master/src/programs.rkt:210:2 ??? [57] 65.9% ...aster/src/common.rkt:47:2 [61] 34.1% --------------------------------------------------------------------------- substitute-e [29] 24.2% for-loop [20] 75.8% [29] 1270(1.1%) 0(0.0%) substitute-e ...ie/master/src/core/ematch.rkt:71:0 mk-enode! [38] 75.8% substitute-e [29] 24.2% --------------------------------------------------------------------------- merge-egraph-nodes! [30] 26.6% for-loop [20] 73.4% [30] 670(0.6%) 0(0.0%) merge-egraph-nodes! ...r/src/core/egraph.rkt:153:0 update-leader! [39] 73.4% merge-egraph-nodes! [30] 26.6% --------------------------------------------------------------------------- run-improve50 [17] 100.0% [31] 344(0.3%) 0(0.0%) get-final-combination ...er/src/mainloop.rkt:264:0 ??? [13] 100.0% --------------------------------------------------------------------------- best-alt [22] 100.0% [32] 334(0.3%) 0(0.0%) argmins ...lies/herbie/master/src/common.rkt:152:0 composed [40] 100.0% --------------------------------------------------------------------------- match-e [24] 100.0% [33] 312(0.3%) 0(0.0%) for-loop ...erbie/master/src/core/ematch.rkt:59:11 for-loop [41] 100.0% --------------------------------------------------------------------------- rule-valid-at-type? [18] 100.0% [34] 310(0.3%) 0(0.0%) *complex-rules* ...ster/src/syntax/rules.rkt:560:0 for-loop [42] 100.0% --------------------------------------------------------------------------- prepare-points [25] 100.0% [35] 38932(33.5%) 0(0.0%) loop ...ghtlies/herbie/master/src/points.rkt:158:2 make-exacts* [43] 53.8% loop [44] 46.2% --------------------------------------------------------------------------- setup-alt-simplified [26] 100.0% [36] 5568(4.8%) 0(0.0%) simplify-alt ...es/herbie/master/src/glue.rkt:76:0 ??? [57] 100.0% --------------------------------------------------------------------------- for-loop [27] 100.0% [37] 2154(1.9%) 0(0.0%) run-iter! .../herbie/master/src/mainloop.rkt:215:0 localize-error [45] 84.5% choose-best-alt! [49] 15.5% --------------------------------------------------------------------------- for-loop [20] 21.3% substitute-e [29] 78.7% [38] 1614(1.4%) 0(0.0%) mk-enode! ...rbie/master/src/core/egraph.rkt:102:0 new-enode [46] 100.0% --------------------------------------------------------------------------- merge-egraph-nodes! [30] 100.0% [39] 670(0.6%) 0(0.0%) update-leader! ...master/src/core/egraph.rkt:218:0 for-loop [47] 100.0% --------------------------------------------------------------------------- argmins [32] 100.0% [40] 334(0.3%) 0(0.0%) composed ...ollects/racket/private/list.rkt:321:16 errors [48] 100.0% --------------------------------------------------------------------------- for-loop [33] 50.0% match-e [24] 50.0% [41] 312(0.3%) 0(0.0%) for-loop ...erbie/master/src/core/ematch.rkt:65:37 match-e [24] 100.0% --------------------------------------------------------------------------- *complex-rules* [34] 100.0% [42] 310(0.3%) 310(0.3%) for-loop ...lies/herbie/master/src/common.rkt:99:9 --------------------------------------------------------------------------- loop [35] 39.6% prepare-points [25] 60.4% [43] 52890(45.6%) 0(0.0%) make-exacts* ...herbie/master/src/points.rkt:138:0 loop [64] 86.8% eval-prog [50] 13.2% --------------------------------------------------------------------------- loop [35] 35.9% prepare-points [25] 64.1% [44] 50038(43.1%) 0(0.0%) loop ...ghtlies/herbie/master/src/points.rkt:141:4 loop [64] 100.0% --------------------------------------------------------------------------- run-iter! [37] 100.0% [45] 1820(1.6%) 0(0.0%) localize-error ...aster/src/core/localize.rkt:47:0 hash-ref! [54] 100.0% --------------------------------------------------------------------------- mk-enode! [38] 100.0% [46] 1614(1.4%) 0(0.0%) new-enode ...herbie/master/src/core/enode.rkt:97:0 type-of-enode-expr [51] 100.0% --------------------------------------------------------------------------- update-leader! [39] 100.0% [47] 670(0.6%) 0(0.0%) for-loop ...erbie/master/src/core/egraph.rkt:223:6 for-loop [52] 100.0% --------------------------------------------------------------------------- composed [40] 100.0% [48] 334(0.3%) 0(0.0%) errors ...tlies/herbie/master/src/points.rkt:271:0 for-loop [53] 100.0% --------------------------------------------------------------------------- run-iter! [37] 100.0% [49] 334(0.3%) 0(0.0%) choose-best-alt! .../master/src/mainloop.rkt:115:0 ??? [67] 100.0% --------------------------------------------------------------------------- make-exacts* [43] 100.0% [50] 6976(6.0%) 0(0.0%) eval-prog .../herbie/master/src/programs.rkt:150:0 hash-ref! [54] 95.2% f6 [3] 4.8% --------------------------------------------------------------------------- new-enode [46] 100.0% [51] 1614(1.4%) 0(0.0%) type-of-enode-expr ...ster/src/core/enode.rkt:68:0 get-sigs [55] 100.0% --------------------------------------------------------------------------- for-loop [47] 100.0% [52] 670(0.6%) 0(0.0%) for-loop ...erbie/master/src/core/egraph.rkt:224:8 hash-update! [56] 100.0% --------------------------------------------------------------------------- errors [48] 100.0% [53] 334(0.3%) 0(0.0%) for-loop ...ies/herbie/master/src/points.rkt:274:4 ??? [72] 100.0% --------------------------------------------------------------------------- localize-error [45] 4.1% eval-prog [50] 16.8% ??? [16] 17.4% loop [64] 61.7% [54] 8460(7.3%) 0(0.0%) hash-ref! ...racket/private/more-scheme.rkt:373:13 ??? [59] 61.7% parse-loop12 [60] 17.4% bigfloat-hash [58] 16.8% f6 [3] 4.1% --------------------------------------------------------------------------- type-of-enode-expr [51] 100.0% [55] 1614(1.4%) 0(0.0%) get-sigs ...s/herbie/master/src/type-check.rkt:5:0 ??? [57] 40.4% ??? [67] 21.3% ??? [63] 19.3% ...aster/src/common.rkt:47:2 [61] 19.0% --------------------------------------------------------------------------- for-loop [52] 100.0% [56] 670(0.6%) 0(0.0%) hash-update! ...ket/private/more-scheme.rkt:362:13 ??? [62] 100.0% --------------------------------------------------------------------------- get-sigs [55] 2.4% for-loop [28] 4.8% ??? [13] 19.0% simplify-alt [36] 30.0% ??? [57] 37.9% [57] 9104(7.8%) 0(0.0%) ??? ...llects/racket/private/norm-define.rkt:53:83 ??? [57] 37.9% iterate-egraph!13 [2] 29.3% return/no-unsupplied [68] 8.8% loop [4] 8.5% ??? [67] 8.3% ??? [80] 6.0% ??? [70] 1.2% --------------------------------------------------------------------------- hash-ref! [54] 100.0% [58] 6640(5.7%) 296(0.3%) bigfloat-hash ...h/private/bigfloat/mpfr.rkt:165:0 sig+exp->bigfloat [65] 55.2% bfcanonicalize [66] 40.4% --------------------------------------------------------------------------- hash-ref! [54] 100.0% [59] 6326(5.5%) 0(0.0%) ??? ...htlies/herbie/master/src/programs.rkt:194:5 loop [64] 100.0% --------------------------------------------------------------------------- hash-ref! [54] 100.0% [60] 1820(1.6%) 0(0.0%) parse-loop12 ...s/racket/match/compiler.rkt:418:15 loop [64] 95.6% loop [5] 4.4% --------------------------------------------------------------------------- get-sigs [55] 31.1% for-loop [28] 68.9% [61] 984(0.8%) 984(0.8%) ...aster/src/common.rkt:47:2 ...e/arr-i.rkt:906:19 --------------------------------------------------------------------------- hash-update! [56] 100.0% [62] 670(0.6%) 0(0.0%) ??? ...es/herbie/master/src/core/egraph.rkt:226:24 for-loop [69] 100.0% --------------------------------------------------------------------------- get-sigs [55] 100.0% [63] 312(0.3%) 0(0.0%) ??? ...ts/racket/contract/private/arr-i.rkt:804:10 ??? [71] 100.0% --------------------------------------------------------------------------- loop [44] 0.3% parse-loop12 [60] 0.8% make-exacts* [43] 0.9% ??? [59] 6.1% loop [64] 92.0% [64] 104428(90.0%) 0(0.0%) loop ...cket/collects/racket/private/map.rkt:25:19 loop [64] 92.0% hash-ref! [54] 6.1% ??? [72] 1.1% ??? [16] 0.8% bf-complex-mult [83] 0.0% ??? [13] 0.0% --------------------------------------------------------------------------- bigfloat-hash [58] 100.0% [65] 3662(3.2%) 3364(2.9%) sig+exp->bigfloat ...ivate/bigfloat/mpfr.rkt:385:0 integer->mpz [78] 8.1% --------------------------------------------------------------------------- bigfloat-hash [58] 100.0% [66] 2682(2.3%) 2368(2.0%) bfcanonicalize .../private/bigfloat/mpfr.rkt:155:0 bigfloat->sig+exp [76] 11.7% --------------------------------------------------------------------------- variable? [6] 17.9% choose-best-alt! [49] 19.2% get-sigs [55] 19.7% ??? [57] 43.2% [67] 1744(1.5%) 682(0.6%) ??? ...contract/private/arrow-val-first.rkt:357:18 ??? [100] 22.0% hash-has-key? [73] 19.7% ??? [74] 19.2% --------------------------------------------------------------------------- ??? [57] 100.0% [68] 804(0.7%) 804(0.7%) return/no-unsupplied ...ct/private/arr-i.rkt:533:0 --------------------------------------------------------------------------- ??? [62] 100.0% [69] 670(0.6%) 670(0.6%) for-loop ...rbie/master/src/core/egraph.rkt:227:26 --------------------------------------------------------------------------- ??? [57] 100.0% [70] 326(0.3%) 0(0.0%) ??? ...racket/collects/racket/private/kw.rkt:761:9 ??? [75] 100.0% --------------------------------------------------------------------------- ??? [63] 100.0% [71] 312(0.3%) 0(0.0%) ??? ...ects/racket/contract/private/hash.rkt:217:4 ??? [77] 100.0% --------------------------------------------------------------------------- for-loop [53] 0.3% loop [64] 99.7% [72] 95708(82.5%) 0(0.0%) ??? ...htlies/herbie/master/src/programs.rkt:156:4 ??? [79] 100.0% --------------------------------------------------------------------------- ??? [67] 100.0% [73] 344(0.3%) 0(0.0%) hash-has-key? ...et/private/more-scheme.rkt:368:13 ??? [80] 100.0% --------------------------------------------------------------------------- ??? [67] 100.0% [74] 334(0.3%) 0(0.0%) ??? ...s/herbie/master/src/core/alt-table.rkt:54:0 ??? [13] 100.0% --------------------------------------------------------------------------- ??? [70] 100.0% [75] 326(0.3%) 326(0.3%) ??? ...s/racket/contract/private/arr-i.rkt:1233:27 --------------------------------------------------------------------------- bfcanonicalize [66] 100.0% [76] 314(0.3%) 0(0.0%) bigfloat->sig+exp ...ivate/bigfloat/mpfr.rkt:370:0 new-mpz [81] 100.0% --------------------------------------------------------------------------- ??? [71] 100.0% [77] 312(0.3%) 0(0.0%) ??? ...ects/racket/contract/private/list.rkt:169:2 ??? [82] 100.0% --------------------------------------------------------------------------- sig+exp->bigfloat [65] 100.0% [78] 298(0.3%) 298(0.3%) integer->mpz ...math/private/bigfloat/gmp.rkt:87:0 --------------------------------------------------------------------------- ??? [72] 100.0% [79] 95708(82.5%) 7714(6.6%) ??? ...acket/collects/racket/private/kw.rkt:444:14 bf-complex-mult [83] 78.4% bf-complex-add [84] 11.7% ??? [86] 0.7% --------------------------------------------------------------------------- hash-has-key? [73] 17.4% ??? [57] 82.6% [80] 1978(1.7%) 652(0.6%) ??? ...ects/racket/contract/private/list.rkt:737:4 for-loop [85] 49.6% ??? [90] 17.4% --------------------------------------------------------------------------- bigfloat->sig+exp [76] 100.0% [81] 314(0.3%) 314(0.3%) new-mpz ...-lib/math/private/bigfloat/gmp.rkt:73:0 --------------------------------------------------------------------------- ??? [77] 100.0% [82] 312(0.3%) 0(0.0%) ??? ...ects/racket/contract/private/list.rkt:678:5 for-loop [87] 100.0% --------------------------------------------------------------------------- loop [64] 0.5% ??? [79] 99.5% [83] 75376(64.9%) 2948(2.5%) bf-complex-mult .../master/src/bigcomplex.rkt:33:0 bf* [88] 62.4% ??? [94] 30.5% ...higher-order.rkt:346:33 [89] 3.2% --------------------------------------------------------------------------- ??? [79] 100.0% [84] 11176(9.6%) 1318(1.1%) bf-complex-add ...e/master/src/bigcomplex.rkt:22:0 ??? [94] 85.3% ...higher-order.rkt:346:33 [89] 2.9% --------------------------------------------------------------------------- ??? [80] 100.0% [85] 982(0.8%) 326(0.3%) for-loop ...acket/contract/private/list.rkt:743:12 for-loop [91] 34.0% ??? [90] 32.8% --------------------------------------------------------------------------- ??? [79] 100.0% [86] 648(0.6%) 316(0.3%) ??? ...ects/racket/contract/private/prop.rkt:493:4 ??? [92] 51.2% --------------------------------------------------------------------------- ??? [82] 100.0% [87] 312(0.3%) 0(0.0%) for-loop ...racket/contract/private/list.rkt:680:9 get/build-late-neg-projection [93]100.0% --------------------------------------------------------------------------- bf-complex-mult [83] 100.0% [88] 47052(40.5%) 716(0.6%) bf* ...ath/private/bigfloat/bigfloat-mpfr.rkt:95:0 ??? [94] 98.5% --------------------------------------------------------------------------- bf-complex-add [84] 11.8% bf-complex-mult [83] 88.2% [89] 2722(2.3%) 0(0.0%) ...higher-order.rkt:346:33 (unknown source) ??? [95] 75.5% ??? [100] 24.5% --------------------------------------------------------------------------- for-loop [85] 48.3% ??? [80] 51.7% [90] 666(0.6%) 322(0.3%) ??? ...private/unconstrained-domain-arrow.rkt:74:4 make-keyword-procedure [96] 51.7% --------------------------------------------------------------------------- for-loop [85] 100.0% [91] 334(0.3%) 334(0.3%) for-loop ...racket/contract/private/hash.rkt:239:6 --------------------------------------------------------------------------- ??? [86] 100.0% [92] 332(0.3%) 332(0.3%) ??? ...lects/racket/contract/private/orc.rkt:83:14 --------------------------------------------------------------------------- for-loop [87] 100.0% [93] 312(0.3%) 0(0.0%) get/build-late-neg-projection ...te/guts.rkt:691:0 ??? [97] 100.0% --------------------------------------------------------------------------- bf-complex-add [84] 12.1% bf-complex-mult [83] 29.1% bf* [88] 58.8% [94] 78848(67.9%) 5802(5.0%) ??? ...-racket/utils/simple-result-arrow.rkt:39:12 bfadd [98] 83.6% bfneg [99] 9.1% --------------------------------------------------------------------------- ...higher-order.rkt:346:33 [89] 100.0% [95] 2056(1.8%) 1380(1.2%) ??? ...cts/racket/contract/private/list.rkt:187:10 ??? [100] 32.9% --------------------------------------------------------------------------- ??? [90] 100.0% [96] 344(0.3%) 344(0.3%) make-keyword-procedure ...ket/private/kw.rkt:260:4 --------------------------------------------------------------------------- get/build-late-neg-projection [93]100.0% [97] 312(0.3%) 0(0.0%) ??? ...cts/racket/contract/private/prop.rkt:314:12 build-compound-type-name [101] 100.0% --------------------------------------------------------------------------- ??? [94] 100.0% [98] 65894(56.8%) 43790(37.7%) bfadd ...-lib/math/private/bigfloat/mpfr.rkt:819:4 ??? [102] 33.5% --------------------------------------------------------------------------- ??? [94] 100.0% [99] 7152(6.2%) 4274(3.7%) bfneg ...-lib/math/private/bigfloat/mpfr.rkt:616:4 ??? [102] 40.2% --------------------------------------------------------------------------- ??? [67] 22.2% ...higher-order.rkt:346:33 [89] 38.6% ??? [95] 39.2% [100] 1726(1.5%) 1726(1.5%) ??? ...ects/racket/contract/private/guts.rkt:644:8 --------------------------------------------------------------------------- contract-struct-name [103] 50.0% ??? [97] 50.0% [101] 312(0.3%) 312(0.3%) build-compound-type-name ...private/guts.rkt:448:0 contract-struct-name [103] 50.0% --------------------------------------------------------------------------- bfneg [99] 11.5% bfadd [98] 88.5% [102] 24982(21.5%) 24982(21.5%) ??? .../share/racket/collects/ffi/unsafe.rkt:861:4 --------------------------------------------------------------------------- build-compound-type-name [101] 100.0% [103] 312(0.3%) 0(0.0%) contract-struct-name ...ract/private/prop.rkt:89:0 build-compound-type-name [101] 100.0% ---------------------------------------------------------------------------