Profiling results ----------------- Total cpu time observed: 1251592ms (out of 1255052ms) Number of samples taken: 3634 (once every 344ms) (Hiding functions with self<1.0% and local<2.0%: 27 of 295 hidden) ========================================================================================== Caller Idx Total Self Name+src Local% ms(pct) ms(pct) Callee ========================================================================================== ??? [87] 100.0% [1] 992864(79.3%) 0(0.0%) profile-thunk16 ...t/pkgs/profile-lib/main.rkt:9:0 run [21] 100.0% ------------------------------------------------------------------------------------------ ??? [87] 100.0% [2] 969086(77.4%) 0(0.0%) run-improve50 ...f-of-prods/src/mainloop.rkt:234:0 for-loop [22] 96.1% get-final-combination [27] 3.5% setup-alt-simplified [37] 0.3% loop [101] 0.1% ??? [132] 0.0% ------------------------------------------------------------------------------------------ ??? [192] 100.0% [3] 626700(50.1%) 328(0.0%) iterate-egraph!13 ...s/src/core/simplify.rkt:102:0 one-iter [23] 97.2% map-enodes [33] 2.7% ------------------------------------------------------------------------------------------ ??? [192] 100.0% [4] 257316(20.6%) 0(0.0%) loop .../diff-of-prods/src/core/simplify.rkt:215:2 pass [24] 100.0% ------------------------------------------------------------------------------------------ rewriter [97] 100.0% [5] 68644(5.5%) 3526(0.3%) *rules* ...iff-of-prods/src/syntax/rules.rkt:493:0 for-loop [25] 89.9% ormap [48] 2.9% flag-set? [67] 0.5% curried [210] 0.5% list-member? [176] 0.5% dict? [262] 0.5% ------------------------------------------------------------------------------------------ ??? [166] 100.0% [6] 68008(5.4%) 0(0.0%) approximate9 ...-of-prods/src/core/taylor.rkt:12:0 loop [26] 88.5% f137 [187] 10.5% taylor-exp [38] 1.0% ------------------------------------------------------------------------------------------ hash-ref! [179] 100.0% [7] 22748(1.8%) 0(0.0%) ??? ...ie/diff-of-prods/src/core/taylor.rkt:392:23 for-loop [30] 98.6% simplify [182] 1.4% ------------------------------------------------------------------------------------------ hash-ref! [179] 100.0% [8] 22604(1.8%) 0(0.0%) ??? ...ie/diff-of-prods/src/core/taylor.rkt:285:26 for-loop [29] 100.0% ------------------------------------------------------------------------------------------ hash-ref! [179] 100.0% [9] 18038(1.4%) 0(0.0%) ??? ...ie/diff-of-prods/src/core/taylor.rkt:483:23 for-loop [31] 100.0% ------------------------------------------------------------------------------------------ hash-ref! [179] 100.0% [10] 17542(1.4%) 0(0.0%) ??? ...ie/diff-of-prods/src/core/taylor.rkt:295:23 for-loop [32] 100.0% ------------------------------------------------------------------------------------------ map-enodes [33] 4.1% loop [193] 95.9% [11] 16104(1.3%) 1022(0.1%) for-loop ...f-of-prods/src/core/simplify.rkt:173:2 eval-const-expr [34] 46.6% setfindf [35] 32.1% compose [196] 10.7% ??? [166] 4.3% ------------------------------------------------------------------------------------------ parse-loop12 [169] 100.0% [12] 12142(1.0%) 0(0.0%) for-loop ...iff-of-prods/src/core/reduce.rkt:99:13 make-multiplication-node [28] 97.3% f137 [187] 2.7% ------------------------------------------------------------------------------------------ matcher [118] 100.0% [13] 5498(0.4%) 948(0.1%) for-loop ...ff-of-prods/src/core/matcher.rkt:159:6 pattern-substitute [36] 50.5% pattern-match [54] 32.3% ------------------------------------------------------------------------------------------ copying-mergesort [260] 100.0% [14] 4108(0.3%) 0(0.0%) jloop ...t/collects/racket/private/sort.rkt:121:23 ??? [162] 91.9% ??? [166] 8.1% ------------------------------------------------------------------------------------------ f137 [187] 100.0% [15] 3394(0.3%) 0(0.0%) loop ...ie/diff-of-prods/src/core/taylor.rkt:262:2 hash-ref! [179] 100.0% ------------------------------------------------------------------------------------------ f137 [187] 100.0% [16] 2426(0.2%) 1020(0.1%) combine-mterms ...-prods/src/core/reduce.rkt:191:0 for-loop [40] 58.0% ------------------------------------------------------------------------------------------ hash-ref! [179] 100.0% [17] 1998(0.2%) 0(0.0%) ??? ...ie/diff-of-prods/src/core/taylor.rkt:322:33 for-loop [39] 100.0% ------------------------------------------------------------------------------------------ parse-loop12 [169] 23.4% map [129] 76.6% [18] 1306(0.1%) 0(0.0%) ??? ...rbie/diff-of-prods/src/core/reduce.rkt:61:5 for-loop [41] 100.0% ------------------------------------------------------------------------------------------ hash-ref! [179] 100.0% [19] 336(0.0%) 0(0.0%) ??? ...ie/diff-of-prods/src/core/taylor.rkt:338:33 for-loop [42] 100.0% ------------------------------------------------------------------------------------------ f137 [187] 100.0% [20] 330(0.0%) 0(0.0%) exprs-to-branch-on ...ds/src/core/regimes.rkt:55:0 all-critical-subexpressions [43] 100.0% ------------------------------------------------------------------------------------------ profile-thunk16 [1] 100.0% [21] 993204(79.4%) 0(0.0%) run ...share/racket/pkgs/profile-lib/main.rkt:39:2 ??? [87] 100.0% ------------------------------------------------------------------------------------------ run-improve50 [2] 100.0% [22] 931234(74.4%) 0(0.0%) for-loop .../diff-of-prods/src/mainloop.rkt:249:10 run-iter! [44] 100.0% ------------------------------------------------------------------------------------------ iterate-egraph!13 [3] 100.0% [23] 609284(48.7%) 7296(0.6%) one-iter ...f-of-prods/src/core/simplify.rkt:113:0 loop [45] 77.4% for-loop [47] 20.1% apply-match [62] 1.1% ------------------------------------------------------------------------------------------ loop [4] 100.0% [24] 257316(20.6%) 360(0.0%) pass .../diff-of-prods/src/core/simplify.rkt:205:2 for-loop [46] 99.6% ------------------------------------------------------------------------------------------ merge-egraph-nodes! [90] 2.0% *rules* [5] 97.5% [25] 63314(5.1%) 18728(1.5%) for-loop ...rbie/diff-of-prods/src/common.rkt:94:9 ormap [48] 55.3% flag-set? [67] 13.5% list-member? [176] 0.6% update-en-expr [221] 0.5% ------------------------------------------------------------------------------------------ approximate9 [6] 100.0% [26] 60200(4.8%) 0(0.0%) loop ...bie/diff-of-prods/src/core/taylor.rkt:86:4 ??? [166] 100.0% ------------------------------------------------------------------------------------------ run-improve50 [2] 100.0% [27] 33534(2.7%) 0(0.0%) get-final-combination ...ds/src/mainloop.rkt:264:0 split-table [50] 96.8% extract-alt [57] 2.2% ??? [166] 1.1% ------------------------------------------------------------------------------------------ map [129] 31.0% parse-loop12 [169] 33.6% for-loop [12] 35.4% [28] 33386(2.7%) 0(0.0%) make-multiplication-node .../core/reduce.rkt:230:0 make-multiplication-subnode [49] 100.0% ------------------------------------------------------------------------------------------ ??? [8] 100.0% [29] 22604(1.8%) 0(0.0%) for-loop ...ff-of-prods/src/core/taylor.rkt:285:52 ??? [52] 63.1% hash-ref! [179] 35.4% simplify [182] 1.5% ------------------------------------------------------------------------------------------ ??? [7] 100.0% [30] 22424(1.8%) 0(0.0%) for-loop ...ff-of-prods/src/core/taylor.rkt:396:33 for-loop [51] 100.0% ------------------------------------------------------------------------------------------ ??? [9] 100.0% [31] 18038(1.4%) 0(0.0%) for-loop ...ff-of-prods/src/core/taylor.rkt:487:35 parse-loop12 [169] 100.0% ------------------------------------------------------------------------------------------ ??? [10] 100.0% [32] 17542(1.4%) 0(0.0%) for-loop ...ff-of-prods/src/core/taylor.rkt:298:27 hash-ref! [179] 100.0% ------------------------------------------------------------------------------------------ iterate-egraph!13 [3] 100.0% [33] 17088(1.4%) 0(0.0%) map-enodes ...f-of-prods/src/core/egraph.rkt:139:0 loop [193] 94.2% for-loop [11] 3.9% hash-keys [59] 1.9% ------------------------------------------------------------------------------------------ for-loop [11] 100.0% [34] 7498(0.6%) 2080(0.2%) eval-const-expr ...of-prods/src/programs.rkt:166:0 f137 [187] 64.0% ??? [58] 8.3% ------------------------------------------------------------------------------------------ for-loop [11] 100.0% [35] 5162(0.4%) 3088(0.2%) setfindf ...bie/diff-of-prods/src/common.rkt:179:0 for-loop [56] 40.2% ------------------------------------------------------------------------------------------ for-loop [13] 35.7% pattern-substitute [36] 64.3% [36] 2776(0.2%) 1766(0.1%) pattern-substitute ...ds/src/core/matcher.rkt:73:0 pattern-substitute [36] 64.3% variable? [53] 7.3% ??? [132] 2.9% ------------------------------------------------------------------------------------------ run-improve50 [2] 100.0% [37] 2578(0.2%) 0(0.0%) setup-alt-simplified ...of-prods/src/glue.rkt:49:0 simplify-alt [55] 100.0% ------------------------------------------------------------------------------------------ approximate9 [6] 28.7% f137 [187] 71.3% [38] 2406(0.2%) 0(0.0%) taylor-exp ...f-of-prods/src/core/taylor.rkt:386:0 simplify [182] 100.0% ------------------------------------------------------------------------------------------ ??? [17] 100.0% [39] 1998(0.2%) 326(0.0%) for-loop ...ff-of-prods/src/core/taylor.rkt:324:46 hash-ref! [179] 83.7% ------------------------------------------------------------------------------------------ combine-mterms [16] 100.0% [40] 1406(0.1%) 0(0.0%) for-loop ...iff-of-prods/src/core/reduce.rkt:195:5 hash-ref! [179] 100.0% ------------------------------------------------------------------------------------------ ??? [18] 100.0% [41] 1306(0.1%) 360(0.0%) for-loop ...diff-of-prods/src/core/reduce.rkt:62:7 pattern-match [54] 72.4% ------------------------------------------------------------------------------------------ ??? [19] 100.0% [42] 336(0.0%) 0(0.0%) for-loop ...ff-of-prods/src/core/taylor.rkt:341:46 hash-ref! [179] 100.0% ------------------------------------------------------------------------------------------ exprs-to-branch-on [20] 100.0% [43] 330(0.0%) 0(0.0%) all-critical-subexpressions ...re/regimes.rkt:71:0 for-loop [60] 100.0% ------------------------------------------------------------------------------------------ for-loop [22] 100.0% [44] 931234(74.4%) 0(0.0%) run-iter! .../diff-of-prods/src/mainloop.rkt:215:0 simplify! [61] 69.8% gen-rewrites! [64] 19.4% gen-series! [65] 7.5% finalize-iter! [69] 3.1% ------------------------------------------------------------------------------------------ f137 [187] 0.7% one-iter [23] 99.3% [45] 474490(37.9%) 1346(0.1%) loop ...cket/collects/racket/private/map.rkt:52:19 apply-match [62] 99.0% f137 [187] 0.7% ------------------------------------------------------------------------------------------ pass [24] 100.0% [46] 256274(20.5%) 1600(0.1%) for-loop ...-of-prods/src/core/simplify.rkt:208:29 argmin [63] 75.2% loop [66] 18.7% for-loop [70] 4.5% make-sequence [226] 0.9% filter [224] 0.1% ------------------------------------------------------------------------------------------ for-loop [47] 49.3% one-iter [23] 50.7% [47] 122164(9.8%) 23050(1.8%) for-loop ...-of-prods/src/core/simplify.rkt:123:12 for-loop [47] 49.3% match-e [81] 40.6% ------------------------------------------------------------------------------------------ *rules* [5] 5.4% for-loop [25] 94.6% [48] 37030(3.0%) 6488(0.5%) ormap ...et/collects/racket/private/map.rkt:105:13 flag-set? [67] 76.1% curried [210] 3.6% list-member? [176] 2.8% ------------------------------------------------------------------------------------------ make-multiplication-node [28] 100.0% [49] 33386(2.7%) 1048(0.1%) make-multiplication-subnode ...re/reduce.rkt:240:0 for-loop [68] 93.8% group-by68 [73] 3.1% ------------------------------------------------------------------------------------------ get-final-combination [27] 100.0% [50] 32450(2.6%) 0(0.0%) split-table ...ie/diff-of-prods/src/glue.rkt:162:0 f137 [187] 100.0% ------------------------------------------------------------------------------------------ for-loop [30] 100.0% [51] 22424(1.8%) 0(0.0%) for-loop ...ff-of-prods/src/core/taylor.rkt:398:39 hash-ref! [179] 99.2% simplify [182] 0.8% ------------------------------------------------------------------------------------------ for-loop [29] 100.0% [52] 18218(1.5%) 0(0.0%) ??? ...ie/diff-of-prods/src/core/taylor.rkt:288:19 hash-ref! [179] 100.0% ------------------------------------------------------------------------------------------ pattern-match [54] 2.3% pattern-substitute [36] 4.4% matcher [118] 6.9% substitute-e [89] 13.1% match-e [81] 73.3% [53] 15660(1.3%) 0(0.0%) variable? ...-of-prods/src/syntax/syntax.rkt:567:0 ??? [132] 100.0% ------------------------------------------------------------------------------------------ for-loop [41] 23.1% for-loop [71] 30.9% for-loop [13] 46.0% [54] 2720(0.2%) 728(0.1%) pattern-match ...f-prods/src/core/matcher.rkt:48:0 for-loop [71] 42.3% ??? [132] 24.4% variable? [53] 6.5% ------------------------------------------------------------------------------------------ setup-alt-simplified [37] 100.0% [55] 2578(0.2%) 0(0.0%) simplify-alt ...ie/diff-of-prods/src/glue.rkt:76:0 ??? [192] 100.0% ------------------------------------------------------------------------------------------ setfindf [35] 100.0% [56] 2074(0.2%) 2074(0.2%) for-loop ...bie/diff-of-prods/src/common.rkt:180:2 ------------------------------------------------------------------------------------------ get-final-combination [27] 100.0% [57] 722(0.1%) 0(0.0%) extract-alt ...bie/diff-of-prods/src/glue.rkt:55:0 loop [72] 100.0% ------------------------------------------------------------------------------------------ eval-const-expr [34] 100.0% [58] 622(0.0%) 0(0.0%) ??? ...cket/collects/racket/private/kw.rkt:1633:36 unpack245 [74] 100.0% ------------------------------------------------------------------------------------------ map-enodes [33] 100.0% [59] 332(0.0%) 0(0.0%) hash-keys .../collects/racket/private/hash.rkt:2:2 loop [75] 100.0% ------------------------------------------------------------------------------------------ all-critical-subexpressions [43] 100.0% [60] 330(0.0%) 0(0.0%) for-loop ...iff-of-prods/src/core/regimes.rkt:75:2 ??? [76] 100.0% ------------------------------------------------------------------------------------------ run-iter! [44] 100.0% [61] 649574(51.9%) 0(0.0%) simplify! .../diff-of-prods/src/mainloop.rkt:155:0 for-loop [77] 100.0% ------------------------------------------------------------------------------------------ one-iter [23] 1.4% loop [45] 98.6% [62] 476748(38.1%) 1648(0.1%) apply-match ...f-prods/src/core/simplify.rkt:130:2 for-loop [78] 88.2% match-e [81] 9.1% update-leader! [100] 1.3% reduce-to-single! [85] 1.0% ------------------------------------------------------------------------------------------ for-loop [46] 100.0% [63] 192654(15.4%) 328(0.0%) argmin ...re/racket/collects/racket/list.rkt:743:0 for-loop [79] 88.3% expression-cost [83] 11.5% ------------------------------------------------------------------------------------------ run-iter! [44] 100.0% [64] 181062(14.5%) 0(0.0%) gen-rewrites! ...f-of-prods/src/mainloop.rkt:142:0 for-loop [80] 100.0% ------------------------------------------------------------------------------------------ run-iter! [44] 100.0% [65] 69660(5.6%) 0(0.0%) gen-series! ...iff-of-prods/src/mainloop.rkt:129:0 for-loop [82] 100.0% ------------------------------------------------------------------------------------------ for-loop [46] 100.0% [66] 47818(3.8%) 354(0.0%) loop ...hare/racket/collects/racket/list.rkt:729:4 for-loop [79] 84.4% expression-cost [83] 14.8% ------------------------------------------------------------------------------------------ *rules* [5] 1.0% for-loop [25] 23.1% ormap [48] 76.0% [67] 37090(3.0%) 11648(0.9%) flag-set? ...bie/diff-of-prods/src/config.rkt:32:0 ??? [204] 34.6% return/no-unsupplied [206] 34.0% ------------------------------------------------------------------------------------------ make-multiplication-subnode [49] 100.0% [68] 31310(2.5%) 0(0.0%) for-loop ...iff-of-prods/src/core/reduce.rkt:242:3 mterm->expr [93] 82.3% make-multiplication-subsubsubnode [84] 15.6% compose [196] 1.2% map [129] 0.9% ------------------------------------------------------------------------------------------ run-iter! [44] 100.0% [69] 28574(2.3%) 0(0.0%) finalize-iter! ...-of-prods/src/mainloop.rkt:169:0 ??? [132] 100.0% ------------------------------------------------------------------------------------------ for-loop [46] 100.0% [70] 11478(0.9%) 11478(0.9%) for-loop ...-of-prods/src/core/simplify.rkt:195:13 ------------------------------------------------------------------------------------------ pattern-match [54] 100.0% [71] 1992(0.2%) 310(0.0%) for-loop ...iff-of-prods/src/core/matcher.rkt:66:9 pattern-match [54] 84.4% ------------------------------------------------------------------------------------------ extract-alt [57] 41.3% best-alt [174] 58.7% [72] 1748(0.1%) 0(0.0%) loop .../herbie/diff-of-prods/src/common.rkt:146:2 composed [195] 100.0% ------------------------------------------------------------------------------------------ make-multiplication-subnode [49] 100.0% [73] 1028(0.1%) 1028(0.1%) group-by68 ...acket/collects/racket/list.rkt:749:0 ------------------------------------------------------------------------------------------ ??? [58] 100.0% [74] 622(0.0%) 0(0.0%) unpack245 ...private/arrow-higher-order.rkt:354:44 maybe-cons-kwd [86] 100.0% ------------------------------------------------------------------------------------------ hash-keys [59] 3.7% loop [75] 96.3% [75] 332(0.0%) 332(0.0%) loop ...acket/collects/racket/private/hash.rkt:3:4 loop [75] 96.3% ------------------------------------------------------------------------------------------ for-loop [60] 100.0% [76] 330(0.0%) 0(0.0%) ??? ...tract/private/arrow-higher-order.rkt:346:33 f137 [187] 100.0% ------------------------------------------------------------------------------------------ simplify! [61] 98.0% [77] 663144(53.0%) 0(0.0%) for-loop ...e/diff-of-prods/src/mainloop.rkt:159:6 ??? [87] 100.0% ------------------------------------------------------------------------------------------ apply-match [62] 100.0% [78] 420404(33.6%) 1354(0.1%) for-loop ...-of-prods/src/core/simplify.rkt:145:10 mk-enode! [96] 35.5% substitute-e [89] 28.4% merge-egraph-nodes! [90] 23.6% loop! [203] 10.0% list-member? [176] 2.2% ------------------------------------------------------------------------------------------ loop [66] 19.2% argmin [63] 80.8% [79] 210580(16.8%) 6798(0.5%) for-loop ...e/diff-of-prods/src/programs.rkt:199:2 ??? [192] 68.9% ...prods/src/common.rkt:47:2 [133] 25.7% ??? [131] 2.2% ------------------------------------------------------------------------------------------ gen-rewrites! [64] 100.0% [80] 181062(14.5%) 0(0.0%) for-loop .../diff-of-prods/src/mainloop.rkt:147:11 ??? [88] 100.0% ------------------------------------------------------------------------------------------ apply-match [62] 17.7% for-loop [98] 28.1% for-loop [47] 54.1% [81] 142596(11.4%) 48634(3.9%) match-e .../diff-of-prods/src/core/ematch.rkt:46:0 for-loop [91] 44.1% for-loop [98] 9.6% ??? [132] 7.7% list-cartesian-product [102] 3.9% variable? [53] 3.3% loop [193] 1.5% custom-in-set [257] 0.5% ------------------------------------------------------------------------------------------ gen-series! [65] 100.0% [82] 69660(5.6%) 0(0.0%) for-loop ...e/diff-of-prods/src/mainloop.rkt:135:7 taylor-alt [92] 100.0% ------------------------------------------------------------------------------------------ loop [66] 24.2% argmin [63] 75.8% [83] 29210(2.3%) 334(0.0%) expression-cost ...of-prods/src/programs.rkt:198:0 compile [94] 98.9% ------------------------------------------------------------------------------------------ for-loop [68] 100.0% [84] 4876(0.4%) 0(0.0%) make-multiplication-subsubsubnode ...uce.rkt:262:0 mterm->expr [93] 100.0% ------------------------------------------------------------------------------------------ apply-match [62] 100.0% [85] 4780(0.4%) 2030(0.2%) reduce-to-single! ...ods/src/core/egraph.rkt:324:0 for-loop [95] 50.5% make-sequence [226] 7.0% ------------------------------------------------------------------------------------------ unpack245 [74] 100.0% [86] 622(0.0%) 0(0.0%) maybe-cons-kwd ...ate/arrow-higher-order.rkt:498:0 arrow-higher-order:lnp [228] 100.0% ------------------------------------------------------------------------------------------ for-loop [77] 18.8% run [21] 31.7% [87] 1226192(98.0%) 0(0.0%) ??? ...lects/racket/private/more-scheme.rkt:261:28 ??? [192] 36.4% profile-thunk16 [1] 31.7% run-improve50 [2] 30.8% loop [101] 1.1% ------------------------------------------------------------------------------------------ for-loop [80] 100.0% [88] 181062(14.5%) 0(0.0%) ??? ...rbie/diff-of-prods/src/alternative.rkt:88:0 rewriter [97] 100.0% ------------------------------------------------------------------------------------------ substitute-e [89] 3.6% for-loop [78] 96.4% [89] 119330(9.5%) 3818(0.3%) substitute-e ...-of-prods/src/core/ematch.rkt:71:0 mk-enode! [96] 91.7% substitute-e [89] 3.6% ??? [132] 1.5% variable? [53] 0.8% ------------------------------------------------------------------------------------------ for-loop [104] 3.8% merge-egraph-nodes! [90] 4.6% for-loop [78] 91.7% [90] 99148(7.9%) 4464(0.4%) merge-egraph-nodes! ...s/src/core/egraph.rkt:152:0 update-leader! [100] 58.3% for-loop [103] 15.6% loop! [203] 5.9% for-loop [104] 5.1% merge-egraph-nodes! [90] 4.6% enode-merge! [105] 4.5% for-loop [25] 1.3% make-sequence [226] 0.5% ------------------------------------------------------------------------------------------ match-e [81] 100.0% [91] 85268(6.8%) 27464(2.2%) for-loop ...iff-of-prods/src/core/ematch.rkt:59:11 for-loop [98] 61.8% list-cartesian-product [102] 8.5% loop [193] 1.3% foldl [212] 0.6% curried [210] 0.4% filter [224] 0.4% ------------------------------------------------------------------------------------------ for-loop [82] 100.0% [92] 69660(5.6%) 0(0.0%) taylor-alt ...bie/diff-of-prods/src/glue.rkt:134:0 for-loop [99] 99.5% expression->type [108] 0.5% ------------------------------------------------------------------------------------------ make-multiplication-subsubsubnode [84] 15.9% for-loop [68] 84.1% [93] 30652(2.4%) 0(0.0%) mterm->expr ...-of-prods/src/core/reduce.rkt:270:0 expression->type [108] 75.3% f137 [187] 24.7% ------------------------------------------------------------------------------------------ expression-cost [83] 100.0% [94] 28876(2.3%) 0(0.0%) compile ...ie/diff-of-prods/src/programs.rkt:175:0 hash-ref! [179] 100.0% ------------------------------------------------------------------------------------------ reduce-to-single! [85] 100.0% [95] 2414(0.2%) 2414(0.2%) for-loop ...iff-of-prods/src/core/egraph.rkt:325:8 ------------------------------------------------------------------------------------------ mk-egraph [208] 0.2% expr->enode [225] 2.3% substitute-e [89] 41.2% for-loop [78] 56.3% [96] 265420(21.2%) 20930(1.7%) mk-enode! ...ff-of-prods/src/core/egraph.rkt:101:0 new-enode [106] 89.9% hash-has-key? [138] 1.3% ------------------------------------------------------------------------------------------ ??? [88] 10.5% matcher [118] 89.5% [97] 181062(14.5%) 11610(0.9%) rewriter ...ff-of-prods/src/core/matcher.rkt:131:2 for-loop [107] 90.3% expression->type [108] 3.8% *rules* [5] 3.7% f137 [187] 1.5% type-of [213] 0.0% ------------------------------------------------------------------------------------------ match-e [81] 29.7% for-loop [91] 70.3% [98] 78142(6.2%) 5536(0.4%) for-loop ...iff-of-prods/src/core/ematch.rkt:65:37 match-e [81] 91.6% ??? [113] 3.5% ------------------------------------------------------------------------------------------ taylor-alt [92] 100.0% [99] 69324(5.5%) 0(0.0%) for-loop ...erbie/diff-of-prods/src/glue.rkt:139:6 ??? [166] 100.0% ------------------------------------------------------------------------------------------ apply-match [62] 9.3% merge-egraph-nodes! [90] 90.7% [100] 68986(5.5%) 11882(0.9%) update-leader! ...-prods/src/core/egraph.rkt:217:0 for-loop [109] 79.3% make-sequence [226] 1.0% custom-set-union! [115] 1.0% update-en-expr [221] 0.9% hash-ref! [179] 0.5% ------------------------------------------------------------------------------------------ run-improve50 [2] 4.9% ??? [87] 95.1% [101] 28782(2.3%) 0(0.0%) loop .../herbie/diff-of-prods/src/points.rkt:193:2 make-exacts* [121] 55.0% loop [110] 42.7% filter-points [116] 1.2% loop [122] 1.2% ------------------------------------------------------------------------------------------ list-cartesian-product [102] 26.0% match-e [81] 30.2% for-loop [91] 43.8% [102] 15804(1.3%) 12988(1.0%) list-cartesian-product ...src/core/ematch.rkt:20:0 list-cartesian-product [102] 26.0% for-loop [112] 14.6% ------------------------------------------------------------------------------------------ merge-egraph-nodes! [90] 100.0% [103] 15648(1.3%) 12580(1.0%) for-loop ...iff-of-prods/src/core/egraph.rkt:232:6 update-en-expr [221] 19.6% ------------------------------------------------------------------------------------------ merge-egraph-nodes! [90] 100.0% [104] 9284(0.7%) 0(0.0%) for-loop ...ff-of-prods/src/core/egraph.rkt:200:10 merge-egraph-nodes! [90] 85.7% loop! [203] 14.3% ------------------------------------------------------------------------------------------ merge-egraph-nodes! [90] 100.0% [105] 4646(0.4%) 344(0.0%) enode-merge! ...-of-prods/src/core/enode.rkt:129:0 adopt-enode! [111] 65.0% custom-set-intersect! [114] 27.6% ------------------------------------------------------------------------------------------ mk-enode! [96] 100.0% [106] 238652(19.1%) 2064(0.2%) new-enode ...diff-of-prods/src/core/enode.rkt:97:0 type-of-enode-expr [117] 97.3% set [220] 1.6% ------------------------------------------------------------------------------------------ rewriter [97] 100.0% [107] 181062(14.5%) 2780(0.2%) for-loop ...f-of-prods/src/core/matcher.rkt:134:10 matcher [118] 99.8% ------------------------------------------------------------------------------------------ taylor-alt [92] 0.0% loop [194] 1.7% f137 [187] 3.5% mterm->expr [93] 11.9% rewriter [97] 28.1% for-loop [119] 54.7% [108] 92474(7.4%) 1042(0.1%) expression->type ...-prods/src/type-check.rkt:45:0 for-loop [119] 98.9% ??? [132] 0.6% ------------------------------------------------------------------------------------------ update-leader! [100] 100.0% [109] 54700(4.4%) 1374(0.1%) for-loop ...iff-of-prods/src/core/egraph.rkt:222:6 for-loop [120] 96.9% update-en-expr [221] 0.6% ------------------------------------------------------------------------------------------ loop [101] 100.0% [110] 12280(1.0%) 0(0.0%) loop .../herbie/diff-of-prods/src/points.rkt:151:2 make-exacts* [121] 41.2% loop [122] 41.0% eval-prog [237] 17.8% ------------------------------------------------------------------------------------------ enode-merge! [105] 100.0% [111] 3022(0.2%) 334(0.0%) adopt-enode! ...-of-prods/src/core/enode.rkt:105:0 custom-set-union [218] 88.9% ------------------------------------------------------------------------------------------ list-cartesian-product [102] 100.0% [112] 2816(0.2%) 2816(0.2%) for-loop ...diff-of-prods/src/core/ematch.rkt:24:8 ------------------------------------------------------------------------------------------ for-loop [98] 100.0% [113] 2756(0.2%) 1374(0.1%) ??? ...rbie/diff-of-prods/src/core/ematch.rkt:50:5 for-loop [123] 50.1% ------------------------------------------------------------------------------------------ enode-merge! [105] 100.0% [114] 1280(0.1%) 920(0.1%) custom-set-intersect! ...ivate/set-types.rkt:269:0 for-loop [125] 28.1% ------------------------------------------------------------------------------------------ update-leader! [100] 100.0% [115] 694(0.1%) 0(0.0%) custom-set-union! ...t/private/set-types.rkt:245:0 for-loop [124] 100.0% ------------------------------------------------------------------------------------------ loop [101] 100.0% [116] 340(0.0%) 0(0.0%) filter-points ...iff-of-prods/src/points.rkt:159:0 for-loop [126] 100.0% ------------------------------------------------------------------------------------------ new-enode [106] 100.0% [117] 232102(18.5%) 2736(0.2%) type-of-enode-expr ...rods/src/core/enode.rkt:68:0 get-sigs [127] 98.5% parse-loop12 [169] 0.3% ------------------------------------------------------------------------------------------ matcher [118] 16.5% for-loop [128] 33.9% for-loop [107] 49.5% [118] 181062(14.5%) 3164(0.3%) matcher ...iff-of-prods/src/core/matcher.rkt:167:2 rewriter [97] 49.2% for-loop [128] 33.9% matcher [118] 16.5% for-loop [13] 0.2% variable? [53] 0.0% ------------------------------------------------------------------------------------------ expression->type [108] 100.0% [119] 91790(7.3%) 336(0.0%) for-loop .../diff-of-prods/src/type-check.rkt:52:5 expression->type [108] 55.3% f137 [187] 44.4% return/no-unsupplied [206] 0.1% ------------------------------------------------------------------------------------------ for-loop [109] 100.0% [120] 53002(4.2%) 612(0.0%) for-loop ...iff-of-prods/src/core/egraph.rkt:223:8 hash-update! [130] 98.8% ------------------------------------------------------------------------------------------ loop [110] 24.2% loop [101] 75.8% [121] 20884(1.7%) 0(0.0%) make-exacts* ...diff-of-prods/src/points.rkt:138:0 loop [193] 48.3% map [129] 44.8% eval-prog [237] 6.9% ------------------------------------------------------------------------------------------ loop [101] 6.2% loop [110] 93.8% [122] 5368(0.4%) 0(0.0%) loop .../herbie/diff-of-prods/src/points.rkt:141:4 map [129] 100.0% ------------------------------------------------------------------------------------------ ??? [113] 100.0% [123] 1382(0.1%) 1382(0.1%) for-loop ...diff-of-prods/src/core/ematch.rkt:51:7 ------------------------------------------------------------------------------------------ custom-set-union! [115] 100.0% [124] 694(0.1%) 694(0.1%) for-loop ...cts/racket/private/set-types.rkt:253:4 ------------------------------------------------------------------------------------------ custom-set-intersect! [114] 100.0% [125] 360(0.0%) 360(0.0%) for-loop ...cts/racket/private/set-types.rkt:272:4 ------------------------------------------------------------------------------------------ filter-points [116] 100.0% [126] 340(0.0%) 340(0.0%) for-loop ...bie/diff-of-prods/src/points.rkt:162:4 ------------------------------------------------------------------------------------------ type-of-enode-expr [117] 100.0% [127] 228672(18.3%) 5108(0.4%) get-sigs ...e/diff-of-prods/src/type-check.rkt:5:0 ??? [131] 42.4% ??? [192] 29.0% ??? [132] 14.5% ...prods/src/common.rkt:47:2 [133] 11.9% ------------------------------------------------------------------------------------------ matcher [118] 100.0% [128] 181062(14.5%) 0(0.0%) for-loop ...f-of-prods/src/core/matcher.rkt:183:21 matcher [118] 100.0% ------------------------------------------------------------------------------------------ for-loop [68] 0.4% parse-loop12 [169] 3.0% loop [122] 7.9% make-exacts* [121] 13.7% f137 [187] 75.0% [129] 68284(5.5%) 656(0.1%) map ...acket/collects/racket/private/map.rkt:20:13 f137 [187] 44.2% loop [193] 23.2% parse-loop12 [169] 14.8% simplify-node [135] 9.9% make-multiplication-node [28] 4.6% simplify* [188] 1.5% ??? [18] 0.2% taylor [199] 0.1% make-addition-node* [136] 0.1% ------------------------------------------------------------------------------------------ for-loop [120] 100.0% [130] 52390(4.2%) 0(0.0%) hash-update! ...ket/private/more-scheme.rkt:362:13 ??? [134] 100.0% ------------------------------------------------------------------------------------------ ??? [166] 0.4% for-loop [79] 3.0% f137 [187] 32.0% get-sigs [127] 64.6% [131] 150304(12.0%) 9816(0.8%) ??? ...ts/racket/contract/private/arr-i.rkt:804:10 ??? [137] 52.4% for-loop [139] 33.9% get/build-late-neg-projection [161] 5.5% ??? [241] 0.9% ??? [246] 0.2% ------------------------------------------------------------------------------------------ pattern-substitute [36] 0.2% run-improve50 [2] 0.2% free-variables [151] 0.5% expression->type [108] 0.8% pattern-match [54] 1.0% ??? [250] 2.7% substitute-e [89] 3.0% variable? [53] 11.6% match-e [81] 16.4% f137 [187] 17.3% finalize-iter! [69] 21.0% get-sigs [127] 24.5% [132] 135414(10.8%) 35160(2.8%) ??? ...contract/private/arrow-val-first.rkt:357:18 hash-has-key? [138] 51.3% for-loop [143] 20.5% ??? [250] 0.8% atab-add-altns [145] 0.8% ------------------------------------------------------------------------------------------ ??? [166] 1.7% f137 [187] 18.1% get-sigs [127] 26.8% for-loop [79] 53.4% [133] 101416(8.1%) 34054(2.7%) ...prods/src/common.rkt:47:2 ...e/arr-i.rkt:906:19 ??? [141] 37.3% ??? [142] 28.4% ------------------------------------------------------------------------------------------ hash-update! [130] 100.0% [134] 52390(4.2%) 2102(0.2%) ??? ...ie/diff-of-prods/src/core/egraph.rkt:225:24 for-loop [140] 95.3% make-sequence [226] 0.7% ------------------------------------------------------------------------------------------ simplify [182] 5.2% map [129] 94.8% [135] 25068(2.0%) 0(0.0%) simplify-node ...of-prods/src/core/reduce.rkt:50:0 f137 [187] 53.3% append-map [144] 45.2% combine-aterms [147] 1.4% ------------------------------------------------------------------------------------------ map [129] 100.0% [136] 364(0.0%) 0(0.0%) make-addition-node* ...s/src/core/reduce.rkt:222:0 make-addition-node [146] 100.0% ------------------------------------------------------------------------------------------ ??? [131] 100.0% [137] 78796(6.3%) 5388(0.4%) ??? ...ects/racket/contract/private/hash.rkt:217:4 ??? [148] 93.2% ------------------------------------------------------------------------------------------ mk-enode! [96] 4.8% ??? [132] 95.2% [138] 73042(5.8%) 16030(1.3%) hash-has-key? ...et/private/more-scheme.rkt:368:13 ??? [202] 76.6% ------------------------------------------------------------------------------------------ for-loop [216] 28.5% ??? [131] 71.5% [139] 71328(5.7%) 15752(1.3%) for-loop ...racket/contract/private/hash.rkt:239:6 ??? [217] 75.6% ??? [254] 2.3% ------------------------------------------------------------------------------------------ ??? [134] 100.0% [140] 49938(4.0%) 41990(3.4%) for-loop ...ff-of-prods/src/core/egraph.rkt:226:26 update-en-expr [221] 15.9% ------------------------------------------------------------------------------------------ for-loop [240] 6.8% ??? [217] 14.8% ...prods/src/common.rkt:47:2 [133] 78.4% [141] 37850(3.0%) 11492(0.9%) ??? ...ects/racket/contract/private/list.rkt:342:4 ??? [217] 70.2% ??? [250] 9.2% ??? [241] 2.6% ------------------------------------------------------------------------------------------ ...prods/src/common.rkt:47:2 [133] 100.0% [142] 28798(2.3%) 9376(0.7%) ??? ...s/racket/contract/private/arr-i.rkt:1268:39 ??? [204] 33.1% return/no-unsupplied [206] 21.1% assoc-ref [150] 13.2% ------------------------------------------------------------------------------------------ ??? [132] 100.0% [143] 27886(2.2%) 0(0.0%) for-loop ...f-of-prods/src/core/alt-table.rkt:51:2 atab-add-altn [149] 100.0% ------------------------------------------------------------------------------------------ append-map [144] 25.7% f137 [187] 36.4% simplify-node [135] 37.9% [144] 23568(1.9%) 1378(0.1%) append-map ...acket/collects/racket/list.rkt:565:2 parse-loop12 [169] 61.1% append-map [144] 25.7% f137 [187] 9.5% free-variables [151] 2.3% ------------------------------------------------------------------------------------------ ??? [132] 100.0% [145] 1020(0.1%) 0(0.0%) atab-add-altns ...rods/src/core/alt-table.rkt:50:0 atab-add-altn [149] 100.0% ------------------------------------------------------------------------------------------ make-addition-node* [136] 100.0% [146] 364(0.0%) 364(0.0%) make-addition-node ...ds/src/core/reduce.rkt:208:0 ------------------------------------------------------------------------------------------ simplify-node [135] 100.0% [147] 358(0.0%) 0(0.0%) combine-aterms ...-prods/src/core/reduce.rkt:183:0 for-loop [152] 100.0% ------------------------------------------------------------------------------------------ ??? [137] 100.0% [148] 73408(5.9%) 5422(0.4%) ??? ...ects/racket/contract/private/list.rkt:169:2 ??? [153] 92.6% ------------------------------------------------------------------------------------------ atab-add-altns [145] 3.5% for-loop [143] 96.5% [149] 28906(2.3%) 0(0.0%) atab-add-altn ...rods/src/core/alt-table.rkt:208:0 best-and-tied-at-points [154] 94.0% override-at-pnts [155] 6.0% ------------------------------------------------------------------------------------------ ??? [142] 100.0% [150] 3794(0.3%) 3794(0.3%) assoc-ref ...collects/racket/private/dict.rkt:56:0 ------------------------------------------------------------------------------------------ append-map [144] 100.0% [151] 1348(0.1%) 660(0.1%) free-variables ...-of-prods/src/programs.rkt:100:0 ??? [132] 51.0% ------------------------------------------------------------------------------------------ combine-aterms [147] 100.0% [152] 358(0.0%) 358(0.0%) for-loop ...iff-of-prods/src/core/reduce.rkt:185:4 ------------------------------------------------------------------------------------------ ??? [148] 100.0% [153] 67986(5.4%) 2672(0.2%) ??? ...ects/racket/contract/private/list.rkt:678:5 for-loop [156] 96.1% ------------------------------------------------------------------------------------------ atab-add-altn [149] 100.0% [154] 27172(2.2%) 358(0.0%) best-and-tied-at-points ...ore/alt-table.rkt:122:0 errors [157] 94.8% for-loop [158] 3.9% ------------------------------------------------------------------------------------------ atab-add-altn [149] 100.0% [155] 1734(0.1%) 0(0.0%) override-at-pnts ...s/src/core/alt-table.rkt:145:0 errors [157] 100.0% ------------------------------------------------------------------------------------------ ??? [153] 100.0% [156] 65314(5.2%) 17824(1.4%) for-loop ...racket/contract/private/list.rkt:680:9 add-list-context [160] 47.6% get/build-late-neg-projection [161] 25.2% ------------------------------------------------------------------------------------------ override-at-pnts [155] 3.9% composed [195] 4.8% option-on-expr [205] 11.6% loop [193] 21.2% best-and-tied-at-points [154] 58.5% [157] 44024(3.5%) 0(0.0%) errors ...erbie/diff-of-prods/src/points.rkt:218:0 for-loop [159] 79.7% eval-prog [237] 20.3% ------------------------------------------------------------------------------------------ best-and-tied-at-points [154] 100.0% [158] 1052(0.1%) 1052(0.1%) for-loop ...of-prods/src/core/alt-table.rkt:124:16 ------------------------------------------------------------------------------------------ errors [157] 100.0% [159] 35098(2.8%) 1384(0.1%) for-loop ...bie/diff-of-prods/src/points.rkt:221:4 ??? [162] 88.3% ??? [166] 5.8% ------------------------------------------------------------------------------------------ for-loop [156] 100.0% [160] 31060(2.5%) 31060(2.5%) add-list-context ...ontract/private/list.rkt:752:0 ------------------------------------------------------------------------------------------ unconstrained-domain->-projection [165] 0.7% ??? [164] 11.7% ??? [131] 20.6% for-loop [156] 66.5% [161] 24704(2.0%) 5134(0.4%) get/build-late-neg-projection ...te/guts.rkt:691:0 ??? [163] 64.1% ??? [164] 14.3% unconstrained-domain->-projection [165] 2.0% ------------------------------------------------------------------------------------------ ??? [256] 3.1% jloop [14] 5.5% loop [267] 12.0% loop [193] 34.4% for-loop [159] 44.9% [162] 68958(5.5%) 1388(0.1%) ??? ...herbie/diff-of-prods/src/programs.rkt:154:4 ??? [167] 93.8% ??? [166] 2.5% ??? [173] 1.7% ------------------------------------------------------------------------------------------ get/build-late-neg-projection [161] 100.0% [163] 18602(1.5%) 2382(0.2%) ??? ...cts/racket/contract/private/prop.rkt:314:12 build-compound-type-name [168] 87.2% ------------------------------------------------------------------------------------------ get/build-late-neg-projection [161] 100.0% [164] 6552(0.5%) 636(0.1%) ??? ...ects/racket/contract/private/hash.rkt:211:2 get/build-late-neg-projection [161] 90.3% ------------------------------------------------------------------------------------------ get/build-late-neg-projection [161] 100.0% [165] 666(0.1%) 332(0.0%) unconstrained-domain->-projection ...rrow.rkt:60:0 get/build-late-neg-projection [161] 50.2% ------------------------------------------------------------------------------------------ for-loop [201] 0.2% jloop [14] 0.4% loop [267] 0.4% get-final-combination [27] 0.4% for-loop [11] 0.8% loop [193] 1.2% ??? [162] 1.9% for-loop [159] 2.3% f137 [187] 10.7% loop [26] 23.1% ??? [192] 28.3% for-loop [99] 28.5% [166] 86856(6.9%) 1052(0.1%) ??? ...tract/private/arrow-higher-order.rkt:342:33 ??? [192] 39.4% approximate9 [6] 27.6% hash-ref! [179] 23.0% ??? [250] 2.4% ...prods/src/common.rkt:47:2 [133] 2.0% best-alt [174] 1.6% ??? [173] 0.8% ??? [131] 0.8% simplify [182] 0.6% arrow-higher-order:lnp [228] 0.4% successfully-got-the-right-kind-of-function [232] 0.2% ??? [217] 0.1% ------------------------------------------------------------------------------------------ ??? [162] 100.0% [167] 64684(5.2%) 37454(3.0%) ??? ...acket/collects/racket/private/kw.rkt:444:14 ??? [171] 12.3% bf* [172] 10.6% ??? [207] 9.4% ??? [209] 8.0% parse-loop12 [169] 0.6% ??? [254] 0.6% ------------------------------------------------------------------------------------------ contract-struct-name [170] 13.4% ??? [163] 86.6% [168] 16220(1.3%) 9524(0.8%) build-compound-type-name ...private/guts.rkt:448:0 contract-struct-name [170] 51.6% ------------------------------------------------------------------------------------------ ??? [167] 0.7% simplify [182] 0.7% loop [193] 0.8% type-of-enode-expr [117] 1.4% hash-ref! [179] 2.0% f137 [187] 5.1% parse-loop12 [169] 9.3% for-loop [31] 20.5% append-map [144] 22.2% map [129] 37.2% [169] 50696(4.1%) 7014(0.6%) parse-loop12 ...s/racket/match/compiler.rkt:418:15 for-loop [175] 20.5% loop [193] 16.0% make-multiplication-node [28] 14.2% f137 [187] 10.9% for-loop [12] 10.6% map [129] 9.7% parse-loop12 [169] 9.3% ??? [18] 0.2% ------------------------------------------------------------------------------------------ build-compound-type-name [168] 100.0% [170] 10040(0.8%) 6696(0.5%) contract-struct-name ...ract/private/prop.rkt:89:0 build-compound-type-name [168] 38.3% ------------------------------------------------------------------------------------------ ??? [167] 100.0% [171] 7968(0.6%) 4138(0.3%) ??? .../diff-of-prods/src/syntax/syntax.rkt:122:17 return/no-unsupplied [206] 39.0% list-member? [176] 4.5% ??? [204] 4.5% ------------------------------------------------------------------------------------------ ??? [167] 100.0% [172] 6862(0.5%) 0(0.0%) bf* ...ath/private/bigfloat/bigfloat-mpfr.rkt:95:0 ??? [207] 100.0% ------------------------------------------------------------------------------------------ ??? [166] 36.5% ??? [162] 63.5% [173] 1884(0.2%) 358(0.0%) ??? ...contract/private/../../private/kw.rkt:761:9 real->bigfloat [177] 81.0% ------------------------------------------------------------------------------------------ ??? [166] 100.0% [174] 1388(0.1%) 0(0.0%) best-alt ...herbie/diff-of-prods/src/glue.rkt:71:0 loop [72] 73.9% argmins [178] 26.1% ------------------------------------------------------------------------------------------ parse-loop12 [169] 100.0% [175] 18038(1.4%) 0(0.0%) for-loop ...ff-of-prods/src/core/taylor.rkt:490:59 hash-ref! [179] 100.0% ------------------------------------------------------------------------------------------ *rules* [5] 3.0% for-loop [25] 3.2% ??? [171] 3.2% ormap [48] 9.1% for-loop [78] 81.5% [176] 11244(0.9%) 2076(0.2%) list-member? ...llects/racket/private/set.rkt:24:0 loop [180] 44.3% member [181] 37.2% ------------------------------------------------------------------------------------------ ??? [173] 100.0% [177] 1526(0.1%) 1094(0.1%) real->bigfloat .../private/bigfloat/mpfr.rkt:451:0 ??? [243] 28.3% ------------------------------------------------------------------------------------------ best-alt [174] 100.0% [178] 362(0.0%) 0(0.0%) argmins ...rbie/diff-of-prods/src/common.rkt:145:0 composed [195] 100.0% ------------------------------------------------------------------------------------------ for-loop [42] 0.1% for-loop [39] 0.2% update-leader! [100] 0.4% simplify* [188] 0.5% for-loop [40] 0.7% eval-prog [237] 0.9% loop [15] 2.0% for-loop [29] 2.7% loop [193] 3.0% ??? [52] 4.0% for-loop [175] 4.8% for-loop [32] 5.1% for-loop [51] 5.8% compile [94] 12.3% ??? [184] 17.0% ??? [183] 19.6% ??? [166] 19.6% [179] 98370(7.9%) 30380(2.4%) hash-ref! ...racket/private/more-scheme.rkt:373:13 ??? [184] 21.2% simplify [182] 21.1% ??? [183] 19.6% ??? [8] 7.0% ??? [7] 6.0% ??? [10] 5.1% ??? [9] 4.8% bigfloat-hash [185] 0.8% parse-loop12 [169] 0.8% f137 [187] 0.5% ??? [17] 0.2% ??? [19] 0.1% ??? [186] 0.0% ------------------------------------------------------------------------------------------ list-member? [176] 100.0% [180] 4984(0.4%) 4984(0.4%) loop (unknown source) ------------------------------------------------------------------------------------------ list-member? [176] 100.0% [181] 4184(0.3%) 4184(0.3%) member (unknown source) ------------------------------------------------------------------------------------------ ??? [7] 0.5% loop [193] 0.5% for-loop [51] 0.5% for-loop [29] 0.5% ??? [166] 1.5% taylor-exp [38] 3.6% hash-ref! [179] 91.5% [182] 67634(5.4%) 0(0.0%) simplify ...diff-of-prods/src/core/reduce.rkt:16:0 f137 [187] 94.6% debug-print [211] 2.0% simplify-node [135] 1.9% simplify* [188] 0.5% parse-loop12 [169] 0.5% ------------------------------------------------------------------------------------------ hash-ref! [179] 100.0% [183] 59844(4.8%) 0(0.0%) ??? ...bie/diff-of-prods/src/core/taylor.rkt:44:15 hash-ref! [179] 100.0% ------------------------------------------------------------------------------------------ hash-ref! [179] 100.0% [184] 28342(2.3%) 2312(0.2%) ??? ...herbie/diff-of-prods/src/programs.rkt:183:5 hash-ref! [179] 82.2% loop [193] 13.8% ------------------------------------------------------------------------------------------ hash-ref! [179] 100.0% [185] 3234(0.3%) 312(0.0%) bigfloat-hash ...h/private/bigfloat/mpfr.rkt:165:0 bfcanonicalize [189] 54.7% sig+exp->bigfloat [190] 35.7% ------------------------------------------------------------------------------------------ hash-ref! [179] 100.0% [186] 300(0.0%) 0(0.0%) ??? ...e/diff-of-prods/src/core/localize.rkt:22:13 repeat [191] 100.0% ------------------------------------------------------------------------------------------ ??? [76] 0.0% for-loop [12] 0.0% composed [195] 0.1% hash-ref! [179] 0.3% loop [45] 0.4% eval-prog [237] 0.5% approximate9 [6] 0.6% mterm->expr [93] 0.6% loop [194] 0.6% append-map [144] 0.7% loop [193] 1.1% parse-loop12 [169] 1.1% simplify-node [135] 1.3% eval-const-expr [34] 2.4% simplify [182] 7.2% f137 [187] 8.2% map [129] 12.1% split-table [50] 14.5% rewriter [97] 16.0% for-loop [119] 32.0% [187] 197352(15.8%) 6812(0.5%) f137 .../collects/racket/match/compiler.rkt:507:40 map [129] 19.9% ??? [131] 18.4% ??? [192] 12.8% loop [193] 12.6% f137 [187] 8.2% ??? [132] 7.9% ...prods/src/common.rkt:47:2 [133] 6.2% expression->type [108] 2.1% append-map [144] 2.0% option-on-expr [205] 2.0% loop [194] 1.1% ??? [197] 0.9% ??? [166] 0.8% return/no-unsupplied [206] 0.4% loop [45] 0.4% ??? [204] 0.3% combine-mterms [16] 0.3% parse-loop12 [169] 0.3% loop [15] 0.3% composed [195] 0.2% curried [210] 0.2% taylor-exp [38] 0.2% compose [196] 0.1% taylor [199] 0.0% exprs-to-branch-on [20] 0.0% ------------------------------------------------------------------------------------------ simplify [182] 8.9% map [129] 91.1% [188] 4118(0.3%) 1736(0.1%) simplify* ...iff-of-prods/src/core/reduce.rkt:31:0 hash-ref! [179] 33.6% ??? [198] 24.2% ------------------------------------------------------------------------------------------ bigfloat-hash [185] 100.0% [189] 1768(0.1%) 1768(0.1%) bfcanonicalize .../private/bigfloat/mpfr.rkt:155:0 ------------------------------------------------------------------------------------------ bigfloat-hash [185] 100.0% [190] 1154(0.1%) 1154(0.1%) sig+exp->bigfloat ...ivate/bigfloat/mpfr.rkt:385:0 ------------------------------------------------------------------------------------------ ??? [186] 100.0% [191] 300(0.0%) 0(0.0%) repeat ...diff-of-prods/src/core/localize.rkt:13:0 for-loop [200] 100.0% ------------------------------------------------------------------------------------------ simplify-alt [55] 0.1% get-sigs [127] 2.2% f137 [187] 2.7% for-loop [79] 4.9% ??? [166] 5.8% ??? [192] 6.2% for-loop [201] 36.9% ??? [87] 40.7% [192] 992852(79.3%) 65500(5.2%) ??? ...llects/racket/private/norm-define.rkt:53:83 for-loop [201] 36.9% iterate-egraph!13 [3] 30.5% loop [4] 10.5% ??? [202] 6.6% ??? [192] 6.2% ??? [166] 4.9% ??? [204] 0.5% return/no-unsupplied [206] 0.3% mk-egraph [208] 0.3% ??? [217] 0.1% dict? [262] 0.1% ??? [214] 0.0% ------------------------------------------------------------------------------------------ make-exacts* [121] 0.1% map-enodes [33] 0.9% for-loop [91] 1.0% map [129] 1.7% match-e [81] 2.7% ??? [184] 2.9% option-on-expr [205] 4.0% loop! [203] 6.2% parse-loop12 [169] 7.0% f137 [187] 13.9% loop [193] 59.5% [193] 128000(10.2%) 7860(0.6%) loop ...cket/collects/racket/private/map.rkt:25:19 loop [193] 59.5% option-on-expr [205] 13.7% f137 [187] 7.4% loop! [203] 5.4% errors [157] 4.0% hash-ref! [179] 2.9% foldl [212] 1.0% parse-loop12 [169] 1.0% for-loop [11] 0.9% simplify [182] 0.3% curried [210] 0.3% ??? [162] 0.2% ??? [209] 0.0% set-precompute! [215] 0.0% ??? [207] 0.0% ??? [166] 0.0% ------------------------------------------------------------------------------------------ f137 [187] 100.0% [194] 12368(1.0%) 0(0.0%) loop ...bie/diff-of-prods/src/core/reduce.rkt:18:2 f137 [187] 61.7% expression->type [108] 35.6% type-of [213] 2.7% ------------------------------------------------------------------------------------------ argmins [178] 6.7% loop [72] 32.3% f137 [187] 61.0% [195] 5410(0.4%) 662(0.1%) composed ...ollects/racket/private/list.rkt:321:16 f137 [187] 48.8% errors [157] 39.0% ------------------------------------------------------------------------------------------ for-loop [68] 14.8% f137 [187] 14.8% for-loop [11] 70.4% [196] 2450(0.2%) 2450(0.2%) compose ...collects/racket/private/list.rkt:385:12 ------------------------------------------------------------------------------------------ f137 [187] 100.0% [197] 1748(0.1%) 0(0.0%) ??? ...tract/private/arrow-higher-order.rkt:336:46 ??? [250] 100.0% ------------------------------------------------------------------------------------------ simplify* [188] 100.0% [198] 998(0.1%) 312(0.0%) ??? ...racket/collects/racket/private/kw.rkt:762:9 ??? [219] 68.7% ------------------------------------------------------------------------------------------ f137 [187] 47.4% map [129] 52.6% [199] 684(0.1%) 0(0.0%) taylor .../diff-of-prods/src/core/taylor.rkt:163:0 debug-print [211] 100.0% ------------------------------------------------------------------------------------------ repeat [191] 100.0% [200] 300(0.0%) 300(0.0%) for-loop ...ff-of-prods/src/core/localize.rkt:14:2 ------------------------------------------------------------------------------------------ ??? [192] 100.0% [201] 795540(63.6%) 0(0.0%) for-loop ...f-of-prods/src/core/simplify.rkt:63:12 ??? [192] 100.0% ??? [166] 0.0% ------------------------------------------------------------------------------------------ hash-has-key? [138] 25.6% ??? [192] 74.4% [202] 218648(17.5%) 76510(6.1%) ??? ...ects/racket/contract/private/list.rkt:737:4 for-loop [216] 53.7% ??? [236] 9.2% ??? [217] 1.1% ??? [250] 0.6% successfully-got-the-right-kind-of-function [232] 0.3% arrow-higher-order:lnp [228] 0.2% ------------------------------------------------------------------------------------------ for-loop [104] 1.6% merge-egraph-nodes! [90] 11.9% loop [193] 28.4% for-loop [78] 58.1% [203] 51978(4.2%) 9284(0.7%) loop! ...ie/diff-of-prods/src/core/enode.rkt:192:2 loop [193] 36.0% custom-set-union [218] 35.1% set [220] 13.0% update-en-expr [221] 4.7% ------------------------------------------------------------------------------------------ ??? [171] 1.1% f137 [187] 2.1% ??? [192] 27.6% ??? [142] 29.5% flag-set? [67] 39.7% [204] 32370(2.6%) 9206(0.7%) ??? ...racket/collects/racket/private/kw.rkt:761:9 ??? [219] 61.6% ??? [250] 10.0% ------------------------------------------------------------------------------------------ f137 [187] 12.0% loop [193] 88.0% [205] 32120(2.6%) 332(0.0%) option-on-expr ...prods/src/core/regimes.rkt:103:0 sort-context-on-expr [222] 40.8% loop [193] 29.0% errors [157] 15.9% pick-errors [227] 6.7% err-lsts->split-indices [229] 3.4% sindices->spoints [231] 3.2% ------------------------------------------------------------------------------------------ for-loop [119] 1.1% f137 [187] 2.4% ??? [171] 10.3% ??? [142] 20.1% ??? [192] 24.5% flag-set? [67] 41.7% [206] 30238(2.4%) 23916(1.9%) return/no-unsupplied ...ct/private/arr-i.rkt:533:0 filter [224] 20.9% ------------------------------------------------------------------------------------------ loop [193] 2.3% ??? [167] 45.9% bf* [172] 51.7% [207] 13268(1.1%) 2072(0.2%) ??? ...-racket/utils/simple-result-arrow.rkt:39:12 bfadd [223] 78.0% bfexp [233] 6.4% ------------------------------------------------------------------------------------------ ??? [192] 100.0% [208] 6730(0.5%) 0(0.0%) mk-egraph ...ff-of-prods/src/core/egraph.rkt:123:0 expr->enode [225] 90.3% mk-enode! [96] 9.7% ------------------------------------------------------------------------------------------ loop [193] 11.8% ??? [167] 88.2% [209] 5846(0.5%) 5846(0.5%) ??? ...rivate/unconstrained-domain-arrow.rkt:40:13 ------------------------------------------------------------------------------------------ loop [193] 10.8% f137 [187] 11.0% *rules* [5] 11.8% for-loop [91] 21.9% ormap [48] 44.6% [210] 3030(0.2%) 3030(0.2%) curried ...cket/collects/racket/function.rkt:71:18 ------------------------------------------------------------------------------------------ taylor [199] 34.0% simplify [182] 66.0% [211] 2014(0.2%) 982(0.1%) debug-print ...e/diff-of-prods/src/debug.rkt:107:0 for-loop [230] 51.2% ------------------------------------------------------------------------------------------ for-loop [91] 32.3% loop [193] 67.7% [212] 1944(0.2%) 1286(0.1%) foldl ...et/collects/racket/private/list.rkt:229:4 merge2 [234] 33.8% ------------------------------------------------------------------------------------------ loop [194] 33.5% rewriter [97] 66.5% [213] 990(0.1%) 990(0.1%) type-of ...e/diff-of-prods/src/type-check.rkt:38:0 ------------------------------------------------------------------------------------------ ??? [192] 100.0% [214] 696(0.1%) 0(0.0%) ??? ...-racket/utils/simple-result-arrow.rkt:60:15 ??? [243] 100.0% ------------------------------------------------------------------------------------------ loop [193] 100.0% [215] 328(0.0%) 0(0.0%) set-precompute! ...ods/src/core/simplify.rkt:172:0 make-sequence [226] 100.0% ------------------------------------------------------------------------------------------ ??? [202] 100.0% [216] 117340(9.4%) 67994(5.4%) for-loop ...acket/contract/private/list.rkt:743:12 ??? [236] 23.0% for-loop [139] 17.3% ??? [241] 1.7% ------------------------------------------------------------------------------------------ ??? [166] 0.4% ??? [202] 2.5% ??? [192] 2.6% ??? [141] 36.9% for-loop [139] 57.2% [217] 94276(7.5%) 21980(1.8%) ??? ...cts/racket/contract/private/list.rkt:187:10 ??? [235] 53.3% ??? [141] 11.9% for-loop [240] 9.9% ??? [254] 1.1% ??? [250] 0.5% ------------------------------------------------------------------------------------------ adopt-enode! [111] 12.0% loop! [203] 88.0% [218] 22362(1.8%) 7994(0.6%) custom-set-union ...et/private/set-types.rkt:168:0 for-loop [239] 49.2% for-loop [242] 15.1% ------------------------------------------------------------------------------------------ ??? [198] 3.3% ??? [204] 96.7% [219] 20620(1.6%) 19940(1.6%) ??? ...s/racket/contract/private/arr-i.rkt:1233:27 ??? [246] 3.3% ------------------------------------------------------------------------------------------ new-enode [106] 21.7% loop! [203] 78.3% [220] 17630(1.4%) 17630(1.4%) set ...collects/racket/private/set-types.rkt:981:0 ------------------------------------------------------------------------------------------ for-loop [25] 1.7% for-loop [109] 1.9% update-leader! [100] 3.7% for-loop [103] 17.7% loop! [203] 29.3% for-loop [140] 45.8% [221] 17372(1.4%) 17372(1.4%) update-en-expr ...-prods/src/core/egraph.rkt:211:0 ------------------------------------------------------------------------------------------ option-on-expr [205] 100.0% [222] 13110(1.0%) 0(0.0%) sort-context-on-expr ...prods/src/points.rkt:115:0 ??? [238] 97.3% eval-prog [237] 2.7% ------------------------------------------------------------------------------------------ ??? [207] 100.0% [223] 10352(0.8%) 8576(0.7%) bfadd ...-lib/math/private/bigfloat/mpfr.rkt:819:4 ??? [243] 17.2% ------------------------------------------------------------------------------------------ for-loop [46] 4.6% for-loop [91] 9.0% return/no-unsupplied [206] 86.4% [224] 7316(0.6%) 7316(0.6%) filter ...t/collects/racket/private/list.rkt:256:2 ------------------------------------------------------------------------------------------ mk-egraph [208] 24.6% expr->enode [225] 75.4% [225] 6074(0.5%) 0(0.0%) expr->enode ...-of-prods/src/core/egraph.rkt:124:2 expr->enode [225] 75.4% mk-enode! [96] 24.6% ------------------------------------------------------------------------------------------ set-precompute! [215] 6.8% reduce-to-single! [85] 7.0% ??? [134] 7.3% merge-egraph-nodes! [90] 14.3% update-leader! [100] 14.6% for-loop [46] 49.9% [226] 4790(0.4%) 4126(0.3%) make-sequence ...ects/racket/private/for.rkt:509:2 ??? [247] 13.9% ------------------------------------------------------------------------------------------ option-on-expr [205] 100.0% [227] 2158(0.2%) 0(0.0%) pick-errors ...of-prods/src/core/regimes.rkt:184:0 for-loop [244] 100.0% ------------------------------------------------------------------------------------------ ??? [166] 25.4% ??? [202] 25.7% maybe-cons-kwd [86] 48.8% [228] 1274(0.1%) 624(0.0%) arrow-higher-order:lnp ...w-higher-order.rkt:597:7 ??? [248] 51.0% ------------------------------------------------------------------------------------------ option-on-expr [205] 100.0% [229] 1082(0.1%) 0(0.0%) err-lsts->split-indices .../core/regimes.rkt:222:0 add-splitpoint [245] 100.0% ------------------------------------------------------------------------------------------ debug-print [211] 100.0% [230] 1032(0.1%) 1032(0.1%) for-loop ...rbie/diff-of-prods/src/debug.rkt:113:2 ------------------------------------------------------------------------------------------ option-on-expr [205] 100.0% [231] 1020(0.1%) 0(0.0%) sindices->spoints ...ds/src/core/regimes.rkt:116:0 eval-prog [237] 100.0% ------------------------------------------------------------------------------------------ ??? [166] 30.5% ??? [202] 69.5% [232] 984(0.1%) 626(0.1%) successfully-got-the-right-kind-of-function ...9:4 arity-checking-wrapper [249] 36.4% ------------------------------------------------------------------------------------------ ??? [207] 100.0% [233] 844(0.1%) 462(0.0%) bfexp ...-lib/math/private/bigfloat/mpfr.rkt:616:4 ??? [243] 45.3% ------------------------------------------------------------------------------------------ foldl [212] 100.0% [234] 658(0.1%) 658(0.1%) merge2 ...e/diff-of-prods/src/core/ematch.rkt:31:0 ------------------------------------------------------------------------------------------ ??? [217] 100.0% [235] 50278(4.0%) 4334(0.3%) ??? ...ects/racket/contract/private/list.rkt:686:7 ??? [250] 86.1% ??? [254] 5.3% ------------------------------------------------------------------------------------------ ??? [202] 42.8% for-loop [216] 57.2% [236] 47098(3.8%) 23398(1.9%) ??? ...private/unconstrained-domain-arrow.rkt:74:4 make-keyword-procedure [251] 50.3% ------------------------------------------------------------------------------------------ sort-context-on-expr [222] 2.6% sindices->spoints [231] 7.3% make-exacts* [121] 10.4% loop [110] 15.7% errors [157] 64.0% [237] 13942(1.1%) 1016(0.1%) eval-prog .../diff-of-prods/src/programs.rkt:148:0 f137 [187] 64.7% hash-ref! [179] 28.0% ------------------------------------------------------------------------------------------ sort-context-on-expr [222] 100.0% [238] 12752(1.0%) 0(0.0%) ??? ...cket/collects/racket/private/sort.rkt:403:3 generic-sort/key [252] 81.0% loop [267] 19.0% ------------------------------------------------------------------------------------------ custom-set-union [218] 100.0% [239] 10992(0.9%) 3818(0.3%) for-loop ...cts/racket/private/set-types.rkt:174:3 for-loop [253] 65.3% ------------------------------------------------------------------------------------------ ??? [217] 100.0% [240] 9336(0.7%) 4192(0.3%) for-loop ...acket/contract/private/list.rkt:190:15 ??? [141] 55.1% ------------------------------------------------------------------------------------------ ??? [141] 22.5% ??? [131] 31.1% for-loop [216] 46.4% [241] 4420(0.4%) 336(0.0%) ??? ...ects/racket/contract/private/hash.rkt:222:6 check-hash/c [255] 92.4% ------------------------------------------------------------------------------------------ custom-set-union [218] 100.0% [242] 3376(0.3%) 3376(0.3%) for-loop ...cts/racket/private/set-types.rkt:152:2 ------------------------------------------------------------------------------------------ bfexp [233] 11.6% real->bigfloat [177] 13.1% ??? [214] 21.2% bfadd [223] 54.0% [243] 3286(0.3%) 3286(0.3%) ??? .../share/racket/collects/ffi/unsafe.rkt:861:4 ------------------------------------------------------------------------------------------ pick-errors [227] 100.0% [244] 2158(0.2%) 0(0.0%) for-loop ...ff-of-prods/src/core/regimes.rkt:186:2 ??? [256] 100.0% ------------------------------------------------------------------------------------------ err-lsts->split-indices [229] 100.0% [245] 1082(0.1%) 0(0.0%) add-splitpoint ...prods/src/core/regimes.rkt:235:2 for-loop [258] 100.0% ------------------------------------------------------------------------------------------ ??? [131] 34.6% ??? [219] 65.4% [246] 1040(0.1%) 1040(0.1%) ??? ...ects/racket/contract/private/prop.rkt:256:4 ------------------------------------------------------------------------------------------ make-sequence [226] 100.0% [247] 664(0.1%) 0(0.0%) ??? ...acket/collects/racket/private/for.rkt:429:7 custom-in-set [257] 100.0% ------------------------------------------------------------------------------------------ arrow-higher-order:lnp [228] 100.0% [248] 650(0.1%) 650(0.1%) ??? ...et/contract/private/arity-checking.rkt:19:2 ------------------------------------------------------------------------------------------ successfully-got-the-right-kind-of-function [232]100.0% [249] 358(0.0%) 0(0.0%) arity-checking-wrapper ...w-higher-order.rkt:402:0 matches-arity-exactly? [259] 100.0% ------------------------------------------------------------------------------------------ ??? [217] 0.7% ??? [132] 1.7% ??? [202] 2.1% ??? [197] 2.9% ??? [166] 3.4% ??? [204] 5.4% ??? [141] 11.6% ??? [235] 72.1% [250] 59996(4.8%) 49002(3.9%) ??? ...ects/racket/contract/private/guts.rkt:644:8 contract? [261] 8.7% ??? [132] 6.4% dict? [262] 3.2% ------------------------------------------------------------------------------------------ ??? [236] 100.0% [251] 23700(1.9%) 23700(1.9%) make-keyword-procedure ...ket/private/kw.rkt:260:4 ------------------------------------------------------------------------------------------ ??? [238] 100.0% [252] 10326(0.8%) 0(0.0%) generic-sort/key .../racket/private/sort.rkt:185:2 copying-mergesort [260] 93.4% loop [267] 6.6% ------------------------------------------------------------------------------------------ for-loop [239] 100.0% [253] 7174(0.6%) 7174(0.6%) for-loop ...cts/racket/private/set-types.rkt:178:5 ------------------------------------------------------------------------------------------ ??? [167] 6.3% ??? [217] 18.3% for-loop [139] 28.8% ??? [235] 46.6% [254] 5734(0.5%) 3812(0.3%) ??? ...ects/racket/contract/private/prop.rkt:493:4 ??? [264] 33.5% ------------------------------------------------------------------------------------------ ??? [241] 100.0% [255] 4084(0.3%) 1404(0.1%) check-hash/c ...ket/contract/private/hash.rkt:83:0 flat-contract? [263] 65.6% ------------------------------------------------------------------------------------------ for-loop [244] 100.0% [256] 2158(0.2%) 0(0.0%) ??? ...ie/diff-of-prods/src/core/regimes.rkt:177:2 ??? [162] 100.0% ------------------------------------------------------------------------------------------ match-e [81] 49.6% ??? [247] 50.4% [257] 1318(0.1%) 1318(0.1%) custom-in-set ...acket/private/set-types.rkt:577:0 ------------------------------------------------------------------------------------------ add-splitpoint [245] 100.0% [258] 1082(0.1%) 0(0.0%) for-loop ...ff-of-prods/src/core/regimes.rkt:237:4 for-loop [265] 66.7% loop [266] 33.3% ------------------------------------------------------------------------------------------ arity-checking-wrapper [249] 100.0% [259] 358(0.0%) 358(0.0%) matches-arity-exactly? ...te/arrow-common.rkt:70:0 ------------------------------------------------------------------------------------------ generic-sort/key [252] 48.4% copying-mergesort [260] 51.6% [260] 9644(0.8%) 0(0.0%) copying-mergesort ...racket/private/sort.rkt:130:8 copying-mergesort [260] 51.6% loop [267] 37.7% jloop [14] 10.6% ------------------------------------------------------------------------------------------ ??? [250] 100.0% [261] 5242(0.4%) 5242(0.4%) contract? ...acket/contract/private/guts.rkt:109:0 ------------------------------------------------------------------------------------------ *rules* [5] 7.2% ??? [250] 41.9% ??? [192] 50.9% [262] 4628(0.4%) 4628(0.4%) dict? ...ollects/racket/private/generic.rkt:146:11 ------------------------------------------------------------------------------------------ check-hash/c [255] 100.0% [263] 2680(0.2%) 2680(0.2%) flat-contract? .../contract/private/guts.rkt:111:0 ------------------------------------------------------------------------------------------ ??? [254] 100.0% [264] 1922(0.2%) 632(0.1%) ??? ...lects/racket/contract/private/orc.rkt:83:14 ??? [268] 67.1% ------------------------------------------------------------------------------------------ for-loop [258] 100.0% [265] 722(0.1%) 722(0.1%) for-loop ...ff-of-prods/src/core/regimes.rkt:241:8 ------------------------------------------------------------------------------------------ for-loop [258] 16.7% loop [266] 83.3% [266] 360(0.0%) 360(0.0%) loop ...hare/racket/collects/racket/list.rkt:154:2 loop [266] 83.3% ------------------------------------------------------------------------------------------ generic-sort/key [252] 7.9% ??? [238] 28.1% copying-mergesort [260] 64.0% [267] 8644(0.7%) 0(0.0%) loop ...ket/collects/racket/private/sort.rkt:97:12 ??? [162] 95.9% ??? [166] 4.1% ------------------------------------------------------------------------------------------ ??? [264] 100.0% [268] 1290(0.1%) 1290(0.1%) ??? ...ects/racket/contract/private/list.rkt:141:5 ------------------------------------------------------------------------------------------