Profiling results ----------------- Total cpu time observed: 125710ms (out of 129432ms) Number of samples taken: 307 (once every 409ms) (Hiding functions with self<1.0% and local<2.0%: 3 of 102 hidden) ============================================================================== Caller Idx Total Self Name+src Local% ms(pct) ms(pct) Callee ============================================================================== run [11] 49.2% [1] 124612(99.1%) 0(0.0%) ??? ...lects/racket/private/more-scheme.rkt:261:28 profile-thunk16 [6] 49.2% prepare-points [12] 42.8% run-improve50 [7] 7.9% ------------------------------------------------------------------------------ ->flonum [61] 100.0% [2] 7464(5.9%) 0(0.0%) iterate-egraph!13 ...p/src/core/simplify.rkt:105:0 one-iter [8] 100.0% ------------------------------------------------------------------------------ eval-prog [40] 1.5% f6 [3] 10.5% hash-ref! [48] 88.0% [3] 2926(2.3%) 0(0.0%) f6 ...et/collects/racket/match/compiler.rkt:507:40 map [9] 88.0% f6 [3] 10.5% ??? [18] 1.5% ------------------------------------------------------------------------------ ->flonum [61] 100.0% [4] 1574(1.3%) 0(0.0%) loop ...herbie/develop/src/core/simplify.rkt:237:2 pass [10] 100.0% ------------------------------------------------------------------------------ parse-loop12 [53] 7.7% loop [5] 92.3% [5] 342(0.3%) 0(0.0%) loop ...cket/collects/racket/private/map.rkt:36:19 loop [5] 92.3% ??? [18] 7.7% ------------------------------------------------------------------------------ ??? [1] 100.0% [6] 122692(97.6%) 0(0.0%) profile-thunk16 ...t/pkgs/profile-lib/main.rkt:9:0 run [11] 100.0% ------------------------------------------------------------------------------ ??? [1] 100.0% [7] 18188(14.5%) 0(0.0%) run-improve50 ...ie/develop/src/mainloop.rkt:234:0 setup-alt-simplified [13] 44.5% prepare-points [12] 33.7% for-loop [16] 14.2% setup-prog [20] 3.9% get-final-combination [21] 3.8% ------------------------------------------------------------------------------ iterate-egraph!13 [2] 100.0% [8] 7464(5.9%) 0(0.0%) one-iter ...ie/develop/src/core/simplify.rkt:116:0 for-loop [14] 51.3% for-loop [15] 48.7% ------------------------------------------------------------------------------ ??? [17] 6.8% f6 [3] 93.2% [9] 2576(2.0%) 0(0.0%) map ...acket/collects/racket/private/map.rkt:20:13 ??? [17] 93.2% ??? [18] 6.8% ------------------------------------------------------------------------------ loop [4] 100.0% [10] 1574(1.3%) 0(0.0%) pass ...herbie/develop/src/core/simplify.rkt:227:2 for-loop [19] 100.0% ------------------------------------------------------------------------------ profile-thunk16 [6] 100.0% [11] 122692(97.6%) 0(0.0%) run ...share/racket/pkgs/profile-lib/main.rkt:39:2 ??? [1] 100.0% ------------------------------------------------------------------------------ run-improve50 [7] 5.5% ??? [1] 94.5% [12] 112562(89.5%) 0(0.0%) prepare-points ...bie/develop/src/points.rkt:214:0 make-exacts* [31] 36.1% loop [22] 34.3% loop [32] 29.7% ------------------------------------------------------------------------------ run-improve50 [7] 100.0% [13] 8086(6.4%) 0(0.0%) setup-alt-simplified .../develop/src/glue.rkt:49:0 simplify-alt [23] 100.0% ------------------------------------------------------------------------------ for-loop [14] 50.0% one-iter [8] 50.0% [14] 3830(3.0%) 0(0.0%) for-loop ...e/develop/src/core/simplify.rkt:126:12 for-loop [14] 50.0% rule-valid-at-type? [24] 45.7% match-e [28] 4.3% ------------------------------------------------------------------------------ one-iter [8] 100.0% [15] 3634(2.9%) 0(0.0%) for-loop ...ie/develop/src/core/simplify.rkt:166:2 for-loop [25] 81.3% update-leader! [42] 9.6% match-e [28] 9.1% ------------------------------------------------------------------------------ run-improve50 [7] 100.0% [16] 2576(2.0%) 0(0.0%) for-loop ...herbie/develop/src/mainloop.rkt:249:10 run-iter! [26] 100.0% ------------------------------------------------------------------------------ map [9] 14.3% loop [56] 85.7% [17] 2576(2.0%) 0(0.0%) ??? ...ket/collects/racket/private/list.rkt:323:18 hash-ref! [48] 96.6% map [9] 3.4% ------------------------------------------------------------------------------ get-final-combination [21] 14.1% loop [5] 14.5% map [9] 14.8% f6 [3] 14.8% loop [56] 41.8% [18] 2360(1.9%) 330(0.3%) ??? ...tract/private/arrow-higher-order.rkt:342:33 ->flonum [61] 71.2% ??? [64] 14.8% ------------------------------------------------------------------------------ pass [10] 100.0% [19] 1574(1.3%) 0(0.0%) for-loop ...e/develop/src/core/simplify.rkt:230:29 argmin [27] 79.0% loop [30] 21.0% ------------------------------------------------------------------------------ run-improve50 [7] 100.0% [20] 702(0.6%) 0(0.0%) setup-prog ...ies/herbie/develop/src/glue.rkt:40:0 ??? [62] 100.0% ------------------------------------------------------------------------------ run-improve50 [7] 100.0% [21] 686(0.5%) 0(0.0%) get-final-combination ...op/src/mainloop.rkt:264:0 extract-alt [29] 51.6% ??? [18] 48.4% ------------------------------------------------------------------------------ prepare-points [12] 100.0% [22] 38560(30.7%) 0(0.0%) loop ...htlies/herbie/develop/src/points.rkt:158:2 make-exacts* [31] 59.1% loop [32] 40.9% ------------------------------------------------------------------------------ setup-alt-simplified [13] 100.0% [23] 8086(6.4%) 0(0.0%) simplify-alt ...s/herbie/develop/src/glue.rkt:76:0 ->flonum [61] 100.0% ------------------------------------------------------------------------------ for-loop [14] 100.0% [24] 3500(2.8%) 2272(1.8%) rule-valid-at-type? .../src/syntax/rules.rkt:548:0 *complex-rules* [36] 35.1% ------------------------------------------------------------------------------ for-loop [15] 100.0% [25] 2954(2.3%) 0(0.0%) for-loop ...e/develop/src/core/simplify.rkt:148:10 merge-egraph-nodes! [34] 53.4% substitute-e [37] 24.2% mk-enode! [41] 22.4% ------------------------------------------------------------------------------ for-loop [16] 100.0% [26] 2576(2.0%) 0(0.0%) run-iter! ...herbie/develop/src/mainloop.rkt:215:0 localize-error [33] 100.0% ------------------------------------------------------------------------------ for-loop [19] 100.0% [27] 1244(1.0%) 0(0.0%) argmin ...re/racket/collects/racket/list.rkt:743:0 for-loop [35] 100.0% ------------------------------------------------------------------------------ for-loop [45] 25.0% for-loop [15] 25.0% for-loop [14] 50.0% [28] 660(0.5%) 330(0.3%) match-e ...herbie/develop/src/core/ematch.rkt:46:0 for-loop [39] 50.0% ------------------------------------------------------------------------------ get-final-combination [21] 100.0% [29] 354(0.3%) 0(0.0%) extract-alt ...es/herbie/develop/src/glue.rkt:55:0 argmins [38] 100.0% ------------------------------------------------------------------------------ for-loop [19] 100.0% [30] 330(0.3%) 0(0.0%) loop ...hare/racket/collects/racket/list.rkt:729:4 for-loop [35] 100.0% ------------------------------------------------------------------------------ loop [22] 36.0% prepare-points [12] 64.0% [31] 63426(50.5%) 0(0.0%) make-exacts* ...erbie/develop/src/points.rkt:138:0 loop [56] 88.5% eval-prog [40] 11.0% ------------------------------------------------------------------------------ loop [22] 32.1% prepare-points [12] 67.9% [32] 49136(39.1%) 0(0.0%) loop ...htlies/herbie/develop/src/points.rkt:141:4 loop [56] 100.0% ------------------------------------------------------------------------------ run-iter! [26] 100.0% [33] 2576(2.0%) 0(0.0%) localize-error ...velop/src/core/localize.rkt:47:0 hash-ref! [48] 100.0% ------------------------------------------------------------------------------ for-loop [47] 6.6% merge-egraph-nodes! [34] 16.5% for-loop [25] 76.9% [34] 1578(1.3%) 0(0.0%) merge-egraph-nodes! ...p/src/core/egraph.rkt:153:0 update-leader! [42] 49.9% for-loop [46] 20.4% merge-egraph-nodes! [34] 16.5% for-loop [47] 6.6% for-loop [43] 6.6% ------------------------------------------------------------------------------ loop [30] 21.0% argmin [27] 79.0% [35] 1574(1.3%) 0(0.0%) for-loop .../herbie/develop/src/programs.rkt:210:2 ->flonum [61] 100.0% ------------------------------------------------------------------------------ rule-valid-at-type? [24] 100.0% [36] 1228(1.0%) 326(0.3%) *complex-rules* ...elop/src/syntax/rules.rkt:560:0 for-loop [43] 73.5% ------------------------------------------------------------------------------ substitute-e [37] 50.0% for-loop [25] 50.0% [37] 714(0.6%) 0(0.0%) substitute-e ...e/develop/src/core/ematch.rkt:71:0 substitute-e [37] 50.0% mk-enode! [41] 50.0% ------------------------------------------------------------------------------ extract-alt [29] 100.0% [38] 354(0.3%) 0(0.0%) argmins ...ies/herbie/develop/src/common.rkt:152:0 composed [44] 100.0% ------------------------------------------------------------------------------ match-e [28] 100.0% [39] 330(0.3%) 330(0.3%) for-loop ...rbie/develop/src/core/ematch.rkt:59:11 for-loop [45] 50.0% ------------------------------------------------------------------------------ make-exacts* [31] 100.0% [40] 6964(5.5%) 0(0.0%) eval-prog ...herbie/develop/src/programs.rkt:150:0 hash-ref! [48] 95.0% f6 [3] 5.0% ------------------------------------------------------------------------------ for-loop [25] 48.1% substitute-e [37] 51.9% [41] 1376(1.1%) 0(0.0%) mk-enode! ...bie/develop/src/core/egraph.rkt:102:0 new-enode [49] 100.0% ------------------------------------------------------------------------------ for-loop [15] 27.0% merge-egraph-nodes! [34] 73.0% [42] 1294(1.0%) 0(0.0%) update-leader! ...evelop/src/core/egraph.rkt:218:0 for-loop [50] 100.0% ------------------------------------------------------------------------------ merge-egraph-nodes! [34] 25.7% *complex-rules* [36] 74.3% [43] 1214(1.0%) 1214(1.0%) for-loop ...ies/herbie/develop/src/common.rkt:99:9 ------------------------------------------------------------------------------ argmins [38] 100.0% [44] 354(0.3%) 0(0.0%) composed ...ollects/racket/private/list.rkt:321:16 errors [71] 100.0% ------------------------------------------------------------------------------ for-loop [39] 100.0% [45] 330(0.3%) 0(0.0%) for-loop ...rbie/develop/src/core/ematch.rkt:65:37 match-e [28] 100.0% ------------------------------------------------------------------------------ merge-egraph-nodes! [34] 100.0% [46] 322(0.3%) 0(0.0%) for-loop ...rbie/develop/src/core/egraph.rkt:233:6 update-en-expr [73] 100.0% ------------------------------------------------------------------------------ merge-egraph-nodes! [34] 100.0% [47] 312(0.2%) 0(0.0%) for-loop ...bie/develop/src/core/egraph.rkt:201:10 merge-egraph-nodes! [34] 100.0% ------------------------------------------------------------------------------ localize-error [33] 3.6% eval-prog [40] 15.3% ??? [17] 24.4% loop [56] 56.7% [48] 9190(7.3%) 0(0.0%) hash-ref! ...racket/private/more-scheme.rkt:373:13 ??? [52] 56.7% parse-loop12 [53] 24.4% bigfloat-hash [51] 15.3% f6 [3] 3.6% ------------------------------------------------------------------------------ mk-enode! [41] 100.0% [49] 1376(1.1%) 0(0.0%) new-enode ...erbie/develop/src/core/enode.rkt:97:0 type-of-enode-expr [54] 100.0% ------------------------------------------------------------------------------ update-leader! [42] 100.0% [50] 1294(1.0%) 0(0.0%) for-loop ...rbie/develop/src/core/egraph.rkt:223:6 for-loop [55] 100.0% ------------------------------------------------------------------------------ hash-ref! [48] 100.0% [51] 6614(5.3%) 0(0.0%) bigfloat-hash ...h/private/bigfloat/mpfr.rkt:165:0 sig+exp->bigfloat [57] 53.6% bfcanonicalize [58] 46.4% ------------------------------------------------------------------------------ hash-ref! [48] 100.0% [52] 6288(5.0%) 0(0.0%) ??? ...tlies/herbie/develop/src/programs.rkt:194:5 loop [56] 100.0% ------------------------------------------------------------------------------ hash-ref! [48] 100.0% [53] 2576(2.0%) 0(0.0%) parse-loop12 ...s/racket/match/compiler.rkt:418:15 loop [56] 98.3% loop [5] 1.7% ------------------------------------------------------------------------------ new-enode [49] 100.0% [54] 1376(1.1%) 0(0.0%) type-of-enode-expr ...elop/src/core/enode.rkt:68:0 get-sigs [59] 100.0% ------------------------------------------------------------------------------ for-loop [50] 100.0% [55] 1294(1.0%) 0(0.0%) for-loop ...rbie/develop/src/core/egraph.rkt:224:8 hash-update! [60] 100.0% ------------------------------------------------------------------------------ loop [32] 0.3% make-exacts* [31] 0.4% parse-loop12 [53] 0.8% ??? [52] 5.5% loop [56] 93.0% [56] 114616(91.2%) 740(0.6%) loop ...cket/collects/racket/private/map.rkt:25:19 loop [56] 93.0% hash-ref! [48] 5.5% ??? [17] 0.7% ??? [79] 0.7% bf-complex-add [86] 0.0% ??? [18] 0.0% bf-complex-mult [85] 0.0% ------------------------------------------------------------------------------ bigfloat-hash [51] 100.0% [57] 3544(2.8%) 3544(2.8%) sig+exp->bigfloat ...ivate/bigfloat/mpfr.rkt:385:0 ------------------------------------------------------------------------------ bigfloat-hash [51] 100.0% [58] 3070(2.4%) 3070(2.4%) bfcanonicalize .../private/bigfloat/mpfr.rkt:155:0 ------------------------------------------------------------------------------ type-of-enode-expr [54] 100.0% [59] 1376(1.1%) 0(0.0%) get-sigs .../herbie/develop/src/type-check.rkt:5:0 ??? [62] 50.6% ->flonum [61] 26.6% ??? [64] 22.8% ------------------------------------------------------------------------------ for-loop [55] 100.0% [60] 1294(1.0%) 0(0.0%) hash-update! ...ket/private/more-scheme.rkt:362:13 ??? [63] 100.0% ------------------------------------------------------------------------------ get-sigs [59] 1.2% for-loop [35] 5.1% ??? [18] 14.6% simplify-alt [23] 36.8% ->flonum [61] 40.4% [61] 10386(8.3%) 644(0.5%) ->flonum ...s/racket/private/norm-define.rkt:53:83 ->flonum [61] 40.4% iterate-egraph!13 [2] 35.3% ??? [66] 8.0% loop [4] 5.1% ??? [70] 4.1% ??? [95] 1.0% ------------------------------------------------------------------------------ get-sigs [59] 49.8% setup-prog [20] 50.2% [62] 1398(1.1%) 0(0.0%) ??? ...contract/private/arrow-val-first.rkt:357:18 make-alt-table [67] 50.2% hash-has-key? [68] 49.8% ------------------------------------------------------------------------------ hash-update! [60] 100.0% [63] 1294(1.0%) 0(0.0%) ??? ...s/herbie/develop/src/core/egraph.rkt:226:24 for-loop [65] 100.0% ------------------------------------------------------------------------------ get-sigs [59] 47.3% ??? [18] 52.7% [64] 664(0.5%) 0(0.0%) ??? ...ts/racket/contract/private/arr-i.rkt:804:10 get/build-late-neg-projection [84] 52.7% ??? [69] 47.3% ------------------------------------------------------------------------------ ??? [63] 100.0% [65] 1294(1.0%) 980(0.8%) for-loop ...bie/develop/src/core/egraph.rkt:227:26 update-en-expr [73] 24.3% ------------------------------------------------------------------------------ ->flonum [61] 100.0% [66] 1070(0.9%) 366(0.3%) ??? ...racket/collects/racket/private/kw.rkt:761:9 ??? [72] 65.8% ------------------------------------------------------------------------------ ??? [62] 100.0% [67] 702(0.6%) 342(0.3%) make-alt-table ...elop/src/core/alt-table.rkt:32:0 errors [71] 51.3% ------------------------------------------------------------------------------ ??? [62] 100.0% [68] 696(0.6%) 0(0.0%) hash-has-key? ...et/private/more-scheme.rkt:368:13 ??? [70] 100.0% ------------------------------------------------------------------------------ ??? [64] 100.0% [69] 314(0.2%) 0(0.0%) ??? ...ects/racket/contract/private/hash.rkt:217:4 ??? [74] 100.0% ------------------------------------------------------------------------------ hash-has-key? [68] 35.5% ->flonum [61] 64.5% [70] 1960(1.6%) 992(0.8%) ??? ...ects/racket/contract/private/list.rkt:737:4 for-loop [76] 31.6% ??? [77] 17.8% ------------------------------------------------------------------------------ composed [44] 49.6% make-alt-table [67] 50.4% [71] 714(0.6%) 0(0.0%) errors ...lies/herbie/develop/src/points.rkt:271:0 for-loop [75] 100.0% ------------------------------------------------------------------------------ ??? [66] 100.0% [72] 704(0.6%) 704(0.6%) ??? ...s/racket/contract/private/arr-i.rkt:1233:27 ------------------------------------------------------------------------------ for-loop [65] 49.4% for-loop [46] 50.6% [73] 636(0.5%) 636(0.5%) update-en-expr ...evelop/src/core/egraph.rkt:212:0 ------------------------------------------------------------------------------ ??? [69] 100.0% [74] 314(0.2%) 0(0.0%) ??? ...ects/racket/contract/private/list.rkt:169:2 ??? [78] 100.0% ------------------------------------------------------------------------------ errors [71] 100.0% [75] 714(0.6%) 0(0.0%) for-loop ...es/herbie/develop/src/points.rkt:274:4 ??? [79] 100.0% ------------------------------------------------------------------------------ ??? [70] 100.0% [76] 620(0.5%) 310(0.2%) for-loop ...acket/contract/private/list.rkt:743:12 ??? [82] 50.0% ------------------------------------------------------------------------------ ??? [70] 100.0% [77] 348(0.3%) 0(0.0%) ??? ...private/unconstrained-domain-arrow.rkt:74:4 make-keyword-procedure [80] 100.0% ------------------------------------------------------------------------------ ??? [74] 100.0% [78] 314(0.2%) 0(0.0%) ??? ...ects/racket/contract/private/list.rkt:678:5 for-loop [81] 100.0% ------------------------------------------------------------------------------ for-loop [75] 0.7% loop [56] 99.3% [79] 105480(83.9%) 0(0.0%) ??? ...tlies/herbie/develop/src/programs.rkt:156:4 ??? [83] 100.0% ------------------------------------------------------------------------------ ??? [77] 100.0% [80] 348(0.3%) 348(0.3%) make-keyword-procedure ...ket/private/kw.rkt:260:4 ------------------------------------------------------------------------------ ??? [78] 100.0% [81] 314(0.2%) 0(0.0%) for-loop ...racket/contract/private/list.rkt:680:9 get/build-late-neg-projection [84] 100.0% ------------------------------------------------------------------------------ for-loop [76] 100.0% [82] 310(0.2%) 310(0.2%) ??? ...ects/racket/contract/private/hash.rkt:222:6 ------------------------------------------------------------------------------ ??? [79] 100.0% [83] 105480(83.9%) 8228(6.5%) ??? ...acket/collects/racket/private/kw.rkt:444:14 bf-complex-mult [85] 80.7% bf-complex-add [86] 9.5% ??? [87] 1.0% ------------------------------------------------------------------------------ unconstrained-domain->-projection [89] 26.4% ??? [64] 26.4% for-loop [81] 47.3% [84] 664(0.5%) 0(0.0%) get/build-late-neg-projection ...te/guts.rkt:691:0 ??? [88] 73.6% unconstrained-domain->-projection [89] 26.4% ------------------------------------------------------------------------------ loop [56] 0.5% ??? [83] 99.5% [85] 85528(68.0%) 4726(3.8%) bf-complex-mult ...develop/src/bigcomplex.rkt:33:0 bf* [90] 58.1% ??? [94] 34.0% ...higher-order.rkt:346:33 [91] 2.5% ------------------------------------------------------------------------------ loop [56] 3.7% ??? [83] 96.3% [86] 10444(8.3%) 514(0.4%) bf-complex-add .../develop/src/bigcomplex.rkt:22:0 ??? [94] 95.1% ------------------------------------------------------------------------------ ??? [83] 100.0% [87] 1048(0.8%) 702(0.6%) ??? ...ects/racket/contract/private/prop.rkt:493:4 ??? [93] 33.0% ------------------------------------------------------------------------------ get/build-late-neg-projection [84] 100.0% [88] 664(0.5%) 0(0.0%) ??? ...cts/racket/contract/private/prop.rkt:314:12 build-compound-type-name [92] 100.0% ------------------------------------------------------------------------------ get/build-late-neg-projection [84] 100.0% [89] 350(0.3%) 0(0.0%) unconstrained-domain->-projection ...rrow.rkt:60:0 get/build-late-neg-projection [84] 100.0% ------------------------------------------------------------------------------ bf-complex-mult [85] 100.0% [90] 49654(39.5%) 1808(1.4%) bf* ...ath/private/bigfloat/bigfloat-mpfr.rkt:95:0 ??? [94] 96.4% ------------------------------------------------------------------------------ bf-complex-mult [85] 100.0% [91] 2104(1.7%) 1064(0.8%) ...higher-order.rkt:346:33 (unknown source) ??? [95] 49.4% ------------------------------------------------------------------------------ contract-struct-name [96] 23.6% ??? [88] 76.4% [92] 664(0.5%) 314(0.2%) build-compound-type-name ...private/guts.rkt:448:0 contract-struct-name [96] 76.4% ------------------------------------------------------------------------------ ??? [87] 100.0% [93] 346(0.3%) 346(0.3%) ??? ...lects/racket/contract/private/orc.rkt:83:14 ------------------------------------------------------------------------------ bf-complex-add [86] 11.4% bf-complex-mult [85] 33.5% bf* [90] 55.1% [94] 86820(69.1%) 6978(5.6%) ??? ...-racket/utils/simple-result-arrow.rkt:39:12 bfmul [97] 82.1% bfneg [98] 9.9% ------------------------------------------------------------------------------ ->flonum [61] 23.0% ...higher-order.rkt:346:33 [91] 77.0% [95] 1350(1.1%) 1350(1.1%) ??? ...cts/racket/contract/private/list.rkt:187:10 ------------------------------------------------------------------------------ build-compound-type-name [92] 100.0% [96] 664(0.5%) 350(0.3%) contract-struct-name ...ract/private/prop.rkt:89:0 build-compound-type-name [92] 47.3% ------------------------------------------------------------------------------ ??? [94] 100.0% [97] 71270(56.7%) 42002(33.4%) bfmul ...-lib/math/private/bigfloat/mpfr.rkt:819:4 ??? [99] 41.1% ------------------------------------------------------------------------------ ??? [94] 100.0% [98] 8572(6.8%) 4224(3.4%) bfneg ...-lib/math/private/bigfloat/mpfr.rkt:616:4 ??? [99] 50.7% ------------------------------------------------------------------------------ bfneg [98] 12.9% bfmul [97] 87.1% [99] 33616(26.7%) 33616(26.7%) ??? .../share/racket/collects/ffi/unsafe.rkt:861:4 ------------------------------------------------------------------------------