Profiling results ----------------- Total cpu time observed: 19126ms (out of 18764ms) Number of samples taken: 68 (once every 281ms) ====================================================================== Caller Idx Total Self Name+src Local% ms(pct) ms(pct) Callee ====================================================================== ??? [26] 100.0% [1] 18906(98.8%) 0(0.0%) profile-thunk14 ...t/pkgs/profile-lib/main.rkt:9:0 run [5] 100.0% ---------------------------------------------------------------------- ??? [26] 100.0% [2] 3958(20.7%) 0(0.0%) run-improve58 ...ock/herbie/src/mainloop.rkt:242:0 for-loop [6] 50.0% get-final-combination [7] 44.3% loop [33] 5.7% ---------------------------------------------------------------------- ??? [26] 100.0% [3] 1746(9.1%) 0(0.0%) simplify ...lock/herbie/src/core/simplify.rkt:39:0 for-loop [8] 50.6% simplify-expr [9] 35.6% loop [10] 13.7% ---------------------------------------------------------------------- copying-mergesort [41] 100.0% [4] 678(3.5%) 0(0.0%) jloop ...et/collects/racket/private/sort.rkt:85:19 ??? [56] 100.0% ---------------------------------------------------------------------- profile-thunk14 [1] 100.0% [5] 18906(98.8%) 0(0.0%) run ...share/racket/pkgs/profile-lib/main.rkt:31:2 ??? [26] 100.0% ---------------------------------------------------------------------- run-improve58 [2] 100.0% [6] 1980(10.4%) 0(0.0%) for-loop ...ztatlock/herbie/src/mainloop.rkt:253:8 run-iter! [11] 100.0% ---------------------------------------------------------------------- run-improve58 [2] 100.0% [7] 1754(9.2%) 0(0.0%) get-final-combination ...ie/src/mainloop.rkt:269:0 split-table [12] 100.0% ---------------------------------------------------------------------- simplify [3] 100.0% [8] 884(4.6%) 0(0.0%) for-loop ...ock/herbie/src/core/simplify.rkt:61:12 iterate-egraph!5 [13] 100.0% ---------------------------------------------------------------------- simplify [3] 100.0% [9] 622(3.3%) 0(0.0%) simplify-expr ...herbie/src/core/simplify.rkt:68:0 iterate-egraph!5 [13] 100.0% ---------------------------------------------------------------------- simplify [3] 100.0% [10] 240(1.3%) 0(0.0%) loop ...tatlock/herbie/src/core/simplify.rkt:203:2 pass [14] 100.0% ---------------------------------------------------------------------- for-loop [6] 100.0% [11] 1980(10.4%) 0(0.0%) run-iter! ...tatlock/herbie/src/mainloop.rkt:223:0 simplify! [16] 88.2% gen-series! [19] 11.8% ---------------------------------------------------------------------- get-final-combination [7] 100.0% [12] 1754(9.2%) 0(0.0%) split-table .../ztatlock/herbie/src/glue.rkt:171:0 infer-splitpoints4 [15] 100.0% ---------------------------------------------------------------------- simplify-expr [9] 41.3% for-loop [8] 58.7% [13] 1506(7.9%) 0(0.0%) iterate-egraph!5 ...bie/src/core/simplify.rkt:95:0 one-iter [17] 100.0% ---------------------------------------------------------------------- loop [10] 100.0% [14] 240(1.3%) 0(0.0%) pass ...tatlock/herbie/src/core/simplify.rkt:193:2 for-loop [18] 100.0% ---------------------------------------------------------------------- split-table [12] 100.0% [15] 1754(9.2%) 0(0.0%) infer-splitpoints4 ...ie/src/core/regimes.rkt:19:0 option-on-expr [21] 88.7% exprs-to-branch-on [25] 11.3% ---------------------------------------------------------------------- run-iter! [11] 100.0% [16] 1746(9.1%) 0(0.0%) simplify! ...tatlock/herbie/src/mainloop.rkt:162:0 for-loop [20] 100.0% ---------------------------------------------------------------------- iterate-egraph!5 [13] 100.0% [17] 1506(7.9%) 0(0.0%) one-iter ...ock/herbie/src/core/simplify.rkt:106:0 for-loop [22] 44.1% loop [23] 42.6% apply-match [28] 13.3% ---------------------------------------------------------------------- pass [14] 100.0% [18] 240(1.3%) 240(1.3%) for-loop ...ck/herbie/src/core/simplify.rkt:196:29 ---------------------------------------------------------------------- run-iter! [11] 100.0% [19] 234(1.2%) 0(0.0%) gen-series! ...tlock/herbie/src/mainloop.rkt:134:0 for-loop [24] 100.0% ---------------------------------------------------------------------- simplify! [16] 100.0% [20] 1746(9.1%) 0(0.0%) for-loop ...ztatlock/herbie/src/mainloop.rkt:166:6 ??? [26] 100.0% ---------------------------------------------------------------------- infer-splitpoints4 [15] 100.0% [21] 1556(8.1%) 0(0.0%) option-on-expr ...erbie/src/core/regimes.rkt:106:0 sort-context-on-expr [27] 86.1% err-lsts->split-indices [31] 13.9% ---------------------------------------------------------------------- for-loop [22] 50.0% one-iter [17] 50.0% [22] 664(3.5%) 0(0.0%) for-loop ...ck/herbie/src/core/simplify.rkt:116:12 for-loop [22] 50.0% match-e [29] 50.0% ---------------------------------------------------------------------- one-iter [17] 100.0% [23] 642(3.4%) 0(0.0%) loop ...cket/collects/racket/private/map.rkt:53:19 apply-match [28] 100.0% ---------------------------------------------------------------------- gen-series! [19] 100.0% [24] 234(1.2%) 0(0.0%) for-loop ...ztatlock/herbie/src/mainloop.rkt:140:7 taylor-alt [30] 100.0% ---------------------------------------------------------------------- infer-splitpoints4 [15] 100.0% [25] 198(1.0%) 0(0.0%) exprs-to-branch-on ...ie/src/core/regimes.rkt:41:0 critical-subexpression [32] 100.0% ---------------------------------------------------------------------- for-loop [20] 3.0% run [5] 47.9% [26] 19126(100.0%) 0(0.0%) ??? ...lects/racket/private/more-scheme.rkt:261:28 profile-thunk14 [1] 47.9% loop [33] 39.7% run-improve58 [2] 9.4% simplify [3] 3.0% ---------------------------------------------------------------------- option-on-expr [21] 100.0% [27] 1340(7.0%) 0(0.0%) sort-context-on-expr ...herbie/src/points.rkt:50:0 sort [34] 100.0% ---------------------------------------------------------------------- one-iter [17] 23.8% loop [23] 76.2% [28] 842(4.4%) 0(0.0%) apply-match .../herbie/src/core/simplify.rkt:122:2 merge-egraph-nodes! [35] 52.3% loop! [42] 24.0% update-leader! [38] 23.8% ---------------------------------------------------------------------- for-loop [22] 100.0% [29] 664(3.5%) 664(3.5%) match-e ...tatlock/herbie/src/core/ematch.rkt:46:0 ---------------------------------------------------------------------- for-loop [24] 100.0% [30] 234(1.2%) 0(0.0%) taylor-alt ...e/ztatlock/herbie/src/glue.rkt:142:0 for-loop [36] 100.0% ---------------------------------------------------------------------- option-on-expr [21] 100.0% [31] 216(1.1%) 0(0.0%) err-lsts->split-indices .../core/regimes.rkt:224:0 add-splitpoint [37] 100.0% ---------------------------------------------------------------------- exprs-to-branch-on [25] 100.0% [32] 198(1.0%) 0(0.0%) critical-subexpression ...rc/core/regimes.rkt:49:0 localize-error [39] 100.0% ---------------------------------------------------------------------- run-improve58 [2] 1.5% ??? [26] 98.5% [33] 15392(80.5%) 0(0.0%) loop /home/ztatlock/herbie/src/points.rkt:122:2 loop [40] 64.2% make-exacts* [48] 29.5% loop [49] 6.3% ---------------------------------------------------------------------- sort-context-on-expr [27] 100.0% [34] 1340(7.0%) 0(0.0%) sort ...ket/collects/racket/private/sort.rkt:213:0 copying-mergesort [41] 65.4% loop [50] 34.6% ---------------------------------------------------------------------- for-loop [45] 16.7% merge-egraph-nodes! [35] 16.7% apply-match [28] 66.7% [35] 440(2.3%) 0(0.0%) merge-egraph-nodes! ...e/src/core/egraph.rkt:152:0 enode-merge! [44] 50.0% merge-egraph-nodes! [35] 16.7% for-loop [45] 16.7% loop! [42] 16.7% ---------------------------------------------------------------------- taylor-alt [30] 100.0% [36] 234(1.2%) 0(0.0%) for-loop /home/ztatlock/herbie/src/glue.rkt:144:2 location-do [43] 100.0% ---------------------------------------------------------------------- err-lsts->split-indices [31] 100.0% [37] 216(1.1%) 0(0.0%) add-splitpoint ...erbie/src/core/regimes.rkt:237:2 for-loop [46] 100.0% ---------------------------------------------------------------------- apply-match [28] 100.0% [38] 200(1.0%) 0(0.0%) update-leader! ...herbie/src/core/egraph.rkt:217:0 for-loop [47] 100.0% ---------------------------------------------------------------------- critical-subexpression [32] 100.0% [39] 198(1.0%) 0(0.0%) localize-error ...erbie/src/core/localize.rkt:47:0 hash-ref! [63] 100.0% ---------------------------------------------------------------------- loop [33] 100.0% [40] 9874(51.6%) 0(0.0%) loop /home/ztatlock/herbie/src/points.rkt:93:2 loop [49] 49.0% make-exacts* [48] 32.7% eval-prog [60] 18.3% ---------------------------------------------------------------------- sort [34] 30.7% copying-mergesort [41] 69.3% [41] 876(4.6%) 0(0.0%) copying-mergesort .../racket/private/sort.rkt:91:4 copying-mergesort [41] 69.3% jloop [4] 19.3% loop [50] 11.3% ---------------------------------------------------------------------- apply-match [28] 47.9% merge-egraph-nodes! [35] 52.1% [42] 422(2.2%) 0(0.0%) loop! .../ztatlock/herbie/src/core/enode.rkt:163:2 custom-set-union [51] 100.0% ---------------------------------------------------------------------- for-loop [36] 100.0% [43] 234(1.2%) 0(0.0%) location-do ...tlock/herbie/src/programs.rkt:129:0 approximate9 [52] 100.0% ---------------------------------------------------------------------- merge-egraph-nodes! [35] 100.0% [44] 220(1.2%) 0(0.0%) enode-merge! ...ck/herbie/src/core/enode.rkt:100:0 custom-set-intersect! [53] 100.0% ---------------------------------------------------------------------- merge-egraph-nodes! [35] 100.0% [45] 220(1.2%) 0(0.0%) for-loop ...lock/herbie/src/core/egraph.rkt:200:10 merge-egraph-nodes! [35] 100.0% ---------------------------------------------------------------------- add-splitpoint [37] 100.0% [46] 216(1.1%) 216(1.1%) for-loop ...lock/herbie/src/core/regimes.rkt:239:4 ---------------------------------------------------------------------- update-leader! [38] 100.0% [47] 200(1.0%) 0(0.0%) for-loop ...tlock/herbie/src/core/egraph.rkt:222:6 for-loop [54] 100.0% ---------------------------------------------------------------------- loop [40] 41.5% loop [33] 58.5% [48] 7772(40.6%) 0(0.0%) make-exacts* ...tatlock/herbie/src/points.rkt:80:0 map [55] 55.1% loop [73] 44.9% ---------------------------------------------------------------------- loop [33] 16.7% loop [40] 83.3% [49] 5816(30.4%) 0(0.0%) loop /home/ztatlock/herbie/src/points.rkt:83:4 map [55] 100.0% ---------------------------------------------------------------------- copying-mergesort [41] 29.9% sort [34] 70.1% [50] 662(3.5%) 0(0.0%) loop ...cket/collects/racket/private/sort.rkt:64:8 ??? [56] 100.0% ---------------------------------------------------------------------- loop! [42] 100.0% [51] 422(2.2%) 0(0.0%) custom-set-union ...et/private/set-types.rkt:168:0 for-loop [57] 100.0% ---------------------------------------------------------------------- location-do [43] 100.0% [52] 234(1.2%) 0(0.0%) approximate9 ...ck/herbie/src/core/taylor.rkt:11:0 loop [58] 100.0% ---------------------------------------------------------------------- enode-merge! [44] 100.0% [53] 220(1.2%) 220(1.2%) custom-set-intersect! ...ivate/set-types.rkt:270:0 ---------------------------------------------------------------------- for-loop [47] 100.0% [54] 200(1.0%) 0(0.0%) for-loop ...tlock/herbie/src/core/egraph.rkt:223:8 hash-update! [59] 100.0% ---------------------------------------------------------------------- make-exacts* [48] 42.4% loop [49] 57.6% [55] 10096(52.8%) 0(0.0%) map ...acket/collects/racket/private/map.rkt:21:13 loop [73] 84.3% ??? [74] 15.7% ---------------------------------------------------------------------- loop [50] 49.4% jloop [4] 50.6% [56] 1340(7.0%) 0(0.0%) ??? /home/ztatlock/herbie/src/points.rkt:52:27 eval-prog [60] 100.0% ---------------------------------------------------------------------- custom-set-union [51] 100.0% [57] 422(2.2%) 0(0.0%) for-loop ...cts/racket/private/set-types.rkt:174:3 for-loop [61] 100.0% ---------------------------------------------------------------------- approximate9 [52] 100.0% [58] 234(1.2%) 0(0.0%) loop ...e/ztatlock/herbie/src/core/taylor.rkt:82:4 hash-ref! [63] 100.0% ---------------------------------------------------------------------- for-loop [54] 100.0% [59] 200(1.0%) 0(0.0%) hash-update! ...ket/private/more-scheme.rkt:362:13 ??? [62] 100.0% ---------------------------------------------------------------------- ??? [56] 42.6% loop [40] 57.4% [60] 3144(16.4%) 1158(6.1%) eval-prog ...tatlock/herbie/src/programs.rkt:162:0 hash-ref! [63] 49.2% ??? [64] 7.0% parse-lambda [65] 6.9% ---------------------------------------------------------------------- for-loop [57] 100.0% [61] 422(2.2%) 422(2.2%) for-loop ...cts/racket/private/set-types.rkt:178:5 ---------------------------------------------------------------------- hash-update! [59] 100.0% [62] 200(1.0%) 0(0.0%) ??? .../ztatlock/herbie/src/core/egraph.rkt:225:24 for-loop [66] 100.0% ---------------------------------------------------------------------- ??? [69] 5.9% loop [58] 5.9% localize-error [39] 10.0% eval-prog [60] 78.2% [63] 1980(10.4%) 0(0.0%) hash-ref! ...racket/private/more-scheme.rkt:373:13 bigfloat-hash [67] 78.2% parse-loop50 [72] 10.0% ??? [69] 5.9% simplify [68] 5.9% ---------------------------------------------------------------------- eval-prog [60] 100.0% [64] 220(1.2%) 0(0.0%) ??? ...collects/racket/private/qq-and-or.rkt:155:9 ??? [70] 100.0% ---------------------------------------------------------------------- eval-prog [60] 100.0% [65] 218(1.1%) 218(1.1%) parse-lambda ...llects/racket/private/kw.rkt:393:2 ---------------------------------------------------------------------- ??? [62] 100.0% [66] 200(1.0%) 200(1.0%) for-loop ...lock/herbie/src/core/egraph.rkt:226:26 ---------------------------------------------------------------------- hash-ref! [63] 100.0% [67] 1548(8.1%) 0(0.0%) bigfloat-hash ...h/private/bigfloat/mpfr.rkt:165:0 bfcanonicalize [71] 100.0% ---------------------------------------------------------------------- hash-ref! [63] 100.0% [68] 234(1.2%) 0(0.0%) simplify ...atlock/herbie/src/core/reduce.rkt:18:0 parse-loop50 [72] 100.0% ---------------------------------------------------------------------- hash-ref! [63] 100.0% [69] 234(1.2%) 0(0.0%) ??? ...e/ztatlock/herbie/src/core/taylor.rkt:42:15 hash-ref! [63] 100.0% ---------------------------------------------------------------------- ??? [64] 100.0% [70] 220(1.2%) 220(1.2%) ??? ...ollects/racket/private/qq-and-or.rkt:164:21 ---------------------------------------------------------------------- bigfloat-hash [67] 100.0% [71] 1548(8.1%) 1548(8.1%) bfcanonicalize .../private/bigfloat/mpfr.rkt:155:0 ---------------------------------------------------------------------- hash-ref! [63] 45.8% simplify [68] 54.2% [72] 432(2.3%) 234(1.2%) parse-loop50 ...s/racket/match/compiler.rkt:410:15 loop [73] 45.8% ---------------------------------------------------------------------- map [55] 1.0% parse-loop50 [72] 1.6% make-exacts* [48] 1.8% loop [73] 95.6% [73] 12198(63.8%) 0(0.0%) loop ...cket/collects/racket/private/map.rkt:26:19 loop [73] 95.6% ??? [74] 2.8% ??? [81] 1.6% ->flonum [75] 0.0% ---------------------------------------------------------------------- map [55] 12.3% loop [73] 87.7% [74] 12900(67.4%) 712(3.7%) ??? /home/ztatlock/herbie/src/programs.rkt:168:4 ??? [76] 44.3% real->bigfloat [77] 35.9% ??? [87] 7.5% ...e/case-arrow.rkt:150:50 [78] 6.7% ---------------------------------------------------------------------- loop [73] 100.0% [75] 688(3.6%) 0(0.0%) ->flonum ...ock/herbie/src/syntax/syntax.rkt:224:0 ??? [79] 69.2% ??? [80] 30.8% ---------------------------------------------------------------------- ??? [74] 100.0% [76] 5716(29.9%) 198(1.0%) ??? ...acket/collects/racket/private/kw.rkt:400:14 ??? [81] 68.7% ...higher-order.rkt:369:33 [82] 23.1% ...higher-order.rkt:373:33 [83] 4.8% ---------------------------------------------------------------------- ??? [74] 100.0% [77] 4632(24.2%) 4426(23.1%) real->bigfloat .../private/bigfloat/mpfr.rkt:451:0 ??? [88] 4.4% ---------------------------------------------------------------------- ??? [74] 100.0% [78] 870(4.5%) 870(4.5%) ...e/case-arrow.rkt:150:50 (unknown source) ---------------------------------------------------------------------- ->flonum [75] 100.0% [79] 476(2.5%) 0(0.0%) ??? ...-racket/utils/simple-result-arrow.rkt:47:15 ??? [88] 100.0% ---------------------------------------------------------------------- ->flonum [75] 100.0% [80] 212(1.1%) 212(1.1%) ??? /home/ztatlock/herbie/src/config.rkt:29:0 ---------------------------------------------------------------------- loop [73] 4.8% ??? [76] 95.2% [81] 4124(21.6%) 258(1.3%) ??? ...-racket/utils/simple-result-arrow.rkt:26:12 bfadd [84] 49.1% bfsqr [85] 29.5% ??? [89] 15.1% ---------------------------------------------------------------------- ??? [76] 100.0% [82] 1318(6.9%) 0(0.0%) ...higher-order.rkt:369:33 (unknown source) ??? [86] 66.8% ??? [87] 33.2% ---------------------------------------------------------------------- ??? [76] 100.0% [83] 274(1.4%) 0(0.0%) ...higher-order.rkt:373:33 (unknown source) ??? [86] 100.0% ---------------------------------------------------------------------- ??? [81] 100.0% [84] 2024(10.6%) 1518(7.9%) bfadd ...-lib/math/private/bigfloat/mpfr.rkt:819:4 ??? [88] 25.0% ---------------------------------------------------------------------- ??? [81] 100.0% [85] 1218(6.4%) 728(3.8%) bfsqr ...-lib/math/private/bigfloat/mpfr.rkt:616:4 ??? [88] 40.2% ---------------------------------------------------------------------- ...higher-order.rkt:373:33 [83] 23.7% ...higher-order.rkt:369:33 [82] 76.3% [86] 1154(6.0%) 0(0.0%) ??? ...cts/racket/contract/private/list.rkt:187:10 ??? [87] 100.0% ---------------------------------------------------------------------- ...higher-order.rkt:369:33 [82] 17.1% ??? [74] 37.9% ??? [86] 45.0% [87] 2562(13.4%) 0(0.0%) ??? ...ects/racket/contract/private/guts.rkt:638:8 ??? [89] 100.0% ---------------------------------------------------------------------- real->bigfloat [77] 12.3% ??? [79] 28.4% bfsqr [85] 29.2% bfadd [84] 30.2% [88] 1678(8.8%) 1678(8.8%) ??? .../share/racket/collects/ffi/unsafe.rkt:861:4 ---------------------------------------------------------------------- ??? [81] 19.6% ??? [87] 80.4% [89] 3186(16.7%) 2482(13.0%) ??? ...tract/private/arrow-higher-order.rkt:373:33 ??? [90] 22.1% ---------------------------------------------------------------------- ??? [89] 100.0% [90] 704(3.7%) 482(2.5%) ??? ...llects/racket/contract/combinator.rkt:178:4 any-wrap/traverse [91] 31.5% ---------------------------------------------------------------------- ??? [90] 100.0% [91] 222(1.2%) 222(1.2%) any-wrap/traverse ...cket/utils/any-wrap.rkt:106:2 ----------------------------------------------------------------------