Profiling results ----------------- Total cpu time observed: 478350ms (out of 479720ms) Number of samples taken: 2072 (once every 231ms) (Hiding functions with self<1.0% and local<2.0%: 17 of 277 hidden) ============================================================================== Caller Idx Total Self Name+src Local% ms(pct) ms(pct) Callee ============================================================================== ??? [92] 100.0% [1] 398086(83.2%) 0(0.0%) profile-thunk16 ...t/pkgs/profile-lib/main.rkt:9:0 run [19] 100.0% ------------------------------------------------------------------------------ ??? [92] 100.0% [2] 389588(81.4%) 0(0.0%) run-improve50 ...f-of-prods/src/mainloop.rkt:234:0 for-loop [20] 94.3% get-final-combination [24] 4.8% loop [107] 0.8% setup-alt-simplified [38] 0.1% ------------------------------------------------------------------------------ ??? [215] 100.0% [3] 349364(73.0%) 0(0.0%) iterate-egraph!13 ...s/src/core/simplify.rkt:102:0 one-iter [21] 99.3% map-enodes [32] 0.7% debug-print [196] 0.0% ------------------------------------------------------------------------------ ??? [215] 100.0% [4] 48476(10.1%) 0(0.0%) loop .../diff-of-prods/src/core/simplify.rkt:215:2 pass [22] 100.0% ------------------------------------------------------------------------------ ??? [205] 100.0% [5] 23202(4.9%) 0(0.0%) approximate9 ...-of-prods/src/core/taylor.rkt:12:0 loop [23] 86.6% f6 [190] 13.0% taylor [192] 0.4% ------------------------------------------------------------------------------ f6 [190] 4.8% loop [193] 95.2% [6] 18490(3.9%) 0(0.0%) option-on-expr ...prods/src/core/regimes.rkt:103:0 sindices->spoints [26] 64.2% loop [193] 16.3% sort-context-on-expr [33] 10.7% err-lsts->split-indices [36] 4.1% errors [161] 3.0% pick-errors [39] 1.7% ------------------------------------------------------------------------------ hash-ref! [169] 100.0% [7] 14826(3.1%) 0(0.0%) ??? ...ie/diff-of-prods/src/core/taylor.rkt:285:26 for-loop [25] 100.0% ------------------------------------------------------------------------------ parse-loop12 [183] 13.7% for-loop [188] 20.4% map [191] 65.9% [8] 10030(2.1%) 320(0.1%) make-multiplication-node .../core/reduce.rkt:230:0 make-multiplication-subnode [28] 96.8% ------------------------------------------------------------------------------ hash-ref! [169] 100.0% [9] 8388(1.8%) 0(0.0%) ??? ...ie/diff-of-prods/src/core/taylor.rkt:295:23 for-loop [29] 100.0% ------------------------------------------------------------------------------ hash-ref! [169] 100.0% [10] 7378(1.5%) 0(0.0%) ??? ...ie/diff-of-prods/src/core/taylor.rkt:338:33 for-loop [30] 78.9% hash-ref! [169] 21.1% ------------------------------------------------------------------------------ append-map [11] 4.3% simplify-node [194] 19.6% f6 [190] 76.2% [11] 4240(0.9%) 102(0.0%) append-map ...acket/collects/racket/list.rkt:565:2 parse-loop12 [183] 76.4% f6 [190] 12.8% free-variables [15] 5.3% append-map [11] 4.3% ------------------------------------------------------------------------------ ??? [199] 9.1% map [191] 44.9% f6 [190] 46.0% [12] 3936(0.8%) 0(0.0%) taylor-quotient ...prods/src/core/taylor.rkt:328:0 first-nonzero-exp [31] 61.8% simplify [175] 38.2% ------------------------------------------------------------------------------ hash-ref! [169] 100.0% [13] 1794(0.4%) 0(0.0%) ??? ...ie/diff-of-prods/src/core/taylor.rkt:392:23 for-loop [34] 100.0% ------------------------------------------------------------------------------ rewriter [112] 100.0% [14] 974(0.2%) 0(0.0%) *rules* ...iff-of-prods/src/syntax/rules.rkt:493:0 for-loop [35] 100.0% ------------------------------------------------------------------------------ append-map [11] 100.0% [15] 718(0.2%) 0(0.0%) free-variables ...-of-prods/src/programs.rkt:100:0 variable? [27] 100.0% ------------------------------------------------------------------------------ hash-ref! [169] 100.0% [16] 716(0.1%) 0(0.0%) ??? ...ie/diff-of-prods/src/core/taylor.rkt:483:23 for-loop [37] 100.0% ------------------------------------------------------------------------------ copying-mergesort [89] 100.0% [17] 634(0.1%) 0(0.0%) jloop ...t/collects/racket/private/sort.rkt:121:23 ??? [198] 100.0% ------------------------------------------------------------------------------ f6 [190] 100.0% [18] 102(0.0%) 0(0.0%) exprs-to-branch-on ...ds/src/core/regimes.rkt:55:0 for-loop [40] 100.0% ------------------------------------------------------------------------------ profile-thunk16 [1] 100.0% [19] 398086(83.2%) 0(0.0%) run ...share/racket/pkgs/profile-lib/main.rkt:39:2 ??? [92] 100.0% ------------------------------------------------------------------------------ run-improve50 [2] 100.0% [20] 367476(76.8%) 0(0.0%) for-loop .../diff-of-prods/src/mainloop.rkt:249:10 run-iter! [41] 100.0% ------------------------------------------------------------------------------ iterate-egraph!13 [3] 100.0% [21] 346940(72.5%) 5320(1.1%) one-iter ...f-of-prods/src/core/simplify.rkt:113:0 loop [42] 74.6% for-loop [43] 21.1% apply-match [61] 2.6% ------------------------------------------------------------------------------ loop [4] 100.0% [22] 48476(10.1%) 0(0.0%) pass .../diff-of-prods/src/core/simplify.rkt:205:2 for-loop [44] 100.0% ------------------------------------------------------------------------------ approximate9 [5] 100.0% [23] 20090(4.2%) 0(0.0%) loop ...bie/diff-of-prods/src/core/taylor.rkt:86:4 ??? [205] 60.5% hash-ref! [169] 39.5% ------------------------------------------------------------------------------ run-improve50 [2] 100.0% [24] 18748(3.9%) 0(0.0%) get-final-combination ...ds/src/mainloop.rkt:264:0 split-table [45] 99.7% extract-alt [59] 0.3% ------------------------------------------------------------------------------ ??? [7] 100.0% [25] 14826(3.1%) 0(0.0%) for-loop ...ff-of-prods/src/core/taylor.rkt:285:52 hash-ref! [169] 82.6% ??? [48] 11.7% simplify [175] 5.8% ------------------------------------------------------------------------------ option-on-expr [6] 100.0% [26] 11872(2.5%) 0(0.0%) sindices->spoints ...ds/src/core/regimes.rkt:116:0 loop [46] 100.0% ------------------------------------------------------------------------------ free-variables [15] 7.0% substitute-e [95] 14.1% match-e [80] 78.9% [27] 10196(2.1%) 0(0.0%) variable? ...-of-prods/src/syntax/syntax.rkt:567:0 ??? [139] 100.0% ------------------------------------------------------------------------------ make-multiplication-node [8] 100.0% [28] 9710(2.0%) 0(0.0%) make-multiplication-subnode ...re/reduce.rkt:240:0 for-loop [47] 96.6% group-by68 [54] 3.4% ------------------------------------------------------------------------------ ??? [9] 100.0% [29] 8388(1.8%) 326(0.1%) for-loop ...ff-of-prods/src/core/taylor.rkt:298:27 hash-ref! [169] 91.8% simplify [175] 4.3% ------------------------------------------------------------------------------ ??? [10] 100.0% [30] 6352(1.3%) 0(0.0%) for-loop ...ff-of-prods/src/core/taylor.rkt:341:46 hash-ref! [169] 100.0% ------------------------------------------------------------------------------ taylor-quotient [12] 100.0% [31] 2432(0.5%) 0(0.0%) first-nonzero-exp ...ods/src/core/taylor.rkt:260:0 hash-ref! [169] 100.0% ------------------------------------------------------------------------------ iterate-egraph!13 [3] 100.0% [32] 2324(0.5%) 0(0.0%) map-enodes ...f-of-prods/src/core/egraph.rkt:139:0 loop [193] 84.5% hash-keys [53] 15.5% ------------------------------------------------------------------------------ option-on-expr [6] 100.0% [33] 1978(0.4%) 0(0.0%) sort-context-on-expr ...prods/src/points.rkt:115:0 ??? [49] 97.5% eval-prog [168] 2.5% ------------------------------------------------------------------------------ ??? [13] 100.0% [34] 1794(0.4%) 0(0.0%) for-loop ...ff-of-prods/src/core/taylor.rkt:396:33 for-loop [50] 100.0% ------------------------------------------------------------------------------ merge-egraph-nodes! [93] 8.4% *simplify-rules* [234] 9.4% *rules* [14] 82.1% [35] 1186(0.2%) 212(0.0%) for-loop ...rbie/diff-of-prods/src/common.rkt:94:9 ormap [51] 82.1% ------------------------------------------------------------------------------ option-on-expr [6] 100.0% [36] 766(0.2%) 0(0.0%) err-lsts->split-indices .../core/regimes.rkt:222:0 add-splitpoint [52] 100.0% ------------------------------------------------------------------------------ ??? [16] 100.0% [37] 716(0.1%) 0(0.0%) for-loop ...ff-of-prods/src/core/taylor.rkt:487:35 parse-loop12 [183] 100.0% ------------------------------------------------------------------------------ run-improve50 [2] 100.0% [38] 322(0.1%) 0(0.0%) setup-alt-simplified ...of-prods/src/glue.rkt:49:0 simplify-alt [55] 100.0% ------------------------------------------------------------------------------ option-on-expr [6] 100.0% [39] 308(0.1%) 0(0.0%) pick-errors ...of-prods/src/core/regimes.rkt:184:0 for-loop [56] 65.6% point->alt [57] 34.4% ------------------------------------------------------------------------------ exprs-to-branch-on [18] 100.0% [40] 102(0.0%) 0(0.0%) for-loop ...ff-of-prods/src/core/regimes.rkt:57:27 all-critical-subexpressions [58] 100.0% ------------------------------------------------------------------------------ for-loop [20] 100.0% [41] 367476(76.8%) 0(0.0%) run-iter! .../diff-of-prods/src/mainloop.rkt:215:0 simplify! [60] 87.5% gen-series! [63] 6.5% finalize-iter! [64] 4.0% gen-rewrites! [69] 1.0% localize-error [70] 0.7% choose-best-alt! [72] 0.3% ------------------------------------------------------------------------------ one-iter [21] 100.0% [42] 258810(54.1%) 360(0.1%) loop ...cket/collects/racket/private/map.rkt:52:19 apply-match [61] 99.9% ------------------------------------------------------------------------------ for-loop [43] 49.3% one-iter [21] 50.7% [43] 73352(15.3%) 13092(2.7%) for-loop ...-of-prods/src/core/simplify.rkt:123:12 for-loop [43] 49.3% match-e [80] 41.1% ------------------------------------------------------------------------------ pass [22] 100.0% [44] 48476(10.1%) 746(0.2%) for-loop ...-of-prods/src/core/simplify.rkt:208:29 argmin [62] 58.4% loop [65] 28.5% for-loop [68] 11.0% make-sequence [149] 0.6% ------------------------------------------------------------------------------ get-final-combination [24] 100.0% [45] 18698(3.9%) 0(0.0%) split-table ...ie/diff-of-prods/src/glue.rkt:162:0 f6 [190] 99.4% ??? [139] 0.6% ------------------------------------------------------------------------------ sindices->spoints [26] 100.0% [46] 11872(2.5%) 0(0.0%) loop ...cket/collects/racket/private/map.rkt:36:19 sidx->spoint [66] 100.0% ------------------------------------------------------------------------------ make-multiplication-subnode [28] 100.0% [47] 9382(2.0%) 112(0.0%) for-loop ...iff-of-prods/src/core/reduce.rkt:242:3 make-multiplication-subsubsubnode [67] 87.5% mterm->expr [84] 11.3% ------------------------------------------------------------------------------ for-loop [25] 100.0% [48] 4348(0.9%) 0(0.0%) ??? ...ie/diff-of-prods/src/core/taylor.rkt:288:19 hash-ref! [169] 100.0% ------------------------------------------------------------------------------ sort-context-on-expr [33] 100.0% [49] 1928(0.4%) 0(0.0%) ??? ...cket/collects/racket/private/sort.rkt:403:3 generic-sort/key [71] 83.8% loop [100] 16.2% ------------------------------------------------------------------------------ for-loop [34] 100.0% [50] 1794(0.4%) 0(0.0%) for-loop ...ff-of-prods/src/core/taylor.rkt:398:39 hash-ref! [169] 100.0% ------------------------------------------------------------------------------ for-loop [35] 100.0% [51] 974(0.2%) 0(0.0%) ormap ...et/collects/racket/private/map.rkt:105:13 flag-set? [73] 100.0% ------------------------------------------------------------------------------ err-lsts->split-indices [36] 100.0% [52] 766(0.2%) 0(0.0%) add-splitpoint ...prods/src/core/regimes.rkt:235:2 for-loop [74] 100.0% ------------------------------------------------------------------------------ map-enodes [32] 100.0% [53] 360(0.1%) 0(0.0%) hash-keys .../collects/racket/private/hash.rkt:2:2 loop [75] 100.0% ------------------------------------------------------------------------------ make-multiplication-subnode [28] 100.0% [54] 328(0.1%) 328(0.1%) group-by68 ...acket/collects/racket/list.rkt:749:0 ------------------------------------------------------------------------------ setup-alt-simplified [38] 100.0% [55] 322(0.1%) 0(0.0%) simplify-alt ...ie/diff-of-prods/src/glue.rkt:76:0 ??? [215] 100.0% ------------------------------------------------------------------------------ pick-errors [39] 100.0% [56] 202(0.0%) 0(0.0%) for-loop ...ff-of-prods/src/core/regimes.rkt:186:2 ??? [76] 100.0% ------------------------------------------------------------------------------ pick-errors [39] 100.0% [57] 106(0.0%) 0(0.0%) point->alt ...-of-prods/src/core/regimes.rkt:171:0 eval-prog [168] 100.0% ------------------------------------------------------------------------------ for-loop [40] 100.0% [58] 102(0.0%) 0(0.0%) all-critical-subexpressions ...re/regimes.rkt:71:0 for-loop [77] 100.0% ------------------------------------------------------------------------------ get-final-combination [24] 100.0% [59] 50(0.0%) 0(0.0%) extract-alt ...bie/diff-of-prods/src/glue.rkt:55:0 loop [231] 100.0% ------------------------------------------------------------------------------ run-iter! [41] 100.0% [60] 321514(67.2%) 0(0.0%) simplify! .../diff-of-prods/src/mainloop.rkt:155:0 for-loop [78] 100.0% ------------------------------------------------------------------------------ one-iter [21] 3.4% loop [42] 96.6% [61] 267582(55.9%) 1016(0.2%) apply-match ...f-prods/src/core/simplify.rkt:130:2 for-loop [79] 89.6% match-e [80] 8.9% reduce-to-single! [88] 0.7% update-leader! [104] 0.4% ------------------------------------------------------------------------------ for-loop [44] 100.0% [62] 28310(5.9%) 0(0.0%) argmin ...re/racket/collects/racket/list.rkt:743:0 for-loop [81] 93.9% expression-cost [85] 6.1% ------------------------------------------------------------------------------ run-iter! [41] 100.0% [63] 23886(5.0%) 0(0.0%) gen-series! ...iff-of-prods/src/mainloop.rkt:129:0 for-loop [82] 100.0% ------------------------------------------------------------------------------ run-iter! [41] 100.0% [64] 14880(3.1%) 0(0.0%) finalize-iter! ...-of-prods/src/mainloop.rkt:169:0 ??? [139] 100.0% ------------------------------------------------------------------------------ for-loop [44] 100.0% [65] 13824(2.9%) 0(0.0%) loop ...hare/racket/collects/racket/list.rkt:729:4 for-loop [81] 84.5% expression-cost [85] 15.5% ------------------------------------------------------------------------------ loop [46] 100.0% [66] 11872(2.5%) 0(0.0%) sidx->spoint ...f-prods/src/core/regimes.rkt:126:2 binary-search [83] 81.4% binary-search-floats [87] 18.6% ------------------------------------------------------------------------------ make-multiplication-subsubsubnode [67] 2.2% for-loop [47] 97.8% [67] 8208(1.7%) 0(0.0%) make-multiplication-subsubsubnode ...uce.rkt:262:0 mterm->expr [84] 97.8% make-multiplication-subsubsubnode [67] 2.2% ------------------------------------------------------------------------------ for-loop [44] 100.0% [68] 5316(1.1%) 5316(1.1%) for-loop ...-of-prods/src/core/simplify.rkt:195:13 ------------------------------------------------------------------------------ run-iter! [41] 100.0% [69] 3592(0.8%) 0(0.0%) gen-rewrites! ...f-of-prods/src/mainloop.rkt:142:0 for-loop [86] 100.0% ------------------------------------------------------------------------------ run-iter! [41] 100.0% [70] 2428(0.5%) 0(0.0%) localize-error ...prods/src/core/localize.rkt:47:0 hash-ref! [169] 95.9% for-loop [91] 4.1% ------------------------------------------------------------------------------ ??? [49] 100.0% [71] 1616(0.3%) 0(0.0%) generic-sort/key .../racket/private/sort.rkt:185:2 copying-mergesort [89] 84.4% loop [100] 15.6% ------------------------------------------------------------------------------ run-iter! [41] 100.0% [72] 1176(0.2%) 0(0.0%) choose-best-alt! ...f-prods/src/mainloop.rkt:115:0 ??? [139] 100.0% ------------------------------------------------------------------------------ ormap [51] 100.0% [73] 974(0.2%) 642(0.1%) flag-set? ...bie/diff-of-prods/src/config.rkt:32:0 ??? [227] 34.1% ------------------------------------------------------------------------------ add-splitpoint [52] 100.0% [74] 766(0.2%) 256(0.1%) for-loop ...ff-of-prods/src/core/regimes.rkt:237:4 for-loop [90] 66.6% ------------------------------------------------------------------------------ hash-keys [53] 2.3% loop [75] 97.7% [75] 360(0.1%) 360(0.1%) loop ...acket/collects/racket/private/hash.rkt:3:4 loop [75] 97.7% ------------------------------------------------------------------------------ ??? [164] 34.4% for-loop [56] 65.6% [76] 308(0.1%) 0(0.0%) ??? ...ie/diff-of-prods/src/core/regimes.rkt:177:2 ??? [198] 100.0% ------------------------------------------------------------------------------ all-critical-subexpressions [58] 100.0% [77] 102(0.0%) 0(0.0%) for-loop ...iff-of-prods/src/core/regimes.rkt:75:2 f6 [190] 100.0% ------------------------------------------------------------------------------ simplify! [60] 98.2% [78] 327268(68.4%) 0(0.0%) for-loop ...e/diff-of-prods/src/mainloop.rkt:159:6 ??? [92] 100.0% ------------------------------------------------------------------------------ apply-match [61] 100.0% [79] 239858(50.1%) 1388(0.3%) for-loop ...-of-prods/src/core/simplify.rkt:145:10 merge-egraph-nodes! [93] 35.3% mk-enode! [103] 28.7% substitute-e [95] 18.0% loop! [197] 13.9% list-member? [226] 3.5% ------------------------------------------------------------------------------ apply-match [61] 18.3% for-loop [105] 25.0% for-loop [43] 56.6% [80] 84102(17.6%) 26292(5.5%) match-e .../diff-of-prods/src/core/ematch.rkt:46:0 for-loop [94] 48.5% for-loop [105] 9.7% ??? [139] 4.5% variable? [27] 3.9% list-cartesian-product [108] 2.5% loop [193] 2.4% custom-in-set [132] 1.0% filter [240] 0.1% ------------------------------------------------------------------------------ loop [65] 30.5% argmin [62] 69.5% [81] 38270(8.0%) 684(0.1%) for-loop ...e/diff-of-prods/src/programs.rkt:199:2 ??? [215] 72.4% ...prods/src/common.rkt:47:2 [141] 25.1% ??? [140] 0.7% ------------------------------------------------------------------------------ gen-series! [63] 100.0% [82] 23886(5.0%) 0(0.0%) for-loop ...e/diff-of-prods/src/mainloop.rkt:135:7 taylor-alt [96] 100.0% ------------------------------------------------------------------------------ sidx->spoint [66] 100.0% [83] 9664(2.0%) 0(0.0%) binary-search ...iff-of-prods/src/common.rkt:221:0 pred [97] 100.0% ------------------------------------------------------------------------------ for-loop [47] 11.5% make-multiplication-subsubsubnode [67] 88.5% [84] 9270(1.9%) 0(0.0%) mterm->expr ...-of-prods/src/core/reduce.rkt:270:0 f6 [190] 100.0% ------------------------------------------------------------------------------ argmin [62] 44.7% loop [65] 55.3% [85] 3864(0.8%) 298(0.1%) expression-cost ...of-prods/src/programs.rkt:198:0 compile [99] 92.3% ------------------------------------------------------------------------------ gen-rewrites! [69] 100.0% [86] 3592(0.8%) 0(0.0%) for-loop .../diff-of-prods/src/mainloop.rkt:147:11 ??? [98] 100.0% ------------------------------------------------------------------------------ sidx->spoint [66] 100.0% [87] 2208(0.5%) 0(0.0%) binary-search-floats ...prods/src/common.rkt:236:0 pred [97] 100.0% ------------------------------------------------------------------------------ apply-match [61] 100.0% [88] 1758(0.4%) 458(0.1%) reduce-to-single! ...ods/src/core/egraph.rkt:324:0 for-loop [101] 55.1% make-sequence [149] 18.9% ------------------------------------------------------------------------------ generic-sort/key [71] 43.9% copying-mergesort [89] 56.1% [89] 1364(0.3%) 0(0.0%) copying-mergesort ...racket/private/sort.rkt:130:8 copying-mergesort [89] 56.1% loop [100] 32.2% jloop [17] 11.6% ------------------------------------------------------------------------------ for-loop [74] 100.0% [90] 510(0.1%) 510(0.1%) for-loop ...ff-of-prods/src/core/regimes.rkt:241:8 ------------------------------------------------------------------------------ localize-error [70] 100.0% [91] 100(0.0%) 0(0.0%) for-loop ...f-of-prods/src/core/localize.rkt:61:10 loop [102] 100.0% ------------------------------------------------------------------------------ for-loop [78] 23.9% run [19] 30.7% [92] 473162(98.9%) 64(0.0%) ??? ...lects/racket/private/more-scheme.rkt:261:28 ??? [215] 38.2% profile-thunk16 [1] 30.7% run-improve50 [2] 30.0% loop [107] 1.0% ------------------------------------------------------------------------------ for-loop [109] 3.4% merge-egraph-nodes! [93] 4.7% for-loop [79] 91.9% [93] 84714(17.7%) 1066(0.2%) merge-egraph-nodes! ...s/src/core/egraph.rkt:152:0 update-leader! [104] 66.1% loop! [197] 10.5% for-loop [110] 8.0% for-loop [109] 4.8% merge-egraph-nodes! [93] 4.7% enode-merge! [111] 4.1% make-sequence [149] 0.4% for-loop [35] 0.1% ------------------------------------------------------------------------------ match-e [80] 100.0% [94] 51374(10.7%) 17142(3.6%) for-loop ...iff-of-prods/src/core/ematch.rkt:59:11 for-loop [105] 52.6% list-cartesian-product [108] 9.9% loop [193] 6.3% curried [209] 1.6% foldl [201] 1.2% filter [240] 0.6% curry* [113] 0.3% ------------------------------------------------------------------------------ substitute-e [95] 5.3% for-loop [79] 94.7% [95] 43106(9.0%) 2296(0.5%) substitute-e ...-of-prods/src/core/ematch.rkt:71:0 mk-enode! [103] 89.2% substitute-e [95] 5.3% variable? [27] 1.4% ??? [139] 0.8% ------------------------------------------------------------------------------ for-loop [82] 100.0% [96] 23886(5.0%) 0(0.0%) taylor-alt ...bie/diff-of-prods/src/glue.rkt:134:0 for-loop [106] 100.0% ------------------------------------------------------------------------------ binary-search-floats [87] 18.6% binary-search [83] 81.4% [97] 11872(2.5%) 0(0.0%) pred .../diff-of-prods/src/core/regimes.rkt:132:17 loop [107] 91.1% errors [161] 8.9% ------------------------------------------------------------------------------ for-loop [86] 100.0% [98] 3592(0.8%) 0(0.0%) ??? ...rbie/diff-of-prods/src/alternative.rkt:88:0 rewriter [112] 100.0% ------------------------------------------------------------------------------ expression-cost [85] 100.0% [99] 3566(0.7%) 730(0.2%) compile ...ie/diff-of-prods/src/programs.rkt:175:0 hash-ref! [169] 79.5% ------------------------------------------------------------------------------ generic-sort/key [71] 19.5% ??? [49] 24.1% copying-mergesort [89] 56.4% [100] 1294(0.3%) 0(0.0%) loop ...ket/collects/racket/private/sort.rkt:97:12 ??? [198] 91.8% ??? [205] 8.2% ------------------------------------------------------------------------------ reduce-to-single! [88] 100.0% [101] 968(0.2%) 968(0.2%) for-loop ...iff-of-prods/src/core/egraph.rkt:325:8 ------------------------------------------------------------------------------ for-loop [91] 100.0% [102] 100(0.0%) 100(0.0%) loop ...ket/collects/racket/private/map.rkt:112:23 ------------------------------------------------------------------------------ expr->enode [243] 1.4% substitute-e [95] 35.3% for-loop [79] 63.2% [103] 108832(22.8%) 10474(2.2%) mk-enode! ...ff-of-prods/src/core/egraph.rkt:101:0 new-enode [114] 88.3% hash-has-key? [143] 1.4% mutable-set [122] 0.7% ------------------------------------------------------------------------------ apply-match [61] 1.8% merge-egraph-nodes! [93] 98.2% [104] 62128(13.0%) 4640(1.0%) update-leader! ...-prods/src/core/egraph.rkt:217:0 for-loop [115] 90.6% update-en-expr [206] 0.8% mutable-set [122] 0.6% ------------------------------------------------------------------------------ match-e [80] 32.1% for-loop [94] 67.9% [105] 43668(9.1%) 4250(0.9%) for-loop ...iff-of-prods/src/core/ematch.rkt:65:37 match-e [80] 87.5% ??? [121] 3.8% ------------------------------------------------------------------------------ taylor-alt [96] 100.0% [106] 23886(5.0%) 0(0.0%) for-loop ...erbie/diff-of-prods/src/glue.rkt:139:6 ??? [205] 100.0% ------------------------------------------------------------------------------ run-improve50 [2] 12.8% ??? [92] 41.7% pred [97] 45.5% [107] 23762(5.0%) 0(0.0%) loop .../herbie/diff-of-prods/src/points.rkt:193:2 loop [128] 50.7% loop [116] 24.6% make-exacts* [129] 24.3% for-loop [124] 0.4% ------------------------------------------------------------------------------ match-e [80] 16.0% list-cartesian-product [108] 24.0% for-loop [94] 60.0% [108] 8810(1.8%) 6996(1.5%) list-cartesian-product ...src/core/ematch.rkt:20:0 list-cartesian-product [108] 24.0% for-loop [120] 14.0% ------------------------------------------------------------------------------ merge-egraph-nodes! [93] 100.0% [109] 7056(1.5%) 0(0.0%) for-loop ...ff-of-prods/src/core/egraph.rkt:200:10 merge-egraph-nodes! [93] 82.6% loop! [197] 17.4% ------------------------------------------------------------------------------ merge-egraph-nodes! [93] 100.0% [110] 6782(1.4%) 5164(1.1%) for-loop ...iff-of-prods/src/core/egraph.rkt:232:6 update-en-expr [206] 23.9% ------------------------------------------------------------------------------ merge-egraph-nodes! [93] 100.0% [111] 3612(0.8%) 592(0.1%) enode-merge! ...-of-prods/src/core/enode.rkt:129:0 adopt-enode! [118] 65.3% custom-set-intersect! [123] 18.3% ------------------------------------------------------------------------------ ??? [98] 31.0% matcher [130] 69.0% [112] 3592(0.8%) 330(0.1%) rewriter ...ff-of-prods/src/core/matcher.rkt:131:2 for-loop [117] 69.0% f6 [190] 15.3% *rules* [14] 9.7% expression->type [119] 4.5% ------------------------------------------------------------------------------ for-loop [94] 100.0% [113] 246(0.1%) 146(0.0%) curry* ...racket/collects/racket/function.rkt:44:2 procedure-arity [125] 40.7% ------------------------------------------------------------------------------ mk-enode! [103] 100.0% [114] 96148(20.1%) 336(0.1%) new-enode ...diff-of-prods/src/core/enode.rkt:97:0 type-of-enode-expr [126] 98.3% set [208] 1.3% ------------------------------------------------------------------------------ update-leader! [104] 100.0% [115] 56288(11.8%) 840(0.2%) for-loop ...iff-of-prods/src/core/egraph.rkt:222:6 for-loop [127] 97.3% update-en-expr [206] 1.2% ------------------------------------------------------------------------------ loop [107] 100.0% [116] 5856(1.2%) 0(0.0%) loop .../herbie/diff-of-prods/src/points.rkt:151:2 loop [128] 55.9% make-exacts* [129] 36.0% eval-prog [168] 8.1% ------------------------------------------------------------------------------ rewriter [112] 100.0% [117] 3592(0.8%) 0(0.0%) for-loop ...f-of-prods/src/core/matcher.rkt:134:10 matcher [130] 100.0% ------------------------------------------------------------------------------ enode-merge! [111] 100.0% [118] 2360(0.5%) 1348(0.3%) adopt-enode! ...-of-prods/src/core/enode.rkt:105:0 custom-set-union [207] 42.9% ------------------------------------------------------------------------------ rewriter [112] 8.1% f6 [190] 91.9% [119] 1990(0.4%) 0(0.0%) expression->type ...-prods/src/type-check.rkt:45:0 for-loop [131] 84.9% ??? [139] 15.1% ------------------------------------------------------------------------------ list-cartesian-product [108] 100.0% [120] 1814(0.4%) 1814(0.4%) for-loop ...diff-of-prods/src/core/ematch.rkt:24:8 ------------------------------------------------------------------------------ for-loop [105] 100.0% [121] 1660(0.3%) 1560(0.3%) ??? ...rbie/diff-of-prods/src/core/ematch.rkt:50:5 custom-in-set [132] 6.0% ------------------------------------------------------------------------------ update-leader! [104] 33.6% mk-enode! [103] 66.4% [122] 1076(0.2%) 714(0.1%) mutable-set .../racket/private/set-types.rkt:999:0 for-loop [133] 33.6% ------------------------------------------------------------------------------ enode-merge! [111] 100.0% [123] 660(0.1%) 660(0.1%) custom-set-intersect! ...ivate/set-types.rkt:269:0 ------------------------------------------------------------------------------ loop [107] 100.0% [124] 104(0.0%) 0(0.0%) for-loop ...ie/diff-of-prods/src/points.rkt:200:24 for-loop [134] 100.0% ------------------------------------------------------------------------------ curry* [113] 100.0% [125] 100(0.0%) 100(0.0%) procedure-arity ...ket/private/norm-arity.rkt:7:27 ------------------------------------------------------------------------------ new-enode [114] 100.0% [126] 94522(19.8%) 3068(0.6%) type-of-enode-expr ...rods/src/core/enode.rkt:68:0 get-sigs [135] 96.8% ------------------------------------------------------------------------------ for-loop [115] 100.0% [127] 54778(11.5%) 270(0.1%) for-loop ...iff-of-prods/src/core/egraph.rkt:223:8 hash-update! [136] 99.5% ------------------------------------------------------------------------------ loop [116] 21.4% loop [107] 78.6% [128] 15312(3.2%) 0(0.0%) loop .../herbie/diff-of-prods/src/points.rkt:141:4 map [191] 97.8% loop [193] 2.2% ------------------------------------------------------------------------------ loop [116] 26.8% loop [107] 73.2% [129] 7872(1.6%) 0(0.0%) make-exacts* ...diff-of-prods/src/points.rkt:138:0 map [191] 50.5% loop [193] 49.5% ------------------------------------------------------------------------------ for-loop [137] 22.9% matcher [130] 27.1% for-loop [117] 50.0% [130] 3592(0.8%) 0(0.0%) matcher ...iff-of-prods/src/core/matcher.rkt:167:2 rewriter [112] 50.0% matcher [130] 27.1% for-loop [137] 22.9% ------------------------------------------------------------------------------ expression->type [119] 100.0% [131] 1690(0.4%) 718(0.2%) for-loop .../diff-of-prods/src/type-check.rkt:52:5 f6 [190] 38.5% ??? [227] 19.1% ------------------------------------------------------------------------------ ??? [121] 9.1% match-e [80] 90.9% [132] 1100(0.2%) 1100(0.2%) custom-in-set ...acket/private/set-types.rkt:577:0 ------------------------------------------------------------------------------ mutable-set [122] 100.0% [133] 362(0.1%) 362(0.1%) for-loop ...cts/racket/private/set-types.rkt:943:2 ------------------------------------------------------------------------------ for-loop [124] 100.0% [134] 104(0.0%) 0(0.0%) for-loop ...ie/diff-of-prods/src/points.rkt:201:26 ??? [205] 100.0% ------------------------------------------------------------------------------ type-of-enode-expr [126] 100.0% [135] 91454(19.1%) 1290(0.3%) get-sigs ...e/diff-of-prods/src/type-check.rkt:5:0 ??? [140] 45.2% ??? [215] 24.6% ??? [139] 14.6% ...prods/src/common.rkt:47:2 [141] 14.1% ------------------------------------------------------------------------------ for-loop [127] 100.0% [136] 54508(11.4%) 664(0.1%) hash-update! ...ket/private/more-scheme.rkt:362:13 ??? [138] 98.8% ------------------------------------------------------------------------------ matcher [130] 100.0% [137] 2280(0.5%) 0(0.0%) for-loop ...f-of-prods/src/core/matcher.rkt:183:21 matcher [130] 100.0% ------------------------------------------------------------------------------ hash-update! [136] 100.0% [138] 53844(11.3%) 676(0.1%) ??? ...ie/diff-of-prods/src/core/egraph.rkt:225:24 for-loop [142] 98.1% make-sequence [149] 0.7% ------------------------------------------------------------------------------ split-table [45] 0.2% expression->type [119] 0.6% simplify* [195] 0.6% ??? [252] 1.5% substitute-e [95] 1.7% choose-best-alt! [72] 2.2% f6 [190] 6.5% match-e [80] 13.6% variable? [27] 19.5% get-sigs [135] 25.5% finalize-iter! [64] 28.0% [139] 52378(10.9%) 13082(2.7%) ??? ...contract/private/arrow-val-first.rkt:357:18 hash-has-key? [143] 42.6% for-loop [146] 27.8% ??? [150] 2.2% ??? [252] 1.9% split-atab [151] 0.2% ------------------------------------------------------------------------------ for-loop [81] 0.6% f6 [190] 8.9% get-sigs [135] 90.5% [140] 45708(9.6%) 4030(0.8%) ??? ...ts/racket/contract/private/arr-i.rkt:804:10 ??? [144] 50.5% for-loop [145] 32.4% get/build-late-neg-projection [166] 6.2% ??? [249] 1.5% ??? [250] 0.6% ------------------------------------------------------------------------------ ??? [205] 0.7% f6 [190] 4.5% for-loop [81] 40.4% get-sigs [135] 54.5% [141] 23748(5.0%) 6998(1.5%) ...prods/src/common.rkt:47:2 ...e/arr-i.rkt:906:19 ??? [147] 36.3% ??? [148] 32.8% ------------------------------------------------------------------------------ ??? [138] 100.0% [142] 52814(11.0%) 42168(8.8%) for-loop ...ff-of-prods/src/core/egraph.rkt:226:26 update-en-expr [206] 20.2% ------------------------------------------------------------------------------ mk-enode! [103] 6.2% ??? [139] 93.8% [143] 24030(5.0%) 6596(1.4%) hash-has-key? ...et/private/more-scheme.rkt:368:13 ??? [225] 70.2% ??? [232] 2.3% ------------------------------------------------------------------------------ ??? [140] 100.0% [144] 23104(4.8%) 1882(0.4%) ??? ...ects/racket/contract/private/hash.rkt:217:4 ??? [152] 91.9% ------------------------------------------------------------------------------ for-loop [236] 22.4% ??? [140] 77.6% [145] 19048(4.0%) 3396(0.7%) for-loop ...racket/contract/private/hash.rkt:239:6 ??? [237] 79.9% ??? [254] 2.3% ------------------------------------------------------------------------------ ??? [139] 100.0% [146] 14772(3.1%) 0(0.0%) for-loop ...f-of-prods/src/core/alt-table.rkt:51:2 atab-add-altn [153] 100.0% ------------------------------------------------------------------------------ for-loop [248] 12.0% ??? [237] 15.9% ...prods/src/common.rkt:47:2 [141] 72.1% [147] 8610(1.8%) 2280(0.5%) ??? ...ects/racket/contract/private/list.rkt:342:4 ??? [237] 67.8% ??? [252] 15.2% ??? [249] 3.2% ------------------------------------------------------------------------------ ...prods/src/common.rkt:47:2 [141] 100.0% [148] 7782(1.6%) 3404(0.7%) ??? ...s/racket/contract/private/arr-i.rkt:1268:39 ??? [227] 25.2% return/no-unsupplied [229] 17.0% assoc-ref [154] 14.0% ------------------------------------------------------------------------------ for-loop [44] 21.1% reduce-to-single! [88] 25.1% ??? [138] 26.7% merge-egraph-nodes! [93] 27.0% [149] 1324(0.3%) 1324(0.3%) make-sequence ...ects/racket/private/for.rkt:509:2 ------------------------------------------------------------------------------ ??? [139] 100.0% [150] 1176(0.2%) 0(0.0%) ??? ...e/diff-of-prods/src/core/alt-table.rkt:54:0 ??? [205] 100.0% ------------------------------------------------------------------------------ ??? [139] 100.0% [151] 106(0.0%) 0(0.0%) split-atab ...of-prods/src/core/alt-table.rkt:74:0 for-loop [155] 100.0% ------------------------------------------------------------------------------ ??? [144] 100.0% [152] 21222(4.4%) 278(0.1%) ??? ...ects/racket/contract/private/list.rkt:169:2 ??? [156] 98.7% ------------------------------------------------------------------------------ for-loop [146] 99.3% [153] 14880(3.1%) 0(0.0%) atab-add-altn ...rods/src/core/alt-table.rkt:208:0 best-and-tied-at-points [157] 83.9% override-at-pnts [158] 9.6% loop [193] 6.6% ------------------------------------------------------------------------------ ??? [148] 100.0% [154] 1090(0.2%) 1090(0.2%) assoc-ref ...collects/racket/private/dict.rkt:56:0 ------------------------------------------------------------------------------ split-atab [151] 100.0% [155] 106(0.0%) 0(0.0%) for-loop ...f-of-prods/src/core/alt-table.rkt:75:2 for-loop [159] 50.9% for-loop [160] 49.1% ------------------------------------------------------------------------------ ??? [152] 100.0% [156] 20944(4.4%) 2078(0.4%) ??? ...ects/racket/contract/private/list.rkt:678:5 for-loop [162] 90.1% ------------------------------------------------------------------------------ atab-add-altn [153] 100.0% [157] 12482(2.6%) 0(0.0%) best-and-tied-at-points ...ore/alt-table.rkt:122:0 errors [161] 97.1% for-loop [163] 2.9% ------------------------------------------------------------------------------ atab-add-altn [153] 100.0% [158] 1422(0.3%) 0(0.0%) override-at-pnts ...s/src/core/alt-table.rkt:145:0 errors [161] 100.0% ------------------------------------------------------------------------------ for-loop [155] 100.0% [159] 54(0.0%) 0(0.0%) for-loop ...-of-prods/src/core/alt-table.rkt:76:45 ??? [164] 100.0% ------------------------------------------------------------------------------ for-loop [155] 100.0% [160] 52(0.0%) 0(0.0%) for-loop ...-of-prods/src/core/alt-table.rkt:86:30 ??? [164] 100.0% ------------------------------------------------------------------------------ option-on-expr [6] 2.9% pred [97] 5.4% composed [242] 6.3% override-at-pnts [158] 7.3% loop [193] 15.5% best-and-tied-at-points [157] 62.5% [161] 19384(4.1%) 50(0.0%) errors ...erbie/diff-of-prods/src/points.rkt:218:0 for-loop [165] 83.2% eval-prog [168] 16.6% ------------------------------------------------------------------------------ ??? [156] 100.0% [162] 18866(3.9%) 3630(0.8%) for-loop ...racket/contract/private/list.rkt:680:9 add-list-context [167] 44.5% get/build-late-neg-projection [166] 36.3% ------------------------------------------------------------------------------ best-and-tied-at-points [157] 100.0% [163] 364(0.1%) 364(0.1%) for-loop ...of-prods/src/core/alt-table.rkt:124:16 ------------------------------------------------------------------------------ for-loop [160] 49.1% for-loop [159] 50.9% [164] 106(0.0%) 0(0.0%) ??? ...ie/diff-of-prods/src/core/regimes.rkt:284:4 ??? [76] 100.0% ------------------------------------------------------------------------------ errors [161] 100.0% [165] 16124(3.4%) 1960(0.4%) for-loop ...bie/diff-of-prods/src/points.rkt:221:4 ??? [198] 80.2% ??? [205] 3.7% ulp-difference [172] 3.0% ------------------------------------------------------------------------------ ??? [171] 12.3% ??? [140] 15.8% for-loop [162] 70.8% [166] 9670(2.0%) 2380(0.5%) get/build-late-neg-projection ...te/guts.rkt:691:0 ??? [170] 63.1% ??? [171] 15.8% ------------------------------------------------------------------------------ for-loop [162] 100.0% [167] 8388(1.8%) 8388(1.8%) add-list-context ...ontract/private/list.rkt:752:0 ------------------------------------------------------------------------------ sort-context-on-expr [33] 1.3% point->alt [57] 2.8% loop [116] 12.3% errors [161] 83.6% [168] 3840(0.8%) 890(0.2%) eval-prog .../diff-of-prods/src/programs.rkt:148:0 f6 [190] 67.3% hash-ref! [169] 2.7% ??? [173] 2.6% ??? [205] 1.3% ??? [174] 1.3% ------------------------------------------------------------------------------ for-loop [189] 0.1% eval-prog [168] 0.1% loop [193] 0.3% simplify* [195] 0.7% for-loop [50] 1.0% ??? [10] 1.2% ??? [48] 2.2% for-loop [30] 3.5% localize-error [70] 4.2% compile [99] 4.4% ??? [199] 4.6% first-nonzero-exp [31] 5.3% for-loop [29] 5.5% ??? [179] 6.4% loop [23] 8.7% ??? [176] 10.9% ??? [205] 17.7% for-loop [25] 22.4% [169] 26386(5.5%) 3848(0.8%) hash-ref! ...racket/private/more-scheme.rkt:373:13 ??? [7] 25.5% simplify [175] 16.7% ??? [176] 10.9% ??? [177] 8.7% ??? [179] 7.8% f6 [190] 7.4% parse-loop12 [183] 6.3% ??? [9] 6.1% ??? [10] 4.8% ??? [13] 1.0% ??? [16] 0.2% bigfloat-hash [181] 0.0% ------------------------------------------------------------------------------ get/build-late-neg-projection [166] 100.0% [170] 6954(1.5%) 1294(0.3%) ??? ...cts/racket/contract/private/prop.rkt:314:12 build-compound-type-name [178] 81.4% ------------------------------------------------------------------------------ get/build-late-neg-projection [166] 100.0% [171] 2822(0.6%) 336(0.1%) ??? ...ects/racket/contract/private/hash.rkt:211:2 get/build-late-neg-projection [166] 88.1% ------------------------------------------------------------------------------ for-loop [165] 100.0% [172] 486(0.1%) 0(0.0%) ulp-difference ...diff-of-prods/src/float.rkt:19:0 ??? [227] 89.3% return/no-unsupplied [229] 10.7% ------------------------------------------------------------------------------ eval-prog [168] 100.0% [173] 100(0.0%) 0(0.0%) ??? ...cket/collects/racket/private/kw.rkt:1633:36 unpack245 [180] 100.0% ------------------------------------------------------------------------------ eval-prog [168] 100.0% [174] 50(0.0%) 0(0.0%) ??? ...collects/racket/private/qq-and-or.rkt:155:9 ??? [182] 100.0% ------------------------------------------------------------------------------ for-loop [29] 1.7% ??? [205] 3.3% for-loop [25] 4.9% taylor-quotient [12] 7.2% hash-ref! [169] 82.5% [175] 20938(4.4%) 0(0.0%) simplify ...diff-of-prods/src/core/reduce.rkt:16:0 f6 [190] 84.5% parse-loop12 [183] 11.7% simplify-node [194] 1.7% debug7 [185] 1.6% debug-print [196] 0.5% ------------------------------------------------------------------------------ hash-ref! [169] 100.0% [176] 15924(3.3%) 0(0.0%) ??? ...bie/diff-of-prods/src/core/taylor.rkt:44:15 hash-ref! [169] 100.0% ------------------------------------------------------------------------------ hash-ref! [169] 100.0% [177] 7942(1.7%) 0(0.0%) ??? ...bie/diff-of-prods/src/core/taylor.rkt:67:15 ??? [205] 100.0% ------------------------------------------------------------------------------ contract-struct-name [184] 22.1% ??? [170] 77.9% [178] 5660(1.2%) 2644(0.6%) build-compound-type-name ...private/guts.rkt:448:0 contract-struct-name [184] 69.4% ------------------------------------------------------------------------------ hash-ref! [169] 100.0% [179] 2840(0.6%) 374(0.1%) ??? ...herbie/diff-of-prods/src/programs.rkt:183:5 hash-ref! [169] 85.6% loop [193] 3.7% ------------------------------------------------------------------------------ ??? [173] 100.0% [180] 100(0.0%) 0(0.0%) unpack245 ...private/arrow-higher-order.rkt:354:44 maybe-cons-kwd [186] 100.0% ------------------------------------------------------------------------------ hash-ref! [169] 100.0% [181] 52(0.0%) 0(0.0%) bigfloat-hash ...h/private/bigfloat/mpfr.rkt:165:0 bfcanonicalize [187] 100.0% ------------------------------------------------------------------------------ ??? [174] 100.0% [182] 50(0.0%) 50(0.0%) ??? ...ollects/racket/private/qq-and-or.rkt:164:21 ------------------------------------------------------------------------------ f6 [190] 3.6% for-loop [37] 5.3% map [191] 7.5% simplify [175] 15.6% parse-loop12 [183] 18.9% hash-ref! [169] 23.1% append-map [11] 26.0% [183] 10066(2.1%) 2518(0.5%) parse-loop12 ...s/racket/match/compiler.rkt:418:15 for-loop [188] 23.9% loop [193] 23.1% parse-loop12 [183] 18.9% make-multiplication-node [8] 5.7% for-loop [189] 5.3% f6 [190] 5.0% ------------------------------------------------------------------------------ build-compound-type-name [178] 100.0% [184] 4838(1.0%) 3016(0.6%) contract-struct-name ...ract/private/prop.rkt:89:0 build-compound-type-name [178] 44.7% ------------------------------------------------------------------------------ simplify [175] 100.0% [185] 334(0.1%) 0(0.0%) debug7 ...herbie/diff-of-prods/src/debug.rkt:102:0 ??? [227] 100.0% ------------------------------------------------------------------------------ unpack245 [180] 100.0% [186] 100(0.0%) 0(0.0%) maybe-cons-kwd ...ate/arrow-higher-order.rkt:498:0 arrow-higher-order:lnp [244] 100.0% ------------------------------------------------------------------------------ bigfloat-hash [181] 100.0% [187] 52(0.0%) 52(0.0%) bfcanonicalize .../private/bigfloat/mpfr.rkt:155:0 ------------------------------------------------------------------------------ parse-loop12 [183] 100.0% [188] 2410(0.5%) 0(0.0%) for-loop ...iff-of-prods/src/core/reduce.rkt:99:13 make-multiplication-node [8] 85.0% f6 [190] 15.0% ------------------------------------------------------------------------------ parse-loop12 [183] 100.0% [189] 716(0.1%) 0(0.0%) for-loop ...ff-of-prods/src/core/taylor.rkt:490:59 ??? [199] 50.3% hash-ref! [169] 49.7% ------------------------------------------------------------------------------ composed [242] 0.1% for-loop [77] 0.1% for-loop [188] 0.2% ??? [199] 0.3% parse-loop12 [183] 0.4% append-map [11] 0.6% eval-const-expr [214] 0.7% simplify-node [194] 0.9% for-loop [131] 1.0% approximate9 [5] 1.6% eval-prog [168] 1.9% rewriter [112] 3.9% mterm->expr [84] 4.2% hash-ref! [169] 5.6% simplify [175] 10.1% f6 [190] 10.7% map [191] 17.6% split-table [45] 39.5% [190] 44614(9.3%) 1924(0.4%) f6 ...et/collects/racket/match/compiler.rkt:507:40 loop [193] 37.4% map [191] 29.5% f6 [190] 10.7% ??? [215] 3.9% ??? [140] 2.5% ??? [139] 2.0% option-on-expr [6] 2.0% ??? [205] 1.8% expression->type [119] 1.7% append-map [11] 1.5% taylor [192] 1.0% taylor-quotient [12] 0.8% compose [212] 0.7% ...prods/src/common.rkt:47:2 [141] 0.3% parse-loop12 [183] 0.2% exprs-to-branch-on [18] 0.1% composed [242] 0.1% ------------------------------------------------------------------------------ ??? [199] 1.0% make-exacts* [129] 10.7% loop [128] 40.3% f6 [190] 47.4% [191] 37178(7.8%) 56(0.0%) map ...acket/collects/racket/private/map.rkt:20:13 loop [193] 47.2% f6 [190] 28.0% ??? [198] 7.2% make-multiplication-node [8] 4.5% parse-loop12 [183] 2.6% simplify* [195] 2.0% simplify-node [194] 1.9% ??? [199] 1.6% taylor-quotient [12] 1.4% ??? [205] 1.0% ??? [216] 0.9% ------------------------------------------------------------------------------ approximate9 [5] 12.0% f6 [190] 88.0% [192] 834(0.2%) 100(0.0%) taylor .../diff-of-prods/src/core/taylor.rkt:163:0 list-member? [226] 44.8% debug-print [196] 43.2% ------------------------------------------------------------------------------ make-exacts* [129] 0.0% ??? [179] 0.1% loop [128] 0.2% parse-loop12 [183] 0.7% map-enodes [32] 0.7% atab-add-altn [153] 0.8% option-on-expr [6] 1.1% for-loop [94] 3.1% map [191] 3.2% match-e [80] 5.1% f6 [190] 9.0% loop! [197] 10.0% loop [193] 65.9% [193] 72918(15.2%) 8604(1.8%) loop ...cket/collects/racket/private/map.rkt:25:19 loop [193] 65.9% loop! [197] 9.1% option-on-expr [6] 9.0% ??? [198] 3.4% foldl [201] 1.6% errors [161] 1.1% for-loop [200] 0.7% loop [202] 0.7% ??? [199] 0.6% curried [209] 0.5% hash-ref! [169] 0.1% ??? [216] 0.1% ??? [205] 0.1% ------------------------------------------------------------------------------ simplify [175] 9.6% map [191] 90.4% [194] 3782(0.8%) 0(0.0%) simplify-node ...of-prods/src/core/reduce.rkt:50:0 f6 [190] 73.3% append-map [11] 26.7% ------------------------------------------------------------------------------ map [191] 100.0% [195] 2394(0.5%) 1052(0.2%) simplify* ...iff-of-prods/src/core/reduce.rkt:31:0 hash-ref! [169] 42.1% ??? [139] 14.0% ------------------------------------------------------------------------------ iterate-egraph!13 [3] 17.7% simplify [175] 18.4% taylor [192] 63.8% [196] 564(0.1%) 204(0.0%) debug-print ...e/diff-of-prods/src/debug.rkt:107:0 for-loop [203] 63.8% ------------------------------------------------------------------------------ for-loop [109] 2.1% merge-egraph-nodes! [93] 17.5% loop [193] 30.3% for-loop [79] 50.2% [197] 45136(9.4%) 9066(1.9%) loop! ...ie/diff-of-prods/src/core/enode.rkt:192:2 loop [193] 36.9% custom-set-union [207] 32.3% set [208] 12.6% update-en-expr [206] 6.7% ------------------------------------------------------------------------------ ??? [76] 0.8% jloop [17] 1.7% loop [100] 3.1% map [191] 7.0% for-loop [165] 34.1% loop [193] 53.3% [198] 37968(7.9%) 390(0.1%) ??? ...herbie/diff-of-prods/src/programs.rkt:154:4 ??? [204] 91.6% ??? [205] 4.6% ??? [211] 2.8% ------------------------------------------------------------------------------ for-loop [189] 11.1% map [191] 27.6% loop [193] 61.3% [199] 3250(0.7%) 0(0.0%) ??? ...ket/collects/racket/private/list.rkt:323:18 hash-ref! [169] 57.6% f6 [190] 16.6% curried [209] 11.1% taylor-quotient [12] 11.1% map [191] 3.7% ------------------------------------------------------------------------------ loop [193] 100.0% [200] 1964(0.4%) 1184(0.2%) for-loop ...f-of-prods/src/core/simplify.rkt:173:2 setfindf [213] 17.7% eval-const-expr [214] 16.9% compose [212] 5.1% ------------------------------------------------------------------------------ for-loop [94] 34.1% loop [193] 65.9% [201] 1758(0.4%) 628(0.1%) foldl ...et/collects/racket/private/list.rkt:229:4 merge2 [210] 64.3% ------------------------------------------------------------------------------ loop [193] 2.3% loop [202] 97.7% [202] 648(0.1%) 648(0.1%) loop ...ket/collects/racket/private/list.rkt:82:16 loop [202] 97.7% ------------------------------------------------------------------------------ debug-print [196] 100.0% [203] 360(0.1%) 360(0.1%) for-loop ...rbie/diff-of-prods/src/debug.rkt:113:2 ------------------------------------------------------------------------------ ??? [198] 100.0% [204] 34776(7.3%) 6684(1.4%) ??? ...acket/collects/racket/private/kw.rkt:444:14 ??? [216] 62.0% ??? [218] 13.2% ??? [220] 4.4% ??? [254] 1.1% ------------------------------------------------------------------------------ eval-prog [168] 0.2% for-loop [134] 0.3% loop [100] 0.3% loop [193] 0.9% map [191] 1.2% for-loop [165] 1.9% ??? [150] 3.7% ??? [198] 5.5% f6 [190] 7.8% ??? [177] 8.7% loop [23] 13.2% ??? [215] 27.8% for-loop [106] 28.1% [205] 30566(6.4%) 462(0.1%) ??? ...tract/private/arrow-higher-order.rkt:342:33 ??? [215] 41.2% approximate9 [5] 27.0% hash-ref! [169] 21.9% best-alt [221] 3.7% ??? [252] 3.2% simplify [175] 1.1% ...prods/src/common.rkt:47:2 [141] 0.5% ------------------------------------------------------------------------------ update-leader! [104] 2.4% for-loop [115] 3.3% for-loop [110] 8.1% loop! [197] 33.0% for-loop [142] 53.2% [206] 20022(4.2%) 19662(4.1%) update-en-expr ...-prods/src/core/egraph.rkt:211:0 ------------------------------------------------------------------------------ adopt-enode! [118] 6.2% loop! [197] 93.8% [207] 16328(3.4%) 5372(1.1%) custom-set-union ...et/private/set-types.rkt:168:0 for-loop [217] 56.8% for-loop [219] 10.3% ------------------------------------------------------------------------------ new-enode [114] 10.3% loop! [197] 89.7% [208] 12464(2.6%) 12464(2.6%) set ...collects/racket/private/set-types.rkt:981:0 ------------------------------------------------------------------------------ loop [193] 17.5% ??? [199] 18.9% for-loop [94] 63.6% [209] 1904(0.4%) 1904(0.4%) curried ...cket/collects/racket/function.rkt:71:18 ------------------------------------------------------------------------------ foldl [201] 100.0% [210] 1130(0.2%) 1130(0.2%) merge2 ...e/diff-of-prods/src/core/ematch.rkt:31:0 ------------------------------------------------------------------------------ ??? [198] 100.0% [211] 1058(0.2%) 54(0.0%) ??? ...contract/private/../../private/kw.rkt:761:9 real->bigfloat [222] 94.9% ------------------------------------------------------------------------------ for-loop [200] 23.0% f6 [190] 77.0% [212] 434(0.1%) 434(0.1%) compose ...collects/racket/private/list.rkt:385:12 ------------------------------------------------------------------------------ for-loop [200] 100.0% [213] 348(0.1%) 0(0.0%) setfindf ...bie/diff-of-prods/src/common.rkt:179:0 for-loop [223] 100.0% ------------------------------------------------------------------------------ for-loop [200] 100.0% [214] 332(0.1%) 0(0.0%) eval-const-expr ...of-prods/src/programs.rkt:166:0 f6 [190] 100.0% ------------------------------------------------------------------------------ simplify-alt [55] 0.0% f6 [190] 0.4% get-sigs [135] 1.8% for-loop [81] 2.2% ??? [205] 3.8% ??? [215] 6.3% for-loop [224] 41.0% ??? [92] 44.1% [215] 428754(89.6%) 16572(3.5%) ??? ...llects/racket/private/norm-define.rkt:53:83 for-loop [224] 41.0% iterate-egraph!13 [3] 39.9% ??? [215] 6.3% loop [4] 4.6% ??? [225] 3.0% ??? [205] 2.8% return/no-unsupplied [229] 0.4% ??? [227] 0.3% mk-egraph [230] 0.2% list-member? [226] 0.1% *simplify-rules* [234] 0.0% ??? [232] 0.0% dict? [256] 0.0% ??? [235] 0.0% ??? [237] 0.0% ------------------------------------------------------------------------------ map [191] 1.4% loop [193] 5.6% ??? [204] 92.9% [216] 23200(4.9%) 22756(4.8%) ??? ...-racket/utils/simple-result-arrow.rkt:39:12 bfsub [233] 1.0% ------------------------------------------------------------------------------ custom-set-union [207] 100.0% [217] 9270(1.9%) 3518(0.7%) for-loop ...cts/racket/private/set-types.rkt:174:3 for-loop [228] 62.0% ------------------------------------------------------------------------------ ??? [204] 100.0% [218] 4598(1.0%) 2170(0.5%) ??? .../diff-of-prods/src/syntax/syntax.rkt:122:17 ??? [227] 38.8% return/no-unsupplied [229] 14.0% ------------------------------------------------------------------------------ custom-set-union [207] 100.0% [219] 1686(0.4%) 1686(0.4%) for-loop ...cts/racket/private/set-types.rkt:152:2 ------------------------------------------------------------------------------ ??? [204] 100.0% [220] 1544(0.3%) 1544(0.3%) ??? ...rivate/unconstrained-domain-arrow.rkt:40:13 ------------------------------------------------------------------------------ ??? [205] 100.0% [221] 1176(0.2%) 0(0.0%) best-alt ...herbie/diff-of-prods/src/glue.rkt:71:0 loop [231] 100.0% ------------------------------------------------------------------------------ ??? [211] 100.0% [222] 1004(0.2%) 1004(0.2%) real->bigfloat .../private/bigfloat/mpfr.rkt:451:0 ------------------------------------------------------------------------------ setfindf [213] 100.0% [223] 348(0.1%) 348(0.1%) for-loop ...bie/diff-of-prods/src/common.rkt:180:2 ------------------------------------------------------------------------------ ??? [215] 100.0% [224] 366354(76.6%) 0(0.0%) for-loop ...f-of-prods/src/core/simplify.rkt:63:12 ??? [215] 100.0% ------------------------------------------------------------------------------ hash-has-key? [143] 32.0% ??? [215] 68.0% [225] 52712(11.0%) 20602(4.3%) ??? ...ects/racket/contract/private/list.rkt:737:4 for-loop [236] 46.8% ??? [247] 10.7% ??? [237] 2.0% arrow-higher-order:lnp [244] 0.7% ??? [252] 0.6% ------------------------------------------------------------------------------ ??? [215] 4.0% taylor [192] 4.1% for-loop [79] 92.0% [226] 9224(1.9%) 1102(0.2%) list-member? ...llects/racket/private/set.rkt:24:0 loop [238] 70.3% member [241] 17.8% ------------------------------------------------------------------------------ for-loop [131] 4.4% flag-set? [73] 4.6% debug7 [185] 4.6% ulp-difference [172] 6.0% ??? [218] 24.5% ??? [148] 26.9% ??? [215] 29.1% [227] 7288(1.5%) 812(0.2%) ??? ...racket/collects/racket/private/kw.rkt:761:9 ??? [239] 67.5% ??? [252] 21.4% ------------------------------------------------------------------------------ for-loop [217] 100.0% [228] 5752(1.2%) 5752(1.2%) for-loop ...cts/racket/private/set-types.rkt:178:5 ------------------------------------------------------------------------------ ulp-difference [172] 1.0% ??? [218] 12.3% ??? [148] 25.4% ??? [215] 61.2% [229] 5218(1.1%) 3322(0.7%) return/no-unsupplied ...ct/private/arr-i.rkt:533:0 filter [240] 36.3% ------------------------------------------------------------------------------ ??? [215] 100.0% [230] 1562(0.3%) 0(0.0%) mk-egraph ...ff-of-prods/src/core/egraph.rkt:123:0 expr->enode [243] 100.0% ------------------------------------------------------------------------------ extract-alt [59] 4.1% best-alt [221] 95.9% [231] 1226(0.3%) 0(0.0%) loop .../herbie/diff-of-prods/src/common.rkt:146:2 composed [242] 100.0% ------------------------------------------------------------------------------ ??? [215] 37.2% hash-has-key? [143] 62.8% [232] 886(0.2%) 886(0.2%) ??? ...ects/racket/contract/private/hash.rkt:245:7 ------------------------------------------------------------------------------ ??? [216] 100.0% [233] 224(0.0%) 174(0.0%) bfsub ...-lib/math/private/bigfloat/mpfr.rkt:819:4 ??? [245] 22.3% ------------------------------------------------------------------------------ ??? [215] 100.0% [234] 112(0.0%) 0(0.0%) *simplify-rules* ...ods/src/syntax/rules.rkt:497:0 for-loop [35] 100.0% ------------------------------------------------------------------------------ ??? [215] 100.0% [235] 50(0.0%) 0(0.0%) ??? ...-racket/utils/simple-result-arrow.rkt:60:15 ??? [245] 100.0% ------------------------------------------------------------------------------ ??? [225] 100.0% [236] 24694(5.2%) 14738(3.1%) for-loop ...acket/contract/private/list.rkt:743:12 ??? [247] 20.7% for-loop [145] 17.3% ??? [249] 2.4% ------------------------------------------------------------------------------ ??? [215] 0.4% ??? [225] 4.3% ??? [147] 33.5% for-loop [145] 61.9% [237] 24602(5.1%) 3024(0.6%) ??? ...cts/racket/contract/private/list.rkt:187:10 ??? [246] 59.1% for-loop [248] 13.2% ??? [147] 11.1% ??? [254] 4.3% ------------------------------------------------------------------------------ list-member? [226] 100.0% [238] 6480(1.4%) 6480(1.4%) loop (unknown source) ------------------------------------------------------------------------------ ??? [227] 100.0% [239] 4918(1.0%) 4584(1.0%) ??? ...s/racket/contract/private/arr-i.rkt:1233:27 ??? [250] 6.8% ------------------------------------------------------------------------------ match-e [80] 4.5% for-loop [94] 12.9% return/no-unsupplied [229] 82.6% [240] 2296(0.5%) 2296(0.5%) filter ...t/collects/racket/private/list.rkt:256:2 ------------------------------------------------------------------------------ list-member? [226] 100.0% [241] 1642(0.3%) 1642(0.3%) member (unknown source) ------------------------------------------------------------------------------ f6 [190] 22.6% loop [231] 77.4% [242] 1584(0.3%) 0(0.0%) composed ...ollects/racket/private/list.rkt:321:16 errors [161] 77.4% f6 [190] 22.6% ------------------------------------------------------------------------------ expr->enode [243] 40.6% mk-egraph [230] 59.4% [243] 1562(0.3%) 0(0.0%) expr->enode ...-of-prods/src/core/egraph.rkt:124:2 mk-enode! [103] 59.4% expr->enode [243] 40.6% ------------------------------------------------------------------------------ maybe-cons-kwd [186] 20.5% ??? [225] 79.5% [244] 488(0.1%) 100(0.0%) arrow-higher-order:lnp ...w-higher-order.rkt:597:7 ??? [251] 79.5% ------------------------------------------------------------------------------ ??? [235] 50.0% bfsub [233] 50.0% [245] 100(0.0%) 100(0.0%) ??? .../share/racket/collects/ffi/unsafe.rkt:861:4 ------------------------------------------------------------------------------ ??? [237] 100.0% [246] 14536(3.0%) 808(0.2%) ??? ...ects/racket/contract/private/list.rkt:686:7 ??? [252] 89.9% ??? [254] 4.5% ------------------------------------------------------------------------------ for-loop [236] 47.5% ??? [225] 52.5% [247] 10752(2.2%) 5966(1.2%) ??? ...private/unconstrained-domain-arrow.rkt:74:4 make-keyword-procedure [253] 44.5% ------------------------------------------------------------------------------ ??? [237] 100.0% [248] 3252(0.7%) 1194(0.2%) for-loop ...acket/contract/private/list.rkt:190:15 ??? [147] 63.3% ------------------------------------------------------------------------------ ??? [147] 17.6% for-loop [236] 38.2% ??? [140] 44.1% [249] 1554(0.3%) 912(0.2%) ??? ...ects/racket/contract/private/hash.rkt:222:6 check-hash/c [255] 41.3% ------------------------------------------------------------------------------ ??? [140] 45.4% ??? [239] 54.6% [250] 612(0.1%) 612(0.1%) ??? ...ects/racket/contract/private/prop.rkt:256:4 ------------------------------------------------------------------------------ arrow-higher-order:lnp [244] 100.0% [251] 388(0.1%) 388(0.1%) ??? ...et/contract/private/arity-checking.rkt:19:2 ------------------------------------------------------------------------------ ??? [225] 1.7% ??? [205] 5.0% ??? [139] 5.1% ??? [227] 8.0% ??? [147] 13.4% ??? [246] 66.8% [252] 19558(4.1%) 15872(3.3%) ??? ...ects/racket/contract/private/guts.rkt:644:8 dict? [256] 7.2% contract? [257] 6.7% ??? [139] 5.0% ------------------------------------------------------------------------------ ??? [247] 100.0% [253] 4786(1.0%) 4786(1.0%) make-keyword-procedure ...ket/private/kw.rkt:260:4 ------------------------------------------------------------------------------ ??? [204] 15.3% for-loop [145] 17.2% ??? [246] 26.0% ??? [237] 41.6% [254] 2530(0.5%) 1514(0.3%) ??? ...ects/racket/contract/private/prop.rkt:493:4 ??? [258] 40.2% ------------------------------------------------------------------------------ ??? [249] 100.0% [255] 642(0.1%) 0(0.0%) check-hash/c ...ket/contract/private/hash.rkt:83:0 flat-contract? [259] 100.0% ------------------------------------------------------------------------------ ??? [215] 6.7% ??? [252] 93.3% [256] 1502(0.3%) 1502(0.3%) dict? ...ollects/racket/private/generic.rkt:146:11 ------------------------------------------------------------------------------ ??? [252] 100.0% [257] 1302(0.3%) 1302(0.3%) contract? ...acket/contract/private/guts.rkt:109:0 ------------------------------------------------------------------------------ ??? [254] 100.0% [258] 1016(0.2%) 660(0.1%) ??? ...lects/racket/contract/private/orc.rkt:83:14 ??? [260] 35.0% ------------------------------------------------------------------------------ check-hash/c [255] 100.0% [259] 642(0.1%) 642(0.1%) flat-contract? .../contract/private/guts.rkt:111:0 ------------------------------------------------------------------------------ ??? [258] 100.0% [260] 356(0.1%) 356(0.1%) ??? ...ects/racket/contract/private/list.rkt:141:5 ------------------------------------------------------------------------------