Profiling results ----------------- Total cpu time observed: 66422ms (out of 66924ms) Number of samples taken: 190 (once every 350ms) ================================================================================ Caller Idx Total Self Name+src Local% ms(pct) ms(pct) Callee ================================================================================ ??? [5] 100.0% [1] 66422(100.0%) 0(0.0%) profile-thunk16 ...e/pkgs/profile-lib/main.rkt:9:0 run [3] 100.0% -------------------------------------------------------------------------------- ??? [5] 100.0% [2] 996(1.5%) 0(0.0%) errors ...s/herbie/use-places/src/points.rkt:201:0 for-loop [4] 100.0% -------------------------------------------------------------------------------- profile-thunk16 [1] 100.0% [3] 66422(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] 996(1.5%) 368(0.6%) for-loop ...herbie/use-places/src/points.rkt:203:2 ??? [5] 63.1% -------------------------------------------------------------------------------- for-loop [4] 0.3% run [3] 49.8% [5] 66422(100.0%) 0(0.0%) ??? ...lects/racket/private/more-scheme.rkt:261:28 profile-thunk16 [1] 49.8% run-improve47 [6] 36.4% prepare-points-intervals [9] 12.6% errors [2] 0.6% oracle-error [7] 0.2% ??? [29] 0.2% ??? [18] 0.2% -------------------------------------------------------------------------------- ??? [5] 100.0% [6] 48356(72.8%) 0(0.0%) run-improve47 ...use-places/src/mainloop.rkt:346:0 simplify! [8] 99.1% prepare-points-intervals [9] 0.9% -------------------------------------------------------------------------------- ??? [5] 100.0% [7] 322(0.5%) 0(0.0%) oracle-error ...ie/use-places/src/points.rkt:188:0 for-loop [10] 100.0% -------------------------------------------------------------------------------- run-improve47 [6] 100.0% [8] 47904(72.1%) 0(0.0%) simplify! ...bie/use-places/src/mainloop.rkt:224:0 ??? [11] 100.0% -------------------------------------------------------------------------------- run-improve47 [6] 2.6% ??? [5] 97.4% [9] 17200(25.9%) 0(0.0%) prepare-points-intervals ...s/src/points.rkt:110:0 loop [12] 100.0% -------------------------------------------------------------------------------- oracle-error [7] 100.0% [10] 322(0.5%) 0(0.0%) for-loop ...herbie/use-places/src/points.rkt:189:2 ??? [13] 100.0% -------------------------------------------------------------------------------- simplify! [8] 100.0% [11] 47904(72.1%) 0(0.0%) ??? ...erbie/use-places/src/core/simplify.rkt:31:0 for-loop [14] 99.3% loop [19] 0.7% -------------------------------------------------------------------------------- prepare-points-intervals [9] 100.0% [12] 17200(25.9%) 0(0.0%) loop ...ies/herbie/use-places/src/points.rkt:123:4 loop [15] 85.0% ??? [16] 15.0% -------------------------------------------------------------------------------- for-loop [10] 100.0% [13] 322(0.5%) 322(0.5%) ??? ...7.2/collects/racket/private/for.rkt:1233:14 -------------------------------------------------------------------------------- ??? [11] 100.0% [14] 47550(71.6%) 0(0.0%) for-loop .../use-places/src/core/simplify.rkt:51:2 ??? [17] 98.1% precompute-phase [20] 0.7% for-loop [21] 0.6% loop [19] 0.6% -------------------------------------------------------------------------------- loop [12] 100.0% [15] 14622(22.0%) 290(0.4%) loop ...lies/herbie/use-places/src/points.rkt:81:2 ??? [18] 96.0% ??? [52] 2.0% -------------------------------------------------------------------------------- loop [12] 100.0% [16] 2578(3.9%) 0(0.0%) ??? ...lies/herbie/use-places/src/points.rkt:106:2 ??? [29] 100.0% -------------------------------------------------------------------------------- for-loop [14] 100.0% [17] 46626(70.2%) 0(0.0%) ??? ...erbie/use-places/src/core/simplify.rkt:92:0 for-loop [22] 78.2% find-matches [23] 21.8% -------------------------------------------------------------------------------- ??? [5] 2.1% loop [15] 97.9% [18] 14342(21.6%) 0(0.0%) ??? ...es/herbie/use-places/src/programs.rkt:115:2 ??? [24] 67.5% ??? [29] 32.5% -------------------------------------------------------------------------------- for-loop [14] 45.7% ??? [11] 54.3% [19] 652(1.0%) 0(0.0%) loop ...ie/use-places/src/core/extraction.rkt:25:2 for-loop [25] 100.0% -------------------------------------------------------------------------------- for-loop [14] 100.0% [20] 326(0.5%) 0(0.0%) precompute-phase ...es/src/core/simplify.rkt:101:0 for-loop [26] 100.0% -------------------------------------------------------------------------------- for-loop [14] 100.0% [21] 300(0.5%) 0(0.0%) for-loop .../use-places/src/core/simplify.rkt:59:4 prune-phase [27] 100.0% -------------------------------------------------------------------------------- ??? [17] 100.0% [22] 36470(54.9%) 0(0.0%) for-loop .../use-places/src/core/simplify.rkt:93:2 for-loop [28] 100.0% -------------------------------------------------------------------------------- ??? [17] 100.0% [23] 10156(15.3%) 0(0.0%) find-matches ...-places/src/core/simplify.rkt:84:0 for-loop [30] 100.0% -------------------------------------------------------------------------------- ??? [18] 100.0% [24] 9674(14.6%) 410(0.6%) ??? ...t-7.2/collects/racket/private/kw.rkt:594:14 ??? [31] 59.2% ??? [29] 36.5% -------------------------------------------------------------------------------- loop [19] 100.0% [25] 652(1.0%) 0(0.0%) for-loop ...se-places/src/core/extraction.rkt:29:4 for-loop [32] 100.0% -------------------------------------------------------------------------------- precompute-phase [20] 100.0% [26] 326(0.5%) 0(0.0%) for-loop ...use-places/src/core/simplify.rkt:102:2 set-precompute! [33] 100.0% -------------------------------------------------------------------------------- for-loop [21] 100.0% [27] 300(0.5%) 0(0.0%) prune-phase ...-places/src/core/simplify.rkt:106:0 for-loop [34] 100.0% -------------------------------------------------------------------------------- for-loop [22] 100.0% [28] 36470(54.9%) 334(0.5%) for-loop .../use-places/src/core/simplify.rkt:96:4 merge-egraph-nodes! [35] 65.1% dedup-children! [58] 28.0% pattern-substitute [40] 4.4% mk-enode-rec! [43] 1.7% -------------------------------------------------------------------------------- ??? [5] 2.9% ??? [16] 23.2% ??? [24] 31.8% ??? [18] 42.0% [29] 11102(16.7%) 1404(2.1%) ??? ...tract/private/arrow-higher-order.rkt:360:33 mk-ival [37] 39.3% ival-mult [51] 31.8% sample-multi-bounded [39] 16.2% -------------------------------------------------------------------------------- for-loop [30] 48.4% find-matches [23] 51.6% [30] 10156(15.3%) 332(0.5%) for-loop .../use-places/src/core/simplify.rkt:86:8 for-loop [30] 48.4% match-e [36] 48.4% -------------------------------------------------------------------------------- ??? [24] 100.0% [31] 5730(8.6%) 0(0.0%) ??? ...tract/private/arrow-higher-order.rkt:364:33 ival-add [38] 60.0% ival-fma [41] 20.9% ival-sub [42] 19.2% -------------------------------------------------------------------------------- for-loop [25] 100.0% [32] 652(1.0%) 354(0.5%) for-loop ...e-places/src/core/extraction.rkt:37:16 for-loop [45] 45.7% -------------------------------------------------------------------------------- for-loop [26] 100.0% [33] 326(0.5%) 0(0.0%) set-precompute! ...ces/src/core/simplify.rkt:110:0 for-loop [44] 100.0% -------------------------------------------------------------------------------- prune-phase [27] 100.0% [34] 300(0.5%) 0(0.0%) for-loop ...use-places/src/core/simplify.rkt:107:2 update-leader! [49] 100.0% -------------------------------------------------------------------------------- merge-egraph-nodes! [35] 8.0% for-loop [48] 8.4% for-loop [28] 83.6% [35] 23724(35.7%) 328(0.5%) merge-egraph-nodes! ...s/src/core/egraph.rkt:145:0 loop! [46] 58.7% update-leader! [49] 15.4% for-loop [48] 9.8% merge-egraph-nodes! [35] 8.0% dedup-children! [58] 7.4% -------------------------------------------------------------------------------- for-loop [61] 35.5% for-loop [30] 64.5% [36] 9824(14.8%) 1334(2.0%) match-e ...bie/use-places/src/core/ematch.rkt:39:0 for-loop [47] 87.0% constant? [86] 4.7% ??? [52] 3.3% -------------------------------------------------------------------------------- ??? [29] 100.0% [37] 4362(6.6%) 0(0.0%) mk-ival ...bie/use-places/src/biginterval.rkt:65:0 bf [50] 100.0% -------------------------------------------------------------------------------- ??? [31] 100.0% [38] 3436(5.2%) 588(0.9%) ival-add ...e/use-places/src/biginterval.rkt:101:0 bfadd [62] 82.9% -------------------------------------------------------------------------------- ??? [29] 100.0% [39] 1802(2.7%) 932(1.4%) sample-multi-bounded ...places/src/points.rkt:15:0 random-ranges [53] 32.3% for-loop [57] 16.0% -------------------------------------------------------------------------------- pattern-substitute [40] 32.6% for-loop [28] 67.4% [40] 1590(2.4%) 982(1.5%) pattern-substitute ...es/src/core/matcher.rkt:46:0 pattern-substitute [40] 32.6% return/no-unsupplied [55] 9.4% ??? [52] 6.5% -------------------------------------------------------------------------------- ??? [31] 100.0% [41] 1196(1.8%) 0(0.0%) ival-fma ...e/use-places/src/biginterval.rkt:274:0 ival-mult [51] 51.8% bfadd [62] 48.2% -------------------------------------------------------------------------------- ??? [31] 100.0% [42] 1098(1.7%) 0(0.0%) ival-sub ...e/use-places/src/biginterval.rkt:107:0 bfadd [62] 100.0% -------------------------------------------------------------------------------- for-loop [28] 100.0% [43] 618(0.9%) 0(0.0%) mk-enode-rec! ...-places/src/core/egraph.rkt:117:0 do-curry [65] 52.4% new-enode [56] 47.6% -------------------------------------------------------------------------------- set-precompute! [33] 100.0% [44] 326(0.5%) 0(0.0%) for-loop ...use-places/src/core/simplify.rkt:112:2 setfindf [54] 100.0% -------------------------------------------------------------------------------- for-loop [32] 100.0% [45] 298(0.4%) 298(0.4%) for-loop ...e-places/src/core/extraction.rkt:41:23 -------------------------------------------------------------------------------- loop [59] 23.9% merge-egraph-nodes! [35] 76.1% [46] 16034(24.1%) 2888(4.3%) loop! ...erbie/use-places/src/core/enode.rkt:194:2 custom-set-union [60] 46.1% loop [59] 31.0% set [64] 9.8% update-en-expr [90] 2.7% -------------------------------------------------------------------------------- match-e [36] 100.0% [47] 9824(14.8%) 1876(2.8%) for-loop ...e/use-places/src/core/ematch.rkt:52:11 for-loop [61] 59.0% loop [59] 20.5% procedure-reduce-keyword-arity-mask [66] 6.1% do-curry [65] 1.7% ??? [74] 1.5% -------------------------------------------------------------------------------- merge-egraph-nodes! [35] 100.0% [48] 4830(7.3%) 0(0.0%) for-loop ...e/use-places/src/core/egraph.rkt:199:4 merge-egraph-nodes! [35] 93.1% dedup-children! [58] 6.9% -------------------------------------------------------------------------------- for-loop [34] 6.3% merge-egraph-nodes! [35] 93.7% [49] 4734(7.1%) 0(0.0%) update-leader! ...places/src/core/egraph.rkt:213:0 for-loop [63] 100.0% -------------------------------------------------------------------------------- mk-ival [37] 100.0% [50] 4362(6.6%) 0(0.0%) bf ...ath-lib/math/private/bigfloat/mpfr.rkt:601:2 new-mpfr [71] 82.9% ??? [73] 17.1% -------------------------------------------------------------------------------- ival-fma [41] 14.9% ??? [29] 85.1% [51] 4154(6.3%) 2196(3.3%) ival-mult .../use-places/src/biginterval.rkt:119:0 bfadd [62] 47.1% -------------------------------------------------------------------------------- loop [15] 18.9% pattern-substitute [40] 19.8% match-e [36] 61.3% [52] 1564(2.4%) 1564(2.4%) ??? ...contract/private/arrow-val-first.rkt:390:18 -------------------------------------------------------------------------------- sample-multi-bounded [39] 100.0% [53] 582(0.9%) 0(0.0%) random-ranges ...e/use-places/src/common.rkt:171:0 cons/c [67] 100.0% -------------------------------------------------------------------------------- for-loop [44] 100.0% [54] 326(0.5%) 0(0.0%) setfindf ...herbie/use-places/src/common.rkt:130:0 for-loop [68] 100.0% -------------------------------------------------------------------------------- pattern-substitute [40] 100.0% [55] 298(0.4%) 298(0.4%) return/no-unsupplied ...ct/private/arr-i.rkt:542:0 -------------------------------------------------------------------------------- mk-enode-rec! [43] 100.0% [56] 294(0.4%) 0(0.0%) new-enode ...e/use-places/src/core/enode.rkt:101:0 type-of-enode-expr [69] 100.0% -------------------------------------------------------------------------------- sample-multi-bounded [39] 100.0% [57] 288(0.4%) 288(0.4%) for-loop .../herbie/use-places/src/points.rkt:23:4 -------------------------------------------------------------------------------- for-loop [48] 2.5% merge-egraph-nodes! [35] 19.8% for-loop [28] 77.7% [58] 13132(19.8%) 0(0.0%) dedup-children! ...places/src/core/enode.rkt:202:0 loop [70] 100.0% -------------------------------------------------------------------------------- loop! [46] 3.6% for-loop [47] 5.2% loop [59] 91.2% [59] 10340(15.6%) 1624(2.4%) loop ...-7.2/collects/racket/private/map.rkt:40:19 loop [59] 91.2% loop! [46] 3.3% step [79] 3.0% ??? [74] 0.6% -------------------------------------------------------------------------------- loop! [46] 100.0% [60] 7732(11.6%) 2516(3.8%) custom-set-union ...et/private/set-types.rkt:168:0 for-loop [72] 59.7% for-loop [77] 7.8% -------------------------------------------------------------------------------- for-loop [47] 100.0% [61] 6890(10.4%) 372(0.6%) for-loop ...e/use-places/src/core/ematch.rkt:58:37 match-e [36] 85.0% ??? [76] 9.6% -------------------------------------------------------------------------------- ival-fma [41] 8.9% ival-sub [42] 16.9% ival-mult [51] 30.2% ival-add [38] 44.0% [62] 6480(9.8%) 0(0.0%) bfadd ...-lib/math/private/bigfloat/mpfr.rkt:821:4 new-mpfr [71] 64.8% ??? [73] 35.2% -------------------------------------------------------------------------------- update-leader! [49] 100.0% [63] 4734(7.1%) 300(0.5%) for-loop ...e/use-places/src/core/egraph.rkt:218:6 hash-update! [81] 60.4% for-loop [75] 33.2% -------------------------------------------------------------------------------- loop! [46] 100.0% [64] 3128(4.7%) 3128(4.7%) set ...collects/racket/private/set-types.rkt:981:0 -------------------------------------------------------------------------------- mk-enode-rec! [43] 49.8% for-loop [47] 50.2% [65] 650(1.0%) 650(1.0%) do-curry ...-7.2/collects/racket/function.rkt:71:2 -------------------------------------------------------------------------------- for-loop [47] 100.0% [66] 600(0.9%) 600(0.9%) procedure-reduce-keyword-arity-mask ....rkt:1562:4 -------------------------------------------------------------------------------- random-ranges [53] 100.0% [67] 582(0.9%) 0(0.0%) cons/c .../racket/contract/private/guts.rkt:504:15 coerce-contract [78] 100.0% -------------------------------------------------------------------------------- setfindf [54] 100.0% [68] 326(0.5%) 326(0.5%) for-loop ...herbie/use-places/src/common.rkt:131:2 -------------------------------------------------------------------------------- new-enode [56] 100.0% [69] 294(0.4%) 0(0.0%) type-of-enode-expr ...aces/src/core/enode.rkt:66:0 table-ref [80] 100.0% -------------------------------------------------------------------------------- dedup-children! [58] 5.4% loop [70] 94.6% [70] 13132(19.8%) 13132(19.8%) loop ...racket-7.2/collects/racket/list.rkt:434:17 loop [70] 94.6% -------------------------------------------------------------------------------- bf [50] 46.3% bfadd [62] 53.7% [71] 7818(11.8%) 7818(11.8%) new-mpfr ...b/math/private/bigfloat/mpfr.rkt:335:0 -------------------------------------------------------------------------------- custom-set-union [60] 100.0% [72] 4616(6.9%) 1340(2.0%) for-loop ...cts/racket/private/set-types.rkt:174:3 for-loop [82] 71.0% -------------------------------------------------------------------------------- bf [50] 24.7% bfadd [62] 75.3% [73] 3024(4.6%) 3024(4.6%) ??? /opt/racket-7.2/collects/ffi/unsafe.rkt:905:4 -------------------------------------------------------------------------------- for-loop [47] 17.9% loop [59] 82.1% [74] 1672(2.5%) 1672(2.5%) ??? ...ket-7.2/collects/racket/function.rkt:138:13 -------------------------------------------------------------------------------- for-loop [63] 100.0% [75] 1574(2.4%) 0(0.0%) for-loop ...e/use-places/src/core/egraph.rkt:219:8 hash-update! [81] 100.0% -------------------------------------------------------------------------------- for-loop [61] 100.0% [76] 662(1.0%) 0(0.0%) ??? .../herbie/use-places/src/core/ematch.rkt:43:5 for-loop [83] 100.0% -------------------------------------------------------------------------------- custom-set-union [60] 100.0% [77] 600(0.9%) 600(0.9%) for-loop ...cts/racket/private/set-types.rkt:152:2 -------------------------------------------------------------------------------- cons/c [67] 100.0% [78] 582(0.9%) 0(0.0%) coerce-contract ...contract/private/guts.rkt:308:0 coerce-contract/f [84] 100.0% -------------------------------------------------------------------------------- loop [59] 100.0% [79] 308(0.5%) 308(0.5%) step ...ket-7.2/collects/racket/function.rkt:145:9 -------------------------------------------------------------------------------- type-of-enode-expr [69] 100.0% [80] 294(0.4%) 294(0.4%) table-ref ...herbie/use-places/src/common.rkt:33:0 -------------------------------------------------------------------------------- for-loop [75] 35.5% for-loop [63] 64.5% [81] 4434(6.7%) 0(0.0%) hash-update! ...cket/private/more-scheme.rkt:365:4 ??? [85] 100.0% -------------------------------------------------------------------------------- for-loop [72] 100.0% [82] 3276(4.9%) 3276(4.9%) for-loop ...cts/racket/private/set-types.rkt:178:5 -------------------------------------------------------------------------------- ??? [76] 100.0% [83] 662(1.0%) 326(0.5%) for-loop ...ie/use-places/src/core/ematch.rkt:44:7 constant? [86] 50.8% -------------------------------------------------------------------------------- coerce-contract [78] 100.0% [84] 582(0.9%) 0(0.0%) coerce-contract/f ...ntract/private/guts.rkt:373:0 coerce-simple-value [87] 100.0% -------------------------------------------------------------------------------- hash-update! [81] 100.0% [85] 4434(6.7%) 0(0.0%) ??? ...erbie/use-places/src/core/egraph.rkt:221:24 for-loop [88] 100.0% -------------------------------------------------------------------------------- for-loop [83] 19.5% match-e [36] 80.5% [86] 1722(2.6%) 0(0.0%) constant? ...se-places/src/syntax/syntax.rkt:726:0 value? [89] 100.0% -------------------------------------------------------------------------------- coerce-contract/f [84] 100.0% [87] 582(0.9%) 582(0.9%) coerce-simple-value ...ract/private/guts.rkt:386:0 -------------------------------------------------------------------------------- ??? [85] 100.0% [88] 4434(6.7%) 4140(6.2%) for-loop .../use-places/src/core/egraph.rkt:222:26 update-en-expr [90] 6.6% -------------------------------------------------------------------------------- constant? [86] 100.0% [89] 1722(2.6%) 1722(2.6%) value? ...bie/use-places/src/syntax/types.rkt:18:0 -------------------------------------------------------------------------------- for-loop [88] 22.9% loop! [46] 77.1% [90] 1286(1.9%) 1286(1.9%) update-en-expr ...places/src/core/egraph.rkt:207:0 --------------------------------------------------------------------------------