Profiling results ----------------- Total cpu time observed: 35106ms (out of 35600ms) Number of samples taken: 154 (once every 228ms) ======================================================================== Caller Idx Total Self Name+src Local% ms(pct) ms(pct) Callee ======================================================================== ??? [27] 100.0% [1] 34438(98.1%) 0(0.0%) profile-thunk14 ...t/pkgs/profile-lib/main.rkt:9:0 run [5] 100.0% ------------------------------------------------------------------------ ??? [27] 100.0% [2] 8030(22.9%) 0(0.0%) run-improve58 ...ock/herbie/src/mainloop.rkt:242:0 for-loop [6] 76.4% get-final-combination [9] 15.5% loop [36] 8.1% ------------------------------------------------------------------------ ??? [27] 100.0% [3] 4672(13.3%) 0(0.0%) simplify ...lock/herbie/src/core/simplify.rkt:39:0 simplify-expr [7] 59.6% for-loop [8] 27.1% iterate-egraph!5 [11] 13.3% ------------------------------------------------------------------------ copying-mergesort [49] 100.0% [4] 322(0.9%) 0(0.0%) jloop ...et/collects/racket/private/sort.rkt:85:19 ??? [62] 100.0% ------------------------------------------------------------------------ profile-thunk14 [1] 98.8% [5] 34870(99.3%) 0(0.0%) run ...share/racket/pkgs/profile-lib/main.rkt:31:2 ??? [27] 100.0% ------------------------------------------------------------------------ run-improve58 [2] 100.0% [6] 6134(17.5%) 0(0.0%) for-loop ...ztatlock/herbie/src/mainloop.rkt:253:8 run-iter! [10] 100.0% ------------------------------------------------------------------------ simplify [3] 100.0% [7] 2786(7.9%) 0(0.0%) simplify-expr ...herbie/src/core/simplify.rkt:68:0 iterate-egraph!5 [11] 100.0% ------------------------------------------------------------------------ simplify [3] 100.0% [8] 1264(3.6%) 0(0.0%) for-loop ...ock/herbie/src/core/simplify.rkt:61:12 iterate-egraph!5 [11] 100.0% ------------------------------------------------------------------------ run-improve58 [2] 100.0% [9] 1244(3.5%) 0(0.0%) get-final-combination ...ie/src/mainloop.rkt:269:0 split-table [12] 100.0% ------------------------------------------------------------------------ for-loop [6] 100.0% [10] 6134(17.5%) 0(0.0%) run-iter! ...tatlock/herbie/src/mainloop.rkt:223:0 simplify! [13] 76.2% finalize-iter! [16] 16.6% gen-series! [17] 3.6% localize-error [41] 3.6% ------------------------------------------------------------------------ simplify [3] 13.3% for-loop [8] 27.1% simplify-expr [7] 59.6% [11] 4672(13.3%) 0(0.0%) iterate-egraph!5 ...bie/src/core/simplify.rkt:95:0 one-iter [14] 95.7% map-enodes [18] 4.3% ------------------------------------------------------------------------ get-final-combination [9] 100.0% [12] 1244(3.5%) 0(0.0%) split-table .../ztatlock/herbie/src/glue.rkt:171:0 infer-splitpoints4 [15] 100.0% ------------------------------------------------------------------------ run-iter! [10] 100.0% [13] 4672(13.3%) 0(0.0%) simplify! ...tatlock/herbie/src/mainloop.rkt:162:0 for-loop [19] 100.0% ------------------------------------------------------------------------ iterate-egraph!5 [11] 100.0% [14] 4470(12.7%) 222(0.6%) one-iter ...ock/herbie/src/core/simplify.rkt:106:0 for-loop [20] 75.4% loop [23] 19.6% ------------------------------------------------------------------------ split-table [12] 100.0% [15] 1244(3.5%) 0(0.0%) infer-splitpoints4 ...ie/src/core/regimes.rkt:19:0 option-on-expr [21] 84.2% exprs-to-branch-on [26] 15.8% ------------------------------------------------------------------------ run-iter! [10] 100.0% [16] 1018(2.9%) 0(0.0%) finalize-iter! ...ck/herbie/src/mainloop.rkt:177:0 ??? [22] 100.0% ------------------------------------------------------------------------ run-iter! [10] 100.0% [17] 222(0.6%) 0(0.0%) gen-series! ...tlock/herbie/src/mainloop.rkt:134:0 for-loop [24] 100.0% ------------------------------------------------------------------------ iterate-egraph!5 [11] 100.0% [18] 202(0.6%) 0(0.0%) map-enodes ...ock/herbie/src/core/egraph.rkt:139:0 for-loop [25] 100.0% ------------------------------------------------------------------------ simplify! [13] 100.0% [19] 4672(13.3%) 0(0.0%) for-loop ...ztatlock/herbie/src/mainloop.rkt:166:6 ??? [27] 100.0% ------------------------------------------------------------------------ for-loop [20] 50.0% one-iter [14] 50.0% [20] 3370(9.6%) 844(2.4%) for-loop ...ck/herbie/src/core/simplify.rkt:116:12 for-loop [20] 50.0% match-e [28] 37.5% ------------------------------------------------------------------------ infer-splitpoints4 [15] 100.0% [21] 1048(3.0%) 0(0.0%) option-on-expr ...erbie/src/core/regimes.rkt:106:0 sort-context-on-expr [29] 85.1% pick-errors [35] 14.9% ------------------------------------------------------------------------ finalize-iter! [16] 100.0% [22] 1018(2.9%) 200(0.6%) ??? ...contract/private/arrow-val-first.rkt:357:18 for-loop [31] 80.4% ------------------------------------------------------------------------ one-iter [14] 100.0% [23] 878(2.5%) 0(0.0%) loop ...cket/collects/racket/private/map.rkt:53:19 apply-match [30] 100.0% ------------------------------------------------------------------------ gen-series! [17] 100.0% [24] 222(0.6%) 0(0.0%) for-loop ...ztatlock/herbie/src/mainloop.rkt:140:7 taylor-alt [32] 100.0% ------------------------------------------------------------------------ map-enodes [18] 100.0% [25] 202(0.6%) 0(0.0%) for-loop ...ock/herbie/src/core/simplify.rkt:161:2 compose [33] 100.0% ------------------------------------------------------------------------ infer-splitpoints4 [15] 100.0% [26] 196(0.6%) 0(0.0%) exprs-to-branch-on ...ie/src/core/regimes.rkt:41:0 critical-subexpression [34] 100.0% ------------------------------------------------------------------------ for-loop [19] 4.4% run [5] 48.1% [27] 35106(100.0%) 0(0.0%) ??? ...lects/racket/private/more-scheme.rkt:261:28 profile-thunk14 [1] 46.8% loop [36] 39.2% run-improve58 [2] 9.6% simplify [3] 4.4% ------------------------------------------------------------------------ for-loop [47] 16.3% for-loop [20] 83.7% [28] 2526(7.2%) 1468(4.2%) match-e ...tatlock/herbie/src/core/ematch.rkt:46:0 for-loop [38] 25.5% for-loop [47] 16.3% constant? [42] 12.5% ------------------------------------------------------------------------ option-on-expr [21] 100.0% [29] 892(2.5%) 0(0.0%) sort-context-on-expr ...herbie/src/points.rkt:50:0 sort [37] 100.0% ------------------------------------------------------------------------ loop [23] 100.0% [30] 878(2.5%) 0(0.0%) apply-match .../herbie/src/core/simplify.rkt:122:2 merge-egraph-nodes! [40] 48.1% substitute-e [43] 26.7% loop! [86] 25.3% ------------------------------------------------------------------------ ??? [22] 100.0% [31] 818(2.3%) 0(0.0%) for-loop ...ock/herbie/src/core/alt-table.rkt:51:2 atab-add-altn [39] 100.0% ------------------------------------------------------------------------ for-loop [24] 100.0% [32] 222(0.6%) 0(0.0%) taylor-alt ...e/ztatlock/herbie/src/glue.rkt:142:0 for-loop [44] 100.0% ------------------------------------------------------------------------ for-loop [25] 100.0% [33] 202(0.6%) 202(0.6%) compose ...collects/racket/private/list.rkt:385:12 ------------------------------------------------------------------------ exprs-to-branch-on [26] 100.0% [34] 196(0.6%) 0(0.0%) critical-subexpression ...rc/core/regimes.rkt:49:0 localize-error [41] 100.0% ------------------------------------------------------------------------ option-on-expr [21] 100.0% [35] 156(0.4%) 0(0.0%) pick-errors ...k/herbie/src/core/regimes.rkt:173:0 for-loop [45] 100.0% ------------------------------------------------------------------------ run-improve58 [2] 2.4% ??? [27] 97.6% [36] 27728(79.0%) 0(0.0%) loop /home/ztatlock/herbie/src/points.rkt:122:2 make-exacts* [56] 54.0% loop [46] 45.2% loop [55] 0.7% ------------------------------------------------------------------------ sort-context-on-expr [29] 100.0% [37] 892(2.5%) 0(0.0%) sort ...ket/collects/racket/private/sort.rkt:213:0 copying-mergesort [49] 69.3% loop [59] 30.7% ------------------------------------------------------------------------ match-e [28] 100.0% [38] 844(2.4%) 222(0.6%) for-loop ...tlock/herbie/src/core/ematch.rkt:59:11 for-loop [47] 47.6% list-cartesian-product [52] 26.1% ------------------------------------------------------------------------ for-loop [31] 100.0% [39] 818(2.3%) 0(0.0%) atab-add-altn ...rbie/src/core/alt-table.rkt:208:0 best-and-tied-at-points [48] 100.0% ------------------------------------------------------------------------ apply-match [30] 100.0% [40] 422(1.2%) 0(0.0%) merge-egraph-nodes! ...e/src/core/egraph.rkt:152:0 update-leader! [53] 52.1% enode-merge! [54] 47.9% ------------------------------------------------------------------------ critical-subexpression [34] 46.9% run-iter! [10] 53.1% [41] 418(1.2%) 0(0.0%) localize-error ...erbie/src/core/localize.rkt:47:0 hash-ref! [66] 100.0% ------------------------------------------------------------------------ match-e [28] 100.0% [42] 416(1.2%) 416(1.2%) constant? ...ck/herbie/src/syntax/syntax.rkt:221:0 ------------------------------------------------------------------------ apply-match [30] 100.0% [43] 234(0.7%) 0(0.0%) substitute-e ...ck/herbie/src/core/ematch.rkt:71:0 mk-enode! [50] 100.0% ------------------------------------------------------------------------ taylor-alt [32] 100.0% [44] 222(0.6%) 0(0.0%) for-loop /home/ztatlock/herbie/src/glue.rkt:144:2 location-do [51] 100.0% ------------------------------------------------------------------------ pick-errors [35] 100.0% [45] 156(0.4%) 0(0.0%) for-loop ...lock/herbie/src/core/regimes.rkt:176:4 eval-prog [65] 100.0% ------------------------------------------------------------------------ loop [36] 100.0% [46] 12542(35.7%) 0(0.0%) loop /home/ztatlock/herbie/src/points.rkt:93:2 loop [57] 68.5% make-exacts* [56] 29.9% eval-prog [65] 1.6% ------------------------------------------------------------------------ for-loop [38] 39.3% match-e [28] 60.7% [47] 1024(2.9%) 200(0.6%) for-loop ...tlock/herbie/src/core/ematch.rkt:65:37 match-e [28] 80.5% ------------------------------------------------------------------------ atab-add-altn [39] 100.0% [48] 818(2.3%) 0(0.0%) best-and-tied-at-points ...ore/alt-table.rkt:122:0 errors [58] 100.0% ------------------------------------------------------------------------ sort [37] 37.0% copying-mergesort [49] 63.0% [49] 618(1.8%) 0(0.0%) copying-mergesort .../racket/private/sort.rkt:91:4 copying-mergesort [49] 63.0% loop [59] 23.9% jloop [4] 13.0% ------------------------------------------------------------------------ substitute-e [43] 100.0% [50] 234(0.7%) 234(0.7%) mk-enode! ...lock/herbie/src/core/egraph.rkt:101:0 ------------------------------------------------------------------------ for-loop [44] 100.0% [51] 222(0.6%) 0(0.0%) location-do ...tlock/herbie/src/programs.rkt:129:0 approximate9 [60] 100.0% ------------------------------------------------------------------------ list-cartesian-product [52] 50.0% for-loop [38] 50.0% [52] 220(0.6%) 220(0.6%) list-cartesian-product ...src/core/ematch.rkt:20:0 list-cartesian-product [52] 50.0% ------------------------------------------------------------------------ merge-egraph-nodes! [40] 100.0% [53] 220(0.6%) 0(0.0%) update-leader! ...herbie/src/core/egraph.rkt:217:0 for-loop [61] 100.0% ------------------------------------------------------------------------ merge-egraph-nodes! [40] 100.0% [54] 202(0.6%) 202(0.6%) enode-merge! ...ck/herbie/src/core/enode.rkt:100:0 ------------------------------------------------------------------------ loop [36] 0.1% loop [55] 99.9% [55] 200(0.6%) 200(0.6%) loop ...hare/racket/collects/racket/list.rkt:154:2 loop [55] 99.9% ------------------------------------------------------------------------ loop [46] 20.0% loop [36] 80.0% [56] 18742(53.4%) 0(0.0%) make-exacts* ...tatlock/herbie/src/points.rkt:80:0 loop [80] 49.8% map [79] 47.8% eval-prog [65] 2.4% ------------------------------------------------------------------------ loop [46] 100.0% [57] 8586(24.5%) 0(0.0%) loop /home/ztatlock/herbie/src/points.rkt:83:4 map [79] 100.0% ------------------------------------------------------------------------ best-and-tied-at-points [48] 100.0% [58] 818(2.3%) 0(0.0%) errors /home/ztatlock/herbie/src/points.rkt:144:0 eval-prog [65] 51.6% for-loop [63] 48.4% ------------------------------------------------------------------------ sort [37] 48.1% copying-mergesort [49] 51.9% [59] 570(1.6%) 0(0.0%) loop ...cket/collects/racket/private/sort.rkt:64:8 ??? [62] 100.0% ------------------------------------------------------------------------ location-do [51] 100.0% [60] 222(0.6%) 0(0.0%) approximate9 ...ck/herbie/src/core/taylor.rkt:11:0 loop [64] 100.0% ------------------------------------------------------------------------ update-leader! [53] 100.0% [61] 220(0.6%) 220(0.6%) for-loop ...tlock/herbie/src/core/egraph.rkt:222:6 ------------------------------------------------------------------------ jloop [4] 36.1% loop [59] 63.9% [62] 892(2.5%) 0(0.0%) ??? /home/ztatlock/herbie/src/points.rkt:52:27 eval-prog [65] 100.0% ------------------------------------------------------------------------ errors [58] 100.0% [63] 396(1.1%) 0(0.0%) for-loop ...e/ztatlock/herbie/src/points.rkt:147:4 ??? [82] 100.0% ------------------------------------------------------------------------ approximate9 [60] 100.0% [64] 222(0.6%) 0(0.0%) loop ...e/ztatlock/herbie/src/core/taylor.rkt:82:4 hash-ref! [66] 100.0% ------------------------------------------------------------------------ for-loop [45] 7.4% loop [46] 9.4% errors [58] 19.9% make-exacts* [56] 21.3% ??? [62] 42.0% [65] 2122(6.0%) 852(2.4%) eval-prog ...tatlock/herbie/src/programs.rkt:162:0 hash-ref! [66] 30.7% go [67] 11.3% ??? [68] 10.4% parse-lambda [69] 4.8% new-lambda [70] 2.6% ------------------------------------------------------------------------ ??? [74] 8.6% loop [64] 8.6% localize-error [41] 9.5% loop [80] 20.3% ??? [83] 22.8% eval-prog [65] 30.2% [66] 1292(3.7%) 0(0.0%) hash-ref! ...racket/private/more-scheme.rkt:373:13 bigfloat-hash [71] 30.2% ??? [73] 20.3% f6 [76] 19.0% parse-loop12 [72] 13.3% ??? [74] 8.6% simplify [75] 8.6% ------------------------------------------------------------------------ eval-prog [65] 100.0% [67] 240(0.7%) 240(0.7%) go .../collects/racket/private/qq-and-or.rkt:50:20 ------------------------------------------------------------------------ eval-prog [65] 100.0% [68] 220(0.6%) 220(0.6%) ??? ...collects/racket/private/qq-and-or.rkt:155:9 ------------------------------------------------------------------------ eval-prog [65] 100.0% [69] 102(0.3%) 102(0.3%) parse-lambda ...llects/racket/private/kw.rkt:393:2 ------------------------------------------------------------------------ eval-prog [65] 100.0% [70] 56(0.2%) 56(0.2%) new-lambda ...ollects/racket/private/kw.rkt:631:11 ------------------------------------------------------------------------ hash-ref! [66] 100.0% [71] 652(1.9%) 0(0.0%) bigfloat-hash ...h/private/bigfloat/mpfr.rkt:165:0 sig+exp->bigfloat [77] 69.3% bfcanonicalize [78] 30.7% ------------------------------------------------------------------------ hash-ref! [66] 100.0% [72] 418(1.2%) 0(0.0%) parse-loop12 ...s/racket/match/compiler.rkt:410:15 loop [80] 100.0% ------------------------------------------------------------------------ hash-ref! [66] 100.0% [73] 416(1.2%) 0(0.0%) ??? /home/ztatlock/herbie/src/programs.rkt:197:5 loop [80] 100.0% ------------------------------------------------------------------------ hash-ref! [66] 100.0% [74] 222(0.6%) 0(0.0%) ??? ...e/ztatlock/herbie/src/core/taylor.rkt:42:15 hash-ref! [66] 100.0% ------------------------------------------------------------------------ hash-ref! [66] 100.0% [75] 222(0.6%) 0(0.0%) simplify ...atlock/herbie/src/core/reduce.rkt:18:0 f6 [76] 100.0% ------------------------------------------------------------------------ simplify [75] 8.7% map [79] 26.0% hash-ref! [66] 65.3% [76] 640(1.8%) 0(0.0%) f6 ...et/collects/racket/match/compiler.rkt:499:40 map [79] 100.0% ------------------------------------------------------------------------ bigfloat-hash [71] 100.0% [77] 452(1.3%) 452(1.3%) sig+exp->bigfloat ...ivate/bigfloat/mpfr.rkt:385:0 ------------------------------------------------------------------------ bigfloat-hash [71] 100.0% [78] 200(0.6%) 200(0.6%) bfcanonicalize .../private/bigfloat/mpfr.rkt:155:0 ------------------------------------------------------------------------ f6 [76] 3.5% loop [57] 47.2% make-exacts* [56] 49.2% [79] 18176(51.8%) 0(0.0%) map ...acket/collects/racket/private/map.rkt:21:13 loop [80] 95.8% ??? [82] 1.3% ??? [83] 1.1% f6 [76] 0.9% ??? [94] 0.6% ??? [81] 0.3% ------------------------------------------------------------------------ make-exacts* [56] 0.5% loop! [86] 0.8% parse-loop12 [72] 0.8% map [79] 1.3% ??? [73] 1.5% loop [80] 95.0% [80] 27702(78.9%) 0(0.0%) loop ...cket/collects/racket/private/map.rkt:26:19 loop [80] 95.0% ??? [82] 1.8% hash-ref! [66] 1.5% ??? [83] 0.8% loop! [86] 0.8% ??? [94] 0.0% ->flonum [84] 0.0% ------------------------------------------------------------------------ map [79] 100.0% [81] 222(0.6%) 0(0.0%) ??? /home/ztatlock/herbie/src/core/reduce.rkt:52:5 for-loop [85] 100.0% ------------------------------------------------------------------------ map [79] 0.9% for-loop [63] 1.5% loop [80] 97.7% [82] 27036(77.0%) 0(0.0%) ??? /home/ztatlock/herbie/src/programs.rkt:168:4 ??? [87] 94.1% real->bigfloat [88] 5.1% ??? [97] 0.8% ------------------------------------------------------------------------ map [79] 42.2% loop [80] 57.8% [83] 418(1.2%) 0(0.0%) ??? ...ket/collects/racket/private/list.rkt:323:18 hash-ref! [66] 100.0% ------------------------------------------------------------------------ loop [80] 100.0% [84] 236(0.7%) 0(0.0%) ->flonum ...ock/herbie/src/syntax/syntax.rkt:224:0 ??? [92] 100.0% ------------------------------------------------------------------------ ??? [81] 100.0% [85] 222(0.6%) 0(0.0%) for-loop ...atlock/herbie/src/core/reduce.rkt:53:7 pattern-match [90] 100.0% ------------------------------------------------------------------------ loop [80] 50.0% apply-match [30] 50.0% [86] 222(0.6%) 0(0.0%) loop! .../ztatlock/herbie/src/core/enode.rkt:163:2 loop [80] 50.0% update-en-expr [89] 50.0% ------------------------------------------------------------------------ ??? [82] 100.0% [87] 25434(72.4%) 0(0.0%) ??? ...acket/collects/racket/private/kw.rkt:400:14 ??? [94] 91.2% bf* [91] 5.4% ...higher-order.rkt:373:33 [93] 1.9% ??? [92] 1.6% ------------------------------------------------------------------------ ??? [82] 100.0% [88] 1376(3.9%) 1376(3.9%) real->bigfloat .../private/bigfloat/mpfr.rkt:451:0 ------------------------------------------------------------------------ loop! [86] 100.0% [89] 222(0.6%) 222(0.6%) update-en-expr ...herbie/src/core/egraph.rkt:211:0 ------------------------------------------------------------------------ for-loop [85] 100.0% [90] 222(0.6%) 222(0.6%) pattern-match .../herbie/src/core/matcher.rkt:47:0 ------------------------------------------------------------------------ ??? [87] 100.0% [91] 1362(3.9%) 0(0.0%) bf* ...ath/private/bigfloat/bigfloat-mpfr.rkt:95:0 ??? [94] 100.0% ------------------------------------------------------------------------ ->flonum [84] 37.3% ??? [87] 62.7% [92] 632(1.8%) 632(1.8%) ??? /home/ztatlock/herbie/src/config.rkt:29:0 ------------------------------------------------------------------------ ??? [87] 100.0% [93] 480(1.4%) 242(0.7%) ...higher-order.rkt:373:33 (unknown source) ??? [95] 49.6% ------------------------------------------------------------------------ loop [80] 0.8% map [79] 0.9% bf* [91] 5.5% ??? [87] 92.9% [94] 24976(71.1%) 22292(63.5%) ??? ...-racket/utils/simple-result-arrow.rkt:26:12 ??? [99] 5.5% bfmul [96] 3.5% bfexpm1 [98] 1.7% ------------------------------------------------------------------------ ...higher-order.rkt:373:33 [93]100.0% [95] 238(0.7%) 0(0.0%) ??? ...cts/racket/contract/private/list.rkt:187:10 ??? [97] 100.0% ------------------------------------------------------------------------ ??? [94] 100.0% [96] 884(2.5%) 662(1.9%) bfmul ...-lib/math/private/bigfloat/mpfr.rkt:819:4 ??? [100] 25.1% ------------------------------------------------------------------------ ??? [82] 48.7% ??? [95] 51.3% [97] 464(1.3%) 0(0.0%) ??? ...ects/racket/contract/private/guts.rkt:638:8 ??? [99] 100.0% ------------------------------------------------------------------------ ??? [94] 100.0% [98] 418(1.2%) 418(1.2%) bfexpm1 ...ib/math/private/bigfloat/mpfr.rkt:616:4 ------------------------------------------------------------------------ ??? [97] 25.1% ??? [94] 74.9% [99] 1846(5.3%) 682(1.9%) ??? ...tract/private/arrow-higher-order.rkt:373:33 ??? [101] 63.1% ------------------------------------------------------------------------ bfmul [96] 100.0% [100] 222(0.6%) 222(0.6%) ??? .../share/racket/collects/ffi/unsafe.rkt:861:4 ------------------------------------------------------------------------ ??? [99] 100.0% [101] 1164(3.3%) 1164(3.3%) ??? ...llects/racket/contract/combinator.rkt:178:4 ------------------------------------------------------------------------