"skip no precompute" Profiling results ----------------- Total cpu time observed: 5456ms (out of 5668ms) Number of samples taken: 29 (once every 188ms) (Hiding functions with self<1.0% and local<2.0%: 1 of 108 hidden) ======================================================================= Caller Idx Total Self Name+src Local% ms(pct) ms(pct) Callee ======================================================================= [1] 5456(100.0%) 0(0.0%) ??? ...lects/racket/private/more-scheme.rkt:261:28 profile-thunk16 [9] 100.0% ----------------------------------------------------------------------- ??? [83] 100.0% [2] 1014(18.6%) 0(0.0%) approximate9 ...act-exprs/src/core/taylor.rkt:11:0 loop [10] 80.3% for-loop [15] 19.7% ----------------------------------------------------------------------- hash-ref! [73] 100.0% [3] 608(11.1%) 0(0.0%) ??? ...ie/extract-exprs/src/core/taylor.rkt:290:26 for-loop [11] 100.0% ----------------------------------------------------------------------- for-loop [99] 100.0% [4] 408(7.5%) 208(3.8%) expand-implicit (unknown source) resolve+shift28 [14] 49.0% ----------------------------------------------------------------------- parse-loop74 [5] 34.0% hash-ref! [73] 66.0% [5] 408(7.5%) 0(0.0%) parse-loop74 (unknown source) eval-const-expr [22] 66.0% parse-loop74 [5] 34.0% ----------------------------------------------------------------------- hash-ref! [73] 100.0% [6] 408(7.5%) 0(0.0%) ??? ...ie/extract-exprs/src/core/taylor.rkt:300:23 for-loop [12] 100.0% ----------------------------------------------------------------------- hash-ref! [73] 100.0% [7] 400(7.3%) 0(0.0%) taylor-quotient ...exprs/src/core/taylor.rkt:333:0 first-nonzero-exp [13] 100.0% ----------------------------------------------------------------------- for-loop [99] 100.0% [8] 200(3.7%) 0(0.0%) expand-identifier (unknown source) resolve+shift28 [14] 100.0% ----------------------------------------------------------------------- ??? [1] 100.0% [9] 5456(100.0%) 0(0.0%) profile-thunk16 ...e/pkgs/profile-lib/main.rkt:9:0 run [16] 100.0% ----------------------------------------------------------------------- approximate9 [2] 100.0% [10] 814(14.9%) 0(0.0%) loop ...bie/extract-exprs/src/core/taylor.rkt:86:4 hash-ref! [73] 74.4% ??? [83] 25.6% ----------------------------------------------------------------------- ??? [3] 100.0% [11] 608(11.1%) 0(0.0%) for-loop ...tract-exprs/src/core/taylor.rkt:290:52 hash-ref! [73] 34.2% f61 [19] 32.9% ??? [20] 32.9% ----------------------------------------------------------------------- ??? [6] 100.0% [12] 408(7.5%) 0(0.0%) for-loop ...tract-exprs/src/core/taylor.rkt:303:27 hash-ref! [73] 100.0% ----------------------------------------------------------------------- taylor-quotient [7] 100.0% [13] 400(7.3%) 0(0.0%) first-nonzero-exp ...prs/src/core/taylor.rkt:265:0 hash-ref! [73] 100.0% ----------------------------------------------------------------------- expand-implicit [4] 50.0% expand-identifier [8] 50.0% [14] 400(7.3%) 0(0.0%) resolve+shift28 (unknown source) fallback-loop [18] 100.0% ----------------------------------------------------------------------- approximate9 [2] 100.0% [15] 200(3.7%) 0(0.0%) for-loop ...xtract-exprs/src/core/taylor.rkt:29:18 taylor [17] 100.0% ----------------------------------------------------------------------- profile-thunk16 [9] 100.0% [16] 5456(100.0%) 0(0.0%) run ...et-7.5/share/pkgs/profile-lib/main.rkt:39:2 .../more-scheme.rkt:261:28 [21] 100.0% ----------------------------------------------------------------------- for-loop [15] 49.3% hash-ref! [73] 50.7% [17] 406(7.4%) 0(0.0%) taylor .../extract-exprs/src/core/taylor.rkt:169:0 debug-print [33] 50.7% taylor-sqrt [23] 49.3% ----------------------------------------------------------------------- resolve+shift28 [14] 100.0% [18] 400(7.3%) 0(0.0%) fallback-loop (unknown source) for-loop [99] 100.0% ----------------------------------------------------------------------- hash-ref! [73] 50.0% for-loop [11] 50.0% [19] 400(7.3%) 0(0.0%) f61 (unknown source) eval-const-expr [22] 100.0% ----------------------------------------------------------------------- for-loop [11] 100.0% [20] 200(3.7%) 0(0.0%) ??? ...ie/extract-exprs/src/core/taylor.rkt:293:19 hash-ref! [73] 100.0% ----------------------------------------------------------------------- for-loop [68] 8.1% run [16] 91.9% [21] 5456(100.0%) 310(5.7%) .../more-scheme.rkt:261:28 (unknown source) run-improve47 [24] 67.1% prepare-points-intervals [25] 15.0% ??? [26] 3.6% for-loop [28] 3.4% eval-errors [29] 3.2% errors [63] 1.7% ??? [27] 1.7% get-final-combination [30] 1.4% ----------------------------------------------------------------------- f61 [19] 49.5% parse-loop74 [5] 50.5% [22] 808(14.8%) 0(0.0%) eval-const-expr ...ct-exprs/src/programs.rkt:120:0 temp85_0 [67] 100.0% ----------------------------------------------------------------------- taylor [17] 100.0% [23] 200(3.7%) 0(0.0%) taylor-sqrt ...act-exprs/src/core/taylor.rkt:351:0 hash-ref! [73] 100.0% ----------------------------------------------------------------------- .../more-scheme.rkt:261:28 [21] 100.0% [24] 3934(72.1%) 0(0.0%) run-improve47 ...ract-exprs/src/mainloop.rkt:346:0 for-loop [31] 100.0% ----------------------------------------------------------------------- .../more-scheme.rkt:261:28 [21] 100.0% [25] 818(15.0%) 0(0.0%) prepare-points-intervals ...s/src/points.rkt:120:0 loop [32] 100.0% ----------------------------------------------------------------------- .../more-scheme.rkt:261:28 [21] 100.0% [26] 388(7.1%) 388(7.1%) ??? .../extract-exprs/src/syntax/syntax.rkt:214:17 ----------------------------------------------------------------------- .../more-scheme.rkt:261:28 [21] 100.0% [27] 188(3.4%) 188(3.4%) ??? ...cket-7.5/collects/racket/function.rkt:93:12 ----------------------------------------------------------------------- .../more-scheme.rkt:261:28 [21] 100.0% [28] 184(3.4%) 0(0.0%) for-loop ...bie/extract-exprs/src/sandbox.rkt:69:8 debug-print [33] 100.0% ----------------------------------------------------------------------- .../more-scheme.rkt:261:28 [21] 100.0% [29] 176(3.2%) 0(0.0%) eval-errors .../extract-exprs/src/points.rkt:168:0 for-loop [34] 100.0% ----------------------------------------------------------------------- .../more-scheme.rkt:261:28 [21] 100.0% [30] 156(2.9%) 0(0.0%) get-final-combination ...rs/src/mainloop.rkt:371:0 infer-splitpoints [35] 100.0% ----------------------------------------------------------------------- run-improve47 [24] 100.0% [31] 3934(72.1%) 0(0.0%) for-loop ...e/extract-exprs/src/mainloop.rkt:365:4 run-iter! [36] 100.0% ----------------------------------------------------------------------- prepare-points-intervals [25] 100.0% [32] 818(15.0%) 0(0.0%) loop .../herbie/extract-exprs/src/points.rkt:132:4 loop [37] 80.2% ??? [39] 19.8% ----------------------------------------------------------------------- for-loop [28] 47.2% taylor [17] 52.8% [33] 390(7.1%) 0(0.0%) debug-print ...e/extract-exprs/src/debug.rkt:110:0 ??? [38] 100.0% ----------------------------------------------------------------------- eval-errors [29] 100.0% [34] 176(3.2%) 176(3.2%) for-loop ...bie/extract-exprs/src/points.rkt:170:2 ----------------------------------------------------------------------- get-final-combination [30] 100.0% [35] 156(2.9%) 0(0.0%) infer-splitpoints ...prs/src/core/regimes.rkt:33:0 for-loop [40] 100.0% ----------------------------------------------------------------------- for-loop [31] 100.0% [36] 3934(72.1%) 0(0.0%) run-iter! .../extract-exprs/src/mainloop.rkt:327:0 finalize-iter! [41] 47.8% gen-series! [42] 25.8% simplify! [43] 16.8% gen-rewrites! [45] 9.7% ----------------------------------------------------------------------- loop [32] 100.0% [37] 656(12.0%) 0(0.0%) loop ...s/herbie/extract-exprs/src/points.rkt:79:2 ??? [44] 73.2% real->precision [46] 26.8% ----------------------------------------------------------------------- debug-print [33] 100.0% [38] 390(7.1%) 390(7.1%) ??? .../contract/private/arrow-val-first.rkt:555:3 ----------------------------------------------------------------------- loop [32] 100.0% [39] 162(3.0%) 0(0.0%) ??? ...s/herbie/extract-exprs/src/points.rkt:113:6 ??? [44] 100.0% ----------------------------------------------------------------------- infer-splitpoints [35] 100.0% [40] 156(2.9%) 0(0.0%) for-loop ...xtract-exprs/src/core/regimes.rkt:45:6 option-on-expr [47] 100.0% ----------------------------------------------------------------------- run-iter! [36] 100.0% [41] 1880(34.5%) 0(0.0%) finalize-iter! ...act-exprs/src/mainloop.rkt:278:0 ??? [48] 100.0% ----------------------------------------------------------------------- run-iter! [36] 100.0% [42] 1014(18.6%) 0(0.0%) gen-series! ...xtract-exprs/src/mainloop.rkt:160:0 for-loop [49] 100.0% ----------------------------------------------------------------------- run-iter! [36] 100.0% [43] 660(12.1%) 0(0.0%) simplify! .../extract-exprs/src/mainloop.rkt:224:0 ??? [50] 100.0% ----------------------------------------------------------------------- ??? [39] 25.2% loop [37] 74.8% [44] 642(11.8%) 162(3.0%) ??? ...tract/private/arrow-higher-order.rkt:379:33 ival-div [51] 74.8% ----------------------------------------------------------------------- run-iter! [36] 100.0% [45] 380(7.0%) 0(0.0%) gen-rewrites! ...ract-exprs/src/mainloop.rkt:183:0 for-loop [52] 100.0% ----------------------------------------------------------------------- loop [37] 100.0% [46] 176(3.2%) 0(0.0%) real->precision ...ct-exprs/src/programs.rkt:94:11 ??? [83] 100.0% ----------------------------------------------------------------------- for-loop [40] 100.0% [47] 156(2.9%) 0(0.0%) option-on-expr ...exprs/src/core/regimes.rkt:124:0 for-loop [53] 100.0% ----------------------------------------------------------------------- finalize-iter! [41] 100.0% [48] 1880(34.5%) 0(0.0%) ??? ...contract/private/arrow-val-first.rkt:486:18 for-loop [54] 100.0% ----------------------------------------------------------------------- gen-series! [42] 100.0% [49] 1014(18.6%) 0(0.0%) for-loop ...e/extract-exprs/src/mainloop.rkt:167:7 taylor-alt [55] 100.0% ----------------------------------------------------------------------- simplify! [43] 100.0% [50] 660(12.1%) 0(0.0%) ??? ...ie/extract-exprs/src/core/simplify.rkt:44:0 egraph-run [56] 100.0% ----------------------------------------------------------------------- ??? [44] 100.0% [51] 480(8.8%) 480(8.8%) ival-div ...xtract-exprs/src/biginterval.rkt:156:0 ----------------------------------------------------------------------- gen-rewrites! [45] 100.0% [52] 380(7.0%) 0(0.0%) for-loop .../extract-exprs/src/mainloop.rkt:191:11 rewrite-expression-head24 [57] 100.0% ----------------------------------------------------------------------- option-on-expr [47] 100.0% [53] 156(2.9%) 0(0.0%) for-loop ...tract-exprs/src/core/regimes.rkt:135:4 errors [63] 100.0% ----------------------------------------------------------------------- ??? [48] 100.0% [54] 1880(34.5%) 0(0.0%) for-loop ...ract-exprs/src/core/alt-table.rkt:46:2 atab-add-altn [58] 79.6% loop [62] 10.9% errors [63] 9.6% ----------------------------------------------------------------------- for-loop [49] 100.0% [55] 1014(18.6%) 0(0.0%) taylor-alt ...extract-exprs/src/mainloop.rkt:146:0 for-loop [59] 100.0% ----------------------------------------------------------------------- ??? [50] 100.0% [56] 660(12.1%) 0(0.0%) egraph-run .../pkgs/egg-herbie-linux/main.rkt:49:0 egraph-add-exprs [60] 100.0% ----------------------------------------------------------------------- for-loop [52] 100.0% [57] 380(7.0%) 0(0.0%) rewrite-expression-head24 ...core/matcher.rkt:85:0 rewriter [61] 100.0% ----------------------------------------------------------------------- for-loop [54] 100.0% [58] 1496(27.4%) 0(0.0%) atab-add-altn ...xprs/src/core/alt-table.rkt:194:0 errors [63] 100.0% ----------------------------------------------------------------------- taylor-alt [55] 100.0% [59] 1014(18.6%) 0(0.0%) for-loop ...e/extract-exprs/src/mainloop.rkt:152:6 ??? [83] 100.0% ----------------------------------------------------------------------- egraph-run [56] 100.0% [60] 660(12.1%) 0(0.0%) egraph-add-exprs ...gg-herbie-linux/main.rkt:111:0 ??? [64] 66.1% loop [96] 33.9% ----------------------------------------------------------------------- matcher [70] 25.0% rewrite-expression-head24 [57] 75.0% [61] 380(7.0%) 190(3.5%) rewriter ...xtract-exprs/src/core/matcher.rkt:87:2 for-loop [65] 75.0% ----------------------------------------------------------------------- for-loop [54] 100.0% [62] 204(3.7%) 0(0.0%) loop ...extract-exprs/src/core/alt-table.rkt:168:2 loop [66] 100.0% ----------------------------------------------------------------------- for-loop [53] 7.7% for-loop [54] 8.9% .../more-scheme.rkt:261:28 [21] 9.3% atab-add-altn [58] 74.1% [63] 2020(37.0%) 0(0.0%) errors ...erbie/extract-exprs/src/points.rkt:190:0 for-loop [68] 43.9% temp85_0 [67] 37.0% eval-prog [71] 9.6% loop [96] 9.5% ----------------------------------------------------------------------- egraph-add-exprs [60] 100.0% [64] 436(8.0%) 0(0.0%) ??? ...e/extract-exprs/src/core/simplify.rkt:112:6 for-loop [69] 100.0% ----------------------------------------------------------------------- rewriter [61] 100.0% [65] 380(7.0%) 0(0.0%) for-loop ...xtract-exprs/src/core/matcher.rkt:89:4 matcher [70] 100.0% ----------------------------------------------------------------------- loop [62] 10.0% loop [66] 90.0% [66] 204(3.7%) 0(0.0%) loop ...racket-7.5/collects/racket/list.rkt:417:34 loop [66] 90.0% loop [96] 10.0% ----------------------------------------------------------------------- errors [63] 48.1% eval-const-expr [22] 51.9% [67] 1556(28.5%) 0(0.0%) temp85_0 (unknown source) compile15 [72] 100.0% ----------------------------------------------------------------------- errors [63] 100.0% [68] 886(16.2%) 0(0.0%) for-loop ...bie/extract-exprs/src/points.rkt:192:2 .../more-scheme.rkt:261:28 [21] 100.0% ----------------------------------------------------------------------- ??? [64] 100.0% [69] 436(8.0%) 436(8.0%) for-loop ...ract-exprs/src/core/simplify.rkt:131:2 ----------------------------------------------------------------------- for-loop [81] 25.0% for-loop [65] 75.0% [70] 380(7.0%) 0(0.0%) matcher ...xtract-exprs/src/core/matcher.rkt:115:2 ??? [74] 75.0% rewriter [61] 25.0% ----------------------------------------------------------------------- errors [63] 100.0% [71] 194(3.6%) 0(0.0%) eval-prog ...e/extract-exprs/src/programs.rkt:82:0 hash-ref! [73] 100.0% ----------------------------------------------------------------------- temp85_0 [67] 100.0% [72] 1556(28.5%) 0(0.0%) compile15 (unknown source) temp91_0 [75] 100.0% ----------------------------------------------------------------------- ??? [78] 3.4% for-loop [11] 3.4% ??? [77] 3.4% ??? [20] 4.1% ??? [79] 4.1% taylor-sqrt [23] 4.1% for-loop [12] 7.6% first-nonzero-exp [13] 11.0% eval-prog [71] 16.1% loop [10] 19.6% ??? [83] 23.0% [73] 1208(22.1%) 194(3.6%) hash-ref! .../racket/private/more-scheme.rkt:376:2 ??? [76] 19.6% ??? [3] 13.1% taylor-quotient [7] 11.0% parse-loop74 [5] 9.0% taylor [17] 8.5% ??? [6] 7.6% ??? [79] 4.1% f61 [19] 4.1% ??? [77] 3.4% ??? [78] 3.4% ----------------------------------------------------------------------- matcher [70] 100.0% [74] 380(7.0%) 0(0.0%) ??? ...e/extract-exprs/src/core/matcher.rkt:127:11 for-loop [81] 50.0% for-loop [80] 50.0% ----------------------------------------------------------------------- compile15 [72] 100.0% [75] 1556(28.5%) 0(0.0%) temp91_0 (unknown source) temp118_0 [82] 89.7% compile-top9 [85] 10.3% ----------------------------------------------------------------------- hash-ref! [73] 100.0% [76] 606(11.1%) 0(0.0%) ??? ...bie/extract-exprs/src/core/taylor.rkt:67:15 ??? [83] 100.0% ----------------------------------------------------------------------- hash-ref! [73] 100.0% [77] 208(3.8%) 0(0.0%) ??? ...bie/extract-exprs/src/core/taylor.rkt:44:15 hash-ref! [73] 100.0% ----------------------------------------------------------------------- hash-ref! [73] 100.0% [78] 208(3.8%) 0(0.0%) ??? ...ie/extract-exprs/src/core/taylor.rkt:327:33 hash-ref! [73] 100.0% ----------------------------------------------------------------------- hash-ref! [73] 100.0% [79] 200(3.7%) 0(0.0%) ??? ...ie/extract-exprs/src/core/taylor.rkt:343:33 hash-ref! [73] 100.0% ----------------------------------------------------------------------- ??? [74] 100.0% [80] 190(3.5%) 0(0.0%) for-loop ...tract-exprs/src/core/matcher.rkt:103:4 foldl [84] 100.0% ----------------------------------------------------------------------- ??? [74] 100.0% [81] 190(3.5%) 0(0.0%) for-loop ...ract-exprs/src/core/matcher.rkt:129:15 matcher [70] 100.0% ----------------------------------------------------------------------- temp91_0 [75] 100.0% [82] 1396(25.6%) 0(0.0%) temp118_0 (unknown source) expand-capturing-lifts [86] 100.0% ----------------------------------------------------------------------- loop [10] 5.8% real->precision [46] 14.8% ??? [76] 17.0% location-do [87] 31.2% for-loop [59] 31.2% [83] 1190(21.8%) 0(0.0%) ??? ...tract/private/arrow-higher-order.rkt:375:33 location-do [87] 31.2% approximate9 [2] 31.2% hash-ref! [73] 22.8% bf [89] 14.8% ----------------------------------------------------------------------- for-loop [80] 100.0% [84] 190(3.5%) 0(0.0%) foldl ....5/collects/racket/private/list.rkt:229:4 ??? [88] 100.0% ----------------------------------------------------------------------- temp91_0 [75] 100.0% [85] 160(2.9%) 0(0.0%) compile-top9 (unknown source) compile-forms33 [90] 100.0% ----------------------------------------------------------------------- loop [96] 12.1% temp118_0 [82] 87.9% [86] 1588(29.1%) 0(0.0%) expand-capturing-lifts (unknown source) lambda-clause-expander [91] 87.9% expand-id-application-form17 [92] 12.1% ----------------------------------------------------------------------- location-do [87] 40.1% ??? [83] 59.9% [87] 1014(18.6%) 0(0.0%) location-do ...extract-exprs/src/programs.rkt:63:0 ??? [83] 59.9% location-do [87] 40.1% ----------------------------------------------------------------------- foldl [84] 100.0% [88] 190(3.5%) 0(0.0%) ??? ...bie/extract-exprs/src/core/matcher.rkt:25:7 fallback-update [93] 100.0% ----------------------------------------------------------------------- ??? [83] 100.0% [89] 176(3.2%) 0(0.0%) bf ...ath-lib/math/private/bigfloat/mpfr.rkt:615:2 ??? [94] 100.0% ----------------------------------------------------------------------- compile-top9 [85] 100.0% [90] 160(2.9%) 0(0.0%) compile-forms33 (unknown source) for-loop [99] 100.0% ----------------------------------------------------------------------- expand-capturing-lifts [86] 100.0% [91] 1396(25.6%) 0(0.0%) lambda-clause-expander (unknown source) finish-bodys [95] 71.6% loop [96] 14.3% datum->syntax6 [97] 14.0% ----------------------------------------------------------------------- expand-capturing-lifts [86] 100.0% [92] 192(3.5%) 0(0.0%) expand-id-application-form17 (unknown source) binding-lookup52 [98] 100.0% ----------------------------------------------------------------------- ??? [88] 100.0% [93] 190(3.5%) 190(3.5%) fallback-update ...s/racket/private/dict.rkt:115:2 ----------------------------------------------------------------------- bf [89] 100.0% [94] 176(3.2%) 176(3.2%) ??? /opt/racket-7.5/collects/ffi/unsafe.rkt:938:4 ----------------------------------------------------------------------- lambda-clause-expander [91] 29.2% for-loop [99] 70.8% [95] 1000(18.3%) 0(0.0%) finish-bodys (unknown source) for-loop [99] 100.0% ----------------------------------------------------------------------- egraph-add-exprs [60] 0.3% errors [63] 23.4% lambda-clause-expander [91] 24.4% loop [66] 24.9% loop [96] 26.7% [96] 820(15.0%) 204(3.7%) loop (unknown source) loop [96] 26.7% dispatch-transformer41 [101] 24.4% expand-capturing-lifts [86] 23.4% string-join9 [100] 0.3% ----------------------------------------------------------------------- lambda-clause-expander [91] 100.0% [97] 196(3.6%) 196(3.6%) datum->syntax6 (unknown source) ----------------------------------------------------------------------- expand-id-application-form17 [92] 100.0% [98] 192(3.5%) 192(3.5%) binding-lookup52 (unknown source) ----------------------------------------------------------------------- fallback-loop [18] 3.1% compile-forms33 [90] 13.8% for-loop [99] 22.0% finish-bodys [95] 61.1% [99] 1160(21.3%) 400(7.3%) for-loop (unknown source) finish-bodys [95] 42.4% for-loop [99] 22.0% compile-module-linklet57 [104] 13.8% dispatch-transformer41 [101] 8.6% expand-implicit [4] 4.8% dispatch-variable [103] 3.3% expand-identifier [8] 1.9% ----------------------------------------------------------------------- loop [96] 100.0% [100] 224(4.1%) 0(0.0%) string-join9 ....5/collects/racket/string.rkt:29:0 add-between31 [102] 100.0% ----------------------------------------------------------------------- loop [96] 50.0% for-loop [99] 50.0% [101] 400(7.3%) 0(0.0%) dispatch-transformer41 (unknown source) apply-transformer52 [105] 100.0% ----------------------------------------------------------------------- string-join9 [100] 100.0% [102] 224(4.1%) 224(4.1%) add-between31 ....5/collects/racket/list.rkt:336:0 ----------------------------------------------------------------------- for-loop [99] 100.0% [103] 192(3.5%) 0(0.0%) dispatch-variable (unknown source) substitute-variable6 [106] 100.0% ----------------------------------------------------------------------- for-loop [99] 100.0% [104] 160(2.9%) 160(2.9%) compile-module-linklet57 (unknown source) ----------------------------------------------------------------------- dispatch-transformer41 [101] 100.0% [105] 400(7.3%) 0(0.0%) apply-transformer52 (unknown source) apply-transformer-in-context [107]100.0% ----------------------------------------------------------------------- dispatch-variable [103] 100.0% [106] 192(3.5%) 192(3.5%) substitute-variable6 (unknown source) ----------------------------------------------------------------------- apply-transformer52 [105] 100.0% [107] 400(7.3%) 400(7.3%) apply-transformer-in-context (unknown source) -----------------------------------------------------------------------