Profiling results ----------------- Total cpu time observed: 137172ms (out of 141336ms) Number of samples taken: 314 (once every 437ms) (Hiding functions with self<1.0% and local<2.0%: 2 of 98 hidden) ========================================================================= Caller Idx Total Self Name+src Local% ms(pct) ms(pct) Callee ========================================================================= ??? [14] 100.0% [1] 135874(99.1%) 0(0.0%) profile-thunk16 ...t/pkgs/profile-lib/main.rkt:9:0 run [9] 100.0% ------------------------------------------------------------------------- map [61] 0.3% loop [80] 99.7% [2] 117136(85.4%) 0(0.0%) ??? ...tlies/herbie/develop/src/programs.rkt:154:4 ??? [10] 100.0% ------------------------------------------------------------------------- ??? [81] 100.0% [3] 8932(6.5%) 0(0.0%) iterate-egraph!13 ...p/src/core/simplify.rkt:102:0 one-iter [11] 100.0% ------------------------------------------------------------------------- hash-ref! [70] 100.0% [4] 1758(1.3%) 0(0.0%) f6 ...et/collects/racket/match/compiler.rkt:507:40 map [61] 100.0% ------------------------------------------------------------------------- ??? [81] 100.0% [5] 1356(1.0%) 0(0.0%) loop ...herbie/develop/src/core/simplify.rkt:215:2 pass [12] 100.0% ------------------------------------------------------------------------- parse-loop12 [78] 2.1% loop [6] 97.9% [6] 710(0.5%) 0(0.0%) loop ...cket/collects/racket/private/map.rkt:36:19 loop [6] 97.9% ??? [76] 2.1% ------------------------------------------------------------------------- match-e [37] 100.0% [7] 348(0.3%) 0(0.0%) for-loop ...rbie/develop/src/core/ematch.rkt:59:11 for-loop [13] 100.0% ------------------------------------------------------------------------- match-e [37] 100.0% [8] 348(0.3%) 0(0.0%) variable? ...e/develop/src/syntax/syntax.rkt:567:0 ??? [88] 100.0% ------------------------------------------------------------------------- profile-thunk16 [1] 99.8% [9] 136210(99.3%) 0(0.0%) run ...share/racket/pkgs/profile-lib/main.rkt:39:2 ??? [14] 100.0% ------------------------------------------------------------------------- ??? [2] 100.0% [10] 117136(85.4%) 7660(5.6%) ??? ...acket/collects/racket/private/kw.rkt:444:14 bf-complex-mult [15] 79.9% bf-complex-add [16] 10.1% ??? [76] 1.8% ??? [20] 1.0% ------------------------------------------------------------------------- iterate-egraph!13 [3] 100.0% [11] 8932(6.5%) 0(0.0%) one-iter ...ie/develop/src/core/simplify.rkt:113:0 for-loop [17] 53.1% loop [18] 46.9% ------------------------------------------------------------------------- loop [5] 100.0% [12] 1356(1.0%) 0(0.0%) pass ...herbie/develop/src/core/simplify.rkt:205:2 for-loop [19] 100.0% ------------------------------------------------------------------------- for-loop [7] 100.0% [13] 348(0.3%) 0(0.0%) for-loop ...rbie/develop/src/core/ematch.rkt:65:37 match-e [37] 100.0% ------------------------------------------------------------------------- run [9] 50.0% [14] 136508(99.5%) 0(0.0%) ??? ...lects/racket/private/more-scheme.rkt:261:28 profile-thunk16 [1] 49.8% loop [29] 43.7% run-improve50 [22] 6.5% ------------------------------------------------------------------------- ??? [10] 100.0% [15] 93560(68.2%) 3712(2.7%) bf-complex-mult ...develop/src/bigcomplex.rkt:33:0 bf* [21] 59.0% ??? [30] 32.4% ...higher-order.rkt:346:33 [23] 4.7% ------------------------------------------------------------------------- ??? [10] 100.0% [16] 11808(8.6%) 394(0.3%) bf-complex-add .../develop/src/bigcomplex.rkt:22:0 ??? [30] 86.9% ...higher-order.rkt:346:33 [23] 9.8% ------------------------------------------------------------------------- for-loop [17] 50.0% one-iter [11] 50.0% [17] 4742(3.5%) 354(0.3%) for-loop ...e/develop/src/core/simplify.rkt:123:12 for-loop [17] 50.0% rule-valid-at-type? [25] 42.5% match-e [37] 3.8% ------------------------------------------------------------------------- one-iter [11] 100.0% [18] 4190(3.1%) 0(0.0%) loop ...cket/collects/racket/private/map.rkt:52:19 apply-match [24] 100.0% ------------------------------------------------------------------------- pass [12] 100.0% [19] 1356(1.0%) 0(0.0%) for-loop ...e/develop/src/core/simplify.rkt:208:29 argmin [26] 53.7% loop [27] 46.3% ------------------------------------------------------------------------- ??? [10] 100.0% [20] 1168(0.9%) 774(0.6%) ??? ...ects/racket/contract/private/prop.rkt:493:4 ??? [28] 33.7% ------------------------------------------------------------------------- bf-complex-mult [15] 100.0% [21] 55202(40.2%) 0(0.0%) bf* ...ath/private/bigfloat/bigfloat-mpfr.rkt:95:0 ??? [30] 100.0% ------------------------------------------------------------------------- ??? [14] 100.0% [22] 17552(12.8%) 0(0.0%) run-improve50 ...ie/develop/src/mainloop.rkt:234:0 setup-alt-simplified [31] 54.8% loop [29] 31.2% for-loop [34] 11.9% get-final-combination [38] 2.1% ------------------------------------------------------------------------- bf-complex-add [16] 20.9% bf-complex-mult [15] 79.1% [23] 5522(4.0%) 1160(0.8%) ...higher-order.rkt:346:33 (unknown source) ??? [32] 79.0% ------------------------------------------------------------------------- loop [18] 100.0% [24] 4190(3.1%) 332(0.2%) apply-match ...develop/src/core/simplify.rkt:130:2 for-loop [33] 83.8% match-e [37] 8.3% ------------------------------------------------------------------------- for-loop [17] 100.0% [25] 4030(2.9%) 3072(2.2%) rule-valid-at-type? .../src/syntax/rules.rkt:468:0 for-loop [36] 23.8% ------------------------------------------------------------------------- ??? [76] 30.8% for-loop [19] 69.2% [26] 1052(0.8%) 0(0.0%) argmin ...re/racket/collects/racket/list.rkt:743:0 for-loop [35] 100.0% ------------------------------------------------------------------------- for-loop [19] 100.0% [27] 628(0.5%) 0(0.0%) loop ...hare/racket/collects/racket/list.rkt:729:4 for-loop [35] 52.2% expression-cost [39] 47.8% ------------------------------------------------------------------------- ??? [20] 100.0% [28] 394(0.3%) 394(0.3%) ??? ...lects/racket/contract/private/orc.rkt:83:14 ------------------------------------------------------------------------- run-improve50 [22] 4.4% ??? [14] 95.6% [29] 124426(90.7%) 0(0.0%) loop ...htlies/herbie/develop/src/points.rkt:193:2 make-exacts* [52] 52.6% loop [41] 44.7% loop [53] 2.4% for-loop [48] 0.3% ------------------------------------------------------------------------- bf-complex-add [16] 10.7% bf-complex-mult [15] 31.6% bf* [21] 57.7% [30] 95740(69.8%) 6616(4.8%) ??? ...-racket/utils/simple-result-arrow.rkt:39:12 bfmul [40] 84.8% bfneg [43] 8.3% ------------------------------------------------------------------------- run-improve50 [22] 100.0% [31] 9624(7.0%) 0(0.0%) setup-alt-simplified .../develop/src/glue.rkt:49:0 simplify-alt [42] 100.0% ------------------------------------------------------------------------- ...higher-order.rkt:346:33 [23] 100.0% [32] 4362(3.2%) 2964(2.2%) ??? ...cts/racket/contract/private/list.rkt:187:10 ??? [46] 32.0% ------------------------------------------------------------------------- apply-match [24] 100.0% [33] 3510(2.6%) 0(0.0%) for-loop ...e/develop/src/core/simplify.rkt:145:10 merge-egraph-nodes! [45] 51.4% loop! [89] 19.9% mk-enode! [56] 19.1% substitute-e [49] 9.6% ------------------------------------------------------------------------- run-improve50 [22] 100.0% [34] 2082(1.5%) 0(0.0%) for-loop ...herbie/develop/src/mainloop.rkt:249:10 run-iter! [44] 100.0% ------------------------------------------------------------------------- loop [27] 23.8% argmin [26] 76.2% [35] 1380(1.0%) 0(0.0%) for-loop .../herbie/develop/src/programs.rkt:199:2 ??? [81] 100.0% ------------------------------------------------------------------------- rule-valid-at-type? [25] 100.0% [36] 958(0.7%) 660(0.5%) for-loop ...ies/herbie/develop/src/common.rkt:94:9 list-member? [51] 31.1% ------------------------------------------------------------------------- apply-match [24] 16.4% for-loop [13] 32.9% for-loop [17] 50.7% [37] 706(0.5%) 358(0.3%) match-e ...herbie/develop/src/core/ematch.rkt:46:0 for-loop [7] 32.9% variable? [8] 16.4% ------------------------------------------------------------------------- run-improve50 [22] 100.0% [38] 376(0.3%) 0(0.0%) get-final-combination ...op/src/mainloop.rkt:264:0 extract-alt [47] 100.0% ------------------------------------------------------------------------- loop [27] 100.0% [39] 300(0.2%) 0(0.0%) expression-cost .../develop/src/programs.rkt:198:0 compile [50] 100.0% ------------------------------------------------------------------------- ??? [30] 100.0% [40] 81140(59.2%) 57788(42.1%) bfmul ...-lib/math/private/bigfloat/mpfr.rkt:819:4 ??? [87] 28.8% ------------------------------------------------------------------------- loop [29] 100.0% [41] 55578(40.5%) 0(0.0%) loop ...htlies/herbie/develop/src/points.rkt:151:2 loop [53] 58.8% make-exacts* [52] 35.4% eval-prog [62] 5.8% ------------------------------------------------------------------------- setup-alt-simplified [31] 100.0% [42] 9624(7.0%) 0(0.0%) simplify-alt ...s/herbie/develop/src/glue.rkt:76:0 ??? [81] 100.0% ------------------------------------------------------------------------- ??? [30] 100.0% [43] 7984(5.8%) 5878(4.3%) bfneg ...-lib/math/private/bigfloat/mpfr.rkt:616:4 ??? [87] 26.4% ------------------------------------------------------------------------- for-loop [34] 100.0% [44] 2082(1.5%) 0(0.0%) run-iter! ...herbie/develop/src/mainloop.rkt:215:0 localize-error [55] 84.4% choose-best-alt! [60] 15.6% ------------------------------------------------------------------------- for-loop [58] 10.0% merge-egraph-nodes! [45] 20.0% for-loop [33] 70.1% [45] 1804(1.3%) 0(0.0%) merge-egraph-nodes! ...p/src/core/egraph.rkt:152:0 update-leader! [54] 70.1% merge-egraph-nodes! [45] 20.0% for-loop [58] 10.0% ------------------------------------------------------------------------- ??? [32] 100.0% [46] 1398(1.0%) 1398(1.0%) ??? ...ects/racket/contract/private/guts.rkt:644:8 ------------------------------------------------------------------------- get-final-combination [38] 100.0% [47] 376(0.3%) 0(0.0%) extract-alt ...es/herbie/develop/src/glue.rkt:55:0 argmins [57] 100.0% ------------------------------------------------------------------------- loop [29] 100.0% [48] 336(0.2%) 0(0.0%) for-loop ...s/herbie/develop/src/points.rkt:200:24 ??? [59] 100.0% ------------------------------------------------------------------------- substitute-e [49] 50.0% for-loop [33] 50.0% [49] 336(0.2%) 0(0.0%) substitute-e ...e/develop/src/core/ematch.rkt:71:0 substitute-e [49] 50.0% mk-enode! [56] 50.0% ------------------------------------------------------------------------- expression-cost [39] 100.0% [50] 300(0.2%) 0(0.0%) compile ...s/herbie/develop/src/programs.rkt:175:0 hash-ref! [70] 100.0% ------------------------------------------------------------------------- for-loop [36] 100.0% [51] 298(0.2%) 298(0.2%) list-member? ...llects/racket/private/set.rkt:24:0 ------------------------------------------------------------------------- loop [41] 23.1% loop [29] 76.9% [52] 85160(62.1%) 0(0.0%) make-exacts* ...erbie/develop/src/points.rkt:138:0 map [61] 50.3% loop [80] 45.7% eval-prog [62] 4.0% ------------------------------------------------------------------------- loop [29] 8.5% loop [41] 91.5% [53] 35726(26.0%) 0(0.0%) loop ...htlies/herbie/develop/src/points.rkt:141:4 map [61] 100.0% ------------------------------------------------------------------------- merge-egraph-nodes! [45] 100.0% [54] 1804(1.3%) 0(0.0%) update-leader! ...evelop/src/core/egraph.rkt:217:0 for-loop [63] 100.0% ------------------------------------------------------------------------- run-iter! [44] 100.0% [55] 1758(1.3%) 0(0.0%) localize-error ...velop/src/core/localize.rkt:47:0 hash-ref! [70] 100.0% ------------------------------------------------------------------------- substitute-e [49] 33.4% for-loop [33] 66.6% [56] 1006(0.7%) 0(0.0%) mk-enode! ...bie/develop/src/core/egraph.rkt:101:0 new-enode [64] 100.0% ------------------------------------------------------------------------- extract-alt [47] 100.0% [57] 376(0.3%) 0(0.0%) argmins ...ies/herbie/develop/src/common.rkt:145:0 composed [65] 100.0% ------------------------------------------------------------------------- merge-egraph-nodes! [45] 100.0% [58] 360(0.3%) 0(0.0%) for-loop ...bie/develop/src/core/egraph.rkt:200:10 merge-egraph-nodes! [45] 100.0% ------------------------------------------------------------------------- for-loop [48] 100.0% [59] 336(0.2%) 336(0.2%) ??? ...tract/private/arrow-higher-order.rkt:346:33 ------------------------------------------------------------------------- run-iter! [44] 100.0% [60] 324(0.2%) 0(0.0%) choose-best-alt! ...develop/src/mainloop.rkt:115:0 ??? [88] 100.0% ------------------------------------------------------------------------- ??? [67] 0.2% f6 [4] 2.0% loop [53] 44.5% make-exacts* [52] 53.3% [61] 80292(58.5%) 0(0.0%) map ...acket/collects/racket/private/map.rkt:20:13 loop [80] 97.3% ??? [67] 2.0% ??? [2] 0.5% ??? [76] 0.2% ------------------------------------------------------------------------- loop [41] 48.4% make-exacts* [52] 51.6% [62] 6616(4.8%) 0(0.0%) eval-prog ...herbie/develop/src/programs.rkt:148:0 hash-ref! [70] 100.0% ------------------------------------------------------------------------- update-leader! [54] 100.0% [63] 1804(1.3%) 0(0.0%) for-loop ...rbie/develop/src/core/egraph.rkt:222:6 for-loop [66] 100.0% ------------------------------------------------------------------------- mk-enode! [56] 100.0% [64] 1006(0.7%) 0(0.0%) new-enode ...erbie/develop/src/core/enode.rkt:97:0 type-of-enode-expr [68] 100.0% ------------------------------------------------------------------------- argmins [57] 100.0% [65] 376(0.3%) 0(0.0%) composed ...ollects/racket/private/list.rkt:321:16 errors [69] 100.0% ------------------------------------------------------------------------- for-loop [63] 100.0% [66] 1804(1.3%) 0(0.0%) for-loop ...rbie/develop/src/core/egraph.rkt:223:8 hash-update! [71] 100.0% ------------------------------------------------------------------------- map [61] 16.1% loop [80] 83.9% [67] 1758(1.3%) 354(0.3%) ??? ...ket/collects/racket/private/list.rkt:323:18 hash-ref! [70] 95.1% map [61] 2.4% ------------------------------------------------------------------------- new-enode [64] 100.0% [68] 1006(0.7%) 0(0.0%) type-of-enode-expr ...elop/src/core/enode.rkt:68:0 get-sigs [72] 100.0% ------------------------------------------------------------------------- composed [65] 100.0% [69] 376(0.3%) 0(0.0%) errors ...lies/herbie/develop/src/points.rkt:218:0 for-loop [73] 100.0% ------------------------------------------------------------------------- compile [50] 1.2% ??? [74] 2.3% localize-error [55] 2.8% eval-prog [62] 12.5% ??? [67] 17.4% loop [80] 63.8% [70] 8674(6.3%) 300(0.2%) hash-ref! ...racket/private/more-scheme.rkt:373:13 ??? [74] 66.1% parse-loop12 [78] 17.4% bigfloat-hash [75] 12.5% f6 [4] 2.8% ------------------------------------------------------------------------- for-loop [66] 100.0% [71] 1804(1.3%) 0(0.0%) hash-update! ...ket/private/more-scheme.rkt:362:13 ??? [77] 100.0% ------------------------------------------------------------------------- type-of-enode-expr [68] 100.0% [72] 1006(0.7%) 0(0.0%) get-sigs .../herbie/develop/src/type-check.rkt:5:0 ...velop/src/common.rkt:47:2 [79] 66.6% ??? [81] 33.4% ------------------------------------------------------------------------- errors [69] 100.0% [73] 376(0.3%) 0(0.0%) for-loop ...es/herbie/develop/src/points.rkt:221:4 ??? [76] 100.0% ------------------------------------------------------------------------- hash-ref! [70] 100.0% [74] 6916(5.0%) 0(0.0%) ??? ...tlies/herbie/develop/src/programs.rkt:183:5 loop [80] 95.7% hash-ref! [70] 4.3% ------------------------------------------------------------------------- hash-ref! [70] 100.0% [75] 6616(4.8%) 0(0.0%) bigfloat-hash ...h/private/bigfloat/mpfr.rkt:165:0 sig+exp->bigfloat [82] 49.0% bfcanonicalize [83] 45.6% bigfloat->sig+exp [85] 5.4% ------------------------------------------------------------------------- ??? [95] 7.7% loop [80] 8.1% map [61] 8.2% for-loop [73] 9.0% loop [6] 17.0% ??? [10] 50.1% [76] 4186(3.1%) 2430(1.8%) ??? ...tract/private/arrow-higher-order.rkt:342:33 ??? [81] 34.2% argmin [26] 7.7% ------------------------------------------------------------------------- hash-update! [71] 100.0% [77] 1804(1.3%) 0(0.0%) ??? ...s/herbie/develop/src/core/egraph.rkt:225:24 for-loop [84] 100.0% ------------------------------------------------------------------------- hash-ref! [70] 100.0% [78] 1758(1.3%) 0(0.0%) parse-loop12 ...s/racket/match/compiler.rkt:418:15 loop [80] 90.5% loop [6] 9.5% ------------------------------------------------------------------------- get-sigs [72] 100.0% [79] 670(0.5%) 324(0.2%) ...velop/src/common.rkt:47:2 ...e/arr-i.rkt:906:19 ??? [86] 51.6% ------------------------------------------------------------------------- make-exacts* [52] 0.1% loop! [89] 0.4% parse-loop12 [78] 0.9% map [61] 1.3% ??? [74] 5.2% loop [80] 92.1% [80] 126168(92.0%) 0(0.0%) loop ...cket/collects/racket/private/map.rkt:25:19 loop [80] 92.1% hash-ref! [70] 5.2% ??? [2] 1.4% ??? [67] 0.9% loop! [89] 0.4% ??? [76] 0.0% ------------------------------------------------------------------------- get-sigs [72] 0.9% for-loop [35] 5.6% ??? [76] 11.9% simplify-alt [42] 38.9% ??? [81] 40.8% [81] 12044(8.8%) 2154(1.6%) ??? ...llects/racket/private/norm-define.rkt:53:83 ??? [81] 40.8% iterate-egraph!13 [3] 36.6% loop [5] 4.2% ??? [90] 3.6% ??? [88] 2.8% ------------------------------------------------------------------------- bigfloat-hash [75] 100.0% [82] 3240(2.4%) 2932(2.1%) sig+exp->bigfloat ...ivate/bigfloat/mpfr.rkt:385:0 ??? [87] 9.5% ------------------------------------------------------------------------- bigfloat-hash [75] 100.0% [83] 3020(2.2%) 3020(2.2%) bfcanonicalize .../private/bigfloat/mpfr.rkt:155:0 ------------------------------------------------------------------------- ??? [77] 100.0% [84] 1804(1.3%) 1446(1.1%) for-loop ...bie/develop/src/core/egraph.rkt:226:26 update-en-expr [91] 19.8% ------------------------------------------------------------------------- bigfloat-hash [75] 100.0% [85] 356(0.3%) 0(0.0%) bigfloat->sig+exp ...ivate/bigfloat/mpfr.rkt:370:0 new-mpz [92] 100.0% ------------------------------------------------------------------------- ...velop/src/common.rkt:47:2 [79]100.0% [86] 346(0.3%) 346(0.3%) ??? ...s/racket/contract/private/arr-i.rkt:1268:39 ------------------------------------------------------------------------- sig+exp->bigfloat [82] 1.2% bfneg [43] 8.2% bfmul [40] 90.6% [87] 25766(18.8%) 25766(18.8%) ??? .../share/racket/collects/ffi/unsafe.rkt:861:4 ------------------------------------------------------------------------- choose-best-alt! [60] 32.0% ??? [81] 33.7% variable? [8] 34.3% [88] 1014(0.7%) 690(0.5%) ??? ...contract/private/arrow-val-first.rkt:357:18 ??? [95] 32.0% ------------------------------------------------------------------------- for-loop [33] 41.3% loop [80] 58.7% [89] 700(0.5%) 366(0.3%) loop! ...s/herbie/develop/src/core/enode.rkt:192:2 loop [80] 58.7% set [93] 23.9% ------------------------------------------------------------------------- ??? [81] 100.0% [90] 652(0.5%) 324(0.2%) ??? ...ects/racket/contract/private/list.rkt:737:4 for-loop [94] 50.3% ------------------------------------------------------------------------- for-loop [84] 100.0% [91] 358(0.3%) 358(0.3%) update-en-expr ...evelop/src/core/egraph.rkt:211:0 ------------------------------------------------------------------------- bigfloat->sig+exp [85] 100.0% [92] 356(0.3%) 356(0.3%) new-mpz ...-lib/math/private/bigfloat/gmp.rkt:73:0 ------------------------------------------------------------------------- loop! [89] 100.0% [93] 334(0.2%) 334(0.2%) set ...collects/racket/private/set-types.rkt:981:0 ------------------------------------------------------------------------- ??? [90] 100.0% [94] 328(0.2%) 0(0.0%) for-loop ...acket/contract/private/list.rkt:743:12 do-chaperone-procedure [96] 100.0% ------------------------------------------------------------------------- ??? [88] 100.0% [95] 324(0.2%) 0(0.0%) ??? .../herbie/develop/src/core/alt-table.rkt:54:0 ??? [76] 100.0% ------------------------------------------------------------------------- for-loop [94] 100.0% [96] 328(0.2%) 328(0.2%) do-chaperone-procedure ...et/private/kw.rkt:1616:2 -------------------------------------------------------------------------