Profiling results ----------------- Total cpu time observed: 56280ms (out of 56492ms) Number of samples taken: 204 (once every 276ms) ======================================================================== Caller Idx Total Self Name+src Local% ms(pct) ms(pct) Callee ======================================================================== ??? [9] 100.0% [1] 56280(100.0%) 0(0.0%) profile-thunk16 ...e/pkgs/profile-lib/main.rkt:9:0 run [5] 100.0% ------------------------------------------------------------------------ ??? [9] 100.0% [2] 48126(85.5%) 0(0.0%) run-improve43 ...ie/develop/src/mainloop.rkt:362:0 simplify! [12] 85.1% for-loop [6] 14.9% ------------------------------------------------------------------------ ??? [9] 100.0% [3] 5640(10.0%) 0(0.0%) prepare-points-intervals19 ...src/points.rkt:130:0 loop [7] 100.0% ------------------------------------------------------------------------ matcher [40] 100.0% [4] 280(0.5%) 0(0.0%) ??? .../herbie/develop/src/core/matcher.rkt:178:11 for-loop [8] 100.0% ------------------------------------------------------------------------ profile-thunk16 [1] 100.0% [5] 56280(100.0%) 0(0.0%) run ...et-7.0/share/pkgs/profile-lib/main.rkt:39:2 ??? [9] 100.0% ------------------------------------------------------------------------ run-improve43 [2] 100.0% [6] 7158(12.7%) 0(0.0%) for-loop .../herbie/develop/src/mainloop.rkt:377:4 run-iter! [10] 100.0% ------------------------------------------------------------------------ prepare-points-intervals19 [3] 100.0% [7] 5640(10.0%) 272(0.5%) loop ...htlies/herbie/develop/src/points.rkt:142:4 loop [11] 81.0% loop [74] 9.8% ??? [101] 4.4% ------------------------------------------------------------------------ ??? [4] 100.0% [8] 280(0.5%) 0(0.0%) for-loop ...ie/develop/src/core/matcher.rkt:182:21 matcher [40] 100.0% ------------------------------------------------------------------------ run [5] 50.0% [9] 56280(100.0%) 0(0.0%) ??? ...lects/racket/private/more-scheme.rkt:261:28 profile-thunk16 [1] 50.0% run-improve43 [2] 42.8% prepare-points-intervals19 [3] 5.0% errors [78] 1.1% eval-errors [13] 0.9% oracle-error [16] 0.2% ------------------------------------------------------------------------ for-loop [6] 100.0% [10] 7158(12.7%) 0(0.0%) run-iter! ...herbie/develop/src/mainloop.rkt:343:0 simplify! [12] 85.6% finalize-iter! [14] 10.4% gen-rewrites! [15] 3.9% ------------------------------------------------------------------------ loop [7] 100.0% [11] 4566(8.1%) 268(0.5%) loop ...htlies/herbie/develop/src/points.rkt:111:2 ??? [86] 82.2% ??? [90] 11.9% ------------------------------------------------------------------------ run-iter! [10] 13.0% run-improve43 [2] 87.0% [12] 47098(83.7%) 0(0.0%) simplify! ...herbie/develop/src/mainloop.rkt:239:0 simplify-batch6 [17] 100.0% ------------------------------------------------------------------------ ??? [9] 100.0% [13] 984(1.7%) 0(0.0%) eval-errors ...herbie/develop/src/points.rkt:207:0 for-loop [18] 100.0% ------------------------------------------------------------------------ run-iter! [10] 100.0% [14] 748(1.3%) 0(0.0%) finalize-iter! ...e/develop/src/mainloop.rkt:294:0 ??? [44] 100.0% ------------------------------------------------------------------------ run-iter! [10] 100.0% [15] 280(0.5%) 0(0.0%) gen-rewrites! ...ie/develop/src/mainloop.rkt:195:0 for-loop [19] 100.0% ------------------------------------------------------------------------ ??? [9] 100.0% [16] 248(0.4%) 0(0.0%) oracle-error ...erbie/develop/src/points.rkt:216:0 for-loop [20] 100.0% ------------------------------------------------------------------------ simplify! [12] 100.0% [17] 47098(83.7%) 0(0.0%) simplify-batch6 ...elop/src/core/simplify.rkt:30:0 loop [21] 95.2% loop [22] 4.8% ------------------------------------------------------------------------ eval-errors [13] 100.0% [18] 984(1.7%) 0(0.0%) for-loop ...es/herbie/develop/src/points.rkt:209:2 ??? [90] 100.0% ------------------------------------------------------------------------ gen-rewrites! [15] 100.0% [19] 280(0.5%) 0(0.0%) for-loop ...herbie/develop/src/mainloop.rkt:204:11 rewrite-expression-head20 [23] 100.0% ------------------------------------------------------------------------ oracle-error [16] 100.0% [20] 248(0.4%) 248(0.4%) for-loop ...es/herbie/develop/src/points.rkt:217:2 ------------------------------------------------------------------------ simplify-batch6 [17] 100.0% [21] 44858(79.7%) 0(0.0%) loop .../herbie/develop/src/core/simplify.rkt:43:2 one-iter [24] 100.0% ------------------------------------------------------------------------ simplify-batch6 [17] 100.0% [22] 2240(4.0%) 0(0.0%) loop ...herbie/develop/src/core/simplify.rkt:146:2 for-loop [25] 100.0% ------------------------------------------------------------------------ for-loop [19] 100.0% [23] 280(0.5%) 0(0.0%) rewrite-expression-head20 ...ore/matcher.rkt:128:0 rewriter [26] 100.0% ------------------------------------------------------------------------ loop [21] 100.0% [24] 44858(79.7%) 0(0.0%) one-iter ...bie/develop/src/core/simplify.rkt:52:0 for-loop [27] 91.0% for-loop [28] 7.3% loop [29] 1.7% ------------------------------------------------------------------------ loop [22] 100.0% [25] 2240(4.0%) 250(0.4%) for-loop ...ie/develop/src/core/simplify.rkt:152:4 argmin [30] 33.4% loop [31] 33.4% expression-cost [36] 22.1% ------------------------------------------------------------------------ rewrite-expression-head20 [23] 33.3% matcher [40] 66.7% [26] 280(0.5%) 0(0.0%) rewriter ...bie/develop/src/core/matcher.rkt:131:2 for-loop [33] 66.7% *rules* [32] 33.3% ------------------------------------------------------------------------ one-iter [24] 100.0% [27] 40806(72.5%) 0(0.0%) for-loop ...ie/develop/src/core/simplify.rkt:103:2 for-loop [34] 81.7% update-leader! [60] 10.2% match-e [35] 5.5% set [77] 2.6% ------------------------------------------------------------------------ for-loop [28] 50.0% one-iter [24] 50.0% [28] 3294(5.9%) 280(0.5%) for-loop ...ie/develop/src/core/simplify.rkt:63:12 for-loop [28] 50.0% match-e [35] 42.1% ??? [41] 3.6% ------------------------------------------------------------------------ one-iter [24] 100.0% [29] 758(1.3%) 0(0.0%) loop ...-7.0/collects/racket/private/map.rkt:74:19 set-precompute! [37] 100.0% ------------------------------------------------------------------------ for-loop [25] 100.0% [30] 748(1.3%) 0(0.0%) argmin ...acket-7.0/collects/racket/list.rkt:765:0 expression-cost [36] 66.3% for-loop [38] 33.7% ------------------------------------------------------------------------ for-loop [25] 100.0% [31] 748(1.3%) 0(0.0%) loop .../racket-7.0/collects/racket/list.rkt:751:4 expression-cost [36] 66.6% for-loop [38] 33.4% ------------------------------------------------------------------------ rewriter [26] 100.0% [32] 280(0.5%) 0(0.0%) *rules* ...rbie/develop/src/syntax/rules.rkt:767:0 for-loop [39] 100.0% ------------------------------------------------------------------------ rewriter [26] 100.0% [33] 280(0.5%) 0(0.0%) for-loop ...ie/develop/src/core/matcher.rkt:134:10 matcher [40] 100.0% ------------------------------------------------------------------------ for-loop [27] 100.0% [34] 33324(59.2%) 0(0.0%) for-loop ...bie/develop/src/core/simplify.rkt:86:4 merge-egraph-nodes! [50] 67.1% loop! [68] 29.9% substitute-e [46] 2.3% mk-enode! [62] 0.8% ------------------------------------------------------------------------ for-loop [27] 21.6% for-loop [51] 38.1% for-loop [28] 40.3% [35] 5034(8.9%) 878(1.6%) match-e ...herbie/develop/src/core/ematch.rkt:39:0 for-loop [42] 81.5% ??? [44] 4.2% custom-in-set [49] 2.7% ------------------------------------------------------------------------ for-loop [25] 33.2% argmin [30] 33.3% loop [31] 33.5% [36] 1488(2.6%) 0(0.0%) expression-cost .../develop/src/programs.rkt:205:0 compile [43] 100.0% ------------------------------------------------------------------------ loop [29] 100.0% [37] 758(1.3%) 0(0.0%) set-precompute! ...lop/src/core/simplify.rkt:122:0 for-loop [45] 100.0% ------------------------------------------------------------------------ loop [31] 49.8% argmin [30] 50.2% [38] 502(0.9%) 0(0.0%) for-loop .../herbie/develop/src/programs.rkt:206:2 table-ref [47] 100.0% ------------------------------------------------------------------------ *rules* [32] 100.0% [39] 280(0.5%) 0(0.0%) for-loop ...ies/herbie/develop/src/common.rkt:71:9 ormap [48] 100.0% ------------------------------------------------------------------------ for-loop [8] 50.0% for-loop [33] 50.0% [40] 280(0.5%) 0(0.0%) matcher ...rbie/develop/src/core/matcher.rkt:166:2 ??? [4] 50.0% rewriter [26] 50.0% ------------------------------------------------------------------------ for-loop [28] 100.0% [41] 240(0.4%) 240(0.4%) ??? ...s/racket/contract/private/arr-i.rkt:1252:29 ------------------------------------------------------------------------ match-e [35] 100.0% [42] 4590(8.2%) 2716(4.8%) for-loop ...rbie/develop/src/core/ematch.rkt:52:11 for-loop [51] 56.9% filter [56] 2.7% cartesian-product [59] 2.3% ------------------------------------------------------------------------ expression-cost [36] 100.0% [43] 1488(2.6%) 0(0.0%) compile ...s/herbie/develop/src/programs.rkt:182:0 hash-ref! [52] 100.0% ------------------------------------------------------------------------ match-e [35] 40.2% finalize-iter! [14] 59.8% [44] 1250(2.2%) 502(0.9%) ??? ...contract/private/arrow-val-first.rkt:388:18 for-loop [54] 59.8% ------------------------------------------------------------------------ set-precompute! [37] 100.0% [45] 758(1.3%) 0(0.0%) for-loop ...ie/develop/src/core/simplify.rkt:124:2 merge-egraph-nodes! [50] 67.3% setfindf [58] 32.7% ------------------------------------------------------------------------ for-loop [34] 100.0% [46] 752(1.3%) 0(0.0%) substitute-e ...e/develop/src/core/ematch.rkt:64:0 for-loop [53] 100.0% ------------------------------------------------------------------------ for-loop [38] 100.0% [47] 502(0.9%) 252(0.4%) table-ref ...es/herbie/develop/src/common.rkt:42:0 for-loop [57] 49.8% ------------------------------------------------------------------------ for-loop [39] 100.0% [48] 280(0.5%) 0(0.0%) ormap ....0/collects/racket/private/map.rkt:141:13 flag-set? [55] 100.0% ------------------------------------------------------------------------ match-e [35] 100.0% [49] 268(0.5%) 268(0.5%) custom-in-set ...acket/private/set-types.rkt:577:0 ------------------------------------------------------------------------ for-loop [45] 2.2% merge-egraph-nodes! [50] 4.6% for-loop [61] 14.2% for-loop [34] 79.0% [50] 22868(40.6%) 206(0.4%) merge-egraph-nodes! ...p/src/core/egraph.rkt:144:0 update-leader! [60] 58.9% for-loop [61] 19.8% loop! [68] 14.1% merge-egraph-nodes! [50] 4.6% enode-merge! [65] 1.7% ------------------------------------------------------------------------ for-loop [42] 100.0% [51] 3810(6.8%) 206(0.4%) for-loop ...rbie/develop/src/core/ematch.rkt:58:37 match-e [35] 94.6% ------------------------------------------------------------------------ ??? [63] 48.0% compile [43] 52.0% [52] 1488(2.6%) 1244(2.2%) hash-ref! .../racket/private/more-scheme.rkt:376:2 ??? [63] 53.4% ------------------------------------------------------------------------ substitute-e [46] 100.0% [53] 752(1.3%) 0(0.0%) for-loop ...rbie/develop/src/core/ematch.rkt:73:24 mk-enode! [62] 100.0% ------------------------------------------------------------------------ ??? [44] 100.0% [54] 748(1.3%) 0(0.0%) for-loop ...ie/develop/src/core/alt-table.rkt:51:2 atab-add-altn [64] 100.0% ------------------------------------------------------------------------ ormap [48] 100.0% [55] 280(0.5%) 280(0.5%) flag-set? ...es/herbie/develop/src/config.rkt:28:0 ------------------------------------------------------------------------ for-loop [42] 100.0% [56] 252(0.4%) 252(0.4%) filter ...0/collects/racket/private/list.rkt:256:2 ------------------------------------------------------------------------ table-ref [47] 100.0% [57] 250(0.4%) 250(0.4%) for-loop ...ies/herbie/develop/src/common.rkt:44:4 ------------------------------------------------------------------------ for-loop [45] 100.0% [58] 248(0.4%) 0(0.0%) setfindf ...es/herbie/develop/src/common.rkt:139:0 for-loop [66] 100.0% ------------------------------------------------------------------------ for-loop [42] 100.0% [59] 212(0.4%) 212(0.4%) cartesian-product ...ollects/racket/list.rkt:822:0 ------------------------------------------------------------------------ for-loop [27] 21.1% merge-egraph-nodes! [50] 78.9% [60] 19630(34.9%) 0(0.0%) update-leader! ...evelop/src/core/egraph.rkt:212:0 for-loop [67] 100.0% ------------------------------------------------------------------------ merge-egraph-nodes! [50] 100.0% [61] 7752(13.8%) 0(0.0%) for-loop ...rbie/develop/src/core/egraph.rkt:198:4 merge-egraph-nodes! [50] 79.1% loop! [68] 20.9% ------------------------------------------------------------------------ for-loop [34] 25.0% for-loop [53] 75.0% [62] 1002(1.8%) 750(1.3%) mk-enode! ...rbie/develop/src/core/egraph.rkt:99:0 hash-has-key? [71] 25.1% ------------------------------------------------------------------------ hash-ref! [52] 100.0% [63] 990(1.8%) 244(0.4%) ??? ...tlies/herbie/develop/src/programs.rkt:190:5 hash-ref! [52] 91.8% ------------------------------------------------------------------------ for-loop [54] 100.0% [64] 748(1.3%) 0(0.0%) atab-add-altn ...elop/src/core/alt-table.rkt:200:0 best-and-tied-at-points [69] 67.1% override-at-pnts [73] 32.9% ------------------------------------------------------------------------ merge-egraph-nodes! [50] 100.0% [65] 520(0.9%) 0(0.0%) enode-merge! ...e/develop/src/core/enode.rkt:127:0 custom-set-intersect! [70] 52.3% adopt-enode! [72] 47.7% ------------------------------------------------------------------------ setfindf [58] 100.0% [66] 248(0.4%) 248(0.4%) for-loop ...es/herbie/develop/src/common.rkt:140:2 ------------------------------------------------------------------------ update-leader! [60] 100.0% [67] 19630(34.9%) 0(0.0%) for-loop ...rbie/develop/src/core/egraph.rkt:217:6 hash-update! [79] 54.1% for-loop [75] 45.9% ------------------------------------------------------------------------ for-loop [61] 7.6% merge-egraph-nodes! [50] 18.3% loop [74] 29.5% for-loop [34] 44.6% [68] 16624(29.5%) 3694(6.6%) loop! ...s/herbie/develop/src/core/enode.rkt:190:2 loop [74] 36.4% custom-set-union [76] 35.2% set [77] 10.2% update-en-expr [91] 5.7% ------------------------------------------------------------------------ atab-add-altn [64] 100.0% [69] 502(0.9%) 0(0.0%) best-and-tied-at-points ...ore/alt-table.rkt:112:0 errors [78] 100.0% ------------------------------------------------------------------------ enode-merge! [65] 100.0% [70] 272(0.5%) 272(0.5%) custom-set-intersect! ...ivate/set-types.rkt:269:0 ------------------------------------------------------------------------ mk-enode! [62] 100.0% [71] 252(0.4%) 252(0.4%) hash-has-key? ...ket/private/more-scheme.rkt:371:2 ------------------------------------------------------------------------ enode-merge! [65] 100.0% [72] 248(0.4%) 0(0.0%) adopt-enode! ...e/develop/src/core/enode.rkt:103:0 custom-set-union [76] 100.0% ------------------------------------------------------------------------ atab-add-altn [64] 100.0% [73] 246(0.4%) 0(0.0%) override-at-pnts ...p/src/core/alt-table.rkt:135:0 errors [78] 100.0% ------------------------------------------------------------------------ loop [7] 5.0% loop! [68] 9.0% loop [74] 86.1% [74] 11116(19.8%) 1134(2.0%) loop ...-7.0/collects/racket/private/map.rkt:40:19 loop [74] 86.1% loop! [68] 8.6% ??? [90] 5.0% ------------------------------------------------------------------------ for-loop [67] 100.0% [75] 9016(16.0%) 0(0.0%) for-loop ...rbie/develop/src/core/egraph.rkt:218:8 hash-update! [79] 100.0% ------------------------------------------------------------------------ adopt-enode! [72] 3.8% loop! [68] 96.2% [76] 6554(11.6%) 538(1.0%) custom-set-union ...et/private/set-types.rkt:168:0 for-loop [80] 87.3% for-loop [83] 4.5% ------------------------------------------------------------------------ for-loop [27] 24.1% loop! [68] 75.9% [77] 4460(7.9%) 3874(6.9%) set ...collects/racket/private/set-types.rkt:981:0 for-loop [82] 13.1% ------------------------------------------------------------------------ override-at-pnts [73] 12.1% best-and-tied-at-points [69] 24.7% ??? [9] 63.2% [78] 2030(3.6%) 0(0.0%) errors ...lies/herbie/develop/src/points.rkt:232:0 for-loop [81] 100.0% ------------------------------------------------------------------------ for-loop [75] 45.9% for-loop [67] 54.1% [79] 19630(34.9%) 0(0.0%) hash-update! ...cket/private/more-scheme.rkt:365:4 ??? [84] 100.0% ------------------------------------------------------------------------ custom-set-union [76] 100.0% [80] 5724(10.2%) 782(1.4%) for-loop ...cts/racket/private/set-types.rkt:174:3 for-loop [85] 86.3% ------------------------------------------------------------------------ errors [78] 100.0% [81] 2030(3.6%) 1030(1.8%) for-loop ...es/herbie/develop/src/points.rkt:235:4 ??? [86] 36.8% ulp-difference [87] 12.4% ------------------------------------------------------------------------ set [77] 100.0% [82] 586(1.0%) 586(1.0%) for-loop ...cts/racket/private/set-types.rkt:937:4 ------------------------------------------------------------------------ custom-set-union [76] 100.0% [83] 292(0.5%) 292(0.5%) for-loop ...cts/racket/private/set-types.rkt:152:2 ------------------------------------------------------------------------ hash-update! [79] 100.0% [84] 19630(34.9%) 0(0.0%) ??? ...s/herbie/develop/src/core/egraph.rkt:220:24 for-loop [88] 100.0% ------------------------------------------------------------------------ for-loop [80] 100.0% [85] 4942(8.8%) 4942(8.8%) for-loop ...cts/racket/private/set-types.rkt:178:5 ------------------------------------------------------------------------ for-loop [81] 16.6% loop [11] 83.4% [86] 4502(8.0%) 250(0.4%) ??? ...tlies/herbie/develop/src/programs.rkt:147:2 ??? [89] 65.8% ??? [101] 17.6% ??? [90] 11.1% ------------------------------------------------------------------------ for-loop [81] 100.0% [87] 252(0.4%) 252(0.4%) ulp-difference ...erbie/develop/src/float.rkt:13:0 ------------------------------------------------------------------------ ??? [84] 100.0% [88] 19630(34.9%) 17580(31.2%) for-loop ...bie/develop/src/core/egraph.rkt:221:26 update-en-expr [91] 10.4% ------------------------------------------------------------------------ ??? [86] 100.0% [89] 2962(5.3%) 0(0.0%) ??? ...t-7.0/collects/racket/private/kw.rkt:592:14 ??? [90] 100.0% ------------------------------------------------------------------------ ??? [86] 9.0% loop [11] 9.8% loop [74] 10.0% for-loop [18] 17.8% ??? [89] 53.4% [90] 5542(9.8%) 298(0.5%) ??? ...tract/private/arrow-higher-order.rkt:357:33 ival-mult [92] 53.4% ->flonum [93] 36.6% sample-multi-bounded [94] 4.6% ------------------------------------------------------------------------ for-loop [88] 49.4% loop! [68] 50.6% [91] 4154(7.4%) 4154(7.4%) update-en-expr ...evelop/src/core/egraph.rkt:206:0 ------------------------------------------------------------------------ ??? [90] 100.0% [92] 2962(5.3%) 290(0.5%) ival-mult ...rbie/develop/src/biginterval.rkt:95:0 classify-ival [95] 54.5% bf* [97] 27.1% ...higher-order.rkt:361:33 [98] 8.6% ------------------------------------------------------------------------ ??? [90] 100.0% [93] 2026(3.6%) 1042(1.9%) ->flonum ...s/herbie/develop/src/programs.rkt:37:0 return/no-unsupplied [96] 48.6% ------------------------------------------------------------------------ ??? [90] 100.0% [94] 256(0.5%) 256(0.5%) sample-multi-bounded ...evelop/src/points.rkt:16:0 ------------------------------------------------------------------------ ival-mult [92] 100.0% [95] 1614(2.9%) 858(1.5%) classify-ival ...develop/src/biginterval.rkt:300:0 fold-binary-pred [100] 46.8% ------------------------------------------------------------------------ ->flonum [93] 100.0% [96] 984(1.7%) 984(1.7%) return/no-unsupplied ...ct/private/arr-i.rkt:534:0 ------------------------------------------------------------------------ ival-mult [92] 100.0% [97] 802(1.4%) 0(0.0%) bf* ...ath/private/bigfloat/bigfloat-mpfr.rkt:95:0 ??? [99] 100.0% ------------------------------------------------------------------------ ival-mult [92] 100.0% [98] 256(0.5%) 256(0.5%) ...higher-order.rkt:361:33 (unknown source) ------------------------------------------------------------------------ bf* [97] 100.0% [99] 802(1.4%) 244(0.4%) ??? ...-racket/utils/simple-result-arrow.rkt:39:12 bfmul [102] 69.6% ------------------------------------------------------------------------ classify-ival [95] 100.0% [100] 756(1.3%) 0(0.0%) fold-binary-pred ...gfloat/bigfloat-mpfr.rkt:117:0 ??? [101] 100.0% ------------------------------------------------------------------------ loop [7] 13.8% fold-binary-pred [100] 42.1% ??? [86] 44.1% [101] 1796(3.2%) 756(1.3%) ??? ...tract/private/arrow-higher-order.rkt:361:33 mk-ival [103] 44.1% ??? [105] 13.8% ------------------------------------------------------------------------ ??? [99] 100.0% [102] 558(1.0%) 292(0.5%) bfmul ...-lib/math/private/bigfloat/mpfr.rkt:821:4 ??? [104] 47.7% ------------------------------------------------------------------------ ??? [101] 100.0% [103] 792(1.4%) 0(0.0%) mk-ival ...herbie/develop/src/biginterval.rkt:53:0 bf [106] 100.0% ------------------------------------------------------------------------ bfmul [102] 100.0% [104] 266(0.5%) 266(0.5%) ??? /opt/racket-7.0/collects/ffi/unsafe.rkt:898:4 ------------------------------------------------------------------------ ??? [101] 100.0% [105] 248(0.4%) 248(0.4%) ??? ...cts/racket/contract/private/list.rkt:209:10 ------------------------------------------------------------------------ mk-ival [103] 100.0% [106] 792(1.4%) 0(0.0%) bf ...ath-lib/math/private/bigfloat/mpfr.rkt:601:2 new-mpfr [107] 100.0% ------------------------------------------------------------------------ bf [106] 100.0% [107] 792(1.4%) 792(1.4%) new-mpfr ...b/math/private/bigfloat/mpfr.rkt:335:0 ------------------------------------------------------------------------