Profiling results ----------------- Total cpu time observed: 8332ms (out of 8520ms) Number of samples taken: 40 (once every 208ms) ==================================================================== Caller Idx Total Self Name+src Local% ms(pct) ms(pct) Callee ==================================================================== [1] 8332(100.0%) 0(0.0%) ??? ...lects/racket/private/more-scheme.rkt:261:28 profile-thunk16 [7] 100.0% -------------------------------------------------------------------- ??? [76] 100.0% [2] 1378(16.5%) 0(0.0%) approximate9 ...ie/master/src/core/taylor.rkt:12:0 loop [9] 85.1% for-loop [12] 14.9% -------------------------------------------------------------------- matcher [62] 100.0% [3] 1272(15.3%) 0(0.0%) ??? ...s/herbie/master/src/core/matcher.rkt:130:11 for-loop [8] 96.0% foldl [11] 4.0% -------------------------------------------------------------------- hash-ref! [81] 100.0% [4] 1172(14.1%) 0(0.0%) ??? ...ies/herbie/master/src/core/taylor.rkt:68:15 hash-ref! [81] 73.4% ??? [76] 26.6% -------------------------------------------------------------------- hash-ref! [81] 100.0% [5] 950(11.4%) 0(0.0%) ??? ...es/herbie/master/src/core/taylor.rkt:291:26 for-loop [10] 100.0% -------------------------------------------------------------------- rewriter [55] 100.0% [6] 646(7.8%) 0(0.0%) *rules* ...erbie/master/src/syntax/rules.rkt:666:0 for-loop [98] 100.0% -------------------------------------------------------------------- ??? [1] 100.0% [7] 8332(100.0%) 0(0.0%) profile-thunk16 ...e/pkgs/profile-lib/main.rkt:9:0 run [13] 100.0% -------------------------------------------------------------------- ??? [3] 100.0% [8] 1272(15.3%) 0(0.0%) for-loop ...bie/master/src/core/matcher.rkt:132:15 matcher [62] 100.0% -------------------------------------------------------------------- approximate9 [2] 100.0% [9] 1172(14.1%) 0(0.0%) loop ...ies/herbie/master/src/core/taylor.rkt:87:4 hash-ref! [81] 100.0% -------------------------------------------------------------------- ??? [5] 100.0% [10] 950(11.4%) 0(0.0%) for-loop ...rbie/master/src/core/taylor.rkt:291:52 hash-ref! [81] 68.4% simplify [14] 21.1% ??? [15] 10.5% -------------------------------------------------------------------- ??? [3] 100.0% [11] 206(2.5%) 206(2.5%) foldl ....5/collects/racket/private/list.rkt:229:4 -------------------------------------------------------------------- approximate9 [2] 100.0% [12] 206(2.5%) 0(0.0%) for-loop ...erbie/master/src/core/taylor.rkt:30:18 taylor [36] 100.0% -------------------------------------------------------------------- profile-thunk16 [7] 100.0% [13] 8332(100.0%) 0(0.0%) run ...et-7.5/share/pkgs/profile-lib/main.rkt:39:2 .../more-scheme.rkt:261:28 [16]100.0% -------------------------------------------------------------------- for-loop [10] 17.1% hash-ref! [81] 82.9% [14] 1172(14.1%) 0(0.0%) simplify ...herbie/master/src/core/reduce.rkt:16:0 f46 [17] 64.0% f67 [18] 18.9% simplify* [34] 17.1% -------------------------------------------------------------------- for-loop [10] 100.0% [15] 200(2.4%) 0(0.0%) ??? ...es/herbie/master/src/core/taylor.rkt:294:19 hash-ref! [81] 100.0% -------------------------------------------------------------------- for-loop [63] 2.4% run [13] 97.6% [16] 8332(100.0%) 0(0.0%) .../more-scheme.rkt:261:28 (unknown source) prepare-points-intervals [19] 49.6% run-improve47 [20] 44.1% oracle-error [21] 2.5% errors [60] 1.3% ??? [76] 1.3% ??? [29] 1.1% -------------------------------------------------------------------- map [28] 36.7% simplify [14] 63.3% [17] 750(9.0%) 0(0.0%) f46 (unknown source) map [28] 100.0% -------------------------------------------------------------------- simplify [14] 100.0% [18] 222(2.7%) 0(0.0%) f67 (unknown source) eval-const-expr [43] 100.0% -------------------------------------------------------------------- .../more-scheme.rkt:261:28 [16]100.0% [19] 4136(49.6%) 0(0.0%) prepare-points-intervals ...r/src/points.rkt:110:0 loop [22] 100.0% -------------------------------------------------------------------- .../more-scheme.rkt:261:28 [16]100.0% [20] 3766(45.2%) 0(0.0%) run-improve47 ...bie/master/src/mainloop.rkt:346:0 for-loop [23] 94.2% simplify! [32] 5.8% -------------------------------------------------------------------- .../more-scheme.rkt:261:28 [16]100.0% [21] 212(2.5%) 0(0.0%) oracle-error ...herbie/master/src/points.rkt:188:0 for-loop [24] 100.0% -------------------------------------------------------------------- prepare-points-intervals [19] 100.0% [22] 4136(49.6%) 184(2.2%) loop ...ghtlies/herbie/master/src/points.rkt:123:4 ??? [26] 57.3% loop [27] 38.3% -------------------------------------------------------------------- run-improve47 [20] 100.0% [23] 3546(42.6%) 0(0.0%) for-loop ...s/herbie/master/src/mainloop.rkt:365:4 run-iter! [25] 100.0% -------------------------------------------------------------------- oracle-error [21] 100.0% [24] 212(2.5%) 0(0.0%) for-loop ...ies/herbie/master/src/points.rkt:189:2 map [28] 100.0% -------------------------------------------------------------------- for-loop [23] 100.0% [25] 3546(42.6%) 0(0.0%) run-iter! .../herbie/master/src/mainloop.rkt:327:0 gen-series! [30] 38.9% gen-rewrites! [31] 35.9% finalize-iter! [33] 15.6% simplify! [32] 9.7% -------------------------------------------------------------------- loop [22] 100.0% [26] 2368(28.4%) 0(0.0%) ??? ...ightlies/herbie/master/src/points.rkt:106:2 loop [73] 51.0% ??? [76] 49.0% -------------------------------------------------------------------- loop [22] 100.0% [27] 1584(19.0%) 200(2.4%) loop ...ightlies/herbie/master/src/points.rkt:81:2 ??? [29] 87.4% -------------------------------------------------------------------- taylor [36] 17.6% for-loop [24] 18.2% f46 [17] 64.2% [28] 1168(14.0%) 0(0.0%) map ...t-7.5/collects/racket/private/map.rkt:35:13 f46 [17] 23.5% ??? [35] 18.2% taylor [36] 17.6% simplify-node [37] 17.1% simplify* [34] 15.0% parse-loop80 [38] 8.6% -------------------------------------------------------------------- .../more-scheme.rkt:261:28 [16] 10.3% ??? [35] 11.9% loop [27] 77.8% [29] 1780(21.4%) 184(2.2%) ??? ...htlies/herbie/master/src/programs.rkt:115:2 ??? [76] 44.7% ??? [44] 22.8% loop [73] 22.1% -------------------------------------------------------------------- run-iter! [25] 100.0% [30] 1378(16.5%) 0(0.0%) gen-series! ...erbie/master/src/mainloop.rkt:160:0 for-loop [39] 100.0% -------------------------------------------------------------------- run-iter! [25] 100.0% [31] 1272(15.3%) 0(0.0%) gen-rewrites! ...bie/master/src/mainloop.rkt:183:0 for-loop [40] 100.0% -------------------------------------------------------------------- run-improve47 [20] 39.0% run-iter! [25] 61.0% [32] 564(6.8%) 0(0.0%) simplify! .../herbie/master/src/mainloop.rkt:224:0 egraph-run [41] 100.0% -------------------------------------------------------------------- run-iter! [25] 100.0% [33] 552(6.6%) 0(0.0%) finalize-iter! ...ie/master/src/mainloop.rkt:278:0 ??? [42] 100.0% -------------------------------------------------------------------- simplify [14] 36.4% map [28] 63.6% [34] 550(6.6%) 0(0.0%) simplify* ...erbie/master/src/core/reduce.rkt:31:0 constant? [51] 63.6% hash-ref! [81] 36.4% -------------------------------------------------------------------- map [28] 100.0% [35] 212(2.5%) 0(0.0%) ??? ...ghtlies/herbie/master/src/points.rkt:190:26 ??? [29] 100.0% -------------------------------------------------------------------- map [28] 33.3% taylor [36] 33.3% for-loop [12] 33.3% [36] 206(2.5%) 0(0.0%) taylor .../herbie/master/src/core/taylor.rkt:170:0 taylor [36] 33.3% map [28] 33.3% debug-print [45] 33.3% -------------------------------------------------------------------- map [28] 100.0% [37] 200(2.4%) 0(0.0%) simplify-node ...e/master/src/core/reduce.rkt:48:0 gather-additive-terms6 [46] 100.0% -------------------------------------------------------------------- map [28] 100.0% [38] 200(2.4%) 0(0.0%) parse-loop80 (unknown source) eval-const-expr [43] 100.0% -------------------------------------------------------------------- gen-series! [30] 100.0% [39] 1378(16.5%) 0(0.0%) for-loop ...s/herbie/master/src/mainloop.rkt:167:7 taylor-alt [47] 100.0% -------------------------------------------------------------------- gen-rewrites! [31] 100.0% [40] 1272(15.3%) 0(0.0%) for-loop .../herbie/master/src/mainloop.rkt:191:11 rewrite-expression-head20 [48] 100.0% -------------------------------------------------------------------- simplify! [32] 100.0% [41] 564(6.8%) 0(0.0%) egraph-run ...bie/master/src/core/eggmath.rkt:51:0 egraph-add-exprs [49] 100.0% -------------------------------------------------------------------- finalize-iter! [33] 100.0% [42] 552(6.6%) 0(0.0%) ??? ...contract/private/arrow-val-first.rkt:486:18 for-loop [50] 100.0% -------------------------------------------------------------------- parse-loop80 [38] 47.4% f67 [18] 52.6% [43] 422(5.1%) 0(0.0%) eval-const-expr ...e/master/src/programs.rkt:118:0 loop [73] 52.6% eval [66] 47.4% -------------------------------------------------------------------- ??? [29] 100.0% [44] 406(4.9%) 0(0.0%) ??? ...tract/private/arrow-higher-order.rkt:379:33 ival-div [52] 100.0% -------------------------------------------------------------------- taylor [36] 100.0% [45] 206(2.5%) 0(0.0%) debug-print ...s/herbie/master/src/debug.rkt:110:0 for-loop [53] 100.0% -------------------------------------------------------------------- simplify-node [37] 100.0% [46] 200(2.4%) 0(0.0%) gather-additive-terms6 ...src/core/reduce.rkt:70:0 constant? [51] 100.0% -------------------------------------------------------------------- for-loop [39] 100.0% [47] 1378(16.5%) 0(0.0%) taylor-alt ...herbie/master/src/mainloop.rkt:146:0 for-loop [54] 100.0% -------------------------------------------------------------------- for-loop [40] 100.0% [48] 1272(15.3%) 0(0.0%) rewrite-expression-head20 ...core/matcher.rkt:87:0 rewriter [55] 100.0% -------------------------------------------------------------------- egraph-run [41] 100.0% [49] 564(6.8%) 0(0.0%) egraph-add-exprs ...ter/src/core/eggmath.rkt:111:0 ??? [56] 100.0% -------------------------------------------------------------------- ??? [42] 100.0% [50] 552(6.6%) 0(0.0%) for-loop ...bie/master/src/core/alt-table.rkt:55:2 atab-add-altn [57] 100.0% -------------------------------------------------------------------- gather-additive-terms6 [46] 36.4% simplify* [34] 63.6% [51] 550(6.6%) 0(0.0%) constant? ...ie/master/src/syntax/syntax.rkt:726:0 value? [58] 100.0% -------------------------------------------------------------------- ??? [44] 100.0% [52] 406(4.9%) 406(4.9%) ival-div ...erbie/master/src/biginterval.rkt:155:0 -------------------------------------------------------------------- debug-print [45] 100.0% [53] 206(2.5%) 206(2.5%) for-loop ...lies/herbie/master/src/debug.rkt:116:2 -------------------------------------------------------------------- taylor-alt [47] 100.0% [54] 1378(16.5%) 0(0.0%) for-loop ...s/herbie/master/src/mainloop.rkt:152:6 ??? [76] 100.0% -------------------------------------------------------------------- rewrite-expression-head20 [48] 27.4% matcher [62] 72.6% [55] 1272(15.3%) 200(2.4%) rewriter ...erbie/master/src/core/matcher.rkt:90:2 for-loop [59] 81.5% *rules* [6] 15.4% -------------------------------------------------------------------- egraph-add-exprs [49] 100.0% [56] 564(6.8%) 0(0.0%) ??? ...es/herbie/master/src/core/simplify.rkt:72:6 for-loop [61] 100.0% -------------------------------------------------------------------- for-loop [50] 100.0% [57] 552(6.6%) 0(0.0%) atab-add-altn ...ster/src/core/alt-table.rkt:203:0 errors [60] 100.0% -------------------------------------------------------------------- constant? [51] 100.0% [58] 550(6.6%) 550(6.6%) value? .../herbie/master/src/syntax/types.rkt:18:0 -------------------------------------------------------------------- rewriter [55] 100.0% [59] 1272(15.3%) 0(0.0%) for-loop ...erbie/master/src/core/matcher.rkt:92:4 matcher [62] 96.5% for-loop [65] 3.5% -------------------------------------------------------------------- .../more-scheme.rkt:261:28 [16] 28.3% atab-add-altn [57] 71.7% [60] 770(9.2%) 0(0.0%) errors ...tlies/herbie/master/src/points.rkt:201:0 for-loop [63] 52.2% eval-prog [64] 47.8% -------------------------------------------------------------------- ??? [56] 100.0% [61] 564(6.8%) 564(6.8%) for-loop ...rbie/master/src/core/simplify.rkt:91:2 -------------------------------------------------------------------- for-loop [8] 50.0% for-loop [59] 50.0% [62] 1272(15.3%) 0(0.0%) matcher ...erbie/master/src/core/matcher.rkt:118:2 ??? [3] 52.7% rewriter [55] 47.3% -------------------------------------------------------------------- errors [60] 100.0% [63] 402(4.8%) 0(0.0%) for-loop ...ies/herbie/master/src/points.rkt:203:2 .../more-scheme.rkt:261:28 [16]100.0% -------------------------------------------------------------------- errors [60] 100.0% [64] 368(4.4%) 0(0.0%) eval-prog ...s/herbie/master/src/programs.rkt:83:0 temp85_0 [68] 50.0% eval [66] 50.0% -------------------------------------------------------------------- for-loop [59] 100.0% [65] 220(2.6%) 0(0.0%) for-loop ...erbie/master/src/core/matcher.rkt:99:8 fix-up-variables [67] 100.0% -------------------------------------------------------------------- eval-prog [64] 47.9% eval-const-expr [43] 52.1% [66] 384(4.6%) 0(0.0%) eval (unknown source) datum->syntax6 [70] 52.1% add-ns-scopes [71] 47.9% -------------------------------------------------------------------- for-loop [65] 100.0% [67] 220(2.6%) 0(0.0%) fix-up-variables ...ter/src/core/matcher.rkt:111:2 for-loop [69] 100.0% -------------------------------------------------------------------- eval-prog [64] 100.0% [68] 184(2.2%) 0(0.0%) temp85_0 (unknown source) compile15 [72] 100.0% -------------------------------------------------------------------- fix-up-variables [67] 100.0% [69] 220(2.6%) 0(0.0%) for-loop ...erbie/master/src/core/matcher.rkt:42:9 for-loop [74] 100.0% -------------------------------------------------------------------- eval [66] 100.0% [70] 200(2.4%) 0(0.0%) datum->syntax6 (unknown source) loop [73] 100.0% -------------------------------------------------------------------- eval [66] 100.0% [71] 184(2.2%) 0(0.0%) add-ns-scopes (unknown source) gf [103] 100.0% -------------------------------------------------------------------- temp85_0 [68] 100.0% [72] 184(2.2%) 0(0.0%) compile15 (unknown source) temp91_0 [75] 100.0% -------------------------------------------------------------------- syntax-e/no-taint [107] 1.1% eval-const-expr [43] 1.1% datum->syntax6 [70] 2.3% gf [103] 10.6% ??? [29] 17.8% loop [73] 26.1% ??? [26] 40.9% [73] 2208(26.5%) 200(2.4%) loop (unknown source) ??? [76] 58.8% loop [73] 26.1% gf [103] 11.7% expand-capturing-lifts [83] 1.1% -------------------------------------------------------------------- for-loop [69] 100.0% [74] 220(2.6%) 0(0.0%) for-loop ...erbie/master/src/core/matcher.rkt:27:9 core457 [77] 100.0% -------------------------------------------------------------------- compile15 [72] 100.0% [75] 184(2.2%) 0(0.0%) temp91_0 (unknown source) temp118_0 [78] 100.0% -------------------------------------------------------------------- .../more-scheme.rkt:261:28 [16] 4.2% ??? [4] 7.6% location-do [80] 9.6% for-loop [54] 9.6% ??? [29] 15.4% ??? [26] 22.5% loop [73] 31.1% [76] 5154(61.9%) 822(9.9%) ??? ...tract/private/arrow-higher-order.rkt:375:33 sample-multi-bounded [79] 38.3% ival-mult [82] 11.6% location-do [80] 9.6% approximate9 [2] 9.6% hash-ref! [81] 7.6% mk-ival [84] 7.4% -------------------------------------------------------------------- for-loop [74] 100.0% [77] 220(2.6%) 0(0.0%) core457 ...acket/contract/private/arr-i.rkt:976:19 unsafe-chaperone-procedure [85]100.0% -------------------------------------------------------------------- temp91_0 [75] 100.0% [78] 184(2.2%) 0(0.0%) temp118_0 (unknown source) expand-capturing-lifts [83] 100.0% -------------------------------------------------------------------- ??? [76] 100.0% [79] 1976(23.7%) 400(4.8%) sample-multi-bounded ...master/src/points.rkt:15:0 random-ranges [87] 40.6% for-loop [88] 29.5% return/no-unsupplied [109] 9.7% -------------------------------------------------------------------- location-do [80] 32.2% ??? [76] 67.8% [80] 1378(16.5%) 0(0.0%) location-do ...herbie/master/src/programs.rkt:64:0 ??? [76] 67.8% location-do [80] 32.2% -------------------------------------------------------------------- ??? [15] 1.9% simplify* [34] 2.4% ??? [90] 4.3% for-loop [10] 8.6% ??? [86] 14.2% ??? [76] 14.2% loop [9] 14.2% ??? [4] 40.2% [81] 1172(14.1%) 200(2.4%) hash-ref! .../racket/private/more-scheme.rkt:376:2 ??? [4] 54.4% ??? [86] 14.2% ??? [5] 12.9% simplify [14] 11.8% ??? [90] 4.3% -------------------------------------------------------------------- ??? [76] 100.0% [82] 596(7.2%) 406(4.9%) ival-mult ...rbie/master/src/biginterval.rkt:119:0 bfmul [92] 31.9% -------------------------------------------------------------------- temp118_0 [78] 45.3% loop [73] 54.7% [83] 406(4.9%) 0(0.0%) expand-capturing-lifts (unknown source) dispatch-transformer41 [91] 54.7% lambda-clause-expander [93] 45.3% -------------------------------------------------------------------- ??? [76] 100.0% [84] 382(4.6%) 0(0.0%) mk-ival .../herbie/master/src/biginterval.rkt:65:0 bf [89] 100.0% -------------------------------------------------------------------- core457 [77] 100.0% [85] 220(2.6%) 220(2.6%) unsafe-chaperone-procedure ...ivate/kw.rkt:1807:11 -------------------------------------------------------------------- hash-ref! [81] 100.0% [86] 1172(14.1%) 0(0.0%) ??? ...ies/herbie/master/src/core/taylor.rkt:45:15 hash-ref! [81] 100.0% -------------------------------------------------------------------- sample-multi-bounded [79] 100.0% [87] 802(9.6%) 0(0.0%) random-ranges ...erbie/master/src/common.rkt:171:0 cons/c [94] 100.0% -------------------------------------------------------------------- sample-multi-bounded [79] 100.0% [88] 582(7.0%) 582(7.0%) for-loop ...lies/herbie/master/src/points.rkt:23:4 -------------------------------------------------------------------- mk-ival [84] 100.0% [89] 382(4.6%) 0(0.0%) bf ...ath-lib/math/private/bigfloat/mpfr.rkt:615:2 new-mpfr [95] 100.0% -------------------------------------------------------------------- hash-ref! [81] 100.0% [90] 350(4.2%) 0(0.0%) ??? ...es/herbie/master/src/core/taylor.rkt:328:33 hash-ref! [81] 100.0% -------------------------------------------------------------------- expand-capturing-lifts [83] 100.0% [91] 222(2.7%) 0(0.0%) dispatch-transformer41 (unknown source) apply-transformer52 [96] 100.0% -------------------------------------------------------------------- ival-mult [82] 100.0% [92] 190(2.3%) 0(0.0%) bfmul ...-lib/math/private/bigfloat/mpfr.rkt:835:4 new-mpfr [95] 100.0% -------------------------------------------------------------------- expand-capturing-lifts [83] 100.0% [93] 184(2.2%) 0(0.0%) lambda-clause-expander (unknown source) finish-bodys [97] 100.0% -------------------------------------------------------------------- random-ranges [87] 100.0% [94] 802(9.6%) 0(0.0%) cons/c .../racket/contract/private/guts.rkt:500:15 coerce-contract [99] 100.0% -------------------------------------------------------------------- bfmul [92] 33.2% bf [89] 66.8% [95] 572(6.9%) 572(6.9%) new-mpfr ...b/math/private/bigfloat/mpfr.rkt:348:0 -------------------------------------------------------------------- dispatch-transformer41 [91] 100.0% [96] 222(2.7%) 0(0.0%) apply-transformer52 (unknown source) apply-post-expansion [100] 100.0% -------------------------------------------------------------------- lambda-clause-expander [93] 5.9% for-loop [98] 94.1% [97] 184(2.2%) 0(0.0%) finish-bodys (unknown source) for-loop [98] 100.0% -------------------------------------------------------------------- for-loop [98] 2.3% finish-bodys [97] 19.8% *rules* [6] 77.8% [98] 830(10.0%) 240(2.9%) for-loop (unknown source) ormap [102] 48.9% finish-bodys [97] 18.7% for-loop [98] 2.3% dispatch-variable [104] 1.2% -------------------------------------------------------------------- cons/c [94] 100.0% [99] 802(9.6%) 0(0.0%) coerce-contract ...contract/private/guts.rkt:307:0 coerce-contract/f [101] 100.0% -------------------------------------------------------------------- apply-transformer52 [96] 100.0% [100] 222(2.7%) 0(0.0%) apply-post-expansion (unknown source) gf [103] 100.0% -------------------------------------------------------------------- coerce-contract [99] 100.0% [101] 802(9.6%) 0(0.0%) coerce-contract/f ...ntract/private/guts.rkt:372:0 coerce-simple-value [105] 100.0% -------------------------------------------------------------------- for-loop [98] 100.0% [102] 406(4.9%) 0(0.0%) ormap ....5/collects/racket/private/map.rkt:141:13 flag-set? [106] 100.0% -------------------------------------------------------------------- apply-post-expansion [100] 7.8% add-ns-scopes [71] 11.3% loop [73] 80.9% [103] 406(4.9%) 406(4.9%) gf (unknown source) loop [73] 73.0% syntax-e/no-taint [107] 7.8% -------------------------------------------------------------------- for-loop [98] 100.0% [104] 184(2.2%) 0(0.0%) dispatch-variable (unknown source) substitute-variable6 [108] 100.0% -------------------------------------------------------------------- coerce-contract/f [101] 100.0% [105] 802(9.6%) 802(9.6%) coerce-simple-value ...ract/private/guts.rkt:385:0 -------------------------------------------------------------------- ormap [102] 100.0% [106] 406(4.9%) 200(2.4%) flag-set? ...ies/herbie/master/src/config.rkt:28:0 return/no-unsupplied [109] 50.7% -------------------------------------------------------------------- gf [103] 100.0% [107] 222(2.7%) 0(0.0%) syntax-e/no-taint (unknown source) loop [73] 100.0% -------------------------------------------------------------------- dispatch-variable [104] 100.0% [108] 184(2.2%) 184(2.2%) substitute-variable6 (unknown source) -------------------------------------------------------------------- sample-multi-bounded [79] 48.2% flag-set? [106] 51.8% [109] 398(4.8%) 398(4.8%) return/no-unsupplied ...ct/private/arr-i.rkt:566:0 --------------------------------------------------------------------