Profiling results ----------------- Total cpu time observed: 2079828ms (out of 2085440ms) Number of samples taken: 8419 (once every 247ms) (Hiding functions with self<1.0% and local<2.0%: 15 of 262 hidden) =========================================================================================== Caller Idx Total Self Name+src Local% ms(pct) ms(pct) Callee =========================================================================================== ??? [180] 100.0% [1] 1822670(87.6%) 464(0.0%) iterate-egraph!13 ...s/src/core/simplify.rkt:102:0 one-iter [17] 98.6% map-enodes [21] 1.4% ------------------------------------------------------------------------------------------- ??? [69] 100.0% [2] 1657414(79.7%) 0(0.0%) profile-thunk16 ...t/pkgs/profile-lib/main.rkt:9:0 run [18] 100.0% ------------------------------------------------------------------------------------------- ??? [69] 100.0% [3] 1655952(79.6%) 0(0.0%) run-improve50 ...f-of-prods/src/mainloop.rkt:234:0 for-loop [19] 99.9% loop [87] 0.1% setup-alt-simplified [31] 0.0% get-final-combination [36] 0.0% ------------------------------------------------------------------------------------------- ??? [180] 100.0% [4] 221440(10.6%) 0(0.0%) loop .../diff-of-prods/src/core/simplify.rkt:215:2 pass [20] 100.0% ------------------------------------------------------------------------------------------- substitute-e [71] 13.9% match-e [61] 86.1% [5] 45224(2.2%) 1838(0.1%) variable? ...-of-prods/src/syntax/syntax.rkt:567:0 ??? [121] 95.9% ------------------------------------------------------------------------------------------- map-enodes [21] 4.9% loop [193] 95.1% [6] 23396(1.1%) 3242(0.2%) for-loop ...f-of-prods/src/core/simplify.rkt:173:2 setfindf [22] 54.4% eval-const-expr [26] 20.7% curried [206] 6.0% compose [30] 5.0% ------------------------------------------------------------------------------------------- ??? [152] 100.0% [7] 10698(0.5%) 0(0.0%) approximate9 ...-of-prods/src/core/taylor.rkt:12:0 loop [23] 90.4% taylor-quotient [32] 6.2% f137 [178] 3.4% ------------------------------------------------------------------------------------------- hash-ref! [156] 100.0% [8] 6824(0.3%) 0(0.0%) ??? ...ie/diff-of-prods/src/core/taylor.rkt:295:23 for-loop [24] 100.0% ------------------------------------------------------------------------------------------- hash-ref! [156] 100.0% [9] 5448(0.3%) 0(0.0%) ??? ...ie/diff-of-prods/src/core/taylor.rkt:392:23 for-loop [25] 100.0% ------------------------------------------------------------------------------------------- hash-ref! [156] 100.0% [10] 4296(0.2%) 0(0.0%) ??? ...ie/diff-of-prods/src/core/taylor.rkt:483:23 for-loop [27] 100.0% ------------------------------------------------------------------------------------------- hash-ref! [156] 100.0% [11] 1440(0.1%) 0(0.0%) ??? ...ie/diff-of-prods/src/core/taylor.rkt:338:33 hash-ref! [156] 73.2% for-loop [33] 26.8% ------------------------------------------------------------------------------------------- parse-loop12 [187] 100.0% [12] 1074(0.1%) 0(0.0%) simplify-node ...of-prods/src/core/reduce.rkt:50:0 append-map [29] 69.6% f137 [178] 30.4% ------------------------------------------------------------------------------------------- append-map [29] 100.0% [13] 760(0.0%) 326(0.0%) free-variables ...-of-prods/src/programs.rkt:100:0 ??? [121] 57.1% ------------------------------------------------------------------------------------------- parse-loop12 [187] 100.0% [14] 748(0.0%) 0(0.0%) for-loop ...iff-of-prods/src/core/reduce.rkt:99:13 make-multiplication-node [28] 55.3% f137 [178] 44.7% ------------------------------------------------------------------------------------------- f137 [178] 100.0% [15] 636(0.0%) 0(0.0%) loop ...bie/diff-of-prods/src/core/reduce.rkt:18:2 expression->type [35] 52.2% f137 [178] 47.8% ------------------------------------------------------------------------------------------- hash-ref! [156] 100.0% [16] 334(0.0%) 0(0.0%) ??? ...ie/diff-of-prods/src/core/taylor.rkt:285:26 for-loop [34] 100.0% ------------------------------------------------------------------------------------------- iterate-egraph!13 [1] 100.0% [17] 1797370(86.4%) 14738(0.7%) one-iter ...f-of-prods/src/core/simplify.rkt:113:0 loop [38] 83.0% for-loop [39] 15.2% apply-match [50] 0.8% hash-keys [200] 0.0% filter [236] 0.0% ------------------------------------------------------------------------------------------- profile-thunk16 [2] 100.0% [18] 1657476(79.7%) 0(0.0%) run ...share/racket/pkgs/profile-lib/main.rkt:39:2 ??? [69] 100.0% ------------------------------------------------------------------------------------------- run-improve50 [3] 100.0% [19] 1653648(79.5%) 0(0.0%) for-loop .../diff-of-prods/src/mainloop.rkt:249:10 run-iter! [37] 100.0% ------------------------------------------------------------------------------------------- loop [4] 100.0% [20] 221440(10.6%) 2814(0.1%) pass .../diff-of-prods/src/core/simplify.rkt:205:2 for-loop [40] 98.7% ------------------------------------------------------------------------------------------- iterate-egraph!13 [1] 100.0% [21] 24836(1.2%) 0(0.0%) map-enodes ...f-of-prods/src/core/egraph.rkt:139:0 loop [193] 95.4% for-loop [6] 4.6% ------------------------------------------------------------------------------------------- for-loop [6] 100.0% [22] 12722(0.6%) 6216(0.3%) setfindf ...bie/diff-of-prods/src/common.rkt:179:0 for-loop [42] 34.1% ??? [121] 14.2% custom-in-set [237] 2.8% ------------------------------------------------------------------------------------------- approximate9 [7] 100.0% [23] 9676(0.5%) 326(0.0%) loop ...bie/diff-of-prods/src/core/taylor.rkt:86:4 ??? [152] 96.6% ------------------------------------------------------------------------------------------- ??? [8] 100.0% [24] 6824(0.3%) 660(0.0%) for-loop ...ff-of-prods/src/core/taylor.rkt:298:27 hash-ref! [156] 96.0% ------------------------------------------------------------------------------------------- ??? [9] 100.0% [25] 5448(0.3%) 0(0.0%) for-loop ...ff-of-prods/src/core/taylor.rkt:396:33 for-loop [41] 100.0% ------------------------------------------------------------------------------------------- for-loop [6] 100.0% [26] 4838(0.2%) 1666(0.1%) eval-const-expr ...of-prods/src/programs.rkt:166:0 f137 [178] 57.7% ??? [199] 6.9% parse-app [201] 1.0% ------------------------------------------------------------------------------------------- ??? [10] 100.0% [27] 4296(0.2%) 0(0.0%) for-loop ...ff-of-prods/src/core/taylor.rkt:487:35 parse-loop12 [187] 100.0% ------------------------------------------------------------------------------------------- simplify [166] 2.4% for-loop [14] 18.8% parse-loop12 [187] 78.9% [28] 2204(0.1%) 0(0.0%) make-multiplication-node .../core/reduce.rkt:230:0 make-multiplication-subnode [43] 100.0% ------------------------------------------------------------------------------------------- parse-loop12 [187] 12.5% append-map [29] 15.4% simplify-node [12] 18.7% f137 [178] 53.4% [29] 1834(0.1%) 0(0.0%) append-map ...acket/collects/racket/list.rkt:565:2 parse-loop12 [187] 36.7% f137 [178] 30.1% append-map [29] 15.4% loop [193] 9.5% free-variables [13] 8.4% ------------------------------------------------------------------------------------------- for-loop [6] 100.0% [30] 1180(0.1%) 1180(0.1%) compose ...collects/racket/private/list.rkt:385:12 ------------------------------------------------------------------------------------------- run-improve50 [3] 100.0% [31] 694(0.0%) 0(0.0%) setup-alt-simplified ...of-prods/src/glue.rkt:49:0 simplify-alt [44] 100.0% ------------------------------------------------------------------------------------------- approximate9 [7] 100.0% [32] 660(0.0%) 0(0.0%) taylor-quotient ...prods/src/core/taylor.rkt:328:0 simplify [166] 50.6% first-nonzero-exp [47] 49.4% ------------------------------------------------------------------------------------------- ??? [11] 100.0% [33] 386(0.0%) 0(0.0%) for-loop ...ff-of-prods/src/core/taylor.rkt:341:46 hash-ref! [156] 100.0% ------------------------------------------------------------------------------------------- ??? [16] 100.0% [34] 334(0.0%) 0(0.0%) for-loop ...ff-of-prods/src/core/taylor.rkt:285:52 ??? [45] 100.0% ------------------------------------------------------------------------------------------- loop [15] 33.3% for-loop [46] 66.7% [35] 332(0.0%) 0(0.0%) expression->type ...-prods/src/type-check.rkt:45:0 for-loop [46] 100.0% ------------------------------------------------------------------------------------------- run-improve50 [3] 100.0% [36] 306(0.0%) 0(0.0%) get-final-combination ...ds/src/mainloop.rkt:264:0 split-table [48] 100.0% ------------------------------------------------------------------------------------------- for-loop [19] 100.0% [37] 1653648(79.5%) 0(0.0%) run-iter! .../diff-of-prods/src/mainloop.rkt:215:0 simplify! [49] 98.7% gen-series! [54] 0.6% finalize-iter! [55] 0.5% gen-rewrites! [57] 0.1% ------------------------------------------------------------------------------------------- one-iter [17] 100.0% [38] 1491718(71.7%) 2436(0.1%) loop ...cket/collects/racket/private/map.rkt:52:19 apply-match [50] 99.8% ------------------------------------------------------------------------------------------- for-loop [39] 49.2% one-iter [17] 50.8% [39] 274054(13.2%) 43054(2.1%) for-loop ...-of-prods/src/core/simplify.rkt:123:12 for-loop [39] 49.2% match-e [61] 41.9% ??? [92] 0.2% ------------------------------------------------------------------------------------------- pass [20] 100.0% [40] 218572(10.5%) 4350(0.2%) for-loop ...-of-prods/src/core/simplify.rkt:208:29 argmin [51] 74.2% loop [52] 14.0% for-loop [53] 8.8% make-sequence [218] 0.6% filter [236] 0.2% ------------------------------------------------------------------------------------------- for-loop [25] 100.0% [41] 5448(0.3%) 0(0.0%) for-loop ...ff-of-prods/src/core/taylor.rkt:398:39 hash-ref! [156] 100.0% ------------------------------------------------------------------------------------------- setfindf [22] 100.0% [42] 4338(0.2%) 4338(0.2%) for-loop ...bie/diff-of-prods/src/common.rkt:180:2 ------------------------------------------------------------------------------------------- make-multiplication-node [28] 100.0% [43] 2204(0.1%) 0(0.0%) make-multiplication-subnode ...re/reduce.rkt:240:0 for-loop [56] 97.7% group-by68 [58] 2.3% ------------------------------------------------------------------------------------------- setup-alt-simplified [31] 100.0% [44] 694(0.0%) 0(0.0%) simplify-alt ...ie/diff-of-prods/src/glue.rkt:76:0 ??? [180] 100.0% ------------------------------------------------------------------------------------------- for-loop [34] 100.0% [45] 334(0.0%) 0(0.0%) ??? ...ie/diff-of-prods/src/core/taylor.rkt:288:19 hash-ref! [156] 100.0% ------------------------------------------------------------------------------------------- expression->type [35] 100.0% [46] 332(0.0%) 0(0.0%) for-loop .../diff-of-prods/src/type-check.rkt:52:5 expression->type [35] 66.7% f137 [178] 33.3% ------------------------------------------------------------------------------------------- taylor-quotient [32] 100.0% [47] 326(0.0%) 0(0.0%) first-nonzero-exp ...ods/src/core/taylor.rkt:260:0 hash-ref! [156] 100.0% ------------------------------------------------------------------------------------------- get-final-combination [36] 100.0% [48] 306(0.0%) 0(0.0%) split-table ...ie/diff-of-prods/src/glue.rkt:162:0 f137 [178] 100.0% ------------------------------------------------------------------------------------------- run-iter! [37] 100.0% [49] 1632150(78.5%) 362(0.0%) simplify! .../diff-of-prods/src/mainloop.rkt:155:0 for-loop [59] 100.0% ------------------------------------------------------------------------------------------- one-iter [17] 1.0% loop [38] 99.0% [50] 1504272(72.3%) 3124(0.2%) apply-match ...f-prods/src/core/simplify.rkt:130:2 for-loop [60] 88.6% match-e [61] 10.2% update-leader! [80] 0.7% reduce-to-single! [65] 0.3% ------------------------------------------------------------------------------------------- for-loop [40] 100.0% [51] 162260(7.8%) 656(0.0%) argmin ...re/racket/collects/racket/list.rkt:743:0 for-loop [62] 86.7% expression-cost [63] 12.9% ------------------------------------------------------------------------------------------- for-loop [40] 100.0% [52] 30644(1.5%) 0(0.0%) loop ...hare/racket/collects/racket/list.rkt:729:4 for-loop [62] 92.0% expression-cost [63] 8.0% ------------------------------------------------------------------------------------------- for-loop [40] 100.0% [53] 19250(0.9%) 19250(0.9%) for-loop ...-of-prods/src/core/simplify.rkt:195:13 ------------------------------------------------------------------------------------------- run-iter! [37] 100.0% [54] 10698(0.5%) 0(0.0%) gen-series! ...iff-of-prods/src/mainloop.rkt:129:0 for-loop [64] 100.0% ------------------------------------------------------------------------------------------- run-iter! [37] 100.0% [55] 8664(0.4%) 0(0.0%) finalize-iter! ...-of-prods/src/mainloop.rkt:169:0 ??? [121] 100.0% ------------------------------------------------------------------------------------------- make-multiplication-subnode [43] 100.0% [56] 2154(0.1%) 0(0.0%) for-loop ...iff-of-prods/src/core/reduce.rkt:242:3 make-multiplication-subsubsubnode [66] 51.0% mterm->expr [75] 49.0% ------------------------------------------------------------------------------------------- run-iter! [37] 100.0% [57] 1062(0.1%) 0(0.0%) gen-rewrites! ...f-of-prods/src/mainloop.rkt:142:0 for-loop [67] 100.0% ------------------------------------------------------------------------------------------- make-multiplication-subnode [43] 100.0% [58] 50(0.0%) 0(0.0%) group-by68 ...acket/collects/racket/list.rkt:749:0 hash-update [68] 100.0% ------------------------------------------------------------------------------------------- simplify! [49] 99.1% [59] 1646502(79.2%) 0(0.0%) for-loop ...e/diff-of-prods/src/mainloop.rkt:159:6 ??? [69] 100.0% debug7 [191] 0.0% ------------------------------------------------------------------------------------------- apply-match [50] 100.0% [60] 1332798(64.1%) 5320(0.3%) for-loop ...-of-prods/src/core/simplify.rkt:145:10 merge-egraph-nodes! [70] 30.5% mk-enode! [78] 27.5% substitute-e [71] 19.9% loop! [90] 17.3% list-member? [164] 4.4% ------------------------------------------------------------------------------------------- apply-match [50] 23.1% for-loop [79] 31.0% for-loop [39] 45.9% [61] 382774(18.4%) 105872(5.1%) match-e .../diff-of-prods/src/core/ematch.rkt:46:0 for-loop [72] 50.7% for-loop [79] 10.2% ??? [121] 7.4% variable? [5] 4.0% list-cartesian-product [83] 2.5% loop [193] 1.6% curry* [86] 0.8% custom-in-set [237] 0.1% filter [236] 0.0% ------------------------------------------------------------------------------------------- loop [52] 16.7% argmin [51] 83.3% [62] 168928(8.1%) 2996(0.1%) for-loop ...e/diff-of-prods/src/programs.rkt:199:2 ??? [180] 72.9% ...prods/src/common.rkt:47:2 [123] 22.4% ??? [120] 2.9% ------------------------------------------------------------------------------------------- loop [52] 10.5% argmin [51] 89.5% [63] 23320(1.1%) 708(0.0%) expression-cost ...of-prods/src/programs.rkt:198:0 compile [73] 97.0% ------------------------------------------------------------------------------------------- gen-series! [54] 100.0% [64] 10698(0.5%) 0(0.0%) for-loop ...e/diff-of-prods/src/mainloop.rkt:135:7 taylor-alt [74] 100.0% ------------------------------------------------------------------------------------------- apply-match [50] 100.0% [65] 4478(0.2%) 2986(0.1%) reduce-to-single! ...ods/src/core/egraph.rkt:324:0 for-loop [76] 26.6% make-sequence [218] 6.7% ------------------------------------------------------------------------------------------- for-loop [56] 100.0% [66] 1098(0.1%) 0(0.0%) make-multiplication-subsubsubnode ...uce.rkt:262:0 mterm->expr [75] 100.0% ------------------------------------------------------------------------------------------- gen-rewrites! [57] 100.0% [67] 1062(0.1%) 0(0.0%) for-loop .../diff-of-prods/src/mainloop.rkt:147:11 ??? [77] 100.0% ------------------------------------------------------------------------------------------- group-by68 [58] 100.0% [68] 50(0.0%) 50(0.0%) hash-update ...cket/private/more-scheme.rkt:356:13 ------------------------------------------------------------------------------------------- run [18] 27.3% for-loop [59] 27.4% [69] 2042660(98.2%) 0(0.0%) ??? ...lects/racket/private/more-scheme.rkt:261:28 ??? [180] 45.4% profile-thunk16 [2] 27.3% run-improve50 [3] 27.3% loop [87] 0.1% ------------------------------------------------------------------------------------------- merge-egraph-nodes! [70] 5.5% for-loop [81] 8.6% for-loop [60] 85.9% [70] 406334(19.5%) 10314(0.5%) merge-egraph-nodes! ...s/src/core/egraph.rkt:152:0 update-leader! [80] 45.5% for-loop [82] 17.0% loop! [90] 12.6% for-loop [81] 12.4% merge-egraph-nodes! [70] 5.5% enode-merge! [84] 3.4% for-loop [197] 0.7% make-sequence [218] 0.3% ------------------------------------------------------------------------------------------- substitute-e [71] 5.8% for-loop [60] 94.2% [71] 265660(12.8%) 14052(0.7%) substitute-e ...-of-prods/src/core/ematch.rkt:71:0 mk-enode! [78] 87.7% substitute-e [71] 5.8% ??? [121] 1.7% variable? [5] 0.9% ------------------------------------------------------------------------------------------- match-e [61] 100.0% [72] 261452(12.6%) 77476(3.7%) for-loop ...iff-of-prods/src/core/ematch.rkt:59:11 for-loop [79] 60.3% list-cartesian-product [83] 9.1% loop [193] 4.1% curry* [86] 0.7% foldl [205] 0.7% curried [206] 0.4% filter [236] 0.3% ------------------------------------------------------------------------------------------- expression-cost [63] 100.0% [73] 22612(1.1%) 716(0.0%) compile ...ie/diff-of-prods/src/programs.rkt:175:0 hash-ref! [156] 96.8% ------------------------------------------------------------------------------------------- for-loop [64] 100.0% [74] 10698(0.5%) 0(0.0%) taylor-alt ...bie/diff-of-prods/src/glue.rkt:134:0 for-loop [85] 100.0% ------------------------------------------------------------------------------------------- for-loop [56] 49.0% make-multiplication-subsubsubnode [66] 51.0% [75] 2154(0.1%) 0(0.0%) mterm->expr ...-of-prods/src/core/reduce.rkt:270:0 f137 [178] 100.0% ------------------------------------------------------------------------------------------- reduce-to-single! [65] 100.0% [76] 1192(0.1%) 1192(0.1%) for-loop ...iff-of-prods/src/core/egraph.rkt:325:8 ------------------------------------------------------------------------------------------- for-loop [67] 100.0% [77] 1062(0.1%) 0(0.0%) ??? ...rbie/diff-of-prods/src/alternative.rkt:88:0 rewriter [88] 66.1% loop [193] 33.9% ------------------------------------------------------------------------------------------- mk-egraph [188] 0.0% expr->enode [196] 0.9% substitute-e [71] 38.5% for-loop [60] 60.6% [78] 605714(29.1%) 46906(2.3%) mk-enode! ...ff-of-prods/src/core/egraph.rkt:101:0 new-enode [89] 90.0% hash-has-key? [126] 2.1% mutable-set [107] 0.2% ------------------------------------------------------------------------------------------- match-e [61] 28.1% for-loop [72] 71.9% [79] 232268(11.2%) 12344(0.6%) for-loop ...iff-of-prods/src/core/ematch.rkt:65:37 match-e [61] 91.6% ??? [92] 3.9% ------------------------------------------------------------------------------------------- apply-match [50] 4.9% merge-egraph-nodes! [70] 95.1% [80] 226254(10.9%) 19388(0.9%) update-leader! ...-prods/src/core/egraph.rkt:217:0 for-loop [91] 85.9% update-en-expr [202] 2.4% custom-set-union! [96] 1.4% make-sequence [218] 0.8% mutable-set [107] 0.6% hash-ref! [156] 0.3% ------------------------------------------------------------------------------------------- merge-egraph-nodes! [70] 100.0% [81] 85212(4.1%) 0(0.0%) for-loop ...ff-of-prods/src/core/egraph.rkt:200:10 merge-egraph-nodes! [70] 81.1% loop! [90] 18.9% ------------------------------------------------------------------------------------------- merge-egraph-nodes! [70] 100.0% [82] 70276(3.4%) 56018(2.7%) for-loop ...iff-of-prods/src/core/egraph.rkt:232:6 update-en-expr [202] 20.3% ------------------------------------------------------------------------------------------- match-e [61] 20.7% list-cartesian-product [83] 28.2% for-loop [72] 51.1% [83] 41792(2.0%) 33172(1.6%) list-cartesian-product ...src/core/ematch.rkt:20:0 list-cartesian-product [83] 28.2% for-loop [94] 15.1% ------------------------------------------------------------------------------------------- merge-egraph-nodes! [70] 100.0% [84] 14148(0.7%) 4000(0.2%) enode-merge! ...-of-prods/src/core/enode.rkt:129:0 adopt-enode! [93] 61.8% custom-set-intersect! [98] 9.9% ------------------------------------------------------------------------------------------- taylor-alt [74] 100.0% [85] 10698(0.5%) 0(0.0%) for-loop ...erbie/diff-of-prods/src/glue.rkt:139:6 ??? [152] 100.0% ------------------------------------------------------------------------------------------- for-loop [72] 37.8% match-e [61] 62.2% [86] 5398(0.3%) 1390(0.1%) curry* ...racket/collects/racket/function.rkt:44:2 procedure-arity [95] 74.2% ------------------------------------------------------------------------------------------- run-improve50 [3] 28.4% ??? [69] 71.6% [87] 4596(0.2%) 0(0.0%) loop .../herbie/diff-of-prods/src/points.rkt:193:2 loop [97] 52.6% make-exacts* [108] 29.9% loop [109] 16.2% for-loop [101] 1.3% ------------------------------------------------------------------------------------------- ??? [77] 25.7% matcher [111] 74.3% [88] 702(0.0%) 0(0.0%) rewriter ...ff-of-prods/src/core/matcher.rkt:131:2 for-loop [100] 74.3% *rules* [99] 25.7% ------------------------------------------------------------------------------------------- mk-enode! [78] 100.0% [89] 545040(26.2%) 1236(0.1%) new-enode ...diff-of-prods/src/core/enode.rkt:97:0 type-of-enode-expr [102] 98.6% set [105] 0.8% mutable-set [107] 0.3% ------------------------------------------------------------------------------------------- for-loop [81] 3.6% merge-egraph-nodes! [70] 15.9% loop [193] 30.5% for-loop [60] 50.0% [90] 321652(15.5%) 65400(3.1%) loop! ...ie/diff-of-prods/src/core/enode.rkt:192:2 custom-set-union [104] 38.5% loop [193] 33.7% set [105] 11.0% update-en-expr [202] 5.5% ------------------------------------------------------------------------------------------- update-leader! [80] 100.0% [91] 194424(9.3%) 4904(0.2%) for-loop ...iff-of-prods/src/core/egraph.rkt:222:6 for-loop [103] 97.3% update-en-expr [202] 0.2% ------------------------------------------------------------------------------------------- for-loop [39] 9.8% for-loop [79] 90.2% [92] 11282(0.5%) 5420(0.3%) ??? ...rbie/diff-of-prods/src/core/ematch.rkt:50:5 for-loop [106] 46.0% custom-in-set [237] 6.0% ------------------------------------------------------------------------------------------- enode-merge! [84] 100.0% [93] 8742(0.4%) 3018(0.1%) adopt-enode! ...-of-prods/src/core/enode.rkt:105:0 custom-set-union [104] 65.5% ------------------------------------------------------------------------------------------- list-cartesian-product [83] 100.0% [94] 8620(0.4%) 8620(0.4%) for-loop ...diff-of-prods/src/core/ematch.rkt:24:8 ------------------------------------------------------------------------------------------- curry* [86] 100.0% [95] 4008(0.2%) 4008(0.2%) procedure-arity ...ket/private/norm-arity.rkt:7:27 ------------------------------------------------------------------------------------------- update-leader! [80] 100.0% [96] 3166(0.2%) 1952(0.1%) custom-set-union! ...t/private/set-types.rkt:245:0 for-loop [110] 38.3% ------------------------------------------------------------------------------------------- loop [87] 100.0% [97] 2416(0.1%) 0(0.0%) loop .../herbie/diff-of-prods/src/points.rkt:151:2 make-exacts* [108] 44.0% eval-prog [145] 32.5% loop [109] 23.6% ------------------------------------------------------------------------------------------- enode-merge! [84] 100.0% [98] 1406(0.1%) 1306(0.1%) custom-set-intersect! ...ivate/set-types.rkt:269:0 for-loop [112] 7.1% ------------------------------------------------------------------------------------------- rewriter [88] 100.0% [99] 702(0.0%) 0(0.0%) *rules* ...iff-of-prods/src/syntax/rules.rkt:493:0 for-loop [197] 57.0% ormap [209] 43.0% ------------------------------------------------------------------------------------------- rewriter [88] 100.0% [100] 702(0.0%) 0(0.0%) for-loop ...f-of-prods/src/core/matcher.rkt:134:10 matcher [111] 100.0% ------------------------------------------------------------------------------------------- loop [87] 100.0% [101] 62(0.0%) 0(0.0%) for-loop ...ie/diff-of-prods/src/points.rkt:200:24 for-loop [113] 100.0% ------------------------------------------------------------------------------------------- new-enode [89] 100.0% [102] 537270(25.8%) 11400(0.5%) type-of-enode-expr ...rods/src/core/enode.rkt:68:0 get-sigs [114] 97.8% parse-loop12 [187] 0.1% ------------------------------------------------------------------------------------------- for-loop [91] 100.0% [103] 189154(9.1%) 1808(0.1%) for-loop ...iff-of-prods/src/core/egraph.rkt:223:8 hash-update! [115] 99.0% ------------------------------------------------------------------------------------------- adopt-enode! [93] 4.0% loop! [90] 96.0% [104] 141408(6.8%) 49636(2.4%) custom-set-union ...et/private/set-types.rkt:168:0 for-loop [116] 56.0% for-loop [117] 8.9% ------------------------------------------------------------------------------------------- new-enode [89] 5.9% loop! [90] 94.1% [105] 77394(3.7%) 77394(3.7%) set ...collects/racket/private/set-types.rkt:981:0 ------------------------------------------------------------------------------------------- ??? [92] 100.0% [106] 5186(0.2%) 3202(0.2%) for-loop ...diff-of-prods/src/core/ematch.rkt:51:7 ??? [121] 38.3% ------------------------------------------------------------------------------------------- mk-enode! [78] 27.0% update-leader! [80] 34.7% new-enode [89] 38.3% [107] 4132(0.2%) 3388(0.2%) mutable-set .../racket/private/set-types.rkt:999:0 for-loop [118] 18.0% ------------------------------------------------------------------------------------------- loop [97] 43.6% loop [87] 56.4% [108] 2434(0.1%) 0(0.0%) make-exacts* ...diff-of-prods/src/points.rkt:138:0 loop [193] 53.1% map [181] 37.4% eval-prog [145] 9.5% ------------------------------------------------------------------------------------------- loop [97] 43.3% loop [87] 56.7% [109] 1316(0.1%) 0(0.0%) loop .../herbie/diff-of-prods/src/points.rkt:141:4 map [181] 100.0% ------------------------------------------------------------------------------------------- custom-set-union! [96] 100.0% [110] 1214(0.1%) 1214(0.1%) for-loop ...cts/racket/private/set-types.rkt:253:4 ------------------------------------------------------------------------------------------- matcher [111] 8.3% for-loop [119] 41.7% for-loop [100] 50.0% [111] 702(0.0%) 0(0.0%) matcher ...iff-of-prods/src/core/matcher.rkt:167:2 rewriter [88] 50.0% for-loop [119] 41.7% matcher [111] 8.3% ------------------------------------------------------------------------------------------- custom-set-intersect! [98] 100.0% [112] 100(0.0%) 100(0.0%) for-loop ...cts/racket/private/set-types.rkt:272:4 ------------------------------------------------------------------------------------------- for-loop [101] 100.0% [113] 62(0.0%) 62(0.0%) for-loop ...ie/diff-of-prods/src/points.rkt:201:26 ------------------------------------------------------------------------------------------- type-of-enode-expr [102] 100.0% [114] 525460(25.3%) 7188(0.3%) get-sigs ...e/diff-of-prods/src/type-check.rkt:5:0 ??? [120] 39.9% ??? [180] 29.5% ??? [121] 15.1% ...prods/src/common.rkt:47:2 [123] 14.0% ------------------------------------------------------------------------------------------- for-loop [103] 100.0% [115] 187346(9.0%) 3592(0.2%) hash-update! ...ket/private/more-scheme.rkt:362:13 ??? [122] 98.1% ------------------------------------------------------------------------------------------- custom-set-union [104] 100.0% [116] 79164(3.8%) 28378(1.4%) for-loop ...cts/racket/private/set-types.rkt:174:3 for-loop [124] 64.2% ------------------------------------------------------------------------------------------- custom-set-union [104] 100.0% [117] 12608(0.6%) 12608(0.6%) for-loop ...cts/racket/private/set-types.rkt:152:2 ------------------------------------------------------------------------------------------- mutable-set [107] 100.0% [118] 744(0.0%) 744(0.0%) for-loop ...cts/racket/private/set-types.rkt:943:2 ------------------------------------------------------------------------------------------- matcher [111] 100.0% [119] 702(0.0%) 0(0.0%) for-loop ...f-of-prods/src/core/matcher.rkt:183:21 matcher [111] 100.0% ------------------------------------------------------------------------------------------- f137 [178] 0.3% for-loop [62] 2.3% get-sigs [114] 97.4% [120] 215542(10.4%) 11092(0.5%) ??? ...ts/racket/contract/private/arr-i.rkt:804:10 ??? [127] 51.3% for-loop [128] 37.2% get/build-late-neg-projection [143] 5.0% ??? [204] 0.8% ??? [207] 0.1% ------------------------------------------------------------------------------------------- debug7 [191] 0.0% free-variables [13] 0.2% f137 [178] 0.3% ??? [234] 0.7% setfindf [22] 0.8% for-loop [106] 0.9% finalize-iter! [55] 4.0% substitute-e [71] 5.7% variable? [5] 20.3% match-e [61] 29.5% get-sigs [114] 37.2% [121] 213896(10.3%) 102604(4.9%) ??? ...contract/private/arrow-val-first.rkt:357:18 hash-has-key? [126] 47.2% for-loop [131] 3.8% ??? [234] 0.6% atab-add-altns [132] 0.2% ??? [133] 0.2% ------------------------------------------------------------------------------------------- hash-update! [115] 100.0% [122] 183754(8.8%) 2720(0.1%) ??? ...ie/diff-of-prods/src/core/egraph.rkt:225:24 for-loop [125] 98.0% make-sequence [218] 0.5% ------------------------------------------------------------------------------------------- ??? [152] 0.0% ??? [180] 0.3% f137 [178] 0.3% for-loop [62] 33.6% get-sigs [114] 65.7% [123] 112324(5.4%) 34714(1.7%) ...prods/src/common.rkt:47:2 ...e/arr-i.rkt:906:19 ??? [129] 36.3% ??? [130] 31.6% ------------------------------------------------------------------------------------------- for-loop [116] 100.0% [124] 50786(2.4%) 50786(2.4%) for-loop ...cts/racket/private/set-types.rkt:178:5 ------------------------------------------------------------------------------------------- ??? [122] 100.0% [125] 180094(8.7%) 152358(7.3%) for-loop ...ff-of-prods/src/core/egraph.rkt:226:26 update-en-expr [202] 15.4% ------------------------------------------------------------------------------------------- mk-enode! [78] 11.1% ??? [121] 88.9% [126] 113628(5.5%) 32404(1.6%) hash-has-key? ...et/private/more-scheme.rkt:368:13 ??? [185] 67.6% ??? [189] 3.9% ------------------------------------------------------------------------------------------- ??? [120] 100.0% [127] 110598(5.3%) 4574(0.2%) ??? ...ects/racket/contract/private/hash.rkt:217:4 ??? [134] 95.9% ------------------------------------------------------------------------------------------- for-loop [194] 21.9% ??? [120] 78.1% [128] 102834(4.9%) 16396(0.8%) for-loop ...racket/contract/private/hash.rkt:239:6 ??? [215] 81.5% ??? [235] 2.6% ------------------------------------------------------------------------------------------- for-loop [227] 3.5% ??? [215] 14.0% ...prods/src/common.rkt:47:2 [123] 82.5% [129] 40812(2.0%) 9202(0.4%) ??? ...ects/racket/contract/private/list.rkt:342:4 ??? [215] 73.0% ??? [234] 7.8% ??? [204] 6.4% ------------------------------------------------------------------------------------------- ...prods/src/common.rkt:47:2 [123] 100.0% [130] 35500(1.7%) 8462(0.4%) ??? ...s/racket/contract/private/arr-i.rkt:1268:39 ??? [186] 41.7% return/no-unsupplied [226] 22.7% assoc-ref [136] 11.8% ------------------------------------------------------------------------------------------- ??? [121] 100.0% [131] 8254(0.4%) 0(0.0%) for-loop ...f-of-prods/src/core/alt-table.rkt:51:2 atab-add-altn [135] 100.0% ------------------------------------------------------------------------------------------- ??? [121] 100.0% [132] 410(0.0%) 0(0.0%) atab-add-altns ...rods/src/core/alt-table.rkt:50:0 atab-add-altn [135] 100.0% ------------------------------------------------------------------------------------------- ??? [121] 100.0% [133] 358(0.0%) 0(0.0%) ??? ...e/diff-of-prods/src/core/alt-table.rkt:54:0 ??? [152] 100.0% ------------------------------------------------------------------------------------------- ??? [127] 100.0% [134] 106024(5.1%) 6310(0.3%) ??? ...ects/racket/contract/private/list.rkt:169:2 ??? [137] 94.0% ------------------------------------------------------------------------------------------- atab-add-altns [132] 4.7% for-loop [131] 95.3% [135] 8664(0.4%) 0(0.0%) atab-add-altn ...rods/src/core/alt-table.rkt:208:0 best-and-tied-at-points [138] 100.0% ------------------------------------------------------------------------------------------- ??? [130] 100.0% [136] 4172(0.2%) 4172(0.2%) assoc-ref ...collects/racket/private/dict.rkt:56:0 ------------------------------------------------------------------------------------------- ??? [134] 100.0% [137] 99714(4.8%) 6102(0.3%) ??? ...ects/racket/contract/private/list.rkt:678:5 for-loop [139] 93.9% ------------------------------------------------------------------------------------------- atab-add-altn [135] 100.0% [138] 8664(0.4%) 0(0.0%) best-and-tied-at-points ...ore/alt-table.rkt:122:0 errors [140] 95.3% for-loop [141] 4.7% ------------------------------------------------------------------------------------------- ??? [137] 100.0% [139] 93612(4.5%) 16990(0.8%) for-loop ...racket/contract/private/list.rkt:680:9 add-list-context [142] 50.0% get/build-late-neg-projection [143] 31.8% ------------------------------------------------------------------------------------------- option-on-expr [214] 0.6% composed [174] 4.1% best-and-tied-at-points [138] 95.3% [140] 8664(0.4%) 0(0.0%) errors ...erbie/diff-of-prods/src/points.rkt:218:0 for-loop [144] 82.3% eval-prog [145] 17.7% ------------------------------------------------------------------------------------------- best-and-tied-at-points [138] 100.0% [141] 408(0.0%) 408(0.0%) for-loop ...of-prods/src/core/alt-table.rkt:124:16 ------------------------------------------------------------------------------------------- for-loop [139] 100.0% [142] 46824(2.3%) 46824(2.3%) add-list-context ...ontract/private/list.rkt:752:0 ------------------------------------------------------------------------------------------- ??? [148] 8.4% ??? [120] 18.1% for-loop [139] 73.4% [143] 40580(2.0%) 4834(0.2%) get/build-late-neg-projection ...te/guts.rkt:691:0 ??? [146] 76.7% ??? [148] 13.1% ------------------------------------------------------------------------------------------- errors [140] 100.0% [144] 7128(0.3%) 1058(0.1%) for-loop ...bie/diff-of-prods/src/points.rkt:221:4 ??? [147] 80.2% ??? [152] 2.8% ulp-difference [150] 2.1% ------------------------------------------------------------------------------------------- make-exacts* [108] 9.1% loop [97] 30.7% errors [140] 60.2% [145] 2552(0.1%) 502(0.0%) eval-prog .../diff-of-prods/src/programs.rkt:148:0 hash-ref! [156] 35.7% f137 [178] 30.6% ??? [149] 14.0% ------------------------------------------------------------------------------------------- get/build-late-neg-projection [143] 100.0% [146] 33140(1.6%) 8866(0.4%) ??? ...cts/racket/contract/private/prop.rkt:314:12 build-compound-type-name [151] 73.2% ------------------------------------------------------------------------------------------- loop [247] 1.1% loop [193] 35.8% for-loop [144] 63.1% [147] 9070(0.4%) 60(0.0%) ??? ...herbie/diff-of-prods/src/programs.rkt:154:4 ??? [153] 90.0% ??? [152] 5.3% ??? [154] 4.1% ------------------------------------------------------------------------------------------- get/build-late-neg-projection [143] 100.0% [148] 8762(0.4%) 1882(0.1%) ??? ...ects/racket/contract/private/hash.rkt:211:2 get/build-late-neg-projection [143] 78.5% ------------------------------------------------------------------------------------------- eval-prog [145] 100.0% [149] 358(0.0%) 0(0.0%) ??? ...collects/racket/private/qq-and-or.rkt:155:9 ??? [155] 100.0% ------------------------------------------------------------------------------------------- for-loop [144] 100.0% [150] 150(0.0%) 100(0.0%) ulp-difference ...diff-of-prods/src/float.rkt:19:0 ??? [186] 33.3% ------------------------------------------------------------------------------------------- contract-struct-name [157] 23.1% ??? [146] 76.9% [151] 24274(1.2%) 15086(0.7%) build-compound-type-name ...private/guts.rkt:448:0 contract-struct-name [157] 55.0% ------------------------------------------------------------------------------------------- ??? [240] 0.4% loop [193] 0.9% for-loop [144] 1.6% ??? [133] 2.8% ??? [147] 3.8% f137 [178] 6.2% loop [23] 24.6% ??? [180] 29.9% for-loop [85] 29.9% [152] 12682(0.6%) 152(0.0%) ??? ...tract/private/arrow-higher-order.rkt:342:33 ??? [180] 40.3% approximate9 [7] 29.9% hash-ref! [156] 24.6% best-alt [162] 2.8% ??? [234] 0.8% ...prods/src/common.rkt:47:2 [123] 0.4% ------------------------------------------------------------------------------------------- ??? [147] 100.0% [153] 8162(0.4%) 5400(0.3%) ??? ...acket/collects/racket/private/kw.rkt:444:14 bf* [158] 13.3% ??? [159] 6.8% ??? [160] 5.6% ??? [168] 4.0% ...higher-order.rkt:346:33 [163] 2.1% ??? [235] 2.0% ------------------------------------------------------------------------------------------- ??? [147] 100.0% [154] 368(0.0%) 0(0.0%) ??? ...contract/private/../../private/kw.rkt:761:9 real->bigfloat [161] 100.0% ------------------------------------------------------------------------------------------- ??? [149] 100.0% [155] 358(0.0%) 358(0.0%) ??? ...ollects/racket/private/qq-and-or.rkt:164:21 ------------------------------------------------------------------------------------------- ??? [45] 0.1% for-loop [33] 0.2% first-nonzero-exp [47] 0.5% ??? [11] 0.8% eval-prog [145] 0.9% ??? [211] 1.5% loop [193] 1.7% update-leader! [80] 2.0% for-loop [198] 2.1% for-loop [41] 4.0% for-loop [24] 5.2% ??? [167] 7.4% ??? [152] 7.8% compile [73] 29.6% ??? [165] 34.3% [156] 34246(1.6%) 19442(0.9%) hash-ref! ...racket/private/more-scheme.rkt:373:13 ??? [165] 39.6% simplify [166] 8.7% ??? [167] 7.4% ??? [8] 5.8% ??? [9] 4.0% ??? [10] 2.1% parse-loop12 [187] 1.5% ??? [11] 1.0% bigfloat-hash [169] 0.9% f137 [178] 0.6% ??? [16] 0.1% ------------------------------------------------------------------------------------------- build-compound-type-name [151] 100.0% [157] 17522(0.8%) 9188(0.4%) contract-struct-name ...ract/private/prop.rkt:89:0 build-compound-type-name [151] 55.8% ------------------------------------------------------------------------------------------- ??? [153] 100.0% [158] 1088(0.1%) 0(0.0%) bf* ...ath/private/bigfloat/bigfloat-mpfr.rkt:95:0 ??? [168] 100.0% ------------------------------------------------------------------------------------------- ??? [153] 100.0% [159] 556(0.0%) 406(0.0%) ??? .../diff-of-prods/src/syntax/syntax.rkt:122:17 ??? [186] 18.0% list-member? [164] 9.0% ------------------------------------------------------------------------------------------- ??? [153] 100.0% [160] 456(0.0%) 456(0.0%) ??? ...rivate/unconstrained-domain-arrow.rkt:40:13 ------------------------------------------------------------------------------------------- ??? [154] 100.0% [161] 368(0.0%) 368(0.0%) real->bigfloat .../private/bigfloat/mpfr.rkt:451:0 ------------------------------------------------------------------------------------------- ??? [152] 100.0% [162] 358(0.0%) 0(0.0%) best-alt ...herbie/diff-of-prods/src/glue.rkt:71:0 argmins [170] 100.0% ------------------------------------------------------------------------------------------- ??? [153] 100.0% [163] 170(0.0%) 0(0.0%) ...higher-order.rkt:346:33 (unknown source) ??? [215] 100.0% ------------------------------------------------------------------------------------------- ??? [159] 0.1% for-loop [60] 99.9% [164] 58132(2.8%) 1152(0.1%) list-member? ...llects/racket/private/set.rkt:24:0 loop [171] 89.1% member [172] 8.9% ------------------------------------------------------------------------------------------- hash-ref! [156] 100.0% [165] 18380(0.9%) 3140(0.2%) ??? ...herbie/diff-of-prods/src/programs.rkt:183:5 hash-ref! [156] 88.7% loop [193] 4.6% ------------------------------------------------------------------------------------------- taylor-quotient [32] 3.4% hash-ref! [156] 96.6% [166] 9712(0.5%) 0(0.0%) simplify ...diff-of-prods/src/core/reduce.rkt:16:0 parse-loop12 [187] 71.8% f137 [178] 24.2% debug7 [191] 3.4% make-multiplication-node [28] 0.5% ------------------------------------------------------------------------------------------- hash-ref! [156] 100.0% [167] 9242(0.4%) 0(0.0%) ??? ...bie/diff-of-prods/src/core/taylor.rkt:44:15 hash-ref! [156] 100.0% ------------------------------------------------------------------------------------------- ??? [153] 23.2% bf* [158] 76.8% [168] 1416(0.1%) 0(0.0%) ??? ...-racket/utils/simple-result-arrow.rkt:39:12 bfmul [173] 84.0% bfsqrt [176] 16.0% ------------------------------------------------------------------------------------------- hash-ref! [156] 100.0% [169] 910(0.0%) 0(0.0%) bigfloat-hash ...h/private/bigfloat/mpfr.rkt:165:0 bfcanonicalize [175] 87.0% sig+exp->bigfloat [177] 13.0% ------------------------------------------------------------------------------------------- best-alt [162] 100.0% [170] 358(0.0%) 0(0.0%) argmins ...rbie/diff-of-prods/src/common.rkt:145:0 composed [174] 100.0% ------------------------------------------------------------------------------------------- list-member? [164] 100.0% [171] 51784(2.5%) 51784(2.5%) loop (unknown source) ------------------------------------------------------------------------------------------- list-member? [164] 100.0% [172] 5196(0.2%) 5196(0.2%) member (unknown source) ------------------------------------------------------------------------------------------- ??? [168] 100.0% [173] 1190(0.1%) 494(0.0%) bfmul ...-lib/math/private/bigfloat/mpfr.rkt:819:4 ??? [179] 58.5% ------------------------------------------------------------------------------------------- argmins [170] 32.0% f137 [178] 68.0% [174] 1118(0.1%) 0(0.0%) composed ...ollects/racket/private/list.rkt:321:16 f137 [178] 34.3% parse-loop12 [187] 33.6% errors [140] 32.0% ------------------------------------------------------------------------------------------- bigfloat-hash [169] 100.0% [175] 792(0.0%) 792(0.0%) bfcanonicalize .../private/bigfloat/mpfr.rkt:155:0 ------------------------------------------------------------------------------------------- ??? [168] 100.0% [176] 226(0.0%) 226(0.0%) bfsqrt ...lib/math/private/bigfloat/mpfr.rkt:616:4 ------------------------------------------------------------------------------------------- bigfloat-hash [169] 100.0% [177] 118(0.0%) 118(0.0%) sig+exp->bigfloat ...ivate/bigfloat/mpfr.rkt:385:0 ------------------------------------------------------------------------------------------- loop [15] 0.7% for-loop [46] 0.7% composed [174] 0.8% approximate9 [7] 1.0% eval-prog [145] 1.8% simplify-node [12] 1.8% loop [193] 2.5% split-table [48] 2.9% for-loop [14] 3.6% hash-ref! [156] 4.2% parse-loop12 [187] 4.5% append-map [29] 5.4% map [181] 7.0% simplify [166] 7.6% f137 [178] 10.7% mterm->expr [75] 14.8% eval-const-expr [26] 30.2% [178] 9252(0.4%) 714(0.0%) f137 .../collects/racket/match/compiler.rkt:507:40 map [181] 18.9% ??? [182] 15.0% ??? [180] 14.9% f137 [178] 10.7% append-map [29] 10.4% ??? [120] 7.3% ??? [121] 4.3% gather-multiplicative-terms [183] 3.6% loop [193] 2.3% ??? [152] 1.8% composed [174] 1.5% loop [15] 1.4% ...prods/src/common.rkt:47:2 [123] 1.3% option-on-expr [214] 0.6% ------------------------------------------------------------------------------------------- bfmul [173] 100.0% [179] 696(0.0%) 696(0.0%) ??? .../share/racket/collects/ffi/unsafe.rkt:861:4 ------------------------------------------------------------------------------------------- simplify-alt [44] 0.0% f137 [178] 0.0% ??? [152] 0.4% ??? [180] 0.8% for-loop [62] 2.0% get-sigs [114] 2.5% ??? [69] 46.6% for-loop [184] 46.7% [180] 2064354(99.3%) 68046(3.3%) ??? ...llects/racket/private/norm-define.rkt:53:83 for-loop [184] 46.7% iterate-egraph!13 [1] 42.9% loop [4] 4.4% ??? [185] 3.1% ??? [180] 0.8% ??? [152] 0.3% mk-egraph [188] 0.1% ??? [186] 0.1% return/no-unsupplied [226] 0.1% ??? [215] 0.1% *simplify-rules* [190] 0.0% dict? [242] 0.0% ??? [189] 0.0% ...prods/src/common.rkt:47:2 [123] 0.0% extract-smallest [192] 0.0% debug7 [191] 0.0% ------------------------------------------------------------------------------------------- parse-loop12 [187] 14.0% make-exacts* [108] 18.0% loop [109] 26.0% f137 [178] 42.0% [181] 5056(0.2%) 0(0.0%) map ...acket/collects/racket/private/map.rkt:20:13 loop [193] 47.8% parse-loop12 [187] 30.5% f137 [178] 17.9% ??? [211] 3.8% ------------------------------------------------------------------------------------------- f137 [178] 100.0% [182] 1392(0.1%) 0(0.0%) ??? ...tract/private/arrow-higher-order.rkt:336:46 ??? [234] 100.0% ------------------------------------------------------------------------------------------- f137 [178] 100.0% [183] 334(0.0%) 334(0.0%) gather-multiplicative-terms ...re/reduce.rkt:116:0 ------------------------------------------------------------------------------------------- ??? [180] 100.0% [184] 2020570(97.2%) 332(0.0%) for-loop ...f-of-prods/src/core/simplify.rkt:63:12 ??? [180] 100.0% ??? [199] 0.0% ------------------------------------------------------------------------------------------- hash-has-key? [126] 28.6% ??? [180] 71.4% [185] 268332(12.9%) 86238(4.1%) ??? ...ects/racket/contract/private/list.rkt:737:4 for-loop [194] 53.6% ??? [203] 11.8% ??? [215] 1.3% successfully-got-the-right-kind-of-function [208] 0.5% arrow-higher-order:lnp [229] 0.4% ??? [234] 0.2% ------------------------------------------------------------------------------------------- ulp-difference [150] 0.3% ??? [159] 0.5% ??? [180] 22.8% ??? [130] 76.4% [186] 19360(0.9%) 3462(0.2%) ??? ...racket/collects/racket/private/kw.rkt:761:9 ??? [195] 69.3% ??? [234] 12.9% ------------------------------------------------------------------------------------------- composed [174] 1.3% loop [193] 2.3% append-map [29] 2.3% type-of-enode-expr [102] 4.2% map [181] 5.9% hash-ref! [156] 7.3% for-loop [27] 12.2% simplify [166] 23.4% parse-loop12 [187] 41.2% [187] 9866(0.5%) 4764(0.2%) parse-loop12 ...s/racket/match/compiler.rkt:418:15 parse-loop12 [187] 41.2% for-loop [198] 12.2% loop [193] 9.7% f137 [178] 5.5% make-multiplication-node [28] 4.2% parse-app [201] 3.5% append-map [29] 1.8% simplify-node [12] 1.8% for-loop [14] 1.4% map [181] 0.8% ------------------------------------------------------------------------------------------- ??? [180] 100.0% [188] 5848(0.3%) 0(0.0%) mk-egraph ...ff-of-prods/src/core/egraph.rkt:123:0 expr->enode [196] 99.1% mk-enode! [78] 0.9% ------------------------------------------------------------------------------------------- ??? [180] 19.3% hash-has-key? [126] 80.7% [189] 5514(0.3%) 5514(0.3%) ??? ...ects/racket/contract/private/hash.rkt:245:7 ------------------------------------------------------------------------------------------- ??? [180] 100.0% [190] 992(0.0%) 0(0.0%) *simplify-rules* ...ods/src/syntax/rules.rkt:497:0 for-loop [197] 100.0% ------------------------------------------------------------------------------------------- for-loop [59] 11.3% ??? [180] 13.5% simplify [166] 75.2% [191] 444(0.0%) 50(0.0%) debug7 ...herbie/diff-of-prods/src/debug.rkt:102:0 return/no-unsupplied [226] 75.2% ??? [121] 13.5% ------------------------------------------------------------------------------------------- ??? [180] 100.0% [192] 326(0.0%) 0(0.0%) extract-smallest ...ds/src/core/simplify.rkt:191:0 hash-keys [200] 100.0% ------------------------------------------------------------------------------------------- ??? [77] 0.0% make-exacts* [108] 0.0% map [181] 0.0% f137 [178] 0.1% append-map [29] 0.3% ??? [165] 0.3% parse-loop12 [187] 0.7% map-enodes [21] 0.8% match-e [61] 3.2% for-loop [72] 3.5% loop! [90] 16.0% loop [193] 75.0% [193] 251472(12.1%) 23686(1.1%) loop ...cket/collects/racket/private/map.rkt:25:19 loop [193] 75.0% loop! [90] 15.6% foldl [205] 1.4% curried [206] 1.3% for-loop [6] 0.7% parse-loop12 [187] 0.6% hash-ref! [156] 0.3% f137 [178] 0.3% option-on-expr [214] 0.1% ??? [211] 0.1% ??? [147] 0.0% set-precompute! [210] 0.0% ??? [152] 0.0% ------------------------------------------------------------------------------------------- ??? [185] 100.0% [194] 143954(6.9%) 75838(3.6%) for-loop ...acket/contract/private/list.rkt:743:12 ??? [203] 26.1% for-loop [128] 15.7% ??? [204] 4.6% arrow-higher-order:lnp [229] 0.9% successfully-got-the-right-kind-of-function [208] 0.1% ------------------------------------------------------------------------------------------- ??? [186] 100.0% [195] 13408(0.6%) 12068(0.6%) ??? ...s/racket/contract/private/arr-i.rkt:1233:27 ??? [207] 10.0% ------------------------------------------------------------------------------------------- mk-egraph [188] 26.5% expr->enode [196] 73.5% [196] 5798(0.3%) 332(0.0%) expr->enode ...-of-prods/src/core/egraph.rkt:124:2 expr->enode [196] 73.5% mk-enode! [78] 25.3% ------------------------------------------------------------------------------------------- *rules* [99] 8.0% *simplify-rules* [190] 19.9% merge-egraph-nodes! [70] 72.1% [197] 4982(0.2%) 2926(0.1%) for-loop ...rbie/diff-of-prods/src/common.rkt:94:9 update-en-expr [202] 14.3% flag-set? [220] 13.7% ormap [209] 13.2% ------------------------------------------------------------------------------------------- parse-loop12 [187] 100.0% [198] 4296(0.2%) 0(0.0%) for-loop ...ff-of-prods/src/core/taylor.rkt:490:59 hash-ref! [156] 100.0% ------------------------------------------------------------------------------------------- eval-const-expr [26] 48.4% for-loop [184] 51.6% [199] 686(0.0%) 0(0.0%) ??? ...cket/collects/racket/private/kw.rkt:1633:36 ??? [212] 100.0% ------------------------------------------------------------------------------------------- extract-smallest [192] 47.7% one-iter [17] 52.3% [200] 684(0.0%) 0(0.0%) hash-keys .../collects/racket/private/hash.rkt:2:2 loop [213] 100.0% ------------------------------------------------------------------------------------------- eval-const-expr [26] 11.0% parse-loop12 [187] 76.7% [201] 454(0.0%) 454(0.0%) parse-app .../collects/racket/private/kw.rkt:951:2 ------------------------------------------------------------------------------------------- for-loop [91] 0.4% for-loop [197] 0.8% update-leader! [80] 6.4% for-loop [82] 16.9% for-loop [125] 32.9% loop! [90] 42.6% [202] 84346(4.1%) 84346(4.1%) update-en-expr ...-prods/src/core/egraph.rkt:211:0 ------------------------------------------------------------------------------------------- ??? [185] 45.8% for-loop [194] 54.2% [203] 69268(3.3%) 36190(1.7%) ??? ...private/unconstrained-domain-arrow.rkt:74:4 make-keyword-procedure [216] 47.8% ------------------------------------------------------------------------------------------- ??? [120] 15.9% ??? [129] 23.9% for-loop [194] 60.2% [204] 10910(0.5%) 4434(0.2%) ??? ...ects/racket/contract/private/hash.rkt:222:6 check-hash/c [217] 59.4% ------------------------------------------------------------------------------------------- for-loop [72] 33.6% loop [193] 66.4% [205] 7140(0.3%) 4366(0.2%) foldl ...et/collects/racket/private/list.rkt:229:4 merge2 [219] 38.9% ------------------------------------------------------------------------------------------- for-loop [72] 17.2% for-loop [6] 21.3% loop [193] 61.5% [206] 6640(0.3%) 6640(0.3%) curried ...cket/collects/racket/function.rkt:71:18 ------------------------------------------------------------------------------------------- ??? [120] 15.2% ??? [195] 84.8% [207] 1580(0.1%) 1580(0.1%) ??? ...ects/racket/contract/private/prop.rkt:256:4 ------------------------------------------------------------------------------------------- for-loop [194] 7.8% ??? [185] 92.2% [208] 1366(0.1%) 946(0.0%) successfully-got-the-right-kind-of-function ...9:4 arity-checking-wrapper [221] 30.7% ------------------------------------------------------------------------------------------- *rules* [99] 31.5% for-loop [197] 68.5% [209] 960(0.0%) 300(0.0%) ormap ...et/collects/racket/private/map.rkt:105:13 flag-set? [220] 68.8% ------------------------------------------------------------------------------------------- loop [193] 100.0% [210] 772(0.0%) 104(0.0%) set-precompute! ...ods/src/core/simplify.rkt:172:0 make-sequence [218] 86.5% ------------------------------------------------------------------------------------------- map [181] 17.9% loop [193] 82.1% [211] 716(0.0%) 0(0.0%) ??? ...ket/collects/racket/private/list.rkt:323:18 hash-ref! [156] 100.0% ------------------------------------------------------------------------------------------- ??? [199] 100.0% [212] 686(0.0%) 0(0.0%) ??? ...tract/private/arrow-higher-order.rkt:354:44 ??? [215] 51.6% maybe-cons-kwd [222] 48.4% ------------------------------------------------------------------------------------------- hash-keys [200] 3.9% loop [213] 96.1% [213] 684(0.0%) 684(0.0%) loop ...acket/collects/racket/private/hash.rkt:3:4 loop [213] 96.1% ------------------------------------------------------------------------------------------- f137 [178] 17.6% loop [193] 82.4% [214] 306(0.0%) 0(0.0%) option-on-expr ...prods/src/core/regimes.rkt:103:0 sort-context-on-expr [223] 67.3% pick-errors [224] 16.3% errors [140] 16.3% ------------------------------------------------------------------------------------------- ...higher-order.rkt:346:33 [163] 0.1% ??? [212] 0.3% ??? [185] 2.7% ??? [180] 3.3% ??? [129] 28.6% for-loop [128] 65.0% [215] 128930(6.2%) 24752(1.2%) ??? ...cts/racket/contract/private/list.rkt:187:10 ??? [225] 62.7% ??? [129] 8.9% for-loop [227] 7.1% ??? [235] 2.1% ------------------------------------------------------------------------------------------- ??? [203] 100.0% [216] 33078(1.6%) 33078(1.6%) make-keyword-procedure ...ket/private/kw.rkt:260:4 ------------------------------------------------------------------------------------------- ??? [204] 100.0% [217] 6476(0.3%) 3084(0.1%) check-hash/c ...ket/contract/private/hash.rkt:83:0 flat-contract? [228] 52.4% ------------------------------------------------------------------------------------------- reduce-to-single! [65] 4.7% set-precompute! [210] 10.4% ??? [122] 14.7% merge-egraph-nodes! [70] 20.5% for-loop [40] 21.6% update-leader! [80] 28.1% [218] 6410(0.3%) 4756(0.2%) make-sequence ...ects/racket/private/for.rkt:509:2 ??? [230] 25.8% ------------------------------------------------------------------------------------------- foldl [205] 100.0% [219] 2774(0.1%) 2774(0.1%) merge2 ...e/diff-of-prods/src/core/ematch.rkt:31:0 ------------------------------------------------------------------------------------------- ormap [209] 49.1% for-loop [197] 50.9% [220] 1344(0.1%) 684(0.0%) flag-set? ...bie/diff-of-prods/src/config.rkt:32:0 return/no-unsupplied [226] 49.1% ------------------------------------------------------------------------------------------- successfully-got-the-right-kind-of-function [208]100.0% [221] 420(0.0%) 0(0.0%) arity-checking-wrapper ...w-higher-order.rkt:402:0 matches-arity-exactly? [231] 100.0% ------------------------------------------------------------------------------------------- ??? [212] 100.0% [222] 332(0.0%) 0(0.0%) maybe-cons-kwd ...ate/arrow-higher-order.rkt:498:0 arrow-higher-order:lnp [229] 100.0% ------------------------------------------------------------------------------------------- option-on-expr [214] 100.0% [223] 206(0.0%) 0(0.0%) sort-context-on-expr ...prods/src/points.rkt:115:0 ??? [232] 100.0% ------------------------------------------------------------------------------------------- option-on-expr [214] 100.0% [224] 50(0.0%) 0(0.0%) pick-errors ...of-prods/src/core/regimes.rkt:184:0 for-loop [233] 100.0% ------------------------------------------------------------------------------------------- ??? [215] 100.0% [225] 80798(3.9%) 6962(0.3%) ??? ...ects/racket/contract/private/list.rkt:686:7 ??? [234] 84.7% ??? [235] 6.7% ------------------------------------------------------------------------------------------- debug7 [191] 2.5% flag-set? [220] 4.8% ??? [180] 33.5% ??? [130] 59.2% [226] 13628(0.7%) 9116(0.4%) return/no-unsupplied ...ct/private/arr-i.rkt:533:0 filter [236] 33.1% ------------------------------------------------------------------------------------------- ??? [215] 100.0% [227] 9210(0.4%) 6362(0.3%) for-loop ...acket/contract/private/list.rkt:190:15 ??? [129] 30.9% ------------------------------------------------------------------------------------------- check-hash/c [217] 100.0% [228] 3392(0.2%) 3392(0.2%) flat-contract? .../contract/private/guts.rkt:111:0 ------------------------------------------------------------------------------------------- maybe-cons-kwd [222] 12.0% ??? [185] 40.1% for-loop [194] 47.9% [229] 2764(0.1%) 384(0.0%) arrow-higher-order:lnp ...w-higher-order.rkt:597:7 ??? [238] 86.1% ------------------------------------------------------------------------------------------- make-sequence [218] 100.0% [230] 1654(0.1%) 274(0.0%) ??? ...acket/collects/racket/private/for.rkt:429:7 custom-in-set [237] 83.4% ------------------------------------------------------------------------------------------- arity-checking-wrapper [221] 100.0% [231] 420(0.0%) 420(0.0%) matches-arity-exactly? ...te/arrow-common.rkt:70:0 ------------------------------------------------------------------------------------------- sort-context-on-expr [223] 100.0% [232] 206(0.0%) 0(0.0%) ??? ...cket/collects/racket/private/sort.rkt:403:3 generic-sort/key [239] 100.0% ------------------------------------------------------------------------------------------- pick-errors [224] 100.0% [233] 50(0.0%) 0(0.0%) for-loop ...ff-of-prods/src/core/regimes.rkt:186:2 ??? [240] 100.0% ------------------------------------------------------------------------------------------- ??? [152] 0.1% ??? [185] 0.7% ??? [121] 1.6% ??? [182] 1.7% ??? [186] 3.1% ??? [129] 7.9% ??? [225] 84.9% [234] 80610(3.9%) 72852(3.5%) ??? ...ects/racket/contract/private/guts.rkt:644:8 contract? [243] 4.9% dict? [242] 2.9% ??? [121] 1.9% ------------------------------------------------------------------------------------------- ??? [153] 1.5% for-loop [128] 24.1% ??? [215] 24.9% ??? [225] 49.4% [235] 10998(0.5%) 5850(0.3%) ??? ...ects/racket/contract/private/prop.rkt:493:4 ??? [241] 46.8% ------------------------------------------------------------------------------------------- one-iter [17] 0.7% match-e [61] 5.3% for-loop [40] 5.3% for-loop [72] 21.3% return/no-unsupplied [226] 67.3% [236] 6706(0.3%) 6706(0.3%) filter ...t/collects/racket/private/list.rkt:256:2 ------------------------------------------------------------------------------------------- setfindf [22] 11.4% ??? [92] 21.3% match-e [61] 23.8% ??? [230] 43.5% [237] 3170(0.2%) 3170(0.2%) custom-in-set ...acket/private/set-types.rkt:577:0 ------------------------------------------------------------------------------------------- arrow-higher-order:lnp [229] 100.0% [238] 2380(0.1%) 2380(0.1%) ??? ...et/contract/private/arity-checking.rkt:19:2 ------------------------------------------------------------------------------------------- ??? [232] 100.0% [239] 206(0.0%) 0(0.0%) generic-sort/key .../racket/private/sort.rkt:185:2 copying-mergesort [244] 75.7% loop [247] 24.3% ------------------------------------------------------------------------------------------- for-loop [233] 100.0% [240] 50(0.0%) 0(0.0%) ??? ...ie/diff-of-prods/src/core/regimes.rkt:177:2 ??? [152] 100.0% ------------------------------------------------------------------------------------------- ??? [235] 100.0% [241] 5148(0.2%) 1780(0.1%) ??? ...lects/racket/contract/private/orc.rkt:83:14 ??? [245] 65.4% ------------------------------------------------------------------------------------------- ??? [180] 45.7% ??? [234] 54.3% [242] 4286(0.2%) 4286(0.2%) dict? ...ollects/racket/private/generic.rkt:146:11 ------------------------------------------------------------------------------------------- ??? [234] 100.0% [243] 3940(0.2%) 3612(0.2%) contract? ...acket/contract/private/guts.rkt:109:0 coerce-contract/f4 [246] 8.3% ------------------------------------------------------------------------------------------- copying-mergesort [244] 23.1% generic-sort/key [239] 76.9% [244] 156(0.0%) 0(0.0%) copying-mergesort ...racket/private/sort.rkt:130:8 loop [247] 76.9% copying-mergesort [244] 23.1% ------------------------------------------------------------------------------------------- ??? [241] 100.0% [245] 3368(0.2%) 3368(0.2%) ??? ...ects/racket/contract/private/list.rkt:141:5 ------------------------------------------------------------------------------------------- contract? [243] 100.0% [246] 328(0.0%) 328(0.0%) coerce-contract/f4 ...tract/private/guts.rkt:299:0 ------------------------------------------------------------------------------------------- generic-sort/key [239] 24.3% copying-mergesort [244] 75.7% [247] 206(0.0%) 104(0.0%) loop ...ket/collects/racket/private/sort.rkt:97:12 ??? [147] 49.5% -------------------------------------------------------------------------------------------