Profiling results ----------------- Total cpu time observed: 64738ms (out of 65032ms) Number of samples taken: 216 (once every 300ms) (Hiding functions with self<1.0% and local<2.0%: 3 of 105 hidden) ===================================================================== Caller Idx Total Self Name+src Local% ms(pct) ms(pct) Callee ===================================================================== ??? [5] 100.0% [1] 64738(100.0%) 0(0.0%) profile-thunk16 ...e/pkgs/profile-lib/main.rkt:9:0 run [3] 100.0% --------------------------------------------------------------------- ??? [5] 100.0% [2] 646(1.0%) 0(0.0%) errors ...erbie/no-dirty-bits/src/points.rkt:228:0 for-loop [4] 100.0% --------------------------------------------------------------------- profile-thunk16 [1] 100.0% [3] 64738(100.0%) 0(0.0%) run ...et-7.0/share/pkgs/profile-lib/main.rkt:39:2 ??? [5] 100.0% --------------------------------------------------------------------- errors [2] 100.0% [4] 646(1.0%) 0(0.0%) for-loop ...bie/no-dirty-bits/src/points.rkt:230:2 ??? [5] 100.0% --------------------------------------------------------------------- for-loop [4] 0.3% run [3] 49.8% [5] 64738(100.0%) 0(0.0%) ??? ...lects/racket/private/more-scheme.rkt:261:28 profile-thunk16 [1] 49.8% run-improve40 [6] 43.9% prepare-points-intervals [7] 5.1% errors [2] 0.3% oracle-error [8] 0.2% eval-errors [9] 0.2% ??? [70] 0.2% ??? [83] 0.2% --------------------------------------------------------------------- ??? [5] 100.0% [6] 56900(87.9%) 0(0.0%) run-improve40 ...dirty-bits/src/mainloop.rkt:336:0 simplify! [10] 99.5% for-loop [14] 0.5% --------------------------------------------------------------------- ??? [5] 100.0% [7] 6586(10.2%) 0(0.0%) prepare-points-intervals ...s/src/points.rkt:133:0 loop [11] 100.0% --------------------------------------------------------------------- ??? [5] 100.0% [8] 308(0.5%) 0(0.0%) oracle-error ...no-dirty-bits/src/points.rkt:212:0 for-loop [12] 100.0% --------------------------------------------------------------------- ??? [5] 100.0% [9] 298(0.5%) 0(0.0%) eval-errors .../no-dirty-bits/src/points.rkt:203:0 for-loop [13] 100.0% --------------------------------------------------------------------- run-improve40 [6] 100.0% [10] 56602(87.4%) 0(0.0%) simplify! .../no-dirty-bits/src/mainloop.rkt:213:0 ??? [15] 100.0% --------------------------------------------------------------------- prepare-points-intervals [7]100.0% [11] 6586(10.2%) 0(0.0%) loop .../herbie/no-dirty-bits/src/points.rkt:145:4 loop [16] 71.1% ??? [17] 24.1% loop [18] 4.8% --------------------------------------------------------------------- oracle-error [8] 100.0% [12] 308(0.5%) 0(0.0%) for-loop ...bie/no-dirty-bits/src/points.rkt:213:2 loop [62] 100.0% --------------------------------------------------------------------- eval-errors [9] 100.0% [13] 298(0.5%) 0(0.0%) for-loop ...bie/no-dirty-bits/src/points.rkt:205:2 point-error [19] 100.0% --------------------------------------------------------------------- run-improve40 [6] 100.0% [14] 298(0.5%) 0(0.0%) for-loop ...e/no-dirty-bits/src/mainloop.rkt:351:4 run-iter! [20] 100.0% --------------------------------------------------------------------- simplify! [10] 100.0% [15] 56602(87.4%) 0(0.0%) ??? ...ie/no-dirty-bits/src/core/simplify.rkt:26:0 for-loop [21] 98.4% loop [22] 1.6% --------------------------------------------------------------------- loop [11] 100.0% [16] 4682(7.2%) 0(0.0%) loop .../herbie/no-dirty-bits/src/points.rkt:104:2 ??? [70] 78.9% ??? [83] 21.1% --------------------------------------------------------------------- loop [11] 100.0% [17] 1590(2.5%) 346(0.5%) ??? ...s/herbie/no-dirty-bits/src/points.rkt:129:2 ??? [83] 59.6% ??? [84] 18.6% --------------------------------------------------------------------- loop [11] 100.0% [18] 314(0.5%) 314(0.5%) loop ...7.0/collects/racket/private/map.rkt:110:23 --------------------------------------------------------------------- for-loop [13] 100.0% [19] 298(0.5%) 0(0.0%) point-error .../no-dirty-bits/src/points.rkt:195:0 ulp-difference [23] 100.0% --------------------------------------------------------------------- for-loop [14] 100.0% [20] 298(0.5%) 0(0.0%) run-iter! .../no-dirty-bits/src/mainloop.rkt:317:0 localize! [24] 100.0% --------------------------------------------------------------------- ??? [15] 100.0% [21] 55692(86.0%) 0(0.0%) for-loop ...-dirty-bits/src/core/simplify.rkt:33:2 one-iter [25] 100.0% --------------------------------------------------------------------- ??? [15] 100.0% [22] 910(1.4%) 0(0.0%) loop .../no-dirty-bits/src/core/simplify.rkt:139:2 for-loop [26] 100.0% --------------------------------------------------------------------- point-error [19] 100.0% [23] 298(0.5%) 0(0.0%) ulp-difference ...no-dirty-bits/src/float.rkt:14:0 ??? [27] 100.0% --------------------------------------------------------------------- run-iter! [20] 100.0% [24] 298(0.5%) 0(0.0%) localize! .../no-dirty-bits/src/mainloop.rkt:116:0 localize-error [28] 100.0% --------------------------------------------------------------------- for-loop [21] 100.0% [25] 55692(86.0%) 0(0.0%) one-iter ...-dirty-bits/src/core/simplify.rkt:82:0 for-loop [29] 85.9% find-matches [30] 13.5% for-loop [31] 0.6% --------------------------------------------------------------------- loop [22] 100.0% [26] 910(1.4%) 0(0.0%) for-loop ...dirty-bits/src/core/simplify.rkt:145:4 argmin [32] 34.1% loop [34] 33.0% for-loop [33] 33.0% --------------------------------------------------------------------- ulp-difference [23] 100.0% [27] 298(0.5%) 298(0.5%) ??? ...s/racket/contract/private/arr-i.rkt:1252:29 --------------------------------------------------------------------- localize! [24] 100.0% [28] 298(0.5%) 0(0.0%) localize-error ...-bits/src/core/localize.rkt:52:0 hash-ref! [45] 100.0% --------------------------------------------------------------------- one-iter [25] 100.0% [29] 47860(73.9%) 0(0.0%) for-loop ...-dirty-bits/src/core/simplify.rkt:91:2 loop [35] 87.1% update-leader! [53] 12.9% --------------------------------------------------------------------- one-iter [25] 100.0% [30] 7502(11.6%) 0(0.0%) find-matches ...ty-bits/src/core/simplify.rkt:56:0 for-loop [36] 100.0% --------------------------------------------------------------------- one-iter [25] 100.0% [31] 330(0.5%) 0(0.0%) for-loop ...dirty-bits/src/core/simplify.rkt:107:2 set-precompute! [38] 100.0% --------------------------------------------------------------------- for-loop [26] 100.0% [32] 310(0.5%) 0(0.0%) argmin ...acket-7.0/collects/racket/list.rkt:765:0 expression-cost [37] 100.0% --------------------------------------------------------------------- for-loop [26] 100.0% [33] 300(0.5%) 0(0.0%) for-loop ...irty-bits/src/core/simplify.rkt:149:16 for-loop [39] 100.0% --------------------------------------------------------------------- for-loop [26] 100.0% [34] 300(0.5%) 0(0.0%) loop .../racket-7.0/collects/racket/list.rkt:751:4 expression-cost [37] 100.0% --------------------------------------------------------------------- for-loop [29] 100.0% [35] 41692(64.4%) 0(0.0%) loop ...e/no-dirty-bits/src/core/simplify.rkt:96:4 apply-match [40] 100.0% --------------------------------------------------------------------- for-loop [36] 50.0% find-matches [30] 50.0% [36] 7502(11.6%) 0(0.0%) for-loop ...-dirty-bits/src/core/simplify.rkt:58:8 for-loop [36] 50.0% match-e [44] 50.0% --------------------------------------------------------------------- loop [34] 49.2% argmin [32] 50.8% [37] 610(0.9%) 0(0.0%) expression-cost ...rty-bits/src/programs.rkt:204:0 compile [41] 100.0% --------------------------------------------------------------------- for-loop [31] 100.0% [38] 330(0.5%) 0(0.0%) set-precompute! ...its/src/core/simplify.rkt:113:0 for-loop [42] 100.0% --------------------------------------------------------------------- for-loop [33] 100.0% [39] 300(0.5%) 300(0.5%) for-loop ...irty-bits/src/core/simplify.rkt:153:23 --------------------------------------------------------------------- loop [35] 100.0% [40] 41692(64.4%) 0(0.0%) apply-match ...rty-bits/src/core/simplify.rkt:64:0 for-loop [43] 91.2% match-e [44] 8.8% --------------------------------------------------------------------- expression-cost [37] 100.0% [41] 610(0.9%) 0(0.0%) compile ...ie/no-dirty-bits/src/programs.rkt:181:0 hash-ref! [45] 100.0% --------------------------------------------------------------------- set-precompute! [38] 100.0% [42] 330(0.5%) 0(0.0%) for-loop ...dirty-bits/src/core/simplify.rkt:115:2 setfindf [46] 100.0% --------------------------------------------------------------------- apply-match [40] 100.0% [43] 38042(58.8%) 0(0.0%) for-loop ...-dirty-bits/src/core/simplify.rkt:77:2 merge-egraph-nodes! [47] 86.2% dedup-children! [63] 10.1% substitute-e [49] 3.1% mk-enode! [66] 0.7% --------------------------------------------------------------------- apply-match [40] 24.0% for-loop [54] 28.3% for-loop [36] 47.7% [44] 11152(17.2%) 2500(3.9%) match-e .../no-dirty-bits/src/core/ematch.rkt:39:0 for-loop [48] 79.9% ??? [57] 4.5% --------------------------------------------------------------------- ??? [51] 16.5% localize-error [28] 32.8% compile [41] 50.7% [45] 908(1.4%) 310(0.5%) hash-ref! .../racket/private/more-scheme.rkt:376:2 ??? [51] 33.0% parse-loop15 [52] 32.8% --------------------------------------------------------------------- for-loop [42] 100.0% [46] 330(0.5%) 0(0.0%) setfindf ...bie/no-dirty-bits/src/common.rkt:139:0 for-loop [50] 100.0% --------------------------------------------------------------------- merge-egraph-nodes! [47] 3.8% for-loop [56] 5.8% for-loop [43] 90.3% [47] 32780(50.6%) 510(0.8%) merge-egraph-nodes! ...s/src/core/egraph.rkt:145:0 update-leader! [53] 76.0% loop! [55] 11.6% for-loop [56] 6.8% merge-egraph-nodes! [47] 3.8% dedup-children! [63] 0.3% --------------------------------------------------------------------- match-e [44] 100.0% [48] 9876(15.3%) 5374(8.3%) for-loop ...o-dirty-bits/src/core/ematch.rkt:52:11 for-loop [54] 41.7% loop [62] 8.8% curry* [59] 3.3% foldl [72] 1.5% foldr [60] 1.2% --------------------------------------------------------------------- for-loop [58] 28.5% for-loop [43] 71.5% [49] 1170(1.8%) 0(0.0%) substitute-e ...irty-bits/src/core/ematch.rkt:64:0 for-loop [58] 80.2% ??? [57] 19.8% --------------------------------------------------------------------- setfindf [46] 100.0% [50] 330(0.5%) 330(0.5%) for-loop ...bie/no-dirty-bits/src/common.rkt:140:2 --------------------------------------------------------------------- hash-ref! [45] 100.0% [51] 300(0.5%) 300(0.5%) ??? ...herbie/no-dirty-bits/src/programs.rkt:189:5 hash-ref! [45] 50.0% --------------------------------------------------------------------- hash-ref! [45] 100.0% [52] 298(0.5%) 0(0.0%) parse-loop15 ...s/racket/match/compiler.rkt:418:15 loop [62] 100.0% --------------------------------------------------------------------- for-loop [29] 19.0% merge-egraph-nodes! [47] 81.0% [53] 32492(50.2%) 0(0.0%) update-leader! ...y-bits/src/core/egraph.rkt:213:0 for-loop [61] 100.0% --------------------------------------------------------------------- for-loop [48] 100.0% [54] 5710(8.8%) 0(0.0%) for-loop ...o-dirty-bits/src/core/ematch.rkt:58:37 match-e [44] 100.0% --------------------------------------------------------------------- loop [62] 30.0% merge-egraph-nodes! [47] 70.0% [55] 5288(8.2%) 630(1.0%) loop! ...ie/no-dirty-bits/src/core/enode.rkt:191:2 loop [62] 40.6% custom-set-union [64] 37.9% set [65] 15.5% --------------------------------------------------------------------- merge-egraph-nodes! [47] 100.0% [56] 4396(6.8%) 0(0.0%) for-loop ...o-dirty-bits/src/core/egraph.rkt:199:4 merge-egraph-nodes! [47] 93.2% dedup-children! [63] 6.8% --------------------------------------------------------------------- substitute-e [49] 31.9% match-e [44] 68.1% [57] 1772(2.7%) 1772(2.7%) ??? ...contract/private/arrow-val-first.rkt:388:18 --------------------------------------------------------------------- substitute-e [49] 100.0% [58] 1170(1.8%) 0(0.0%) for-loop ...o-dirty-bits/src/core/ematch.rkt:73:24 mk-enode! [66] 51.6% substitute-e [49] 48.4% --------------------------------------------------------------------- for-loop [48] 100.0% [59] 322(0.5%) 322(0.5%) curry* ...et-7.0/collects/racket/function.rkt:44:2 --------------------------------------------------------------------- for-loop [48] 100.0% [60] 246(0.4%) 0(0.0%) foldr ....0/collects/racket/private/list.rkt:242:4 cp-2 [67] 100.0% --------------------------------------------------------------------- update-leader! [53] 100.0% [61] 32492(50.2%) 0(0.0%) for-loop ...o-dirty-bits/src/core/egraph.rkt:218:6 hash-update! [77] 58.0% for-loop [68] 42.0% --------------------------------------------------------------------- parse-loop15 [52] 0.3% for-loop [48] 1.7% loop! [55] 4.3% for-loop [12] 6.3% loop [62] 87.4% [62] 4890(7.6%) 1172(1.8%) loop ...-7.0/collects/racket/private/map.rkt:40:19 loop [62] 87.4% ??? [70] 6.3% loop! [55] 3.1% foldl [72] 0.5% map [74] 0.3% --------------------------------------------------------------------- for-loop [56] 6.6% merge-egraph-nodes! [47] 8.0% for-loop [43] 85.4% [63] 4496(6.9%) 0(0.0%) dedup-children! ...y-bits/src/core/enode.rkt:199:0 loop [69] 100.0% --------------------------------------------------------------------- loop! [55] 100.0% [64] 2140(3.3%) 1502(2.3%) custom-set-union ...et/private/set-types.rkt:168:0 for-loop [71] 29.8% --------------------------------------------------------------------- loop! [55] 100.0% [65] 1644(2.5%) 1644(2.5%) set ...collects/racket/private/set-types.rkt:981:0 --------------------------------------------------------------------- for-loop [43] 29.6% for-loop [58] 70.4% [66] 858(1.3%) 302(0.5%) mk-enode! ...o-dirty-bits/src/core/egraph.rkt:99:0 new-enode [73] 35.2% hash-has-key? [75] 29.6% --------------------------------------------------------------------- foldr [60] 100.0% [67] 246(0.4%) 0(0.0%) cp-2 .../racket-7.0/collects/racket/list.rkt:826:2 for-loop [76] 100.0% --------------------------------------------------------------------- for-loop [61] 100.0% [68] 13648(21.1%) 0(0.0%) for-loop ...o-dirty-bits/src/core/egraph.rkt:219:8 hash-update! [77] 100.0% --------------------------------------------------------------------- dedup-children! [63] 8.2% loop [69] 91.8% [69] 4496(6.9%) 4496(6.9%) loop ...racket-7.0/collects/racket/list.rkt:434:17 loop [69] 91.8% --------------------------------------------------------------------- loop [62] 7.1% ??? [5] 7.5% loop [16] 85.4% [70] 4324(6.7%) 0(0.0%) ??? ...herbie/no-dirty-bits/src/programs.rkt:146:2 ??? [78] 78.4% ??? [83] 21.6% --------------------------------------------------------------------- custom-set-union [64] 100.0% [71] 638(1.0%) 308(0.5%) for-loop ...cts/racket/private/set-types.rkt:174:3 for-loop [79] 51.7% --------------------------------------------------------------------- loop [62] 46.1% for-loop [48] 53.9% [72] 560(0.9%) 302(0.5%) foldl ....0/collects/racket/private/list.rkt:229:4 merge2 [81] 46.1% --------------------------------------------------------------------- mk-enode! [66] 100.0% [73] 302(0.5%) 0(0.0%) new-enode ...no-dirty-bits/src/core/enode.rkt:96:0 type-of-enode-expr [80] 100.0% --------------------------------------------------------------------- loop [62] 100.0% [74] 298(0.5%) 0(0.0%) map ...t-7.0/collects/racket/private/map.rkt:35:13 ??? [83] 100.0% --------------------------------------------------------------------- mk-enode! [66] 100.0% [75] 254(0.4%) 254(0.4%) hash-has-key? ...ket/private/more-scheme.rkt:371:2 --------------------------------------------------------------------- cp-2 [67] 100.0% [76] 246(0.4%) 246(0.4%) for-loop ...ket-7.0/collects/racket/list.rkt:827:4 --------------------------------------------------------------------- for-loop [68] 42.0% for-loop [61] 58.0% [77] 32492(50.2%) 0(0.0%) hash-update! ...cket/private/more-scheme.rkt:365:4 ??? [82] 100.0% --------------------------------------------------------------------- ??? [70] 100.0% [78] 3392(5.2%) 0(0.0%) ??? ...t-7.0/collects/racket/private/kw.rkt:592:14 ??? [84] 56.0% ??? [83] 44.0% --------------------------------------------------------------------- for-loop [71] 100.0% [79] 330(0.5%) 330(0.5%) for-loop ...cts/racket/private/set-types.rkt:178:5 --------------------------------------------------------------------- new-enode [73] 100.0% [80] 302(0.5%) 0(0.0%) type-of-enode-expr ...bits/src/core/enode.rkt:69:0 table-ref [85] 100.0% --------------------------------------------------------------------- foldl [72] 100.0% [81] 258(0.4%) 258(0.4%) merge2 ...e/no-dirty-bits/src/core/ematch.rkt:24:0 --------------------------------------------------------------------- hash-update! [77] 100.0% [82] 32492(50.2%) 546(0.8%) ??? ...ie/no-dirty-bits/src/core/egraph.rkt:221:24 for-loop [86] 96.4% update-en-expr [93] 0.9% --------------------------------------------------------------------- map [74] 6.0% ??? [5] 6.5% ??? [70] 18.7% ??? [17] 19.0% loop [16] 19.9% ??? [78] 30.0% [83] 4984(7.7%) 940(1.5%) ??? ...tract/private/arrow-higher-order.rkt:357:33 ->flonum [87] 32.1% ival-mult [88] 30.0% sample-multi-bounded [90] 19.0% --------------------------------------------------------------------- ??? [17] 13.5% ??? [78] 86.5% [84] 2194(3.4%) 0(0.0%) ??? ...tract/private/arrow-higher-order.rkt:361:33 ival-add [89] 58.0% ival-sub [91] 28.5% ??? [92] 13.5% --------------------------------------------------------------------- type-of-enode-expr [80] 100.0% [85] 302(0.5%) 302(0.5%) table-ref ...bie/no-dirty-bits/src/common.rkt:42:0 --------------------------------------------------------------------- ??? [82] 100.0% [86] 31324(48.4%) 26992(41.7%) for-loop ...-dirty-bits/src/core/egraph.rkt:222:26 update-en-expr [93] 13.8% --------------------------------------------------------------------- ??? [83] 100.0% [87] 1602(2.5%) 960(1.5%) ->flonum ...ie/no-dirty-bits/src/programs.rkt:38:0 ??? [101] 20.8% return/no-unsupplied [95] 19.2% --------------------------------------------------------------------- ??? [83] 100.0% [88] 1494(2.3%) 300(0.5%) ival-mult ...-dirty-bits/src/biginterval.rkt:105:0 bf* [94] 59.8% classify-ival [97] 20.1% --------------------------------------------------------------------- ??? [84] 100.0% [89] 1272(2.0%) 340(0.5%) ival-add ...no-dirty-bits/src/biginterval.rkt:87:0 ??? [98] 73.3% --------------------------------------------------------------------- ??? [83] 100.0% [90] 948(1.5%) 298(0.5%) sample-multi-bounded ...y-bits/src/points.rkt:16:0 return/no-unsupplied [95] 36.5% for-loop [96] 32.1% --------------------------------------------------------------------- ??? [84] 100.0% [91] 626(1.0%) 0(0.0%) ival-sub ...no-dirty-bits/src/biginterval.rkt:93:0 ??? [98] 100.0% --------------------------------------------------------------------- ??? [84] 100.0% [92] 296(0.5%) 296(0.5%) ??? ...cts/racket/contract/private/list.rkt:209:10 --------------------------------------------------------------------- ??? [82] 6.2% for-loop [86] 93.8% [93] 4620(7.1%) 4620(7.1%) update-en-expr ...y-bits/src/core/egraph.rkt:207:0 --------------------------------------------------------------------- ival-mult [88] 100.0% [94] 894(1.4%) 0(0.0%) bf* ...ath/private/bigfloat/bigfloat-mpfr.rkt:95:0 ??? [98] 100.0% --------------------------------------------------------------------- ->flonum [87] 47.1% sample-multi-bounded [90] 52.9% [95] 654(1.0%) 346(0.5%) return/no-unsupplied ...ct/private/arr-i.rkt:534:0 filter [99] 47.1% --------------------------------------------------------------------- sample-multi-bounded [90] 100.0% [96] 304(0.5%) 304(0.5%) for-loop ...rbie/no-dirty-bits/src/points.rkt:26:4 --------------------------------------------------------------------- ival-mult [88] 100.0% [97] 300(0.5%) 300(0.5%) classify-ival ...ty-bits/src/biginterval.rkt:310:0 --------------------------------------------------------------------- ival-sub [91] 25.5% bf* [94] 36.5% ival-add [89] 38.0% [98] 2452(3.8%) 0(0.0%) ??? ...-racket/utils/simple-result-arrow.rkt:39:12 bfadd [100] 100.0% --------------------------------------------------------------------- return/no-unsupplied [95] 100.0% [99] 308(0.5%) 308(0.5%) filter ...0/collects/racket/private/list.rkt:256:2 --------------------------------------------------------------------- ??? [98] 100.0% [100] 2452(3.8%) 322(0.5%) bfadd ...-lib/math/private/bigfloat/mpfr.rkt:821:4 ??? [101] 62.4% new-mpfr [102] 24.5% --------------------------------------------------------------------- ->flonum [87] 17.9% bfadd [100] 82.1% [101] 1864(2.9%) 1864(2.9%) ??? /opt/racket-7.0/collects/ffi/unsafe.rkt:898:4 --------------------------------------------------------------------- bfadd [100] 100.0% [102] 600(0.9%) 600(0.9%) new-mpfr ...b/math/private/bigfloat/mpfr.rkt:335:0 ---------------------------------------------------------------------