Profiling results ----------------- Total cpu time observed: 164352ms (out of 166068ms) Number of samples taken: 693 (once every 237ms) (Hiding functions with self<1.0% and local<2.0%: 12 of 204 hidden) ========================================================================= Caller Idx Total Self Name+src Local% ms(pct) ms(pct) Callee ========================================================================= ??? [47] 100.0% [1] 147046(89.5%) 0(0.0%) profile-thunk14 ...t/pkgs/profile-lib/main.rkt:9:0 run [12] 100.0% ------------------------------------------------------------------------- ??? [47] 100.0% [2] 86522(52.6%) 0(0.0%) run-improve58 ...ock/herbie/src/mainloop.rkt:242:0 for-loop [13] 74.0% get-final-combination [15] 24.4% loop [60] 1.4% setup-prog [21] 0.2% ------------------------------------------------------------------------- simplify-alt [29] 0.3% loop [121] 7.2% ??? [47] 92.5% [3] 61304(37.3%) 788(0.5%) simplify ...lock/herbie/src/core/simplify.rkt:39:0 simplify-expr [14] 60.2% for-loop [16] 24.6% iterate-egraph!5 [24] 13.0% loop [27] 1.0% ------------------------------------------------------------------------- copying-mergesort [74] 100.0% [4] 3632(2.2%) 0(0.0%) jloop ...et/collects/racket/private/sort.rkt:85:19 ??? [107] 100.0% ------------------------------------------------------------------------- hash-ref! [137] 100.0% [5] 2748(1.7%) 0(0.0%) ??? ...e/ztatlock/herbie/src/core/taylor.rkt:42:15 hash-ref! [137] 86.4% ??? [28] 13.6% ------------------------------------------------------------------------- hash-ref! [137] 100.0% [6] 2054(1.2%) 0(0.0%) ??? .../ztatlock/herbie/src/core/taylor.rkt:295:23 for-loop [17] 100.0% ------------------------------------------------------------------------- hash-ref! [137] 100.0% [7] 1076(0.7%) 0(0.0%) ??? .../ztatlock/herbie/src/core/taylor.rkt:285:26 for-loop [18] 100.0% ------------------------------------------------------------------------- ??? [131] 27.6% f6 [174] 72.4% [8] 798(0.5%) 0(0.0%) taylor-quotient ...erbie/src/core/taylor.rkt:328:0 first-nonzero-exp [19] 72.4% simplify [129] 27.6% ------------------------------------------------------------------------- hash-ref! [137] 30.0% f6 [174] 70.0% [9] 594(0.4%) 0(0.0%) taylor-invert .../herbie/src/core/taylor.rkt:312:0 first-nonzero-exp [19] 70.0% simplify [129] 30.0% ------------------------------------------------------------------------- map [106] 100.0% [10] 416(0.3%) 196(0.1%) simplify-node ...k/herbie/src/core/reduce.rkt:41:0 append-map [20] 52.9% ------------------------------------------------------------------------- hash-ref! [137] 100.0% [11] 180(0.1%) 0(0.0%) ??? .../ztatlock/herbie/src/core/taylor.rkt:392:23 for-loop [22] 100.0% ------------------------------------------------------------------------- profile-thunk14 [1] 100.0% [12] 147046(89.5%) 0(0.0%) run ...share/racket/pkgs/profile-lib/main.rkt:31:2 ??? [47] 100.0% ------------------------------------------------------------------------- run-improve58 [2] 100.0% [13] 64048(39.0%) 0(0.0%) for-loop ...ztatlock/herbie/src/mainloop.rkt:253:8 run-iter! [23] 100.0% ------------------------------------------------------------------------- simplify [3] 100.0% [14] 36890(22.4%) 0(0.0%) simplify-expr ...herbie/src/core/simplify.rkt:68:0 iterate-egraph!5 [24] 93.0% loop [27] 7.0% ------------------------------------------------------------------------- run-improve58 [2] 100.0% [15] 21072(12.8%) 0(0.0%) get-final-combination ...ie/src/mainloop.rkt:269:0 split-table [25] 79.0% extract-alt [26] 21.0% ------------------------------------------------------------------------- simplify [3] 100.0% [16] 15062(9.2%) 422(0.3%) for-loop ...ock/herbie/src/core/simplify.rkt:61:12 iterate-egraph!5 [24] 95.9% loop [27] 1.3% ------------------------------------------------------------------------- ??? [6] 100.0% [17] 2054(1.2%) 438(0.3%) for-loop ...lock/herbie/src/core/taylor.rkt:298:27 hash-ref! [137] 89.3% ------------------------------------------------------------------------- ??? [7] 100.0% [18] 1076(0.7%) 0(0.0%) for-loop ...lock/herbie/src/core/taylor.rkt:285:52 ??? [28] 61.4% hash-ref! [137] 38.6% ------------------------------------------------------------------------- taylor-invert [9] 41.9% taylor-quotient [8] 58.1% [19] 994(0.6%) 0(0.0%) first-nonzero-exp ...bie/src/core/taylor.rkt:260:0 hash-ref! [137] 77.9% simplify [129] 22.1% ------------------------------------------------------------------------- simplify-node [10] 100.0% [20] 220(0.1%) 0(0.0%) append-map ...acket/collects/racket/list.rkt:565:2 parse-loop12 [155] 100.0% ------------------------------------------------------------------------- run-improve58 [2] 100.0% [21] 196(0.1%) 0(0.0%) setup-prog /home/ztatlock/herbie/src/glue.rkt:46:0 simplify-alt [29] 100.0% ------------------------------------------------------------------------- ??? [11] 100.0% [22] 180(0.1%) 0(0.0%) for-loop ...lock/herbie/src/core/taylor.rkt:396:33 for-loop [30] 100.0% ------------------------------------------------------------------------- for-loop [13] 100.0% [23] 64048(39.0%) 0(0.0%) run-iter! ...tatlock/herbie/src/mainloop.rkt:223:0 simplify! [31] 88.5% gen-series! [34] 8.0% finalize-iter! [36] 2.6% choose-best-alt! [37] 0.3% gen-rewrites! [38] 0.3% ------------------------------------------------------------------------- simplify [3] 14.0% for-loop [16] 25.5% simplify-expr [14] 60.5% [24] 56710(34.5%) 242(0.1%) iterate-egraph!5 ...bie/src/core/simplify.rkt:95:0 one-iter [32] 97.7% ------------------------------------------------------------------------- get-final-combination [15] 100.0% [25] 16642(10.1%) 0(0.0%) split-table .../ztatlock/herbie/src/glue.rkt:171:0 infer-splitpoints4 [33] 94.8% ??? [45] 5.2% ------------------------------------------------------------------------- get-final-combination [15] 100.0% [26] 4430(2.7%) 0(0.0%) extract-alt ...e/ztatlock/herbie/src/glue.rkt:57:0 loop [121] 100.0% ------------------------------------------------------------------------- for-loop [16] 6.0% simplify [3] 18.3% simplify-expr [14] 75.8% [27] 3384(2.1%) 0(0.0%) loop ...tatlock/herbie/src/core/simplify.rkt:203:2 pass [35] 100.0% ------------------------------------------------------------------------- ??? [5] 29.8% for-loop [18] 70.2% [28] 1254(0.8%) 0(0.0%) ??? .../ztatlock/herbie/src/core/taylor.rkt:288:19 hash-ref! [137] 100.0% ------------------------------------------------------------------------- setup-prog [21] 100.0% [29] 196(0.1%) 0(0.0%) simplify-alt .../ztatlock/herbie/src/glue.rkt:84:0 simplify [3] 100.0% ------------------------------------------------------------------------- for-loop [22] 100.0% [30] 180(0.1%) 0(0.0%) for-loop ...lock/herbie/src/core/taylor.rkt:398:39 hash-ref! [137] 100.0% ------------------------------------------------------------------------- run-iter! [23] 100.0% [31] 56678(34.5%) 0(0.0%) simplify! ...tatlock/herbie/src/mainloop.rkt:162:0 for-loop [39] 100.0% ------------------------------------------------------------------------- iterate-egraph!5 [24] 100.0% [32] 55426(33.7%) 1550(0.9%) one-iter ...ock/herbie/src/core/simplify.rkt:106:0 for-loop [40] 64.8% loop [41] 30.9% apply-match [48] 1.5% ------------------------------------------------------------------------- split-table [25] 100.0% [33] 15776(9.6%) 0(0.0%) infer-splitpoints4 ...ie/src/core/regimes.rkt:19:0 option-on-expr [42] 77.1% loop [121] 22.9% ------------------------------------------------------------------------- run-iter! [23] 100.0% [34] 5116(3.1%) 0(0.0%) gen-series! ...tlock/herbie/src/mainloop.rkt:134:0 for-loop [43] 100.0% ------------------------------------------------------------------------- loop [27] 100.0% [35] 3384(2.1%) 200(0.1%) pass ...tatlock/herbie/src/core/simplify.rkt:193:2 for-loop [44] 94.1% ------------------------------------------------------------------------- run-iter! [23] 100.0% [36] 1670(1.0%) 0(0.0%) finalize-iter! ...ck/herbie/src/mainloop.rkt:177:0 ??? [45] 100.0% ------------------------------------------------------------------------- run-iter! [23] 100.0% [37] 200(0.1%) 0(0.0%) choose-best-alt! .../herbie/src/mainloop.rkt:120:0 ??? [45] 100.0% ------------------------------------------------------------------------- run-iter! [23] 100.0% [38] 196(0.1%) 0(0.0%) gen-rewrites! ...ock/herbie/src/mainloop.rkt:148:0 for-loop [46] 100.0% ------------------------------------------------------------------------- simplify! [31] 100.0% [39] 56678(34.5%) 0(0.0%) for-loop ...ztatlock/herbie/src/mainloop.rkt:166:6 ??? [47] 100.0% ------------------------------------------------------------------------- for-loop [40] 48.2% one-iter [32] 51.8% [40] 35914(21.9%) 7492(4.6%) for-loop ...ck/herbie/src/core/simplify.rkt:116:12 for-loop [40] 48.2% match-e [61] 39.0% ??? [110] 0.6% ------------------------------------------------------------------------- one-iter [32] 100.0% [41] 17130(10.4%) 604(0.4%) loop ...cket/collects/racket/private/map.rkt:53:19 apply-match [48] 96.5% ------------------------------------------------------------------------- loop [121] 22.9% infer-splitpoints4 [33] 77.1% [42] 15776(9.6%) 0(0.0%) option-on-expr ...erbie/src/core/regimes.rkt:106:0 sort-context-on-expr [49] 91.7% pick-errors [55] 4.3% err-lsts->split-indices [56] 2.8% loop [121] 1.3% ------------------------------------------------------------------------- gen-series! [34] 100.0% [43] 5116(3.1%) 0(0.0%) for-loop ...ztatlock/herbie/src/mainloop.rkt:140:7 taylor-alt [50] 100.0% ------------------------------------------------------------------------- pass [35] 100.0% [44] 3184(1.9%) 0(0.0%) for-loop ...ck/herbie/src/core/simplify.rkt:196:29 argmin [51] 54.2% for-loop [53] 33.2% make-sequence [114] 6.3% loop [58] 6.3% ------------------------------------------------------------------------- debug7 [187] 6.2% choose-best-alt! [37] 6.9% split-table [25] 29.7% finalize-iter! [36] 57.3% [45] 2916(1.8%) 0(0.0%) ??? ...contract/private/arrow-val-first.rkt:357:18 for-loop [52] 57.3% split-atab [54] 29.7% atab-pick-alt8 [57] 6.9% ??? [177] 6.2% ------------------------------------------------------------------------- gen-rewrites! [38] 100.0% [46] 196(0.1%) 0(0.0%) for-loop ...tatlock/herbie/src/mainloop.rkt:153:11 ??? [59] 100.0% ------------------------------------------------------------------------- for-loop [39] 12.8% run [12] 42.9% [47] 150024(91.3%) 0(0.0%) ??? ...lects/racket/private/more-scheme.rkt:261:28 profile-thunk14 [1] 42.9% run-improve58 [2] 22.9% loop [60] 21.4% simplify [3] 12.8% ------------------------------------------------------------------------- one-iter [32] 4.8% loop [41] 95.2% [48] 17358(10.6%) 1014(0.6%) apply-match .../herbie/src/core/simplify.rkt:122:2 merge-egraph-nodes! [75] 31.1% match-e [61] 30.6% for-loop [64] 13.1% loop! [128] 11.2% substitute-e [79] 7.0% mk-enode! [95] 1.2% ------------------------------------------------------------------------- option-on-expr [42] 100.0% [49] 14462(8.8%) 0(0.0%) sort-context-on-expr ...herbie/src/points.rkt:50:0 sort [62] 100.0% ------------------------------------------------------------------------- for-loop [43] 100.0% [50] 5116(3.1%) 0(0.0%) taylor-alt ...e/ztatlock/herbie/src/glue.rkt:142:0 for-loop [63] 100.0% ------------------------------------------------------------------------- for-loop [44] 100.0% [51] 1726(1.1%) 0(0.0%) argmin ...re/racket/collects/racket/list.rkt:743:0 expression-cost [65] 100.0% ------------------------------------------------------------------------- ??? [45] 100.0% [52] 1670(1.0%) 0(0.0%) for-loop ...ock/herbie/src/core/alt-table.rkt:51:2 atab-add-altn [66] 100.0% ------------------------------------------------------------------------- for-loop [44] 100.0% [53] 1058(0.6%) 1058(0.6%) for-loop ...ck/herbie/src/core/simplify.rkt:183:13 ------------------------------------------------------------------------- ??? [45] 100.0% [54] 866(0.5%) 0(0.0%) split-atab ...k/herbie/src/core/alt-table.rkt:74:0 for-loop [67] 100.0% ------------------------------------------------------------------------- option-on-expr [42] 100.0% [55] 678(0.4%) 0(0.0%) pick-errors ...k/herbie/src/core/regimes.rkt:173:0 for-loop [68] 100.0% ------------------------------------------------------------------------- option-on-expr [42] 100.0% [56] 434(0.3%) 0(0.0%) err-lsts->split-indices .../core/regimes.rkt:224:0 add-splitpoint [69] 100.0% ------------------------------------------------------------------------- ??? [45] 100.0% [57] 200(0.1%) 0(0.0%) atab-pick-alt8 ...rbie/src/core/alt-table.rkt:54:0 ??? [70] 100.0% ------------------------------------------------------------------------- for-loop [44] 100.0% [58] 200(0.1%) 0(0.0%) loop ...hare/racket/collects/racket/list.rkt:729:4 expression-cost [65] 100.0% ------------------------------------------------------------------------- for-loop [46] 100.0% [59] 196(0.1%) 0(0.0%) ??? /home/ztatlock/herbie/src/alternative.rkt:90:0 rewriter [71] 100.0% ------------------------------------------------------------------------- run-improve58 [2] 1.9% ??? [47] 98.1% [60] 64708(39.4%) 0(0.0%) loop /home/ztatlock/herbie/src/points.rkt:122:2 loop [72] 49.1% make-exacts* [88] 33.7% loop [89] 16.9% for-loop [83] 0.3% ------------------------------------------------------------------------- apply-match [48] 11.5% for-loop [90] 16.7% for-loop [40] 71.8% [61] 33292(20.3%) 14180(8.6%) match-e ...tatlock/herbie/src/core/ematch.rkt:46:0 for-loop [73] 45.3% for-loop [90] 11.0% loop [121] 3.2% list-cartesian-product [94] 2.7% curry* [84] 0.3% ------------------------------------------------------------------------- sort-context-on-expr [49] 100.0% [62] 14462(8.8%) 0(0.0%) sort ...ket/collects/racket/private/sort.rkt:213:0 copying-mergesort [74] 69.0% loop [91] 31.0% ------------------------------------------------------------------------- taylor-alt [50] 100.0% [63] 5116(3.1%) 0(0.0%) for-loop /home/ztatlock/herbie/src/glue.rkt:144:2 location-do [76] 100.0% ------------------------------------------------------------------------- apply-match [48] 100.0% [64] 2266(1.4%) 216(0.1%) for-loop ...ck/herbie/src/core/simplify.rkt:136:10 loop! [128] 55.4% substitute-e [79] 17.7% merge-egraph-nodes! [75] 17.3% ------------------------------------------------------------------------- loop [58] 10.4% argmin [51] 89.6% [65] 1926(1.2%) 0(0.0%) expression-cost ...k/herbie/src/programs.rkt:212:0 compile [77] 100.0% ------------------------------------------------------------------------- for-loop [52] 100.0% [66] 1670(1.0%) 0(0.0%) atab-add-altn ...rbie/src/core/alt-table.rkt:208:0 best-and-tied-at-points [78] 100.0% ------------------------------------------------------------------------- split-atab [54] 100.0% [67] 866(0.5%) 0(0.0%) for-loop ...ock/herbie/src/core/alt-table.rkt:75:2 for-loop [80] 74.4% for-loop [82] 25.6% ------------------------------------------------------------------------- pick-errors [55] 100.0% [68] 678(0.4%) 0(0.0%) for-loop ...lock/herbie/src/core/regimes.rkt:176:4 eval-prog [127] 100.0% ------------------------------------------------------------------------- err-lsts->split-indices [56] 100.0% [69] 434(0.3%) 0(0.0%) add-splitpoint ...erbie/src/core/regimes.rkt:237:2 for-loop [81] 100.0% ------------------------------------------------------------------------- atab-pick-alt8 [57] 100.0% [70] 200(0.1%) 0(0.0%) ??? ...tract/private/arrow-higher-order.rkt:369:33 best-alt [85] 100.0% ------------------------------------------------------------------------- ??? [59] 33.3% matcher [105] 66.7% [71] 196(0.1%) 0(0.0%) rewriter ...lock/herbie/src/core/matcher.rkt:123:2 for-loop [87] 66.7% *rules* [86] 33.3% ------------------------------------------------------------------------- loop [60] 100.0% [72] 31756(19.3%) 0(0.0%) loop /home/ztatlock/herbie/src/points.rkt:93:2 loop [89] 55.6% make-exacts* [88] 39.5% eval-prog [127] 4.9% ------------------------------------------------------------------------- match-e [61] 100.0% [73] 18436(11.2%) 7742(4.7%) for-loop ...tlock/herbie/src/core/ematch.rkt:59:11 for-loop [90] 45.6% list-cartesian-product [94] 12.9% loop [121] 4.8% ------------------------------------------------------------------------- sort [62] 42.9% copying-mergesort [74] 57.1% [74] 9982(6.1%) 0(0.0%) copying-mergesort .../racket/private/sort.rkt:91:4 copying-mergesort [74] 57.1% loop [91] 33.8% jloop [4] 9.1% ------------------------------------------------------------------------- merge-egraph-nodes! [75] 3.6% for-loop [64] 6.8% apply-match [48] 87.7% [75] 5794(3.5%) 0(0.0%) merge-egraph-nodes! ...e/src/core/egraph.rkt:152:0 update-leader! [93] 64.4% loop! [128] 19.9% for-loop [98] 6.8% merge-egraph-nodes! [75] 3.6% enode-merge! [102] 3.5% ------------------------------------------------------------------------- location-do [76] 18.9% for-loop [63] 81.1% [76] 5116(3.1%) 0(0.0%) location-do ...tlock/herbie/src/programs.rkt:129:0 approximate9 [92] 81.1% location-do [76] 18.9% ------------------------------------------------------------------------- expression-cost [65] 100.0% [77] 1926(1.2%) 0(0.0%) compile .../ztatlock/herbie/src/programs.rkt:189:0 hash-ref! [137] 100.0% ------------------------------------------------------------------------- atab-add-altn [66] 100.0% [78] 1670(1.0%) 242(0.1%) best-and-tied-at-points ...ore/alt-table.rkt:122:0 errors [123] 73.4% for-loop [101] 12.1% ------------------------------------------------------------------------- substitute-e [79] 8.3% for-loop [64] 24.8% apply-match [48] 67.0% [79] 1624(1.0%) 202(0.1%) substitute-e ...ck/herbie/src/core/ematch.rkt:71:0 mk-enode! [95] 87.6% substitute-e [79] 8.3% ------------------------------------------------------------------------- for-loop [67] 100.0% [80] 644(0.4%) 0(0.0%) for-loop ...ck/herbie/src/core/alt-table.rkt:80:53 loop [96] 100.0% ------------------------------------------------------------------------- add-splitpoint [69] 100.0% [81] 434(0.3%) 0(0.0%) for-loop ...lock/herbie/src/core/regimes.rkt:239:4 for-loop [97] 100.0% ------------------------------------------------------------------------- for-loop [67] 100.0% [82] 222(0.1%) 0(0.0%) for-loop ...ck/herbie/src/core/alt-table.rkt:76:45 ??? [111] 100.0% ------------------------------------------------------------------------- loop [60] 100.0% [83] 218(0.1%) 0(0.0%) for-loop .../ztatlock/herbie/src/points.rkt:128:18 for-loop [99] 100.0% ------------------------------------------------------------------------- match-e [61] 100.0% [84] 202(0.1%) 0(0.0%) curry* ...racket/collects/racket/function.rkt:44:2 procedure-arity [100] 100.0% ------------------------------------------------------------------------- ??? [70] 100.0% [85] 200(0.1%) 0(0.0%) best-alt /home/ztatlock/herbie/src/glue.rkt:79:0 loop [103] 100.0% ------------------------------------------------------------------------- rewriter [71] 100.0% [86] 196(0.1%) 0(0.0%) *rules* ...tlock/herbie/src/syntax/rules.rkt:296:0 for-loop [104] 100.0% ------------------------------------------------------------------------- rewriter [71] 100.0% [87] 196(0.1%) 0(0.0%) for-loop ...ock/herbie/src/core/matcher.rkt:126:10 matcher [105] 100.0% ------------------------------------------------------------------------- loop [72] 36.5% loop [60] 63.5% [88] 34336(20.9%) 0(0.0%) make-exacts* ...tatlock/herbie/src/points.rkt:80:0 loop [121] 50.0% map [106] 48.0% eval-prog [127] 2.0% ------------------------------------------------------------------------- loop [60] 38.2% loop [72] 61.8% [89] 28598(17.4%) 0(0.0%) loop /home/ztatlock/herbie/src/points.rkt:83:4 map [106] 100.0% ------------------------------------------------------------------------- match-e [61] 37.4% for-loop [73] 62.6% [90] 15158(9.2%) 1902(1.2%) for-loop ...tlock/herbie/src/core/ematch.rkt:65:37 match-e [61] 72.8% ??? [110] 14.6% ------------------------------------------------------------------------- sort [62] 41.4% copying-mergesort [74] 58.6% [91] 10830(6.6%) 0(0.0%) loop ...cket/collects/racket/private/sort.rkt:64:8 ??? [107] 96.0% ??? [136] 4.0% ------------------------------------------------------------------------- location-do [76] 100.0% [92] 5116(3.1%) 0(0.0%) approximate9 ...ck/herbie/src/core/taylor.rkt:11:0 loop [108] 91.4% f6 [174] 4.3% for-loop [115] 4.3% ------------------------------------------------------------------------- merge-egraph-nodes! [75] 100.0% [93] 3938(2.4%) 1054(0.6%) update-leader! ...herbie/src/core/egraph.rkt:217:0 for-loop [109] 68.2% make-sequence [114] 5.1% ------------------------------------------------------------------------- list-cartesian-product [94] 17.4% match-e [61] 31.9% for-loop [73] 50.6% [94] 3796(2.3%) 3394(2.1%) list-cartesian-product ...src/core/ematch.rkt:20:0 list-cartesian-product [94] 17.4% for-loop [113] 8.0% ------------------------------------------------------------------------- apply-match [48] 12.4% substitute-e [79] 87.6% [95] 1624(1.0%) 1220(0.7%) mk-enode! ...lock/herbie/src/core/egraph.rkt:101:0 hash-has-key? [112] 24.9% ------------------------------------------------------------------------- for-loop [80] 100.0% [96] 644(0.4%) 0(0.0%) loop ...ket/collects/racket/private/list.rkt:264:4 ??? [111] 100.0% ------------------------------------------------------------------------- for-loop [81] 100.0% [97] 434(0.3%) 434(0.3%) for-loop ...lock/herbie/src/core/regimes.rkt:243:8 ------------------------------------------------------------------------- merge-egraph-nodes! [75] 100.0% [98] 392(0.2%) 392(0.2%) for-loop ...tlock/herbie/src/core/egraph.rkt:232:6 ------------------------------------------------------------------------- for-loop [83] 100.0% [99] 218(0.1%) 0(0.0%) for-loop .../ztatlock/herbie/src/points.rkt:129:20 sample-default [116] 100.0% ------------------------------------------------------------------------- curry* [84] 100.0% [100] 202(0.1%) 202(0.1%) procedure-arity ...ket/private/norm-arity.rkt:7:27 ------------------------------------------------------------------------- best-and-tied-at-points [78] 100.0% [101] 202(0.1%) 202(0.1%) for-loop ...k/herbie/src/core/alt-table.rkt:124:16 ------------------------------------------------------------------------- merge-egraph-nodes! [75] 100.0% [102] 202(0.1%) 0(0.0%) enode-merge! ...ck/herbie/src/core/enode.rkt:100:0 adopt-enode! [117] 100.0% ------------------------------------------------------------------------- best-alt [85] 100.0% [103] 200(0.1%) 0(0.0%) loop /home/ztatlock/herbie/src/common.rkt:86:2 composed [118] 100.0% ------------------------------------------------------------------------- *rules* [86] 100.0% [104] 196(0.1%) 0(0.0%) for-loop ...e/ztatlock/herbie/src/common.rkt:205:9 ormap [119] 100.0% ------------------------------------------------------------------------- for-loop [120] 25.0% matcher [105] 25.0% for-loop [87] 50.0% [105] 196(0.1%) 0(0.0%) matcher ...tlock/herbie/src/core/matcher.rkt:159:2 rewriter [71] 50.0% matcher [105] 25.0% for-loop [120] 25.0% ------------------------------------------------------------------------- gather-multiplicative-terms [180] 0.3% f6 [174] 6.4% make-exacts* [88] 34.1% loop [89] 59.2% [106] 48326(29.4%) 0(0.0%) map ...acket/collects/racket/private/map.rkt:21:13 loop [121] 91.6% f6 [174] 3.8% ??? [136] 1.7% ??? [131] 1.2% parse-loop12 [155] 0.6% gather-multiplicative-terms [180] 0.3% simplify-node [10] 0.1% taylor [179] 0.1% make-multiplication-node [146] 0.1% ------------------------------------------------------------------------- jloop [4] 25.9% loop [91] 74.1% [107] 14028(8.5%) 0(0.0%) ??? /home/ztatlock/herbie/src/points.rkt:52:27 eval-prog [127] 96.6% ??? [136] 3.4% ------------------------------------------------------------------------- approximate9 [92] 100.0% [108] 4676(2.8%) 0(0.0%) loop ...e/ztatlock/herbie/src/core/taylor.rkt:82:4 hash-ref! [137] 96.0% iterate-diagonal [126] 4.0% ------------------------------------------------------------------------- update-leader! [93] 100.0% [109] 2684(1.6%) 0(0.0%) for-loop ...tlock/herbie/src/core/egraph.rkt:222:6 for-loop [122] 100.0% ------------------------------------------------------------------------- for-loop [40] 16.5% for-loop [90] 83.5% [110] 2660(1.6%) 1338(0.8%) ??? /home/ztatlock/herbie/src/core/ematch.rkt:50:5 for-loop [124] 49.7% ------------------------------------------------------------------------- for-loop [82] 25.6% loop [96] 74.4% [111] 866(0.5%) 220(0.1%) ??? .../ztatlock/herbie/src/core/regimes.rkt:291:8 eval-prog [127] 74.6% ------------------------------------------------------------------------- mk-enode! [95] 100.0% [112] 404(0.2%) 404(0.2%) hash-has-key? ...et/private/more-scheme.rkt:368:13 ------------------------------------------------------------------------- list-cartesian-product [94] 100.0% [113] 402(0.2%) 402(0.2%) for-loop ...atlock/herbie/src/core/ematch.rkt:24:8 ------------------------------------------------------------------------- update-leader! [93] 50.0% for-loop [44] 50.0% [114] 400(0.2%) 400(0.2%) make-sequence ...ects/racket/private/for.rkt:508:2 ------------------------------------------------------------------------- approximate9 [92] 100.0% [115] 220(0.1%) 0(0.0%) for-loop ...tlock/herbie/src/core/taylor.rkt:28:18 taylor-sqrt [125] 100.0% ------------------------------------------------------------------------- for-loop [99] 100.0% [116] 218(0.1%) 0(0.0%) sample-default ...rc/syntax/distributions.rkt:11:0 ??? [165] 100.0% ------------------------------------------------------------------------- enode-merge! [102] 100.0% [117] 202(0.1%) 0(0.0%) adopt-enode! ...ock/herbie/src/core/enode.rkt:76:0 custom-set-union [139] 100.0% ------------------------------------------------------------------------- loop [103] 100.0% [118] 200(0.1%) 0(0.0%) composed ...ollects/racket/private/list.rkt:321:16 errors [123] 100.0% ------------------------------------------------------------------------- for-loop [104] 100.0% [119] 196(0.1%) 0(0.0%) ormap ...et/collects/racket/private/map.rkt:106:13 ??? [165] 100.0% ------------------------------------------------------------------------- matcher [105] 100.0% [120] 196(0.1%) 0(0.0%) for-loop ...ock/herbie/src/core/matcher.rkt:175:21 matcher [105] 100.0% ------------------------------------------------------------------------- option-on-expr [42] 0.1% parse-loop12 [155] 0.2% ??? [136] 0.3% make-exacts* [88] 0.4% for-loop [73] 0.6% loop! [128] 1.0% match-e [61] 1.2% map [106] 1.5% extract-alt [26] 4.1% infer-splitpoints4 [33] 4.3% ??? [151] 7.6% loop [121] 78.5% [121] 81268(49.4%) 2540(1.5%) loop ...cket/collects/racket/private/map.rkt:26:19 loop [121] 78.5% hash-ref! [137] 7.6% option-on-expr [42] 4.3% simplify [3] 4.1% ??? [136] 1.9% loop! [128] 1.0% curried [185] 0.4% foldl [134] 0.4% ??? [131] 0.2% for-loop [132] 0.1% errors [123] 0.1% ??? [177] 0.1% real->bigfloat [150] 0.1% ->flonum [156] 0.0% ------------------------------------------------------------------------- for-loop [109] 100.0% [122] 2684(1.6%) 0(0.0%) for-loop ...tlock/herbie/src/core/egraph.rkt:223:8 hash-update! [130] 100.0% ------------------------------------------------------------------------- composed [118] 12.3% loop [121] 12.4% best-and-tied-at-points [78] 75.3% [123] 1628(1.0%) 0(0.0%) errors /home/ztatlock/herbie/src/points.rkt:144:0 for-loop [133] 49.4% eval-prog [127] 38.2% ??? [135] 12.4% ------------------------------------------------------------------------- ??? [110] 100.0% [124] 1322(0.8%) 1322(0.8%) for-loop ...atlock/herbie/src/core/ematch.rkt:51:7 ------------------------------------------------------------------------- for-loop [115] 100.0% [125] 220(0.1%) 0(0.0%) taylor-sqrt ...ck/herbie/src/core/taylor.rkt:346:0 simplify [129] 100.0% ------------------------------------------------------------------------- loop [108] 100.0% [126] 186(0.1%) 186(0.1%) iterate-diagonal ...rbie/src/core/taylor.rkt:150:0 ------------------------------------------------------------------------- errors [123] 3.5% ??? [111] 3.6% for-loop [68] 3.8% make-exacts* [88] 3.8% loop [72] 8.8% ??? [107] 76.4% [127] 17738(10.8%) 8210(5.0%) eval-prog ...tatlock/herbie/src/programs.rkt:162:0 hash-ref! [137] 37.3% ??? [141] 6.3% go [142] 3.9% parse-lambda [144] 3.6% inductor [145] 2.6% ------------------------------------------------------------------------- for-loop [64] 17.9% merge-egraph-nodes! [75] 23.6% loop [121] 26.8% apply-match [48] 31.7% [128] 4460(2.7%) 880(0.5%) loop! .../ztatlock/herbie/src/core/enode.rkt:163:2 custom-set-union [139] 44.9% loop [121] 26.8% set [140] 16.3% update-en-expr [167] 2.2% ------------------------------------------------------------------------- taylor-invert [9] 4.8% taylor-sqrt [125] 5.9% taylor-quotient [8] 5.9% first-nonzero-exp [19] 5.9% hash-ref! [137] 77.4% [129] 3700(2.3%) 0(0.0%) simplify ...atlock/herbie/src/core/reduce.rkt:18:0 f6 [174] 66.6% debug-print [184] 16.9% parse-loop12 [155] 11.6% make-multiplication-node [146] 4.9% ------------------------------------------------------------------------- for-loop [122] 100.0% [130] 2684(1.6%) 218(0.1%) hash-update! ...ket/private/more-scheme.rkt:362:13 ??? [138] 91.9% ------------------------------------------------------------------------- loop [121] 12.9% map [106] 87.1% [131] 1170(0.7%) 0(0.0%) ??? ...ket/collects/racket/private/list.rkt:323:18 f6 [174] 74.5% hash-ref! [137] 16.1% taylor-quotient [8] 9.4% ------------------------------------------------------------------------- loop [121] 100.0% [132] 1042(0.6%) 384(0.2%) for-loop ...ock/herbie/src/core/simplify.rkt:161:2 compose [143] 63.1% ------------------------------------------------------------------------- errors [123] 100.0% [133] 804(0.5%) 0(0.0%) for-loop ...e/ztatlock/herbie/src/points.rkt:147:4 ??? [136] 74.9% ulp-difference [148] 25.1% ------------------------------------------------------------------------- loop [121] 100.0% [134] 606(0.4%) 404(0.2%) foldl ...et/collects/racket/private/list.rkt:229:4 merge2 [147] 33.3% ------------------------------------------------------------------------- errors [123] 100.0% [135] 202(0.1%) 202(0.1%) ??? ...cket/collects/racket/private/for.rkt:1145:9 ------------------------------------------------------------------------- loop [91] 0.7% ??? [107] 0.8% for-loop [133] 1.0% map [106] 1.3% loop [121] 96.3% [136] 62572(38.1%) 2364(1.4%) ??? /home/ztatlock/herbie/src/programs.rkt:168:4 ??? [149] 64.2% loop [121] 16.5% real->bigfloat [150] 11.8% ??? [177] 2.7% ->flonum [156] 1.0% ------------------------------------------------------------------------- for-loop [30] 0.2% for-loop [18] 0.5% first-nonzero-exp [19] 0.7% ??? [28] 1.2% ??? [131] 1.2% ??? [5] 2.5% for-loop [17] 3.2% compile [77] 4.9% loop [108] 5.4% ??? [151] 9.7% eval-prog [127] 13.8% ??? [153] 19.7% loop [121] 36.2% [137] 13222(8.0%) 2376(1.4%) hash-ref! ...racket/private/more-scheme.rkt:373:13 ??? [151] 46.7% ??? [153] 19.7% bigfloat-hash [152] 12.7% ??? [6] 3.6% simplify [129] 2.9% ??? [5] 2.8% f6 [174] 1.9% ??? [7] 1.3% parse-loop12 [155] 1.2% taylor [179] 0.5% taylor-invert [9] 0.4% ??? [11] 0.2% ------------------------------------------------------------------------- hash-update! [130] 100.0% [138] 2466(1.5%) 202(0.1%) ??? .../ztatlock/herbie/src/core/egraph.rkt:225:24 for-loop [154] 91.8% ------------------------------------------------------------------------- adopt-enode! [117] 8.6% loop! [128] 91.4% [139] 2350(1.4%) 838(0.5%) custom-set-union ...et/private/set-types.rkt:168:0 for-loop [157] 64.3% ------------------------------------------------------------------------- loop! [128] 100.0% [140] 1232(0.7%) 1232(0.7%) set ...collects/racket/private/set-types.rkt:982:0 ------------------------------------------------------------------------- eval-prog [127] 100.0% [141] 1114(0.7%) 662(0.4%) ??? ...collects/racket/private/qq-and-or.rkt:155:9 ??? [158] 40.6% ------------------------------------------------------------------------- eval-prog [127] 100.0% [142] 686(0.4%) 442(0.3%) go .../collects/racket/private/qq-and-or.rkt:50:20 loop [160] 35.6% ------------------------------------------------------------------------- for-loop [132] 100.0% [143] 658(0.4%) 658(0.4%) compose ...collects/racket/private/list.rkt:385:12 ------------------------------------------------------------------------- eval-prog [127] 100.0% [144] 642(0.4%) 642(0.4%) parse-lambda ...llects/racket/private/kw.rkt:393:2 ------------------------------------------------------------------------- inductor [145] 37.9% eval-prog [127] 62.1% [145] 468(0.3%) 202(0.1%) inductor .../ztatlock/herbie/src/programs.rkt:73:2 inductor [145] 37.9% real->bigfloat [150] 18.9% ------------------------------------------------------------------------- simplify [129] 45.0% map [106] 55.0% [146] 400(0.2%) 0(0.0%) make-multiplication-node .../core/reduce.rkt:221:0 make-multiplication-subnode [159]100.0% ------------------------------------------------------------------------- foldl [134] 100.0% [147] 202(0.1%) 202(0.1%) merge2 ...ztatlock/herbie/src/core/ematch.rkt:31:0 ------------------------------------------------------------------------- for-loop [133] 100.0% [148] 202(0.1%) 202(0.1%) ulp-difference ...atlock/herbie/src/float.rkt:19:0 ------------------------------------------------------------------------- ??? [136] 100.0% [149] 40158(24.4%) 1536(0.9%) ??? ...acket/collects/racket/private/kw.rkt:400:14 ??? [172] 43.0% bf* [161] 34.2% ...higher-order.rkt:373:33 [162] 16.0% ...higher-order.rkt:369:33 [166] 2.0% ------------------------------------------------------------------------- inductor [145] 1.9% loop [121] 46.6% ??? [136] 51.5% [150] 14314(8.7%) 11164(6.8%) real->bigfloat .../private/bigfloat/mpfr.rkt:451:0 ??? [183] 22.0% ------------------------------------------------------------------------- hash-ref! [137] 100.0% [151] 8312(5.1%) 202(0.1%) ??? /home/ztatlock/herbie/src/programs.rkt:197:5 loop [121] 76.8% hash-ref! [137] 22.0% ------------------------------------------------------------------------- hash-ref! [137] 100.0% [152] 5966(3.6%) 176(0.1%) bigfloat-hash ...h/private/bigfloat/mpfr.rkt:165:0 bfcanonicalize [163] 92.3% sig+exp->bigfloat [169] 4.8% ------------------------------------------------------------------------- hash-ref! [137] 100.0% [153] 4490(2.7%) 0(0.0%) ??? ...e/ztatlock/herbie/src/core/taylor.rkt:63:15 hash-ref! [137] 100.0% ------------------------------------------------------------------------- ??? [138] 100.0% [154] 2264(1.4%) 2064(1.3%) for-loop ...lock/herbie/src/core/egraph.rkt:226:26 update-en-expr [167] 8.8% ------------------------------------------------------------------------- hash-ref! [137] 10.5% append-map [20] 12.3% simplify [129] 24.0% map [106] 53.2% [155] 1786(1.1%) 824(0.5%) parse-loop12 ...s/racket/match/compiler.rkt:410:15 f6 [174] 37.2% for-loop [170] 12.3% loop [121] 8.4% loop [171] 2.1% ------------------------------------------------------------------------- ??? [136] 39.2% loop [121] 60.8% [156] 1634(1.0%) 524(0.3%) ->flonum ...ock/herbie/src/syntax/syntax.rkt:224:0 ??? [165] 37.5% ??? [182] 30.5% ------------------------------------------------------------------------- custom-set-union [139] 100.0% [157] 1512(0.9%) 224(0.1%) for-loop ...cts/racket/private/set-types.rkt:174:3 for-loop [164] 85.2% ------------------------------------------------------------------------- ??? [141] 100.0% [158] 452(0.3%) 452(0.3%) ??? ...ollects/racket/private/qq-and-or.rkt:164:21 ------------------------------------------------------------------------- make-multiplication-node [146] 100.0% [159] 400(0.2%) 0(0.0%) make-multiplication-subnode ...re/reduce.rkt:231:0 group-by68 [168] 100.0% ------------------------------------------------------------------------- go [142] 100.0% [160] 244(0.1%) 244(0.1%) loop ...llects/racket/private/qq-and-or.rkt:101:61 ------------------------------------------------------------------------- ??? [149] 100.0% [161] 13718(8.3%) 0(0.0%) bf* ...ath/private/bigfloat/bigfloat-mpfr.rkt:95:0 ??? [172] 100.0% ------------------------------------------------------------------------- ??? [149] 100.0% [162] 6408(3.9%) 0(0.0%) ...higher-order.rkt:373:33 (unknown source) ??? [173] 65.1% ??? [177] 34.9% ------------------------------------------------------------------------- bigfloat-hash [152] 100.0% [163] 5506(3.4%) 5250(3.2%) bfcanonicalize .../private/bigfloat/mpfr.rkt:155:0 bigfloat->sig+exp [175] 4.6% ------------------------------------------------------------------------- for-loop [157] 100.0% [164] 1288(0.8%) 1288(0.8%) for-loop ...cts/racket/private/set-types.rkt:178:5 ------------------------------------------------------------------------- ormap [119] 19.1% sample-default [116] 21.2% ->flonum [156] 59.6% [165] 1026(0.6%) 1026(0.6%) ??? /home/ztatlock/herbie/src/config.rkt:29:0 ------------------------------------------------------------------------- ??? [149] 100.0% [166] 794(0.5%) 0(0.0%) ...higher-order.rkt:369:33 (unknown source) ??? [177] 100.0% ------------------------------------------------------------------------- loop! [128] 50.0% for-loop [154] 50.0% [167] 400(0.2%) 400(0.2%) update-en-expr ...herbie/src/core/egraph.rkt:211:0 ------------------------------------------------------------------------- make-multiplication-subnode [159]100.0% [168] 400(0.2%) 400(0.2%) group-by68 ...acket/collects/racket/list.rkt:749:0 ------------------------------------------------------------------------- bigfloat-hash [152] 100.0% [169] 284(0.2%) 284(0.2%) sig+exp->bigfloat ...ivate/bigfloat/mpfr.rkt:385:0 ------------------------------------------------------------------------- parse-loop12 [155] 100.0% [170] 220(0.1%) 0(0.0%) for-loop ...tlock/herbie/src/core/reduce.rkt:80:11 f6 [174] 100.0% ------------------------------------------------------------------------- parse-loop12 [155] 4.3% loop [171] 95.7% [171] 188(0.1%) 188(0.1%) loop ...cket/collects/racket/private/map.rkt:37:19 loop [171] 95.7% ------------------------------------------------------------------------- bf* [161] 44.3% ??? [149] 55.7% [172] 30972(18.8%) 2236(1.4%) ??? ...-racket/utils/simple-result-arrow.rkt:26:12 bfmul [176] 65.9% bfsqr [178] 14.7% ??? [182] 12.2% ------------------------------------------------------------------------- ...higher-order.rkt:373:33 [162] 100.0% [173] 4170(2.5%) 214(0.1%) ??? ...cts/racket/contract/private/list.rkt:187:10 ??? [177] 94.9% ------------------------------------------------------------------------- approximate9 [92] 1.6% for-loop [170] 2.1% parse-loop12 [155] 3.3% ??? [131] 5.2% hash-ref! [137] 11.4% simplify [129] 17.0% f6 [174] 17.8% map [106] 41.6% [174] 3420(2.1%) 798(0.5%) f6 ...et/collects/racket/match/compiler.rkt:499:40 map [106] 67.2% f6 [174] 17.8% gather-multiplicative-terms [180] 2.7% taylor-quotient [8] 2.4% taylor-invert [9] 2.2% combine-mterms [181] 2.1% taylor [179] 1.1% ------------------------------------------------------------------------- bfcanonicalize [163] 100.0% [175] 256(0.2%) 256(0.2%) bigfloat->sig+exp ...ivate/bigfloat/mpfr.rkt:370:0 ------------------------------------------------------------------------- ??? [172] 100.0% [176] 20422(12.4%) 14096(8.6%) bfmul ...-lib/math/private/bigfloat/mpfr.rkt:819:4 ??? [183] 31.0% ------------------------------------------------------------------------- ??? [45] 1.6% ...higher-order.rkt:369:33 [166] 7.1% ??? [136] 15.2% ...higher-order.rkt:373:33 [162] 19.9% loop [121] 21.0% ??? [173] 35.2% [177] 11228(6.8%) 396(0.2%) ??? ...ects/racket/contract/private/guts.rkt:638:8 ??? [182] 96.5% ------------------------------------------------------------------------- ??? [172] 100.0% [178] 4550(2.8%) 3836(2.3%) bfsqr ...-lib/math/private/bigfloat/mpfr.rkt:616:4 ??? [183] 15.7% ------------------------------------------------------------------------- hash-ref! [137] 31.6% f6 [174] 31.9% map [106] 36.5% [179] 570(0.3%) 182(0.1%) taylor ...tatlock/herbie/src/core/taylor.rkt:157:0 debug-print [184] 36.5% debug7 [187] 31.6% ------------------------------------------------------------------------- map [106] 42.3% f6 [174] 57.7% [180] 416(0.3%) 220(0.1%) gather-multiplicative-terms ...re/reduce.rkt:107:0 curried [185] 47.1% map [106] 42.3% ------------------------------------------------------------------------- f6 [174] 100.0% [181] 220(0.1%) 0(0.0%) combine-mterms ...herbie/src/core/reduce.rkt:182:0 for-loop [186] 100.0% ------------------------------------------------------------------------- ->flonum [156] 3.3% ??? [172] 24.6% ??? [177] 70.7% [182] 15314(9.3%) 8326(5.1%) ??? ...tract/private/arrow-higher-order.rkt:373:33 ??? [188] 44.2% ??? [190] 1.4% ------------------------------------------------------------------------- bfsqr [178] 7.0% real->bigfloat [150] 30.9% bfmul [176] 62.1% [183] 10190(6.2%) 10190(6.2%) ??? .../share/racket/collects/ffi/unsafe.rkt:861:4 ------------------------------------------------------------------------- taylor [179] 24.9% simplify [129] 75.1% [184] 834(0.5%) 208(0.1%) debug-print ...ztatlock/herbie/src/debug.rkt:107:0 for-loop [189] 75.1% ------------------------------------------------------------------------- gather-multiplicative-terms [180] 30.8% loop [121] 69.2% [185] 636(0.4%) 636(0.4%) curried ...cket/collects/racket/function.rkt:71:18 ------------------------------------------------------------------------- combine-mterms [181] 100.0% [186] 220(0.1%) 220(0.1%) for-loop ...tlock/herbie/src/core/reduce.rkt:186:5 ------------------------------------------------------------------------- taylor [179] 100.0% [187] 180(0.1%) 0(0.0%) debug7 /home/ztatlock/herbie/src/debug.rkt:102:0 ??? [45] 100.0% ------------------------------------------------------------------------- ??? [182] 100.0% [188] 6768(4.1%) 3652(2.2%) ??? ...llects/racket/contract/combinator.rkt:178:4 any-wrap/traverse [191] 46.0% ------------------------------------------------------------------------- debug-print [184] 100.0% [189] 626(0.4%) 626(0.4%) for-loop /home/ztatlock/herbie/src/debug.rkt:113:2 ------------------------------------------------------------------------- ??? [182] 100.0% [190] 220(0.1%) 0(0.0%) ??? ...ects/racket/contract/private/prop.rkt:489:4 ??? [192] 100.0% ------------------------------------------------------------------------- ??? [188] 100.0% [191] 3116(1.9%) 3116(1.9%) any-wrap/traverse ...cket/utils/any-wrap.rkt:106:2 ------------------------------------------------------------------------- ??? [190] 100.0% [192] 220(0.1%) 220(0.1%) ??? ...lects/racket/contract/private/orc.rkt:73:14 -------------------------------------------------------------------------