Profiling results ----------------- Total cpu time observed: 28414ms (out of 28760ms) Number of samples taken: 85 (once every 334ms) ======================================================================== Caller Idx Total Self Name+src Local% ms(pct) ms(pct) Callee ======================================================================== ??? [28] 100.0% [1] 25112(88.4%) 0(0.0%) profile-thunk16 ...t/pkgs/profile-lib/main.rkt:9:0 run [5] 100.0% ------------------------------------------------------------------------ ??? [60] 100.0% [2] 19804(69.7%) 0(0.0%) iterate-egraph!13 ...p/src/core/simplify.rkt:105:0 one-iter [6] 98.3% map-enodes [8] 1.7% ------------------------------------------------------------------------ ??? [28] 100.0% [3] 18550(65.3%) 0(0.0%) run-improve50 ...ie/develop/src/mainloop.rkt:234:0 for-loop [7] 98.2% get-final-combination [10] 1.8% ------------------------------------------------------------------------ ??? [60] 100.0% [4] 336(1.2%) 0(0.0%) loop ...herbie/develop/src/core/simplify.rkt:237:2 pass [9] 100.0% ------------------------------------------------------------------------ profile-thunk16 [1] 97.5% [5] 25762(90.7%) 0(0.0%) run ...share/racket/pkgs/profile-lib/main.rkt:39:2 ??? [28] 100.0% ------------------------------------------------------------------------ iterate-egraph!13 [2] 100.0% [6] 19458(68.5%) 326(1.1%) one-iter ...ie/develop/src/core/simplify.rkt:116:0 for-loop [12] 85.0% for-loop [13] 13.3% ------------------------------------------------------------------------ run-improve50 [3] 100.0% [7] 18224(64.1%) 0(0.0%) for-loop ...herbie/develop/src/mainloop.rkt:249:10 run-iter! [11] 100.0% ------------------------------------------------------------------------ iterate-egraph!13 [2] 100.0% [8] 346(1.2%) 0(0.0%) map-enodes ...ie/develop/src/core/egraph.rkt:140:0 for-loop [14] 100.0% ------------------------------------------------------------------------ loop [4] 100.0% [9] 336(1.2%) 0(0.0%) pass ...herbie/develop/src/core/simplify.rkt:227:2 for-loop [15] 100.0% ------------------------------------------------------------------------ run-improve50 [3] 100.0% [10] 326(1.1%) 326(1.1%) get-final-combination ...op/src/mainloop.rkt:264:0 ------------------------------------------------------------------------ for-loop [7] 100.0% [11] 18224(64.1%) 0(0.0%) run-iter! ...herbie/develop/src/mainloop.rkt:215:0 simplify! [16] 96.0% choose-best-alt! [19] 2.2% finalize-iter! [20] 1.8% ------------------------------------------------------------------------ one-iter [6] 100.0% [12] 16540(58.2%) 0(0.0%) for-loop ...ie/develop/src/core/simplify.rkt:166:2 for-loop [17] 85.9% update-leader! [29] 8.0% match-e [18] 6.1% ------------------------------------------------------------------------ for-loop [13] 50.0% one-iter [6] 50.0% [13] 2592(9.1%) 312(1.1%) for-loop ...e/develop/src/core/simplify.rkt:126:12 for-loop [13] 50.0% match-e [18] 44.0% ------------------------------------------------------------------------ map-enodes [8] 100.0% [14] 346(1.2%) 346(1.2%) for-loop ...ie/develop/src/core/simplify.rkt:195:2 ------------------------------------------------------------------------ pass [9] 100.0% [15] 336(1.2%) 0(0.0%) for-loop ...e/develop/src/core/simplify.rkt:230:29 argmin [21] 100.0% ------------------------------------------------------------------------ run-iter! [11] 100.0% [16] 17488(61.5%) 0(0.0%) simplify! ...herbie/develop/src/mainloop.rkt:155:0 for-loop [22] 100.0% ------------------------------------------------------------------------ for-loop [12] 100.0% [17] 14204(50.0%) 364(1.3%) for-loop ...e/develop/src/core/simplify.rkt:148:10 merge-egraph-nodes! [23] 51.2% loop! [37] 20.5% mk-enode! [30] 13.9% substitute-e [25] 11.9% ------------------------------------------------------------------------ for-loop [12] 13.7% for-loop [31] 39.4% for-loop [13] 46.9% [18] 3294(11.6%) 690(2.4%) match-e ...herbie/develop/src/core/ematch.rkt:46:0 for-loop [24] 61.0% for-loop [31] 13.1% ??? [32] 6.7% variable? [27] 3.2% ------------------------------------------------------------------------ run-iter! [11] 100.0% [19] 400(1.4%) 0(0.0%) choose-best-alt! ...develop/src/mainloop.rkt:115:0 ??? [32] 100.0% ------------------------------------------------------------------------ run-iter! [11] 100.0% [20] 336(1.2%) 0(0.0%) finalize-iter! ...e/develop/src/mainloop.rkt:169:0 ??? [32] 100.0% ------------------------------------------------------------------------ for-loop [15] 100.0% [21] 336(1.2%) 0(0.0%) argmin ...re/racket/collects/racket/list.rkt:743:0 for-loop [26] 100.0% ------------------------------------------------------------------------ simplify! [16] 100.0% [22] 17488(61.5%) 0(0.0%) for-loop .../herbie/develop/src/mainloop.rkt:159:6 ??? [28] 100.0% ------------------------------------------------------------------------ for-loop [33] 4.5% merge-egraph-nodes! [23] 9.1% for-loop [17] 86.5% [23] 7270(25.6%) 0(0.0%) merge-egraph-nodes! ...p/src/core/egraph.rkt:153:0 update-leader! [29] 50.3% loop! [37] 14.0% for-loop [33] 13.3% for-loop [34] 13.3% merge-egraph-nodes! [23] 9.1% ------------------------------------------------------------------------ match-e [18] 100.0% [24] 2598(9.1%) 982(3.5%) for-loop ...rbie/develop/src/core/ematch.rkt:59:11 for-loop [31] 74.8% ------------------------------------------------------------------------ substitute-e [25] 12.3% for-loop [17] 87.7% [25] 1694(6.0%) 0(0.0%) substitute-e ...e/develop/src/core/ematch.rkt:71:0 mk-enode! [30] 81.6% substitute-e [25] 12.3% ??? [32] 6.1% ------------------------------------------------------------------------ argmin [21] 100.0% [26] 336(1.2%) 0(0.0%) for-loop .../herbie/develop/src/programs.rkt:210:2 ??? [60] 100.0% ------------------------------------------------------------------------ match-e [18] 100.0% [27] 312(1.1%) 0(0.0%) variable? ...e/develop/src/syntax/syntax.rkt:665:0 ??? [32] 100.0% ------------------------------------------------------------------------ for-loop [22] 20.5% run [5] 36.2% [28] 28414(100.0%) 0(0.0%) ??? ...lects/racket/private/more-scheme.rkt:261:28 profile-thunk16 [1] 33.9% ??? [60] 29.8% run-improve50 [3] 23.0% loop [35] 13.3% ------------------------------------------------------------------------ for-loop [12] 23.4% merge-egraph-nodes! [23] 76.6% [29] 5638(19.8%) 0(0.0%) update-leader! ...evelop/src/core/egraph.rkt:218:0 for-loop [36] 100.0% ------------------------------------------------------------------------ substitute-e [25] 41.3% for-loop [17] 58.7% [30] 3350(11.8%) 668(2.4%) mk-enode! ...bie/develop/src/core/egraph.rkt:102:0 new-enode [38] 69.7% hash-has-key? [39] 10.4% ------------------------------------------------------------------------ match-e [18] 18.6% for-loop [24] 81.4% [31] 2600(9.2%) 324(1.1%) for-loop ...rbie/develop/src/core/ematch.rkt:65:37 match-e [18] 81.2% ??? [42] 12.6% ------------------------------------------------------------------------ variable? [27] 15.5% substitute-e [25] 15.5% finalize-iter! [20] 16.7% choose-best-alt! [19] 19.8% match-e [18] 32.6% [32] 2018(7.1%) 970(3.4%) ??? ...contract/private/arrow-val-first.rkt:357:18 ??? [40] 19.8% for-loop [41] 16.7% hash-has-key? [39] 15.5% ------------------------------------------------------------------------ merge-egraph-nodes! [23] 100.0% [33] 1294(4.6%) 0(0.0%) for-loop ...bie/develop/src/core/egraph.rkt:201:10 merge-egraph-nodes! [23] 50.1% loop! [37] 49.9% ------------------------------------------------------------------------ merge-egraph-nodes! [23] 100.0% [34] 968(3.4%) 670(2.4%) for-loop ...rbie/develop/src/core/egraph.rkt:233:6 update-en-expr [79] 30.8% ------------------------------------------------------------------------ ??? [28] 100.0% [35] 7212(25.4%) 0(0.0%) loop ...htlies/herbie/develop/src/points.rkt:205:2 loop [53] 44.4% make-exacts* [54] 32.1% loop [46] 19.0% filter-exacts [51] 4.5% ------------------------------------------------------------------------ update-leader! [29] 100.0% [36] 5638(19.8%) 0(0.0%) for-loop ...rbie/develop/src/core/egraph.rkt:223:6 for-loop [43] 100.0% ------------------------------------------------------------------------ for-loop [33] 6.6% loop [61] 23.2% merge-egraph-nodes! [23] 24.2% for-loop [17] 46.1% [37] 4894(17.2%) 644(2.3%) loop! ...s/herbie/develop/src/core/enode.rkt:192:2 custom-set-union [44] 56.3% loop [61] 30.4% set [47] 6.7% ------------------------------------------------------------------------ mk-enode! [30] 100.0% [38] 2334(8.2%) 0(0.0%) new-enode ...erbie/develop/src/core/enode.rkt:97:0 type-of-enode-expr [45] 100.0% ------------------------------------------------------------------------ ??? [32] 47.3% mk-enode! [30] 52.7% [39] 660(2.3%) 660(2.3%) hash-has-key? ...et/private/more-scheme.rkt:368:13 ------------------------------------------------------------------------ ??? [32] 100.0% [40] 400(1.4%) 0(0.0%) ??? .../herbie/develop/src/core/alt-table.rkt:54:0 ??? [48] 100.0% ------------------------------------------------------------------------ ??? [32] 100.0% [41] 336(1.2%) 0(0.0%) for-loop ...ie/develop/src/core/alt-table.rkt:51:2 atab-add-altn [49] 100.0% ------------------------------------------------------------------------ for-loop [31] 100.0% [42] 328(1.2%) 0(0.0%) ??? ...ies/herbie/develop/src/core/ematch.rkt:50:5 for-loop [50] 100.0% ------------------------------------------------------------------------ for-loop [36] 100.0% [43] 5638(19.8%) 0(0.0%) for-loop ...rbie/develop/src/core/egraph.rkt:224:8 hash-update! [52] 100.0% ------------------------------------------------------------------------ loop! [37] 100.0% [44] 3240(11.4%) 610(2.1%) custom-set-union ...et/private/set-types.rkt:168:0 for-loop [55] 81.2% ------------------------------------------------------------------------ new-enode [38] 100.0% [45] 2334(8.2%) 348(1.2%) type-of-enode-expr ...elop/src/core/enode.rkt:68:0 get-sigs [56] 85.1% ------------------------------------------------------------------------ loop [35] 100.0% [46] 1372(4.8%) 0(0.0%) loop ...htlies/herbie/develop/src/points.rkt:158:2 make-exacts* [54] 74.1% loop [53] 25.9% ------------------------------------------------------------------------ loop! [37] 100.0% [47] 654(2.3%) 654(2.3%) set ...collects/racket/private/set-types.rkt:981:0 ------------------------------------------------------------------------ ??? [40] 100.0% [48] 400(1.4%) 0(0.0%) ??? ...tract/private/arrow-higher-order.rkt:342:33 best-alt [57] 100.0% ------------------------------------------------------------------------ for-loop [41] 100.0% [49] 336(1.2%) 0(0.0%) atab-add-altn ...elop/src/core/alt-table.rkt:208:0 best-and-tied-at-points [58] 100.0% ------------------------------------------------------------------------ ??? [42] 100.0% [50] 328(1.2%) 328(1.2%) for-loop ...erbie/develop/src/core/ematch.rkt:51:7 ------------------------------------------------------------------------ loop [35] 100.0% [51] 324(1.1%) 0(0.0%) filter-exacts ...rbie/develop/src/points.rkt:178:0 for-loop [59] 100.0% ------------------------------------------------------------------------ for-loop [43] 100.0% [52] 5638(19.8%) 0(0.0%) hash-update! ...ket/private/more-scheme.rkt:362:13 ??? [62] 100.0% ------------------------------------------------------------------------ loop [46] 10.0% loop [35] 90.0% [53] 3558(12.5%) 0(0.0%) loop ...htlies/herbie/develop/src/points.rkt:141:4 loop [61] 100.0% ------------------------------------------------------------------------ loop [46] 30.5% loop [35] 69.5% [54] 3330(11.7%) 0(0.0%) make-exacts* ...erbie/develop/src/points.rkt:138:0 loop [61] 100.0% ------------------------------------------------------------------------ custom-set-union [44] 100.0% [55] 2630(9.3%) 962(3.4%) for-loop ...cts/racket/private/set-types.rkt:174:3 for-loop [63] 63.4% ------------------------------------------------------------------------ type-of-enode-expr [45] 100.0% [56] 1986(7.0%) 0(0.0%) get-sigs .../herbie/develop/src/type-check.rkt:5:0 ??? [60] 49.6% ...velop/src/common.rkt:47:2 [64] 32.0% ??? [66] 18.3% ------------------------------------------------------------------------ ??? [48] 100.0% [57] 400(1.4%) 0(0.0%) best-alt ...tlies/herbie/develop/src/glue.rkt:71:0 argmins [65] 100.0% ------------------------------------------------------------------------ atab-add-altn [49] 100.0% [58] 336(1.2%) 0(0.0%) best-and-tied-at-points ...ore/alt-table.rkt:122:0 for-loop [67] 100.0% ------------------------------------------------------------------------ filter-exacts [51] 100.0% [59] 324(1.1%) 324(1.1%) for-loop ...es/herbie/develop/src/points.rkt:181:4 ------------------------------------------------------------------------ for-loop [26] 0.6% get-sigs [56] 1.6% for-loop [68] 48.9% ??? [28] 48.9% [60] 20140(70.9%) 346(1.2%) ??? ...llects/racket/private/norm-define.rkt:53:83 for-loop [68] 48.9% iterate-egraph!13 [2] 48.3% ??? [71] 1.6% loop [4] 0.6% ------------------------------------------------------------------------ make-exacts* [54] 0.2% loop [53] 0.2% loop! [37] 3.2% loop [61] 96.4% [61] 9510(33.5%) 356(1.3%) loop ...cket/collects/racket/private/map.rkt:25:19 loop [61] 96.4% loop! [37] 2.3% ??? [69] 0.4% ------------------------------------------------------------------------ hash-update! [52] 100.0% [62] 5638(19.8%) 0(0.0%) ??? ...s/herbie/develop/src/core/egraph.rkt:226:24 for-loop [70] 100.0% ------------------------------------------------------------------------ for-loop [55] 100.0% [63] 1668(5.9%) 1668(5.9%) for-loop ...cts/racket/private/set-types.rkt:178:5 ------------------------------------------------------------------------ get-sigs [56] 100.0% [64] 636(2.2%) 0(0.0%) ...velop/src/common.rkt:47:2 ...e/arr-i.rkt:906:19 ??? [75] 52.5% ??? [76] 47.5% ------------------------------------------------------------------------ best-alt [57] 100.0% [65] 400(1.4%) 0(0.0%) argmins ...ies/herbie/develop/src/common.rkt:152:0 composed [72] 100.0% ------------------------------------------------------------------------ get-sigs [56] 100.0% [66] 364(1.3%) 0(0.0%) ??? ...ts/racket/contract/private/arr-i.rkt:804:10 ??? [73] 100.0% ------------------------------------------------------------------------ best-and-tied-at-points [58] 100.0% [67] 336(1.2%) 0(0.0%) for-loop .../develop/src/core/alt-table.rkt:124:16 ??? [74] 100.0% ------------------------------------------------------------------------ ??? [60] 100.0% [68] 20140(70.9%) 0(0.0%) for-loop ...ie/develop/src/core/simplify.rkt:66:12 ??? [60] 100.0% ------------------------------------------------------------------------ loop [61] 100.0% [69] 6888(24.2%) 0(0.0%) ??? ...tlies/herbie/develop/src/programs.rkt:156:4 ??? [77] 70.1% ??? [78] 25.4% ??? [82] 4.6% ------------------------------------------------------------------------ ??? [62] 100.0% [70] 5638(19.8%) 4290(15.1%) for-loop ...bie/develop/src/core/egraph.rkt:227:26 update-en-expr [79] 23.9% ------------------------------------------------------------------------ ??? [60] 100.0% [71] 976(3.4%) 332(1.2%) ??? ...ects/racket/contract/private/list.rkt:737:4 for-loop [80] 66.0% ------------------------------------------------------------------------ argmins [65] 100.0% [72] 400(1.4%) 0(0.0%) composed ...ollects/racket/private/list.rkt:321:16 errors [81] 100.0% ------------------------------------------------------------------------ ??? [66] 100.0% [73] 364(1.3%) 364(1.3%) ??? ...ects/racket/contract/private/hash.rkt:217:4 ------------------------------------------------------------------------ for-loop [67] 100.0% [74] 336(1.2%) 336(1.2%) ??? ...ket/collects/racket/private/for.rkt:1151:14 ------------------------------------------------------------------------ ...velop/src/common.rkt:47:2 [64]100.0% [75] 334(1.2%) 334(1.2%) ??? ...s/racket/contract/private/arr-i.rkt:1268:39 ------------------------------------------------------------------------ ...velop/src/common.rkt:47:2 [64]100.0% [76] 302(1.1%) 0(0.0%) ??? ...ects/racket/contract/private/list.rkt:342:4 ??? [91] 100.0% ------------------------------------------------------------------------ ??? [69] 100.0% [77] 4826(17.0%) 2100(7.4%) ??? ...acket/collects/racket/private/kw.rkt:444:14 ??? [84] 21.3% ??? [85] 20.8% ...higher-order.rkt:346:33 [86] 14.4% ------------------------------------------------------------------------ ??? [69] 100.0% [78] 1748(6.2%) 332(1.2%) ??? ...contract/private/../../private/kw.rkt:761:9 real->bigfloat [83] 81.0% ------------------------------------------------------------------------ for-loop [34] 18.1% for-loop [70] 81.9% [79] 1646(5.8%) 1336(4.7%) update-en-expr ...evelop/src/core/egraph.rkt:212:0 for-loop [89] 18.8% ------------------------------------------------------------------------ ??? [71] 100.0% [80] 644(2.3%) 0(0.0%) for-loop ...acket/contract/private/list.rkt:743:12 ??? [87] 100.0% ------------------------------------------------------------------------ composed [72] 100.0% [81] 400(1.4%) 0(0.0%) errors ...lies/herbie/develop/src/points.rkt:241:0 for-loop [88] 100.0% ------------------------------------------------------------------------ ??? [69] 100.0% [82] 314(1.1%) 314(1.1%) ??? ...tract/private/arrow-higher-order.rkt:145:21 ------------------------------------------------------------------------ ??? [78] 100.0% [83] 1416(5.0%) 1096(3.9%) real->bigfloat .../private/bigfloat/mpfr.rkt:451:0 ??? [93] 22.6% ------------------------------------------------------------------------ ??? [77] 100.0% [84] 1030(3.6%) 1030(3.6%) ??? ...rivate/unconstrained-domain-arrow.rkt:40:13 ------------------------------------------------------------------------ ??? [77] 100.0% [85] 1002(3.5%) 0(0.0%) ??? ...-racket/utils/simple-result-arrow.rkt:39:12 bfsub [90] 100.0% ------------------------------------------------------------------------ ??? [77] 100.0% [86] 694(2.4%) 344(1.2%) ...higher-order.rkt:346:33 (unknown source) ??? [91] 50.4% ------------------------------------------------------------------------ for-loop [80] 100.0% [87] 644(2.3%) 644(2.3%) ??? ...private/unconstrained-domain-arrow.rkt:74:4 ------------------------------------------------------------------------ errors [81] 100.0% [88] 400(1.4%) 0(0.0%) for-loop ...es/herbie/develop/src/points.rkt:244:4 ulp-difference [92] 100.0% ------------------------------------------------------------------------ update-en-expr [79] 100.0% [89] 310(1.1%) 310(1.1%) for-loop ...rbie/develop/src/core/egraph.rkt:214:6 ------------------------------------------------------------------------ ??? [85] 100.0% [90] 1002(3.5%) 374(1.3%) bfsub ...-lib/math/private/bigfloat/mpfr.rkt:819:4 ??? [93] 62.7% ------------------------------------------------------------------------ ??? [76] 46.3% ...higher-order.rkt:346:33 [86] 53.7% [91] 652(2.3%) 652(2.3%) ??? ...cts/racket/contract/private/list.rkt:187:10 ------------------------------------------------------------------------ for-loop [88] 100.0% [92] 400(1.4%) 0(0.0%) ulp-difference ...erbie/develop/src/float.rkt:19:0 return/no-unsupplied [94] 100.0% ------------------------------------------------------------------------ real->bigfloat [83] 33.8% bfsub [90] 66.2% [93] 948(3.3%) 948(3.3%) ??? .../share/racket/collects/ffi/unsafe.rkt:861:4 ------------------------------------------------------------------------ ulp-difference [92] 100.0% [94] 400(1.4%) 400(1.4%) return/no-unsupplied ...ct/private/arr-i.rkt:533:0 ------------------------------------------------------------------------