Profiling results ----------------- Total cpu time observed: 256050ms (out of 259020ms) Number of samples taken: 1086 (once every 236ms) (Hiding functions with self<1.0% and local<2.0%: 11 of 201 hidden) ========================================================================== Caller Idx Total Self Name+src Local% ms(pct) ms(pct) Callee ========================================================================== ??? [39] 100.0% [1] 240368(93.9%) 0(0.0%) profile-thunk14 ...t/pkgs/profile-lib/main.rkt:9:0 run [9] 100.0% -------------------------------------------------------------------------- ??? [39] 100.0% [2] 129976(50.8%) 0(0.0%) run-improve58 ...ock/herbie/src/mainloop.rkt:242:0 for-loop [10] 78.1% get-final-combination [11] 18.5% loop [50] 2.7% setup-prog [13] 0.7% -------------------------------------------------------------------------- simplify-alt [21] 0.9% loop [101] 2.9% ??? [39] 96.3% [3] 98792(38.6%) 394(0.2%) simplify ...lock/herbie/src/core/simplify.rkt:39:0 simplify-expr [18] 67.0% iterate-egraph!5 [23] 16.5% for-loop [12] 13.9% loop [25] 1.7% mk-egraph [28] 0.4% -------------------------------------------------------------------------- hash-ref! [126] 100.0% [4] 19530(7.6%) 402(0.2%) ??? /home/ztatlock/herbie/src/programs.rkt:197:5 loop [101] 89.5% hash-ref! [126] 9.9% -------------------------------------------------------------------------- copying-mergesort [63] 100.0% [5] 7346(2.9%) 0(0.0%) jloop ...et/collects/racket/private/sort.rkt:85:19 ??? [86] 100.0% -------------------------------------------------------------------------- hash-ref! [126] 100.0% [6] 424(0.2%) 0(0.0%) ??? .../ztatlock/herbie/src/core/taylor.rkt:285:26 for-loop [14] 100.0% -------------------------------------------------------------------------- hash-ref! [126] 100.0% [7] 422(0.2%) 0(0.0%) ??? .../ztatlock/herbie/src/core/taylor.rkt:295:23 for-loop [15] 100.0% -------------------------------------------------------------------------- f6 [170] 100.0% [8] 200(0.1%) 0(0.0%) combine-mterms ...herbie/src/core/reduce.rkt:182:0 for-loop [16] 100.0% -------------------------------------------------------------------------- profile-thunk14 [1] 100.0% [9] 240368(93.9%) 0(0.0%) run ...share/racket/pkgs/profile-lib/main.rkt:31:2 ??? [39] 100.0% -------------------------------------------------------------------------- run-improve58 [2] 100.0% [10] 101566(39.7%) 0(0.0%) for-loop ...ztatlock/herbie/src/mainloop.rkt:253:8 run-iter! [17] 100.0% -------------------------------------------------------------------------- run-improve58 [2] 100.0% [11] 24070(9.4%) 0(0.0%) get-final-combination ...ie/src/mainloop.rkt:269:0 split-table [19] 88.3% extract-alt [20] 11.7% -------------------------------------------------------------------------- simplify [3] 100.0% [12] 13758(5.4%) 298(0.1%) for-loop ...ock/herbie/src/core/simplify.rkt:61:12 iterate-egraph!5 [23] 85.4% simplify-expr [18] 6.4% loop [25] 6.0% -------------------------------------------------------------------------- run-improve58 [2] 100.0% [13] 864(0.3%) 0(0.0%) setup-prog /home/ztatlock/herbie/src/glue.rkt:46:0 simplify-alt [21] 100.0% -------------------------------------------------------------------------- ??? [6] 100.0% [14] 424(0.2%) 0(0.0%) for-loop ...lock/herbie/src/core/taylor.rkt:285:52 hash-ref! [126] 100.0% -------------------------------------------------------------------------- ??? [7] 100.0% [15] 422(0.2%) 0(0.0%) for-loop ...lock/herbie/src/core/taylor.rkt:298:27 hash-ref! [126] 100.0% -------------------------------------------------------------------------- combine-mterms [8] 100.0% [16] 200(0.1%) 0(0.0%) for-loop ...tlock/herbie/src/core/reduce.rkt:186:5 hash-ref! [126] 100.0% -------------------------------------------------------------------------- for-loop [10] 100.0% [17] 101566(39.7%) 0(0.0%) run-iter! ...tatlock/herbie/src/mainloop.rkt:223:0 simplify! [22] 93.4% gen-series! [26] 3.1% finalize-iter! [27] 2.6% localize-error [59] 0.4% choose-best-alt! [29] 0.4% -------------------------------------------------------------------------- for-loop [12] 1.3% simplify [3] 98.7% [18] 67104(26.2%) 0(0.0%) simplify-expr ...herbie/src/core/simplify.rkt:68:0 iterate-egraph!5 [23] 95.1% loop [25] 4.3% debug-print [98] 0.3% mk-egraph [28] 0.3% -------------------------------------------------------------------------- get-final-combination [11] 100.0% [19] 21250(8.3%) 0(0.0%) split-table .../ztatlock/herbie/src/glue.rkt:171:0 infer-splitpoints4 [24] 100.0% -------------------------------------------------------------------------- get-final-combination [11] 100.0% [20] 2820(1.1%) 0(0.0%) extract-alt ...e/ztatlock/herbie/src/glue.rkt:57:0 loop [101] 100.0% -------------------------------------------------------------------------- setup-prog [13] 100.0% [21] 864(0.3%) 0(0.0%) simplify-alt .../ztatlock/herbie/src/glue.rkt:84:0 simplify [3] 100.0% -------------------------------------------------------------------------- run-iter! [17] 100.0% [22] 94886(37.1%) 0(0.0%) simplify! ...tatlock/herbie/src/mainloop.rkt:162:0 for-loop [30] 100.0% -------------------------------------------------------------------------- for-loop [12] 12.8% simplify [3] 17.8% simplify-expr [18] 69.5% [23] 91852(35.9%) 318(0.1%) iterate-egraph!5 ...bie/src/core/simplify.rkt:95:0 one-iter [31] 96.9% map-enodes [36] 2.7% -------------------------------------------------------------------------- split-table [19] 100.0% [24] 21250(8.3%) 0(0.0%) infer-splitpoints4 ...ie/src/core/regimes.rkt:19:0 option-on-expr [32] 94.6% loop [101] 4.4% exprs-to-branch-on [38] 1.0% -------------------------------------------------------------------------- for-loop [12] 15.2% simplify [3] 31.5% simplify-expr [18] 53.3% [25] 5428(2.1%) 0(0.0%) loop ...tatlock/herbie/src/core/simplify.rkt:203:2 pass [33] 100.0% -------------------------------------------------------------------------- run-iter! [17] 100.0% [26] 3156(1.2%) 0(0.0%) gen-series! ...tlock/herbie/src/mainloop.rkt:134:0 for-loop [34] 100.0% -------------------------------------------------------------------------- run-iter! [17] 100.0% [27] 2656(1.0%) 0(0.0%) finalize-iter! ...ck/herbie/src/mainloop.rkt:177:0 ??? [35] 100.0% -------------------------------------------------------------------------- simplify-expr [18] 33.1% simplify [3] 66.9% [28] 598(0.2%) 0(0.0%) mk-egraph ...lock/herbie/src/core/egraph.rkt:123:0 expr->enode [37] 100.0% -------------------------------------------------------------------------- run-iter! [17] 100.0% [29] 424(0.2%) 0(0.0%) choose-best-alt! .../herbie/src/mainloop.rkt:120:0 ??? [35] 100.0% -------------------------------------------------------------------------- simplify! [22] 100.0% [30] 94886(37.1%) 0(0.0%) for-loop ...ztatlock/herbie/src/mainloop.rkt:166:6 ??? [39] 100.0% -------------------------------------------------------------------------- iterate-egraph!5 [23] 100.0% [31] 89046(34.8%) 1430(0.6%) one-iter ...ock/herbie/src/core/simplify.rkt:106:0 for-loop [40] 52.4% loop [41] 43.2% apply-match [51] 2.6% -------------------------------------------------------------------------- loop [101] 4.5% infer-splitpoints4 [24] 95.5% [32] 21048(8.2%) 0(0.0%) option-on-expr ...erbie/src/core/regimes.rkt:106:0 sort-context-on-expr [42] 92.4% pick-errors [46] 7.6% -------------------------------------------------------------------------- loop [25] 100.0% [33] 5428(2.1%) 0(0.0%) pass ...tatlock/herbie/src/core/simplify.rkt:193:2 for-loop [43] 96.3% for-loop [49] 3.7% -------------------------------------------------------------------------- gen-series! [26] 100.0% [34] 3156(1.2%) 0(0.0%) for-loop ...ztatlock/herbie/src/mainloop.rkt:140:7 taylor-alt [44] 100.0% -------------------------------------------------------------------------- choose-best-alt! [29] 13.8% finalize-iter! [27] 86.2% [35] 3080(1.2%) 0(0.0%) ??? ...contract/private/arrow-val-first.rkt:357:18 for-loop [45] 86.2% atab-pick-alt8 [47] 13.8% -------------------------------------------------------------------------- iterate-egraph!5 [23] 100.0% [36] 2488(1.0%) 0(0.0%) map-enodes ...ock/herbie/src/core/egraph.rkt:139:0 loop [101] 92.5% for-loop [119] 7.5% -------------------------------------------------------------------------- expr->enode [37] 46.7% mk-egraph [28] 53.3% [37] 598(0.2%) 400(0.2%) expr->enode ...ck/herbie/src/core/egraph.rkt:124:2 expr->enode [37] 46.7% mk-enode! [89] 16.6% -------------------------------------------------------------------------- infer-splitpoints4 [24] 100.0% [38] 202(0.1%) 0(0.0%) exprs-to-branch-on ...ie/src/core/regimes.rkt:41:0 critical-subexpression [48] 100.0% -------------------------------------------------------------------------- for-loop [30] 13.2% run [9] 42.4% [39] 248742(97.1%) 0(0.0%) ??? ...lects/racket/private/more-scheme.rkt:261:28 profile-thunk14 [1] 42.4% loop [50] 24.0% run-improve58 [2] 20.4% simplify [3] 13.2% -------------------------------------------------------------------------- for-loop [40] 48.0% one-iter [31] 52.0% [40] 46656(18.2%) 11470(4.5%) for-loop ...ck/herbie/src/core/simplify.rkt:116:12 for-loop [40] 48.0% match-e [62] 37.5% ??? [104] 0.2% -------------------------------------------------------------------------- one-iter [31] 100.0% [41] 38472(15.0%) 458(0.2%) loop ...cket/collects/racket/private/map.rkt:53:19 apply-match [51] 98.8% -------------------------------------------------------------------------- option-on-expr [32] 100.0% [42] 19454(7.6%) 0(0.0%) sort-context-on-expr ...herbie/src/points.rkt:50:0 sort [52] 100.0% -------------------------------------------------------------------------- pass [33] 100.0% [43] 5228(2.0%) 202(0.1%) for-loop ...ck/herbie/src/core/simplify.rkt:196:29 argmin [55] 35.8% for-loop [56] 35.8% loop [58] 24.5% -------------------------------------------------------------------------- for-loop [34] 100.0% [44] 3156(1.2%) 0(0.0%) taylor-alt ...e/ztatlock/herbie/src/glue.rkt:142:0 for-loop [53] 100.0% -------------------------------------------------------------------------- ??? [35] 100.0% [45] 2656(1.0%) 0(0.0%) for-loop ...ock/herbie/src/core/alt-table.rkt:51:2 atab-add-altn [54] 100.0% -------------------------------------------------------------------------- option-on-expr [32] 100.0% [46] 1594(0.6%) 0(0.0%) pick-errors ...k/herbie/src/core/regimes.rkt:173:0 for-loop [57] 100.0% -------------------------------------------------------------------------- ??? [35] 100.0% [47] 424(0.2%) 0(0.0%) atab-pick-alt8 ...rbie/src/core/alt-table.rkt:54:0 ??? [60] 100.0% -------------------------------------------------------------------------- exprs-to-branch-on [38] 100.0% [48] 202(0.1%) 0(0.0%) critical-subexpression ...rc/core/regimes.rkt:49:0 localize-error [59] 100.0% -------------------------------------------------------------------------- pass [33] 100.0% [49] 200(0.1%) 200(0.1%) for-loop ...ock/herbie/src/core/simplify.rkt:176:2 -------------------------------------------------------------------------- run-improve58 [2] 2.8% ??? [39] 97.2% [50] 122020(47.7%) 0(0.0%) loop /home/ztatlock/herbie/src/points.rkt:122:2 loop [61] 48.2% make-exacts* [72] 33.0% loop [73] 18.4% for-loop [69] 0.5% -------------------------------------------------------------------------- one-iter [31] 5.7% loop [41] 94.3% [51] 40300(15.7%) 988(0.4%) apply-match .../herbie/src/core/simplify.rkt:122:2 merge-egraph-nodes! [74] 39.0% for-loop [64] 20.7% match-e [62] 14.7% loop! [117] 7.7% substitute-e [77] 7.2% mk-enode! [89] 4.0% update-leader! [87] 2.1% reduce-to-single! [68] 2.1% -------------------------------------------------------------------------- sort-context-on-expr [42] 100.0% [52] 19454(7.6%) 0(0.0%) sort ...ket/collects/racket/private/sort.rkt:213:0 copying-mergesort [63] 73.4% loop [76] 26.6% -------------------------------------------------------------------------- taylor-alt [44] 100.0% [53] 3156(1.2%) 0(0.0%) for-loop /home/ztatlock/herbie/src/glue.rkt:144:2 location-do [65] 100.0% -------------------------------------------------------------------------- for-loop [45] 100.0% [54] 2656(1.0%) 0(0.0%) atab-add-altn ...rbie/src/core/alt-table.rkt:208:0 best-and-tied-at-points [67] 91.7% override-at-pnts [71] 8.3% -------------------------------------------------------------------------- for-loop [43] 100.0% [55] 1874(0.7%) 0(0.0%) argmin ...re/racket/collects/racket/list.rkt:743:0 expression-cost [66] 100.0% -------------------------------------------------------------------------- for-loop [43] 100.0% [56] 1870(0.7%) 1870(0.7%) for-loop ...ck/herbie/src/core/simplify.rkt:183:13 -------------------------------------------------------------------------- pick-errors [46] 100.0% [57] 1594(0.6%) 0(0.0%) for-loop ...lock/herbie/src/core/regimes.rkt:176:4 eval-prog [115] 100.0% -------------------------------------------------------------------------- for-loop [43] 100.0% [58] 1282(0.5%) 202(0.1%) loop ...hare/racket/collects/racket/list.rkt:729:4 expression-cost [66] 84.2% -------------------------------------------------------------------------- critical-subexpression [48] 31.3% run-iter! [17] 68.7% [59] 646(0.3%) 0(0.0%) localize-error ...erbie/src/core/localize.rkt:47:0 hash-ref! [126] 100.0% -------------------------------------------------------------------------- atab-pick-alt8 [47] 100.0% [60] 424(0.2%) 0(0.0%) ??? ...tract/private/arrow-higher-order.rkt:369:33 best-alt [70] 100.0% -------------------------------------------------------------------------- loop [50] 100.0% [61] 58810(23.0%) 0(0.0%) loop /home/ztatlock/herbie/src/points.rkt:93:2 loop [73] 46.7% make-exacts* [72] 43.3% eval-prog [115] 10.0% -------------------------------------------------------------------------- apply-match [51] 11.0% for-loop [88] 11.9% for-loop [40] 77.1% [62] 40876(16.0%) 23096(9.0%) match-e ...tatlock/herbie/src/core/ematch.rkt:46:0 for-loop [75] 37.0% for-loop [88] 5.6% list-cartesian-product [90] 2.7% loop [101] 1.8% -------------------------------------------------------------------------- sort [52] 43.6% copying-mergesort [63] 56.4% [63] 14272(5.6%) 0(0.0%) copying-mergesort .../racket/private/sort.rkt:91:4 copying-mergesort [63] 56.4% loop [76] 30.8% jloop [5] 12.9% -------------------------------------------------------------------------- apply-match [51] 100.0% [64] 8342(3.3%) 0(0.0%) for-loop ...ck/herbie/src/core/simplify.rkt:136:10 merge-egraph-nodes! [74] 44.7% loop! [117] 34.7% substitute-e [77] 13.0% mk-enode! [89] 7.6% -------------------------------------------------------------------------- location-do [65] 30.4% for-loop [53] 69.6% [65] 3156(1.2%) 0(0.0%) location-do ...tlock/herbie/src/programs.rkt:129:0 approximate9 [78] 69.6% location-do [65] 30.4% -------------------------------------------------------------------------- loop [58] 36.6% argmin [55] 63.4% [66] 2954(1.2%) 0(0.0%) expression-cost ...k/herbie/src/programs.rkt:212:0 compile [79] 100.0% -------------------------------------------------------------------------- atab-add-altn [54] 100.0% [67] 2436(1.0%) 0(0.0%) best-and-tied-at-points ...ore/alt-table.rkt:122:0 errors [103] 100.0% -------------------------------------------------------------------------- apply-match [51] 100.0% [68] 834(0.3%) 422(0.2%) reduce-to-single! ...bie/src/core/egraph.rkt:324:0 make-sequence [164] 25.4% for-loop [84] 24.0% -------------------------------------------------------------------------- loop [50] 100.0% [69] 572(0.2%) 0(0.0%) for-loop .../ztatlock/herbie/src/points.rkt:128:18 for-loop [80] 100.0% -------------------------------------------------------------------------- ??? [60] 100.0% [70] 424(0.2%) 0(0.0%) best-alt /home/ztatlock/herbie/src/glue.rkt:79:0 loop [82] 51.9% argmins [83] 48.1% -------------------------------------------------------------------------- atab-add-altn [54] 100.0% [71] 220(0.1%) 0(0.0%) override-at-pnts ...e/src/core/alt-table.rkt:145:0 for-loop [81] 100.0% -------------------------------------------------------------------------- loop [61] 38.7% loop [50] 61.3% [72] 65704(25.7%) 0(0.0%) make-exacts* ...tatlock/herbie/src/points.rkt:80:0 loop [101] 52.1% map [85] 43.6% eval-prog [115] 4.2% -------------------------------------------------------------------------- loop [50] 44.9% loop [61] 55.1% [73] 49882(19.5%) 0(0.0%) loop /home/ztatlock/herbie/src/points.rkt:83:4 map [85] 100.0% -------------------------------------------------------------------------- for-loop [93] 3.2% merge-egraph-nodes! [74] 4.7% for-loop [64] 19.2% apply-match [51] 72.9% [74] 19444(7.6%) 842(0.3%) merge-egraph-nodes! ...e/src/core/egraph.rkt:152:0 update-leader! [87] 51.2% for-loop [91] 16.1% loop! [117] 10.1% for-loop [93] 4.8% merge-egraph-nodes! [74] 4.7% enode-merge! [95] 4.5% for-loop [99] 2.2% make-sequence [164] 2.1% -------------------------------------------------------------------------- match-e [62] 100.0% [75] 17920(7.0%) 8884(3.5%) for-loop ...tlock/herbie/src/core/ematch.rkt:59:11 for-loop [88] 36.1% list-cartesian-product [90] 9.8% loop [101] 2.9% foldl [120] 2.3% -------------------------------------------------------------------------- sort [52] 42.8% copying-mergesort [63] 57.2% [76] 12108(4.7%) 0(0.0%) loop ...cket/collects/racket/private/sort.rkt:64:8 ??? [86] 95.9% ??? [125] 4.1% -------------------------------------------------------------------------- substitute-e [77] 5.9% for-loop [64] 24.6% apply-match [51] 69.6% [77] 4000(1.6%) 1244(0.5%) substitute-e ...ck/herbie/src/core/ematch.rkt:71:0 mk-enode! [89] 68.9% substitute-e [77] 5.9% -------------------------------------------------------------------------- location-do [65] 100.0% [78] 3156(1.2%) 0(0.0%) approximate9 ...ck/herbie/src/core/taylor.rkt:11:0 loop [92] 59.4% f6 [170] 26.6% debug-print [98] 7.0% taylor-quotient [94] 7.0% -------------------------------------------------------------------------- expression-cost [66] 100.0% [79] 2954(1.2%) 0(0.0%) compile .../ztatlock/herbie/src/programs.rkt:189:0 hash-ref! [126] 100.0% -------------------------------------------------------------------------- for-loop [69] 100.0% [80] 572(0.2%) 0(0.0%) for-loop .../ztatlock/herbie/src/points.rkt:129:20 sample-default [97] 80.4% sample-double [100] 19.6% -------------------------------------------------------------------------- override-at-pnts [71] 100.0% [81] 220(0.1%) 220(0.1%) for-loop ...k/herbie/src/core/alt-table.rkt:146:43 -------------------------------------------------------------------------- best-alt [70] 100.0% [82] 220(0.1%) 0(0.0%) loop /home/ztatlock/herbie/src/common.rkt:86:2 composed [96] 100.0% -------------------------------------------------------------------------- best-alt [70] 100.0% [83] 204(0.1%) 0(0.0%) argmins /home/ztatlock/herbie/src/common.rkt:85:0 composed [96] 100.0% -------------------------------------------------------------------------- reduce-to-single! [68] 100.0% [84] 200(0.1%) 200(0.1%) for-loop ...tlock/herbie/src/core/egraph.rkt:325:8 -------------------------------------------------------------------------- f6 [170] 2.9% make-exacts* [72] 35.3% loop [73] 61.5% [85] 81082(31.7%) 0(0.0%) map ...acket/collects/racket/private/map.rkt:21:13 loop [101] 96.1% f6 [170] 1.3% parse-loop12 [160] 0.8% ??? [125] 0.7% simplify-node [130] 0.4% loop [112] 0.3% ->flonum [144] 0.2% taylor-invert [113] 0.1% -------------------------------------------------------------------------- jloop [5] 38.8% loop [76] 61.2% [86] 18954(7.4%) 474(0.2%) ??? /home/ztatlock/herbie/src/points.rkt:52:27 eval-prog [115] 96.3% ??? [125] 1.2% -------------------------------------------------------------------------- apply-match [51] 7.4% merge-egraph-nodes! [74] 92.6% [87] 11666(4.6%) 806(0.3%) update-leader! ...herbie/src/core/egraph.rkt:217:0 for-loop [102] 89.5% make-sequence [164] 1.9% mutable-set [123] 1.7% -------------------------------------------------------------------------- match-e [62] 36.7% for-loop [75] 63.3% [88] 11156(4.4%) 606(0.2%) for-loop ...tlock/herbie/src/core/ematch.rkt:65:37 match-e [62] 83.6% ??? [104] 12.8% -------------------------------------------------------------------------- expr->enode [37] 3.8% for-loop [64] 12.2% apply-match [51] 31.0% substitute-e [77] 53.0% [89] 5202(2.0%) 3934(1.5%) mk-enode! ...lock/herbie/src/core/egraph.rkt:101:0 hash-has-key? [107] 16.7% new-enode [109] 7.7% -------------------------------------------------------------------------- match-e [62] 26.2% list-cartesian-product [90] 31.6% for-loop [75] 42.2% [90] 3390(1.3%) 2366(0.9%) list-cartesian-product ...src/core/ematch.rkt:20:0 list-cartesian-product [90] 31.6% for-loop [106] 18.1% -------------------------------------------------------------------------- merge-egraph-nodes! [74] 100.0% [91] 3130(1.2%) 2114(0.8%) for-loop ...tlock/herbie/src/core/egraph.rkt:232:6 update-en-expr [169] 32.5% -------------------------------------------------------------------------- approximate9 [78] 100.0% [92] 1874(0.7%) 0(0.0%) loop ...e/ztatlock/herbie/src/core/taylor.rkt:82:4 hash-ref! [126] 100.0% -------------------------------------------------------------------------- merge-egraph-nodes! [74] 100.0% [93] 1660(0.6%) 0(0.0%) for-loop ...lock/herbie/src/core/egraph.rkt:200:10 merge-egraph-nodes! [74] 75.1% loop! [117] 24.9% -------------------------------------------------------------------------- approximate9 [78] 20.6% f6 [170] 79.4% [94] 1066(0.4%) 0(0.0%) taylor-quotient ...erbie/src/core/taylor.rkt:328:0 first-nonzero-exp [105] 100.0% -------------------------------------------------------------------------- merge-egraph-nodes! [74] 100.0% [95] 882(0.3%) 0(0.0%) enode-merge! ...ck/herbie/src/core/enode.rkt:100:0 adopt-enode! [108] 72.6% custom-set-intersect! [110] 27.4% -------------------------------------------------------------------------- argmins [83] 31.6% loop [82] 34.1% f6 [170] 34.4% [96] 646(0.3%) 0(0.0%) composed ...ollects/racket/private/list.rkt:321:16 errors [103] 65.6% f6 [170] 34.4% -------------------------------------------------------------------------- for-loop [80] 100.0% [97] 460(0.2%) 0(0.0%) sample-default ...rc/syntax/distributions.rkt:11:0 ??? [165] 100.0% -------------------------------------------------------------------------- simplify-expr [18] 50.0% approximate9 [78] 50.0% [98] 444(0.2%) 222(0.1%) debug-print ...ztatlock/herbie/src/debug.rkt:107:0 for-loop [111] 50.0% -------------------------------------------------------------------------- merge-egraph-nodes! [74] 100.0% [99] 422(0.2%) 422(0.2%) for-loop ...e/ztatlock/herbie/src/common.rkt:205:9 -------------------------------------------------------------------------- for-loop [80] 100.0% [100] 112(0.0%) 0(0.0%) sample-double .../src/syntax/distributions.rkt:8:0 random-exp [114] 100.0% -------------------------------------------------------------------------- map-enodes [36] 0.1% parse-loop12 [160] 0.2% for-loop [75] 0.3% f6 [170] 0.3% make-exacts* [72] 0.5% match-e [62] 0.6% infer-splitpoints4 [24] 0.7% extract-alt [20] 0.8% loop! [117] 1.2% map [85] 2.7% ??? [4] 11.7% loop [101] 81.1% [101] 143924(56.2%) 2086(0.8%) loop ...cket/collects/racket/private/map.rkt:26:19 loop [101] 81.1% hash-ref! [126] 11.6% ??? [125] 3.0% loop! [117] 1.1% simplify [3] 0.8% option-on-expr [32] 0.7% foldl [120] 0.4% simplify [118] 0.3% ->flonum [144] 0.1% for-loop [119] 0.1% real->bigfloat [142] 0.0% -------------------------------------------------------------------------- update-leader! [87] 100.0% [102] 10436(4.1%) 0(0.0%) for-loop ...tlock/herbie/src/core/egraph.rkt:222:6 for-loop [116] 100.0% -------------------------------------------------------------------------- composed [96] 14.8% best-and-tied-at-points [67] 85.2% [103] 2860(1.1%) 0(0.0%) errors /home/ztatlock/herbie/src/points.rkt:144:0 eval-prog [115] 61.4% for-loop [121] 38.6% -------------------------------------------------------------------------- for-loop [40] 13.5% for-loop [88] 86.5% [104] 1646(0.6%) 622(0.2%) ??? /home/ztatlock/herbie/src/core/ematch.rkt:50:5 for-loop [122] 62.2% -------------------------------------------------------------------------- taylor-invert [113] 17.1% taylor-quotient [94] 82.9% [105] 1286(0.5%) 0(0.0%) first-nonzero-exp ...bie/src/core/taylor.rkt:260:0 hash-ref! [126] 82.9% simplify [118] 17.1% -------------------------------------------------------------------------- list-cartesian-product [90] 100.0% [106] 1024(0.4%) 1024(0.4%) for-loop ...atlock/herbie/src/core/ematch.rkt:24:8 -------------------------------------------------------------------------- mk-enode! [89] 100.0% [107] 868(0.3%) 868(0.3%) hash-has-key? ...et/private/more-scheme.rkt:368:13 -------------------------------------------------------------------------- enode-merge! [95] 100.0% [108] 640(0.2%) 0(0.0%) adopt-enode! ...ock/herbie/src/core/enode.rkt:76:0 custom-set-union [128] 100.0% -------------------------------------------------------------------------- mk-enode! [89] 100.0% [109] 400(0.2%) 198(0.1%) new-enode ...atlock/herbie/src/core/enode.rkt:68:0 mutable-set [123] 50.5% -------------------------------------------------------------------------- enode-merge! [95] 100.0% [110] 242(0.1%) 242(0.1%) custom-set-intersect! ...ivate/set-types.rkt:270:0 -------------------------------------------------------------------------- debug-print [98] 100.0% [111] 222(0.1%) 222(0.1%) for-loop /home/ztatlock/herbie/src/debug.rkt:113:2 -------------------------------------------------------------------------- map [85] 2.8% loop [112] 97.2% [112] 222(0.1%) 0(0.0%) loop ...cket/collects/racket/private/map.rkt:37:19 loop [112] 97.2% ??? [124] 2.8% -------------------------------------------------------------------------- map [85] 100.0% [113] 220(0.1%) 0(0.0%) taylor-invert .../herbie/src/core/taylor.rkt:312:0 first-nonzero-exp [105] 100.0% -------------------------------------------------------------------------- sample-double [100] 100.0% [114] 112(0.0%) 112(0.0%) random-exp ...ztatlock/herbie/src/common.rkt:153:0 -------------------------------------------------------------------------- for-loop [57] 5.3% errors [103] 5.8% make-exacts* [72] 9.2% loop [61] 19.4% ??? [86] 60.3% [115] 30248(11.8%) 9314(3.6%) eval-prog ...tatlock/herbie/src/programs.rkt:162:0 hash-ref! [126] 61.5% inductor [131] 4.0% ??? [135] 1.5% parse-app [133] 0.8% go [139] 0.7% -------------------------------------------------------------------------- for-loop [102] 100.0% [116] 10436(4.1%) 200(0.1%) for-loop ...tlock/herbie/src/core/egraph.rkt:223:8 hash-update! [127] 98.1% -------------------------------------------------------------------------- for-loop [93] 2.3% for-loop [64] 21.8% merge-egraph-nodes! [74] 22.1% apply-match [51] 25.8% loop [101] 27.9% [117] 8976(3.5%) 1700(0.7%) loop! .../ztatlock/herbie/src/core/enode.rkt:163:2 loop [101] 37.3% custom-set-union [128] 31.7% set [129] 13.6% update-en-expr [169] 6.5% -------------------------------------------------------------------------- first-nonzero-exp [105] 8.1% loop [101] 15.3% hash-ref! [126] 76.6% [118] 2732(1.1%) 0(0.0%) simplify ...atlock/herbie/src/core/reduce.rkt:18:0 f6 [170] 61.8% parse-loop12 [160] 22.7% simplify-node [130] 15.5% -------------------------------------------------------------------------- map-enodes [36] 7.5% loop [101] 92.5% [119] 2488(1.0%) 418(0.2%) for-loop ...ock/herbie/src/core/simplify.rkt:161:2 setfindf [132] 48.3% eval-const-expr [134] 17.8% compose [136] 17.0% -------------------------------------------------------------------------- for-loop [75] 31.9% loop [101] 68.1% [120] 1268(0.5%) 866(0.3%) foldl ...et/collects/racket/private/list.rkt:229:4 merge2 [137] 31.7% -------------------------------------------------------------------------- errors [103] 100.0% [121] 1104(0.4%) 0(0.0%) for-loop ...e/ztatlock/herbie/src/points.rkt:147:4 ??? [125] 80.1% ??? [138] 19.9% -------------------------------------------------------------------------- ??? [104] 100.0% [122] 1024(0.4%) 1024(0.4%) for-loop ...atlock/herbie/src/core/ematch.rkt:51:7 -------------------------------------------------------------------------- update-leader! [87] 50.0% new-enode [109] 50.0% [123] 404(0.2%) 404(0.2%) mutable-set ...racket/private/set-types.rkt:1000:0 -------------------------------------------------------------------------- loop [112] 100.0% [124] 222(0.1%) 0(0.0%) ??? ...ztatlock/herbie/src/core/localize.rkt:43:32 ->flonum [144] 100.0% -------------------------------------------------------------------------- ??? [86] 0.2% loop [76] 0.4% map [85] 0.5% for-loop [121] 0.8% loop [101] 98.0% [125] 111846(43.7%) 3618(1.4%) ??? /home/ztatlock/herbie/src/programs.rkt:168:4 ??? [140] 76.9% real->bigfloat [142] 14.3% ??? [182] 4.6% ->flonum [144] 0.4% -------------------------------------------------------------------------- for-loop [16] 0.2% for-loop [15] 0.7% localize-error [59] 0.8% for-loop [14] 0.9% first-nonzero-exp [105] 1.9% ??? [147] 2.2% loop [92] 2.5% ??? [4] 5.4% compile [79] 6.7% eval-prog [115] 31.9% loop [101] 44.0% [126] 24498(9.6%) 4142(1.6%) hash-ref! ...racket/private/more-scheme.rkt:373:13 ??? [4] 50.4% bigfloat-hash [141] 29.5% simplify [118] 2.9% parse-loop12 [160] 2.2% ??? [147] 2.2% f6 [170] 1.0% ??? [6] 0.9% ??? [7] 0.7% -------------------------------------------------------------------------- for-loop [116] 100.0% [127] 10236(4.0%) 0(0.0%) hash-update! ...ket/private/more-scheme.rkt:362:13 ??? [143] 100.0% -------------------------------------------------------------------------- adopt-enode! [108] 17.8% loop! [117] 82.2% [128] 3588(1.4%) 842(0.3%) custom-set-union ...et/private/set-types.rkt:168:0 for-loop [145] 70.9% for-loop [153] 5.6% -------------------------------------------------------------------------- loop! [117] 100.0% [129] 2248(0.9%) 2248(0.9%) set ...collects/racket/private/set-types.rkt:982:0 -------------------------------------------------------------------------- parse-loop12 [160] 15.0% simplify [118] 28.9% map [85] 56.1% [130] 1468(0.6%) 0(0.0%) simplify-node ...k/herbie/src/core/reduce.rkt:41:0 append-map [146] 71.4% combine-aterms [151] 15.0% f6 [170] 13.6% -------------------------------------------------------------------------- eval-prog [115] 44.2% inductor [131] 55.8% [131] 1210(0.5%) 704(0.3%) inductor .../ztatlock/herbie/src/programs.rkt:73:2 inductor [131] 55.8% integer->bigfloat [148] 17.4% -------------------------------------------------------------------------- for-loop [119] 100.0% [132] 1202(0.5%) 796(0.3%) setfindf ...e/ztatlock/herbie/src/common.rkt:173:0 for-loop [149] 33.8% -------------------------------------------------------------------------- eval-prog [115] 49.6% [133] 480(0.2%) 238(0.1%) parse-app .../collects/racket/private/kw.rkt:903:2 loop [150] 50.4% -------------------------------------------------------------------------- for-loop [119] 100.0% [134] 444(0.2%) 222(0.1%) eval-const-expr ...k/herbie/src/programs.rkt:180:0 ??? [175] 50.0% -------------------------------------------------------------------------- eval-prog [115] 100.0% [135] 440(0.2%) 240(0.1%) ??? ...collects/racket/private/qq-and-or.rkt:155:9 ??? [154] 45.5% -------------------------------------------------------------------------- for-loop [119] 100.0% [136] 424(0.2%) 424(0.2%) compose ...collects/racket/private/list.rkt:385:12 -------------------------------------------------------------------------- foldl [120] 100.0% [137] 402(0.2%) 402(0.2%) merge2 ...ztatlock/herbie/src/core/ematch.rkt:31:0 -------------------------------------------------------------------------- for-loop [121] 100.0% [138] 220(0.1%) 220(0.1%) ??? ...ket/collects/racket/private/for.rkt:1150:14 -------------------------------------------------------------------------- eval-prog [115] 100.0% [139] 204(0.1%) 0(0.0%) go .../collects/racket/private/qq-and-or.rkt:50:20 loop [152] 100.0% -------------------------------------------------------------------------- ??? [125] 100.0% [140] 86012(33.6%) 4666(1.8%) ??? ...acket/collects/racket/private/kw.rkt:400:14 ??? [175] 43.4% bf* [167] 21.2% ...higher-order.rkt:373:33 [156] 12.6% bffma [158] 10.2% ...higher-order.rkt:369:33 [159] 4.0% ...ow-val-first.rkt:357:18 [168] 1.8% bf> [163] 1.3% -------------------------------------------------------------------------- hash-ref! [126] 100.0% [141] 17180(6.7%) 0(0.0%) bigfloat-hash ...h/private/bigfloat/mpfr.rkt:165:0 bfcanonicalize [155] 83.0% sig+exp->bigfloat [161] 14.4% bigfloat->sig+exp [171] 2.6% -------------------------------------------------------------------------- loop [101] 1.4% ??? [125] 98.6% [142] 16196(6.3%) 12472(4.9%) real->bigfloat .../private/bigfloat/mpfr.rkt:451:0 ??? [186] 23.0% -------------------------------------------------------------------------- hash-update! [127] 100.0% [143] 10236(4.0%) 400(0.2%) ??? .../ztatlock/herbie/src/core/egraph.rkt:225:24 for-loop [157] 94.1% make-sequence [164] 2.0% -------------------------------------------------------------------------- map [85] 6.1% ??? [124] 6.7% ??? [125] 13.2% loop [101] 73.9% [144] 3294(1.3%) 1494(0.6%) ->flonum ...ock/herbie/src/syntax/syntax.rkt:224:0 ??? [185] 42.5% ??? [165] 12.1% -------------------------------------------------------------------------- custom-set-union [128] 100.0% [145] 2544(1.0%) 648(0.3%) for-loop ...cts/racket/private/set-types.rkt:174:3 for-loop [162] 74.5% -------------------------------------------------------------------------- append-map [146] 21.4% f6 [170] 28.7% simplify-node [130] 49.9% [146] 1470(0.6%) 0(0.0%) append-map ...acket/collects/racket/list.rkt:565:2 parse-loop12 [160] 48.6% append-map [146] 21.4% f6 [170] 15.1% gather-additive-terms6 [166] 15.0% -------------------------------------------------------------------------- hash-ref! [126] 100.0% [147] 1450(0.6%) 0(0.0%) ??? ...e/ztatlock/herbie/src/core/taylor.rkt:63:15 hash-ref! [126] 100.0% -------------------------------------------------------------------------- inductor [131] 100.0% [148] 506(0.2%) 506(0.2%) integer->bigfloat ...ivate/bigfloat/mpfr.rkt:399:0 -------------------------------------------------------------------------- setfindf [132] 100.0% [149] 406(0.2%) 406(0.2%) for-loop ...e/ztatlock/herbie/src/common.rkt:174:2 -------------------------------------------------------------------------- loop [150] 50.0% parse-app [133] 50.0% [150] 242(0.1%) 242(0.1%) loop .../collects/racket/private/stxcase.rkt:112:7 loop [150] 50.0% -------------------------------------------------------------------------- simplify-node [130] 100.0% [151] 220(0.1%) 220(0.1%) combine-aterms ...herbie/src/core/reduce.rkt:174:0 -------------------------------------------------------------------------- go [139] 20.0% loop [152] 80.0% [152] 204(0.1%) 204(0.1%) loop ...llects/racket/private/qq-and-or.rkt:101:61 loop [152] 80.0% -------------------------------------------------------------------------- custom-set-union [128] 100.0% [153] 202(0.1%) 202(0.1%) for-loop ...cts/racket/private/set-types.rkt:152:2 -------------------------------------------------------------------------- ??? [135] 100.0% [154] 200(0.1%) 200(0.1%) ??? ...ollects/racket/private/qq-and-or.rkt:164:21 -------------------------------------------------------------------------- bigfloat-hash [141] 100.0% [155] 14262(5.6%) 13590(5.3%) bfcanonicalize .../private/bigfloat/mpfr.rkt:155:0 bigfloat->sig+exp [171] 4.7% -------------------------------------------------------------------------- ??? [140] 100.0% [156] 10826(4.2%) 962(0.4%) ...higher-order.rkt:373:33 (unknown source) ??? [176] 72.3% ??? [182] 18.8% -------------------------------------------------------------------------- ??? [143] 100.0% [157] 9634(3.8%) 8066(3.2%) for-loop ...lock/herbie/src/core/egraph.rkt:226:26 update-en-expr [169] 16.3% -------------------------------------------------------------------------- ??? [140] 100.0% [158] 8806(3.4%) 0(0.0%) bffma ...atlock/herbie/src/syntax/syntax.rkt:122:0 bf* [167] 67.2% ...ow-val-first.rkt:357:18 [168] 32.8% -------------------------------------------------------------------------- ??? [140] 100.0% [159] 3472(1.4%) 512(0.2%) ...higher-order.rkt:369:33 (unknown source) ??? [182] 55.0% ??? [176] 30.2% -------------------------------------------------------------------------- parse-loop12 [160] 7.5% append-map [146] 18.4% simplify [118] 19.6% hash-ref! [126] 20.5% map [85] 34.1% [160] 3158(1.2%) 826(0.3%) parse-loop12 ...s/racket/match/compiler.rkt:410:15 f6 [170] 29.1% loop [101] 20.5% for-loop [172] 13.1% parse-loop12 [160] 7.5% simplify-node [130] 7.0% -------------------------------------------------------------------------- bigfloat-hash [141] 100.0% [161] 2472(1.0%) 2000(0.8%) sig+exp->bigfloat ...ivate/bigfloat/mpfr.rkt:385:0 ??? [186] 9.6% integer->mpz [174] 9.5% -------------------------------------------------------------------------- for-loop [145] 100.0% [162] 1896(0.7%) 1896(0.7%) for-loop ...cts/racket/private/set-types.rkt:178:5 -------------------------------------------------------------------------- ??? [140] 100.0% [163] 1126(0.4%) 0(0.0%) bf> ...th/private/bigfloat/bigfloat-mpfr.rkt:127:4 ??? [185] 100.0% -------------------------------------------------------------------------- ??? [143] 19.5% reduce-to-single! [68] 20.5% update-leader! [87] 21.4% merge-egraph-nodes! [74] 38.6% [164] 1036(0.4%) 434(0.2%) make-sequence ...ects/racket/private/for.rkt:508:2 ??? [173] 58.1% -------------------------------------------------------------------------- ->flonum [144] 46.5% sample-default [97] 53.5% [165] 860(0.3%) 860(0.3%) ??? /home/ztatlock/herbie/src/config.rkt:29:0 -------------------------------------------------------------------------- append-map [146] 100.0% [166] 220(0.1%) 220(0.1%) gather-additive-terms6 ...src/core/reduce.rkt:63:0 -------------------------------------------------------------------------- bffma [158] 24.5% ??? [140] 75.5% [167] 24148(9.4%) 286(0.1%) bf* ...ath/private/bigfloat/bigfloat-mpfr.rkt:95:0 ??? [175] 98.8% -------------------------------------------------------------------------- ??? [140] 34.6% bffma [158] 65.4% [168] 4420(1.7%) 226(0.1%) ...ow-val-first.rkt:357:18 (unknown source) ??? [176] 94.9% -------------------------------------------------------------------------- for-loop [91] 26.6% loop! [117] 32.4% for-loop [157] 41.0% [169] 3822(1.5%) 3610(1.4%) update-en-expr ...herbie/src/core/egraph.rkt:211:0 for-loop [180] 5.5% -------------------------------------------------------------------------- composed [96] 1.2% simplify-node [130] 1.5% append-map [146] 2.3% approximate9 [78] 8.0% parse-loop12 [160] 10.3% hash-ref! [126] 13.7% f6 [170] 17.5% simplify [118] 21.7% map [85] 23.8% [170] 2750(1.1%) 440(0.2%) f6 ...et/collects/racket/match/compiler.rkt:499:40 map [85] 57.9% f6 [170] 17.5% taylor-quotient [94] 9.3% append-map [146] 3.8% combine-mterms [8] 3.6% loop [101] 2.8% composed [96] 1.2% -------------------------------------------------------------------------- bigfloat-hash [141] 39.9% bfcanonicalize [155] 60.1% [171] 1118(0.4%) 218(0.1%) bigfloat->sig+exp ...ivate/bigfloat/mpfr.rkt:370:0 new-mpz [177] 60.6% size+limbs->integer [179] 19.9% -------------------------------------------------------------------------- parse-loop12 [160] 100.0% [172] 626(0.2%) 0(0.0%) for-loop ...tlock/herbie/src/core/reduce.rkt:90:13 make-multiplication-node [178] 100.0% -------------------------------------------------------------------------- make-sequence [164] 100.0% [173] 602(0.2%) 602(0.2%) ??? ...acket/collects/racket/private/for.rkt:428:7 -------------------------------------------------------------------------- sig+exp->bigfloat [161] 100.0% [174] 234(0.1%) 234(0.1%) integer->mpz ...math/private/bigfloat/gmp.rkt:87:0 -------------------------------------------------------------------------- eval-const-expr [134] 0.4% bf* [167] 38.8% ??? [140] 60.8% [175] 61438(24.0%) 3308(1.3%) ??? ...-racket/utils/simple-result-arrow.rkt:26:12 bfmul [181] 75.4% ??? [185] 15.6% bfsqr [183] 3.6% -------------------------------------------------------------------------- ...higher-order.rkt:369:33 [159] 8.0% ...ow-val-first.rkt:357:18 [168] 32.1% ...higher-order.rkt:373:33 [156] 59.9% [176] 13076(5.1%) 898(0.4%) ??? ...cts/racket/contract/private/list.rkt:187:10 ??? [182] 93.1% -------------------------------------------------------------------------- bigfloat->sig+exp [171] 100.0% [177] 678(0.3%) 678(0.3%) new-mpz ...-lib/math/private/bigfloat/gmp.rkt:73:0 -------------------------------------------------------------------------- for-loop [172] 100.0% [178] 626(0.2%) 0(0.0%) make-multiplication-node .../core/reduce.rkt:221:0 make-multiplication-subnode [184]100.0% -------------------------------------------------------------------------- bigfloat->sig+exp [171] 100.0% [179] 222(0.1%) 222(0.1%) size+limbs->integer ...vate/bigfloat/gmp.rkt:103:0 -------------------------------------------------------------------------- update-en-expr [169] 100.0% [180] 212(0.1%) 212(0.1%) for-loop ...tlock/herbie/src/core/egraph.rkt:213:6 -------------------------------------------------------------------------- ??? [175] 100.0% [181] 46348(18.1%) 31012(12.1%) bfmul ...-lib/math/private/bigfloat/mpfr.rkt:819:4 ??? [186] 33.1% -------------------------------------------------------------------------- ...higher-order.rkt:369:33 [159] 9.0% ...higher-order.rkt:373:33 [156] 9.5% ??? [125] 24.3% ??? [176] 57.2% [182] 21306(8.3%) 932(0.4%) ??? ...ects/racket/contract/private/guts.rkt:638:8 ??? [185] 95.6% -------------------------------------------------------------------------- ??? [175] 100.0% [183] 2206(0.9%) 1736(0.7%) bfsqr ...-lib/math/private/bigfloat/mpfr.rkt:616:4 ??? [186] 21.3% -------------------------------------------------------------------------- make-multiplication-node [178] 100.0% [184] 626(0.2%) 200(0.1%) make-multiplication-subnode ...re/reduce.rkt:231:0 group-by68 [187] 68.1% -------------------------------------------------------------------------- bf> [163] 3.5% ->flonum [144] 4.3% ??? [175] 29.5% ??? [182] 62.7% [185] 32476(12.7%) 15864(6.2%) ??? ...tract/private/arrow-higher-order.rkt:373:33 ??? [188] 48.6% ??? [189] 2.6% -------------------------------------------------------------------------- sig+exp->bigfloat [161] 1.2% bfsqr [183] 2.4% real->bigfloat [142] 18.8% bfmul [181] 77.6% [186] 19768(7.7%) 19768(7.7%) ??? .../share/racket/collects/ffi/unsafe.rkt:861:4 -------------------------------------------------------------------------- make-multiplication-subnode [184]100.0% [187] 426(0.2%) 426(0.2%) group-by68 ...acket/collects/racket/list.rkt:749:0 -------------------------------------------------------------------------- ??? [185] 100.0% [188] 15772(6.2%) 7386(2.9%) ??? ...llects/racket/contract/combinator.rkt:178:4 any-wrap/traverse [190] 53.2% -------------------------------------------------------------------------- ??? [185] 100.0% [189] 840(0.3%) 840(0.3%) ??? ...ects/racket/contract/private/prop.rkt:489:4 -------------------------------------------------------------------------- ??? [188] 100.0% [190] 8386(3.3%) 8386(3.3%) any-wrap/traverse ...cket/utils/any-wrap.rkt:106:2 --------------------------------------------------------------------------