Profiling results ----------------- Total cpu time observed: 119586ms (out of 123232ms) Number of samples taken: 288 (once every 415ms) (Hiding functions with self<1.0% and local<2.0%: 3 of 105 hidden) =========================================================================== Caller Idx Total Self Name+src Local% ms(pct) ms(pct) Callee =========================================================================== run [11] 49.6% [1] 118948(99.5%) 0(0.0%) ??? ...lects/racket/private/more-scheme.rkt:261:28 profile-thunk16 [6] 49.6% loop [12] 42.9% run-improve50 [8] 7.5% --------------------------------------------------------------------------- for-loop [83] 0.3% loop [28] 0.3% loop [33] 99.4% [2] 100510(84.0%) 0(0.0%) ??? ...tlies/herbie/develop/src/programs.rkt:154:4 ??? [7] 100.0% --------------------------------------------------------------------------- hash-ref! [90] 100.0% [3] 3348(2.8%) 0(0.0%) ??? ...tlies/herbie/develop/src/programs.rkt:192:5 loop [33] 100.0% --------------------------------------------------------------------------- ??? [34] 100.0% [4] 1320(1.1%) 0(0.0%) loop ...herbie/develop/src/core/simplify.rkt:237:2 pass [10] 100.0% --------------------------------------------------------------------------- parse-loop12 [92] 2.6% loop [5] 97.4% [5] 668(0.6%) 0(0.0%) loop ...cket/collects/racket/private/map.rkt:36:19 loop [5] 97.4% f137 [84] 1.8% ??? [9] 0.8% --------------------------------------------------------------------------- ??? [1] 100.0% [6] 117974(98.7%) 0(0.0%) profile-thunk16 ...t/pkgs/profile-lib/main.rkt:9:0 run [11] 100.0% --------------------------------------------------------------------------- ??? [2] 100.0% [7] 100510(84.0%) 5626(4.7%) ??? ...acket/collects/racket/private/kw.rkt:444:14 bf-complex-mult [13] 83.0% bf-complex-add [93] 10.1% parse-loop12 [92] 0.6% --------------------------------------------------------------------------- ??? [1] 100.0% [8] 17190(14.4%) 0(0.0%) run-improve50 ...ie/develop/src/mainloop.rkt:234:0 setup-alt-simplified [14] 57.5% loop [12] 23.2% for-loop [15] 13.5% get-final-combination [17] 3.7% ??? [64] 2.0% --------------------------------------------------------------------------- get-final-combination [17] 9.2% loop [5] 9.9% f137 [84] 20.6% map [87] 29.2% loop [33] 31.1% [9] 3422(2.9%) 0(0.0%) ??? ...tract/private/arrow-higher-order.rkt:342:33 ??? [34] 89.5% ??? [18] 10.5% --------------------------------------------------------------------------- loop [4] 100.0% [10] 1320(1.1%) 0(0.0%) pass ...herbie/develop/src/core/simplify.rkt:227:2 for-loop [16] 100.0% --------------------------------------------------------------------------- profile-thunk16 [6] 100.0% [11] 117974(98.7%) 0(0.0%) run ...share/racket/pkgs/profile-lib/main.rkt:39:2 ??? [1] 100.0% --------------------------------------------------------------------------- run-improve50 [8] 3.8% ??? [1] 96.2% [12] 105748(88.4%) 0(0.0%) loop ...htlies/herbie/develop/src/points.rkt:205:2 loop [28] 34.4% loop [20] 33.9% make-exacts* [29] 31.6% --------------------------------------------------------------------------- ??? [7] 100.0% [13] 83392(69.7%) 3850(3.2%) bf-complex-mult ...develop/src/bigcomplex.rkt:33:0 bf* [19] 55.7% ??? [96] 36.3% ...higher-order.rkt:346:33 [22] 3.4% --------------------------------------------------------------------------- run-improve50 [8] 100.0% [14] 9890(8.3%) 0(0.0%) setup-alt-simplified .../develop/src/glue.rkt:49:0 simplify-alt [21] 100.0% --------------------------------------------------------------------------- run-improve50 [8] 100.0% [15] 2328(1.9%) 0(0.0%) for-loop ...herbie/develop/src/mainloop.rkt:249:10 run-iter! [23] 100.0% --------------------------------------------------------------------------- pass [10] 100.0% [16] 1320(1.1%) 0(0.0%) for-loop ...e/develop/src/core/simplify.rkt:230:29 argmin [24] 75.3% loop [26] 24.7% --------------------------------------------------------------------------- run-improve50 [8] 100.0% [17] 636(0.5%) 0(0.0%) get-final-combination ...op/src/mainloop.rkt:264:0 extract-alt [27] 50.6% ??? [9] 49.4% --------------------------------------------------------------------------- ??? [9] 100.0% [18] 360(0.3%) 0(0.0%) ??? ...contract/private/../../private/kw.rkt:761:9 integer->bigfloat [25] 100.0% --------------------------------------------------------------------------- bf-complex-mult [13] 100.0% [19] 46432(38.8%) 466(0.4%) bf* ...ath/private/bigfloat/bigfloat-mpfr.rkt:95:0 ??? [96] 99.0% --------------------------------------------------------------------------- loop [12] 100.0% [20] 35894(30.0%) 0(0.0%) loop ...htlies/herbie/develop/src/points.rkt:158:2 make-exacts* [29] 52.9% loop [28] 47.1% --------------------------------------------------------------------------- setup-alt-simplified [14] 100.0% [21] 9890(8.3%) 0(0.0%) simplify-alt ...s/herbie/develop/src/glue.rkt:76:0 ??? [34] 100.0% --------------------------------------------------------------------------- bf-complex-mult [13] 100.0% [22] 2834(2.4%) 668(0.6%) ...higher-order.rkt:346:33 (unknown source) ??? [82] 76.4% --------------------------------------------------------------------------- for-loop [15] 100.0% [23] 2328(1.9%) 0(0.0%) run-iter! ...herbie/develop/src/mainloop.rkt:215:0 localize-error [30] 100.0% --------------------------------------------------------------------------- for-loop [16] 100.0% [24] 994(0.8%) 0(0.0%) argmin ...re/racket/collects/racket/list.rkt:743:0 for-loop [31] 100.0% --------------------------------------------------------------------------- ??? [18] 100.0% [25] 360(0.3%) 0(0.0%) integer->bigfloat ...ivate/bigfloat/mpfr.rkt:399:0 ??? [102] 100.0% --------------------------------------------------------------------------- for-loop [16] 100.0% [26] 326(0.3%) 0(0.0%) loop ...hare/racket/collects/racket/list.rkt:729:4 for-loop [31] 100.0% --------------------------------------------------------------------------- get-final-combination [17] 100.0% [27] 322(0.3%) 0(0.0%) extract-alt ...es/herbie/develop/src/glue.rkt:55:0 argmins [32] 100.0% --------------------------------------------------------------------------- loop [20] 31.7% loop [12] 68.3% [28] 53344(44.6%) 0(0.0%) loop ...htlies/herbie/develop/src/points.rkt:141:4 loop [33] 99.4% ??? [2] 0.6% --------------------------------------------------------------------------- loop [20] 36.2% loop [12] 63.8% [29] 52404(43.8%) 0(0.0%) make-exacts* ...erbie/develop/src/points.rkt:138:0 loop [33] 92.9% eval-prog [81] 7.1% --------------------------------------------------------------------------- run-iter! [23] 100.0% [30] 2328(1.9%) 0(0.0%) localize-error ...velop/src/core/localize.rkt:47:0 hash-ref! [90] 100.0% --------------------------------------------------------------------------- loop [26] 24.7% argmin [24] 75.3% [31] 1320(1.1%) 0(0.0%) for-loop .../herbie/develop/src/programs.rkt:208:2 ??? [34] 75.5% ...velop/src/common.rkt:47:2 [35] 24.5% --------------------------------------------------------------------------- extract-alt [27] 100.0% [32] 322(0.3%) 0(0.0%) argmins ...ies/herbie/develop/src/common.rkt:150:0 composed [36] 100.0% --------------------------------------------------------------------------- loop! [56] 0.1% make-exacts* [29] 0.4% loop [28] 0.6% parse-loop12 [92] 1.4% ??? [3] 3.1% loop [33] 94.5% [33] 107728(90.1%) 762(0.6%) loop ...cket/collects/racket/private/map.rkt:25:19 loop [33] 94.5% hash-ref! [90] 3.1% ??? [89] 1.4% ??? [2] 0.9% loop! [56] 0.1% ??? [9] 0.0% --------------------------------------------------------------------------- for-loop [31] 2.5% ??? [9] 21.9% simplify-alt [21] 36.4% ??? [34] 38.4% [34] 13278(11.1%) 1662(1.4%) ??? ...llects/racket/private/norm-define.rkt:53:83 ??? [34] 38.4% iterate-egraph!13 [37] 29.7% ormap [38] 5.0% loop [4] 3.7% ??? [72] 3.4% ??? [39] 3.4% ??? [40] 3.3% return/no-unsupplied [88] 2.3% --------------------------------------------------------------------------- for-loop [31] 100.0% [35] 324(0.3%) 0(0.0%) ...velop/src/common.rkt:47:2 ...e/arr-i.rkt:906:19 ??? [41] 100.0% --------------------------------------------------------------------------- argmins [32] 100.0% [36] 322(0.3%) 0(0.0%) composed ...ollects/racket/private/list.rkt:321:16 errors [78] 100.0% --------------------------------------------------------------------------- ??? [34] 100.0% [37] 7876(6.6%) 0(0.0%) iterate-egraph!13 ...p/src/core/simplify.rkt:105:0 one-iter [42] 100.0% --------------------------------------------------------------------------- ??? [34] 100.0% [38] 1334(1.1%) 0(0.0%) ormap ...et/collects/racket/private/map.rkt:105:13 loop [43] 100.0% --------------------------------------------------------------------------- ??? [34] 100.0% [39] 666(0.6%) 0(0.0%) ??? ...racket/collects/racket/private/kw.rkt:761:9 ??? [85] 51.1% ??? [44] 48.9% --------------------------------------------------------------------------- ??? [34] 100.0% [40] 436(0.4%) 0(0.0%) ??? ...-racket/utils/simple-result-arrow.rkt:60:15 ??? [102] 100.0% --------------------------------------------------------------------------- ...velop/src/common.rkt:47:2 [35] 100.0% [41] 324(0.3%) 0(0.0%) ??? ...s/racket/contract/private/arr-i.rkt:1268:39 return/no-unsupplied [88] 100.0% --------------------------------------------------------------------------- iterate-egraph!13 [37] 100.0% [42] 7876(6.6%) 0(0.0%) one-iter ...ie/develop/src/core/simplify.rkt:116:0 for-loop [45] 61.5% for-loop [46] 38.5% --------------------------------------------------------------------------- ormap [38] 100.0% [43] 1334(1.1%) 1334(1.1%) loop ...ket/collects/racket/private/map.rkt:112:23 --------------------------------------------------------------------------- ??? [39] 100.0% [44] 326(0.3%) 326(0.3%) ??? ...s/racket/contract/private/arr-i.rkt:1233:27 --------------------------------------------------------------------------- for-loop [45] 50.0% one-iter [42] 50.0% [45] 4844(4.1%) 0(0.0%) for-loop ...e/develop/src/core/simplify.rkt:126:12 for-loop [45] 50.0% rule-valid-at-type? [47] 46.7% match-e [49] 3.3% --------------------------------------------------------------------------- one-iter [42] 100.0% [46] 3032(2.5%) 0(0.0%) for-loop ...ie/develop/src/core/simplify.rkt:166:2 for-loop [48] 100.0% --------------------------------------------------------------------------- for-loop [45] 100.0% [47] 4522(3.8%) 2916(2.4%) rule-valid-at-type? .../src/syntax/rules.rkt:494:0 for-loop [50] 35.5% --------------------------------------------------------------------------- for-loop [46] 100.0% [48] 3032(2.5%) 0(0.0%) for-loop ...e/develop/src/core/simplify.rkt:148:10 merge-egraph-nodes! [51] 45.1% mk-enode! [53] 33.2% substitute-e [52] 21.7% --------------------------------------------------------------------------- for-loop [45] 100.0% [49] 322(0.3%) 322(0.3%) match-e ...herbie/develop/src/core/ematch.rkt:46:0 --------------------------------------------------------------------------- rule-valid-at-type? [47] 100.0% [50] 1606(1.3%) 1276(1.1%) for-loop ...ies/herbie/develop/src/common.rkt:99:9 list-member? [57] 20.5% --------------------------------------------------------------------------- for-loop [55] 6.1% merge-egraph-nodes! [51] 25.3% for-loop [48] 68.6% [51] 1368(1.1%) 0(0.0%) merge-egraph-nodes! ...p/src/core/egraph.rkt:153:0 update-leader! [54] 62.5% merge-egraph-nodes! [51] 25.3% for-loop [55] 6.1% loop! [56] 6.1% --------------------------------------------------------------------------- for-loop [48] 100.0% [52] 658(0.6%) 0(0.0%) substitute-e ...e/develop/src/core/ematch.rkt:71:0 mk-enode! [53] 100.0% --------------------------------------------------------------------------- substitute-e [52] 39.5% for-loop [48] 60.5% [53] 1664(1.4%) 0(0.0%) mk-enode! ...bie/develop/src/core/egraph.rkt:102:0 new-enode [58] 100.0% --------------------------------------------------------------------------- merge-egraph-nodes! [51] 100.0% [54] 1034(0.9%) 0(0.0%) update-leader! ...evelop/src/core/egraph.rkt:218:0 for-loop [59] 100.0% --------------------------------------------------------------------------- merge-egraph-nodes! [51] 100.0% [55] 334(0.3%) 0(0.0%) for-loop ...bie/develop/src/core/egraph.rkt:201:10 merge-egraph-nodes! [51] 100.0% --------------------------------------------------------------------------- loop [33] 50.0% merge-egraph-nodes! [51] 50.0% [56] 334(0.3%) 334(0.3%) loop! ...s/herbie/develop/src/core/enode.rkt:192:2 loop [33] 50.0% --------------------------------------------------------------------------- for-loop [50] 100.0% [57] 330(0.3%) 330(0.3%) list-member? ...llects/racket/private/set.rkt:24:0 --------------------------------------------------------------------------- mk-enode! [53] 100.0% [58] 1664(1.4%) 0(0.0%) new-enode ...erbie/develop/src/core/enode.rkt:97:0 type-of-enode-expr [60] 100.0% --------------------------------------------------------------------------- update-leader! [54] 100.0% [59] 1034(0.9%) 0(0.0%) for-loop ...rbie/develop/src/core/egraph.rkt:223:6 for-loop [61] 100.0% --------------------------------------------------------------------------- new-enode [58] 100.0% [60] 1664(1.4%) 0(0.0%) type-of-enode-expr ...elop/src/core/enode.rkt:68:0 get-sigs [62] 100.0% --------------------------------------------------------------------------- for-loop [59] 100.0% [61] 1034(0.9%) 0(0.0%) for-loop ...rbie/develop/src/core/egraph.rkt:224:8 hash-update! [63] 100.0% --------------------------------------------------------------------------- type-of-enode-expr [60] 100.0% [62] 1664(1.4%) 360(0.3%) get-sigs .../herbie/develop/src/type-check.rkt:5:0 ??? [64] 42.3% ??? [66] 36.1% --------------------------------------------------------------------------- for-loop [61] 100.0% [63] 1034(0.9%) 0(0.0%) hash-update! ...ket/private/more-scheme.rkt:362:13 ??? [65] 100.0% --------------------------------------------------------------------------- run-improve50 [8] 33.0% get-sigs [62] 67.0% [64] 1050(0.9%) 0(0.0%) ??? ...contract/private/arrow-val-first.rkt:357:18 hash-has-key? [68] 67.0% atab-add-altns [69] 33.0% --------------------------------------------------------------------------- hash-update! [63] 100.0% [65] 1034(0.9%) 0(0.0%) ??? ...s/herbie/develop/src/core/egraph.rkt:226:24 for-loop [67] 100.0% --------------------------------------------------------------------------- get-sigs [62] 100.0% [66] 600(0.5%) 0(0.0%) ??? ...ts/racket/contract/private/arr-i.rkt:804:10 get/build-late-neg-projection [71] 50.0% ??? [70] 50.0% --------------------------------------------------------------------------- ??? [65] 100.0% [67] 1034(0.9%) 724(0.6%) for-loop ...bie/develop/src/core/egraph.rkt:227:26 update-en-expr [74] 30.0% --------------------------------------------------------------------------- ??? [64] 100.0% [68] 704(0.6%) 346(0.3%) hash-has-key? ...et/private/more-scheme.rkt:368:13 ??? [72] 50.9% --------------------------------------------------------------------------- ??? [64] 100.0% [69] 346(0.3%) 0(0.0%) atab-add-altns ...elop/src/core/alt-table.rkt:50:0 atab-add-altn [73] 100.0% --------------------------------------------------------------------------- ??? [66] 100.0% [70] 300(0.3%) 300(0.3%) ??? ...ects/racket/contract/private/hash.rkt:217:4 --------------------------------------------------------------------------- ??? [75] 50.0% ??? [66] 50.0% [71] 300(0.3%) 300(0.3%) get/build-late-neg-projection ...te/guts.rkt:691:0 ??? [75] 50.0% --------------------------------------------------------------------------- hash-has-key? [68] 34.8% ??? [34] 65.2% [72] 1030(0.9%) 358(0.3%) ??? ...ects/racket/contract/private/list.rkt:737:4 for-loop [76] 65.2% --------------------------------------------------------------------------- atab-add-altns [69] 100.0% [73] 346(0.3%) 0(0.0%) atab-add-altn ...elop/src/core/alt-table.rkt:208:0 best-and-tied-at-points [77] 100.0% --------------------------------------------------------------------------- for-loop [67] 100.0% [74] 310(0.3%) 310(0.3%) update-en-expr ...evelop/src/core/egraph.rkt:212:0 --------------------------------------------------------------------------- get/build-late-neg-projection [71]100.0% [75] 300(0.3%) 0(0.0%) ??? ...ects/racket/contract/private/hash.rkt:211:2 get/build-late-neg-projection [71]100.0% --------------------------------------------------------------------------- ??? [72] 100.0% [76] 672(0.6%) 0(0.0%) for-loop ...acket/contract/private/list.rkt:743:12 for-loop [79] 51.5% ??? [80] 48.5% --------------------------------------------------------------------------- atab-add-altn [73] 100.0% [77] 346(0.3%) 0(0.0%) best-and-tied-at-points ...ore/alt-table.rkt:122:0 errors [78] 100.0% --------------------------------------------------------------------------- composed [36] 48.2% best-and-tied-at-points [77] 51.8% [78] 668(0.6%) 0(0.0%) errors ...lies/herbie/develop/src/points.rkt:241:0 eval-prog [81] 51.8% for-loop [83] 48.2% --------------------------------------------------------------------------- for-loop [76] 100.0% [79] 346(0.3%) 0(0.0%) for-loop ...racket/contract/private/hash.rkt:239:6 ??? [82] 100.0% --------------------------------------------------------------------------- for-loop [76] 100.0% [80] 326(0.3%) 326(0.3%) ??? ...private/unconstrained-domain-arrow.rkt:74:4 --------------------------------------------------------------------------- errors [78] 8.5% make-exacts* [29] 91.5% [81] 4054(3.4%) 0(0.0%) eval-prog ...herbie/develop/src/programs.rkt:148:0 hash-ref! [90] 82.6% f137 [84] 17.4% --------------------------------------------------------------------------- for-loop [79] 13.8% ...higher-order.rkt:346:33 [22] 86.2% [82] 2512(2.1%) 1526(1.3%) ??? ...cts/racket/contract/private/list.rkt:187:10 ??? [85] 25.5% ??? [86] 13.8% --------------------------------------------------------------------------- errors [78] 100.0% [83] 322(0.3%) 0(0.0%) for-loop ...es/herbie/develop/src/points.rkt:244:4 ??? [2] 100.0% --------------------------------------------------------------------------- eval-prog [81] 3.1% loop [5] 5.4% f137 [84] 20.2% hash-ref! [90] 71.3% [84] 3034(2.5%) 0(0.0%) f137 .../collects/racket/match/compiler.rkt:507:40 map [87] 71.3% f137 [84] 20.2% return/no-unsupplied [88] 5.4% ??? [9] 3.1% --------------------------------------------------------------------------- ??? [39] 34.7% ??? [82] 65.3% [85] 980(0.8%) 980(0.8%) ??? ...ects/racket/contract/private/guts.rkt:644:8 --------------------------------------------------------------------------- ??? [82] 100.0% [86] 346(0.3%) 346(0.3%) ??? ...ects/racket/contract/private/list.rkt:686:7 --------------------------------------------------------------------------- ??? [89] 21.4% f137 [84] 78.6% [87] 2328(1.9%) 0(0.0%) map ...acket/collects/racket/private/map.rkt:20:13 ??? [89] 78.6% ??? [9] 21.4% --------------------------------------------------------------------------- ??? [34] 32.1% ??? [41] 33.8% f137 [84] 34.2% [88] 960(0.8%) 960(0.8%) return/no-unsupplied ...ct/private/arr-i.rkt:533:0 --------------------------------------------------------------------------- parse-loop12 [92] 4.6% map [87] 16.2% loop [33] 79.2% [89] 2328(1.9%) 0(0.0%) ??? ...ket/collects/racket/private/list.rkt:323:18 hash-ref! [90] 93.0% map [87] 7.0% --------------------------------------------------------------------------- localize-error [30] 6.1% eval-prog [81] 13.5% ??? [89] 34.9% loop [33] 45.5% [90] 5676(4.7%) 0(0.0%) hash-ref! ...racket/private/more-scheme.rkt:373:13 ??? [3] 45.5% parse-loop12 [92] 34.9% bigfloat-hash [91] 13.5% f137 [84] 6.1% --------------------------------------------------------------------------- hash-ref! [90] 100.0% [91] 3348(2.8%) 0(0.0%) bigfloat-hash ...h/private/bigfloat/mpfr.rkt:165:0 bfcanonicalize [94] 79.6% sig+exp->bigfloat [95] 20.4% --------------------------------------------------------------------------- ??? [7] 20.9% hash-ref! [90] 79.1% [92] 2944(2.5%) 616(0.5%) parse-loop12 ...s/racket/match/compiler.rkt:418:15 loop [33] 68.6% ??? [89] 5.4% loop [5] 3.2% bf-complex-add [93] 1.9% --------------------------------------------------------------------------- parse-loop12 [92] 3.1% ??? [7] 96.9% [93] 10526(8.8%) 1480(1.2%) bf-complex-add .../develop/src/bigcomplex.rkt:22:0 ??? [96] 85.9% --------------------------------------------------------------------------- bigfloat-hash [91] 100.0% [94] 2666(2.2%) 2342(2.0%) bfcanonicalize .../private/bigfloat/mpfr.rkt:155:0 bigfloat->sig+exp [98] 12.2% --------------------------------------------------------------------------- bigfloat-hash [91] 100.0% [95] 682(0.6%) 358(0.3%) sig+exp->bigfloat ...ivate/bigfloat/mpfr.rkt:385:0 integer->mpz [97] 47.5% --------------------------------------------------------------------------- bf-complex-add [93] 10.6% bf-complex-mult [13] 35.5% bf* [19] 53.9% [96] 85288(71.3%) 7556(6.3%) ??? ...-racket/utils/simple-result-arrow.rkt:39:12 bfmul [99] 81.6% bfneg [100] 9.5% --------------------------------------------------------------------------- sig+exp->bigfloat [95] 100.0% [97] 324(0.3%) 324(0.3%) integer->mpz ...math/private/bigfloat/gmp.rkt:87:0 --------------------------------------------------------------------------- bfcanonicalize [94] 100.0% [98] 324(0.3%) 0(0.0%) bigfloat->sig+exp ...ivate/bigfloat/mpfr.rkt:370:0 mpz->integer [101] 100.0% --------------------------------------------------------------------------- ??? [96] 100.0% [99] 69614(58.2%) 49108(41.1%) bfmul ...-lib/math/private/bigfloat/mpfr.rkt:819:4 ??? [102] 29.5% --------------------------------------------------------------------------- ??? [96] 100.0% [100] 8118(6.8%) 5972(5.0%) bfneg ...-lib/math/private/bigfloat/mpfr.rkt:616:4 ??? [102] 26.4% --------------------------------------------------------------------------- bigfloat->sig+exp [98] 100.0% [101] 324(0.3%) 324(0.3%) mpz->integer ...ath/private/bigfloat/gmp.rkt:115:0 --------------------------------------------------------------------------- integer->bigfloat [25] 1.5% ??? [40] 1.9% bfneg [100] 9.2% bfmul [99] 87.5% [102] 23448(19.6%) 23448(19.6%) ??? .../share/racket/collects/ffi/unsafe.rkt:861:4 ---------------------------------------------------------------------------