Profiling results ----------------- Total cpu time observed: 350602ms (out of 352256ms) Number of samples taken: 5575 (once every 63ms) (Hiding functions with self<1.0% and local<2.0%: 15 of 281 hidden) ========================================================================================== Caller Idx Total Self Name+src Local% ms(pct) ms(pct) Callee ========================================================================================== ??? [56] 100.0% [1] 330050(94.1%) 0(0.0%) run-improve50 ...ock/herbie/src/mainloop.rkt:234:0 for-loop [15] 95.5% get-final-combination [18] 3.6% loop [66] 0.6% setup-prog [23] 0.3% errors [170] 0.0% ------------------------------------------------------------------------------------------ ??? [56] 100.0% [2] 316896(90.4%) 0(0.0%) profile-thunk16 ...t/pkgs/profile-lib/main.rkt:9:0 run [14] 100.0% ------------------------------------------------------------------------------------------ simplify-alt [34] 0.4% loop [216] 1.1% ??? [56] 98.5% [3] 299358(85.4%) 110(0.0%) simplify ...lock/herbie/src/core/simplify.rkt:39:0 simplify-expr [16] 51.7% for-loop [17] 40.3% iterate-egraph!5 [30] 7.1% loop [31] 0.8% ------------------------------------------------------------------------------------------ map-enodes [44] 3.5% loop [216] 96.5% [4] 5966(1.7%) 748(0.2%) for-loop ...ock/herbie/src/core/simplify.rkt:161:2 setfindf [19] 39.5% eval-const-expr [20] 34.6% compose [26] 7.2% curried [225] 6.1% ------------------------------------------------------------------------------------------ copying-mergesort [186] 100.0% [5] 2348(0.7%) 0(0.0%) jloop ...t/collects/racket/private/sort.rkt:121:23 ??? [191] 100.0% ------------------------------------------------------------------------------------------ hash-ref! [193] 100.0% [6] 1920(0.5%) 0(0.0%) ??? .../ztatlock/herbie/src/core/taylor.rkt:291:23 for-loop [21] 100.0% ------------------------------------------------------------------------------------------ hash-ref! [193] 100.0% [7] 1728(0.5%) 0(0.0%) ??? .../ztatlock/herbie/src/core/taylor.rkt:281:26 for-loop [22] 100.0% ------------------------------------------------------------------------------------------ rewriter [70] 100.0% [8] 952(0.3%) 104(0.0%) *rules* ...tlock/herbie/src/syntax/rules.rkt:411:0 for-loop [98] 77.5% ??? [251] 11.6% ------------------------------------------------------------------------------------------ hash-ref! [193] 100.0% [9] 526(0.2%) 0(0.0%) ??? .../ztatlock/herbie/src/core/taylor.rkt:388:23 for-loop [25] 100.0% ------------------------------------------------------------------------------------------ hash-ref! [193] 100.0% [10] 412(0.1%) 0(0.0%) ??? .../ztatlock/herbie/src/core/taylor.rkt:318:33 for-loop [27] 100.0% ------------------------------------------------------------------------------------------ simplify [201] 29.4% parse-loop12 [210] 30.3% map [150] 40.3% [11] 402(0.1%) 0(0.0%) simplify-node ...k/herbie/src/core/reduce.rkt:39:0 append-map [24] 88.1% f94 [141] 11.9% ------------------------------------------------------------------------------------------ hash-ref! [193] 100.0% [12] 128(0.0%) 0(0.0%) ??? .../ztatlock/herbie/src/core/taylor.rkt:334:33 for-loop [28] 100.0% ------------------------------------------------------------------------------------------ loop [219] 100.0% [13] 110(0.0%) 0(0.0%) ??? ...ztatlock/herbie/src/core/localize.rkt:43:32 ->flonum [234] 100.0% ------------------------------------------------------------------------------------------ profile-thunk16 [2] 100.0% [14] 316896(90.4%) 0(0.0%) run ...share/racket/pkgs/profile-lib/main.rkt:39:2 ??? [56] 100.0% ------------------------------------------------------------------------------------------ run-improve50 [1] 100.0% [15] 315172(89.9%) 0(0.0%) for-loop ...ztatlock/herbie/src/mainloop.rkt:245:8 run-iter! [29] 100.0% ------------------------------------------------------------------------------------------ simplify [3] 100.0% [16] 154836(44.2%) 248(0.1%) simplify-expr ...herbie/src/core/simplify.rkt:68:0 iterate-egraph!5 [30] 75.1% loop [31] 24.5% debug-print [211] 0.2% mk-egraph [37] 0.1% extract-smallest [39] 0.0% ------------------------------------------------------------------------------------------ simplify [3] 100.0% [17] 120546(34.4%) 224(0.1%) for-loop ...ock/herbie/src/core/simplify.rkt:61:12 iterate-egraph!5 [30] 78.8% loop [31] 20.8% mk-egraph [37] 0.1% debug-print [211] 0.1% ------------------------------------------------------------------------------------------ run-improve50 [1] 100.0% [18] 11752(3.4%) 0(0.0%) get-final-combination ...ie/src/mainloop.rkt:260:0 split-table [32] 70.6% extract-alt [33] 29.4% ------------------------------------------------------------------------------------------ for-loop [4] 100.0% [19] 2358(0.7%) 1770(0.5%) setfindf ...e/ztatlock/herbie/src/common.rkt:168:0 for-loop [36] 13.1% ??? [131] 11.8% ------------------------------------------------------------------------------------------ for-loop [4] 100.0% [20] 2066(0.6%) 788(0.2%) eval-const-expr ...k/herbie/src/programs.rkt:164:0 f94 [141] 47.0% ??? [194] 9.3% parse-app [196] 5.6% ------------------------------------------------------------------------------------------ ??? [6] 100.0% [21] 1920(0.5%) 0(0.0%) for-loop ...lock/herbie/src/core/taylor.rkt:294:27 hash-ref! [193] 100.0% ------------------------------------------------------------------------------------------ ??? [7] 100.0% [22] 1728(0.5%) 0(0.0%) for-loop ...lock/herbie/src/core/taylor.rkt:281:52 hash-ref! [193] 92.6% simplify [201] 5.6% ------------------------------------------------------------------------------------------ run-improve50 [1] 100.0% [23] 1096(0.3%) 0(0.0%) setup-prog /home/ztatlock/herbie/src/glue.rkt:45:0 simplify-alt [34] 100.0% ------------------------------------------------------------------------------------------ f94 [141] 35.2% simplify-node [11] 64.8% [24] 546(0.2%) 0(0.0%) append-map ...acket/collects/racket/list.rkt:565:2 parse-loop12 [210] 73.6% f94 [141] 15.8% free-variables [38] 10.6% ------------------------------------------------------------------------------------------ ??? [9] 100.0% [25] 526(0.2%) 0(0.0%) for-loop ...lock/herbie/src/core/taylor.rkt:392:33 for-loop [35] 100.0% ------------------------------------------------------------------------------------------ for-loop [4] 100.0% [26] 428(0.1%) 428(0.1%) compose ...collects/racket/private/list.rkt:385:12 ------------------------------------------------------------------------------------------ ??? [10] 100.0% [27] 412(0.1%) 98(0.0%) for-loop ...lock/herbie/src/core/taylor.rkt:320:46 simplify [201] 76.2% ------------------------------------------------------------------------------------------ ??? [12] 100.0% [28] 128(0.0%) 0(0.0%) for-loop ...lock/herbie/src/core/taylor.rkt:337:46 hash-ref! [193] 100.0% ------------------------------------------------------------------------------------------ for-loop [15] 100.0% [29] 315172(89.9%) 0(0.0%) run-iter! ...tatlock/herbie/src/mainloop.rkt:215:0 simplify! [40] 93.3% finalize-iter! [43] 4.5% gen-series! [45] 1.3% gen-rewrites! [46] 0.5% localize-error [47] 0.2% ------------------------------------------------------------------------------------------ simplify [3] 9.1% for-loop [17] 40.9% simplify-expr [16] 50.0% [30] 232402(66.3%) 1172(0.3%) iterate-egraph!5 ...bie/src/core/simplify.rkt:95:0 one-iter [41] 96.5% map-enodes [44] 2.8% debug-print [211] 0.1% debug7 [214] 0.1% ------------------------------------------------------------------------------------------ simplify [3] 3.8% for-loop [17] 38.3% simplify-expr [16] 57.8% [31] 65584(18.7%) 0(0.0%) loop ...tatlock/herbie/src/core/simplify.rkt:203:2 pass [42] 100.0% ------------------------------------------------------------------------------------------ get-final-combination [18] 100.0% [32] 8302(2.4%) 0(0.0%) split-table .../ztatlock/herbie/src/glue.rkt:164:0 f94 [141] 100.0% ------------------------------------------------------------------------------------------ get-final-combination [18] 100.0% [33] 3450(1.0%) 0(0.0%) extract-alt ...e/ztatlock/herbie/src/glue.rkt:56:0 loop [216] 96.9% loop [124] 2.1% argmins [127] 0.9% ------------------------------------------------------------------------------------------ setup-prog [23] 100.0% [34] 1096(0.3%) 0(0.0%) simplify-alt .../ztatlock/herbie/src/glue.rkt:83:0 simplify [3] 100.0% ------------------------------------------------------------------------------------------ for-loop [25] 100.0% [35] 526(0.2%) 0(0.0%) for-loop ...lock/herbie/src/core/taylor.rkt:394:39 hash-ref! [193] 100.0% ------------------------------------------------------------------------------------------ setfindf [19] 100.0% [36] 310(0.1%) 310(0.1%) for-loop ...e/ztatlock/herbie/src/common.rkt:169:2 ------------------------------------------------------------------------------------------ simplify-expr [16] 49.2% for-loop [17] 50.8% [37] 248(0.1%) 30(0.0%) mk-egraph ...lock/herbie/src/core/egraph.rkt:123:0 expr->enode [48] 87.9% ------------------------------------------------------------------------------------------ append-map [24] 100.0% [38] 116(0.0%) 0(0.0%) free-variables ...ock/herbie/src/programs.rkt:98:0 variable? [85] 100.0% ------------------------------------------------------------------------------------------ simplify-expr [16] 100.0% [39] 32(0.0%) 0(0.0%) extract-smallest ...ie/src/core/simplify.rkt:179:0 hash-keys [55] 100.0% ------------------------------------------------------------------------------------------ run-iter! [29] 100.0% [40] 294148(83.9%) 204(0.1%) simplify! ...tatlock/herbie/src/mainloop.rkt:155:0 for-loop [49] 99.9% ------------------------------------------------------------------------------------------ iterate-egraph!5 [30] 100.0% [41] 224194(63.9%) 5296(1.5%) one-iter ...ock/herbie/src/core/simplify.rkt:106:0 for-loop [50] 57.8% loop [51] 38.2% apply-match [57] 1.3% filter [261] 0.1% ------------------------------------------------------------------------------------------ loop [31] 100.0% [42] 65584(18.7%) 242(0.1%) pass ...tatlock/herbie/src/core/simplify.rkt:193:2 for-loop [52] 99.5% ------------------------------------------------------------------------------------------ run-iter! [29] 100.0% [43] 14050(4.0%) 0(0.0%) finalize-iter! ...ck/herbie/src/mainloop.rkt:169:0 ??? [131] 100.0% ------------------------------------------------------------------------------------------ iterate-egraph!5 [30] 100.0% [44] 6612(1.9%) 100(0.0%) map-enodes ...ock/herbie/src/core/egraph.rkt:139:0 loop [216] 93.1% for-loop [4] 3.2% hash-keys [55] 2.2% ------------------------------------------------------------------------------------------ run-iter! [29] 100.0% [45] 4044(1.2%) 0(0.0%) gen-series! ...tlock/herbie/src/mainloop.rkt:129:0 for-loop [53] 100.0% ------------------------------------------------------------------------------------------ run-iter! [29] 100.0% [46] 1522(0.4%) 0(0.0%) gen-rewrites! ...ock/herbie/src/mainloop.rkt:142:0 for-loop [54] 100.0% ------------------------------------------------------------------------------------------ critical-subexpression [163] 5.4% run-iter! [29] 94.6% [47] 818(0.2%) 0(0.0%) localize-error ...erbie/src/core/localize.rkt:47:0 hash-ref! [193] 94.6% ??? [197] 5.4% ------------------------------------------------------------------------------------------ mk-egraph [37] 46.2% expr->enode [48] 53.8% [48] 218(0.1%) 58(0.0%) expr->enode ...ck/herbie/src/core/egraph.rkt:124:2 expr->enode [48] 53.8% mk-enode! [87] 17.3% curried [225] 2.3% ------------------------------------------------------------------------------------------ simplify! [40] 99.7% [49] 294874(84.1%) 0(0.0%) for-loop ...ztatlock/herbie/src/mainloop.rkt:159:6 ??? [56] 100.0% ------------------------------------------------------------------------------------------ for-loop [50] 49.2% one-iter [41] 50.8% [50] 129502(36.9%) 21298(6.1%) for-loop ...ck/herbie/src/core/simplify.rkt:116:12 for-loop [50] 49.2% match-e [64] 41.5% ??? [104] 0.2% ------------------------------------------------------------------------------------------ one-iter [41] 100.0% [51] 85754(24.5%) 730(0.2%) loop ...cket/collects/racket/private/map.rkt:52:19 apply-match [57] 99.1% ------------------------------------------------------------------------------------------ pass [42] 100.0% [52] 65244(18.6%) 580(0.2%) for-loop ...ck/herbie/src/core/simplify.rkt:196:29 argmin [58] 79.2% loop [59] 16.2% for-loop [61] 2.8% make-sequence [237] 0.6% filter [261] 0.3% ------------------------------------------------------------------------------------------ gen-series! [45] 100.0% [53] 4044(1.2%) 0(0.0%) for-loop ...ztatlock/herbie/src/mainloop.rkt:135:7 taylor-alt [60] 100.0% ------------------------------------------------------------------------------------------ gen-rewrites! [46] 100.0% [54] 1522(0.4%) 0(0.0%) for-loop ...tatlock/herbie/src/mainloop.rkt:147:11 ??? [62] 94.1% debug-print [211] 5.9% ------------------------------------------------------------------------------------------ extract-smallest [39] 17.8% map-enodes [44] 82.2% [55] 180(0.1%) 0(0.0%) hash-keys .../collects/racket/private/hash.rkt:2:2 loop [63] 100.0% ------------------------------------------------------------------------------------------ for-loop [49] 30.0% run [14] 33.0% [56] 343966(98.1%) 0(0.0%) ??? ...lects/racket/private/more-scheme.rkt:261:28 run-improve50 [1] 35.1% profile-thunk16 [2] 33.0% simplify [3] 30.0% loop [66] 1.9% ------------------------------------------------------------------------------------------ one-iter [41] 3.4% loop [51] 96.6% [57] 88016(25.1%) 2334(0.7%) apply-match .../herbie/src/core/simplify.rkt:122:2 merge-egraph-nodes! [74] 35.6% match-e [64] 27.6% for-loop [67] 13.4% loop! [101] 7.3% substitute-e [76] 6.9% mk-enode! [87] 4.0% update-leader! [84] 1.6% reduce-to-single! [71] 1.0% ------------------------------------------------------------------------------------------ for-loop [52] 100.0% [58] 51654(14.7%) 218(0.1%) argmin ...re/racket/collects/racket/list.rkt:743:0 for-loop [65] 87.6% expression-cost [68] 12.0% ------------------------------------------------------------------------------------------ for-loop [52] 100.0% [59] 10572(3.0%) 156(0.0%) loop ...hare/racket/collects/racket/list.rkt:729:4 for-loop [65] 86.3% expression-cost [68] 12.2% ------------------------------------------------------------------------------------------ for-loop [53] 100.0% [60] 4044(1.2%) 0(0.0%) taylor-alt ...e/ztatlock/herbie/src/glue.rkt:141:0 for-loop [69] 100.0% ------------------------------------------------------------------------------------------ for-loop [52] 100.0% [61] 1830(0.5%) 1830(0.5%) for-loop ...ck/herbie/src/core/simplify.rkt:183:13 ------------------------------------------------------------------------------------------ for-loop [54] 100.0% [62] 1432(0.4%) 0(0.0%) ??? /home/ztatlock/herbie/src/alternative.rkt:88:0 rewriter [70] 92.7% loop [216] 7.3% ------------------------------------------------------------------------------------------ hash-keys [55] 3.4% loop [63] 96.6% [63] 180(0.1%) 180(0.1%) loop ...acket/collects/racket/private/hash.rkt:3:4 loop [63] 96.6% ------------------------------------------------------------------------------------------ apply-match [57] 11.3% for-loop [82] 27.4% for-loop [50] 61.3% [64] 131852(37.6%) 41930(12.0%) match-e ...tatlock/herbie/src/core/ematch.rkt:46:0 for-loop [72] 43.9% for-loop [82] 13.3% ??? [131] 7.3% variable? [85] 3.8% list-cartesian-product [86] 2.3% loop [216] 2.1% custom-in-set [252] 0.6% curry* [96] 0.4% filter [261] 0.1% ------------------------------------------------------------------------------------------ loop [59] 16.8% argmin [58] 83.2% [65] 54346(15.5%) 1418(0.4%) for-loop ...ztatlock/herbie/src/programs.rkt:197:2 location-do [73] 64.4% ...erbie/src/common.rkt:46:2 [75] 30.2% ??? [152] 2.8% ------------------------------------------------------------------------------------------ run-improve50 [1] 12.9% ??? [56] 87.1% [66] 14862(4.2%) 0(0.0%) loop /home/ztatlock/herbie/src/points.rkt:159:2 loop [77] 48.7% make-exacts* [88] 41.8% loop [92] 9.0% for-loop [81] 0.5% ------------------------------------------------------------------------------------------ apply-match [57] 100.0% [67] 11794(3.4%) 340(0.1%) for-loop ...ck/herbie/src/core/simplify.rkt:136:10 merge-egraph-nodes! [74] 35.7% loop! [101] 32.2% substitute-e [76] 18.0% mk-enode! [87] 11.2% ------------------------------------------------------------------------------------------ loop [59] 17.2% argmin [58] 82.8% [68] 7506(2.1%) 342(0.1%) expression-cost ...k/herbie/src/programs.rkt:196:0 compile [78] 95.4% ------------------------------------------------------------------------------------------ taylor-alt [60] 100.0% [69] 4044(1.2%) 0(0.0%) for-loop /home/ztatlock/herbie/src/glue.rkt:143:2 ??? [89] 100.0% ------------------------------------------------------------------------------------------ ??? [62] 21.1% matcher [97] 78.9% [70] 1328(0.4%) 212(0.1%) rewriter ...lock/herbie/src/core/matcher.rkt:127:2 for-loop [79] 81.2% *rules* [8] 15.2% ------------------------------------------------------------------------------------------ apply-match [57] 100.0% [71] 880(0.3%) 744(0.2%) reduce-to-single! ...bie/src/core/egraph.rkt:324:0 for-loop [80] 15.5% ------------------------------------------------------------------------------------------ match-e [64] 100.0% [72] 77972(22.2%) 24296(6.9%) for-loop ...tlock/herbie/src/core/ematch.rkt:59:11 for-loop [82] 56.2% list-cartesian-product [86] 8.6% loop [216] 4.8% curry* [96] 1.3% filter [261] 1.0% curried [225] 0.5% foldl [224] 0.5% loop [226] 0.4% ------------------------------------------------------------------------------------------ ??? [197] 0.1% parse-loop12 [210] 0.3% f94 [141] 0.3% ??? [89] 6.9% location-do [73] 7.3% for-loop [65] 85.1% [73] 41144(11.7%) 8600(2.5%) location-do ...acket/private/norm-define.rkt:53:83 ??? [83] 62.3% location-do [73] 7.3% ??? [254] 2.7% ??? [89] 2.7% return/no-unsupplied [255] 1.3% ??? [249] 0.8% dict? [264] 0.5% ??? [153] 0.3% f94 [141] 0.1% ??? [197] 0.0% ------------------------------------------------------------------------------------------ for-loop [93] 4.5% merge-egraph-nodes! [74] 6.4% for-loop [67] 11.5% apply-match [57] 77.6% [74] 35534(10.1%) 1358(0.4%) merge-egraph-nodes! ...e/src/core/egraph.rkt:152:0 update-leader! [84] 57.5% loop! [101] 12.3% for-loop [94] 7.3% for-loop [93] 6.8% merge-egraph-nodes! [74] 6.4% enode-merge! [95] 4.9% for-loop [98] 0.9% make-sequence [237] 0.3% ------------------------------------------------------------------------------------------ f94 [141] 0.5% ??? [89] 4.1% for-loop [65] 95.4% [75] 17220(4.9%) 4960(1.4%) ...erbie/src/common.rkt:46:2 ...e/arr-i.rkt:906:19 ??? [90] 40.8% ??? [91] 28.5% ------------------------------------------------------------------------------------------ for-loop [67] 18.6% substitute-e [76] 21.1% apply-match [57] 60.3% [76] 8182(2.3%) 820(0.2%) substitute-e ...ck/herbie/src/core/ematch.rkt:71:0 mk-enode! [87] 58.8% substitute-e [76] 21.1% variable? [85] 6.9% ??? [131] 5.6% ------------------------------------------------------------------------------------------ loop [66] 100.0% [77] 7240(2.1%) 0(0.0%) loop /home/ztatlock/herbie/src/points.rkt:119:2 make-exacts* [88] 48.5% loop [92] 39.4% eval-prog [192] 12.1% ------------------------------------------------------------------------------------------ expression-cost [68] 100.0% [78] 7164(2.0%) 230(0.1%) compile .../ztatlock/herbie/src/programs.rkt:173:0 hash-ref! [193] 96.8% ------------------------------------------------------------------------------------------ rewriter [70] 100.0% [79] 1328(0.4%) 0(0.0%) for-loop ...ock/herbie/src/core/matcher.rkt:130:10 matcher [97] 100.0% ------------------------------------------------------------------------------------------ reduce-to-single! [71] 100.0% [80] 136(0.0%) 136(0.0%) for-loop ...tlock/herbie/src/core/egraph.rkt:325:8 ------------------------------------------------------------------------------------------ loop [66] 100.0% [81] 78(0.0%) 0(0.0%) for-loop .../ztatlock/herbie/src/points.rkt:166:24 for-loop [99] 100.0% ------------------------------------------------------------------------------------------ match-e [64] 39.8% for-loop [72] 60.2% [82] 72964(20.8%) 5914(1.7%) for-loop ...tlock/herbie/src/core/ematch.rkt:65:37 match-e [64] 89.0% ??? [104] 3.8% ------------------------------------------------------------------------------------------ hash-has-key? [143] 12.2% location-do [73] 87.8% [83] 29196(8.3%) 9102(2.6%) ??? ...ects/racket/contract/private/list.rkt:737:4 for-loop [102] 54.0% ??? [117] 10.2% ??? [249] 1.8% arrow-higher-order:lnp [217] 1.7% successfully-got-the-right-kind-of-function [218] 0.8% ??? [258] 0.3% ------------------------------------------------------------------------------------------ apply-match [57] 5.9% merge-egraph-nodes! [74] 94.1% [84] 23820(6.8%) 1974(0.6%) update-leader! ...herbie/src/core/egraph.rkt:217:0 for-loop [100] 84.5% custom-set-union! [111] 2.5% update-en-expr [159] 2.4% make-sequence [237] 1.1% hash-ref! [193] 1.1% mutable-set [126] 0.1% ------------------------------------------------------------------------------------------ f94 [141] 0.6% pattern-match [184] 0.8% free-variables [38] 0.8% simplify* [165] 0.8% substitute-e [76] 9.5% match-e [64] 87.5% [85] 14328(4.1%) 926(0.3%) variable? ...ck/herbie/src/syntax/syntax.rkt:529:0 ??? [131] 93.5% ------------------------------------------------------------------------------------------ list-cartesian-product [86] 25.7% match-e [64] 28.3% for-loop [72] 46.0% [86] 11560(3.3%) 9744(2.8%) list-cartesian-product ...src/core/ematch.rkt:20:0 list-cartesian-product [86] 25.7% for-loop [105] 12.1% ------------------------------------------------------------------------------------------ expr->enode [48] 1.3% for-loop [67] 13.6% apply-match [57] 35.8% substitute-e [76] 49.3% [87] 9770(2.8%) 7194(2.1%) mk-enode! ...lock/herbie/src/core/egraph.rkt:101:0 hash-has-key? [143] 12.3% new-enode [107] 12.1% mutable-set [126] 2.0% ------------------------------------------------------------------------------------------ loop [77] 36.1% loop [66] 63.9% [88] 9718(2.8%) 0(0.0%) make-exacts* ...atlock/herbie/src/points.rkt:106:0 loop [216] 45.9% map [150] 41.8% eval-prog [192] 12.3% ------------------------------------------------------------------------------------------ for-loop [181] 1.0% ??? [240] 1.1% ??? [145] 6.6% location-do [73] 21.1% for-loop [69] 21.1% f94 [141] 48.0% [89] 9590(2.7%) 122(0.0%) ??? ...tract/private/arrow-higher-order.rkt:342:33 location-do [73] 40.2% approximate9 [103] 21.1% ??? [258] 15.6% ...erbie/src/common.rkt:46:2 [75] 7.4% best-alt [110] 6.6% ??? [152] 3.5% ->flonum [234] 2.1% arrow-higher-order:lnp [217] 1.1% ??? [235] 0.7% ------------------------------------------------------------------------------------------ for-loop [256] 7.6% ??? [249] 15.5% ...erbie/src/common.rkt:46:2 [75] 76.8% [90] 7024(2.0%) 1768(0.5%) ??? ...ects/racket/contract/private/list.rkt:342:4 ??? [249] 71.2% ??? [258] 11.1% ??? [123] 4.7% ------------------------------------------------------------------------------------------ ...erbie/src/common.rkt:46:2 [75] 100.0% [91] 4900(1.4%) 1578(0.5%) ??? ...s/racket/contract/private/arr-i.rkt:1268:39 ??? [254] 42.2% return/no-unsupplied [255] 18.3% assoc-ref [113] 7.3% ------------------------------------------------------------------------------------------ loop [66] 31.9% loop [77] 68.1% [92] 4190(1.2%) 0(0.0%) loop /home/ztatlock/herbie/src/points.rkt:109:4 map [150] 100.0% ------------------------------------------------------------------------------------------ merge-egraph-nodes! [74] 100.0% [93] 4070(1.2%) 0(0.0%) for-loop ...lock/herbie/src/core/egraph.rkt:200:10 merge-egraph-nodes! [74] 78.1% loop! [101] 21.9% ------------------------------------------------------------------------------------------ merge-egraph-nodes! [74] 100.0% [94] 2628(0.7%) 2156(0.6%) for-loop ...tlock/herbie/src/core/egraph.rkt:232:6 update-en-expr [159] 18.0% ------------------------------------------------------------------------------------------ merge-egraph-nodes! [74] 100.0% [95] 1994(0.6%) 590(0.2%) enode-merge! ...ck/herbie/src/core/enode.rkt:100:0 adopt-enode! [108] 51.0% custom-set-intersect! [112] 19.5% ------------------------------------------------------------------------------------------ match-e [64] 39.3% for-loop [72] 60.7% [96] 1886(0.5%) 402(0.1%) curry* ...racket/collects/racket/function.rkt:44:2 procedure-arity [106] 78.7% ------------------------------------------------------------------------------------------ for-loop [109] 18.1% matcher [97] 31.3% for-loop [79] 50.6% [97] 1328(0.4%) 164(0.0%) matcher ...tlock/herbie/src/core/matcher.rkt:163:2 rewriter [70] 49.4% matcher [97] 31.3% for-loop [109] 18.1% ------------------------------------------------------------------------------------------ merge-egraph-nodes! [74] 34.0% *rules* [8] 66.0% [98] 1118(0.3%) 638(0.2%) for-loop /home/ztatlock/herbie/src/common.rkt:93:9 ??? [251] 18.4% update-en-expr [159] 13.6% ormap [114] 10.9% ------------------------------------------------------------------------------------------ for-loop [81] 100.0% [99] 78(0.0%) 0(0.0%) for-loop .../ztatlock/herbie/src/points.rkt:167:26 ??? [115] 100.0% ------------------------------------------------------------------------------------------ update-leader! [84] 100.0% [100] 20120(5.7%) 1216(0.3%) for-loop ...tlock/herbie/src/core/egraph.rkt:222:6 for-loop [116] 93.8% update-en-expr [159] 0.2% ------------------------------------------------------------------------------------------ for-loop [93] 4.4% for-loop [67] 14.0% merge-egraph-nodes! [74] 21.9% apply-match [57] 28.4% loop [216] 31.2% [101] 16874(4.8%) 3712(1.1%) loop! .../ztatlock/herbie/src/core/enode.rkt:163:2 loop [216] 32.9% custom-set-union [118] 31.8% set [119] 13.4% update-en-expr [159] 7.6% ------------------------------------------------------------------------------------------ ??? [83] 100.0% [102] 15760(4.5%) 8962(2.6%) for-loop ...acket/contract/private/list.rkt:743:12 ??? [117] 24.4% for-loop [121] 14.9% ??? [123] 2.5% successfully-got-the-right-kind-of-function [218] 1.0% arrow-higher-order:lnp [217] 0.4% ------------------------------------------------------------------------------------------ ??? [89] 100.0% [103] 4044(1.2%) 0(0.0%) approximate9 ...ck/herbie/src/core/taylor.rkt:12:0 loop [120] 69.3% f94 [141] 19.3% taylor-sqrt [125] 9.9% taylor-exp [129] 1.5% ------------------------------------------------------------------------------------------ for-loop [50] 18.8% for-loop [82] 81.2% [104] 3392(1.0%) 1888(0.5%) ??? /home/ztatlock/herbie/src/core/ematch.rkt:50:5 for-loop [122] 40.1% custom-in-set [252] 4.2% ------------------------------------------------------------------------------------------ list-cartesian-product [86] 100.0% [105] 1816(0.5%) 1816(0.5%) for-loop ...atlock/herbie/src/core/ematch.rkt:24:8 ------------------------------------------------------------------------------------------ curry* [96] 100.0% [106] 1484(0.4%) 1484(0.4%) procedure-arity ...ket/private/norm-arity.rkt:7:27 ------------------------------------------------------------------------------------------ mk-enode! [87] 100.0% [107] 1184(0.3%) 70(0.0%) new-enode ...atlock/herbie/src/core/enode.rkt:68:0 set [119] 76.9% mutable-set [126] 14.2% check-valid-enode5 [130] 3.0% ------------------------------------------------------------------------------------------ enode-merge! [95] 100.0% [108] 1016(0.3%) 564(0.2%) adopt-enode! ...ock/herbie/src/core/enode.rkt:76:0 custom-set-union [118] 44.5% ------------------------------------------------------------------------------------------ matcher [97] 100.0% [109] 950(0.3%) 0(0.0%) for-loop ...ock/herbie/src/core/matcher.rkt:179:21 matcher [97] 100.0% ------------------------------------------------------------------------------------------ ??? [89] 100.0% [110] 634(0.2%) 0(0.0%) best-alt /home/ztatlock/herbie/src/glue.rkt:78:0 loop [124] 61.2% argmins [127] 38.8% ------------------------------------------------------------------------------------------ update-leader! [84] 100.0% [111] 598(0.2%) 492(0.1%) custom-set-union! ...t/private/set-types.rkt:245:0 for-loop [128] 17.7% ------------------------------------------------------------------------------------------ enode-merge! [95] 100.0% [112] 388(0.1%) 388(0.1%) custom-set-intersect! ...ivate/set-types.rkt:269:0 ------------------------------------------------------------------------------------------ ??? [91] 100.0% [113] 360(0.1%) 360(0.1%) assoc-ref ...collects/racket/private/dict.rkt:56:0 ------------------------------------------------------------------------------------------ for-loop [98] 100.0% [114] 122(0.0%) 0(0.0%) ormap ...et/collects/racket/private/map.rkt:105:13 ??? [251] 100.0% ------------------------------------------------------------------------------------------ for-loop [99] 100.0% [115] 78(0.0%) 78(0.0%) ??? /home/ztatlock/herbie/src/points.rkt:156:9 ------------------------------------------------------------------------------------------ for-loop [100] 100.0% [116] 18870(5.4%) 282(0.1%) for-loop ...tlock/herbie/src/core/egraph.rkt:223:8 hash-update! [132] 98.5% ------------------------------------------------------------------------------------------ ??? [83] 43.7% for-loop [102] 56.3% [117] 6826(1.9%) 2830(0.8%) ??? ...private/unconstrained-domain-arrow.rkt:74:4 make-keyword-procedure [133] 58.5% ------------------------------------------------------------------------------------------ adopt-enode! [108] 7.0% loop! [101] 93.0% [118] 6488(1.9%) 2304(0.7%) custom-set-union ...et/private/set-types.rkt:168:0 for-loop [134] 54.3% for-loop [137] 10.2% ------------------------------------------------------------------------------------------ new-enode [107] 16.7% loop! [101] 83.3% [119] 5434(1.5%) 5434(1.5%) set ...collects/racket/private/set-types.rkt:981:0 ------------------------------------------------------------------------------------------ approximate9 [103] 100.0% [120] 2804(0.8%) 0(0.0%) loop ...e/ztatlock/herbie/src/core/taylor.rkt:83:4 hash-ref! [193] 100.0% ------------------------------------------------------------------------------------------ for-loop [102] 100.0% [121] 2352(0.7%) 1276(0.4%) for-loop ...racket/contract/private/hash.rkt:239:6 ??? [135] 41.7% ??? [257] 4.1% ------------------------------------------------------------------------------------------ ??? [104] 100.0% [122] 1360(0.4%) 944(0.3%) for-loop ...atlock/herbie/src/core/ematch.rkt:51:7 ??? [131] 30.6% ------------------------------------------------------------------------------------------ ??? [90] 45.8% for-loop [102] 54.2% [123] 716(0.2%) 238(0.1%) ??? ...ects/racket/contract/private/hash.rkt:222:6 check-hash/c [138] 66.8% ------------------------------------------------------------------------------------------ extract-alt [33] 16.0% best-alt [110] 84.0% [124] 462(0.1%) 0(0.0%) loop /home/ztatlock/herbie/src/common.rkt:135:2 composed [136] 100.0% ------------------------------------------------------------------------------------------ f94 [141] 11.1% approximate9 [103] 88.9% [125] 450(0.1%) 0(0.0%) taylor-sqrt ...ck/herbie/src/core/taylor.rkt:342:0 hash-ref! [193] 63.6% first-nonzero-exp [139] 36.4% ------------------------------------------------------------------------------------------ update-leader! [84] 8.6% new-enode [107] 42.4% mk-enode! [87] 49.0% [126] 396(0.1%) 396(0.1%) mutable-set .../racket/private/set-types.rkt:999:0 ------------------------------------------------------------------------------------------ extract-alt [33] 11.5% best-alt [110] 88.5% [127] 278(0.1%) 0(0.0%) argmins /home/ztatlock/herbie/src/common.rkt:134:0 composed [136] 100.0% ------------------------------------------------------------------------------------------ custom-set-union! [111] 100.0% [128] 106(0.0%) 106(0.0%) for-loop ...cts/racket/private/set-types.rkt:253:4 ------------------------------------------------------------------------------------------ f94 [141] 43.4% approximate9 [103] 56.6% [129] 106(0.0%) 0(0.0%) taylor-exp ...ock/herbie/src/core/taylor.rkt:382:0 simplify [201] 56.6% ??? [160] 43.4% ------------------------------------------------------------------------------------------ new-enode [107] 100.0% [130] 36(0.0%) 36(0.0%) check-valid-enode5 ...bie/src/core/enode.rkt:177:0 ------------------------------------------------------------------------------------------ pattern-substitute [208] 0.2% setfindf [19] 0.5% for-loop [122] 0.8% substitute-e [76] 2.3% ??? [258] 2.9% variable? [85] 26.3% finalize-iter! [43] 26.8% match-e [64] 38.9% [131] 50914(14.5%) 25470(7.3%) ??? ...contract/private/arrow-val-first.rkt:357:18 for-loop [142] 26.1% hash-has-key? [143] 21.3% ??? [145] 1.2% atab-add-altns [146] 0.7% ??? [258] 0.6% ------------------------------------------------------------------------------------------ for-loop [116] 100.0% [132] 18588(5.3%) 266(0.1%) hash-update! ...ket/private/more-scheme.rkt:362:13 ??? [140] 98.6% ------------------------------------------------------------------------------------------ ??? [117] 100.0% [133] 3996(1.1%) 3996(1.1%) make-keyword-procedure ...ket/private/kw.rkt:260:4 ------------------------------------------------------------------------------------------ custom-set-union [118] 100.0% [134] 3520(1.0%) 562(0.2%) for-loop ...cts/racket/private/set-types.rkt:174:3 for-loop [144] 84.0% ------------------------------------------------------------------------------------------ for-loop [121] 100.0% [135] 980(0.3%) 790(0.2%) ??? ...ects/racket/contract/private/list.rkt:686:7 ??? [257] 15.5% ??? [258] 3.9% ------------------------------------------------------------------------------------------ f94 [141] 21.6% argmins [127] 29.4% loop [124] 48.9% [136] 944(0.3%) 60(0.0%) composed ...ollects/racket/private/list.rkt:321:16 errors [170] 78.4% f94 [141] 15.3% ------------------------------------------------------------------------------------------ custom-set-union [118] 100.0% [137] 664(0.2%) 664(0.2%) for-loop ...cts/racket/private/set-types.rkt:152:2 ------------------------------------------------------------------------------------------ ??? [123] 100.0% [138] 478(0.1%) 356(0.1%) check-hash/c ...ket/contract/private/hash.rkt:83:0 flat-contract? [147] 25.5% ------------------------------------------------------------------------------------------ taylor-sqrt [125] 100.0% [139] 164(0.0%) 0(0.0%) first-nonzero-exp ...bie/src/core/taylor.rkt:256:0 hash-ref! [193] 100.0% ------------------------------------------------------------------------------------------ hash-update! [132] 100.0% [140] 18322(5.2%) 466(0.1%) ??? .../ztatlock/herbie/src/core/egraph.rkt:225:24 for-loop [148] 96.8% make-sequence [237] 0.6% ------------------------------------------------------------------------------------------ location-do [73] 0.0% simplify-node [11] 0.1% ??? [160] 0.1% composed [136] 0.2% append-map [24] 0.2% approximate9 [103] 0.9% parse-loop12 [210] 1.4% hash-ref! [193] 2.3% map [150] 4.1% simplify [201] 6.1% eval-const-expr [20] 6.9% eval-prog [192] 8.8% f94 [141] 25.4% split-table [32] 43.5% [141] 14060(4.0%) 934(0.3%) f94 ...t/collects/racket/match/compiler.rkt:507:40 option-on-expr [151] 41.4% f94 [141] 25.4% map [150] 10.5% ??? [89] 8.5% ??? [154] 2.8% exprs-to-branch-on [155] 2.1% ??? [152] 1.5% location-do [73] 0.8% ...erbie/src/common.rkt:46:2 [75] 0.6% parse-loop12 [210] 0.4% append-map [24] 0.4% taylor [162] 0.4% composed [136] 0.3% combine-mterms [156] 0.1% variable? [85] 0.1% taylor-exp [129] 0.1% taylor-sqrt [125] 0.1% taylor-invert [177] 0.0% ------------------------------------------------------------------------------------------ ??? [131] 100.0% [142] 13716(3.9%) 0(0.0%) for-loop ...ock/herbie/src/core/alt-table.rkt:51:2 atab-add-altn [149] 100.0% ------------------------------------------------------------------------------------------ mk-enode! [87] 9.6% ??? [131] 90.4% [143] 12456(3.6%) 7130(2.0%) hash-has-key? ...et/private/more-scheme.rkt:368:13 ??? [83] 28.6% ??? [153] 14.2% ------------------------------------------------------------------------------------------ for-loop [134] 100.0% [144] 2958(0.8%) 2958(0.8%) for-loop ...cts/racket/private/set-types.rkt:178:5 ------------------------------------------------------------------------------------------ ??? [131] 100.0% [145] 634(0.2%) 0(0.0%) ??? ...ztatlock/herbie/src/core/alt-table.rkt:54:0 ??? [89] 100.0% ------------------------------------------------------------------------------------------ ??? [131] 100.0% [146] 334(0.1%) 0(0.0%) atab-add-altns ...rbie/src/core/alt-table.rkt:50:0 atab-add-altn [149] 100.0% ------------------------------------------------------------------------------------------ check-hash/c [138] 100.0% [147] 122(0.0%) 122(0.0%) flat-contract? .../contract/private/guts.rkt:111:0 ------------------------------------------------------------------------------------------ ??? [140] 100.0% [148] 17742(5.1%) 14704(4.2%) for-loop ...lock/herbie/src/core/egraph.rkt:226:26 update-en-expr [159] 17.1% ------------------------------------------------------------------------------------------ atab-add-altns [146] 2.4% for-loop [142] 97.6% [149] 14050(4.0%) 0(0.0%) atab-add-altn ...rbie/src/core/alt-table.rkt:208:0 best-and-tied-at-points [157] 99.6% ------------------------------------------------------------------------------------------ f94 [141] 20.6% make-exacts* [88] 39.1% loop [92] 40.3% [150] 10388(3.0%) 118(0.0%) map ...acket/collects/racket/private/map.rkt:20:13 loop [216] 76.9% f94 [141] 10.0% parse-loop12 [210] 3.5% ??? [223] 2.5% simplify* [165] 1.6% ??? [160] 1.6% ??? [166] 1.4% loop [219] 1.1% simplify-node [11] 0.6% taylor [162] 0.5% ------------------------------------------------------------------------------------------ f94 [141] 100.0% [151] 7910(2.3%) 0(0.0%) option-on-expr ...erbie/src/core/regimes.rkt:115:0 sort-context-on-expr [158] 87.7% pick-errors [161] 7.2% loop [216] 2.5% errors [170] 1.8% err-lsts->split-indices [169] 0.8% ------------------------------------------------------------------------------------------ f94 [141] 10.3% ??? [89] 16.3% for-loop [65] 73.4% [152] 2040(0.6%) 1562(0.4%) ??? ...ts/racket/contract/private/arr-i.rkt:804:10 get/build-late-neg-projection [164] 15.3% ??? [167] 8.1% ------------------------------------------------------------------------------------------ location-do [73] 7.3% hash-has-key? [143] 92.7% [153] 1908(0.5%) 1908(0.5%) ??? ...ects/racket/contract/private/hash.rkt:245:7 ------------------------------------------------------------------------------------------ f94 [141] 100.0% [154] 400(0.1%) 0(0.0%) ??? ...tract/private/arrow-higher-order.rkt:336:46 ??? [258] 100.0% ------------------------------------------------------------------------------------------ f94 [141] 100.0% [155] 392(0.1%) 0(0.0%) exprs-to-branch-on ...ie/src/core/regimes.rkt:44:0 critical-subexpression [163] 100.0% ------------------------------------------------------------------------------------------ f94 [141] 100.0% [156] 96(0.0%) 0(0.0%) combine-mterms ...herbie/src/core/reduce.rkt:180:0 for-loop [168] 100.0% ------------------------------------------------------------------------------------------ atab-add-altn [149] 100.0% [157] 13988(4.0%) 0(0.0%) best-and-tied-at-points ...ore/alt-table.rkt:122:0 errors [170] 97.6% for-loop [174] 2.4% ------------------------------------------------------------------------------------------ option-on-expr [151] 100.0% [158] 6936(2.0%) 0(0.0%) sort-context-on-expr ...herbie/src/points.rkt:79:0 ??? [171] 100.0% ------------------------------------------------------------------------------------------ for-loop [100] 0.5% for-loop [98] 2.3% for-loop [94] 7.2% update-leader! [84] 8.8% loop! [101] 35.1% for-loop [148] 46.1% [159] 6588(1.9%) 6588(1.9%) update-en-expr ...herbie/src/core/egraph.rkt:211:0 ------------------------------------------------------------------------------------------ taylor-exp [129] 5.6% map [150] 26.6% loop [216] 67.8% [160] 818(0.2%) 46(0.0%) ??? ...ket/collects/racket/private/list.rkt:323:18 hash-ref! [193] 72.1% taylor-invert [177] 15.2% f94 [141] 7.1% ------------------------------------------------------------------------------------------ option-on-expr [151] 100.0% [161] 572(0.2%) 0(0.0%) pick-errors ...k/herbie/src/core/regimes.rkt:187:0 for-loop [172] 100.0% ------------------------------------------------------------------------------------------ map [150] 17.5% hash-ref! [193] 22.6% f94 [141] 59.9% [162] 504(0.1%) 124(0.0%) taylor ...tatlock/herbie/src/core/taylor.rkt:159:0 debug-print [211] 41.3% loop [216] 22.6% debug7 [214] 11.5% ------------------------------------------------------------------------------------------ exprs-to-branch-on [155] 100.0% [163] 392(0.1%) 0(0.0%) critical-subexpression ...rc/core/regimes.rkt:52:0 for-loop [173] 88.8% localize-error [47] 11.2% ------------------------------------------------------------------------------------------ unconstrained-domain->-projection [175] 39.1% ??? [152] 60.9% [164] 312(0.1%) 28(0.0%) get/build-late-neg-projection ...te/guts.rkt:691:0 unconstrained-domain->-projection [175] 51.9% ??? [176] 39.1% ------------------------------------------------------------------------------------------ map [150] 100.0% [165] 296(0.1%) 90(0.0%) simplify* ...tlock/herbie/src/core/reduce.rkt:20:0 variable? [85] 39.9% return/no-unsupplied [255] 29.7% ------------------------------------------------------------------------------------------ map [150] 100.0% [166] 226(0.1%) 114(0.0%) ??? /home/ztatlock/herbie/src/core/reduce.rkt:50:5 for-loop [179] 49.6% ------------------------------------------------------------------------------------------ ??? [152] 100.0% [167] 166(0.0%) 34(0.0%) ??? ...private/unconstrained-domain-arrow.rkt:69:2 get-blame-party-info [178] 79.5% ------------------------------------------------------------------------------------------ combine-mterms [156] 100.0% [168] 96(0.0%) 96(0.0%) for-loop ...tlock/herbie/src/core/reduce.rkt:184:5 ------------------------------------------------------------------------------------------ option-on-expr [151] 100.0% [169] 66(0.0%) 0(0.0%) err-lsts->split-indices .../core/regimes.rkt:238:0 add-splitpoint [180] 100.0% ------------------------------------------------------------------------------------------ run-improve50 [1] 0.7% option-on-expr [151] 1.0% loop [216] 1.3% composed [136] 5.0% best-and-tied-at-points [157] 91.6% [170] 14902(4.3%) 0(0.0%) errors /home/ztatlock/herbie/src/points.rkt:184:0 for-loop [181] 82.7% eval-prog [192] 17.3% ------------------------------------------------------------------------------------------ sort-context-on-expr [158] 100.0% [171] 6936(2.0%) 0(0.0%) ??? ...cket/collects/racket/private/sort.rkt:403:3 generic-sort/key [182] 84.7% loop [190] 14.4% ??? [191] 0.9% ------------------------------------------------------------------------------------------ pick-errors [161] 100.0% [172] 572(0.2%) 0(0.0%) for-loop ...lock/herbie/src/core/regimes.rkt:190:4 eval-prog [192] 92.0% ??? [223] 8.0% ------------------------------------------------------------------------------------------ critical-subexpression [163] 100.0% [173] 348(0.1%) 0(0.0%) for-loop ...lock/herbie/src/core/regimes.rkt:87:19 eval-prog [192] 87.9% ??? [223] 12.1% ------------------------------------------------------------------------------------------ best-and-tied-at-points [157] 100.0% [174] 334(0.1%) 334(0.1%) for-loop ...k/herbie/src/core/alt-table.rkt:124:16 ------------------------------------------------------------------------------------------ get/build-late-neg-projection [164] 100.0% [175] 284(0.1%) 40(0.0%) unconstrained-domain->-projection ...rrow.rkt:60:0 get/build-late-neg-projection [164] 85.9% ------------------------------------------------------------------------------------------ get/build-late-neg-projection [164] 100.0% [176] 244(0.1%) 42(0.0%) ??? ...cts/racket/contract/private/prop.rkt:314:12 build-compound-type-name [183] 82.8% ------------------------------------------------------------------------------------------ f94 [141] 18.4% ??? [160] 81.6% [177] 152(0.0%) 0(0.0%) taylor-invert .../herbie/src/core/taylor.rkt:308:0 simplify [201] 100.0% ------------------------------------------------------------------------------------------ ??? [167] 100.0% [178] 132(0.0%) 132(0.0%) get-blame-party-info ...ate/arrow-common.rkt:136:0 ------------------------------------------------------------------------------------------ ??? [166] 100.0% [179] 112(0.0%) 0(0.0%) for-loop ...atlock/herbie/src/core/reduce.rkt:51:7 pattern-match [184] 100.0% ------------------------------------------------------------------------------------------ err-lsts->split-indices [169] 100.0% [180] 66(0.0%) 36(0.0%) add-splitpoint ...erbie/src/core/regimes.rkt:251:2 for-loop [185] 45.5% ------------------------------------------------------------------------------------------ errors [170] 100.0% [181] 12330(3.5%) 778(0.2%) for-loop ...e/ztatlock/herbie/src/points.rkt:187:4 ??? [223] 86.9% ->flonum [234] 3.0% ulp-difference [228] 3.0% ??? [89] 0.8% ------------------------------------------------------------------------------------------ ??? [171] 100.0% [182] 5876(1.7%) 0(0.0%) generic-sort/key .../racket/private/sort.rkt:185:2 copying-mergesort [186] 86.4% loop [190] 13.6% ------------------------------------------------------------------------------------------ ??? [176] 100.0% [183] 202(0.1%) 172(0.0%) build-compound-type-name ...private/guts.rkt:448:0 contract-struct-name [188] 14.9% ------------------------------------------------------------------------------------------ for-loop [187] 50.0% for-loop [179] 50.0% [184] 112(0.0%) 0(0.0%) pattern-match .../herbie/src/core/matcher.rkt:47:0 for-loop [187] 50.0% variable? [85] 50.0% ------------------------------------------------------------------------------------------ add-splitpoint [180] 100.0% [185] 30(0.0%) 0(0.0%) for-loop ...lock/herbie/src/core/regimes.rkt:253:4 for-loop [189] 100.0% ------------------------------------------------------------------------------------------ generic-sort/key [182] 44.7% copying-mergesort [186] 55.3% [186] 5076(1.4%) 0(0.0%) copying-mergesort ...racket/private/sort.rkt:130:8 copying-mergesort [186] 55.3% loop [190] 33.1% jloop [5] 11.6% ------------------------------------------------------------------------------------------ pattern-match [184] 100.0% [187] 112(0.0%) 0(0.0%) for-loop ...tlock/herbie/src/core/matcher.rkt:65:9 pattern-match [184] 100.0% ------------------------------------------------------------------------------------------ build-compound-type-name [183] 100.0% [188] 30(0.0%) 30(0.0%) contract-struct-name ...ract/private/prop.rkt:89:0 ------------------------------------------------------------------------------------------ for-loop [185] 100.0% [189] 30(0.0%) 30(0.0%) for-loop ...lock/herbie/src/core/regimes.rkt:257:8 ------------------------------------------------------------------------------------------ generic-sort/key [182] 17.7% ??? [171] 22.1% copying-mergesort [186] 60.2% [190] 4528(1.3%) 0(0.0%) loop ...ket/collects/racket/private/sort.rkt:97:12 ??? [191] 100.0% ------------------------------------------------------------------------------------------ ??? [171] 0.9% jloop [5] 33.9% loop [190] 65.3% [191] 6936(2.0%) 0(0.0%) ??? /home/ztatlock/herbie/src/points.rkt:81:27 eval-prog [192] 88.0% ??? [223] 12.0% ------------------------------------------------------------------------------------------ for-loop [173] 2.6% for-loop [172] 4.5% loop [77] 7.6% make-exacts* [88] 10.4% errors [170] 22.2% ??? [191] 52.7% [192] 11582(3.3%) 3140(0.9%) eval-prog ...tatlock/herbie/src/programs.rkt:146:0 f94 [141] 42.4% hash-ref! [193] 15.1% ??? [194] 5.4% go [195] 4.4% ??? [198] 1.8% parse-app [196] 1.7% ??? [197] 1.7% new-lambda [199] 0.3% ------------------------------------------------------------------------------------------ for-loop [28] 0.2% taylor-sqrt [125] 0.7% for-loop [35] 0.8% first-nonzero-exp [139] 1.2% update-leader! [84] 1.9% localize-error [47] 2.6% ??? [160] 3.3% ??? [202] 3.5% for-loop [22] 3.7% eval-prog [192] 4.3% ??? [203] 4.3% for-loop [21] 4.6% loop [120] 6.2% loop [216] 9.0% ??? [200] 26.2% compile [78] 26.3% [193] 13196(3.8%) 6470(1.8%) hash-ref! ...racket/private/more-scheme.rkt:373:13 ??? [200] 39.3% simplify [201] 6.6% parse-loop12 [210] 5.2% ??? [6] 4.6% ??? [203] 4.3% ??? [7] 4.0% ??? [202] 3.5% bigfloat-hash [204] 3.2% f94 [141] 1.9% ??? [9] 0.8% ??? [10] 0.4% taylor [162] 0.4% ??? [12] 0.2% ------------------------------------------------------------------------------------------ eval-const-expr [20] 23.4% eval-prog [192] 76.6% [194] 820(0.2%) 34(0.0%) ??? ...cket/collects/racket/private/kw.rkt:1633:36 unpack242 [205] 95.9% ------------------------------------------------------------------------------------------ eval-prog [192] 100.0% [195] 506(0.1%) 106(0.0%) go .../collects/racket/private/qq-and-or.rkt:50:20 loop [206] 79.1% ------------------------------------------------------------------------------------------ eval-const-expr [20] 24.6% eval-prog [192] 42.8% [196] 472(0.1%) 408(0.1%) parse-app .../collects/racket/private/kw.rkt:951:2 loop [209] 13.6% ------------------------------------------------------------------------------------------ localize-error [47] 12.8% location-do [73] 30.2% eval-prog [192] 57.0% [197] 344(0.1%) 46(0.0%) ??? ...tract/private/arrow-higher-order.rkt:346:33 ??? [257] 43.6% pattern-substitute [208] 30.2% location-do [73] 12.8% ------------------------------------------------------------------------------------------ eval-prog [192] 100.0% [198] 212(0.1%) 90(0.0%) ??? ...collects/racket/private/qq-and-or.rkt:155:9 ??? [207] 57.5% ------------------------------------------------------------------------------------------ eval-prog [192] 100.0% [199] 36(0.0%) 0(0.0%) new-lambda ...ollects/racket/private/kw.rkt:679:11 loop [209] 100.0% ------------------------------------------------------------------------------------------ hash-ref! [193] 100.0% [200] 7094(2.0%) 1022(0.3%) ??? /home/ztatlock/herbie/src/programs.rkt:181:5 hash-ref! [193] 70.3% loop [216] 22.6% ------------------------------------------------------------------------------------------ taylor-exp [129] 1.8% for-loop [22] 2.9% loop [216] 3.5% taylor-invert [177] 4.6% for-loop [27] 9.6% hash-ref! [193] 77.5% [201] 3270(0.9%) 118(0.0%) simplify ...atlock/herbie/src/core/reduce.rkt:15:0 f94 [141] 54.2% debug-print [211] 18.5% parse-loop12 [210] 13.9% debug7 [214] 6.2% simplify-node [11] 3.6% ------------------------------------------------------------------------------------------ hash-ref! [193] 100.0% [202] 2144(0.6%) 0(0.0%) ??? ...e/ztatlock/herbie/src/core/taylor.rkt:43:15 hash-ref! [193] 100.0% ------------------------------------------------------------------------------------------ hash-ref! [193] 100.0% [203] 2080(0.6%) 0(0.0%) ??? ...e/ztatlock/herbie/src/core/taylor.rkt:64:15 hash-ref! [193] 100.0% ------------------------------------------------------------------------------------------ hash-ref! [193] 100.0% [204] 1278(0.4%) 0(0.0%) bigfloat-hash ...h/private/bigfloat/mpfr.rkt:165:0 bfcanonicalize [212] 70.3% sig+exp->bigfloat [215] 21.0% bigfloat->sig+exp [221] 8.8% ------------------------------------------------------------------------------------------ ??? [194] 100.0% [205] 786(0.2%) 122(0.0%) unpack242 ...private/arrow-higher-order.rkt:354:44 maybe-cons-kwd [213] 84.5% ------------------------------------------------------------------------------------------ go [195] 13.3% loop [206] 86.7% [206] 400(0.1%) 400(0.1%) loop ...llects/racket/private/qq-and-or.rkt:101:61 loop [206] 86.7% ------------------------------------------------------------------------------------------ ??? [198] 100.0% [207] 122(0.0%) 122(0.0%) ??? ...ollects/racket/private/qq-and-or.rkt:164:21 ------------------------------------------------------------------------------------------ ??? [197] 20.0% pattern-substitute [208] 80.0% [208] 104(0.0%) 0(0.0%) pattern-substitute ...ie/src/core/matcher.rkt:72:0 pattern-substitute [208] 80.0% ??? [131] 20.0% ------------------------------------------------------------------------------------------ new-lambda [199] 36.0% parse-app [196] 64.0% [209] 100(0.0%) 100(0.0%) loop .../collects/racket/private/stxcase.rkt:112:7 ------------------------------------------------------------------------------------------ f94 [141] 2.2% parse-loop12 [210] 9.6% append-map [24] 10.2% map [150] 15.0% simplify [201] 20.6% hash-ref! [193] 42.4% [210] 1826(0.5%) 772(0.2%) parse-loop12 ...s/racket/match/compiler.rkt:418:15 loop [216] 27.9% loop [219] 13.4% parse-loop12 [210] 9.6% f94 [141] 6.4% make-multiplication-node [222] 5.9% simplify-node [11] 2.2% location-do [73] 1.2% ------------------------------------------------------------------------------------------ for-loop [54] 5.9% for-loop [17] 7.0% taylor [162] 13.7% iterate-egraph!5 [30] 16.0% simplify-expr [16] 17.3% simplify [201] 40.0% [211] 1514(0.4%) 1146(0.3%) debug-print ...ztatlock/herbie/src/debug.rkt:107:0 for-loop [220] 24.3% ------------------------------------------------------------------------------------------ bigfloat-hash [204] 100.0% [212] 898(0.3%) 752(0.2%) bfcanonicalize .../private/bigfloat/mpfr.rkt:155:0 bigfloat->sig+exp [221] 16.3% ------------------------------------------------------------------------------------------ unpack242 [205] 100.0% [213] 664(0.2%) 114(0.0%) maybe-cons-kwd ...ate/arrow-higher-order.rkt:498:0 successfully-got-the-right-kind-of-function [218] 41.6% arrow-higher-order:lnp [217] 41.3% ------------------------------------------------------------------------------------------ taylor [162] 13.1% iterate-egraph!5 [30] 41.2% simplify [201] 45.7% [214] 442(0.1%) 232(0.1%) debug7 /home/ztatlock/herbie/src/debug.rkt:102:0 ??? [254] 27.6% return/no-unsupplied [255] 19.9% ------------------------------------------------------------------------------------------ bigfloat-hash [204] 100.0% [215] 268(0.1%) 268(0.1%) sig+exp->bigfloat ...ivate/bigfloat/mpfr.rkt:385:0 ------------------------------------------------------------------------------------------ ??? [62] 0.0% taylor [162] 0.3% option-on-expr [151] 0.4% make-exacts* [88] 0.5% map [150] 0.7% parse-loop12 [210] 0.8% map-enodes [44] 1.6% ??? [200] 3.8% extract-alt [33] 5.3% for-loop [72] 6.2% match-e [64] 7.2% loop! [101] 9.7% loop [216] 63.5% [216] 42664(12.2%) 3950(1.1%) loop ...cket/collects/racket/private/map.rkt:25:19 loop [216] 63.5% loop! [101] 9.7% simplify [3] 5.3% hash-ref! [193] 3.7% foldl [224] 2.8% loop [226] 2.2% curried [225] 2.2% for-loop [4] 1.5% ??? [223] 1.1% ??? [160] 0.8% errors [170] 0.4% simplify [201] 0.3% ->flonum [234] 0.1% set-precompute! [229] 0.0% ??? [235] 0.0% ------------------------------------------------------------------------------------------ for-loop [102] 6.0% ??? [89] 11.7% maybe-cons-kwd [213] 29.2% ??? [83] 53.1% [217] 938(0.3%) 294(0.1%) arrow-higher-order:lnp ...w-higher-order.rkt:597:7 ??? [227] 68.7% ------------------------------------------------------------------------------------------ for-loop [102] 23.4% ??? [83] 35.8% maybe-cons-kwd [213] 40.8% [218] 676(0.2%) 466(0.1%) successfully-got-the-right-kind-of-function ...9:4 arity-checking-wrapper [230] 31.1% ------------------------------------------------------------------------------------------ map [150] 0.9% parse-loop12 [210] 1.3% loop [219] 97.8% [219] 414(0.1%) 0(0.0%) loop ...cket/collects/racket/private/map.rkt:36:19 loop [219] 97.8% ??? [13] 0.9% ->flonum [234] 0.8% ulp-difference [228] 0.5% ------------------------------------------------------------------------------------------ debug-print [211] 100.0% [220] 368(0.1%) 368(0.1%) for-loop /home/ztatlock/herbie/src/debug.rkt:113:2 ------------------------------------------------------------------------------------------ bigfloat-hash [204] 43.4% bfcanonicalize [212] 56.6% [221] 258(0.1%) 112(0.0%) bigfloat->sig+exp ...ivate/bigfloat/mpfr.rkt:370:0 size+limbs->integer [232] 56.6% ------------------------------------------------------------------------------------------ parse-loop12 [210] 100.0% [222] 166(0.0%) 0(0.0%) make-multiplication-node .../core/reduce.rkt:219:0 make-multiplication-subnode [231] 100.0% ------------------------------------------------------------------------------------------ for-loop [173] 0.2% for-loop [172] 0.2% map [150] 1.1% ??? [191] 3.6% for-loop [181] 45.8% loop [216] 49.2% [223] 23414(6.7%) 616(0.2%) ??? /home/ztatlock/herbie/src/programs.rkt:152:4 ??? [233] 86.3% ??? [235] 7.7% ->flonum [234] 3.4% ------------------------------------------------------------------------------------------ for-loop [72] 17.1% loop [216] 82.9% [224] 2394(0.7%) 668(0.2%) foldl ...et/collects/racket/private/list.rkt:229:4 merge2 [236] 67.8% ??? [240] 4.3% ------------------------------------------------------------------------------------------ expr->enode [48] 1.3% for-loop [4] 16.4% for-loop [72] 21.6% loop [216] 60.7% [225] 2238(0.6%) 2238(0.6%) curried ...cket/collects/racket/function.rkt:71:18 ------------------------------------------------------------------------------------------ for-loop [72] 19.9% loop [216] 80.1% [226] 1550(0.4%) 1550(0.4%) loop ...e/racket/collects/racket/function.rkt:53:6 ------------------------------------------------------------------------------------------ arrow-higher-order:lnp [217] 100.0% [227] 644(0.2%) 644(0.2%) ??? ...et/contract/private/arity-checking.rkt:19:2 ------------------------------------------------------------------------------------------ loop [219] 24.5% for-loop [181] 75.5% [228] 490(0.1%) 0(0.0%) ulp-difference ...atlock/herbie/src/float.rkt:19:0 ??? [251] 100.0% ------------------------------------------------------------------------------------------ loop [216] 100.0% [229] 308(0.1%) 124(0.0%) set-precompute! ...bie/src/core/simplify.rkt:160:0 make-sequence [237] 59.7% ------------------------------------------------------------------------------------------ successfully-got-the-right-kind-of-function [218]100.0% [230] 210(0.1%) 32(0.0%) arity-checking-wrapper ...w-higher-order.rkt:402:0 matches-arity-exactly? [238] 84.8% ------------------------------------------------------------------------------------------ make-multiplication-node [222] 100.0% [231] 166(0.0%) 0(0.0%) make-multiplication-subnode ...re/reduce.rkt:229:0 group-by68 [239] 71.1% for-loop [241] 28.9% ------------------------------------------------------------------------------------------ bigfloat->sig+exp [221] 100.0% [232] 146(0.0%) 146(0.0%) size+limbs->integer ...vate/bigfloat/gmp.rkt:103:0 ------------------------------------------------------------------------------------------ ??? [223] 100.0% [233] 20210(5.8%) 10930(3.1%) ??? ...acket/collects/racket/private/kw.rkt:444:14 ??? [250] 20.7% bf* [242] 10.1% ??? [244] 7.1% ??? [245] 5.3% ??? [257] 2.0% ------------------------------------------------------------------------------------------ ??? [13] 4.3% loop [219] 7.1% ??? [89] 7.7% for-loop [181] 14.3% ??? [223] 30.4% loop [216] 36.1% [234] 2584(0.7%) 388(0.1%) ->flonum .../ztatlock/herbie/src/programs.rkt:34:0 ??? [251] 81.7% ??? [247] 3.3% ------------------------------------------------------------------------------------------ ??? [89] 3.3% loop [216] 6.0% ??? [223] 90.6% [235] 1988(0.6%) 92(0.0%) ??? ...contract/private/../../private/kw.rkt:761:9 real->bigfloat [243] 92.1% integer->bigfloat [248] 3.3% ------------------------------------------------------------------------------------------ foldl [224] 100.0% [236] 1622(0.5%) 1622(0.5%) merge2 ...ztatlock/herbie/src/core/ematch.rkt:31:0 ------------------------------------------------------------------------------------------ ??? [140] 10.8% merge-egraph-nodes! [74] 10.8% set-precompute! [229] 17.5% update-leader! [84] 24.9% for-loop [52] 36.1% [237] 1054(0.3%) 924(0.3%) make-sequence ...ects/racket/private/for.rkt:509:2 ??? [246] 12.3% ------------------------------------------------------------------------------------------ arity-checking-wrapper [230] 100.0% [238] 178(0.1%) 178(0.1%) matches-arity-exactly? ...te/arrow-common.rkt:70:0 ------------------------------------------------------------------------------------------ make-multiplication-subnode [231] 100.0% [239] 118(0.0%) 118(0.0%) group-by68 ...acket/collects/racket/list.rkt:749:0 ------------------------------------------------------------------------------------------ foldl [224] 100.0% [240] 104(0.0%) 0(0.0%) ??? /home/ztatlock/herbie/src/alternative.rkt:66:9 ??? [89] 100.0% ------------------------------------------------------------------------------------------ make-multiplication-subnode [231] 100.0% [241] 48(0.0%) 48(0.0%) for-loop ...tlock/herbie/src/core/reduce.rkt:231:3 ------------------------------------------------------------------------------------------ ??? [233] 100.0% [242] 2042(0.6%) 148(0.0%) bf* ...ath/private/bigfloat/bigfloat-mpfr.rkt:95:0 ??? [250] 92.8% ------------------------------------------------------------------------------------------ ??? [235] 100.0% [243] 1830(0.5%) 1378(0.4%) real->bigfloat .../private/bigfloat/mpfr.rkt:451:0 ??? [260] 24.7% ------------------------------------------------------------------------------------------ ??? [233] 100.0% [244] 1438(0.4%) 1438(0.4%) ??? ...rivate/unconstrained-domain-arrow.rkt:40:13 ------------------------------------------------------------------------------------------ ??? [233] 100.0% [245] 1074(0.3%) 272(0.1%) ??? ...tatlock/herbie/src/syntax/syntax.rkt:118:17 ??? [251] 74.7% ------------------------------------------------------------------------------------------ make-sequence [237] 100.0% [246] 130(0.0%) 104(0.0%) ??? ...acket/collects/racket/private/for.rkt:429:7 custom-in-set [252] 20.0% ------------------------------------------------------------------------------------------ ->flonum [234] 100.0% [247] 86(0.0%) 0(0.0%) ??? ...-racket/utils/simple-result-arrow.rkt:60:15 ??? [260] 100.0% ------------------------------------------------------------------------------------------ ??? [235] 100.0% [248] 66(0.0%) 66(0.0%) integer->bigfloat ...ivate/bigfloat/mpfr.rkt:399:0 ------------------------------------------------------------------------------------------ location-do [73] 4.4% ??? [83] 6.9% ??? [90] 87.6% [249] 7566(2.2%) 3050(0.9%) ??? ...cts/racket/contract/private/list.rkt:187:10 ??? [90] 28.9% for-loop [256] 26.1% ??? [257] 3.6% ??? [258] 1.1% ------------------------------------------------------------------------------------------ bf* [242] 31.2% ??? [233] 68.8% [250] 6068(1.7%) 1026(0.3%) ??? ...-racket/utils/simple-result-arrow.rkt:39:12 bfmul [253] 83.1% ------------------------------------------------------------------------------------------ *rules* [8] 2.9% ormap [114] 3.2% for-loop [98] 5.4% ulp-difference [228] 12.8% ??? [245] 20.9% ->flonum [234] 54.9% [251] 3840(1.1%) 2174(0.6%) ??? /home/ztatlock/herbie/src/config.rkt:48:0 ??? [254] 27.6% return/no-unsupplied [255] 15.8% ------------------------------------------------------------------------------------------ ??? [246] 2.1% ??? [104] 11.7% match-e [64] 86.1% [252] 1226(0.3%) 1226(0.3%) custom-in-set ...acket/private/set-types.rkt:577:0 ------------------------------------------------------------------------------------------ ??? [250] 100.0% [253] 5042(1.4%) 3446(1.0%) bfmul ...-lib/math/private/bigfloat/mpfr.rkt:819:4 ??? [260] 31.7% ------------------------------------------------------------------------------------------ debug7 [214] 2.8% ??? [251] 24.2% location-do [73] 25.7% ??? [91] 47.3% [254] 4366(1.2%) 842(0.2%) ??? ...racket/collects/racket/private/kw.rkt:761:9 ??? [259] 62.1% ??? [258] 18.6% ------------------------------------------------------------------------------------------ simplify* [165] 4.0% debug7 [214] 4.0% location-do [73] 24.5% ??? [251] 27.3% ??? [91] 40.3% [255] 2226(0.6%) 1564(0.4%) return/no-unsupplied ...ct/private/arr-i.rkt:533:0 filter [261] 29.7% ------------------------------------------------------------------------------------------ ??? [249] 100.0% [256] 1974(0.6%) 900(0.3%) for-loop ...acket/contract/private/list.rkt:190:15 ??? [90] 54.4% ------------------------------------------------------------------------------------------ for-loop [121] 8.9% ??? [197] 13.9% ??? [135] 14.1% ??? [249] 25.4% ??? [233] 37.8% [257] 1080(0.3%) 708(0.2%) ??? ...ects/racket/contract/private/prop.rkt:493:4 ??? [262] 34.4% ------------------------------------------------------------------------------------------ ??? [135] 0.8% ??? [249] 1.7% ??? [83] 1.9% ??? [131] 6.8% ??? [154] 8.2% ??? [254] 16.8% ??? [89] 30.8% ??? [90] 32.1% [258] 4856(1.4%) 1556(0.4%) ??? ...ects/racket/contract/private/guts.rkt:644:8 ??? [131] 38.3% contract? [263] 19.9% dict? [264] 9.8% ------------------------------------------------------------------------------------------ ??? [254] 100.0% [259] 2710(0.8%) 2438(0.7%) ??? ...s/racket/contract/private/arr-i.rkt:1233:27 ??? [266] 10.0% ------------------------------------------------------------------------------------------ ??? [247] 4.0% real->bigfloat [243] 21.2% bfmul [253] 74.8% [260] 2134(0.6%) 2134(0.6%) ??? .../share/racket/collects/ffi/unsafe.rkt:861:4 ------------------------------------------------------------------------------------------ one-iter [41] 6.1% for-loop [52] 11.0% match-e [64] 12.1% return/no-unsupplied [255] 31.8% for-loop [72] 39.1% [261] 2082(0.6%) 2082(0.6%) filter ...t/collects/racket/private/list.rkt:256:2 ------------------------------------------------------------------------------------------ ??? [257] 100.0% [262] 372(0.1%) 96(0.0%) ??? ...lects/racket/contract/private/orc.rkt:83:14 ??? [265] 74.2% ------------------------------------------------------------------------------------------ ??? [258] 100.0% [263] 964(0.3%) 964(0.3%) contract? ...acket/contract/private/guts.rkt:109:0 ------------------------------------------------------------------------------------------ location-do [73] 28.3% ??? [258] 71.7% [264] 664(0.2%) 664(0.2%) dict? ...ollects/racket/private/generic.rkt:146:11 ------------------------------------------------------------------------------------------ ??? [262] 100.0% [265] 276(0.1%) 276(0.1%) ??? ...ects/racket/contract/private/list.rkt:141:5 ------------------------------------------------------------------------------------------ ??? [259] 100.0% [266] 272(0.1%) 272(0.1%) ??? ...ects/racket/contract/private/prop.rkt:256:4 ------------------------------------------------------------------------------------------