Profiling results ----------------- Total cpu time observed: 63770ms (out of 64352ms) Number of samples taken: 184 (once every 347ms) (Hiding functions with self<1.0% and local<2.0%: 1 of 90 hidden) =============================================================================== Caller Idx Total Self Name+src Local% ms(pct) ms(pct) Callee =============================================================================== ??? [5] 100.0% [1] 63770(100.0%) 0(0.0%) profile-thunk16 ...e/pkgs/profile-lib/main.rkt:9:0 run [3] 100.0% ------------------------------------------------------------------------------- ??? [5] 100.0% [2] 636(1.0%) 0(0.0%) errors ...tlies/herbie/master/src/points.rkt:201:0 for-loop [4] 100.0% ------------------------------------------------------------------------------- profile-thunk16 [1] 100.0% [3] 63770(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] 636(1.0%) 0(0.0%) for-loop ...ies/herbie/master/src/points.rkt:203:2 ??? [5] 100.0% ------------------------------------------------------------------------------- for-loop [4] 0.3% run [3] 49.8% [5] 63770(100.0%) 0(0.0%) ??? ...lects/racket/private/more-scheme.rkt:261:28 profile-thunk16 [1] 49.8% run-improve47 [6] 35.4% prepare-points-intervals [9] 13.9% errors [2] 0.3% oracle-error [7] 0.2% ??? [30] 0.2% ??? [18] 0.1% ------------------------------------------------------------------------------- ??? [5] 100.0% [6] 45166(70.8%) 0(0.0%) run-improve47 ...bie/master/src/mainloop.rkt:346:0 simplify! [8] 99.3% prepare-points-intervals [9] 0.7% ------------------------------------------------------------------------------- ??? [5] 100.0% [7] 292(0.5%) 0(0.0%) oracle-error ...herbie/master/src/points.rkt:188:0 for-loop [10] 100.0% ------------------------------------------------------------------------------- run-improve47 [6] 100.0% [8] 44854(70.3%) 0(0.0%) simplify! .../herbie/master/src/mainloop.rkt:224:0 ??? [11] 100.0% ------------------------------------------------------------------------------- run-improve47 [6] 1.7% ??? [5] 98.3% [9] 17988(28.2%) 0(0.0%) prepare-points-intervals ...r/src/points.rkt:110:0 loop [12] 100.0% ------------------------------------------------------------------------------- oracle-error [7] 100.0% [10] 292(0.5%) 292(0.5%) for-loop ...ies/herbie/master/src/points.rkt:189:2 ------------------------------------------------------------------------------- simplify! [8] 100.0% [11] 44854(70.3%) 0(0.0%) ??? ...es/herbie/master/src/core/simplify.rkt:31:0 for-loop [13] 99.3% loop [16] 0.7% ------------------------------------------------------------------------------- prepare-points-intervals [9] 100.0% [12] 17988(28.2%) 632(1.0%) loop ...ghtlies/herbie/master/src/points.rkt:123:4 loop [14] 80.1% ??? [15] 16.4% ------------------------------------------------------------------------------- ??? [11] 100.0% [13] 44544(69.9%) 0(0.0%) for-loop ...rbie/master/src/core/simplify.rkt:51:2 ??? [17] 97.3% for-loop [19] 1.4% precompute-phase [20] 1.4% ------------------------------------------------------------------------------- loop [12] 100.0% [14] 14406(22.6%) 910(1.4%) loop ...ightlies/herbie/master/src/points.rkt:81:2 ??? [18] 89.5% ??? [78] 2.1% hash-update! [82] 2.1% ------------------------------------------------------------------------------- loop [12] 100.0% [15] 2950(4.6%) 644(1.0%) ??? ...ightlies/herbie/master/src/points.rkt:106:2 ??? [30] 68.3% compose [22] 9.8% ------------------------------------------------------------------------------- ??? [11] 100.0% [16] 310(0.5%) 0(0.0%) loop ...herbie/master/src/core/extraction.rkt:25:2 for-loop [21] 100.0% ------------------------------------------------------------------------------- for-loop [13] 100.0% [17] 43322(67.9%) 0(0.0%) ??? ...es/herbie/master/src/core/simplify.rkt:92:0 for-loop [23] 83.9% find-matches [25] 16.1% ------------------------------------------------------------------------------- ??? [5] 2.2% loop [14] 97.8% [18] 13174(20.7%) 294(0.5%) ??? ...htlies/herbie/master/src/programs.rkt:115:2 ??? [24] 80.3% ??? [30] 17.5% ------------------------------------------------------------------------------- for-loop [13] 100.0% [19] 612(1.0%) 0(0.0%) for-loop ...rbie/master/src/core/simplify.rkt:59:4 prune-phase [26] 100.0% ------------------------------------------------------------------------------- for-loop [13] 100.0% [20] 610(1.0%) 0(0.0%) precompute-phase ...er/src/core/simplify.rkt:101:0 for-loop [27] 100.0% ------------------------------------------------------------------------------- loop [16] 100.0% [21] 310(0.5%) 0(0.0%) for-loop ...ie/master/src/core/extraction.rkt:29:4 for-loop [28] 100.0% ------------------------------------------------------------------------------- ??? [15] 100.0% [22] 290(0.5%) 290(0.5%) compose ...collects/racket/private/list.rkt:385:12 ------------------------------------------------------------------------------- ??? [17] 100.0% [23] 36368(57.0%) 0(0.0%) for-loop ...rbie/master/src/core/simplify.rkt:93:2 for-loop [29] 100.0% ------------------------------------------------------------------------------- ??? [18] 100.0% [24] 10576(16.6%) 0(0.0%) ??? ...t-7.2/collects/racket/private/kw.rkt:594:14 ??? [32] 63.0% ??? [30] 37.0% ------------------------------------------------------------------------------- ??? [17] 100.0% [25] 6954(10.9%) 0(0.0%) find-matches .../master/src/core/simplify.rkt:84:0 for-loop [31] 100.0% ------------------------------------------------------------------------------- for-loop [19] 100.0% [26] 612(1.0%) 0(0.0%) prune-phase .../master/src/core/simplify.rkt:106:0 for-loop [33] 100.0% ------------------------------------------------------------------------------- precompute-phase [20] 100.0% [27] 610(1.0%) 0(0.0%) for-loop ...bie/master/src/core/simplify.rkt:102:2 set-precompute! [34] 100.0% ------------------------------------------------------------------------------- for-loop [21] 100.0% [28] 310(0.5%) 310(0.5%) for-loop ...e/master/src/core/extraction.rkt:37:16 ------------------------------------------------------------------------------- for-loop [23] 100.0% [29] 36368(57.0%) 0(0.0%) for-loop ...rbie/master/src/core/simplify.rkt:96:4 merge-egraph-nodes! [35] 66.6% dedup-children! [46] 20.5% mk-enode-rec! [37] 12.1% pattern-substitute [44] 0.8% ------------------------------------------------------------------------------- ??? [5] 4.1% ??? [15] 23.5% ??? [18] 26.9% ??? [24] 45.5% [30] 8580(13.5%) 636(1.0%) ??? ...tract/private/arrow-higher-order.rkt:360:33 ival-mult [50] 45.5% mk-ival [39] 23.5% sample-multi-bounded [40] 23.5% ------------------------------------------------------------------------------- for-loop [31] 50.0% find-matches [25] 50.0% [31] 6954(10.9%) 0(0.0%) for-loop ...rbie/master/src/core/simplify.rkt:86:8 for-loop [31] 50.0% match-e [36] 50.0% ------------------------------------------------------------------------------- ??? [24] 100.0% [32] 6668(10.5%) 678(1.1%) ??? ...tract/private/arrow-higher-order.rkt:364:33 ival-sub [38] 43.9% ival-fma [41] 26.2% ival-add [42] 19.7% ------------------------------------------------------------------------------- prune-phase [26] 100.0% [33] 612(1.0%) 0(0.0%) for-loop ...bie/master/src/core/simplify.rkt:107:2 update-leader! [48] 100.0% ------------------------------------------------------------------------------- for-loop [27] 100.0% [34] 610(1.0%) 0(0.0%) set-precompute! ...ter/src/core/simplify.rkt:110:0 for-loop [43] 100.0% ------------------------------------------------------------------------------- merge-egraph-nodes! [35] 3.8% for-loop [49] 9.0% for-loop [29] 87.1% [35] 24206(38.0%) 312(0.5%) merge-egraph-nodes! ...r/src/core/egraph.rkt:145:0 loop! [45] 65.4% update-leader! [48] 14.9% for-loop [49] 9.0% dedup-children! [46] 3.9% merge-egraph-nodes! [35] 3.8% enode-merge! [60] 1.2% ------------------------------------------------------------------------------- for-loop [66] 30.5% for-loop [31] 69.5% [36] 6954(10.9%) 598(0.9%) match-e .../herbie/master/src/core/ematch.rkt:39:0 for-loop [47] 82.6% constant? [59] 4.3% ??? [53] 3.0% make-sequence [57] 2.2% variable? [58] 1.4% ------------------------------------------------------------------------------- loop [61] 3.7% for-loop [29] 96.3% [37] 4404(6.9%) 4098(6.4%) mk-enode-rec! .../master/src/core/egraph.rkt:117:0 for-loop [56] 6.9% loop [61] 3.7% ------------------------------------------------------------------------------- ??? [32] 100.0% [38] 2930(4.6%) 0(0.0%) ival-sub ...erbie/master/src/biginterval.rkt:107:0 bfmul [62] 100.0% ------------------------------------------------------------------------------- ??? [30] 100.0% [39] 2020(3.2%) 0(0.0%) mk-ival .../herbie/master/src/biginterval.rkt:65:0 bf [51] 100.0% ------------------------------------------------------------------------------- ??? [30] 100.0% [40] 2016(3.2%) 328(0.5%) sample-multi-bounded ...master/src/points.rkt:15:0 random-ranges [52] 67.8% for-loop [54] 16.0% ------------------------------------------------------------------------------- ??? [32] 100.0% [41] 1744(2.7%) 0(0.0%) ival-fma ...erbie/master/src/biginterval.rkt:274:0 bfmul [62] 62.6% ival-mult [50] 37.4% ------------------------------------------------------------------------------- ??? [32] 100.0% [42] 1316(2.1%) 0(0.0%) ival-add ...erbie/master/src/biginterval.rkt:101:0 bfmul [62] 100.0% ------------------------------------------------------------------------------- set-precompute! [34] 100.0% [43] 610(1.0%) 298(0.5%) for-loop ...bie/master/src/core/simplify.rkt:112:2 setfindf [55] 51.1% ------------------------------------------------------------------------------- pattern-substitute [44] 50.0% for-loop [29] 50.0% [44] 300(0.5%) 0(0.0%) pattern-substitute ...er/src/core/matcher.rkt:46:0 pattern-substitute [44] 50.0% ??? [53] 50.0% ------------------------------------------------------------------------------- loop [61] 27.1% merge-egraph-nodes! [35] 72.9% [45] 17460(27.4%) 4248(6.7%) loop! ...es/herbie/master/src/core/enode.rkt:194:2 custom-set-union [76] 40.2% loop [61] 31.5% set [65] 11.4% update-en-expr [69] 1.8% ------------------------------------------------------------------------------- merge-egraph-nodes! [35] 17.6% for-loop [29] 82.4% [46] 9048(14.2%) 0(0.0%) dedup-children! ...master/src/core/enode.rkt:202:0 loop [63] 100.0% ------------------------------------------------------------------------------- match-e [36] 100.0% [47] 6356(10.0%) 2694(4.2%) for-loop ...erbie/master/src/core/ematch.rkt:52:11 for-loop [66] 45.3% procedure-reduce-keyword-arity-mask [68] 11.9% loop [61] 5.1% foldr [72] 4.7% do-curry [74] 4.7% ------------------------------------------------------------------------------- for-loop [33] 12.6% merge-egraph-nodes! [35] 87.4% [48] 4850(7.6%) 0(0.0%) update-leader! ...master/src/core/egraph.rkt:213:0 for-loop [64] 100.0% ------------------------------------------------------------------------------- merge-egraph-nodes! [35] 100.0% [49] 4642(7.3%) 0(0.0%) for-loop ...erbie/master/src/core/egraph.rkt:199:4 merge-egraph-nodes! [35] 100.0% ------------------------------------------------------------------------------- ival-fma [41] 14.3% ??? [30] 85.7% [50] 4560(7.2%) 352(0.6%) ival-mult ...rbie/master/src/biginterval.rkt:119:0 bfmul [62] 92.3% ------------------------------------------------------------------------------- mk-ival [39] 100.0% [51] 2020(3.2%) 0(0.0%) bf ...ath-lib/math/private/bigfloat/mpfr.rkt:601:2 new-mpfr [75] 100.0% ------------------------------------------------------------------------------- sample-multi-bounded [40] 100.0% [52] 1366(2.1%) 0(0.0%) random-ranges ...erbie/master/src/common.rkt:171:0 cons/c [67] 67.8% build--> [71] 32.2% ------------------------------------------------------------------------------- pattern-substitute [44] 32.2% match-e [36] 67.8% [53] 932(1.5%) 932(1.5%) ??? ...contract/private/arrow-val-first.rkt:390:18 ------------------------------------------------------------------------------- sample-multi-bounded [40] 100.0% [54] 322(0.5%) 322(0.5%) for-loop ...lies/herbie/master/src/points.rkt:23:4 ------------------------------------------------------------------------------- for-loop [43] 100.0% [55] 312(0.5%) 312(0.5%) setfindf ...ies/herbie/master/src/common.rkt:130:0 ------------------------------------------------------------------------------- mk-enode-rec! [37] 100.0% [56] 306(0.5%) 306(0.5%) for-loop ...rbie/master/src/core/egraph.rkt:109:10 ------------------------------------------------------------------------------- match-e [36] 100.0% [57] 300(0.5%) 300(0.5%) make-sequence ...ects/racket/private/for.rkt:530:2 ------------------------------------------------------------------------------- match-e [36] 100.0% [58] 300(0.5%) 0(0.0%) variable? ...ie/master/src/syntax/syntax.rkt:729:0 value? [70] 100.0% ------------------------------------------------------------------------------- match-e [36] 100.0% [59] 300(0.5%) 0(0.0%) constant? ...ie/master/src/syntax/syntax.rkt:726:0 value? [70] 100.0% ------------------------------------------------------------------------------- merge-egraph-nodes! [35] 100.0% [60] 300(0.5%) 0(0.0%) enode-merge! ...ie/master/src/core/enode.rkt:131:0 adopt-enode! [73] 100.0% ------------------------------------------------------------------------------- for-loop [47] 0.3% mk-enode-rec! [37] 3.0% loop! [45] 4.0% loop [61] 92.7% [61] 10726(16.8%) 1246(2.0%) loop ...-7.2/collects/racket/private/map.rkt:40:19 loop [61] 92.7% loop! [45] 3.8% mk-enode-rec! [37] 3.0% ------------------------------------------------------------------------------- ival-fma [41] 11.4% ival-add [42] 13.8% ival-sub [38] 30.7% ival-mult [50] 44.1% [62] 9546(15.0%) 944(1.5%) bfmul ...-lib/math/private/bigfloat/mpfr.rkt:821:4 new-mpfr [75] 76.6% ??? [78] 13.5% ------------------------------------------------------------------------------- dedup-children! [46] 10.3% loop [63] 89.7% [63] 9048(14.2%) 9048(14.2%) loop ...racket-7.2/collects/racket/list.rkt:434:17 loop [63] 89.7% ------------------------------------------------------------------------------- update-leader! [48] 100.0% [64] 4850(7.6%) 0(0.0%) for-loop ...erbie/master/src/core/egraph.rkt:218:6 hash-update! [82] 53.9% for-loop [77] 46.1% ------------------------------------------------------------------------------- loop! [45] 100.0% [65] 3988(6.3%) 3988(6.3%) set ...collects/racket/private/set-types.rkt:981:0 ------------------------------------------------------------------------------- for-loop [47] 100.0% [66] 3926(6.2%) 300(0.5%) for-loop ...erbie/master/src/core/ematch.rkt:58:37 match-e [36] 96.2% ------------------------------------------------------------------------------- random-ranges [52] 100.0% [67] 926(1.5%) 0(0.0%) cons/c .../racket/contract/private/guts.rkt:504:15 coerce-contract [79] 65.7% flat-contract? [80] 34.3% ------------------------------------------------------------------------------- for-loop [47] 100.0% [68] 906(1.4%) 906(1.4%) procedure-reduce-keyword-arity-mask ....rkt:1562:4 ------------------------------------------------------------------------------- loop! [45] 100.0% [69] 646(1.0%) 646(1.0%) update-en-expr ...master/src/core/egraph.rkt:207:0 ------------------------------------------------------------------------------- constant? [59] 50.0% variable? [58] 50.0% [70] 600(0.9%) 600(0.9%) value? .../herbie/master/src/syntax/types.rkt:18:0 ------------------------------------------------------------------------------- random-ranges [52] 100.0% [71] 440(0.7%) 0(0.0%) build--> ...act/private/arrow-val-first.rkt:1088:0 coerce-contract [79] 100.0% ------------------------------------------------------------------------------- for-loop [47] 100.0% [72] 300(0.5%) 0(0.0%) foldr ....2/collects/racket/private/list.rkt:242:4 cp-2 [81] 100.0% ------------------------------------------------------------------------------- enode-merge! [60] 100.0% [73] 300(0.5%) 0(0.0%) adopt-enode! ...ie/master/src/core/enode.rkt:109:0 custom-set-union [76] 100.0% ------------------------------------------------------------------------------- for-loop [47] 100.0% [74] 298(0.5%) 298(0.5%) do-curry ...-7.2/collects/racket/function.rkt:71:2 ------------------------------------------------------------------------------- bf [51] 21.6% bfmul [62] 78.4% [75] 9332(14.6%) 9332(14.6%) new-mpfr ...b/math/private/bigfloat/mpfr.rkt:335:0 ------------------------------------------------------------------------------- adopt-enode! [73] 3.8% loop! [45] 96.2% [76] 7958(12.5%) 3522(5.5%) custom-set-union ...et/private/set-types.rkt:168:0 for-loop [83] 40.7% for-loop [84] 15.1% ------------------------------------------------------------------------------- for-loop [64] 100.0% [77] 2234(3.5%) 0(0.0%) for-loop ...erbie/master/src/core/egraph.rkt:219:8 hash-update! [82] 100.0% ------------------------------------------------------------------------------- loop [14] 19.3% bfmul [62] 80.7% [78] 1598(2.5%) 1598(2.5%) ??? /opt/racket-7.2/collects/ffi/unsafe.rkt:905:4 ------------------------------------------------------------------------------- build--> [71] 42.0% cons/c [67] 58.0% [79] 1048(1.6%) 0(0.0%) coerce-contract ...contract/private/guts.rkt:308:0 coerce-contract/f [85] 100.0% ------------------------------------------------------------------------------- cons/c [67] 100.0% [80] 318(0.5%) 318(0.5%) flat-contract? .../contract/private/guts.rkt:130:0 ------------------------------------------------------------------------------- foldr [72] 100.0% [81] 300(0.5%) 300(0.5%) cp-2 .../racket-7.2/collects/racket/list.rkt:826:2 ------------------------------------------------------------------------------- loop [14] 5.8% for-loop [77] 43.4% for-loop [64] 50.8% [82] 5148(8.1%) 298(0.5%) hash-update! ...cket/private/more-scheme.rkt:365:4 ??? [86] 94.2% ------------------------------------------------------------------------------- custom-set-union [76] 100.0% [83] 3238(5.1%) 1342(2.1%) for-loop ...cts/racket/private/set-types.rkt:174:3 for-loop [87] 58.6% ------------------------------------------------------------------------------- custom-set-union [76] 100.0% [84] 1198(1.9%) 1198(1.9%) for-loop ...cts/racket/private/set-types.rkt:152:2 ------------------------------------------------------------------------------- coerce-contract [79] 100.0% [85] 1048(1.6%) 0(0.0%) coerce-contract/f ...ntract/private/guts.rkt:373:0 coerce-simple-value [88] 100.0% ------------------------------------------------------------------------------- hash-update! [82] 100.0% [86] 4850(7.6%) 650(1.0%) ??? ...es/herbie/master/src/core/egraph.rkt:221:24 for-loop [89] 86.6% ------------------------------------------------------------------------------- for-loop [83] 100.0% [87] 1896(3.0%) 1896(3.0%) for-loop ...cts/racket/private/set-types.rkt:178:5 ------------------------------------------------------------------------------- coerce-contract/f [85] 100.0% [88] 1048(1.6%) 1048(1.6%) coerce-simple-value ...ract/private/guts.rkt:386:0 ------------------------------------------------------------------------------- ??? [86] 100.0% [89] 4200(6.6%) 4200(6.6%) for-loop ...rbie/master/src/core/egraph.rkt:222:26 -------------------------------------------------------------------------------