Profiling results ----------------- Total cpu time observed: 155444ms (out of 158404ms) Number of samples taken: 376 (once every 413ms) (Hiding functions with self<1.0% and local<2.0%: 1 of 98 hidden) ========================================================================= Caller Idx Total Self Name+src Local% ms(pct) ms(pct) Callee ========================================================================= run [13] 49.7% [1] 153456(98.7%) 0(0.0%) ??? ...lects/racket/private/more-scheme.rkt:261:28 profile-thunk16 [6] 49.7% prepare-points [14] 44.2% run-improve50 [7] 6.1% ------------------------------------------------------------------------- ??? [62] 100.0% [2] 7878(5.1%) 0(0.0%) iterate-egraph!13 ...p/src/core/simplify.rkt:105:0 one-iter [8] 95.9% map-enodes [12] 4.1% ------------------------------------------------------------------------- eval-prog [38] 1.6% f6 [3] 8.0% hash-ref! [46] 90.4% [3] 3642(2.3%) 0(0.0%) f6 ...et/collects/racket/match/compiler.rkt:507:40 map [10] 90.4% f6 [3] 8.0% ??? [9] 1.6% ------------------------------------------------------------------------- ??? [62] 100.0% [4] 1910(1.2%) 0(0.0%) loop ...herbie/develop/src/core/simplify.rkt:237:2 pass [11] 100.0% ------------------------------------------------------------------------- parse-loop12 [53] 1.3% loop [5] 98.7% [5] 432(0.3%) 0(0.0%) loop ...cket/collects/racket/private/map.rkt:36:19 loop [5] 98.7% ??? [9] 1.3% ------------------------------------------------------------------------- ??? [1] 100.0% [6] 152462(98.1%) 0(0.0%) profile-thunk16 ...t/pkgs/profile-lib/main.rkt:9:0 run [13] 100.0% ------------------------------------------------------------------------- ??? [1] 100.0% [7] 17680(11.4%) 0(0.0%) run-improve50 ...ie/develop/src/mainloop.rkt:234:0 setup-alt-simplified [15] 44.5% prepare-points [14] 31.1% for-loop [18] 18.6% get-final-combination [21] 3.9% ??? [64] 1.9% ------------------------------------------------------------------------- iterate-egraph!13 [2] 100.0% [8] 7554(4.9%) 0(0.0%) one-iter ...ie/develop/src/core/simplify.rkt:116:0 for-loop [16] 59.7% for-loop [19] 40.3% ------------------------------------------------------------------------- f6 [3] 5.3% loop [5] 6.6% map [10] 10.0% get-final-combination [21] 10.4% loop [57] 67.8% [9] 6592(4.2%) 0(0.0%) ??? ...tract/private/arrow-higher-order.rkt:342:33 ??? [62] 94.7% ...velop/src/common.rkt:47:2 [40] 5.3% ------------------------------------------------------------------------- ??? [17] 10.0% f6 [3] 90.0% [10] 3294(2.1%) 0(0.0%) map ...acket/collects/racket/private/map.rkt:20:13 ??? [17] 90.0% ??? [9] 10.0% ------------------------------------------------------------------------- loop [4] 100.0% [11] 1910(1.2%) 0(0.0%) pass ...herbie/develop/src/core/simplify.rkt:227:2 for-loop [20] 100.0% ------------------------------------------------------------------------- iterate-egraph!13 [2] 100.0% [12] 324(0.2%) 0(0.0%) map-enodes ...ie/develop/src/core/egraph.rkt:140:0 loop [57] 100.0% ------------------------------------------------------------------------- profile-thunk16 [6] 100.0% [13] 152462(98.1%) 0(0.0%) run ...share/racket/pkgs/profile-lib/main.rkt:39:2 ??? [1] 100.0% ------------------------------------------------------------------------- run-improve50 [7] 3.9% ??? [1] 96.1% [14] 141276(90.9%) 0(0.0%) prepare-points ...bie/develop/src/points.rkt:214:0 loop [22] 34.7% loop [29] 34.0% make-exacts* [30] 31.3% ------------------------------------------------------------------------- run-improve50 [7] 100.0% [15] 7870(5.1%) 0(0.0%) setup-alt-simplified .../develop/src/glue.rkt:49:0 simplify-alt [23] 100.0% ------------------------------------------------------------------------- for-loop [16] 46.6% one-iter [8] 53.4% [16] 4508(2.9%) 634(0.4%) for-loop ...e/develop/src/core/simplify.rkt:126:12 for-loop [16] 46.6% rule-valid-at-type? [25] 35.8% match-e [28] 7.1% ------------------------------------------------------------------------- map [10] 24.2% loop [57] 75.8% [17] 3294(2.1%) 0(0.0%) ??? ...ket/collects/racket/private/list.rkt:323:18 hash-ref! [46] 97.8% map [10] 2.2% ------------------------------------------------------------------------- run-improve50 [7] 100.0% [18] 3294(2.1%) 0(0.0%) for-loop ...herbie/develop/src/mainloop.rkt:249:10 run-iter! [24] 100.0% ------------------------------------------------------------------------- one-iter [8] 100.0% [19] 3046(2.0%) 0(0.0%) for-loop ...ie/develop/src/core/simplify.rkt:166:2 for-loop [26] 89.5% update-leader! [41] 10.5% ------------------------------------------------------------------------- pass [11] 100.0% [20] 1910(1.2%) 0(0.0%) for-loop ...e/develop/src/core/simplify.rkt:230:29 argmin [27] 100.0% ------------------------------------------------------------------------- run-improve50 [7] 100.0% [21] 686(0.4%) 0(0.0%) get-final-combination ...op/src/mainloop.rkt:264:0 ??? [9] 100.0% ------------------------------------------------------------------------- prepare-points [14] 100.0% [22] 48964(31.5%) 0(0.0%) loop ...htlies/herbie/develop/src/points.rkt:158:2 make-exacts* [30] 53.6% loop [29] 46.4% ------------------------------------------------------------------------- setup-alt-simplified [15] 100.0% [23] 7870(5.1%) 0(0.0%) simplify-alt ...s/herbie/develop/src/glue.rkt:76:0 ??? [62] 100.0% ------------------------------------------------------------------------- for-loop [18] 100.0% [24] 3294(2.1%) 0(0.0%) run-iter! ...herbie/develop/src/mainloop.rkt:215:0 localize-error [31] 100.0% ------------------------------------------------------------------------- for-loop [16] 100.0% [25] 3230(2.1%) 2612(1.7%) rule-valid-at-type? .../src/syntax/rules.rkt:548:0 *complex-rules* [36] 19.1% ------------------------------------------------------------------------- for-loop [19] 100.0% [26] 2726(1.8%) 0(0.0%) for-loop ...e/develop/src/core/simplify.rkt:148:10 merge-egraph-nodes! [33] 38.8% substitute-e [34] 36.5% mk-enode! [39] 24.7% ------------------------------------------------------------------------- for-loop [20] 100.0% [27] 1910(1.2%) 0(0.0%) argmin ...re/racket/collects/racket/list.rkt:743:0 for-loop [32] 82.5% expression-cost [37] 17.5% ------------------------------------------------------------------------- for-loop [42] 50.0% for-loop [16] 50.0% [28] 644(0.4%) 0(0.0%) match-e ...herbie/develop/src/core/ematch.rkt:46:0 for-loop [35] 75.3% for-loop [42] 24.7% ------------------------------------------------------------------------- loop [22] 32.1% prepare-points [14] 67.9% [29] 70792(45.5%) 0(0.0%) loop ...htlies/herbie/develop/src/points.rkt:141:4 loop [57] 100.0% ------------------------------------------------------------------------- loop [22] 37.2% prepare-points [14] 62.8% [30] 70484(45.3%) 0(0.0%) make-exacts* ...erbie/develop/src/points.rkt:138:0 loop [57] 89.3% eval-prog [38] 10.7% ------------------------------------------------------------------------- run-iter! [24] 100.0% [31] 3294(2.1%) 0(0.0%) localize-error ...velop/src/core/localize.rkt:47:0 hash-ref! [46] 100.0% ------------------------------------------------------------------------- argmin [27] 100.0% [32] 1576(1.0%) 0(0.0%) for-loop .../herbie/develop/src/programs.rkt:210:2 ...velop/src/common.rkt:47:2 [40] 59.1% ??? [62] 40.9% ------------------------------------------------------------------------- for-loop [43] 11.2% merge-egraph-nodes! [33] 28.6% for-loop [26] 60.2% [33] 1058(0.7%) 356(0.2%) merge-egraph-nodes! ...p/src/core/egraph.rkt:153:0 update-leader! [41] 49.0% merge-egraph-nodes! [33] 28.6% for-loop [43] 11.2% ------------------------------------------------------------------------- for-loop [26] 100.0% [34] 996(0.6%) 0(0.0%) substitute-e ...e/develop/src/core/ematch.rkt:71:0 mk-enode! [39] 100.0% ------------------------------------------------------------------------- match-e [28] 100.0% [35] 644(0.4%) 318(0.2%) for-loop ...rbie/develop/src/core/ematch.rkt:59:11 for-loop [42] 25.3% loop [57] 25.3% ------------------------------------------------------------------------- rule-valid-at-type? [25] 100.0% [36] 618(0.4%) 298(0.2%) *complex-rules* ...elop/src/syntax/rules.rkt:560:0 for-loop [45] 51.8% ------------------------------------------------------------------------- argmin [27] 100.0% [37] 334(0.2%) 0(0.0%) expression-cost .../develop/src/programs.rkt:209:0 compile [44] 100.0% ------------------------------------------------------------------------- make-exacts* [30] 100.0% [38] 7564(4.9%) 658(0.4%) eval-prog ...herbie/develop/src/programs.rkt:150:0 hash-ref! [46] 86.7% f6 [3] 4.6% ------------------------------------------------------------------------- mk-enode-rec! [78] 20.6% for-loop [26] 32.0% substitute-e [34] 47.4% [39] 2102(1.4%) 326(0.2%) mk-enode! ...bie/develop/src/core/egraph.rkt:102:0 new-enode [47] 84.5% ------------------------------------------------------------------------- ??? [9] 27.2% for-loop [32] 72.8% [40] 1280(0.8%) 656(0.4%) ...velop/src/common.rkt:47:2 ...e/arr-i.rkt:906:19 ??? [49] 24.5% coerce-contract [50] 24.2% ------------------------------------------------------------------------- for-loop [19] 31.3% merge-egraph-nodes! [33] 68.7% [41] 1022(0.7%) 0(0.0%) update-leader! ...evelop/src/core/egraph.rkt:218:0 for-loop [48] 100.0% ------------------------------------------------------------------------- match-e [28] 49.4% for-loop [35] 50.6% [42] 644(0.4%) 0(0.0%) for-loop ...rbie/develop/src/core/ematch.rkt:65:37 match-e [28] 100.0% ------------------------------------------------------------------------- merge-egraph-nodes! [33] 100.0% [43] 356(0.2%) 0(0.0%) for-loop ...bie/develop/src/core/egraph.rkt:201:10 merge-egraph-nodes! [33] 100.0% ------------------------------------------------------------------------- expression-cost [37] 100.0% [44] 334(0.2%) 0(0.0%) compile ...s/herbie/develop/src/programs.rkt:186:0 hash-ref! [46] 100.0% ------------------------------------------------------------------------- *complex-rules* [36] 100.0% [45] 320(0.2%) 320(0.2%) for-loop ...ies/herbie/develop/src/common.rkt:99:9 ------------------------------------------------------------------------- ??? [51] 1.6% compile [44] 1.6% localize-error [31] 5.5% eval-prog [38] 9.9% ??? [17] 26.8% loop [57] 54.5% [46] 10186(6.6%) 334(0.2%) hash-ref! ...racket/private/more-scheme.rkt:373:13 ??? [51] 56.1% parse-loop12 [53] 26.8% bigfloat-hash [52] 9.9% f6 [3] 5.5% ------------------------------------------------------------------------- mk-enode! [39] 100.0% [47] 1776(1.1%) 0(0.0%) new-enode ...erbie/develop/src/core/enode.rkt:97:0 type-of-enode-expr [54] 100.0% ------------------------------------------------------------------------- update-leader! [41] 100.0% [48] 1022(0.7%) 0(0.0%) for-loop ...rbie/develop/src/core/egraph.rkt:223:6 for-loop [55] 100.0% ------------------------------------------------------------------------- ...velop/src/common.rkt:47:2 [40]100.0% [49] 314(0.2%) 0(0.0%) ??? ...s/racket/contract/private/arr-i.rkt:1268:39 assoc-ref [56] 100.0% ------------------------------------------------------------------------- ...velop/src/common.rkt:47:2 [40]100.0% [50] 310(0.2%) 310(0.2%) coerce-contract ...contract/private/guts.rkt:257:0 ------------------------------------------------------------------------- hash-ref! [46] 100.0% [51] 6892(4.4%) 0(0.0%) ??? ...tlies/herbie/develop/src/programs.rkt:194:5 loop [57] 95.2% hash-ref! [46] 4.8% ------------------------------------------------------------------------- hash-ref! [46] 100.0% [52] 6558(4.2%) 0(0.0%) bigfloat-hash ...h/private/bigfloat/mpfr.rkt:165:0 bfcanonicalize [58] 55.4% sig+exp->bigfloat [59] 44.6% ------------------------------------------------------------------------- hash-ref! [46] 100.0% [53] 3294(2.1%) 0(0.0%) parse-loop12 ...s/racket/match/compiler.rkt:418:15 loop [57] 94.3% loop [5] 2.2% bf-complex-add [87] 2.0% bf-complex-mult [86] 1.5% ------------------------------------------------------------------------- new-enode [47] 100.0% [54] 1776(1.1%) 0(0.0%) type-of-enode-expr ...elop/src/core/enode.rkt:68:0 get-sigs [60] 100.0% ------------------------------------------------------------------------- for-loop [48] 100.0% [55] 1022(0.7%) 0(0.0%) for-loop ...rbie/develop/src/core/egraph.rkt:224:8 hash-update! [61] 100.0% ------------------------------------------------------------------------- ??? [49] 100.0% [56] 314(0.2%) 314(0.2%) assoc-ref ...collects/racket/private/dict.rkt:56:0 ------------------------------------------------------------------------- map-enodes [12] 0.0% for-loop [35] 0.2% make-exacts* [30] 0.3% loop [29] 0.3% parse-loop12 [53] 1.2% ??? [51] 4.5% loop [57] 93.4% [57] 144536(93.0%) 1046(0.7%) loop ...cket/collects/racket/private/map.rkt:25:19 loop [57] 93.4% hash-ref! [46] 4.5% ??? [17] 1.1% ??? [84] 0.7% bf-complex-mult [86] 0.0% ??? [9] 0.0% for-loop [68] 0.0% ------------------------------------------------------------------------- bigfloat-hash [52] 100.0% [58] 3636(2.3%) 2992(1.9%) bfcanonicalize .../private/bigfloat/mpfr.rkt:155:0 bigfloat->sig+exp [65] 17.7% ------------------------------------------------------------------------- bigfloat-hash [52] 100.0% [59] 2922(1.9%) 2598(1.7%) sig+exp->bigfloat ...ivate/bigfloat/mpfr.rkt:385:0 integer->mpz [67] 11.1% ------------------------------------------------------------------------- type-of-enode-expr [54] 100.0% [60] 1776(1.1%) 0(0.0%) get-sigs .../herbie/develop/src/type-check.rkt:5:0 ??? [62] 57.5% ??? [66] 24.4% ??? [64] 18.0% ------------------------------------------------------------------------- for-loop [55] 100.0% [61] 1022(0.7%) 0(0.0%) hash-update! ...ket/private/more-scheme.rkt:362:13 ??? [63] 100.0% ------------------------------------------------------------------------- for-loop [32] 1.4% get-sigs [60] 2.2% simplify-alt [23] 24.9% ??? [62] 30.6% ??? [9] 37.4% [62] 15780(10.2%) 2424(1.6%) ??? ...llects/racket/private/norm-define.rkt:53:83 ??? [62] 30.6% iterate-egraph!13 [2] 23.9% ??? [69] 17.8% loop [4] 5.4% ??? [77] 3.5% ??? [75] 2.0% mk-egraph [72] 1.4% ------------------------------------------------------------------------- hash-update! [61] 100.0% [63] 1022(0.7%) 0(0.0%) ??? ...s/herbie/develop/src/core/egraph.rkt:226:24 for-loop [70] 100.0% ------------------------------------------------------------------------- get-sigs [60] 49.2% run-improve50 [7] 50.8% [64] 650(0.4%) 0(0.0%) ??? ...contract/private/arrow-val-first.rkt:357:18 atab-add-altns [73] 50.8% hash-has-key? [76] 49.2% ------------------------------------------------------------------------- bfcanonicalize [58] 100.0% [65] 644(0.4%) 644(0.4%) bigfloat->sig+exp ...ivate/bigfloat/mpfr.rkt:370:0 ------------------------------------------------------------------------- get-sigs [60] 100.0% [66] 434(0.3%) 0(0.0%) ??? ...ts/racket/contract/private/arr-i.rkt:804:10 ??? [71] 100.0% ------------------------------------------------------------------------- sig+exp->bigfloat [59] 100.0% [67] 324(0.2%) 324(0.2%) integer->mpz ...math/private/bigfloat/gmp.rkt:87:0 ------------------------------------------------------------------------- loop [57] 100.0% [68] 324(0.2%) 0(0.0%) for-loop ...ie/develop/src/core/simplify.rkt:195:2 setfindf [74] 100.0% ------------------------------------------------------------------------- ??? [62] 100.0% [69] 2812(1.8%) 2812(1.8%) ??? ...racket/collects/racket/private/kw.rkt:761:9 ------------------------------------------------------------------------- ??? [63] 100.0% [70] 1022(0.7%) 1022(0.7%) for-loop ...bie/develop/src/core/egraph.rkt:227:26 ------------------------------------------------------------------------- ??? [66] 100.0% [71] 434(0.3%) 434(0.3%) ??? ...ects/racket/contract/private/hash.rkt:217:4 ------------------------------------------------------------------------- ??? [62] 100.0% [72] 434(0.3%) 0(0.0%) mk-egraph ...bie/develop/src/core/egraph.rkt:131:0 mk-enode-rec! [78] 100.0% ------------------------------------------------------------------------- ??? [64] 100.0% [73] 330(0.2%) 0(0.0%) atab-add-altns ...elop/src/core/alt-table.rkt:50:0 atab-add-altn [79] 100.0% ------------------------------------------------------------------------- for-loop [68] 100.0% [74] 324(0.2%) 324(0.2%) setfindf ...es/herbie/develop/src/common.rkt:186:0 ------------------------------------------------------------------------- ??? [62] 100.0% [75] 322(0.2%) 0(0.0%) ??? ...-racket/utils/simple-result-arrow.rkt:60:15 ??? [97] 100.0% ------------------------------------------------------------------------- ??? [64] 100.0% [76] 320(0.2%) 0(0.0%) hash-has-key? ...et/private/more-scheme.rkt:368:13 ??? [77] 100.0% ------------------------------------------------------------------------- hash-has-key? [76] 16.1% ??? [62] 83.9% [77] 1986(1.3%) 1022(0.7%) ??? ...ects/racket/contract/private/list.rkt:737:4 for-loop [80] 48.5% ------------------------------------------------------------------------- mk-egraph [72] 8.3% mk-enode-rec! [78] 91.7% [78] 434(0.3%) 0(0.0%) mk-enode-rec! ...develop/src/core/egraph.rkt:122:0 mk-enode-rec! [78] 91.7% mk-enode! [39] 8.3% ------------------------------------------------------------------------- atab-add-altns [73] 100.0% [79] 330(0.2%) 0(0.0%) atab-add-altn ...elop/src/core/alt-table.rkt:208:0 best-and-tied-at-points [81] 100.0% ------------------------------------------------------------------------- ??? [77] 100.0% [80] 964(0.6%) 964(0.6%) for-loop ...acket/contract/private/list.rkt:743:12 ------------------------------------------------------------------------- atab-add-altn [79] 100.0% [81] 330(0.2%) 0(0.0%) best-and-tied-at-points ...ore/alt-table.rkt:122:0 errors [82] 100.0% ------------------------------------------------------------------------- best-and-tied-at-points [81] 100.0% [82] 330(0.2%) 0(0.0%) errors ...lies/herbie/develop/src/points.rkt:271:0 for-loop [83] 100.0% ------------------------------------------------------------------------- errors [82] 100.0% [83] 330(0.2%) 0(0.0%) for-loop ...es/herbie/develop/src/points.rkt:274:4 ??? [84] 100.0% ------------------------------------------------------------------------- for-loop [83] 0.3% loop [57] 99.7% [84] 129546(83.3%) 0(0.0%) ??? ...tlies/herbie/develop/src/programs.rkt:156:4 ??? [85] 100.0% ------------------------------------------------------------------------- ??? [84] 100.0% [85] 129546(83.3%) 8902(5.7%) ??? ...acket/collects/racket/private/kw.rkt:444:14 bf-complex-mult [86] 81.8% bf-complex-add [87] 9.1% ??? [88] 1.4% ------------------------------------------------------------------------- parse-loop12 [53] 0.3% loop [57] 1.1% ??? [85] 98.6% [86] 107418(69.1%) 6844(4.4%) bf-complex-mult ...develop/src/bigcomplex.rkt:33:0 bf* [89] 57.2% ??? [92] 32.0% ...higher-order.rkt:346:33 [90] 4.4% ------------------------------------------------------------------------- parse-loop12 [53] 2.8% ??? [85] 97.2% [87] 12102(7.8%) 786(0.5%) bf-complex-add .../develop/src/bigcomplex.rkt:22:0 ??? [92] 84.7% ...higher-order.rkt:346:33 [90] 8.8% ------------------------------------------------------------------------- ??? [85] 100.0% [88] 1866(1.2%) 1004(0.6%) ??? ...ects/racket/contract/private/prop.rkt:493:4 ??? [91] 46.2% ------------------------------------------------------------------------- bf-complex-mult [86] 100.0% [89] 61422(39.5%) 1382(0.9%) bf* ...ath/private/bigfloat/bigfloat-mpfr.rkt:95:0 ??? [92] 97.7% ------------------------------------------------------------------------- bf-complex-add [87] 18.2% bf-complex-mult [86] 81.8% [90] 5832(3.8%) 648(0.4%) ...higher-order.rkt:346:33 (unknown source) ??? [93] 88.9% ------------------------------------------------------------------------- ??? [88] 100.0% [91] 862(0.6%) 862(0.6%) ??? ...lects/racket/contract/private/orc.rkt:83:14 ------------------------------------------------------------------------- bf-complex-add [87] 9.8% bf-complex-mult [86] 32.8% bf* [89] 57.4% [92] 104676(67.3%) 7968(5.1%) ??? ...-racket/utils/simple-result-arrow.rkt:39:12 bfmul [94] 83.4% bfneg [95] 9.0% ------------------------------------------------------------------------- ...higher-order.rkt:346:33 [90] 100.0% [93] 5184(3.3%) 3714(2.4%) ??? ...cts/racket/contract/private/list.rkt:187:10 ??? [96] 28.4% ------------------------------------------------------------------------- ??? [92] 100.0% [94] 87338(56.2%) 60834(39.1%) bfmul ...-lib/math/private/bigfloat/mpfr.rkt:819:4 ??? [97] 30.3% ------------------------------------------------------------------------- ??? [92] 100.0% [95] 9370(6.0%) 7028(4.5%) bfneg ...-lib/math/private/bigfloat/mpfr.rkt:616:4 ??? [97] 25.0% ------------------------------------------------------------------------- ??? [93] 100.0% [96] 1470(0.9%) 1470(0.9%) ??? ...ects/racket/contract/private/guts.rkt:644:8 ------------------------------------------------------------------------- ??? [75] 1.1% bfneg [95] 8.0% bfmul [94] 90.9% [97] 29168(18.8%) 29168(18.8%) ??? .../share/racket/collects/ffi/unsafe.rkt:861:4 -------------------------------------------------------------------------