Profiling results ----------------- Total cpu time observed: 60554ms (out of 60824ms) Number of samples taken: 217 (once every 279ms) (Hiding functions with self<1.0% and local<2.0%: 2 of 95 hidden) ================================================================================ Caller Idx Total Self Name+src Local% ms(pct) ms(pct) Callee ================================================================================ ??? [8] 100.0% [1] 60554(100.0%) 0(0.0%) profile-thunk16 ...e/pkgs/profile-lib/main.rkt:9:0 run [3] 100.0% -------------------------------------------------------------------------------- ??? [8] 100.0% [2] 278(0.5%) 0(0.0%) get-final-combination ...es/src/mainloop.rkt:371:0 argmin [4] 100.0% -------------------------------------------------------------------------------- profile-thunk16 [1] 100.0% [3] 60554(100.0%) 0(0.0%) run ...et-7.2/share/pkgs/profile-lib/main.rkt:39:2 ??? [8] 100.0% -------------------------------------------------------------------------------- get-final-combination [2] 100.0% [4] 278(0.5%) 0(0.0%) argmin ...acket-7.2/collects/racket/list.rkt:765:0 ??? [5] 100.0% -------------------------------------------------------------------------------- argmin [4] 100.0% [5] 278(0.5%) 0(0.0%) ??? ...s/herbie/use-places/src/mainloop.rkt:114:10 errors [6] 100.0% -------------------------------------------------------------------------------- ??? [5] 47.4% ??? [8] 52.6% [6] 586(1.0%) 0(0.0%) errors ...s/herbie/use-places/src/points.rkt:201:0 for-loop [7] 100.0% -------------------------------------------------------------------------------- errors [6] 100.0% [7] 586(1.0%) 0(0.0%) for-loop ...herbie/use-places/src/points.rkt:203:2 ??? [8] 100.0% -------------------------------------------------------------------------------- for-loop [7] 0.3% run [3] 49.8% [8] 60554(100.0%) 336(0.6%) ??? ...lects/racket/private/more-scheme.rkt:261:28 profile-thunk16 [1] 49.8% run-improve47 [9] 42.2% prepare-points-intervals [10] 7.1% errors [6] 0.2% ??? [18] 0.2% get-final-combination [2] 0.2% -------------------------------------------------------------------------------- ??? [8] 100.0% [9] 51070(84.3%) 0(0.0%) run-improve47 ...use-places/src/mainloop.rkt:346:0 simplify! [11] 100.0% -------------------------------------------------------------------------------- ??? [8] 100.0% [10] 8562(14.1%) 0(0.0%) prepare-points-intervals ...s/src/points.rkt:110:0 loop [12] 100.0% -------------------------------------------------------------------------------- run-improve47 [9] 100.0% [11] 51070(84.3%) 0(0.0%) simplify! ...bie/use-places/src/mainloop.rkt:224:0 ??? [13] 100.0% -------------------------------------------------------------------------------- prepare-points-intervals [10] 100.0% [12] 8562(14.1%) 300(0.5%) loop ...ies/herbie/use-places/src/points.rkt:123:4 loop [14] 57.1% ??? [15] 35.3% loop [16] 4.1% -------------------------------------------------------------------------------- simplify! [11] 100.0% [13] 51070(84.3%) 0(0.0%) ??? ...erbie/use-places/src/core/simplify.rkt:31:0 for-loop [17] 100.0% -------------------------------------------------------------------------------- loop [12] 100.0% [14] 4886(8.1%) 0(0.0%) loop ...lies/herbie/use-places/src/points.rkt:81:2 ??? [18] 100.0% -------------------------------------------------------------------------------- loop [12] 100.0% [15] 3024(5.0%) 290(0.5%) ??? ...lies/herbie/use-places/src/points.rkt:106:2 ??? [27] 71.2% compose [19] 10.0% ??? [26] 9.2% -------------------------------------------------------------------------------- loop [12] 100.0% [16] 352(0.6%) 0(0.0%) loop ...7.2/collects/racket/private/map.rkt:110:23 ??? [52] 100.0% -------------------------------------------------------------------------------- ??? [13] 100.0% [17] 51070(84.3%) 0(0.0%) for-loop .../use-places/src/core/simplify.rkt:51:2 ??? [20] 95.5% for-loop [22] 3.5% precompute-phase [23] 1.0% -------------------------------------------------------------------------------- ??? [8] 5.9% loop [14] 94.1% [18] 5194(8.6%) 0(0.0%) ??? ...es/herbie/use-places/src/programs.rkt:115:2 ??? [21] 82.6% ??? [27] 17.4% -------------------------------------------------------------------------------- ??? [15] 100.0% [19] 302(0.5%) 302(0.5%) compose ...collects/racket/private/list.rkt:385:12 -------------------------------------------------------------------------------- for-loop [17] 100.0% [20] 48768(80.5%) 0(0.0%) ??? ...erbie/use-places/src/core/simplify.rkt:92:0 for-loop [24] 89.4% find-matches [25] 10.6% -------------------------------------------------------------------------------- ??? [18] 100.0% [21] 4288(7.1%) 0(0.0%) ??? ...t-7.2/collects/racket/private/kw.rkt:594:14 ??? [26] 92.5% ??? [27] 7.5% -------------------------------------------------------------------------------- for-loop [17] 100.0% [22] 1770(2.9%) 0(0.0%) for-loop .../use-places/src/core/simplify.rkt:59:4 prune-phase [28] 100.0% -------------------------------------------------------------------------------- for-loop [17] 100.0% [23] 532(0.9%) 0(0.0%) precompute-phase ...es/src/core/simplify.rkt:101:0 for-loop [29] 100.0% -------------------------------------------------------------------------------- ??? [20] 100.0% [24] 43620(72.0%) 332(0.5%) for-loop .../use-places/src/core/simplify.rkt:93:2 for-loop [30] 99.2% -------------------------------------------------------------------------------- ??? [20] 100.0% [25] 5148(8.5%) 0(0.0%) find-matches ...-places/src/core/simplify.rkt:84:0 for-loop [31] 100.0% -------------------------------------------------------------------------------- ??? [15] 6.6% ??? [21] 93.4% [26] 4244(7.0%) 1882(3.1%) ??? ...tract/private/arrow-higher-order.rkt:364:33 ival-sub [34] 39.7% ival-add [35] 15.9% -------------------------------------------------------------------------------- ??? [21] 9.5% ??? [18] 26.8% ??? [15] 63.7% [27] 3382(5.6%) 308(0.5%) ??? ...tract/private/arrow-higher-order.rkt:360:33 sample-multi-bounded [32] 63.7% mk-ival [36] 17.7% ival-mult [38] 9.5% -------------------------------------------------------------------------------- for-loop [22] 100.0% [28] 1770(2.9%) 0(0.0%) prune-phase ...-places/src/core/simplify.rkt:106:0 for-loop [33] 100.0% -------------------------------------------------------------------------------- precompute-phase [23] 100.0% [29] 532(0.9%) 0(0.0%) for-loop ...use-places/src/core/simplify.rkt:102:2 set-precompute! [37] 100.0% -------------------------------------------------------------------------------- for-loop [24] 100.0% [30] 43288(71.5%) 0(0.0%) for-loop .../use-places/src/core/simplify.rkt:96:4 merge-egraph-nodes! [46] 79.6% dedup-children! [74] 13.6% pattern-substitute [42] 4.2% mk-enode-rec! [43] 2.6% -------------------------------------------------------------------------------- for-loop [31] 50.0% find-matches [25] 50.0% [31] 5148(8.5%) 0(0.0%) for-loop .../use-places/src/core/simplify.rkt:86:8 for-loop [31] 50.0% match-e [39] 50.0% -------------------------------------------------------------------------------- ??? [27] 100.0% [32] 2154(3.6%) 268(0.4%) sample-multi-bounded ...places/src/points.rkt:15:0 random-ranges [41] 87.6% -------------------------------------------------------------------------------- prune-phase [28] 100.0% [33] 1770(2.9%) 0(0.0%) for-loop ...use-places/src/core/simplify.rkt:107:2 update-leader! [58] 100.0% -------------------------------------------------------------------------------- ??? [26] 100.0% [34] 1686(2.8%) 0(0.0%) ival-sub ...e/use-places/src/biginterval.rkt:107:0 bfmul [40] 100.0% -------------------------------------------------------------------------------- ??? [26] 100.0% [35] 676(1.1%) 676(1.1%) ival-add ...e/use-places/src/biginterval.rkt:101:0 -------------------------------------------------------------------------------- ??? [27] 100.0% [36] 598(1.0%) 0(0.0%) mk-ival ...bie/use-places/src/biginterval.rkt:65:0 bf [44] 100.0% -------------------------------------------------------------------------------- for-loop [29] 100.0% [37] 532(0.9%) 0(0.0%) set-precompute! ...ces/src/core/simplify.rkt:110:0 for-loop [45] 100.0% -------------------------------------------------------------------------------- ??? [27] 100.0% [38] 322(0.5%) 0(0.0%) ival-mult .../use-places/src/biginterval.rkt:119:0 bfmul [40] 100.0% -------------------------------------------------------------------------------- for-loop [61] 37.2% for-loop [31] 62.8% [39] 5148(8.5%) 274(0.5%) match-e ...bie/use-places/src/core/ematch.rkt:39:0 for-loop [47] 90.1% constant? [77] 4.5% -------------------------------------------------------------------------------- ival-mult [38] 16.0% ival-sub [34] 84.0% [40] 2008(3.3%) 0(0.0%) bfmul ...-lib/math/private/bigfloat/mpfr.rkt:821:4 new-mpfr [48] 66.1% ??? [49] 33.9% -------------------------------------------------------------------------------- sample-multi-bounded [32] 100.0% [41] 1886(3.1%) 590(1.0%) random-ranges ...e/use-places/src/common.rkt:171:0 cons/c [50] 34.7% build--> [51] 34.0% -------------------------------------------------------------------------------- pattern-substitute [42] 30.2% for-loop [30] 69.8% [42] 1828(3.0%) 506(0.8%) pattern-substitute ...es/src/core/matcher.rkt:46:0 pattern-substitute [42] 30.2% procedure-reduce-arity [54] 16.4% ??? [53] 12.5% ??? [52] 7.0% constant? [77] 6.2% -------------------------------------------------------------------------------- loop [73] 39.5% for-loop [30] 60.5% [43] 1108(1.8%) 326(0.5%) mk-enode-rec! ...-places/src/core/egraph.rkt:117:0 loop [73] 39.5% new-enode [56] 20.9% do-curry [64] 13.5% hash-has-key? [55] 11.3% -------------------------------------------------------------------------------- mk-ival [36] 100.0% [44] 598(1.0%) 0(0.0%) bf ...ath-lib/math/private/bigfloat/mpfr.rkt:601:2 ??? [49] 100.0% -------------------------------------------------------------------------------- set-precompute! [37] 100.0% [45] 532(0.9%) 0(0.0%) for-loop ...use-places/src/core/simplify.rkt:112:2 merge-egraph-nodes! [46] 61.3% setfindf [57] 38.7% -------------------------------------------------------------------------------- for-loop [45] 0.5% for-loop [60] 5.7% merge-egraph-nodes! [46] 7.6% for-loop [30] 86.2% [46] 34778(57.4%) 260(0.4%) merge-egraph-nodes! ...s/src/core/egraph.rkt:145:0 update-leader! [58] 51.1% loop! [59] 28.5% for-loop [60] 9.0% merge-egraph-nodes! [46] 7.6% dedup-children! [74] 3.4% -------------------------------------------------------------------------------- match-e [39] 100.0% [47] 4874(8.0%) 2166(3.6%) for-loop ...e/use-places/src/core/ematch.rkt:52:11 for-loop [61] 44.1% step [63] 9.4% foldl [65] 8.2% procedure-reduce-keyword-arity-mask [67] 6.2% do-curry [64] 3.1% foldr [68] 3.0% -------------------------------------------------------------------------------- bfmul [40] 100.0% [48] 1328(2.2%) 1328(2.2%) new-mpfr ...b/math/private/bigfloat/mpfr.rkt:335:0 -------------------------------------------------------------------------------- bf [44] 46.8% bfmul [40] 53.2% [49] 1278(2.1%) 1278(2.1%) ??? /opt/racket-7.2/collects/ffi/unsafe.rkt:905:4 -------------------------------------------------------------------------------- random-ranges [41] 100.0% [50] 654(1.1%) 0(0.0%) cons/c .../racket/contract/private/guts.rkt:504:15 coerce-contract [62] 100.0% -------------------------------------------------------------------------------- random-ranges [41] 100.0% [51] 642(1.1%) 0(0.0%) build--> ...act/private/arrow-val-first.rkt:1088:0 coerce-contract [62] 50.5% chaperone-contract? [66] 49.5% -------------------------------------------------------------------------------- pattern-substitute [42] 42.1% loop [16] 57.9% [52] 608(1.0%) 608(1.0%) ??? ...cket-7.2/collects/racket/function.rkt:93:12 -------------------------------------------------------------------------------- pattern-substitute [42] 100.0% [53] 540(0.9%) 296(0.5%) ??? ...contract/private/arrow-val-first.rkt:390:18 ??? [69] 45.2% -------------------------------------------------------------------------------- pattern-substitute [42] 100.0% [54] 300(0.5%) 300(0.5%) procedure-reduce-arity ...t/private/kw.rkt:1690:11 -------------------------------------------------------------------------------- mk-enode-rec! [43] 100.0% [55] 250(0.4%) 250(0.4%) hash-has-key? ...ket/private/more-scheme.rkt:371:2 -------------------------------------------------------------------------------- mk-enode-rec! [43] 100.0% [56] 232(0.4%) 0(0.0%) new-enode ...e/use-places/src/core/enode.rkt:101:0 type-of-enode-expr [70] 100.0% -------------------------------------------------------------------------------- for-loop [45] 100.0% [57] 206(0.3%) 0(0.0%) setfindf ...herbie/use-places/src/common.rkt:130:0 for-loop [71] 100.0% -------------------------------------------------------------------------------- for-loop [33] 8.7% merge-egraph-nodes! [46] 91.3% [58] 20384(33.7%) 0(0.0%) update-leader! ...places/src/core/egraph.rkt:213:0 for-loop [72] 98.8% -------------------------------------------------------------------------------- loop [73] 31.2% merge-egraph-nodes! [46] 68.8% [59] 13422(22.2%) 2592(4.3%) loop! ...erbie/use-places/src/core/enode.rkt:194:2 custom-set-union [75] 41.0% loop [73] 34.4% set [76] 11.8% update-en-expr [93] 3.2% -------------------------------------------------------------------------------- merge-egraph-nodes! [46] 100.0% [60] 5534(9.1%) 0(0.0%) for-loop ...e/use-places/src/core/egraph.rkt:199:4 merge-egraph-nodes! [46] 79.1% dedup-children! [74] 20.9% -------------------------------------------------------------------------------- for-loop [47] 100.0% [61] 3506(5.8%) 0(0.0%) for-loop ...e/use-places/src/core/ematch.rkt:58:37 match-e [39] 100.0% -------------------------------------------------------------------------------- build--> [51] 33.1% cons/c [50] 66.9% [62] 978(1.6%) 0(0.0%) coerce-contract ...contract/private/guts.rkt:308:0 coerce-contract/f [78] 100.0% -------------------------------------------------------------------------------- for-loop [47] 100.0% [63] 606(1.0%) 606(1.0%) step ...ket-7.2/collects/racket/function.rkt:145:9 -------------------------------------------------------------------------------- for-loop [47] 49.8% mk-enode-rec! [43] 50.2% [64] 598(1.0%) 598(1.0%) do-curry ...-7.2/collects/racket/function.rkt:71:2 -------------------------------------------------------------------------------- for-loop [47] 100.0% [65] 506(0.8%) 292(0.5%) foldl ....2/collects/racket/private/list.rkt:229:4 merge2 [79] 42.3% -------------------------------------------------------------------------------- build--> [51] 100.0% [66] 318(0.5%) 318(0.5%) chaperone-contract? ...ract/private/guts.rkt:136:0 -------------------------------------------------------------------------------- for-loop [47] 100.0% [67] 302(0.5%) 302(0.5%) procedure-reduce-keyword-arity-mask ....rkt:1562:4 -------------------------------------------------------------------------------- for-loop [47] 100.0% [68] 296(0.5%) 296(0.5%) foldr ....2/collects/racket/private/list.rkt:242:4 -------------------------------------------------------------------------------- ??? [53] 100.0% [69] 244(0.4%) 244(0.4%) ??? ...ects/racket/contract/private/guts.rkt:772:8 -------------------------------------------------------------------------------- new-enode [56] 100.0% [70] 232(0.4%) 232(0.4%) type-of-enode-expr ...aces/src/core/enode.rkt:66:0 -------------------------------------------------------------------------------- setfindf [57] 100.0% [71] 206(0.3%) 0(0.0%) for-loop ...herbie/use-places/src/common.rkt:131:2 constant? [77] 100.0% -------------------------------------------------------------------------------- update-leader! [58] 100.0% [72] 20138(33.3%) 252(0.4%) for-loop ...e/use-places/src/core/egraph.rkt:218:6 for-loop [80] 56.9% hash-update! [87] 41.8% -------------------------------------------------------------------------------- mk-enode-rec! [43] 9.8% loop! [59] 12.2% loop [73] 77.9% [73] 8922(14.7%) 428(0.7%) loop ...-7.2/collects/racket/private/map.rkt:40:19 loop [73] 77.9% loop! [59] 12.1% mk-enode-rec! [43] 9.8% -------------------------------------------------------------------------------- for-loop [60] 13.8% merge-egraph-nodes! [46] 15.8% for-loop [30] 70.4% [74] 8382(13.8%) 0(0.0%) dedup-children! ...places/src/core/enode.rkt:202:0 loop [81] 88.7% loop [84] 11.3% -------------------------------------------------------------------------------- loop! [59] 100.0% [75] 5862(9.7%) 1472(2.4%) custom-set-union ...et/private/set-types.rkt:168:0 for-loop [82] 70.8% for-loop [86] 4.1% -------------------------------------------------------------------------------- loop! [59] 100.0% [76] 3598(5.9%) 3598(5.9%) set ...collects/racket/private/set-types.rkt:981:0 -------------------------------------------------------------------------------- for-loop [71] 18.2% pattern-substitute [42] 20.0% match-e [39] 61.8% [77] 1132(1.9%) 214(0.4%) constant? ...se-places/src/syntax/syntax.rkt:726:0 value? [85] 81.1% -------------------------------------------------------------------------------- coerce-contract [62] 100.0% [78] 978(1.6%) 0(0.0%) coerce-contract/f ...ntract/private/guts.rkt:373:0 coerce-simple-value [83] 100.0% -------------------------------------------------------------------------------- foldl [65] 100.0% [79] 214(0.4%) 214(0.4%) merge2 ...rbie/use-places/src/core/ematch.rkt:24:0 -------------------------------------------------------------------------------- for-loop [72] 100.0% [80] 11462(18.9%) 0(0.0%) for-loop ...e/use-places/src/core/egraph.rkt:219:8 hash-update! [87] 100.0% -------------------------------------------------------------------------------- dedup-children! [74] 14.7% loop [81] 85.3% [81] 7434(12.3%) 7434(12.3%) loop ...racket-7.2/collects/racket/list.rkt:434:17 loop [81] 85.3% -------------------------------------------------------------------------------- custom-set-union [75] 100.0% [82] 4148(6.9%) 1810(3.0%) for-loop ...cts/racket/private/set-types.rkt:174:3 for-loop [88] 56.4% -------------------------------------------------------------------------------- coerce-contract/f [78] 100.0% [83] 978(1.6%) 978(1.6%) coerce-simple-value ...ract/private/guts.rkt:386:0 -------------------------------------------------------------------------------- dedup-children! [74] 21.9% loop [84] 78.1% [84] 948(1.6%) 292(0.5%) loop ...racket-7.2/collects/racket/list.rkt:417:34 loop [84] 78.1% member [90] 7.3% loop [89] 6.9% -------------------------------------------------------------------------------- constant? [77] 100.0% [85] 918(1.5%) 918(1.5%) value? ...bie/use-places/src/syntax/types.rkt:18:0 -------------------------------------------------------------------------------- custom-set-union [75] 100.0% [86] 242(0.4%) 242(0.4%) for-loop ...cts/racket/private/set-types.rkt:152:2 -------------------------------------------------------------------------------- for-loop [72] 42.4% for-loop [80] 57.6% [87] 19886(32.8%) 0(0.0%) hash-update! ...cket/private/more-scheme.rkt:365:4 ??? [91] 100.0% -------------------------------------------------------------------------------- for-loop [82] 100.0% [88] 2338(3.9%) 2338(3.9%) for-loop ...cts/racket/private/set-types.rkt:178:5 -------------------------------------------------------------------------------- loop [84] 100.0% [89] 448(0.7%) 448(0.7%) loop (unknown source) -------------------------------------------------------------------------------- loop [84] 100.0% [90] 208(0.3%) 208(0.3%) member (unknown source) -------------------------------------------------------------------------------- hash-update! [87] 100.0% [91] 19886(32.8%) 780(1.3%) ??? ...erbie/use-places/src/core/egraph.rkt:221:24 for-loop [92] 94.5% update-en-expr [93] 1.5% -------------------------------------------------------------------------------- ??? [91] 100.0% [92] 18802(31.0%) 17292(28.6%) for-loop .../use-places/src/core/egraph.rkt:222:26 update-en-expr [93] 8.0% -------------------------------------------------------------------------------- ??? [91] 11.0% loop! [59] 34.2% for-loop [92] 54.8% [93] 2756(4.6%) 2756(4.6%) update-en-expr ...places/src/core/egraph.rkt:207:0 --------------------------------------------------------------------------------