Profiling results ----------------- Total cpu time observed: 178982ms (out of 179784ms) Number of samples taken: 550 (once every 325ms) (Hiding functions with self<1.0% and local<2.0%: 2 of 84 hidden) ======================================================================== Caller Idx Total Self Name+src Local% ms(pct) ms(pct) Callee ======================================================================== ??? [3] 100.0% [1] 178982(100.0%) 0(0.0%) profile-thunk16 ...e/pkgs/profile-lib/main.rkt:9:0 run [2] 100.0% ------------------------------------------------------------------------ profile-thunk16 [1] 100.0% [2] 178982(100.0%) 0(0.0%) run ...et-7.0/share/pkgs/profile-lib/main.rkt:39:2 ??? [3] 100.0% ------------------------------------------------------------------------ run [2] 50.0% [3] 178982(100.0%) 0(0.0%) ??? ...lects/racket/private/more-scheme.rkt:261:28 profile-thunk16 [1] 50.0% run-improve40 [4] 48.9% prepare-points-intervals [5] 0.8% ??? [28] 0.1% errors-score [6] 0.1% eval-errors [7] 0.1% oracle-error [8] 0.1% ------------------------------------------------------------------------ ??? [3] 100.0% [4] 174970(97.8%) 0(0.0%) run-improve40 .../better-rr/src/mainloop.rkt:336:0 simplify! [9] 99.8% for-loop [12] 0.2% ------------------------------------------------------------------------ ??? [3] 100.0% [5] 2720(1.5%) 0(0.0%) prepare-points-intervals ...r/src/points.rkt:133:0 loop [10] 100.0% ------------------------------------------------------------------------ ??? [3] 100.0% [6] 346(0.2%) 0(0.0%) errors-score ...bie/better-rr/src/points.rkt:220:0 loop [11] 100.0% ------------------------------------------------------------------------ ??? [3] 100.0% [7] 302(0.2%) 0(0.0%) eval-errors ...rbie/better-rr/src/points.rkt:203:0 for-loop [13] 100.0% ------------------------------------------------------------------------ ??? [3] 100.0% [8] 296(0.2%) 0(0.0%) oracle-error ...bie/better-rr/src/points.rkt:212:0 for-loop [14] 100.0% ------------------------------------------------------------------------ run-improve40 [4] 100.0% [9] 174658(97.6%) 0(0.0%) simplify! ...rbie/better-rr/src/mainloop.rkt:213:0 ??? [15] 100.0% ------------------------------------------------------------------------ prepare-points-intervals [5] 100.0% [10] 2720(1.5%) 0(0.0%) loop ...lies/herbie/better-rr/src/points.rkt:145:4 loop [16] 100.0% ------------------------------------------------------------------------ errors-score [6] 100.0% [11] 346(0.2%) 0(0.0%) loop .../racket-7.0/collects/racket/list.rkt:559:2 ordinary-value? [17] 100.0% ------------------------------------------------------------------------ run-improve40 [4] 100.0% [12] 312(0.2%) 0(0.0%) for-loop ...erbie/better-rr/src/mainloop.rkt:351:4 run-iter! [18] 100.0% ------------------------------------------------------------------------ eval-errors [7] 100.0% [13] 302(0.2%) 0(0.0%) for-loop .../herbie/better-rr/src/points.rkt:205:2 ulp-difference [19] 100.0% ------------------------------------------------------------------------ oracle-error [8] 100.0% [14] 296(0.2%) 296(0.2%) for-loop .../herbie/better-rr/src/points.rkt:213:2 ------------------------------------------------------------------------ simplify! [9] 100.0% [15] 174658(97.6%) 0(0.0%) ??? ...herbie/better-rr/src/core/simplify.rkt:26:0 for-loop [20] 100.0% ------------------------------------------------------------------------ loop [10] 100.0% [16] 2720(1.5%) 0(0.0%) loop ...lies/herbie/better-rr/src/points.rkt:104:2 ??? [21] 85.0% ??? [24] 15.0% ------------------------------------------------------------------------ loop [11] 100.0% [17] 346(0.2%) 346(0.2%) ordinary-value? ...ie/better-rr/src/float.rkt:54:0 ------------------------------------------------------------------------ for-loop [12] 100.0% [18] 312(0.2%) 0(0.0%) run-iter! ...rbie/better-rr/src/mainloop.rkt:317:0 gen-rewrites! [22] 100.0% ------------------------------------------------------------------------ for-loop [13] 100.0% [19] 302(0.2%) 302(0.2%) ulp-difference ...bie/better-rr/src/float.rkt:14:0 ------------------------------------------------------------------------ ??? [15] 100.0% [20] 174658(97.6%) 0(0.0%) for-loop ...e/better-rr/src/core/simplify.rkt:33:2 one-iter [23] 100.0% ------------------------------------------------------------------------ loop [16] 100.0% [21] 2312(1.3%) 0(0.0%) ??? ...ies/herbie/better-rr/src/programs.rkt:146:2 ??? [25] 52.9% ??? [24] 47.1% ------------------------------------------------------------------------ run-iter! [18] 100.0% [22] 312(0.2%) 312(0.2%) gen-rewrites! .../better-rr/src/mainloop.rkt:172:0 ------------------------------------------------------------------------ for-loop [20] 100.0% [23] 174658(97.6%) 310(0.2%) one-iter ...e/better-rr/src/core/simplify.rkt:86:0 for-loop [26] 86.7% find-matches [27] 12.5% for-loop [30] 0.6% ------------------------------------------------------------------------ loop [16] 27.2% ??? [21] 72.8% [24] 1498(0.8%) 408(0.2%) ??? ...tract/private/arrow-higher-order.rkt:357:33 mk-ival [29] 72.8% ------------------------------------------------------------------------ ??? [21] 100.0% [25] 1222(0.7%) 0(0.0%) ??? ...t-7.0/collects/racket/private/kw.rkt:592:14 ??? [28] 100.0% ------------------------------------------------------------------------ one-iter [23] 100.0% [26] 151498(84.6%) 0(0.0%) for-loop ...e/better-rr/src/core/simplify.rkt:95:2 loop [31] 100.0% ------------------------------------------------------------------------ one-iter [23] 100.0% [27] 21846(12.2%) 0(0.0%) find-matches ...tter-rr/src/core/simplify.rkt:56:0 for-loop [32] 100.0% ------------------------------------------------------------------------ ??? [3] 22.2% ??? [25] 77.8% [28] 1570(0.9%) 0(0.0%) ??? ...tract/private/arrow-higher-order.rkt:361:33 ival-add [33] 77.8% ??? [36] 22.2% ------------------------------------------------------------------------ ??? [24] 100.0% [29] 1090(0.6%) 0(0.0%) mk-ival ...rbie/better-rr/src/biginterval.rkt:59:0 bf [34] 100.0% ------------------------------------------------------------------------ one-iter [23] 100.0% [30] 1004(0.6%) 0(0.0%) for-loop .../better-rr/src/core/simplify.rkt:111:2 set-precompute! [35] 100.0% ------------------------------------------------------------------------ loop [31] 0.4% for-loop [26] 99.6% [31] 151498(84.6%) 0(0.0%) loop ...rbie/better-rr/src/core/simplify.rkt:100:4 apply-match [37] 99.6% loop [31] 0.4% ------------------------------------------------------------------------ for-loop [32] 49.2% find-matches [27] 50.8% [32] 21846(12.2%) 2580(1.4%) for-loop ...e/better-rr/src/core/simplify.rkt:58:8 for-loop [32] 49.2% match-e [42] 43.4% ??? [69] 0.7% ------------------------------------------------------------------------ ??? [28] 100.0% [33] 1222(0.7%) 0(0.0%) ival-add ...bie/better-rr/src/biginterval.rkt:87:0 ??? [39] 73.3% ...higher-order.rkt:361:33 [40] 26.7% ------------------------------------------------------------------------ mk-ival [29] 100.0% [34] 1090(0.6%) 0(0.0%) bf ...ath-lib/math/private/bigfloat/mpfr.rkt:601:2 new-mpfr [48] 100.0% ------------------------------------------------------------------------ for-loop [30] 100.0% [35] 1004(0.6%) 0(0.0%) set-precompute! ...-rr/src/core/simplify.rkt:117:0 for-loop [38] 100.0% ------------------------------------------------------------------------ ??? [28] 100.0% [36] 348(0.2%) 348(0.2%) ??? ...cts/racket/contract/private/list.rkt:209:10 ------------------------------------------------------------------------ loop [31] 100.0% [37] 151498(84.6%) 300(0.2%) apply-match ...etter-rr/src/core/simplify.rkt:65:0 for-loop [41] 92.4% match-e [42] 5.2% set [66] 1.8% custom-set-intersect [45] 0.4% ------------------------------------------------------------------------ set-precompute! [35] 100.0% [38] 1004(0.6%) 0(0.0%) for-loop .../better-rr/src/core/simplify.rkt:119:2 setfindf [43] 100.0% ------------------------------------------------------------------------ ival-add [33] 100.0% [39] 896(0.5%) 298(0.2%) ??? ...-racket/utils/simple-result-arrow.rkt:39:12 bfadd [44] 66.7% ------------------------------------------------------------------------ ival-add [33] 100.0% [40] 326(0.2%) 326(0.2%) ...higher-order.rkt:361:33 (unknown source) ------------------------------------------------------------------------ apply-match [37] 100.0% [41] 140048(78.2%) 298(0.2%) for-loop ...e/better-rr/src/core/simplify.rkt:78:2 merge-egraph-nodes! [46] 59.4% dedup-children! [55] 39.7% substitute-e [50] 0.7% ------------------------------------------------------------------------ apply-match [37] 19.6% for-loop [56] 25.5% for-loop [32] 54.8% [42] 26774(15.0%) 4766(2.7%) match-e ...rbie/better-rr/src/core/ematch.rkt:39:0 for-loop [47] 73.2% ??? [67] 4.4% variable? [57] 3.7% make-sequence [49] 3.7% ------------------------------------------------------------------------ for-loop [38] 100.0% [43] 1004(0.6%) 332(0.2%) setfindf .../herbie/better-rr/src/common.rkt:139:0 for-loop [52] 33.5% custom-in-set [53] 33.5% ------------------------------------------------------------------------ ??? [39] 100.0% [44] 598(0.3%) 296(0.2%) bfadd ...-lib/math/private/bigfloat/mpfr.rkt:821:4 new-mpfr [48] 50.5% ------------------------------------------------------------------------ apply-match [37] 100.0% [45] 598(0.3%) 0(0.0%) custom-set-intersect ...rivate/set-types.rkt:195:0 for-loop [51] 100.0% ------------------------------------------------------------------------ merge-egraph-nodes! [46] 2.3% for-loop [41] 97.7% [46] 83180(46.5%) 0(0.0%) merge-egraph-nodes! ...r/src/core/egraph.rkt:145:0 loop! [54] 91.3% dedup-children! [55] 4.6% merge-egraph-nodes! [46] 2.3% update-leader! [61] 1.1% enode-merge! [62] 0.7% ------------------------------------------------------------------------ match-e [42] 100.0% [47] 22304(12.5%) 12028(6.7%) for-loop ...ie/better-rr/src/core/ematch.rkt:52:11 for-loop [56] 45.8% curried [60] 4.3% cartesian-product [58] 3.1% cp-2 [70] 1.3% foldr [63] 1.3% ------------------------------------------------------------------------ bfadd [44] 21.7% bf [34] 78.3% [48] 1392(0.8%) 1392(0.8%) new-mpfr ...b/math/private/bigfloat/mpfr.rkt:335:0 ------------------------------------------------------------------------ match-e [42] 100.0% [49] 984(0.5%) 984(0.5%) make-sequence ...ects/racket/private/for.rkt:528:2 ------------------------------------------------------------------------ for-loop [59] 22.0% for-loop [41] 78.0% [50] 982(0.5%) 0(0.0%) substitute-e ...better-rr/src/core/ematch.rkt:64:0 for-loop [59] 89.0% variable? [57] 11.0% ------------------------------------------------------------------------ custom-set-intersect [45] 100.0% [51] 598(0.3%) 598(0.3%) for-loop ...cts/racket/private/set-types.rkt:207:3 ------------------------------------------------------------------------ setfindf [43] 100.0% [52] 336(0.2%) 336(0.2%) for-loop .../herbie/better-rr/src/common.rkt:140:2 ------------------------------------------------------------------------ setfindf [43] 100.0% [53] 336(0.2%) 336(0.2%) custom-in-set ...acket/private/set-types.rkt:577:0 ------------------------------------------------------------------------ loop [65] 29.9% merge-egraph-nodes! [46] 70.1% [54] 77834(43.5%) 15588(8.7%) loop! ...herbie/better-rr/src/core/enode.rkt:191:2 custom-set-union [73] 43.6% loop [65] 34.3% set [66] 11.0% ------------------------------------------------------------------------ merge-egraph-nodes! [46] 6.5% for-loop [41] 93.5% [55] 59424(33.2%) 0(0.0%) dedup-children! ...ter-rr/src/core/enode.rkt:199:0 loop [64] 100.0% ------------------------------------------------------------------------ for-loop [47] 100.0% [56] 13052(7.3%) 332(0.2%) for-loop ...ie/better-rr/src/core/ematch.rkt:58:37 match-e [42] 94.9% ??? [69] 2.5% ------------------------------------------------------------------------ substitute-e [50] 11.3% match-e [42] 88.7% [57] 2868(1.6%) 300(0.2%) variable? ...etter-rr/src/syntax/syntax.rkt:1159:0 ??? [67] 89.5% ------------------------------------------------------------------------ for-loop [47] 100.0% [58] 1038(0.6%) 1038(0.6%) cartesian-product ...ollects/racket/list.rkt:822:0 ------------------------------------------------------------------------ substitute-e [50] 100.0% [59] 982(0.5%) 334(0.2%) for-loop ...ie/better-rr/src/core/ematch.rkt:73:24 substitute-e [50] 33.0% mk-enode! [72] 33.0% ------------------------------------------------------------------------ for-loop [47] 100.0% [60] 970(0.5%) 970(0.5%) curried ...-7.0/collects/racket/function.rkt:71:18 ------------------------------------------------------------------------ merge-egraph-nodes! [46] 100.0% [61] 914(0.5%) 0(0.0%) update-leader! ...ter-rr/src/core/egraph.rkt:213:0 for-loop [68] 100.0% ------------------------------------------------------------------------ merge-egraph-nodes! [46] 100.0% [62] 596(0.3%) 0(0.0%) enode-merge! ...better-rr/src/core/enode.rkt:128:0 adopt-enode! [71] 100.0% ------------------------------------------------------------------------ for-loop [47] 100.0% [63] 300(0.2%) 0(0.0%) foldr ....0/collects/racket/private/list.rkt:242:4 cp-2 [70] 100.0% ------------------------------------------------------------------------ dedup-children! [55] 9.7% loop [64] 90.3% [64] 59424(33.2%) 59424(33.2%) loop ...racket-7.0/collects/racket/list.rkt:434:17 loop [64] 90.3% ------------------------------------------------------------------------ loop! [54] 4.6% loop [65] 95.4% [65] 45808(25.6%) 3550(2.0%) loop ...-7.0/collects/racket/private/map.rkt:40:19 loop [65] 95.4% loop! [54] 4.3% ------------------------------------------------------------------------ apply-match [37] 12.7% loop! [54] 87.3% [66] 21532(12.0%) 19388(10.8%) set ...collects/racket/private/set-types.rkt:981:0 for-loop [74] 10.0% ------------------------------------------------------------------------ variable? [57] 47.1% match-e [42] 52.9% [67] 5448(3.0%) 5448(3.0%) ??? ...contract/private/arrow-val-first.rkt:388:18 ------------------------------------------------------------------------ update-leader! [61] 100.0% [68] 914(0.5%) 0(0.0%) for-loop ...ie/better-rr/src/core/egraph.rkt:218:6 hash-update! [79] 67.2% for-loop [76] 32.8% ------------------------------------------------------------------------ for-loop [32] 47.5% for-loop [56] 52.5% [69] 632(0.4%) 332(0.2%) ??? ...s/herbie/better-rr/src/core/ematch.rkt:43:5 for-loop [75] 47.5% ------------------------------------------------------------------------ foldr [63] 50.0% for-loop [47] 50.0% [70] 600(0.3%) 600(0.3%) cp-2 .../racket-7.0/collects/racket/list.rkt:826:2 ------------------------------------------------------------------------ enode-merge! [62] 100.0% [71] 596(0.3%) 298(0.2%) adopt-enode! ...better-rr/src/core/enode.rkt:104:0 custom-set-union [73] 50.0% ------------------------------------------------------------------------ for-loop [59] 100.0% [72] 324(0.2%) 324(0.2%) mk-enode! ...ie/better-rr/src/core/egraph.rkt:99:0 ------------------------------------------------------------------------ adopt-enode! [71] 0.8% loop! [54] 99.2% [73] 38910(21.7%) 11474(6.4%) custom-set-union ...et/private/set-types.rkt:168:0 for-loop [77] 63.0% for-loop [78] 7.5% ------------------------------------------------------------------------ set [66] 100.0% [74] 2144(1.2%) 2144(1.2%) for-loop ...cts/racket/private/set-types.rkt:937:4 ------------------------------------------------------------------------ ??? [69] 100.0% [75] 300(0.2%) 300(0.2%) for-loop ...bie/better-rr/src/core/ematch.rkt:44:7 ------------------------------------------------------------------------ for-loop [68] 100.0% [76] 300(0.2%) 0(0.0%) for-loop ...ie/better-rr/src/core/egraph.rkt:219:8 hash-update! [79] 100.0% ------------------------------------------------------------------------ custom-set-union [73] 100.0% [77] 24522(13.7%) 6398(3.6%) for-loop ...cts/racket/private/set-types.rkt:174:3 for-loop [80] 73.9% ------------------------------------------------------------------------ custom-set-union [73] 100.0% [78] 2914(1.6%) 2914(1.6%) for-loop ...cts/racket/private/set-types.rkt:152:2 ------------------------------------------------------------------------ for-loop [76] 32.8% for-loop [68] 67.2% [79] 914(0.5%) 0(0.0%) hash-update! ...cket/private/more-scheme.rkt:365:4 ??? [81] 100.0% ------------------------------------------------------------------------ for-loop [77] 100.0% [80] 18124(10.1%) 18124(10.1%) for-loop ...cts/racket/private/set-types.rkt:178:5 ------------------------------------------------------------------------ hash-update! [79] 100.0% [81] 914(0.5%) 0(0.0%) ??? ...herbie/better-rr/src/core/egraph.rkt:221:24 for-loop [82] 100.0% ------------------------------------------------------------------------ ??? [81] 100.0% [82] 914(0.5%) 914(0.5%) for-loop ...e/better-rr/src/core/egraph.rkt:222:26 ------------------------------------------------------------------------