Profiling results ----------------- Total cpu time observed: 144080ms (out of 148780ms) Number of samples taken: 332 (once every 434ms) (Hiding functions with self<1.0% and local<2.0%: 1 of 92 hidden) ======================================================================================== Caller Idx Total Self Name+src Local% ms(pct) ms(pct) Callee ======================================================================================== ??? [11] 100.0% [1] 141396(98.1%) 0(0.0%) profile-thunk16 ...t/pkgs/profile-lib/main.rkt:9:0 run [7] 100.0% ---------------------------------------------------------------------------------------- map [46] 0.4% loop [68] 99.6% [2] 124576(86.5%) 0(0.0%) ??? ...tlies/herbie/develop/src/programs.rkt:154:4 ??? [8] 100.0% ---------------------------------------------------------------------------------------- ??? [60] 100.0% [3] 8146(5.7%) 0(0.0%) iterate-egraph!13 ...p/src/core/simplify.rkt:102:0 one-iter [9] 100.0% ---------------------------------------------------------------------------------------- hash-ref! [56] 100.0% [4] 1772(1.2%) 0(0.0%) f6 ...et/collects/racket/match/compiler.rkt:507:40 map [46] 100.0% ---------------------------------------------------------------------------------------- ??? [60] 100.0% [5] 1374(1.0%) 0(0.0%) loop ...herbie/develop/src/core/simplify.rkt:215:2 pass [10] 100.0% ---------------------------------------------------------------------------------------- parse-loop12 [63] 1.8% loop [6] 98.2% [6] 708(0.5%) 0(0.0%) loop ...cket/collects/racket/private/map.rkt:36:19 loop [6] 98.2% ??? [15] 1.8% ---------------------------------------------------------------------------------------- profile-thunk16 [1] 100.0% [7] 141396(98.1%) 0(0.0%) run ...share/racket/pkgs/profile-lib/main.rkt:39:2 ??? [11] 100.0% ---------------------------------------------------------------------------------------- ??? [2] 100.0% [8] 124576(86.5%) 8896(6.2%) ??? ...acket/collects/racket/private/kw.rkt:444:14 bf-complex-mult [76] 83.8% bf-complex-add [12] 6.7% ??? [16] 1.3% parse-loop12 [63] 0.3% ??? [15] 0.3% ??? [18] 0.3% ---------------------------------------------------------------------------------------- iterate-egraph!13 [3] 100.0% [9] 8146(5.7%) 0(0.0%) one-iter ...ie/develop/src/core/simplify.rkt:113:0 for-loop [13] 59.9% loop [14] 40.1% ---------------------------------------------------------------------------------------- loop [5] 100.0% [10] 1374(1.0%) 0(0.0%) pass ...herbie/develop/src/core/simplify.rkt:205:2 for-loop [17] 100.0% ---------------------------------------------------------------------------------------- run [7] 50.0% [11] 141396(98.1%) 476(0.3%) ??? ...lects/racket/private/more-scheme.rkt:261:28 profile-thunk16 [1] 50.0% loop [26] 44.2% run-improve50 [19] 5.7% ---------------------------------------------------------------------------------------- ??? [8] 100.0% [12] 8312(5.8%) 0(0.0%) bf-complex-add .../develop/src/bigcomplex.rkt:22:0 ??? [85] 91.6% ...higher-order.rkt:346:33 [82] 8.4% ---------------------------------------------------------------------------------------- for-loop [13] 50.0% one-iter [9] 50.0% [13] 4876(3.4%) 330(0.2%) for-loop ...e/develop/src/core/simplify.rkt:123:12 for-loop [13] 50.0% rule-valid-at-type? [20] 43.3% match-e [25] 3.3% ---------------------------------------------------------------------------------------- one-iter [9] 100.0% [14] 3270(2.3%) 0(0.0%) loop ...cket/collects/racket/private/map.rkt:52:19 apply-match [21] 100.0% ---------------------------------------------------------------------------------------- get-final-combination [33] 18.2% ??? [8] 18.9% loop [68] 22.9% loop [6] 40.0% [15] 1770(1.2%) 700(0.5%) ??? ...tract/private/arrow-higher-order.rkt:342:33 ??? [60] 60.5% ---------------------------------------------------------------------------------------- ??? [8] 100.0% [16] 1606(1.1%) 1606(1.1%) ??? ...rivate/unconstrained-domain-arrow.rkt:40:13 ---------------------------------------------------------------------------------------- pass [10] 100.0% [17] 1374(1.0%) 360(0.2%) for-loop ...e/develop/src/core/simplify.rkt:208:29 argmin [22] 47.7% loop [23] 26.1% ---------------------------------------------------------------------------------------- ??? [8] 100.0% [18] 324(0.2%) 0(0.0%) ??? ...ects/racket/contract/private/prop.rkt:493:4 ??? [24] 100.0% ---------------------------------------------------------------------------------------- ??? [11] 100.0% [19] 16052(11.1%) 0(0.0%) run-improve50 ...ie/develop/src/mainloop.rkt:234:0 setup-alt-simplified [27] 51.1% loop [26] 35.8% for-loop [29] 11.0% get-final-combination [33] 2.0% ---------------------------------------------------------------------------------------- for-loop [13] 100.0% [20] 4222(2.9%) 2864(2.0%) rule-valid-at-type? .../src/syntax/rules.rkt:489:0 for-loop [30] 32.2% ---------------------------------------------------------------------------------------- loop [14] 100.0% [21] 3270(2.3%) 0(0.0%) apply-match ...develop/src/core/simplify.rkt:130:2 for-loop [28] 79.9% update-leader! [44] 20.1% ---------------------------------------------------------------------------------------- for-loop [17] 100.0% [22] 656(0.5%) 0(0.0%) argmin ...re/racket/collects/racket/list.rkt:743:0 expression-cost [32] 50.6% for-loop [31] 49.4% ---------------------------------------------------------------------------------------- for-loop [17] 100.0% [23] 358(0.2%) 0(0.0%) loop ...hare/racket/collects/racket/list.rkt:729:4 for-loop [31] 100.0% ---------------------------------------------------------------------------------------- ??? [18] 100.0% [24] 324(0.2%) 324(0.2%) ??? ...lects/racket/contract/private/orc.rkt:83:14 ---------------------------------------------------------------------------------------- for-loop [13] 100.0% [25] 324(0.2%) 324(0.2%) match-e ...herbie/develop/src/core/ematch.rkt:46:0 ---------------------------------------------------------------------------------------- run-improve50 [19] 4.4% ??? [11] 95.6% [26] 130618(90.7%) 0(0.0%) loop ...htlies/herbie/develop/src/points.rkt:193:2 make-exacts* [40] 54.1% loop [34] 43.9% loop [41] 2.0% ---------------------------------------------------------------------------------------- run-improve50 [19] 100.0% [27] 8208(5.7%) 0(0.0%) setup-alt-simplified .../develop/src/glue.rkt:49:0 simplify-alt [35] 100.0% ---------------------------------------------------------------------------------------- apply-match [21] 100.0% [28] 2612(1.8%) 0(0.0%) for-loop ...e/develop/src/core/simplify.rkt:145:10 substitute-e [37] 50.8% merge-egraph-nodes! [38] 36.4% mk-enode! [43] 12.8% ---------------------------------------------------------------------------------------- run-improve50 [19] 100.0% [29] 1772(1.2%) 0(0.0%) for-loop ...herbie/develop/src/mainloop.rkt:249:10 run-iter! [36] 100.0% ---------------------------------------------------------------------------------------- rule-valid-at-type? [20] 100.0% [30] 1358(0.9%) 1358(0.9%) for-loop ...ies/herbie/develop/src/common.rkt:99:9 ---------------------------------------------------------------------------------------- argmin [22] 47.5% loop [23] 52.5% [31] 682(0.5%) 0(0.0%) for-loop .../herbie/develop/src/programs.rkt:199:2 ??? [60] 52.5% ...velop/src/common.rkt:47:2 [65] 47.5% ---------------------------------------------------------------------------------------- argmin [22] 100.0% [32] 332(0.2%) 0(0.0%) expression-cost .../develop/src/programs.rkt:198:0 compile [39] 100.0% ---------------------------------------------------------------------------------------- run-improve50 [19] 100.0% [33] 322(0.2%) 0(0.0%) get-final-combination ...op/src/mainloop.rkt:264:0 ??? [15] 100.0% ---------------------------------------------------------------------------------------- loop [26] 100.0% [34] 57326(39.8%) 0(0.0%) loop ...htlies/herbie/develop/src/points.rkt:151:2 loop [41] 54.3% make-exacts* [40] 40.1% eval-prog [47] 5.5% ---------------------------------------------------------------------------------------- setup-alt-simplified [27] 100.0% [35] 8208(5.7%) 0(0.0%) simplify-alt ...s/herbie/develop/src/glue.rkt:76:0 ??? [60] 100.0% ---------------------------------------------------------------------------------------- for-loop [29] 100.0% [36] 1772(1.2%) 0(0.0%) run-iter! ...herbie/develop/src/mainloop.rkt:215:0 localize-error [42] 100.0% ---------------------------------------------------------------------------------------- substitute-e [37] 24.3% for-loop [28] 75.7% [37] 1326(0.9%) 0(0.0%) substitute-e ...e/develop/src/core/ematch.rkt:71:0 mk-enode! [43] 75.7% substitute-e [37] 24.3% ---------------------------------------------------------------------------------------- for-loop [28] 100.0% [38] 952(0.7%) 0(0.0%) merge-egraph-nodes! ...p/src/core/egraph.rkt:152:0 update-leader! [44] 66.4% enode-merge! [45] 33.6% ---------------------------------------------------------------------------------------- expression-cost [32] 100.0% [39] 332(0.2%) 0(0.0%) compile ...s/herbie/develop/src/programs.rkt:175:0 hash-ref! [56] 100.0% ---------------------------------------------------------------------------------------- loop [34] 24.6% loop [26] 75.4% [40] 93636(65.0%) 0(0.0%) make-exacts* ...erbie/develop/src/points.rkt:138:0 map [46] 50.3% loop [68] 45.3% eval-prog [47] 4.4% ---------------------------------------------------------------------------------------- loop [26] 7.9% loop [34] 92.1% [41] 33802(23.5%) 0(0.0%) loop ...htlies/herbie/develop/src/points.rkt:141:4 map [46] 100.0% ---------------------------------------------------------------------------------------- run-iter! [36] 100.0% [42] 1772(1.2%) 0(0.0%) localize-error ...velop/src/core/localize.rkt:47:0 hash-ref! [56] 100.0% ---------------------------------------------------------------------------------------- for-loop [28] 20.1% substitute-e [37] 79.9% [43] 1660(1.2%) 0(0.0%) mk-enode! ...bie/develop/src/core/egraph.rkt:101:0 new-enode [48] 100.0% ---------------------------------------------------------------------------------------- merge-egraph-nodes! [38] 49.0% apply-match [21] 51.0% [44] 1290(0.9%) 0(0.0%) update-leader! ...evelop/src/core/egraph.rkt:217:0 for-loop [49] 100.0% ---------------------------------------------------------------------------------------- merge-egraph-nodes! [38] 100.0% [45] 320(0.2%) 0(0.0%) enode-merge! ...e/develop/src/core/enode.rkt:129:0 adopt-enode! [50] 100.0% ---------------------------------------------------------------------------------------- f6 [4] 2.1% loop [41] 40.9% make-exacts* [40] 57.0% [46] 82646(57.4%) 0(0.0%) map ...acket/collects/racket/private/map.rkt:20:13 loop [68] 97.3% ??? [51] 2.1% ??? [2] 0.5% ---------------------------------------------------------------------------------------- loop [34] 43.4% make-exacts* [40] 56.6% [47] 7330(5.1%) 0(0.0%) eval-prog ...herbie/develop/src/programs.rkt:148:0 hash-ref! [56] 95.5% ??? [54] 4.5% ---------------------------------------------------------------------------------------- mk-enode! [43] 100.0% [48] 1660(1.2%) 0(0.0%) new-enode ...erbie/develop/src/core/enode.rkt:97:0 type-of-enode-expr [52] 100.0% ---------------------------------------------------------------------------------------- update-leader! [44] 100.0% [49] 1290(0.9%) 0(0.0%) for-loop ...rbie/develop/src/core/egraph.rkt:222:6 for-loop [53] 100.0% ---------------------------------------------------------------------------------------- enode-merge! [45] 100.0% [50] 320(0.2%) 0(0.0%) adopt-enode! ...e/develop/src/core/enode.rkt:105:0 custom-set-union [55] 100.0% ---------------------------------------------------------------------------------------- map [46] 18.7% loop [68] 81.3% [51] 1772(1.2%) 0(0.0%) ??? ...ket/collects/racket/private/list.rkt:323:18 hash-ref! [56] 100.0% ---------------------------------------------------------------------------------------- new-enode [48] 100.0% [52] 1660(1.2%) 0(0.0%) type-of-enode-expr ...elop/src/core/enode.rkt:68:0 get-sigs [57] 100.0% ---------------------------------------------------------------------------------------- for-loop [49] 100.0% [53] 1290(0.9%) 0(0.0%) for-loop ...rbie/develop/src/core/egraph.rkt:223:8 hash-update! [58] 100.0% ---------------------------------------------------------------------------------------- eval-prog [47] 100.0% [54] 330(0.2%) 0(0.0%) ??? ...cket/collects/racket/private/kw.rkt:1633:36 unpack245 [59] 100.0% ---------------------------------------------------------------------------------------- adopt-enode! [50] 100.0% [55] 320(0.2%) 320(0.2%) custom-set-union ...et/private/set-types.rkt:168:0 ---------------------------------------------------------------------------------------- ??? [61] 1.8% compile [39] 1.8% localize-error [42] 2.8% eval-prog [47] 15.9% ??? [51] 16.6% loop [68] 61.0% [56] 9104(6.3%) 332(0.2%) hash-ref! ...racket/private/more-scheme.rkt:373:13 ??? [61] 62.8% parse-loop12 [63] 16.6% bigfloat-hash [62] 15.9% f6 [4] 2.8% ---------------------------------------------------------------------------------------- type-of-enode-expr [52] 100.0% [57] 1660(1.2%) 322(0.2%) get-sigs .../herbie/develop/src/type-check.rkt:5:0 ...velop/src/common.rkt:47:2 [65] 39.5% ??? [66] 21.0% ??? [60] 20.1% ---------------------------------------------------------------------------------------- for-loop [53] 100.0% [58] 1290(0.9%) 0(0.0%) hash-update! ...ket/private/more-scheme.rkt:362:13 ??? [64] 100.0% ---------------------------------------------------------------------------------------- ??? [54] 100.0% [59] 330(0.2%) 0(0.0%) unpack245 ...private/arrow-higher-order.rkt:354:44 maybe-cons-kwd [67] 100.0% ---------------------------------------------------------------------------------------- get-sigs [57] 1.1% for-loop [31] 1.2% ??? [15] 8.9% simplify-alt [35] 39.4% ??? [60] 45.2% [60] 10268(7.1%) 406(0.3%) ??? ...llects/racket/private/norm-define.rkt:53:83 ??? [60] 45.2% iterate-egraph!13 [3] 39.1% loop [5] 6.1% return/no-unsupplied [74] 3.3% ??? [77] 2.2% ---------------------------------------------------------------------------------------- hash-ref! [56] 100.0% [61] 7006(4.9%) 0(0.0%) ??? ...tlies/herbie/develop/src/programs.rkt:183:5 loop [68] 95.3% hash-ref! [56] 4.7% ---------------------------------------------------------------------------------------- hash-ref! [56] 100.0% [62] 7000(4.9%) 0(0.0%) bigfloat-hash ...h/private/bigfloat/mpfr.rkt:165:0 bfcanonicalize [69] 55.4% sig+exp->bigfloat [70] 44.6% ---------------------------------------------------------------------------------------- ??? [8] 16.3% hash-ref! [56] 83.7% [63] 2118(1.5%) 346(0.2%) parse-loop12 ...s/racket/match/compiler.rkt:418:15 loop [68] 73.4% loop [6] 10.2% ---------------------------------------------------------------------------------------- hash-update! [58] 100.0% [64] 1290(0.9%) 0(0.0%) ??? ...s/herbie/develop/src/core/egraph.rkt:225:24 for-loop [71] 100.0% ---------------------------------------------------------------------------------------- for-loop [31] 33.1% get-sigs [57] 66.9% [65] 980(0.7%) 324(0.2%) ...velop/src/common.rkt:47:2 ...e/arr-i.rkt:906:19 ??? [72] 66.9% ---------------------------------------------------------------------------------------- get-sigs [57] 100.0% [66] 348(0.2%) 0(0.0%) ??? ...contract/private/arrow-val-first.rkt:357:18 hash-has-key? [73] 100.0% ---------------------------------------------------------------------------------------- unpack245 [59] 100.0% [67] 330(0.2%) 0(0.0%) maybe-cons-kwd ...ate/arrow-higher-order.rkt:498:0 successfully-got-the-right-kind-of-function [75]100.0% ---------------------------------------------------------------------------------------- make-exacts* [40] 0.2% parse-loop12 [63] 0.7% map [46] 1.3% ??? [61] 5.0% loop [68] 92.9% [68] 132988(92.3%) 350(0.2%) loop ...cket/collects/racket/private/map.rkt:25:19 loop [68] 92.9% hash-ref! [56] 5.0% ??? [2] 1.4% ??? [51] 0.7% bf-complex-mult [76] 0.0% ??? [15] 0.0% ---------------------------------------------------------------------------------------- bigfloat-hash [62] 100.0% [69] 3876(2.7%) 3876(2.7%) bfcanonicalize .../private/bigfloat/mpfr.rkt:155:0 ---------------------------------------------------------------------------------------- bigfloat-hash [62] 100.0% [70] 3124(2.2%) 2778(1.9%) sig+exp->bigfloat ...ivate/bigfloat/mpfr.rkt:385:0 integer->mpz [79] 11.1% ---------------------------------------------------------------------------------------- ??? [64] 100.0% [71] 1290(0.9%) 1290(0.9%) for-loop ...bie/develop/src/core/egraph.rkt:226:26 ---------------------------------------------------------------------------------------- ...velop/src/common.rkt:47:2 [65] 100.0% [72] 656(0.5%) 0(0.0%) ??? ...s/racket/contract/private/arr-i.rkt:1268:39 ??? [78] 100.0% ---------------------------------------------------------------------------------------- ??? [66] 100.0% [73] 348(0.2%) 0(0.0%) hash-has-key? ...et/private/more-scheme.rkt:368:13 ??? [77] 100.0% ---------------------------------------------------------------------------------------- ??? [60] 100.0% [74] 342(0.2%) 0(0.0%) return/no-unsupplied ...ct/private/arr-i.rkt:533:0 filter [80] 100.0% ---------------------------------------------------------------------------------------- maybe-cons-kwd [67] 100.0% [75] 330(0.2%) 330(0.2%) successfully-got-the-right-kind-of-function ...9:4 ---------------------------------------------------------------------------------------- loop [68] 0.7% ??? [8] 99.3% [76] 105116(73.0%) 6042(4.2%) bf-complex-mult ...develop/src/bigcomplex.rkt:33:0 bf* [81] 49.7% ??? [85] 40.2% ...higher-order.rkt:346:33 [82] 4.3% ---------------------------------------------------------------------------------------- hash-has-key? [73] 33.5% ??? [60] 66.5% [77] 1040(0.7%) 358(0.2%) ??? ...ects/racket/contract/private/list.rkt:737:4 ??? [87] 33.5% for-loop [83] 32.1% ---------------------------------------------------------------------------------------- ??? [72] 100.0% [78] 656(0.5%) 334(0.2%) ??? ...racket/collects/racket/private/kw.rkt:761:9 ??? [84] 49.1% ---------------------------------------------------------------------------------------- sig+exp->bigfloat [70] 100.0% [79] 346(0.2%) 346(0.2%) integer->mpz ...math/private/bigfloat/gmp.rkt:87:0 ---------------------------------------------------------------------------------------- return/no-unsupplied [74] 100.0% [80] 342(0.2%) 342(0.2%) filter ...t/collects/racket/private/list.rkt:256:2 ---------------------------------------------------------------------------------------- bf-complex-mult [76] 100.0% [81] 52234(36.3%) 0(0.0%) bf* ...ath/private/bigfloat/bigfloat-mpfr.rkt:95:0 ??? [85] 100.0% ---------------------------------------------------------------------------------------- bf-complex-add [12] 13.3% bf-complex-mult [76] 86.7% [82] 5266(3.7%) 1204(0.8%) ...higher-order.rkt:346:33 (unknown source) ??? [86] 77.1% ---------------------------------------------------------------------------------------- ??? [77] 100.0% [83] 334(0.2%) 0(0.0%) for-loop ...acket/contract/private/list.rkt:743:12 ??? [87] 100.0% ---------------------------------------------------------------------------------------- ??? [78] 100.0% [84] 322(0.2%) 322(0.2%) ??? ...s/racket/contract/private/arr-i.rkt:1233:27 ---------------------------------------------------------------------------------------- bf-complex-add [12] 7.5% bf-complex-mult [76] 41.4% bf* [81] 51.1% [85] 102120(70.9%) 4166(2.9%) ??? ...-racket/utils/simple-result-arrow.rkt:39:12 bfmul [88] 83.7% bfneg [89] 12.2% ---------------------------------------------------------------------------------------- ...higher-order.rkt:346:33 [82] 100.0% [86] 4062(2.8%) 3338(2.3%) ??? ...cts/racket/contract/private/list.rkt:187:10 ??? [90] 17.8% ---------------------------------------------------------------------------------------- for-loop [83] 49.0% ??? [77] 51.0% [87] 682(0.5%) 682(0.5%) ??? ...private/unconstrained-domain-arrow.rkt:74:4 ---------------------------------------------------------------------------------------- ??? [85] 100.0% [88] 85510(59.3%) 61496(42.7%) bfmul ...-lib/math/private/bigfloat/mpfr.rkt:819:4 ??? [91] 28.1% ---------------------------------------------------------------------------------------- ??? [85] 100.0% [89] 12444(8.6%) 5484(3.8%) bfneg ...-lib/math/private/bigfloat/mpfr.rkt:616:4 ??? [91] 55.9% ---------------------------------------------------------------------------------------- ??? [86] 100.0% [90] 724(0.5%) 724(0.5%) ??? ...ects/racket/contract/private/guts.rkt:644:8 ---------------------------------------------------------------------------------------- bfneg [89] 22.5% bfmul [88] 77.5% [91] 30974(21.5%) 30974(21.5%) ??? .../share/racket/collects/ffi/unsafe.rkt:861:4 ----------------------------------------------------------------------------------------