Profiling results ----------------- Total cpu time observed: 22610ms (out of 23040ms) Number of samples taken: 96 (once every 236ms) ======================================================================= Caller Idx Total Self Name+src Local% ms(pct) ms(pct) Callee ======================================================================= ??? [19] 100.0% [1] 21976(97.2%) 0(0.0%) profile-thunk14 ...t/pkgs/profile-lib/main.rkt:9:0 run [4] 100.0% ----------------------------------------------------------------------- ??? [19] 100.0% [2] 8072(35.7%) 0(0.0%) run-improve58 ...ock/herbie/src/mainloop.rkt:242:0 for-loop [5] 92.4% loop [24] 5.2% setup-prog [6] 2.4% ----------------------------------------------------------------------- hash-ref! [63] 100.0% [3] 450(2.0%) 0(0.0%) ??? /home/ztatlock/herbie/src/programs.rkt:197:5 loop [54] 100.0% ----------------------------------------------------------------------- profile-thunk14 [1] 98.2% [4] 22390(99.0%) 0(0.0%) run ...share/racket/pkgs/profile-lib/main.rkt:31:2 ??? [19] 100.0% ----------------------------------------------------------------------- run-improve58 [2] 100.0% [5] 7458(33.0%) 0(0.0%) for-loop ...ztatlock/herbie/src/mainloop.rkt:253:8 run-iter! [7] 100.0% ----------------------------------------------------------------------- run-improve58 [2] 100.0% [6] 192(0.8%) 0(0.0%) setup-prog /home/ztatlock/herbie/src/glue.rkt:46:0 simplify-alt [8] 100.0% ----------------------------------------------------------------------- for-loop [5] 100.0% [7] 7458(33.0%) 0(0.0%) run-iter! ...tatlock/herbie/src/mainloop.rkt:223:0 simplify! [10] 82.8% finalize-iter! [11] 11.6% gen-series! [12] 5.6% ----------------------------------------------------------------------- setup-prog [6] 100.0% [8] 192(0.8%) 0(0.0%) simplify-alt .../ztatlock/herbie/src/glue.rkt:84:0 simplify [9] 100.0% ----------------------------------------------------------------------- simplify-alt [8] 3.0% ??? [19] 97.0% [9] 6368(28.2%) 244(1.1%) simplify ...lock/herbie/src/core/simplify.rkt:39:0 simplify-expr [14] 49.9% for-loop [15] 29.5% iterate-egraph!5 [20] 10.3% make-simplify-change [18] 3.5% loop [23] 3.0% ----------------------------------------------------------------------- run-iter! [7] 100.0% [10] 6176(27.3%) 0(0.0%) simplify! ...tatlock/herbie/src/mainloop.rkt:162:0 for-loop [13] 100.0% ----------------------------------------------------------------------- run-iter! [7] 100.0% [11] 866(3.8%) 0(0.0%) finalize-iter! ...ck/herbie/src/mainloop.rkt:177:0 ??? [16] 100.0% ----------------------------------------------------------------------- run-iter! [7] 100.0% [12] 416(1.8%) 0(0.0%) gen-series! ...tlock/herbie/src/mainloop.rkt:134:0 for-loop [17] 100.0% ----------------------------------------------------------------------- simplify! [10] 100.0% [13] 6176(27.3%) 0(0.0%) for-loop ...ztatlock/herbie/src/mainloop.rkt:166:6 ??? [19] 100.0% ----------------------------------------------------------------------- simplify [9] 100.0% [14] 3180(14.1%) 0(0.0%) simplify-expr ...herbie/src/core/simplify.rkt:68:0 iterate-egraph!5 [20] 93.6% loop [23] 6.4% ----------------------------------------------------------------------- simplify [9] 100.0% [15] 1876(8.3%) 0(0.0%) for-loop ...ock/herbie/src/core/simplify.rkt:61:12 iterate-egraph!5 [20] 100.0% ----------------------------------------------------------------------- finalize-iter! [11] 100.0% [16] 866(3.8%) 0(0.0%) ??? ...contract/private/arrow-val-first.rkt:357:18 for-loop [21] 100.0% ----------------------------------------------------------------------- gen-series! [12] 100.0% [17] 416(1.8%) 0(0.0%) for-loop ...ztatlock/herbie/src/mainloop.rkt:140:7 taylor-alt [22] 100.0% ----------------------------------------------------------------------- simplify [9] 100.0% [18] 220(1.0%) 220(1.0%) make-simplify-change ...src/core/simplify.rkt:33:0 ----------------------------------------------------------------------- for-loop [13] 9.3% run [4] 46.0% [19] 22610(100.0%) 0(0.0%) ??? ...lects/racket/private/more-scheme.rkt:261:28 profile-thunk14 [1] 44.2% loop [24] 32.6% run-improve58 [2] 13.9% simplify [9] 9.3% ----------------------------------------------------------------------- simplify [9] 11.9% for-loop [15] 34.0% simplify-expr [14] 54.0% [20] 5510(24.4%) 0(0.0%) iterate-egraph!5 ...bie/src/core/simplify.rkt:95:0 one-iter [25] 96.0% map-enodes [29] 4.0% ----------------------------------------------------------------------- ??? [16] 100.0% [21] 866(3.8%) 0(0.0%) for-loop ...ock/herbie/src/core/alt-table.rkt:51:2 atab-add-altn [26] 100.0% ----------------------------------------------------------------------- for-loop [17] 100.0% [22] 416(1.8%) 0(0.0%) taylor-alt ...e/ztatlock/herbie/src/glue.rkt:142:0 for-loop [27] 100.0% ----------------------------------------------------------------------- simplify [9] 48.7% simplify-expr [14] 51.3% [23] 394(1.7%) 0(0.0%) loop ...tatlock/herbie/src/core/simplify.rkt:203:2 pass [28] 100.0% ----------------------------------------------------------------------- run-improve58 [2] 2.8% ??? [19] 97.2% [24] 14960(66.2%) 0(0.0%) loop /home/ztatlock/herbie/src/points.rkt:122:2 loop [30] 46.0% make-exacts* [38] 35.7% loop [39] 16.8% for-loop [37] 1.5% ----------------------------------------------------------------------- iterate-egraph!5 [20] 100.0% [25] 5288(23.4%) 216(1.0%) one-iter ...ock/herbie/src/core/simplify.rkt:106:0 for-loop [31] 66.7% loop [32] 25.1% apply-match [40] 4.2% ----------------------------------------------------------------------- for-loop [21] 100.0% [26] 866(3.8%) 0(0.0%) atab-add-altn ...rbie/src/core/alt-table.rkt:208:0 best-and-tied-at-points [33] 100.0% ----------------------------------------------------------------------- taylor-alt [22] 100.0% [27] 416(1.8%) 0(0.0%) for-loop /home/ztatlock/herbie/src/glue.rkt:144:2 location-do [34] 100.0% ----------------------------------------------------------------------- loop [23] 100.0% [28] 394(1.7%) 0(0.0%) pass ...tatlock/herbie/src/core/simplify.rkt:193:2 for-loop [35] 100.0% ----------------------------------------------------------------------- iterate-egraph!5 [20] 100.0% [29] 222(1.0%) 0(0.0%) map-enodes ...ock/herbie/src/core/egraph.rkt:139:0 for-loop [36] 100.0% ----------------------------------------------------------------------- loop [24] 100.0% [30] 6878(30.4%) 0(0.0%) loop /home/ztatlock/herbie/src/points.rkt:93:2 make-exacts* [38] 52.6% loop [39] 40.8% eval-prog [48] 6.5% ----------------------------------------------------------------------- for-loop [31] 50.0% one-iter [25] 50.0% [31] 3526(15.6%) 602(2.7%) for-loop ...ck/herbie/src/core/simplify.rkt:116:12 for-loop [31] 50.0% match-e [47] 41.5% ----------------------------------------------------------------------- one-iter [25] 100.0% [32] 1326(5.9%) 0(0.0%) loop ...cket/collects/racket/private/map.rkt:53:19 apply-match [40] 100.0% ----------------------------------------------------------------------- atab-add-altn [26] 100.0% [33] 866(3.8%) 0(0.0%) best-and-tied-at-points ...ore/alt-table.rkt:122:0 errors [41] 100.0% ----------------------------------------------------------------------- for-loop [27] 28.9% location-do [34] 71.1% [34] 416(1.8%) 0(0.0%) location-do ...tlock/herbie/src/programs.rkt:129:0 location-do [34] 71.1% approximate9 [42] 28.9% ----------------------------------------------------------------------- pass [28] 100.0% [35] 394(1.7%) 0(0.0%) for-loop ...ck/herbie/src/core/simplify.rkt:196:29 for-loop [43] 100.0% ----------------------------------------------------------------------- map-enodes [29] 100.0% [36] 222(1.0%) 0(0.0%) for-loop ...ock/herbie/src/core/simplify.rkt:161:2 setfindf [44] 100.0% ----------------------------------------------------------------------- loop [24] 100.0% [37] 222(1.0%) 0(0.0%) for-loop .../ztatlock/herbie/src/points.rkt:128:18 for-loop [45] 100.0% ----------------------------------------------------------------------- loop [30] 40.4% loop [24] 59.6% [38] 8960(39.6%) 0(0.0%) make-exacts* ...tatlock/herbie/src/points.rkt:80:0 map [46] 50.8% loop [54] 46.6% eval-prog [48] 2.5% ----------------------------------------------------------------------- loop [24] 47.3% loop [30] 52.7% [39] 5328(23.6%) 0(0.0%) loop /home/ztatlock/herbie/src/points.rkt:83:4 map [46] 100.0% ----------------------------------------------------------------------- one-iter [25] 14.2% loop [32] 85.8% [40] 1546(6.8%) 220(1.0%) apply-match .../herbie/src/core/simplify.rkt:122:2 loop! [62] 44.2% merge-egraph-nodes! [53] 14.2% substitute-e [52] 14.2% match-e [47] 13.1% ----------------------------------------------------------------------- best-and-tied-at-points [33] 100.0% [41] 866(3.8%) 0(0.0%) errors /home/ztatlock/herbie/src/points.rkt:144:0 for-loop [49] 50.8% eval-prog [48] 49.2% ----------------------------------------------------------------------- location-do [34] 100.0% [42] 416(1.8%) 0(0.0%) approximate9 ...ck/herbie/src/core/taylor.rkt:11:0 f143 [64] 53.4% taylor-sqrt [50] 46.6% ----------------------------------------------------------------------- for-loop [35] 100.0% [43] 394(1.7%) 394(1.7%) for-loop ...ck/herbie/src/core/simplify.rkt:183:13 ----------------------------------------------------------------------- for-loop [36] 100.0% [44] 222(1.0%) 222(1.0%) setfindf ...e/ztatlock/herbie/src/common.rkt:173:0 ----------------------------------------------------------------------- for-loop [37] 100.0% [45] 222(1.0%) 0(0.0%) for-loop .../ztatlock/herbie/src/points.rkt:129:20 sample-double [51] 100.0% ----------------------------------------------------------------------- make-exacts* [38] 46.1% loop [39] 53.9% [46] 9882(43.7%) 0(0.0%) map ...acket/collects/racket/private/map.rkt:21:13 loop [54] 97.5% ??? [61] 2.5% ----------------------------------------------------------------------- apply-match [40] 2.2% for-loop [67] 4.3% for-loop [31] 93.5% [47] 3126(13.8%) 2296(10.2%) match-e ...tatlock/herbie/src/core/ematch.rkt:46:0 for-loop [55] 24.4% constant? [60] 2.2% ----------------------------------------------------------------------- make-exacts* [38] 20.7% errors [41] 38.6% loop [30] 40.8% [48] 1104(4.9%) 0(0.0%) eval-prog ...tatlock/herbie/src/programs.rkt:162:0 hash-ref! [63] 61.4% ??? [58] 19.9% parse-lambda [59] 18.7% ----------------------------------------------------------------------- errors [41] 100.0% [49] 440(1.9%) 238(1.1%) for-loop ...e/ztatlock/herbie/src/points.rkt:147:4 ??? [61] 45.9% ----------------------------------------------------------------------- approximate9 [42] 46.6% f143 [64] 53.4% [50] 416(1.8%) 0(0.0%) taylor-sqrt ...ck/herbie/src/core/taylor.rkt:346:0 simplify [56] 100.0% ----------------------------------------------------------------------- for-loop [45] 100.0% [51] 222(1.0%) 0(0.0%) sample-double .../src/syntax/distributions.rkt:8:0 random-exp [57] 100.0% ----------------------------------------------------------------------- substitute-e [52] 50.0% apply-match [40] 50.0% [52] 220(1.0%) 220(1.0%) substitute-e ...ck/herbie/src/core/ematch.rkt:71:0 substitute-e [52] 50.0% ----------------------------------------------------------------------- apply-match [40] 100.0% [53] 220(1.0%) 0(0.0%) merge-egraph-nodes! ...e/src/core/egraph.rkt:152:0 loop! [62] 100.0% ----------------------------------------------------------------------- make-exacts* [38] 0.5% map [46] 0.6% loop! [62] 0.8% ??? [3] 3.1% loop [54] 95.0% [54] 14484(64.1%) 474(2.1%) loop ...cket/collects/racket/private/map.rkt:26:19 loop [54] 95.0% hash-ref! [63] 3.1% ??? [61] 1.1% loop! [62] 0.8% ----------------------------------------------------------------------- match-e [47] 100.0% [55] 830(3.7%) 628(2.8%) for-loop ...tlock/herbie/src/core/ematch.rkt:59:11 for-loop [67] 24.3% ----------------------------------------------------------------------- taylor-sqrt [50] 100.0% [56] 416(1.8%) 0(0.0%) simplify ...atlock/herbie/src/core/reduce.rkt:18:0 parse-loop50 [65] 53.4% f143 [64] 46.6% ----------------------------------------------------------------------- sample-double [51] 100.0% [57] 222(1.0%) 222(1.0%) random-exp ...ztatlock/herbie/src/common.rkt:153:0 ----------------------------------------------------------------------- eval-prog [48] 100.0% [58] 220(1.0%) 0(0.0%) ??? ...collects/racket/private/qq-and-or.rkt:155:9 ??? [66] 100.0% ----------------------------------------------------------------------- eval-prog [48] 100.0% [59] 206(0.9%) 206(0.9%) parse-lambda ...llects/racket/private/kw.rkt:393:2 ----------------------------------------------------------------------- match-e [47] 100.0% [60] 202(0.9%) 202(0.9%) constant? ...ck/herbie/src/syntax/syntax.rkt:221:0 ----------------------------------------------------------------------- for-loop [49] 1.5% map [46] 1.8% loop [54] 96.8% [61] 13788(61.0%) 484(2.1%) ??? /home/ztatlock/herbie/src/programs.rkt:168:4 ??? [68] 84.9% real->bigfloat [69] 9.9% ??? [83] 1.7% ----------------------------------------------------------------------- loop [54] 12.2% merge-egraph-nodes! [53] 12.2% apply-match [40] 75.7% [62] 904(4.0%) 0(0.0%) loop! .../ztatlock/herbie/src/core/enode.rkt:163:2 custom-set-union [70] 75.7% loop [54] 12.2% set [72] 12.2% ----------------------------------------------------------------------- eval-prog [48] 46.9% loop [54] 53.1% [63] 678(3.0%) 0(0.0%) hash-ref! ...racket/private/more-scheme.rkt:373:13 ??? [3] 53.1% bigfloat-hash [71] 46.9% ----------------------------------------------------------------------- f143 [64] 26.7% approximate9 [42] 26.7% simplify [56] 46.6% [64] 416(1.8%) 0(0.0%) f143 .../collects/racket/match/compiler.rkt:499:40 gather-multiplicative-terms [73] 46.6% f143 [64] 26.7% taylor-sqrt [50] 26.7% ----------------------------------------------------------------------- parse-loop50 [65] 50.0% simplify [56] 50.0% [65] 222(1.0%) 222(1.0%) parse-loop50 ...s/racket/match/compiler.rkt:410:15 parse-loop50 [65] 50.0% ----------------------------------------------------------------------- ??? [58] 100.0% [66] 220(1.0%) 220(1.0%) ??? ...ollects/racket/private/qq-and-or.rkt:164:21 ----------------------------------------------------------------------- for-loop [55] 100.0% [67] 202(0.9%) 0(0.0%) for-loop ...tlock/herbie/src/core/ematch.rkt:65:37 match-e [47] 100.0% ----------------------------------------------------------------------- ??? [61] 100.0% [68] 11700(51.7%) 722(3.2%) ??? ...acket/collects/racket/private/kw.rkt:400:14 ??? [78] 68.2% ...higher-order.rkt:373:33 [74] 17.8% bf* [75] 7.8% ----------------------------------------------------------------------- ??? [61] 100.0% [69] 1364(6.0%) 1128(5.0%) real->bigfloat .../private/bigfloat/mpfr.rkt:451:0 ??? [85] 17.3% ----------------------------------------------------------------------- loop! [62] 100.0% [70] 684(3.0%) 202(0.9%) custom-set-union ...et/private/set-types.rkt:168:0 for-loop [77] 70.5% ----------------------------------------------------------------------- hash-ref! [63] 100.0% [71] 678(3.0%) 0(0.0%) bigfloat-hash ...h/private/bigfloat/mpfr.rkt:165:0 sig+exp->bigfloat [76] 100.0% ----------------------------------------------------------------------- loop! [62] 100.0% [72] 220(1.0%) 220(1.0%) set ...collects/racket/private/set-types.rkt:982:0 ----------------------------------------------------------------------- f143 [64] 100.0% [73] 194(0.9%) 194(0.9%) gather-multiplicative-terms ...re/reduce.rkt:107:0 ----------------------------------------------------------------------- ??? [68] 100.0% [74] 2078(9.2%) 0(0.0%) ...higher-order.rkt:373:33 (unknown source) ??? [79] 66.4% ??? [83] 33.6% ----------------------------------------------------------------------- ??? [68] 100.0% [75] 918(4.1%) 0(0.0%) bf* ...ath/private/bigfloat/bigfloat-mpfr.rkt:95:0 ??? [78] 100.0% ----------------------------------------------------------------------- bigfloat-hash [71] 100.0% [76] 678(3.0%) 678(3.0%) sig+exp->bigfloat ...ivate/bigfloat/mpfr.rkt:385:0 ----------------------------------------------------------------------- custom-set-union [70] 100.0% [77] 482(2.1%) 242(1.1%) for-loop ...cts/racket/private/set-types.rkt:174:3 for-loop [80] 49.8% ----------------------------------------------------------------------- bf* [75] 10.3% ??? [68] 89.7% [78] 8900(39.4%) 2180(9.6%) ??? ...-racket/utils/simple-result-arrow.rkt:26:12 bfmul [81] 30.8% bfatan [82] 24.1% ??? [84] 20.6% ----------------------------------------------------------------------- ...higher-order.rkt:373:33 [74] 100.0% [79] 1380(6.1%) 238(1.1%) ??? ...cts/racket/contract/private/list.rkt:187:10 ??? [83] 82.8% ----------------------------------------------------------------------- for-loop [77] 100.0% [80] 240(1.1%) 240(1.1%) for-loop ...cts/racket/private/set-types.rkt:178:5 ----------------------------------------------------------------------- ??? [78] 100.0% [81] 2742(12.1%) 1610(7.1%) bfmul ...-lib/math/private/bigfloat/mpfr.rkt:819:4 ??? [85] 41.3% ----------------------------------------------------------------------- ??? [78] 100.0% [82] 2148(9.5%) 1698(7.5%) bfatan ...lib/math/private/bigfloat/mpfr.rkt:616:4 ??? [85] 20.9% ----------------------------------------------------------------------- ??? [61] 11.5% ...higher-order.rkt:373:33 [74] 33.6% ??? [79] 54.9% [83] 2080(9.2%) 0(0.0%) ??? ...ects/racket/contract/private/guts.rkt:638:8 ??? [84] 100.0% ----------------------------------------------------------------------- ??? [78] 46.8% ??? [83] 53.2% [84] 3910(17.3%) 1826(8.1%) ??? ...tract/private/arrow-higher-order.rkt:373:33 ??? [86] 47.7% ??? [87] 5.6% ----------------------------------------------------------------------- real->bigfloat [69] 13.0% bfatan [82] 24.8% bfmul [81] 62.3% [85] 1818(8.0%) 1818(8.0%) ??? .../share/racket/collects/ffi/unsafe.rkt:861:4 ----------------------------------------------------------------------- ??? [84] 100.0% [86] 1866(8.3%) 916(4.1%) ??? ...llects/racket/contract/combinator.rkt:178:4 any-wrap/traverse [88] 50.9% ----------------------------------------------------------------------- ??? [84] 100.0% [87] 218(1.0%) 218(1.0%) ??? ...ects/racket/contract/private/prop.rkt:489:4 ----------------------------------------------------------------------- ??? [86] 100.0% [88] 950(4.2%) 950(4.2%) any-wrap/traverse ...cket/utils/any-wrap.rkt:106:2 -----------------------------------------------------------------------