Profiling results ----------------- Total cpu time observed: 463368ms (out of 472212ms) Number of samples taken: 1304 (once every 355ms) (Hiding functions with self<1.0% and local<2.0%: 20 of 293 hidden) ========================================================================================= Caller Idx Total Self Name+src Local% ms(pct) ms(pct) Callee ========================================================================================= ??? [72] 100.0% [1] 412044(88.9%) 0(0.0%) profile-thunk16 ...t/pkgs/profile-lib/main.rkt:9:0 run [21] 100.0% ----------------------------------------------------------------------------------------- ??? [72] 100.0% [2] 385346(83.2%) 0(0.0%) run-improve50 ...f-of-prods/src/mainloop.rkt:234:0 for-loop [22] 70.1% get-final-combination [24] 29.6% loop [131] 0.2% setup-alt-simplified [38] 0.1% ----------------------------------------------------------------------------------------- ??? [198] 100.0% [3] 234616(50.6%) 0(0.0%) iterate-egraph!13 ...s/src/core/simplify.rkt:102:0 one-iter [23] 98.6% debug-print [57] 0.2% ----------------------------------------------------------------------------------------- ??? [182] 100.0% [4] 41434(8.9%) 0(0.0%) approximate9 ...-of-prods/src/core/taylor.rkt:12:0 loop [25] 97.5% f6 [52] 2.5% ----------------------------------------------------------------------------------------- hash-ref! [211] 100.0% [5] 37628(8.1%) 0(0.0%) ??? ...bie/diff-of-prods/src/core/taylor.rkt:44:15 ??? [44] 92.7% hash-ref! [211] 6.4% simplify [43] 1.0% ----------------------------------------------------------------------------------------- hash-ref! [211] 100.0% [6] 35950(7.8%) 0(0.0%) ??? ...ie/diff-of-prods/src/core/taylor.rkt:285:26 for-loop [26] 100.0% ----------------------------------------------------------------------------------------- hash-ref! [211] 100.0% [7] 32126(6.9%) 352(0.1%) ??? ...ie/diff-of-prods/src/core/taylor.rkt:295:23 for-loop [27] 99.7% ----------------------------------------------------------------------------------------- hash-ref! [211] 100.0% [8] 29028(6.3%) 0(0.0%) ??? ...ie/diff-of-prods/src/core/taylor.rkt:322:33 for-loop [28] 100.0% ----------------------------------------------------------------------------------------- hash-ref! [211] 100.0% [9] 22472(4.8%) 682(0.1%) ??? ...herbie/diff-of-prods/src/programs.rkt:183:5 loop [199] 97.0% ----------------------------------------------------------------------------------------- hash-ref! [211] 100.0% [10] 16334(3.5%) 0(0.0%) ??? ...bie/diff-of-prods/src/core/taylor.rkt:67:15 ??? [182] 92.6% hash-ref! [211] 7.4% ----------------------------------------------------------------------------------------- hash-ref! [211] 100.0% [11] 14834(3.2%) 0(0.0%) ??? ...ie/diff-of-prods/src/core/taylor.rkt:392:23 for-loop [29] 100.0% ----------------------------------------------------------------------------------------- ??? [198] 100.0% [12] 14142(3.1%) 0(0.0%) loop .../diff-of-prods/src/core/simplify.rkt:215:2 pass [30] 100.0% ----------------------------------------------------------------------------------------- substitute-e [77] 7.0% free-variables [273] 9.9% match-e [64] 83.1% [13] 10434(2.3%) 0(0.0%) variable? ...-of-prods/src/syntax/syntax.rkt:567:0 ??? [132] 100.0% ----------------------------------------------------------------------------------------- loop [199] 100.0% [14] 2834(0.6%) 1062(0.2%) for-loop ...f-of-prods/src/core/simplify.rkt:173:2 eval-const-expr [32] 37.0% setfindf [35] 25.5% ----------------------------------------------------------------------------------------- copying-mergesort [118] 100.0% [15] 2746(0.6%) 0(0.0%) jloop ...t/collects/racket/private/sort.rkt:121:23 ??? [173] 100.0% ----------------------------------------------------------------------------------------- hash-ref! [211] 100.0% [16] 2106(0.5%) 0(0.0%) ??? ...ie/diff-of-prods/src/core/taylor.rkt:483:23 for-loop [31] 100.0% ----------------------------------------------------------------------------------------- hash-ref! [211] 100.0% [17] 1028(0.2%) 0(0.0%) ??? ...ie/diff-of-prods/src/core/taylor.rkt:338:33 for-loop [34] 65.8% hash-ref! [211] 34.2% ----------------------------------------------------------------------------------------- f6 [52] 100.0% [18] 1026(0.2%) 0(0.0%) taylor .../diff-of-prods/src/core/taylor.rkt:163:0 debug7 [33] 65.1% loop [199] 34.9% ----------------------------------------------------------------------------------------- f6 [52] 100.0% [19] 330(0.1%) 0(0.0%) loop ...bie/diff-of-prods/src/core/reduce.rkt:18:2 expression->type [36] 100.0% ----------------------------------------------------------------------------------------- f6 [52] 100.0% [20] 326(0.1%) 0(0.0%) taylor-invert ...f-prods/src/core/taylor.rkt:312:0 first-nonzero-exp [37] 100.0% ----------------------------------------------------------------------------------------- profile-thunk16 [1] 99.9% [21] 412394(89.0%) 0(0.0%) run ...share/racket/pkgs/profile-lib/main.rkt:39:2 ??? [72] 100.0% ----------------------------------------------------------------------------------------- run-improve50 [2] 100.0% [22] 270316(58.3%) 0(0.0%) for-loop .../diff-of-prods/src/mainloop.rkt:249:10 run-iter! [39] 100.0% ----------------------------------------------------------------------------------------- iterate-egraph!13 [3] 100.0% [23] 231424(49.9%) 3032(0.7%) one-iter ...f-of-prods/src/core/simplify.rkt:113:0 loop [40] 69.1% for-loop [42] 26.0% apply-match [51] 3.2% ----------------------------------------------------------------------------------------- run-improve50 [2] 100.0% [24] 114010(24.6%) 0(0.0%) get-final-combination ...ds/src/mainloop.rkt:264:0 split-table [41] 99.7% extract-alt [47] 0.3% ----------------------------------------------------------------------------------------- approximate9 [4] 100.0% [25] 40406(8.7%) 0(0.0%) loop ...bie/diff-of-prods/src/core/taylor.rkt:86:4 ??? [182] 59.6% hash-ref! [211] 40.4% ----------------------------------------------------------------------------------------- ??? [6] 100.0% [26] 35950(7.8%) 348(0.1%) for-loop ...ff-of-prods/src/core/taylor.rkt:285:52 ??? [44] 62.5% hash-ref! [211] 34.3% simplify [43] 2.7% ----------------------------------------------------------------------------------------- ??? [7] 100.0% [27] 32126(6.9%) 0(0.0%) for-loop ...ff-of-prods/src/core/taylor.rkt:298:27 hash-ref! [211] 100.0% ----------------------------------------------------------------------------------------- ??? [8] 100.0% [28] 29028(6.3%) 0(0.0%) for-loop ...ff-of-prods/src/core/taylor.rkt:324:46 hash-ref! [211] 100.0% ----------------------------------------------------------------------------------------- ??? [11] 100.0% [29] 14834(3.2%) 0(0.0%) for-loop ...ff-of-prods/src/core/taylor.rkt:396:33 for-loop [45] 100.0% ----------------------------------------------------------------------------------------- loop [12] 100.0% [30] 14142(3.1%) 0(0.0%) pass .../diff-of-prods/src/core/simplify.rkt:205:2 for-loop [46] 100.0% ----------------------------------------------------------------------------------------- ??? [16] 100.0% [31] 2106(0.5%) 0(0.0%) for-loop ...ff-of-prods/src/core/taylor.rkt:487:35 parse-loop12 [188] 100.0% ----------------------------------------------------------------------------------------- for-loop [14] 100.0% [32] 1048(0.2%) 0(0.0%) eval-const-expr ...of-prods/src/programs.rkt:166:0 f6 [52] 100.0% ----------------------------------------------------------------------------------------- simplify [43] 35.0% taylor [18] 65.0% [33] 1028(0.2%) 0(0.0%) debug7 ...herbie/diff-of-prods/src/debug.rkt:102:0 ??? [132] 66.1% ??? [235] 33.9% ----------------------------------------------------------------------------------------- ??? [17] 100.0% [34] 1028(0.2%) 0(0.0%) for-loop ...ff-of-prods/src/core/taylor.rkt:341:46 hash-ref! [211] 100.0% ----------------------------------------------------------------------------------------- for-loop [14] 100.0% [35] 724(0.2%) 724(0.2%) setfindf ...bie/diff-of-prods/src/common.rkt:179:0 ----------------------------------------------------------------------------------------- for-loop [48] 50.0% loop [19] 50.0% [36] 330(0.1%) 0(0.0%) expression->type ...-prods/src/type-check.rkt:45:0 for-loop [48] 100.0% ----------------------------------------------------------------------------------------- taylor-invert [20] 100.0% [37] 326(0.1%) 0(0.0%) first-nonzero-exp ...ods/src/core/taylor.rkt:260:0 hash-ref! [211] 100.0% ----------------------------------------------------------------------------------------- run-improve50 [2] 100.0% [38] 314(0.1%) 0(0.0%) setup-alt-simplified ...of-prods/src/glue.rkt:49:0 simplify-alt [49] 100.0% ----------------------------------------------------------------------------------------- for-loop [22] 100.0% [39] 270316(58.3%) 0(0.0%) run-iter! .../diff-of-prods/src/mainloop.rkt:215:0 simplify! [50] 77.8% gen-series! [53] 15.4% finalize-iter! [54] 5.4% gen-rewrites! [58] 0.8% choose-best-alt! [59] 0.4% ----------------------------------------------------------------------------------------- one-iter [23] 100.0% [40] 159948(34.5%) 0(0.0%) loop ...cket/collects/racket/private/map.rkt:52:19 apply-match [51] 100.0% ----------------------------------------------------------------------------------------- get-final-combination [24] 100.0% [41] 113652(24.5%) 0(0.0%) split-table ...ie/diff-of-prods/src/glue.rkt:162:0 f6 [52] 99.7% ??? [132] 0.3% ----------------------------------------------------------------------------------------- for-loop [42] 49.2% one-iter [23] 50.8% [42] 60214(13.0%) 13482(2.9%) for-loop ...-of-prods/src/core/simplify.rkt:123:12 for-loop [42] 49.2% match-e [64] 38.8% ----------------------------------------------------------------------------------------- ??? [182] 0.8% parse-loop12 [188] 0.9% loop [199] 0.9% ??? [5] 0.9% taylor-sqrt [170] 0.9% for-loop [204] 1.7% for-loop [26] 3.5% hash-ref! [211] 90.6% [43] 40372(8.7%) 0(0.0%) simplify ...diff-of-prods/src/core/reduce.rkt:16:0 f6 [52] 60.7% parse-loop12 [188] 30.7% debug-print [57] 6.9% debug7 [33] 0.9% simplify-node [161] 0.9% ----------------------------------------------------------------------------------------- ??? [5] 38.6% for-loop [26] 61.4% [44] 35914(7.8%) 0(0.0%) ??? ...ie/diff-of-prods/src/core/taylor.rkt:288:19 hash-ref! [211] 100.0% ----------------------------------------------------------------------------------------- for-loop [29] 100.0% [45] 14834(3.2%) 0(0.0%) for-loop ...ff-of-prods/src/core/taylor.rkt:398:39 hash-ref! [211] 100.0% ----------------------------------------------------------------------------------------- pass [30] 100.0% [46] 14142(3.1%) 0(0.0%) for-loop ...-of-prods/src/core/simplify.rkt:208:29 argmin [55] 73.2% loop [56] 24.5% for-loop [60] 2.3% ----------------------------------------------------------------------------------------- get-final-combination [24] 100.0% [47] 358(0.1%) 0(0.0%) extract-alt ...bie/diff-of-prods/src/glue.rkt:55:0 loop [206] 100.0% ----------------------------------------------------------------------------------------- expression->type [36] 100.0% [48] 330(0.1%) 0(0.0%) for-loop .../diff-of-prods/src/type-check.rkt:52:5 expression->type [36] 50.0% f6 [52] 50.0% ----------------------------------------------------------------------------------------- setup-alt-simplified [38] 100.0% [49] 314(0.1%) 0(0.0%) simplify-alt ...ie/diff-of-prods/src/glue.rkt:76:0 ??? [198] 100.0% ----------------------------------------------------------------------------------------- run-iter! [39] 100.0% [50] 210200(45.4%) 0(0.0%) simplify! .../diff-of-prods/src/mainloop.rkt:155:0 for-loop [61] 100.0% ----------------------------------------------------------------------------------------- one-iter [23] 4.5% loop [40] 95.5% [51] 167464(36.1%) 1052(0.2%) apply-match ...f-prods/src/core/simplify.rkt:130:2 for-loop [62] 86.8% match-e [64] 9.7% update-leader! [88] 2.2% ----------------------------------------------------------------------------------------- ??? [162] 0.0% for-loop [48] 0.0% approximate9 [4] 0.2% simplify-node [161] 0.3% composed [218] 0.4% loop [199] 0.6% eval-const-expr [32] 0.7% hash-ref! [211] 0.8% append-map [167] 0.9% eval-prog [165] 2.3% parse-loop12 [188] 3.4% f6 [52] 4.8% simplify [43] 6.2% map [154] 7.3% split-table [41] 71.9% [52] 146864(31.7%) 9072(2.0%) f6 ...et/collects/racket/match/compiler.rkt:507:40 loop [199] 55.1% option-on-expr [63] 16.8% map [154] 15.0% f6 [52] 4.8% ??? [182] 2.4% append-map [167] 1.4% compose [254] 0.5% composed [218] 0.4% taylor [18] 0.3% ??? [198] 0.3% taylor-sqrt [170] 0.2% ??? [71] 0.2% parse-loop12 [188] 0.1% combine-mterms [70] 0.1% loop [19] 0.0% taylor-invert [20] 0.0% ----------------------------------------------------------------------------------------- run-iter! [39] 100.0% [53] 41740(9.0%) 0(0.0%) gen-series! ...iff-of-prods/src/mainloop.rkt:129:0 for-loop [65] 100.0% ----------------------------------------------------------------------------------------- run-iter! [39] 100.0% [54] 14620(3.2%) 0(0.0%) finalize-iter! ...-of-prods/src/mainloop.rkt:169:0 ??? [132] 100.0% ----------------------------------------------------------------------------------------- for-loop [46] 100.0% [55] 10350(2.2%) 0(0.0%) argmin ...re/racket/collects/racket/list.rkt:743:0 for-loop [66] 96.7% expression-cost [69] 3.3% ----------------------------------------------------------------------------------------- for-loop [46] 100.0% [56] 3464(0.7%) 0(0.0%) loop ...hare/racket/collects/racket/list.rkt:729:4 for-loop [66] 79.8% expression-cost [69] 20.2% ----------------------------------------------------------------------------------------- iterate-egraph!13 [3] 11.4% simplify [43] 88.6% [57] 3140(0.7%) 1038(0.2%) debug-print ...e/diff-of-prods/src/debug.rkt:107:0 for-loop [67] 66.9% ----------------------------------------------------------------------------------------- run-iter! [39] 100.0% [58] 2040(0.4%) 0(0.0%) gen-rewrites! ...f-of-prods/src/mainloop.rkt:142:0 for-loop [68] 100.0% ----------------------------------------------------------------------------------------- run-iter! [39] 100.0% [59] 1058(0.2%) 0(0.0%) choose-best-alt! ...f-prods/src/mainloop.rkt:115:0 ??? [132] 100.0% ----------------------------------------------------------------------------------------- for-loop [46] 100.0% [60] 328(0.1%) 328(0.1%) for-loop ...-of-prods/src/core/simplify.rkt:195:13 ----------------------------------------------------------------------------------------- simplify! [50] 99.2% [61] 211982(45.7%) 0(0.0%) for-loop ...e/diff-of-prods/src/mainloop.rkt:159:6 ??? [72] 100.0% ----------------------------------------------------------------------------------------- apply-match [51] 100.0% [62] 145442(31.4%) 354(0.1%) for-loop ...-of-prods/src/core/simplify.rkt:145:10 merge-egraph-nodes! [76] 26.5% mk-enode! [85] 25.5% loop! [212] 24.1% substitute-e [77] 17.2% list-member? [215] 6.4% ----------------------------------------------------------------------------------------- f6 [52] 22.7% loop [199] 77.3% [63] 113294(24.5%) 0(0.0%) option-on-expr ...prods/src/core/regimes.rkt:103:0 sindices->spoints [73] 69.2% loop [199] 10.0% err-lsts->split-indices [78] 9.3% sort-context-on-expr [79] 7.3% errors [159] 3.7% pick-errors [82] 0.6% ----------------------------------------------------------------------------------------- apply-match [51] 13.7% for-loop [87] 28.9% for-loop [42] 57.3% [64] 62954(13.6%) 20266(4.4%) match-e .../diff-of-prods/src/core/ematch.rkt:46:0 for-loop [75] 47.3% for-loop [87] 7.8% ??? [132] 7.3% variable? [13] 5.3% curry* [96] 1.4% loop [199] 0.8% list-cartesian-product [93] 0.8% custom-in-set [130] 0.6% ----------------------------------------------------------------------------------------- gen-series! [53] 100.0% [65] 41740(9.0%) 0(0.0%) for-loop ...e/diff-of-prods/src/mainloop.rkt:135:7 taylor-alt [74] 100.0% ----------------------------------------------------------------------------------------- loop [56] 21.7% argmin [55] 78.3% [66] 12774(2.8%) 0(0.0%) for-loop ...e/diff-of-prods/src/programs.rkt:199:2 ??? [198] 75.5% ...prods/src/common.rkt:47:2 [201] 24.5% ----------------------------------------------------------------------------------------- debug-print [57] 100.0% [67] 2102(0.5%) 2102(0.5%) for-loop ...rbie/diff-of-prods/src/debug.rkt:113:2 ----------------------------------------------------------------------------------------- gen-rewrites! [58] 100.0% [68] 2040(0.4%) 0(0.0%) for-loop .../diff-of-prods/src/mainloop.rkt:147:11 ??? [80] 100.0% ----------------------------------------------------------------------------------------- argmin [55] 32.9% loop [56] 67.1% [69] 1040(0.2%) 0(0.0%) expression-cost ...of-prods/src/programs.rkt:198:0 compile [81] 100.0% ----------------------------------------------------------------------------------------- f6 [52] 100.0% [70] 712(0.2%) 354(0.1%) combine-mterms ...-prods/src/core/reduce.rkt:191:0 for-loop [83] 50.3% ----------------------------------------------------------------------------------------- f6 [52] 100.0% [71] 336(0.1%) 0(0.0%) ??? ...tract/private/arrow-higher-order.rkt:336:46 ??? [258] 100.0% ----------------------------------------------------------------------------------------- for-loop [61] 15.9% run [21] 37.9% [72] 451956(97.5%) 0(0.0%) ??? ...lects/racket/private/more-scheme.rkt:261:28 profile-thunk16 [1] 37.8% run-improve50 [2] 35.2% ??? [198] 23.6% loop [131] 3.4% ----------------------------------------------------------------------------------------- option-on-expr [63] 100.0% [73] 78356(16.9%) 0(0.0%) sindices->spoints ...ds/src/core/regimes.rkt:116:0 loop [84] 99.6% ----------------------------------------------------------------------------------------- for-loop [65] 100.0% [74] 41740(9.0%) 0(0.0%) taylor-alt ...bie/diff-of-prods/src/glue.rkt:134:0 for-loop [86] 100.0% ----------------------------------------------------------------------------------------- match-e [64] 100.0% [75] 39912(8.6%) 11148(2.4%) for-loop ...iff-of-prods/src/core/ematch.rkt:59:11 for-loop [87] 62.3% list-cartesian-product [93] 6.4% loop [199] 1.7% foldl [222] 1.3% curry* [96] 1.3% filter [253] 0.8% ----------------------------------------------------------------------------------------- for-loop [92] 6.8% merge-egraph-nodes! [76] 8.1% for-loop [62] 85.0% [76] 38580(8.3%) 362(0.1%) merge-egraph-nodes! ...s/src/core/egraph.rkt:152:0 update-leader! [88] 43.4% for-loop [90] 20.4% for-loop [92] 12.2% loop! [212] 10.5% merge-egraph-nodes! [76] 8.1% enode-merge! [95] 4.5% ----------------------------------------------------------------------------------------- substitute-e [77] 6.8% for-loop [62] 93.2% [77] 25078(5.4%) 1076(0.2%) substitute-e ...-of-prods/src/core/ematch.rkt:71:0 mk-enode! [85] 87.3% substitute-e [77] 6.8% ??? [132] 2.1% variable? [13] 1.0% ----------------------------------------------------------------------------------------- option-on-expr [63] 100.0% [78] 10542(2.3%) 0(0.0%) err-lsts->split-indices .../core/regimes.rkt:222:0 add-splitpoint [89] 100.0% ----------------------------------------------------------------------------------------- option-on-expr [63] 100.0% [79] 8234(1.8%) 0(0.0%) sort-context-on-expr ...prods/src/points.rkt:115:0 ??? [91] 100.0% ----------------------------------------------------------------------------------------- for-loop [68] 100.0% [80] 2040(0.4%) 0(0.0%) ??? ...rbie/diff-of-prods/src/alternative.rkt:88:0 rewriter [94] 100.0% ----------------------------------------------------------------------------------------- expression-cost [69] 100.0% [81] 1040(0.2%) 358(0.1%) compile ...ie/diff-of-prods/src/programs.rkt:175:0 hash-ref! [211] 65.6% ----------------------------------------------------------------------------------------- option-on-expr [63] 100.0% [82] 708(0.2%) 0(0.0%) pick-errors ...of-prods/src/core/regimes.rkt:184:0 point->alt [97] 50.3% for-loop [98] 49.7% ----------------------------------------------------------------------------------------- combine-mterms [70] 100.0% [83] 358(0.1%) 358(0.1%) for-loop ...iff-of-prods/src/core/reduce.rkt:195:5 ----------------------------------------------------------------------------------------- map [154] 0.0% loop [84] 21.5% sindices->spoints [73] 78.4% [84] 78312(16.9%) 0(0.0%) loop ...cket/collects/racket/private/map.rkt:36:19 sidx->spoint [99] 78.4% loop [84] 21.5% ----------------------------------------------------------------------------------------- expr->enode [239] 2.8% substitute-e [77] 36.1% for-loop [62] 61.1% [85] 60644(13.1%) 4244(0.9%) mk-enode! ...ff-of-prods/src/core/egraph.rkt:101:0 new-enode [100] 90.2% hash-has-key? [138] 1.7% ----------------------------------------------------------------------------------------- taylor-alt [74] 100.0% [86] 41740(9.0%) 0(0.0%) for-loop ...erbie/diff-of-prods/src/glue.rkt:139:6 ??? [182] 100.0% ----------------------------------------------------------------------------------------- match-e [64] 22.5% for-loop [75] 77.5% [87] 33618(7.3%) 1064(0.2%) for-loop ...iff-of-prods/src/core/ematch.rkt:65:37 match-e [64] 93.8% ??? [106] 3.6% ----------------------------------------------------------------------------------------- apply-match [51] 16.6% merge-egraph-nodes! [76] 83.4% [88] 22538(4.9%) 1414(0.3%) update-leader! ...-prods/src/core/egraph.rkt:217:0 for-loop [101] 90.9% custom-set-union! [110] 1.6% make-sequence [112] 1.3% ----------------------------------------------------------------------------------------- err-lsts->split-indices [78] 100.0% [89] 10542(2.3%) 0(0.0%) add-splitpoint ...prods/src/core/regimes.rkt:235:2 for-loop [102] 100.0% ----------------------------------------------------------------------------------------- merge-egraph-nodes! [76] 100.0% [90] 8348(1.8%) 6612(1.4%) for-loop ...iff-of-prods/src/core/egraph.rkt:232:6 update-en-expr [236] 20.8% ----------------------------------------------------------------------------------------- sort-context-on-expr [79] 100.0% [91] 8234(1.8%) 0(0.0%) ??? ...cket/collects/racket/private/sort.rkt:403:3 generic-sort/key [103] 91.8% loop [127] 8.2% ----------------------------------------------------------------------------------------- merge-egraph-nodes! [76] 100.0% [92] 7516(1.6%) 0(0.0%) for-loop ...ff-of-prods/src/core/egraph.rkt:200:10 merge-egraph-nodes! [76] 72.5% loop! [212] 27.5% ----------------------------------------------------------------------------------------- match-e [64] 14.3% list-cartesian-product [93] 28.1% for-loop [75] 57.6% [93] 4766(1.0%) 4080(0.9%) list-cartesian-product ...src/core/ematch.rkt:20:0 list-cartesian-product [93] 28.1% for-loop [109] 14.4% ----------------------------------------------------------------------------------------- ??? [80] 34.1% matcher [119] 65.9% [94] 2040(0.4%) 696(0.2%) rewriter ...ff-of-prods/src/core/matcher.rkt:131:2 for-loop [104] 65.9% *rules* [107] 27.8% ----------------------------------------------------------------------------------------- merge-egraph-nodes! [76] 100.0% [95] 1726(0.4%) 0(0.0%) enode-merge! ...-of-prods/src/core/enode.rkt:129:0 adopt-enode! [105] 79.7% custom-set-intersect! [111] 20.3% ----------------------------------------------------------------------------------------- for-loop [75] 38.2% match-e [64] 61.8% [96] 1718(0.4%) 714(0.2%) curry* ...racket/collects/racket/function.rkt:44:2 procedure-arity [108] 58.4% ----------------------------------------------------------------------------------------- pick-errors [82] 100.0% [97] 356(0.1%) 0(0.0%) point->alt ...-of-prods/src/core/regimes.rkt:171:0 eval-prog [165] 100.0% ----------------------------------------------------------------------------------------- pick-errors [82] 100.0% [98] 352(0.1%) 0(0.0%) for-loop ...ff-of-prods/src/core/regimes.rkt:186:2 ??? [171] 100.0% ----------------------------------------------------------------------------------------- loop [84] 100.0% [99] 78014(16.8%) 0(0.0%) sidx->spoint ...f-prods/src/core/regimes.rkt:126:2 binary-search [114] 62.6% binary-search-floats [115] 37.4% ----------------------------------------------------------------------------------------- mk-enode! [85] 100.0% [100] 54722(11.8%) 276(0.1%) new-enode ...diff-of-prods/src/core/enode.rkt:97:0 type-of-enode-expr [113] 97.1% set [232] 1.8% ----------------------------------------------------------------------------------------- update-leader! [88] 100.0% [101] 20480(4.4%) 1022(0.2%) for-loop ...iff-of-prods/src/core/egraph.rkt:222:6 for-loop [116] 93.4% update-en-expr [236] 1.6% ----------------------------------------------------------------------------------------- add-splitpoint [89] 100.0% [102] 10542(2.3%) 3042(0.7%) for-loop ...ff-of-prods/src/core/regimes.rkt:237:4 for-loop [117] 71.1% ----------------------------------------------------------------------------------------- ??? [91] 100.0% [103] 7558(1.6%) 0(0.0%) generic-sort/key .../racket/private/sort.rkt:185:2 copying-mergesort [118] 85.7% loop [127] 14.3% ----------------------------------------------------------------------------------------- rewriter [94] 100.0% [104] 2040(0.4%) 0(0.0%) for-loop ...f-of-prods/src/core/matcher.rkt:134:10 matcher [119] 100.0% ----------------------------------------------------------------------------------------- enode-merge! [95] 100.0% [105] 1376(0.3%) 302(0.1%) adopt-enode! ...-of-prods/src/core/enode.rkt:105:0 custom-set-union [229] 78.1% ----------------------------------------------------------------------------------------- for-loop [87] 100.0% [106] 1376(0.3%) 1028(0.2%) ??? ...rbie/diff-of-prods/src/core/ematch.rkt:50:5 for-loop [122] 25.3% ----------------------------------------------------------------------------------------- rewriter [94] 100.0% [107] 1344(0.3%) 0(0.0%) *rules* ...iff-of-prods/src/syntax/rules.rkt:493:0 for-loop [120] 100.0% ----------------------------------------------------------------------------------------- curry* [96] 100.0% [108] 1004(0.2%) 1004(0.2%) procedure-arity ...ket/private/norm-arity.rkt:7:27 ----------------------------------------------------------------------------------------- list-cartesian-product [93] 100.0% [109] 686(0.1%) 686(0.1%) for-loop ...diff-of-prods/src/core/ematch.rkt:24:8 ----------------------------------------------------------------------------------------- update-leader! [88] 100.0% [110] 356(0.1%) 0(0.0%) custom-set-union! ...t/private/set-types.rkt:245:0 for-loop [121] 100.0% ----------------------------------------------------------------------------------------- enode-merge! [95] 100.0% [111] 350(0.1%) 350(0.1%) custom-set-intersect! ...ivate/set-types.rkt:269:0 ----------------------------------------------------------------------------------------- update-leader! [88] 100.0% [112] 288(0.1%) 0(0.0%) make-sequence ...ects/racket/private/for.rkt:509:2 ??? [123] 100.0% ----------------------------------------------------------------------------------------- new-enode [100] 100.0% [113] 53150(11.5%) 676(0.1%) type-of-enode-expr ...rods/src/core/enode.rkt:68:0 get-sigs [125] 98.1% parse-loop12 [188] 0.7% ----------------------------------------------------------------------------------------- sidx->spoint [99] 100.0% [114] 48818(10.5%) 0(0.0%) binary-search ...iff-of-prods/src/common.rkt:221:0 pred [124] 100.0% ----------------------------------------------------------------------------------------- sidx->spoint [99] 100.0% [115] 29196(6.3%) 0(0.0%) binary-search-floats ...prods/src/common.rkt:236:0 pred [124] 100.0% ----------------------------------------------------------------------------------------- for-loop [101] 100.0% [116] 19132(4.1%) 314(0.1%) for-loop ...iff-of-prods/src/core/egraph.rkt:223:8 hash-update! [126] 98.4% ----------------------------------------------------------------------------------------- for-loop [102] 100.0% [117] 7500(1.6%) 7500(1.6%) for-loop ...ff-of-prods/src/core/regimes.rkt:241:8 ----------------------------------------------------------------------------------------- generic-sort/key [103] 42.1% copying-mergesort [118] 57.9% [118] 6478(1.4%) 0(0.0%) copying-mergesort ...racket/private/sort.rkt:130:8 copying-mergesort [118] 57.9% loop [127] 31.5% jloop [15] 10.6% ----------------------------------------------------------------------------------------- for-loop [128] 9.8% matcher [119] 42.9% for-loop [104] 47.3% [119] 2040(0.4%) 0(0.0%) matcher ...iff-of-prods/src/core/matcher.rkt:167:2 rewriter [94] 47.3% matcher [119] 42.9% for-loop [128] 9.8% ----------------------------------------------------------------------------------------- *simplify-rules* [227] 20.9% *rules* [107] 79.1% [120] 1700(0.4%) 0(0.0%) for-loop ...rbie/diff-of-prods/src/common.rkt:94:9 flag-set? [135] 59.2% ormap [129] 40.8% ----------------------------------------------------------------------------------------- custom-set-union! [110] 100.0% [121] 356(0.1%) 356(0.1%) for-loop ...cts/racket/private/set-types.rkt:253:4 ----------------------------------------------------------------------------------------- ??? [106] 100.0% [122] 348(0.1%) 0(0.0%) for-loop ...diff-of-prods/src/core/ematch.rkt:51:7 ??? [132] 100.0% ----------------------------------------------------------------------------------------- make-sequence [112] 100.0% [123] 288(0.1%) 0(0.0%) ??? ...acket/collects/racket/private/for.rkt:429:7 custom-in-set [130] 100.0% ----------------------------------------------------------------------------------------- binary-search-floats [115] 37.4% binary-search [114] 62.6% [124] 78014(16.8%) 0(0.0%) pred .../diff-of-prods/src/core/regimes.rkt:132:17 loop [131] 85.7% errors [159] 14.3% ----------------------------------------------------------------------------------------- type-of-enode-expr [113] 100.0% [125] 52116(11.2%) 0(0.0%) get-sigs ...e/diff-of-prods/src/type-check.rkt:5:0 ??? [133] 40.8% ??? [198] 26.2% ...prods/src/common.rkt:47:2 [201] 19.9% ??? [132] 13.1% ----------------------------------------------------------------------------------------- for-loop [116] 100.0% [126] 18818(4.1%) 360(0.1%) hash-update! ...ket/private/more-scheme.rkt:362:13 ??? [134] 98.1% ----------------------------------------------------------------------------------------- ??? [91] 12.3% generic-sort/key [103] 19.7% copying-mergesort [118] 68.0% [127] 5488(1.2%) 0(0.0%) loop ...ket/collects/racket/private/sort.rkt:97:12 ??? [173] 81.5% ??? [182] 18.5% ----------------------------------------------------------------------------------------- matcher [119] 100.0% [128] 1046(0.2%) 0(0.0%) for-loop ...f-of-prods/src/core/matcher.rkt:183:21 matcher [119] 100.0% ----------------------------------------------------------------------------------------- for-loop [120] 100.0% [129] 694(0.1%) 0(0.0%) ormap ...et/collects/racket/private/map.rkt:105:13 flag-set? [135] 100.0% ----------------------------------------------------------------------------------------- ??? [123] 44.7% match-e [64] 55.3% [130] 644(0.1%) 644(0.1%) custom-in-set ...acket/private/set-types.rkt:577:0 ----------------------------------------------------------------------------------------- run-improve50 [2] 0.7% ??? [72] 30.9% pred [124] 68.4% [131] 97662(21.1%) 336(0.1%) loop .../herbie/diff-of-prods/src/points.rkt:193:2 loop [136] 52.7% loop [146] 27.5% make-exacts* [147] 15.8% for-loop [142] 3.6% ----------------------------------------------------------------------------------------- for-loop [122] 0.7% split-table [41] 0.7% debug7 [33] 1.4% choose-best-alt! [59] 2.2% substitute-e [77] 2.8% ??? [258] 6.4% get-sigs [125] 13.9% variable? [13] 21.3% match-e [64] 21.4% finalize-iter! [54] 29.2% [132] 48950(10.6%) 18898(4.1%) ??? ...contract/private/arrow-val-first.rkt:357:18 hash-has-key? [138] 29.3% for-loop [139] 27.7% ??? [143] 2.2% atab-add-altns [144] 1.4% split-atab [145] 0.7% ----------------------------------------------------------------------------------------- ??? [182] 4.9% get-sigs [125] 95.1% [133] 22336(4.8%) 1442(0.3%) ??? ...ts/racket/contract/private/arr-i.rkt:804:10 ??? [140] 51.6% for-loop [141] 34.0% get/build-late-neg-projection [169] 4.8% ??? [250] 3.2% ----------------------------------------------------------------------------------------- hash-update! [126] 100.0% [134] 18458(4.0%) 0(0.0%) ??? ...ie/diff-of-prods/src/core/egraph.rkt:225:24 for-loop [137] 100.0% ----------------------------------------------------------------------------------------- ormap [129] 40.8% for-loop [120] 59.2% [135] 1700(0.4%) 1024(0.2%) flag-set? ...bie/diff-of-prods/src/config.rkt:32:0 ??? [235] 20.6% return/no-unsupplied [237] 19.2% ----------------------------------------------------------------------------------------- loop [131] 100.0% [136] 51498(11.1%) 0(0.0%) loop .../herbie/diff-of-prods/src/points.rkt:151:2 eval-prog [165] 79.8% loop [146] 11.4% make-exacts* [147] 8.9% ----------------------------------------------------------------------------------------- ??? [134] 100.0% [137] 18458(4.0%) 17038(3.7%) for-loop ...ff-of-prods/src/core/egraph.rkt:226:26 update-en-expr [236] 7.7% ----------------------------------------------------------------------------------------- mk-enode! [85] 6.5% ??? [132] 93.5% [138] 15732(3.4%) 4864(1.0%) hash-has-key? ...et/private/more-scheme.rkt:368:13 ??? [213] 58.5% ??? [151] 10.6% ----------------------------------------------------------------------------------------- ??? [132] 100.0% [139] 13926(3.0%) 0(0.0%) for-loop ...f-of-prods/src/core/alt-table.rkt:51:2 atab-add-altn [148] 100.0% ----------------------------------------------------------------------------------------- ??? [133] 100.0% [140] 11520(2.5%) 708(0.2%) ??? ...ects/racket/contract/private/hash.rkt:217:4 ??? [149] 93.9% ----------------------------------------------------------------------------------------- for-loop [230] 15.3% ??? [133] 84.7% [141] 8956(1.9%) 684(0.1%) for-loop ...racket/contract/private/hash.rkt:239:6 ??? [231] 88.7% ??? [261] 3.6% ----------------------------------------------------------------------------------------- loop [131] 100.0% [142] 3544(0.8%) 0(0.0%) for-loop ...ie/diff-of-prods/src/points.rkt:200:24 for-loop [150] 80.1% ??? [152] 19.9% ----------------------------------------------------------------------------------------- ??? [132] 100.0% [143] 1058(0.2%) 0(0.0%) ??? ...e/diff-of-prods/src/core/alt-table.rkt:54:0 ??? [182] 100.0% ----------------------------------------------------------------------------------------- ??? [132] 100.0% [144] 694(0.1%) 0(0.0%) atab-add-altns ...rods/src/core/alt-table.rkt:50:0 atab-add-altn [148] 100.0% ----------------------------------------------------------------------------------------- ??? [132] 100.0% [145] 358(0.1%) 0(0.0%) split-atab ...of-prods/src/core/alt-table.rkt:74:0 for-loop [153] 100.0% ----------------------------------------------------------------------------------------- loop [136] 17.9% loop [131] 82.1% [146] 32744(7.1%) 0(0.0%) loop .../herbie/diff-of-prods/src/points.rkt:141:4 map [154] 98.9% loop [199] 1.1% ----------------------------------------------------------------------------------------- loop [136] 22.9% loop [131] 77.1% [147] 19962(4.3%) 0(0.0%) make-exacts* ...diff-of-prods/src/points.rkt:138:0 map [154] 63.7% loop [199] 36.3% ----------------------------------------------------------------------------------------- atab-add-altns [144] 4.7% for-loop [139] 95.3% [148] 14620(3.2%) 0(0.0%) atab-add-altn ...rods/src/core/alt-table.rkt:208:0 best-and-tied-at-points [155] 85.5% override-at-pnts [157] 14.5% ----------------------------------------------------------------------------------------- ??? [140] 100.0% [149] 10812(2.3%) 384(0.1%) ??? ...ects/racket/contract/private/list.rkt:169:2 ??? [156] 96.4% ----------------------------------------------------------------------------------------- for-loop [142] 100.0% [150] 2838(0.6%) 358(0.1%) for-loop ...ie/diff-of-prods/src/points.rkt:201:26 ??? [182] 87.4% ----------------------------------------------------------------------------------------- hash-has-key? [138] 100.0% [151] 1668(0.4%) 1668(0.4%) ??? ...ects/racket/contract/private/hash.rkt:245:7 ----------------------------------------------------------------------------------------- for-loop [142] 100.0% [152] 706(0.2%) 350(0.1%) ??? ...tract/private/arrow-higher-order.rkt:346:33 ??? [231] 50.4% ----------------------------------------------------------------------------------------- split-atab [145] 100.0% [153] 358(0.1%) 0(0.0%) for-loop ...f-of-prods/src/core/alt-table.rkt:75:2 for-loop [158] 100.0% ----------------------------------------------------------------------------------------- loop [199] 0.5% ??? [162] 0.5% parse-loop12 [188] 1.4% make-exacts* [147] 17.2% f6 [52] 36.4% loop [146] 43.9% [154] 73800(15.9%) 686(0.1%) map ...acket/collects/racket/private/map.rkt:20:13 loop [199] 44.8% f6 [52] 19.5% ??? [173] 16.3% parse-loop12 [188] 13.9% ??? [162] 1.4% simplify-node [161] 1.3% ??? [182] 1.0% make-multiplication-node [219] 0.8% loop [84] 0.4% simplify* [203] 0.3% ----------------------------------------------------------------------------------------- atab-add-altn [148] 100.0% [155] 12498(2.7%) 0(0.0%) best-and-tied-at-points ...ore/alt-table.rkt:122:0 errors [159] 97.1% for-loop [163] 2.9% ----------------------------------------------------------------------------------------- ??? [149] 100.0% [156] 10428(2.3%) 354(0.1%) ??? ...ects/racket/contract/private/list.rkt:678:5 for-loop [160] 96.6% ----------------------------------------------------------------------------------------- atab-add-altn [148] 100.0% [157] 2122(0.5%) 0(0.0%) override-at-pnts ...s/src/core/alt-table.rkt:145:0 errors [159] 100.0% ----------------------------------------------------------------------------------------- for-loop [153] 100.0% [158] 358(0.1%) 0(0.0%) for-loop ...-of-prods/src/core/alt-table.rkt:76:45 ??? [164] 100.0% ----------------------------------------------------------------------------------------- composed [218] 3.4% override-at-pnts [157] 5.1% option-on-expr [63] 9.9% loop [199] 26.0% pred [124] 26.7% best-and-tied-at-points [155] 28.9% [159] 41974(9.1%) 0(0.0%) errors ...erbie/diff-of-prods/src/points.rkt:218:0 for-loop [166] 67.8% eval-prog [165] 31.4% ----------------------------------------------------------------------------------------- ??? [156] 100.0% [160] 10074(2.2%) 1424(0.3%) for-loop ...racket/contract/private/list.rkt:680:9 add-list-context [168] 55.5% get/build-late-neg-projection [169] 30.3% ----------------------------------------------------------------------------------------- simplify [43] 8.5% map [154] 91.5% [161] 4158(0.9%) 0(0.0%) simplify-node ...of-prods/src/core/reduce.rkt:50:0 f6 [52] 49.2% append-map [167] 42.3% combine-aterms [172] 8.5% ----------------------------------------------------------------------------------------- loop [199] 39.0% map [154] 61.0% [162] 1686(0.4%) 0(0.0%) ??? ...ket/collects/racket/private/list.rkt:323:18 taylor-sqrt [170] 42.0% hash-ref! [211] 28.4% f6 [52] 19.0% map [154] 10.7% ----------------------------------------------------------------------------------------- best-and-tied-at-points [155] 100.0% [163] 358(0.1%) 358(0.1%) for-loop ...of-prods/src/core/alt-table.rkt:124:16 ----------------------------------------------------------------------------------------- for-loop [158] 100.0% [164] 358(0.1%) 0(0.0%) ??? ...ie/diff-of-prods/src/core/regimes.rkt:284:4 ??? [171] 100.0% ----------------------------------------------------------------------------------------- point->alt [97] 0.7% errors [159] 24.1% loop [136] 75.2% [165] 54616(11.8%) 15048(3.2%) eval-prog .../diff-of-prods/src/programs.rkt:148:0 hash-ref! [211] 46.0% f6 [52] 21.0% ??? [182] 1.8% ??? [177] 1.2% ??? [178] 1.2% go [181] 0.6% ----------------------------------------------------------------------------------------- errors [159] 100.0% [166] 28440(6.1%) 4154(0.9%) for-loop ...bie/diff-of-prods/src/points.rkt:221:4 ??? [173] 67.1% ??? [182] 10.9% ulp-difference [175] 6.2% ----------------------------------------------------------------------------------------- simplify-node [161] 19.0% f6 [52] 81.0% [167] 5866(1.3%) 1074(0.2%) append-map ...acket/collects/racket/list.rkt:565:2 f6 [52] 52.8% parse-loop12 [188] 32.4% free-variables [273] 5.4% ----------------------------------------------------------------------------------------- for-loop [160] 100.0% [168] 5594(1.2%) 5594(1.2%) add-list-context ...ontract/private/list.rkt:752:0 ----------------------------------------------------------------------------------------- unconstrained-domain->-projection [180] 4.3% ??? [176] 8.7% ??? [133] 13.0% for-loop [160] 74.0% [169] 4132(0.9%) 1060(0.2%) get/build-late-neg-projection ...te/guts.rkt:691:0 ??? [174] 61.3% ??? [176] 8.7% unconstrained-domain->-projection [180] 4.3% listof-late-neg-projection [179] 4.3% ----------------------------------------------------------------------------------------- f6 [52] 33.7% ??? [162] 66.3% [170] 1068(0.2%) 0(0.0%) taylor-sqrt ...-of-prods/src/core/taylor.rkt:346:0 hash-ref! [211] 66.3% simplify [43] 33.7% ----------------------------------------------------------------------------------------- for-loop [98] 49.6% ??? [164] 50.4% [171] 710(0.2%) 0(0.0%) ??? ...ie/diff-of-prods/src/core/regimes.rkt:177:2 ??? [173] 100.0% ----------------------------------------------------------------------------------------- simplify-node [161] 100.0% [172] 354(0.1%) 354(0.1%) combine-aterms ...-prods/src/core/reduce.rkt:183:0 ----------------------------------------------------------------------------------------- ??? [171] 0.9% jloop [15] 3.5% loop [127] 5.7% map [154] 15.5% for-loop [166] 24.5% loop [199] 49.8% [173] 77852(16.8%) 2510(0.5%) ??? ...herbie/diff-of-prods/src/programs.rkt:154:4 ??? [183] 75.2% ??? [189] 11.4% ??? [182] 10.2% ----------------------------------------------------------------------------------------- get/build-late-neg-projection [169] 100.0% [174] 2714(0.6%) 1040(0.2%) ??? ...cts/racket/contract/private/prop.rkt:314:12 build-compound-type-name [184] 61.7% ----------------------------------------------------------------------------------------- for-loop [166] 100.0% [175] 1760(0.4%) 1398(0.3%) ulp-difference ...diff-of-prods/src/float.rkt:19:0 ??? [235] 20.6% ----------------------------------------------------------------------------------------- get/build-late-neg-projection [169] 100.0% [176] 718(0.2%) 0(0.0%) ??? ...ects/racket/contract/private/hash.rkt:211:2 get/build-late-neg-projection [169] 100.0% ----------------------------------------------------------------------------------------- eval-prog [165] 100.0% [177] 664(0.1%) 318(0.1%) ??? ...cket/collects/racket/private/kw.rkt:1633:36 unpack245 [186] 52.1% ----------------------------------------------------------------------------------------- eval-prog [165] 100.0% [178] 660(0.1%) 0(0.0%) ??? ...collects/racket/private/qq-and-or.rkt:155:9 ??? [185] 100.0% ----------------------------------------------------------------------------------------- get/build-late-neg-projection [169] 100.0% [179] 358(0.1%) 358(0.1%) listof-late-neg-projection ...ivate/list.rkt:162:0 ----------------------------------------------------------------------------------------- get/build-late-neg-projection [169] 100.0% [180] 358(0.1%) 0(0.0%) unconstrained-domain->-projection ...rrow.rkt:60:0 get/build-late-neg-projection [169] 100.0% ----------------------------------------------------------------------------------------- eval-prog [165] 100.0% [181] 302(0.1%) 0(0.0%) go .../collects/racket/private/qq-and-or.rkt:50:20 loop [187] 100.0% ----------------------------------------------------------------------------------------- map [154] 1.0% ??? [143] 1.2% eval-prog [165] 1.4% loop [127] 1.4% loop [199] 2.2% for-loop [150] 3.5% for-loop [166] 4.1% ??? [10] 7.7% ??? [173] 11.2% loop [25] 11.3% f6 [52] 15.2% ??? [198] 19.9% for-loop [86] 19.9% [182] 71008(15.3%) 1750(0.4%) ??? ...tract/private/arrow-higher-order.rkt:342:33 ??? [198] 45.1% approximate9 [4] 19.7% hash-ref! [211] 19.0% ??? [258] 4.4% ...prods/src/common.rkt:47:2 [201] 4.4% ??? [133] 1.5% ->bf [196] 1.4% best-alt [194] 1.2% ??? [189] 0.5% simplify [43] 0.2% ----------------------------------------------------------------------------------------- ??? [173] 100.0% [183] 58574(12.6%) 28008(6.0%) ??? ...acket/collects/racket/private/kw.rkt:444:14 ??? [200] 33.8% ??? [190] 5.9% bf* [191] 5.4% ??? [192] 3.4% ...higher-order.rkt:346:33 [195] 1.8% parse-loop12 [188] 1.2% ??? [261] 0.6% ----------------------------------------------------------------------------------------- ??? [174] 100.0% [184] 1674(0.4%) 316(0.1%) build-compound-type-name ...private/guts.rkt:448:0 contract-struct-name [193] 81.1% ----------------------------------------------------------------------------------------- ??? [178] 100.0% [185] 660(0.1%) 660(0.1%) ??? ...ollects/racket/private/qq-and-or.rkt:164:21 ----------------------------------------------------------------------------------------- ??? [177] 100.0% [186] 346(0.1%) 0(0.0%) unpack245 ...private/arrow-higher-order.rkt:354:44 maybe-cons-kwd [197] 100.0% ----------------------------------------------------------------------------------------- go [181] 20.0% loop [187] 80.0% [187] 302(0.1%) 302(0.1%) loop ...llects/racket/private/qq-and-or.rkt:101:61 loop [187] 80.0% ----------------------------------------------------------------------------------------- type-of-enode-expr [113] 1.1% f6 [52] 1.1% hash-ref! [211] 2.1% ??? [183] 2.3% loop [199] 2.6% for-loop [31] 6.7% append-map [167] 8.0% simplify [43] 15.9% parse-loop12 [188] 23.6% map [154] 36.7% [188] 31660(6.8%) 18768(4.1%) parse-loop12 ...s/racket/match/compiler.rkt:418:15 parse-loop12 [188] 23.6% f6 [52] 17.8% loop [199] 9.2% for-loop [204] 5.6% for-loop [205] 3.7% map [154] 3.2% simplify* [203] 1.4% simplify [43] 1.1% ??? [207] 0.6% ----------------------------------------------------------------------------------------- ??? [182] 3.9% ??? [173] 96.1% [189] 9198(2.0%) 0(0.0%) ??? ...contract/private/../../private/kw.rkt:761:9 real->bigfloat [202] 96.1% loop [208] 3.9% ----------------------------------------------------------------------------------------- ??? [183] 100.0% [190] 3450(0.7%) 3450(0.7%) ??? ...rivate/unconstrained-domain-arrow.rkt:40:13 ----------------------------------------------------------------------------------------- ??? [183] 100.0% [191] 3178(0.7%) 0(0.0%) bf* ...ath/private/bigfloat/bigfloat-mpfr.rkt:95:0 ??? [200] 100.0% ----------------------------------------------------------------------------------------- ??? [183] 100.0% [192] 2010(0.4%) 294(0.1%) ??? .../diff-of-prods/src/syntax/syntax.rkt:122:17 ??? [235] 68.7% return/no-unsupplied [237] 16.7% ----------------------------------------------------------------------------------------- build-compound-type-name [184] 100.0% [193] 1358(0.3%) 1358(0.3%) contract-struct-name ...ract/private/prop.rkt:89:0 ----------------------------------------------------------------------------------------- ??? [182] 100.0% [194] 1058(0.2%) 0(0.0%) best-alt ...herbie/diff-of-prods/src/glue.rkt:71:0 loop [206] 66.7% argmins [209] 33.3% ----------------------------------------------------------------------------------------- ??? [183] 100.0% [195] 1038(0.2%) 354(0.1%) ...higher-order.rkt:346:33 (unknown source) ??? [231] 65.9% ----------------------------------------------------------------------------------------- ??? [182] 100.0% [196] 1000(0.2%) 0(0.0%) ->bf ...herbie/diff-of-prods/src/programs.rkt:51:0 ...prods/src/common.rkt:47:2 [201] 67.8% ??? [198] 32.2% ----------------------------------------------------------------------------------------- unpack245 [186] 100.0% [197] 346(0.1%) 0(0.0%) maybe-cons-kwd ...ate/arrow-higher-order.rkt:498:0 successfully-got-the-right-kind-of-function [242]100.0% ----------------------------------------------------------------------------------------- simplify-alt [49] 0.1% f6 [52] 0.1% ->bf [196] 0.1% for-loop [66] 1.0% get-sigs [125] 1.5% ??? [198] 11.1% ??? [182] 17.0% for-loop [210] 30.1% ??? [72] 38.5% [198] 310938(67.1%) 13078(2.8%) ??? ...llects/racket/private/norm-define.rkt:53:83 iterate-egraph!13 [3] 37.0% for-loop [210] 30.1% ??? [182] 11.2% ??? [198] 11.1% ??? [213] 2.6% loop [12] 1.8% ??? [235] 1.7% return/no-unsupplied [237] 0.7% loop [223] 0.2% mk-egraph [220] 0.2% list-member? [215] 0.2% *simplify-rules* [227] 0.1% ??? [231] 0.0% ----------------------------------------------------------------------------------------- loop [146] 0.0% make-exacts* [147] 0.0% for-loop [75] 0.2% taylor [18] 0.2% match-e [64] 0.3% option-on-expr [63] 1.9% parse-loop12 [188] 2.4% map [154] 2.5% loop! [212] 2.7% ??? [9] 11.7% f6 [52] 28.0% loop [199] 49.8% [199] 168952(36.5%) 2756(0.6%) loop ...cket/collects/racket/private/map.rkt:25:19 loop [199] 49.8% option-on-expr [63] 28.0% hash-ref! [211] 11.7% loop! [212] 2.5% ??? [173] 2.5% errors [159] 1.9% parse-loop12 [188] 1.6% f6 [52] 0.6% foldl [222] 0.3% for-loop [14] 0.2% simplify [43] 0.2% ??? [162] 0.2% ??? [182] 0.0% map [154] 0.0% ----------------------------------------------------------------------------------------- bf* [191] 13.8% ??? [183] 86.2% [200] 22992(5.0%) 11114(2.4%) ??? ...-racket/utils/simple-result-arrow.rkt:39:12 bfmul [214] 44.9% bfsqrt [221] 6.8% ----------------------------------------------------------------------------------------- ->bf [196] 3.9% ??? [182] 18.0% for-loop [66] 18.1% get-sigs [125] 60.0% [201] 17316(3.7%) 5902(1.3%) ...prods/src/common.rkt:47:2 ...e/arr-i.rkt:906:19 ??? [216] 35.7% ??? [217] 30.2% ----------------------------------------------------------------------------------------- ??? [189] 100.0% [202] 8842(1.9%) 5636(1.2%) real->bigfloat .../private/bigfloat/mpfr.rkt:451:0 ??? [233] 36.3% ----------------------------------------------------------------------------------------- parse-loop12 [188] 33.5% map [154] 66.5% [203] 2100(0.5%) 694(0.1%) simplify* ...iff-of-prods/src/core/reduce.rkt:31:0 return/no-unsupplied [237] 32.9% hash-ref! [211] 17.0% ??? [225] 17.0% ----------------------------------------------------------------------------------------- parse-loop12 [188] 100.0% [204] 1760(0.4%) 0(0.0%) for-loop ...ff-of-prods/src/core/taylor.rkt:490:59 hash-ref! [211] 60.7% simplify [43] 39.3% ----------------------------------------------------------------------------------------- parse-loop12 [188] 100.0% [205] 1728(0.4%) 686(0.1%) for-loop ...iff-of-prods/src/core/reduce.rkt:99:13 make-multiplication-node [219] 60.3% ----------------------------------------------------------------------------------------- extract-alt [47] 33.6% best-alt [194] 66.4% [206] 1064(0.2%) 0(0.0%) loop .../herbie/diff-of-prods/src/common.rkt:146:2 composed [218] 100.0% ----------------------------------------------------------------------------------------- parse-loop12 [188] 100.0% [207] 358(0.1%) 0(0.0%) ??? ...rbie/diff-of-prods/src/core/reduce.rkt:61:5 for-loop [224] 100.0% ----------------------------------------------------------------------------------------- ??? [189] 100.0% [208] 356(0.1%) 0(0.0%) loop ...h-lib/math/private/bigfloat/mpfr.rkt:435:9 integer->mpz [226] 100.0% ----------------------------------------------------------------------------------------- best-alt [194] 100.0% [209] 352(0.1%) 0(0.0%) argmins ...rbie/diff-of-prods/src/common.rkt:145:0 composed [218] 100.0% ----------------------------------------------------------------------------------------- ??? [198] 100.0% [210] 193478(41.8%) 0(0.0%) for-loop ...f-of-prods/src/core/simplify.rkt:63:12 ??? [198] 100.0% ----------------------------------------------------------------------------------------- simplify* [203] 0.0% first-nonzero-exp [37] 0.1% for-loop [204] 0.1% ??? [17] 0.1% for-loop [34] 0.3% taylor-sqrt [170] 0.5% ??? [162] 0.6% ??? [5] 0.8% ??? [10] 0.8% compile [81] 1.0% for-loop [45] 1.8% for-loop [28] 4.1% loop [25] 4.9% for-loop [26] 5.0% ??? [182] 8.2% for-loop [27] 11.9% eval-prog [165] 13.9% ??? [44] 21.3% loop [199] 23.3% [211] 67578(14.6%) 358(0.1%) hash-ref! ...racket/private/more-scheme.rkt:373:13 ??? [9] 24.3% ??? [6] 21.2% bigfloat-hash [228] 13.9% ??? [7] 11.9% simplify [43] 7.1% ??? [5] 6.8% ??? [10] 5.7% ??? [8] 4.1% ??? [11] 1.8% f6 [52] 1.6% parse-loop12 [188] 0.8% ??? [17] 0.4% ??? [16] 0.2% ----------------------------------------------------------------------------------------- for-loop [92] 3.1% merge-egraph-nodes! [76] 11.5% loop [199] 29.0% for-loop [62] 56.4% [212] 44418(9.6%) 9646(2.1%) loop! ...ie/diff-of-prods/src/core/enode.rkt:192:2 custom-set-union [229] 39.1% loop [199] 32.2% set [232] 12.8% update-en-expr [236] 2.6% ----------------------------------------------------------------------------------------- hash-has-key? [138] 33.3% ??? [198] 66.7% [213] 27630(6.0%) 9710(2.1%) ??? ...ects/racket/contract/private/list.rkt:737:4 for-loop [230] 49.8% ??? [248] 10.0% ??? [258] 1.3% ??? [231] 1.3% arrow-higher-order:lnp [255] 1.3% successfully-got-the-right-kind-of-function [242] 1.2% ----------------------------------------------------------------------------------------- ??? [200] 100.0% [214] 10322(2.2%) 5318(1.1%) bfmul ...-lib/math/private/bigfloat/mpfr.rkt:819:4 ??? [233] 48.5% ----------------------------------------------------------------------------------------- ??? [198] 6.9% for-loop [62] 93.1% [215] 9964(2.2%) 1402(0.3%) list-member? ...llects/racket/private/set.rkt:24:0 loop [234] 85.9% ----------------------------------------------------------------------------------------- ...prods/src/common.rkt:47:2 [201] 100.0% [216] 6184(1.3%) 3462(0.7%) ??? ...s/racket/contract/private/arr-i.rkt:1268:39 return/no-unsupplied [237] 21.5% ??? [235] 11.7% assoc-ref [243] 10.8% ----------------------------------------------------------------------------------------- ??? [231] 3.4% for-loop [256] 3.4% ...prods/src/common.rkt:47:2 [201] 93.2% [217] 5230(1.1%) 712(0.2%) ??? ...ects/racket/contract/private/list.rkt:342:4 ??? [231] 67.2% ??? [250] 12.3% ??? [258] 6.8% ----------------------------------------------------------------------------------------- argmins [209] 8.4% loop [206] 25.4% f6 [52] 66.3% [218] 4196(0.9%) 0(0.0%) composed ...ollects/racket/private/list.rkt:321:16 f6 [52] 66.3% errors [159] 33.7% ----------------------------------------------------------------------------------------- map [154] 50.0% for-loop [205] 50.0% [219] 2082(0.4%) 0(0.0%) make-multiplication-node .../core/reduce.rkt:230:0 make-multiplication-subnode [238] 100.0% ----------------------------------------------------------------------------------------- ??? [198] 100.0% [220] 1670(0.4%) 0(0.0%) mk-egraph ...ff-of-prods/src/core/egraph.rkt:123:0 expr->enode [239] 100.0% ----------------------------------------------------------------------------------------- ??? [200] 100.0% [221] 1556(0.3%) 344(0.1%) bfsqrt ...lib/math/private/bigfloat/mpfr.rkt:616:4 ??? [233] 77.9% ----------------------------------------------------------------------------------------- loop [199] 49.2% for-loop [75] 50.8% [222] 1418(0.3%) 350(0.1%) foldl ...et/collects/racket/private/list.rkt:229:4 merge2 [240] 75.3% ----------------------------------------------------------------------------------------- ??? [198] 100.0% [223] 738(0.2%) 0(0.0%) loop ...s/herbie/diff-of-prods/src/points.rkt:66:6 random-exp [241] 100.0% ----------------------------------------------------------------------------------------- ??? [207] 100.0% [224] 358(0.1%) 0(0.0%) for-loop ...diff-of-prods/src/core/reduce.rkt:62:7 pattern-match [244] 100.0% ----------------------------------------------------------------------------------------- simplify* [203] 100.0% [225] 358(0.1%) 0(0.0%) ??? ...racket/collects/racket/private/kw.rkt:762:9 ??? [249] 100.0% ----------------------------------------------------------------------------------------- loop [208] 100.0% [226] 356(0.1%) 356(0.1%) integer->mpz ...math/private/bigfloat/gmp.rkt:87:0 ----------------------------------------------------------------------------------------- ??? [198] 100.0% [227] 356(0.1%) 0(0.0%) *simplify-rules* ...ods/src/syntax/rules.rkt:497:0 for-loop [120] 100.0% ----------------------------------------------------------------------------------------- hash-ref! [211] 100.0% [228] 25124(5.4%) 0(0.0%) bigfloat-hash ...h/private/bigfloat/mpfr.rkt:165:0 bfcanonicalize [245] 98.7% ----------------------------------------------------------------------------------------- adopt-enode! [105] 5.2% loop! [212] 94.8% [229] 20696(4.5%) 6252(1.3%) custom-set-union ...et/private/set-types.rkt:168:0 for-loop [246] 61.2% for-loop [251] 8.6% ----------------------------------------------------------------------------------------- ??? [213] 100.0% [230] 13756(3.0%) 6646(1.4%) for-loop ...acket/contract/private/list.rkt:743:12 ??? [248] 34.6% for-loop [141] 10.0% ??? [250] 4.8% arrow-higher-order:lnp [255] 2.3% ----------------------------------------------------------------------------------------- ??? [213] 2.6% ??? [152] 2.6% ??? [198] 2.7% ...higher-order.rkt:346:33 [195] 5.0% ??? [217] 28.5% for-loop [141] 58.5% [231] 13576(2.9%) 4208(0.9%) ??? ...cts/racket/contract/private/list.rkt:187:10 ??? [247] 58.5% for-loop [256] 2.7% ??? [261] 2.6% ??? [217] 2.6% ??? [258] 2.6% ----------------------------------------------------------------------------------------- new-enode [100] 8.0% loop! [212] 92.0% [232] 12292(2.7%) 12292(2.7%) set ...collects/racket/private/set-types.rkt:981:0 ----------------------------------------------------------------------------------------- bfsqrt [221] 12.9% real->bigfloat [202] 34.0% bfmul [214] 53.1% [233] 9422(2.0%) 9422(2.0%) ??? .../share/racket/collects/ffi/unsafe.rkt:861:4 ----------------------------------------------------------------------------------------- list-member? [215] 100.0% [234] 8562(1.8%) 8562(1.8%) loop (unknown source) ----------------------------------------------------------------------------------------- debug7 [33] 4.1% flag-set? [135] 4.2% ulp-difference [175] 4.3% ??? [216] 8.6% ??? [192] 16.4% ??? [198] 62.3% [235] 8406(1.8%) 1044(0.2%) ??? ...racket/collects/racket/private/kw.rkt:761:9 ??? [249] 83.6% ??? [258] 3.9% ----------------------------------------------------------------------------------------- for-loop [101] 5.5% for-loop [137] 24.0% for-loop [90] 29.4% loop! [212] 41.1% [236] 5912(1.3%) 5912(1.3%) update-en-expr ...-prods/src/core/egraph.rkt:211:0 ----------------------------------------------------------------------------------------- flag-set? [135] 6.2% ??? [192] 6.4% simplify* [203] 13.2% ??? [216] 25.4% ??? [198] 48.8% [237] 5236(1.1%) 4436(1.0%) return/no-unsupplied ...ct/private/arr-i.rkt:533:0 filter [253] 15.3% ----------------------------------------------------------------------------------------- make-multiplication-node [219] 100.0% [238] 2082(0.4%) 0(0.0%) make-multiplication-subnode ...re/reduce.rkt:240:0 for-loop [252] 82.8% compose [254] 17.2% ----------------------------------------------------------------------------------------- mk-egraph [220] 48.9% expr->enode [239] 51.1% [239] 1670(0.4%) 0(0.0%) expr->enode ...-of-prods/src/core/egraph.rkt:124:2 expr->enode [239] 51.1% mk-enode! [85] 48.9% ----------------------------------------------------------------------------------------- foldl [222] 100.0% [240] 1068(0.2%) 1068(0.2%) merge2 ...e/diff-of-prods/src/core/ematch.rkt:31:0 ----------------------------------------------------------------------------------------- loop [223] 100.0% [241] 738(0.2%) 738(0.2%) random-exp ...e/diff-of-prods/src/common.rkt:246:0 ----------------------------------------------------------------------------------------- ??? [213] 48.4% maybe-cons-kwd [197] 51.6% [242] 670(0.1%) 324(0.1%) successfully-got-the-right-kind-of-function ...9:4 arity-checking-wrapper [257] 51.6% ----------------------------------------------------------------------------------------- ??? [216] 100.0% [243] 666(0.1%) 666(0.1%) assoc-ref ...collects/racket/private/dict.rkt:56:0 ----------------------------------------------------------------------------------------- for-loop [224] 100.0% [244] 358(0.1%) 358(0.1%) pattern-match ...f-prods/src/core/matcher.rkt:48:0 ----------------------------------------------------------------------------------------- bigfloat-hash [228] 100.0% [245] 24790(5.3%) 24432(5.3%) bfcanonicalize .../private/bigfloat/mpfr.rkt:155:0 bigfloat->sig+exp [266] 1.4% ----------------------------------------------------------------------------------------- custom-set-union [229] 100.0% [246] 12662(2.7%) 4374(0.9%) for-loop ...cts/racket/private/set-types.rkt:174:3 for-loop [259] 65.5% ----------------------------------------------------------------------------------------- ??? [231] 100.0% [247] 7946(1.7%) 702(0.2%) ??? ...ects/racket/contract/private/list.rkt:686:7 ??? [258] 86.8% ??? [261] 4.3% ----------------------------------------------------------------------------------------- ??? [213] 36.8% for-loop [230] 63.2% [248] 7534(1.6%) 4094(0.9%) ??? ...private/unconstrained-domain-arrow.rkt:74:4 make-keyword-procedure [260] 45.7% ----------------------------------------------------------------------------------------- ??? [225] 4.8% ??? [235] 95.2% [249] 7388(1.6%) 7008(1.5%) ??? ...s/racket/contract/private/arr-i.rkt:1233:27 ??? [265] 5.1% ----------------------------------------------------------------------------------------- ??? [217] 32.0% for-loop [230] 32.5% ??? [133] 35.5% [250] 2012(0.4%) 652(0.1%) ??? ...ects/racket/contract/private/hash.rkt:222:6 check-hash/c [262] 67.6% ----------------------------------------------------------------------------------------- custom-set-union [229] 100.0% [251] 1782(0.4%) 1782(0.4%) for-loop ...cts/racket/private/set-types.rkt:152:2 ----------------------------------------------------------------------------------------- make-multiplication-subnode [238] 100.0% [252] 1724(0.4%) 710(0.2%) for-loop ...iff-of-prods/src/core/reduce.rkt:242:3 make-multiplication-subsubsubnode [263] 58.8% ----------------------------------------------------------------------------------------- for-loop [75] 28.6% return/no-unsupplied [237] 71.4% [253] 1120(0.2%) 1120(0.2%) filter ...t/collects/racket/private/list.rkt:256:2 ----------------------------------------------------------------------------------------- make-multiplication-subnode [238] 33.3% f6 [52] 66.7% [254] 1076(0.2%) 1076(0.2%) compose ...collects/racket/private/list.rkt:385:12 ----------------------------------------------------------------------------------------- for-loop [230] 47.5% ??? [213] 52.5% [255] 678(0.1%) 0(0.0%) arrow-higher-order:lnp ...w-higher-order.rkt:597:7 ??? [264] 100.0% ----------------------------------------------------------------------------------------- ??? [231] 100.0% [256] 360(0.1%) 0(0.0%) for-loop ...acket/contract/private/list.rkt:190:15 ??? [217] 100.0% ----------------------------------------------------------------------------------------- successfully-got-the-right-kind-of-function [242]100.0% [257] 346(0.1%) 0(0.0%) arity-checking-wrapper ...w-higher-order.rkt:402:0 matches-arity-exactly? [267] 100.0% ----------------------------------------------------------------------------------------- ??? [235] 2.7% ??? [71] 2.8% ??? [231] 2.9% ??? [213] 2.9% ??? [217] 5.9% ??? [182] 26.0% ??? [247] 56.8% [258] 12142(2.6%) 8298(1.8%) ??? ...ects/racket/contract/private/guts.rkt:644:8 ??? [132] 28.7% contract? [272] 2.9% ----------------------------------------------------------------------------------------- for-loop [246] 100.0% [259] 8288(1.8%) 8288(1.8%) for-loop ...cts/racket/private/set-types.rkt:178:5 ----------------------------------------------------------------------------------------- ??? [248] 100.0% [260] 3440(0.7%) 3440(0.7%) make-keyword-procedure ...ket/private/kw.rkt:260:4 ----------------------------------------------------------------------------------------- for-loop [141] 23.7% ??? [247] 25.0% ??? [183] 25.4% ??? [231] 25.9% [261] 1376(0.3%) 706(0.2%) ??? ...ects/racket/contract/private/prop.rkt:493:4 ??? [269] 48.7% ----------------------------------------------------------------------------------------- ??? [250] 100.0% [262] 1360(0.3%) 1002(0.2%) check-hash/c ...ket/contract/private/hash.rkt:83:0 flat-contract? [270] 26.3% ----------------------------------------------------------------------------------------- for-loop [252] 100.0% [263] 1014(0.2%) 328(0.1%) make-multiplication-subsubsubnode ...uce.rkt:262:0 mterm->expr [268] 67.7% ----------------------------------------------------------------------------------------- arrow-higher-order:lnp [255] 100.0% [264] 678(0.1%) 678(0.1%) ??? ...et/contract/private/arity-checking.rkt:19:2 ----------------------------------------------------------------------------------------- ??? [249] 100.0% [265] 380(0.1%) 380(0.1%) ??? ...ects/racket/contract/private/prop.rkt:256:4 ----------------------------------------------------------------------------------------- bfcanonicalize [245] 100.0% [266] 358(0.1%) 0(0.0%) bigfloat->sig+exp ...ivate/bigfloat/mpfr.rkt:370:0 size+limbs->integer [271] 100.0% ----------------------------------------------------------------------------------------- arity-checking-wrapper [257] 100.0% [267] 346(0.1%) 346(0.1%) matches-arity-exactly? ...te/arrow-common.rkt:70:0 ----------------------------------------------------------------------------------------- make-multiplication-subsubsubnode [263] 100.0% [268] 686(0.1%) 326(0.1%) mterm->expr ...-of-prods/src/core/reduce.rkt:270:0 free-variables [273] 52.5% ----------------------------------------------------------------------------------------- ??? [261] 100.0% [269] 670(0.1%) 670(0.1%) ??? ...lects/racket/contract/private/orc.rkt:83:14 ----------------------------------------------------------------------------------------- check-hash/c [262] 100.0% [270] 358(0.1%) 358(0.1%) flat-contract? .../contract/private/guts.rkt:111:0 ----------------------------------------------------------------------------------------- bigfloat->sig+exp [266] 100.0% [271] 358(0.1%) 358(0.1%) size+limbs->integer ...vate/bigfloat/gmp.rkt:103:0 ----------------------------------------------------------------------------------------- ??? [258] 100.0% [272] 356(0.1%) 356(0.1%) contract? ...acket/contract/private/guts.rkt:109:0 ----------------------------------------------------------------------------------------- mterm->expr [268] 26.8% append-map [167] 73.2% [273] 1344(0.3%) 306(0.1%) free-variables ...-of-prods/src/programs.rkt:100:0 variable? [13] 77.2% -----------------------------------------------------------------------------------------