Profiling results ----------------- Total cpu time observed: 2136198ms (out of 2142068ms) Number of samples taken: 7946 (once every 269ms) (Hiding functions with self<1.0% and local<2.0%: 17 of 286 hidden) =========================================================================================== Caller Idx Total Self Name+src Local% ms(pct) ms(pct) Callee =========================================================================================== ??? [179] 100.0% [1] 1872610(87.7%) 674(0.0%) iterate-egraph!13 ...s/src/core/simplify.rkt:102:0 one-iter [17] 98.2% map-enodes [21] 1.7% debug-print [209] 0.0% ------------------------------------------------------------------------------------------- ??? [78] 100.0% [2] 1780582(83.4%) 0(0.0%) profile-thunk16 ...t/pkgs/profile-lib/main.rkt:9:0 run [18] 100.0% ------------------------------------------------------------------------------------------- ??? [78] 100.0% [3] 1776046(83.1%) 0(0.0%) run-improve50 ...f-of-prods/src/mainloop.rkt:234:0 for-loop [19] 98.7% get-final-combination [22] 0.9% loop [95] 0.3% setup-alt-simplified [30] 0.1% ------------------------------------------------------------------------------------------- ??? [179] 100.0% [4] 139492(6.5%) 0(0.0%) loop .../diff-of-prods/src/core/simplify.rkt:215:2 pass [20] 100.0% ------------------------------------------------------------------------------------------- map-enodes [21] 5.6% loop [225] 94.4% [5] 29980(1.4%) 5368(0.3%) for-loop ...f-of-prods/src/core/simplify.rkt:173:2 setfindf [24] 39.6% eval-const-expr [25] 31.5% compose [28] 5.2% curried [240] 4.7% ??? [176] 1.1% ------------------------------------------------------------------------------------------- f137 [130] 1.5% loop [225] 98.5% [6] 16360(0.8%) 0(0.0%) option-on-expr ...prods/src/core/regimes.rkt:103:0 sindices->spoints [23] 91.9% sort-context-on-expr [31] 4.5% errors [162] 2.0% err-lsts->split-indices [36] 1.2% pick-errors [37] 0.3% ------------------------------------------------------------------------------------------- rewriter [96] 100.0% [7] 4684(0.2%) 1348(0.1%) *rules* ...iff-of-prods/src/syntax/rules.rkt:493:0 for-loop [99] 71.2% ------------------------------------------------------------------------------------------- hash-ref! [203] 100.0% [8] 4054(0.2%) 0(0.0%) ??? ...ie/diff-of-prods/src/core/taylor.rkt:285:26 for-loop [26] 100.0% ------------------------------------------------------------------------------------------- hash-ref! [203] 100.0% [9] 2790(0.1%) 0(0.0%) ??? ...ie/diff-of-prods/src/core/taylor.rkt:295:23 for-loop [27] 100.0% ------------------------------------------------------------------------------------------- hash-ref! [203] 100.0% [10] 1416(0.1%) 0(0.0%) ??? ...ie/diff-of-prods/src/core/taylor.rkt:392:23 for-loop [29] 100.0% ------------------------------------------------------------------------------------------- hash-ref! [203] 100.0% [11] 1380(0.1%) 0(0.0%) ??? ...ie/diff-of-prods/src/core/taylor.rkt:338:33 for-loop [32] 52.5% hash-ref! [203] 47.5% ------------------------------------------------------------------------------------------- map [138] 47.4% f137 [130] 52.6% [12] 684(0.0%) 0(0.0%) taylor-invert ...f-prods/src/core/taylor.rkt:312:0 first-nonzero-exp [34] 100.0% ------------------------------------------------------------------------------------------- f137 [130] 100.0% [13] 664(0.0%) 0(0.0%) taylor-exp ...f-of-prods/src/core/taylor.rkt:386:0 simplify [44] 100.0% ------------------------------------------------------------------------------------------- hash-ref! [203] 100.0% [14] 662(0.0%) 0(0.0%) ??? ...ie/diff-of-prods/src/core/taylor.rkt:322:33 for-loop [35] 100.0% ------------------------------------------------------------------------------------------- map [138] 100.0% [15] 334(0.0%) 0(0.0%) simplify-node ...of-prods/src/core/reduce.rkt:50:0 append-map [33] 100.0% ------------------------------------------------------------------------------------------- copying-mergesort [76] 100.0% [16] 156(0.0%) 0(0.0%) jloop ...t/collects/racket/private/sort.rkt:121:23 ??? [170] 67.9% ??? [176] 32.1% ------------------------------------------------------------------------------------------- iterate-egraph!13 [1] 100.0% [17] 1839552(86.1%) 21272(1.0%) one-iter ...f-of-prods/src/core/simplify.rkt:113:0 loop [39] 73.7% for-loop [40] 23.0% apply-match [54] 1.9% filter [254] 0.0% ------------------------------------------------------------------------------------------- profile-thunk16 [2] 100.0% [18] 1780582(83.4%) 0(0.0%) run ...share/racket/pkgs/profile-lib/main.rkt:39:2 ??? [78] 100.0% ------------------------------------------------------------------------------------------- run-improve50 [3] 100.0% [19] 1753098(82.1%) 0(0.0%) for-loop .../diff-of-prods/src/mainloop.rkt:249:10 run-iter! [38] 100.0% ------------------------------------------------------------------------------------------- loop [4] 100.0% [20] 139492(6.5%) 888(0.0%) pass .../diff-of-prods/src/core/simplify.rkt:205:2 for-loop [41] 99.1% ------------------------------------------------------------------------------------------- iterate-egraph!13 [1] 100.0% [21] 31666(1.5%) 332(0.0%) map-enodes ...f-of-prods/src/core/egraph.rkt:139:0 loop [225] 93.6% for-loop [5] 5.3% ------------------------------------------------------------------------------------------- run-improve50 [3] 100.0% [22] 16360(0.8%) 0(0.0%) get-final-combination ...ds/src/mainloop.rkt:264:0 split-table [42] 100.0% ------------------------------------------------------------------------------------------- option-on-expr [6] 100.0% [23] 15042(0.7%) 0(0.0%) sindices->spoints ...ds/src/core/regimes.rkt:116:0 loop [43] 100.0% ------------------------------------------------------------------------------------------- for-loop [5] 100.0% [24] 11866(0.6%) 7146(0.3%) setfindf ...bie/diff-of-prods/src/common.rkt:179:0 for-loop [45] 30.7% ??? [133] 9.1% ------------------------------------------------------------------------------------------- for-loop [5] 100.0% [25] 9456(0.4%) 1944(0.1%) eval-const-expr ...of-prods/src/programs.rkt:166:0 f137 [130] 47.5% ??? [174] 18.0% ??? [239] 10.5% parse-app [232] 3.4% ------------------------------------------------------------------------------------------- ??? [8] 100.0% [26] 4054(0.2%) 0(0.0%) for-loop ...ff-of-prods/src/core/taylor.rkt:285:52 hash-ref! [203] 79.6% ??? [49] 13.0% simplify [44] 7.4% ------------------------------------------------------------------------------------------- ??? [9] 100.0% [27] 2790(0.1%) 0(0.0%) for-loop ...ff-of-prods/src/core/taylor.rkt:298:27 hash-ref! [203] 100.0% ------------------------------------------------------------------------------------------- for-loop [5] 100.0% [28] 1552(0.1%) 1552(0.1%) compose ...collects/racket/private/list.rkt:385:12 ------------------------------------------------------------------------------------------- ??? [10] 100.0% [29] 1416(0.1%) 0(0.0%) for-loop ...ff-of-prods/src/core/taylor.rkt:396:33 for-loop [46] 100.0% ------------------------------------------------------------------------------------------- run-improve50 [3] 100.0% [30] 1364(0.1%) 0(0.0%) setup-alt-simplified ...of-prods/src/glue.rkt:49:0 simplify-alt [47] 100.0% ------------------------------------------------------------------------------------------- option-on-expr [6] 100.0% [31] 742(0.0%) 0(0.0%) sort-context-on-expr ...prods/src/points.rkt:115:0 ??? [48] 100.0% ------------------------------------------------------------------------------------------- ??? [11] 100.0% [32] 724(0.0%) 0(0.0%) for-loop ...ff-of-prods/src/core/taylor.rkt:341:46 hash-ref! [203] 100.0% ------------------------------------------------------------------------------------------- simplify-node [15] 48.1% f137 [130] 51.9% [33] 694(0.0%) 0(0.0%) append-map ...acket/collects/racket/list.rkt:565:2 free-variables [50] 51.9% parse-loop12 [217] 48.1% ------------------------------------------------------------------------------------------- taylor-invert [12] 100.0% [34] 684(0.0%) 0(0.0%) first-nonzero-exp ...ods/src/core/taylor.rkt:260:0 simplify [44] 100.0% ------------------------------------------------------------------------------------------- ??? [14] 100.0% [35] 662(0.0%) 0(0.0%) for-loop ...ff-of-prods/src/core/taylor.rkt:324:46 hash-ref! [203] 100.0% ------------------------------------------------------------------------------------------- option-on-expr [6] 100.0% [36] 204(0.0%) 0(0.0%) err-lsts->split-indices .../core/regimes.rkt:222:0 add-splitpoint [51] 100.0% ------------------------------------------------------------------------------------------- option-on-expr [6] 100.0% [37] 52(0.0%) 0(0.0%) pick-errors ...of-prods/src/core/regimes.rkt:184:0 for-loop [52] 100.0% ------------------------------------------------------------------------------------------- for-loop [19] 100.0% [38] 1753098(82.1%) 0(0.0%) run-iter! .../diff-of-prods/src/mainloop.rkt:215:0 simplify! [53] 95.6% finalize-iter! [57] 3.0% gen-rewrites! [60] 0.8% gen-series! [62] 0.4% ------------------------------------------------------------------------------------------- one-iter [17] 100.0% [39] 1354856(63.4%) 3636(0.2%) loop ...cket/collects/racket/private/map.rkt:52:19 apply-match [54] 99.7% ------------------------------------------------------------------------------------------- for-loop [40] 48.6% one-iter [17] 51.4% [40] 423600(19.8%) 94120(4.4%) for-loop ...-of-prods/src/core/simplify.rkt:123:12 for-loop [40] 48.6% match-e [68] 38.7% ??? [107] 0.2% ------------------------------------------------------------------------------------------- pass [20] 100.0% [41] 138276(6.5%) 650(0.0%) for-loop ...-of-prods/src/core/simplify.rkt:208:29 argmin [55] 67.4% loop [58] 25.8% for-loop [61] 5.1% filter [254] 0.8% make-sequence [256] 0.5% ------------------------------------------------------------------------------------------- get-final-combination [22] 100.0% [42] 16360(0.8%) 0(0.0%) split-table ...ie/diff-of-prods/src/glue.rkt:162:0 f137 [130] 100.0% ------------------------------------------------------------------------------------------- parse-loop12 [217] 0.0% loop [43] 2.3% sindices->spoints [23] 97.7% [43] 15402(0.7%) 0(0.0%) loop ...cket/collects/racket/private/map.rkt:36:19 sidx->spoint [59] 97.7% loop [43] 2.3% ulp-difference [173] 0.0% ------------------------------------------------------------------------------------------- for-loop [26] 4.7% loop [140] 5.1% taylor-exp [13] 10.3% first-nonzero-exp [34] 10.6% hash-ref! [203] 69.4% [44] 6446(0.3%) 360(0.0%) simplify ...diff-of-prods/src/core/reduce.rkt:16:0 f137 [130] 50.9% parse-loop12 [217] 33.2% debug-print [209] 5.2% simplify* [233] 5.1% ------------------------------------------------------------------------------------------- setfindf [24] 100.0% [45] 3646(0.2%) 3646(0.2%) for-loop ...bie/diff-of-prods/src/common.rkt:180:2 ------------------------------------------------------------------------------------------- for-loop [29] 100.0% [46] 1416(0.1%) 0(0.0%) for-loop ...ff-of-prods/src/core/taylor.rkt:398:39 hash-ref! [203] 100.0% ------------------------------------------------------------------------------------------- setup-alt-simplified [30] 100.0% [47] 1364(0.1%) 0(0.0%) simplify-alt ...ie/diff-of-prods/src/glue.rkt:76:0 ??? [179] 100.0% ------------------------------------------------------------------------------------------- sort-context-on-expr [31] 100.0% [48] 742(0.0%) 0(0.0%) ??? ...cket/collects/racket/private/sort.rkt:403:3 generic-sort/key [63] 85.2% ??? [170] 8.1% loop [87] 6.7% ------------------------------------------------------------------------------------------- for-loop [26] 100.0% [49] 694(0.0%) 0(0.0%) ??? ...ie/diff-of-prods/src/core/taylor.rkt:288:19 hash-ref! [203] 100.0% ------------------------------------------------------------------------------------------- append-map [33] 100.0% [50] 360(0.0%) 0(0.0%) free-variables ...-of-prods/src/programs.rkt:100:0 variable? [56] 100.0% ------------------------------------------------------------------------------------------- err-lsts->split-indices [36] 100.0% [51] 204(0.0%) 0(0.0%) add-splitpoint ...prods/src/core/regimes.rkt:235:2 for-loop [64] 100.0% ------------------------------------------------------------------------------------------- pick-errors [37] 100.0% [52] 52(0.0%) 0(0.0%) for-loop ...ff-of-prods/src/core/regimes.rkt:186:2 ??? [65] 100.0% ------------------------------------------------------------------------------------------- run-iter! [38] 100.0% [53] 1676148(78.5%) 0(0.0%) simplify! .../diff-of-prods/src/mainloop.rkt:155:0 for-loop [66] 100.0% ------------------------------------------------------------------------------------------- one-iter [17] 2.6% loop [39] 97.4% [54] 1386668(64.9%) 6026(0.3%) apply-match ...f-prods/src/core/simplify.rkt:130:2 for-loop [67] 86.3% match-e [68] 10.6% update-leader! [91] 2.0% reduce-to-single! [73] 0.7% ------------------------------------------------------------------------------------------- ??? [176] 0.3% for-loop [41] 99.7% [55] 93450(4.4%) 718(0.0%) argmin ...re/racket/collects/racket/list.rkt:743:0 for-loop [69] 87.8% expression-cost [72] 11.4% ------------------------------------------------------------------------------------------- free-variables [50] 0.6% substitute-e [81] 14.7% match-e [68] 84.7% [56] 55526(2.6%) 1894(0.1%) variable? ...-of-prods/src/syntax/syntax.rkt:567:0 ??? [133] 96.6% ------------------------------------------------------------------------------------------- run-iter! [38] 100.0% [57] 53314(2.5%) 0(0.0%) finalize-iter! ...-of-prods/src/mainloop.rkt:169:0 ??? [133] 100.0% ------------------------------------------------------------------------------------------- for-loop [41] 100.0% [58] 35616(1.7%) 366(0.0%) loop ...hare/racket/collects/racket/list.rkt:729:4 for-loop [69] 92.6% expression-cost [72] 6.4% ------------------------------------------------------------------------------------------- loop [43] 100.0% [59] 15042(0.7%) 0(0.0%) sidx->spoint ...f-prods/src/core/regimes.rkt:126:2 binary-search [71] 89.2% binary-search-floats [75] 10.8% ------------------------------------------------------------------------------------------- run-iter! [38] 100.0% [60] 14462(0.7%) 0(0.0%) gen-rewrites! ...f-of-prods/src/mainloop.rkt:142:0 for-loop [70] 100.0% ------------------------------------------------------------------------------------------- for-loop [41] 100.0% [61] 7098(0.3%) 7098(0.3%) for-loop ...-of-prods/src/core/simplify.rkt:195:13 ------------------------------------------------------------------------------------------- run-iter! [38] 100.0% [62] 6446(0.3%) 0(0.0%) gen-series! ...iff-of-prods/src/mainloop.rkt:129:0 for-loop [74] 100.0% ------------------------------------------------------------------------------------------- ??? [48] 100.0% [63] 632(0.0%) 0(0.0%) generic-sort/key .../racket/private/sort.rkt:185:2 copying-mergesort [76] 100.0% ------------------------------------------------------------------------------------------- add-splitpoint [51] 100.0% [64] 204(0.0%) 54(0.0%) for-loop ...ff-of-prods/src/core/regimes.rkt:237:4 for-loop [77] 73.5% ------------------------------------------------------------------------------------------- for-loop [52] 100.0% [65] 52(0.0%) 0(0.0%) ??? ...ie/diff-of-prods/src/core/regimes.rkt:177:2 ??? [170] 100.0% ------------------------------------------------------------------------------------------- simplify! [53] 99.9% [66] 1677988(78.6%) 0(0.0%) for-loop ...e/diff-of-prods/src/mainloop.rkt:159:6 ??? [78] 100.0% ------------------------------------------------------------------------------------------- apply-match [54] 100.0% [67] 1196492(56.0%) 5028(0.2%) for-loop ...-of-prods/src/core/simplify.rkt:145:10 mk-enode! [89] 29.1% merge-egraph-nodes! [79] 26.8% loop! [103] 24.1% substitute-e [81] 17.2% list-member? [189] 2.4% ------------------------------------------------------------------------------------------- apply-match [54] 19.0% for-loop [90] 26.3% for-loop [40] 54.7% [68] 474872(22.2%) 149824(7.0%) match-e .../diff-of-prods/src/core/ematch.rkt:46:0 for-loop [80] 49.9% for-loop [90] 7.6% ??? [133] 7.0% variable? [56] 3.9% list-cartesian-product [93] 2.5% loop [225] 1.4% custom-in-set [269] 0.6% curry* [100] 0.3% filter [254] 0.1% ------------------------------------------------------------------------------------------- loop [58] 28.7% argmin [55] 71.3% [69] 115026(5.4%) 2828(0.1%) for-loop ...e/diff-of-prods/src/programs.rkt:199:2 ??? [179] 67.0% ...prods/src/common.rkt:47:2 [136] 27.5% ??? [134] 3.1% ------------------------------------------------------------------------------------------- gen-rewrites! [60] 100.0% [70] 14462(0.7%) 0(0.0%) for-loop .../diff-of-prods/src/mainloop.rkt:147:11 ??? [83] 100.0% ------------------------------------------------------------------------------------------- sidx->spoint [59] 100.0% [71] 13424(0.6%) 0(0.0%) binary-search ...iff-of-prods/src/common.rkt:221:0 pred [82] 100.0% ------------------------------------------------------------------------------------------- loop [58] 17.6% argmin [55] 82.4% [72] 12956(0.6%) 0(0.0%) expression-cost ...of-prods/src/programs.rkt:198:0 compile [84] 100.0% ------------------------------------------------------------------------------------------- apply-match [54] 100.0% [73] 9766(0.5%) 3390(0.2%) reduce-to-single! ...ods/src/core/egraph.rkt:324:0 for-loop [86] 54.1% make-sequence [256] 7.5% filter-loop! [88] 3.8% ------------------------------------------------------------------------------------------- gen-series! [62] 100.0% [74] 6446(0.3%) 0(0.0%) for-loop ...e/diff-of-prods/src/mainloop.rkt:135:7 taylor-alt [85] 100.0% ------------------------------------------------------------------------------------------- sidx->spoint [59] 100.0% [75] 1618(0.1%) 0(0.0%) binary-search-floats ...prods/src/common.rkt:236:0 pred [82] 100.0% ------------------------------------------------------------------------------------------- copying-mergesort [76] 35.0% generic-sort/key [63] 65.0% [76] 632(0.0%) 0(0.0%) copying-mergesort ...racket/private/sort.rkt:130:8 loop [87] 58.9% copying-mergesort [76] 35.0% jloop [16] 6.2% ------------------------------------------------------------------------------------------- for-loop [64] 100.0% [77] 150(0.0%) 150(0.0%) for-loop ...ff-of-prods/src/core/regimes.rkt:241:8 ------------------------------------------------------------------------------------------- for-loop [66] 26.7% run [18] 29.2% [78] 2095884(98.1%) 0(0.0%) ??? ...lects/racket/private/more-scheme.rkt:261:28 ??? [179] 41.6% profile-thunk16 [2] 29.2% run-improve50 [3] 29.1% loop [95] 0.2% ------------------------------------------------------------------------------------------- for-loop [94] 2.9% merge-egraph-nodes! [79] 4.3% for-loop [67] 92.9% [79] 320278(15.0%) 6438(0.3%) merge-egraph-nodes! ...s/src/core/egraph.rkt:152:0 update-leader! [91] 53.9% for-loop [92] 14.6% loop! [103] 13.3% for-loop [94] 7.3% merge-egraph-nodes! [79] 4.3% enode-merge! [97] 3.9% for-loop [99] 0.8% make-sequence [256] 0.1% ------------------------------------------------------------------------------------------- match-e [68] 100.0% [80] 303316(14.2%) 107492(5.0%) for-loop ...iff-of-prods/src/core/ematch.rkt:59:11 for-loop [90] 56.3% list-cartesian-product [93] 7.3% loop [225] 4.0% foldl [238] 0.8% filter [254] 0.4% curry* [100] 0.4% curried [240] 0.2% ------------------------------------------------------------------------------------------- substitute-e [81] 7.8% for-loop [67] 92.2% [81] 205344(9.6%) 9744(0.5%) substitute-e ...-of-prods/src/core/ematch.rkt:71:0 mk-enode! [89] 84.6% substitute-e [81] 7.8% ??? [133] 2.6% variable? [56] 1.7% ------------------------------------------------------------------------------------------- binary-search-floats [75] 10.8% binary-search [71] 89.2% [82] 15042(0.7%) 0(0.0%) pred .../diff-of-prods/src/core/regimes.rkt:132:17 loop [95] 99.6% errors [162] 0.4% ------------------------------------------------------------------------------------------- for-loop [70] 100.0% [83] 14462(0.7%) 0(0.0%) ??? ...rbie/diff-of-prods/src/alternative.rkt:88:0 rewriter [96] 100.0% ------------------------------------------------------------------------------------------- expression-cost [72] 100.0% [84] 12956(0.6%) 744(0.0%) compile ...ie/diff-of-prods/src/programs.rkt:175:0 hash-ref! [203] 94.3% ------------------------------------------------------------------------------------------- for-loop [74] 100.0% [85] 6446(0.3%) 0(0.0%) taylor-alt ...bie/diff-of-prods/src/glue.rkt:134:0 for-loop [98] 100.0% ------------------------------------------------------------------------------------------- reduce-to-single! [73] 100.0% [86] 5280(0.2%) 5280(0.2%) for-loop ...iff-of-prods/src/core/egraph.rkt:325:8 ------------------------------------------------------------------------------------------- ??? [48] 9.5% copying-mergesort [76] 90.5% [87] 526(0.0%) 0(0.0%) loop ...ket/collects/racket/private/sort.rkt:97:12 ??? [170] 90.5% ??? [176] 9.5% ------------------------------------------------------------------------------------------- reduce-to-single! [73] 100.0% [88] 368(0.0%) 0(0.0%) filter-loop! ...-of-prods/src/core/enode.rkt:143:2 for-loop [101] 100.0% ------------------------------------------------------------------------------------------- mk-egraph [191] 0.2% expr->enode [206] 2.0% substitute-e [81] 32.6% for-loop [67] 65.3% [89] 533462(25.0%) 42586(2.0%) mk-enode! ...ff-of-prods/src/core/egraph.rkt:101:0 new-enode [102] 89.8% hash-has-key? [142] 1.9% ------------------------------------------------------------------------------------------- match-e [68] 24.8% for-loop [80] 75.2% [90] 245634(11.5%) 14728(0.7%) for-loop ...iff-of-prods/src/core/ematch.rkt:65:37 match-e [68] 91.2% ??? [107] 3.8% ------------------------------------------------------------------------------------------- apply-match [54] 12.9% merge-egraph-nodes! [79] 87.1% [91] 213258(10.0%) 14376(0.7%) update-leader! ...-prods/src/core/egraph.rkt:217:0 for-loop [104] 87.5% custom-set-union! [110] 2.1% update-en-expr [152] 1.5% make-sequence [256] 1.0% hash-ref! [203] 0.7% ------------------------------------------------------------------------------------------- merge-egraph-nodes! [79] 100.0% [92] 47516(2.2%) 39050(1.8%) for-loop ...iff-of-prods/src/core/egraph.rkt:232:6 update-en-expr [152] 17.8% ------------------------------------------------------------------------------------------- match-e [68] 24.7% list-cartesian-product [93] 28.0% for-loop [80] 47.3% [93] 42364(2.0%) 33224(1.6%) list-cartesian-product ...src/core/ematch.rkt:20:0 list-cartesian-product [93] 28.0% for-loop [108] 14.5% ------------------------------------------------------------------------------------------- merge-egraph-nodes! [79] 100.0% [94] 33006(1.5%) 0(0.0%) for-loop ...ff-of-prods/src/core/egraph.rkt:200:10 merge-egraph-nodes! [79] 55.5% loop! [103] 44.5% ------------------------------------------------------------------------------------------- run-improve50 [3] 18.9% ??? [78] 26.9% pred [82] 54.2% [95] 27650(1.3%) 0(0.0%) loop .../herbie/diff-of-prods/src/points.rkt:193:2 loop [105] 77.8% make-exacts* [121] 11.2% loop [122] 10.8% for-loop [114] 0.2% ------------------------------------------------------------------------------------------- ??? [83] 22.0% matcher [119] 78.0% [96] 14462(0.7%) 1678(0.1%) rewriter ...ff-of-prods/src/core/matcher.rkt:131:2 for-loop [106] 79.4% *rules* [7] 7.0% expression->type [111] 5.7% f137 [130] 5.2% ------------------------------------------------------------------------------------------- merge-egraph-nodes! [79] 100.0% [97] 12590(0.6%) 2922(0.1%) enode-merge! ...-of-prods/src/core/enode.rkt:129:0 adopt-enode! [109] 54.3% custom-set-intersect! [112] 22.5% ------------------------------------------------------------------------------------------- taylor-alt [85] 100.0% [98] 6446(0.3%) 0(0.0%) for-loop ...erbie/diff-of-prods/src/glue.rkt:139:6 ??? [176] 100.0% ------------------------------------------------------------------------------------------- merge-egraph-nodes! [79] 45.5% *rules* [7] 54.5% [99] 6118(0.3%) 3746(0.2%) for-loop ...rbie/diff-of-prods/src/common.rkt:94:9 ormap [113] 33.3% update-en-expr [152] 5.4% ------------------------------------------------------------------------------------------- for-loop [80] 49.6% match-e [68] 50.4% [100] 3122(0.1%) 1020(0.0%) curry* ...racket/collects/racket/function.rkt:44:2 procedure-arity [246] 67.3% ------------------------------------------------------------------------------------------- filter-loop! [88] 100.0% [101] 368(0.0%) 368(0.0%) for-loop ...iff-of-prods/src/core/enode.rkt:147:12 ------------------------------------------------------------------------------------------- mk-enode! [89] 100.0% [102] 478856(22.4%) 692(0.0%) new-enode ...diff-of-prods/src/core/enode.rkt:97:0 type-of-enode-expr [115] 98.6% set [118] 0.5% ------------------------------------------------------------------------------------------- for-loop [94] 3.4% merge-egraph-nodes! [79] 9.6% loop [225] 28.3% for-loop [67] 58.7% [103] 353686(16.6%) 63652(3.0%) loop! ...ie/diff-of-prods/src/core/enode.rkt:192:2 custom-set-union [117] 38.4% loop [225] 32.7% set [118] 12.9% update-en-expr [152] 5.3% ------------------------------------------------------------------------------------------- update-leader! [91] 100.0% [104] 186640(8.7%) 5068(0.2%) for-loop ...iff-of-prods/src/core/egraph.rkt:222:6 for-loop [116] 96.7% update-en-expr [152] 0.6% ------------------------------------------------------------------------------------------- loop [95] 100.0% [105] 21514(1.0%) 0(0.0%) loop .../herbie/diff-of-prods/src/points.rkt:151:2 eval-prog [168] 78.8% make-exacts* [121] 13.3% loop [122] 7.9% ------------------------------------------------------------------------------------------- rewriter [96] 100.0% [106] 14462(0.7%) 358(0.0%) for-loop ...f-of-prods/src/core/matcher.rkt:134:10 matcher [119] 99.5% ------------------------------------------------------------------------------------------- for-loop [40] 12.5% for-loop [90] 87.5% [107] 11428(0.5%) 4732(0.2%) ??? ...rbie/diff-of-prods/src/core/ematch.rkt:50:5 for-loop [120] 58.6% ------------------------------------------------------------------------------------------- list-cartesian-product [93] 100.0% [108] 9140(0.4%) 9140(0.4%) for-loop ...diff-of-prods/src/core/ematch.rkt:24:8 ------------------------------------------------------------------------------------------- enode-merge! [97] 100.0% [109] 6836(0.3%) 2094(0.1%) adopt-enode! ...-of-prods/src/core/enode.rkt:105:0 custom-set-union [117] 69.4% ------------------------------------------------------------------------------------------- update-leader! [91] 100.0% [110] 4452(0.2%) 3282(0.2%) custom-set-union! ...t/private/set-types.rkt:245:0 for-loop [125] 26.3% ------------------------------------------------------------------------------------------- for-loop [123] 4.6% mterm->expr [267] 10.0% rewriter [96] 85.4% [111] 3344(0.2%) 692(0.0%) expression->type ...-prods/src/type-check.rkt:45:0 for-loop [123] 79.3% ------------------------------------------------------------------------------------------- enode-merge! [97] 100.0% [112] 2832(0.1%) 2832(0.1%) custom-set-intersect! ...ivate/set-types.rkt:269:0 ------------------------------------------------------------------------------------------- for-loop [99] 100.0% [113] 2040(0.1%) 0(0.0%) ormap ...et/collects/racket/private/map.rkt:105:13 flag-set? [124] 84.0% curried [240] 16.0% ------------------------------------------------------------------------------------------- loop [95] 100.0% [114] 60(0.0%) 0(0.0%) for-loop ...ie/diff-of-prods/src/points.rkt:200:24 for-loop [126] 100.0% ------------------------------------------------------------------------------------------- new-enode [102] 100.0% [115] 472288(22.1%) 9880(0.5%) type-of-enode-expr ...rods/src/core/enode.rkt:68:0 get-sigs [127] 97.6% parse-loop12 [217] 0.4% ------------------------------------------------------------------------------------------- for-loop [104] 100.0% [116] 180516(8.5%) 2612(0.1%) for-loop ...iff-of-prods/src/core/egraph.rkt:223:8 hash-update! [128] 98.6% ------------------------------------------------------------------------------------------- adopt-enode! [109] 3.1% loop! [103] 96.9% [117] 150948(7.1%) 46470(2.2%) custom-set-union ...et/private/set-types.rkt:168:0 for-loop [129] 59.4% for-loop [131] 9.8% ------------------------------------------------------------------------------------------- new-enode [102] 2.8% loop! [103] 97.2% [118] 93634(4.4%) 93634(4.4%) set ...collects/racket/private/set-types.rkt:981:0 ------------------------------------------------------------------------------------------- for-loop [132] 16.7% matcher [119] 33.0% for-loop [106] 50.3% [119] 14462(0.7%) 718(0.0%) matcher ...iff-of-prods/src/core/matcher.rkt:167:2 rewriter [96] 49.7% matcher [119] 33.0% for-loop [132] 16.7% ------------------------------------------------------------------------------------------- ??? [107] 100.0% [120] 6696(0.3%) 5898(0.3%) for-loop ...diff-of-prods/src/core/ematch.rkt:51:7 ??? [133] 11.9% ------------------------------------------------------------------------------------------- loop [105] 48.1% loop [95] 51.9% [121] 5954(0.3%) 0(0.0%) make-exacts* ...diff-of-prods/src/points.rkt:138:0 map [138] 40.9% loop [225] 39.1% eval-prog [168] 20.1% ------------------------------------------------------------------------------------------- loop [105] 36.2% loop [95] 63.8% [122] 4682(0.2%) 0(0.0%) loop .../herbie/diff-of-prods/src/points.rkt:141:4 map [138] 100.0% ------------------------------------------------------------------------------------------- expression->type [111] 100.0% [123] 2652(0.1%) 0(0.0%) for-loop .../diff-of-prods/src/type-check.rkt:52:5 f137 [130] 81.6% ??? [190] 12.6% expression->type [111] 5.8% ------------------------------------------------------------------------------------------- *simplify-rules* [200] 2.8% ormap [113] 97.2% [124] 1764(0.1%) 1414(0.1%) flag-set? ...bie/diff-of-prods/src/config.rkt:32:0 ??? [190] 19.8% ------------------------------------------------------------------------------------------- custom-set-union! [110] 100.0% [125] 1170(0.1%) 1170(0.1%) for-loop ...cts/racket/private/set-types.rkt:253:4 ------------------------------------------------------------------------------------------- for-loop [114] 100.0% [126] 60(0.0%) 0(0.0%) for-loop ...ie/diff-of-prods/src/points.rkt:201:26 ??? [176] 100.0% ------------------------------------------------------------------------------------------- type-of-enode-expr [115] 100.0% [127] 460742(21.6%) 4500(0.2%) get-sigs ...e/diff-of-prods/src/type-check.rkt:5:0 ??? [134] 39.8% ??? [179] 31.1% ??? [133] 14.7% ...prods/src/common.rkt:47:2 [136] 13.4% ------------------------------------------------------------------------------------------- for-loop [116] 100.0% [128] 177904(8.3%) 1370(0.1%) hash-update! ...ket/private/more-scheme.rkt:362:13 ??? [135] 99.2% ------------------------------------------------------------------------------------------- custom-set-union [117] 100.0% [129] 89620(4.2%) 29326(1.4%) for-loop ...cts/racket/private/set-types.rkt:174:3 for-loop [137] 67.3% ------------------------------------------------------------------------------------------- composed [208] 0.2% loop [225] 0.2% ??? [148] 0.4% approximate9 [182] 1.1% hash-ref! [203] 1.4% eval-prog [168] 3.1% map [138] 3.6% simplify [44] 4.1% for-loop [123] 6.3% rewriter [96] 10.5% eval-const-expr [25] 12.3% f137 [130] 12.6% split-table [42] 44.0% [130] 36612(1.7%) 922(0.0%) f137 .../collects/racket/match/compiler.rkt:507:40 loop [225] 43.3% f137 [130] 12.6% ??? [179] 9.9% ??? [134] 9.9% map [138] 8.8% ??? [176] 4.0% ??? [139] 3.7% ??? [133] 2.6% ...prods/src/common.rkt:47:2 [136] 1.9% loop [140] 0.7% option-on-expr [6] 0.7% taylor-exp [13] 0.5% composed [208] 0.2% append-map [33] 0.2% taylor-invert [12] 0.2% ------------------------------------------------------------------------------------------- custom-set-union [117] 100.0% [131] 14858(0.7%) 14858(0.7%) for-loop ...cts/racket/private/set-types.rkt:152:2 ------------------------------------------------------------------------------------------- matcher [119] 100.0% [132] 11164(0.5%) 0(0.0%) for-loop ...f-of-prods/src/core/matcher.rkt:183:21 matcher [119] 100.0% ------------------------------------------------------------------------------------------- for-loop [120] 0.3% f137 [130] 0.4% setfindf [24] 0.4% ??? [226] 0.9% substitute-e [81] 5.3% finalize-iter! [57] 20.2% variable? [56] 20.6% match-e [68] 25.2% get-sigs [127] 26.1% [133] 260586(12.2%) 98794(4.6%) ??? ...contract/private/arrow-val-first.rkt:357:18 hash-has-key? [142] 40.6% for-loop [145] 20.2% ??? [226] 0.9% ??? [149] 0.4% ------------------------------------------------------------------------------------------- ??? [176] 0.4% for-loop [69] 1.8% f137 [130] 2.0% get-sigs [127] 95.8% [134] 191502(9.0%) 12412(0.6%) ??? ...ts/racket/contract/private/arr-i.rkt:804:10 ??? [143] 51.5% for-loop [144] 35.6% get/build-late-neg-projection [167] 5.1% ??? [218] 0.5% ??? [150] 0.4% ------------------------------------------------------------------------------------------- hash-update! [128] 100.0% [135] 176534(8.3%) 1046(0.0%) ??? ...ie/diff-of-prods/src/core/egraph.rkt:225:24 for-loop [141] 99.2% make-sequence [256] 0.2% ------------------------------------------------------------------------------------------- f137 [130] 0.7% ??? [176] 0.9% for-loop [69] 33.3% get-sigs [127] 65.0% [136] 94874(4.4%) 28044(1.3%) ...prods/src/common.rkt:47:2 ...e/arr-i.rkt:906:19 ??? [146] 37.8% ??? [147] 31.7% ------------------------------------------------------------------------------------------- for-loop [129] 100.0% [137] 60294(2.8%) 60294(2.8%) for-loop ...cts/racket/private/set-types.rkt:178:5 ------------------------------------------------------------------------------------------- parse-loop12 [217] 2.3% ??? [148] 3.1% make-exacts* [121] 20.6% f137 [130] 34.5% loop [122] 39.5% [138] 11840(0.6%) 0(0.0%) map ...acket/collects/racket/private/map.rkt:20:13 loop [225] 54.2% f137 [130] 17.0% ??? [170] 8.9% parse-loop12 [217] 8.0% ??? [148] 3.7% ??? [176] 3.1% simplify* [233] 2.1% make-multiplication-node [235] 1.4% taylor-invert [12] 0.9% simplify-node [15] 0.7% ------------------------------------------------------------------------------------------- f137 [130] 100.0% [139] 1372(0.1%) 0(0.0%) ??? ...tract/private/arrow-higher-order.rkt:336:46 ??? [226] 100.0% ------------------------------------------------------------------------------------------- f137 [130] 100.0% [140] 626(0.0%) 0(0.0%) loop ...ie/diff-of-prods/src/core/taylor.rkt:262:2 simplify [44] 52.1% hash-ref! [203] 47.9% ------------------------------------------------------------------------------------------- ??? [135] 100.0% [141] 175080(8.2%) 147322(6.9%) for-loop ...ff-of-prods/src/core/egraph.rkt:226:26 update-en-expr [152] 15.9% ------------------------------------------------------------------------------------------- mk-enode! [89] 8.8% ??? [133] 91.2% [142] 116778(5.5%) 36642(1.7%) hash-has-key? ...et/private/more-scheme.rkt:368:13 ??? [188] 62.9% ??? [192] 5.8% ------------------------------------------------------------------------------------------- ??? [134] 100.0% [143] 98536(4.6%) 7146(0.3%) ??? ...ects/racket/contract/private/hash.rkt:217:4 ??? [151] 92.7% ------------------------------------------------------------------------------------------- for-loop [201] 20.1% ??? [134] 79.9% [144] 85316(4.0%) 15044(0.7%) for-loop ...racket/contract/private/hash.rkt:239:6 ??? [202] 79.5% ??? [229] 2.9% ------------------------------------------------------------------------------------------- ??? [133] 100.0% [145] 53314(2.5%) 0(0.0%) for-loop ...f-of-prods/src/core/alt-table.rkt:51:2 atab-add-altn [153] 100.0% ------------------------------------------------------------------------------------------- ...prods/src/common.rkt:47:2 [136] 100.0% [146] 35878(1.7%) 15364(0.7%) ??? ...s/racket/contract/private/arr-i.rkt:1268:39 ??? [190] 27.2% return/no-unsupplied [237] 20.4% assoc-ref [154] 9.5% ------------------------------------------------------------------------------------------- for-loop [216] 5.3% ??? [202] 12.5% ...prods/src/common.rkt:47:2 [136] 82.1% [147] 30116(1.4%) 5246(0.2%) ??? ...ects/racket/contract/private/list.rkt:342:4 ??? [202] 71.6% ??? [226] 10.8% ??? [218] 7.2% ------------------------------------------------------------------------------------------- map [138] 31.8% loop [225] 68.2% [148] 2044(0.1%) 0(0.0%) ??? ...ket/collects/racket/private/list.rkt:323:18 hash-ref! [203] 64.6% f137 [130] 31.8% map [138] 3.6% ------------------------------------------------------------------------------------------- ??? [133] 100.0% [149] 1000(0.0%) 0(0.0%) ??? ...e/diff-of-prods/src/core/alt-table.rkt:54:0 ??? [176] 100.0% ------------------------------------------------------------------------------------------- ??? [134] 100.0% [150] 698(0.0%) 0(0.0%) ??? ...private/unconstrained-domain-arrow.rkt:69:2 get-blame-party-info [155] 100.0% ------------------------------------------------------------------------------------------- ??? [143] 100.0% [151] 91390(4.3%) 3716(0.2%) ??? ...ects/racket/contract/private/list.rkt:169:2 ??? [156] 95.9% ------------------------------------------------------------------------------------------- for-loop [99] 0.4% for-loop [104] 1.4% update-leader! [91] 4.2% for-loop [92] 10.8% for-loop [141] 35.6% loop! [103] 47.7% [152] 78074(3.7%) 75642(3.5%) update-en-expr ...-prods/src/core/egraph.rkt:211:0 for-loop [159] 3.1% ------------------------------------------------------------------------------------------- for-loop [145] 100.0% [153] 53314(2.5%) 0(0.0%) atab-add-altn ...rods/src/core/alt-table.rkt:208:0 best-and-tied-at-points [157] 93.0% override-at-pnts [158] 6.4% loop [225] 0.6% ------------------------------------------------------------------------------------------- ??? [146] 100.0% [154] 3418(0.2%) 3418(0.2%) assoc-ref ...collects/racket/private/dict.rkt:56:0 ------------------------------------------------------------------------------------------- ??? [150] 100.0% [155] 698(0.0%) 370(0.0%) get-blame-party-info ...ate/arrow-common.rkt:136:0 show-blame-positive [160] 47.0% ------------------------------------------------------------------------------------------- ??? [151] 100.0% [156] 87674(4.1%) 5602(0.3%) ??? ...ects/racket/contract/private/list.rkt:678:5 for-loop [161] 93.6% ------------------------------------------------------------------------------------------- atab-add-altn [153] 100.0% [157] 49562(2.3%) 362(0.0%) best-and-tied-at-points ...ore/alt-table.rkt:122:0 errors [162] 97.9% for-loop [163] 1.4% ------------------------------------------------------------------------------------------- atab-add-altn [153] 100.0% [158] 3404(0.2%) 0(0.0%) override-at-pnts ...s/src/core/alt-table.rkt:145:0 errors [162] 90.5% for-loop [164] 9.5% ------------------------------------------------------------------------------------------- update-en-expr [152] 100.0% [159] 2432(0.1%) 2432(0.1%) for-loop ...iff-of-prods/src/core/egraph.rkt:213:6 ------------------------------------------------------------------------------------------- get-blame-party-info [155] 100.0% [160] 328(0.0%) 328(0.0%) show-blame-positive ...act/private/blame.rkt:150:0 ------------------------------------------------------------------------------------------- ??? [156] 100.0% [161] 82072(3.8%) 14504(0.7%) for-loop ...racket/contract/private/list.rkt:680:9 add-list-context [165] 54.6% get/build-late-neg-projection [167] 27.8% ------------------------------------------------------------------------------------------- pred [82] 0.1% option-on-expr [6] 0.6% composed [208] 1.9% override-at-pnts [158] 5.8% best-and-tied-at-points [157] 91.5% [162] 53000(2.5%) 0(0.0%) errors ...erbie/diff-of-prods/src/points.rkt:218:0 for-loop [166] 84.1% eval-prog [168] 15.2% ------------------------------------------------------------------------------------------- best-and-tied-at-points [157] 100.0% [163] 686(0.0%) 328(0.0%) for-loop ...of-prods/src/core/alt-table.rkt:124:16 ??? [169] 52.2% ------------------------------------------------------------------------------------------- override-at-pnts [158] 100.0% [164] 324(0.0%) 324(0.0%) for-loop ...of-prods/src/core/alt-table.rkt:146:43 ------------------------------------------------------------------------------------------- for-loop [161] 100.0% [165] 44774(2.1%) 44774(2.1%) add-list-context ...ontract/private/list.rkt:752:0 ------------------------------------------------------------------------------------------- errors [162] 100.0% [166] 44598(2.1%) 1136(0.1%) for-loop ...bie/diff-of-prods/src/points.rkt:221:4 ??? [170] 85.5% ulp-difference [173] 7.9% ??? [176] 4.0% ------------------------------------------------------------------------------------------- ??? [172] 12.1% ??? [134] 17.0% for-loop [161] 70.2% [167] 32490(1.5%) 5730(0.3%) get/build-late-neg-projection ...te/guts.rkt:691:0 ??? [171] 69.8% ??? [172] 13.1% ------------------------------------------------------------------------------------------- make-exacts* [121] 4.6% errors [162] 30.8% loop [105] 64.7% [168] 26220(1.2%) 2772(0.1%) eval-prog .../diff-of-prods/src/programs.rkt:148:0 hash-ref! [203] 67.4% f137 [130] 19.4% parse-app [232] 1.4% ??? [174] 1.3% ------------------------------------------------------------------------------------------- for-loop [163] 100.0% [169] 358(0.0%) 358(0.0%) ??? ...ket/collects/racket/private/for.rkt:1151:14 ------------------------------------------------------------------------------------------- ??? [65] 0.1% ??? [48] 0.1% jloop [16] 0.2% loop [87] 1.0% map [138] 2.2% loop [225] 17.3% for-loop [166] 79.1% [170] 48224(2.3%) 464(0.0%) ??? ...herbie/diff-of-prods/src/programs.rkt:154:4 ??? [175] 87.0% ??? [176] 8.8% ??? [183] 3.2% ------------------------------------------------------------------------------------------- get/build-late-neg-projection [167] 100.0% [171] 25372(1.2%) 6158(0.3%) ??? ...cts/racket/contract/private/prop.rkt:314:12 build-compound-type-name [177] 75.7% ------------------------------------------------------------------------------------------- get/build-late-neg-projection [167] 100.0% [172] 8228(0.4%) 334(0.0%) ??? ...ects/racket/contract/private/hash.rkt:211:2 get/build-late-neg-projection [167] 95.9% ------------------------------------------------------------------------------------------- loop [43] 9.2% for-loop [166] 90.8% [173] 3896(0.2%) 2448(0.1%) ulp-difference ...diff-of-prods/src/float.rkt:19:0 ??? [190] 27.6% return/no-unsupplied [237] 9.6% ------------------------------------------------------------------------------------------- eval-prog [168] 16.2% eval-const-expr [25] 83.8% [174] 2030(0.1%) 0(0.0%) ??? ...cket/collects/racket/private/kw.rkt:1633:36 unpack245 [178] 100.0% ------------------------------------------------------------------------------------------- ??? [170] 100.0% [175] 41962(2.0%) 24096(1.1%) ??? ...acket/collects/racket/private/kw.rkt:444:14 ??? [181] 22.9% ??? [239] 9.4% ??? [242] 6.7% bf* [184] 3.1% ------------------------------------------------------------------------------------------- loop [87] 0.3% jloop [16] 0.3% loop [225] 0.3% for-loop [126] 0.3% for-loop [5] 1.7% map [138] 1.8% loop [193] 3.5% ??? [221] 4.5% ??? [149] 5.0% for-loop [166] 9.0% ??? [179] 12.2% for-loop [98] 12.2% ??? [170] 21.3% f137 [130] 26.1% [176] 19910(0.9%) 50(0.0%) ??? ...tract/private/arrow-higher-order.rkt:342:33 ??? [179] 52.3% approximate9 [182] 12.2% ??? [226] 8.5% hash-ref! [203] 8.0% best-alt [185] 5.2% ...prods/src/common.rkt:47:2 [136] 4.4% ??? [183] 4.0% ??? [134] 3.7% argmin [55] 1.5% ------------------------------------------------------------------------------------------- contract-struct-name [180] 13.9% ??? [171] 86.1% [177] 19214(0.9%) 10648(0.5%) build-compound-type-name ...private/guts.rkt:448:0 contract-struct-name [180] 54.5% ------------------------------------------------------------------------------------------- ??? [174] 100.0% [178] 2030(0.1%) 688(0.0%) unpack245 ...private/arrow-higher-order.rkt:354:44 maybe-cons-kwd [186] 48.8% ??? [229] 17.3% ------------------------------------------------------------------------------------------- simplify-alt [47] 0.0% f137 [130] 0.1% ??? [176] 0.5% for-loop [69] 1.3% ??? [179] 1.6% get-sigs [127] 2.3% for-loop [187] 46.3% ??? [78] 46.9% [179] 2041826(95.6%) 52526(2.5%) ??? ...llects/racket/private/norm-define.rkt:53:83 for-loop [187] 46.4% iterate-egraph!13 [1] 44.7% loop [4] 2.8% ??? [188] 2.6% ??? [179] 1.6% mk-egraph [191] 0.3% ??? [190] 0.2% return/no-unsupplied [237] 0.2% ??? [176] 0.1% ??? [202] 0.0% dict? [245] 0.0% extract-smallest [198] 0.0% ??? [192] 0.0% loop [199] 0.0% list-member? [189] 0.0% *simplify-rules* [200] 0.0% ------------------------------------------------------------------------------------------- build-compound-type-name [177] 100.0% [180] 12368(0.6%) 8566(0.4%) contract-struct-name ...ract/private/prop.rkt:89:0 build-compound-type-name [177] 36.9% ------------------------------------------------------------------------------------------- ??? [175] 100.0% [181] 9620(0.5%) 5094(0.2%) ??? .../diff-of-prods/src/syntax/syntax.rkt:122:17 ??? [190] 25.0% return/no-unsupplied [237] 22.1% ------------------------------------------------------------------------------------------- ??? [176] 100.0% [182] 6446(0.3%) 0(0.0%) approximate9 ...-of-prods/src/core/taylor.rkt:12:0 loop [193] 74.0% f137 [130] 26.0% ------------------------------------------------------------------------------------------- ??? [176] 33.6% ??? [170] 66.4% [183] 2348(0.1%) 0(0.0%) ??? ...contract/private/../../private/kw.rkt:761:9 real->bigfloat [194] 66.4% integer->bigfloat [195] 33.6% ------------------------------------------------------------------------------------------- ??? [175] 100.0% [184] 1306(0.1%) 0(0.0%) bf* ...ath/private/bigfloat/bigfloat-mpfr.rkt:95:0 ??? [239] 100.0% ------------------------------------------------------------------------------------------- ??? [176] 100.0% [185] 1026(0.0%) 0(0.0%) best-alt ...herbie/diff-of-prods/src/glue.rkt:71:0 argmins [196] 64.1% loop [197] 35.9% ------------------------------------------------------------------------------------------- unpack245 [178] 100.0% [186] 990(0.0%) 330(0.0%) maybe-cons-kwd ...ate/arrow-higher-order.rkt:498:0 successfully-got-the-right-kind-of-function [222] 33.5% arrow-higher-order:lnp [220] 33.1% ------------------------------------------------------------------------------------------- ??? [179] 100.0% [187] 1965408(92.0%) 0(0.0%) for-loop ...f-of-prods/src/core/simplify.rkt:63:12 ??? [179] 99.9% debug-print [209] 0.0% ------------------------------------------------------------------------------------------- hash-has-key? [142] 32.1% ??? [179] 67.9% [188] 228980(10.7%) 85086(4.0%) ??? ...ects/racket/contract/private/list.rkt:737:4 for-loop [201] 47.3% ??? [213] 12.7% arrow-higher-order:lnp [220] 1.3% ??? [202] 0.9% successfully-got-the-right-kind-of-function [222] 0.4% ??? [226] 0.3% ------------------------------------------------------------------------------------------- ??? [179] 0.2% for-loop [67] 99.8% [189] 29006(1.4%) 1124(0.1%) list-member? ...llects/racket/private/set.rkt:24:0 loop [204] 72.4% member [207] 23.7% ------------------------------------------------------------------------------------------- for-loop [123] 1.4% flag-set? [124] 1.5% ulp-difference [173] 4.5% ??? [181] 10.0% ??? [146] 40.7% ??? [179] 42.0% [190] 23984(1.1%) 6142(0.3%) ??? ...racket/collects/racket/private/kw.rkt:761:9 ??? [205] 63.5% ??? [226] 10.9% ------------------------------------------------------------------------------------------- ??? [179] 100.0% [191] 11882(0.6%) 0(0.0%) mk-egraph ...ff-of-prods/src/core/egraph.rkt:123:0 expr->enode [206] 92.6% mk-enode! [89] 7.4% ------------------------------------------------------------------------------------------- ??? [179] 4.6% hash-has-key? [142] 95.4% [192] 7040(0.3%) 7040(0.3%) ??? ...ects/racket/contract/private/hash.rkt:245:7 ------------------------------------------------------------------------------------------- approximate9 [182] 100.0% [193] 4772(0.2%) 0(0.0%) loop ...bie/diff-of-prods/src/core/taylor.rkt:86:4 hash-ref! [203] 56.7% ??? [176] 43.3% ------------------------------------------------------------------------------------------- ??? [183] 100.0% [194] 1560(0.1%) 1024(0.0%) real->bigfloat .../private/bigfloat/mpfr.rkt:451:0 ??? [265] 34.4% ------------------------------------------------------------------------------------------- ??? [183] 100.0% [195] 788(0.0%) 788(0.0%) integer->bigfloat ...ivate/bigfloat/mpfr.rkt:399:0 ------------------------------------------------------------------------------------------- best-alt [185] 100.0% [196] 658(0.0%) 0(0.0%) argmins ...rbie/diff-of-prods/src/common.rkt:145:0 composed [208] 100.0% ------------------------------------------------------------------------------------------- best-alt [185] 100.0% [197] 368(0.0%) 0(0.0%) loop .../herbie/diff-of-prods/src/common.rkt:146:2 composed [208] 100.0% ------------------------------------------------------------------------------------------- ??? [179] 100.0% [198] 328(0.0%) 0(0.0%) extract-smallest ...ds/src/core/simplify.rkt:191:0 hash-keys [210] 100.0% ------------------------------------------------------------------------------------------- ??? [179] 100.0% [199] 60(0.0%) 0(0.0%) loop ...s/herbie/diff-of-prods/src/points.rkt:66:6 random-exp [211] 100.0% ------------------------------------------------------------------------------------------- ??? [179] 100.0% [200] 50(0.0%) 0(0.0%) *simplify-rules* ...ods/src/syntax/rules.rkt:497:0 flag-set? [124] 100.0% ------------------------------------------------------------------------------------------- ??? [188] 100.0% [201] 108262(5.1%) 59626(2.8%) for-loop ...acket/contract/private/list.rkt:743:12 ??? [213] 25.4% for-loop [144] 15.8% ??? [218] 2.4% successfully-got-the-right-kind-of-function [222] 0.7% arrow-higher-order:lnp [220] 0.7% ------------------------------------------------------------------------------------------- ??? [179] 2.0% ??? [188] 2.2% ??? [147] 27.2% for-loop [144] 68.5% [202] 98998(4.6%) 15998(0.7%) ??? ...cts/racket/contract/private/list.rkt:187:10 ??? [212] 67.4% ??? [147] 7.6% for-loop [216] 6.9% ??? [229] 1.9% ------------------------------------------------------------------------------------------- simplify* [233] 0.1% ??? [11] 0.3% for-loop [35] 0.3% loop [140] 0.3% ??? [49] 0.3% for-loop [32] 0.3% for-loop [46] 0.7% loop [193] 1.4% for-loop [27] 1.9% ??? [219] 2.2% ??? [176] 2.4% for-loop [26] 2.5% ??? [148] 2.6% update-leader! [91] 3.8% eval-prog [168] 13.1% compile [84] 16.0% ??? [214] 16.3% loop [225] 33.7% [203] 37818(1.8%) 11976(0.6%) hash-ref! ...racket/private/more-scheme.rkt:373:13 ??? [214] 53.9% bigfloat-hash [215] 12.7% parse-loop12 [217] 4.3% ??? [8] 3.1% ??? [219] 2.2% simplify [44] 2.2% ??? [9] 1.9% ??? [221] 1.4% ??? [10] 0.7% f137 [130] 0.6% ??? [11] 0.6% ??? [14] 0.3% ------------------------------------------------------------------------------------------- list-member? [189] 100.0% [204] 21010(1.0%) 21010(1.0%) loop (unknown source) ------------------------------------------------------------------------------------------- ??? [190] 100.0% [205] 15236(0.7%) 14814(0.7%) ??? ...s/racket/contract/private/arr-i.rkt:1233:27 ??? [223] 2.8% ------------------------------------------------------------------------------------------- mk-egraph [191] 33.6% expr->enode [206] 66.4% [206] 11000(0.5%) 336(0.0%) expr->enode ...-of-prods/src/core/egraph.rkt:124:2 expr->enode [206] 66.4% mk-enode! [89] 32.8% ------------------------------------------------------------------------------------------- list-member? [189] 100.0% [207] 6872(0.3%) 6872(0.3%) member (unknown source) ------------------------------------------------------------------------------------------- f137 [130] 26.0% loop [197] 26.6% argmins [196] 47.5% [208] 1386(0.1%) 0(0.0%) composed ...ollects/racket/private/list.rkt:321:16 errors [162] 74.0% f137 [130] 26.0% ------------------------------------------------------------------------------------------- for-loop [187] 23.6% simplify [44] 24.3% iterate-egraph!13 [1] 52.0% [209] 1380(0.1%) 1044(0.0%) debug-print ...e/diff-of-prods/src/debug.rkt:107:0 for-loop [224] 24.3% ------------------------------------------------------------------------------------------- extract-smallest [198] 100.0% [210] 328(0.0%) 328(0.0%) hash-keys .../collects/racket/private/hash.rkt:2:2 ------------------------------------------------------------------------------------------- loop [199] 100.0% [211] 60(0.0%) 60(0.0%) random-exp ...e/diff-of-prods/src/common.rkt:246:0 ------------------------------------------------------------------------------------------- ??? [202] 100.0% [212] 66750(3.1%) 3216(0.2%) ??? ...ects/racket/contract/private/list.rkt:686:7 ??? [226] 91.3% ??? [229] 3.9% ------------------------------------------------------------------------------------------- for-loop [201] 48.6% ??? [188] 51.4% [213] 56524(2.6%) 27434(1.3%) ??? ...private/unconstrained-domain-arrow.rkt:74:4 make-keyword-procedure [227] 51.5% ------------------------------------------------------------------------------------------- hash-ref! [203] 100.0% [214] 27164(1.3%) 2746(0.1%) ??? ...herbie/diff-of-prods/src/programs.rkt:183:5 loop [225] 61.1% hash-ref! [203] 33.5% ------------------------------------------------------------------------------------------- hash-ref! [203] 100.0% [215] 16926(0.8%) 50(0.0%) bigfloat-hash ...h/private/bigfloat/mpfr.rkt:165:0 bfcanonicalize [228] 94.6% sig+exp->bigfloat [234] 4.8% bigfloat->sig+exp [248] 0.3% ------------------------------------------------------------------------------------------- ??? [202] 100.0% [216] 6844(0.3%) 3626(0.2%) for-loop ...acket/contract/private/list.rkt:190:15 ??? [147] 47.0% ------------------------------------------------------------------------------------------- append-map [33] 1.6% loop [225] 2.6% map [138] 8.8% simplify [44] 18.5% parse-loop12 [217] 18.9% type-of-enode-expr [115] 24.3% hash-ref! [203] 25.2% [217] 6844(0.3%) 3730(0.2%) parse-loop12 ...s/racket/match/compiler.rkt:418:15 loop [225] 27.8% parse-loop12 [217] 18.9% parse-app [232] 7.9% map [138] 2.8% loop [43] 1.8% make-multiplication-node [235] 1.6% simplify* [233] 1.6% ------------------------------------------------------------------------------------------- ??? [134] 16.4% ??? [147] 38.4% for-loop [201] 45.3% [218] 5670(0.3%) 1754(0.1%) ??? ...ects/racket/contract/private/hash.rkt:222:6 check-hash/c [230] 69.1% ------------------------------------------------------------------------------------------- hash-ref! [203] 100.0% [219] 4472(0.2%) 0(0.0%) ??? ...bie/diff-of-prods/src/core/taylor.rkt:44:15 hash-ref! [203] 100.0% ------------------------------------------------------------------------------------------- maybe-cons-kwd [186] 8.3% for-loop [201] 18.2% ??? [188] 73.5% [220] 3954(0.2%) 1364(0.1%) arrow-higher-order:lnp ...w-higher-order.rkt:597:7 ??? [231] 65.5% ------------------------------------------------------------------------------------------- hash-ref! [203] 100.0% [221] 2706(0.1%) 0(0.0%) ??? ...bie/diff-of-prods/src/core/taylor.rkt:67:15 ??? [176] 100.0% ------------------------------------------------------------------------------------------- maybe-cons-kwd [186] 17.0% for-loop [201] 40.1% ??? [188] 42.9% [222] 1954(0.1%) 1732(0.1%) successfully-got-the-right-kind-of-function ...9:4 arity-checking-wrapper [236] 11.4% ------------------------------------------------------------------------------------------- ??? [205] 100.0% [223] 422(0.0%) 422(0.0%) ??? ...ects/racket/contract/private/prop.rkt:256:4 ------------------------------------------------------------------------------------------- debug-print [209] 100.0% [224] 336(0.0%) 336(0.0%) for-loop ...rbie/diff-of-prods/src/debug.rkt:113:2 ------------------------------------------------------------------------------------------- make-exacts* [121] 0.0% map [138] 0.1% atab-add-altn [153] 0.1% parse-loop12 [217] 0.5% map-enodes [21] 1.7% f137 [130] 1.9% match-e [68] 2.6% for-loop [80] 3.4% ??? [214] 4.4% loop! [103] 16.3% loop [225] 69.0% [225] 294850(13.8%) 29424(1.4%) loop ...cket/collects/racket/private/map.rkt:25:19 loop [225] 69.0% loop! [103] 14.6% hash-ref! [203] 4.4% foldl [238] 1.9% option-on-expr [6] 1.9% for-loop [5] 1.6% curried [240] 0.5% parse-loop12 [217] 0.2% ??? [148] 0.2% f137 [130] 0.1% ??? [170] 0.1% loop [261] 0.1% set-precompute! [249] 0.0% ??? [242] 0.0% ??? [239] 0.0% ??? [176] 0.0% ??? [253] 0.0% ------------------------------------------------------------------------------------------- ??? [188] 0.9% ??? [139] 1.8% ??? [176] 2.2% ??? [133] 3.0% ??? [190] 3.4% ??? [147] 8.5% ??? [212] 80.2% [226] 76026(3.6%) 67572(3.2%) ??? ...ects/racket/contract/private/guts.rkt:644:8 contract? [241] 4.8% ??? [133] 4.0% dict? [245] 2.4% ------------------------------------------------------------------------------------------- ??? [213] 100.0% [227] 29090(1.4%) 29090(1.4%) make-keyword-procedure ...ket/private/kw.rkt:260:4 ------------------------------------------------------------------------------------------- bigfloat-hash [215] 100.0% [228] 16008(0.7%) 15600(0.7%) bfcanonicalize .../private/bigfloat/mpfr.rkt:155:0 bigfloat->sig+exp [248] 2.5% ------------------------------------------------------------------------------------------- unpack245 [178] 4.9% ??? [202] 25.7% for-loop [144] 33.8% ??? [212] 35.7% [229] 7256(0.3%) 4698(0.2%) ??? ...ects/racket/contract/private/prop.rkt:493:4 ??? [244] 35.3% ------------------------------------------------------------------------------------------- ??? [218] 100.0% [230] 3916(0.2%) 1114(0.1%) check-hash/c ...ket/contract/private/hash.rkt:83:0 flat-contract? [243] 71.6% ------------------------------------------------------------------------------------------- arrow-higher-order:lnp [220] 100.0% [231] 2590(0.1%) 2280(0.1%) ??? ...et/contract/private/arity-checking.rkt:19:2 procedure-arity [246] 12.0% ------------------------------------------------------------------------------------------- eval-const-expr [25] 22.1% eval-prog [168] 24.8% parse-loop12 [217] 49.4% [232] 1454(0.1%) 1454(0.1%) parse-app .../collects/racket/private/kw.rkt:951:2 ------------------------------------------------------------------------------------------- simplify [44] 24.7% parse-loop12 [217] 25.3% map [138] 49.9% [233] 1318(0.1%) 328(0.0%) simplify* ...iff-of-prods/src/core/reduce.rkt:31:0 return/no-unsupplied [237] 25.3% hash-ref! [203] 25.0% ??? [250] 24.7% ------------------------------------------------------------------------------------------- bigfloat-hash [215] 100.0% [234] 812(0.0%) 712(0.0%) sig+exp->bigfloat ...ivate/bigfloat/mpfr.rkt:385:0 integer->mpz [252] 12.3% ------------------------------------------------------------------------------------------- map [138] 49.8% parse-loop12 [217] 50.2% [235] 666(0.0%) 0(0.0%) make-multiplication-node .../core/reduce.rkt:230:0 make-multiplication-subnode [247] 100.0% ------------------------------------------------------------------------------------------- successfully-got-the-right-kind-of-function [222]100.0% [236] 222(0.0%) 60(0.0%) arity-checking-wrapper ...w-higher-order.rkt:402:0 matches-arity-exactly? [251] 73.0% ------------------------------------------------------------------------------------------- simplify* [233] 1.9% ulp-difference [173] 2.1% ??? [181] 11.9% ??? [146] 41.0% ??? [179] 43.2% [237] 17892(0.8%) 10510(0.5%) return/no-unsupplied ...ct/private/arr-i.rkt:533:0 filter [254] 41.3% ------------------------------------------------------------------------------------------- for-loop [80] 32.1% loop [225] 67.9% [238] 10446(0.5%) 4680(0.2%) foldl ...et/collects/racket/private/list.rkt:229:4 merge2 [255] 55.2% ------------------------------------------------------------------------------------------- loop [225] 5.3% eval-const-expr [25] 15.0% bf* [184] 19.8% ??? [175] 59.9% [239] 6608(0.3%) 3176(0.1%) ??? ...-racket/utils/simple-result-arrow.rkt:39:12 bfsub [257] 40.4% bfexp [259] 11.5% ------------------------------------------------------------------------------------------- ormap [113] 6.6% for-loop [80] 20.7% for-loop [5] 28.5% loop [225] 44.3% [240] 4946(0.2%) 4946(0.2%) curried ...cket/collects/racket/function.rkt:71:18 ------------------------------------------------------------------------------------------- ??? [226] 100.0% [241] 3650(0.2%) 3650(0.2%) contract? ...acket/contract/private/guts.rkt:109:0 ------------------------------------------------------------------------------------------- loop [225] 10.1% ??? [175] 89.9% [242] 3126(0.1%) 3126(0.1%) ??? ...rivate/unconstrained-domain-arrow.rkt:40:13 ------------------------------------------------------------------------------------------- check-hash/c [230] 100.0% [243] 2802(0.1%) 2802(0.1%) flat-contract? .../contract/private/guts.rkt:111:0 ------------------------------------------------------------------------------------------- ??? [229] 100.0% [244] 2558(0.1%) 1600(0.1%) ??? ...lects/racket/contract/private/orc.rkt:83:14 ??? [258] 37.5% ------------------------------------------------------------------------------------------- ??? [179] 28.3% ??? [226] 71.7% [245] 2506(0.1%) 2506(0.1%) dict? ...ollects/racket/private/generic.rkt:146:11 ------------------------------------------------------------------------------------------- ??? [231] 12.9% curry* [100] 87.1% [246] 2412(0.1%) 2412(0.1%) procedure-arity ...ket/private/norm-arity.rkt:7:27 ------------------------------------------------------------------------------------------- make-multiplication-node [235] 100.0% [247] 666(0.0%) 0(0.0%) make-multiplication-subnode ...re/reduce.rkt:240:0 for-loop [260] 100.0% ------------------------------------------------------------------------------------------- bigfloat-hash [215] 12.1% bfcanonicalize [228] 87.9% [248] 464(0.0%) 60(0.0%) bigfloat->sig+exp ...ivate/bigfloat/mpfr.rkt:370:0 size+limbs->integer [262] 38.4% new-mpz [263] 24.6% mpz->integer [264] 24.1% ------------------------------------------------------------------------------------------- loop [225] 100.0% [249] 408(0.0%) 56(0.0%) set-precompute! ...ods/src/core/simplify.rkt:172:0 make-sequence [256] 86.3% ------------------------------------------------------------------------------------------- simplify* [233] 100.0% [250] 326(0.0%) 326(0.0%) ??? ...racket/collects/racket/private/kw.rkt:762:9 ------------------------------------------------------------------------------------------- arity-checking-wrapper [236] 100.0% [251] 162(0.0%) 162(0.0%) matches-arity-exactly? ...te/arrow-common.rkt:70:0 ------------------------------------------------------------------------------------------- sig+exp->bigfloat [234] 100.0% [252] 100(0.0%) 100(0.0%) integer->mpz ...math/private/bigfloat/gmp.rkt:87:0 ------------------------------------------------------------------------------------------- loop [225] 100.0% [253] 50(0.0%) 0(0.0%) ??? ...diff-of-prods/src/core/alt-table.rkt:199:30 loop [261] 100.0% ------------------------------------------------------------------------------------------- one-iter [17] 6.3% match-e [68] 8.7% for-loop [41] 8.9% for-loop [80] 12.8% return/no-unsupplied [237] 63.4% [254] 11652(0.5%) 11652(0.5%) filter ...t/collects/racket/private/list.rkt:256:2 ------------------------------------------------------------------------------------------- foldl [238] 100.0% [255] 5766(0.3%) 5766(0.3%) merge2 ...e/diff-of-prods/src/core/ematch.rkt:31:0 ------------------------------------------------------------------------------------------- merge-egraph-nodes! [79] 4.5% set-precompute! [249] 7.8% ??? [135] 9.1% for-loop [41] 16.1% reduce-to-single! [73] 16.2% update-leader! [91] 46.3% [256] 4492(0.2%) 3462(0.2%) make-sequence ...ects/racket/private/for.rkt:509:2 ??? [266] 22.9% ------------------------------------------------------------------------------------------- ??? [239] 100.0% [257] 2670(0.1%) 1846(0.1%) bfsub ...-lib/math/private/bigfloat/mpfr.rkt:819:4 ??? [265] 30.9% ------------------------------------------------------------------------------------------- ??? [244] 100.0% [258] 958(0.0%) 958(0.0%) ??? ...ects/racket/contract/private/list.rkt:141:5 ------------------------------------------------------------------------------------------- ??? [239] 100.0% [259] 762(0.0%) 648(0.0%) bfexp ...-lib/math/private/bigfloat/mpfr.rkt:616:4 ??? [265] 15.0% ------------------------------------------------------------------------------------------- make-multiplication-subnode [247] 100.0% [260] 666(0.0%) 0(0.0%) for-loop ...iff-of-prods/src/core/reduce.rkt:242:3 mterm->expr [267] 50.2% partition [268] 49.8% ------------------------------------------------------------------------------------------- loop [225] 1.1% ??? [253] 14.4% loop [261] 84.6% [261] 348(0.0%) 348(0.0%) loop ...ket/collects/racket/private/list.rkt:82:16 loop [261] 84.6% ------------------------------------------------------------------------------------------- bigfloat->sig+exp [248] 100.0% [262] 178(0.0%) 178(0.0%) size+limbs->integer ...vate/bigfloat/gmp.rkt:103:0 ------------------------------------------------------------------------------------------- bigfloat->sig+exp [248] 100.0% [263] 114(0.0%) 114(0.0%) new-mpz ...-lib/math/private/bigfloat/gmp.rkt:73:0 ------------------------------------------------------------------------------------------- bigfloat->sig+exp [248] 100.0% [264] 112(0.0%) 112(0.0%) mpz->integer ...ath/private/bigfloat/gmp.rkt:115:0 ------------------------------------------------------------------------------------------- bfexp [259] 7.7% real->bigfloat [194] 36.4% bfsub [257] 55.9% [265] 1474(0.1%) 1474(0.1%) ??? .../share/racket/collects/ffi/unsafe.rkt:861:4 ------------------------------------------------------------------------------------------- make-sequence [256] 100.0% [266] 1030(0.0%) 334(0.0%) ??? ...acket/collects/racket/private/for.rkt:429:7 custom-in-set [269] 67.6% ------------------------------------------------------------------------------------------- for-loop [260] 100.0% [267] 334(0.0%) 0(0.0%) mterm->expr ...-of-prods/src/core/reduce.rkt:270:0 expression->type [111] 100.0% ------------------------------------------------------------------------------------------- for-loop [260] 100.0% [268] 332(0.0%) 332(0.0%) partition ...racket/collects/racket/list.rkt:547:0 ------------------------------------------------------------------------------------------- ??? [266] 18.6% match-e [68] 81.4% [269] 3752(0.2%) 3752(0.2%) custom-in-set ...acket/private/set-types.rkt:577:0 -------------------------------------------------------------------------------------------