Profiling results ----------------- Total cpu time observed: 116752ms (out of 120328ms) Number of samples taken: 284 (once every 411ms) (Hiding functions with self<1.0% and local<2.0%: 2 of 96 hidden) ======================================================================= Caller Idx Total Self Name+src Local% ms(pct) ms(pct) Callee ======================================================================= run [13] 49.3% [1] 115390(98.8%) 0(0.0%) ??? ...lects/racket/private/more-scheme.rkt:261:28 profile-thunk16 [6] 49.3% prepare-points [14] 43.2% run-improve50 [7] 7.4% ----------------------------------------------------------------------- ??? [65] 100.0% [2] 8464(7.2%) 0(0.0%) iterate-egraph!13 ...p/src/core/simplify.rkt:105:0 one-iter [8] 96.1% map-enodes [12] 3.9% ----------------------------------------------------------------------- get-final-combination [22] 11.3% f137 [9] 16.6% map [19] 23.1% loop [58] 49.0% [3] 2752(2.4%) 0(0.0%) ??? ...tract/private/arrow-higher-order.rkt:342:33 ??? [65] 83.4% ??? [11] 16.6% ----------------------------------------------------------------------- ??? [65] 100.0% [4] 1088(0.9%) 0(0.0%) loop ...herbie/develop/src/core/simplify.rkt:237:2 pass [10] 100.0% ----------------------------------------------------------------------- parse-loop12 [55] 2.0% loop [5] 98.0% [5] 318(0.3%) 0(0.0%) loop ...cket/collects/racket/private/map.rkt:36:19 loop [5] 98.0% f137 [9] 2.0% ----------------------------------------------------------------------- ??? [1] 100.0% [6] 113832(97.5%) 0(0.0%) profile-thunk16 ...t/pkgs/profile-lib/main.rkt:9:0 run [13] 100.0% ----------------------------------------------------------------------- ??? [1] 100.0% [7] 15598(13.4%) 0(0.0%) run-improve50 ...ie/develop/src/mainloop.rkt:234:0 setup-alt-simplified [15] 50.5% prepare-points [14] 34.9% for-loop [18] 12.6% get-final-combination [22] 2.0% ----------------------------------------------------------------------- iterate-egraph!13 [2] 100.0% [8] 8130(7.0%) 0(0.0%) one-iter ...ie/develop/src/core/simplify.rkt:116:0 for-loop [16] 52.1% for-loop [17] 47.9% ----------------------------------------------------------------------- eval-prog [41] 1.5% loop [5] 6.6% f137 [9] 17.4% hash-ref! [49] 74.5% [9] 2416(2.1%) 0(0.0%) f137 .../collects/racket/match/compiler.rkt:507:40 map [19] 74.5% f137 [9] 17.4% ??? [73] 6.6% ??? [3] 1.5% ----------------------------------------------------------------------- loop [4] 100.0% [10] 1088(0.9%) 0(0.0%) pass ...herbie/develop/src/core/simplify.rkt:227:2 for-loop [20] 100.0% ----------------------------------------------------------------------- ??? [3] 100.0% [11] 456(0.4%) 0(0.0%) ??? ...contract/private/../../private/kw.rkt:761:9 integer->bigfloat [21] 100.0% ----------------------------------------------------------------------- iterate-egraph!13 [2] 100.0% [12] 334(0.3%) 0(0.0%) map-enodes ...ie/develop/src/core/egraph.rkt:140:0 loop [58] 100.0% ----------------------------------------------------------------------- profile-thunk16 [6] 100.0% [13] 113832(97.5%) 0(0.0%) run ...share/racket/pkgs/profile-lib/main.rkt:39:2 ??? [1] 100.0% ----------------------------------------------------------------------- run-improve50 [7] 5.2% ??? [1] 94.8% [14] 105240(90.1%) 0(0.0%) prepare-points ...bie/develop/src/points.rkt:214:0 loop [23] 34.0% make-exacts* [31] 33.0% loop [32] 33.0% ----------------------------------------------------------------------- run-improve50 [7] 100.0% [15] 7878(6.7%) 0(0.0%) setup-alt-simplified .../develop/src/glue.rkt:49:0 simplify-alt [24] 100.0% ----------------------------------------------------------------------- one-iter [8] 100.0% [16] 4238(3.6%) 0(0.0%) for-loop ...ie/develop/src/core/simplify.rkt:166:2 for-loop [25] 92.7% update-leader! [43] 7.3% ----------------------------------------------------------------------- for-loop [17] 50.0% one-iter [8] 50.0% [17] 3892(3.3%) 0(0.0%) for-loop ...e/develop/src/core/simplify.rkt:126:12 for-loop [17] 50.0% rule-valid-at-type? [26] 41.9% match-e [30] 8.1% ----------------------------------------------------------------------- run-improve50 [7] 100.0% [18] 1960(1.7%) 0(0.0%) for-loop ...herbie/develop/src/mainloop.rkt:249:10 run-iter! [27] 100.0% ----------------------------------------------------------------------- ??? [28] 16.2% f137 [9] 83.8% [19] 1960(1.7%) 0(0.0%) map ...acket/collects/racket/private/map.rkt:20:13 ??? [28] 83.8% ??? [3] 16.2% ----------------------------------------------------------------------- pass [10] 100.0% [20] 1088(0.9%) 0(0.0%) for-loop ...e/develop/src/core/simplify.rkt:230:29 argmin [29] 100.0% ----------------------------------------------------------------------- ??? [11] 100.0% [21] 456(0.4%) 456(0.4%) integer->bigfloat ...ivate/bigfloat/mpfr.rkt:399:0 ----------------------------------------------------------------------- run-improve50 [7] 100.0% [22] 312(0.3%) 0(0.0%) get-final-combination ...op/src/mainloop.rkt:264:0 ??? [3] 100.0% ----------------------------------------------------------------------- prepare-points [14] 100.0% [23] 35750(30.6%) 0(0.0%) loop ...htlies/herbie/develop/src/points.rkt:158:2 make-exacts* [31] 60.5% loop [32] 39.5% ----------------------------------------------------------------------- setup-alt-simplified [15] 100.0% [24] 7878(6.7%) 0(0.0%) simplify-alt ...s/herbie/develop/src/glue.rkt:76:0 ??? [65] 100.0% ----------------------------------------------------------------------- for-loop [16] 100.0% [25] 3928(3.4%) 0(0.0%) for-loop ...e/develop/src/core/simplify.rkt:148:10 substitute-e [34] 41.3% merge-egraph-nodes! [35] 40.9% mk-enode! [42] 17.7% ----------------------------------------------------------------------- for-loop [17] 100.0% [26] 3258(2.8%) 1694(1.5%) rule-valid-at-type? .../src/syntax/rules.rkt:548:0 *complex-rules* [36] 48.0% ----------------------------------------------------------------------- for-loop [18] 100.0% [27] 1960(1.7%) 0(0.0%) run-iter! ...herbie/develop/src/mainloop.rkt:215:0 localize-error [33] 100.0% ----------------------------------------------------------------------- map [19] 27.3% loop [58] 72.7% [28] 1960(1.7%) 0(0.0%) ??? ...ket/collects/racket/private/list.rkt:323:18 hash-ref! [49] 95.9% map [19] 4.1% ----------------------------------------------------------------------- for-loop [20] 100.0% [29] 1088(0.9%) 0(0.0%) argmin ...re/racket/collects/racket/list.rkt:743:0 expression-cost [37] 67.1% for-loop [39] 32.9% ----------------------------------------------------------------------- for-loop [17] 41.5% for-loop [46] 58.5% [30] 634(0.5%) 0(0.0%) match-e ...herbie/develop/src/core/ematch.rkt:46:0 for-loop [38] 66.1% for-loop [46] 16.9% variable? [40] 16.9% ----------------------------------------------------------------------- loop [23] 38.3% prepare-points [14] 61.7% [31] 56372(48.3%) 0(0.0%) make-exacts* ...erbie/develop/src/points.rkt:138:0 loop [58] 92.9% eval-prog [41] 7.1% ----------------------------------------------------------------------- loop [23] 28.9% prepare-points [14] 71.1% [32] 48868(41.9%) 0(0.0%) loop ...htlies/herbie/develop/src/points.rkt:141:4 loop [58] 100.0% ----------------------------------------------------------------------- run-iter! [27] 100.0% [33] 1960(1.7%) 0(0.0%) localize-error ...velop/src/core/localize.rkt:47:0 hash-ref! [49] 100.0% ----------------------------------------------------------------------- substitute-e [34] 32.3% for-loop [25] 67.7% [34] 1624(1.4%) 0(0.0%) substitute-e ...e/develop/src/core/ematch.rkt:71:0 mk-enode! [42] 61.3% substitute-e [34] 32.3% ??? [67] 6.4% ----------------------------------------------------------------------- for-loop [48] 9.3% merge-egraph-nodes! [35] 20.0% for-loop [25] 70.7% [35] 1608(1.4%) 0(0.0%) merge-egraph-nodes! ...p/src/core/egraph.rkt:153:0 update-leader! [43] 70.7% merge-egraph-nodes! [35] 20.0% for-loop [48] 9.3% ----------------------------------------------------------------------- rule-valid-at-type? [26] 100.0% [36] 1564(1.3%) 320(0.3%) *complex-rules* ...elop/src/syntax/rules.rkt:560:0 for-loop [44] 79.5% ----------------------------------------------------------------------- argmin [29] 100.0% [37] 730(0.6%) 0(0.0%) expression-cost .../develop/src/programs.rkt:209:0 compile [45] 100.0% ----------------------------------------------------------------------- match-e [30] 100.0% [38] 634(0.5%) 0(0.0%) for-loop ...rbie/develop/src/core/ematch.rkt:59:11 for-loop [46] 75.4% list-cartesian-product [47] 24.6% ----------------------------------------------------------------------- argmin [29] 100.0% [39] 358(0.3%) 0(0.0%) for-loop .../herbie/develop/src/programs.rkt:210:2 ??? [65] 100.0% ----------------------------------------------------------------------- match-e [30] 100.0% [40] 322(0.3%) 0(0.0%) variable? ...e/develop/src/syntax/syntax.rkt:665:0 ??? [67] 100.0% ----------------------------------------------------------------------- make-exacts* [31] 100.0% [41] 3986(3.4%) 0(0.0%) eval-prog ...herbie/develop/src/programs.rkt:150:0 hash-ref! [49] 88.6% f137 [9] 11.4% ----------------------------------------------------------------------- for-loop [25] 34.6% substitute-e [34] 65.4% [42] 2010(1.7%) 322(0.3%) mk-enode! ...bie/develop/src/core/egraph.rkt:102:0 new-enode [51] 84.0% ----------------------------------------------------------------------- for-loop [16] 16.2% merge-egraph-nodes! [35] 83.8% [43] 1918(1.6%) 0(0.0%) update-leader! ...evelop/src/core/egraph.rkt:218:0 for-loop [50] 100.0% ----------------------------------------------------------------------- *complex-rules* [36] 100.0% [44] 1244(1.1%) 932(0.8%) for-loop ...ies/herbie/develop/src/common.rkt:99:9 list-member? [52] 25.1% ----------------------------------------------------------------------- expression-cost [37] 100.0% [45] 730(0.6%) 0(0.0%) compile ...s/herbie/develop/src/programs.rkt:186:0 hash-ref! [49] 100.0% ----------------------------------------------------------------------- match-e [30] 25.4% for-loop [38] 74.6% [46] 634(0.5%) 0(0.0%) for-loop ...rbie/develop/src/core/ematch.rkt:65:37 match-e [30] 100.0% ----------------------------------------------------------------------- list-cartesian-product [47] 50.0% for-loop [38] 50.0% [47] 312(0.3%) 312(0.3%) list-cartesian-product ...src/core/ematch.rkt:20:0 list-cartesian-product [47] 50.0% ----------------------------------------------------------------------- merge-egraph-nodes! [35] 100.0% [48] 300(0.3%) 0(0.0%) for-loop ...bie/develop/src/core/egraph.rkt:201:10 merge-egraph-nodes! [35] 100.0% ----------------------------------------------------------------------- ??? [53] 3.8% localize-error [33] 5.7% compile [45] 7.9% eval-prog [41] 12.7% ??? [28] 25.8% loop [58] 44.1% [49] 6220(5.3%) 374(0.3%) hash-ref! ...racket/private/more-scheme.rkt:373:13 ??? [53] 49.8% parse-loop12 [55] 25.8% bigfloat-hash [54] 12.7% f137 [9] 5.7% ----------------------------------------------------------------------- update-leader! [43] 100.0% [50] 1918(1.6%) 0(0.0%) for-loop ...rbie/develop/src/core/egraph.rkt:223:6 for-loop [56] 100.0% ----------------------------------------------------------------------- mk-enode! [42] 100.0% [51] 1688(1.4%) 0(0.0%) new-enode ...erbie/develop/src/core/enode.rkt:97:0 type-of-enode-expr [57] 100.0% ----------------------------------------------------------------------- for-loop [44] 100.0% [52] 312(0.3%) 312(0.3%) list-member? ...llects/racket/private/set.rkt:24:0 ----------------------------------------------------------------------- hash-ref! [49] 100.0% [53] 3572(3.1%) 356(0.3%) ??? ...tlies/herbie/develop/src/programs.rkt:194:5 loop [58] 90.0% hash-ref! [49] 6.6% ----------------------------------------------------------------------- hash-ref! [49] 100.0% [54] 3530(3.0%) 0(0.0%) bigfloat-hash ...h/private/bigfloat/mpfr.rkt:165:0 bfcanonicalize [59] 56.1% sig+exp->bigfloat [62] 35.1% bigfloat->sig+exp [63] 8.8% ----------------------------------------------------------------------- hash-ref! [49] 100.0% [55] 1960(1.7%) 0(0.0%) parse-loop12 ...s/racket/match/compiler.rkt:418:15 loop [58] 97.7% loop [5] 2.3% ----------------------------------------------------------------------- for-loop [50] 100.0% [56] 1918(1.6%) 0(0.0%) for-loop ...rbie/develop/src/core/egraph.rkt:224:8 hash-update! [60] 100.0% ----------------------------------------------------------------------- new-enode [51] 100.0% [57] 1688(1.4%) 0(0.0%) type-of-enode-expr ...elop/src/core/enode.rkt:68:0 get-sigs [61] 100.0% ----------------------------------------------------------------------- map-enodes [12] 0.0% make-exacts* [31] 0.4% parse-loop12 [55] 0.6% loop [32] 0.8% ??? [53] 3.0% loop [58] 95.2% [58] 106764(91.4%) 696(0.6%) loop ...cket/collects/racket/private/map.rkt:25:19 loop [58] 95.2% hash-ref! [49] 3.0% ??? [64] 1.2% ??? [28] 0.6% ??? [3] 0.0% for-loop [69] 0.0% ----------------------------------------------------------------------- bigfloat-hash [54] 100.0% [59] 1980(1.7%) 1980(1.7%) bfcanonicalize .../private/bigfloat/mpfr.rkt:155:0 ----------------------------------------------------------------------- for-loop [56] 100.0% [60] 1918(1.6%) 0(0.0%) hash-update! ...ket/private/more-scheme.rkt:362:13 ??? [66] 100.0% ----------------------------------------------------------------------- type-of-enode-expr [57] 100.0% [61] 1688(1.4%) 0(0.0%) get-sigs .../herbie/develop/src/type-check.rkt:5:0 ??? [67] 41.5% ??? [65] 37.7% ??? [68] 20.9% ----------------------------------------------------------------------- bigfloat-hash [54] 100.0% [62] 1240(1.1%) 956(0.8%) sig+exp->bigfloat ...ivate/bigfloat/mpfr.rkt:385:0 ??? [94] 22.9% ----------------------------------------------------------------------- bigfloat-hash [54] 100.0% [63] 310(0.3%) 0(0.0%) bigfloat->sig+exp ...ivate/bigfloat/mpfr.rkt:370:0 new-mpz [70] 100.0% ----------------------------------------------------------------------- loop [58] 100.0% [64] 99906(85.6%) 0(0.0%) ??? ...tlies/herbie/develop/src/programs.rkt:156:4 ??? [71] 100.0% ----------------------------------------------------------------------- for-loop [39] 1.0% get-sigs [61] 1.8% ??? [3] 18.6% simplify-alt [24] 33.6% ??? [65] 40.0% [65] 11536(9.9%) 1280(1.1%) ??? ...llects/racket/private/norm-define.rkt:53:83 ??? [65] 40.0% iterate-egraph!13 [2] 35.8% ??? [73] 6.2% loop [4] 4.2% ??? [77] 2.7% ??? [80] 2.0% ----------------------------------------------------------------------- hash-update! [60] 100.0% [66] 1918(1.6%) 0(0.0%) ??? ...s/herbie/develop/src/core/egraph.rkt:226:24 for-loop [72] 100.0% ----------------------------------------------------------------------- substitute-e [34] 23.3% variable? [40] 24.2% get-sigs [61] 52.6% [67] 1332(1.1%) 322(0.3%) ??? ...contract/private/arrow-val-first.rkt:357:18 hash-has-key? [74] 75.8% ----------------------------------------------------------------------- get-sigs [61] 100.0% [68] 352(0.3%) 0(0.0%) ??? ...ts/racket/contract/private/arr-i.rkt:804:10 ??? [75] 100.0% ----------------------------------------------------------------------- loop [58] 100.0% [69] 334(0.3%) 0(0.0%) for-loop ...ie/develop/src/core/simplify.rkt:195:2 curried [76] 100.0% ----------------------------------------------------------------------- bigfloat->sig+exp [63] 100.0% [70] 310(0.3%) 310(0.3%) new-mpz ...-lib/math/private/bigfloat/gmp.rkt:73:0 ----------------------------------------------------------------------- ??? [64] 100.0% [71] 99906(85.6%) 4704(4.0%) ??? ...acket/collects/racket/private/kw.rkt:444:14 bf-complex-mult [78] 86.5% bf-complex-add [79] 7.7% ----------------------------------------------------------------------- ??? [66] 100.0% [72] 1918(1.6%) 1598(1.4%) for-loop ...bie/develop/src/core/egraph.rkt:227:26 update-en-expr [82] 16.7% ----------------------------------------------------------------------- f137 [9] 30.9% ??? [65] 69.1% [73] 1030(0.9%) 1030(0.9%) ??? ...racket/collects/racket/private/kw.rkt:761:9 ----------------------------------------------------------------------- ??? [67] 100.0% [74] 1010(0.9%) 310(0.3%) hash-has-key? ...et/private/more-scheme.rkt:368:13 ??? [80] 69.3% ----------------------------------------------------------------------- ??? [68] 100.0% [75] 352(0.3%) 0(0.0%) ??? ...ects/racket/contract/private/hash.rkt:217:4 ??? [81] 100.0% ----------------------------------------------------------------------- for-loop [69] 100.0% [76] 334(0.3%) 334(0.3%) curried ...cket/collects/racket/function.rkt:71:18 ----------------------------------------------------------------------- ??? [65] 100.0% [77] 306(0.3%) 306(0.3%) ??? ...-racket/utils/simple-result-arrow.rkt:60:15 ----------------------------------------------------------------------- ??? [71] 100.0% [78] 86424(74.0%) 4090(3.5%) bf-complex-mult ...develop/src/bigcomplex.rkt:33:0 bf* [83] 52.6% ??? [87] 38.8% ...higher-order.rkt:346:33 [84] 3.9% ----------------------------------------------------------------------- ??? [71] 100.0% [79] 7708(6.6%) 320(0.3%) bf-complex-add .../develop/src/bigcomplex.rkt:22:0 ??? [87] 91.6% ...higher-order.rkt:346:33 [84] 4.2% ----------------------------------------------------------------------- ??? [65] 49.3% hash-has-key? [74] 50.7% [80] 1380(1.2%) 1036(0.9%) ??? ...ects/racket/contract/private/list.rkt:737:4 for-loop [86] 24.9% ----------------------------------------------------------------------- ??? [75] 100.0% [81] 352(0.3%) 0(0.0%) ??? ...ects/racket/contract/private/list.rkt:169:2 ??? [85] 100.0% ----------------------------------------------------------------------- for-loop [72] 100.0% [82] 320(0.3%) 320(0.3%) update-en-expr ...evelop/src/core/egraph.rkt:212:0 ----------------------------------------------------------------------- bf-complex-mult [78] 100.0% [83] 45470(38.9%) 0(0.0%) bf* ...ath/private/bigfloat/bigfloat-mpfr.rkt:95:0 ??? [87] 100.0% ----------------------------------------------------------------------- bf-complex-add [79] 8.9% bf-complex-mult [78] 91.1% [84] 3668(3.1%) 352(0.3%) ...higher-order.rkt:346:33 (unknown source) ??? [88] 90.4% ----------------------------------------------------------------------- ??? [81] 100.0% [85] 352(0.3%) 0(0.0%) ??? ...ects/racket/contract/private/list.rkt:678:5 for-loop [89] 100.0% ----------------------------------------------------------------------- ??? [80] 100.0% [86] 344(0.3%) 344(0.3%) for-loop ...acket/contract/private/list.rkt:743:12 ----------------------------------------------------------------------- bf-complex-add [79] 8.2% bf-complex-mult [78] 39.0% bf* [83] 52.8% [87] 86054(73.7%) 8084(6.9%) ??? ...-racket/utils/simple-result-arrow.rkt:39:12 bfadd [90] 78.6% bfneg [91] 12.0% ----------------------------------------------------------------------- ...higher-order.rkt:346:33 [84]100.0% [88] 3316(2.8%) 2326(2.0%) ??? ...cts/racket/contract/private/list.rkt:187:10 ??? [92] 29.9% ----------------------------------------------------------------------- ??? [85] 100.0% [89] 352(0.3%) 0(0.0%) for-loop ...racket/contract/private/list.rkt:680:9 add-list-context [93] 100.0% ----------------------------------------------------------------------- ??? [87] 100.0% [90] 67626(57.9%) 46564(39.9%) bfadd ...-lib/math/private/bigfloat/mpfr.rkt:819:4 ??? [94] 31.1% ----------------------------------------------------------------------- ??? [87] 100.0% [91] 10344(8.9%) 6266(5.4%) bfneg ...-lib/math/private/bigfloat/mpfr.rkt:616:4 ??? [94] 39.4% ----------------------------------------------------------------------- ??? [88] 100.0% [92] 990(0.8%) 990(0.8%) ??? ...ects/racket/contract/private/guts.rkt:644:8 ----------------------------------------------------------------------- for-loop [89] 100.0% [93] 352(0.3%) 352(0.3%) add-list-context ...ontract/private/list.rkt:752:0 ----------------------------------------------------------------------- sig+exp->bigfloat [62] 1.1% bfneg [91] 16.0% bfadd [90] 82.8% [94] 25424(21.8%) 25424(21.8%) ??? .../share/racket/collects/ffi/unsafe.rkt:861:4 -----------------------------------------------------------------------