Profiling results ----------------- Total cpu time observed: 172676ms (out of 173816ms) Number of samples taken: 530 (once every 326ms) (Hiding functions with self<1.0% and local<2.0%: 7 of 212 hidden) ================================================================================== Caller Idx Total Self Name+src Local% ms(pct) ms(pct) Callee ================================================================================== ??? [15] 100.0% [1] 172676(100.0%) 0(0.0%) profile-thunk16 ...e/pkgs/profile-lib/main.rkt:9:0 run [7] 100.0% ---------------------------------------------------------------------------------- ??? [95] 100.0% [2] 3134(1.8%) 0(0.0%) approximate9 ...ie/master/src/core/taylor.rkt:12:0 loop [8] 90.4% for-loop [13] 9.6% ---------------------------------------------------------------------------------- loop [193] 19.5% for-loop [195] 80.5% [3] 1542(0.9%) 0(0.0%) syntax-e (unknown source) syntax-e/no-taint [9] 100.0% ---------------------------------------------------------------------------------- matcher [72] 100.0% [4] 972(0.6%) 0(0.0%) ??? ...s/herbie/master/src/core/matcher.rkt:130:11 for-loop [10] 100.0% ---------------------------------------------------------------------------------- for-loop [195] 100.0% [5] 906(0.5%) 0(0.0%) expand-implicit (unknown source) resolve+shift28 [11] 66.9% binding-lookup52 [12] 33.1% ---------------------------------------------------------------------------------- hash-ref! [112] 100.0% [6] 298(0.2%) 0(0.0%) ??? ...es/herbie/master/src/core/taylor.rkt:301:23 for-loop [14] 100.0% ---------------------------------------------------------------------------------- profile-thunk16 [1] 100.0% [7] 172676(100.0%) 0(0.0%) run ...et-7.2/share/pkgs/profile-lib/main.rkt:39:2 ??? [15] 100.0% ---------------------------------------------------------------------------------- approximate9 [2] 100.0% [8] 2834(1.6%) 0(0.0%) loop ...ies/herbie/master/src/core/taylor.rkt:87:4 ??? [95] 88.1% iterate-diagonal [17] 11.9% ---------------------------------------------------------------------------------- expand-id-application-form17 [198] 16.3% syntax-e [3] 83.7% [9] 1842(1.1%) 0(0.0%) syntax-e/no-taint (unknown source) loop [193] 100.0% ---------------------------------------------------------------------------------- ??? [4] 100.0% [10] 972(0.6%) 0(0.0%) for-loop ...bie/master/src/core/matcher.rkt:132:15 matcher [72] 100.0% ---------------------------------------------------------------------------------- expand-implicit [5] 100.0% [11] 606(0.4%) 0(0.0%) resolve+shift28 (unknown source) fallback-loop [16] 100.0% ---------------------------------------------------------------------------------- expand-implicit [5] 100.0% [12] 300(0.2%) 300(0.2%) binding-lookup52 (unknown source) ---------------------------------------------------------------------------------- approximate9 [2] 100.0% [13] 300(0.2%) 0(0.0%) for-loop ...erbie/master/src/core/taylor.rkt:30:18 taylor [18] 100.0% ---------------------------------------------------------------------------------- ??? [6] 100.0% [14] 298(0.2%) 0(0.0%) for-loop ...rbie/master/src/core/taylor.rkt:304:27 hash-ref! [112] 100.0% ---------------------------------------------------------------------------------- for-loop [80] 0.2% for-loop [166] 0.6% run [7] 49.6% [15] 172676(100.0%) 888(0.5%) ??? ...lects/racket/private/more-scheme.rkt:261:28 profile-thunk16 [1] 49.6% run-improve47 [19] 38.4% prepare-points-intervals [25] 10.1% oracle-error [20] 0.4% ??? [76] 0.4% get-final-combination [21] 0.3% eval-errors [22] 0.2% errors [164] 0.2% eval-const-expr [154] 0.2% ??? [92] 0.1% ---------------------------------------------------------------------------------- resolve+shift28 [11] 100.0% [16] 606(0.4%) 0(0.0%) fallback-loop (unknown source) for-loop [195] 100.0% ---------------------------------------------------------------------------------- loop [8] 100.0% [17] 336(0.2%) 0(0.0%) iterate-diagonal ...ster/src/core/taylor.rkt:154:0 hash-ref! [112] 100.0% ---------------------------------------------------------------------------------- taylor [18] 50.0% for-loop [13] 50.0% [18] 300(0.2%) 0(0.0%) taylor .../herbie/master/src/core/taylor.rkt:170:0 taylor [18] 50.0% taylor-invert [23] 50.0% ---------------------------------------------------------------------------------- ??? [15] 100.0% [19] 133500(77.3%) 0(0.0%) run-improve47 ...bie/master/src/mainloop.rkt:345:0 for-loop [24] 74.4% simplify! [32] 25.1% prepare-points-intervals [25] 0.4% ---------------------------------------------------------------------------------- ??? [15] 100.0% [20] 1516(0.9%) 0(0.0%) oracle-error ...herbie/master/src/points.rkt:188:0 for-loop [26] 100.0% ---------------------------------------------------------------------------------- ??? [15] 100.0% [21] 948(0.5%) 0(0.0%) get-final-combination ...er/src/mainloop.rkt:369:0 infer-splitpoints [27] 100.0% ---------------------------------------------------------------------------------- ??? [15] 100.0% [22] 656(0.4%) 0(0.0%) eval-errors .../herbie/master/src/points.rkt:179:0 for-loop [28] 100.0% ---------------------------------------------------------------------------------- taylor [18] 100.0% [23] 300(0.2%) 0(0.0%) taylor-invert .../master/src/core/taylor.rkt:318:0 simplify [126] 100.0% ---------------------------------------------------------------------------------- run-improve47 [19] 100.0% [24] 99354(57.5%) 0(0.0%) for-loop ...s/herbie/master/src/mainloop.rkt:363:4 run-iter! [29] 100.0% ---------------------------------------------------------------------------------- run-improve47 [19] 1.7% ??? [15] 98.3% [25] 35336(20.5%) 0(0.0%) prepare-points-intervals ...r/src/points.rkt:110:0 loop [30] 100.0% ---------------------------------------------------------------------------------- oracle-error [20] 100.0% [26] 1516(0.9%) 0(0.0%) for-loop ...ies/herbie/master/src/points.rkt:189:2 loop [162] 79.8% map [155] 20.2% ---------------------------------------------------------------------------------- get-final-combination [21] 100.0% [27] 948(0.5%) 0(0.0%) infer-splitpoints ...ter/src/core/regimes.rkt:34:0 for-loop [31] 100.0% ---------------------------------------------------------------------------------- eval-errors [22] 100.0% [28] 656(0.4%) 332(0.2%) for-loop ...ies/herbie/master/src/points.rkt:181:2 ??? [76] 49.4% ---------------------------------------------------------------------------------- for-loop [24] 100.0% [29] 99354(57.5%) 0(0.0%) run-iter! .../herbie/master/src/mainloop.rkt:326:0 simplify! [32] 87.9% finalize-iter! [34] 6.1% gen-series! [35] 3.5% gen-rewrites! [36] 1.3% localize! [39] 0.9% choose-best-alt! [40] 0.3% ---------------------------------------------------------------------------------- prepare-points-intervals [25] 100.0% [30] 35336(20.5%) 300(0.2%) loop ...ghtlies/herbie/master/src/points.rkt:123:4 loop [33] 95.7% ??? [37] 3.4% ---------------------------------------------------------------------------------- infer-splitpoints [27] 100.0% [31] 948(0.5%) 0(0.0%) for-loop ...erbie/master/src/core/regimes.rkt:47:6 option-on-expr [38] 100.0% ---------------------------------------------------------------------------------- run-improve47 [19] 27.8% run-iter! [29] 72.2% [32] 120878(70.0%) 0(0.0%) simplify! .../herbie/master/src/mainloop.rkt:223:0 ??? [41] 100.0% ---------------------------------------------------------------------------------- loop [30] 100.0% [33] 33828(19.6%) 636(0.4%) loop ...ightlies/herbie/master/src/points.rkt:81:2 ??? [76] 94.2% ??? [106] 2.1% hash-update! [137] 1.8% ---------------------------------------------------------------------------------- run-iter! [29] 100.0% [34] 6036(3.5%) 0(0.0%) finalize-iter! ...ie/master/src/mainloop.rkt:277:0 ??? [106] 100.0% ---------------------------------------------------------------------------------- run-iter! [29] 100.0% [35] 3434(2.0%) 0(0.0%) gen-series! ...erbie/master/src/mainloop.rkt:159:0 for-loop [42] 100.0% ---------------------------------------------------------------------------------- run-iter! [29] 100.0% [36] 1330(0.8%) 0(0.0%) gen-rewrites! ...bie/master/src/mainloop.rkt:182:0 for-loop [43] 73.1% group-by61 [46] 26.9% ---------------------------------------------------------------------------------- loop [30] 100.0% [37] 1208(0.7%) 0(0.0%) ??? ...ightlies/herbie/master/src/points.rkt:106:2 ??? [95] 100.0% ---------------------------------------------------------------------------------- for-loop [31] 100.0% [38] 948(0.5%) 0(0.0%) option-on-expr ...aster/src/core/regimes.rkt:126:0 sort-context-on-expr [45] 68.6% for-loop [47] 31.4% ---------------------------------------------------------------------------------- run-iter! [29] 100.0% [39] 940(0.5%) 0(0.0%) localize! .../herbie/master/src/mainloop.rkt:126:0 localize-error [44] 100.0% ---------------------------------------------------------------------------------- run-iter! [29] 100.0% [40] 298(0.2%) 0(0.0%) choose-best-alt! .../master/src/mainloop.rkt:116:0 ??? [106] 100.0% ---------------------------------------------------------------------------------- simplify! [32] 100.0% [41] 120878(70.0%) 0(0.0%) ??? ...es/herbie/master/src/core/simplify.rkt:26:0 for-loop [48] 97.0% one-iter [54] 1.7% loop [56] 1.3% ---------------------------------------------------------------------------------- gen-series! [35] 100.0% [42] 3434(2.0%) 0(0.0%) for-loop ...s/herbie/master/src/mainloop.rkt:166:7 taylor-alt [49] 100.0% ---------------------------------------------------------------------------------- gen-rewrites! [36] 100.0% [43] 972(0.6%) 0(0.0%) for-loop .../herbie/master/src/mainloop.rkt:190:11 rewrite-expression-head20 [50] 100.0% ---------------------------------------------------------------------------------- localize! [39] 100.0% [44] 940(0.5%) 0(0.0%) localize-error ...aster/src/core/localize.rkt:66:0 hash-ref! [112] 100.0% ---------------------------------------------------------------------------------- option-on-expr [38] 100.0% [45] 650(0.4%) 0(0.0%) sort-context-on-expr ...src/core/regimes.rkt:119:0 for-loop [52] 50.2% ??? [53] 49.8% ---------------------------------------------------------------------------------- gen-rewrites! [36] 100.0% [46] 358(0.2%) 0(0.0%) group-by61 ...t-7.2/collects/racket/list.rkt:771:0 for-loop [51] 100.0% ---------------------------------------------------------------------------------- option-on-expr [38] 100.0% [47] 298(0.2%) 0(0.0%) for-loop ...rbie/master/src/core/regimes.rkt:136:4 errors [164] 100.0% ---------------------------------------------------------------------------------- ??? [41] 100.0% [48] 117254(67.9%) 0(0.0%) for-loop ...rbie/master/src/core/simplify.rkt:35:2 one-iter [54] 99.3% loop [56] 0.7% ---------------------------------------------------------------------------------- for-loop [42] 100.0% [49] 3434(2.0%) 0(0.0%) taylor-alt ...herbie/master/src/mainloop.rkt:145:0 for-loop [55] 100.0% ---------------------------------------------------------------------------------- for-loop [43] 100.0% [50] 972(0.6%) 0(0.0%) rewrite-expression-head20 ...core/matcher.rkt:87:0 rewriter [57] 100.0% ---------------------------------------------------------------------------------- group-by61 [46] 100.0% [51] 358(0.2%) 0(0.0%) for-loop ...ket-7.2/collects/racket/list.rkt:805:4 hash-update [58] 100.0% ---------------------------------------------------------------------------------- sort-context-on-expr [45] 100.0% [52] 326(0.2%) 326(0.2%) for-loop ...bie/master/src/core/regimes.rkt:120:19 ---------------------------------------------------------------------------------- sort-context-on-expr [45] 100.0% [53] 324(0.2%) 0(0.0%) ??? ...-7.2/collects/racket/private/sort.rkt:369:3 generic-sort/key [59] 100.0% ---------------------------------------------------------------------------------- ??? [41] 1.8% for-loop [48] 98.2% [54] 118490(68.6%) 0(0.0%) one-iter ...rbie/master/src/core/simplify.rkt:72:0 for-loop [60] 70.1% find-matches [61] 27.4% for-loop [63] 1.3% for-loop [64] 1.3% ---------------------------------------------------------------------------------- taylor-alt [49] 100.0% [55] 3434(2.0%) 0(0.0%) for-loop ...s/herbie/master/src/mainloop.rkt:151:6 ??? [95] 100.0% ---------------------------------------------------------------------------------- for-loop [48] 36.6% ??? [41] 63.4% [56] 2388(1.4%) 0(0.0%) loop ...herbie/master/src/core/extraction.rkt:25:2 for-loop [62] 100.0% ---------------------------------------------------------------------------------- rewrite-expression-head20 [50] 44.3% matcher [72] 55.7% [57] 972(0.6%) 312(0.2%) rewriter ...erbie/master/src/core/matcher.rkt:90:2 for-loop [65] 72.5% *rules* [66] 11.5% ---------------------------------------------------------------------------------- for-loop [51] 100.0% [58] 358(0.2%) 358(0.2%) hash-update ...acket/private/more-scheme.rkt:358:4 ---------------------------------------------------------------------------------- ??? [53] 100.0% [59] 324(0.2%) 0(0.0%) generic-sort/key .../racket/private/sort.rkt:156:2 copying-mergesort [67] 100.0% ---------------------------------------------------------------------------------- one-iter [54] 100.0% [60] 83080(48.1%) 0(0.0%) for-loop ...rbie/master/src/core/simplify.rkt:74:2 for-loop [68] 100.0% ---------------------------------------------------------------------------------- one-iter [54] 100.0% [61] 32418(18.8%) 0(0.0%) find-matches .../master/src/core/simplify.rkt:62:0 for-loop [69] 100.0% ---------------------------------------------------------------------------------- loop [56] 100.0% [62] 2388(1.4%) 324(0.2%) for-loop ...ie/master/src/core/extraction.rkt:29:4 for-loop [70] 86.4% ---------------------------------------------------------------------------------- one-iter [54] 100.0% [63] 1504(0.9%) 0(0.0%) for-loop ...rbie/master/src/core/simplify.rkt:81:2 set-precompute! [71] 100.0% ---------------------------------------------------------------------------------- one-iter [54] 100.0% [64] 1488(0.9%) 0(0.0%) for-loop ...rbie/master/src/core/simplify.rkt:84:2 update-leader! [94] 80.0% reduce-to-single! [75] 20.0% ---------------------------------------------------------------------------------- rewriter [57] 100.0% [65] 972(0.6%) 0(0.0%) for-loop ...erbie/master/src/core/matcher.rkt:92:4 matcher [72] 100.0% ---------------------------------------------------------------------------------- rewriter [57] 100.0% [66] 334(0.2%) 0(0.0%) *rules* ...erbie/master/src/syntax/rules.rkt:666:0 for-loop [73] 100.0% ---------------------------------------------------------------------------------- copying-mergesort [67] 50.0% generic-sort/key [59] 50.0% [67] 324(0.2%) 0(0.0%) copying-mergesort ...racket/private/sort.rkt:129:8 copying-mergesort [67] 50.0% loop [74] 50.0% ---------------------------------------------------------------------------------- for-loop [60] 100.0% [68] 83080(48.1%) 308(0.2%) for-loop ...rbie/master/src/core/simplify.rkt:77:4 merge-egraph-nodes! [84] 57.6% dedup-children! [104] 27.9% pattern-substitute [78] 9.9% mk-enode-rec! [79] 4.2% ---------------------------------------------------------------------------------- for-loop [69] 50.0% find-matches [61] 50.0% [69] 32418(18.8%) 298(0.2%) for-loop ...rbie/master/src/core/simplify.rkt:64:8 for-loop [69] 50.0% match-e [77] 49.1% ??? [115] 0.5% ---------------------------------------------------------------------------------- for-loop [62] 100.0% [70] 2064(1.2%) 1190(0.7%) for-loop ...e/master/src/core/extraction.rkt:37:16 for-loop [81] 42.3% ---------------------------------------------------------------------------------- for-loop [63] 100.0% [71] 1504(0.9%) 0(0.0%) set-precompute! ...ster/src/core/simplify.rkt:88:0 for-loop [80] 100.0% ---------------------------------------------------------------------------------- for-loop [10] 44.4% for-loop [65] 55.6% [72] 972(0.6%) 0(0.0%) matcher ...erbie/master/src/core/matcher.rkt:118:2 ??? [4] 44.4% rewriter [57] 44.4% variable? [87] 11.2% ---------------------------------------------------------------------------------- *rules* [66] 100.0% [73] 334(0.2%) 0(0.0%) for-loop ...lies/herbie/master/src/common.rkt:62:9 flag-set? [82] 100.0% ---------------------------------------------------------------------------------- copying-mergesort [67] 100.0% [74] 324(0.2%) 0(0.0%) loop ...7.2/collects/racket/private/sort.rkt:96:12 ??? [76] 100.0% ---------------------------------------------------------------------------------- for-loop [64] 100.0% [75] 298(0.2%) 0(0.0%) reduce-to-single! ...ter/src/core/egraph.rkt:320:0 filter-loop! [83] 100.0% ---------------------------------------------------------------------------------- loop [74] 0.9% for-loop [28] 0.9% loop [162] 1.7% ??? [171] 2.5% ??? [15] 6.0% loop [33] 88.1% [76] 36198(21.0%) 908(0.5%) ??? ...htlies/herbie/master/src/programs.rkt:115:2 ??? [85] 88.0% ??? [95] 8.7% ??? [170] 0.8% ---------------------------------------------------------------------------------- for-loop [93] 29.6% for-loop [69] 70.4% [77] 31812(18.4%) 2446(1.4%) match-e .../herbie/master/src/core/ematch.rkt:39:0 for-loop [86] 80.5% constant? [139] 6.9% variable? [87] 3.2% ??? [106] 2.5% ---------------------------------------------------------------------------------- pattern-substitute [78] 28.8% for-loop [68] 71.2% [78] 8248(4.8%) 3026(1.8%) pattern-substitute ...er/src/core/matcher.rkt:46:0 pattern-substitute [78] 28.8% ??? [170] 10.7% return/no-unsupplied [175] 9.9% do-curry [98] 7.5% constant? [139] 5.8% variable? [87] 4.2% ??? [106] 2.4% ??? [130] 1.8% ---------------------------------------------------------------------------------- loop [162] 31.5% for-loop [68] 68.5% [79] 3458(2.0%) 632(0.4%) mk-enode-rec! .../master/src/core/egraph.rkt:117:0 loop [162] 44.3% hash-has-key? [88] 32.2% new-enode [89] 14.3% ---------------------------------------------------------------------------------- set-precompute! [71] 100.0% [80] 1504(0.9%) 0(0.0%) for-loop ...rbie/master/src/core/simplify.rkt:90:2 ??? [15] 59.8% merge-egraph-nodes! [84] 20.2% setfindf [90] 19.9% ---------------------------------------------------------------------------------- for-loop [70] 100.0% [81] 874(0.5%) 874(0.5%) for-loop ...e/master/src/core/extraction.rkt:41:23 ---------------------------------------------------------------------------------- for-loop [73] 100.0% [82] 334(0.2%) 334(0.2%) flag-set? ...ies/herbie/master/src/config.rkt:28:0 ---------------------------------------------------------------------------------- reduce-to-single! [75] 100.0% [83] 298(0.2%) 0(0.0%) filter-loop! ...ie/master/src/core/enode.rkt:145:2 set [107] 100.0% ---------------------------------------------------------------------------------- for-loop [80] 0.6% for-loop [96] 3.2% merge-egraph-nodes! [84] 3.6% for-loop [68] 92.6% [84] 48180(27.9%) 634(0.4%) merge-egraph-nodes! ...r/src/core/egraph.rkt:145:0 loop! [91] 56.1% update-leader! [94] 32.0% for-loop [96] 4.4% merge-egraph-nodes! [84] 3.6% dedup-children! [104] 2.0% enode-merge! [103] 0.6% ---------------------------------------------------------------------------------- eval-const-expr [154] 1.0% ??? [76] 99.0% [85] 32186(18.6%) 2002(1.2%) ??? ...t-7.2/collects/racket/private/kw.rkt:594:14 ??? [92] 72.2% ??? [95] 15.7% ??? [169] 5.9% ---------------------------------------------------------------------------------- match-e [77] 100.0% [86] 28778(16.7%) 10344(6.0%) for-loop ...erbie/master/src/core/ematch.rkt:52:11 for-loop [93] 46.5% procedure-reduce-keyword-arity-mask [97] 9.0% do-curry [98] 6.5% loop [162] 3.3% foldr [99] 3.0% cartesian-product [101] 2.1% cp-2 [118] 1.0% ---------------------------------------------------------------------------------- matcher [72] 8.2% pattern-substitute [78] 22.5% match-e [77] 69.3% [87] 3972(2.3%) 624(0.4%) variable? ...ie/master/src/syntax/syntax.rkt:729:0 ??? [106] 45.4% value? [152] 38.9% ---------------------------------------------------------------------------------- mk-enode-rec! [79] 100.0% [88] 1584(0.9%) 1584(0.9%) hash-has-key? ...ket/private/more-scheme.rkt:371:2 ---------------------------------------------------------------------------------- mk-enode-rec! [79] 100.0% [89] 658(0.4%) 0(0.0%) new-enode ...erbie/master/src/core/enode.rkt:101:0 type-of-enode-expr [100] 100.0% ---------------------------------------------------------------------------------- for-loop [80] 100.0% [90] 300(0.2%) 0(0.0%) setfindf ...ies/herbie/master/src/common.rkt:130:0 for-loop [102] 100.0% ---------------------------------------------------------------------------------- loop [162] 32.1% merge-egraph-nodes! [84] 67.9% [91] 28752(16.7%) 8372(4.8%) loop! ...es/herbie/master/src/core/enode.rkt:194:2 loop [162] 34.4% custom-set-union [123] 30.0% set [107] 14.2% update-en-expr [167] 3.8% ---------------------------------------------------------------------------------- ??? [15] 1.5% ??? [85] 98.5% [92] 23584(13.7%) 3242(1.9%) ??? ...tract/private/arrow-higher-order.rkt:364:33 ival-acos [108] 33.6% ival-sub [109] 31.9% ival-div [111] 19.2% ??? [119] 1.5% ---------------------------------------------------------------------------------- for-loop [86] 100.0% [93] 17794(10.3%) 0(0.0%) for-loop ...erbie/master/src/core/ematch.rkt:58:37 match-e [77] 95.7% ??? [115] 4.3% ---------------------------------------------------------------------------------- for-loop [64] 6.8% merge-egraph-nodes! [84] 93.2% [94] 17504(10.1%) 330(0.2%) update-leader! ...master/src/core/egraph.rkt:213:0 for-loop [105] 96.4% ---------------------------------------------------------------------------------- loop [8] 6.5% ??? [37] 9.4% location-do [113] 10.1% for-loop [55] 10.1% ??? [76] 24.5% ??? [85] 39.4% [95] 12836(7.4%) 898(0.5%) ??? ...tract/private/arrow-higher-order.rkt:360:33 ival-mult [110] 37.1% mk-ival [114] 19.8% location-do [113] 10.1% sample-multi-bounded [116] 9.4% approximate9 [2] 9.0% hash-ref! [112] 6.5% simplify [126] 1.2% ---------------------------------------------------------------------------------- merge-egraph-nodes! [84] 100.0% [96] 3950(2.3%) 0(0.0%) for-loop ...erbie/master/src/core/egraph.rkt:199:4 merge-egraph-nodes! [84] 84.8% dedup-children! [104] 15.2% ---------------------------------------------------------------------------------- for-loop [86] 100.0% [97] 3030(1.8%) 3030(1.8%) procedure-reduce-keyword-arity-mask ....rkt:1562:4 ---------------------------------------------------------------------------------- pattern-substitute [78] 22.3% for-loop [86] 77.7% [98] 2792(1.6%) 2792(1.6%) do-curry ...-7.2/collects/racket/function.rkt:71:2 ---------------------------------------------------------------------------------- for-loop [86] 100.0% [99] 1160(0.7%) 882(0.5%) foldr ....2/collects/racket/private/list.rkt:242:4 cp-2 [118] 24.0% ---------------------------------------------------------------------------------- new-enode [89] 100.0% [100] 658(0.4%) 0(0.0%) type-of-enode-expr ...ster/src/core/enode.rkt:66:0 table-ref [117] 100.0% ---------------------------------------------------------------------------------- for-loop [86] 100.0% [101] 598(0.3%) 598(0.3%) cartesian-product ...ollects/racket/list.rkt:822:0 ---------------------------------------------------------------------------------- setfindf [90] 100.0% [102] 300(0.2%) 0(0.0%) for-loop ...ies/herbie/master/src/common.rkt:131:2 ??? [106] 100.0% ---------------------------------------------------------------------------------- merge-egraph-nodes! [84] 100.0% [103] 296(0.2%) 0(0.0%) enode-merge! ...ie/master/src/core/enode.rkt:131:0 adopt-enode! [120] 100.0% ---------------------------------------------------------------------------------- for-loop [96] 2.4% merge-egraph-nodes! [84] 6.2% for-loop [68] 91.4% [104] 25374(14.7%) 0(0.0%) dedup-children! ...master/src/core/enode.rkt:202:0 loop [121] 68.5% loop [124] 31.5% ---------------------------------------------------------------------------------- update-leader! [94] 100.0% [105] 16876(9.8%) 334(0.2%) for-loop ...erbie/master/src/core/egraph.rkt:218:6 for-loop [122] 56.8% hash-update! [137] 41.2% ---------------------------------------------------------------------------------- choose-best-alt! [40] 2.5% for-loop [102] 2.5% pattern-substitute [78] 4.9% loop [33] 5.9% variable? [87] 15.1% match-e [77] 18.4% finalize-iter! [34] 50.6% [106] 11924(6.9%) 4886(2.8%) ??? ...contract/private/arrow-val-first.rkt:390:18 for-loop [125] 50.6% ??? [130] 5.9% ??? [135] 2.5% ---------------------------------------------------------------------------------- filter-loop! [83] 3.5% loop! [91] 96.5% [107] 8554(5.0%) 8554(5.0%) set ...collects/racket/private/set-types.rkt:981:0 ---------------------------------------------------------------------------------- ??? [92] 100.0% [108] 7936(4.6%) 5904(3.4%) ival-acos ...rbie/master/src/biginterval.rkt:348:0 bfacos [129] 25.6% ---------------------------------------------------------------------------------- ??? [92] 100.0% [109] 7520(4.4%) 0(0.0%) ival-sub ...herbie/master/src/biginterval.rkt:99:0 bfmul [180] 100.0% ---------------------------------------------------------------------------------- ??? [95] 100.0% [110] 4756(2.8%) 1686(1.0%) ival-mult ...rbie/master/src/biginterval.rkt:111:0 bfmul [180] 64.6% ---------------------------------------------------------------------------------- ??? [92] 100.0% [111] 4526(2.6%) 1660(1.0%) ival-div ...erbie/master/src/biginterval.rkt:147:0 bfmul [180] 63.3% ---------------------------------------------------------------------------------- for-loop [14] 2.6% localize-error [44] 6.3% iterate-diagonal [17] 8.9% map [155] 18.6% ??? [128] 27.8% ??? [95] 35.8% [112] 3774(2.2%) 336(0.2%) hash-ref! .../racket/private/more-scheme.rkt:376:2 simplify [126] 35.8% ??? [128] 27.8% parse-loop80 [140] 24.9% ??? [6] 2.6% ---------------------------------------------------------------------------------- ??? [95] 40.1% location-do [113] 59.9% [113] 3434(2.0%) 0(0.0%) location-do ...herbie/master/src/programs.rkt:64:0 location-do [113] 59.9% ??? [95] 40.1% ---------------------------------------------------------------------------------- ??? [95] 100.0% [114] 2540(1.5%) 300(0.2%) mk-ival .../herbie/master/src/biginterval.rkt:57:0 bf [127] 88.2% ---------------------------------------------------------------------------------- for-loop [69] 24.8% for-loop [93] 75.2% [115] 1242(0.7%) 308(0.2%) ??? ...lies/herbie/master/src/core/ematch.rkt:43:5 for-loop [131] 75.2% ---------------------------------------------------------------------------------- ??? [95] 100.0% [116] 1208(0.7%) 918(0.5%) sample-multi-bounded ...master/src/points.rkt:15:0 for-loop [136] 24.0% ---------------------------------------------------------------------------------- type-of-enode-expr [100] 100.0% [117] 658(0.4%) 334(0.2%) table-ref ...ies/herbie/master/src/common.rkt:33:0 for-loop [133] 49.2% ---------------------------------------------------------------------------------- foldr [99] 48.1% for-loop [86] 51.9% [118] 578(0.3%) 278(0.2%) cp-2 .../racket-7.2/collects/racket/list.rkt:826:2 for-loop [134] 51.9% ---------------------------------------------------------------------------------- for-loop [132] 50.0% ??? [92] 50.0% [119] 360(0.2%) 360(0.2%) ??? ...cts/racket/contract/private/list.rkt:209:10 for-loop [132] 50.0% ---------------------------------------------------------------------------------- enode-merge! [103] 100.0% [120] 296(0.2%) 0(0.0%) adopt-enode! ...ie/master/src/core/enode.rkt:109:0 custom-set-union [123] 100.0% ---------------------------------------------------------------------------------- dedup-children! [104] 9.0% loop [121] 91.0% [121] 17386(10.1%) 17386(10.1%) loop ...racket-7.2/collects/racket/list.rkt:434:17 loop [121] 91.0% ---------------------------------------------------------------------------------- for-loop [105] 100.0% [122] 9588(5.6%) 0(0.0%) for-loop ...erbie/master/src/core/egraph.rkt:219:8 hash-update! [137] 100.0% ---------------------------------------------------------------------------------- adopt-enode! [120] 3.1% loop! [91] 96.9% [123] 9568(5.5%) 3248(1.9%) custom-set-union ...et/private/set-types.rkt:168:0 for-loop [138] 62.9% for-loop [149] 3.1% ---------------------------------------------------------------------------------- dedup-children! [104] 21.3% loop [124] 78.7% [124] 7988(4.6%) 0(0.0%) loop ...racket-7.2/collects/racket/list.rkt:417:34 loop [124] 78.7% loop [193] 11.6% member [142] 9.8% ---------------------------------------------------------------------------------- ??? [106] 100.0% [125] 6036(3.5%) 0(0.0%) for-loop ...bie/master/src/core/alt-table.rkt:55:2 atab-add-altn [141] 50.0% errors [164] 39.9% loop [145] 10.1% ---------------------------------------------------------------------------------- taylor-invert [23] 9.7% ??? [95] 9.7% hash-ref! [112] 80.6% [126] 3098(1.8%) 310(0.2%) simplify ...herbie/master/src/core/reduce.rkt:16:0 parse-loop80 [140] 39.0% f67 [143] 31.6% debug-print [147] 9.7% simplify* [148] 9.7% ---------------------------------------------------------------------------------- mk-ival [114] 100.0% [127] 2240(1.3%) 300(0.2%) bf ...ath-lib/math/private/bigfloat/mpfr.rkt:601:2 new-mpfr [184] 47.2% ??? [185] 39.4% ---------------------------------------------------------------------------------- hash-ref! [112] 100.0% [128] 2198(1.3%) 0(0.0%) ??? ...ies/herbie/master/src/core/taylor.rkt:45:15 hash-ref! [112] 100.0% ---------------------------------------------------------------------------------- ival-acos [108] 100.0% [129] 2032(1.2%) 0(0.0%) bfacos ...lib/math/private/bigfloat/mpfr.rkt:618:4 new-mpfr [184] 69.3% ??? [185] 30.7% ---------------------------------------------------------------------------------- pattern-substitute [78] 29.9% ??? [106] 70.1% [130] 1004(0.6%) 0(0.0%) ??? ...ects/racket/contract/private/guts.rkt:772:8 bigvalue? [144] 70.1% dict? [146] 29.9% ---------------------------------------------------------------------------------- ??? [115] 100.0% [131] 934(0.5%) 0(0.0%) for-loop ...herbie/master/src/core/ematch.rkt:44:7 constant? [139] 100.0% ---------------------------------------------------------------------------------- ??? [119] 100.0% [132] 360(0.2%) 0(0.0%) for-loop ...acket/contract/private/list.rkt:212:15 ??? [119] 100.0% ---------------------------------------------------------------------------------- table-ref [117] 100.0% [133] 324(0.2%) 324(0.2%) for-loop ...lies/herbie/master/src/common.rkt:35:4 ---------------------------------------------------------------------------------- cp-2 [118] 100.0% [134] 300(0.2%) 300(0.2%) for-loop ...ket-7.2/collects/racket/list.rkt:827:4 ---------------------------------------------------------------------------------- ??? [106] 100.0% [135] 298(0.2%) 0(0.0%) ??? ...s/herbie/master/src/core/alt-table.rkt:58:0 argmin [150] 100.0% ---------------------------------------------------------------------------------- sample-multi-bounded [116] 100.0% [136] 290(0.2%) 290(0.2%) for-loop ...lies/herbie/master/src/points.rkt:23:4 ---------------------------------------------------------------------------------- loop [33] 3.5% for-loop [105] 40.5% for-loop [122] 55.9% [137] 17150(9.9%) 608(0.4%) hash-update! ...cket/private/more-scheme.rkt:365:4 ??? [151] 96.5% ---------------------------------------------------------------------------------- custom-set-union [123] 100.0% [138] 6022(3.5%) 1892(1.1%) for-loop ...cts/racket/private/set-types.rkt:174:3 for-loop [153] 68.6% ---------------------------------------------------------------------------------- pattern-substitute [78] 13.5% for-loop [131] 20.2% match-e [77] 66.3% [139] 4626(2.7%) 934(0.5%) constant? ...ie/master/src/syntax/syntax.rkt:726:0 value? [152] 79.8% ---------------------------------------------------------------------------------- hash-ref! [112] 30.1% map [155] 31.3% simplify [126] 38.6% [140] 3128(1.8%) 0(0.0%) parse-loop80 ...s/racket/match/compiler.rkt:418:15 eval-const-expr [154] 48.8% map [155] 39.7% loop [162] 10.2% for-loop [161] 1.3% ---------------------------------------------------------------------------------- for-loop [125] 100.0% [141] 3020(1.7%) 0(0.0%) atab-add-altn ...ster/src/core/alt-table.rkt:203:0 errors [164] 79.7% for-loop [156] 10.3% loop [159] 9.9% ---------------------------------------------------------------------------------- loop [124] 100.0% [142] 1890(1.1%) 1890(1.1%) member (unknown source) ---------------------------------------------------------------------------------- loop [162] 21.7% simplify [126] 30.4% map [155] 47.9% [143] 980(0.6%) 0(0.0%) f67 ...2/collects/racket/match/compiler.rkt:507:40 map [155] 91.3% eval-const-expr [154] 8.7% ---------------------------------------------------------------------------------- ??? [130] 100.0% [144] 704(0.4%) 704(0.4%) bigvalue? ...rbie/master/src/syntax/types.rkt:19:0 ---------------------------------------------------------------------------------- for-loop [125] 100.0% [145] 610(0.4%) 308(0.2%) loop ...herbie/master/src/core/alt-table.rkt:177:2 loop [157] 49.5% ---------------------------------------------------------------------------------- ??? [130] 100.0% [146] 300(0.2%) 300(0.2%) dict? ...ollects/racket/private/generic.rkt:146:11 ---------------------------------------------------------------------------------- simplify [126] 100.0% [147] 300(0.2%) 0(0.0%) debug-print ...s/herbie/master/src/debug.rkt:110:0 ??? [158] 100.0% ---------------------------------------------------------------------------------- simplify [126] 100.0% [148] 300(0.2%) 0(0.0%) simplify* ...erbie/master/src/core/reduce.rkt:31:0 return/no-unsupplied [175] 100.0% ---------------------------------------------------------------------------------- custom-set-union [123] 100.0% [149] 298(0.2%) 298(0.2%) for-loop ...cts/racket/private/set-types.rkt:152:2 ---------------------------------------------------------------------------------- ??? [135] 100.0% [150] 298(0.2%) 0(0.0%) argmin ...acket-7.2/collects/racket/list.rkt:765:0 ??? [160] 100.0% ---------------------------------------------------------------------------------- hash-update! [137] 100.0% [151] 16542(9.6%) 1536(0.9%) ??? ...es/herbie/master/src/core/egraph.rkt:221:24 for-loop [163] 90.7% ---------------------------------------------------------------------------------- variable? [87] 29.5% constant? [139] 70.5% [152] 5238(3.0%) 5238(3.0%) value? .../herbie/master/src/syntax/types.rkt:18:0 ---------------------------------------------------------------------------------- for-loop [138] 100.0% [153] 4130(2.4%) 4130(2.4%) for-loop ...cts/racket/private/set-types.rkt:178:5 ---------------------------------------------------------------------------------- f67 [143] 11.1% ??? [15] 29.1% parse-loop80 [140] 59.8% [154] 3088(1.8%) 0(0.0%) eval-const-expr ...e/master/src/programs.rkt:118:0 temp85_0 [174] 89.5% ??? [85] 10.5% ---------------------------------------------------------------------------------- for-loop [26] 13.7% f67 [143] 40.2% parse-loop80 [140] 46.1% [155] 2226(1.3%) 0(0.0%) map ...t-7.2/collects/racket/private/map.rkt:35:13 hash-ref! [112] 33.3% parse-loop80 [140] 22.9% f67 [143] 21.1% ??? [171] 13.7% loop [162] 8.9% ---------------------------------------------------------------------------------- atab-add-altn [141] 100.0% [156] 312(0.2%) 312(0.2%) for-loop ...ie/master/src/core/alt-table.rkt:119:2 ---------------------------------------------------------------------------------- loop [145] 6.2% loop [157] 93.8% [157] 302(0.2%) 302(0.2%) loop ...racket-7.2/collects/racket/list.rkt:434:28 loop [157] 93.8% ---------------------------------------------------------------------------------- debug-print [147] 100.0% [158] 300(0.2%) 300(0.2%) ??? .../contract/private/arrow-val-first.rkt:430:3 ---------------------------------------------------------------------------------- atab-add-altn [141] 100.0% [159] 300(0.2%) 300(0.2%) loop ...-7.2/collects/racket/private/hash.rkt:20:4 ---------------------------------------------------------------------------------- argmin [150] 100.0% [160] 298(0.2%) 0(0.0%) ??? ...tlies/herbie/master/src/mainloop.rkt:113:10 errors [164] 100.0% ---------------------------------------------------------------------------------- parse-loop80 [140] 100.0% [161] 286(0.2%) 0(0.0%) for-loop ...bie/master/src/core/localize.rkt:53:21 for-loop [165] 100.0% ---------------------------------------------------------------------------------- map [155] 0.1% parse-loop80 [140] 1.1% for-loop [86] 1.9% for-loop [26] 4.9% mk-enode-rec! [79] 10.0% loop! [91] 11.1% loop [162] 71.0% [162] 24840(14.4%) 940(0.5%) loop ...-7.2/collects/racket/private/map.rkt:40:19 loop [162] 71.0% loop! [91] 10.9% mk-enode-rec! [79] 8.2% ??? [171] 2.5% ??? [76] 2.4% ??? [170] 1.2% f67 [143] 1.1% bf* [172] 0.1% foldl [173] 0.0% ??? [169] 0.0% ---------------------------------------------------------------------------------- ??? [151] 100.0% [163] 15006(8.7%) 14408(8.3%) for-loop ...rbie/master/src/core/egraph.rkt:222:26 update-en-expr [167] 4.0% ---------------------------------------------------------------------------------- ??? [160] 4.7% for-loop [47] 4.7% ??? [15] 14.9% for-loop [125] 37.9% atab-add-altn [141] 37.9% [164] 6354(3.7%) 0(0.0%) errors ...tlies/herbie/master/src/points.rkt:205:0 for-loop [166] 57.3% eval-prog [168] 42.7% ---------------------------------------------------------------------------------- for-loop [161] 100.0% [165] 286(0.2%) 286(0.2%) for-loop ...bie/master/src/core/localize.rkt:54:23 ---------------------------------------------------------------------------------- errors [164] 100.0% [166] 3638(2.1%) 298(0.2%) for-loop ...ies/herbie/master/src/points.rkt:207:2 ??? [15] 83.6% ??? [178] 8.2% ---------------------------------------------------------------------------------- for-loop [163] 21.4% loop! [91] 78.6% [167] 2792(1.6%) 2792(1.6%) update-en-expr ...master/src/core/egraph.rkt:207:0 ---------------------------------------------------------------------------------- errors [164] 100.0% [168] 2716(1.6%) 0(0.0%) eval-prog ...s/herbie/master/src/programs.rkt:83:0 temp85_0 [174] 89.0% eval [179] 11.0% ---------------------------------------------------------------------------------- loop [162] 14.5% ??? [85] 85.5% [169] 2228(1.3%) 1548(0.9%) ??? .../herbie/master/src/syntax/syntax.rkt:214:17 return/no-unsupplied [175] 30.5% ---------------------------------------------------------------------------------- ??? [76] 19.5% loop [162] 20.5% pattern-substitute [78] 60.0% [170] 1476(0.9%) 1476(0.9%) ??? ...cket-7.2/collects/racket/function.rkt:93:12 ---------------------------------------------------------------------------------- map [155] 33.4% loop [162] 66.6% [171] 916(0.5%) 0(0.0%) ??? ...ghtlies/herbie/master/src/points.rkt:190:26 ??? [76] 100.0% ---------------------------------------------------------------------------------- loop [162] 100.0% [172] 332(0.2%) 0(0.0%) bf* ...ath/private/bigfloat/bigfloat-mpfr.rkt:95:0 ??? [176] 100.0% ---------------------------------------------------------------------------------- loop [162] 100.0% [173] 330(0.2%) 0(0.0%) foldl ....2/collects/racket/private/list.rkt:229:4 merge2 [177] 100.0% ---------------------------------------------------------------------------------- eval-prog [168] 46.7% eval-const-expr [154] 53.3% [174] 5182(3.0%) 306(0.2%) temp85_0 (unknown source) compile15 [181] 94.1% ---------------------------------------------------------------------------------- simplify* [148] 15.3% ??? [169] 34.7% pattern-substitute [78] 50.0% [175] 1960(1.1%) 1304(0.8%) return/no-unsupplied ...ct/private/arr-i.rkt:542:0 filter [182] 33.5% ---------------------------------------------------------------------------------- bf* [172] 100.0% [176] 332(0.2%) 0(0.0%) ??? ...-racket/utils/simple-result-arrow.rkt:39:12 bfmul [180] 100.0% ---------------------------------------------------------------------------------- foldl [173] 100.0% [177] 330(0.2%) 330(0.2%) merge2 ...s/herbie/master/src/core/ematch.rkt:24:0 ---------------------------------------------------------------------------------- for-loop [166] 100.0% [178] 298(0.2%) 298(0.2%) ??? ...7.2/collects/racket/private/for.rkt:1233:14 ---------------------------------------------------------------------------------- eval-prog [168] 100.0% [179] 298(0.2%) 0(0.0%) eval (unknown source) namespace-syntax-introduce3 [183] 100.0% ---------------------------------------------------------------------------------- ??? [176] 2.4% ival-div [111] 20.8% ival-mult [110] 22.3% ival-sub [109] 54.5% [180] 13788(8.0%) 322(0.2%) bfmul ...-lib/math/private/bigfloat/mpfr.rkt:821:4 new-mpfr [184] 56.2% ??? [185] 41.4% ---------------------------------------------------------------------------------- temp85_0 [174] 100.0% [181] 4876(2.8%) 0(0.0%) compile15 (unknown source) temp91_0 [186] 100.0% ---------------------------------------------------------------------------------- return/no-unsupplied [175] 100.0% [182] 656(0.4%) 656(0.4%) filter ...2/collects/racket/private/list.rkt:256:2 ---------------------------------------------------------------------------------- eval [179] 100.0% [183] 298(0.2%) 0(0.0%) namespace-syntax-introduce3 (unknown source) free-identifier=? [187] 100.0% ---------------------------------------------------------------------------------- bf [127] 10.4% bfacos [129] 13.8% bfmul [180] 75.9% [184] 10218(5.9%) 10218(5.9%) new-mpfr ...b/math/private/bigfloat/mpfr.rkt:335:0 ---------------------------------------------------------------------------------- bfacos [129] 8.6% bf [127] 12.2% bfmul [180] 79.1% [185] 7220(4.2%) 7220(4.2%) ??? /opt/racket-7.2/collects/ffi/unsafe.rkt:905:4 ---------------------------------------------------------------------------------- compile15 [181] 100.0% [186] 4876(2.8%) 0(0.0%) temp91_0 (unknown source) temp118_0 [188] 93.6% compile-top9 [189] 6.4% ---------------------------------------------------------------------------------- namespace-syntax-introduce3 [183] 100.0% [187] 298(0.2%) 298(0.2%) free-identifier=? (unknown source) ---------------------------------------------------------------------------------- temp91_0 [186] 100.0% [188] 4566(2.6%) 0(0.0%) temp118_0 (unknown source) expand-capturing-lifts [190] 100.0% ---------------------------------------------------------------------------------- temp91_0 [186] 100.0% [189] 310(0.2%) 0(0.0%) compile-top9 (unknown source) compile-forms33 [191] 100.0% ---------------------------------------------------------------------------------- temp118_0 [188] 100.0% [190] 4566(2.6%) 0(0.0%) expand-capturing-lifts (unknown source) lambda-clause-expander [192] 100.0% ---------------------------------------------------------------------------------- compile-top9 [189] 100.0% [191] 310(0.2%) 0(0.0%) compile-forms33 (unknown source) for-loop [195] 100.0% ---------------------------------------------------------------------------------- expand-capturing-lifts [190] 100.0% [192] 4566(2.6%) 0(0.0%) lambda-clause-expander (unknown source) finish-bodys [194] 80.3% loop [193] 19.7% ---------------------------------------------------------------------------------- syntax->list [205] 0.6% loop [193] 1.8% lambda-clause-expander [192] 6.1% syntax-e/no-taint [9] 17.5% loop [124] 74.0% [193] 8240(4.8%) 6398(3.7%) loop (unknown source) gf [196] 16.9% dispatch-transformer41 [197] 4.2% expand-id-application-form17 [198] 1.8% loop [193] 1.8% syntax-e [3] 0.6% ---------------------------------------------------------------------------------- lambda-clause-expander [192] 25.3% for-loop [195] 74.7% [194] 3666(2.1%) 0(0.0%) finish-bodys (unknown source) for-loop [195] 100.0% ---------------------------------------------------------------------------------- fallback-loop [16] 1.1% compile-forms33 [191] 7.8% for-loop [195] 9.0% finish-bodys [194] 82.1% [195] 3976(2.3%) 1810(1.0%) for-loop (unknown source) finish-bodys [194] 61.6% for-loop [195] 9.0% compile-module-linklet57 [201] 7.8% syntax-e [3] 4.7% expand-implicit [5] 1.5% ---------------------------------------------------------------------------------- loop [193] 100.0% [196] 1542(0.9%) 598(0.3%) gf (unknown source) propagation-apply [199] 41.6% propagation-apply-shifted [202] 19.6% ---------------------------------------------------------------------------------- loop [193] 100.0% [197] 600(0.3%) 0(0.0%) dispatch-transformer41 (unknown source) apply-transformer52 [200] 100.0% ---------------------------------------------------------------------------------- loop [193] 100.0% [198] 300(0.2%) 0(0.0%) expand-id-application-form17 (unknown source) syntax-e/no-taint [9] 100.0% ---------------------------------------------------------------------------------- gf [196] 100.0% [199] 642(0.4%) 642(0.4%) propagation-apply (unknown source) ---------------------------------------------------------------------------------- dispatch-transformer41 [197] 100.0% [200] 600(0.3%) 0(0.0%) apply-transformer52 (unknown source) apply-transformer-in-context [203] 100.0% ---------------------------------------------------------------------------------- for-loop [195] 100.0% [201] 310(0.2%) 310(0.2%) compile-module-linklet57 (unknown source) ---------------------------------------------------------------------------------- gf [196] 100.0% [202] 302(0.2%) 302(0.2%) propagation-apply-shifted (unknown source) ---------------------------------------------------------------------------------- apply-transformer52 [200] 100.0% [203] 600(0.3%) 300(0.2%) apply-transformer-in-context (unknown source) go [204] 50.0% ---------------------------------------------------------------------------------- apply-transformer-in-context [203] 100.0% [204] 300(0.2%) 0(0.0%) go .../collects/racket/private/qq-and-or.rkt:50:20 syntax->list [205] 100.0% ---------------------------------------------------------------------------------- go [204] 100.0% [205] 300(0.2%) 0(0.0%) syntax->list (unknown source) loop [193] 100.0% ----------------------------------------------------------------------------------