Profiling results ----------------- Total cpu time observed: 28526ms (out of 29032ms) Number of samples taken: 83 (once every 344ms) ====================================================================== Caller Idx Total Self Name+src Local% ms(pct) ms(pct) Callee ====================================================================== run [7] 50.0% [1] 28526(100.0%) 0(0.0%) ??? ...lects/racket/private/more-scheme.rkt:261:28 profile-thunk16 [2] 50.0% prepare-points-intervals [8] 36.0% run-improve40 [3] 10.6% errors [4] 1.2% oracle-error [5] 1.1% eval-errors [21] 0.6% baseline-error [6] 0.5% ---------------------------------------------------------------------- ??? [1] 100.0% [2] 28526(100.0%) 0(0.0%) profile-thunk16 ...e/pkgs/profile-lib/main.rkt:9:0 run [7] 100.0% ---------------------------------------------------------------------- ??? [1] 100.0% [3] 6052(21.2%) 0(0.0%) run-improve40 ...ie/develop/src/mainloop.rkt:340:0 simplify! [9] 90.3% prepare-points-intervals [8] 9.7% ---------------------------------------------------------------------- ??? [1] 100.0% [4] 688(2.4%) 0(0.0%) errors ...lies/herbie/develop/src/points.rkt:228:0 for-loop [10] 100.0% ---------------------------------------------------------------------- ??? [1] 100.0% [5] 636(2.2%) 0(0.0%) oracle-error ...erbie/develop/src/points.rkt:212:0 for-loop [11] 100.0% ---------------------------------------------------------------------- ??? [1] 100.0% [6] 306(1.1%) 0(0.0%) baseline-error ...bie/develop/src/points.rkt:216:0 argmin [12] 100.0% ---------------------------------------------------------------------- profile-thunk16 [2] 100.0% [7] 28526(100.0%) 0(0.0%) run ...et-7.0/share/pkgs/profile-lib/main.rkt:39:2 ??? [1] 100.0% ---------------------------------------------------------------------- run-improve40 [3] 2.8% ??? [1] 97.2% [8] 21108(74.0%) 0(0.0%) prepare-points-intervals ...p/src/points.rkt:133:0 loop [13] 100.0% ---------------------------------------------------------------------- run-improve40 [3] 100.0% [9] 5464(19.2%) 0(0.0%) simplify! ...herbie/develop/src/mainloop.rkt:217:0 ??? [14] 100.0% ---------------------------------------------------------------------- errors [4] 100.0% [10] 688(2.4%) 0(0.0%) for-loop ...es/herbie/develop/src/points.rkt:230:2 point-error [16] 55.2% ??? [23] 44.8% ---------------------------------------------------------------------- oracle-error [5] 100.0% [11] 636(2.2%) 310(1.1%) for-loop ...es/herbie/develop/src/points.rkt:213:2 loop [15] 51.3% ---------------------------------------------------------------------- baseline-error [6] 100.0% [12] 306(1.1%) 0(0.0%) argmin ...acket-7.0/collects/racket/list.rkt:765:0 ??? [17] 100.0% ---------------------------------------------------------------------- prepare-points-intervals [8] 100.0% [13] 21108(74.0%) 338(1.2%) loop ...htlies/herbie/develop/src/points.rkt:145:4 loop [18] 97.0% ??? [22] 1.4% ---------------------------------------------------------------------- simplify! [9] 100.0% [14] 5464(19.2%) 0(0.0%) ??? ...s/herbie/develop/src/core/simplify.rkt:26:0 for-loop [19] 82.9% loop [20] 17.1% ---------------------------------------------------------------------- loop! [70] 9.4% for-loop [11] 20.5% loop [15] 70.1% [15] 1590(5.6%) 0(0.0%) loop ...-7.0/collects/racket/private/map.rkt:40:19 loop [15] 70.1% ??? [23] 20.5% loop! [70] 9.4% ---------------------------------------------------------------------- for-loop [10] 100.0% [16] 380(1.3%) 0(0.0%) point-error ...herbie/develop/src/points.rkt:195:0 ulp-difference [31] 100.0% ---------------------------------------------------------------------- argmin [12] 100.0% [17] 306(1.1%) 0(0.0%) ??? ...htlies/herbie/develop/src/points.rkt:217:27 eval-errors [21] 100.0% ---------------------------------------------------------------------- loop [13] 100.0% [18] 20482(71.8%) 0(0.0%) loop ...htlies/herbie/develop/src/points.rkt:104:2 ??? [23] 87.2% ??? [37] 9.5% ??? [25] 3.3% ---------------------------------------------------------------------- ??? [14] 100.0% [19] 4530(15.9%) 0(0.0%) for-loop ...bie/develop/src/core/simplify.rkt:33:2 one-iter [24] 100.0% ---------------------------------------------------------------------- ??? [14] 100.0% [20] 934(3.3%) 0(0.0%) loop ...herbie/develop/src/core/simplify.rkt:143:2 for-loop [27] 66.8% debug-print [28] 33.2% ---------------------------------------------------------------------- ??? [17] 48.6% ??? [1] 51.4% [21] 630(2.2%) 0(0.0%) eval-errors ...herbie/develop/src/points.rkt:203:0 for-loop [26] 100.0% ---------------------------------------------------------------------- loop [13] 100.0% [22] 288(1.0%) 0(0.0%) ??? ...ghtlies/herbie/develop/src/points.rkt:129:2 ??? [37] 100.0% ---------------------------------------------------------------------- for-loop [10] 1.7% loop [15] 1.8% loop [18] 96.6% [23] 18490(64.8%) 334(1.2%) ??? ...tlies/herbie/develop/src/programs.rkt:146:2 ??? [29] 89.6% ??? [37] 8.6% ---------------------------------------------------------------------- for-loop [19] 100.0% [24] 4530(15.9%) 0(0.0%) one-iter ...bie/develop/src/core/simplify.rkt:86:0 for-loop [30] 87.3% find-matches [33] 12.7% ---------------------------------------------------------------------- loop [18] 100.0% [25] 672(2.4%) 324(1.1%) ??? ...contract/private/arrow-val-first.rkt:388:18 ??? [34] 51.8% ---------------------------------------------------------------------- eval-errors [21] 100.0% [26] 630(2.2%) 0(0.0%) for-loop ...es/herbie/develop/src/points.rkt:205:2 ??? [37] 51.4% ulp-difference [31] 48.6% ---------------------------------------------------------------------- loop [20] 100.0% [27] 624(2.2%) 0(0.0%) for-loop ...ie/develop/src/core/simplify.rkt:149:4 loop [32] 100.0% ---------------------------------------------------------------------- loop [20] 100.0% [28] 310(1.1%) 0(0.0%) debug-print .../herbie/develop/src/debug.rkt:110:0 ??? [35] 100.0% ---------------------------------------------------------------------- ??? [23] 100.0% [29] 16558(58.0%) 310(1.1%) ??? ...t-7.0/collects/racket/private/kw.rkt:592:14 ??? [36] 66.2% ??? [37] 31.9% ---------------------------------------------------------------------- one-iter [24] 100.0% [30] 3956(13.9%) 0(0.0%) for-loop ...bie/develop/src/core/simplify.rkt:95:2 loop [38] 92.5% update-leader! [72] 7.5% ---------------------------------------------------------------------- for-loop [26] 44.6% point-error [16] 55.4% [31] 686(2.4%) 380(1.3%) ulp-difference ...erbie/develop/src/float.rkt:14:0 return/no-unsupplied [42] 44.6% ---------------------------------------------------------------------- for-loop [27] 100.0% [32] 624(2.2%) 0(0.0%) loop .../racket-7.0/collects/racket/list.rkt:751:4 expression-cost [39] 100.0% ---------------------------------------------------------------------- one-iter [24] 100.0% [33] 574(2.0%) 0(0.0%) find-matches ...develop/src/core/simplify.rkt:56:0 for-loop [40] 100.0% ---------------------------------------------------------------------- ??? [25] 100.0% [34] 348(1.2%) 0(0.0%) ??? ...ects/racket/contract/private/prop.rkt:519:4 ??? [41] 100.0% ---------------------------------------------------------------------- debug-print [28] 100.0% [35] 310(1.1%) 310(1.1%) ??? .../contract/private/arrow-val-first.rkt:428:3 ---------------------------------------------------------------------- fold-binary-pred [69] 7.8% ??? [29] 92.2% [36] 11350(39.8%) 1730(6.1%) ??? ...tract/private/arrow-higher-order.rkt:361:33 ival-fma [43] 46.5% ival-add [45] 26.2% ival-sub [47] 16.5% ---------------------------------------------------------------------- ??? [22] 3.0% for-loop [26] 3.4% ??? [23] 16.9% loop [18] 20.7% ??? [29] 55.9% [37] 9444(33.1%) 324(1.1%) ??? ...tract/private/arrow-higher-order.rkt:357:33 ival-mult [53] 55.9% ->flonum [46] 27.4% mk-ival [48] 10.2% sample-multi-bounded [52] 3.0% ---------------------------------------------------------------------- for-loop [30] 100.0% [38] 3658(12.8%) 0(0.0%) loop ...herbie/develop/src/core/simplify.rkt:100:4 apply-match [44] 100.0% ---------------------------------------------------------------------- loop [32] 100.0% [39] 624(2.2%) 0(0.0%) expression-cost .../develop/src/programs.rkt:204:0 compile [49] 100.0% ---------------------------------------------------------------------- for-loop [40] 50.0% find-matches [33] 50.0% [40] 574(2.0%) 0(0.0%) for-loop ...bie/develop/src/core/simplify.rkt:58:8 for-loop [40] 50.0% match-e [50] 50.0% ---------------------------------------------------------------------- ??? [34] 100.0% [41] 348(1.2%) 348(1.2%) ??? ...lects/racket/contract/private/orc.rkt:83:14 ---------------------------------------------------------------------- ulp-difference [31] 100.0% [42] 306(1.1%) 0(0.0%) return/no-unsupplied ...ct/private/arr-i.rkt:534:0 filter [51] 100.0% ---------------------------------------------------------------------- ??? [36] 100.0% [43] 5788(20.3%) 292(1.0%) ival-fma ...rbie/develop/src/biginterval.rkt:254:0 ival-mult [53] 89.5% ??? [68] 5.5% ---------------------------------------------------------------------- loop [38] 100.0% [44] 3658(12.8%) 0(0.0%) apply-match .../develop/src/core/simplify.rkt:65:0 for-loop [54] 91.9% custom-set-intersect [59] 8.1% ---------------------------------------------------------------------- ??? [36] 100.0% [45] 2970(10.4%) 0(0.0%) ival-add ...erbie/develop/src/biginterval.rkt:87:0 ??? [68] 100.0% ---------------------------------------------------------------------- ??? [37] 100.0% [46] 2588(9.1%) 2286(8.0%) ->flonum ...s/herbie/develop/src/programs.rkt:38:0 ??? [58] 11.7% ---------------------------------------------------------------------- ??? [36] 100.0% [47] 1874(6.6%) 0(0.0%) ival-sub ...erbie/develop/src/biginterval.rkt:93:0 ??? [68] 84.0% ...higher-order.rkt:361:33 [63] 16.0% ---------------------------------------------------------------------- ??? [37] 100.0% [48] 964(3.4%) 296(1.0%) mk-ival ...herbie/develop/src/biginterval.rkt:59:0 bf [55] 69.3% ---------------------------------------------------------------------- expression-cost [39] 100.0% [49] 624(2.2%) 0(0.0%) compile ...s/herbie/develop/src/programs.rkt:181:0 hash-ref! [56] 100.0% ---------------------------------------------------------------------- for-loop [67] 24.6% for-loop [40] 75.4% [50] 574(2.0%) 0(0.0%) match-e ...herbie/develop/src/core/ematch.rkt:39:0 for-loop [57] 100.0% ---------------------------------------------------------------------- return/no-unsupplied [42] 100.0% [51] 306(1.1%) 306(1.1%) filter ...0/collects/racket/private/list.rkt:256:2 ---------------------------------------------------------------------- ??? [37] 100.0% [52] 288(1.0%) 288(1.0%) sample-multi-bounded ...evelop/src/points.rkt:16:0 ---------------------------------------------------------------------- ival-fma [43] 49.5% ??? [37] 50.5% [53] 10458(36.7%) 1626(5.7%) ival-mult ...bie/develop/src/biginterval.rkt:105:0 bf* [60] 47.4% classify-ival [61] 33.9% ...higher-order.rkt:361:33 [63] 3.1% ---------------------------------------------------------------------- apply-match [44] 100.0% [54] 3360(11.8%) 0(0.0%) for-loop ...bie/develop/src/core/simplify.rkt:78:2 merge-egraph-nodes! [62] 82.1% dedup-children! [73] 17.9% ---------------------------------------------------------------------- mk-ival [48] 100.0% [55] 668(2.3%) 0(0.0%) bf ...ath-lib/math/private/bigfloat/mpfr.rkt:601:2 new-mpfr [84] 100.0% ---------------------------------------------------------------------- ??? [64] 34.6% compile [49] 65.4% [56] 624(2.2%) 300(1.1%) hash-ref! .../racket/private/more-scheme.rkt:376:2 ??? [64] 51.9% ---------------------------------------------------------------------- match-e [50] 100.0% [57] 574(2.0%) 574(2.0%) for-loop ...rbie/develop/src/core/ematch.rkt:52:11 for-loop [67] 24.6% ---------------------------------------------------------------------- ->flonum [46] 100.0% [58] 302(1.1%) 0(0.0%) ??? ...s/racket/contract/private/arr-i.rkt:1252:29 ??? [65] 100.0% ---------------------------------------------------------------------- apply-match [44] 100.0% [59] 298(1.0%) 0(0.0%) custom-set-intersect ...rivate/set-types.rkt:195:0 for-loop [66] 100.0% ---------------------------------------------------------------------- ival-mult [53] 100.0% [60] 4958(17.4%) 0(0.0%) bf* ...ath/private/bigfloat/bigfloat-mpfr.rkt:95:0 ??? [68] 100.0% ---------------------------------------------------------------------- ival-mult [53] 100.0% [61] 3548(12.4%) 300(1.1%) classify-ival ...develop/src/biginterval.rkt:310:0 fold-binary-pred [69] 47.8% force [71] 35.1% ...higher-order.rkt:357:33 [75] 8.7% ---------------------------------------------------------------------- merge-egraph-nodes! [62] 11.4% for-loop [74] 16.3% for-loop [54] 72.3% [62] 2760(9.7%) 0(0.0%) merge-egraph-nodes! ...p/src/core/egraph.rkt:145:0 loop! [70] 45.2% update-leader! [72] 21.7% for-loop [74] 16.3% merge-egraph-nodes! [62] 11.4% dedup-children! [73] 5.4% ---------------------------------------------------------------------- ival-sub [47] 47.9% ival-mult [53] 52.1% [63] 626(2.2%) 300(1.1%) ...higher-order.rkt:361:33 (unknown source) ??? [80] 52.1% ---------------------------------------------------------------------- hash-ref! [56] 100.0% [64] 324(1.1%) 324(1.1%) ??? ...tlies/herbie/develop/src/programs.rkt:189:5 hash-ref! [56] 66.7% ---------------------------------------------------------------------- ??? [58] 100.0% [65] 302(1.1%) 302(1.1%) ??? ...ects/racket/contract/private/prop.rkt:274:4 ---------------------------------------------------------------------- custom-set-intersect [59] 100.0% [66] 298(1.0%) 0(0.0%) for-loop ...cts/racket/private/set-types.rkt:207:3 for-loop [76] 100.0% ---------------------------------------------------------------------- for-loop [57] 100.0% [67] 282(1.0%) 0(0.0%) for-loop ...rbie/develop/src/core/ematch.rkt:58:37 match-e [50] 100.0% ---------------------------------------------------------------------- ival-fma [43] 3.2% ival-sub [47] 16.0% ival-add [45] 30.2% bf* [60] 50.5% [68] 9820(34.4%) 1000(3.5%) ??? ...-racket/utils/simple-result-arrow.rkt:39:12 bfmul [77] 89.8% ---------------------------------------------------------------------- classify-ival [61] 100.0% [69] 1696(5.9%) 302(1.1%) fold-binary-pred ...gfloat/bigfloat-mpfr.rkt:117:0 ??? [36] 82.2% ---------------------------------------------------------------------- loop [15] 40.5% merge-egraph-nodes! [62] 59.5% [70] 1562(5.5%) 296(1.0%) loop! ...s/herbie/develop/src/core/enode.rkt:191:2 loop [15] 40.5% set [79] 31.0% custom-set-union [83] 19.1% ---------------------------------------------------------------------- classify-ival [61] 100.0% [71] 1244(4.4%) 1244(4.4%) force ...collects/racket/private/promise.rkt:109:0 ---------------------------------------------------------------------- for-loop [30] 24.9% merge-egraph-nodes! [62] 75.1% [72] 1196(4.2%) 0(0.0%) update-leader! ...evelop/src/core/egraph.rkt:213:0 for-loop [78] 100.0% ---------------------------------------------------------------------- merge-egraph-nodes! [62] 33.3% for-loop [54] 66.7% [73] 900(3.2%) 0(0.0%) dedup-children! ...evelop/src/core/enode.rkt:199:0 loop [81] 66.7% loop [82] 33.3% ---------------------------------------------------------------------- merge-egraph-nodes! [62] 100.0% [74] 900(3.2%) 0(0.0%) for-loop ...rbie/develop/src/core/egraph.rkt:199:4 merge-egraph-nodes! [62] 100.0% ---------------------------------------------------------------------- classify-ival [61] 100.0% [75] 308(1.1%) 0(0.0%) ...higher-order.rkt:357:33 (unknown source) ??? [80] 100.0% ---------------------------------------------------------------------- for-loop [66] 100.0% [76] 298(1.0%) 298(1.0%) for-loop ...cts/racket/private/set-types.rkt:201:4 ---------------------------------------------------------------------- ??? [68] 100.0% [77] 8820(30.9%) 592(2.1%) bfmul ...-lib/math/private/bigfloat/mpfr.rkt:821:4 new-mpfr [84] 55.5% ??? [85] 37.8% ---------------------------------------------------------------------- update-leader! [72] 100.0% [78] 1196(4.2%) 0(0.0%) for-loop ...rbie/develop/src/core/egraph.rkt:218:6 for-loop [86] 50.0% hash-update! [90] 50.0% ---------------------------------------------------------------------- loop! [70] 100.0% [79] 968(3.4%) 968(3.4%) set ...collects/racket/private/set-types.rkt:981:0 ---------------------------------------------------------------------- ...higher-order.rkt:357:33 [75] 48.6% ...higher-order.rkt:361:33 [63] 51.4% [80] 634(2.2%) 326(1.1%) ??? ...cts/racket/contract/private/list.rkt:209:10 ??? [87] 48.6% ---------------------------------------------------------------------- dedup-children! [73] 19.8% loop [81] 80.2% [81] 600(2.1%) 600(2.1%) loop ...racket-7.0/collects/racket/list.rkt:434:17 loop [81] 80.2% ---------------------------------------------------------------------- dedup-children! [73] 10.0% loop [82] 90.0% [82] 300(1.1%) 0(0.0%) loop ...racket-7.0/collects/racket/list.rkt:417:34 loop [82] 90.0% loop [88] 10.0% ---------------------------------------------------------------------- loop! [70] 100.0% [83] 298(1.0%) 0(0.0%) custom-set-union ...et/private/set-types.rkt:168:0 for-loop [89] 100.0% ---------------------------------------------------------------------- bf [55] 12.0% bfmul [77] 88.0% [84] 5564(19.5%) 5564(19.5%) new-mpfr ...b/math/private/bigfloat/mpfr.rkt:335:0 ---------------------------------------------------------------------- bfmul [77] 100.0% [85] 3332(11.7%) 3332(11.7%) ??? /opt/racket-7.0/collects/ffi/unsafe.rkt:898:4 ---------------------------------------------------------------------- for-loop [78] 100.0% [86] 598(2.1%) 0(0.0%) for-loop ...rbie/develop/src/core/egraph.rkt:219:8 hash-update! [90] 100.0% ---------------------------------------------------------------------- ??? [80] 100.0% [87] 308(1.1%) 308(1.1%) ??? ...ects/racket/contract/private/guts.rkt:746:8 ---------------------------------------------------------------------- loop [82] 100.0% [88] 300(1.1%) 300(1.1%) loop (unknown source) ---------------------------------------------------------------------- custom-set-union [83] 100.0% [89] 298(1.0%) 298(1.0%) for-loop ...cts/racket/private/set-types.rkt:174:3 ---------------------------------------------------------------------- for-loop [78] 50.0% for-loop [86] 50.0% [90] 1196(4.2%) 0(0.0%) hash-update! ...cket/private/more-scheme.rkt:365:4 ??? [91] 100.0% ---------------------------------------------------------------------- hash-update! [90] 100.0% [91] 1196(4.2%) 0(0.0%) ??? ...s/herbie/develop/src/core/egraph.rkt:221:24 for-loop [92] 100.0% ---------------------------------------------------------------------- ??? [91] 100.0% [92] 1196(4.2%) 1196(4.2%) for-loop ...bie/develop/src/core/egraph.rkt:222:26 ----------------------------------------------------------------------