Profiling results ----------------- Total cpu time observed: 902742ms (out of 908808ms) Number of samples taken: 2597 (once every 348ms) (Hiding functions with self<1.0% and local<2.0%: 22 of 293 hidden) =========================================================================================== Caller Idx Total Self Name+src Local% ms(pct) ms(pct) Callee =========================================================================================== ??? [68] 100.0% [1] 822578(91.1%) 0(0.0%) profile-thunk16 ...t/pkgs/profile-lib/main.rkt:9:0 run [20] 100.0% ------------------------------------------------------------------------------------------- ??? [68] 100.0% [2] 787028(87.2%) 0(0.0%) run-improve50 ...f-of-prods/src/mainloop.rkt:234:0 for-loop [21] 55.5% get-final-combination [23] 44.2% loop [126] 0.2% setup-alt-simplified [34] 0.1% ------------------------------------------------------------------------------------------- ??? [196] 100.0% [3] 401460(44.5%) 360(0.0%) iterate-egraph!13 ...s/src/core/simplify.rkt:102:0 one-iter [22] 97.8% map-enodes [30] 2.1% ------------------------------------------------------------------------------------------- ??? [195] 100.0% [4] 39138(4.3%) 368(0.0%) approximate9 ...-of-prods/src/core/taylor.rkt:12:0 loop [24] 90.1% f176 [44] 6.3% taylor-quotient [65] 0.9% ------------------------------------------------------------------------------------------- hash-ref! [219] 100.0% [5] 32816(3.6%) 0(0.0%) ??? ...bie/diff-of-prods/src/core/taylor.rkt:44:15 ??? [41] 95.7% hash-ref! [219] 4.3% ------------------------------------------------------------------------------------------- ??? [196] 100.0% [6] 32094(3.6%) 0(0.0%) loop .../diff-of-prods/src/core/simplify.rkt:215:2 pass [25] 100.0% ------------------------------------------------------------------------------------------- hash-ref! [219] 100.0% [7] 31854(3.5%) 0(0.0%) ??? ...ie/diff-of-prods/src/core/taylor.rkt:295:23 for-loop [26] 100.0% ------------------------------------------------------------------------------------------- hash-ref! [219] 100.0% [8] 31106(3.4%) 0(0.0%) ??? ...ie/diff-of-prods/src/core/taylor.rkt:285:26 for-loop [27] 100.0% ------------------------------------------------------------------------------------------- hash-ref! [219] 100.0% [9] 26886(3.0%) 0(0.0%) ??? ...ie/diff-of-prods/src/core/taylor.rkt:322:33 for-loop [28] 100.0% ------------------------------------------------------------------------------------------- free-variables [165] 2.0% f176 [44] 2.1% pattern-match [166] 2.2% substitute-e [73] 12.1% match-e [58] 81.6% [10] 16700(1.8%) 366(0.0%) variable? ...-of-prods/src/syntax/syntax.rkt:567:0 ??? [171] 97.8% ------------------------------------------------------------------------------------------- hash-ref! [219] 100.0% [11] 13428(1.5%) 0(0.0%) ??? ...ie/diff-of-prods/src/core/taylor.rkt:392:23 for-loop [29] 100.0% ------------------------------------------------------------------------------------------- hash-ref! [219] 100.0% [12] 13144(1.5%) 0(0.0%) ??? ...bie/diff-of-prods/src/core/taylor.rkt:67:15 ??? [195] 93.2% hash-ref! [219] 6.8% ------------------------------------------------------------------------------------------- copying-mergesort [115] 100.0% [13] 2926(0.3%) 0(0.0%) jloop ...t/collects/racket/private/sort.rkt:121:23 ??? [192] 77.7% ??? [195] 22.3% ------------------------------------------------------------------------------------------- hash-ref! [219] 100.0% [14] 2130(0.2%) 0(0.0%) ??? ...ie/diff-of-prods/src/core/taylor.rkt:338:33 hash-ref! [219] 67.6% for-loop [32] 32.4% ------------------------------------------------------------------------------------------- f176 [44] 100.0% [15] 1770(0.2%) 358(0.0%) taylor-invert ...f-prods/src/core/taylor.rkt:312:0 simplify [39] 59.5% first-nonzero-exp [79] 20.2% ------------------------------------------------------------------------------------------- hash-ref! [219] 100.0% [16] 1412(0.2%) 0(0.0%) ??? ...ie/diff-of-prods/src/core/taylor.rkt:483:23 for-loop [31] 100.0% ------------------------------------------------------------------------------------------- map [146] 22.3% f176 [44] 77.7% [17] 1380(0.2%) 0(0.0%) taylor .../diff-of-prods/src/core/taylor.rkt:163:0 loop [243] 51.6% debug-print [52] 26.1% debug7 [54] 22.3% ------------------------------------------------------------------------------------------- f176 [44] 100.0% [18] 1012(0.1%) 310(0.0%) combine-mterms ...-prods/src/core/reduce.rkt:191:0 for-loop [33] 69.4% ------------------------------------------------------------------------------------------- rewriter [91] 100.0% [19] 1006(0.1%) 0(0.0%) *rules* ...iff-of-prods/src/syntax/rules.rkt:493:0 for-loop [229] 100.0% ------------------------------------------------------------------------------------------- profile-thunk16 [1] 100.0% [20] 822578(91.1%) 0(0.0%) run ...share/racket/pkgs/profile-lib/main.rkt:39:2 ??? [68] 100.0% ------------------------------------------------------------------------------------------- run-improve50 [2] 100.0% [21] 436874(48.4%) 0(0.0%) for-loop .../diff-of-prods/src/mainloop.rkt:249:10 run-iter! [35] 100.0% ------------------------------------------------------------------------------------------- iterate-egraph!13 [3] 100.0% [22] 392646(43.5%) 7566(0.8%) one-iter ...f-of-prods/src/core/simplify.rkt:113:0 loop [37] 63.5% for-loop [38] 30.1% apply-match [46] 4.1% ------------------------------------------------------------------------------------------- run-improve50 [2] 100.0% [23] 347814(38.5%) 0(0.0%) get-final-combination ...ds/src/mainloop.rkt:264:0 split-table [36] 100.0% ------------------------------------------------------------------------------------------- approximate9 [4] 100.0% [24] 35254(3.9%) 0(0.0%) loop ...bie/diff-of-prods/src/core/taylor.rkt:86:4 ??? [195] 62.7% hash-ref! [219] 37.3% ------------------------------------------------------------------------------------------- loop [6] 100.0% [25] 32094(3.6%) 662(0.1%) pass .../diff-of-prods/src/core/simplify.rkt:205:2 for-loop [40] 97.9% ------------------------------------------------------------------------------------------- ??? [7] 100.0% [26] 31854(3.5%) 328(0.0%) for-loop ...ff-of-prods/src/core/taylor.rkt:298:27 hash-ref! [219] 98.6% simplify [39] 1.1% ------------------------------------------------------------------------------------------- ??? [8] 100.0% [27] 31106(3.4%) 360(0.0%) for-loop ...ff-of-prods/src/core/taylor.rkt:285:52 ??? [41] 62.3% hash-ref! [219] 36.2% simplify [39] 0.9% ------------------------------------------------------------------------------------------- ??? [9] 100.0% [28] 26886(3.0%) 0(0.0%) for-loop ...ff-of-prods/src/core/taylor.rkt:324:46 hash-ref! [219] 98.7% simplify [39] 1.3% ------------------------------------------------------------------------------------------- ??? [11] 100.0% [29] 13428(1.5%) 0(0.0%) for-loop ...ff-of-prods/src/core/taylor.rkt:396:33 for-loop [42] 100.0% ------------------------------------------------------------------------------------------- iterate-egraph!13 [3] 100.0% [30] 8454(0.9%) 0(0.0%) map-enodes ...f-of-prods/src/core/egraph.rkt:139:0 loop [243] 100.0% ------------------------------------------------------------------------------------------- ??? [16] 100.0% [31] 1412(0.2%) 0(0.0%) for-loop ...ff-of-prods/src/core/taylor.rkt:487:35 parse-loop12 [197] 100.0% ------------------------------------------------------------------------------------------- ??? [14] 100.0% [32] 1050(0.1%) 0(0.0%) for-loop ...ff-of-prods/src/core/taylor.rkt:341:46 hash-ref! [219] 100.0% ------------------------------------------------------------------------------------------- combine-mterms [18] 100.0% [33] 702(0.1%) 358(0.0%) for-loop ...iff-of-prods/src/core/reduce.rkt:195:5 hash-ref! [219] 49.0% ------------------------------------------------------------------------------------------- run-improve50 [2] 100.0% [34] 660(0.1%) 0(0.0%) setup-alt-simplified ...of-prods/src/glue.rkt:49:0 simplify-alt [43] 100.0% ------------------------------------------------------------------------------------------- for-loop [21] 100.0% [35] 436874(48.4%) 0(0.0%) run-iter! .../diff-of-prods/src/mainloop.rkt:215:0 simplify! [45] 84.4% gen-series! [47] 9.0% finalize-iter! [48] 5.7% gen-rewrites! [51] 0.5% ------------------------------------------------------------------------------------------- get-final-combination [23] 100.0% [36] 347814(38.5%) 0(0.0%) split-table ...ie/diff-of-prods/src/glue.rkt:162:0 f176 [44] 99.9% ??? [171] 0.1% ------------------------------------------------------------------------------------------- one-iter [22] 100.0% [37] 249252(27.6%) 1006(0.1%) loop ...cket/collects/racket/private/map.rkt:52:19 apply-match [46] 99.6% ------------------------------------------------------------------------------------------- for-loop [38] 48.7% one-iter [22] 51.3% [38] 118356(13.1%) 25964(2.9%) for-loop ...-of-prods/src/core/simplify.rkt:123:12 for-loop [38] 48.7% match-e [58] 39.0% ------------------------------------------------------------------------------------------- for-loop [26] 1.0% for-loop [28] 1.0% for-loop [27] 1.9% loop [243] 1.9% taylor-invert [15] 2.9% hash-ref! [219] 89.5% [39] 36722(4.1%) 0(0.0%) simplify ...diff-of-prods/src/core/reduce.rkt:16:0 f176 [44] 57.3% parse-loop12 [197] 31.0% simplify* [208] 3.9% debug-print [52] 3.9% debug7 [54] 3.0% simplify-node [151] 1.0% ------------------------------------------------------------------------------------------- pass [25] 100.0% [40] 31432(3.5%) 0(0.0%) for-loop ...-of-prods/src/core/simplify.rkt:208:29 argmin [49] 63.7% loop [50] 29.8% for-loop [53] 5.4% make-sequence [80] 1.1% ------------------------------------------------------------------------------------------- ??? [5] 41.0% for-loop [27] 59.0% [41] 31404(3.5%) 0(0.0%) ??? ...ie/diff-of-prods/src/core/taylor.rkt:288:19 hash-ref! [219] 100.0% ------------------------------------------------------------------------------------------- for-loop [29] 100.0% [42] 13428(1.5%) 0(0.0%) for-loop ...ff-of-prods/src/core/taylor.rkt:398:39 hash-ref! [219] 100.0% ------------------------------------------------------------------------------------------- setup-alt-simplified [34] 100.0% [43] 660(0.1%) 0(0.0%) simplify-alt ...ie/diff-of-prods/src/glue.rkt:76:0 ??? [196] 100.0% ------------------------------------------------------------------------------------------- for-loop [187] 0.0% for-loop [212] 0.0% hash-ref! [219] 0.0% composed [226] 0.0% simplify-node [151] 0.1% loop [243] 0.1% approximate9 [4] 0.2% rewriter [91] 0.2% append-map [159] 0.3% eval-const-expr [263] 0.5% eval-prog [145] 0.8% parse-loop12 [197] 0.9% f176 [44] 1.8% simplify [39] 2.1% map [146] 2.5% split-table [36] 90.2% [44] 378472(41.9%) 4504(0.5%) f176 .../collects/racket/match/compiler.rkt:507:40 loop [243] 77.9% option-on-expr [56] 12.3% map [146] 5.2% f176 [44] 1.8% ??? [195] 0.9% append-map [159] 0.3% ??? [171] 0.2% ??? [196] 0.2% parse-loop12 [197] 0.1% taylor-invert [15] 0.1% taylor-quotient [65] 0.1% ...prods/src/common.rkt:47:2 [129] 0.1% loop [64] 0.1% combine-mterms [18] 0.1% taylor [17] 0.1% composed [226] 0.0% gather-multiplicative-terms [66] 0.0% ??? [127] 0.0% compose [264] 0.0% variable? [10] 0.0% ------------------------------------------------------------------------------------------- run-iter! [35] 100.0% [45] 368602(40.8%) 0(0.0%) simplify! .../diff-of-prods/src/mainloop.rkt:155:0 for-loop [55] 100.0% ------------------------------------------------------------------------------------------- one-iter [22] 6.1% loop [37] 93.9% [46] 264394(29.3%) 0(0.0%) apply-match ...f-prods/src/core/simplify.rkt:130:2 for-loop [57] 85.9% match-e [58] 12.3% update-leader! [85] 1.7% reduce-to-single! [67] 0.1% ------------------------------------------------------------------------------------------- run-iter! [35] 100.0% [47] 39138(4.3%) 0(0.0%) gen-series! ...iff-of-prods/src/mainloop.rkt:129:0 for-loop [59] 100.0% ------------------------------------------------------------------------------------------- run-iter! [35] 100.0% [48] 24736(2.7%) 0(0.0%) finalize-iter! ...-of-prods/src/mainloop.rkt:169:0 ??? [171] 100.0% ------------------------------------------------------------------------------------------- for-loop [40] 100.0% [49] 20034(2.2%) 0(0.0%) argmin ...re/racket/collects/racket/list.rkt:743:0 for-loop [60] 91.8% expression-cost [62] 8.2% ------------------------------------------------------------------------------------------- for-loop [40] 100.0% [50] 9356(1.0%) 0(0.0%) loop ...hare/racket/collects/racket/list.rkt:729:4 for-loop [60] 96.2% expression-cost [62] 3.8% ------------------------------------------------------------------------------------------- run-iter! [35] 100.0% [51] 2292(0.3%) 0(0.0%) gen-rewrites! ...f-of-prods/src/mainloop.rkt:142:0 for-loop [61] 100.0% ------------------------------------------------------------------------------------------- taylor [17] 20.3% simplify [39] 79.7% [52] 1776(0.2%) 360(0.0%) debug-print ...e/diff-of-prods/src/debug.rkt:107:0 for-loop [63] 79.7% ------------------------------------------------------------------------------------------- for-loop [40] 100.0% [53] 1682(0.2%) 1682(0.2%) for-loop ...-of-prods/src/core/simplify.rkt:195:13 ------------------------------------------------------------------------------------------- taylor [17] 22.1% simplify [39] 77.9% [54] 1394(0.2%) 358(0.0%) debug7 ...herbie/diff-of-prods/src/debug.rkt:102:0 ??? [171] 47.9% ??? [253] 26.4% ------------------------------------------------------------------------------------------- simplify! [45] 99.0% [55] 372146(41.2%) 0(0.0%) for-loop ...e/diff-of-prods/src/mainloop.rkt:159:6 ??? [68] 100.0% ------------------------------------------------------------------------------------------- f176 [44] 13.6% loop [243] 86.4% [56] 347454(38.5%) 0(0.0%) option-on-expr ...prods/src/core/regimes.rkt:103:0 sindices->spoints [69] 90.2% loop [243] 3.3% err-lsts->split-indices [74] 2.9% sort-context-on-expr [75] 2.1% errors [189] 1.2% pick-errors [78] 0.4% ------------------------------------------------------------------------------------------- apply-match [46] 100.0% [57] 227054(25.2%) 668(0.1%) for-loop ...-of-prods/src/core/simplify.rkt:145:10 mk-enode! [82] 29.8% loop! [98] 24.1% merge-egraph-nodes! [71] 23.3% substitute-e [73] 15.4% list-member? [206] 7.0% ------------------------------------------------------------------------------------------- apply-match [46] 15.1% for-loop [83] 24.9% for-loop [38] 60.0% [58] 124932(13.8%) 37782(4.2%) match-e .../diff-of-prods/src/core/ematch.rkt:46:0 for-loop [70] 52.1% for-loop [83] 6.2% ??? [171] 6.1% variable? [10] 4.3% list-cartesian-product [86] 2.3% loop [243] 1.5% custom-in-set [268] 0.9% filter [237] 0.2% ------------------------------------------------------------------------------------------- gen-series! [47] 100.0% [59] 39138(4.3%) 0(0.0%) for-loop ...e/diff-of-prods/src/mainloop.rkt:135:7 taylor-alt [72] 100.0% ------------------------------------------------------------------------------------------- loop [50] 32.9% argmin [49] 67.1% [60] 27380(3.0%) 332(0.0%) for-loop ...e/diff-of-prods/src/programs.rkt:199:2 ??? [196] 72.3% ...prods/src/common.rkt:47:2 [129] 26.5% ------------------------------------------------------------------------------------------- gen-rewrites! [51] 100.0% [61] 2292(0.3%) 0(0.0%) for-loop .../diff-of-prods/src/mainloop.rkt:147:11 ??? [76] 100.0% ------------------------------------------------------------------------------------------- loop [50] 17.9% argmin [49] 82.1% [62] 2010(0.2%) 334(0.0%) expression-cost ...of-prods/src/programs.rkt:198:0 compile [77] 83.4% ------------------------------------------------------------------------------------------- debug-print [52] 100.0% [63] 1416(0.2%) 1416(0.2%) for-loop ...rbie/diff-of-prods/src/debug.rkt:113:2 ------------------------------------------------------------------------------------------- f176 [44] 100.0% [64] 1024(0.1%) 360(0.0%) loop ...bie/diff-of-prods/src/core/reduce.rkt:18:2 expression->type [183] 64.8% ------------------------------------------------------------------------------------------- approximate9 [4] 50.0% f176 [44] 50.0% [65] 720(0.1%) 0(0.0%) taylor-quotient ...prods/src/core/taylor.rkt:328:0 first-nonzero-exp [79] 100.0% ------------------------------------------------------------------------------------------- f176 [44] 100.0% [66] 362(0.0%) 0(0.0%) gather-multiplicative-terms ...re/reduce.rkt:116:0 compose [264] 100.0% ------------------------------------------------------------------------------------------- apply-match [46] 100.0% [67] 326(0.0%) 0(0.0%) reduce-to-single! ...ods/src/core/egraph.rkt:324:0 make-sequence [80] 100.0% ------------------------------------------------------------------------------------------- for-loop [55] 14.3% run [20] 39.5% [68] 885956(98.1%) 0(0.0%) ??? ...lects/racket/private/more-scheme.rkt:261:28 profile-thunk16 [1] 39.5% run-improve50 [2] 37.7% ??? [196] 20.6% loop [126] 2.2% ------------------------------------------------------------------------------------------- option-on-expr [56] 100.0% [69] 313400(34.7%) 0(0.0%) sindices->spoints ...ds/src/core/regimes.rkt:116:0 loop [81] 100.0% ------------------------------------------------------------------------------------------- match-e [58] 100.0% [70] 81902(9.1%) 28388(3.1%) for-loop ...iff-of-prods/src/core/ematch.rkt:59:11 for-loop [83] 54.7% list-cartesian-product [86] 7.9% loop [243] 5.8% curry* [94] 1.1% filter [237] 0.6% ------------------------------------------------------------------------------------------- merge-egraph-nodes! [71] 2.2% for-loop [90] 3.2% for-loop [57] 94.6% [71] 52924(5.9%) 1684(0.2%) merge-egraph-nodes! ...s/src/core/egraph.rkt:152:0 update-leader! [85] 49.0% for-loop [87] 22.4% loop! [98] 13.2% for-loop [90] 5.8% enode-merge! [92] 2.7% merge-egraph-nodes! [71] 2.2% for-loop [229] 1.4% ------------------------------------------------------------------------------------------- for-loop [59] 100.0% [72] 39138(4.3%) 0(0.0%) taylor-alt ...bie/diff-of-prods/src/glue.rkt:134:0 for-loop [84] 100.0% ------------------------------------------------------------------------------------------- substitute-e [73] 9.0% for-loop [57] 91.0% [73] 35044(3.9%) 2038(0.2%) substitute-e ...-of-prods/src/core/ematch.rkt:71:0 mk-enode! [82] 83.6% substitute-e [73] 9.0% variable? [10] 2.2% ??? [171] 1.8% ------------------------------------------------------------------------------------------- option-on-expr [56] 100.0% [74] 9986(1.1%) 328(0.0%) err-lsts->split-indices .../core/regimes.rkt:222:0 add-splitpoint [88] 93.3% for-loop [95] 3.4% ------------------------------------------------------------------------------------------- option-on-expr [56] 100.0% [75] 7268(0.8%) 0(0.0%) sort-context-on-expr ...prods/src/points.rkt:115:0 ??? [89] 95.6% eval-prog [145] 4.4% ------------------------------------------------------------------------------------------- for-loop [61] 100.0% [76] 2292(0.3%) 0(0.0%) ??? ...rbie/diff-of-prods/src/alternative.rkt:88:0 rewriter [91] 100.0% ------------------------------------------------------------------------------------------- expression-cost [62] 100.0% [77] 1676(0.2%) 0(0.0%) compile ...ie/diff-of-prods/src/programs.rkt:175:0 hash-ref! [219] 100.0% ------------------------------------------------------------------------------------------- option-on-expr [56] 100.0% [78] 1368(0.2%) 0(0.0%) pick-errors ...of-prods/src/core/regimes.rkt:184:0 for-loop [93] 100.0% ------------------------------------------------------------------------------------------- taylor-invert [15] 33.2% taylor-quotient [65] 66.8% [79] 1078(0.1%) 0(0.0%) first-nonzero-exp ...ods/src/core/taylor.rkt:260:0 hash-ref! [219] 100.0% ------------------------------------------------------------------------------------------- reduce-to-single! [67] 47.5% for-loop [40] 52.5% [80] 686(0.1%) 686(0.1%) make-sequence ...ects/racket/private/for.rkt:509:2 ------------------------------------------------------------------------------------------- parse-loop12 [197] 0.0% map [146] 0.1% loop [81] 28.1% sindices->spoints [69] 71.8% [81] 314076(34.8%) 340(0.0%) loop ...cket/collects/racket/private/map.rkt:36:19 sidx->spoint [96] 71.8% loop [81] 28.1% ??? [195] 0.0% ------------------------------------------------------------------------------------------- mk-egraph [210] 0.3% expr->enode [227] 2.4% substitute-e [73] 29.4% for-loop [57] 67.9% [82] 99680(11.0%) 8662(1.0%) mk-enode! ...ff-of-prods/src/core/egraph.rkt:101:0 new-enode [97] 87.8% hash-has-key? [176] 3.1% ------------------------------------------------------------------------------------------- match-e [58] 20.5% for-loop [70] 79.5% [83] 61914(6.9%) 4084(0.5%) for-loop ...iff-of-prods/src/core/ematch.rkt:65:37 match-e [58] 90.7% ??? [103] 3.8% ------------------------------------------------------------------------------------------- taylor-alt [72] 100.0% [84] 39138(4.3%) 0(0.0%) for-loop ...erbie/diff-of-prods/src/glue.rkt:139:6 ??? [195] 100.0% ------------------------------------------------------------------------------------------- apply-match [46] 13.8% merge-egraph-nodes! [71] 86.2% [85] 32312(3.6%) 2674(0.3%) update-leader! ...-prods/src/core/egraph.rkt:217:0 for-loop [99] 88.7% update-en-expr [235] 1.1% hash-ref! [219] 1.0% ------------------------------------------------------------------------------------------- match-e [58] 24.0% list-cartesian-product [86] 25.7% for-loop [70] 50.3% [86] 12296(1.4%) 9896(1.1%) list-cartesian-product ...src/core/ematch.rkt:20:0 list-cartesian-product [86] 25.7% for-loop [102] 18.2% ------------------------------------------------------------------------------------------- merge-egraph-nodes! [71] 100.0% [87] 11876(1.3%) 10916(1.2%) for-loop ...iff-of-prods/src/core/egraph.rkt:232:6 update-en-expr [235] 8.1% ------------------------------------------------------------------------------------------- err-lsts->split-indices [74] 100.0% [88] 9318(1.0%) 0(0.0%) add-splitpoint ...prods/src/core/regimes.rkt:235:2 for-loop [100] 100.0% ------------------------------------------------------------------------------------------- sort-context-on-expr [75] 100.0% [89] 6946(0.8%) 0(0.0%) ??? ...cket/collects/racket/private/sort.rkt:403:3 generic-sort/key [101] 84.9% loop [122] 15.1% ------------------------------------------------------------------------------------------- merge-egraph-nodes! [71] 100.0% [90] 4770(0.5%) 0(0.0%) for-loop ...ff-of-prods/src/core/egraph.rkt:200:10 merge-egraph-nodes! [71] 70.5% loop! [98] 29.5% ------------------------------------------------------------------------------------------- ??? [76] 39.5% matcher [116] 60.5% [91] 2292(0.3%) 0(0.0%) rewriter ...ff-of-prods/src/core/matcher.rkt:131:2 for-loop [104] 76.2% f176 [44] 12.4% *rules* [19] 11.4% ------------------------------------------------------------------------------------------- merge-egraph-nodes! [71] 100.0% [92] 1410(0.2%) 0(0.0%) enode-merge! ...-of-prods/src/core/enode.rkt:129:0 adopt-enode! [105] 100.0% ------------------------------------------------------------------------------------------- pick-errors [78] 100.0% [93] 1368(0.2%) 320(0.0%) for-loop ...ff-of-prods/src/core/regimes.rkt:186:2 ??? [106] 76.6% ------------------------------------------------------------------------------------------- for-loop [70] 100.0% [94] 1044(0.1%) 366(0.0%) curry* ...racket/collects/racket/function.rkt:44:2 procedure-arity [107] 64.9% ------------------------------------------------------------------------------------------- err-lsts->split-indices [74] 100.0% [95] 340(0.0%) 0(0.0%) for-loop ...ff-of-prods/src/core/regimes.rkt:260:4 map [146] 100.0% ------------------------------------------------------------------------------------------- loop [81] 100.0% [96] 313400(34.7%) 0(0.0%) sidx->spoint ...f-prods/src/core/regimes.rkt:126:2 binary-search [108] 60.4% binary-search-floats [109] 39.6% ------------------------------------------------------------------------------------------- mk-enode! [82] 100.0% [97] 87560(9.7%) 290(0.0%) new-enode ...diff-of-prods/src/core/enode.rkt:97:0 type-of-enode-expr [110] 99.3% set [113] 0.4% ------------------------------------------------------------------------------------------- for-loop [90] 1.7% merge-egraph-nodes! [71] 9.3% loop [243] 25.7% for-loop [57] 63.3% [98] 64216(7.1%) 13102(1.5%) loop! ...ie/diff-of-prods/src/core/enode.rkt:192:2 custom-set-union [111] 40.5% loop [243] 28.9% set [113] 11.9% update-en-expr [235] 5.2% ------------------------------------------------------------------------------------------- update-leader! [85] 100.0% [99] 28646(3.2%) 982(0.1%) for-loop ...iff-of-prods/src/core/egraph.rkt:222:6 for-loop [112] 95.4% update-en-expr [235] 1.1% ------------------------------------------------------------------------------------------- add-splitpoint [88] 100.0% [100] 9318(1.0%) 3314(0.4%) for-loop ...ff-of-prods/src/core/regimes.rkt:237:4 for-loop [114] 64.4% ------------------------------------------------------------------------------------------- ??? [89] 100.0% [101] 5900(0.7%) 0(0.0%) generic-sort/key .../racket/private/sort.rkt:185:2 copying-mergesort [115] 77.1% loop [122] 22.9% ------------------------------------------------------------------------------------------- list-cartesian-product [86] 100.0% [102] 2400(0.3%) 2400(0.3%) for-loop ...diff-of-prods/src/core/ematch.rkt:24:8 ------------------------------------------------------------------------------------------- for-loop [83] 100.0% [103] 2366(0.3%) 1318(0.1%) ??? ...rbie/diff-of-prods/src/core/ematch.rkt:50:5 for-loop [117] 44.3% ------------------------------------------------------------------------------------------- rewriter [91] 100.0% [104] 2292(0.3%) 0(0.0%) for-loop ...f-of-prods/src/core/matcher.rkt:134:10 matcher [116] 100.0% ------------------------------------------------------------------------------------------- enode-merge! [92] 100.0% [105] 1410(0.2%) 722(0.1%) adopt-enode! ...-of-prods/src/core/enode.rkt:105:0 custom-set-union [111] 48.8% ------------------------------------------------------------------------------------------- ??? [190] 25.6% for-loop [93] 74.4% [106] 1408(0.2%) 0(0.0%) ??? ...ie/diff-of-prods/src/core/regimes.rkt:177:2 ??? [192] 100.0% ------------------------------------------------------------------------------------------- curry* [94] 100.0% [107] 678(0.1%) 678(0.1%) procedure-arity ...ket/private/norm-arity.rkt:7:27 ------------------------------------------------------------------------------------------- sidx->spoint [96] 100.0% [108] 189224(21.0%) 0(0.0%) binary-search ...iff-of-prods/src/common.rkt:221:0 pred [118] 100.0% ------------------------------------------------------------------------------------------- sidx->spoint [96] 100.0% [109] 124176(13.8%) 0(0.0%) binary-search-floats ...prods/src/common.rkt:236:0 pred [118] 100.0% ------------------------------------------------------------------------------------------- new-enode [97] 100.0% [110] 86912(9.6%) 2692(0.3%) type-of-enode-expr ...rods/src/core/enode.rkt:68:0 get-sigs [119] 96.5% parse-loop12 [197] 0.4% ------------------------------------------------------------------------------------------- adopt-enode! [105] 2.4% loop! [98] 97.6% [111] 28366(3.1%) 7834(0.9%) custom-set-union ...et/private/set-types.rkt:168:0 for-loop [121] 64.1% for-loop [123] 8.3% ------------------------------------------------------------------------------------------- for-loop [99] 100.0% [112] 27338(3.0%) 304(0.0%) for-loop ...iff-of-prods/src/core/egraph.rkt:223:8 hash-update! [120] 98.9% ------------------------------------------------------------------------------------------- new-enode [97] 2.3% loop! [98] 97.7% [113] 15258(1.7%) 15258(1.7%) set ...collects/racket/private/set-types.rkt:981:0 ------------------------------------------------------------------------------------------- for-loop [100] 100.0% [114] 6004(0.7%) 6004(0.7%) for-loop ...ff-of-prods/src/core/regimes.rkt:241:8 ------------------------------------------------------------------------------------------- generic-sort/key [101] 44.5% copying-mergesort [115] 55.5% [115] 4546(0.5%) 0(0.0%) copying-mergesort ...racket/private/sort.rkt:130:8 copying-mergesort [115] 55.5% loop [122] 28.4% jloop [13] 16.1% ------------------------------------------------------------------------------------------- for-loop [124] 18.5% matcher [116] 31.5% for-loop [104] 50.0% [116] 2292(0.3%) 0(0.0%) matcher ...iff-of-prods/src/core/matcher.rkt:167:2 rewriter [91] 42.1% matcher [116] 31.5% for-loop [124] 18.5% for-loop [125] 7.9% ------------------------------------------------------------------------------------------- ??? [103] 100.0% [117] 1048(0.1%) 360(0.0%) for-loop ...diff-of-prods/src/core/ematch.rkt:51:7 ??? [171] 65.6% ------------------------------------------------------------------------------------------- binary-search-floats [109] 39.6% binary-search [108] 60.4% [118] 313400(34.7%) 0(0.0%) pred .../diff-of-prods/src/core/regimes.rkt:132:17 loop [126] 98.3% errors [189] 1.7% ------------------------------------------------------------------------------------------- type-of-enode-expr [110] 100.0% [119] 83860(9.3%) 2104(0.2%) get-sigs ...e/diff-of-prods/src/type-check.rkt:5:0 ??? [127] 41.2% ??? [196] 31.3% ...prods/src/common.rkt:47:2 [129] 13.1% ??? [171] 11.9% ------------------------------------------------------------------------------------------- for-loop [112] 100.0% [120] 27034(3.0%) 368(0.0%) hash-update! ...ket/private/more-scheme.rkt:362:13 ??? [128] 98.6% ------------------------------------------------------------------------------------------- custom-set-union [111] 100.0% [121] 18184(2.0%) 4060(0.4%) for-loop ...cts/racket/private/set-types.rkt:174:3 for-loop [130] 77.7% ------------------------------------------------------------------------------------------- ??? [89] 26.0% generic-sort/key [101] 33.7% copying-mergesort [115] 40.3% [122] 4020(0.4%) 0(0.0%) loop ...ket/collects/racket/private/sort.rkt:97:12 ??? [192] 100.0% ------------------------------------------------------------------------------------------- custom-set-union [111] 100.0% [123] 2348(0.3%) 2348(0.3%) for-loop ...cts/racket/private/set-types.rkt:152:2 ------------------------------------------------------------------------------------------- matcher [116] 100.0% [124] 1604(0.2%) 0(0.0%) for-loop ...f-of-prods/src/core/matcher.rkt:183:21 matcher [116] 100.0% ------------------------------------------------------------------------------------------- matcher [116] 100.0% [125] 360(0.0%) 0(0.0%) for-loop ...ff-of-prods/src/core/matcher.rkt:159:6 pattern-match [166] 100.0% ------------------------------------------------------------------------------------------- run-improve50 [2] 0.5% ??? [68] 11.2% pred [118] 88.3% [126] 348970(38.7%) 0(0.0%) loop .../herbie/diff-of-prods/src/points.rkt:193:2 loop [131] 90.3% loop [139] 5.4% make-exacts* [140] 3.9% for-loop [137] 0.4% ------------------------------------------------------------------------------------------- f176 [44] 0.9% ??? [195] 3.7% get-sigs [119] 95.4% [127] 36232(4.0%) 1718(0.2%) ??? ...ts/racket/contract/private/arr-i.rkt:804:10 ??? [134] 46.2% for-loop [133] 40.5% get/build-late-neg-projection [157] 3.8% ??? [239] 2.0% ??? [138] 1.0% ??? [236] 0.9% ------------------------------------------------------------------------------------------- hash-update! [120] 100.0% [128] 26666(3.0%) 360(0.0%) ??? ...ie/diff-of-prods/src/core/egraph.rkt:225:24 for-loop [132] 98.6% ------------------------------------------------------------------------------------------- f176 [44] 1.6% ??? [195] 3.6% for-loop [60] 37.7% get-sigs [119] 57.1% [129] 19198(2.1%) 6536(0.7%) ...prods/src/common.rkt:47:2 ...e/arr-i.rkt:906:19 ??? [135] 37.3% ??? [136] 28.7% ------------------------------------------------------------------------------------------- for-loop [121] 100.0% [130] 14124(1.6%) 14124(1.6%) for-loop ...cts/racket/private/set-types.rkt:178:5 ------------------------------------------------------------------------------------------- loop [126] 100.0% [131] 315052(34.9%) 0(0.0%) loop .../herbie/diff-of-prods/src/points.rkt:151:2 eval-prog [145] 94.5% make-exacts* [140] 2.8% loop [139] 2.7% ------------------------------------------------------------------------------------------- ??? [128] 100.0% [132] 26306(2.9%) 23088(2.6%) for-loop ...ff-of-prods/src/core/egraph.rkt:226:26 update-en-expr [235] 12.2% ------------------------------------------------------------------------------------------- for-loop [221] 21.4% ??? [127] 78.6% [133] 18658(2.1%) 3468(0.4%) for-loop ...racket/contract/private/hash.rkt:239:6 ??? [220] 76.4% ??? [238] 5.0% ------------------------------------------------------------------------------------------- ??? [127] 100.0% [134] 16742(1.9%) 708(0.1%) ??? ...ects/racket/contract/private/hash.rkt:217:4 ??? [141] 95.8% ------------------------------------------------------------------------------------------- for-loop [240] 5.2% ??? [220] 9.7% ...prods/src/common.rkt:47:2 [129] 85.1% [135] 7152(0.8%) 1468(0.2%) ??? ...ects/racket/contract/private/list.rkt:342:4 ??? [220] 75.8% ??? [239] 9.3% ??? [260] 4.6% ------------------------------------------------------------------------------------------- ...prods/src/common.rkt:47:2 [129] 100.0% [136] 5510(0.6%) 2224(0.2%) ??? ...s/racket/contract/private/arr-i.rkt:1268:39 ??? [253] 29.9% return/no-unsupplied [224] 23.4% assoc-ref [144] 6.4% ------------------------------------------------------------------------------------------- loop [126] 100.0% [137] 1308(0.1%) 326(0.0%) for-loop ...ie/diff-of-prods/src/points.rkt:200:24 for-loop [142] 75.1% ------------------------------------------------------------------------------------------- ??? [127] 100.0% [138] 358(0.0%) 0(0.0%) ??? ...private/unconstrained-domain-arrow.rkt:69:2 get-blame-party-info [143] 100.0% ------------------------------------------------------------------------------------------- loop [131] 31.2% loop [126] 68.8% [139] 27390(3.0%) 332(0.0%) loop .../herbie/diff-of-prods/src/points.rkt:141:4 map [146] 98.8% ------------------------------------------------------------------------------------------- loop [131] 38.8% loop [126] 61.2% [140] 22492(2.5%) 0(0.0%) make-exacts* ...diff-of-prods/src/points.rkt:138:0 map [146] 47.1% loop [243] 31.0% eval-prog [145] 21.9% ------------------------------------------------------------------------------------------- ??? [134] 100.0% [141] 16034(1.8%) 664(0.1%) ??? ...ects/racket/contract/private/list.rkt:169:2 ??? [147] 95.9% ------------------------------------------------------------------------------------------- for-loop [137] 100.0% [142] 982(0.1%) 0(0.0%) for-loop ...ie/diff-of-prods/src/points.rkt:201:26 ??? [195] 100.0% ------------------------------------------------------------------------------------------- ??? [138] 100.0% [143] 358(0.0%) 0(0.0%) get-blame-party-info ...ate/arrow-common.rkt:136:0 show-blame-positive [148] 100.0% ------------------------------------------------------------------------------------------- ??? [136] 100.0% [144] 350(0.0%) 350(0.0%) assoc-ref ...collects/racket/private/dict.rkt:56:0 ------------------------------------------------------------------------------------------- sort-context-on-expr [75] 0.1% make-exacts* [140] 1.6% errors [189] 2.7% loop [131] 95.6% [145] 311574(34.5%) 10814(1.2%) eval-prog .../diff-of-prods/src/programs.rkt:148:0 hash-ref! [219] 92.6% f176 [44] 3.1% ??? [152] 0.3% ??? [154] 0.1% ??? [195] 0.1% ??? [155] 0.1% ------------------------------------------------------------------------------------------- for-loop [95] 0.5% parse-loop12 [197] 3.6% make-exacts* [140] 16.3% f176 [44] 37.3% loop [139] 41.7% [146] 64920(7.2%) 718(0.1%) map ...acket/collects/racket/private/map.rkt:20:13 loop [243] 48.8% f176 [44] 19.9% parse-loop12 [197] 13.6% ??? [192] 10.0% simplify-node [151] 1.9% make-multiplication-node [150] 1.1% simplify* [208] 0.7% ??? [195] 0.6% loop [81] 0.5% ??? [153] 0.1% taylor [17] 0.0% ------------------------------------------------------------------------------------------- ??? [141] 100.0% [147] 15370(1.7%) 324(0.0%) ??? ...ects/racket/contract/private/list.rkt:678:5 for-loop [149] 97.9% ------------------------------------------------------------------------------------------- get-blame-party-info [143] 100.0% [148] 358(0.0%) 358(0.0%) show-blame-positive ...act/private/blame.rkt:150:0 ------------------------------------------------------------------------------------------- ??? [147] 100.0% [149] 15046(1.7%) 2398(0.3%) for-loop ...racket/contract/private/list.rkt:680:9 add-list-context [156] 64.0% get/build-late-neg-projection [157] 20.1% ------------------------------------------------------------------------------------------- parse-loop12 [197] 10.4% for-loop [212] 30.1% map [146] 59.5% [150] 3464(0.4%) 0(0.0%) make-multiplication-node .../core/reduce.rkt:230:0 make-multiplication-subnode [158] 100.0% ------------------------------------------------------------------------------------------- simplify [39] 17.4% map [146] 82.6% [151] 2074(0.2%) 0(0.0%) simplify-node ...of-prods/src/core/reduce.rkt:50:0 append-map [159] 66.7% f176 [44] 33.3% ------------------------------------------------------------------------------------------- eval-prog [145] 100.0% [152] 1024(0.1%) 368(0.0%) ??? ...cket/collects/racket/private/kw.rkt:1633:36 unpack245 [161] 64.1% ------------------------------------------------------------------------------------------- parse-loop12 [197] 47.8% map [146] 52.2% [153] 694(0.1%) 0(0.0%) ??? ...rbie/diff-of-prods/src/core/reduce.rkt:61:5 for-loop [160] 100.0% ------------------------------------------------------------------------------------------- eval-prog [145] 100.0% [154] 358(0.0%) 0(0.0%) ??? ...collects/racket/private/qq-and-or.rkt:155:9 ??? [162] 100.0% ------------------------------------------------------------------------------------------- eval-prog [145] 100.0% [155] 318(0.0%) 0(0.0%) ??? ...tract/private/arrow-higher-order.rkt:346:33 ??? [238] 100.0% ------------------------------------------------------------------------------------------- for-loop [149] 100.0% [156] 9626(1.1%) 9626(1.1%) add-list-context ...ontract/private/list.rkt:752:0 ------------------------------------------------------------------------------------------- unconstrained-domain->-projection [169] 7.5% ??? [168] 8.0% ??? [127] 15.5% for-loop [149] 69.0% [157] 4382(0.5%) 0(0.0%) get/build-late-neg-projection ...te/guts.rkt:691:0 ??? [163] 84.5% ??? [168] 8.0% unconstrained-domain->-projection [169] 7.5% ------------------------------------------------------------------------------------------- make-multiplication-node [150] 100.0% [158] 3464(0.4%) 300(0.0%) make-multiplication-subnode ...re/reduce.rkt:240:0 for-loop [164] 60.4% group-by68 [167] 20.6% compose [264] 10.3% ------------------------------------------------------------------------------------------- parse-loop12 [197] 2.3% append-map [159] 7.5% simplify-node [151] 23.6% f176 [44] 66.6% [159] 3126(0.3%) 0(0.0%) append-map ...acket/collects/racket/list.rkt:565:2 f176 [44] 60.6% free-variables [165] 19.3% parse-loop12 [197] 12.7% append-map [159] 7.5% ------------------------------------------------------------------------------------------- ??? [153] 100.0% [160] 694(0.1%) 0(0.0%) for-loop ...diff-of-prods/src/core/reduce.rkt:62:7 pattern-match [166] 52.2% foldl [254] 47.8% ------------------------------------------------------------------------------------------- ??? [152] 100.0% [161] 656(0.1%) 328(0.0%) unpack245 ...private/arrow-higher-order.rkt:354:44 maybe-cons-kwd [170] 50.0% ------------------------------------------------------------------------------------------- ??? [154] 100.0% [162] 358(0.0%) 358(0.0%) ??? ...ollects/racket/private/qq-and-or.rkt:164:21 ------------------------------------------------------------------------------------------- get/build-late-neg-projection [157] 100.0% [163] 4382(0.5%) 1322(0.1%) ??? ...cts/racket/contract/private/prop.rkt:314:12 build-compound-type-name [172] 69.8% ------------------------------------------------------------------------------------------- make-multiplication-subnode [158] 100.0% [164] 2092(0.2%) 726(0.1%) for-loop ...iff-of-prods/src/core/reduce.rkt:242:3 make-multiplication-subsubsubnode [173] 65.3% ------------------------------------------------------------------------------------------- mterm->expr [179] 19.0% append-map [159] 81.0% [165] 1706(0.2%) 0(0.0%) free-variables ...-of-prods/src/programs.rkt:100:0 ??? [171] 80.8% variable? [10] 19.2% ------------------------------------------------------------------------------------------- for-loop [125] 24.9% for-loop [160] 25.1% for-loop [174] 50.0% [166] 722(0.1%) 362(0.0%) pattern-match ...f-prods/src/core/matcher.rkt:48:0 for-loop [174] 50.0% variable? [10] 24.9% ------------------------------------------------------------------------------------------- make-multiplication-subnode [158] 100.0% [167] 714(0.1%) 360(0.0%) group-by68 ...acket/collects/racket/list.rkt:749:0 hash-update [175] 49.6% ------------------------------------------------------------------------------------------- get/build-late-neg-projection [157] 100.0% [168] 702(0.1%) 0(0.0%) ??? ...ects/racket/contract/private/hash.rkt:211:2 get/build-late-neg-projection [157] 100.0% ------------------------------------------------------------------------------------------- get/build-late-neg-projection [157] 100.0% [169] 658(0.1%) 0(0.0%) unconstrained-domain->-projection ...rrow.rkt:60:0 get/build-late-neg-projection [157] 100.0% ------------------------------------------------------------------------------------------- unpack245 [161] 100.0% [170] 328(0.0%) 0(0.0%) maybe-cons-kwd ...ate/arrow-higher-order.rkt:498:0 successfully-got-the-right-kind-of-function [242]100.0% ------------------------------------------------------------------------------------------- setfindf [262] 0.5% split-table [36] 0.5% debug7 [54] 0.9% for-loop [117] 0.9% f176 [44] 1.3% free-variables [165] 1.8% substitute-e [73] 2.2% ??? [260] 2.9% get-sigs [119] 13.3% match-e [58] 19.6% variable? [10] 21.7% finalize-iter! [48] 32.8% [171] 75418(8.4%) 25246(2.8%) ??? ...contract/private/arrow-val-first.rkt:357:18 for-loop [177] 31.9% hash-has-key? [176] 28.5% ??? [260] 2.7% atab-add-altns [180] 0.9% split-atab [181] 0.5% ------------------------------------------------------------------------------------------- contract-struct-name [178] 22.1% ??? [163] 77.9% [172] 3060(0.3%) 2038(0.2%) build-compound-type-name ...private/guts.rkt:448:0 contract-struct-name [178] 49.4% ------------------------------------------------------------------------------------------- make-multiplication-subsubsubnode [173] 13.2% for-loop [164] 86.8% [173] 1366(0.2%) 0(0.0%) make-multiplication-subsubsubnode ...uce.rkt:262:0 mterm->expr [179] 86.8% make-multiplication-subsubsubnode [173] 13.2% ------------------------------------------------------------------------------------------- pattern-match [166] 100.0% [174] 722(0.1%) 0(0.0%) for-loop ...iff-of-prods/src/core/matcher.rkt:66:9 pattern-match [166] 100.0% ------------------------------------------------------------------------------------------- group-by68 [167] 100.0% [175] 354(0.0%) 354(0.0%) hash-update ...cket/private/more-scheme.rkt:356:13 ------------------------------------------------------------------------------------------- mk-enode! [82] 12.5% ??? [171] 87.5% [176] 24784(2.7%) 9380(1.0%) hash-has-key? ...et/private/more-scheme.rkt:368:13 ??? [204] 52.1% ??? [209] 10.0% ------------------------------------------------------------------------------------------- ??? [171] 100.0% [177] 24028(2.7%) 0(0.0%) for-loop ...f-of-prods/src/core/alt-table.rkt:51:2 atab-add-altn [182] 100.0% ------------------------------------------------------------------------------------------- build-compound-type-name [172] 100.0% [178] 2002(0.2%) 1022(0.1%) contract-struct-name ...ract/private/prop.rkt:89:0 build-compound-type-name [172] 58.2% ------------------------------------------------------------------------------------------- make-multiplication-subsubsubnode [173] 100.0% [179] 1366(0.2%) 682(0.1%) mterm->expr ...-of-prods/src/core/reduce.rkt:270:0 expression->type [183] 26.4% free-variables [165] 23.7% ------------------------------------------------------------------------------------------- ??? [171] 100.0% [180] 708(0.1%) 0(0.0%) atab-add-altns ...rods/src/core/alt-table.rkt:50:0 atab-add-altn [182] 100.0% ------------------------------------------------------------------------------------------- ??? [171] 100.0% [181] 360(0.0%) 0(0.0%) split-atab ...of-prods/src/core/alt-table.rkt:74:0 for-loop [184] 100.0% ------------------------------------------------------------------------------------------- atab-add-altns [180] 2.9% for-loop [177] 97.1% [182] 24736(2.7%) 0(0.0%) atab-add-altn ...rods/src/core/alt-table.rkt:208:0 best-and-tied-at-points [185] 91.8% override-at-pnts [186] 8.2% ------------------------------------------------------------------------------------------- mterm->expr [179] 11.7% loop [64] 40.8% for-loop [187] 47.5% [183] 1024(0.1%) 336(0.0%) expression->type ...-prods/src/type-check.rkt:45:0 for-loop [187] 67.2% ------------------------------------------------------------------------------------------- split-atab [181] 100.0% [184] 360(0.0%) 0(0.0%) for-loop ...f-of-prods/src/core/alt-table.rkt:75:2 for-loop [188] 100.0% ------------------------------------------------------------------------------------------- atab-add-altn [182] 100.0% [185] 22710(2.5%) 334(0.0%) best-and-tied-at-points ...ore/alt-table.rkt:122:0 errors [189] 98.5% ------------------------------------------------------------------------------------------- atab-add-altn [182] 100.0% [186] 2026(0.2%) 0(0.0%) override-at-pnts ...s/src/core/alt-table.rkt:145:0 errors [189] 100.0% ------------------------------------------------------------------------------------------- expression->type [183] 100.0% [187] 688(0.1%) 0(0.0%) for-loop .../diff-of-prods/src/type-check.rkt:52:5 expression->type [183] 70.6% ??? [253] 17.4% f176 [44] 11.9% ------------------------------------------------------------------------------------------- for-loop [184] 100.0% [188] 360(0.0%) 0(0.0%) for-loop ...-of-prods/src/core/alt-table.rkt:76:45 ??? [190] 100.0% ------------------------------------------------------------------------------------------- composed [226] 3.0% override-at-pnts [186] 4.4% option-on-expr [56] 8.6% pred [118] 11.2% loop [243] 24.6% best-and-tied-at-points [185] 48.2% [189] 46434(5.1%) 352(0.0%) errors ...erbie/diff-of-prods/src/points.rkt:218:0 for-loop [191] 80.8% eval-prog [145] 18.4% ------------------------------------------------------------------------------------------- for-loop [188] 100.0% [190] 360(0.0%) 0(0.0%) ??? ...ie/diff-of-prods/src/core/regimes.rkt:284:4 ??? [106] 100.0% ------------------------------------------------------------------------------------------- errors [189] 100.0% [191] 37526(4.2%) 3308(0.4%) for-loop ...bie/diff-of-prods/src/points.rkt:221:4 ??? [192] 78.5% ??? [195] 9.2% ulp-difference [193] 2.7% ------------------------------------------------------------------------------------------- ??? [106] 1.8% jloop [13] 2.9% loop [122] 5.1% map [146] 8.1% for-loop [191] 37.0% loop [243] 45.1% [192] 79512(8.8%) 2822(0.3%) ??? ...herbie/diff-of-prods/src/programs.rkt:154:4 ??? [194] 80.5% ??? [199] 8.5% ??? [195] 6.9% ------------------------------------------------------------------------------------------- for-loop [191] 100.0% [193] 1024(0.1%) 664(0.1%) ulp-difference ...diff-of-prods/src/float.rkt:19:0 ??? [253] 35.2% ------------------------------------------------------------------------------------------- ??? [192] 100.0% [194] 63990(7.1%) 33114(3.7%) ??? ...acket/collects/racket/private/kw.rkt:444:14 ??? [205] 17.9% bf* [198] 12.0% ??? [200] 8.0% ??? [201] 6.5% ??? [238] 1.7% parse-loop12 [197] 0.5% ------------------------------------------------------------------------------------------- for-loop [251] 0.5% eval-prog [145] 0.5% for-loop [203] 0.5% loop [81] 0.5% map [146] 0.6% jloop [13] 1.0% for-loop [142] 1.5% loop [243] 3.5% for-loop [191] 5.4% ??? [12] 6.9% ??? [192] 8.4% loop [24] 11.6% f176 [44] 14.4% ??? [196] 21.5% for-loop [84] 21.5% [195] 63754(7.1%) 2018(0.2%) ??? ...tract/private/arrow-higher-order.rkt:342:33 ??? [196] 48.6% approximate9 [4] 21.5% hash-ref! [219] 18.4% ??? [260] 2.9% ??? [127] 2.1% best-alt [202] 1.6% ...prods/src/common.rkt:47:2 [129] 1.1% ??? [199] 0.6% ------------------------------------------------------------------------------------------- f176 [44] 0.0% simplify-alt [43] 0.1% for-loop [60] 1.3% get-sigs [119] 1.8% ??? [196] 8.1% ??? [195] 9.8% for-loop [203] 36.1% ??? [68] 41.9% [196] 492864(54.6%) 18368(2.0%) ??? ...llects/racket/private/norm-define.rkt:53:83 iterate-egraph!13 [3] 39.9% for-loop [203] 36.2% ??? [196] 8.1% ??? [195] 6.4% ??? [204] 2.8% loop [6] 2.6% return/no-unsupplied [224] 0.8% ??? [253] 0.4% mk-egraph [210] 0.2% ??? [220] 0.1% ??? [214] 0.1% ??? [209] 0.1% loop [216] 0.1% *simplify-rules* [218] 0.1% dict? [269] 0.0% ------------------------------------------------------------------------------------------- ??? [194] 1.3% type-of-enode-expr [110] 1.4% append-map [159] 1.6% hash-ref! [219] 2.7% loop [243] 4.2% f176 [44] 4.3% for-loop [31] 5.4% simplify [39] 17.1% parse-loop12 [197] 27.8% map [146] 34.1% [197] 25922(2.9%) 14142(1.6%) parse-loop12 ...s/racket/match/compiler.rkt:418:15 parse-loop12 [197] 27.8% f176 [44] 13.6% loop [243] 9.5% map [146] 6.5% for-loop [211] 5.4% for-loop [212] 3.0% simplify* [208] 2.6% ??? [153] 1.3% loop [81] 0.6% append-map [159] 0.3% make-multiplication-node [150] 0.3% ------------------------------------------------------------------------------------------- ??? [194] 100.0% [198] 7656(0.8%) 0(0.0%) bf* ...ath/private/bigfloat/bigfloat-mpfr.rkt:95:0 ??? [205] 100.0% ------------------------------------------------------------------------------------------- ??? [195] 5.0% ??? [192] 95.0% [199] 7158(0.8%) 0(0.0%) ??? ...contract/private/../../private/kw.rkt:761:9 real->bigfloat [207] 95.0% integer->bigfloat [215] 5.0% ------------------------------------------------------------------------------------------- ??? [194] 100.0% [200] 5100(0.6%) 3470(0.4%) ??? .../diff-of-prods/src/syntax/syntax.rkt:122:17 return/no-unsupplied [224] 19.5% list-member? [206] 6.5% ??? [253] 5.9% ------------------------------------------------------------------------------------------- ??? [194] 100.0% [201] 4134(0.5%) 4134(0.5%) ??? ...rivate/unconstrained-domain-arrow.rkt:40:13 ------------------------------------------------------------------------------------------- ??? [195] 100.0% [202] 1408(0.2%) 0(0.0%) best-alt ...herbie/diff-of-prods/src/glue.rkt:71:0 loop [213] 76.7% argmins [217] 23.3% ------------------------------------------------------------------------------------------- ??? [196] 100.0% [203] 370258(41.0%) 0(0.0%) for-loop ...f-of-prods/src/core/simplify.rkt:63:12 ??? [196] 99.9% ??? [195] 0.1% ------------------------------------------------------------------------------------------- hash-has-key? [176] 27.5% ??? [196] 72.5% [204] 46922(5.2%) 18354(2.0%) ??? ...ects/racket/contract/private/list.rkt:737:4 for-loop [221] 48.9% ??? [236] 8.4% ??? [220] 2.1% ??? [260] 0.7% ------------------------------------------------------------------------------------------- bf* [198] 40.0% ??? [194] 60.0% [205] 19134(2.1%) 3214(0.4%) ??? ...-racket/utils/simple-result-arrow.rkt:39:12 bfmul [223] 55.7% bfneg [225] 27.5% ------------------------------------------------------------------------------------------- ??? [200] 2.1% for-loop [57] 97.9% [206] 16278(1.8%) 334(0.0%) list-member? ...llects/racket/private/set.rkt:24:0 loop [222] 85.0% member [228] 12.9% ------------------------------------------------------------------------------------------- ??? [199] 100.0% [207] 6798(0.8%) 5680(0.6%) real->bigfloat .../private/bigfloat/mpfr.rkt:451:0 ??? [252] 16.4% ------------------------------------------------------------------------------------------- simplify [39] 25.6% parse-loop12 [197] 37.2% map [146] 37.3% [208] 5572(0.6%) 2376(0.3%) simplify* ...iff-of-prods/src/core/reduce.rkt:31:0 hash-ref! [219] 25.6% return/no-unsupplied [224] 18.7% ??? [230] 13.0% ------------------------------------------------------------------------------------------- ??? [196] 29.7% hash-has-key? [176] 70.3% [209] 3540(0.4%) 3540(0.4%) ??? ...ects/racket/contract/private/hash.rkt:245:7 ------------------------------------------------------------------------------------------- ??? [196] 100.0% [210] 2730(0.3%) 0(0.0%) mk-egraph ...ff-of-prods/src/core/egraph.rkt:123:0 expr->enode [227] 87.8% mk-enode! [82] 12.2% ------------------------------------------------------------------------------------------- parse-loop12 [197] 100.0% [211] 1412(0.2%) 0(0.0%) for-loop ...ff-of-prods/src/core/taylor.rkt:490:59 hash-ref! [219] 100.0% ------------------------------------------------------------------------------------------- parse-loop12 [197] 100.0% [212] 1400(0.2%) 0(0.0%) for-loop ...iff-of-prods/src/core/reduce.rkt:99:13 make-multiplication-node [150] 74.4% f176 [44] 25.6% ------------------------------------------------------------------------------------------- best-alt [202] 100.0% [213] 1080(0.1%) 0(0.0%) loop .../herbie/diff-of-prods/src/common.rkt:146:2 composed [226] 100.0% ------------------------------------------------------------------------------------------- ??? [196] 100.0% [214] 360(0.0%) 0(0.0%) ??? ...-racket/utils/simple-result-arrow.rkt:60:15 ??? [252] 100.0% ------------------------------------------------------------------------------------------- ??? [199] 100.0% [215] 360(0.0%) 0(0.0%) integer->bigfloat ...ivate/bigfloat/mpfr.rkt:399:0 ??? [252] 100.0% ------------------------------------------------------------------------------------------- ??? [196] 100.0% [216] 332(0.0%) 0(0.0%) loop ...s/herbie/diff-of-prods/src/points.rkt:66:6 random-exp [231] 100.0% ------------------------------------------------------------------------------------------- best-alt [202] 100.0% [217] 328(0.0%) 0(0.0%) argmins ...rbie/diff-of-prods/src/common.rkt:145:0 composed [226] 100.0% ------------------------------------------------------------------------------------------- ??? [196] 100.0% [218] 306(0.0%) 0(0.0%) *simplify-rules* ...ods/src/syntax/rules.rkt:497:0 for-loop [229] 100.0% ------------------------------------------------------------------------------------------- for-loop [33] 0.0% for-loop [211] 0.0% for-loop [32] 0.1% ??? [5] 0.1% update-leader! [85] 0.1% ??? [12] 0.1% first-nonzero-exp [79] 0.1% ??? [14] 0.1% simplify* [208] 0.2% ??? [233] 0.2% compile [77] 0.3% for-loop [42] 0.3% loop [24] 0.7% for-loop [28] 0.8% for-loop [27] 0.9% ??? [195] 1.5% for-loop [26] 2.3% ??? [41] 3.7% eval-prog [145] 38.0% loop [243] 50.0% [219] 327984(36.3%) 5108(0.6%) hash-ref! ...racket/private/more-scheme.rkt:373:13 ??? [233] 50.3% bigfloat-hash [232] 37.8% ??? [8] 3.6% ??? [7] 2.4% simplify [39] 1.3% ??? [5] 1.2% ??? [9] 0.8% ??? [12] 0.8% ??? [11] 0.3% f176 [44] 0.2% parse-loop12 [197] 0.2% ??? [14] 0.2% ??? [16] 0.0% ------------------------------------------------------------------------------------------- ??? [204] 4.3% ??? [196] 5.4% ??? [135] 27.7% for-loop [133] 61.0% [220] 23380(2.6%) 6486(0.7%) ??? ...cts/racket/contract/private/list.rkt:187:10 ??? [234] 56.5% for-loop [240] 7.0% ??? [135] 5.9% ??? [238] 2.8% ------------------------------------------------------------------------------------------- ??? [204] 100.0% [221] 22952(2.5%) 12562(1.4%) for-loop ...acket/contract/private/list.rkt:743:12 ??? [236] 22.1% for-loop [133] 17.4% ??? [239] 4.3% successfully-got-the-right-kind-of-function [242] 1.4% ------------------------------------------------------------------------------------------- list-member? [206] 100.0% [222] 13838(1.5%) 13838(1.5%) loop (unknown source) ------------------------------------------------------------------------------------------- ??? [205] 100.0% [223] 10656(1.2%) 6976(0.8%) bfmul ...-lib/math/private/bigfloat/mpfr.rkt:819:4 ??? [252] 34.5% ------------------------------------------------------------------------------------------- ??? [200] 12.8% simplify* [208] 13.4% ??? [136] 16.6% ??? [196] 57.1% [224] 7760(0.9%) 4754(0.5%) return/no-unsupplied ...ct/private/arr-i.rkt:533:0 filter [237] 38.7% ------------------------------------------------------------------------------------------- ??? [205] 100.0% [225] 5264(0.6%) 3858(0.4%) bfneg ...-lib/math/private/bigfloat/mpfr.rkt:616:4 ??? [252] 26.7% ------------------------------------------------------------------------------------------- argmins [217] 11.8% loop [213] 38.7% f176 [44] 49.5% [226] 2790(0.3%) 0(0.0%) composed ...ollects/racket/private/list.rkt:321:16 errors [189] 50.5% f176 [44] 49.5% ------------------------------------------------------------------------------------------- expr->enode [227] 39.7% mk-egraph [210] 60.3% [227] 2398(0.3%) 0(0.0%) expr->enode ...-of-prods/src/core/egraph.rkt:124:2 mk-enode! [82] 60.3% expr->enode [227] 39.7% ------------------------------------------------------------------------------------------- list-member? [206] 100.0% [228] 2106(0.2%) 2106(0.2%) member (unknown source) ------------------------------------------------------------------------------------------- *simplify-rules* [218] 15.0% merge-egraph-nodes! [71] 35.6% *rules* [19] 49.4% [229] 2036(0.2%) 1014(0.1%) for-loop ...rbie/diff-of-prods/src/common.rkt:94:9 ormap [241] 32.2% update-en-expr [235] 18.0% ------------------------------------------------------------------------------------------- simplify* [208] 100.0% [230] 726(0.1%) 726(0.1%) ??? ...racket/collects/racket/private/kw.rkt:762:9 ------------------------------------------------------------------------------------------- loop [216] 100.0% [231] 332(0.0%) 332(0.0%) random-exp ...e/diff-of-prods/src/common.rkt:246:0 ------------------------------------------------------------------------------------------- hash-ref! [219] 100.0% [232] 286976(31.8%) 360(0.0%) bigfloat-hash ...h/private/bigfloat/mpfr.rkt:165:0 bfcanonicalize [244] 97.3% sig+exp->bigfloat [245] 2.6% ------------------------------------------------------------------------------------------- hash-ref! [219] 100.0% [233] 257136(28.5%) 662(0.1%) ??? ...herbie/diff-of-prods/src/programs.rkt:183:5 loop [243] 99.5% hash-ref! [219] 0.4% ------------------------------------------------------------------------------------------- ??? [220] 100.0% [234] 13212(1.5%) 638(0.1%) ??? ...ects/racket/contract/private/list.rkt:686:7 ??? [260] 95.2% ------------------------------------------------------------------------------------------- for-loop [99] 2.8% update-leader! [85] 3.1% for-loop [229] 3.1% for-loop [87] 8.2% for-loop [132] 27.4% loop! [98] 55.4% [235] 11730(1.3%) 11730(1.3%) update-en-expr ...-prods/src/core/egraph.rkt:211:0 ------------------------------------------------------------------------------------------- ??? [127] 3.6% ??? [204] 42.2% for-loop [221] 54.3% [236] 9352(1.0%) 5002(0.6%) ??? ...private/unconstrained-domain-arrow.rkt:74:4 make-keyword-procedure [246] 46.5% ------------------------------------------------------------------------------------------- match-e [58] 7.5% for-loop [70] 17.0% return/no-unsupplied [224] 75.5% [237] 3982(0.4%) 3982(0.4%) filter ...t/collects/racket/private/list.rkt:256:2 ------------------------------------------------------------------------------------------- ??? [155] 10.5% ??? [220] 21.8% for-loop [133] 30.9% ??? [194] 36.8% [238] 3020(0.3%) 1946(0.2%) ??? ...ects/racket/contract/private/prop.rkt:493:4 ??? [248] 35.6% ------------------------------------------------------------------------------------------- ??? [135] 28.2% ??? [127] 29.8% for-loop [221] 42.0% [239] 2372(0.3%) 326(0.0%) ??? ...ects/racket/contract/private/hash.rkt:222:6 check-hash/c [247] 86.3% ------------------------------------------------------------------------------------------- ??? [220] 100.0% [240] 1640(0.2%) 898(0.1%) for-loop ...acket/contract/private/list.rkt:190:15 ??? [135] 45.2% ------------------------------------------------------------------------------------------- for-loop [229] 100.0% [241] 656(0.1%) 0(0.0%) ormap ...et/collects/racket/private/map.rkt:105:13 flag-set? [249] 100.0% ------------------------------------------------------------------------------------------- for-loop [221] 49.5% maybe-cons-kwd [170] 50.5% [242] 650(0.1%) 0(0.0%) successfully-got-the-right-kind-of-function ...9:4 arity-checking-wrapper [250] 100.0% ------------------------------------------------------------------------------------------- make-exacts* [140] 0.0% taylor [17] 0.2% match-e [58] 0.4% map-enodes [30] 0.6% for-loop [70] 0.7% parse-loop12 [197] 0.8% option-on-expr [56] 0.9% map [146] 1.1% loop! [98] 2.6% f176 [44] 26.2% loop [243] 32.1% ??? [233] 34.5% [243] 434124(48.1%) 5452(0.6%) loop ...cket/collects/racket/private/map.rkt:25:19 hash-ref! [219] 34.5% loop [243] 32.1% option-on-expr [56] 26.2% loop! [98] 2.4% errors [189] 0.9% ??? [192] 0.7% parse-loop12 [197] 0.7% for-loop [251] 0.6% f176 [44] 0.4% foldl [254] 0.3% simplify [39] 0.2% ??? [195] 0.0% ------------------------------------------------------------------------------------------- bigfloat-hash [232] 100.0% [244] 279180(30.9%) 277450(30.7%) bfcanonicalize .../private/bigfloat/mpfr.rkt:155:0 bigfloat->sig+exp [255] 0.6% ------------------------------------------------------------------------------------------- bigfloat-hash [232] 100.0% [245] 7436(0.8%) 5686(0.6%) sig+exp->bigfloat ...ivate/bigfloat/mpfr.rkt:385:0 integer->mpz [256] 13.9% ??? [252] 9.6% ------------------------------------------------------------------------------------------- ??? [236] 100.0% [246] 4350(0.5%) 4350(0.5%) make-keyword-procedure ...ket/private/kw.rkt:260:4 ------------------------------------------------------------------------------------------- ??? [239] 100.0% [247] 2046(0.2%) 1042(0.1%) check-hash/c ...ket/contract/private/hash.rkt:83:0 flat-contract? [257] 49.1% ------------------------------------------------------------------------------------------- ??? [238] 100.0% [248] 1074(0.1%) 756(0.1%) ??? ...lects/racket/contract/private/orc.rkt:83:14 ??? [259] 29.6% ------------------------------------------------------------------------------------------- ormap [241] 100.0% [249] 656(0.1%) 0(0.0%) flag-set? ...bie/diff-of-prods/src/config.rkt:32:0 ??? [253] 100.0% ------------------------------------------------------------------------------------------- successfully-got-the-right-kind-of-function [242]100.0% [250] 650(0.1%) 322(0.0%) arity-checking-wrapper ...w-higher-order.rkt:402:0 matches-arity-exactly? [258] 50.5% ------------------------------------------------------------------------------------------- loop [243] 100.0% [251] 8454(0.9%) 2052(0.2%) for-loop ...f-of-prods/src/core/simplify.rkt:173:2 setfindf [262] 31.8% eval-const-expr [263] 27.8% compose [264] 12.3% ??? [195] 3.8% ------------------------------------------------------------------------------------------- integer->bigfloat [215] 4.7% ??? [214] 4.7% sig+exp->bigfloat [245] 9.4% real->bigfloat [207] 14.6% bfneg [225] 18.4% bfmul [223] 48.2% [252] 7640(0.8%) 7640(0.8%) ??? .../share/racket/collects/ffi/unsafe.rkt:861:4 ------------------------------------------------------------------------------------------- ??? [200] 4.3% for-loop [187] 5.1% ulp-difference [193] 5.1% debug7 [54] 5.2% flag-set? [249] 9.3% ??? [136] 23.4% ??? [196] 47.5% [253] 7034(0.8%) 2766(0.3%) ??? ...racket/collects/racket/private/kw.rkt:761:9 ??? [261] 47.1% ??? [260] 13.6% ------------------------------------------------------------------------------------------- for-loop [160] 13.8% loop [243] 86.2% [254] 2412(0.3%) 992(0.1%) foldl ...et/collects/racket/private/list.rkt:229:4 merge2 [265] 58.9% ------------------------------------------------------------------------------------------- bfcanonicalize [244] 100.0% [255] 1730(0.2%) 0(0.0%) bigfloat->sig+exp ...ivate/bigfloat/mpfr.rkt:370:0 size+limbs->integer [266] 79.4% new-mpz [267] 20.6% ------------------------------------------------------------------------------------------- sig+exp->bigfloat [245] 100.0% [256] 1034(0.1%) 1034(0.1%) integer->mpz ...math/private/bigfloat/gmp.rkt:87:0 ------------------------------------------------------------------------------------------- check-hash/c [247] 100.0% [257] 1004(0.1%) 1004(0.1%) flat-contract? .../contract/private/guts.rkt:111:0 ------------------------------------------------------------------------------------------- arity-checking-wrapper [250] 100.0% [258] 328(0.0%) 328(0.0%) matches-arity-exactly? ...te/arrow-common.rkt:70:0 ------------------------------------------------------------------------------------------- ??? [248] 100.0% [259] 318(0.0%) 318(0.0%) ??? ...ects/racket/contract/private/list.rkt:141:5 ------------------------------------------------------------------------------------------- ??? [204] 1.7% ??? [135] 3.4% ??? [253] 5.0% ??? [171] 10.5% ??? [195] 10.7% ??? [234] 65.2% [260] 19288(2.1%) 15950(1.8%) ??? ...ects/racket/contract/private/guts.rkt:644:8 ??? [171] 12.3% dict? [269] 3.4% ------------------------------------------------------------------------------------------- ??? [253] 100.0% [261] 3312(0.4%) 3012(0.3%) ??? ...s/racket/contract/private/arr-i.rkt:1233:27 ??? [271] 9.1% ------------------------------------------------------------------------------------------- for-loop [251] 100.0% [262] 2690(0.3%) 1702(0.2%) setfindf ...bie/diff-of-prods/src/common.rkt:179:0 ??? [171] 13.3% custom-in-set [268] 12.2% for-loop [270] 11.2% ------------------------------------------------------------------------------------------- for-loop [251] 100.0% [263] 2352(0.3%) 648(0.1%) eval-const-expr ...of-prods/src/programs.rkt:166:0 f176 [44] 72.4% ------------------------------------------------------------------------------------------- make-multiplication-subnode [158] 16.9% f176 [44] 17.0% gather-multiplicative-terms [66] 17.1% for-loop [251] 49.1% [264] 2120(0.2%) 2120(0.2%) compose ...collects/racket/private/list.rkt:385:12 ------------------------------------------------------------------------------------------- foldl [254] 100.0% [265] 1420(0.2%) 1420(0.2%) merge2 ...e/diff-of-prods/src/core/ematch.rkt:31:0 ------------------------------------------------------------------------------------------- bigfloat->sig+exp [255] 100.0% [266] 1374(0.2%) 1374(0.2%) size+limbs->integer ...vate/bigfloat/gmp.rkt:103:0 ------------------------------------------------------------------------------------------- bigfloat->sig+exp [255] 100.0% [267] 356(0.0%) 356(0.0%) new-mpz ...-lib/math/private/bigfloat/gmp.rkt:73:0 ------------------------------------------------------------------------------------------- setfindf [262] 23.4% match-e [58] 76.6% [268] 1402(0.2%) 1402(0.2%) custom-in-set ...acket/private/set-types.rkt:577:0 ------------------------------------------------------------------------------------------- ??? [260] 48.5% ??? [196] 51.5% [269] 1362(0.2%) 1362(0.2%) dict? ...ollects/racket/private/generic.rkt:146:11 ------------------------------------------------------------------------------------------- setfindf [262] 100.0% [270] 302(0.0%) 302(0.0%) for-loop ...bie/diff-of-prods/src/common.rkt:180:2 ------------------------------------------------------------------------------------------- ??? [261] 100.0% [271] 300(0.0%) 300(0.0%) ??? ...ects/racket/contract/private/prop.rkt:256:4 -------------------------------------------------------------------------------------------