Profiling results ----------------- Total cpu time observed: 26748ms (out of 27668ms) Number of samples taken: 65 (once every 412ms) ======================================================================== Caller Idx Total Self Name+src Local% ms(pct) ms(pct) Callee ======================================================================== ??? [31] 100.0% [1] 25764(96.3%) 0(0.0%) profile-thunk16 ...t/pkgs/profile-lib/main.rkt:9:0 run [5] 100.0% ------------------------------------------------------------------------ ??? [31] 100.0% [2] 10160(38.0%) 0(0.0%) run-improve50 ...ie/develop/src/mainloop.rkt:234:0 for-loop [6] 93.2% loop [8] 3.7% get-final-combination [10] 3.0% ------------------------------------------------------------------------ ->flonum [65] 100.0% [3] 8836(33.0%) 0(0.0%) iterate-egraph!13 ...p/src/core/simplify.rkt:105:0 one-iter [7] 100.0% ------------------------------------------------------------------------ ->flonum [65] 100.0% [4] 952(3.6%) 0(0.0%) loop ...herbie/develop/src/core/simplify.rkt:237:2 pass [9] 100.0% ------------------------------------------------------------------------ profile-thunk16 [1] 100.0% [5] 25764(96.3%) 0(0.0%) run ...share/racket/pkgs/profile-lib/main.rkt:39:2 ??? [31] 100.0% ------------------------------------------------------------------------ run-improve50 [2] 100.0% [6] 9472(35.4%) 0(0.0%) for-loop ...herbie/develop/src/mainloop.rkt:249:10 run-iter! [11] 100.0% ------------------------------------------------------------------------ iterate-egraph!13 [3] 100.0% [7] 8836(33.0%) 0(0.0%) one-iter ...ie/develop/src/core/simplify.rkt:116:0 for-loop [12] 59.0% for-loop [13] 41.0% ------------------------------------------------------------------------ run-improve50 [2] 14.5% ??? [31] 85.5% [8] 2626(9.8%) 0(0.0%) loop ...htlies/herbie/develop/src/points.rkt:238:2 make-exacts* [46] 42.4% loop [41] 27.5% for-loop [44] 16.1% loop [45] 13.9% ------------------------------------------------------------------------ loop [4] 100.0% [9] 952(3.6%) 0(0.0%) pass ...herbie/develop/src/core/simplify.rkt:227:2 for-loop [14] 100.0% ------------------------------------------------------------------------ run-improve50 [2] 100.0% [10] 308(1.2%) 0(0.0%) get-final-combination ...op/src/mainloop.rkt:264:0 extract-alt [15] 100.0% ------------------------------------------------------------------------ for-loop [6] 100.0% [11] 9472(35.4%) 0(0.0%) run-iter! ...herbie/develop/src/mainloop.rkt:215:0 simplify! [16] 92.9% localize-error [20] 3.7% finalize-iter! [21] 3.3% ------------------------------------------------------------------------ for-loop [12] 50.0% one-iter [7] 50.0% [12] 5212(19.5%) 1050(3.9%) for-loop ...e/develop/src/core/simplify.rkt:126:12 for-loop [12] 50.0% match-e [17] 39.9% ------------------------------------------------------------------------ one-iter [7] 100.0% [13] 3624(13.5%) 0(0.0%) for-loop ...ie/develop/src/core/simplify.rkt:166:2 for-loop [18] 90.8% match-e [17] 9.2% ------------------------------------------------------------------------ pass [9] 100.0% [14] 952(3.6%) 0(0.0%) for-loop ...e/develop/src/core/simplify.rkt:230:29 argmin [19] 100.0% ------------------------------------------------------------------------ get-final-combination [10] 100.0% [15] 308(1.2%) 0(0.0%) extract-alt ...es/herbie/develop/src/glue.rkt:55:0 argmins [22] 100.0% ------------------------------------------------------------------------ run-iter! [11] 100.0% [16] 8804(32.9%) 0(0.0%) simplify! ...herbie/develop/src/mainloop.rkt:155:0 for-loop [23] 100.0% ------------------------------------------------------------------------ for-loop [13] 3.7% for-loop [34] 7.3% for-loop [12] 89.0% [17] 4494(16.8%) 320(1.2%) match-e ...herbie/develop/src/core/ematch.rkt:46:0 for-loop [24] 82.0% for-loop [34] 7.3% loop [50] 3.6% ------------------------------------------------------------------------ for-loop [13] 100.0% [18] 3292(12.3%) 0(0.0%) for-loop ...e/develop/src/core/simplify.rkt:148:10 mk-enode! [33] 49.9% merge-egraph-nodes! [25] 20.5% loop! [26] 19.9% substitute-e [28] 9.7% ------------------------------------------------------------------------ for-loop [14] 100.0% [19] 952(3.6%) 0(0.0%) argmin ...re/racket/collects/racket/list.rkt:743:0 for-loop [27] 68.5% expression-cost [30] 31.5% ------------------------------------------------------------------------ run-iter! [11] 100.0% [20] 352(1.3%) 0(0.0%) localize-error ...velop/src/core/localize.rkt:47:0 hash-ref! [67] 100.0% ------------------------------------------------------------------------ run-iter! [11] 100.0% [21] 316(1.2%) 0(0.0%) finalize-iter! ...e/develop/src/mainloop.rkt:169:0 ??? [54] 100.0% ------------------------------------------------------------------------ extract-alt [15] 100.0% [22] 308(1.2%) 0(0.0%) argmins ...ies/herbie/develop/src/common.rkt:152:0 composed [29] 100.0% ------------------------------------------------------------------------ simplify! [16] 100.0% [23] 8804(32.9%) 0(0.0%) for-loop .../herbie/develop/src/mainloop.rkt:159:6 ??? [31] 100.0% ------------------------------------------------------------------------ match-e [17] 100.0% [24] 3846(14.4%) 332(1.2%) for-loop ...rbie/develop/src/core/ematch.rkt:59:11 list-cartesian-product [32] 73.6% for-loop [34] 22.0% ------------------------------------------------------------------------ merge-egraph-nodes! [25] 25.4% for-loop [18] 74.6% [25] 676(2.5%) 0(0.0%) merge-egraph-nodes! ...p/src/core/egraph.rkt:153:0 enode-merge! [35] 74.6% merge-egraph-nodes! [25] 25.4% ------------------------------------------------------------------------ for-loop [18] 100.0% [26] 654(2.4%) 0(0.0%) loop! ...s/herbie/develop/src/core/enode.rkt:192:2 custom-set-union [43] 100.0% ------------------------------------------------------------------------ argmin [19] 100.0% [27] 652(2.4%) 0(0.0%) for-loop .../herbie/develop/src/programs.rkt:210:2 ->flonum [65] 51.2% ...velop/src/common.rkt:47:2 [53] 48.8% ------------------------------------------------------------------------ for-loop [18] 100.0% [28] 320(1.2%) 0(0.0%) substitute-e ...e/develop/src/core/ematch.rkt:71:0 mk-enode! [33] 100.0% ------------------------------------------------------------------------ argmins [22] 100.0% [29] 308(1.2%) 0(0.0%) composed ...ollects/racket/private/list.rkt:321:16 errors [78] 100.0% ------------------------------------------------------------------------ argmin [19] 100.0% [30] 300(1.1%) 0(0.0%) expression-cost .../develop/src/programs.rkt:209:0 compile [36] 100.0% ------------------------------------------------------------------------ for-loop [23] 11.0% run [5] 42.7% [31] 26748(100.0%) 0(0.0%) ??? ...lects/racket/private/more-scheme.rkt:261:28 profile-thunk16 [1] 42.7% prepare-points [37] 25.0% ->flonum [65] 14.7% run-improve50 [2] 13.5% loop [8] 4.2% ------------------------------------------------------------------------ list-cartesian-product [32] 50.0% for-loop [24] 50.0% [32] 2832(10.6%) 2832(10.6%) list-cartesian-product ...src/core/ematch.rkt:20:0 list-cartesian-product [32] 50.0% ------------------------------------------------------------------------ substitute-e [28] 16.3% for-loop [18] 83.7% [33] 1962(7.3%) 0(0.0%) mk-enode! ...bie/develop/src/core/egraph.rkt:102:0 new-enode [38] 100.0% ------------------------------------------------------------------------ match-e [17] 24.4% for-loop [24] 75.6% [34] 1342(5.0%) 356(1.3%) for-loop ...rbie/develop/src/core/ematch.rkt:65:37 match-e [17] 49.0% ??? [40] 24.4% ------------------------------------------------------------------------ merge-egraph-nodes! [25] 100.0% [35] 676(2.5%) 0(0.0%) enode-merge! ...e/develop/src/core/enode.rkt:129:0 adopt-enode! [39] 100.0% ------------------------------------------------------------------------ expression-cost [30] 100.0% [36] 300(1.1%) 0(0.0%) compile ...s/herbie/develop/src/programs.rkt:186:0 hash-ref! [67] 100.0% ------------------------------------------------------------------------ ??? [31] 100.0% [37] 13358(49.9%) 0(0.0%) prepare-points ...bie/develop/src/points.rkt:214:0 loop [45] 58.0% make-exacts* [46] 20.6% loop [41] 16.6% for-loop [44] 4.8% ------------------------------------------------------------------------ mk-enode! [33] 100.0% [38] 1962(7.3%) 0(0.0%) new-enode ...erbie/develop/src/core/enode.rkt:97:0 type-of-enode-expr [42] 100.0% ------------------------------------------------------------------------ enode-merge! [35] 100.0% [39] 676(2.5%) 0(0.0%) adopt-enode! ...e/develop/src/core/enode.rkt:105:0 custom-set-union [43] 100.0% ------------------------------------------------------------------------ for-loop [34] 100.0% [40] 328(1.2%) 328(1.2%) ??? ...ies/herbie/develop/src/core/ematch.rkt:50:5 ------------------------------------------------------------------------ loop [8] 24.6% prepare-points [37] 75.4% [41] 2934(11.0%) 0(0.0%) loop ...htlies/herbie/develop/src/points.rkt:158:2 make-exacts* [46] 61.4% loop [45] 38.6% ------------------------------------------------------------------------ new-enode [38] 100.0% [42] 1962(7.3%) 0(0.0%) type-of-enode-expr ...elop/src/core/enode.rkt:68:0 get-sigs [47] 100.0% ------------------------------------------------------------------------ loop! [26] 49.2% adopt-enode! [39] 50.8% [43] 1330(5.0%) 332(1.2%) custom-set-union ...et/private/set-types.rkt:168:0 for-loop [49] 75.0% ------------------------------------------------------------------------ loop [8] 39.7% prepare-points [37] 60.3% [44] 1068(4.0%) 0(0.0%) for-loop ...s/herbie/develop/src/points.rkt:255:26 ??? [48] 100.0% ------------------------------------------------------------------------ loop [8] 4.0% loop [41] 12.2% prepare-points [37] 83.8% [45] 9248(34.6%) 0(0.0%) loop ...htlies/herbie/develop/src/points.rkt:141:4 loop [50] 100.0% ------------------------------------------------------------------------ loop [8] 19.7% loop [41] 31.8% prepare-points [37] 48.6% [46] 5668(21.2%) 0(0.0%) make-exacts* ...erbie/develop/src/points.rkt:138:0 loop [50] 93.3% eval-prog [55] 6.7% ------------------------------------------------------------------------ type-of-enode-expr [42] 100.0% [47] 1962(7.3%) 0(0.0%) get-sigs .../herbie/develop/src/type-check.rkt:5:0 ??? [51] 51.5% ->flonum [65] 16.8% ...velop/src/common.rkt:47:2 [53] 16.3% ??? [54] 15.4% ------------------------------------------------------------------------ for-loop [44] 100.0% [48] 1068(4.0%) 0(0.0%) ??? ...ghtlies/herbie/develop/src/points.rkt:230:7 for-loop [52] 71.0% ??? [57] 29.0% ------------------------------------------------------------------------ custom-set-union [43] 100.0% [49] 998(3.7%) 660(2.5%) for-loop ...cts/racket/private/set-types.rkt:174:3 for-loop [56] 33.9% ------------------------------------------------------------------------ ??? [86] 0.1% loop [45] 0.2% make-exacts* [46] 0.3% match-e [17] 2.1% parse-loop12 [73] 2.3% loop [50] 95.1% [50] 15214(56.9%) 0(0.0%) loop ...cket/collects/racket/private/map.rkt:25:19 loop [50] 95.1% ??? [59] 2.3% curried [61] 2.1% ??? [86] 0.2% ??? [57] 0.2% ??? [88] 0.1% ------------------------------------------------------------------------ get-sigs [47] 100.0% [51] 1010(3.8%) 0(0.0%) ??? ...ts/racket/contract/private/arr-i.rkt:804:10 for-loop [58] 65.9% ??? [60] 34.1% ------------------------------------------------------------------------ ??? [48] 100.0% [52] 758(2.8%) 0(0.0%) for-loop ...es/herbie/develop/src/points.rkt:231:9 ??? [57] 100.0% ------------------------------------------------------------------------ for-loop [27] 49.8% get-sigs [47] 50.2% [53] 638(2.4%) 318(1.2%) ...velop/src/common.rkt:47:2 ...e/arr-i.rkt:906:19 ??? [62] 50.2% ------------------------------------------------------------------------ get-sigs [47] 48.9% finalize-iter! [21] 51.1% [54] 618(2.3%) 0(0.0%) ??? ...contract/private/arrow-val-first.rkt:357:18 atab-add-altns [63] 51.1% hash-has-key? [64] 48.9% ------------------------------------------------------------------------ make-exacts* [46] 100.0% [55] 380(1.4%) 380(1.4%) eval-prog ...herbie/develop/src/programs.rkt:150:0 ------------------------------------------------------------------------ for-loop [49] 100.0% [56] 338(1.3%) 338(1.3%) for-loop ...cts/racket/private/set-types.rkt:178:5 ------------------------------------------------------------------------ ??? [48] 9.9% ??? [86] 20.0% for-loop [52] 24.3% loop [50] 45.7% [57] 3118(11.7%) 676(2.5%) ??? ...tract/private/arrow-higher-order.rkt:342:33 ->flonum [65] 78.3% ------------------------------------------------------------------------ ??? [51] 100.0% [58] 666(2.5%) 0(0.0%) for-loop ...racket/contract/private/hash.rkt:239:6 ??? [66] 100.0% ------------------------------------------------------------------------ loop [50] 100.0% [59] 352(1.3%) 0(0.0%) ??? ...ket/collects/racket/private/list.rkt:323:18 hash-ref! [67] 100.0% ------------------------------------------------------------------------ ??? [51] 100.0% [60] 344(1.3%) 344(1.3%) ??? ...ects/racket/contract/private/hash.rkt:217:4 ------------------------------------------------------------------------ loop [50] 100.0% [61] 326(1.2%) 326(1.2%) curried ...cket/collects/racket/function.rkt:71:18 ------------------------------------------------------------------------ ...velop/src/common.rkt:47:2 [53]100.0% [62] 320(1.2%) 0(0.0%) ??? ...s/racket/contract/private/arr-i.rkt:1268:39 ??? [68] 100.0% ------------------------------------------------------------------------ ??? [54] 100.0% [63] 316(1.2%) 0(0.0%) atab-add-altns ...elop/src/core/alt-table.rkt:50:0 atab-add-altn [69] 100.0% ------------------------------------------------------------------------ ??? [54] 100.0% [64] 302(1.1%) 0(0.0%) hash-has-key? ...et/private/more-scheme.rkt:368:13 ??? [71] 100.0% ------------------------------------------------------------------------ get-sigs [47] 0.9% for-loop [27] 0.9% ??? [57] 20.0% for-loop [70] 39.1% ??? [31] 39.1% [65] 12230(45.7%) 2108(7.9%) ->flonum ...s/racket/private/norm-define.rkt:53:83 for-loop [70] 39.1% iterate-egraph!13 [3] 35.7% loop [4] 3.4% loop [74] 2.7% ??? [71] 1.8% ------------------------------------------------------------------------ for-loop [58] 100.0% [66] 666(2.5%) 0(0.0%) ??? ...cts/racket/contract/private/list.rkt:187:10 ??? [72] 100.0% ------------------------------------------------------------------------ ??? [76] 23.0% compile [36] 23.0% ??? [59] 27.0% localize-error [20] 27.0% [67] 652(2.4%) 0(0.0%) hash-ref! ...racket/private/more-scheme.rkt:373:13 parse-loop12 [73] 54.0% ??? [76] 46.0% ------------------------------------------------------------------------ ??? [62] 100.0% [68] 320(1.2%) 0(0.0%) ??? ...racket/collects/racket/private/kw.rkt:761:9 ??? [77] 100.0% ------------------------------------------------------------------------ atab-add-altns [63] 100.0% [69] 316(1.2%) 0(0.0%) atab-add-altn ...elop/src/core/alt-table.rkt:208:0 best-and-tied-at-points [75] 100.0% ------------------------------------------------------------------------ ->flonum [65] 100.0% [70] 9788(36.6%) 0(0.0%) for-loop ...ie/develop/src/core/simplify.rkt:66:12 ->flonum [65] 100.0% ------------------------------------------------------------------------ hash-has-key? [64] 31.3% ->flonum [65] 68.7% [71] 966(3.6%) 632(2.4%) ??? ...ects/racket/contract/private/list.rkt:737:4 for-loop [81] 34.6% ------------------------------------------------------------------------ ??? [66] 100.0% [72] 666(2.5%) 0(0.0%) ??? ...ects/racket/contract/private/list.rkt:686:7 ??? [79] 51.1% ??? [77] 48.9% ------------------------------------------------------------------------ hash-ref! [67] 100.0% [73] 352(1.3%) 0(0.0%) parse-loop12 ...s/racket/match/compiler.rkt:418:15 loop [50] 50.0% bf* [91] 50.0% ------------------------------------------------------------------------ ->flonum [65] 100.0% [74] 334(1.2%) 0(0.0%) loop ...ghtlies/herbie/develop/src/points.rkt:66:6 random-exp [80] 100.0% ------------------------------------------------------------------------ atab-add-altn [69] 100.0% [75] 316(1.2%) 0(0.0%) best-and-tied-at-points ...ore/alt-table.rkt:122:0 errors [78] 100.0% ------------------------------------------------------------------------ hash-ref! [67] 100.0% [76] 300(1.1%) 300(1.1%) ??? ...tlies/herbie/develop/src/programs.rkt:194:5 hash-ref! [67] 50.0% ------------------------------------------------------------------------ ??? [68] 49.5% ??? [72] 50.5% [77] 646(2.4%) 326(1.2%) ??? ...ects/racket/contract/private/guts.rkt:644:8 dict? [85] 49.5% ------------------------------------------------------------------------ composed [29] 49.4% best-and-tied-at-points [75] 50.6% [78] 624(2.3%) 0(0.0%) errors ...lies/herbie/develop/src/points.rkt:271:0 for-loop [82] 100.0% ------------------------------------------------------------------------ ??? [72] 100.0% [79] 340(1.3%) 0(0.0%) ??? ...ects/racket/contract/private/prop.rkt:493:4 ??? [83] 100.0% ------------------------------------------------------------------------ loop [74] 100.0% [80] 334(1.2%) 334(1.2%) random-exp .../herbie/develop/src/common.rkt:253:0 ------------------------------------------------------------------------ ??? [71] 100.0% [81] 334(1.2%) 0(0.0%) for-loop ...acket/contract/private/list.rkt:743:12 ??? [84] 100.0% ------------------------------------------------------------------------ errors [78] 100.0% [82] 624(2.3%) 0(0.0%) for-loop ...es/herbie/develop/src/points.rkt:274:4 ??? [86] 100.0% ------------------------------------------------------------------------ ??? [79] 100.0% [83] 340(1.3%) 0(0.0%) ??? ...lects/racket/contract/private/orc.rkt:83:14 ??? [87] 100.0% ------------------------------------------------------------------------ for-loop [81] 100.0% [84] 334(1.2%) 334(1.2%) ??? ...private/unconstrained-domain-arrow.rkt:74:4 ------------------------------------------------------------------------ ??? [77] 100.0% [85] 320(1.2%) 320(1.2%) dict? ...ollects/racket/private/generic.rkt:146:11 ------------------------------------------------------------------------ for-loop [82] 4.5% loop [50] 95.5% [86] 13734(51.3%) 2418(9.0%) ??? ...tlies/herbie/develop/src/programs.rkt:156:4 ??? [89] 36.7% ??? [88] 22.3% loop [50] 18.8% ??? [57] 4.5% ------------------------------------------------------------------------ ??? [83] 100.0% [87] 340(1.3%) 340(1.3%) ??? ...ects/racket/contract/private/list.rkt:141:5 ------------------------------------------------------------------------ loop [50] 45.7% ??? [86] 54.3% [88] 5650(21.1%) 690(2.6%) ??? ...contract/private/../../private/kw.rkt:761:9 real->bigfloat [90] 87.8% ------------------------------------------------------------------------ ??? [86] 100.0% [89] 5042(18.9%) 1752(6.6%) ??? ...acket/collects/racket/private/kw.rkt:444:14 bf* [91] 65.3% ------------------------------------------------------------------------ ??? [88] 100.0% [90] 4960(18.5%) 3832(14.3%) real->bigfloat .../private/bigfloat/mpfr.rkt:451:0 ??? [94] 22.7% ------------------------------------------------------------------------ parse-loop12 [73] 9.7% ??? [89] 90.3% [91] 3642(13.6%) 0(0.0%) bf* ...ath/private/bigfloat/bigfloat-mpfr.rkt:95:0 ??? [92] 100.0% ------------------------------------------------------------------------ bf* [91] 100.0% [92] 3642(13.6%) 0(0.0%) ??? ...-racket/utils/simple-result-arrow.rkt:39:12 bfmul [93] 100.0% ------------------------------------------------------------------------ ??? [92] 100.0% [93] 3642(13.6%) 2890(10.8%) bfmul ...-lib/math/private/bigfloat/mpfr.rkt:819:4 ??? [94] 20.6% ------------------------------------------------------------------------ bfmul [93] 40.0% real->bigfloat [90] 60.0% [94] 1880(7.0%) 1880(7.0%) ??? .../share/racket/collects/ffi/unsafe.rkt:861:4 ------------------------------------------------------------------------