Profiling results ----------------- Total cpu time observed: 23544ms (out of 24192ms) Number of samples taken: 98 (once every 240ms) (Hiding functions with self<1.0% and local<2.0%: 1 of 93 hidden) ====================================================================== Caller Idx Total Self Name+src Local% ms(pct) ms(pct) Callee ====================================================================== ??? [30] 100.0% [1] 21676(92.1%) 0(0.0%) profile-thunk14 ...t/pkgs/profile-lib/main.rkt:9:0 run [8] 100.0% ---------------------------------------------------------------------- ??? [30] 100.0% [2] 7318(31.1%) 0(0.0%) run-improve58 ...ock/herbie/src/mainloop.rkt:242:0 for-loop [9] 88.5% finalize-table! [12] 8.8% loop [34] 2.7% ---------------------------------------------------------------------- ??? [30] 100.0% [3] 5420(23.0%) 0(0.0%) simplify ...lock/herbie/src/core/simplify.rkt:39:0 simplify-expr [10] 41.0% for-loop [11] 34.6% iterate-egraph!5 [16] 24.3% ---------------------------------------------------------------------- map [68] 41.6% loop [71] 58.4% [4] 436(1.9%) 0(0.0%) ??? ...ket/collects/racket/private/list.rkt:323:18 hash-ref! [60] 58.4% map [68] 41.6% ---------------------------------------------------------------------- hash-ref! [60] 100.0% [5] 404(1.7%) 0(0.0%) simplify ...atlock/herbie/src/core/reduce.rkt:18:0 parse-loop12 [64] 100.0% ---------------------------------------------------------------------- location-do [46] 100.0% [6] 404(1.7%) 0(0.0%) approximate9 ...ck/herbie/src/core/taylor.rkt:11:0 loop [13] 100.0% ---------------------------------------------------------------------- hash-ref! [60] 100.0% [7] 202(0.9%) 0(0.0%) ??? .../ztatlock/herbie/src/core/taylor.rkt:285:26 for-loop [14] 100.0% ---------------------------------------------------------------------- profile-thunk14 [1] 98.0% [8] 22120(94.0%) 0(0.0%) run ...share/racket/pkgs/profile-lib/main.rkt:31:2 ??? [30] 100.0% ---------------------------------------------------------------------- run-improve58 [2] 100.0% [9] 6478(27.5%) 0(0.0%) for-loop ...ztatlock/herbie/src/mainloop.rkt:253:8 run-iter! [15] 100.0% ---------------------------------------------------------------------- completely-simplify-alt [76] 16.6% simplify [3] 83.4% [10] 2666(11.3%) 0(0.0%) simplify-expr ...herbie/src/core/simplify.rkt:68:0 iterate-egraph!5 [16] 100.0% ---------------------------------------------------------------------- simplify [3] 100.0% [11] 1878(8.0%) 0(0.0%) for-loop ...ock/herbie/src/core/simplify.rkt:61:12 iterate-egraph!5 [16] 100.0% ---------------------------------------------------------------------- run-improve58 [2] 100.0% [12] 644(2.7%) 0(0.0%) finalize-table! ...k/herbie/src/mainloop.rkt:264:0 post-process [17] 100.0% ---------------------------------------------------------------------- approximate9 [6] 100.0% [13] 404(1.7%) 0(0.0%) loop ...e/ztatlock/herbie/src/core/taylor.rkt:82:4 hash-ref! [60] 100.0% ---------------------------------------------------------------------- ??? [7] 100.0% [14] 202(0.9%) 0(0.0%) for-loop ...lock/herbie/src/core/taylor.rkt:285:52 hash-ref! [60] 100.0% ---------------------------------------------------------------------- for-loop [9] 100.0% [15] 6478(27.5%) 0(0.0%) run-iter! ...tatlock/herbie/src/mainloop.rkt:223:0 simplify! [19] 83.7% localize-error [20] 6.7% finalize-iter! [21] 6.5% gen-series! [23] 3.1% ---------------------------------------------------------------------- simplify [3] 22.5% for-loop [11] 32.0% simplify-expr [10] 45.5% [16] 5862(24.9%) 0(0.0%) iterate-egraph!5 ...bie/src/core/simplify.rkt:95:0 one-iter [18] 100.0% ---------------------------------------------------------------------- finalize-table! [12] 100.0% [17] 644(2.7%) 0(0.0%) post-process .../ztatlock/herbie/src/glue.rkt:95:0 completely-simplify-alt [76] 34.5% loop [71] 34.2% for-loop [22] 31.4% ---------------------------------------------------------------------- iterate-egraph!5 [16] 100.0% [18] 5862(24.9%) 240(1.0%) one-iter ...ock/herbie/src/core/simplify.rkt:106:0 loop [25] 46.4% for-loop [26] 41.9% apply-match [31] 7.6% ---------------------------------------------------------------------- run-iter! [15] 100.0% [19] 5420(23.0%) 0(0.0%) simplify! ...tatlock/herbie/src/mainloop.rkt:162:0 for-loop [24] 100.0% ---------------------------------------------------------------------- run-iter! [15] 100.0% [20] 436(1.9%) 0(0.0%) localize-error ...erbie/src/core/localize.rkt:47:0 hash-ref! [60] 100.0% ---------------------------------------------------------------------- run-iter! [15] 100.0% [21] 420(1.8%) 0(0.0%) finalize-iter! ...ck/herbie/src/mainloop.rkt:177:0 ??? [27] 100.0% ---------------------------------------------------------------------- post-process [17] 100.0% [22] 202(0.9%) 0(0.0%) for-loop /home/ztatlock/herbie/src/glue.rkt:119:17 append-map [28] 100.0% ---------------------------------------------------------------------- run-iter! [15] 100.0% [23] 202(0.9%) 0(0.0%) gen-series! ...tlock/herbie/src/mainloop.rkt:134:0 for-loop [29] 100.0% ---------------------------------------------------------------------- simplify! [19] 100.0% [24] 5420(23.0%) 0(0.0%) for-loop ...ztatlock/herbie/src/mainloop.rkt:166:6 ??? [30] 100.0% ---------------------------------------------------------------------- one-iter [18] 100.0% [25] 2720(11.6%) 0(0.0%) loop ...cket/collects/racket/private/map.rkt:53:19 apply-match [31] 100.0% ---------------------------------------------------------------------- for-loop [26] 50.0% one-iter [18] 50.0% [26] 2458(10.4%) 700(3.0%) for-loop ...ck/herbie/src/core/simplify.rkt:116:12 for-loop [26] 50.0% match-e [35] 35.8% ---------------------------------------------------------------------- finalize-iter! [21] 100.0% [27] 420(1.8%) 0(0.0%) ??? ...contract/private/arrow-val-first.rkt:357:18 for-loop [32] 100.0% ---------------------------------------------------------------------- for-loop [22] 100.0% [28] 202(0.9%) 0(0.0%) append-map ...acket/collects/racket/list.rkt:565:2 taylor-alt [33] 100.0% ---------------------------------------------------------------------- gen-series! [23] 100.0% [29] 202(0.9%) 0(0.0%) for-loop ...ztatlock/herbie/src/mainloop.rkt:140:7 taylor-alt [33] 100.0% ---------------------------------------------------------------------- for-loop [24] 8.0% run [8] 44.4% [30] 23544(100.0%) 0(0.0%) ??? ...lects/racket/private/more-scheme.rkt:261:28 profile-thunk14 [1] 42.5% loop [34] 37.4% run-improve58 [2] 12.0% simplify [3] 8.0% ---------------------------------------------------------------------- one-iter [18] 14.0% loop [25] 86.0% [31] 3164(13.4%) 0(0.0%) apply-match .../herbie/src/core/simplify.rkt:122:2 for-loop [36] 29.6% merge-egraph-nodes! [37] 22.2% match-e [35] 21.0% mk-enode! [38] 13.3% substitute-e [41] 7.6% loop! [75] 6.3% ---------------------------------------------------------------------- ??? [27] 100.0% [32] 420(1.8%) 0(0.0%) for-loop ...ock/herbie/src/core/alt-table.rkt:51:2 atab-add-altn [39] 100.0% ---------------------------------------------------------------------- for-loop [29] 50.0% append-map [28] 50.0% [33] 404(1.7%) 0(0.0%) taylor-alt ...e/ztatlock/herbie/src/glue.rkt:142:0 for-loop [40] 100.0% ---------------------------------------------------------------------- run-improve58 [2] 1.2% ??? [30] 98.8% [34] 16422(69.8%) 0(0.0%) loop /home/ztatlock/herbie/src/points.rkt:122:2 loop [42] 50.4% make-exacts* [49] 34.6% loop [50] 12.3% filter-points [47] 1.5% ---------------------------------------------------------------------- for-loop [51] 13.6% apply-match [31] 17.9% for-loop [26] 68.5% [35] 2422(10.3%) 1500(6.4%) match-e ...tatlock/herbie/src/core/ematch.rkt:46:0 for-loop [44] 14.0% constant? [48] 9.8% list-cartesian-product [52] 9.2% for-loop [51] 4.6% loop [71] 4.6% ---------------------------------------------------------------------- apply-match [31] 100.0% [36] 938(4.0%) 0(0.0%) for-loop ...ck/herbie/src/core/simplify.rkt:136:10 loop! [75] 100.0% ---------------------------------------------------------------------- apply-match [31] 100.0% [37] 702(3.0%) 0(0.0%) merge-egraph-nodes! ...e/src/core/egraph.rkt:152:0 update-leader! [43] 100.0% ---------------------------------------------------------------------- apply-match [31] 100.0% [38] 422(1.8%) 422(1.8%) mk-enode! ...lock/herbie/src/core/egraph.rkt:101:0 ---------------------------------------------------------------------- for-loop [32] 100.0% [39] 420(1.8%) 0(0.0%) atab-add-altn ...rbie/src/core/alt-table.rkt:208:0 best-and-tied-at-points [45] 100.0% ---------------------------------------------------------------------- taylor-alt [33] 100.0% [40] 404(1.7%) 0(0.0%) for-loop /home/ztatlock/herbie/src/glue.rkt:144:2 location-do [46] 100.0% ---------------------------------------------------------------------- substitute-e [41] 50.0% apply-match [31] 50.0% [41] 240(1.0%) 240(1.0%) substitute-e ...ck/herbie/src/core/ematch.rkt:71:0 substitute-e [41] 50.0% ---------------------------------------------------------------------- loop [34] 100.0% [42] 8274(35.1%) 0(0.0%) loop /home/ztatlock/herbie/src/points.rkt:93:2 loop [50] 55.8% make-exacts* [49] 35.6% eval-prog [56] 8.6% ---------------------------------------------------------------------- merge-egraph-nodes! [37] 100.0% [43] 702(3.0%) 242(1.0%) update-leader! ...herbie/src/core/egraph.rkt:217:0 for-loop [53] 65.5% ---------------------------------------------------------------------- match-e [35] 100.0% [44] 438(1.9%) 0(0.0%) for-loop ...tlock/herbie/src/core/ematch.rkt:59:11 for-loop [51] 72.6% list-cartesian-product [52] 27.4% ---------------------------------------------------------------------- atab-add-altn [39] 100.0% [45] 420(1.8%) 0(0.0%) best-and-tied-at-points ...ore/alt-table.rkt:122:0 errors [54] 100.0% ---------------------------------------------------------------------- for-loop [40] 35.0% location-do [46] 65.0% [46] 404(1.7%) 0(0.0%) location-do ...tlock/herbie/src/programs.rkt:129:0 location-do [46] 65.0% approximate9 [6] 35.0% ---------------------------------------------------------------------- loop [34] 100.0% [47] 244(1.0%) 0(0.0%) filter-points ...tlock/herbie/src/points.rkt:101:0 for-loop [55] 100.0% ---------------------------------------------------------------------- match-e [35] 100.0% [48] 238(1.0%) 238(1.0%) constant? ...ck/herbie/src/syntax/syntax.rkt:221:0 ---------------------------------------------------------------------- loop [42] 34.1% loop [34] 65.9% [49] 8632(36.7%) 0(0.0%) make-exacts* ...tatlock/herbie/src/points.rkt:80:0 loop [71] 51.8% map [68] 45.6% eval-prog [56] 2.6% ---------------------------------------------------------------------- loop [34] 30.4% loop [42] 69.6% [50] 6632(28.2%) 0(0.0%) loop /home/ztatlock/herbie/src/points.rkt:83:4 map [68] 100.0% ---------------------------------------------------------------------- match-e [35] 33.6% for-loop [44] 66.4% [51] 660(2.8%) 0(0.0%) for-loop ...tlock/herbie/src/core/ematch.rkt:65:37 match-e [35] 100.0% ---------------------------------------------------------------------- list-cartesian-product [52] 24.0% match-e [35] 24.0% for-loop [44] 51.9% [52] 462(2.0%) 222(0.9%) list-cartesian-product ...src/core/ematch.rkt:20:0 for-loop [59] 51.9% list-cartesian-product [52] 24.0% ---------------------------------------------------------------------- update-leader! [43] 100.0% [53] 460(2.0%) 0(0.0%) for-loop ...tlock/herbie/src/core/egraph.rkt:222:6 for-loop [57] 100.0% ---------------------------------------------------------------------- best-and-tied-at-points [45] 100.0% [54] 420(1.8%) 0(0.0%) errors /home/ztatlock/herbie/src/points.rkt:144:0 for-loop [58] 100.0% ---------------------------------------------------------------------- filter-points [47] 100.0% [55] 244(1.0%) 244(1.0%) for-loop ...e/ztatlock/herbie/src/points.rkt:104:4 ---------------------------------------------------------------------- make-exacts* [49] 24.2% loop [42] 75.8% [56] 942(4.0%) 234(1.0%) eval-prog ...tatlock/herbie/src/programs.rkt:162:0 hash-ref! [60] 75.2% ---------------------------------------------------------------------- for-loop [53] 100.0% [57] 460(2.0%) 0(0.0%) for-loop ...tlock/herbie/src/core/egraph.rkt:223:8 hash-update! [61] 100.0% ---------------------------------------------------------------------- errors [54] 100.0% [58] 420(1.8%) 200(0.8%) for-loop ...e/ztatlock/herbie/src/points.rkt:147:4 ??? [73] 52.4% ---------------------------------------------------------------------- list-cartesian-product [52] 100.0% [59] 240(1.0%) 240(1.0%) for-loop ...atlock/herbie/src/core/ematch.rkt:24:8 ---------------------------------------------------------------------- for-loop [14] 4.3% eval-prog [56] 9.8% ??? [67] 10.9% loop [13] 10.9% localize-error [20] 11.7% ??? [4] 16.5% loop [71] 35.9% [60] 1548(6.6%) 0(0.0%) hash-ref! ...racket/private/more-scheme.rkt:373:13 ??? [63] 35.9% f6 [66] 23.4% ??? [67] 10.9% simplify [5] 10.9% bigfloat-hash [62] 9.8% parse-loop12 [64] 4.7% ??? [7] 4.3% ---------------------------------------------------------------------- for-loop [57] 100.0% [61] 460(2.0%) 0(0.0%) hash-update! ...ket/private/more-scheme.rkt:362:13 ??? [65] 100.0% ---------------------------------------------------------------------- hash-ref! [60] 100.0% [62] 708(3.0%) 0(0.0%) bigfloat-hash ...h/private/bigfloat/mpfr.rkt:165:0 bfcanonicalize [69] 100.0% ---------------------------------------------------------------------- hash-ref! [60] 100.0% [63] 708(3.0%) 0(0.0%) ??? /home/ztatlock/herbie/src/programs.rkt:197:5 loop [71] 100.0% ---------------------------------------------------------------------- hash-ref! [60] 35.3% simplify [5] 64.7% [64] 624(2.7%) 404(1.7%) parse-loop12 ...s/racket/match/compiler.rkt:410:15 loop [71] 35.3% ---------------------------------------------------------------------- hash-update! [61] 100.0% [65] 460(2.0%) 0(0.0%) ??? .../ztatlock/herbie/src/core/egraph.rkt:225:24 for-loop [70] 100.0% ---------------------------------------------------------------------- hash-ref! [60] 100.0% [66] 436(1.9%) 0(0.0%) f6 ...et/collects/racket/match/compiler.rkt:499:40 map [68] 100.0% ---------------------------------------------------------------------- hash-ref! [60] 100.0% [67] 404(1.7%) 0(0.0%) ??? ...e/ztatlock/herbie/src/core/taylor.rkt:42:15 hash-ref! [60] 100.0% ---------------------------------------------------------------------- ??? [4] 1.3% f6 [66] 2.6% make-exacts* [49] 35.7% loop [50] 60.3% [68] 11000(46.7%) 0(0.0%) map ...acket/collects/racket/private/map.rkt:21:13 loop [71] 93.2% ??? [73] 4.1% ??? [4] 1.3% ->flonum [74] 1.3% ---------------------------------------------------------------------- bigfloat-hash [62] 100.0% [69] 708(3.0%) 708(3.0%) bfcanonicalize .../private/bigfloat/mpfr.rkt:155:0 ---------------------------------------------------------------------- ??? [65] 100.0% [70] 460(2.0%) 218(0.9%) for-loop ...lock/herbie/src/core/egraph.rkt:226:26 update-en-expr [72] 52.6% ---------------------------------------------------------------------- parse-loop12 [64] 0.0% make-exacts* [49] 0.2% post-process [17] 0.4% loop! [75] 0.8% match-e [35] 1.3% map [68] 1.5% ??? [63] 4.2% loop [71] 91.5% [71] 16868(71.6%) 442(1.9%) loop ...cket/collects/racket/private/map.rkt:26:19 loop [71] 91.5% hash-ref! [60] 4.2% ??? [73] 1.5% loop! [75] 0.8% completely-simplify-alt [76] 0.4% ??? [4] 0.2% ->flonum [74] 0.0% ---------------------------------------------------------------------- for-loop [70] 100.0% [72] 242(1.0%) 242(1.0%) update-en-expr ...herbie/src/core/egraph.rkt:211:0 ---------------------------------------------------------------------- for-loop [58] 1.5% map [68] 3.2% loop [71] 95.3% [73] 14318(60.8%) 402(1.7%) ??? /home/ztatlock/herbie/src/programs.rkt:168:4 ??? [77] 66.8% real->bigfloat [78] 25.6% ??? [88] 4.7% ---------------------------------------------------------------------- map [68] 37.8% loop [71] 62.2% [74] 1154(4.9%) 484(2.1%) ->flonum ...ock/herbie/src/syntax/syntax.rkt:224:0 ??? [90] 58.1% ---------------------------------------------------------------------- apply-match [31] 17.4% loop [71] 30.7% for-loop [36] 51.8% [75] 1136(4.8%) 460(2.0%) loop! .../ztatlock/herbie/src/core/enode.rkt:163:2 loop [71] 30.7% custom-set-union [79] 28.0% set [80] 10.5% ---------------------------------------------------------------------- loop [71] 49.8% post-process [17] 50.2% [76] 442(1.9%) 0(0.0%) completely-simplify-alt ...erbie/src/glue.rkt:87:0 simplify-expr [10] 100.0% ---------------------------------------------------------------------- ??? [73] 100.0% [77] 9570(40.6%) 702(3.0%) ??? ...acket/collects/racket/private/kw.rkt:400:14 ??? [81] 67.4% ...higher-order.rkt:373:33 [82] 25.2% ---------------------------------------------------------------------- ??? [73] 100.0% [78] 3668(15.6%) 3222(13.7%) real->bigfloat .../private/bigfloat/mpfr.rkt:451:0 ??? [89] 12.2% ---------------------------------------------------------------------- loop! [75] 100.0% [79] 438(1.9%) 240(1.0%) custom-set-union ...et/private/set-types.rkt:168:0 for-loop [83] 45.2% ---------------------------------------------------------------------- loop! [75] 100.0% [80] 238(1.0%) 238(1.0%) set ...collects/racket/private/set-types.rkt:982:0 ---------------------------------------------------------------------- ??? [77] 100.0% [81] 6454(27.4%) 472(2.0%) ??? ...-racket/utils/simple-result-arrow.rkt:26:12 bfdiv [84] 45.8% ??? [90] 25.0% bfneg [85] 21.8% ---------------------------------------------------------------------- ??? [77] 100.0% [82] 2414(10.3%) 0(0.0%) ...higher-order.rkt:373:33 (unknown source) ??? [88] 70.3% ??? [86] 29.7% ---------------------------------------------------------------------- custom-set-union [79] 100.0% [83] 198(0.8%) 0(0.0%) for-loop ...cts/racket/private/set-types.rkt:174:3 for-loop [87] 100.0% ---------------------------------------------------------------------- ??? [81] 100.0% [84] 2958(12.6%) 2710(11.5%) bfdiv ...-lib/math/private/bigfloat/mpfr.rkt:819:4 ??? [89] 8.4% ---------------------------------------------------------------------- ??? [81] 100.0% [85] 1408(6.0%) 932(4.0%) bfneg ...-lib/math/private/bigfloat/mpfr.rkt:616:4 ??? [89] 33.8% ---------------------------------------------------------------------- ...higher-order.rkt:373:33 [82]100.0% [86] 718(3.0%) 0(0.0%) ??? ...cts/racket/contract/private/list.rkt:187:10 ??? [88] 100.0% ---------------------------------------------------------------------- for-loop [83] 100.0% [87] 198(0.8%) 198(0.8%) for-loop ...cts/racket/private/set-types.rkt:178:5 ---------------------------------------------------------------------- ??? [73] 21.9% ??? [86] 23.2% ...higher-order.rkt:373:33 [82] 54.9% [88] 3092(13.1%) 0(0.0%) ??? ...ects/racket/contract/private/guts.rkt:638:8 ??? [90] 100.0% ---------------------------------------------------------------------- bfdiv [84] 21.2% real->bigfloat [78] 38.1% bfneg [85] 40.7% [89] 1170(5.0%) 1170(5.0%) ??? .../share/racket/collects/ffi/unsafe.rkt:861:4 ---------------------------------------------------------------------- ->flonum [74] 12.5% ??? [81] 30.0% ??? [88] 57.5% [90] 5378(22.8%) 2178(9.3%) ??? ...tract/private/arrow-higher-order.rkt:373:33 ??? [91] 59.5% ---------------------------------------------------------------------- ??? [90] 100.0% [91] 3200(13.6%) 1364(5.8%) ??? ...llects/racket/contract/combinator.rkt:178:4 any-wrap/traverse [92] 57.4% ---------------------------------------------------------------------- ??? [91] 100.0% [92] 1836(7.8%) 1836(7.8%) any-wrap/traverse ...cket/utils/any-wrap.rkt:106:2 ----------------------------------------------------------------------