Profiling results ----------------- Total cpu time observed: 23186ms (out of 23432ms) Number of samples taken: 114 (once every 203ms) (Hiding functions with self<1.0% and local<2.0%: 1 of 80 hidden) ==================================================================== Caller Idx Total Self Name+src Local% ms(pct) ms(pct) Callee ==================================================================== ??? [7] 100.0% [1] 23186(100.0%) 0(0.0%) profile-thunk16 ...e/pkgs/profile-lib/main.rkt:9:0 run [4] 100.0% -------------------------------------------------------------------- ??? [7] 100.0% [2] 16930(73.0%) 0(0.0%) run-improve40 ...ie/develop/src/mainloop.rkt:336:0 simplify! [5] 100.0% -------------------------------------------------------------------- ??? [7] 100.0% [3] 174(0.8%) 0(0.0%) get-final-combination ...op/src/mainloop.rkt:357:0 ??? [6] 100.0% -------------------------------------------------------------------- profile-thunk16 [1] 100.0% [4] 23186(100.0%) 0(0.0%) run ...et-7.0/share/pkgs/profile-lib/main.rkt:39:2 ??? [7] 100.0% -------------------------------------------------------------------- run-improve40 [2] 100.0% [5] 16930(73.0%) 0(0.0%) simplify! ...herbie/develop/src/mainloop.rkt:213:0 ??? [8] 100.0% -------------------------------------------------------------------- get-final-combination [3] 100.0% [6] 174(0.8%) 0(0.0%) ??? ...s/herbie/develop/src/core/simplify.rkt:22:0 ??? [8] 100.0% -------------------------------------------------------------------- run [4] 50.0% [7] 23186(100.0%) 0(0.0%) ??? ...lects/racket/private/more-scheme.rkt:261:28 profile-thunk16 [1] 50.0% run-improve40 [2] 36.5% prepare-points-intervals [10] 11.1% eval-errors [11] 1.0% oracle-error [12] 0.5% errors [13] 0.5% get-final-combination [3] 0.4% -------------------------------------------------------------------- ??? [6] 1.0% simplify! [5] 99.0% [8] 17104(73.8%) 0(0.0%) ??? ...s/herbie/develop/src/core/simplify.rkt:26:0 for-loop [9] 99.0% one-iter [14] 1.0% -------------------------------------------------------------------- ??? [8] 100.0% [9] 16930(73.0%) 0(0.0%) for-loop ...bie/develop/src/core/simplify.rkt:33:2 one-iter [14] 100.0% -------------------------------------------------------------------- ??? [7] 100.0% [10] 5146(22.2%) 0(0.0%) prepare-points-intervals ...p/src/points.rkt:133:0 loop [15] 100.0% -------------------------------------------------------------------- ??? [7] 100.0% [11] 478(2.1%) 0(0.0%) eval-errors ...herbie/develop/src/points.rkt:203:0 for-loop [16] 100.0% -------------------------------------------------------------------- ??? [7] 100.0% [12] 240(1.0%) 0(0.0%) oracle-error ...erbie/develop/src/points.rkt:212:0 for-loop [17] 100.0% -------------------------------------------------------------------- ??? [7] 100.0% [13] 218(0.9%) 0(0.0%) errors ...lies/herbie/develop/src/points.rkt:228:0 for-loop [18] 100.0% -------------------------------------------------------------------- ??? [8] 1.0% for-loop [9] 99.0% [14] 17104(73.8%) 0(0.0%) one-iter ...bie/develop/src/core/simplify.rkt:86:0 for-loop [19] 80.6% find-matches [21] 19.4% -------------------------------------------------------------------- prepare-points-intervals [10]100.0% [15] 5146(22.2%) 0(0.0%) loop ...htlies/herbie/develop/src/points.rkt:145:4 loop [20] 69.6% ??? [22] 30.4% -------------------------------------------------------------------- eval-errors [11] 100.0% [16] 478(2.1%) 0(0.0%) for-loop ...es/herbie/develop/src/points.rkt:205:2 ??? [33] 50.2% ??? [28] 49.8% -------------------------------------------------------------------- oracle-error [12] 100.0% [17] 240(1.0%) 0(0.0%) for-loop ...es/herbie/develop/src/points.rkt:213:2 map [23] 100.0% -------------------------------------------------------------------- errors [13] 100.0% [18] 218(0.9%) 218(0.9%) for-loop ...es/herbie/develop/src/points.rkt:230:2 -------------------------------------------------------------------- one-iter [14] 100.0% [19] 13780(59.4%) 0(0.0%) for-loop ...bie/develop/src/core/simplify.rkt:95:2 loop [24] 100.0% -------------------------------------------------------------------- loop [15] 100.0% [20] 3580(15.4%) 0(0.0%) loop ...htlies/herbie/develop/src/points.rkt:104:2 ??? [28] 87.5% ??? [33] 12.5% -------------------------------------------------------------------- one-iter [14] 100.0% [21] 3324(14.3%) 0(0.0%) find-matches ...develop/src/core/simplify.rkt:56:0 for-loop [25] 100.0% -------------------------------------------------------------------- loop [15] 100.0% [22] 1566(6.8%) 0(0.0%) ??? ...ghtlies/herbie/develop/src/points.rkt:129:2 ??? [33] 100.0% -------------------------------------------------------------------- for-loop [17] 100.0% [23] 240(1.0%) 0(0.0%) map ...t-7.0/collects/racket/private/map.rkt:35:13 ??? [26] 100.0% -------------------------------------------------------------------- for-loop [19] 100.0% [24] 13780(59.4%) 0(0.0%) loop ...herbie/develop/src/core/simplify.rkt:100:4 apply-match [27] 100.0% -------------------------------------------------------------------- for-loop [25] 50.0% find-matches [21] 50.0% [25] 3324(14.3%) 374(1.6%) for-loop ...bie/develop/src/core/simplify.rkt:58:8 for-loop [25] 50.0% match-e [30] 44.4% -------------------------------------------------------------------- map [23] 100.0% [26] 240(1.0%) 0(0.0%) ??? ...htlies/herbie/develop/src/points.rkt:214:26 ??? [28] 100.0% -------------------------------------------------------------------- loop [24] 100.0% [27] 13780(59.4%) 170(0.7%) apply-match .../develop/src/core/simplify.rkt:65:0 for-loop [29] 87.5% match-e [30] 8.2% set [54] 3.1% -------------------------------------------------------------------- for-loop [16] 6.6% ??? [26] 6.6% loop [20] 86.8% [28] 3610(15.6%) 0(0.0%) ??? ...tlies/herbie/develop/src/programs.rkt:146:2 ??? [31] 86.8% ??? [33] 13.2% -------------------------------------------------------------------- apply-match [27] 100.0% [29] 12060(52.0%) 0(0.0%) for-loop ...bie/develop/src/core/simplify.rkt:78:2 merge-egraph-nodes! [32] 76.1% dedup-children! [52] 22.3% substitute-e [37] 1.6% -------------------------------------------------------------------- apply-match [27] 18.1% for-loop [40] 28.1% for-loop [25] 53.8% [30] 4074(17.6%) 698(3.0%) match-e ...herbie/develop/src/core/ematch.rkt:39:0 for-loop [34] 82.4% ??? [36] 2.6% -------------------------------------------------------------------- ??? [28] 100.0% [31] 3132(13.5%) 260(1.1%) ??? ...t-7.0/collects/racket/private/kw.rkt:592:14 ??? [33] 70.1% ??? [35] 21.6% -------------------------------------------------------------------- for-loop [44] 1.8% merge-egraph-nodes! [32] 3.9% for-loop [29] 94.3% [32] 9180(39.6%) 156(0.7%) merge-egraph-nodes! ...p/src/core/egraph.rkt:145:0 loop! [38] 62.1% update-leader! [39] 26.1% for-loop [44] 4.4% merge-egraph-nodes! [32] 3.9% enode-merge! [50] 1.8% -------------------------------------------------------------------- for-loop [16] 4.9% loop [20] 9.1% ??? [28] 9.7% ??? [22] 31.8% ??? [31] 44.6% [33] 4928(21.3%) 516(2.2%) ??? ...tract/private/arrow-higher-order.rkt:357:33 ival-mult [41] 44.6% sample-multi-bounded [42] 26.2% ->flonum [43] 18.8% -------------------------------------------------------------------- match-e [30] 100.0% [34] 3550(15.3%) 2584(11.1%) for-loop ...rbie/develop/src/core/ematch.rkt:52:11 for-loop [40] 37.6% loop [51] 5.7% filter [47] 2.7% loop [49] 2.6% -------------------------------------------------------------------- ??? [31] 100.0% [35] 676(2.9%) 0(0.0%) ??? ...tract/private/arrow-higher-order.rkt:361:33 ival-add [45] 65.7% ival-sub [46] 34.3% -------------------------------------------------------------------- match-e [30] 100.0% [36] 208(0.9%) 208(0.9%) ??? ...contract/private/arrow-val-first.rkt:388:18 -------------------------------------------------------------------- for-loop [29] 100.0% [37] 194(0.8%) 0(0.0%) substitute-e ...e/develop/src/core/ematch.rkt:64:0 for-loop [48] 100.0% -------------------------------------------------------------------- loop [51] 42.4% merge-egraph-nodes! [32] 57.6% [38] 6120(26.4%) 2226(9.6%) loop! ...s/herbie/develop/src/core/enode.rkt:191:2 loop [51] 46.4% custom-set-union [56] 21.5% set [54] 11.3% update-en-expr [79] 5.1% -------------------------------------------------------------------- merge-egraph-nodes! [32] 100.0% [39] 2502(10.8%) 0(0.0%) update-leader! ...evelop/src/core/egraph.rkt:213:0 for-loop [53] 84.3% for-loop [58] 15.7% -------------------------------------------------------------------- for-loop [34] 100.0% [40] 2286(9.9%) 0(0.0%) for-loop ...rbie/develop/src/core/ematch.rkt:58:37 match-e [30] 100.0% -------------------------------------------------------------------- ??? [33] 100.0% [41] 2196(9.5%) 422(1.8%) ival-mult ...bie/develop/src/biginterval.rkt:105:0 bf* [55] 70.4% classify-ival [59] 10.4% -------------------------------------------------------------------- ??? [33] 100.0% [42] 1290(5.6%) 244(1.1%) sample-multi-bounded ...evelop/src/points.rkt:16:0 return/no-unsupplied [57] 67.6% loop [61] 13.5% -------------------------------------------------------------------- ??? [33] 100.0% [43] 926(4.0%) 926(4.0%) ->flonum ...s/herbie/develop/src/programs.rkt:38:0 -------------------------------------------------------------------- merge-egraph-nodes! [32] 100.0% [44] 630(2.7%) 0(0.0%) for-loop ...rbie/develop/src/core/egraph.rkt:199:4 merge-egraph-nodes! [32] 62.9% dedup-children! [52] 37.1% -------------------------------------------------------------------- ??? [35] 100.0% [45] 444(1.9%) 180(0.8%) ival-add ...erbie/develop/src/biginterval.rkt:87:0 ??? [64] 59.5% -------------------------------------------------------------------- ??? [35] 100.0% [46] 232(1.0%) 0(0.0%) ival-sub ...erbie/develop/src/biginterval.rkt:93:0 ??? [64] 100.0% -------------------------------------------------------------------- for-loop [34] 100.0% [47] 194(0.8%) 194(0.8%) filter ...0/collects/racket/private/list.rkt:256:2 -------------------------------------------------------------------- substitute-e [37] 100.0% [48] 194(0.8%) 0(0.0%) for-loop ...rbie/develop/src/core/ematch.rkt:73:24 mk-enode! [60] 100.0% -------------------------------------------------------------------- for-loop [34] 100.0% [49] 186(0.8%) 186(0.8%) loop ...cket-7.0/collects/racket/function.rkt:53:6 -------------------------------------------------------------------- merge-egraph-nodes! [32] 100.0% [50] 168(0.7%) 0(0.0%) enode-merge! ...e/develop/src/core/enode.rkt:128:0 custom-set-intersect! [62] 100.0% -------------------------------------------------------------------- for-loop [34] 0.1% loop! [38] 18.9% loop [51] 81.1% [51] 5190(22.4%) 322(1.4%) loop ...-7.0/collects/racket/private/map.rkt:40:19 loop [51] 81.1% loop! [38] 18.2% -------------------------------------------------------------------- for-loop [44] 8.0% for-loop [29] 92.0% [52] 2920(12.6%) 0(0.0%) dedup-children! ...evelop/src/core/enode.rkt:199:0 loop [63] 64.2% loop [65] 35.8% -------------------------------------------------------------------- update-leader! [39] 100.0% [53] 2108(9.1%) 0(0.0%) for-loop ...rbie/develop/src/core/egraph.rkt:218:6 hash-update! [70] 58.3% for-loop [66] 41.7% -------------------------------------------------------------------- apply-match [27] 23.6% loop! [38] 76.4% [54] 1804(7.8%) 1378(5.9%) set ...collects/racket/private/set-types.rkt:981:0 for-loop [68] 23.6% -------------------------------------------------------------------- ival-mult [41] 100.0% [55] 1546(6.7%) 190(0.8%) bf* ...ath/private/bigfloat/bigfloat-mpfr.rkt:95:0 ??? [64] 87.7% -------------------------------------------------------------------- loop! [38] 100.0% [56] 1502(6.5%) 734(3.2%) custom-set-union ...et/private/set-types.rkt:168:0 for-loop [67] 51.1% -------------------------------------------------------------------- sample-multi-bounded [42] 100.0% [57] 872(3.8%) 872(3.8%) return/no-unsupplied ...ct/private/arr-i.rkt:534:0 -------------------------------------------------------------------- update-leader! [39] 100.0% [58] 394(1.7%) 394(1.7%) for-loop ...rbie/develop/src/core/egraph.rkt:228:6 -------------------------------------------------------------------- ival-mult [41] 100.0% [59] 228(1.0%) 228(1.0%) classify-ival ...develop/src/biginterval.rkt:310:0 -------------------------------------------------------------------- for-loop [48] 100.0% [60] 194(0.8%) 194(0.8%) mk-enode! ...rbie/develop/src/core/egraph.rkt:99:0 -------------------------------------------------------------------- sample-multi-bounded [42] 100.0% [61] 174(0.8%) 0(0.0%) loop ...ghtlies/herbie/develop/src/points.rkt:45:6 random-exp [69] 100.0% -------------------------------------------------------------------- enode-merge! [50] 100.0% [62] 168(0.7%) 168(0.7%) custom-set-intersect! ...ivate/set-types.rkt:269:0 -------------------------------------------------------------------- dedup-children! [52] 29.0% loop [63] 71.0% [63] 1874(8.1%) 1874(8.1%) loop ...racket-7.0/collects/racket/list.rkt:434:17 loop [63] 71.0% -------------------------------------------------------------------- ival-sub [46] 12.5% ival-add [45] 14.3% bf* [55] 73.2% [64] 1852(8.0%) 264(1.1%) ??? ...-racket/utils/simple-result-arrow.rkt:39:12 bfsub [71] 85.7% -------------------------------------------------------------------- dedup-children! [52] 17.2% loop [65] 82.8% [65] 1046(4.5%) 0(0.0%) loop ...racket-7.0/collects/racket/list.rkt:417:34 loop [65] 82.8% loop [72] 12.3% member [73] 4.9% -------------------------------------------------------------------- for-loop [53] 100.0% [66] 880(3.8%) 0(0.0%) for-loop ...rbie/develop/src/core/egraph.rkt:219:8 hash-update! [70] 100.0% -------------------------------------------------------------------- custom-set-union [56] 100.0% [67] 768(3.3%) 578(2.5%) for-loop ...cts/racket/private/set-types.rkt:174:3 for-loop [74] 24.7% -------------------------------------------------------------------- set [54] 100.0% [68] 426(1.8%) 426(1.8%) for-loop ...cts/racket/private/set-types.rkt:937:4 -------------------------------------------------------------------- loop [61] 100.0% [69] 174(0.8%) 174(0.8%) random-exp .../herbie/develop/src/common.rkt:173:0 -------------------------------------------------------------------- for-loop [66] 41.7% for-loop [53] 58.3% [70] 2108(9.1%) 0(0.0%) hash-update! ...cket/private/more-scheme.rkt:365:4 ??? [75] 100.0% -------------------------------------------------------------------- ??? [64] 100.0% [71] 1588(6.8%) 0(0.0%) bfsub ...-lib/math/private/bigfloat/mpfr.rkt:821:4 ??? [76] 87.0% new-mpfr [77] 13.0% -------------------------------------------------------------------- loop [65] 100.0% [72] 842(3.6%) 842(3.6%) loop (unknown source) -------------------------------------------------------------------- loop [65] 100.0% [73] 204(0.9%) 204(0.9%) member (unknown source) -------------------------------------------------------------------- for-loop [67] 100.0% [74] 190(0.8%) 190(0.8%) for-loop ...cts/racket/private/set-types.rkt:178:5 -------------------------------------------------------------------- hash-update! [70] 100.0% [75] 2108(9.1%) 0(0.0%) ??? ...s/herbie/develop/src/core/egraph.rkt:221:24 for-loop [78] 100.0% -------------------------------------------------------------------- bfsub [71] 100.0% [76] 1382(6.0%) 1382(6.0%) ??? /opt/racket-7.0/collects/ffi/unsafe.rkt:898:4 -------------------------------------------------------------------- bfsub [71] 100.0% [77] 206(0.9%) 206(0.9%) new-mpfr ...b/math/private/bigfloat/mpfr.rkt:335:0 -------------------------------------------------------------------- ??? [75] 100.0% [78] 2108(9.1%) 1894(8.2%) for-loop ...bie/develop/src/core/egraph.rkt:222:26 update-en-expr [79] 10.2% -------------------------------------------------------------------- for-loop [78] 23.6% loop! [38] 76.4% [79] 906(3.9%) 906(3.9%) update-en-expr ...evelop/src/core/egraph.rkt:207:0 --------------------------------------------------------------------