Profiling results ----------------- Total cpu time observed: 271238ms (out of 274020ms) Number of samples taken: 2302 (once every 118ms) (Hiding functions with self<1.0% and local<2.0%: 25 of 295 hidden) ========================================================================================= Caller Idx Total Self Name+src Local% ms(pct) ms(pct) Callee ========================================================================================= ??? [60] 100.0% [1] 258528(95.3%) 0(0.0%) profile-thunk16 ...t/pkgs/profile-lib/main.rkt:9:0 run [17] 100.0% ----------------------------------------------------------------------------------------- ??? [60] 100.0% [2] 233560(86.1%) 112(0.0%) run-improve50 ...ock/herbie/src/mainloop.rkt:234:0 for-loop [18] 82.5% get-final-combination [23] 16.5% loop [68] 0.8% ??? [104] 0.0% setup-alt-simplified [32] 0.0% ----------------------------------------------------------------------------------------- simplify-alt [43] 0.1% loop [196] 3.4% ??? [60] 96.5% [3] 121878(44.9%) 122(0.0%) simplify ...lock/herbie/src/core/simplify.rkt:39:0 simplify-expr [19] 49.7% for-loop [24] 30.0% iterate-egraph!5 [34] 17.0% loop [39] 3.2% ----------------------------------------------------------------------------------------- hash-ref! [205] 100.0% [4] 51844(19.1%) 122(0.0%) ??? ...e/ztatlock/herbie/src/core/taylor.rkt:43:15 ??? [36] 95.4% hash-ref! [205] 3.9% simplify [35] 0.5% ----------------------------------------------------------------------------------------- hash-ref! [205] 99.5% [5] 50604(18.7%) 108(0.0%) ??? .../ztatlock/herbie/src/core/taylor.rkt:281:26 for-loop [20] 100.0% ----------------------------------------------------------------------------------------- hash-ref! [205] 100.0% [6] 45216(16.7%) 0(0.0%) ??? .../ztatlock/herbie/src/core/taylor.rkt:291:23 for-loop [21] 100.0% ----------------------------------------------------------------------------------------- hash-ref! [205] 100.0% [7] 40602(15.0%) 0(0.0%) ??? .../ztatlock/herbie/src/core/taylor.rkt:318:33 for-loop [22] 100.0% ----------------------------------------------------------------------------------------- hash-ref! [205] 100.0% [8] 29136(10.7%) 222(0.1%) ??? /home/ztatlock/herbie/src/programs.rkt:181:5 loop [196] 89.9% hash-ref! [205] 9.8% ----------------------------------------------------------------------------------------- hash-ref! [205] 100.0% [9] 24238(8.9%) 0(0.0%) ??? .../ztatlock/herbie/src/core/taylor.rkt:388:23 for-loop [25] 99.5% partition-list [31] 0.5% ----------------------------------------------------------------------------------------- generic-sort/key [190] 5.3% copying-mergesort [199] 94.7% [10] 2370(0.9%) 0(0.0%) jloop ...t/collects/racket/private/sort.rkt:121:23 ??? [218] 94.7% errors-score [30] 5.3% ----------------------------------------------------------------------------------------- parse-loop12 [189] 6.3% loop [196] 11.3% map [164] 82.4% [11] 1860(0.7%) 202(0.1%) ??? /home/ztatlock/herbie/src/core/reduce.rkt:50:5 for-loop [26] 89.1% ----------------------------------------------------------------------------------------- f6 [159] 100.0% [12] 1150(0.4%) 0(0.0%) taylor-invert .../herbie/src/core/taylor.rkt:308:0 first-nonzero-exp [192] 50.1% simplify [35] 49.9% ----------------------------------------------------------------------------------------- hash-ref! [205] 100.0% [13] 1068(0.4%) 210(0.1%) ??? .../ztatlock/herbie/src/core/taylor.rkt:479:23 for-loop [28] 70.2% hash-ref! [205] 10.1% ----------------------------------------------------------------------------------------- f6 [159] 100.0% [14] 848(0.3%) 0(0.0%) combine-mterms ...herbie/src/core/reduce.rkt:180:0 for-loop [27] 100.0% ----------------------------------------------------------------------------------------- hash-ref! [205] 100.0% [15] 802(0.3%) 0(0.0%) ??? .../ztatlock/herbie/src/core/taylor.rkt:334:33 for-loop [29] 61.3% hash-ref! [205] 38.7% ----------------------------------------------------------------------------------------- rewriter [74] 100.0% [16] 704(0.3%) 0(0.0%) *rules* ...tlock/herbie/src/syntax/rules.rkt:411:0 for-loop [102] 85.5% ??? [255] 14.5% ----------------------------------------------------------------------------------------- profile-thunk16 [1] 99.9% [17] 258660(95.4%) 0(0.0%) run ...share/racket/pkgs/profile-lib/main.rkt:39:2 ??? [60] 100.0% ----------------------------------------------------------------------------------------- run-improve50 [2] 100.0% [18] 192768(71.1%) 0(0.0%) for-loop ...tatlock/herbie/src/mainloop.rkt:249:10 run-iter! [33] 100.0% ----------------------------------------------------------------------------------------- simplify [3] 100.0% [19] 60522(22.3%) 0(0.0%) simplify-expr ...herbie/src/core/simplify.rkt:68:0 iterate-egraph!5 [34] 81.2% loop [39] 18.8% ----------------------------------------------------------------------------------------- ??? [5] 100.0% [20] 50604(18.7%) 140(0.1%) for-loop ...lock/herbie/src/core/taylor.rkt:281:52 ??? [36] 66.3% hash-ref! [205] 31.3% simplify [35] 2.3% ----------------------------------------------------------------------------------------- ??? [6] 100.0% [21] 45216(16.7%) 0(0.0%) for-loop ...lock/herbie/src/core/taylor.rkt:294:27 hash-ref! [205] 99.5% simplify [35] 0.5% ----------------------------------------------------------------------------------------- ??? [7] 100.0% [22] 40602(15.0%) 210(0.1%) for-loop ...lock/herbie/src/core/taylor.rkt:320:46 hash-ref! [205] 98.5% simplify [35] 1.0% ----------------------------------------------------------------------------------------- run-improve50 [2] 100.0% [23] 38556(14.2%) 0(0.0%) get-final-combination ...ie/src/mainloop.rkt:264:0 split-table [37] 89.0% extract-alt [40] 11.0% ----------------------------------------------------------------------------------------- simplify [3] 100.0% [24] 36540(13.5%) 420(0.2%) for-loop ...ock/herbie/src/core/simplify.rkt:61:12 iterate-egraph!5 [34] 87.2% loop [39] 11.3% loop [196] 0.3% ----------------------------------------------------------------------------------------- ??? [9] 100.0% [25] 24120(8.9%) 0(0.0%) for-loop ...lock/herbie/src/core/taylor.rkt:392:33 for-loop [38] 100.0% ----------------------------------------------------------------------------------------- ??? [11] 100.0% [26] 1658(0.6%) 252(0.1%) for-loop ...atlock/herbie/src/core/reduce.rkt:51:7 pattern-match [41] 84.8% ----------------------------------------------------------------------------------------- combine-mterms [14] 100.0% [27] 848(0.3%) 478(0.2%) for-loop ...tlock/herbie/src/core/reduce.rkt:184:5 hash-ref! [205] 43.6% ----------------------------------------------------------------------------------------- ??? [13] 100.0% [28] 750(0.3%) 0(0.0%) for-loop ...lock/herbie/src/core/taylor.rkt:483:35 parse-loop12 [189] 100.0% ----------------------------------------------------------------------------------------- ??? [15] 100.0% [29] 598(0.2%) 0(0.0%) for-loop ...lock/herbie/src/core/taylor.rkt:337:46 hash-ref! [205] 100.0% ----------------------------------------------------------------------------------------- jloop [10] 100.0% [30] 126(0.0%) 0(0.0%) errors-score ...atlock/herbie/src/points.rkt:194:0 loop [242] 100.0% ----------------------------------------------------------------------------------------- ??? [9] 100.0% [31] 118(0.0%) 0(0.0%) partition-list ...herbie/src/core/taylor.rkt:372:0 rle [42] 100.0% ----------------------------------------------------------------------------------------- run-improve50 [2] 100.0% [32] 110(0.0%) 0(0.0%) setup-alt-simplified ...k/herbie/src/glue.rkt:54:0 simplify-alt [43] 100.0% ----------------------------------------------------------------------------------------- for-loop [18] 100.0% [33] 192768(71.1%) 0(0.0%) run-iter! ...tatlock/herbie/src/mainloop.rkt:215:0 simplify! [44] 60.8% gen-series! [46] 29.2% finalize-iter! [48] 8.7% gen-rewrites! [50] 0.6% localize-error [52] 0.4% ----------------------------------------------------------------------------------------- simplify [3] 20.4% for-loop [24] 31.3% simplify-expr [19] 48.3% [34] 101786(37.5%) 578(0.2%) iterate-egraph!5 ...bie/src/core/simplify.rkt:95:0 one-iter [45] 95.4% map-enodes [49] 4.1% ----------------------------------------------------------------------------------------- taylor-sqrt [183] 0.2% ??? [76] 0.2% parse-loop12 [189] 0.2% first-nonzero-exp [192] 0.2% loop [196] 0.4% ??? [4] 0.4% for-loop [21] 0.7% for-loop [22] 0.7% taylor-invert [12] 1.1% for-loop [20] 4.8% hash-ref! [205] 89.8% [35] 53832(19.8%) 380(0.1%) simplify ...atlock/herbie/src/core/reduce.rkt:15:0 f6 [159] 56.6% parse-loop12 [189] 37.3% debug-print [173] 2.1% debug7 [176] 1.4% simplify-node [172] 1.0% simplify* [198] 0.9% ----------------------------------------------------------------------------------------- ??? [4] 35.3% for-loop [20] 64.7% [36] 50330(18.6%) 0(0.0%) ??? .../ztatlock/herbie/src/core/taylor.rkt:284:19 hash-ref! [205] 100.0% ----------------------------------------------------------------------------------------- get-final-combination [23] 100.0% [37] 34302(12.6%) 0(0.0%) split-table .../ztatlock/herbie/src/glue.rkt:168:0 f6 [159] 94.3% ??? [104] 5.7% ----------------------------------------------------------------------------------------- for-loop [25] 100.0% [38] 24120(8.9%) 118(0.0%) for-loop ...lock/herbie/src/core/taylor.rkt:394:39 hash-ref! [205] 99.5% ----------------------------------------------------------------------------------------- simplify [3] 20.3% for-loop [24] 21.3% simplify-expr [19] 58.4% [39] 19444(7.2%) 0(0.0%) loop ...tatlock/herbie/src/core/simplify.rkt:203:2 pass [47] 100.0% ----------------------------------------------------------------------------------------- get-final-combination [23] 100.0% [40] 4254(1.6%) 0(0.0%) extract-alt ...e/ztatlock/herbie/src/glue.rkt:60:0 loop [196] 97.1% argmins [113] 2.9% ----------------------------------------------------------------------------------------- for-loop [51] 20.7% for-loop [26] 79.3% [41] 1406(0.5%) 246(0.1%) pattern-match .../herbie/src/core/matcher.rkt:47:0 for-loop [51] 61.8% ??? [104] 17.2% variable? [90] 3.5% ----------------------------------------------------------------------------------------- partition-list [31] 100.0% [42] 118(0.0%) 0(0.0%) rle ...e/ztatlock/herbie/src/core/taylor.rkt:368:0 group-by68 [231] 100.0% ----------------------------------------------------------------------------------------- setup-alt-simplified [32] 100.0% [43] 110(0.0%) 0(0.0%) simplify-alt .../ztatlock/herbie/src/glue.rkt:87:0 simplify [3] 100.0% ----------------------------------------------------------------------------------------- run-iter! [33] 100.0% [44] 117118(43.2%) 0(0.0%) simplify! ...tatlock/herbie/src/mainloop.rkt:155:0 for-loop [53] 100.0% ----------------------------------------------------------------------------------------- iterate-egraph!5 [34] 100.0% [45] 97078(35.8%) 1912(0.7%) one-iter ...ock/herbie/src/core/simplify.rkt:106:0 for-loop [54] 65.7% loop [56] 28.8% apply-match [62] 3.0% loop [149] 0.5% ----------------------------------------------------------------------------------------- run-iter! [33] 100.0% [46] 56268(20.7%) 0(0.0%) gen-series! ...tlock/herbie/src/mainloop.rkt:129:0 for-loop [55] 100.0% ----------------------------------------------------------------------------------------- loop [39] 100.0% [47] 19444(7.2%) 0(0.0%) pass ...tatlock/herbie/src/core/simplify.rkt:193:2 for-loop [57] 100.0% ----------------------------------------------------------------------------------------- run-iter! [33] 100.0% [48] 16794(6.2%) 0(0.0%) finalize-iter! ...ck/herbie/src/mainloop.rkt:169:0 ??? [104] 100.0% ----------------------------------------------------------------------------------------- iterate-egraph!5 [34] 100.0% [49] 4130(1.5%) 0(0.0%) map-enodes ...ock/herbie/src/core/egraph.rkt:139:0 loop [196] 87.1% for-loop [58] 9.1% set-precompute! [211] 3.8% ----------------------------------------------------------------------------------------- run-iter! [33] 100.0% [50] 1178(0.4%) 0(0.0%) gen-rewrites! ...ock/herbie/src/mainloop.rkt:142:0 for-loop [59] 100.0% ----------------------------------------------------------------------------------------- pattern-match [41] 100.0% [51] 1160(0.4%) 578(0.2%) for-loop ...tlock/herbie/src/core/matcher.rkt:65:9 pattern-match [41] 50.2% ----------------------------------------------------------------------------------------- run-iter! [33] 100.0% [52] 686(0.3%) 0(0.0%) localize-error ...erbie/src/core/localize.rkt:47:0 hash-ref! [205] 81.6% ??? [180] 18.4% ----------------------------------------------------------------------------------------- simplify! [44] 99.6% [53] 117536(43.3%) 0(0.0%) for-loop ...ztatlock/herbie/src/mainloop.rkt:159:6 ??? [60] 100.0% ----------------------------------------------------------------------------------------- for-loop [54] 48.5% one-iter [45] 51.5% [54] 63806(23.5%) 16448(6.1%) for-loop ...ck/herbie/src/core/simplify.rkt:116:12 for-loop [54] 48.5% match-e [69] 36.8% ??? [106] 0.3% ----------------------------------------------------------------------------------------- gen-series! [46] 100.0% [55] 56268(20.7%) 0(0.0%) for-loop ...ztatlock/herbie/src/mainloop.rkt:135:7 taylor-alt [61] 100.0% ----------------------------------------------------------------------------------------- one-iter [45] 100.0% [56] 27984(10.3%) 156(0.1%) loop ...cket/collects/racket/private/map.rkt:52:19 apply-match [62] 99.4% ----------------------------------------------------------------------------------------- pass [47] 100.0% [57] 19444(7.2%) 624(0.2%) for-loop ...ck/herbie/src/core/simplify.rkt:196:29 argmin [63] 70.9% loop [64] 23.7% make-sequence [223] 1.1% ----------------------------------------------------------------------------------------- map-enodes [49] 11.2% loop [196] 88.8% [58] 3346(1.2%) 236(0.1%) for-loop ...ock/herbie/src/core/simplify.rkt:161:2 eval-const-expr [65] 40.5% setfindf [67] 26.1% compose [237] 20.4% ->flonum [236] 6.0% ----------------------------------------------------------------------------------------- gen-rewrites! [50] 100.0% [59] 1178(0.4%) 0(0.0%) for-loop ...tatlock/herbie/src/mainloop.rkt:147:11 ??? [66] 100.0% ----------------------------------------------------------------------------------------- for-loop [53] 15.2% run [17] 41.3% [60] 269212(99.3%) 0(0.0%) ??? ...lects/racket/private/more-scheme.rkt:261:28 profile-thunk16 [1] 41.3% run-improve50 [2] 36.9% simplify [3] 15.2% loop [68] 6.6% ----------------------------------------------------------------------------------------- for-loop [55] 100.0% [61] 56268(20.7%) 0(0.0%) taylor-alt ...e/ztatlock/herbie/src/glue.rkt:145:0 for-loop [70] 100.0% ----------------------------------------------------------------------------------------- one-iter [45] 9.5% loop [56] 90.5% [62] 30766(11.3%) 2040(0.8%) apply-match .../herbie/src/core/simplify.rkt:122:2 match-e [69] 31.0% merge-egraph-nodes! [79] 27.5% for-loop [72] 14.8% loop! [207] 6.3% substitute-e [82] 5.7% mk-enode! [93] 4.1% update-leader! [91] 3.6% reduce-to-single! [75] 0.3% ----------------------------------------------------------------------------------------- for-loop [57] 100.0% [63] 13784(5.1%) 0(0.0%) argmin ...re/racket/collects/racket/list.rkt:743:0 for-loop [71] 88.9% expression-cost [73] 11.1% ----------------------------------------------------------------------------------------- for-loop [57] 100.0% [64] 4608(1.7%) 0(0.0%) loop ...hare/racket/collects/racket/list.rkt:729:4 for-loop [71] 54.6% expression-cost [73] 45.4% ----------------------------------------------------------------------------------------- for-loop [58] 100.0% [65] 1354(0.5%) 480(0.2%) eval-const-expr ...k/herbie/src/programs.rkt:164:0 f6 [159] 37.2% ??? [160] 19.6% ??? [254] 7.7% ----------------------------------------------------------------------------------------- for-loop [59] 100.0% [66] 1178(0.4%) 0(0.0%) ??? /home/ztatlock/herbie/src/alternative.rkt:88:0 rewriter [74] 100.0% ----------------------------------------------------------------------------------------- for-loop [58] 100.0% [67] 874(0.3%) 770(0.3%) setfindf ...e/ztatlock/herbie/src/common.rkt:168:0 ??? [104] 11.9% ----------------------------------------------------------------------------------------- run-improve50 [2] 3.0% pred [228] 39.4% ??? [60] 57.6% [68] 60968(22.5%) 0(0.0%) loop /home/ztatlock/herbie/src/points.rkt:159:2 loop [77] 65.9% loop [88] 18.5% make-exacts* [89] 15.3% ----------------------------------------------------------------------------------------- apply-match [62] 10.3% for-loop [87] 22.3% for-loop [54] 67.4% [69] 56512(20.8%) 22136(8.2%) match-e ...tatlock/herbie/src/core/ematch.rkt:46:0 for-loop [78] 37.5% ??? [104] 9.3% for-loop [87] 9.3% variable? [90] 4.3% list-cartesian-product [92] 2.1% custom-in-set [126] 1.5% curry* [97] 0.8% loop [196] 0.7% filter [267] 0.2% ----------------------------------------------------------------------------------------- taylor-alt [61] 100.0% [70] 56268(20.7%) 0(0.0%) for-loop /home/ztatlock/herbie/src/glue.rkt:147:2 ??? [76] 100.0% ----------------------------------------------------------------------------------------- loop [64] 17.0% argmin [63] 83.0% [71] 14768(5.4%) 268(0.1%) for-loop ...ztatlock/herbie/src/programs.rkt:197:2 location-do [85] 69.0% ...erbie/src/common.rkt:46:2 [80] 24.1% ??? [98] 5.0% ----------------------------------------------------------------------------------------- apply-match [62] 100.0% [72] 4542(1.7%) 148(0.1%) for-loop ...ck/herbie/src/core/simplify.rkt:136:10 loop! [207] 45.6% merge-egraph-nodes! [79] 26.6% substitute-e [82] 19.2% mk-enode! [93] 5.4% ----------------------------------------------------------------------------------------- argmin [63] 42.2% loop [64] 57.8% [73] 3624(1.3%) 212(0.1%) expression-cost ...k/herbie/src/programs.rkt:196:0 compile [81] 94.2% ----------------------------------------------------------------------------------------- ??? [66] 28.1% matcher [96] 71.9% [74] 1178(0.4%) 248(0.1%) rewriter ...lock/herbie/src/core/matcher.rkt:127:2 for-loop [83] 77.8% *rules* [16] 17.4% ----------------------------------------------------------------------------------------- apply-match [62] 100.0% [75] 104(0.0%) 0(0.0%) reduce-to-single! ...bie/src/core/egraph.rkt:324:0 filter-loop! [84] 100.0% ----------------------------------------------------------------------------------------- eval-prog [156] 0.3% f6 [159] 4.5% location-do [85] 47.1% for-loop [70] 47.1% [76] 59752(22.0%) 0(0.0%) ??? ...tract/private/arrow-higher-order.rkt:342:33 location-do [85] 48.3% approximate9 [86] 47.0% ??? [265] 2.0% best-alt [100] 1.1% ...erbie/src/common.rkt:46:2 [80] 0.7% ??? [98] 0.4% ??? [235] 0.2% simplify [35] 0.1% ----------------------------------------------------------------------------------------- loop [68] 100.0% [77] 40200(14.8%) 0(0.0%) loop /home/ztatlock/herbie/src/points.rkt:119:2 eval-prog [156] 67.4% loop [88] 17.3% make-exacts* [89] 15.3% ----------------------------------------------------------------------------------------- match-e [69] 100.0% [78] 27708(10.2%) 8852(3.3%) for-loop ...tlock/herbie/src/core/ematch.rkt:59:11 for-loop [87] 58.9% list-cartesian-product [92] 8.2% loop [196] 3.5% curry* [97] 1.7% filter [267] 0.4% ----------------------------------------------------------------------------------------- merge-egraph-nodes! [79] 3.4% for-loop [72] 12.5% apply-match [62] 83.4% [79] 9686(3.6%) 478(0.2%) merge-egraph-nodes! ...e/src/core/egraph.rkt:152:0 update-leader! [91] 58.8% loop! [207] 14.5% enode-merge! [99] 9.2% for-loop [101] 7.4% merge-egraph-nodes! [79] 3.4% for-loop [102] 1.0% ----------------------------------------------------------------------------------------- f6 [159] 2.5% ??? [76] 10.3% for-loop [71] 87.2% [80] 4088(1.5%) 772(0.3%) ...erbie/src/common.rkt:46:2 ...e/arr-i.rkt:906:19 ??? [94] 52.1% ??? [95] 29.1% ----------------------------------------------------------------------------------------- expression-cost [73] 100.0% [81] 3412(1.3%) 110(0.0%) compile .../ztatlock/herbie/src/programs.rkt:173:0 hash-ref! [205] 96.8% ----------------------------------------------------------------------------------------- for-loop [72] 22.8% substitute-e [82] 25.1% apply-match [62] 52.1% [82] 2618(1.0%) 406(0.1%) substitute-e ...ck/herbie/src/core/ematch.rkt:71:0 mk-enode! [93] 42.6% substitute-e [82] 25.1% ??? [104] 10.5% variable? [90] 6.3% ----------------------------------------------------------------------------------------- rewriter [74] 100.0% [83] 1178(0.4%) 226(0.1%) for-loop ...ock/herbie/src/core/matcher.rkt:130:10 matcher [96] 94.1% ----------------------------------------------------------------------------------------- reduce-to-single! [75] 100.0% [84] 104(0.0%) 104(0.0%) filter-loop! ...ck/herbie/src/core/enode.rkt:114:2 ----------------------------------------------------------------------------------------- f6 [159] 0.1% for-loop [71] 15.2% location-do [85] 33.3% ??? [76] 51.4% [85] 67298(24.8%) 3270(1.2%) location-do ...acket/private/norm-define.rkt:53:83 ??? [76] 50.3% location-do [85] 33.3% ??? [133] 10.3% ??? [260] 0.4% ??? [256] 0.2% dict? [268] 0.1% ----------------------------------------------------------------------------------------- ??? [76] 100.0% [86] 56176(20.7%) 0(0.0%) approximate9 ...ck/herbie/src/core/taylor.rkt:12:0 loop [103] 97.1% f6 [159] 2.0% taylor-sqrt [183] 0.5% taylor-quotient [118] 0.2% taylor [166] 0.2% ----------------------------------------------------------------------------------------- match-e [69] 34.5% for-loop [78] 65.5% [87] 26046(9.6%) 1722(0.6%) for-loop ...tlock/herbie/src/core/ematch.rkt:65:37 match-e [69] 89.1% ??? [106] 4.4% ----------------------------------------------------------------------------------------- loop [77] 38.2% loop [68] 61.8% [88] 18266(6.7%) 0(0.0%) loop /home/ztatlock/herbie/src/points.rkt:109:4 map [164] 68.1% loop [196] 31.9% ----------------------------------------------------------------------------------------- loop [77] 39.7% loop [68] 60.3% [89] 15488(5.7%) 0(0.0%) make-exacts* ...atlock/herbie/src/points.rkt:106:0 loop [196] 47.6% map [164] 35.7% eval-prog [156] 16.6% ----------------------------------------------------------------------------------------- simplify* [198] 1.3% pattern-match [41] 1.3% f6 [159] 1.7% substitute-e [82] 5.9% free-variables [191] 7.8% match-e [69] 80.4% [90] 7404(2.7%) 0(0.0%) variable? ...ck/herbie/src/syntax/syntax.rkt:529:0 ??? [104] 100.0% ----------------------------------------------------------------------------------------- apply-match [62] 15.4% merge-egraph-nodes! [79] 84.6% [91] 7148(2.6%) 662(0.2%) update-leader! ...herbie/src/core/egraph.rkt:217:0 for-loop [105] 83.7% make-sequence [223] 3.9% custom-set-union! [115] 3.1% ----------------------------------------------------------------------------------------- match-e [69] 25.2% list-cartesian-product [92] 28.6% for-loop [78] 46.2% [92] 3894(1.4%) 3362(1.2%) list-cartesian-product ...src/core/ematch.rkt:20:0 list-cartesian-product [92] 28.6% for-loop [109] 12.0% ----------------------------------------------------------------------------------------- for-loop [72] 9.3% substitute-e [82] 42.7% apply-match [62] 48.0% [93] 2616(1.0%) 1572(0.6%) mk-enode! ...lock/herbie/src/core/egraph.rkt:101:0 hash-has-key? [121] 24.2% new-enode [112] 12.2% mutable-set [119] 3.4% ----------------------------------------------------------------------------------------- for-loop [262] 4.8% ??? [256] 13.3% ...erbie/src/common.rkt:46:2 [80] 81.9% [94] 2128(0.8%) 454(0.2%) ??? ...ects/racket/contract/private/list.rkt:342:4 ??? [256] 64.9% ??? [114] 11.4% ??? [265] 10.2% ----------------------------------------------------------------------------------------- ...erbie/src/common.rkt:46:2 [80] 100.0% [95] 1188(0.4%) 514(0.2%) ??? ...s/racket/contract/private/arr-i.rkt:1268:39 ??? [260] 56.7% ----------------------------------------------------------------------------------------- for-loop [107] 22.8% matcher [96] 28.3% for-loop [83] 48.9% [96] 1178(0.4%) 0(0.0%) matcher ...tlock/herbie/src/core/matcher.rkt:163:2 rewriter [74] 48.9% matcher [96] 28.3% for-loop [107] 22.8% ----------------------------------------------------------------------------------------- match-e [69] 46.2% for-loop [78] 53.8% [97] 1092(0.4%) 702(0.3%) curry* ...racket/collects/racket/function.rkt:44:2 procedure-arity [111] 35.7% ----------------------------------------------------------------------------------------- ??? [76] 23.9% for-loop [71] 76.1% [98] 972(0.4%) 832(0.3%) ??? ...ts/racket/contract/private/arr-i.rkt:804:10 ??? [117] 14.4% ----------------------------------------------------------------------------------------- merge-egraph-nodes! [79] 100.0% [99] 894(0.3%) 134(0.0%) enode-merge! ...ck/herbie/src/core/enode.rkt:100:0 adopt-enode! [108] 61.3% custom-set-intersect! [116] 23.7% ----------------------------------------------------------------------------------------- ??? [76] 100.0% [100] 724(0.3%) 0(0.0%) best-alt /home/ztatlock/herbie/src/glue.rkt:82:0 loop [110] 72.9% argmins [113] 27.1% ----------------------------------------------------------------------------------------- merge-egraph-nodes! [79] 100.0% [101] 714(0.3%) 384(0.1%) for-loop ...tlock/herbie/src/core/egraph.rkt:232:6 update-en-expr [222] 46.2% ----------------------------------------------------------------------------------------- merge-egraph-nodes! [79] 14.0% *rules* [16] 86.0% [102] 700(0.3%) 478(0.2%) for-loop /home/ztatlock/herbie/src/common.rkt:93:9 ??? [255] 31.7% ----------------------------------------------------------------------------------------- approximate9 [86] 100.0% [103] 54552(20.1%) 0(0.0%) loop ...e/ztatlock/herbie/src/core/taylor.rkt:83:4 hash-ref! [205] 100.0% ----------------------------------------------------------------------------------------- setfindf [67] 0.3% run-improve50 [2] 0.3% debug7 [176] 0.6% free-variables [191] 0.9% for-loop [125] 0.9% pattern-match [41] 1.3% substitute-e [82] 1.7% ??? [265] 2.6% split-table [37] 5.0% variable? [90] 19.2% match-e [69] 22.1% finalize-iter! [48] 42.8% [104] 38256(14.1%) 11008(4.1%) ??? ...contract/private/arrow-val-first.rkt:357:18 for-loop [120] 42.1% hash-has-key? [121] 20.9% split-atab [124] 5.0% atab-add-altns [127] 1.1% ??? [265] 0.6% ----------------------------------------------------------------------------------------- update-leader! [91] 100.0% [105] 5984(2.2%) 588(0.2%) for-loop ...tlock/herbie/src/core/egraph.rkt:222:6 for-loop [122] 90.2% ----------------------------------------------------------------------------------------- for-loop [54] 23.8% for-loop [87] 76.2% [106] 1648(0.6%) 318(0.1%) ??? /home/ztatlock/herbie/src/core/ematch.rkt:50:5 for-loop [125] 74.6% custom-in-set [126] 6.1% ----------------------------------------------------------------------------------------- matcher [96] 100.0% [107] 952(0.4%) 0(0.0%) for-loop ...ock/herbie/src/core/matcher.rkt:179:21 matcher [96] 100.0% ----------------------------------------------------------------------------------------- enode-merge! [99] 100.0% [108] 548(0.2%) 0(0.0%) adopt-enode! ...ock/herbie/src/core/enode.rkt:76:0 custom-set-union [220] 100.0% ----------------------------------------------------------------------------------------- list-cartesian-product [92] 100.0% [109] 532(0.2%) 532(0.2%) for-loop ...atlock/herbie/src/core/ematch.rkt:24:8 ----------------------------------------------------------------------------------------- best-alt [100] 100.0% [110] 528(0.2%) 0(0.0%) loop /home/ztatlock/herbie/src/common.rkt:135:2 composed [123] 100.0% ----------------------------------------------------------------------------------------- curry* [97] 100.0% [111] 390(0.1%) 390(0.1%) procedure-arity ...ket/private/norm-arity.rkt:7:27 ----------------------------------------------------------------------------------------- mk-enode! [93] 100.0% [112] 320(0.1%) 0(0.0%) new-enode ...atlock/herbie/src/core/enode.rkt:68:0 set [221] 61.2% check-valid-enode5 [130] 38.8% ----------------------------------------------------------------------------------------- extract-alt [40] 38.8% best-alt [100] 61.2% [113] 320(0.1%) 0(0.0%) argmins /home/ztatlock/herbie/src/common.rkt:134:0 composed [123] 100.0% ----------------------------------------------------------------------------------------- ??? [94] 100.0% [114] 242(0.1%) 0(0.0%) ??? ...ects/racket/contract/private/hash.rkt:222:6 check-hash/c [128] 100.0% ----------------------------------------------------------------------------------------- update-leader! [91] 100.0% [115] 220(0.1%) 118(0.0%) custom-set-union! ...t/private/set-types.rkt:245:0 for-loop [131] 46.4% ----------------------------------------------------------------------------------------- enode-merge! [99] 100.0% [116] 212(0.1%) 212(0.1%) custom-set-intersect! ...ivate/set-types.rkt:269:0 ----------------------------------------------------------------------------------------- ??? [98] 100.0% [117] 140(0.1%) 0(0.0%) ??? ...private/unconstrained-domain-arrow.rkt:69:2 get-blame-party-info [129] 100.0% ----------------------------------------------------------------------------------------- approximate9 [86] 100.0% [118] 104(0.0%) 0(0.0%) taylor-quotient ...erbie/src/core/taylor.rkt:324:0 first-nonzero-exp [192] 100.0% ----------------------------------------------------------------------------------------- mk-enode! [93] 100.0% [119] 90(0.0%) 90(0.0%) mutable-set .../racket/private/set-types.rkt:999:0 ----------------------------------------------------------------------------------------- ??? [104] 100.0% [120] 16498(6.1%) 0(0.0%) for-loop ...ock/herbie/src/core/alt-table.rkt:51:2 atab-add-altn [132] 100.0% ----------------------------------------------------------------------------------------- mk-enode! [93] 7.0% ??? [104] 93.0% [121] 9024(3.3%) 4592(1.7%) hash-has-key? ...et/private/more-scheme.rkt:368:13 ??? [133] 34.7% ??? [136] 14.4% ----------------------------------------------------------------------------------------- for-loop [105] 100.0% [122] 5396(2.0%) 248(0.1%) for-loop ...tlock/herbie/src/core/egraph.rkt:223:8 hash-update! [134] 95.4% ----------------------------------------------------------------------------------------- argmins [113] 8.6% loop [110] 14.1% f6 [159] 77.3% [123] 3740(1.4%) 234(0.1%) composed ...ollects/racket/private/list.rkt:321:16 f6 [159] 68.0% errors [146] 22.7% free-variables [191] 3.1% ----------------------------------------------------------------------------------------- ??? [104] 100.0% [124] 1968(0.7%) 0(0.0%) split-atab ...k/herbie/src/core/alt-table.rkt:74:0 for-loop [135] 100.0% ----------------------------------------------------------------------------------------- ??? [106] 100.0% [125] 1230(0.5%) 882(0.3%) for-loop ...atlock/herbie/src/core/ematch.rkt:51:7 ??? [104] 28.3% ----------------------------------------------------------------------------------------- ??? [106] 9.5% match-e [69] 90.5% [126] 1058(0.4%) 1058(0.4%) custom-in-set ...acket/private/set-types.rkt:577:0 ----------------------------------------------------------------------------------------- ??? [104] 100.0% [127] 408(0.2%) 0(0.0%) atab-add-altns ...rbie/src/core/alt-table.rkt:50:0 atab-add-altn [132] 100.0% ----------------------------------------------------------------------------------------- ??? [114] 100.0% [128] 242(0.1%) 128(0.0%) check-hash/c ...ket/contract/private/hash.rkt:83:0 flat-contract? [138] 47.1% ----------------------------------------------------------------------------------------- ??? [117] 100.0% [129] 140(0.1%) 0(0.0%) get-blame-party-info ...ate/arrow-common.rkt:136:0 show-blame-positive [137] 100.0% ----------------------------------------------------------------------------------------- new-enode [112] 100.0% [130] 124(0.0%) 124(0.0%) check-valid-enode5 ...bie/src/core/enode.rkt:177:0 ----------------------------------------------------------------------------------------- custom-set-union! [115] 100.0% [131] 102(0.0%) 102(0.0%) for-loop ...cts/racket/private/set-types.rkt:253:4 ----------------------------------------------------------------------------------------- atab-add-altns [127] 2.4% for-loop [120] 97.6% [132] 16906(6.2%) 0(0.0%) atab-add-altn ...rbie/src/core/alt-table.rkt:208:0 best-and-tied-at-points [139] 91.0% override-at-pnts [142] 7.7% loop [196] 0.7% ----------------------------------------------------------------------------------------- hash-has-key? [121] 31.1% location-do [85] 68.9% [133] 10092(3.7%) 4196(1.5%) ??? ...ects/racket/contract/private/list.rkt:737:4 for-loop [141] 43.6% ??? [148] 6.4% arrow-higher-order:lnp [184] 6.0% successfully-got-the-right-kind-of-function [151] 2.5% ----------------------------------------------------------------------------------------- for-loop [122] 100.0% [134] 5148(1.9%) 0(0.0%) hash-update! ...ket/private/more-scheme.rkt:362:13 ??? [140] 100.0% ----------------------------------------------------------------------------------------- split-atab [124] 100.0% [135] 1968(0.7%) 0(0.0%) for-loop ...ock/herbie/src/core/alt-table.rkt:75:2 for-loop [143] 52.8% for-loop [144] 24.0% for-loop [145] 23.2% ----------------------------------------------------------------------------------------- hash-has-key? [121] 100.0% [136] 1298(0.5%) 1298(0.5%) ??? ...ects/racket/contract/private/hash.rkt:245:7 ----------------------------------------------------------------------------------------- get-blame-party-info [129] 100.0% [137] 140(0.1%) 140(0.1%) show-blame-positive ...act/private/blame.rkt:150:0 ----------------------------------------------------------------------------------------- check-hash/c [128] 100.0% [138] 114(0.0%) 114(0.0%) flat-contract? .../contract/private/guts.rkt:111:0 ----------------------------------------------------------------------------------------- atab-add-altn [132] 100.0% [139] 15382(5.7%) 216(0.1%) best-and-tied-at-points ...ore/alt-table.rkt:122:0 errors [146] 94.9% for-loop [150] 3.7% ----------------------------------------------------------------------------------------- hash-update! [134] 100.0% [140] 5148(1.9%) 216(0.1%) ??? .../ztatlock/herbie/src/core/egraph.rkt:225:24 for-loop [147] 95.8% ----------------------------------------------------------------------------------------- ??? [133] 100.0% [141] 4396(1.6%) 3022(1.1%) for-loop ...acket/contract/private/list.rkt:743:12 ??? [148] 19.9% for-loop [152] 7.0% successfully-got-the-right-kind-of-function [151] 4.3% ----------------------------------------------------------------------------------------- atab-add-altn [132] 100.0% [142] 1306(0.5%) 0(0.0%) override-at-pnts ...e/src/core/alt-table.rkt:145:0 errors [146] 100.0% ----------------------------------------------------------------------------------------- for-loop [135] 100.0% [143] 1040(0.4%) 0(0.0%) for-loop ...ck/herbie/src/core/alt-table.rkt:80:53 loop [149] 91.9% filter [267] 8.1% ----------------------------------------------------------------------------------------- for-loop [135] 100.0% [144] 472(0.2%) 0(0.0%) for-loop ...ck/herbie/src/core/alt-table.rkt:86:30 ??? [154] 100.0% ----------------------------------------------------------------------------------------- for-loop [135] 100.0% [145] 456(0.2%) 0(0.0%) for-loop ...ck/herbie/src/core/alt-table.rkt:76:45 ??? [154] 100.0% ----------------------------------------------------------------------------------------- option-on-expr [165] 1.2% composed [123] 4.5% loop [196] 4.6% pred [228] 5.0% override-at-pnts [142] 6.9% best-and-tied-at-points [139] 77.3% [146] 18876(7.0%) 0(0.0%) errors /home/ztatlock/herbie/src/points.rkt:184:0 for-loop [153] 79.3% eval-prog [156] 20.1% ----------------------------------------------------------------------------------------- ??? [140] 100.0% [147] 4932(1.8%) 4066(1.5%) for-loop ...lock/herbie/src/core/egraph.rkt:226:26 update-en-expr [222] 17.6% ----------------------------------------------------------------------------------------- ??? [133] 42.4% for-loop [141] 57.6% [148] 1520(0.6%) 1158(0.4%) ??? ...private/unconstrained-domain-arrow.rkt:74:4 make-keyword-procedure [202] 23.8% ----------------------------------------------------------------------------------------- one-iter [45] 31.4% for-loop [143] 68.6% [149] 1394(0.5%) 438(0.2%) loop ...ket/collects/racket/private/list.rkt:264:4 ??? [154] 68.6% ----------------------------------------------------------------------------------------- best-and-tied-at-points [139] 100.0% [150] 572(0.2%) 342(0.1%) for-loop ...k/herbie/src/core/alt-table.rkt:124:16 ??? [157] 40.2% ----------------------------------------------------------------------------------------- for-loop [141] 42.8% ??? [133] 57.2% [151] 444(0.2%) 444(0.2%) successfully-got-the-right-kind-of-function ...9:4 ----------------------------------------------------------------------------------------- for-loop [141] 100.0% [152] 308(0.1%) 232(0.1%) for-loop ...racket/contract/private/hash.rkt:239:6 ??? [155] 24.7% ----------------------------------------------------------------------------------------- errors [146] 100.0% [153] 14976(5.5%) 504(0.2%) for-loop ...e/ztatlock/herbie/src/points.rkt:187:4 ??? [226] 85.6% ->flonum [236] 7.0% ulp-difference [158] 2.8% ??? [157] 1.3% ----------------------------------------------------------------------------------------- for-loop [145] 24.2% for-loop [144] 25.1% loop [149] 50.7% [154] 1884(0.7%) 474(0.2%) ??? .../ztatlock/herbie/src/core/regimes.rkt:305:8 eval-prog [156] 62.5% ??? [226] 12.3% ----------------------------------------------------------------------------------------- for-loop [152] 100.0% [155] 76(0.0%) 0(0.0%) ??? ...ects/racket/contract/private/list.rkt:686:7 ??? [249] 100.0% ----------------------------------------------------------------------------------------- for-loop [186] 0.9% ??? [154] 3.0% make-exacts* [89] 6.5% errors [146] 9.5% ??? [218] 12.2% loop [77] 68.0% [156] 39834(14.7%) 6488(2.4%) eval-prog ...tatlock/herbie/src/programs.rkt:146:0 hash-ref! [205] 71.6% f6 [159] 7.1% ??? [161] 1.8% ??? [160] 1.6% parse-lambda [162] 0.6% ??? [76] 0.4% ??? [163] 0.3% ----------------------------------------------------------------------------------------- for-loop [153] 46.0% for-loop [150] 54.0% [157] 426(0.2%) 426(0.2%) ??? ...ket/collects/racket/private/for.rkt:1151:14 ----------------------------------------------------------------------------------------- for-loop [153] 100.0% [158] 420(0.2%) 0(0.0%) ulp-difference ...atlock/herbie/src/float.rkt:19:0 ??? [255] 100.0% ----------------------------------------------------------------------------------------- ??? [175] 0.1% for-loop [201] 0.3% composed [123] 0.5% simplify-node [172] 0.5% approximate9 [86] 0.6% hash-ref! [205] 0.7% eval-const-expr [65] 0.7% eval-prog [156] 1.6% append-map [181] 1.8% loop [196] 2.7% f6 [159] 5.0% parse-loop12 [189] 5.7% simplify [35] 15.7% map [164] 19.8% split-table [37] 44.1% [159] 72672(26.8%) 8904(3.3%) f6 ...et/collects/racket/match/compiler.rkt:507:40 option-on-expr [165] 44.1% map [164] 37.3% f6 [159] 5.0% append-map [181] 2.5% ??? [76] 1.6% gather-multiplicative-terms [174] 0.7% composed [123] 0.5% combine-mterms [14] 0.5% parse-app [200] 0.3% ??? [169] 0.3% taylor [166] 0.2% taylor-invert [12] 0.2% parse-loop12 [189] 0.2% variable? [90] 0.2% compose [237] 0.2% ...erbie/src/common.rkt:46:2 [80] 0.1% location-do [85] 0.1% make-keyword-procedure [202] 0.0% ----------------------------------------------------------------------------------------- eval-const-expr [65] 30.0% eval-prog [156] 70.0% [160] 886(0.3%) 484(0.2%) ??? ...cket/collects/racket/private/kw.rkt:1633:36 unpack242 [168] 45.4% ----------------------------------------------------------------------------------------- eval-prog [156] 100.0% [161] 732(0.3%) 130(0.0%) ??? ...collects/racket/private/qq-and-or.rkt:155:9 ??? [167] 82.2% ----------------------------------------------------------------------------------------- eval-prog [156] 100.0% [162] 224(0.1%) 114(0.0%) parse-lambda ...llects/racket/private/kw.rkt:437:2 loop [213] 49.1% ----------------------------------------------------------------------------------------- eval-prog [156] 100.0% [163] 124(0.0%) 0(0.0%) ??? ...tract/private/arrow-higher-order.rkt:346:33 ??? [249] 100.0% ----------------------------------------------------------------------------------------- ??? [175] 0.3% gather-multiplicative-terms [174] 1.1% parse-loop12 [189] 4.4% make-exacts* [89] 10.4% loop [88] 23.5% f6 [159] 60.3% [164] 53012(19.5%) 976(0.4%) map ...acket/collects/racket/private/map.rkt:20:13 f6 [159] 33.7% loop [196] 32.7% parse-loop12 [189] 21.3% simplify-node [172] 3.4% ??? [226] 2.4% simplify* [198] 1.6% ??? [175] 1.2% gather-multiplicative-terms [174] 0.9% ??? [11] 0.8% taylor-sqrt [183] 0.5% make-multiplication-node [209] 0.4% ->flonum [236] 0.3% ----------------------------------------------------------------------------------------- f6 [159] 100.0% [165] 32334(11.9%) 0(0.0%) option-on-expr ...erbie/src/core/regimes.rkt:115:0 sindices->spoints [170] 77.2% sort-context-on-expr [171] 17.2% loop [196] 2.7% pick-errors [177] 1.1% err-lsts->split-indices [178] 1.1% errors [146] 0.7% ----------------------------------------------------------------------------------------- approximate9 [86] 7.8% f6 [159] 92.2% [166] 1288(0.5%) 342(0.1%) taylor ...tatlock/herbie/src/core/taylor.rkt:159:0 debug-print [173] 49.4% loop [196] 16.1% debug7 [176] 7.9% ----------------------------------------------------------------------------------------- ??? [161] 100.0% [167] 602(0.2%) 602(0.2%) ??? ...ollects/racket/private/qq-and-or.rkt:164:21 ----------------------------------------------------------------------------------------- ??? [160] 100.0% [168] 402(0.1%) 264(0.1%) unpack242 ...private/arrow-higher-order.rkt:354:44 maybe-cons-kwd [179] 34.3% ----------------------------------------------------------------------------------------- f6 [159] 100.0% [169] 208(0.1%) 0(0.0%) ??? ...tract/private/arrow-higher-order.rkt:336:46 ??? [265] 100.0% ----------------------------------------------------------------------------------------- option-on-expr [165] 100.0% [170] 24970(9.2%) 0(0.0%) sindices->spoints ...ie/src/core/regimes.rkt:128:0 loop [197] 100.0% ----------------------------------------------------------------------------------------- option-on-expr [165] 100.0% [171] 5562(2.1%) 0(0.0%) sort-context-on-expr ...herbie/src/points.rkt:79:0 ??? [180] 100.0% ----------------------------------------------------------------------------------------- simplify [35] 12.6% map [164] 87.4% [172] 4432(1.6%) 220(0.1%) simplify-node ...k/herbie/src/core/reduce.rkt:39:0 append-map [181] 43.9% f6 [159] 40.8% combine-aterms [185] 10.4% ----------------------------------------------------------------------------------------- taylor [166] 36.1% simplify [35] 63.9% [173] 1762(0.6%) 324(0.1%) debug-print ...ztatlock/herbie/src/debug.rkt:107:0 for-loop [182] 81.6% ----------------------------------------------------------------------------------------- gather-multiplicative-terms [174] 1.7% map [164] 37.2% f6 [159] 61.0% [174] 1724(0.6%) 1054(0.4%) gather-multiplicative-terms ...re/reduce.rkt:105:0 map [164] 51.8% compose [237] 16.8% gather-multiplicative-terms [174] 1.7% ----------------------------------------------------------------------------------------- loop [196] 34.2% map [164] 65.8% [175] 1284(0.5%) 0(0.0%) ??? ...ket/collects/racket/private/list.rkt:323:18 f6 [159] 44.5% hash-ref! [205] 30.2% taylor-sqrt [183] 19.5% map [164] 5.8% ----------------------------------------------------------------------------------------- taylor [166] 11.8% simplify [35] 88.2% [176] 866(0.3%) 552(0.2%) debug7 /home/ztatlock/herbie/src/debug.rkt:102:0 ??? [104] 25.6% assoc-ref [188] 10.6% ----------------------------------------------------------------------------------------- option-on-expr [165] 100.0% [177] 356(0.1%) 0(0.0%) pick-errors ...k/herbie/src/core/regimes.rkt:187:0 for-loop [186] 100.0% ----------------------------------------------------------------------------------------- option-on-expr [165] 100.0% [178] 354(0.1%) 0(0.0%) err-lsts->split-indices .../core/regimes.rkt:238:0 add-splitpoint [187] 100.0% ----------------------------------------------------------------------------------------- unpack242 [168] 100.0% [179] 138(0.1%) 0(0.0%) maybe-cons-kwd ...ate/arrow-higher-order.rkt:498:0 arrow-higher-order:lnp [184] 100.0% ----------------------------------------------------------------------------------------- localize-error [52] 2.2% sort-context-on-expr [171] 97.8% [180] 5688(2.1%) 0(0.0%) ??? ...cket/collects/racket/private/sort.rkt:403:3 generic-sort/key [190] 85.2% loop [208] 14.8% ----------------------------------------------------------------------------------------- append-map [181] 1.5% simplify-node [172] 26.0% f6 [159] 72.5% [181] 5440(2.0%) 732(0.3%) append-map ...acket/collects/racket/list.rkt:565:2 f6 [159] 50.4% parse-loop12 [189] 26.3% free-variables [191] 11.2% loop [196] 6.6% append-map [181] 1.5% ----------------------------------------------------------------------------------------- debug-print [173] 100.0% [182] 1438(0.5%) 1438(0.5%) for-loop /home/ztatlock/herbie/src/debug.rkt:113:2 ----------------------------------------------------------------------------------------- map [164] 31.5% ??? [175] 32.8% approximate9 [86] 35.7% [183] 762(0.3%) 132(0.0%) taylor-sqrt ...ck/herbie/src/core/taylor.rkt:342:0 hash-ref! [205] 42.0% first-nonzero-exp [192] 28.6% simplify [35] 12.1% ----------------------------------------------------------------------------------------- maybe-cons-kwd [179] 18.6% ??? [133] 81.4% [184] 740(0.3%) 0(0.0%) arrow-higher-order:lnp ...w-higher-order.rkt:597:7 ??? [193] 100.0% ----------------------------------------------------------------------------------------- simplify-node [172] 100.0% [185] 460(0.2%) 108(0.0%) combine-aterms ...herbie/src/core/reduce.rkt:172:0 for-loop [195] 76.5% ----------------------------------------------------------------------------------------- pick-errors [177] 100.0% [186] 356(0.1%) 0(0.0%) for-loop ...lock/herbie/src/core/regimes.rkt:190:4 eval-prog [156] 100.0% ----------------------------------------------------------------------------------------- err-lsts->split-indices [178] 100.0% [187] 354(0.1%) 0(0.0%) add-splitpoint ...erbie/src/core/regimes.rkt:251:2 for-loop [194] 100.0% ----------------------------------------------------------------------------------------- debug7 [176] 100.0% [188] 92(0.0%) 92(0.0%) assoc-ref ...collects/racket/private/dict.rkt:56:0 ----------------------------------------------------------------------------------------- f6 [159] 1.1% hash-ref! [205] 1.4% for-loop [28] 1.5% append-map [181] 4.6% loop [196] 5.1% simplify [35] 22.5% parse-loop12 [189] 28.7% map [164] 34.9% [189] 39024(14.4%) 24804(9.1%) parse-loop12 ...s/racket/match/compiler.rkt:418:15 parse-loop12 [189] 28.7% loop [196] 12.2% f6 [159] 11.9% map [164] 4.6% parse-app [200] 2.5% for-loop [201] 2.1% make-multiplication-node [209] 1.5% simplify* [198] 1.2% simplify [35] 0.3% make-keyword-procedure [202] 0.2% loop [197] 0.2% for-loop [204] 0.1% ??? [11] 0.1% ----------------------------------------------------------------------------------------- ??? [180] 100.0% [190] 4846(1.8%) 0(0.0%) generic-sort/key .../racket/private/sort.rkt:185:2 copying-mergesort [199] 80.6% loop [208] 16.8% jloop [10] 2.6% ----------------------------------------------------------------------------------------- composed [123] 7.6% append-map [181] 92.4% [191] 1534(0.6%) 618(0.2%) free-variables ...ock/herbie/src/programs.rkt:98:0 variable? [90] 37.7% ??? [104] 22.0% ----------------------------------------------------------------------------------------- taylor-quotient [118] 11.6% taylor-sqrt [183] 24.3% taylor-invert [12] 64.1% [192] 898(0.3%) 0(0.0%) first-nonzero-exp ...bie/src/core/taylor.rkt:256:0 hash-ref! [205] 88.4% simplify [35] 11.6% ----------------------------------------------------------------------------------------- arrow-higher-order:lnp [184] 100.0% [193] 740(0.3%) 740(0.3%) ??? ...et/contract/private/arity-checking.rkt:19:2 ----------------------------------------------------------------------------------------- add-splitpoint [187] 100.0% [194] 354(0.1%) 0(0.0%) for-loop ...lock/herbie/src/core/regimes.rkt:253:4 for-loop [203] 100.0% ----------------------------------------------------------------------------------------- combine-aterms [185] 100.0% [195] 352(0.1%) 110(0.0%) for-loop ...tlock/herbie/src/core/reduce.rkt:174:4 hash-ref! [205] 68.8% ----------------------------------------------------------------------------------------- loop [88] 0.0% make-exacts* [89] 0.1% for-loop [24] 0.1% atab-add-altn [132] 0.1% taylor [166] 0.3% append-map [181] 0.5% option-on-expr [165] 0.8% match-e [69] 0.8% map-enodes [49] 1.1% for-loop [78] 1.1% loop! [207] 1.8% map [164] 2.0% extract-alt [40] 4.2% parse-loop12 [189] 10.3% ??? [8] 31.6% loop [196] 45.3% [196] 82792(30.5%) 1828(0.7%) loop ...cket/collects/racket/private/map.rkt:25:19 loop [196] 45.3% hash-ref! [205] 31.6% parse-loop12 [189] 7.4% simplify [3] 4.2% f6 [159] 4.1% loop! [207] 1.7% for-loop [58] 1.0% errors [146] 0.8% ??? [226] 0.7% foldl [212] 0.4% simplify [35] 0.3% ??? [175] 0.2% make-multiplication-node [209] 0.2% ??? [11] 0.1% simplify* [198] 0.0% ->flonum [236] 0.0% set-precompute! [211] 0.0% bf* [246] 0.0% ??? [249] 0.0% ----------------------------------------------------------------------------------------- parse-loop12 [189] 0.5% loop [197] 8.6% sindices->spoints [170] 90.9% [197] 25092(9.3%) 122(0.0%) loop ...cket/collects/racket/private/map.rkt:36:19 sidx->spoint [206] 90.9% loop [197] 8.6% ----------------------------------------------------------------------------------------- loop [196] 2.6% simplify [35] 10.4% parse-loop12 [189] 28.4% map [164] 58.6% [198] 4626(1.7%) 2128(0.8%) simplify* ...tlock/herbie/src/core/reduce.rkt:20:0 hash-ref! [205] 31.8% ??? [210] 17.8% return/no-unsupplied [261] 2.3% variable? [90] 2.1% ----------------------------------------------------------------------------------------- generic-sort/key [190] 40.1% copying-mergesort [199] 59.9% [199] 3906(1.4%) 0(0.0%) copying-mergesort ...racket/private/sort.rkt:130:8 copying-mergesort [199] 59.9% loop [208] 25.7% jloop [10] 14.4% ----------------------------------------------------------------------------------------- f6 [159] 30.4% parse-loop12 [189] 69.6% [200] 2174(0.8%) 1948(0.7%) parse-app .../collects/racket/private/kw.rkt:951:2 loop [213] 10.4% ----------------------------------------------------------------------------------------- parse-loop12 [189] 100.0% [201] 1190(0.4%) 0(0.0%) for-loop ...tlock/herbie/src/core/reduce.rkt:88:13 f6 [159] 64.0% make-multiplication-node [209] 36.0% ----------------------------------------------------------------------------------------- f6 [159] 16.2% parse-loop12 [189] 31.5% ??? [148] 52.3% [202] 692(0.3%) 692(0.3%) make-keyword-procedure ...ket/private/kw.rkt:260:4 ----------------------------------------------------------------------------------------- for-loop [194] 100.0% [203] 354(0.1%) 354(0.1%) for-loop ...lock/herbie/src/core/regimes.rkt:257:8 ----------------------------------------------------------------------------------------- parse-loop12 [189] 100.0% [204] 124(0.0%) 0(0.0%) for-loop ...tlock/herbie/src/core/reduce.rkt:78:11 make-multiplication-node [209] 100.0% ----------------------------------------------------------------------------------------- ??? [13] 0.0% for-loop [195] 0.0% for-loop [27] 0.1% for-loop [29] 0.1% ??? [15] 0.1% taylor-sqrt [183] 0.1% simplify* [198] 0.2% localize-error [52] 0.3% ??? [175] 0.3% first-nonzero-exp [192] 0.4% ??? [4] 0.4% compile [81] 1.7% ??? [8] 2.0% for-loop [38] 2.3% for-loop [22] 4.3% ??? [215] 4.9% for-loop [20] 5.3% loop [103] 8.1% for-loop [21] 12.1% eval-prog [156] 13.0% loop [196] 19.5% ??? [36] 24.4% [205] 87824(32.4%) 5632(2.1%) hash-ref! ...racket/private/more-scheme.rkt:373:13 ??? [5] 24.1% ??? [8] 21.6% bigfloat-hash [214] 12.8% ??? [6] 12.2% ??? [4] 6.9% simplify [35] 6.4% ??? [215] 4.9% ??? [7] 4.4% ??? [9] 2.3% f6 [159] 1.3% parse-loop12 [189] 0.6% ??? [15] 0.2% ??? [13] 0.1% lognormalize [225] 0.0% ----------------------------------------------------------------------------------------- loop [197] 100.0% [206] 24970(9.2%) 0(0.0%) sidx->spoint .../herbie/src/core/regimes.rkt:142:2 binary-search [216] 60.3% binary-search-floats [217] 39.7% ----------------------------------------------------------------------------------------- merge-egraph-nodes! [79] 18.1% apply-match [62] 23.5% for-loop [72] 25.0% loop [196] 33.5% [207] 5478(2.0%) 1054(0.4%) loop! .../ztatlock/herbie/src/core/enode.rkt:163:2 loop [196] 36.6% custom-set-union [220] 27.2% set [221] 17.7% update-en-expr [222] 7.2% ----------------------------------------------------------------------------------------- generic-sort/key [190] 24.5% ??? [180] 25.4% copying-mergesort [199] 50.1% [208] 3318(1.2%) 94(0.0%) loop ...ket/collects/racket/private/sort.rkt:97:12 ??? [218] 97.2% ----------------------------------------------------------------------------------------- for-loop [204] 5.5% loop [196] 6.0% for-loop [201] 19.0% parse-loop12 [189] 29.9% map [164] 39.6% [209] 2254(0.8%) 104(0.0%) make-multiplication-node .../core/reduce.rkt:219:0 make-multiplication-subnode [219] 95.4% ----------------------------------------------------------------------------------------- simplify* [198] 100.0% [210] 822(0.3%) 310(0.1%) ??? ...racket/collects/racket/private/kw.rkt:762:9 ??? [266] 32.6% ??? [265] 29.7% ----------------------------------------------------------------------------------------- map-enodes [49] 23.1% loop [196] 76.9% [211] 676(0.2%) 134(0.0%) set-precompute! ...bie/src/core/simplify.rkt:160:0 make-sequence [223] 80.2% ----------------------------------------------------------------------------------------- loop [196] 100.0% [212] 500(0.2%) 222(0.1%) foldl ...et/collects/racket/private/list.rkt:229:4 merge2 [224] 55.6% ----------------------------------------------------------------------------------------- parse-lambda [162] 6.5% loop [213] 26.2% parse-app [200] 67.3% [213] 336(0.1%) 336(0.1%) loop .../collects/racket/private/stxcase.rkt:112:7 loop [213] 26.2% ----------------------------------------------------------------------------------------- hash-ref! [205] 100.0% [214] 28174(10.4%) 0(0.0%) bigfloat-hash ...h/private/bigfloat/mpfr.rkt:165:0 bfcanonicalize [227] 88.7% sig+exp->bigfloat [229] 10.3% bigfloat->sig+exp [239] 0.4% ----------------------------------------------------------------------------------------- hash-ref! [205] 100.0% [215] 20282(7.5%) 0(0.0%) ??? ...e/ztatlock/herbie/src/core/taylor.rkt:64:15 hash-ref! [205] 100.0% ----------------------------------------------------------------------------------------- sidx->spoint [206] 100.0% [216] 15052(5.5%) 0(0.0%) binary-search ...tlock/herbie/src/common.rkt:197:0 pred [228] 100.0% ----------------------------------------------------------------------------------------- sidx->spoint [206] 100.0% [217] 9918(3.7%) 0(0.0%) binary-search-floats ...erbie/src/common.rkt:212:0 pred [228] 100.0% ----------------------------------------------------------------------------------------- jloop [10] 41.0% loop [208] 59.0% [218] 5468(2.0%) 244(0.1%) ??? /home/ztatlock/herbie/src/points.rkt:81:27 eval-prog [156] 88.8% ??? [226] 4.5% ->flonum [236] 2.2% ----------------------------------------------------------------------------------------- make-multiplication-node [209] 100.0% [219] 2150(0.8%) 136(0.1%) make-multiplication-subnode ...re/reduce.rkt:229:0 group-by68 [231] 47.8% for-loop [232] 30.5% compose [237] 15.3% ----------------------------------------------------------------------------------------- adopt-enode! [108] 25.8% loop! [207] 74.2% [220] 2128(0.8%) 438(0.2%) custom-set-union ...et/private/set-types.rkt:168:0 for-loop [230] 62.9% for-loop [233] 16.5% ----------------------------------------------------------------------------------------- new-enode [112] 9.7% loop! [207] 90.3% [221] 2018(0.7%) 2018(0.7%) set ...collects/racket/private/set-types.rkt:981:0 ----------------------------------------------------------------------------------------- for-loop [101] 16.6% loop! [207] 39.7% for-loop [147] 43.7% [222] 1982(0.7%) 1982(0.7%) update-en-expr ...herbie/src/core/egraph.rkt:211:0 ----------------------------------------------------------------------------------------- for-loop [57] 20.8% update-leader! [91] 27.1% set-precompute! [211] 52.1% [223] 1040(0.4%) 1040(0.4%) make-sequence ...ects/racket/private/for.rkt:509:2 ----------------------------------------------------------------------------------------- foldl [212] 100.0% [224] 278(0.1%) 278(0.1%) merge2 ...ztatlock/herbie/src/core/ematch.rkt:31:0 ----------------------------------------------------------------------------------------- hash-ref! [205] 100.0% [225] 108(0.0%) 0(0.0%) lognormalize ...k/herbie/src/core/taylor.rkt:455:0 group-by68 [231] 100.0% ----------------------------------------------------------------------------------------- ??? [154] 0.5% ??? [218] 0.6% map [164] 2.9% for-loop [153] 29.5% loop [196] 66.4% [226] 43380(16.0%) 2246(0.8%) ??? /home/ztatlock/herbie/src/programs.rkt:152:4 ??? [234] 69.2% ??? [235] 20.8% ->flonum [236] 4.8% ----------------------------------------------------------------------------------------- bigfloat-hash [214] 100.0% [227] 25002(9.2%) 24734(9.1%) bfcanonicalize .../private/bigfloat/mpfr.rkt:155:0 bigfloat->sig+exp [239] 1.1% ----------------------------------------------------------------------------------------- binary-search-floats [217] 39.7% binary-search [216] 60.3% [228] 24970(9.2%) 0(0.0%) pred ...tatlock/herbie/src/core/regimes.rkt:148:17 loop [68] 96.3% errors [146] 3.7% ----------------------------------------------------------------------------------------- bigfloat-hash [214] 100.0% [229] 2916(1.1%) 2658(1.0%) sig+exp->bigfloat ...ivate/bigfloat/mpfr.rkt:385:0 integer->mpz [240] 8.8% ----------------------------------------------------------------------------------------- custom-set-union [220] 100.0% [230] 1338(0.5%) 726(0.3%) for-loop ...cts/racket/private/set-types.rkt:174:3 for-loop [238] 45.7% ----------------------------------------------------------------------------------------- lognormalize [225] 8.6% rle [42] 9.4% make-multiplication-subnode [219] 82.0% [231] 1254(0.5%) 910(0.3%) group-by68 ...acket/collects/racket/list.rkt:749:0 hash-update [241] 18.8% for-loop [244] 8.6% ----------------------------------------------------------------------------------------- make-multiplication-subnode [219] 100.0% [232] 656(0.2%) 212(0.1%) for-loop ...tlock/herbie/src/core/reduce.rkt:231:3 compose [237] 32.3% make-multiplication-subsubsubnode [243] 18.9% loop [242] 16.5% ----------------------------------------------------------------------------------------- custom-set-union [220] 100.0% [233] 352(0.1%) 352(0.1%) for-loop ...cts/racket/private/set-types.rkt:152:2 ----------------------------------------------------------------------------------------- ??? [226] 100.0% [234] 30014(11.1%) 11612(4.3%) ??? ...acket/collects/racket/private/kw.rkt:444:14 ??? [254] 30.5% bf* [246] 16.8% ??? [247] 6.7% ??? [248] 6.3% ??? [249] 0.7% ...higher-order.rkt:346:33 [251] 0.4% ----------------------------------------------------------------------------------------- ??? [76] 1.0% ??? [226] 99.0% [235] 9138(3.4%) 470(0.2%) ??? ...contract/private/../../private/kw.rkt:761:9 real->bigfloat [245] 93.8% ----------------------------------------------------------------------------------------- ??? [218] 2.7% for-loop [58] 4.4% map [164] 4.9% loop [196] 20.2% for-loop [153] 22.7% ??? [226] 45.2% [236] 4592(1.7%) 336(0.1%) ->flonum .../ztatlock/herbie/src/programs.rkt:34:0 ??? [255] 90.4% ??? [252] 2.3% ----------------------------------------------------------------------------------------- for-loop [232] 11.6% f6 [159] 13.6% make-multiplication-subnode [219] 18.0% gather-multiplicative-terms [174] 19.5% for-loop [58] 37.2% [237] 1832(0.7%) 1832(0.7%) compose ...collects/racket/private/list.rkt:385:12 ----------------------------------------------------------------------------------------- for-loop [230] 100.0% [238] 612(0.2%) 612(0.2%) for-loop ...cts/racket/private/set-types.rkt:178:5 ----------------------------------------------------------------------------------------- bigfloat-hash [214] 28.3% bfcanonicalize [227] 71.7% [239] 374(0.1%) 136(0.1%) bigfloat->sig+exp ...ivate/bigfloat/mpfr.rkt:370:0 mpz->integer [250] 35.3% new-mpz [253] 28.3% ----------------------------------------------------------------------------------------- sig+exp->bigfloat [229] 100.0% [240] 258(0.1%) 258(0.1%) integer->mpz ...math/private/bigfloat/gmp.rkt:87:0 ----------------------------------------------------------------------------------------- group-by68 [231] 100.0% [241] 236(0.1%) 236(0.1%) hash-update ...cket/private/more-scheme.rkt:356:13 ----------------------------------------------------------------------------------------- for-loop [232] 46.2% errors-score [30] 53.8% [242] 234(0.1%) 234(0.1%) loop ...hare/racket/collects/racket/list.rkt:551:2 ----------------------------------------------------------------------------------------- for-loop [232] 100.0% [243] 124(0.0%) 124(0.0%) make-multiplication-subsubsubnode ...uce.rkt:251:0 ----------------------------------------------------------------------------------------- group-by68 [231] 100.0% [244] 108(0.0%) 108(0.0%) for-loop .../racket/collects/racket/list.rkt:783:4 ----------------------------------------------------------------------------------------- ??? [235] 100.0% [245] 8574(3.2%) 6410(2.4%) real->bigfloat .../private/bigfloat/mpfr.rkt:451:0 ??? [264] 25.2% ----------------------------------------------------------------------------------------- loop [196] 2.3% ??? [234] 97.7% [246] 5144(1.9%) 0(0.0%) bf* ...ath/private/bigfloat/bigfloat-mpfr.rkt:95:0 ??? [254] 100.0% ----------------------------------------------------------------------------------------- ??? [234] 100.0% [247] 2012(0.7%) 2012(0.7%) ??? ...rivate/unconstrained-domain-arrow.rkt:40:13 ----------------------------------------------------------------------------------------- ??? [234] 100.0% [248] 1880(0.7%) 108(0.0%) ??? ...tatlock/herbie/src/syntax/syntax.rkt:118:17 ??? [255] 94.3% ----------------------------------------------------------------------------------------- ??? [155] 15.0% loop [196] 19.4% ??? [163] 24.5% ??? [234] 41.1% [249] 506(0.2%) 102(0.0%) ??? ...ects/racket/contract/private/prop.rkt:493:4 ??? [257] 79.8% ----------------------------------------------------------------------------------------- bigfloat->sig+exp [239] 100.0% [250] 132(0.0%) 132(0.0%) mpz->integer ...ath/private/bigfloat/gmp.rkt:115:0 ----------------------------------------------------------------------------------------- ??? [234] 100.0% [251] 124(0.0%) 0(0.0%) ...higher-order.rkt:346:33 (unknown source) ??? [256] 100.0% ----------------------------------------------------------------------------------------- ->flonum [236] 100.0% [252] 106(0.0%) 106(0.0%) ??? ...-racket/utils/simple-result-arrow.rkt:60:15 ----------------------------------------------------------------------------------------- bigfloat->sig+exp [239] 100.0% [253] 106(0.0%) 106(0.0%) new-mpz ...-lib/math/private/bigfloat/gmp.rkt:73:0 ----------------------------------------------------------------------------------------- eval-const-expr [65] 0.7% bf* [246] 35.7% ??? [234] 63.6% [254] 14398(5.3%) 2636(1.0%) ??? ...-racket/utils/simple-result-arrow.rkt:39:12 bfmul [258] 49.7% bfsqrt [259] 32.0% ----------------------------------------------------------------------------------------- *rules* [16] 1.5% for-loop [102] 3.3% ulp-difference [158] 6.3% ??? [248] 26.6% ->flonum [236] 62.3% [255] 6666(2.5%) 2730(1.0%) ??? /home/ztatlock/herbie/src/config.rkt:48:0 ??? [260] 36.3% return/no-unsupplied [261] 22.7% ----------------------------------------------------------------------------------------- ...higher-order.rkt:346:33 [251] 6.1% location-do [85] 6.9% ??? [94] 87.0% [256] 2030(0.7%) 1154(0.4%) ??? ...cts/racket/contract/private/list.rkt:187:10 ??? [94] 27.8% for-loop [262] 15.4% ----------------------------------------------------------------------------------------- ??? [249] 100.0% [257] 404(0.1%) 280(0.1%) ??? ...lects/racket/contract/private/orc.rkt:83:14 ??? [263] 30.7% ----------------------------------------------------------------------------------------- ??? [254] 100.0% [258] 7152(2.6%) 4454(1.6%) bfmul ...-lib/math/private/bigfloat/mpfr.rkt:819:4 ??? [264] 37.7% ----------------------------------------------------------------------------------------- ??? [254] 100.0% [259] 4610(1.7%) 2892(1.1%) bfsqrt ...lib/math/private/bigfloat/mpfr.rkt:616:4 ??? [264] 37.3% ----------------------------------------------------------------------------------------- location-do [85] 7.1% ??? [95] 20.2% ??? [255] 72.7% [260] 3332(1.2%) 632(0.2%) ??? ...racket/collects/racket/private/kw.rkt:761:9 ??? [266] 70.1% ??? [265] 10.9% ----------------------------------------------------------------------------------------- simplify* [198] 6.7% ??? [255] 93.3% [261] 1622(0.6%) 1358(0.5%) return/no-unsupplied ...ct/private/arr-i.rkt:533:0 filter [267] 16.3% ----------------------------------------------------------------------------------------- ??? [256] 100.0% [262] 312(0.1%) 106(0.0%) for-loop ...acket/contract/private/list.rkt:190:15 ??? [94] 66.0% ----------------------------------------------------------------------------------------- ??? [257] 100.0% [263] 124(0.0%) 124(0.0%) ??? ...ects/racket/contract/private/list.rkt:141:5 ----------------------------------------------------------------------------------------- bfsqrt [259] 26.1% real->bigfloat [245] 32.9% bfmul [258] 41.0% [264] 6580(2.4%) 6580(2.4%) ??? .../share/racket/collects/ffi/unsafe.rkt:861:4 ----------------------------------------------------------------------------------------- ??? [169] 7.7% ??? [104] 7.8% ??? [210] 9.0% ??? [260] 13.5% ??? [94] 16.1% ??? [76] 45.9% [265] 2704(1.0%) 800(0.3%) ??? ...ects/racket/contract/private/guts.rkt:644:8 ??? [104] 53.6% contract? [270] 8.4% dict? [268] 8.4% ----------------------------------------------------------------------------------------- ??? [210] 10.3% ??? [260] 89.7% [266] 2604(1.0%) 2376(0.9%) ??? ...s/racket/contract/private/arr-i.rkt:1233:27 ??? [269] 8.8% ----------------------------------------------------------------------------------------- for-loop [143] 11.8% for-loop [78] 16.3% match-e [69] 34.6% return/no-unsupplied [261] 37.2% [267] 710(0.3%) 710(0.3%) filter ...t/collects/racket/private/list.rkt:256:2 ----------------------------------------------------------------------------------------- location-do [85] 28.3% ??? [265] 71.7% [268] 318(0.1%) 318(0.1%) dict? ...ollects/racket/private/generic.rkt:146:11 ----------------------------------------------------------------------------------------- ??? [266] 100.0% [269] 228(0.1%) 228(0.1%) ??? ...ects/racket/contract/private/prop.rkt:256:4 ----------------------------------------------------------------------------------------- ??? [265] 100.0% [270] 228(0.1%) 228(0.1%) contract? ...acket/contract/private/guts.rkt:109:0 -----------------------------------------------------------------------------------------