Profiling results ----------------- Total cpu time observed: 15796ms (out of 16020ms) Number of samples taken: 52 (once every 304ms) ======================================================================================== Caller Idx Total Self Name+src Local% ms(pct) ms(pct) Callee ======================================================================================== ??? [97] 100.0% [1] 15796(100.0%) 0(0.0%) run-improve47 ...rface-bugs/src/mainloop.rkt:345:0 for-loop [7] 96.4% simplify! [13] 3.6% ---------------------------------------------------------------------------------------- ??? [97] 100.0% [2] 15796(100.0%) 0(0.0%) profile-thunk16 ...e/pkgs/profile-lib/main.rkt:9:0 run [6] 100.0% ---------------------------------------------------------------------------------------- matcher [39] 100.0% [3] 1996(12.6%) 0(0.0%) ??? ...-interface-bugs/src/core/matcher.rkt:128:11 for-loop [8] 87.4% for-loop [9] 12.6% ---------------------------------------------------------------------------------------- hash-ref! [43] 100.0% [4] 270(1.7%) 0(0.0%) ??? ...ix-interface-bugs/src/core/taylor.rkt:68:15 hash-ref! [43] 66.7% ??? [35] 33.3% ---------------------------------------------------------------------------------------- ??? [35] 100.0% [5] 270(1.7%) 0(0.0%) approximate9 ...face-bugs/src/core/taylor.rkt:12:0 loop [10] 100.0% ---------------------------------------------------------------------------------------- profile-thunk16 [2] 100.0% [6] 15796(100.0%) 0(0.0%) run ...et-7.2/share/pkgs/profile-lib/main.rkt:39:2 ??? [97] 100.0% ---------------------------------------------------------------------------------------- run-improve47 [1] 100.0% [7] 15228(96.4%) 0(0.0%) for-loop ...-interface-bugs/src/mainloop.rkt:364:4 run-iter! [11] 100.0% ---------------------------------------------------------------------------------------- ??? [3] 100.0% [8] 1996(12.6%) 0(0.0%) for-loop ...rface-bugs/src/core/matcher.rkt:130:15 matcher [39] 100.0% ---------------------------------------------------------------------------------------- ??? [3] 100.0% [9] 604(3.8%) 0(0.0%) for-loop ...erface-bugs/src/core/matcher.rkt:104:4 foldl [12] 100.0% ---------------------------------------------------------------------------------------- approximate9 [5] 100.0% [10] 270(1.7%) 0(0.0%) loop ...ix-interface-bugs/src/core/taylor.rkt:87:4 hash-ref! [43] 100.0% ---------------------------------------------------------------------------------------- for-loop [7] 100.0% [11] 15228(96.4%) 0(0.0%) run-iter! ...interface-bugs/src/mainloop.rkt:326:0 simplify! [13] 81.8% gen-rewrites! [14] 13.1% finalize-iter! [16] 3.3% gen-series! [17] 1.8% ---------------------------------------------------------------------------------------- for-loop [9] 100.0% [12] 604(3.8%) 0(0.0%) foldl ....2/collects/racket/private/list.rkt:229:4 ??? [15] 100.0% ---------------------------------------------------------------------------------------- run-improve47 [1] 4.4% run-iter! [11] 95.6% [13] 13032(82.5%) 0(0.0%) simplify! ...interface-bugs/src/mainloop.rkt:223:0 ??? [18] 100.0% ---------------------------------------------------------------------------------------- run-iter! [11] 100.0% [14] 1996(12.6%) 0(0.0%) gen-rewrites! ...rface-bugs/src/mainloop.rkt:182:0 for-loop [19] 100.0% ---------------------------------------------------------------------------------------- foldl [12] 100.0% [15] 604(3.8%) 0(0.0%) ??? ...ix-interface-bugs/src/core/matcher.rkt:26:7 core651 [74] 100.0% ---------------------------------------------------------------------------------------- run-iter! [11] 100.0% [16] 498(3.2%) 0(0.0%) finalize-iter! ...face-bugs/src/mainloop.rkt:277:0 ??? [64] 100.0% ---------------------------------------------------------------------------------------- run-iter! [11] 100.0% [17] 270(1.7%) 0(0.0%) gen-series! ...terface-bugs/src/mainloop.rkt:159:0 for-loop [20] 100.0% ---------------------------------------------------------------------------------------- simplify! [13] 100.0% [18] 13032(82.5%) 0(0.0%) ??? ...x-interface-bugs/src/core/simplify.rkt:26:0 for-loop [21] 93.5% one-iter [25] 4.5% loop [24] 2.0% ---------------------------------------------------------------------------------------- gen-rewrites! [14] 100.0% [19] 1996(12.6%) 0(0.0%) for-loop ...interface-bugs/src/mainloop.rkt:190:11 rewrite-expression-head20 [22] 100.0% ---------------------------------------------------------------------------------------- gen-series! [17] 100.0% [20] 270(1.7%) 0(0.0%) for-loop ...-interface-bugs/src/mainloop.rkt:166:7 taylor-alt [23] 100.0% ---------------------------------------------------------------------------------------- ??? [18] 100.0% [21] 12182(77.1%) 0(0.0%) for-loop ...erface-bugs/src/core/simplify.rkt:35:2 one-iter [25] 100.0% ---------------------------------------------------------------------------------------- for-loop [19] 100.0% [22] 1996(12.6%) 0(0.0%) rewrite-expression-head20 ...core/matcher.rkt:86:0 rewriter [26] 100.0% ---------------------------------------------------------------------------------------- for-loop [20] 100.0% [23] 270(1.7%) 0(0.0%) taylor-alt ...nterface-bugs/src/mainloop.rkt:145:0 for-loop [27] 100.0% ---------------------------------------------------------------------------------------- ??? [18] 100.0% [24] 260(1.6%) 0(0.0%) loop ...nterface-bugs/src/core/extraction.rkt:25:2 for-loop [28] 100.0% ---------------------------------------------------------------------------------------- ??? [18] 4.6% for-loop [21] 95.4% [25] 12772(80.9%) 0(0.0%) one-iter ...erface-bugs/src/core/simplify.rkt:72:0 find-matches [29] 55.6% for-loop [30] 37.9% for-loop [33] 4.4% for-loop [34] 2.1% ---------------------------------------------------------------------------------------- rewrite-expression-head20 [22] 35.1% matcher [39] 64.9% [26] 1996(12.6%) 0(0.0%) rewriter ...terface-bugs/src/core/matcher.rkt:88:2 for-loop [31] 89.0% *rules* [32] 11.0% ---------------------------------------------------------------------------------------- taylor-alt [23] 100.0% [27] 270(1.7%) 0(0.0%) for-loop ...-interface-bugs/src/mainloop.rkt:151:6 ??? [35] 100.0% ---------------------------------------------------------------------------------------- loop [24] 100.0% [28] 260(1.6%) 0(0.0%) for-loop ...face-bugs/src/core/extraction.rkt:29:4 for-loop [36] 100.0% ---------------------------------------------------------------------------------------- one-iter [25] 100.0% [29] 7104(45.0%) 0(0.0%) find-matches ...ce-bugs/src/core/simplify.rkt:62:0 for-loop [37] 100.0% ---------------------------------------------------------------------------------------- one-iter [25] 100.0% [30] 4840(30.6%) 0(0.0%) for-loop ...erface-bugs/src/core/simplify.rkt:74:2 for-loop [38] 100.0% ---------------------------------------------------------------------------------------- rewriter [26] 100.0% [31] 1996(12.6%) 280(1.8%) for-loop ...terface-bugs/src/core/matcher.rkt:90:4 matcher [39] 88.5% for-loop [41] 8.7% ---------------------------------------------------------------------------------------- rewriter [26] 100.0% [32] 590(3.7%) 0(0.0%) *rules* ...terface-bugs/src/syntax/rules.rkt:666:0 for-loop [40] 100.0% ---------------------------------------------------------------------------------------- one-iter [25] 100.0% [33] 556(3.5%) 0(0.0%) for-loop ...erface-bugs/src/core/simplify.rkt:84:2 update-leader! [54] 100.0% ---------------------------------------------------------------------------------------- one-iter [25] 100.0% [34] 272(1.7%) 272(1.7%) for-loop ...erface-bugs/src/core/simplify.rkt:81:2 ---------------------------------------------------------------------------------------- ??? [4] 33.3% location-do [42] 33.3% for-loop [27] 33.3% [35] 270(1.7%) 0(0.0%) ??? ...tract/private/arrow-higher-order.rkt:360:33 location-do [42] 33.3% approximate9 [5] 33.3% hash-ref! [43] 33.3% ---------------------------------------------------------------------------------------- for-loop [28] 100.0% [36] 260(1.6%) 0(0.0%) for-loop ...ace-bugs/src/core/extraction.rkt:37:16 for-loop [44] 100.0% ---------------------------------------------------------------------------------------- for-loop [37] 50.0% find-matches [29] 50.0% [37] 7104(45.0%) 0(0.0%) for-loop ...erface-bugs/src/core/simplify.rkt:64:8 for-loop [37] 50.0% match-e [45] 50.0% ---------------------------------------------------------------------------------------- for-loop [30] 100.0% [38] 4840(30.6%) 0(0.0%) for-loop ...erface-bugs/src/core/simplify.rkt:77:4 merge-egraph-nodes! [46] 77.9% mk-enode-rec! [47] 17.0% dedup-children! [58] 5.1% ---------------------------------------------------------------------------------------- for-loop [8] 46.0% for-loop [31] 54.0% [39] 1996(12.6%) 0(0.0%) matcher ...terface-bugs/src/core/matcher.rkt:116:2 ??? [3] 54.0% rewriter [26] 46.0% ---------------------------------------------------------------------------------------- *rules* [32] 100.0% [40] 590(3.7%) 0(0.0%) for-loop ...fix-interface-bugs/src/common.rkt:74:9 ormap [48] 100.0% ---------------------------------------------------------------------------------------- for-loop [31] 100.0% [41] 522(3.3%) 0(0.0%) for-loop ...terface-bugs/src/core/matcher.rkt:97:8 fix-up-variables [49] 100.0% ---------------------------------------------------------------------------------------- ??? [35] 100.0% [42] 270(1.7%) 0(0.0%) location-do ...nterface-bugs/src/programs.rkt:64:0 ??? [35] 100.0% ---------------------------------------------------------------------------------------- ??? [51] 16.7% ??? [52] 16.7% ??? [35] 16.7% loop [10] 16.7% ??? [4] 33.3% [43] 270(1.7%) 0(0.0%) hash-ref! .../racket/private/more-scheme.rkt:376:2 ??? [4] 50.0% ??? [52] 16.7% ??? [51] 16.7% simplify [50] 16.7% ---------------------------------------------------------------------------------------- for-loop [36] 100.0% [44] 260(1.6%) 260(1.6%) for-loop ...ace-bugs/src/core/extraction.rkt:41:23 ---------------------------------------------------------------------------------------- for-loop [62] 37.1% for-loop [37] 62.9% [45] 7104(45.0%) 1488(9.4%) match-e ...interface-bugs/src/core/ematch.rkt:39:0 for-loop [53] 64.3% variable? [55] 7.9% ??? [64] 7.1% constant? [92] 4.2% ---------------------------------------------------------------------------------------- merge-egraph-nodes! [46] 19.8% for-loop [38] 80.2% [46] 3768(23.9%) 246(1.6%) merge-egraph-nodes! ...s/src/core/egraph.rkt:145:0 update-leader! [54] 36.8% loop! [65] 33.5% merge-egraph-nodes! [46] 19.8% dedup-children! [58] 3.4% ---------------------------------------------------------------------------------------- loop [56] 50.0% for-loop [38] 50.0% [47] 824(5.2%) 572(3.6%) mk-enode-rec! ...ce-bugs/src/core/egraph.rkt:117:0 loop [56] 50.0% hash-has-key? [61] 15.3% ---------------------------------------------------------------------------------------- for-loop [40] 100.0% [48] 590(3.7%) 304(1.9%) ormap ....2/collects/racket/private/map.rkt:141:13 flag-set? [59] 48.5% ---------------------------------------------------------------------------------------- for-loop [41] 100.0% [49] 522(3.3%) 0(0.0%) fix-up-variables ...ugs/src/core/matcher.rkt:109:2 pattern-match [57] 100.0% ---------------------------------------------------------------------------------------- hash-ref! [43] 100.0% [50] 270(1.7%) 0(0.0%) simplify ...nterface-bugs/src/core/reduce.rkt:16:0 parse-loop79 [60] 100.0% ---------------------------------------------------------------------------------------- hash-ref! [43] 100.0% [51] 270(1.7%) 0(0.0%) ??? ...x-interface-bugs/src/core/taylor.rkt:344:33 hash-ref! [43] 100.0% ---------------------------------------------------------------------------------------- hash-ref! [43] 100.0% [52] 270(1.7%) 0(0.0%) ??? ...ix-interface-bugs/src/core/taylor.rkt:45:15 hash-ref! [43] 100.0% ---------------------------------------------------------------------------------------- match-e [45] 100.0% [53] 5940(37.6%) 1418(9.0%) for-loop ...terface-bugs/src/core/ematch.rkt:52:11 for-loop [62] 76.3% do-curry [66] 4.8% procedure-reduce-keyword-arity-mask [69] 2.3% ---------------------------------------------------------------------------------------- for-loop [33] 26.9% merge-egraph-nodes! [46] 73.1% [54] 2066(13.1%) 0(0.0%) update-leader! ...e-bugs/src/core/egraph.rkt:213:0 for-loop [63] 87.3% for-loop [72] 12.7% ---------------------------------------------------------------------------------------- match-e [45] 100.0% [55] 1524(9.6%) 0(0.0%) variable? ...face-bugs/src/syntax/syntax.rkt:729:0 value? [98] 80.4% ??? [64] 19.6% ---------------------------------------------------------------------------------------- loop! [65] 3.5% loop [56] 34.2% mk-enode-rec! [47] 62.3% [56] 1322(8.4%) 0(0.0%) loop ...-7.2/collects/racket/private/map.rkt:40:19 mk-enode-rec! [47] 62.3% loop [56] 34.2% loop! [65] 3.5% ---------------------------------------------------------------------------------------- pattern-match [57] 23.8% fix-up-variables [49] 76.2% [57] 522(3.3%) 248(1.6%) pattern-match ...ce-bugs/src/core/matcher.rkt:30:0 for-loop [70] 52.5% pattern-match [57] 23.8% ---------------------------------------------------------------------------------------- for-loop [38] 49.2% merge-egraph-nodes! [46] 50.8% [58] 504(3.2%) 0(0.0%) dedup-children! ...e-bugs/src/core/enode.rkt:202:0 loop [67] 100.0% ---------------------------------------------------------------------------------------- ormap [48] 100.0% [59] 286(1.8%) 0(0.0%) flag-set? ...ix-interface-bugs/src/config.rkt:28:0 return/no-unsupplied [68] 100.0% ---------------------------------------------------------------------------------------- simplify [50] 100.0% [60] 270(1.7%) 0(0.0%) parse-loop79 ...s/racket/match/compiler.rkt:418:15 eval-const-expr [71] 100.0% ---------------------------------------------------------------------------------------- mk-enode-rec! [47] 100.0% [61] 252(1.6%) 252(1.6%) hash-has-key? ...ket/private/more-scheme.rkt:371:2 ---------------------------------------------------------------------------------------- for-loop [53] 100.0% [62] 5388(34.1%) 270(1.7%) for-loop ...terface-bugs/src/core/ematch.rkt:58:37 match-e [45] 90.3% ??? [80] 4.7% ---------------------------------------------------------------------------------------- update-leader! [54] 100.0% [63] 1804(11.4%) 0(0.0%) for-loop ...terface-bugs/src/core/egraph.rkt:218:6 for-loop [73] 86.0% hash-update! [82] 14.0% ---------------------------------------------------------------------------------------- variable? [55] 16.5% finalize-iter! [16] 27.6% match-e [45] 55.9% [64] 1804(11.4%) 298(1.9%) ??? ...contract/private/arrow-val-first.rkt:390:18 ??? [83] 55.9% atab-add-altns [79] 14.0% for-loop [81] 13.6% ---------------------------------------------------------------------------------------- loop [56] 16.5% merge-egraph-nodes! [46] 83.5% [65] 1756(11.1%) 986(6.2%) loop! ...x-interface-bugs/src/core/enode.rkt:194:2 loop [56] 16.5% custom-set-union [77] 15.5% set [75] 11.8% ---------------------------------------------------------------------------------------- for-loop [53] 100.0% [66] 568(3.6%) 568(3.6%) do-curry ...-7.2/collects/racket/function.rkt:71:2 ---------------------------------------------------------------------------------------- dedup-children! [58] 20.0% loop [67] 80.0% [67] 504(3.2%) 504(3.2%) loop ...racket-7.2/collects/racket/list.rkt:434:17 loop [67] 80.0% ---------------------------------------------------------------------------------------- flag-set? [59] 100.0% [68] 286(1.8%) 0(0.0%) return/no-unsupplied ...ct/private/arr-i.rkt:542:0 filter [76] 100.0% ---------------------------------------------------------------------------------------- for-loop [53] 100.0% [69] 276(1.7%) 276(1.7%) procedure-reduce-keyword-arity-mask ....rkt:1562:4 ---------------------------------------------------------------------------------------- pattern-match [57] 100.0% [70] 274(1.7%) 0(0.0%) for-loop ...terface-bugs/src/core/matcher.rkt:27:9 core651 [74] 100.0% ---------------------------------------------------------------------------------------- parse-loop79 [60] 100.0% [71] 270(1.7%) 0(0.0%) eval-const-expr ...ace-bugs/src/programs.rkt:118:0 eval-prog [78] 100.0% ---------------------------------------------------------------------------------------- update-leader! [54] 100.0% [72] 262(1.7%) 262(1.7%) for-loop ...terface-bugs/src/core/egraph.rkt:228:6 ---------------------------------------------------------------------------------------- for-loop [63] 100.0% [73] 1552(9.8%) 0(0.0%) for-loop ...terface-bugs/src/core/egraph.rkt:219:8 hash-update! [82] 100.0% ---------------------------------------------------------------------------------------- for-loop [70] 31.2% ??? [15] 68.8% [74] 878(5.6%) 0(0.0%) core651 ...acket/contract/private/arr-i.rkt:929:19 ??? [83] 34.6% successfully-got-the-right-kind-of-function [84] 34.2% un-dep/maybe-chaperone [85] 31.2% ---------------------------------------------------------------------------------------- loop! [65] 100.0% [75] 498(3.2%) 498(3.2%) set ...collects/racket/private/set-types.rkt:981:0 ---------------------------------------------------------------------------------------- return/no-unsupplied [68] 100.0% [76] 286(1.8%) 286(1.8%) filter ...2/collects/racket/private/list.rkt:256:2 ---------------------------------------------------------------------------------------- loop! [65] 100.0% [77] 272(1.7%) 0(0.0%) custom-set-union ...et/private/set-types.rkt:168:0 for-loop [86] 100.0% ---------------------------------------------------------------------------------------- eval-const-expr [71] 100.0% [78] 270(1.7%) 0(0.0%) eval-prog ...-interface-bugs/src/programs.rkt:83:0 eval [87] 100.0% ---------------------------------------------------------------------------------------- ??? [64] 100.0% [79] 252(1.6%) 0(0.0%) atab-add-altns ...bugs/src/core/alt-table.rkt:49:0 atab-add-altn [88] 100.0% ---------------------------------------------------------------------------------------- for-loop [62] 100.0% [80] 252(1.6%) 0(0.0%) ??? ...fix-interface-bugs/src/core/ematch.rkt:43:5 for-loop [89] 100.0% ---------------------------------------------------------------------------------------- ??? [64] 100.0% [81] 246(1.6%) 0(0.0%) for-loop ...rface-bugs/src/core/alt-table.rkt:55:2 errors [90] 100.0% ---------------------------------------------------------------------------------------- for-loop [63] 14.0% for-loop [73] 86.0% [82] 1804(11.4%) 0(0.0%) hash-update! ...cket/private/more-scheme.rkt:365:4 ??? [91] 100.0% ---------------------------------------------------------------------------------------- core651 [74] 23.2% ??? [64] 76.8% [83] 1312(8.3%) 1008(6.4%) ??? ...ects/racket/contract/private/guts.rkt:772:8 ??? [93] 23.2% ---------------------------------------------------------------------------------------- core651 [74] 100.0% [84] 300(1.9%) 300(1.9%) successfully-got-the-right-kind-of-function ...1:4 ---------------------------------------------------------------------------------------- core651 [74] 100.0% [85] 274(1.7%) 274(1.7%) un-dep/maybe-chaperone ...private/arr-i.rkt:1108:2 ---------------------------------------------------------------------------------------- custom-set-union [77] 100.0% [86] 272(1.7%) 272(1.7%) for-loop ...cts/racket/private/set-types.rkt:174:3 ---------------------------------------------------------------------------------------- eval-prog [78] 100.0% [87] 270(1.7%) 0(0.0%) eval (unknown source) namespace-syntax-introduce3 [94] 100.0% ---------------------------------------------------------------------------------------- atab-add-altns [79] 100.0% [88] 252(1.6%) 0(0.0%) atab-add-altn ...bugs/src/core/alt-table.rkt:203:0 override-at-pnts [95] 100.0% ---------------------------------------------------------------------------------------- ??? [80] 100.0% [89] 252(1.6%) 0(0.0%) for-loop ...nterface-bugs/src/core/ematch.rkt:44:7 constant? [92] 100.0% ---------------------------------------------------------------------------------------- for-loop [81] 100.0% [90] 246(1.6%) 0(0.0%) errors .../fix-interface-bugs/src/points.rkt:216:0 for-loop [96] 100.0% ---------------------------------------------------------------------------------------- hash-update! [82] 100.0% [91] 1804(11.4%) 278(1.8%) ??? ...x-interface-bugs/src/core/egraph.rkt:221:24 for-loop [99] 70.8% update-en-expr [102] 13.7% ---------------------------------------------------------------------------------------- for-loop [89] 45.7% match-e [45] 54.3% [92] 552(3.5%) 0(0.0%) constant? ...face-bugs/src/syntax/syntax.rkt:726:0 value? [98] 100.0% ---------------------------------------------------------------------------------------- ??? [83] 100.0% [93] 304(1.9%) 304(1.9%) ??? /opt/racket-7.2/collects/racket/dict.rkt:11:8 ---------------------------------------------------------------------------------------- eval [87] 100.0% [94] 270(1.7%) 0(0.0%) namespace-syntax-introduce3 (unknown source) free-identifier=? [100] 100.0% ---------------------------------------------------------------------------------------- atab-add-altn [88] 100.0% [95] 252(1.6%) 0(0.0%) override-at-pnts ...s/src/core/alt-table.rkt:138:0 for-loop [101] 100.0% ---------------------------------------------------------------------------------------- errors [90] 100.0% [96] 246(1.6%) 0(0.0%) for-loop ...ix-interface-bugs/src/points.rkt:218:2 ??? [97] 100.0% ---------------------------------------------------------------------------------------- for-loop [96] 0.5% run [6] 49.7% [97] 15796(100.0%) 0(0.0%) ??? ...lects/racket/private/more-scheme.rkt:261:28 profile-thunk16 [2] 49.7% run-improve47 [1] 49.7% ??? [104] 0.5% ---------------------------------------------------------------------------------------- constant? [92] 31.0% variable? [55] 69.0% [98] 1778(11.3%) 1778(11.3%) value? ...interface-bugs/src/syntax/types.rkt:18:0 ---------------------------------------------------------------------------------------- ??? [91] 100.0% [99] 1278(8.1%) 1278(8.1%) for-loop ...erface-bugs/src/core/egraph.rkt:222:26 ---------------------------------------------------------------------------------------- namespace-syntax-introduce3 [94] 100.0% [100] 270(1.7%) 0(0.0%) free-identifier=? (unknown source) resolve+shift28 [103] 100.0% ---------------------------------------------------------------------------------------- override-at-pnts [95] 100.0% [101] 252(1.6%) 252(1.6%) for-loop ...ace-bugs/src/core/alt-table.rkt:139:22 ---------------------------------------------------------------------------------------- ??? [91] 100.0% [102] 248(1.6%) 248(1.6%) update-en-expr ...e-bugs/src/core/egraph.rkt:207:0 ---------------------------------------------------------------------------------------- free-identifier=? [100] 100.0% [103] 270(1.7%) 270(1.7%) resolve+shift28 (unknown source) ---------------------------------------------------------------------------------------- ??? [97] 100.0% [104] 246(1.6%) 0(0.0%) ??? ...e/fix-interface-bugs/src/programs.rkt:115:2 ??? [105] 100.0% ---------------------------------------------------------------------------------------- ??? [104] 100.0% [105] 246(1.6%) 246(1.6%) ??? ...cket-7.2/collects/racket/function.rkt:93:12 ----------------------------------------------------------------------------------------