Profiling results ----------------- Total cpu time observed: 106244ms (out of 107116ms) Number of samples taken: 303 (once every 351ms) (Hiding functions with self<1.0% and local<2.0%: 1 of 184 hidden) ========================================================================== Caller Idx Total Self Name+src Local% ms(pct) ms(pct) Callee ========================================================================== ??? [42] 100.0% [1] 93420(87.9%) 0(0.0%) profile-thunk16 ...t/pkgs/profile-lib/main.rkt:9:0 run [14] 100.0% -------------------------------------------------------------------------- ??? [42] 100.0% [2] 77212(72.7%) 0(0.0%) run-improve50 ...f-of-prods/src/mainloop.rkt:234:0 for-loop [15] 94.6% get-final-combination [17] 5.0% loop [51] 0.4% -------------------------------------------------------------------------- ->flonum [50] 100.0% [3] 6772(6.4%) 0(0.0%) loop .../diff-of-prods/src/core/simplify.rkt:215:2 pass [16] 100.0% -------------------------------------------------------------------------- ??? [147] 100.0% [4] 3904(3.7%) 0(0.0%) approximate9 ...-of-prods/src/core/taylor.rkt:12:0 loop [18] 81.5% f6 [83] 18.5% -------------------------------------------------------------------------- hash-ref! [151] 100.0% [5] 2820(2.7%) 0(0.0%) ??? ...ie/diff-of-prods/src/core/taylor.rkt:295:23 for-loop [19] 100.0% -------------------------------------------------------------------------- hash-ref! [151] 100.0% [6] 2466(2.3%) 0(0.0%) ??? ...ie/diff-of-prods/src/core/taylor.rkt:392:23 for-loop [20] 100.0% -------------------------------------------------------------------------- substitute-e [90] 23.9% match-e [87] 76.1% [7] 1364(1.3%) 0(0.0%) variable? ...-of-prods/src/syntax/syntax.rkt:567:0 ??? [37] 100.0% -------------------------------------------------------------------------- copying-mergesort [134] 100.0% [8] 1040(1.0%) 360(0.3%) jloop ...t/collects/racket/private/sort.rkt:121:23 ??? [143] 65.4% -------------------------------------------------------------------------- f6 [83] 100.0% [9] 362(0.3%) 0(0.0%) loop ...ie/diff-of-prods/src/core/taylor.rkt:262:2 hash-ref! [151] 100.0% -------------------------------------------------------------------------- f6 [83] 100.0% [10] 360(0.3%) 0(0.0%) taylor-invert ...f-prods/src/core/taylor.rkt:312:0 simplify [157] 100.0% -------------------------------------------------------------------------- hash-ref! [151] 100.0% [11] 360(0.3%) 0(0.0%) ??? ...ie/diff-of-prods/src/core/taylor.rkt:483:23 for-loop [22] 100.0% -------------------------------------------------------------------------- hash-ref! [151] 100.0% [12] 354(0.3%) 0(0.0%) ??? ...ie/diff-of-prods/src/core/taylor.rkt:285:26 for-loop [23] 100.0% -------------------------------------------------------------------------- f6 [83] 100.0% [13] 334(0.3%) 0(0.0%) loop ...bie/diff-of-prods/src/core/reduce.rkt:18:2 expression->type [21] 100.0% -------------------------------------------------------------------------- profile-thunk16 [1] 100.0% [14] 93420(87.9%) 0(0.0%) run ...share/racket/pkgs/profile-lib/main.rkt:39:2 ??? [42] 100.0% -------------------------------------------------------------------------- run-improve50 [2] 100.0% [15] 73020(68.7%) 0(0.0%) for-loop .../diff-of-prods/src/mainloop.rkt:249:10 run-iter! [24] 100.0% -------------------------------------------------------------------------- loop [3] 100.0% [16] 6772(6.4%) 0(0.0%) pass .../diff-of-prods/src/core/simplify.rkt:205:2 for-loop [25] 100.0% -------------------------------------------------------------------------- run-improve50 [2] 100.0% [17] 3852(3.6%) 0(0.0%) get-final-combination ...ds/src/mainloop.rkt:264:0 split-table [26] 100.0% -------------------------------------------------------------------------- approximate9 [4] 100.0% [18] 3182(3.0%) 0(0.0%) loop ...bie/diff-of-prods/src/core/taylor.rkt:86:4 ??? [147] 100.0% -------------------------------------------------------------------------- ??? [5] 100.0% [19] 2820(2.7%) 0(0.0%) for-loop ...ff-of-prods/src/core/taylor.rkt:298:27 hash-ref! [151] 94.1% simplify [157] 5.9% -------------------------------------------------------------------------- ??? [6] 100.0% [20] 2466(2.3%) 0(0.0%) for-loop ...ff-of-prods/src/core/taylor.rkt:396:33 for-loop [27] 100.0% -------------------------------------------------------------------------- loop [13] 48.1% rewriter [54] 51.9% [21] 694(0.7%) 0(0.0%) expression->type ...-prods/src/type-check.rkt:45:0 for-loop [28] 100.0% -------------------------------------------------------------------------- ??? [11] 100.0% [22] 360(0.3%) 0(0.0%) for-loop ...ff-of-prods/src/core/taylor.rkt:487:35 parse-loop12 [169] 100.0% -------------------------------------------------------------------------- ??? [12] 100.0% [23] 354(0.3%) 0(0.0%) for-loop ...ff-of-prods/src/core/taylor.rkt:285:52 hash-ref! [151] 100.0% -------------------------------------------------------------------------- for-loop [15] 100.0% [24] 73020(68.7%) 0(0.0%) run-iter! .../diff-of-prods/src/mainloop.rkt:215:0 simplify! [29] 75.7% finalize-iter! [30] 17.1% gen-series! [32] 5.3% gen-rewrites! [34] 1.0% localize-error [35] 0.9% -------------------------------------------------------------------------- pass [16] 100.0% [25] 6772(6.4%) 0(0.0%) for-loop ...-of-prods/src/core/simplify.rkt:208:29 argmin [31] 80.3% loop [33] 19.7% -------------------------------------------------------------------------- get-final-combination [17] 100.0% [26] 3852(3.6%) 0(0.0%) split-table ...ie/diff-of-prods/src/glue.rkt:162:0 f6 [83] 100.0% -------------------------------------------------------------------------- for-loop [20] 100.0% [27] 2466(2.3%) 0(0.0%) for-loop ...ff-of-prods/src/core/taylor.rkt:398:39 hash-ref! [151] 100.0% -------------------------------------------------------------------------- expression->type [21] 100.0% [28] 694(0.7%) 0(0.0%) for-loop .../diff-of-prods/src/type-check.rkt:52:5 f6 [83] 100.0% -------------------------------------------------------------------------- run-iter! [24] 100.0% [29] 55280(52.0%) 0(0.0%) simplify! .../diff-of-prods/src/mainloop.rkt:155:0 for-loop [36] 100.0% -------------------------------------------------------------------------- run-iter! [24] 100.0% [30] 12468(11.7%) 0(0.0%) finalize-iter! ...-of-prods/src/mainloop.rkt:169:0 ??? [37] 100.0% -------------------------------------------------------------------------- for-loop [25] 100.0% [31] 5440(5.1%) 0(0.0%) argmin ...re/racket/collects/racket/list.rkt:743:0 for-loop [38] 74.4% expression-cost [40] 25.6% -------------------------------------------------------------------------- run-iter! [24] 100.0% [32] 3904(3.7%) 0(0.0%) gen-series! ...iff-of-prods/src/mainloop.rkt:129:0 for-loop [39] 100.0% -------------------------------------------------------------------------- for-loop [25] 100.0% [33] 1332(1.3%) 0(0.0%) loop ...hare/racket/collects/racket/list.rkt:729:4 for-loop [38] 75.7% expression-cost [40] 24.3% -------------------------------------------------------------------------- run-iter! [24] 100.0% [34] 694(0.7%) 0(0.0%) gen-rewrites! ...f-of-prods/src/mainloop.rkt:142:0 for-loop [41] 100.0% -------------------------------------------------------------------------- run-iter! [24] 100.0% [35] 674(0.6%) 0(0.0%) localize-error ...prods/src/core/localize.rkt:47:0 hash-ref! [151] 100.0% -------------------------------------------------------------------------- simplify! [29] 100.0% [36] 55280(52.0%) 0(0.0%) for-loop ...e/diff-of-prods/src/mainloop.rkt:159:6 ??? [42] 99.3% debug7 [49] 0.7% -------------------------------------------------------------------------- f6 [83] 2.0% match-e [87] 3.9% substitute-e [90] 3.9% variable? [7] 7.7% get-sigs [125] 12.1% finalize-iter! [30] 70.4% [37] 17704(16.7%) 2054(1.9%) ??? ...contract/private/arrow-val-first.rkt:357:18 for-loop [43] 66.5% hash-has-key? [45] 18.0% atab-add-altns [47] 4.0% -------------------------------------------------------------------------- loop [33] 19.9% argmin [31] 80.1% [38] 5058(4.8%) 0(0.0%) for-loop ...e/diff-of-prods/src/programs.rkt:199:2 ->flonum [50] 79.3% ...prods/src/common.rkt:47:2 [133] 20.7% -------------------------------------------------------------------------- gen-series! [32] 100.0% [39] 3904(3.7%) 0(0.0%) for-loop ...e/diff-of-prods/src/mainloop.rkt:135:7 taylor-alt [44] 100.0% -------------------------------------------------------------------------- loop [33] 18.9% argmin [31] 81.1% [40] 1714(1.6%) 0(0.0%) expression-cost ...of-prods/src/programs.rkt:198:0 compile [46] 100.0% -------------------------------------------------------------------------- gen-rewrites! [34] 100.0% [41] 694(0.7%) 0(0.0%) for-loop .../diff-of-prods/src/mainloop.rkt:147:11 ??? [48] 100.0% -------------------------------------------------------------------------- for-loop [36] 17.8% run [14] 36.6% [42] 102572(96.5%) 0(0.0%) ??? ...lects/racket/private/more-scheme.rkt:261:28 profile-thunk16 [1] 36.6% run-improve50 [2] 28.7% ->flonum [50] 26.8% loop [51] 7.9% -------------------------------------------------------------------------- ??? [37] 100.0% [43] 11768(11.1%) 0(0.0%) for-loop ...f-of-prods/src/core/alt-table.rkt:51:2 atab-add-altn [52] 100.0% -------------------------------------------------------------------------- for-loop [39] 100.0% [44] 3904(3.7%) 0(0.0%) taylor-alt ...bie/diff-of-prods/src/glue.rkt:134:0 for-loop [53] 100.0% -------------------------------------------------------------------------- ??? [37] 100.0% [45] 3182(3.0%) 324(0.3%) hash-has-key? ...et/private/more-scheme.rkt:368:13 ??? [59] 78.4% ??? [55] 11.4% -------------------------------------------------------------------------- expression-cost [40] 100.0% [46] 1714(1.6%) 324(0.3%) compile ...ie/diff-of-prods/src/programs.rkt:175:0 hash-ref! [151] 81.1% -------------------------------------------------------------------------- ??? [37] 100.0% [47] 700(0.7%) 0(0.0%) atab-add-altns ...rods/src/core/alt-table.rkt:50:0 atab-add-altn [52] 100.0% -------------------------------------------------------------------------- for-loop [41] 100.0% [48] 694(0.7%) 0(0.0%) ??? ...rbie/diff-of-prods/src/alternative.rkt:88:0 rewriter [54] 100.0% -------------------------------------------------------------------------- for-loop [36] 100.0% [49] 360(0.3%) 0(0.0%) debug7 ...herbie/diff-of-prods/src/debug.rkt:102:0 return/no-unsupplied [165] 100.0% -------------------------------------------------------------------------- get-sigs [125] 1.8% for-loop [38] 1.8% ??? [147] 7.8% for-loop [57] 19.8% ->flonum [50] 25.4% ??? [42] 41.5% [50] 74748(70.4%) 4716(4.4%) ->flonum ...s/racket/private/norm-define.rkt:53:83 iterate-egraph!13 [56] 38.7% ->flonum [50] 25.4% for-loop [57] 19.8% loop [3] 3.6% ??? [59] 3.3% ??? [147] 2.7% ??? [161] 1.5% return/no-unsupplied [165] 0.4% mk-egraph [62] 0.3% -------------------------------------------------------------------------- run-improve50 [2] 2.1% ??? [42] 97.9% [51] 16548(15.6%) 0(0.0%) loop .../herbie/diff-of-prods/src/points.rkt:193:2 make-exacts* [68] 59.9% loop [60] 38.1% for-loop [65] 2.0% -------------------------------------------------------------------------- atab-add-altns [47] 5.6% for-loop [43] 94.4% [52] 12468(11.7%) 0(0.0%) atab-add-altn ...rods/src/core/alt-table.rkt:208:0 best-and-tied-at-points [58] 97.1% override-at-pnts [63] 2.9% -------------------------------------------------------------------------- taylor-alt [44] 100.0% [53] 3904(3.7%) 0(0.0%) for-loop ...erbie/diff-of-prods/src/glue.rkt:139:6 ??? [147] 100.0% -------------------------------------------------------------------------- ??? [48] 41.4% matcher [72] 58.6% [54] 694(0.7%) 0(0.0%) rewriter ...ff-of-prods/src/core/matcher.rkt:131:2 for-loop [61] 58.6% *rules* [64] 24.1% expression->type [21] 17.3% -------------------------------------------------------------------------- hash-has-key? [45] 100.0% [55] 364(0.3%) 364(0.3%) ??? ...ects/racket/contract/private/hash.rkt:245:7 -------------------------------------------------------------------------- ->flonum [50] 100.0% [56] 58602(55.2%) 0(0.0%) iterate-egraph!13 ...s/src/core/simplify.rkt:102:0 one-iter [66] 95.3% map-enodes [71] 4.7% -------------------------------------------------------------------------- ->flonum [50] 100.0% [57] 30592(28.8%) 0(0.0%) for-loop ...f-of-prods/src/core/simplify.rkt:63:12 ->flonum [50] 100.0% -------------------------------------------------------------------------- atab-add-altn [52] 100.0% [58] 12108(11.4%) 0(0.0%) best-and-tied-at-points ...ore/alt-table.rkt:122:0 errors [67] 97.3% for-loop [74] 2.7% -------------------------------------------------------------------------- hash-has-key? [45] 29.5% ->flonum [50] 70.5% [59] 8458(8.0%) 3438(3.2%) ??? ...ects/racket/contract/private/list.rkt:737:4 for-loop [69] 47.0% ??? [73] 8.0% ??? [152] 4.3% -------------------------------------------------------------------------- loop [51] 100.0% [60] 6310(5.9%) 0(0.0%) loop .../herbie/diff-of-prods/src/points.rkt:151:2 loop [70] 60.4% make-exacts* [68] 34.0% eval-prog [80] 5.6% -------------------------------------------------------------------------- rewriter [54] 100.0% [61] 694(0.7%) 0(0.0%) for-loop ...f-of-prods/src/core/matcher.rkt:134:10 matcher [72] 100.0% -------------------------------------------------------------------------- ->flonum [50] 100.0% [62] 660(0.6%) 0(0.0%) mk-egraph ...ff-of-prods/src/core/egraph.rkt:123:0 mk-enode! [94] 50.6% expr->enode [76] 49.4% -------------------------------------------------------------------------- atab-add-altn [52] 100.0% [63] 360(0.3%) 360(0.3%) override-at-pnts ...s/src/core/alt-table.rkt:145:0 -------------------------------------------------------------------------- rewriter [54] 100.0% [64] 334(0.3%) 334(0.3%) *rules* ...iff-of-prods/src/syntax/rules.rkt:493:0 -------------------------------------------------------------------------- loop [51] 100.0% [65] 332(0.3%) 0(0.0%) for-loop ...ie/diff-of-prods/src/points.rkt:200:24 for-loop [75] 100.0% -------------------------------------------------------------------------- iterate-egraph!13 [56] 100.0% [66] 55854(52.6%) 1048(1.0%) one-iter ...f-of-prods/src/core/simplify.rkt:113:0 loop [77] 64.9% for-loop [78] 29.0% apply-match [82] 4.3% -------------------------------------------------------------------------- loop [88] 2.6% option-on-expr [97] 5.4% best-and-tied-at-points [58] 92.0% [67] 12802(12.0%) 358(0.3%) errors ...erbie/diff-of-prods/src/points.rkt:218:0 for-loop [79] 84.0% eval-prog [80] 13.2% -------------------------------------------------------------------------- loop [60] 17.8% loop [51] 82.2% [68] 12052(11.3%) 0(0.0%) make-exacts* ...diff-of-prods/src/points.rkt:138:0 map [86] 56.6% loop [88] 40.6% eval-prog [80] 2.8% -------------------------------------------------------------------------- ??? [59] 100.0% [69] 3978(3.7%) 3678(3.5%) for-loop ...acket/contract/private/list.rkt:743:12 for-loop [137] 7.5% -------------------------------------------------------------------------- loop [60] 100.0% [70] 3812(3.6%) 0(0.0%) loop .../herbie/diff-of-prods/src/points.rkt:141:4 map [86] 100.0% -------------------------------------------------------------------------- iterate-egraph!13 [56] 100.0% [71] 2748(2.6%) 0(0.0%) map-enodes ...f-of-prods/src/core/egraph.rkt:139:0 loop [88] 87.0% for-loop [98] 13.0% -------------------------------------------------------------------------- matcher [72] 50.0% for-loop [61] 50.0% [72] 694(0.7%) 0(0.0%) matcher ...iff-of-prods/src/core/matcher.rkt:167:2 matcher [72] 50.0% rewriter [54] 50.0% -------------------------------------------------------------------------- ??? [59] 100.0% [73] 680(0.6%) 0(0.0%) ??? ...private/unconstrained-domain-arrow.rkt:74:4 make-keyword-procedure [81] 100.0% -------------------------------------------------------------------------- best-and-tied-at-points [58] 100.0% [74] 332(0.3%) 332(0.3%) for-loop ...of-prods/src/core/alt-table.rkt:124:16 -------------------------------------------------------------------------- for-loop [65] 100.0% [75] 332(0.3%) 0(0.0%) for-loop ...ie/diff-of-prods/src/points.rkt:201:26 ??? [147] 100.0% -------------------------------------------------------------------------- mk-egraph [62] 33.3% expr->enode [76] 66.7% [76] 326(0.3%) 0(0.0%) expr->enode ...-of-prods/src/core/egraph.rkt:124:2 expr->enode [76] 66.7% mk-enode! [94] 33.3% -------------------------------------------------------------------------- one-iter [66] 100.0% [77] 36242(34.1%) 0(0.0%) loop ...cket/collects/racket/private/map.rkt:52:19 apply-match [82] 100.0% -------------------------------------------------------------------------- for-loop [78] 46.8% one-iter [66] 53.2% [78] 16174(15.2%) 5184(4.9%) for-loop ...-of-prods/src/core/simplify.rkt:123:12 for-loop [78] 46.8% match-e [87] 34.0% -------------------------------------------------------------------------- errors [67] 100.0% [79] 10752(10.1%) 714(0.7%) for-loop ...bie/diff-of-prods/src/points.rkt:221:4 ??? [143] 77.4% ??? [147] 12.6% ulp-difference [84] 3.3% -------------------------------------------------------------------------- make-exacts* [68] 14.2% loop [60] 14.8% errors [67] 71.0% [80] 2382(2.2%) 334(0.3%) eval-prog .../diff-of-prods/src/programs.rkt:148:0 f6 [83] 57.0% hash-ref! [151] 29.0% -------------------------------------------------------------------------- ??? [73] 100.0% [81] 680(0.6%) 680(0.6%) make-keyword-procedure ...ket/private/kw.rkt:260:4 -------------------------------------------------------------------------- one-iter [66] 6.2% loop [77] 93.8% [82] 38632(36.4%) 660(0.6%) apply-match ...f-prods/src/core/simplify.rkt:130:2 for-loop [85] 94.0% match-e [87] 3.4% update-leader! [96] 0.8% -------------------------------------------------------------------------- loop [88] 1.3% approximate9 [4] 2.0% eval-prog [80] 3.3% hash-ref! [151] 3.6% for-loop [28] 4.7% parse-loop12 [169] 7.9% map [86] 8.5% simplify [157] 10.5% f6 [83] 18.9% split-table [26] 39.2% [83] 9142(8.6%) 716(0.7%) f6 ...et/collects/racket/match/compiler.rkt:507:40 loop [88] 31.4% map [86] 22.7% f6 [83] 18.9% option-on-expr [97] 7.8% ??? [37] 3.9% ??? [147] 3.3% gather-multiplicative-terms [92] 2.6% loop [9] 1.3% loop [13] 0.7% ...prods/src/common.rkt:47:2 [133] 0.7% taylor-invert [10] 0.7% -------------------------------------------------------------------------- for-loop [79] 100.0% [84] 358(0.3%) 358(0.3%) ulp-difference ...diff-of-prods/src/float.rkt:19:0 -------------------------------------------------------------------------- apply-match [82] 100.0% [85] 36320(34.2%) 0(0.0%) for-loop ...-of-prods/src/core/simplify.rkt:145:10 mk-enode! [94] 31.5% merge-egraph-nodes! [89] 24.2% substitute-e [90] 23.0% loop! [107] 20.5% list-member? [93] 0.8% -------------------------------------------------------------------------- gather-multiplicative-terms [92] 0.9% parse-loop12 [169] 1.6% f6 [83] 16.5% loop [70] 29.1% make-exacts* [68] 51.9% [86] 13122(12.4%) 0(0.0%) map ...acket/collects/racket/private/map.rkt:20:13 loop [88] 81.0% parse-loop12 [169] 8.0% f6 [83] 6.9% ??? [150] 2.5% gather-multiplicative-terms [92] 0.9% simplify* [174] 0.7% -------------------------------------------------------------------------- apply-match [82] 6.3% for-loop [95] 20.8% for-loop [78] 72.9% [87] 12320(11.6%) 7614(7.2%) match-e .../diff-of-prods/src/core/ematch.rkt:46:0 for-loop [91] 34.4% list-cartesian-product [100] 4.3% for-loop [95] 3.7% variable? [7] 2.8% ??? [37] 2.8% -------------------------------------------------------------------------- make-exacts* [68] 0.2% for-loop [91] 0.2% map-enodes [71] 0.5% option-on-expr [97] 0.6% map [86] 0.8% parse-loop12 [169] 1.7% ??? [162] 2.3% loop! [107] 7.4% f6 [83] 9.9% loop [88] 76.5% [88] 29846(28.1%) 986(0.9%) loop ...cket/collects/racket/private/map.rkt:25:19 loop [88] 76.5% option-on-expr [97] 9.9% loop! [107] 6.3% hash-ref! [151] 2.3% ??? [104] 1.1% ??? [143] 0.9% f6 [83] 0.6% errors [67] 0.6% for-loop [98] 0.5% foldl [102] 0.2% ??? [147] 0.0% -------------------------------------------------------------------------- merge-egraph-nodes! [89] 1.9% for-loop [101] 3.8% for-loop [85] 94.3% [89] 8776(8.3%) 658(0.6%) merge-egraph-nodes! ...s/src/core/egraph.rkt:152:0 update-leader! [96] 52.8% for-loop [99] 14.0% for-loop [101] 11.0% loop! [107] 9.1% enode-merge! [103] 3.8% merge-egraph-nodes! [89] 1.9% -------------------------------------------------------------------------- substitute-e [90] 7.4% for-loop [85] 92.6% [90] 8356(7.9%) 0(0.0%) substitute-e ...-of-prods/src/core/ematch.rkt:71:0 mk-enode! [94] 87.8% substitute-e [90] 7.4% ??? [37] 3.4% variable? [7] 1.3% -------------------------------------------------------------------------- match-e [87] 100.0% [91] 6382(6.0%) 630(0.6%) for-loop ...iff-of-prods/src/core/ematch.rkt:59:11 for-loop [95] 69.7% list-cartesian-product [100] 9.9% loop [88] 5.3% foldl [102] 5.2% -------------------------------------------------------------------------- gather-multiplicative-terms [92] 16.7% map [86] 16.7% f6 [83] 66.7% [92] 720(0.7%) 360(0.3%) gather-multiplicative-terms ...re/reduce.rkt:116:0 compose [112] 50.0% map [86] 16.7% gather-multiplicative-terms [92] 16.7% -------------------------------------------------------------------------- for-loop [85] 100.0% [93] 300(0.3%) 0(0.0%) list-member? ...llects/racket/private/set.rkt:24:0 loop [105] 100.0% -------------------------------------------------------------------------- expr->enode [76] 1.7% mk-egraph [62] 1.7% substitute-e [90] 37.7% for-loop [85] 58.9% [94] 19440(18.3%) 1692(1.6%) mk-enode! ...ff-of-prods/src/core/egraph.rkt:101:0 new-enode [106] 91.3% -------------------------------------------------------------------------- match-e [87] 16.8% for-loop [91] 83.2% [95] 5144(4.8%) 0(0.0%) for-loop ...iff-of-prods/src/core/ematch.rkt:65:37 match-e [87] 93.0% ??? [115] 7.0% -------------------------------------------------------------------------- apply-match [82] 6.3% merge-egraph-nodes! [89] 93.7% [96] 5124(4.8%) 368(0.3%) update-leader! ...-prods/src/core/egraph.rkt:217:0 for-loop [108] 92.8% -------------------------------------------------------------------------- f6 [83] 18.6% loop [88] 81.4% [97] 3852(3.6%) 0(0.0%) option-on-expr ...prods/src/core/regimes.rkt:103:0 sort-context-on-expr [109] 55.0% err-lsts->split-indices [113] 18.4% errors [67] 17.9% loop [88] 8.7% -------------------------------------------------------------------------- map-enodes [71] 13.0% loop [88] 87.0% [98] 2748(2.6%) 0(0.0%) for-loop ...f-of-prods/src/core/simplify.rkt:173:2 setfindf [110] 37.2% eval-const-expr [111] 36.8% compose [112] 13.0% curried [116] 13.0% -------------------------------------------------------------------------- merge-egraph-nodes! [89] 100.0% [99] 1392(1.3%) 688(0.6%) for-loop ...iff-of-prods/src/core/egraph.rkt:232:6 update-en-expr [145] 50.6% -------------------------------------------------------------------------- for-loop [91] 48.0% match-e [87] 52.0% [100] 1322(1.2%) 1322(1.2%) list-cartesian-product ...src/core/ematch.rkt:20:0 -------------------------------------------------------------------------- merge-egraph-nodes! [89] 100.0% [101] 1292(1.2%) 0(0.0%) for-loop ...ff-of-prods/src/core/egraph.rkt:200:10 merge-egraph-nodes! [89] 51.2% loop! [107] 48.8% -------------------------------------------------------------------------- for-loop [91] 49.9% loop [88] 50.1% [102] 670(0.6%) 0(0.0%) foldl ...et/collects/racket/private/list.rkt:229:4 merge2 [114] 100.0% -------------------------------------------------------------------------- merge-egraph-nodes! [89] 100.0% [103] 332(0.3%) 0(0.0%) enode-merge! ...-of-prods/src/core/enode.rkt:129:0 adopt-enode! [117] 100.0% -------------------------------------------------------------------------- loop [88] 100.0% [104] 332(0.3%) 0(0.0%) ??? ...ket/collects/racket/private/list.rkt:323:18 hash-ref! [151] 100.0% -------------------------------------------------------------------------- list-member? [93] 100.0% [105] 300(0.3%) 300(0.3%) loop (unknown source) -------------------------------------------------------------------------- mk-enode! [94] 100.0% [106] 17748(16.7%) 0(0.0%) new-enode ...diff-of-prods/src/core/enode.rkt:97:0 type-of-enode-expr [118] 100.0% -------------------------------------------------------------------------- for-loop [101] 3.5% merge-egraph-nodes! [89] 8.8% loop [88] 35.7% for-loop [85] 52.0% [107] 9038(8.5%) 1354(1.3%) loop! ...ie/diff-of-prods/src/core/enode.rkt:192:2 loop [88] 42.6% set [120] 22.7% custom-set-union [122] 21.7% update-en-expr [145] 5.5% -------------------------------------------------------------------------- update-leader! [96] 100.0% [108] 4756(4.5%) 0(0.0%) for-loop ...iff-of-prods/src/core/egraph.rkt:222:6 for-loop [119] 100.0% -------------------------------------------------------------------------- option-on-expr [97] 100.0% [109] 2118(2.0%) 0(0.0%) sort-context-on-expr ...prods/src/points.rkt:115:0 ??? [121] 100.0% -------------------------------------------------------------------------- for-loop [98] 100.0% [110] 1022(1.0%) 724(0.7%) setfindf ...bie/diff-of-prods/src/common.rkt:179:0 for-loop [124] 29.2% -------------------------------------------------------------------------- for-loop [98] 100.0% [111] 1010(1.0%) 686(0.6%) eval-const-expr ...of-prods/src/programs.rkt:166:0 ??? [150] 32.1% -------------------------------------------------------------------------- for-loop [98] 49.9% gather-multiplicative-terms [92] 50.1% [112] 718(0.7%) 718(0.7%) compose ...collects/racket/private/list.rkt:385:12 -------------------------------------------------------------------------- option-on-expr [97] 100.0% [113] 708(0.7%) 0(0.0%) err-lsts->split-indices .../core/regimes.rkt:222:0 add-splitpoint [123] 100.0% -------------------------------------------------------------------------- foldl [102] 100.0% [114] 670(0.6%) 670(0.6%) merge2 ...e/diff-of-prods/src/core/ematch.rkt:31:0 -------------------------------------------------------------------------- for-loop [95] 100.0% [115] 360(0.3%) 360(0.3%) ??? ...rbie/diff-of-prods/src/core/ematch.rkt:50:5 -------------------------------------------------------------------------- for-loop [98] 100.0% [116] 358(0.3%) 358(0.3%) curried ...cket/collects/racket/function.rkt:71:18 -------------------------------------------------------------------------- enode-merge! [103] 100.0% [117] 332(0.3%) 332(0.3%) adopt-enode! ...-of-prods/src/core/enode.rkt:105:0 -------------------------------------------------------------------------- new-enode [106] 100.0% [118] 17748(16.7%) 694(0.7%) type-of-enode-expr ...rods/src/core/enode.rkt:68:0 get-sigs [125] 96.1% -------------------------------------------------------------------------- for-loop [108] 100.0% [119] 4756(4.5%) 360(0.3%) for-loop ...iff-of-prods/src/core/egraph.rkt:223:8 hash-update! [126] 92.4% -------------------------------------------------------------------------- loop! [107] 100.0% [120] 4104(3.9%) 4104(3.9%) set ...collects/racket/private/set-types.rkt:981:0 -------------------------------------------------------------------------- sort-context-on-expr [109] 100.0% [121] 2118(2.0%) 0(0.0%) ??? ...cket/collects/racket/private/sort.rkt:403:3 generic-sort/key [127] 83.0% loop [140] 17.0% -------------------------------------------------------------------------- loop! [107] 100.0% [122] 1962(1.8%) 644(0.6%) custom-set-union ...et/private/set-types.rkt:168:0 for-loop [129] 33.8% for-loop [130] 33.3% -------------------------------------------------------------------------- err-lsts->split-indices [113] 100.0% [123] 708(0.7%) 0(0.0%) add-splitpoint ...prods/src/core/regimes.rkt:235:2 for-loop [128] 100.0% -------------------------------------------------------------------------- setfindf [110] 100.0% [124] 298(0.3%) 298(0.3%) for-loop ...bie/diff-of-prods/src/common.rkt:180:2 -------------------------------------------------------------------------- type-of-enode-expr [118] 100.0% [125] 17054(16.1%) 332(0.3%) get-sigs ...e/diff-of-prods/src/type-check.rkt:5:0 ??? [131] 56.1% ->flonum [50] 23.4% ??? [37] 12.5% ...prods/src/common.rkt:47:2 [133] 6.0% -------------------------------------------------------------------------- for-loop [119] 100.0% [126] 4396(4.1%) 0(0.0%) hash-update! ...ket/private/more-scheme.rkt:362:13 ??? [132] 100.0% -------------------------------------------------------------------------- ??? [121] 100.0% [127] 1758(1.7%) 0(0.0%) generic-sort/key .../racket/private/sort.rkt:185:2 copying-mergesort [134] 100.0% -------------------------------------------------------------------------- add-splitpoint [123] 100.0% [128] 708(0.7%) 346(0.3%) for-loop ...ff-of-prods/src/core/regimes.rkt:237:4 for-loop [136] 51.1% -------------------------------------------------------------------------- custom-set-union [122] 100.0% [129] 664(0.6%) 664(0.6%) for-loop ...cts/racket/private/set-types.rkt:152:2 -------------------------------------------------------------------------- custom-set-union [122] 100.0% [130] 654(0.6%) 0(0.0%) for-loop ...cts/racket/private/set-types.rkt:174:3 for-loop [135] 100.0% -------------------------------------------------------------------------- ??? [147] 3.4% get-sigs [125] 96.6% [131] 9906(9.3%) 332(0.3%) ??? ...ts/racket/contract/private/arr-i.rkt:804:10 for-loop [137] 45.5% ??? [139] 44.2% get/build-late-neg-projection [164] 7.0% -------------------------------------------------------------------------- hash-update! [126] 100.0% [132] 4396(4.1%) 0(0.0%) ??? ...ie/diff-of-prods/src/core/egraph.rkt:225:24 for-loop [138] 100.0% -------------------------------------------------------------------------- f6 [83] 13.9% get-sigs [125] 42.5% for-loop [38] 43.5% [133] 2402(2.3%) 1740(1.6%) ...prods/src/common.rkt:47:2 ...e/arr-i.rkt:906:19 ??? [141] 13.9% ??? [142] 13.7% -------------------------------------------------------------------------- generic-sort/key [127] 28.4% copying-mergesort [134] 71.6% [134] 1758(1.7%) 0(0.0%) copying-mergesort ...racket/private/sort.rkt:130:8 copying-mergesort [134] 71.6% jloop [8] 14.8% loop [140] 13.6% -------------------------------------------------------------------------- for-loop [130] 100.0% [135] 654(0.6%) 654(0.6%) for-loop ...cts/racket/private/set-types.rkt:178:5 -------------------------------------------------------------------------- for-loop [128] 100.0% [136] 362(0.3%) 362(0.3%) for-loop ...ff-of-prods/src/core/regimes.rkt:241:8 -------------------------------------------------------------------------- for-loop [69] 6.2% ??? [131] 93.8% [137] 4804(4.5%) 300(0.3%) for-loop ...racket/contract/private/hash.rkt:239:6 ??? [152] 93.8% -------------------------------------------------------------------------- ??? [132] 100.0% [138] 4396(4.1%) 3378(3.2%) for-loop ...ff-of-prods/src/core/egraph.rkt:226:26 update-en-expr [145] 23.2% -------------------------------------------------------------------------- ??? [131] 100.0% [139] 4376(4.1%) 332(0.3%) ??? ...ects/racket/contract/private/hash.rkt:217:4 ??? [144] 92.4% -------------------------------------------------------------------------- ??? [121] 33.4% copying-mergesort [134] 66.6% [140] 1078(1.0%) 0(0.0%) loop ...ket/collects/racket/private/sort.rkt:97:12 ??? [143] 100.0% -------------------------------------------------------------------------- ...prods/src/common.rkt:47:2 [133] 100.0% [141] 334(0.3%) 0(0.0%) ??? ...ects/racket/contract/private/list.rkt:342:4 ??? [152] 100.0% -------------------------------------------------------------------------- ...prods/src/common.rkt:47:2 [133] 100.0% [142] 328(0.3%) 0(0.0%) ??? ...s/racket/contract/private/arr-i.rkt:1268:39 return/no-unsupplied [165] 100.0% -------------------------------------------------------------------------- jloop [8] 2.7% loop [140] 4.3% for-loop [79] 33.5% loop [88] 59.4% [143] 24852(23.4%) 308(0.3%) ??? ...herbie/diff-of-prods/src/programs.rkt:154:4 ??? [146] 83.8% ??? [149] 10.8% ??? [147] 4.2% -------------------------------------------------------------------------- ??? [139] 100.0% [144] 4044(3.8%) 0(0.0%) ??? ...ects/racket/contract/private/list.rkt:169:2 ??? [148] 100.0% -------------------------------------------------------------------------- for-loop [99] 25.9% loop! [107] 36.6% for-loop [138] 37.5% [145] 2718(2.6%) 2718(2.6%) update-en-expr ...-prods/src/core/egraph.rkt:211:0 -------------------------------------------------------------------------- ??? [143] 100.0% [146] 20834(19.6%) 6628(6.2%) ??? ...acket/collects/racket/private/kw.rkt:444:14 ??? [150] 51.5% ??? [154] 16.7% -------------------------------------------------------------------------- for-loop [75] 3.7% loop [182] 3.8% loop [88] 4.3% ??? [143] 11.4% loop [18] 11.7% for-loop [79] 15.0% f6 [83] 15.0% for-loop [53] 15.7% ->flonum [50] 19.6% [147] 9078(8.5%) 334(0.3%) ??? ...tract/private/arrow-higher-order.rkt:342:33 ->flonum [50] 61.4% approximate9 [4] 15.7% hash-ref! [151] 11.7% ??? [152] 4.0% ??? [131] 3.7% -------------------------------------------------------------------------- ??? [144] 100.0% [148] 4044(3.8%) 0(0.0%) ??? ...ects/racket/contract/private/list.rkt:678:5 for-loop [153] 100.0% -------------------------------------------------------------------------- ??? [143] 100.0% [149] 2676(2.5%) 0(0.0%) ??? ...contract/private/../../private/kw.rkt:761:9 real->bigfloat [155] 100.0% -------------------------------------------------------------------------- eval-const-expr [111] 2.8% map [86] 2.9% ??? [146] 94.2% [150] 11382(10.7%) 7716(7.3%) ??? ...-racket/utils/simple-result-arrow.rkt:39:12 bfdiv [160] 19.3% bfexp [163] 12.9% -------------------------------------------------------------------------- for-loop [180] 1.0% for-loop [23] 1.4% simplify* [174] 2.0% ??? [104] 2.6% loop [88] 5.5% eval-prog [80] 5.5% loop [9] 5.7% for-loop [27] 7.4% localize-error [35] 8.1% compile [46] 9.7% ??? [158] 11.7% ??? [147] 11.7% ??? [162] 12.4% for-loop [19] 15.3% [151] 6298(5.9%) 1412(1.3%) hash-ref! ...racket/private/more-scheme.rkt:373:13 ??? [162] 21.8% simplify [157] 16.4% ??? [5] 16.3% ??? [158] 11.7% parse-loop12 [169] 8.1% ??? [6] 7.4% bigfloat-hash [166] 5.5% f6 [83] 2.6% ??? [12] 1.4% ??? [11] 1.0% -------------------------------------------------------------------------- ??? [141] 6.0% ??? [147] 6.5% ??? [59] 6.5% for-loop [137] 81.0% [152] 5560(5.2%) 1052(1.0%) ??? ...cts/racket/contract/private/list.rkt:187:10 ??? [156] 74.6% ??? [167] 6.5% -------------------------------------------------------------------------- ??? [148] 100.0% [153] 4044(3.8%) 730(0.7%) for-loop ...racket/contract/private/list.rkt:680:9 add-list-context [159] 64.2% get/build-late-neg-projection [164] 17.7% -------------------------------------------------------------------------- ??? [146] 100.0% [154] 3480(3.3%) 2074(2.0%) ??? .../diff-of-prods/src/syntax/syntax.rkt:122:17 ??? [161] 30.0% return/no-unsupplied [165] 10.4% -------------------------------------------------------------------------- ??? [149] 100.0% [155] 2676(2.5%) 2316(2.2%) real->bigfloat .../private/bigfloat/mpfr.rkt:451:0 ??? [170] 13.5% -------------------------------------------------------------------------- ??? [152] 100.0% [156] 4146(3.9%) 0(0.0%) ??? ...ects/racket/contract/private/list.rkt:686:7 ??? [168] 100.0% -------------------------------------------------------------------------- for-loop [19] 8.5% taylor-invert [10] 9.2% hash-ref! [151] 82.3% [157] 3904(3.7%) 0(0.0%) simplify ...diff-of-prods/src/core/reduce.rkt:16:0 f6 [83] 54.6% parse-loop12 [169] 27.7% debug-print [175] 9.2% simplify* [174] 8.5% -------------------------------------------------------------------------- hash-ref! [151] 100.0% [158] 3182(3.0%) 0(0.0%) ??? ...bie/diff-of-prods/src/core/taylor.rkt:44:15 hash-ref! [151] 100.0% -------------------------------------------------------------------------- for-loop [153] 100.0% [159] 2598(2.4%) 2598(2.4%) add-list-context ...ontract/private/list.rkt:752:0 -------------------------------------------------------------------------- ??? [150] 100.0% [160] 2198(2.1%) 1508(1.4%) bfdiv ...-lib/math/private/bigfloat/mpfr.rkt:819:4 ??? [170] 31.4% -------------------------------------------------------------------------- ??? [154] 49.1% ->flonum [50] 50.9% [161] 2128(2.0%) 1074(1.0%) ??? ...racket/collects/racket/private/kw.rkt:761:9 ??? [172] 49.5% -------------------------------------------------------------------------- hash-ref! [151] 100.0% [162] 2080(2.0%) 670(0.6%) ??? ...herbie/diff-of-prods/src/programs.rkt:183:5 hash-ref! [151] 54.8% loop [88] 33.2% -------------------------------------------------------------------------- ??? [150] 100.0% [163] 1468(1.4%) 1128(1.1%) bfexp ...-lib/math/private/bigfloat/mpfr.rkt:616:4 ??? [170] 23.2% -------------------------------------------------------------------------- ??? [173] 24.6% ??? [131] 24.6% for-loop [153] 50.8% [164] 1410(1.3%) 332(0.3%) get/build-late-neg-projection ...te/guts.rkt:691:0 ??? [171] 63.6% ??? [173] 24.6% -------------------------------------------------------------------------- ??? [142] 23.7% ->flonum [50] 24.0% debug7 [49] 26.0% ??? [154] 26.2% [165] 1382(1.3%) 1382(1.3%) return/no-unsupplied ...ct/private/arr-i.rkt:533:0 -------------------------------------------------------------------------- hash-ref! [151] 100.0% [166] 690(0.6%) 0(0.0%) bigfloat-hash ...h/private/bigfloat/mpfr.rkt:165:0 sig+exp->bigfloat [176] 51.0% bfcanonicalize [177] 49.0% -------------------------------------------------------------------------- ??? [152] 100.0% [167] 362(0.3%) 362(0.3%) ??? ...ects/racket/contract/private/prop.rkt:493:4 -------------------------------------------------------------------------- ??? [156] 100.0% [168] 4146(3.9%) 4146(3.9%) ??? ...ects/racket/contract/private/guts.rkt:644:8 -------------------------------------------------------------------------- for-loop [22] 6.3% parse-loop12 [169] 10.6% simplify [157] 20.2% hash-ref! [151] 23.8% map [86] 39.1% [169] 2836(2.7%) 1082(1.0%) parse-loop12 ...s/racket/match/compiler.rkt:418:15 loop [88] 24.4% map [86] 19.0% loop [182] 12.1% parse-loop12 [169] 10.6% f6 [83] 7.4% for-loop [180] 6.3% -------------------------------------------------------------------------- bfexp [163] 24.5% real->bigfloat [155] 25.9% bfdiv [160] 49.6% [170] 1390(1.3%) 1390(1.3%) ??? .../share/racket/collects/ffi/unsafe.rkt:861:4 -------------------------------------------------------------------------- get/build-late-neg-projection [164]100.0% [171] 1078(1.0%) 0(0.0%) ??? ...cts/racket/contract/private/prop.rkt:314:12 build-compound-type-name [178] 100.0% -------------------------------------------------------------------------- ??? [161] 100.0% [172] 1054(1.0%) 1054(1.0%) ??? ...s/racket/contract/private/arr-i.rkt:1233:27 -------------------------------------------------------------------------- get/build-late-neg-projection [164]100.0% [173] 694(0.7%) 0(0.0%) ??? ...ects/racket/contract/private/hash.rkt:211:2 get/build-late-neg-projection [164]100.0% -------------------------------------------------------------------------- simplify [157] 48.0% map [86] 52.0% [174] 692(0.7%) 0(0.0%) simplify* ...iff-of-prods/src/core/reduce.rkt:31:0 hash-ref! [151] 100.0% -------------------------------------------------------------------------- simplify [157] 100.0% [175] 360(0.3%) 0(0.0%) debug-print ...e/diff-of-prods/src/debug.rkt:107:0 for-loop [179] 100.0% -------------------------------------------------------------------------- bigfloat-hash [166] 100.0% [176] 352(0.3%) 0(0.0%) sig+exp->bigfloat ...ivate/bigfloat/mpfr.rkt:385:0 integer->mpz [181] 100.0% -------------------------------------------------------------------------- bigfloat-hash [166] 100.0% [177] 338(0.3%) 338(0.3%) bfcanonicalize .../private/bigfloat/mpfr.rkt:155:0 -------------------------------------------------------------------------- ??? [171] 100.0% [178] 1078(1.0%) 358(0.3%) build-compound-type-name ...private/guts.rkt:448:0 contract-struct-name [183] 66.8% -------------------------------------------------------------------------- debug-print [175] 100.0% [179] 360(0.3%) 360(0.3%) for-loop ...rbie/diff-of-prods/src/debug.rkt:113:2 -------------------------------------------------------------------------- parse-loop12 [169] 100.0% [180] 360(0.3%) 0(0.0%) for-loop ...ff-of-prods/src/core/taylor.rkt:490:59 hash-ref! [151] 100.0% -------------------------------------------------------------------------- sig+exp->bigfloat [176] 100.0% [181] 352(0.3%) 352(0.3%) integer->mpz ...math/private/bigfloat/gmp.rkt:87:0 -------------------------------------------------------------------------- parse-loop12 [169] 1.4% loop [182] 98.6% [182] 342(0.3%) 0(0.0%) loop ...cket/collects/racket/private/map.rkt:36:19 loop [182] 98.6% ??? [147] 1.4% -------------------------------------------------------------------------- build-compound-type-name [178] 100.0% [183] 720(0.7%) 720(0.7%) contract-struct-name ...ract/private/prop.rkt:89:0 --------------------------------------------------------------------------