Profiling results ----------------- Total cpu time observed: 85512ms (out of 85924ms) Number of samples taken: 265 (once every 323ms) (Hiding functions with self<1.0% and local<2.0%: 1 of 105 hidden) ================================================================================= Caller Idx Total Self Name+src Local% ms(pct) ms(pct) Callee ================================================================================= ??? [5] 100.0% [1] 85512(100.0%) 0(0.0%) profile-thunk16 ...e/pkgs/profile-lib/main.rkt:9:0 run [3] 100.0% --------------------------------------------------------------------------------- ??? [5] 100.0% [2] 324(0.4%) 0(0.0%) errors ...s/herbie/use-places/src/points.rkt:201:0 for-loop [4] 100.0% --------------------------------------------------------------------------------- profile-thunk16 [1] 100.0% [3] 85512(100.0%) 0(0.0%) run ...et-7.2/share/pkgs/profile-lib/main.rkt:39:2 ??? [5] 100.0% --------------------------------------------------------------------------------- errors [2] 100.0% [4] 324(0.4%) 0(0.0%) for-loop ...herbie/use-places/src/points.rkt:203:2 ??? [5] 100.0% --------------------------------------------------------------------------------- for-loop [4] 0.1% run [3] 49.9% [5] 85512(100.0%) 0(0.0%) ??? ...lects/racket/private/more-scheme.rkt:261:28 profile-thunk16 [1] 49.9% run-improve47 [6] 45.7% prepare-points-intervals [9] 4.0% eval-errors [7] 0.2% errors [2] 0.1% ??? [41] 0.1% --------------------------------------------------------------------------------- ??? [5] 100.0% [6] 78084(91.3%) 0(0.0%) run-improve47 ...use-places/src/mainloop.rkt:346:0 simplify! [8] 99.2% prepare-points-intervals [9] 0.5% for-loop [10] 0.4% --------------------------------------------------------------------------------- ??? [5] 100.0% [7] 268(0.3%) 0(0.0%) eval-errors ...bie/use-places/src/points.rkt:179:0 for-loop [11] 100.0% --------------------------------------------------------------------------------- run-improve47 [6] 100.0% [8] 77428(90.5%) 0(0.0%) simplify! ...bie/use-places/src/mainloop.rkt:224:0 ??? [12] 100.0% --------------------------------------------------------------------------------- run-improve47 [6] 4.9% ??? [5] 95.1% [9] 7192(8.4%) 0(0.0%) prepare-points-intervals ...s/src/points.rkt:110:0 loop [13] 95.1% eval-prog [14] 4.9% --------------------------------------------------------------------------------- run-improve47 [6] 100.0% [10] 300(0.4%) 0(0.0%) for-loop ...rbie/use-places/src/mainloop.rkt:365:4 run-iter! [15] 100.0% --------------------------------------------------------------------------------- eval-errors [7] 100.0% [11] 268(0.3%) 268(0.3%) for-loop ...herbie/use-places/src/points.rkt:181:2 --------------------------------------------------------------------------------- simplify! [8] 100.0% [12] 77428(90.5%) 0(0.0%) ??? ...erbie/use-places/src/core/simplify.rkt:31:0 for-loop [16] 99.6% loop [23] 0.4% --------------------------------------------------------------------------------- prepare-points-intervals [9] 100.0% [13] 6836(8.0%) 662(0.8%) loop ...ies/herbie/use-places/src/points.rkt:123:4 ??? [17] 50.2% loop [18] 40.1% --------------------------------------------------------------------------------- prepare-points-intervals [9] 100.0% [14] 356(0.4%) 0(0.0%) eval-prog ...rbie/use-places/src/programs.rkt:83:0 loop [19] 100.0% --------------------------------------------------------------------------------- for-loop [10] 100.0% [15] 300(0.4%) 0(0.0%) run-iter! ...bie/use-places/src/mainloop.rkt:327:0 localize! [20] 100.0% --------------------------------------------------------------------------------- ??? [12] 100.0% [16] 77120(90.2%) 0(0.0%) for-loop .../use-places/src/core/simplify.rkt:51:2 ??? [21] 98.7% loop [23] 0.5% precompute-phase [26] 0.4% for-loop [27] 0.4% --------------------------------------------------------------------------------- loop [13] 100.0% [17] 3432(4.0%) 0(0.0%) ??? ...lies/herbie/use-places/src/points.rkt:106:2 ??? [41] 100.0% --------------------------------------------------------------------------------- loop [13] 100.0% [18] 2742(3.2%) 0(0.0%) loop ...lies/herbie/use-places/src/points.rkt:81:2 ??? [22] 89.1% hash-update! [98] 10.9% --------------------------------------------------------------------------------- loop [19] 33.3% expand-capturing-lifts [24] 33.3% eval-prog [14] 33.3% [19] 356(0.4%) 0(0.0%) loop (unknown source) expand-capturing-lifts [24] 33.3% loop [19] 33.3% for-loop [25] 33.3% --------------------------------------------------------------------------------- run-iter! [15] 100.0% [20] 300(0.4%) 0(0.0%) localize! ...bie/use-places/src/mainloop.rkt:127:0 localize-error [28] 100.0% --------------------------------------------------------------------------------- for-loop [16] 100.0% [21] 76138(89.0%) 0(0.0%) ??? ...erbie/use-places/src/core/simplify.rkt:92:0 for-loop [29] 92.2% find-matches [30] 7.8% --------------------------------------------------------------------------------- loop [18] 100.0% [22] 2442(2.9%) 0(0.0%) ??? ...es/herbie/use-places/src/programs.rkt:115:2 ??? [31] 81.4% ??? [41] 18.6% --------------------------------------------------------------------------------- ??? [12] 46.4% for-loop [16] 53.6% [23] 664(0.8%) 0(0.0%) loop ...ie/use-places/src/core/extraction.rkt:25:2 debug5 [32] 53.6% for-loop [36] 46.4% --------------------------------------------------------------------------------- loop [19] 100.0% [24] 356(0.4%) 0(0.0%) expand-capturing-lifts (unknown source) loop [19] 100.0% --------------------------------------------------------------------------------- run-module-instance!125 [34] 50.0% loop [19] 50.0% [25] 356(0.4%) 0(0.0%) for-loop (unknown source) run-module-instance!125 [34] 50.0% temp37_0 [33] 50.0% --------------------------------------------------------------------------------- for-loop [16] 100.0% [26] 326(0.4%) 0(0.0%) precompute-phase ...es/src/core/simplify.rkt:101:0 for-loop [35] 100.0% --------------------------------------------------------------------------------- for-loop [16] 100.0% [27] 300(0.4%) 0(0.0%) for-loop .../use-places/src/core/simplify.rkt:59:4 prune-phase [37] 100.0% --------------------------------------------------------------------------------- localize! [20] 100.0% [28] 300(0.4%) 0(0.0%) localize-error ...laces/src/core/localize.rkt:66:0 hash-ref! [38] 100.0% --------------------------------------------------------------------------------- ??? [21] 100.0% [29] 70170(82.1%) 0(0.0%) for-loop .../use-places/src/core/simplify.rkt:93:2 for-loop [39] 100.0% --------------------------------------------------------------------------------- ??? [21] 100.0% [30] 5968(7.0%) 0(0.0%) find-matches ...-places/src/core/simplify.rkt:84:0 for-loop [40] 100.0% --------------------------------------------------------------------------------- ??? [22] 100.0% [31] 1988(2.3%) 0(0.0%) ??? ...t-7.2/collects/racket/private/kw.rkt:594:14 ??? [41] 83.4% ??? [44] 16.6% --------------------------------------------------------------------------------- loop [23] 100.0% [32] 356(0.4%) 0(0.0%) debug5 ...es/herbie/use-places/src/debug.rkt:102:0 return/no-unsupplied [42] 100.0% --------------------------------------------------------------------------------- for-loop [25] 100.0% [33] 356(0.4%) 0(0.0%) temp37_0 (unknown source) [running body] [43] 100.0% --------------------------------------------------------------------------------- for-loop [25] 100.0% [34] 356(0.4%) 0(0.0%) run-module-instance!125 (unknown source) for-loop [25] 100.0% --------------------------------------------------------------------------------- precompute-phase [26] 100.0% [35] 326(0.4%) 0(0.0%) for-loop ...use-places/src/core/simplify.rkt:102:2 set-precompute! [45] 100.0% --------------------------------------------------------------------------------- loop [23] 100.0% [36] 308(0.4%) 0(0.0%) for-loop ...se-places/src/core/extraction.rkt:29:4 for-loop [46] 100.0% --------------------------------------------------------------------------------- for-loop [27] 100.0% [37] 300(0.4%) 0(0.0%) prune-phase ...-places/src/core/simplify.rkt:106:0 for-loop [47] 100.0% --------------------------------------------------------------------------------- map [59] 50.0% localize-error [28] 50.0% [38] 300(0.4%) 0(0.0%) hash-ref! .../racket/private/more-scheme.rkt:376:2 parse-loop30 [48] 100.0% --------------------------------------------------------------------------------- for-loop [29] 100.0% [39] 70170(82.1%) 310(0.4%) for-loop .../use-places/src/core/simplify.rkt:96:4 merge-egraph-nodes! [60] 80.9% dedup-children! [85] 13.9% pattern-substitute [51] 3.4% mk-enode-rec! [53] 1.4% --------------------------------------------------------------------------------- for-loop [40] 50.0% find-matches [30] 50.0% [40] 5968(7.0%) 0(0.0%) for-loop .../use-places/src/core/simplify.rkt:86:8 for-loop [40] 50.0% match-e [49] 50.0% --------------------------------------------------------------------------------- ??? [5] 5.5% ??? [22] 7.7% ??? [31] 28.3% ??? [17] 58.5% [41] 5868(6.9%) 1292(1.5%) ??? ...tract/private/arrow-higher-order.rkt:360:33 sample-multi-bounded [50] 47.5% ival-mult [52] 22.7% mk-ival [54] 7.7% --------------------------------------------------------------------------------- debug5 [32] 100.0% [42] 356(0.4%) 356(0.4%) return/no-unsupplied ...ct/private/arr-i.rkt:542:0 --------------------------------------------------------------------------------- temp37_0 [33] 100.0% [43] 356(0.4%) 0(0.0%) [running body] ...h/private/bigfloat/mpfr.rkt":##f loop [55] 100.0% --------------------------------------------------------------------------------- ??? [31] 100.0% [44] 330(0.4%) 0(0.0%) ??? ...tract/private/arrow-higher-order.rkt:364:33 ival-sub [56] 100.0% --------------------------------------------------------------------------------- for-loop [35] 100.0% [45] 326(0.4%) 0(0.0%) set-precompute! ...ces/src/core/simplify.rkt:110:0 for-loop [57] 100.0% --------------------------------------------------------------------------------- for-loop [36] 100.0% [46] 308(0.4%) 0(0.0%) for-loop ...e-places/src/core/extraction.rkt:37:16 for-loop [58] 100.0% --------------------------------------------------------------------------------- prune-phase [37] 100.0% [47] 300(0.4%) 0(0.0%) for-loop ...use-places/src/core/simplify.rkt:107:2 update-leader! [71] 100.0% --------------------------------------------------------------------------------- hash-ref! [38] 100.0% [48] 300(0.4%) 0(0.0%) parse-loop30 ...s/racket/match/compiler.rkt:418:15 map [59] 100.0% --------------------------------------------------------------------------------- for-loop [74] 33.5% for-loop [40] 66.5% [49] 5968(7.0%) 0(0.0%) match-e ...bie/use-places/src/core/ematch.rkt:39:0 for-loop [61] 88.6% constant? [64] 7.8% variable? [67] 1.8% ??? [77] 1.8% --------------------------------------------------------------------------------- ??? [41] 100.0% [50] 2790(3.3%) 300(0.4%) sample-multi-bounded ...places/src/points.rkt:15:0 random-ranges [62] 67.9% for-loop [65] 21.4% --------------------------------------------------------------------------------- for-loop [39] 100.0% [51] 2388(2.8%) 2388(2.8%) pattern-substitute ...es/src/core/matcher.rkt:46:0 --------------------------------------------------------------------------------- ??? [41] 100.0% [52] 1332(1.6%) 300(0.4%) ival-mult .../use-places/src/biginterval.rkt:119:0 bfmul [63] 77.5% --------------------------------------------------------------------------------- for-loop [39] 100.0% [53] 950(1.1%) 332(0.4%) mk-enode-rec! ...-places/src/core/egraph.rkt:117:0 new-enode [68] 33.7% for-loop [70] 31.4% --------------------------------------------------------------------------------- ??? [41] 100.0% [54] 454(0.5%) 0(0.0%) mk-ival ...bie/use-places/src/biginterval.rkt:65:0 bf [66] 100.0% --------------------------------------------------------------------------------- [running body] [43] 2.9% loop [55] 97.1% [55] 356(0.4%) 356(0.4%) loop ...7.2/collects/racket/private/list.rkt:82:16 loop [55] 97.1% --------------------------------------------------------------------------------- ??? [44] 100.0% [56] 330(0.4%) 0(0.0%) ival-sub ...e/use-places/src/biginterval.rkt:107:0 bfmul [63] 100.0% --------------------------------------------------------------------------------- set-precompute! [45] 100.0% [57] 326(0.4%) 0(0.0%) for-loop ...use-places/src/core/simplify.rkt:112:2 merge-egraph-nodes! [60] 100.0% --------------------------------------------------------------------------------- for-loop [46] 100.0% [58] 308(0.4%) 308(0.4%) for-loop ...e-places/src/core/extraction.rkt:41:23 --------------------------------------------------------------------------------- parse-loop30 [48] 100.0% [59] 300(0.4%) 0(0.0%) map ...t-7.2/collects/racket/private/map.rkt:35:13 hash-ref! [38] 50.0% loop [69] 50.0% --------------------------------------------------------------------------------- for-loop [57] 0.3% merge-egraph-nodes! [60] 7.7% for-loop [73] 10.1% for-loop [39] 81.9% [60] 57078(66.7%) 0(0.0%) merge-egraph-nodes! ...s/src/core/egraph.rkt:145:0 update-leader! [71] 47.4% loop! [72] 29.2% for-loop [73] 12.5% merge-egraph-nodes! [60] 7.7% dedup-children! [85] 2.1% enode-merge! [83] 0.5% --------------------------------------------------------------------------------- match-e [49] 100.0% [61] 5670(6.6%) 4052(4.7%) for-loop ...e/use-places/src/core/ematch.rkt:52:11 for-loop [74] 41.9% procedure-reduce-keyword-arity-mask [79] 3.1% step [82] 2.6% --------------------------------------------------------------------------------- sample-multi-bounded [50] 100.0% [62] 1894(2.2%) 636(0.7%) random-ranges ...e/use-places/src/common.rkt:171:0 cons/c [76] 50.6% build--> [81] 15.8% --------------------------------------------------------------------------------- ival-sub [56] 24.2% ival-mult [52] 75.8% [63] 1362(1.6%) 0(0.0%) bfmul ...-lib/math/private/bigfloat/mpfr.rkt:821:4 ??? [75] 100.0% --------------------------------------------------------------------------------- match-e [49] 100.0% [64] 632(0.7%) 0(0.0%) constant? ...se-places/src/syntax/syntax.rkt:726:0 value? [78] 100.0% --------------------------------------------------------------------------------- sample-multi-bounded [50] 100.0% [65] 596(0.7%) 596(0.7%) for-loop .../herbie/use-places/src/points.rkt:23:4 --------------------------------------------------------------------------------- mk-ival [54] 100.0% [66] 454(0.5%) 0(0.0%) bf ...ath-lib/math/private/bigfloat/mpfr.rkt:601:2 ??? [75] 100.0% --------------------------------------------------------------------------------- match-e [49] 100.0% [67] 322(0.4%) 0(0.0%) variable? ...se-places/src/syntax/syntax.rkt:729:0 ??? [77] 100.0% --------------------------------------------------------------------------------- mk-enode-rec! [53] 100.0% [68] 320(0.4%) 0(0.0%) new-enode ...e/use-places/src/core/enode.rkt:101:0 type-of-enode-expr [80] 100.0% --------------------------------------------------------------------------------- map [59] 4.5% loop [69] 95.5% [69] 300(0.4%) 300(0.4%) loop ...-7.2/collects/racket/private/map.rkt:54:19 loop [69] 95.5% --------------------------------------------------------------------------------- mk-enode-rec! [53] 100.0% [70] 298(0.3%) 298(0.3%) for-loop .../use-places/src/core/egraph.rkt:109:10 --------------------------------------------------------------------------------- for-loop [47] 0.9% merge-egraph-nodes! [60] 99.1% [71] 32968(38.6%) 0(0.0%) update-leader! ...places/src/core/egraph.rkt:213:0 for-loop [84] 100.0% --------------------------------------------------------------------------------- loop [87] 20.4% merge-egraph-nodes! [60] 79.6% [72] 20360(23.8%) 2594(3.0%) loop! ...erbie/use-places/src/core/enode.rkt:194:2 custom-set-union [86] 58.8% loop [87] 22.0% set [88] 9.1% update-en-expr [104] 3.2% --------------------------------------------------------------------------------- merge-egraph-nodes! [60] 100.0% [73] 12798(15.0%) 0(0.0%) for-loop ...e/use-places/src/core/egraph.rkt:199:4 merge-egraph-nodes! [60] 88.0% dedup-children! [85] 12.0% --------------------------------------------------------------------------------- for-loop [61] 100.0% [74] 3784(4.4%) 0(0.0%) for-loop ...e/use-places/src/core/ematch.rkt:58:37 match-e [49] 100.0% --------------------------------------------------------------------------------- bf [66] 25.0% bfmul [63] 75.0% [75] 1816(2.1%) 1816(2.1%) ??? /opt/racket-7.2/collects/ffi/unsafe.rkt:905:4 --------------------------------------------------------------------------------- random-ranges [62] 100.0% [76] 958(1.1%) 0(0.0%) cons/c .../racket/contract/private/guts.rkt:504:15 coerce-contract [89] 100.0% --------------------------------------------------------------------------------- match-e [49] 49.5% variable? [67] 50.5% [77] 638(0.7%) 322(0.4%) ??? ...contract/private/arrow-val-first.rkt:390:18 ??? [90] 49.5% --------------------------------------------------------------------------------- constant? [64] 100.0% [78] 632(0.7%) 632(0.7%) value? ...bie/use-places/src/syntax/types.rkt:18:0 --------------------------------------------------------------------------------- for-loop [61] 100.0% [79] 348(0.4%) 348(0.4%) procedure-reduce-keyword-arity-mask ....rkt:1562:4 --------------------------------------------------------------------------------- new-enode [68] 100.0% [80] 320(0.4%) 320(0.4%) type-of-enode-expr ...aces/src/core/enode.rkt:66:0 --------------------------------------------------------------------------------- random-ranges [62] 100.0% [81] 300(0.4%) 300(0.4%) build--> ...act/private/arrow-val-first.rkt:1088:0 --------------------------------------------------------------------------------- for-loop [61] 100.0% [82] 298(0.3%) 298(0.3%) step ...ket-7.2/collects/racket/function.rkt:145:9 --------------------------------------------------------------------------------- merge-egraph-nodes! [60] 100.0% [83] 296(0.3%) 0(0.0%) enode-merge! ...se-places/src/core/enode.rkt:131:0 adopt-enode! [91] 100.0% --------------------------------------------------------------------------------- update-leader! [71] 100.0% [84] 32968(38.6%) 322(0.4%) for-loop ...e/use-places/src/core/egraph.rkt:218:6 hash-update! [98] 62.6% for-loop [93] 36.4% --------------------------------------------------------------------------------- merge-egraph-nodes! [60] 11.9% for-loop [73] 14.0% for-loop [39] 74.0% [85] 13200(15.4%) 0(0.0%) dedup-children! ...places/src/core/enode.rkt:202:0 loop [92] 97.7% loop [97] 2.3% --------------------------------------------------------------------------------- loop! [72] 100.0% [86] 12442(14.6%) 7032(8.2%) custom-set-union ...et/private/set-types.rkt:168:0 for-loop [94] 40.8% for-loop [96] 2.7% --------------------------------------------------------------------------------- loop! [72] 7.8% loop [87] 92.2% [87] 8520(10.0%) 334(0.4%) loop ...-7.2/collects/racket/private/map.rkt:40:19 loop [87] 92.2% loop! [72] 7.8% --------------------------------------------------------------------------------- loop! [72] 100.0% [88] 3702(4.3%) 3702(4.3%) set ...collects/racket/private/set-types.rkt:981:0 --------------------------------------------------------------------------------- cons/c [76] 100.0% [89] 958(1.1%) 0(0.0%) coerce-contract ...contract/private/guts.rkt:308:0 coerce-contract/f [95] 100.0% --------------------------------------------------------------------------------- ??? [77] 100.0% [90] 316(0.4%) 316(0.4%) ??? ...ects/racket/contract/private/guts.rkt:772:8 --------------------------------------------------------------------------------- enode-merge! [83] 100.0% [91] 296(0.3%) 296(0.3%) adopt-enode! ...se-places/src/core/enode.rkt:109:0 --------------------------------------------------------------------------------- dedup-children! [85] 5.5% loop [92] 94.5% [92] 12900(15.1%) 12900(15.1%) loop ...racket-7.2/collects/racket/list.rkt:434:17 loop [92] 94.5% --------------------------------------------------------------------------------- for-loop [84] 100.0% [93] 11998(14.0%) 0(0.0%) for-loop ...e/use-places/src/core/egraph.rkt:219:8 hash-update! [98] 100.0% --------------------------------------------------------------------------------- custom-set-union [86] 100.0% [94] 5078(5.9%) 1568(1.8%) for-loop ...cts/racket/private/set-types.rkt:174:3 for-loop [99] 69.1% --------------------------------------------------------------------------------- coerce-contract [89] 100.0% [95] 958(1.1%) 0(0.0%) coerce-contract/f ...ntract/private/guts.rkt:373:0 coerce-simple-value [100] 100.0% --------------------------------------------------------------------------------- custom-set-union [86] 100.0% [96] 332(0.4%) 332(0.4%) for-loop ...cts/racket/private/set-types.rkt:152:2 --------------------------------------------------------------------------------- dedup-children! [85] 14.3% loop [97] 85.7% [97] 300(0.4%) 0(0.0%) loop ...racket-7.2/collects/racket/list.rkt:417:34 loop [97] 85.7% member [101] 14.3% --------------------------------------------------------------------------------- loop [18] 0.9% for-loop [93] 36.4% for-loop [84] 62.7% [98] 32946(38.5%) 300(0.4%) hash-update! ...cket/private/more-scheme.rkt:365:4 ??? [102] 99.1% --------------------------------------------------------------------------------- for-loop [94] 100.0% [99] 3510(4.1%) 3510(4.1%) for-loop ...cts/racket/private/set-types.rkt:178:5 --------------------------------------------------------------------------------- coerce-contract/f [95] 100.0% [100] 958(1.1%) 958(1.1%) coerce-simple-value ...ract/private/guts.rkt:386:0 --------------------------------------------------------------------------------- loop [97] 100.0% [101] 300(0.4%) 300(0.4%) member (unknown source) --------------------------------------------------------------------------------- hash-update! [98] 100.0% [102] 32646(38.2%) 968(1.1%) ??? ...erbie/use-places/src/core/egraph.rkt:221:24 for-loop [103] 96.1% update-en-expr [104] 0.9% --------------------------------------------------------------------------------- ??? [102] 100.0% [103] 31382(36.7%) 28530(33.4%) for-loop .../use-places/src/core/egraph.rkt:222:26 update-en-expr [104] 9.1% --------------------------------------------------------------------------------- ??? [102] 6.7% loop! [72] 29.0% for-loop [103] 64.3% [104] 4436(5.2%) 4436(5.2%) update-en-expr ...places/src/core/egraph.rkt:207:0 ---------------------------------------------------------------------------------