Profiling results ----------------- Total cpu time observed: 102498ms (out of 103464ms) Number of samples taken: 445 (once every 230ms) (Hiding functions with self<1.0% and local<2.0%: 2 of 197 hidden) ========================================================================= Caller Idx Total Self Name+src Local% ms(pct) ms(pct) Callee ========================================================================= ??? [57] 100.0% [1] 96478(94.1%) 0(0.0%) profile-thunk16 ...t/pkgs/profile-lib/main.rkt:9:0 run [15] 100.0% ------------------------------------------------------------------------- ??? [57] 100.0% [2] 71302(69.6%) 0(0.0%) run-improve58 ...ock/herbie/src/mainloop.rkt:244:0 for-loop [16] 57.1% get-final-combination [17] 41.6% loop [68] 1.0% setup-prog [25] 0.3% ------------------------------------------------------------------------- simplify-alt [37] 0.7% loop [141] 5.1% ??? [57] 94.2% [3] 33636(32.8%) 0(0.0%) simplify ...lock/herbie/src/core/simplify.rkt:39:0 simplify-expr [18] 60.2% for-loop [19] 25.2% iterate-egraph!5 [30] 13.4% mk-egraph [27] 0.6% loop [35] 0.6% ------------------------------------------------------------------------- hash-ref! [172] 100.0% [4] 27688(27.0%) 216(0.2%) ??? /home/ztatlock/herbie/src/programs.rkt:294:5 loop [141] 97.8% hash-ref! [172] 2.1% ------------------------------------------------------------------------- copying-mergesort [157] 100.0% [5] 9868(9.6%) 0(0.0%) jloop ...t/collects/racket/private/sort.rkt:121:23 ??? [168] 100.0% ------------------------------------------------------------------------- hash-ref! [172] 100.0% [6] 4524(4.4%) 0(0.0%) ??? .../ztatlock/herbie/src/core/taylor.rkt:285:26 for-loop [20] 100.0% ------------------------------------------------------------------------- hash-ref! [172] 100.0% [7] 4124(4.0%) 0(0.0%) ??? .../ztatlock/herbie/src/core/taylor.rkt:295:23 for-loop [21] 100.0% ------------------------------------------------------------------------- hash-ref! [172] 100.0% [8] 4082(4.0%) 0(0.0%) ??? ...e/ztatlock/herbie/src/core/taylor.rkt:43:15 ??? [33] 95.1% hash-ref! [172] 4.9% ------------------------------------------------------------------------- hash-ref! [172] 100.0% [9] 3154(3.1%) 0(0.0%) ??? .../ztatlock/herbie/src/core/taylor.rkt:322:33 for-loop [22] 100.0% ------------------------------------------------------------------------- hash-ref! [172] 100.0% [10] 2236(2.2%) 0(0.0%) ??? .../ztatlock/herbie/src/core/taylor.rkt:392:23 for-loop [23] 100.0% ------------------------------------------------------------------------- f94 [109] 100.0% [11] 870(0.8%) 0(0.0%) taylor-invert .../herbie/src/core/taylor.rkt:312:0 first-nonzero-exp [125] 74.7% simplify [32] 25.3% ------------------------------------------------------------------------- hash-ref! [172] 100.0% [12] 728(0.7%) 0(0.0%) ??? .../ztatlock/herbie/src/core/taylor.rkt:338:33 hash-ref! [172] 72.5% for-loop [28] 27.5% ------------------------------------------------------------------------- f94 [109] 100.0% [13] 400(0.4%) 0(0.0%) combine-mterms ...herbie/src/core/reduce.rkt:180:0 for-loop [24] 100.0% ------------------------------------------------------------------------- hash-ref! [172] 100.0% [14] 222(0.2%) 0(0.0%) ??? .../ztatlock/herbie/src/core/taylor.rkt:483:23 for-loop [26] 100.0% ------------------------------------------------------------------------- profile-thunk16 [1] 99.8% [15] 96700(94.3%) 0(0.0%) run ...share/racket/pkgs/profile-lib/main.rkt:39:2 ??? [57] 100.0% ------------------------------------------------------------------------- run-improve58 [2] 100.0% [16] 40738(39.7%) 0(0.0%) for-loop ...ztatlock/herbie/src/mainloop.rkt:255:8 run-iter! [29] 100.0% ------------------------------------------------------------------------- run-improve58 [2] 100.0% [17] 29654(28.9%) 0(0.0%) get-final-combination ...ie/src/mainloop.rkt:271:0 split-table [31] 94.2% extract-alt [36] 5.8% ------------------------------------------------------------------------- simplify [3] 100.0% [18] 20234(19.7%) 0(0.0%) simplify-expr ...herbie/src/core/simplify.rkt:68:0 iterate-egraph!5 [30] 91.5% loop [35] 8.5% ------------------------------------------------------------------------- simplify [3] 100.0% [19] 8472(8.3%) 0(0.0%) for-loop ...ock/herbie/src/core/simplify.rkt:61:12 iterate-egraph!5 [30] 100.0% ------------------------------------------------------------------------- ??? [6] 100.0% [20] 4524(4.4%) 0(0.0%) for-loop ...lock/herbie/src/core/taylor.rkt:285:52 ??? [33] 56.2% hash-ref! [172] 39.4% simplify [32] 4.4% ------------------------------------------------------------------------- ??? [7] 100.0% [21] 4124(4.0%) 264(0.3%) for-loop ...lock/herbie/src/core/taylor.rkt:298:27 hash-ref! [172] 96.8% ------------------------------------------------------------------------- ??? [9] 100.0% [22] 3154(3.1%) 0(0.0%) for-loop ...lock/herbie/src/core/taylor.rkt:324:46 hash-ref! [172] 100.0% ------------------------------------------------------------------------- ??? [10] 100.0% [23] 2236(2.2%) 0(0.0%) for-loop ...lock/herbie/src/core/taylor.rkt:396:33 for-loop [34] 100.0% ------------------------------------------------------------------------- combine-mterms [13] 100.0% [24] 400(0.4%) 200(0.2%) for-loop ...tlock/herbie/src/core/reduce.rkt:184:5 hash-ref! [172] 50.0% ------------------------------------------------------------------------- run-improve58 [2] 100.0% [25] 224(0.2%) 0(0.0%) setup-prog /home/ztatlock/herbie/src/glue.rkt:46:0 simplify-alt [37] 100.0% ------------------------------------------------------------------------- ??? [14] 100.0% [26] 222(0.2%) 0(0.0%) for-loop ...lock/herbie/src/core/taylor.rkt:487:35 parse-loop50 [132] 100.0% ------------------------------------------------------------------------- simplify [3] 100.0% [27] 216(0.2%) 0(0.0%) mk-egraph ...lock/herbie/src/core/egraph.rkt:123:0 expr->enode [38] 100.0% ------------------------------------------------------------------------- ??? [12] 100.0% [28] 200(0.2%) 0(0.0%) for-loop ...lock/herbie/src/core/taylor.rkt:341:46 hash-ref! [172] 100.0% ------------------------------------------------------------------------- for-loop [16] 100.0% [29] 40738(39.7%) 0(0.0%) run-iter! ...tatlock/herbie/src/mainloop.rkt:225:0 simplify! [39] 77.8% gen-series! [41] 14.2% finalize-iter! [42] 6.5% gen-rewrites! [46] 1.0% choose-best-alt! [47] 0.5% ------------------------------------------------------------------------- simplify [3] 14.3% for-loop [19] 26.9% simplify-expr [18] 58.8% [30] 31504(30.7%) 0(0.0%) iterate-egraph!5 ...bie/src/core/simplify.rkt:95:0 one-iter [40] 96.5% map-enodes [44] 3.5% ------------------------------------------------------------------------- get-final-combination [17] 100.0% [31] 27928(27.2%) 0(0.0%) split-table .../ztatlock/herbie/src/glue.rkt:171:0 f94 [109] 95.9% ??? [53] 4.1% ------------------------------------------------------------------------- for-loop [20] 4.3% taylor-invert [11] 4.7% hash-ref! [172] 91.1% [32] 4700(4.6%) 0(0.0%) simplify ...atlock/herbie/src/core/reduce.rkt:15:0 f94 [109] 50.4% parse-loop50 [132] 36.3% debug-print [45] 9.0% simplify-node [48] 4.3% ------------------------------------------------------------------------- ??? [8] 41.4% for-loop [20] 58.6% [33] 4304(4.2%) 0(0.0%) ??? .../ztatlock/herbie/src/core/taylor.rkt:288:19 hash-ref! [172] 100.0% ------------------------------------------------------------------------- for-loop [23] 100.0% [34] 2236(2.2%) 0(0.0%) for-loop ...lock/herbie/src/core/taylor.rkt:398:39 hash-ref! [172] 100.0% ------------------------------------------------------------------------- simplify [3] 10.5% simplify-expr [18] 89.5% [35] 1916(1.9%) 0(0.0%) loop ...tatlock/herbie/src/core/simplify.rkt:203:2 pass [43] 100.0% ------------------------------------------------------------------------- get-final-combination [17] 100.0% [36] 1726(1.7%) 0(0.0%) extract-alt ...e/ztatlock/herbie/src/glue.rkt:57:0 loop [141] 100.0% ------------------------------------------------------------------------- setup-prog [25] 100.0% [37] 224(0.2%) 0(0.0%) simplify-alt .../ztatlock/herbie/src/glue.rkt:84:0 simplify [3] 100.0% ------------------------------------------------------------------------- mk-egraph [27] 100.0% [38] 216(0.2%) 0(0.0%) expr->enode ...ck/herbie/src/core/egraph.rkt:124:2 mk-enode! [100] 100.0% ------------------------------------------------------------------------- run-iter! [29] 100.0% [39] 31686(30.9%) 0(0.0%) simplify! ...tatlock/herbie/src/mainloop.rkt:164:0 for-loop [49] 100.0% ------------------------------------------------------------------------- iterate-egraph!5 [30] 100.0% [40] 30412(29.7%) 1078(1.1%) one-iter ...ock/herbie/src/core/simplify.rkt:106:0 for-loop [50] 60.5% loop [51] 31.1% apply-match [58] 4.2% loop [102] 0.7% ------------------------------------------------------------------------- run-iter! [29] 100.0% [41] 5792(5.7%) 0(0.0%) gen-series! ...tlock/herbie/src/mainloop.rkt:136:0 for-loop [52] 100.0% ------------------------------------------------------------------------- run-iter! [29] 100.0% [42] 2640(2.6%) 0(0.0%) finalize-iter! ...ck/herbie/src/mainloop.rkt:179:0 ??? [53] 100.0% ------------------------------------------------------------------------- loop [35] 100.0% [43] 1916(1.9%) 422(0.4%) pass ...tatlock/herbie/src/core/simplify.rkt:193:2 for-loop [54] 78.0% ------------------------------------------------------------------------- iterate-egraph!5 [30] 100.0% [44] 1092(1.1%) 0(0.0%) map-enodes ...ock/herbie/src/core/egraph.rkt:139:0 loop [141] 100.0% ------------------------------------------------------------------------- simplify [32] 100.0% [45] 422(0.4%) 220(0.2%) debug-print ...ztatlock/herbie/src/debug.rkt:107:0 for-loop [56] 47.9% ------------------------------------------------------------------------- run-iter! [29] 100.0% [46] 400(0.4%) 0(0.0%) gen-rewrites! ...ock/herbie/src/mainloop.rkt:150:0 for-loop [55] 100.0% ------------------------------------------------------------------------- run-iter! [29] 100.0% [47] 220(0.2%) 0(0.0%) choose-best-alt! .../herbie/src/mainloop.rkt:122:0 ??? [53] 100.0% ------------------------------------------------------------------------- simplify [32] 100.0% [48] 200(0.2%) 0(0.0%) simplify-node ...k/herbie/src/core/reduce.rkt:39:0 append-map [126] 100.0% ------------------------------------------------------------------------- simplify! [39] 100.0% [49] 31686(30.9%) 0(0.0%) for-loop ...ztatlock/herbie/src/mainloop.rkt:168:6 ??? [57] 100.0% ------------------------------------------------------------------------- for-loop [50] 49.5% one-iter [40] 50.5% [50] 18392(17.9%) 4752(4.6%) for-loop ...ck/herbie/src/core/simplify.rkt:116:12 for-loop [50] 49.5% match-e [69] 36.4% ??? [114] 0.7% ------------------------------------------------------------------------- one-iter [40] 100.0% [51] 9454(9.2%) 0(0.0%) loop ...cket/collects/racket/private/map.rkt:52:19 apply-match [58] 100.0% ------------------------------------------------------------------------- gen-series! [41] 100.0% [52] 5792(5.7%) 0(0.0%) for-loop ...ztatlock/herbie/src/mainloop.rkt:142:7 taylor-alt [59] 100.0% ------------------------------------------------------------------------- debug7 [140] 4.8% choose-best-alt! [47] 5.2% split-table [31] 27.2% finalize-iter! [42] 62.8% [53] 4206(4.1%) 200(0.2%) ??? ...contract/private/arrow-val-first.rkt:357:18 for-loop [60] 58.0% split-atab [61] 27.2% ??? [65] 5.2% atab-add-altns [66] 4.8% ------------------------------------------------------------------------- pass [43] 100.0% [54] 1494(1.5%) 0(0.0%) for-loop ...ck/herbie/src/core/simplify.rkt:196:29 for-loop [62] 43.9% argmin [63] 42.6% loop [67] 13.5% ------------------------------------------------------------------------- gen-rewrites! [46] 100.0% [55] 400(0.4%) 0(0.0%) for-loop ...tatlock/herbie/src/mainloop.rkt:155:11 ??? [64] 100.0% ------------------------------------------------------------------------- debug-print [45] 100.0% [56] 202(0.2%) 202(0.2%) for-loop /home/ztatlock/herbie/src/debug.rkt:113:2 ------------------------------------------------------------------------- for-loop [49] 10.7% run [15] 43.1% [57] 100912(98.5%) 0(0.0%) ??? ...lects/racket/private/more-scheme.rkt:261:28 profile-thunk16 [1] 42.9% run-improve58 [2] 30.9% loop [68] 15.5% simplify [3] 10.7% ------------------------------------------------------------------------- one-iter [40] 12.0% loop [51] 88.0% [58] 10740(10.5%) 0(0.0%) apply-match .../herbie/src/core/simplify.rkt:122:2 merge-egraph-nodes! [81] 32.0% for-loop [71] 27.7% match-e [69] 16.1% loop! [152] 10.7% substitute-e [83] 5.8% mk-enode! [100] 3.9% reduce-to-single! [77] 2.0% update-leader! [99] 1.9% ------------------------------------------------------------------------- for-loop [52] 100.0% [59] 5792(5.7%) 0(0.0%) taylor-alt ...e/ztatlock/herbie/src/glue.rkt:142:0 for-loop [70] 100.0% ------------------------------------------------------------------------- ??? [53] 100.0% [60] 2438(2.4%) 0(0.0%) for-loop ...ock/herbie/src/core/alt-table.rkt:51:2 atab-add-altn [72] 100.0% ------------------------------------------------------------------------- ??? [53] 100.0% [61] 1146(1.1%) 0(0.0%) split-atab ...k/herbie/src/core/alt-table.rkt:74:0 for-loop [73] 100.0% ------------------------------------------------------------------------- for-loop [54] 100.0% [62] 656(0.6%) 656(0.6%) for-loop ...ck/herbie/src/core/simplify.rkt:183:13 ------------------------------------------------------------------------- for-loop [54] 100.0% [63] 636(0.6%) 0(0.0%) argmin ...re/racket/collects/racket/list.rkt:743:0 expression-cost [74] 65.4% for-loop [76] 34.6% ------------------------------------------------------------------------- for-loop [55] 100.0% [64] 400(0.4%) 0(0.0%) ??? /home/ztatlock/herbie/src/alternative.rkt:90:0 rewriter [75] 100.0% ------------------------------------------------------------------------- ??? [53] 100.0% [65] 220(0.2%) 0(0.0%) ??? ...ztatlock/herbie/src/core/alt-table.rkt:54:0 ??? [127] 100.0% ------------------------------------------------------------------------- ??? [53] 100.0% [66] 202(0.2%) 0(0.0%) atab-add-altns ...rbie/src/core/alt-table.rkt:50:0 atab-add-altn [72] 100.0% ------------------------------------------------------------------------- for-loop [54] 100.0% [67] 202(0.2%) 0(0.0%) loop ...hare/racket/collects/racket/list.rkt:729:4 expression-cost [74] 100.0% ------------------------------------------------------------------------- run-improve58 [2] 2.3% ??? [57] 97.7% [68] 30296(29.6%) 0(0.0%) loop /home/ztatlock/herbie/src/points.rkt:119:2 loop [78] 59.8% make-exacts* [94] 28.0% loop [95] 11.5% for-loop [90] 0.7% ------------------------------------------------------------------------- apply-match [58] 7.6% for-loop [97] 10.6% for-loop [50] 81.8% [69] 15124(14.8%) 7926(7.7%) match-e ...tatlock/herbie/src/core/ematch.rkt:46:0 for-loop [79] 40.9% for-loop [97] 6.1% custom-in-set [87] 2.8% list-cartesian-product [103] 2.1% loop [141] 0.7% ------------------------------------------------------------------------- taylor-alt [59] 100.0% [70] 5792(5.7%) 0(0.0%) for-loop /home/ztatlock/herbie/src/glue.rkt:144:2 location-do [80] 100.0% ------------------------------------------------------------------------- apply-match [58] 100.0% [71] 2970(2.9%) 0(0.0%) for-loop ...ck/herbie/src/core/simplify.rkt:136:10 loop! [152] 50.0% merge-egraph-nodes! [81] 29.8% substitute-e [83] 13.4% mk-enode! [100] 6.8% ------------------------------------------------------------------------- atab-add-altns [66] 7.7% for-loop [60] 92.3% [72] 2640(2.6%) 0(0.0%) atab-add-altn ...rbie/src/core/alt-table.rkt:208:0 best-and-tied-at-points [82] 83.2% override-at-pnts [86] 16.8% ------------------------------------------------------------------------- split-atab [61] 100.0% [73] 1146(1.1%) 0(0.0%) for-loop ...ock/herbie/src/core/alt-table.rkt:75:2 for-loop [84] 59.7% for-loop [89] 21.1% for-loop [92] 19.2% ------------------------------------------------------------------------- loop [67] 32.7% argmin [63] 67.3% [74] 618(0.6%) 0(0.0%) expression-cost ...k/herbie/src/programs.rkt:309:0 compile [85] 100.0% ------------------------------------------------------------------------- ??? [64] 16.2% matcher [104] 83.8% [75] 400(0.4%) 200(0.2%) rewriter ...lock/herbie/src/core/matcher.rkt:127:2 for-loop [88] 83.8% *rules* [93] 6.2% ------------------------------------------------------------------------- argmin [63] 100.0% [76] 220(0.2%) 220(0.2%) for-loop ...ztatlock/herbie/src/programs.rkt:310:2 ------------------------------------------------------------------------- apply-match [58] 100.0% [77] 220(0.2%) 0(0.0%) reduce-to-single! ...bie/src/core/egraph.rkt:324:0 for-loop [91] 100.0% ------------------------------------------------------------------------- loop [68] 100.0% [78] 18126(17.7%) 0(0.0%) loop /home/ztatlock/herbie/src/points.rkt:90:2 make-exacts* [94] 42.6% eval-prog [170] 36.0% loop [95] 21.4% ------------------------------------------------------------------------- match-e [69] 100.0% [79] 6578(6.4%) 4038(3.9%) for-loop ...tlock/herbie/src/core/ematch.rkt:59:11 for-loop [97] 29.0% loop [141] 6.7% loop [106] 3.3% list-cartesian-product [103] 3.1% filter [193] 1.6% ------------------------------------------------------------------------- location-do [80] 28.0% for-loop [70] 72.0% [80] 5792(5.7%) 0(0.0%) location-do ...tlock/herbie/src/programs.rkt:226:0 approximate9 [96] 72.0% location-do [80] 28.0% ------------------------------------------------------------------------- for-loop [107] 2.3% merge-egraph-nodes! [81] 2.5% for-loop [71] 20.5% apply-match [58] 74.7% [81] 4320(4.2%) 200(0.2%) merge-egraph-nodes! ...e/src/core/egraph.rkt:152:0 update-leader! [99] 47.2% for-loop [101] 26.1% loop! [152] 17.2% merge-egraph-nodes! [81] 2.5% for-loop [107] 2.3% ------------------------------------------------------------------------- atab-add-altn [72] 100.0% [82] 2196(2.1%) 0(0.0%) best-and-tied-at-points ...ore/alt-table.rkt:122:0 errors [98] 95.4% for-loop [108] 4.6% ------------------------------------------------------------------------- substitute-e [83] 9.7% for-loop [71] 29.3% apply-match [58] 61.0% [83] 1020(1.0%) 198(0.2%) substitute-e ...ck/herbie/src/core/ematch.rkt:71:0 mk-enode! [100] 80.6% substitute-e [83] 9.7% ------------------------------------------------------------------------- for-loop [73] 100.0% [84] 684(0.7%) 0(0.0%) for-loop ...ck/herbie/src/core/alt-table.rkt:80:53 loop [102] 100.0% ------------------------------------------------------------------------- expression-cost [74] 100.0% [85] 618(0.6%) 0(0.0%) compile .../ztatlock/herbie/src/programs.rkt:286:0 hash-ref! [172] 100.0% ------------------------------------------------------------------------- atab-add-altn [72] 100.0% [86] 444(0.4%) 0(0.0%) override-at-pnts ...e/src/core/alt-table.rkt:145:0 errors [98] 100.0% ------------------------------------------------------------------------- match-e [69] 100.0% [87] 424(0.4%) 424(0.4%) custom-in-set ...acket/private/set-types.rkt:577:0 ------------------------------------------------------------------------- rewriter [75] 100.0% [88] 400(0.4%) 0(0.0%) for-loop ...ock/herbie/src/core/matcher.rkt:130:10 matcher [104] 100.0% ------------------------------------------------------------------------- for-loop [73] 100.0% [89] 242(0.2%) 0(0.0%) for-loop ...ck/herbie/src/core/alt-table.rkt:86:30 ??? [113] 100.0% ------------------------------------------------------------------------- loop [68] 100.0% [90] 222(0.2%) 0(0.0%) for-loop .../ztatlock/herbie/src/points.rkt:126:18 for-loop [105] 100.0% ------------------------------------------------------------------------- reduce-to-single! [77] 100.0% [91] 220(0.2%) 220(0.2%) for-loop ...lock/herbie/src/core/egraph.rkt:328:21 ------------------------------------------------------------------------- for-loop [73] 100.0% [92] 220(0.2%) 0(0.0%) for-loop ...ck/herbie/src/core/alt-table.rkt:76:45 ??? [113] 100.0% ------------------------------------------------------------------------- rewriter [75] 100.0% [93] 200(0.2%) 0(0.0%) *rules* ...tlock/herbie/src/syntax/rules.rkt:414:0 ??? [180] 100.0% ------------------------------------------------------------------------- loop [78] 47.7% loop [68] 52.3% [94] 16198(15.8%) 0(0.0%) make-exacts* ...tatlock/herbie/src/points.rkt:77:0 map [123] 40.2% loop [141] 36.6% eval-prog [170] 23.2% ------------------------------------------------------------------------- loop [68] 47.3% loop [78] 52.7% [95] 7344(7.2%) 0(0.0%) loop /home/ztatlock/herbie/src/points.rkt:80:4 map [123] 100.0% ------------------------------------------------------------------------- location-do [80] 100.0% [96] 5792(5.7%) 0(0.0%) approximate9 ...ck/herbie/src/core/taylor.rkt:12:0 loop [110] 81.7% f94 [109] 11.0% taylor-sqrt [117] 3.8% taylor-quotient [121] 3.5% ------------------------------------------------------------------------- match-e [69] 36.1% for-loop [79] 63.9% [97] 3978(3.9%) 646(0.6%) for-loop ...tlock/herbie/src/core/ematch.rkt:65:37 match-e [69] 78.7% ??? [114] 5.0% ------------------------------------------------------------------------- loop [141] 7.3% composed [155] 7.4% override-at-pnts [86] 14.9% best-and-tied-at-points [82] 70.4% [98] 2976(2.9%) 0(0.0%) errors /home/ztatlock/herbie/src/points.rkt:142:0 for-loop [111] 74.0% eval-prog [170] 26.0% ------------------------------------------------------------------------- apply-match [58] 8.6% merge-egraph-nodes! [81] 91.4% [99] 2350(2.3%) 420(0.4%) update-leader! ...herbie/src/core/egraph.rkt:217:0 for-loop [112] 73.5% mutable-set [120] 8.6% ------------------------------------------------------------------------- for-loop [71] 12.2% expr->enode [38] 13.0% apply-match [58] 25.3% substitute-e [83] 49.5% [100] 1660(1.6%) 1242(1.2%) mk-enode! ...lock/herbie/src/core/egraph.rkt:101:0 new-enode [118] 13.0% hash-has-key? [119] 12.2% ------------------------------------------------------------------------- merge-egraph-nodes! [81] 100.0% [101] 1126(1.1%) 1126(1.1%) for-loop ...tlock/herbie/src/core/egraph.rkt:232:6 ------------------------------------------------------------------------- one-iter [40] 22.8% for-loop [84] 77.2% [102] 886(0.9%) 202(0.2%) loop ...ket/collects/racket/private/list.rkt:264:4 ??? [113] 77.2% ------------------------------------------------------------------------- list-cartesian-product [103] 25.7% for-loop [79] 36.6% match-e [69] 37.7% [103] 822(0.8%) 822(0.8%) list-cartesian-product ...src/core/ematch.rkt:20:0 list-cartesian-product [103] 25.7% ------------------------------------------------------------------------- matcher [104] 23.2% for-loop [115] 26.8% for-loop [88] 50.0% [104] 400(0.4%) 0(0.0%) matcher ...tlock/herbie/src/core/matcher.rkt:163:2 rewriter [75] 50.0% for-loop [115] 26.8% matcher [104] 23.2% ------------------------------------------------------------------------- for-loop [90] 100.0% [105] 222(0.2%) 0(0.0%) for-loop .../ztatlock/herbie/src/points.rkt:127:20 ??? [116] 100.0% ------------------------------------------------------------------------- for-loop [79] 100.0% [106] 220(0.2%) 220(0.2%) loop ...e/racket/collects/racket/function.rkt:53:6 ------------------------------------------------------------------------- merge-egraph-nodes! [81] 100.0% [107] 202(0.2%) 0(0.0%) for-loop ...lock/herbie/src/core/egraph.rkt:200:10 merge-egraph-nodes! [81] 100.0% ------------------------------------------------------------------------- best-and-tied-at-points [82] 100.0% [108] 100(0.1%) 100(0.1%) for-loop ...k/herbie/src/core/alt-table.rkt:124:16 ------------------------------------------------------------------------- ??? [137] 0.2% composed [155] 0.2% loop [141] 0.2% for-loop [150] 0.2% parse-loop50 [132] 0.3% approximate9 [96] 0.7% append-map [126] 0.7% hash-ref! [172] 0.9% f94 [109] 1.6% simplify [32] 3.3% map [123] 3.8% split-table [31] 88.0% [109] 30422(29.7%) 642(0.6%) f94 ...t/collects/racket/match/compiler.rkt:507:40 option-on-expr [122] 84.5% map [123] 5.7% loop [141] 3.6% f94 [109] 1.6% taylor-invert [11] 0.9% append-map [126] 0.7% taylor [128] 0.6% combine-mterms [13] 0.4% parse-loop50 [132] 0.2% composed [155] 0.2% ------------------------------------------------------------------------- approximate9 [96] 100.0% [110] 4732(4.6%) 0(0.0%) loop ...e/ztatlock/herbie/src/core/taylor.rkt:83:4 hash-ref! [172] 100.0% ------------------------------------------------------------------------- errors [98] 100.0% [111] 2202(2.1%) 202(0.2%) for-loop ...e/ztatlock/herbie/src/points.rkt:145:4 ??? [171] 46.3% ->flonum [174] 26.2% ulp-difference [129] 9.2% ??? [127] 9.2% ------------------------------------------------------------------------- update-leader! [99] 100.0% [112] 1728(1.7%) 0(0.0%) for-loop ...tlock/herbie/src/core/egraph.rkt:222:6 for-loop [124] 100.0% ------------------------------------------------------------------------- for-loop [92] 19.2% for-loop [89] 21.1% loop [102] 59.7% [113] 1146(1.1%) 0(0.0%) ??? .../ztatlock/herbie/src/core/regimes.rkt:295:8 eval-prog [170] 100.0% ------------------------------------------------------------------------- for-loop [97] 45.2% for-loop [50] 54.8% [114] 442(0.4%) 242(0.2%) ??? /home/ztatlock/herbie/src/core/ematch.rkt:50:5 for-loop [130] 45.2% ------------------------------------------------------------------------- matcher [104] 100.0% [115] 400(0.4%) 0(0.0%) for-loop ...ock/herbie/src/core/matcher.rkt:179:21 matcher [104] 100.0% ------------------------------------------------------------------------- for-loop [105] 100.0% [116] 222(0.2%) 222(0.2%) ??? ...k/herbie/src/syntax/distributions.rkt:65:14 ------------------------------------------------------------------------- approximate9 [96] 100.0% [117] 220(0.2%) 0(0.0%) taylor-sqrt ...ck/herbie/src/core/taylor.rkt:346:0 first-nonzero-exp [125] 100.0% ------------------------------------------------------------------------- mk-enode! [100] 100.0% [118] 216(0.2%) 0(0.0%) new-enode ...atlock/herbie/src/core/enode.rkt:68:0 set [158] 100.0% ------------------------------------------------------------------------- mk-enode! [100] 100.0% [119] 202(0.2%) 202(0.2%) hash-has-key? ...et/private/more-scheme.rkt:368:13 ------------------------------------------------------------------------- update-leader! [99] 100.0% [120] 202(0.2%) 202(0.2%) mutable-set .../racket/private/set-types.rkt:999:0 ------------------------------------------------------------------------- approximate9 [96] 100.0% [121] 200(0.2%) 0(0.0%) taylor-quotient ...erbie/src/core/taylor.rkt:328:0 ??? [137] 100.0% ------------------------------------------------------------------------- loop [141] 4.0% f94 [109] 96.0% [122] 26782(26.1%) 0(0.0%) option-on-expr ...erbie/src/core/regimes.rkt:110:0 sort-context-on-expr [131] 88.9% pick-errors [133] 7.2% err-lsts->split-indices [135] 2.4% loop [141] 0.8% sindices->spoints [139] 0.7% ------------------------------------------------------------------------- parse-loop50 [132] 0.4% f94 [109] 15.5% make-exacts* [94] 39.5% loop [95] 44.6% [123] 16460(16.1%) 200(0.2%) map ...acket/collects/racket/private/map.rkt:20:13 loop [141] 82.8% f94 [109] 9.7% parse-loop50 [132] 4.2% ??? [171] 1.3% ??? [137] 1.3% simplify* [145] 0.4% ------------------------------------------------------------------------- for-loop [112] 100.0% [124] 1728(1.7%) 0(0.0%) for-loop ...tlock/herbie/src/core/egraph.rkt:223:8 hash-update! [134] 100.0% ------------------------------------------------------------------------- taylor-sqrt [117] 25.3% taylor-invert [11] 74.7% [125] 870(0.8%) 208(0.2%) first-nonzero-exp ...bie/src/core/taylor.rkt:260:0 hash-ref! [172] 76.1% ------------------------------------------------------------------------- simplify-node [48] 15.6% f94 [109] 84.4% [126] 642(0.6%) 0(0.0%) append-map ...acket/collects/racket/list.rkt:565:2 f94 [109] 54.2% free-variables [136] 45.8% ------------------------------------------------------------------------- for-loop [111] 47.9% ??? [65] 52.1% [127] 422(0.4%) 202(0.2%) ??? ...tract/private/arrow-higher-order.rkt:342:33 best-alt [138] 52.1% ------------------------------------------------------------------------- f94 [109] 100.0% [128] 420(0.4%) 220(0.2%) taylor ...tatlock/herbie/src/core/taylor.rkt:161:0 debug7 [140] 47.6% ------------------------------------------------------------------------- for-loop [111] 100.0% [129] 202(0.2%) 0(0.0%) ulp-difference ...atlock/herbie/src/float.rkt:19:0 ??? [180] 100.0% ------------------------------------------------------------------------- ??? [114] 100.0% [130] 200(0.2%) 200(0.2%) for-loop ...atlock/herbie/src/core/ematch.rkt:51:7 ------------------------------------------------------------------------- option-on-expr [122] 100.0% [131] 23798(23.2%) 0(0.0%) sort-context-on-expr ...herbie/src/points.rkt:47:0 ??? [142] 100.0% ------------------------------------------------------------------------- loop [141] 3.1% f94 [109] 3.1% for-loop [26] 6.9% parse-loop50 [132] 19.3% map [123] 30.1% simplify [32] 37.5% [132] 3238(3.2%) 1772(1.7%) parse-loop50 ...s/racket/match/compiler.rkt:418:15 parse-loop50 [132] 19.3% f94 [109] 13.7% loop [141] 9.2% simplify* [145] 7.2% for-loop [147] 6.9% for-loop [150] 3.1% map [123] 2.0% ------------------------------------------------------------------------- option-on-expr [122] 100.0% [133] 1930(1.9%) 0(0.0%) pick-errors ...k/herbie/src/core/regimes.rkt:177:0 for-loop [143] 100.0% ------------------------------------------------------------------------- for-loop [124] 100.0% [134] 1728(1.7%) 0(0.0%) hash-update! ...ket/private/more-scheme.rkt:362:13 ??? [144] 100.0% ------------------------------------------------------------------------- option-on-expr [122] 100.0% [135] 638(0.6%) 0(0.0%) err-lsts->split-indices .../core/regimes.rkt:228:0 add-splitpoint [146] 100.0% ------------------------------------------------------------------------- append-map [126] 100.0% [136] 442(0.4%) 442(0.4%) free-variables ...ock/herbie/src/programs.rkt:87:0 ------------------------------------------------------------------------- taylor-quotient [121] 47.6% map [123] 52.4% [137] 420(0.4%) 200(0.2%) ??? ...ket/collects/racket/private/list.rkt:323:18 f94 [109] 52.4% ------------------------------------------------------------------------- ??? [127] 100.0% [138] 220(0.2%) 0(0.0%) best-alt /home/ztatlock/herbie/src/glue.rkt:79:0 loop [148] 100.0% ------------------------------------------------------------------------- option-on-expr [122] 100.0% [139] 200(0.2%) 0(0.0%) sindices->spoints ...ie/src/core/regimes.rkt:123:0 for-loop [149] 100.0% ------------------------------------------------------------------------- taylor [128] 100.0% [140] 200(0.2%) 0(0.0%) debug7 /home/ztatlock/herbie/src/debug.rkt:102:0 ??? [53] 100.0% ------------------------------------------------------------------------- make-exacts* [94] 0.1% option-on-expr [122] 0.2% for-loop [79] 0.2% match-e [69] 0.4% map [123] 0.4% map-enodes [44] 0.6% parse-loop50 [132] 1.0% loop! [152] 1.6% f94 [109] 2.0% extract-alt [36] 2.0% ??? [4] 44.0% loop [141] 47.6% [141] 54720(53.4%) 920(0.9%) loop ...cket/collects/racket/private/map.rkt:25:19 loop [141] 47.6% hash-ref! [172] 44.0% simplify [3] 2.0% option-on-expr [122] 2.0% loop! [152] 1.6% parse-loop50 [132] 0.8% for-loop [154] 0.6% ??? [171] 0.4% errors [98] 0.2% f94 [109] 0.2% ->flonum [174] 0.0% ------------------------------------------------------------------------- sort-context-on-expr [131] 100.0% [142] 23798(23.2%) 0(0.0%) ??? ...cket/collects/racket/private/sort.rkt:403:3 generic-sort/key [151] 87.9% loop [164] 12.1% ------------------------------------------------------------------------- pick-errors [133] 100.0% [143] 1930(1.9%) 0(0.0%) for-loop ...lock/herbie/src/core/regimes.rkt:180:4 eval-prog [170] 100.0% ------------------------------------------------------------------------- hash-update! [134] 100.0% [144] 1728(1.7%) 0(0.0%) ??? .../ztatlock/herbie/src/core/egraph.rkt:225:24 for-loop [153] 100.0% ------------------------------------------------------------------------- parse-loop50 [132] 48.7% map [123] 51.3% [145] 822(0.8%) 200(0.2%) simplify* ...tlock/herbie/src/core/reduce.rkt:20:0 hash-ref! [172] 51.3% return/no-unsupplied [187] 24.3% ------------------------------------------------------------------------- err-lsts->split-indices [135] 100.0% [146] 638(0.6%) 0(0.0%) add-splitpoint ...erbie/src/core/regimes.rkt:241:2 for-loop [156] 100.0% ------------------------------------------------------------------------- parse-loop50 [132] 100.0% [147] 222(0.2%) 0(0.0%) for-loop ...lock/herbie/src/core/taylor.rkt:490:59 hash-ref! [172] 100.0% ------------------------------------------------------------------------- best-alt [138] 100.0% [148] 220(0.2%) 0(0.0%) loop /home/ztatlock/herbie/src/common.rkt:110:2 composed [155] 100.0% ------------------------------------------------------------------------- sindices->spoints [139] 100.0% [149] 200(0.2%) 0(0.0%) for-loop ...lock/herbie/src/core/regimes.rkt:157:7 ??? [171] 100.0% ------------------------------------------------------------------------- parse-loop50 [132] 100.0% [150] 200(0.2%) 0(0.0%) for-loop ...tlock/herbie/src/core/reduce.rkt:88:13 f94 [109] 100.0% ------------------------------------------------------------------------- ??? [142] 100.0% [151] 20918(20.4%) 0(0.0%) generic-sort/key .../racket/private/sort.rkt:185:2 copying-mergesort [157] 89.7% loop [164] 10.3% ------------------------------------------------------------------------- merge-egraph-nodes! [81] 18.3% apply-match [58] 25.2% for-loop [71] 27.4% loop [141] 29.1% [152] 3476(3.4%) 0(0.0%) loop! .../ztatlock/herbie/src/core/enode.rkt:163:2 custom-set-union [159] 40.5% loop [141] 29.1% set [158] 23.7% update-en-expr [160] 6.7% ------------------------------------------------------------------------- ??? [144] 100.0% [153] 1728(1.7%) 1306(1.3%) for-loop ...lock/herbie/src/core/egraph.rkt:226:26 update-en-expr [160] 24.4% ------------------------------------------------------------------------- loop [141] 100.0% [154] 1092(1.1%) 218(0.2%) for-loop ...ock/herbie/src/core/simplify.rkt:161:2 setfindf [162] 41.6% eval-const-expr [163] 38.5% ------------------------------------------------------------------------- loop [148] 33.2% f94 [109] 66.8% [155] 662(0.6%) 0(0.0%) composed ...ollects/racket/private/list.rkt:321:16 f94 [109] 66.8% errors [98] 33.2% ------------------------------------------------------------------------- add-splitpoint [146] 100.0% [156] 638(0.6%) 0(0.0%) for-loop ...lock/herbie/src/core/regimes.rkt:243:4 for-loop [161] 100.0% ------------------------------------------------------------------------- generic-sort/key [151] 41.8% copying-mergesort [157] 58.2% [157] 18754(18.3%) 0(0.0%) copying-mergesort ...racket/private/sort.rkt:130:8 copying-mergesort [157] 58.2% loop [164] 28.7% jloop [5] 13.2% ------------------------------------------------------------------------- new-enode [118] 12.6% loop! [152] 87.4% [158] 1720(1.7%) 1720(1.7%) set ...collects/racket/private/set-types.rkt:981:0 ------------------------------------------------------------------------- loop! [152] 100.0% [159] 1508(1.5%) 222(0.2%) custom-set-union ...et/private/set-types.rkt:168:0 for-loop [165] 70.6% for-loop [167] 14.7% ------------------------------------------------------------------------- for-loop [153] 47.6% loop! [152] 52.4% [160] 886(0.9%) 886(0.9%) update-en-expr ...herbie/src/core/egraph.rkt:211:0 ------------------------------------------------------------------------- for-loop [156] 100.0% [161] 638(0.6%) 638(0.6%) for-loop ...lock/herbie/src/core/regimes.rkt:247:8 ------------------------------------------------------------------------- for-loop [154] 100.0% [162] 454(0.4%) 212(0.2%) setfindf ...e/ztatlock/herbie/src/common.rkt:143:0 for-loop [166] 53.3% ------------------------------------------------------------------------- for-loop [154] 100.0% [163] 420(0.4%) 0(0.0%) eval-const-expr ...k/herbie/src/programs.rkt:277:0 ??? [184] 52.4% inductor [175] 47.6% ------------------------------------------------------------------------- generic-sort/key [151] 15.5% ??? [142] 20.7% copying-mergesort [157] 63.8% [164] 13930(13.6%) 0(0.0%) loop ...ket/collects/racket/private/sort.rkt:97:12 ??? [168] 100.0% ------------------------------------------------------------------------- custom-set-union [159] 100.0% [165] 1064(1.0%) 200(0.2%) for-loop ...cts/racket/private/set-types.rkt:174:3 for-loop [169] 81.2% ------------------------------------------------------------------------- setfindf [162] 100.0% [166] 242(0.2%) 242(0.2%) for-loop ...e/ztatlock/herbie/src/common.rkt:144:2 ------------------------------------------------------------------------- custom-set-union [159] 100.0% [167] 222(0.2%) 222(0.2%) for-loop ...cts/racket/private/set-types.rkt:152:2 ------------------------------------------------------------------------- jloop [5] 41.5% loop [164] 58.5% [168] 23798(23.2%) 202(0.2%) ??? /home/ztatlock/herbie/src/points.rkt:49:27 eval-prog [170] 98.3% ??? [171] 0.8% ------------------------------------------------------------------------- for-loop [165] 100.0% [169] 864(0.8%) 864(0.8%) for-loop ...cts/racket/private/set-types.rkt:178:5 ------------------------------------------------------------------------- errors [98] 2.1% ??? [113] 3.1% for-loop [143] 5.1% make-exacts* [94] 10.0% loop [78] 17.4% ??? [168] 62.3% [170] 37540(36.6%) 7274(7.1%) eval-prog ...tatlock/herbie/src/programs.rkt:259:0 hash-ref! [172] 78.2% inductor [175] 1.2% go [176] 0.6% ------------------------------------------------------------------------- for-loop [149] 0.9% ??? [168] 1.0% map [123] 1.0% for-loop [111] 4.8% loop [141] 92.3% [171] 21230(20.7%) 1204(1.2%) ??? /home/ztatlock/herbie/src/programs.rkt:265:4 ??? [173] 76.0% ??? [178] 16.3% ->flonum [174] 2.0% ------------------------------------------------------------------------- for-loop [147] 0.0% for-loop [24] 0.1% for-loop [28] 0.1% ??? [8] 0.1% simplify* [145] 0.1% ??? [12] 0.2% compile [85] 0.4% first-nonzero-exp [125] 0.5% for-loop [34] 0.6% for-loop [22] 1.0% ??? [4] 1.3% for-loop [20] 1.5% loop [110] 1.9% for-loop [21] 2.9% ??? [33] 3.6% eval-prog [170] 34.5% loop [141] 49.6% [172] 34916(34.1%) 1024(1.0%) hash-ref! ...racket/private/more-scheme.rkt:373:13 ??? [4] 51.0% bigfloat-hash [177] 34.5% ??? [6] 3.9% ??? [7] 3.0% simplify [32] 1.7% ??? [8] 1.5% ??? [9] 1.0% ??? [10] 0.6% f94 [109] 0.4% ??? [12] 0.3% ??? [14] 0.0% ------------------------------------------------------------------------- ??? [171] 100.0% [173] 16134(15.7%) 1912(1.9%) ??? ...acket/collects/racket/private/kw.rkt:444:14 ??? [184] 61.2% bf* [179] 20.5% ??? [180] 3.7% ...higher-order.rkt:346:33 [181] 2.7% ------------------------------------------------------------------------- loop [141] 29.3% ??? [171] 29.9% for-loop [111] 40.8% [174] 1412(1.4%) 0(0.0%) ->flonum ...ock/herbie/src/syntax/syntax.rkt:230:0 ??? [180] 100.0% ------------------------------------------------------------------------- eval-const-expr [163] 15.2% eval-prog [170] 20.1% inductor [175] 64.7% [175] 656(0.6%) 214(0.2%) inductor .../ztatlock/herbie/src/programs.rkt:71:2 inductor [175] 64.7% ??? [178] 24.5% ------------------------------------------------------------------------- eval-prog [170] 100.0% [176] 242(0.2%) 0(0.0%) go .../collects/racket/private/qq-and-or.rkt:50:20 loop [182] 100.0% ------------------------------------------------------------------------- hash-ref! [172] 100.0% [177] 29346(28.6%) 0(0.0%) bigfloat-hash ...h/private/bigfloat/mpfr.rkt:165:0 bfcanonicalize [183] 92.6% sig+exp->bigfloat [186] 7.4% ------------------------------------------------------------------------- inductor [175] 11.3% ??? [171] 88.7% [178] 3912(3.8%) 0(0.0%) ??? ...contract/private/../../private/kw.rkt:761:9 real->bigfloat [185] 88.7% integer->bigfloat [189] 11.3% ------------------------------------------------------------------------- ??? [173] 100.0% [179] 3310(3.2%) 0(0.0%) bf* ...ath/private/bigfloat/bigfloat-mpfr.rkt:95:0 ??? [184] 100.0% ------------------------------------------------------------------------- *rules* [93] 8.3% ulp-difference [129] 8.4% ??? [173] 24.8% ->flonum [174] 58.5% [180] 2412(2.4%) 1428(1.4%) ??? /home/ztatlock/herbie/src/config.rkt:48:0 ??? [188] 22.6% return/no-unsupplied [187] 18.2% ------------------------------------------------------------------------- ??? [173] 100.0% [181] 434(0.4%) 232(0.2%) ...higher-order.rkt:346:33 (unknown source) ??? [190] 46.5% ------------------------------------------------------------------------- loop [182] 50.0% go [176] 50.0% [182] 242(0.2%) 242(0.2%) loop ...llects/racket/private/qq-and-or.rkt:101:61 loop [182] 50.0% ------------------------------------------------------------------------- bigfloat-hash [177] 100.0% [183] 27166(26.5%) 27166(26.5%) bfcanonicalize .../private/bigfloat/mpfr.rkt:155:0 ------------------------------------------------------------------------- eval-const-expr [163] 1.6% bf* [179] 24.7% ??? [173] 73.7% [184] 13410(13.1%) 2506(2.4%) ??? ...-racket/utils/simple-result-arrow.rkt:39:12 bfmul [191] 69.3% bfsqr [192] 12.0% ------------------------------------------------------------------------- ??? [178] 100.0% [185] 3470(3.4%) 2330(2.3%) real->bigfloat .../private/bigfloat/mpfr.rkt:451:0 ??? [195] 32.9% ------------------------------------------------------------------------- bigfloat-hash [177] 100.0% [186] 2180(2.1%) 2180(2.1%) sig+exp->bigfloat ...ivate/bigfloat/mpfr.rkt:385:0 ------------------------------------------------------------------------- simplify* [145] 31.3% ??? [180] 68.7% [187] 638(0.6%) 422(0.4%) return/no-unsupplied ...ct/private/arr-i.rkt:533:0 filter [193] 33.9% ------------------------------------------------------------------------- ??? [180] 100.0% [188] 546(0.5%) 194(0.2%) ??? ...racket/collects/racket/private/kw.rkt:761:9 ??? [194] 64.5% ------------------------------------------------------------------------- ??? [178] 100.0% [189] 442(0.4%) 242(0.2%) integer->bigfloat ...ivate/bigfloat/mpfr.rkt:399:0 ??? [195] 45.2% ------------------------------------------------------------------------- ...higher-order.rkt:346:33 [181]100.0% [190] 202(0.2%) 202(0.2%) ??? ...ects/racket/contract/private/guts.rkt:644:8 ------------------------------------------------------------------------- ??? [184] 100.0% [191] 9298(9.1%) 5864(5.7%) bfmul ...-lib/math/private/bigfloat/mpfr.rkt:819:4 ??? [195] 36.9% ------------------------------------------------------------------------- ??? [184] 100.0% [192] 1606(1.6%) 1110(1.1%) bfsqr ...-lib/math/private/bigfloat/mpfr.rkt:616:4 ??? [195] 30.9% ------------------------------------------------------------------------- for-loop [79] 48.8% return/no-unsupplied [187] 51.2% [193] 422(0.4%) 422(0.4%) filter ...t/collects/racket/private/list.rkt:256:2 ------------------------------------------------------------------------- ??? [188] 100.0% [194] 352(0.3%) 352(0.3%) ??? ...s/racket/contract/private/arr-i.rkt:1233:27 ------------------------------------------------------------------------- integer->bigfloat [189] 3.8% bfsqr [192] 9.4% real->bigfloat [185] 21.6% bfmul [191] 65.2% [195] 5270(5.1%) 5270(5.1%) ??? .../share/racket/collects/ffi/unsafe.rkt:861:4 -------------------------------------------------------------------------