Profiling results ----------------- Total cpu time observed: 12516ms (out of 12728ms) Number of samples taken: 54 (once every 232ms) ======================================================================== Caller Idx Total Self Name+src Local% ms(pct) ms(pct) Callee ======================================================================== ??? [13] 100.0% [1] 12314(98.4%) 0(0.0%) profile-thunk14 ...t/pkgs/profile-lib/main.rkt:9:0 run [7] 100.0% ------------------------------------------------------------------------ ??? [13] 100.0% [2] 2690(21.5%) 0(0.0%) simplify ...lock/herbie/src/core/simplify.rkt:39:0 simplify-expr [8] 84.4% for-loop [10] 15.6% ------------------------------------------------------------------------ hash-ref! [80] 100.0% [3] 440(3.5%) 0(0.0%) ??? .../ztatlock/herbie/src/core/taylor.rkt:338:33 hash-ref! [80] 50.5% for-loop [12] 49.5% ------------------------------------------------------------------------ hash-ref! [80] 100.0% [4] 440(3.5%) 0(0.0%) ??? .../ztatlock/herbie/src/core/taylor.rkt:285:26 for-loop [9] 100.0% ------------------------------------------------------------------------ hash-ref! [80] 100.0% [5] 222(1.8%) 0(0.0%) ??? .../ztatlock/herbie/src/core/taylor.rkt:295:23 for-loop [11] 100.0% ------------------------------------------------------------------------ f16 [88] 100.0% [6] 218(1.7%) 0(0.0%) taylor-sqrt ...ck/herbie/src/core/taylor.rkt:346:0 simplify [82] 100.0% ------------------------------------------------------------------------ profile-thunk14 [1] 100.0% [7] 12314(98.4%) 0(0.0%) run ...share/racket/pkgs/profile-lib/main.rkt:31:2 ??? [13] 100.0% ------------------------------------------------------------------------ simplify [2] 100.0% [8] 2270(18.1%) 0(0.0%) simplify-expr ...herbie/src/core/simplify.rkt:68:0 iterate-egraph!5 [14] 100.0% ------------------------------------------------------------------------ ??? [4] 100.0% [9] 440(3.5%) 0(0.0%) for-loop ...lock/herbie/src/core/taylor.rkt:285:52 hash-ref! [80] 100.0% ------------------------------------------------------------------------ simplify [2] 100.0% [10] 420(3.4%) 0(0.0%) for-loop ...ock/herbie/src/core/simplify.rkt:61:12 iterate-egraph!5 [14] 100.0% ------------------------------------------------------------------------ ??? [5] 100.0% [11] 222(1.8%) 0(0.0%) for-loop ...lock/herbie/src/core/taylor.rkt:298:27 hash-ref! [80] 100.0% ------------------------------------------------------------------------ ??? [3] 100.0% [12] 218(1.7%) 0(0.0%) for-loop ...lock/herbie/src/core/taylor.rkt:341:46 hash-ref! [80] 100.0% ------------------------------------------------------------------------ for-loop [42] 7.4% run [7] 45.9% [13] 12516(100.0%) 0(0.0%) ??? ...lects/racket/private/more-scheme.rkt:261:28 profile-thunk14 [1] 45.9% run-improve58 [15] 31.0% loop [16] 15.7% simplify [2] 7.4% ------------------------------------------------------------------------ for-loop [10] 15.6% simplify-expr [8] 84.4% [14] 2690(21.5%) 0(0.0%) iterate-egraph!5 ...bie/src/core/simplify.rkt:95:0 one-iter [17] 100.0% ------------------------------------------------------------------------ ??? [13] 100.0% [15] 8590(68.6%) 0(0.0%) run-improve58 ...ock/herbie/src/mainloop.rkt:242:0 get-final-combination [18] 49.8% for-loop [19] 41.7% finalize-table! [22] 5.1% setup-prog [24] 3.4% ------------------------------------------------------------------------ ??? [13] 100.0% [16] 3926(31.4%) 0(0.0%) loop /home/ztatlock/herbie/src/points.rkt:122:2 make-exacts* [28] 55.9% loop [21] 44.1% ------------------------------------------------------------------------ iterate-egraph!5 [14] 100.0% [17] 2690(21.5%) 0(0.0%) one-iter ...ock/herbie/src/core/simplify.rkt:106:0 for-loop [20] 76.9% loop [23] 15.7% loop [25] 7.4% ------------------------------------------------------------------------ run-improve58 [15] 100.0% [18] 4280(34.2%) 0(0.0%) get-final-combination ...ie/src/mainloop.rkt:269:0 split-table [26] 100.0% ------------------------------------------------------------------------ run-improve58 [15] 100.0% [19] 3578(28.6%) 0(0.0%) for-loop ...ztatlock/herbie/src/mainloop.rkt:253:8 run-iter! [27] 100.0% ------------------------------------------------------------------------ for-loop [20] 50.0% one-iter [17] 50.0% [20] 2068(16.5%) 624(5.0%) for-loop ...ck/herbie/src/core/simplify.rkt:116:12 for-loop [20] 50.0% match-e [29] 34.9% ------------------------------------------------------------------------ loop [16] 100.0% [21] 1732(13.8%) 0(0.0%) loop /home/ztatlock/herbie/src/points.rkt:93:2 loop [30] 58.0% make-exacts* [28] 42.0% ------------------------------------------------------------------------ run-improve58 [15] 100.0% [22] 440(3.5%) 0(0.0%) finalize-table! ...k/herbie/src/mainloop.rkt:264:0 post-process [31] 100.0% ------------------------------------------------------------------------ one-iter [17] 100.0% [23] 422(3.4%) 0(0.0%) loop ...cket/collects/racket/private/map.rkt:53:19 apply-match [32] 100.0% ------------------------------------------------------------------------ run-improve58 [15] 100.0% [24] 292(2.3%) 0(0.0%) setup-prog /home/ztatlock/herbie/src/glue.rkt:46:0 ??? [44] 100.0% ------------------------------------------------------------------------ one-iter [17] 100.0% [25] 200(1.6%) 200(1.6%) loop ...ket/collects/racket/private/list.rkt:264:4 ------------------------------------------------------------------------ get-final-combination [18] 100.0% [26] 4280(34.2%) 0(0.0%) split-table .../ztatlock/herbie/src/glue.rkt:171:0 infer-splitpoints4 [33] 100.0% ------------------------------------------------------------------------ for-loop [19] 100.0% [27] 3578(28.6%) 0(0.0%) run-iter! ...tatlock/herbie/src/mainloop.rkt:223:0 simplify! [34] 75.2% gen-series! [37] 12.3% gen-rewrites! [38] 6.9% finalize-iter! [40] 5.6% ------------------------------------------------------------------------ loop [21] 24.9% loop [16] 75.1% [28] 2922(23.3%) 0(0.0%) make-exacts* ...tatlock/herbie/src/points.rkt:80:0 loop [91] 54.0% map [90] 46.0% ------------------------------------------------------------------------ for-loop [43] 14.6% for-loop [20] 85.4% [29] 1444(11.5%) 602(4.8%) match-e ...tatlock/herbie/src/core/ematch.rkt:46:0 for-loop [35] 29.8% for-loop [43] 21.5% loop [91] 6.9% ------------------------------------------------------------------------ loop [21] 100.0% [30] 1004(8.0%) 0(0.0%) loop /home/ztatlock/herbie/src/points.rkt:83:4 map [90] 100.0% ------------------------------------------------------------------------ finalize-table! [22] 100.0% [31] 440(3.5%) 0(0.0%) post-process .../ztatlock/herbie/src/glue.rkt:95:0 for-loop [36] 100.0% ------------------------------------------------------------------------ loop [23] 100.0% [32] 422(3.4%) 0(0.0%) apply-match .../herbie/src/core/simplify.rkt:122:2 loop! [47] 52.1% merge-egraph-nodes! [39] 47.9% ------------------------------------------------------------------------ split-table [26] 100.0% [33] 4280(34.2%) 0(0.0%) infer-splitpoints4 ...ie/src/core/regimes.rkt:19:0 option-on-expr [41] 94.8% for-loop [49] 5.2% ------------------------------------------------------------------------ run-iter! [27] 100.0% [34] 2690(21.5%) 0(0.0%) simplify! ...tatlock/herbie/src/mainloop.rkt:162:0 for-loop [42] 100.0% ------------------------------------------------------------------------ match-e [29] 100.0% [35] 642(5.1%) 442(3.5%) for-loop ...tlock/herbie/src/core/ematch.rkt:59:11 for-loop [43] 31.2% ------------------------------------------------------------------------ post-process [31] 100.0% [36] 440(3.5%) 0(0.0%) for-loop /home/ztatlock/herbie/src/glue.rkt:119:17 append-map [45] 100.0% ------------------------------------------------------------------------ run-iter! [27] 100.0% [37] 440(3.5%) 0(0.0%) gen-series! ...tlock/herbie/src/mainloop.rkt:134:0 for-loop [46] 100.0% ------------------------------------------------------------------------ run-iter! [27] 100.0% [38] 246(2.0%) 0(0.0%) gen-rewrites! ...ock/herbie/src/mainloop.rkt:148:0 for-loop [48] 100.0% ------------------------------------------------------------------------ apply-match [32] 100.0% [39] 202(1.6%) 0(0.0%) merge-egraph-nodes! ...e/src/core/egraph.rkt:152:0 loop! [47] 100.0% ------------------------------------------------------------------------ run-iter! [27] 100.0% [40] 202(1.6%) 0(0.0%) finalize-iter! ...ck/herbie/src/mainloop.rkt:177:0 ??? [44] 100.0% ------------------------------------------------------------------------ infer-splitpoints4 [33] 100.0% [41] 4058(32.4%) 0(0.0%) option-on-expr ...erbie/src/core/regimes.rkt:106:0 sort-context-on-expr [50] 88.6% pick-errors [52] 11.4% ------------------------------------------------------------------------ simplify! [34] 100.0% [42] 2690(21.5%) 0(0.0%) for-loop ...ztatlock/herbie/src/mainloop.rkt:166:6 ??? [13] 100.0% ------------------------------------------------------------------------ for-loop [35] 32.2% match-e [29] 67.8% [43] 622(5.0%) 200(1.6%) for-loop ...tlock/herbie/src/core/ematch.rkt:65:37 match-e [29] 67.8% ------------------------------------------------------------------------ finalize-iter! [40] 40.9% setup-prog [24] 59.1% [44] 494(3.9%) 0(0.0%) ??? ...contract/private/arrow-val-first.rkt:357:18 make-alt-table [54] 59.1% for-loop [56] 40.9% ------------------------------------------------------------------------ for-loop [36] 100.0% [45] 440(3.5%) 0(0.0%) append-map ...acket/collects/racket/list.rkt:565:2 taylor-alt [51] 100.0% ------------------------------------------------------------------------ gen-series! [37] 100.0% [46] 440(3.5%) 0(0.0%) for-loop ...ztatlock/herbie/src/mainloop.rkt:140:7 taylor-alt [51] 100.0% ------------------------------------------------------------------------ merge-egraph-nodes! [39] 47.9% apply-match [32] 52.1% [47] 422(3.4%) 0(0.0%) loop! .../ztatlock/herbie/src/core/enode.rkt:163:2 custom-set-union [53] 100.0% ------------------------------------------------------------------------ gen-rewrites! [38] 100.0% [48] 246(2.0%) 0(0.0%) for-loop ...tatlock/herbie/src/mainloop.rkt:153:11 ??? [55] 100.0% ------------------------------------------------------------------------ infer-splitpoints4 [33] 100.0% [49] 222(1.8%) 222(1.8%) for-loop ...tlock/herbie/src/core/regimes.rkt:25:4 ------------------------------------------------------------------------ option-on-expr [41] 100.0% [50] 3596(28.7%) 0(0.0%) sort-context-on-expr ...herbie/src/points.rkt:50:0 sort [57] 100.0% ------------------------------------------------------------------------ for-loop [46] 50.0% append-map [45] 50.0% [51] 880(7.0%) 0(0.0%) taylor-alt ...e/ztatlock/herbie/src/glue.rkt:142:0 for-loop [58] 100.0% ------------------------------------------------------------------------ option-on-expr [41] 100.0% [52] 462(3.7%) 0(0.0%) pick-errors ...k/herbie/src/core/regimes.rkt:173:0 for-loop [59] 100.0% ------------------------------------------------------------------------ loop! [47] 100.0% [53] 422(3.4%) 220(1.8%) custom-set-union ...et/private/set-types.rkt:168:0 for-loop [62] 47.9% ------------------------------------------------------------------------ ??? [44] 100.0% [54] 292(2.3%) 0(0.0%) make-alt-table ...rbie/src/core/alt-table.rkt:32:0 for-loop [60] 100.0% ------------------------------------------------------------------------ for-loop [48] 100.0% [55] 246(2.0%) 0(0.0%) ??? /home/ztatlock/herbie/src/alternative.rkt:90:0 rewriter [61] 100.0% ------------------------------------------------------------------------ ??? [44] 100.0% [56] 202(1.6%) 0(0.0%) for-loop ...ock/herbie/src/core/alt-table.rkt:51:2 atab-add-altn [63] 100.0% ------------------------------------------------------------------------ sort-context-on-expr [50] 100.0% [57] 3596(28.7%) 0(0.0%) sort ...ket/collects/racket/private/sort.rkt:213:0 copying-mergesort [64] 68.7% loop [70] 31.3% ------------------------------------------------------------------------ taylor-alt [51] 100.0% [58] 880(7.0%) 0(0.0%) for-loop /home/ztatlock/herbie/src/glue.rkt:144:2 location-do [65] 100.0% ------------------------------------------------------------------------ pick-errors [52] 100.0% [59] 462(3.7%) 0(0.0%) for-loop ...lock/herbie/src/core/regimes.rkt:176:4 eval-prog [79] 100.0% ------------------------------------------------------------------------ make-alt-table [54] 100.0% [60] 292(2.3%) 0(0.0%) for-loop ...ck/herbie/src/core/alt-table.rkt:34:15 ??? [66] 100.0% ------------------------------------------------------------------------ ??? [55] 100.0% [61] 246(2.0%) 0(0.0%) rewriter ...lock/herbie/src/core/matcher.rkt:123:2 for-loop [67] 100.0% ------------------------------------------------------------------------ custom-set-union [53] 100.0% [62] 202(1.6%) 0(0.0%) for-loop ...cts/racket/private/set-types.rkt:174:3 for-loop [68] 100.0% ------------------------------------------------------------------------ for-loop [56] 100.0% [63] 202(1.6%) 0(0.0%) atab-add-altn ...rbie/src/core/alt-table.rkt:208:0 best-and-tied-at-points [69] 100.0% ------------------------------------------------------------------------ sort [57] 39.7% copying-mergesort [64] 60.3% [64] 2472(19.8%) 0(0.0%) copying-mergesort .../racket/private/sort.rkt:91:4 copying-mergesort [64] 60.3% loop [70] 28.1% jloop [71] 11.6% ------------------------------------------------------------------------ location-do [65] 25.2% for-loop [58] 74.8% [65] 880(7.0%) 0(0.0%) location-do ...tlock/herbie/src/programs.rkt:129:0 approximate9 [72] 74.8% location-do [65] 25.2% ------------------------------------------------------------------------ for-loop [60] 100.0% [66] 292(2.3%) 292(2.3%) ??? ...ket/collects/racket/private/for.rkt:1150:14 ------------------------------------------------------------------------ rewriter [61] 100.0% [67] 246(2.0%) 0(0.0%) for-loop ...ock/herbie/src/core/matcher.rkt:126:10 matcher [73] 100.0% ------------------------------------------------------------------------ for-loop [62] 100.0% [68] 202(1.6%) 202(1.6%) for-loop ...cts/racket/private/set-types.rkt:178:5 ------------------------------------------------------------------------ atab-add-altn [63] 100.0% [69] 202(1.6%) 0(0.0%) best-and-tied-at-points ...ore/alt-table.rkt:122:0 errors [74] 100.0% ------------------------------------------------------------------------ sort [57] 45.9% copying-mergesort [64] 54.1% [70] 2448(19.6%) 0(0.0%) loop ...cket/collects/racket/private/sort.rkt:64:8 ??? [75] 100.0% ------------------------------------------------------------------------ copying-mergesort [64] 100.0% [71] 1148(9.2%) 0(0.0%) jloop ...et/collects/racket/private/sort.rkt:85:19 ??? [75] 100.0% ------------------------------------------------------------------------ location-do [65] 100.0% [72] 880(7.0%) 0(0.0%) approximate9 ...ck/herbie/src/core/taylor.rkt:11:0 loop [76] 50.0% f16 [88] 50.0% ------------------------------------------------------------------------ for-loop [67] 100.0% [73] 246(2.0%) 0(0.0%) matcher ...tlock/herbie/src/core/matcher.rkt:159:2 for-loop [77] 100.0% ------------------------------------------------------------------------ best-and-tied-at-points [69] 100.0% [74] 202(1.6%) 0(0.0%) errors /home/ztatlock/herbie/src/points.rkt:144:0 for-loop [78] 100.0% ------------------------------------------------------------------------ jloop [71] 31.9% loop [70] 68.1% [75] 3596(28.7%) 440(3.5%) ??? /home/ztatlock/herbie/src/points.rkt:52:27 eval-prog [79] 87.8% ------------------------------------------------------------------------ approximate9 [72] 100.0% [76] 440(3.5%) 0(0.0%) loop ...e/ztatlock/herbie/src/core/taylor.rkt:82:4 hash-ref! [80] 100.0% ------------------------------------------------------------------------ matcher [73] 100.0% [77] 246(2.0%) 246(2.0%) for-loop ...lock/herbie/src/core/matcher.rkt:143:6 ------------------------------------------------------------------------ errors [74] 100.0% [78] 202(1.6%) 0(0.0%) for-loop ...e/ztatlock/herbie/src/points.rkt:147:4 ->flonum [81] 100.0% ------------------------------------------------------------------------ for-loop [59] 12.8% ??? [75] 87.2% [79] 3618(28.9%) 3156(25.2%) eval-prog ...tatlock/herbie/src/programs.rkt:162:0 ??? [84] 6.7% parse-lambda [85] 6.1% ------------------------------------------------------------------------ for-loop [12] 9.9% ??? [86] 9.9% ??? [3] 10.1% for-loop [11] 10.1% for-loop [9] 20.0% ??? [83] 20.0% loop [76] 20.0% [80] 440(3.5%) 0(0.0%) hash-ref! ...racket/private/more-scheme.rkt:373:13 ??? [83] 20.0% ??? [3] 20.0% ??? [4] 20.0% simplify [82] 20.0% ??? [5] 10.1% ??? [86] 9.9% ------------------------------------------------------------------------ for-loop [78] 100.0% [81] 202(1.6%) 0(0.0%) ->flonum ...ock/herbie/src/syntax/syntax.rkt:224:0 ??? [87] 100.0% ------------------------------------------------------------------------ taylor-sqrt [6] 33.1% hash-ref! [80] 66.9% [82] 658(5.3%) 0(0.0%) simplify ...atlock/herbie/src/core/reduce.rkt:18:0 f16 [88] 66.3% parse-loop50 [92] 33.7% ------------------------------------------------------------------------ hash-ref! [80] 100.0% [83] 440(3.5%) 0(0.0%) ??? ...e/ztatlock/herbie/src/core/taylor.rkt:42:15 hash-ref! [80] 100.0% ------------------------------------------------------------------------ eval-prog [79] 100.0% [84] 242(1.9%) 0(0.0%) ??? ...collects/racket/private/qq-and-or.rkt:155:9 ??? [89] 100.0% ------------------------------------------------------------------------ eval-prog [79] 100.0% [85] 220(1.8%) 220(1.8%) parse-lambda ...llects/racket/private/kw.rkt:393:2 ------------------------------------------------------------------------ hash-ref! [80] 100.0% [86] 218(1.7%) 0(0.0%) ??? ...e/ztatlock/herbie/src/core/taylor.rkt:63:15 hash-ref! [80] 100.0% ------------------------------------------------------------------------ ->flonum [81] 100.0% [87] 202(1.6%) 202(1.6%) ??? /home/ztatlock/herbie/src/config.rkt:29:0 ------------------------------------------------------------------------ approximate9 [72] 25.0% f16 [88] 25.3% simplify [82] 49.7% [88] 658(5.3%) 218(1.7%) f16 ...t/collects/racket/match/compiler.rkt:499:40 f16 [88] 25.3% map [90] 25.0% taylor-sqrt [6] 16.6% ------------------------------------------------------------------------ ??? [84] 100.0% [89] 242(1.9%) 242(1.9%) ??? ...ollects/racket/private/qq-and-or.rkt:164:21 ------------------------------------------------------------------------ f16 [88] 15.8% loop [30] 36.0% make-exacts* [28] 48.2% [90] 2788(22.3%) 0(0.0%) map ...acket/collects/racket/private/map.rkt:21:13 loop [91] 84.2% taylor-invert [93] 8.0% parse-loop50 [92] 7.8% ------------------------------------------------------------------------ make-exacts* [28] 0.1% map [90] 0.5% match-e [29] 4.8% loop [91] 94.6% [91] 4126(33.0%) 0(0.0%) loop ...cket/collects/racket/private/map.rkt:26:19 loop [91] 94.6% curried [96] 4.8% ??? [94] 0.5% ------------------------------------------------------------------------ map [90] 49.5% simplify [82] 50.5% [92] 440(3.5%) 440(3.5%) parse-loop50 ...s/racket/match/compiler.rkt:410:15 ------------------------------------------------------------------------ map [90] 100.0% [93] 222(1.8%) 0(0.0%) taylor-invert .../herbie/src/core/taylor.rkt:312:0 first-nonzero-exp [95] 100.0% ------------------------------------------------------------------------ loop [91] 100.0% [94] 3926(31.4%) 0(0.0%) ??? /home/ztatlock/herbie/src/programs.rkt:168:4 ??? [97] 46.9% real->bigfloat [98] 33.7% ??? [101] 19.4% ------------------------------------------------------------------------ taylor-invert [93] 100.0% [95] 222(1.8%) 222(1.8%) first-nonzero-exp ...bie/src/core/taylor.rkt:260:0 ------------------------------------------------------------------------ loop [91] 100.0% [96] 200(1.6%) 200(1.6%) curried ...cket/collects/racket/function.rkt:71:18 ------------------------------------------------------------------------ ??? [94] 100.0% [97] 1842(14.7%) 0(0.0%) ??? ...acket/collects/racket/private/kw.rkt:400:14 ??? [99] 84.0% ...higher-order.rkt:373:33 [100] 16.0% ------------------------------------------------------------------------ ??? [94] 100.0% [98] 1322(10.6%) 1322(10.6%) real->bigfloat .../private/bigfloat/mpfr.rkt:451:0 ------------------------------------------------------------------------ ??? [97] 100.0% [99] 1548(12.4%) 0(0.0%) ??? ...-racket/utils/simple-result-arrow.rkt:26:12 bfadd [102] 66.9% ??? [103] 33.1% ------------------------------------------------------------------------ ??? [97] 100.0% [100] 294(2.3%) 0(0.0%) ...higher-order.rkt:373:33 (unknown source) ??? [101] 100.0% ------------------------------------------------------------------------ ...higher-order.rkt:373:33 [100] 27.8% ??? [94] 72.2% [101] 1056(8.4%) 0(0.0%) ??? ...ects/racket/contract/private/guts.rkt:638:8 ??? [103] 100.0% ------------------------------------------------------------------------ ??? [99] 100.0% [102] 1036(8.3%) 1036(8.3%) bfadd ...-lib/math/private/bigfloat/mpfr.rkt:819:4 ------------------------------------------------------------------------ ??? [99] 32.7% ??? [101] 67.3% [103] 1568(12.5%) 490(3.9%) ??? ...tract/private/arrow-higher-order.rkt:373:33 ??? [104] 52.7% ??? [105] 16.1% ------------------------------------------------------------------------ ??? [103] 100.0% [104] 826(6.6%) 272(2.2%) ??? ...llects/racket/contract/combinator.rkt:178:4 any-wrap/traverse [106] 67.1% ------------------------------------------------------------------------ ??? [103] 100.0% [105] 252(2.0%) 252(2.0%) ??? ...ects/racket/contract/private/prop.rkt:489:4 ------------------------------------------------------------------------ ??? [104] 100.0% [106] 554(4.4%) 554(4.4%) any-wrap/traverse ...cket/utils/any-wrap.rkt:106:2 ------------------------------------------------------------------------