Profiling results ----------------- Total cpu time observed: 116142ms (out of 116904ms) Number of samples taken: 343 (once every 339ms) (Hiding functions with self<1.0% and local<2.0%: 8 of 210 hidden) ================================================================================ Caller Idx Total Self Name+src Local% ms(pct) ms(pct) Callee ================================================================================ run [13] 50.0% [1] 116142(100.0%) 0(0.0%) ??? ...lects/racket/private/more-scheme.rkt:261:28 profile-thunk16 [8] 50.0% run-improve39 [9] 40.8% loop [21] 5.8% prepare-points [22] 3.4% -------------------------------------------------------------------------------- for-loop [106] 39.0% match-e [115] 61.0% [2] 1548(1.3%) 0(0.0%) variable? ...e/develop/src/syntax/syntax.rkt:713:0 ??? [34] 100.0% -------------------------------------------------------------------------------- expand-capturing-lifts [99] 21.7% for-loop [125] 26.7% loop [116] 51.6% [3] 1372(1.2%) 0(0.0%) dispatch-transformer41 (unknown source) apply-transformer52 [10] 100.0% -------------------------------------------------------------------------------- hash-ref! [161] 100.0% [4] 1036(0.9%) 0(0.0%) ??? ...tlies/herbie/develop/src/programs.rkt:153:5 loop [149] 100.0% -------------------------------------------------------------------------------- loop [149] 100.0% [5] 358(0.3%) 0(0.0%) set-precompute! ...lop/src/core/simplify.rkt:140:0 for-loop [11] 100.0% -------------------------------------------------------------------------------- for-loop [125] 100.0% [6] 352(0.3%) 0(0.0%) expand-identifier (unknown source) resolve+shift28 [102] 100.0% -------------------------------------------------------------------------------- taylor [103] 100.0% [7] 314(0.3%) 0(0.0%) taylor-invert ...develop/src/core/taylor.rkt:312:0 first-nonzero-exp [12] 100.0% -------------------------------------------------------------------------------- ??? [1] 100.0% [8] 116142(100.0%) 0(0.0%) profile-thunk16 ...e/pkgs/profile-lib/main.rkt:9:0 run [13] 100.0% -------------------------------------------------------------------------------- ??? [1] 100.0% [9] 94776(81.6%) 0(0.0%) run-improve39 ...ie/develop/src/mainloop.rkt:286:0 for-loop [14] 97.9% setup-prog!32 [15] 1.3% ??? [34] 0.4% -------------------------------------------------------------------------------- dispatch-transformer41 [3] 100.0% [10] 1372(1.2%) 0(0.0%) apply-transformer52 (unknown source) apply-transformer-in-context [16] 50.4% loop [116] 27.8% apply-post-expansion [19] 21.7% -------------------------------------------------------------------------------- set-precompute! [5] 100.0% [11] 358(0.3%) 0(0.0%) for-loop ...ie/develop/src/core/simplify.rkt:142:2 eval-const-expr [18] 100.0% -------------------------------------------------------------------------------- taylor-invert [7] 100.0% [12] 314(0.3%) 0(0.0%) first-nonzero-exp ...lop/src/core/taylor.rkt:260:0 simplify [17] 100.0% -------------------------------------------------------------------------------- profile-thunk16 [8] 100.0% [13] 116142(100.0%) 0(0.0%) run ...racket/share/pkgs/profile-lib/main.rkt:39:2 ??? [1] 100.0% -------------------------------------------------------------------------------- run-improve39 [9] 100.0% [14] 92772(79.9%) 0(0.0%) for-loop .../herbie/develop/src/mainloop.rkt:303:8 run-iter! [20] 100.0% -------------------------------------------------------------------------------- run-improve39 [9] 100.0% [15] 1274(1.1%) 0(0.0%) setup-prog!32 ...bie/develop/src/mainloop.rkt:63:0 prepare-points [22] 77.7% loop [21] 22.3% -------------------------------------------------------------------------------- apply-transformer52 [10] 100.0% [16] 692(0.6%) 0(0.0%) apply-transformer-in-context (unknown source) parse-app [23] 52.9% ??? [24] 47.1% -------------------------------------------------------------------------------- loop [149] 49.5% first-nonzero-exp [12] 50.5% [17] 622(0.5%) 0(0.0%) simplify ...erbie/develop/src/core/reduce.rkt:16:0 f206 [66] 50.5% simplify* [25] 49.5% -------------------------------------------------------------------------------- for-loop [11] 100.0% [18] 358(0.3%) 0(0.0%) eval-const-expr .../develop/src/programs.rkt:132:0 eval-prog [61] 100.0% -------------------------------------------------------------------------------- apply-transformer52 [10] 100.0% [19] 298(0.3%) 0(0.0%) apply-post-expansion (unknown source) gf [126] 100.0% -------------------------------------------------------------------------------- for-loop [14] 100.0% [20] 92772(79.9%) 0(0.0%) run-iter! ...herbie/develop/src/mainloop.rkt:267:0 simplify! [26] 76.9% finalize-iter! [27] 21.1% gen-rewrites! [29] 1.3% gen-series! [30] 0.7% -------------------------------------------------------------------------------- setup-prog!32 [15] 2.1% ??? [1] 97.9% [21] 13762(11.8%) 0(0.0%) loop ...htlies/herbie/develop/src/points.rkt:180:2 loop [28] 42.4% loop [36] 35.9% make-exacts* [35] 19.2% for-loop [31] 2.5% -------------------------------------------------------------------------------- setup-prog!32 [15] 11.2% ??? [1] 88.8% [22] 8878(7.6%) 0(0.0%) prepare-points ...bie/develop/src/points.rkt:156:0 loop [28] 39.0% make-exacts* [35] 34.6% loop [36] 26.4% -------------------------------------------------------------------------------- apply-transformer-in-context [16] 100.0% [23] 366(0.3%) 0(0.0%) parse-app ...collects/racket/private/kw.rkt:1105:2 syntax->list [38] 100.0% -------------------------------------------------------------------------------- apply-transformer-in-context [16] 100.0% [24] 326(0.3%) 0(0.0%) ??? ...collects/racket/private/qq-and-or.rkt:155:9 ??? [32] 100.0% -------------------------------------------------------------------------------- simplify [17] 100.0% [25] 308(0.3%) 0(0.0%) simplify* ...rbie/develop/src/core/reduce.rkt:31:0 hash-ref! [161] 100.0% -------------------------------------------------------------------------------- run-iter! [20] 100.0% [26] 71318(61.4%) 0(0.0%) simplify! ...herbie/develop/src/mainloop.rkt:181:0 for-loop [33] 100.0% -------------------------------------------------------------------------------- run-iter! [20] 100.0% [27] 19604(16.9%) 0(0.0%) finalize-iter! ...e/develop/src/mainloop.rkt:221:0 ??? [34] 100.0% -------------------------------------------------------------------------------- prepare-points [22] 37.3% loop [21] 62.7% [28] 9302(8.0%) 0(0.0%) loop ...htlies/herbie/develop/src/points.rkt:124:2 make-exacts* [35] 70.8% loop [36] 29.2% -------------------------------------------------------------------------------- run-iter! [20] 100.0% [29] 1228(1.1%) 0(0.0%) gen-rewrites! ...ie/develop/src/mainloop.rkt:164:0 for-loop [37] 100.0% -------------------------------------------------------------------------------- run-iter! [20] 100.0% [30] 622(0.5%) 0(0.0%) gen-series! ...rbie/develop/src/mainloop.rkt:151:0 for-loop [39] 100.0% -------------------------------------------------------------------------------- loop [21] 100.0% [31] 342(0.3%) 0(0.0%) for-loop ...s/herbie/develop/src/points.rkt:195:19 ??? [40] 100.0% -------------------------------------------------------------------------------- ??? [24] 100.0% [32] 326(0.3%) 0(0.0%) ??? ...ollects/racket/private/qq-and-or.rkt:164:21 syntax->list [38] 100.0% -------------------------------------------------------------------------------- simplify! [26] 100.0% [33] 71318(61.4%) 0(0.0%) for-loop .../herbie/develop/src/mainloop.rkt:185:6 for-loop [41] 99.1% debug-print [101] 0.9% -------------------------------------------------------------------------------- run-improve39 [9] 1.5% substitute-e [124] 4.2% variable? [2] 6.2% match-e [115] 9.2% finalize-iter! [27] 78.8% [34] 24880(21.4%) 3294(2.8%) ??? ...contract/private/arrow-val-first.rkt:388:18 for-loop [42] 80.3% hash-has-key? [154] 6.4% -------------------------------------------------------------------------------- loop [21] 21.5% prepare-points [22] 25.0% loop [28] 53.6% [35] 12304(10.6%) 316(0.3%) make-exacts* ...erbie/develop/src/points.rkt:104:0 loop [149] 76.5% eval-prog [61] 21.0% -------------------------------------------------------------------------------- prepare-points [22] 23.4% loop [28] 27.1% loop [21] 49.4% [36] 9994(8.6%) 0(0.0%) loop ...htlies/herbie/develop/src/points.rkt:107:4 loop [149] 100.0% -------------------------------------------------------------------------------- gen-rewrites! [29] 100.0% [37] 1228(1.1%) 0(0.0%) for-loop ...herbie/develop/src/mainloop.rkt:169:11 ??? [43] 100.0% -------------------------------------------------------------------------------- ??? [32] 47.1% parse-app [23] 52.9% [38] 692(0.6%) 0(0.0%) syntax->list (unknown source) loop [116] 100.0% -------------------------------------------------------------------------------- gen-series! [30] 100.0% [39] 622(0.5%) 0(0.0%) for-loop .../herbie/develop/src/mainloop.rkt:157:7 taylor-alt [44] 100.0% -------------------------------------------------------------------------------- for-loop [31] 100.0% [40] 342(0.3%) 0(0.0%) ??? ...ghtlies/herbie/develop/src/points.rkt:172:7 for-loop [45] 100.0% -------------------------------------------------------------------------------- for-loop [33] 100.0% [41] 70686(60.9%) 0(0.0%) for-loop .../herbie/develop/src/mainloop.rkt:209:8 ??? [69] 100.0% -------------------------------------------------------------------------------- ??? [34] 100.0% [42] 19984(17.2%) 0(0.0%) for-loop ...ie/develop/src/core/alt-table.rkt:51:2 atab-add-altn [46] 98.4% loop [49] 1.6% -------------------------------------------------------------------------------- for-loop [37] 100.0% [43] 1228(1.1%) 0(0.0%) ??? ...ies/herbie/develop/src/alternative.rkt:60:0 rewriter [47] 100.0% -------------------------------------------------------------------------------- for-loop [39] 100.0% [44] 622(0.5%) 0(0.0%) taylor-alt ...erbie/develop/src/mainloop.rkt:136:0 for-loop [48] 100.0% -------------------------------------------------------------------------------- ??? [40] 100.0% [45] 342(0.3%) 0(0.0%) for-loop ...es/herbie/develop/src/points.rkt:173:9 ??? [69] 100.0% -------------------------------------------------------------------------------- for-loop [42] 100.0% [46] 19656(16.9%) 0(0.0%) atab-add-altn ...elop/src/core/alt-table.rkt:210:0 override-at-pnts [50] 59.4% best-and-tied-at-points [51] 40.6% -------------------------------------------------------------------------------- matcher [57] 48.9% ??? [43] 51.1% [47] 1228(1.1%) 0(0.0%) rewriter ...bie/develop/src/core/matcher.rkt:131:2 for-loop [52] 73.3% *rules* [53] 26.7% -------------------------------------------------------------------------------- taylor-alt [44] 100.0% [48] 622(0.5%) 0(0.0%) for-loop .../herbie/develop/src/mainloop.rkt:142:6 ??? [69] 100.0% -------------------------------------------------------------------------------- for-loop [42] 100.0% [49] 328(0.3%) 0(0.0%) loop ...erbie/develop/src/core/alt-table.rkt:184:2 argmax [54] 100.0% -------------------------------------------------------------------------------- atab-add-altn [46] 100.0% [50] 11680(10.1%) 0(0.0%) override-at-pnts ...p/src/core/alt-table.rkt:145:0 errors [55] 97.1% for-loop [58] 2.9% -------------------------------------------------------------------------------- atab-add-altn [46] 100.0% [51] 7976(6.9%) 0(0.0%) best-and-tied-at-points ...ore/alt-table.rkt:122:0 errors [55] 95.8% for-loop [59] 4.2% -------------------------------------------------------------------------------- rewriter [47] 100.0% [52] 900(0.8%) 0(0.0%) for-loop ...ie/develop/src/core/matcher.rkt:134:10 matcher [57] 66.7% type-of [56] 33.3% -------------------------------------------------------------------------------- rewriter [47] 100.0% [53] 328(0.3%) 0(0.0%) *rules* ...rbie/develop/src/syntax/rules.rkt:643:0 for-loop [135] 100.0% -------------------------------------------------------------------------------- loop [49] 100.0% [54] 328(0.3%) 0(0.0%) argmax ...92/racket/collects/racket/list.rkt:766:0 for-loop [117] 100.0% -------------------------------------------------------------------------------- best-and-tied-at-points [51] 40.3% override-at-pnts [50] 59.7% [55] 18982(16.3%) 0(0.0%) errors ...lies/herbie/develop/src/points.rkt:203:0 for-loop [60] 81.1% eval-prog [61] 18.9% -------------------------------------------------------------------------------- for-loop [52] 100.0% [56] 900(0.8%) 0(0.0%) type-of .../herbie/develop/src/type-check.rkt:34:0 ??? [165] 66.2% table-ref [166] 33.8% -------------------------------------------------------------------------------- for-loop [62] 50.0% for-loop [52] 50.0% [57] 900(0.8%) 0(0.0%) matcher ...rbie/develop/src/core/matcher.rkt:168:2 for-loop [62] 50.0% rewriter [47] 50.0% -------------------------------------------------------------------------------- override-at-pnts [50] 100.0% [58] 342(0.3%) 0(0.0%) for-loop .../develop/src/core/alt-table.rkt:146:43 ??? [63] 100.0% -------------------------------------------------------------------------------- best-and-tied-at-points [51] 100.0% [59] 332(0.3%) 332(0.3%) for-loop .../develop/src/core/alt-table.rkt:124:16 -------------------------------------------------------------------------------- errors [55] 100.0% [60] 15392(13.3%) 646(0.6%) for-loop ...es/herbie/develop/src/points.rkt:206:4 ??? [64] 79.9% ulp-difference [67] 9.3% ??? [69] 6.6% -------------------------------------------------------------------------------- eval-const-expr [18] 5.5% make-exacts* [35] 39.5% errors [55] 55.0% [61] 6528(5.6%) 0(0.0%) eval-prog ...herbie/develop/src/programs.rkt:109:0 temp68_2 [65] 37.0% f206 [66] 29.5% hash-ref! [161] 15.9% loop [116] 13.3% eval4 [68] 4.4% -------------------------------------------------------------------------------- matcher [57] 100.0% [62] 900(0.8%) 0(0.0%) for-loop ...ie/develop/src/core/matcher.rkt:184:21 matcher [57] 100.0% -------------------------------------------------------------------------------- for-loop [58] 100.0% [63] 342(0.3%) 342(0.3%) ??? ...ket/collects/racket/private/for.rkt:1208:14 -------------------------------------------------------------------------------- for-loop [60] 41.7% loop [149] 58.3% [64] 29496(25.4%) 1014(0.9%) ??? ...tlies/herbie/develop/src/programs.rkt:129:2 ??? [70] 79.8% bf [71] 15.7% ??? [69] 1.1% -------------------------------------------------------------------------------- eval-prog [61] 100.0% [65] 2416(2.1%) 0(0.0%) temp68_2 (unknown source) compile16 [72] 100.0% -------------------------------------------------------------------------------- eval-prog [61] 12.6% simplify [17] 14.0% f206 [66] 73.3% [66] 2240(1.9%) 0(0.0%) f206 .../collects/racket/match/compiler.rkt:507:40 f206 [66] 73.3% eval [74] 14.0% table-ref [166] 4.9% ??? [69] 2.5% get/build-late-neg-projection [193] 1.7% ??? [188] 1.6% -------------------------------------------------------------------------------- for-loop [60] 100.0% [67] 1432(1.2%) 0(0.0%) ulp-difference ...erbie/develop/src/float.rkt:19:0 return/no-unsupplied [91] 100.0% -------------------------------------------------------------------------------- eval-prog [61] 100.0% [68] 284(0.2%) 0(0.0%) eval4 (unknown source) syntax-e [73] 100.0% -------------------------------------------------------------------------------- for-loop [48] 0.4% ??? [64] 0.4% f206 [66] 0.4% for-loop [45] 0.5% for-loop [60] 1.3% loop [149] 2.9% for-loop [41] 46.8% location-do [75] 47.2% [69] 75530(65.0%) 0(0.0%) ??? ...tract/private/arrow-higher-order.rkt:357:33 location-do [75] 47.2% ??? [76] 46.6% ->flonum [77] 5.1% approximate9 [83] 0.4% ??? [86] 0.2% -------------------------------------------------------------------------------- ??? [64] 100.0% [70] 23536(20.3%) 10872(9.4%) ??? ...acket/collects/racket/private/kw.rkt:592:14 ??? [88] 28.5% ??? [78] 12.3% ??? [80] 7.0% bf* [82] 3.0% ...higher-order.rkt:361:33 [84] 1.5% -------------------------------------------------------------------------------- ??? [64] 100.0% [71] 4622(4.0%) 0(0.0%) bf ...ath-lib/math/private/bigfloat/mpfr.rkt:601:2 new-mpfr [178] 86.2% ??? [107] 13.8% -------------------------------------------------------------------------------- temp68_2 [65] 100.0% [72] 2416(2.1%) 0(0.0%) compile16 (unknown source) temp74_0 [79] 100.0% -------------------------------------------------------------------------------- eval4 [68] 29.1% loop [116] 70.9% [73] 976(0.8%) 0(0.0%) syntax-e (unknown source) syntax-e/no-taint [81] 100.0% -------------------------------------------------------------------------------- f206 [66] 100.0% [74] 314(0.3%) 0(0.0%) eval (unknown source) namespace-syntax-introduce3 [85] 100.0% -------------------------------------------------------------------------------- ??? [69] 21.9% location-do [75] 78.1% [75] 71308(61.4%) 0(0.0%) location-do ...erbie/develop/src/programs.rkt:90:0 location-do [75] 78.1% ??? [69] 21.9% -------------------------------------------------------------------------------- ??? [69] 99.5% [76] 70740(60.9%) 0(0.0%) ??? ...s/herbie/develop/src/core/simplify.rkt:31:0 iterate-egraph!7 [87] 94.6% loop [89] 4.9% mk-egraph [92] 0.5% -------------------------------------------------------------------------------- ??? [69] 100.0% [77] 3880(3.3%) 2554(2.2%) ->flonum ...s/herbie/develop/src/programs.rkt:36:0 ??? [192] 8.8% ??? [107] 8.7% ??? [175] 8.7% return/no-unsupplied [91] 8.0% -------------------------------------------------------------------------------- ??? [70] 100.0% [78] 2902(2.5%) 2902(2.5%) ??? ...rivate/unconstrained-domain-arrow.rkt:40:13 -------------------------------------------------------------------------------- compile16 [72] 100.0% [79] 2416(2.1%) 0(0.0%) temp74_0 (unknown source) expand-single [90] 100.0% -------------------------------------------------------------------------------- ??? [70] 100.0% [80] 1646(1.4%) 1288(1.1%) ??? ...herbie/develop/src/syntax/syntax.rkt:195:17 ??? [175] 21.7% -------------------------------------------------------------------------------- gf [126] 23.4% syntax-e [73] 76.6% [81] 1274(1.1%) 0(0.0%) syntax-e/no-taint (unknown source) loop [116] 100.0% -------------------------------------------------------------------------------- ??? [70] 100.0% [82] 704(0.6%) 0(0.0%) bf* ...ath/private/bigfloat/bigfloat-mpfr.rkt:95:0 ??? [88] 100.0% -------------------------------------------------------------------------------- ??? [69] 100.0% [83] 622(0.5%) 0(0.0%) approximate9 ...e/develop/src/core/taylor.rkt:12:0 taylor [103] 50.5% for-loop [94] 49.5% -------------------------------------------------------------------------------- ??? [70] 100.0% [84] 344(0.3%) 0(0.0%) ...higher-order.rkt:361:33 (unknown source) ??? [179] 100.0% -------------------------------------------------------------------------------- eval [74] 100.0% [85] 314(0.3%) 0(0.0%) namespace-syntax-introduce3 (unknown source) free-identifier=? [93] 100.0% -------------------------------------------------------------------------------- ??? [69] 100.0% [86] 296(0.3%) 0(0.0%) ??? ...lies/herbie/develop/src/mainloop.rkt:210:62 *simplify-rules* [95] 100.0% -------------------------------------------------------------------------------- ??? [76] 100.0% [87] 66950(57.6%) 340(0.3%) iterate-egraph!7 ...lop/src/core/simplify.rkt:55:0 one-iter [96] 98.5% debug-print [101] 0.4% -------------------------------------------------------------------------------- bf* [82] 9.5% ??? [70] 90.5% [88] 7416(6.4%) 1330(1.1%) ??? ...-racket/utils/simple-result-arrow.rkt:39:12 bfsub [97] 57.1% bfatan [100] 25.0% -------------------------------------------------------------------------------- ??? [76] 100.0% [89] 3456(3.0%) 0(0.0%) loop ...herbie/develop/src/core/simplify.rkt:184:2 for-loop [98] 100.0% -------------------------------------------------------------------------------- temp74_0 [79] 100.0% [90] 2416(2.1%) 0(0.0%) expand-single (unknown source) expand-capturing-lifts [99] 100.0% -------------------------------------------------------------------------------- ->flonum [77] 17.9% ulp-difference [67] 82.1% [91] 1744(1.5%) 1744(1.5%) return/no-unsupplied ...ct/private/arr-i.rkt:534:0 -------------------------------------------------------------------------------- ??? [76] 100.0% [92] 334(0.3%) 0(0.0%) mk-egraph ...bie/develop/src/core/egraph.rkt:131:0 mk-enode-rec! [104] 100.0% -------------------------------------------------------------------------------- namespace-syntax-introduce3 [85] 100.0% [93] 314(0.3%) 0(0.0%) free-identifier=? (unknown source) resolve+shift28 [102] 100.0% -------------------------------------------------------------------------------- approximate9 [83] 100.0% [94] 308(0.3%) 0(0.0%) for-loop ...rbie/develop/src/core/taylor.rkt:29:18 taylor [103] 100.0% -------------------------------------------------------------------------------- ??? [86] 100.0% [95] 296(0.3%) 0(0.0%) *simplify-rules* ...lop/src/syntax/rules.rkt:648:0 for-loop [135] 100.0% -------------------------------------------------------------------------------- iterate-egraph!7 [87] 100.0% [96] 65952(56.8%) 642(0.6%) one-iter ...bie/develop/src/core/simplify.rkt:66:0 for-loop [105] 75.2% for-loop [106] 23.3% -------------------------------------------------------------------------------- ??? [88] 100.0% [97] 4232(3.6%) 408(0.4%) bfsub ...-lib/math/private/bigfloat/mpfr.rkt:821:4 new-mpfr [178] 63.1% ??? [107] 27.2% -------------------------------------------------------------------------------- loop [89] 100.0% [98] 3456(3.0%) 0(0.0%) for-loop ...e/develop/src/core/simplify.rkt:177:29 argmin [108] 72.2% for-loop [110] 19.0% loop [113] 8.7% -------------------------------------------------------------------------------- loop [116] 26.4% expand-single [90] 73.6% [99] 3282(2.8%) 310(0.3%) expand-capturing-lifts (unknown source) lambda-clause-expander [109] 53.3% loop [116] 28.2% dispatch-transformer41 [3] 9.1% -------------------------------------------------------------------------------- ??? [88] 100.0% [100] 1854(1.6%) 0(0.0%) bfatan ...lib/math/private/bigfloat/mpfr.rkt:618:4 new-mpfr [178] 56.7% ??? [107] 43.3% -------------------------------------------------------------------------------- iterate-egraph!7 [87] 32.2% for-loop [33] 67.8% [101] 932(0.8%) 300(0.3%) debug-print .../herbie/develop/src/debug.rkt:107:0 for-loop [111] 67.8% -------------------------------------------------------------------------------- free-identifier=? [93] 47.1% expand-identifier [6] 52.9% [102] 666(0.6%) 314(0.3%) resolve+shift28 (unknown source) fallback-loop [112] 52.9% -------------------------------------------------------------------------------- for-loop [94] 16.5% approximate9 [83] 16.8% taylor [103] 66.7% [103] 622(0.5%) 0(0.0%) taylor ...herbie/develop/src/core/taylor.rkt:163:0 taylor [103] 66.7% taylor-invert [7] 16.8% loop [149] 16.5% -------------------------------------------------------------------------------- mk-egraph [92] 20.0% mk-enode-rec! [104] 80.0% [104] 334(0.3%) 0(0.0%) mk-enode-rec! ...develop/src/core/egraph.rkt:122:0 mk-enode-rec! [104] 80.0% mk-enode! [139] 20.0% -------------------------------------------------------------------------------- one-iter [96] 100.0% [105] 49596(42.7%) 0(0.0%) for-loop ...ie/develop/src/core/simplify.rkt:113:2 for-loop [114] 80.6% match-e [115] 10.1% update-leader! [130] 6.2% reduce-to-single! [119] 1.8% set [153] 0.6% -------------------------------------------------------------------------------- for-loop [106] 48.0% one-iter [96] 52.0% [106] 15386(13.2%) 4486(3.9%) for-loop ...ie/develop/src/core/simplify.rkt:76:12 for-loop [106] 48.0% match-e [115] 33.5% variable? [2] 2.0% -------------------------------------------------------------------------------- ->flonum [77] 11.5% bf [71] 21.8% bfatan [100] 27.4% bfsub [97] 39.3% [107] 2930(2.5%) 2930(2.5%) ??? /home/p92/racket/collects/ffi/unsafe.rkt:898:4 -------------------------------------------------------------------------------- for-loop [98] 100.0% [108] 2496(2.1%) 0(0.0%) argmin ...92/racket/collects/racket/list.rkt:765:0 for-loop [117] 86.7% expression-cost [121] 13.3% -------------------------------------------------------------------------------- expand-capturing-lifts [99] 100.0% [109] 1748(1.5%) 0(0.0%) lambda-clause-expander (unknown source) finish-bodys [118] 59.5% loop [116] 40.5% -------------------------------------------------------------------------------- for-loop [98] 100.0% [110] 658(0.6%) 324(0.3%) for-loop ...e/develop/src/core/simplify.rkt:164:13 for-loop [120] 50.8% -------------------------------------------------------------------------------- debug-print [101] 100.0% [111] 632(0.5%) 632(0.5%) for-loop ...ies/herbie/develop/src/debug.rkt:113:2 -------------------------------------------------------------------------------- resolve+shift28 [102] 100.0% [112] 352(0.3%) 0(0.0%) fallback-loop (unknown source) for-loop [125] 100.0% -------------------------------------------------------------------------------- for-loop [98] 100.0% [113] 302(0.3%) 0(0.0%) loop .../p92/racket/collects/racket/list.rkt:751:4 for-loop [117] 100.0% -------------------------------------------------------------------------------- for-loop [105] 100.0% [114] 39988(34.4%) 0(0.0%) for-loop ...bie/develop/src/core/simplify.rkt:98:4 merge-egraph-nodes! [122] 41.0% mk-enode! [139] 24.6% substitute-e [124] 18.5% loop! [141] 15.8% -------------------------------------------------------------------------------- for-loop [105] 22.2% for-loop [131] 29.3% for-loop [106] 48.5% [115] 15292(13.2%) 2246(1.9%) match-e ...herbie/develop/src/core/ematch.rkt:46:0 for-loop [123] 69.5% ??? [34] 6.1% custom-in-set [127] 5.0% variable? [2] 2.6% make-sequence [156] 2.1% -------------------------------------------------------------------------------- loop [116] 6.5% apply-transformer52 [10] 6.6% syntax->list [38] 10.0% lambda-clause-expander [109] 10.3% for-loop [125] 11.1% eval-prog [61] 11.7% expand-capturing-lifts [99] 18.8% syntax-e/no-taint [81] 25.0% [116] 2904(2.5%) 1346(1.2%) loop (unknown source) gf [126] 15.2% expand-capturing-lifts [99] 11.7% dispatch-transformer41 [3] 10.3% syntax-e [73] 10.0% loop [116] 6.5% for-loop [125] 6.5% -------------------------------------------------------------------------------- loop [113] 10.8% argmax [54] 11.7% argmin [108] 77.5% [117] 2794(2.4%) 598(0.5%) for-loop .../herbie/develop/src/programs.rkt:169:2 ...velop/src/common.rkt:48:2 [167] 45.6% table-ref [166] 33.0% -------------------------------------------------------------------------------- lambda-clause-expander [109] 15.1% for-loop [125] 84.9% [118] 1040(0.9%) 0(0.0%) finish-bodys (unknown source) for-loop [125] 100.0% -------------------------------------------------------------------------------- for-loop [105] 100.0% [119] 906(0.8%) 302(0.3%) reduce-to-single! ...lop/src/core/egraph.rkt:325:0 for-loop [128] 33.3% for-loop [129] 33.3% -------------------------------------------------------------------------------- for-loop [110] 100.0% [120] 334(0.3%) 334(0.3%) for-loop ...e/develop/src/core/simplify.rkt:167:37 -------------------------------------------------------------------------------- argmin [108] 100.0% [121] 332(0.3%) 332(0.3%) expression-cost .../develop/src/programs.rkt:168:0 -------------------------------------------------------------------------------- for-loop [133] 9.5% for-loop [114] 90.5% [122] 16404(14.1%) 334(0.3%) merge-egraph-nodes! ...p/src/core/egraph.rkt:153:0 update-leader! [130] 68.2% for-loop [133] 23.8% enode-merge! [136] 4.0% for-loop [135] 1.9% update-en-expr [180] 1.0% -------------------------------------------------------------------------------- match-e [115] 100.0% [123] 12114(10.4%) 4168(3.6%) for-loop ...rbie/develop/src/core/ematch.rkt:59:11 for-loop [131] 55.6% list-cartesian-product [134] 14.0% loop [149] 2.7% curry* [138] 1.4% -------------------------------------------------------------------------------- for-loop [132] 6.2% for-loop [114] 93.8% [124] 7402(6.4%) 0(0.0%) substitute-e ...e/develop/src/core/ematch.rkt:71:0 for-loop [132] 92.0% ??? [34] 8.0% -------------------------------------------------------------------------------- fallback-loop [112] 1.3% loop [116] 3.9% run-module-instance!125 [137] 15.7% for-loop [125] 22.8% finish-bodys [118] 56.3% [125] 1608(1.4%) 920(0.8%) for-loop (unknown source) finish-bodys [118] 47.9% for-loop [125] 22.8% run-module-instance!125 [137] 15.7% dispatch-transformer41 [3] 4.6% loop [116] 2.5% expand-identifier [6] 1.3% -------------------------------------------------------------------------------- apply-post-expansion [19] 15.1% loop [116] 84.9% [126] 990(0.9%) 990(0.9%) gf (unknown source) syntax-e/no-taint [81] 15.1% -------------------------------------------------------------------------------- match-e [115] 100.0% [127] 906(0.8%) 906(0.8%) custom-in-set ...acket/private/set-types.rkt:577:0 -------------------------------------------------------------------------------- reduce-to-single! [119] 100.0% [128] 302(0.3%) 302(0.3%) for-loop ...rbie/develop/src/core/egraph.rkt:326:8 -------------------------------------------------------------------------------- reduce-to-single! [119] 100.0% [129] 302(0.3%) 0(0.0%) for-loop ...bie/develop/src/core/egraph.rkt:329:21 update-en-expr [180] 100.0% -------------------------------------------------------------------------------- for-loop [105] 20.1% merge-egraph-nodes! [122] 79.9% [130] 15294(13.2%) 320(0.3%) update-leader! ...evelop/src/core/egraph.rkt:218:0 for-loop [140] 89.7% for-loop [142] 8.2% -------------------------------------------------------------------------------- for-loop [123] 100.0% [131] 8988(7.7%) 632(0.5%) for-loop ...rbie/develop/src/core/ematch.rkt:65:37 match-e [115] 91.3% ??? [148] 3.5% -------------------------------------------------------------------------------- substitute-e [124] 100.0% [132] 7042(6.1%) 332(0.3%) for-loop ...rbie/develop/src/core/ematch.rkt:80:24 mk-enode! [139] 85.5% substitute-e [124] 9.8% -------------------------------------------------------------------------------- merge-egraph-nodes! [122] 100.0% [133] 5158(4.4%) 0(0.0%) for-loop ...bie/develop/src/core/egraph.rkt:201:10 merge-egraph-nodes! [122] 54.5% loop! [141] 45.5% -------------------------------------------------------------------------------- list-cartesian-product [134] 27.7% for-loop [123] 72.3% [134] 2490(2.1%) 1832(1.6%) list-cartesian-product ...src/core/ematch.rkt:20:0 list-cartesian-product [134] 27.7% for-loop [143] 19.2% -------------------------------------------------------------------------------- *simplify-rules* [95] 31.7% merge-egraph-nodes! [122] 33.2% *rules* [53] 35.1% [135] 934(0.8%) 606(0.5%) for-loop ...ies/herbie/develop/src/common.rkt:92:9 ormap [146] 35.1% -------------------------------------------------------------------------------- merge-egraph-nodes! [122] 100.0% [136] 660(0.6%) 0(0.0%) enode-merge! ...e/develop/src/core/enode.rkt:127:0 custom-set-intersect! [144] 52.1% adopt-enode! [147] 47.9% -------------------------------------------------------------------------------- for-loop [125] 100.0% [137] 568(0.5%) 0(0.0%) run-module-instance!125 (unknown source) for-loop [125] 100.0% -------------------------------------------------------------------------------- for-loop [123] 100.0% [138] 340(0.3%) 0(0.0%) curry* ...racket/collects/racket/function.rkt:44:2 procedure-arity [145] 100.0% -------------------------------------------------------------------------------- mk-enode-rec! [104] 2.1% for-loop [132] 37.2% for-loop [114] 60.8% [139] 16200(13.9%) 1206(1.0%) mk-enode! ...bie/develop/src/core/egraph.rkt:102:0 new-enode [150] 84.9% for-loop [155] 3.9% hash-has-key? [154] 3.8% -------------------------------------------------------------------------------- update-leader! [130] 100.0% [140] 13716(11.8%) 0(0.0%) for-loop ...rbie/develop/src/core/egraph.rkt:223:6 for-loop [151] 97.8% update-en-expr [180] 2.2% -------------------------------------------------------------------------------- for-loop [133] 18.1% loop [149] 31.8% for-loop [114] 50.1% [141] 8886(7.7%) 1886(1.6%) loop! ...s/herbie/develop/src/core/enode.rkt:190:2 loop [149] 39.0% custom-set-union [152] 29.2% set [153] 16.0% update-en-expr [180] 5.2% -------------------------------------------------------------------------------- update-leader! [130] 100.0% [142] 1258(1.1%) 960(0.8%) for-loop ...rbie/develop/src/core/egraph.rkt:233:6 update-en-expr [180] 23.7% -------------------------------------------------------------------------------- list-cartesian-product [134] 100.0% [143] 658(0.6%) 658(0.6%) for-loop ...erbie/develop/src/core/ematch.rkt:24:8 -------------------------------------------------------------------------------- enode-merge! [136] 100.0% [144] 344(0.3%) 344(0.3%) custom-set-intersect! ...ivate/set-types.rkt:269:0 -------------------------------------------------------------------------------- curry* [138] 100.0% [145] 340(0.3%) 340(0.3%) procedure-arity ...ket/private/norm-arity.rkt:7:27 -------------------------------------------------------------------------------- for-loop [135] 100.0% [146] 328(0.3%) 0(0.0%) ormap ...et/collects/racket/private/map.rkt:141:13 flag-set? [157] 100.0% -------------------------------------------------------------------------------- enode-merge! [136] 100.0% [147] 316(0.3%) 0(0.0%) adopt-enode! ...e/develop/src/core/enode.rkt:103:0 custom-set-union [152] 100.0% -------------------------------------------------------------------------------- for-loop [131] 100.0% [148] 312(0.3%) 0(0.0%) ??? ...ies/herbie/develop/src/core/ematch.rkt:50:5 make-sequence [156] 100.0% -------------------------------------------------------------------------------- for-loop [123] 0.2% loop [36] 0.6% make-exacts* [35] 0.8% taylor [103] 1.1% ??? [4] 3.7% loop! [141] 4.2% loop [149] 89.3% [149] 27714(23.9%) 962(0.8%) loop ...cket/collects/racket/private/map.rkt:40:19 loop [149] 89.3% loop! [141] 4.1% hash-ref! [161] 3.7% ??? [64] 1.2% simplify [17] 1.1% set-precompute! [5] 0.1% ??? [69] 0.1% -------------------------------------------------------------------------------- mk-enode! [139] 100.0% [150] 13748(11.8%) 0(0.0%) new-enode ...erbie/develop/src/core/enode.rkt:95:0 type-of-enode-expr [158] 100.0% -------------------------------------------------------------------------------- for-loop [140] 100.0% [151] 13418(11.6%) 0(0.0%) for-loop ...rbie/develop/src/core/egraph.rkt:224:8 hash-update! [159] 100.0% -------------------------------------------------------------------------------- adopt-enode! [147] 9.8% loop! [141] 90.2% [152] 3214(2.8%) 642(0.6%) custom-set-union ...et/private/set-types.rkt:168:0 for-loop [160] 69.9% for-loop [162] 10.1% -------------------------------------------------------------------------------- for-loop [105] 9.7% loop! [141] 90.3% [153] 3150(2.7%) 2844(2.4%) set ...collects/racket/private/set-types.rkt:981:0 for-loop [163] 9.7% -------------------------------------------------------------------------------- mk-enode! [139] 27.6% ??? [34] 72.4% [154] 2212(1.9%) 922(0.8%) hash-has-key? ...ket/private/more-scheme.rkt:371:2 ??? [176] 31.0% ??? [173] 27.3% -------------------------------------------------------------------------------- mk-enode! [139] 100.0% [155] 636(0.5%) 636(0.5%) for-loop ...bie/develop/src/core/egraph.rkt:114:10 -------------------------------------------------------------------------------- ??? [148] 49.1% match-e [115] 50.9% [156] 636(0.5%) 636(0.5%) make-sequence ...ects/racket/private/for.rkt:528:2 -------------------------------------------------------------------------------- ormap [146] 100.0% [157] 328(0.3%) 328(0.3%) flag-set? ...es/herbie/develop/src/config.rkt:31:0 -------------------------------------------------------------------------------- new-enode [150] 100.0% [158] 13748(11.8%) 1238(1.1%) type-of-enode-expr ...elop/src/core/enode.rkt:68:0 ??? [165] 41.5% table-ref [166] 18.9% for-loop [168] 16.7% ...velop/src/common.rkt:48:2 [167] 9.3% get/build-late-neg-projection [193] 4.6% -------------------------------------------------------------------------------- for-loop [151] 100.0% [159] 13418(11.6%) 0(0.0%) hash-update! ...cket/private/more-scheme.rkt:365:4 ??? [164] 100.0% -------------------------------------------------------------------------------- custom-set-union [152] 100.0% [160] 2248(1.9%) 0(0.0%) for-loop ...cts/racket/private/set-types.rkt:174:3 for-loop [169] 100.0% -------------------------------------------------------------------------------- eval-prog [61] 21.9% simplify* [25] 22.9% loop [149] 55.1% [161] 1344(1.2%) 308(0.3%) hash-ref! .../racket/private/more-scheme.rkt:376:2 ??? [4] 55.1% bigfloat-hash [170] 21.9% -------------------------------------------------------------------------------- custom-set-union [152] 100.0% [162] 324(0.3%) 324(0.3%) for-loop ...cts/racket/private/set-types.rkt:152:2 -------------------------------------------------------------------------------- set [153] 100.0% [163] 306(0.3%) 306(0.3%) for-loop ...cts/racket/private/set-types.rkt:937:4 -------------------------------------------------------------------------------- hash-update! [159] 100.0% [164] 13418(11.6%) 296(0.3%) ??? ...s/herbie/develop/src/core/egraph.rkt:226:24 for-loop [171] 97.8% -------------------------------------------------------------------------------- type-of [56] 9.5% type-of-enode-expr [158] 90.5% [165] 6300(5.4%) 342(0.3%) ??? ...ects/racket/contract/private/hash.rkt:227:4 contract-pos/neg-doubling/proc [172] 94.6% -------------------------------------------------------------------------------- type-of [56] 6.8% f206 [66] 14.6% for-loop [117] 20.6% type-of-enode-expr [158] 58.1% [166] 4478(3.9%) 1586(1.4%) table-ref ...es/herbie/develop/src/common.rkt:47:0 ??? [173] 43.3% ??? [175] 14.1% ??? [176] 7.2% -------------------------------------------------------------------------------- for-loop [117] 49.9% type-of-enode-expr [158] 50.1% [167] 2552(2.2%) 610(0.5%) ...velop/src/common.rkt:48:2 ...e/arr-i.rkt:918:19 ??? [174] 76.1% -------------------------------------------------------------------------------- type-of-enode-expr [158] 100.0% [168] 2298(2.0%) 0(0.0%) for-loop ...racket/contract/private/hash.rkt:277:6 ??? [179] 100.0% -------------------------------------------------------------------------------- for-loop [160] 100.0% [169] 2248(1.9%) 2248(1.9%) for-loop ...cts/racket/private/set-types.rkt:178:5 -------------------------------------------------------------------------------- hash-ref! [161] 100.0% [170] 1036(0.9%) 302(0.3%) bigfloat-hash ...h/private/bigfloat/mpfr.rkt:167:0 sig+exp->bigfloat [177] 70.8% -------------------------------------------------------------------------------- ??? [164] 100.0% [171] 13122(11.3%) 10396(9.0%) for-loop ...bie/develop/src/core/egraph.rkt:227:26 update-en-expr [180] 20.8% -------------------------------------------------------------------------------- ??? [165] 100.0% [172] 5958(5.1%) 5342(4.6%) contract-pos/neg-doubling/proc ...e/guts.rkt:956:0 ??? [182] 5.2% ??? [183] 5.1% -------------------------------------------------------------------------------- hash-has-key? [154] 23.8% table-ref [166] 76.2% [173] 2542(2.2%) 1308(1.1%) ??? ...ects/racket/contract/private/list.rkt:798:4 for-loop [181] 36.9% arrow-higher-order:lnp [184] 11.6% -------------------------------------------------------------------------------- ??? [179] 7.8% for-loop [187] 24.9% ...velop/src/common.rkt:48:2 [167] 67.4% [174] 1942(1.7%) 662(0.6%) ??? ...ects/racket/contract/private/list.rkt:367:4 ??? [179] 67.4% ??? [192] 15.6% -------------------------------------------------------------------------------- ->flonum [77] 25.4% ??? [80] 27.0% table-ref [166] 47.6% [175] 1324(1.1%) 1324(1.1%) ??? ...s/racket/contract/private/arr-i.rkt:1252:29 -------------------------------------------------------------------------------- table-ref [166] 32.1% hash-has-key? [154] 67.9% [176] 1010(0.9%) 1010(0.9%) ??? ...ects/racket/contract/private/hash.rkt:283:7 -------------------------------------------------------------------------------- bigfloat-hash [170] 100.0% [177] 734(0.6%) 0(0.0%) sig+exp->bigfloat ...ivate/bigfloat/mpfr.rkt:387:0 new-mpfr [178] 100.0% -------------------------------------------------------------------------------- sig+exp->bigfloat [177] 8.7% bfatan [100] 12.5% bfsub [97] 31.7% bf [71] 47.2% [178] 8442(7.3%) 8442(7.3%) new-mpfr ...b/math/private/bigfloat/mpfr.rkt:335:0 -------------------------------------------------------------------------------- ...higher-order.rkt:361:33 [84] 7.5% ??? [174] 42.4% for-loop [168] 50.1% [179] 4584(3.9%) 344(0.3%) ??? ...cts/racket/contract/private/list.rkt:209:10 ??? [186] 50.1% for-loop [187] 35.8% ??? [174] 6.6% -------------------------------------------------------------------------------- for-loop [140] 6.5% for-loop [142] 6.5% for-loop [129] 6.6% merge-egraph-nodes! [122] 7.3% loop! [141] 13.5% for-loop [171] 59.5% [180] 4578(3.9%) 1494(1.3%) update-en-expr ...evelop/src/core/egraph.rkt:212:0 for-loop [185] 67.4% -------------------------------------------------------------------------------- ??? [173] 100.0% [181] 938(0.8%) 308(0.3%) for-loop ...acket/contract/private/list.rkt:804:12 ??? [188] 67.2% -------------------------------------------------------------------------------- contract-pos/neg-doubling/proc [172] 100.0% [182] 310(0.3%) 0(0.0%) ??? ...cts/racket/contract/private/guts.rkt:954:34 blame-add-context7 [189] 100.0% -------------------------------------------------------------------------------- contract-pos/neg-doubling/proc [172] 100.0% [183] 306(0.3%) 0(0.0%) ??? ...ects/racket/contract/private/list.rkt:191:2 ??? [190] 100.0% -------------------------------------------------------------------------------- ??? [173] 100.0% [184] 296(0.3%) 0(0.0%) arrow-higher-order:lnp ...w-higher-order.rkt:633:7 ??? [191] 100.0% -------------------------------------------------------------------------------- update-en-expr [180] 100.0% [185] 3084(2.7%) 3084(2.7%) for-loop ...rbie/develop/src/core/egraph.rkt:214:6 -------------------------------------------------------------------------------- ??? [179] 100.0% [186] 2298(2.0%) 0(0.0%) ??? ...ects/racket/contract/private/list.rkt:747:7 ??? [192] 100.0% -------------------------------------------------------------------------------- ??? [179] 100.0% [187] 1640(1.4%) 674(0.6%) for-loop ...acket/contract/private/list.rkt:212:15 ??? [174] 58.9% -------------------------------------------------------------------------------- f206 [66] 34.0% for-loop [181] 66.0% [188] 954(0.8%) 324(0.3%) ??? ...private/unconstrained-domain-arrow.rkt:74:4 make-keyword-procedure [194] 66.0% -------------------------------------------------------------------------------- ??? [182] 100.0% [189] 310(0.3%) 310(0.3%) blame-add-context7 ...ract/private/blame.rkt:165:0 -------------------------------------------------------------------------------- ??? [183] 100.0% [190] 306(0.3%) 0(0.0%) ??? ...ects/racket/contract/private/list.rkt:739:5 get/build-late-neg-projection [193] 100.0% -------------------------------------------------------------------------------- arrow-higher-order:lnp [184] 100.0% [191] 296(0.3%) 0(0.0%) ??? ...et/contract/private/arity-checking.rkt:19:2 for-loop [195] 100.0% -------------------------------------------------------------------------------- ->flonum [77] 10.5% ??? [174] 18.7% ??? [186] 70.8% [192] 3244(2.8%) 2638(2.3%) ??? ...ects/racket/contract/private/guts.rkt:746:8 contract? [198] 18.7% -------------------------------------------------------------------------------- unconstrained-domain->-projection [199] 12.2% f206 [66] 12.2% ??? [190] 24.7% ??? [196] 25.4% type-of-enode-expr [158] 25.4% [193] 1238(1.1%) 624(0.5%) get/build-late-neg-projection ...te/guts.rkt:793:0 ??? [196] 25.4% ??? [197] 24.8% unconstrained-domain->-projection [199] 12.2% -------------------------------------------------------------------------------- ??? [188] 100.0% [194] 630(0.5%) 630(0.5%) make-keyword-procedure ...ket/private/kw.rkt:407:4 -------------------------------------------------------------------------------- ??? [191] 100.0% [195] 296(0.3%) 296(0.3%) for-loop ...ntract/private/arity-checking.rkt:37:5 -------------------------------------------------------------------------------- get/build-late-neg-projection [193] 100.0% [196] 630(0.5%) 0(0.0%) ??? ...ects/racket/contract/private/hash.rkt:221:2 get/build-late-neg-projection [193] 100.0% -------------------------------------------------------------------------------- get/build-late-neg-projection [193] 100.0% [197] 614(0.5%) 302(0.3%) ??? ...cts/racket/contract/private/prop.rkt:344:12 build-compound-type-name [200] 50.8% -------------------------------------------------------------------------------- ??? [192] 100.0% [198] 606(0.5%) 304(0.3%) contract? ...acket/contract/private/guts.rkt:118:0 coerce-contract/f [201] 49.8% -------------------------------------------------------------------------------- get/build-late-neg-projection [193] 100.0% [199] 302(0.3%) 0(0.0%) unconstrained-domain->-projection ...rrow.rkt:60:0 get/build-late-neg-projection [193] 100.0% -------------------------------------------------------------------------------- ??? [197] 100.0% [200] 312(0.3%) 0(0.0%) build-compound-type-name ...private/guts.rkt:515:0 contract-struct-name [202] 100.0% -------------------------------------------------------------------------------- contract? [198] 100.0% [201] 302(0.3%) 302(0.3%) coerce-contract/f ...ntract/private/guts.rkt:350:0 -------------------------------------------------------------------------------- build-compound-type-name [200] 100.0% [202] 312(0.3%) 312(0.3%) contract-struct-name ...ract/private/prop.rkt:87:0 --------------------------------------------------------------------------------