Profiling results ----------------- Total cpu time observed: 26554ms (out of 26916ms) Number of samples taken: 80 (once every 332ms) (Hiding functions with self<1.0% and local<2.0%: 1 of 107 hidden) ====================================================================== Caller Idx Total Self Name+src Local% ms(pct) ms(pct) Callee ====================================================================== run [12] 50.0% [1] 26554(100.0%) 0(0.0%) ??? ...lects/racket/private/more-scheme.rkt:261:28 profile-thunk16 [5] 50.0% run-improve40 [6] 28.4% prepare-points-intervals [7] 14.2% eval-errors [8] 5.1% errors [49] 1.7% oracle-error [11] 0.6% ---------------------------------------------------------------------- hash-ref! [16] 100.0% [2] 304(1.1%) 0(0.0%) simplify ...implify-tweak/src/core/reduce.rkt:16:0 debug5 [10] 100.0% ---------------------------------------------------------------------- ??? [71] 100.0% [3] 304(1.1%) 0(0.0%) approximate9 ...ify-tweak/src/core/taylor.rkt:12:0 loop [9] 100.0% ---------------------------------------------------------------------- match-e [52] 100.0% [4] 300(1.1%) 0(0.0%) variable? ...fy-tweak/src/syntax/syntax.rkt:1159:0 ??? [29] 100.0% ---------------------------------------------------------------------- ??? [1] 100.0% [5] 26554(100.0%) 0(0.0%) profile-thunk16 ...e/pkgs/profile-lib/main.rkt:9:0 run [12] 100.0% ---------------------------------------------------------------------- ??? [1] 100.0% [6] 15088(56.8%) 0(0.0%) run-improve40 ...lify-tweak/src/mainloop.rkt:340:0 simplify! [23] 59.6% for-loop [14] 40.4% ---------------------------------------------------------------------- ??? [1] 100.0% [7] 7542(28.4%) 0(0.0%) prepare-points-intervals ...k/src/points.rkt:133:0 loop [13] 100.0% ---------------------------------------------------------------------- ??? [1] 100.0% [8] 2708(10.2%) 1346(5.1%) eval-errors ...simplify-tweak/src/points.rkt:203:0 for-loop [15] 50.3% ---------------------------------------------------------------------- approximate9 [3] 100.0% [9] 304(1.1%) 0(0.0%) loop ...ie/simplify-tweak/src/core/taylor.rkt:87:4 hash-ref! [16] 100.0% ---------------------------------------------------------------------- simplify [2] 100.0% [10] 304(1.1%) 0(0.0%) debug5 ...erbie/simplify-tweak/src/debug.rkt:102:0 ??? [29] 100.0% ---------------------------------------------------------------------- ??? [1] 100.0% [11] 300(1.1%) 0(0.0%) oracle-error ...implify-tweak/src/points.rkt:212:0 for-loop [17] 100.0% ---------------------------------------------------------------------- profile-thunk16 [5] 100.0% [12] 26554(100.0%) 0(0.0%) run ...et-7.0/share/pkgs/profile-lib/main.rkt:39:2 ??? [1] 100.0% ---------------------------------------------------------------------- prepare-points-intervals [7] 100.0% [13] 7542(28.4%) 306(1.2%) loop ...herbie/simplify-tweak/src/points.rkt:145:4 loop [18] 84.2% ??? [20] 11.8% ---------------------------------------------------------------------- run-improve40 [6] 100.0% [14] 6094(22.9%) 0(0.0%) for-loop .../simplify-tweak/src/mainloop.rkt:355:4 run-iter! [19] 100.0% ---------------------------------------------------------------------- eval-errors [8] 100.0% [15] 1362(5.1%) 0(0.0%) for-loop ...ie/simplify-tweak/src/points.rkt:205:2 ??? [24] 100.0% ---------------------------------------------------------------------- ??? [21] 33.3% ??? [71] 33.3% loop [9] 33.3% [16] 304(1.1%) 0(0.0%) hash-ref! .../racket/private/more-scheme.rkt:376:2 ??? [22] 33.3% ??? [21] 33.3% simplify [2] 33.3% ---------------------------------------------------------------------- oracle-error [11] 100.0% [17] 300(1.1%) 0(0.0%) for-loop ...ie/simplify-tweak/src/points.rkt:213:2 loop [63] 100.0% ---------------------------------------------------------------------- loop [13] 100.0% [18] 6348(23.9%) 298(1.1%) loop ...herbie/simplify-tweak/src/points.rkt:104:2 ??? [24] 79.0% ??? [29] 10.6% ??? [71] 5.6% ---------------------------------------------------------------------- for-loop [14] 100.0% [19] 6094(22.9%) 0(0.0%) run-iter! ...simplify-tweak/src/mainloop.rkt:321:0 simplify! [23] 80.1% finalize-iter! [25] 14.9% gen-series! [26] 5.0% ---------------------------------------------------------------------- loop [13] 100.0% [20] 888(3.3%) 0(0.0%) ??? .../herbie/simplify-tweak/src/points.rkt:129:2 ??? [71] 100.0% ---------------------------------------------------------------------- hash-ref! [16] 100.0% [21] 304(1.1%) 0(0.0%) ??? ...ie/simplify-tweak/src/core/taylor.rkt:45:15 hash-ref! [16] 100.0% ---------------------------------------------------------------------- hash-ref! [16] 100.0% [22] 304(1.1%) 0(0.0%) ??? ...ie/simplify-tweak/src/core/taylor.rkt:68:15 ??? [71] 100.0% ---------------------------------------------------------------------- run-iter! [19] 35.2% run-improve40 [6] 64.8% [23] 13874(52.2%) 0(0.0%) simplify! ...simplify-tweak/src/mainloop.rkt:217:0 ??? [27] 100.0% ---------------------------------------------------------------------- for-loop [54] 12.6% for-loop [15] 18.7% loop [18] 68.8% [24] 7296(27.5%) 0(0.0%) ??? ...erbie/simplify-tweak/src/programs.rkt:146:2 ??? [28] 64.3% ??? [71] 35.7% ---------------------------------------------------------------------- run-iter! [19] 100.0% [25] 910(3.4%) 0(0.0%) finalize-iter! ...ify-tweak/src/mainloop.rkt:272:0 ??? [29] 100.0% ---------------------------------------------------------------------- run-iter! [19] 100.0% [26] 304(1.1%) 0(0.0%) gen-series! ...mplify-tweak/src/mainloop.rkt:153:0 for-loop [30] 100.0% ---------------------------------------------------------------------- simplify! [23] 100.0% [27] 13874(52.2%) 0(0.0%) ??? ...e/simplify-tweak/src/core/simplify.rkt:26:0 for-loop [31] 82.5% one-iter [35] 11.0% loop [33] 6.5% ---------------------------------------------------------------------- ??? [24] 100.0% [28] 4694(17.7%) 0(0.0%) ??? ...t-7.0/collects/racket/private/kw.rkt:592:14 ??? [71] 86.8% ??? [98] 13.2% ---------------------------------------------------------------------- variable? [4] 9.7% substitute-e [61] 9.8% debug5 [10] 9.9% match-e [52] 19.2% loop [18] 21.9% finalize-iter! [25] 29.5% [29] 3084(11.6%) 1874(7.1%) ??? ...contract/private/arrow-val-first.rkt:388:18 for-loop [32] 29.5% ??? [101] 9.7% ---------------------------------------------------------------------- gen-series! [26] 100.0% [30] 304(1.1%) 0(0.0%) for-loop .../simplify-tweak/src/mainloop.rkt:160:7 taylor-alt [34] 100.0% ---------------------------------------------------------------------- ??? [27] 100.0% [31] 11452(43.1%) 0(0.0%) for-loop ...plify-tweak/src/core/simplify.rkt:33:2 one-iter [35] 100.0% ---------------------------------------------------------------------- ??? [29] 100.0% [32] 910(3.4%) 0(0.0%) for-loop ...lify-tweak/src/core/alt-table.rkt:51:2 atab-add-altn [37] 66.2% loop [38] 33.8% ---------------------------------------------------------------------- ??? [27] 100.0% [33] 898(3.4%) 0(0.0%) loop ...simplify-tweak/src/core/simplify.rkt:132:2 for-loop [36] 100.0% ---------------------------------------------------------------------- for-loop [30] 100.0% [34] 304(1.1%) 0(0.0%) taylor-alt ...implify-tweak/src/mainloop.rkt:139:0 for-loop [39] 100.0% ---------------------------------------------------------------------- ??? [27] 11.7% for-loop [31] 88.3% [35] 12976(48.9%) 0(0.0%) one-iter ...plify-tweak/src/core/simplify.rkt:86:0 find-matches [40] 57.4% for-loop [41] 40.3% for-loop [45] 2.3% ---------------------------------------------------------------------- loop [33] 100.0% [36] 898(3.4%) 0(0.0%) for-loop ...lify-tweak/src/core/simplify.rkt:138:4 loop [42] 68.8% for-loop [46] 31.2% ---------------------------------------------------------------------- for-loop [32] 100.0% [37] 602(2.3%) 0(0.0%) atab-add-altn ...weak/src/core/alt-table.rkt:200:0 best-and-tied-at-points [43] 100.0% ---------------------------------------------------------------------- for-loop [32] 100.0% [38] 308(1.2%) 0(0.0%) loop ...implify-tweak/src/core/alt-table.rkt:174:2 loop [44] 100.0% ---------------------------------------------------------------------- taylor-alt [34] 100.0% [39] 304(1.1%) 0(0.0%) for-loop .../simplify-tweak/src/mainloop.rkt:145:6 ??? [71] 100.0% ---------------------------------------------------------------------- one-iter [35] 100.0% [40] 7442(28.0%) 0(0.0%) find-matches ...y-tweak/src/core/simplify.rkt:56:0 for-loop [47] 100.0% ---------------------------------------------------------------------- one-iter [35] 100.0% [41] 5232(19.7%) 0(0.0%) for-loop ...plify-tweak/src/core/simplify.rkt:95:2 apply-match [48] 100.0% ---------------------------------------------------------------------- for-loop [36] 100.0% [42] 618(2.3%) 0(0.0%) loop .../racket-7.0/collects/racket/list.rkt:751:4 for-loop [50] 100.0% ---------------------------------------------------------------------- atab-add-altn [37] 100.0% [43] 602(2.3%) 0(0.0%) best-and-tied-at-points ...ore/alt-table.rkt:112:0 errors [49] 100.0% ---------------------------------------------------------------------- loop [38] 100.0% [44] 308(1.2%) 308(1.2%) loop ...simplify-tweak/src/core/alt-table.rkt:96:2 ---------------------------------------------------------------------- one-iter [35] 100.0% [45] 302(1.1%) 0(0.0%) for-loop ...lify-tweak/src/core/simplify.rkt:100:2 set-precompute! [51] 100.0% ---------------------------------------------------------------------- for-loop [36] 100.0% [46] 280(1.1%) 280(1.1%) for-loop ...ify-tweak/src/core/simplify.rkt:142:16 ---------------------------------------------------------------------- for-loop [47] 50.0% find-matches [40] 50.0% [47] 7442(28.0%) 928(3.5%) for-loop ...plify-tweak/src/core/simplify.rkt:58:8 for-loop [47] 50.0% match-e [52] 43.8% ---------------------------------------------------------------------- for-loop [41] 100.0% [48] 5232(19.7%) 0(0.0%) apply-match ...fy-tweak/src/core/simplify.rkt:65:0 for-loop [53] 94.1% match-e [52] 5.9% ---------------------------------------------------------------------- best-and-tied-at-points [43] 39.7% ??? [1] 60.3% [49] 1518(5.7%) 0(0.0%) errors ...rbie/simplify-tweak/src/points.rkt:228:0 for-loop [54] 100.0% ---------------------------------------------------------------------- loop [42] 100.0% [50] 618(2.3%) 0(0.0%) for-loop .../simplify-tweak/src/programs.rkt:205:2 table-ref [55] 100.0% ---------------------------------------------------------------------- for-loop [45] 100.0% [51] 302(1.1%) 0(0.0%) set-precompute! ...eak/src/core/simplify.rkt:106:0 for-loop [56] 100.0% ---------------------------------------------------------------------- apply-match [48] 4.5% for-loop [62] 23.6% for-loop [47] 71.9% [52] 6822(25.7%) 1464(5.5%) match-e ...simplify-tweak/src/core/ematch.rkt:39:0 for-loop [57] 74.2% ??? [29] 2.9% variable? [4] 1.5% ---------------------------------------------------------------------- apply-match [48] 100.0% [53] 4924(18.5%) 0(0.0%) for-loop ...plify-tweak/src/core/simplify.rkt:78:2 merge-egraph-nodes! [58] 56.1% dedup-children! [59] 31.1% mk-enode! [60] 6.7% substitute-e [61] 6.1% ---------------------------------------------------------------------- errors [49] 100.0% [54] 1518(5.7%) 0(0.0%) for-loop ...ie/simplify-tweak/src/points.rkt:230:2 ??? [24] 60.5% ??? [71] 39.5% ---------------------------------------------------------------------- for-loop [50] 100.0% [55] 618(2.3%) 618(2.3%) table-ref ...ie/simplify-tweak/src/common.rkt:42:0 ---------------------------------------------------------------------- set-precompute! [51] 100.0% [56] 302(1.1%) 0(0.0%) for-loop ...lify-tweak/src/core/simplify.rkt:108:2 merge-egraph-nodes! [58] 100.0% ---------------------------------------------------------------------- match-e [52] 100.0% [57] 5358(20.2%) 2622(9.9%) for-loop ...mplify-tweak/src/core/ematch.rkt:52:11 for-loop [62] 35.5% loop [63] 12.2% loop [67] 5.8% foldl [74] 2.8% cp-2 [75] 2.8% foldr [70] 2.7% ---------------------------------------------------------------------- for-loop [69] 4.8% for-loop [56] 9.9% for-loop [53] 85.3% [58] 3062(11.5%) 290(1.1%) merge-egraph-nodes! ...k/src/core/egraph.rkt:145:0 loop! [72] 61.1% update-leader! [65] 24.6% for-loop [69] 4.8% ---------------------------------------------------------------------- for-loop [53] 100.0% [59] 1530(5.8%) 0(0.0%) dedup-children! ...-tweak/src/core/enode.rkt:199:0 loop [64] 78.8% loop [66] 21.2% ---------------------------------------------------------------------- for-loop [53] 100.0% [60] 332(1.3%) 332(1.3%) mk-enode! ...mplify-tweak/src/core/egraph.rkt:99:0 ---------------------------------------------------------------------- for-loop [68] 50.0% for-loop [53] 50.0% [61] 302(1.1%) 0(0.0%) substitute-e ...ify-tweak/src/core/ematch.rkt:64:0 for-loop [68] 50.0% ??? [29] 50.0% ---------------------------------------------------------------------- for-loop [57] 100.0% [62] 2916(11.0%) 0(0.0%) for-loop ...mplify-tweak/src/core/ematch.rkt:58:37 match-e [52] 100.0% ---------------------------------------------------------------------- for-loop [57] 0.4% loop! [72] 3.3% for-loop [17] 16.1% loop [63] 80.2% [63] 1868(7.0%) 326(1.2%) loop ...-7.0/collects/racket/private/map.rkt:40:19 loop [63] 80.2% ??? [71] 16.1% loop! [72] 3.3% foldl [74] 0.3% ---------------------------------------------------------------------- dedup-children! [59] 9.4% loop [64] 90.6% [64] 1206(4.5%) 1206(4.5%) loop ...racket-7.0/collects/racket/list.rkt:434:17 loop [64] 90.6% ---------------------------------------------------------------------- merge-egraph-nodes! [58] 100.0% [65] 900(3.4%) 0(0.0%) update-leader! ...-tweak/src/core/egraph.rkt:213:0 for-loop [73] 100.0% ---------------------------------------------------------------------- dedup-children! [59] 25.0% loop [66] 75.0% [66] 324(1.2%) 0(0.0%) loop ...racket-7.0/collects/racket/list.rkt:417:34 loop [66] 75.0% loop [76] 25.0% ---------------------------------------------------------------------- for-loop [57] 100.0% [67] 310(1.2%) 310(1.2%) loop ...7.0/collects/racket/private/list.rkt:264:4 ---------------------------------------------------------------------- substitute-e [61] 100.0% [68] 302(1.1%) 0(0.0%) for-loop ...mplify-tweak/src/core/ematch.rkt:73:24 substitute-e [61] 100.0% ---------------------------------------------------------------------- merge-egraph-nodes! [58] 100.0% [69] 294(1.1%) 0(0.0%) for-loop ...mplify-tweak/src/core/egraph.rkt:199:4 merge-egraph-nodes! [58] 100.0% ---------------------------------------------------------------------- for-loop [57] 100.0% [70] 284(1.1%) 0(0.0%) foldr ....0/collects/racket/private/list.rkt:242:4 cp-2 [75] 100.0% ---------------------------------------------------------------------- ??? [22] 1.1% for-loop [39] 1.1% loop [63] 3.3% loop [18] 3.9% for-loop [54] 6.6% ??? [20] 9.7% ??? [24] 28.5% ??? [28] 44.7% [71] 9128(34.4%) 622(2.3%) ??? ...tract/private/arrow-higher-order.rkt:357:33 ival-mult [77] 44.7% ->flonum [78] 35.5% sample-multi-bounded [79] 9.7% approximate9 [3] 1.1% hash-ref! [16] 1.1% ---------------------------------------------------------------------- loop [63] 24.5% merge-egraph-nodes! [58] 75.5% [72] 1872(7.0%) 650(2.4%) loop! ...e/simplify-tweak/src/core/enode.rkt:191:2 custom-set-union [80] 33.2% loop [63] 24.5% set [81] 16.0% ---------------------------------------------------------------------- update-leader! [65] 100.0% [73] 900(3.4%) 0(0.0%) for-loop ...mplify-tweak/src/core/egraph.rkt:218:6 for-loop [82] 66.4% hash-update! [86] 33.6% ---------------------------------------------------------------------- for-loop [57] 47.9% loop [63] 52.1% [74] 626(2.4%) 326(1.2%) foldl ....0/collects/racket/private/list.rkt:229:4 merge2 [83] 47.9% ---------------------------------------------------------------------- foldr [70] 48.8% for-loop [57] 51.2% [75] 582(2.2%) 298(1.1%) cp-2 .../racket-7.0/collects/racket/list.rkt:826:2 for-loop [84] 48.8% ---------------------------------------------------------------------- loop [66] 100.0% [76] 324(1.2%) 324(1.2%) loop (unknown source) ---------------------------------------------------------------------- ??? [71] 100.0% [77] 4076(15.3%) 314(1.2%) ival-mult ...plify-tweak/src/biginterval.rkt:105:0 classify-ival [85] 77.8% bf* [90] 7.6% ...higher-order.rkt:361:33 [92] 6.9% ---------------------------------------------------------------------- ??? [71] 100.0% [78] 3238(12.2%) 2616(9.9%) ->flonum ...e/simplify-tweak/src/programs.rkt:38:0 return/no-unsupplied [87] 9.9% ??? [88] 9.3% ---------------------------------------------------------------------- ??? [71] 100.0% [79] 888(3.3%) 0(0.0%) sample-multi-bounded ...-tweak/src/points.rkt:16:0 for-loop [91] 33.6% ??? [88] 33.6% return/no-unsupplied [87] 32.9% ---------------------------------------------------------------------- loop! [72] 100.0% [80] 622(2.3%) 292(1.1%) custom-set-union ...et/private/set-types.rkt:168:0 for-loop [89] 53.1% ---------------------------------------------------------------------- loop! [72] 100.0% [81] 600(2.3%) 600(2.3%) set ...collects/racket/private/set-types.rkt:981:0 ---------------------------------------------------------------------- for-loop [73] 100.0% [82] 598(2.3%) 0(0.0%) for-loop ...mplify-tweak/src/core/egraph.rkt:219:8 hash-update! [86] 100.0% ---------------------------------------------------------------------- foldl [74] 100.0% [83] 300(1.1%) 300(1.1%) merge2 .../simplify-tweak/src/core/ematch.rkt:24:0 ---------------------------------------------------------------------- cp-2 [75] 100.0% [84] 284(1.1%) 284(1.1%) for-loop ...ket-7.0/collects/racket/list.rkt:827:4 ---------------------------------------------------------------------- ival-mult [77] 100.0% [85] 3170(11.9%) 1250(4.7%) classify-ival ...y-tweak/src/biginterval.rkt:310:0 fold-binary-pred [93] 30.7% ...higher-order.rkt:357:33 [95] 19.2% force [96] 10.6% ---------------------------------------------------------------------- for-loop [73] 33.6% for-loop [82] 66.4% [86] 900(3.4%) 0(0.0%) hash-update! ...cket/private/more-scheme.rkt:365:4 ??? [94] 100.0% ---------------------------------------------------------------------- sample-multi-bounded [79] 47.7% ->flonum [78] 52.3% [87] 612(2.3%) 612(2.3%) return/no-unsupplied ...ct/private/arr-i.rkt:534:0 ---------------------------------------------------------------------- sample-multi-bounded [79] 49.7% ->flonum [78] 50.3% [88] 600(2.3%) 600(2.3%) ??? ...s/racket/contract/private/arr-i.rkt:1252:29 ---------------------------------------------------------------------- custom-set-union [80] 100.0% [89] 330(1.2%) 0(0.0%) for-loop ...cts/racket/private/set-types.rkt:174:3 for-loop [97] 100.0% ---------------------------------------------------------------------- ival-mult [77] 100.0% [90] 310(1.2%) 0(0.0%) bf* ...ath/private/bigfloat/bigfloat-mpfr.rkt:95:0 ??? [103] 100.0% ---------------------------------------------------------------------- sample-multi-bounded [79] 100.0% [91] 298(1.1%) 298(1.1%) for-loop ...bie/simplify-tweak/src/points.rkt:26:4 ---------------------------------------------------------------------- ival-mult [77] 100.0% [92] 282(1.1%) 282(1.1%) ...higher-order.rkt:361:33 (unknown source) ---------------------------------------------------------------------- classify-ival [85] 100.0% [93] 974(3.7%) 0(0.0%) fold-binary-pred ...gfloat/bigfloat-mpfr.rkt:117:0 ??? [98] 100.0% ---------------------------------------------------------------------- hash-update! [86] 100.0% [94] 900(3.4%) 0(0.0%) ??? ...e/simplify-tweak/src/core/egraph.rkt:221:24 for-loop [99] 100.0% ---------------------------------------------------------------------- classify-ival [85] 100.0% [95] 610(2.3%) 0(0.0%) ...higher-order.rkt:357:33 (unknown source) ??? [100] 100.0% ---------------------------------------------------------------------- classify-ival [85] 100.0% [96] 336(1.3%) 336(1.3%) force ...collects/racket/private/promise.rkt:109:0 ---------------------------------------------------------------------- for-loop [89] 100.0% [97] 330(1.2%) 330(1.2%) for-loop ...cts/racket/private/set-types.rkt:178:5 ---------------------------------------------------------------------- ??? [28] 38.8% fold-binary-pred [93] 61.2% [98] 1592(6.0%) 974(3.7%) ??? ...tract/private/arrow-higher-order.rkt:361:33 ival-sub [102] 38.8% ---------------------------------------------------------------------- ??? [94] 100.0% [99] 900(3.4%) 900(3.4%) for-loop ...plify-tweak/src/core/egraph.rkt:222:26 ---------------------------------------------------------------------- ...higher-order.rkt:357:33 [95]100.0% [100] 610(2.3%) 0(0.0%) ??? ...cts/racket/contract/private/list.rkt:209:10 ??? [101] 100.0% ---------------------------------------------------------------------- ??? [29] 33.0% ??? [100] 67.0% [101] 910(3.4%) 910(3.4%) ??? ...ects/racket/contract/private/guts.rkt:746:8 ---------------------------------------------------------------------- ??? [98] 100.0% [102] 618(2.3%) 300(1.1%) ival-sub ...implify-tweak/src/biginterval.rkt:93:0 ??? [103] 51.5% ---------------------------------------------------------------------- bf* [90] 49.4% ival-sub [102] 50.6% [103] 628(2.4%) 0(0.0%) ??? ...-racket/utils/simple-result-arrow.rkt:39:12 bfmul [104] 100.0% ---------------------------------------------------------------------- ??? [103] 100.0% [104] 628(2.4%) 0(0.0%) bfmul ...-lib/math/private/bigfloat/mpfr.rkt:821:4 ??? [105] 50.6% new-mpfr [106] 49.4% ---------------------------------------------------------------------- bfmul [104] 100.0% [105] 318(1.2%) 318(1.2%) ??? /opt/racket-7.0/collects/ffi/unsafe.rkt:898:4 ---------------------------------------------------------------------- bfmul [104] 100.0% [106] 310(1.2%) 310(1.2%) new-mpfr ...b/math/private/bigfloat/mpfr.rkt:335:0 ----------------------------------------------------------------------