LLVMFuzzerTestOneInput:
   26|  7.78k|{
   27|  7.78k|    auto guard = immer::gc_disable_guard{};
   28|       |
   29|  7.78k|    constexpr auto var_count = 4;
   30|  7.78k|    constexpr auto bits      = 2;
   31|       |
   32|  7.78k|    using vector_t    = immer::flex_vector<int, gc_memory, bits, bits>;
   33|  7.78k|    using transient_t = typename vector_t::transient_type;
   34|  7.78k|    using size_t      = std::uint8_t;
   35|       |
   36|  7.78k|    auto vs = std::array<vector_t, var_count>{};
   37|  7.78k|    auto ts = std::array<transient_t, var_count>{};
   38|       |
   39|  7.78k|    auto is_valid_var = [&](auto idx) { return idx >= 0 && idx < var_count; };
   40|  7.78k|    auto is_valid_var_neq = [](auto other) {
   41|  7.78k|        return [=](auto idx) {
   42|  7.78k|            return idx >= 0 && idx < var_count && idx != other;
   43|  7.78k|        };
   44|  7.78k|    };
   45|  7.78k|    auto is_valid_index = [](auto& v) {
   46|  7.78k|        return [&](auto idx) { return idx >= 0 && idx < v.size(); };
   47|  7.78k|    };
   48|  7.78k|    auto is_valid_size = [](auto& v) {
   49|  7.78k|        return [&](auto idx) { return idx >= 0 && idx <= v.size(); };
   50|  7.78k|    };
   51|  7.78k|    auto can_concat = [](auto&& v1, auto&& v2) {
   52|  7.78k|        return v1.size() + v2.size() < vector_t::max_size();
   53|  7.78k|    };
   54|       |
   55|  7.78k|    return fuzzer_input{data, size}.run([&](auto& in) {
   56|  7.78k|        enum ops
   57|  7.78k|        {
   58|  7.78k|            op_transient,
   59|  7.78k|            op_persistent,
   60|  7.78k|            op_push_back,
   61|  7.78k|            op_update,
   62|  7.78k|            op_take,
   63|  7.78k|            op_drop,
   64|  7.78k|            op_concat,
   65|  7.78k|            op_push_back_mut,
   66|  7.78k|            op_update_mut,
   67|  7.78k|            op_take_mut,
   68|  7.78k|            op_drop_mut,
   69|  7.78k|            op_prepend_mut,
   70|  7.78k|            op_prepend_mut_move,
   71|  7.78k|            op_append_mut,
   72|  7.78k|            op_append_mut_move,
   73|  7.78k|        };
   74|  7.78k|        auto dst = read<char>(in, is_valid_var);
   75|  7.78k|        switch (read<char>(in)) {
   76|  7.78k|        case op_transient: {
   77|  7.78k|            auto src = read<char>(in, is_valid_var);
   78|  7.78k|            ts[dst]  = vs[src].transient();
   79|  7.78k|            break;
   80|  7.78k|        }
   81|  7.78k|        case op_persistent: {
   82|  7.78k|            auto src = read<char>(in, is_valid_var);
   83|  7.78k|            vs[dst]  = ts[src].persistent();
   84|  7.78k|            break;
   85|  7.78k|        }
   86|  7.78k|        case op_push_back: {
   87|  7.78k|            auto src = read<char>(in, is_valid_var);
   88|  7.78k|            vs[dst]  = vs[src].push_back(42);
   89|  7.78k|            break;
   90|  7.78k|        }
   91|  7.78k|        case op_update: {
   92|  7.78k|            auto src = read<char>(in, is_valid_var);
   93|  7.78k|            auto idx = read<size_t>(in, is_valid_index(vs[src]));
   94|  7.78k|            vs[dst]  = vs[src].update(idx, [](auto x) { return x + 1; });
   95|  7.78k|            break;
   96|  7.78k|        }
   97|  7.78k|        case op_take: {
   98|  7.78k|            auto src = read<char>(in, is_valid_var);
   99|  7.78k|            auto idx = read<size_t>(in, is_valid_size(vs[src]));
  100|  7.78k|            vs[dst]  = vs[src].take(idx);
  101|  7.78k|            break;
  102|  7.78k|        }
  103|  7.78k|        case op_drop: {
  104|  7.78k|            auto src = read<char>(in, is_valid_var);
  105|  7.78k|            auto idx = read<size_t>(in, is_valid_size(vs[src]));
  106|  7.78k|            vs[dst]  = vs[src].drop(idx);
  107|  7.78k|            break;
  108|  7.78k|        }
  109|  7.78k|        case op_concat: {
  110|  7.78k|            auto src  = read<char>(in, is_valid_var);
  111|  7.78k|            auto src2 = read<char>(in, is_valid_var);
  112|  7.78k|            if (can_concat(vs[src], vs[src2]))
  113|  7.78k|                vs[dst] = vs[src] + vs[src2];
  114|  7.78k|            break;
  115|  7.78k|        }
  116|  7.78k|        case op_push_back_mut: {
  117|  7.78k|            ts[dst].push_back(13);
  118|  7.78k|            break;
  119|  7.78k|        }
  120|  7.78k|        case op_update_mut: {
  121|  7.78k|            auto idx = read<size_t>(in, is_valid_index(ts[dst]));
  122|  7.78k|            ts[dst].update(idx, [](auto x) { return x + 1; });
  123|  7.78k|            break;
  124|  7.78k|        }
  125|  7.78k|        case op_take_mut: {
  126|  7.78k|            auto idx = read<size_t>(in, is_valid_size(ts[dst]));
  127|  7.78k|            ts[dst].take(idx);
  128|  7.78k|            break;
  129|  7.78k|        }
  130|  7.78k|        case op_prepend_mut: {
  131|  7.78k|            auto src = read<char>(in, is_valid_var_neq(dst));
  132|  7.78k|            if (can_concat(ts[dst], ts[src]))
  133|  7.78k|                ts[dst].prepend(ts[src]);
  134|  7.78k|            break;
  135|  7.78k|        }
  136|  7.78k|        case op_prepend_mut_move: {
  137|  7.78k|            auto src = read<char>(in, is_valid_var_neq(dst));
  138|  7.78k|            if (can_concat(ts[dst], ts[src])) {
  139|  7.78k|                ts[dst].prepend(std::move(ts[src]));
  140|  7.78k|                ts[src] = {};
  141|  7.78k|            }
  142|  7.78k|            break;
  143|  7.78k|        }
  144|  7.78k|        case op_append_mut: {
  145|  7.78k|            auto src = read<char>(in, is_valid_var_neq(dst));
  146|  7.78k|            if (can_concat(ts[dst], ts[src]))
  147|  7.78k|                ts[dst].append(ts[src]);
  148|  7.78k|            break;
  149|  7.78k|        }
  150|  7.78k|        case op_append_mut_move: {
  151|  7.78k|            auto src = read<char>(in, is_valid_var_neq(dst));
  152|  7.78k|            if (can_concat(ts[dst], ts[src])) {
  153|  7.78k|                ts[dst].append(std::move(ts[src]));
  154|  7.78k|                ts[src] = {};
  155|  7.78k|            }
  156|  7.78k|            break;
  157|  7.78k|        }
  158|  7.78k|        default:
  159|  7.78k|            break;
  160|  7.78k|        };
  161|  7.78k|        return true;
  162|  7.78k|    });
  163|  7.78k|}
flex-vector-gc.cpp:_ZZ22LLVMFuzzerTestOneInputENK3$_5clI12fuzzer_inputEEDaRT_:
   55|  2.31M|    return fuzzer_input{data, size}.run([&](auto& in) {
   56|  2.31M|        enum ops
   57|  2.31M|        {
   58|  2.31M|            op_transient,
   59|  2.31M|            op_persistent,
   60|  2.31M|            op_push_back,
   61|  2.31M|            op_update,
   62|  2.31M|            op_take,
   63|  2.31M|            op_drop,
   64|  2.31M|            op_concat,
   65|  2.31M|            op_push_back_mut,
   66|  2.31M|            op_update_mut,
   67|  2.31M|            op_take_mut,
   68|  2.31M|            op_drop_mut,
   69|  2.31M|            op_prepend_mut,
   70|  2.31M|            op_prepend_mut_move,
   71|  2.31M|            op_append_mut,
   72|  2.31M|            op_append_mut_move,
   73|  2.31M|        };
   74|  2.31M|        auto dst = read<char>(in, is_valid_var);
   75|  2.31M|        switch (read<char>(in)) {
   76|   116k|        case op_transient: {
  ------------------
  |  Branch (76:9): [True: 116k, False: 2.20M]
  ------------------
   77|   116k|            auto src = read<char>(in, is_valid_var);
   78|   116k|            ts[dst]  = vs[src].transient();
   79|   116k|            break;
   80|      0|        }
   81|  21.6k|        case op_persistent: {
  ------------------
  |  Branch (81:9): [True: 21.6k, False: 2.29M]
  ------------------
   82|  21.6k|            auto src = read<char>(in, is_valid_var);
   83|  21.6k|            vs[dst]  = ts[src].persistent();
   84|  21.6k|            break;
   85|      0|        }
   86|  67.6k|        case op_push_back: {
  ------------------
  |  Branch (86:9): [True: 67.6k, False: 2.25M]
  ------------------
   87|  67.6k|            auto src = read<char>(in, is_valid_var);
   88|  67.6k|            vs[dst]  = vs[src].push_back(42);
   89|  67.6k|            break;
   90|      0|        }
   91|  5.68k|        case op_update: {
  ------------------
  |  Branch (91:9): [True: 5.68k, False: 2.31M]
  ------------------
   92|  5.68k|            auto src = read<char>(in, is_valid_var);
   93|  5.68k|            auto idx = read<size_t>(in, is_valid_index(vs[src]));
   94|  5.68k|            vs[dst]  = vs[src].update(idx, [](auto x) { return x + 1; });
   95|  5.68k|            break;
   96|      0|        }
   97|  12.6k|        case op_take: {
  ------------------
  |  Branch (97:9): [True: 12.6k, False: 2.30M]
  ------------------
   98|  12.6k|            auto src = read<char>(in, is_valid_var);
   99|  12.6k|            auto idx = read<size_t>(in, is_valid_size(vs[src]));
  100|  12.6k|            vs[dst]  = vs[src].take(idx);
  101|  12.6k|            break;
  102|      0|        }
  103|  18.1k|        case op_drop: {
  ------------------
  |  Branch (103:9): [True: 18.1k, False: 2.29M]
  ------------------
  104|  18.1k|            auto src = read<char>(in, is_valid_var);
  105|  18.1k|            auto idx = read<size_t>(in, is_valid_size(vs[src]));
  106|  18.1k|            vs[dst]  = vs[src].drop(idx);
  107|  18.1k|            break;
  108|      0|        }
  109|  60.1k|        case op_concat: {
  ------------------
  |  Branch (109:9): [True: 60.1k, False: 2.25M]
  ------------------
  110|  60.1k|            auto src  = read<char>(in, is_valid_var);
  111|  60.1k|            auto src2 = read<char>(in, is_valid_var);
  112|  60.1k|            if (can_concat(vs[src], vs[src2]))
  ------------------
  |  Branch (112:17): [True: 57.8k, False: 2.35k]
  ------------------
  113|  57.8k|                vs[dst] = vs[src] + vs[src2];
  114|  60.1k|            break;
  115|      0|        }
  116|  49.0k|        case op_push_back_mut: {
  ------------------
  |  Branch (116:9): [True: 49.0k, False: 2.26M]
  ------------------
  117|  49.0k|            ts[dst].push_back(13);
  118|  49.0k|            break;
  119|      0|        }
  120|  11.4k|        case op_update_mut: {
  ------------------
  |  Branch (120:9): [True: 11.4k, False: 2.30M]
  ------------------
  121|  11.4k|            auto idx = read<size_t>(in, is_valid_index(ts[dst]));
  122|  11.4k|            ts[dst].update(idx, [](auto x) { return x + 1; });
  123|  11.4k|            break;
  124|      0|        }
  125|  40.4k|        case op_take_mut: {
  ------------------
  |  Branch (125:9): [True: 40.4k, False: 2.27M]
  ------------------
  126|  40.4k|            auto idx = read<size_t>(in, is_valid_size(ts[dst]));
  127|  40.4k|            ts[dst].take(idx);
  128|  40.4k|            break;
  129|      0|        }
  130|  36.7k|        case op_prepend_mut: {
  ------------------
  |  Branch (130:9): [True: 36.7k, False: 2.28M]
  ------------------
  131|  36.7k|            auto src = read<char>(in, is_valid_var_neq(dst));
  132|  36.7k|            if (can_concat(ts[dst], ts[src]))
  ------------------
  |  Branch (132:17): [True: 33.8k, False: 2.96k]
  ------------------
  133|  33.8k|                ts[dst].prepend(ts[src]);
  134|  36.7k|            break;
  135|      0|        }
  136|  4.78k|        case op_prepend_mut_move: {
  ------------------
  |  Branch (136:9): [True: 4.78k, False: 2.31M]
  ------------------
  137|  4.78k|            auto src = read<char>(in, is_valid_var_neq(dst));
  138|  4.78k|            if (can_concat(ts[dst], ts[src])) {
  ------------------
  |  Branch (138:17): [True: 4.19k, False: 583]
  ------------------
  139|  4.19k|                ts[dst].prepend(std::move(ts[src]));
  140|  4.19k|                ts[src] = {};
  141|  4.19k|            }
  142|  4.78k|            break;
  143|      0|        }
  144|  1.82M|        case op_append_mut: {
  ------------------
  |  Branch (144:9): [True: 1.82M, False: 492k]
  ------------------
  145|  1.82M|            auto src = read<char>(in, is_valid_var_neq(dst));
  146|  1.82M|            if (can_concat(ts[dst], ts[src]))
  ------------------
  |  Branch (146:17): [True: 1.79M, False: 28.0k]
  ------------------
  147|  1.79M|                ts[dst].append(ts[src]);
  148|  1.82M|            break;
  149|      0|        }
  150|  6.36k|        case op_append_mut_move: {
  ------------------
  |  Branch (150:9): [True: 6.36k, False: 2.31M]
  ------------------
  151|  6.36k|            auto src = read<char>(in, is_valid_var_neq(dst));
  152|  6.36k|            if (can_concat(ts[dst], ts[src])) {
  ------------------
  |  Branch (152:17): [True: 5.91k, False: 449]
  ------------------
  153|  5.91k|                ts[dst].append(std::move(ts[src]));
  154|  5.91k|                ts[src] = {};
  155|  5.91k|            }
  156|  6.36k|            break;
  157|      0|        }
  158|  33.6k|        default:
  ------------------
  |  Branch (158:9): [True: 33.6k, False: 2.28M]
  ------------------
  159|  33.6k|            break;
  160|  2.31M|        };
  161|  2.31M|        return true;
  162|  2.31M|    });
flex-vector-gc.cpp:_ZZ22LLVMFuzzerTestOneInputENK3$_0clIcEEDaT_:
   39|  2.93M|    auto is_valid_var = [&](auto idx) { return idx >= 0 && idx < var_count; };
  ------------------
  |  Branch (39:48): [True: 2.85M, False: 86.4k]
  |  Branch (39:60): [True: 2.67M, False: 177k]
  ------------------
flex-vector-gc.cpp:_ZZZ22LLVMFuzzerTestOneInputENK3$_2clIN5immer11flex_vectorIiNS1_13memory_policyINS1_11heap_policyINS1_7gc_heapEEENS1_18no_refcount_policyENS1_15spinlock_policyENS1_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEEDaRT_ENKUlSC_E_clIhEEDaSC_:
   46|  8.14k|        return [&](auto idx) { return idx >= 0 && idx < v.size(); };
  ------------------
  |  Branch (46:39): [True: 8.14k, False: 0]
  |  Branch (46:51): [True: 5.60k, False: 2.53k]
  ------------------
flex-vector-gc.cpp:_ZZ22LLVMFuzzerTestOneInputENK3$_2clIN5immer11flex_vectorIiNS1_13memory_policyINS1_11heap_policyINS1_7gc_heapEEENS1_18no_refcount_policyENS1_15spinlock_policyENS1_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEEDaRT_:
   45|  5.63k|    auto is_valid_index = [](auto& v) {
   46|  5.63k|        return [&](auto idx) { return idx >= 0 && idx < v.size(); };
   47|  5.63k|    };
flex-vector-gc.cpp:_ZZZ22LLVMFuzzerTestOneInputENK3$_5clI12fuzzer_inputEEDaRT_ENKUlS2_E_clIiEEDaS2_:
   94|  5.60k|            vs[dst]  = vs[src].update(idx, [](auto x) { return x + 1; });
flex-vector-gc.cpp:_ZZZ22LLVMFuzzerTestOneInputENK3$_3clIN5immer11flex_vectorIiNS1_13memory_policyINS1_11heap_policyINS1_7gc_heapEEENS1_18no_refcount_policyENS1_15spinlock_policyENS1_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEEDaRT_ENKUlSC_E_clIhEEDaSC_:
   49|  50.3k|        return [&](auto idx) { return idx >= 0 && idx <= v.size(); };
  ------------------
  |  Branch (49:39): [True: 50.3k, False: 0]
  |  Branch (49:51): [True: 30.6k, False: 19.7k]
  ------------------
flex-vector-gc.cpp:_ZZ22LLVMFuzzerTestOneInputENK3$_3clIN5immer11flex_vectorIiNS1_13memory_policyINS1_11heap_policyINS1_7gc_heapEEENS1_18no_refcount_policyENS1_15spinlock_policyENS1_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEEDaRT_:
   48|  30.7k|    auto is_valid_size = [](auto& v) {
   49|  30.7k|        return [&](auto idx) { return idx >= 0 && idx <= v.size(); };
   50|  30.7k|    };
flex-vector-gc.cpp:_ZZ22LLVMFuzzerTestOneInputENK3$_4clIRN5immer11flex_vectorIiNS1_13memory_policyINS1_11heap_policyINS1_7gc_heapEEENS1_18no_refcount_policyENS1_15spinlock_policyENS1_20gc_transience_policyELb0ELb0EEELj2ELj2EEESC_EEDaOT_OT0_:
   51|  60.1k|    auto can_concat = [](auto&& v1, auto&& v2) {
   52|  60.1k|        return v1.size() + v2.size() < vector_t::max_size();
   53|  60.1k|    };
flex-vector-gc.cpp:_ZZZ22LLVMFuzzerTestOneInputENK3$_2clIN5immer21flex_vector_transientIiNS1_13memory_policyINS1_11heap_policyINS1_7gc_heapEEENS1_18no_refcount_policyENS1_15spinlock_policyENS1_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEEDaRT_ENKUlSC_E_clIhEEDaSC_:
   46|  12.9k|        return [&](auto idx) { return idx >= 0 && idx < v.size(); };
  ------------------
  |  Branch (46:39): [True: 12.9k, False: 0]
  |  Branch (46:51): [True: 11.4k, False: 1.53k]
  ------------------
flex-vector-gc.cpp:_ZZ22LLVMFuzzerTestOneInputENK3$_2clIN5immer21flex_vector_transientIiNS1_13memory_policyINS1_11heap_policyINS1_7gc_heapEEENS1_18no_refcount_policyENS1_15spinlock_policyENS1_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEEDaRT_:
   45|  11.4k|    auto is_valid_index = [](auto& v) {
   46|  11.4k|        return [&](auto idx) { return idx >= 0 && idx < v.size(); };
   47|  11.4k|    };
flex-vector-gc.cpp:_ZZZ22LLVMFuzzerTestOneInputENK3$_5clI12fuzzer_inputEEDaRT_ENKUlS2_E0_clIiEEDaS2_:
  122|  11.4k|            ts[dst].update(idx, [](auto x) { return x + 1; });
flex-vector-gc.cpp:_ZZZ22LLVMFuzzerTestOneInputENK3$_3clIN5immer21flex_vector_transientIiNS1_13memory_policyINS1_11heap_policyINS1_7gc_heapEEENS1_18no_refcount_policyENS1_15spinlock_policyENS1_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEEDaRT_ENKUlSC_E_clIhEEDaSC_:
   49|  42.9k|        return [&](auto idx) { return idx >= 0 && idx <= v.size(); };
  ------------------
  |  Branch (49:39): [True: 42.9k, False: 0]
  |  Branch (49:51): [True: 40.4k, False: 2.51k]
  ------------------
flex-vector-gc.cpp:_ZZ22LLVMFuzzerTestOneInputENK3$_3clIN5immer21flex_vector_transientIiNS1_13memory_policyINS1_11heap_policyINS1_7gc_heapEEENS1_18no_refcount_policyENS1_15spinlock_policyENS1_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEEDaRT_:
   48|  40.4k|    auto is_valid_size = [](auto& v) {
   49|  40.4k|        return [&](auto idx) { return idx >= 0 && idx <= v.size(); };
   50|  40.4k|    };
flex-vector-gc.cpp:_ZZZ22LLVMFuzzerTestOneInputENK3$_1clIcEEDaT_ENKUlS1_E_clIcEEDaS1_:
   41|  1.92M|        return [=](auto idx) {
   42|  1.92M|            return idx >= 0 && idx < var_count && idx != other;
  ------------------
  |  Branch (42:20): [True: 1.91M, False: 12.6k]
  |  Branch (42:32): [True: 1.88M, False: 27.3k]
  |  Branch (42:51): [True: 1.87M, False: 13.9k]
  ------------------
   43|  1.92M|        };
flex-vector-gc.cpp:_ZZ22LLVMFuzzerTestOneInputENK3$_1clIcEEDaT_:
   40|  1.87M|    auto is_valid_var_neq = [](auto other) {
   41|  1.87M|        return [=](auto idx) {
   42|  1.87M|            return idx >= 0 && idx < var_count && idx != other;
   43|  1.87M|        };
   44|  1.87M|    };
flex-vector-gc.cpp:_ZZ22LLVMFuzzerTestOneInputENK3$_4clIRN5immer21flex_vector_transientIiNS1_13memory_policyINS1_11heap_policyINS1_7gc_heapEEENS1_18no_refcount_policyENS1_15spinlock_policyENS1_20gc_transience_policyELb0ELb0EEELj2ELj2EEESC_EEDaOT_OT0_:
   51|  1.87M|    auto can_concat = [](auto&& v1, auto&& v2) {
   52|  1.87M|        return v1.size() + v2.size() < vector_t::max_size();
   53|  1.87M|    };

flex-vector-gc.cpp:_ZN12fuzzer_input3runIZ22LLVMFuzzerTestOneInputE3$_5EEiT_:
   50|  7.78k|    {
   51|  7.78k|        if (size_ > fuzzer_input_max_size)
  ------------------
  |  Branch (51:13): [True: 12, False: 7.77k]
  ------------------
   52|     12|            return 0;
   53|  7.77k|        try {
   54|  2.31M|            while (step(*this))
  ------------------
  |  Branch (54:20): [True: 2.31M, False: 7.77k]
  ------------------
   55|  2.31M|                continue;
   56|  7.77k|        } catch (const no_more_input&) {
   57|  7.77k|        };
   58|  7.77k|        return 0;
   59|  7.77k|    }
flex-vector-gc.cpp:_Z4readIcZ22LLVMFuzzerTestOneInputE3$_0ET_R12fuzzer_inputT0_:
   70|  2.68M|{
   71|  2.68M|    auto x = read<T>(fz);
   72|  2.94M|    while (!cond(x))
  ------------------
  |  Branch (72:12): [True: 264k, False: 2.68M]
  ------------------
   73|   264k|        x = read<T>(fz);
   74|  2.68M|    return x;
   75|  2.68M|}
_Z4readIcERKT_R12fuzzer_input:
   64|  7.18M|{
   65|  7.18M|    return *reinterpret_cast<const T*>(fz.next(sizeof(T), alignof(T)));
   66|  7.18M|}
_ZN12fuzzer_input4nextEmm:
   40|  7.29M|    {
   41|  7.29M|        auto& p = const_cast<void*&>(reinterpret_cast<const void*&>(data_));
   42|  7.29M|        auto r  = std::align(align, size, p, size_);
   43|  7.29M|        if (r == nullptr)
  ------------------
  |  Branch (43:13): [True: 7.77k, False: 7.29M]
  ------------------
   44|  7.77k|            throw no_more_input{};
   45|  7.29M|        return next(size);
   46|  7.29M|    }
_ZN12fuzzer_input4nextEm:
   30|  7.29M|    {
   31|  7.29M|        if (size_ < size)
  ------------------
  |  Branch (31:13): [True: 0, False: 7.29M]
  ------------------
   32|      0|            throw no_more_input{};
   33|  7.29M|        auto r = data_;
   34|  7.29M|        data_ += size;
   35|  7.29M|        size_ -= size;
   36|  7.29M|        return r;
   37|  7.29M|    }
flex-vector-gc.cpp:_Z4readIhZZ22LLVMFuzzerTestOneInputENK3$_2clIN5immer11flex_vectorIiNS2_13memory_policyINS2_11heap_policyINS2_7gc_heapEEENS2_18no_refcount_policyENS2_15spinlock_policyENS2_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEEDaRT_EUlSD_E_ESD_R12fuzzer_inputT0_:
   70|  5.63k|{
   71|  5.63k|    auto x = read<T>(fz);
   72|  8.17k|    while (!cond(x))
  ------------------
  |  Branch (72:12): [True: 2.53k, False: 5.63k]
  ------------------
   73|  2.53k|        x = read<T>(fz);
   74|  5.63k|    return x;
   75|  5.63k|}
_Z4readIhERKT_R12fuzzer_input:
   64|   114k|{
   65|   114k|    return *reinterpret_cast<const T*>(fz.next(sizeof(T), alignof(T)));
   66|   114k|}
flex-vector-gc.cpp:_Z4readIhZZ22LLVMFuzzerTestOneInputENK3$_3clIN5immer11flex_vectorIiNS2_13memory_policyINS2_11heap_policyINS2_7gc_heapEEENS2_18no_refcount_policyENS2_15spinlock_policyENS2_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEEDaRT_EUlSD_E_ESD_R12fuzzer_inputT0_:
   70|  30.7k|{
   71|  30.7k|    auto x = read<T>(fz);
   72|  50.4k|    while (!cond(x))
  ------------------
  |  Branch (72:12): [True: 19.7k, False: 30.7k]
  ------------------
   73|  19.7k|        x = read<T>(fz);
   74|  30.7k|    return x;
   75|  30.7k|}
flex-vector-gc.cpp:_Z4readIhZZ22LLVMFuzzerTestOneInputENK3$_2clIN5immer21flex_vector_transientIiNS2_13memory_policyINS2_11heap_policyINS2_7gc_heapEEENS2_18no_refcount_policyENS2_15spinlock_policyENS2_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEEDaRT_EUlSD_E_ESD_R12fuzzer_inputT0_:
   70|  11.4k|{
   71|  11.4k|    auto x = read<T>(fz);
   72|  13.0k|    while (!cond(x))
  ------------------
  |  Branch (72:12): [True: 1.53k, False: 11.4k]
  ------------------
   73|  1.53k|        x = read<T>(fz);
   74|  11.4k|    return x;
   75|  11.4k|}
flex-vector-gc.cpp:_Z4readIhZZ22LLVMFuzzerTestOneInputENK3$_3clIN5immer21flex_vector_transientIiNS2_13memory_policyINS2_11heap_policyINS2_7gc_heapEEENS2_18no_refcount_policyENS2_15spinlock_policyENS2_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEEDaRT_EUlSD_E_ESD_R12fuzzer_inputT0_:
   70|  40.4k|{
   71|  40.4k|    auto x = read<T>(fz);
   72|  42.9k|    while (!cond(x))
  ------------------
  |  Branch (72:12): [True: 2.51k, False: 40.4k]
  ------------------
   73|  2.51k|        x = read<T>(fz);
   74|  40.4k|    return x;
   75|  40.4k|}
flex-vector-gc.cpp:_Z4readIcZZ22LLVMFuzzerTestOneInputENK3$_1clIcEEDaT_EUlS2_E_ES2_R12fuzzer_inputT0_:
   70|  1.87M|{
   71|  1.87M|    auto x = read<T>(fz);
   72|  1.92M|    while (!cond(x))
  ------------------
  |  Branch (72:12): [True: 53.8k, False: 1.87M]
  ------------------
   73|  53.8k|        x = read<T>(fz);
   74|  1.87M|    return x;
   75|  1.87M|}

_ZN5immer6detail3csl3getINS_18no_refcount_policyEEEDcRKNS1_10member_twoINS0_4rbts4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEES3_NS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE11impl_data_tENS1_7inheritIS3_NS1_6memberINSC_5applyISA_E4type5owneeEvE4typeEE4typeEE4typeE:
  170|  20.7M|        {
  171|  20.7M|            return x.get_(type_t<U>{});
  172|  20.7M|        }
_ZNK5immer6detail3csl10member_twoINS0_4rbts4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE11impl_data_tENS1_7inheritIS9_NS1_6memberINSB_5applyIS8_E4type5owneeEvE4typeEE4typeEE4type4get_IS9_EEDcNS1_6type_tIT_EE:
  184|  20.7M|        {
  185|  20.7M|            return n.get_(t);
  186|  20.7M|        }
_ZNK5immer6detail3csl7inheritINS_18no_refcount_policyENS1_6memberINS_20gc_transience_policy5applyINS_11heap_policyINS_7gc_heapEEEE4type5owneeEvE4typeEE4type4get_ENS1_6type_tIS3_EE:
   82|  22.1M|        const T& get_(type_t<T>) const { return *this; }
_ZN5immer6detail3csl3getINS_18no_refcount_policyEEEDcRKNS1_10member_twoINS0_4rbts4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEES3_NS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE14relaxed_data_tENS1_7inheritIS3_NS1_6memberINSC_5applyISA_E4type5owneeEvE4typeEE4typeEE4typeE:
  170|  1.36M|        {
  171|  1.36M|            return x.get_(type_t<U>{});
  172|  1.36M|        }
_ZNK5immer6detail3csl10member_twoINS0_4rbts4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE14relaxed_data_tENS1_7inheritIS9_NS1_6memberINSB_5applyIS8_E4type5owneeEvE4typeEE4typeEE4type4get_IS9_EEDcNS1_6type_tIT_EE:
  184|  1.36M|        {
  185|  1.36M|            return n.get_(t);
  186|  1.36M|        }
_ZN5immer6detail3csl3getINS_20gc_transience_policy5applyINS_11heap_policyINS_7gc_heapEEEE4type5owneeEEEDcRNS1_10member_twoINS0_4rbts4nodeIiNS_13memory_policyIS7_NS_18no_refcount_policyENS_15spinlock_policyES3_Lb0ELb0EEELj2ELj2EE14relaxed_data_tENS1_7inheritISF_NS1_6memberISA_vE4typeEE4typeEE4typeE:
  165|  2.57M|        {
  166|  2.57M|            return x.get_(type_t<U>{});
  167|  2.57M|        }
_ZN5immer6detail3csl10member_twoINS0_4rbts4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE14relaxed_data_tENS1_7inheritIS9_NS1_6memberINSB_5applyIS8_E4type5owneeEvE4typeEE4typeEE4type4get_ISK_EEDcNS1_6type_tIT_EE:
  179|  2.57M|        {
  180|  2.57M|            return n.get_(t);
  181|  2.57M|        }
_ZN5immer6detail3csl6memberINS_20gc_transience_policy5applyINS_11heap_policyINS_7gc_heapEEEE4type5owneeEvE4type4get_ENS1_6type_tISA_EE:
  150|  5.50M|        T& get_(type_t<T>) { return d; }
_ZN5immer6detail3csl3getINS_20gc_transience_policy5applyINS_11heap_policyINS_7gc_heapEEEE4type5owneeEEEDcRNS1_10member_twoINS0_4rbts4nodeIiNS_13memory_policyIS7_NS_18no_refcount_policyENS_15spinlock_policyES3_Lb0ELb0EEELj2ELj2EE11impl_data_tENS1_7inheritISF_NS1_6memberISA_vE4typeEE4typeEE4typeE:
  165|  2.92M|        {
  166|  2.92M|            return x.get_(type_t<U>{});
  167|  2.92M|        }
_ZN5immer6detail3csl10member_twoINS0_4rbts4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE11impl_data_tENS1_7inheritIS9_NS1_6memberINSB_5applyIS8_E4type5owneeEvE4typeEE4typeEE4type4get_ISK_EEDcNS1_6type_tIT_EE:
  179|  2.92M|        {
  180|  2.92M|            return n.get_(t);
  181|  2.92M|        }
_ZN5immer6detail3csl3getINS_20gc_transience_policy5applyINS_11heap_policyINS_7gc_heapEEEE4type5owneeEEEDcRKNS1_10member_twoINS0_4rbts4nodeIiNS_13memory_policyIS7_NS_18no_refcount_policyENS_15spinlock_policyES3_Lb0ELb0EEELj2ELj2EE11impl_data_tENS1_7inheritISF_NS1_6memberISA_vE4typeEE4typeEE4typeE:
  170|  14.5M|        {
  171|  14.5M|            return x.get_(type_t<U>{});
  172|  14.5M|        }
_ZNK5immer6detail3csl10member_twoINS0_4rbts4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE11impl_data_tENS1_7inheritIS9_NS1_6memberINSB_5applyIS8_E4type5owneeEvE4typeEE4typeEE4type4get_ISK_EEDcNS1_6type_tIT_EE:
  184|  14.5M|        {
  185|  14.5M|            return n.get_(t);
  186|  14.5M|        }
_ZNK5immer6detail3csl6memberINS_20gc_transience_policy5applyINS_11heap_policyINS_7gc_heapEEEE4type5owneeEvE4type4get_ENS1_6type_tISA_EE:
  151|  14.5M|        const T& get_(type_t<T>) const { return d; }

_ZN5immer6detail4rbts4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE17make_inner_n_intoEPvmj:
  213|  68.3k|    {
  214|  68.3k|        assert(n <= branches<B>);
  ------------------
  |  Branch (214:9): [True: 68.3k, False: 0]
  ------------------
  215|  68.3k|        assert(size >= sizeof_inner_n(n));
  ------------------
  |  Branch (215:9): [True: 68.3k, False: 0]
  ------------------
  216|  68.3k|        auto p                       = new (buffer) node_t;
  217|  68.3k|        p->impl.d.data.inner.relaxed = nullptr;
  218|  68.3k|#if IMMER_TAGGED_NODE
  219|  68.3k|        p->impl.d.kind = node_t::kind_t::inner;
  220|  68.3k|#endif
  221|  68.3k|        return p;
  222|  68.3k|    }
_ZN5immer6detail4rbts4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE14sizeof_inner_nEj:
  145|   205k|    {
  146|   205k|        return keep_headroom ? max_sizeof_inner : sizeof_packed_inner_n(n);
  ------------------
  |  Branch (146:16): [Folded, False: 205k]
  ------------------
  147|   205k|    }
_ZN5immer6detail4rbts4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE21sizeof_packed_inner_nEj:
  114|   898k|    {
  115|       |        return immer_offsetof(impl_t, d.data.inner) +
  ------------------
  |  |   19|   898k|#define immer_offsetof offsetof
  ------------------
  116|   898k|               inner_t::get_storage_offset() +
  117|   898k|               sizeof(typename inner_t::storage_type) * count;
  118|   898k|    }
_ZN5immer6detail4rbts4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE3incEv:
  956|  3.46M|    {
  957|  3.46M|        refs(this).inc();
  958|  3.46M|        return this;
  959|  3.46M|    }
_ZN5immer6detail4rbts4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE4refsEPKSB_:
  203|  20.7M|    {
  204|  20.7M|        return auto_const_cast(get<refs_t>(x->impl));
  205|  20.7M|    }
_ZN5immer6detail4rbts4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE16make_leaf_n_intoEPvmj:
  330|   122k|    {
  331|   122k|        assert(n <= branches<BL>);
  ------------------
  |  Branch (331:9): [True: 122k, False: 0]
  ------------------
  332|   122k|        assert(size >= sizeof_leaf_n(n));
  ------------------
  |  Branch (332:9): [True: 122k, False: 0]
  ------------------
  333|   122k|        auto p = new (buffer) node_t;
  334|   122k|#if IMMER_TAGGED_NODE
  335|   122k|        p->impl.d.kind = node_t::kind_t::leaf;
  336|   122k|#endif
  337|   122k|        return p;
  338|   122k|    }
_ZN5immer6detail4rbts4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE13sizeof_leaf_nEj:
  160|   366k|    {
  161|   366k|        return keep_headroom ? max_sizeof_leaf : sizeof_packed_leaf_n(n);
  ------------------
  |  Branch (161:16): [Folded, False: 366k]
  ------------------
  162|   366k|    }
_ZN5immer6detail4rbts4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE20sizeof_packed_leaf_nEj:
  107|   366k|    {
  108|       |        return immer_offsetof(impl_t, d.data.leaf) +
  ------------------
  |  |   19|   366k|#define immer_offsetof offsetof
  ------------------
  109|   366k|               leaf_t::get_storage_offset() +
  110|   366k|               sizeof(typename leaf_t::storage_type) * count;
  111|   366k|    }
_ZN5immer6detail4rbts4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE7relaxedEv:
  172|  28.9M|    {
  173|  28.9M|        IMMER_ASSERT_TAGGED(kind() == kind_t::inner);
  ------------------
  |  |   68|  28.9M|#define IMMER_ASSERT_TAGGED(assertion) assert(assertion)
  ------------------
  |  Branch (173:9): [True: 28.9M, False: 0]
  ------------------
  174|  28.9M|        return impl.d.data.inner.relaxed;
  175|  28.9M|    }
_ZNK5immer6detail4rbts4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE4kindEv:
  168|  78.9M|    kind_t kind() const { return impl.d.kind; }
_ZNK5immer6detail4rbts4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE3decEv:
  967|  2.13M|    bool dec() const { return refs(this).dec(); }
_ZN5immer6detail4rbts4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE5innerEv:
  184|  35.7M|    {
  185|  35.7M|        IMMER_ASSERT_TAGGED(kind() == kind_t::inner);
  ------------------
  |  |   68|  35.7M|#define IMMER_ASSERT_TAGGED(assertion) assert(assertion)
  ------------------
  |  Branch (185:9): [True: 35.7M, False: 0]
  ------------------
  186|  35.7M|        return impl.d.data.inner.get_storage_ptr();
  187|  35.7M|    }
_ZN5immer6detail4rbts4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE4refsEPKNS0_3csl10member_twoINSB_14relaxed_data_tENSC_7inheritIS7_NSC_6memberINS9_5applyIS6_E4type5owneeEvE4typeEE4typeEE4typeE:
  196|  1.36M|    {
  197|  1.36M|        return auto_const_cast(get<refs_t>(*x));
  198|  1.36M|    }
_ZN5immer6detail4rbts4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE5owneeEPNS0_3csl10member_twoINSB_14relaxed_data_tENSC_7inheritIS7_NSC_6memberINS9_5applyIS6_E4type5owneeEvE4typeEE4typeEE4typeE:
  200|  2.57M|    static ownee_t& ownee(relaxed_t* x) { return get<ownee_t>(*x); }
_ZN5immer6detail4rbts4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE16sizeof_relaxed_nEj:
  155|   667k|    {
  156|   667k|        return keep_headroom ? max_sizeof_relaxed : sizeof_packed_relaxed_n(n);
  ------------------
  |  Branch (156:16): [Folded, False: 667k]
  ------------------
  157|   667k|    }
_ZN5immer6detail4rbts4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE23sizeof_packed_relaxed_nEj:
  121|   667k|    {
  122|       |        return immer_offsetof(relaxed_t, d.sizes) + sizeof(size_t) * count;
  ------------------
  |  |   19|   667k|#define immer_offsetof offsetof
  ------------------
  123|   667k|    }
_ZN5immer6detail4rbts4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE5owneeEPSB_:
  210|  2.92M|    static ownee_t& ownee(node_t* x) { return get<ownee_t>(x->impl); }
_ZN5immer6detail4rbts4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE16sizeof_inner_r_nEj:
  150|   693k|    {
  151|   693k|        return keep_headroom ? max_sizeof_inner_r : sizeof_packed_inner_r_n(n);
  ------------------
  |  Branch (151:16): [Folded, False: 693k]
  ------------------
  152|   693k|    }
_ZN5immer6detail4rbts4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE23sizeof_packed_inner_r_nEj:
  126|   693k|    {
  127|   693k|        return embed_relaxed ? sizeof_packed_inner_n(count) +
  ------------------
  |  Branch (127:16): [Folded, False: 693k]
  ------------------
  128|      0|                                   sizeof_packed_relaxed_n(count)
  129|   693k|                             : sizeof_packed_inner_n(count);
  130|   693k|    }
_ZN5immer6detail4rbts4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE4leafEv:
  190|  8.73M|    {
  191|  8.73M|        IMMER_ASSERT_TAGGED(kind() == kind_t::leaf);
  ------------------
  |  |   68|  8.73M|#define IMMER_ASSERT_TAGGED(assertion) assert(assertion)
  ------------------
  |  Branch (191:9): [True: 8.73M, False: 0]
  ------------------
  192|  8.73M|        return impl.d.data.leaf.get_storage_ptr();
  193|  8.73M|    }
_ZN5immer6detail4rbts4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE17copy_leaf_emplaceIiEEPSB_SD_jOT_:
  794|  50.4k|    {
  795|  50.4k|        auto dst = copy_leaf_n(n + 1, src, n);
  796|  50.4k|        IMMER_TRY {
  ------------------
  |  |   49|  50.4k|#define IMMER_TRY try
  ------------------
  797|  50.4k|            new (dst->leaf() + n) T(std::forward<U>(x));
  798|  50.4k|        }
  799|  50.4k|        IMMER_CATCH (...) {
  800|      0|            detail::destroy_n(dst->leaf(), n);
  801|      0|            heap::deallocate(node_t::sizeof_leaf_n(n + 1), dst);
  802|      0|            IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
  803|      0|        }
  804|  50.4k|        return dst;
  805|  50.4k|    }
_ZN5immer6detail4rbts4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE11copy_leaf_nEjPSB_j:
  696|  50.4k|    {
  697|  50.4k|        assert(allocn >= n);
  ------------------
  |  Branch (697:9): [True: 50.4k, False: 0]
  ------------------
  698|  50.4k|        IMMER_ASSERT_TAGGED(src->kind() == kind_t::leaf);
  ------------------
  |  |   68|  50.4k|#define IMMER_ASSERT_TAGGED(assertion) assert(assertion)
  ------------------
  |  Branch (698:9): [True: 50.4k, False: 0]
  ------------------
  699|  50.4k|        auto dst = make_leaf_n(allocn);
  700|  50.4k|        IMMER_TRY {
  ------------------
  |  |   49|  50.4k|#define IMMER_TRY try
  ------------------
  701|  50.4k|            detail::uninitialized_copy(
  702|  50.4k|                src->leaf(), src->leaf() + n, dst->leaf());
  703|  50.4k|        }
  704|  50.4k|        IMMER_CATCH (...) {
  705|      0|            heap::deallocate(node_t::sizeof_leaf_n(allocn), dst);
  706|      0|            IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
  707|      0|        }
  708|  50.4k|        return dst;
  709|  50.4k|    }
_ZN5immer6detail4rbts4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE11make_leaf_nEj:
  341|   122k|    {
  342|   122k|        assert(n <= branches<BL>);
  ------------------
  |  Branch (342:9): [True: 122k, False: 0]
  ------------------
  343|   122k|        auto m = heap::allocate(sizeof_leaf_n(n));
  344|   122k|        return make_leaf_n_into(m, sizeof_leaf_n(n), n);
  345|   122k|    }
_ZN5immer6detail4rbts4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE11make_leaf_nIiEEPSB_jOT_:
  470|  17.1k|    {
  471|  17.1k|        assert(n >= 1);
  ------------------
  |  Branch (471:9): [True: 17.1k, False: 0]
  ------------------
  472|  17.1k|        auto p = make_leaf_n(n);
  473|  17.1k|        IMMER_TRY {
  ------------------
  |  |   49|  17.1k|#define IMMER_TRY try
  ------------------
  474|  17.1k|            new (p->leaf()) T(std::forward<U>(x));
  475|  17.1k|        }
  476|  17.1k|        IMMER_CATCH (...) {
  477|      0|            heap::deallocate(node_t::sizeof_leaf_n(n), p);
  478|      0|            IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
  479|      0|        }
  480|  17.1k|        return p;
  481|  17.1k|    }
_ZN5immer6detail4rbts4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE13do_copy_innerEPSB_SC_j:
  558|  90.2k|    {
  559|  90.2k|        IMMER_ASSERT_TAGGED(dst->kind() == kind_t::inner);
  ------------------
  |  |   68|  90.2k|#define IMMER_ASSERT_TAGGED(assertion) assert(assertion)
  ------------------
  |  Branch (559:9): [True: 90.2k, False: 0]
  ------------------
  560|  90.2k|        IMMER_ASSERT_TAGGED(src->kind() == kind_t::inner);
  ------------------
  |  |   68|  90.2k|#define IMMER_ASSERT_TAGGED(assertion) assert(assertion)
  ------------------
  |  Branch (560:9): [True: 90.2k, False: 0]
  ------------------
  561|  90.2k|        auto p = src->inner();
  562|  90.2k|        inc_nodes(p, n);
  563|  90.2k|        std::copy(p, p + n, dst->inner());
  564|  90.2k|        return dst;
  565|  90.2k|    }
_ZN5immer6detail4rbts4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE9inc_nodesEPPSB_j:
  970|   389k|    {
  971|  1.01M|        for (auto i = p, e = i + n; i != e; ++i)
  ------------------
  |  Branch (971:37): [True: 627k, False: 389k]
  ------------------
  972|   627k|            refs(*i).inc();
  973|   389k|    }
_ZN5immer6detail4rbts4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE14copy_inner_r_nEjPSB_j:
  588|  51.6k|    {
  589|  51.6k|        assert(allocn >= n);
  ------------------
  |  Branch (589:9): [True: 51.6k, False: 0]
  ------------------
  590|  51.6k|        IMMER_ASSERT_TAGGED(src->kind() == kind_t::inner);
  ------------------
  |  |   68|  51.6k|#define IMMER_ASSERT_TAGGED(assertion) assert(assertion)
  ------------------
  |  Branch (590:9): [True: 51.6k, False: 0]
  ------------------
  591|  51.6k|        auto dst = make_inner_r_n(allocn);
  592|  51.6k|        return do_copy_inner_r(dst, src, n);
  593|  51.6k|    }
_ZN5immer6detail4rbts4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE15do_copy_inner_rEPSB_SC_j:
  610|  88.7k|    {
  611|  88.7k|        IMMER_ASSERT_TAGGED(dst->kind() == kind_t::inner);
  ------------------
  |  |   68|  88.7k|#define IMMER_ASSERT_TAGGED(assertion) assert(assertion)
  ------------------
  |  Branch (611:9): [True: 88.7k, False: 0]
  ------------------
  612|  88.7k|        IMMER_ASSERT_TAGGED(src->kind() == kind_t::inner);
  ------------------
  |  |   68|  88.7k|#define IMMER_ASSERT_TAGGED(assertion) assert(assertion)
  ------------------
  |  Branch (612:9): [True: 88.7k, False: 0]
  ------------------
  613|  88.7k|        auto src_r = src->relaxed();
  614|  88.7k|        auto dst_r = dst->relaxed();
  615|  88.7k|        inc_nodes(src->inner(), n);
  616|  88.7k|        std::copy(src->inner(), src->inner() + n, dst->inner());
  617|  88.7k|        std::copy(src_r->d.sizes, src_r->d.sizes + n, dst_r->d.sizes);
  618|  88.7k|        dst_r->d.count = n;
  619|  88.7k|        return dst;
  620|  88.7k|    }
_ZN5immer6detail4rbts4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE14make_inner_r_nEj:
  243|   667k|    {
  244|   667k|        assert(n <= branches<B>);
  ------------------
  |  Branch (244:9): [True: 667k, False: 0]
  ------------------
  245|   667k|        auto mp = heap::allocate(sizeof_inner_r_n(n));
  246|   667k|        auto mr = static_cast<void*>(nullptr);
  247|   667k|        if (embed_relaxed) {
  ------------------
  |  Branch (247:13): [Folded, False: 667k]
  ------------------
  248|      0|            mr = reinterpret_cast<unsigned char*>(mp) + sizeof_inner_n(n);
  249|   667k|        } else {
  250|   667k|            IMMER_TRY {
  ------------------
  |  |   49|   667k|#define IMMER_TRY try
  ------------------
  251|   667k|                mr = heap::allocate(sizeof_relaxed_n(n), norefs_tag{});
  252|   667k|            }
  253|   667k|            IMMER_CATCH (...) {
  254|      0|                heap::deallocate(sizeof_inner_r_n(n), mp);
  255|      0|                IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
  256|      0|            }
  257|   667k|        }
  258|   667k|        auto p                       = new (mp) node_t;
  259|   667k|        auto r                       = new (mr) relaxed_t;
  260|   667k|        r->d.count                   = 0;
  261|   667k|        p->impl.d.data.inner.relaxed = r;
  262|   667k|#if IMMER_TAGGED_NODE
  263|   667k|        p->impl.d.kind = node_t::kind_t::inner;
  264|   667k|#endif
  265|   667k|        return p;
  266|   667k|    }
_ZN5immer6detail4rbts4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE9make_pathEjPSB_:
  498|  39.5k|    {
  499|  39.5k|        IMMER_ASSERT_TAGGED(node->kind() == kind_t::leaf);
  ------------------
  |  |   68|  39.5k|#define IMMER_ASSERT_TAGGED(assertion) assert(assertion)
  ------------------
  |  Branch (499:9): [True: 39.5k, False: 0]
  ------------------
  500|  39.5k|        if (shift == endshift<B, BL>)
  ------------------
  |  Branch (500:13): [True: 25.4k, False: 14.0k]
  ------------------
  501|  25.4k|            return node;
  502|  14.0k|        else {
  503|  14.0k|            auto n = node_t::make_inner_n(1);
  504|  14.0k|            IMMER_TRY {
  ------------------
  |  |   49|  14.0k|#define IMMER_TRY try
  ------------------
  505|  14.0k|                n->inner()[0] = make_path(shift - B, node);
  506|  14.0k|            }
  507|  14.0k|            IMMER_CATCH (...) {
  508|      0|                heap::deallocate(node_t::sizeof_inner_n(1), n);
  509|      0|                IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
  510|      0|            }
  511|  14.0k|            return n;
  512|  14.0k|        }
  513|  39.5k|    }
_ZN5immer6detail4rbts4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE12make_inner_nEj:
  224|  68.3k|    {
  225|  68.3k|        assert(n <= branches<B>);
  ------------------
  |  Branch (225:9): [True: 68.3k, False: 0]
  ------------------
  226|  68.3k|        auto m = heap::allocate(sizeof_inner_n(n));
  227|  68.3k|        return make_inner_n_into(m, sizeof_inner_n(n), n);
  228|  68.3k|    }
_ZN5immer6detail4rbts4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE9copy_leafEPSB_j:
  666|  12.4k|    {
  667|  12.4k|        IMMER_ASSERT_TAGGED(src->kind() == kind_t::leaf);
  ------------------
  |  |   68|  12.4k|#define IMMER_ASSERT_TAGGED(assertion) assert(assertion)
  ------------------
  |  Branch (667:9): [True: 12.4k, False: 0]
  ------------------
  668|  12.4k|        auto dst = make_leaf_n(n);
  669|  12.4k|        IMMER_TRY {
  ------------------
  |  |   49|  12.4k|#define IMMER_TRY try
  ------------------
  670|  12.4k|            detail::uninitialized_copy(
  671|  12.4k|                src->leaf(), src->leaf() + n, dst->leaf());
  672|  12.4k|        }
  673|  12.4k|        IMMER_CATCH (...) {
  674|      0|            heap::deallocate(node_t::sizeof_leaf_n(n), dst);
  675|      0|            IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
  676|      0|        }
  677|  12.4k|        return dst;
  678|  12.4k|    }
_ZN5immer6detail4rbts4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE15make_inner_sr_nEjPNS0_3csl10member_twoINSB_14relaxed_data_tENSC_7inheritIS7_NSC_6memberINS9_5applyIS6_E4type5owneeEvE4typeEE4typeEE4typeE:
  269|  26.0k|    {
  270|  26.0k|        return static_if<embed_relaxed, node_t*>(
  271|  26.0k|            [&](auto) { return node_t::make_inner_r_n(n); },
  272|  26.0k|            [&](auto) {
  273|  26.0k|                auto p =
  274|  26.0k|                    new (heap::allocate(node_t::sizeof_inner_r_n(n))) node_t;
  275|  26.0k|                assert(r->d.count >= n);
  276|  26.0k|                node_t::refs(r).inc();
  277|  26.0k|                p->impl.d.data.inner.relaxed = r;
  278|  26.0k|#if IMMER_TAGGED_NODE
  279|  26.0k|                p->impl.d.kind = node_t::kind_t::inner;
  280|  26.0k|#endif
  281|  26.0k|                return p;
  282|  26.0k|            });
  283|  26.0k|    }
_ZZN5immer6detail4rbts4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE15make_inner_sr_nEjPNS0_3csl10member_twoINSB_14relaxed_data_tENSC_7inheritIS7_NSC_6memberINS9_5applyIS6_E4type5owneeEvE4typeEE4typeEE4typeEENKUlT_E0_clINS0_7empty_tEEEDaSS_:
  272|  26.0k|            [&](auto) {
  273|  26.0k|                auto p =
  274|  26.0k|                    new (heap::allocate(node_t::sizeof_inner_r_n(n))) node_t;
  275|  26.0k|                assert(r->d.count >= n);
  ------------------
  |  Branch (275:17): [True: 26.0k, False: 0]
  ------------------
  276|  26.0k|                node_t::refs(r).inc();
  277|  26.0k|                p->impl.d.data.inner.relaxed = r;
  278|  26.0k|#if IMMER_TAGGED_NODE
  279|  26.0k|                p->impl.d.kind = node_t::kind_t::inner;
  280|  26.0k|#endif
  281|  26.0k|                return p;
  282|  26.0k|            });
_ZN5immer6detail4rbts4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE24do_copy_inner_replace_srEPSB_SC_jjSC_:
  652|  26.0k|    {
  653|  26.0k|        if (embed_relaxed)
  ------------------
  |  Branch (653:13): [Folded, False: 26.0k]
  ------------------
  654|      0|            return do_copy_inner_replace_r(dst, src, n, offset, child);
  655|  26.0k|        else {
  656|  26.0k|            auto p = src->inner();
  657|  26.0k|            inc_nodes(p, offset);
  658|  26.0k|            inc_nodes(p + offset + 1, n - offset - 1);
  659|  26.0k|            std::copy(p, p + n, dst->inner());
  660|  26.0k|            dst->inner()[offset] = child;
  661|  26.0k|            return dst;
  662|  26.0k|        }
  663|  26.0k|    }
_ZN5immer6detail4rbts4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE21do_copy_inner_replaceEPSB_SC_jjSC_:
  569|  4.42k|    {
  570|  4.42k|        IMMER_ASSERT_TAGGED(dst->kind() == kind_t::inner);
  ------------------
  |  |   68|  4.42k|#define IMMER_ASSERT_TAGGED(assertion) assert(assertion)
  ------------------
  |  Branch (570:9): [True: 4.42k, False: 0]
  ------------------
  571|  4.42k|        IMMER_ASSERT_TAGGED(src->kind() == kind_t::inner);
  ------------------
  |  |   68|  4.42k|#define IMMER_ASSERT_TAGGED(assertion) assert(assertion)
  ------------------
  |  Branch (571:9): [True: 4.42k, False: 0]
  ------------------
  572|  4.42k|        auto p = src->inner();
  573|  4.42k|        inc_nodes(p, offset);
  574|  4.42k|        inc_nodes(p + offset + 1, n - offset - 1);
  575|  4.42k|        std::copy(p, p + n, dst->inner());
  576|  4.42k|        dst->inner()[offset] = child;
  577|  4.42k|        return dst;
  578|  4.42k|    }
_ZN5immer6detail4rbts4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE12copy_inner_nEjPSB_j:
  543|  5.37k|    {
  544|  5.37k|        assert(allocn >= n);
  ------------------
  |  Branch (544:9): [True: 5.37k, False: 0]
  ------------------
  545|  5.37k|        IMMER_ASSERT_TAGGED(src->kind() == kind_t::inner);
  ------------------
  |  |   68|  5.37k|#define IMMER_ASSERT_TAGGED(assertion) assert(assertion)
  ------------------
  |  Branch (545:9): [True: 5.37k, False: 0]
  ------------------
  546|  5.37k|        auto dst = make_inner_n(allocn);
  547|  5.37k|        return do_copy_inner(dst, src, n);
  548|  5.37k|    }
_ZN5immer6detail4rbts4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE12copy_inner_rEPSB_j:
  581|  2.42k|    {
  582|  2.42k|        IMMER_ASSERT_TAGGED(src->kind() == kind_t::inner);
  ------------------
  |  |   68|  2.42k|#define IMMER_ASSERT_TAGGED(assertion) assert(assertion)
  ------------------
  |  Branch (582:9): [True: 2.42k, False: 0]
  ------------------
  583|  2.42k|        auto dst = make_inner_r_n(n);
  584|  2.42k|        return do_copy_inner_r(dst, src, n);
  585|  2.42k|    }
_ZN5immer6detail4rbts4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE13compute_shiftEv:
  977|  1.27M|    {
  978|  1.27M|        if (kind() == kind_t::leaf)
  ------------------
  |  Branch (978:13): [True: 165k, False: 1.11M]
  ------------------
  979|   165k|            return endshift<B, BL>;
  980|  1.11M|        else
  981|  1.11M|            return B + inner()[0]->compute_shift();
  982|  1.27M|    }
_ZN5immer6detail4rbts4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE5checkEjm:
  986|  60.1k|    {
  987|       |#if IMMER_DEBUG_DEEP_CHECK
  988|       |        assert(size > 0);
  989|       |        if (shift == endshift<B, BL>) {
  990|       |            IMMER_ASSERT_TAGGED(kind() == kind_t::leaf);
  991|       |            assert(size <= branches<BL>);
  992|       |        } else if (auto r = relaxed()) {
  993|       |            auto count = r->d.count;
  994|       |            assert(count > 0);
  995|       |            assert(count <= branches<B>);
  996|       |            if (r->d.sizes[count - 1] != size) {
  997|       |                IMMER_TRACE_F("check");
  998|       |                IMMER_TRACE_E(r->d.sizes[count - 1]);
  999|       |                IMMER_TRACE_E(size);
 1000|       |            }
 1001|       |            assert(r->d.sizes[count - 1] == size);
 1002|       |            for (auto i = 1u; i < count; ++i)
 1003|       |                assert(r->d.sizes[i - 1] < r->d.sizes[i]);
 1004|       |            auto last_size = size_t{};
 1005|       |            for (auto i = 0u; i < count; ++i) {
 1006|       |                assert(inner()[i]->check(shift - B, r->d.sizes[i] - last_size));
 1007|       |                last_size = r->d.sizes[i];
 1008|       |            }
 1009|       |        } else {
 1010|       |            assert(size <= branches<B> << shift);
 1011|       |            auto count =
 1012|       |                (size >> shift) + (size - ((size >> shift) << shift) > 0);
 1013|       |            assert(count <= branches<B>);
 1014|       |            if (count) {
 1015|       |                for (auto i = 1u; i < count - 1; ++i)
 1016|       |                    assert(inner()[i]->check(shift - B, 1 << shift));
 1017|       |                assert(inner()[count - 1]->check(
 1018|       |                    shift - B, size - ((count - 1) << shift)));
 1019|       |            }
 1020|       |        }
 1021|       |#endif // IMMER_DEBUG_DEEP_CHECK
 1022|  60.1k|        return true;
 1023|  60.1k|    }
_ZN5immer6detail4rbts4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE9copy_leafEPSB_jj:
  778|  17.8k|    {
  779|  17.8k|        IMMER_ASSERT_TAGGED(src->kind() == kind_t::leaf);
  ------------------
  |  |   68|  17.8k|#define IMMER_ASSERT_TAGGED(assertion) assert(assertion)
  ------------------
  |  Branch (779:9): [True: 17.8k, False: 0]
  ------------------
  780|  17.8k|        auto dst = make_leaf_n(last - idx);
  781|  17.8k|        IMMER_TRY {
  ------------------
  |  |   49|  17.8k|#define IMMER_TRY try
  ------------------
  782|  17.8k|            detail::uninitialized_copy(
  783|  17.8k|                src->leaf() + idx, src->leaf() + last, dst->leaf());
  784|  17.8k|        }
  785|  17.8k|        IMMER_CATCH (...) {
  786|      0|            heap::deallocate(node_t::sizeof_leaf_n(last - idx), dst);
  787|      0|            IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
  788|      0|        }
  789|  17.8k|        return dst;
  790|  17.8k|    }
_ZN5immer6detail4rbts4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE9copy_leafEPSB_jSC_j:
  712|  8.06k|    {
  713|  8.06k|        IMMER_ASSERT_TAGGED(src1->kind() == kind_t::leaf);
  ------------------
  |  |   68|  8.06k|#define IMMER_ASSERT_TAGGED(assertion) assert(assertion)
  ------------------
  |  Branch (713:9): [True: 8.06k, False: 0]
  ------------------
  714|  8.06k|        IMMER_ASSERT_TAGGED(src2->kind() == kind_t::leaf);
  ------------------
  |  |   68|  8.06k|#define IMMER_ASSERT_TAGGED(assertion) assert(assertion)
  ------------------
  |  Branch (714:9): [True: 8.06k, False: 0]
  ------------------
  715|  8.06k|        auto dst = make_leaf_n(n1 + n2);
  716|  8.06k|        IMMER_TRY {
  ------------------
  |  |   49|  8.06k|#define IMMER_TRY try
  ------------------
  717|  8.06k|            detail::uninitialized_copy(
  718|  8.06k|                src1->leaf(), src1->leaf() + n1, dst->leaf());
  719|  8.06k|        }
  720|  8.06k|        IMMER_CATCH (...) {
  721|      0|            heap::deallocate(node_t::sizeof_leaf_n(n1 + n2), dst);
  722|      0|            IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
  723|      0|        }
  724|  8.06k|        IMMER_TRY {
  ------------------
  |  |   49|  8.06k|#define IMMER_TRY try
  ------------------
  725|  8.06k|            detail::uninitialized_copy(
  726|  8.06k|                src2->leaf(), src2->leaf() + n2, dst->leaf() + n1);
  727|  8.06k|        }
  728|  8.06k|        IMMER_CATCH (...) {
  729|      0|            detail::destroy_n(dst->leaf(), n1);
  730|      0|            heap::deallocate(node_t::sizeof_leaf_n(n1 + n2), dst);
  731|      0|            IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
  732|      0|        }
  733|  8.06k|        return dst;
  734|  8.06k|    }
_ZNK5immer6detail4rbts4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE10can_mutateENS9_5applyIS6_E4type4editE:
  870|  14.5M|    {
  871|  14.5M|        return refs(this).unique() || ownee(this).can_mutate(e);
  ------------------
  |  Branch (871:16): [True: 0, False: 14.5M]
  |  Branch (871:39): [True: 13.5M, False: 976k]
  ------------------
  872|  14.5M|    }
_ZN5immer6detail4rbts4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE5owneeEPKSB_:
  207|  14.5M|    {
  208|  14.5M|        return get<ownee_t>(x->impl);
  209|  14.5M|    }
_ZN5immer6detail4rbts4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE11copy_leaf_eENS9_5applyIS6_E4type4editEPSB_j:
  681|  51.2k|    {
  682|  51.2k|        IMMER_ASSERT_TAGGED(src->kind() == kind_t::leaf);
  ------------------
  |  |   68|  51.2k|#define IMMER_ASSERT_TAGGED(assertion) assert(assertion)
  ------------------
  |  Branch (682:9): [True: 51.2k, False: 0]
  ------------------
  683|  51.2k|        auto dst = make_leaf_e(e);
  684|  51.2k|        IMMER_TRY {
  ------------------
  |  |   49|  51.2k|#define IMMER_TRY try
  ------------------
  685|  51.2k|            detail::uninitialized_copy(
  686|  51.2k|                src->leaf(), src->leaf() + n, dst->leaf());
  687|  51.2k|        }
  688|  51.2k|        IMMER_CATCH (...) {
  689|      0|            heap::deallocate(node_t::max_sizeof_leaf, dst);
  690|      0|            IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
  691|      0|        }
  692|  51.2k|        return dst;
  693|  51.2k|    }
_ZN5immer6detail4rbts4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE11make_leaf_eENS9_5applyIS6_E4type4editE:
  348|  1.41M|    {
  349|  1.41M|        auto p   = new (heap::allocate(max_sizeof_leaf)) node_t;
  350|  1.41M|        ownee(p) = e;
  351|  1.41M|#if IMMER_TAGGED_NODE
  352|  1.41M|        p->impl.d.kind = node_t::kind_t::leaf;
  353|  1.41M|#endif
  354|  1.41M|        return p;
  355|  1.41M|    }
_ZN5immer6detail4rbts4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE11make_leaf_eIiEEPSB_NS9_5applyIS6_E4type4editEOT_:
  485|  17.1k|    {
  486|  17.1k|        auto p = make_leaf_e(e);
  487|  17.1k|        IMMER_TRY {
  ------------------
  |  |   49|  17.1k|#define IMMER_TRY try
  ------------------
  488|  17.1k|            new (p->leaf()) T(std::forward<U>(x));
  489|  17.1k|        }
  490|  17.1k|        IMMER_CATCH (...) {
  491|      0|            heap::deallocate(node_t::max_sizeof_leaf, p);
  492|      0|            IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
  493|      0|        }
  494|  17.1k|        return p;
  495|  17.1k|    }
_ZN5immer6detail4rbts4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE24ensure_mutable_relaxed_nENS9_5applyIS6_E4type4editEj:
  930|   887k|    {
  931|   887k|        auto src_r = relaxed();
  932|   887k|        return static_if<embed_relaxed, relaxed_t*>(
  933|   887k|            [&](auto) { return src_r; },
  934|   887k|            [&](auto) {
  935|   887k|                if (node_t::refs(src_r).unique() ||
  936|   887k|                    node_t::ownee(src_r).can_mutate(e))
  937|   887k|                    return src_r;
  938|   887k|                else {
  939|   887k|                    auto dst_r =
  940|   887k|                        new (heap::allocate(max_sizeof_relaxed)) relaxed_t;
  941|   887k|                    if (src_r) {
  942|   887k|                        std::copy(
  943|   887k|                            src_r->d.sizes, src_r->d.sizes + n, dst_r->d.sizes);
  944|   887k|                        if (node_t::refs(src_r).dec())
  945|   887k|                            heap::deallocate(node_t::sizeof_inner_r_n(n),
  946|   887k|                                             src_r);
  947|   887k|                    }
  948|   887k|                    dst_r->d.count                   = n;
  949|   887k|                    node_t::ownee(dst_r)             = e;
  950|   887k|                    return impl.d.data.inner.relaxed = dst_r;
  951|   887k|                }
  952|   887k|            });
  953|   887k|    }
_ZZN5immer6detail4rbts4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE24ensure_mutable_relaxed_nENS9_5applyIS6_E4type4editEjENKUlT_E0_clINS0_7empty_tEEEDaSG_:
  934|   887k|            [&](auto) {
  935|   887k|                if (node_t::refs(src_r).unique() ||
  ------------------
  |  Branch (935:21): [True: 0, False: 887k]
  ------------------
  936|   887k|                    node_t::ownee(src_r).can_mutate(e))
  ------------------
  |  Branch (936:21): [True: 884k, False: 2.43k]
  ------------------
  937|   884k|                    return src_r;
  938|  2.43k|                else {
  939|  2.43k|                    auto dst_r =
  940|  2.43k|                        new (heap::allocate(max_sizeof_relaxed)) relaxed_t;
  941|  2.43k|                    if (src_r) {
  ------------------
  |  Branch (941:25): [True: 2.43k, False: 0]
  ------------------
  942|  2.43k|                        std::copy(
  943|  2.43k|                            src_r->d.sizes, src_r->d.sizes + n, dst_r->d.sizes);
  944|  2.43k|                        if (node_t::refs(src_r).dec())
  ------------------
  |  Branch (944:29): [True: 0, False: 2.43k]
  ------------------
  945|      0|                            heap::deallocate(node_t::sizeof_inner_r_n(n),
  946|      0|                                             src_r);
  947|  2.43k|                    }
  948|  2.43k|                    dst_r->d.count                   = n;
  949|  2.43k|                    node_t::ownee(dst_r)             = e;
  950|  2.43k|                    return impl.d.data.inner.relaxed = dst_r;
  951|  2.43k|                }
  952|   887k|            });
_ZN5immer6detail4rbts4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE14copy_inner_r_eENS9_5applyIS6_E4type4editEPSB_j:
  596|  34.6k|    {
  597|  34.6k|        IMMER_ASSERT_TAGGED(src->kind() == kind_t::inner);
  ------------------
  |  |   68|  34.6k|#define IMMER_ASSERT_TAGGED(assertion) assert(assertion)
  ------------------
  |  Branch (597:9): [True: 34.6k, False: 0]
  ------------------
  598|  34.6k|        auto dst = make_inner_r_e(e);
  599|  34.6k|        return do_copy_inner_r(dst, src, n);
  600|  34.6k|    }
_ZN5immer6detail4rbts4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE14make_inner_r_eENS9_5applyIS6_E4type4editE:
  286|   819k|    {
  287|   819k|        auto mp = heap::allocate(max_sizeof_inner_r);
  288|   819k|        auto mr = static_cast<void*>(nullptr);
  289|   819k|        if (embed_relaxed) {
  ------------------
  |  Branch (289:13): [Folded, False: 819k]
  ------------------
  290|      0|            mr = reinterpret_cast<unsigned char*>(mp) + max_sizeof_inner;
  291|   819k|        } else {
  292|   819k|            IMMER_TRY {
  ------------------
  |  |   49|   819k|#define IMMER_TRY try
  ------------------
  293|   819k|                mr = heap::allocate(max_sizeof_relaxed, norefs_tag{});
  294|   819k|            }
  295|   819k|            IMMER_CATCH (...) {
  296|      0|                heap::deallocate(max_sizeof_inner_r, mp);
  297|      0|                IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
  298|      0|            }
  299|   819k|        }
  300|   819k|        auto p   = new (mp) node_t;
  301|   819k|        auto r   = new (mr) relaxed_t;
  302|   819k|        ownee(p) = e;
  303|   819k|        static_if<!embed_relaxed>([&](auto) { node_t::ownee(r) = e; });
  304|   819k|        r->d.count                   = 0;
  305|   819k|        p->impl.d.data.inner.relaxed = r;
  306|   819k|#if IMMER_TAGGED_NODE
  307|   819k|        p->impl.d.kind = node_t::kind_t::inner;
  308|   819k|#endif
  309|   819k|        return p;
  310|   819k|    }
_ZZN5immer6detail4rbts4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE14make_inner_r_eENS9_5applyIS6_E4type4editEENKUlT_E_clINS0_7empty_tEEEDaSG_:
  303|   819k|        static_if<!embed_relaxed>([&](auto) { node_t::ownee(r) = e; });
_ZN5immer6detail4rbts4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE11make_path_eENS9_5applyIS6_E4type4editEjPSB_:
  516|  2.28M|    {
  517|  2.28M|        IMMER_ASSERT_TAGGED(node->kind() == kind_t::leaf);
  ------------------
  |  |   68|  2.28M|#define IMMER_ASSERT_TAGGED(assertion) assert(assertion)
  ------------------
  |  Branch (517:9): [True: 2.28M, False: 0]
  ------------------
  518|  2.28M|        if (shift == endshift<B, BL>)
  ------------------
  |  Branch (518:13): [True: 1.70M, False: 575k]
  ------------------
  519|  1.70M|            return node;
  520|   575k|        else {
  521|   575k|            auto n = node_t::make_inner_e(e);
  522|   575k|            IMMER_TRY {
  ------------------
  |  |   49|   575k|#define IMMER_TRY try
  ------------------
  523|   575k|                n->inner()[0] = make_path_e(e, shift - B, node);
  524|   575k|            }
  525|   575k|            IMMER_CATCH (...) {
  526|      0|                heap::deallocate(node_t::max_sizeof_inner, n);
  527|      0|                IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
  528|      0|            }
  529|   575k|            return n;
  530|   575k|        }
  531|  2.28M|    }
_ZN5immer6detail4rbts4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE12make_inner_eENS9_5applyIS6_E4type4editE:
  231|   622k|    {
  232|   622k|        auto m                       = heap::allocate(max_sizeof_inner);
  233|   622k|        auto p                       = new (m) node_t;
  234|   622k|        ownee(p)                     = e;
  235|   622k|        p->impl.d.data.inner.relaxed = nullptr;
  236|   622k|#if IMMER_TAGGED_NODE
  237|   622k|        p->impl.d.kind = node_t::kind_t::inner;
  238|   622k|#endif
  239|   622k|        return p;
  240|   622k|    }
_ZN5immer6detail4rbts4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE12copy_inner_eENS9_5applyIS6_E4type4editEPSB_j:
  551|  25.8k|    {
  552|  25.8k|        IMMER_ASSERT_TAGGED(src->kind() == kind_t::inner);
  ------------------
  |  |   68|  25.8k|#define IMMER_ASSERT_TAGGED(assertion) assert(assertion)
  ------------------
  |  Branch (552:9): [True: 25.8k, False: 0]
  ------------------
  553|  25.8k|        auto dst = make_inner_e(e);
  554|  25.8k|        return do_copy_inner(dst, src, n);
  555|  25.8k|    }
_ZN5immer6detail4rbts4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE15copy_inner_sr_eENS9_5applyIS6_E4type4editEPSB_j:
  603|  21.3k|    {
  604|  21.3k|        IMMER_ASSERT_TAGGED(src->kind() == kind_t::inner);
  ------------------
  |  |   68|  21.3k|#define IMMER_ASSERT_TAGGED(assertion) assert(assertion)
  ------------------
  |  Branch (604:9): [True: 21.3k, False: 0]
  ------------------
  605|  21.3k|        auto dst = make_inner_sr_e(e, src->relaxed());
  606|  21.3k|        return do_copy_inner_sr(dst, src, n);
  607|  21.3k|    }
_ZN5immer6detail4rbts4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE15make_inner_sr_eENS9_5applyIS6_E4type4editEPNS0_3csl10member_twoINSB_14relaxed_data_tENSG_7inheritIS7_NSG_6memberINSE_5owneeEvE4typeEE4typeEE4typeE:
  313|  21.3k|    {
  314|  21.3k|        return static_if<embed_relaxed, node_t*>(
  315|  21.3k|            [&](auto) { return node_t::make_inner_r_e(e); },
  316|  21.3k|            [&](auto) {
  317|  21.3k|                auto p =
  318|  21.3k|                    new (heap::allocate(node_t::max_sizeof_inner_r)) node_t;
  319|  21.3k|                node_t::refs(r).inc();
  320|  21.3k|                p->impl.d.data.inner.relaxed = r;
  321|  21.3k|                node_t::ownee(p)             = e;
  322|  21.3k|#if IMMER_TAGGED_NODE
  323|  21.3k|                p->impl.d.kind = node_t::kind_t::inner;
  324|  21.3k|#endif
  325|  21.3k|                return p;
  326|  21.3k|            });
  327|  21.3k|    }
_ZZN5immer6detail4rbts4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE15make_inner_sr_eENS9_5applyIS6_E4type4editEPNS0_3csl10member_twoINSB_14relaxed_data_tENSG_7inheritIS7_NSG_6memberINSE_5owneeEvE4typeEE4typeEE4typeEENKUlT_E0_clINS0_7empty_tEEEDaST_:
  316|  21.3k|            [&](auto) {
  317|  21.3k|                auto p =
  318|  21.3k|                    new (heap::allocate(node_t::max_sizeof_inner_r)) node_t;
  319|  21.3k|                node_t::refs(r).inc();
  320|  21.3k|                p->impl.d.data.inner.relaxed = r;
  321|  21.3k|                node_t::ownee(p)             = e;
  322|  21.3k|#if IMMER_TAGGED_NODE
  323|  21.3k|                p->impl.d.kind = node_t::kind_t::inner;
  324|  21.3k|#endif
  325|  21.3k|                return p;
  326|  21.3k|            });
_ZN5immer6detail4rbts4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE16do_copy_inner_srEPSB_SC_j:
  640|  21.3k|    {
  641|  21.3k|        if (embed_relaxed)
  ------------------
  |  Branch (641:13): [Folded, False: 21.3k]
  ------------------
  642|      0|            return do_copy_inner_r(dst, src, n);
  643|  21.3k|        else {
  644|  21.3k|            inc_nodes(src->inner(), n);
  645|  21.3k|            std::copy(src->inner(), src->inner() + n, dst->inner());
  646|  21.3k|            return dst;
  647|  21.3k|        }
  648|  21.3k|    }
_ZN5immer6detail4rbts4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE11copy_leaf_eENS9_5applyIS6_E4type4editEPSB_jSG_j:
  738|  2.69k|    {
  739|  2.69k|        IMMER_ASSERT_TAGGED(src1->kind() == kind_t::leaf);
  ------------------
  |  |   68|  2.69k|#define IMMER_ASSERT_TAGGED(assertion) assert(assertion)
  ------------------
  |  Branch (739:9): [True: 2.69k, False: 0]
  ------------------
  740|  2.69k|        IMMER_ASSERT_TAGGED(src2->kind() == kind_t::leaf);
  ------------------
  |  |   68|  2.69k|#define IMMER_ASSERT_TAGGED(assertion) assert(assertion)
  ------------------
  |  Branch (740:9): [True: 2.69k, False: 0]
  ------------------
  741|  2.69k|        auto dst = make_leaf_e(e);
  742|  2.69k|        IMMER_TRY {
  ------------------
  |  |   49|  2.69k|#define IMMER_TRY try
  ------------------
  743|  2.69k|            detail::uninitialized_copy(
  744|  2.69k|                src1->leaf(), src1->leaf() + n1, dst->leaf());
  745|  2.69k|        }
  746|  2.69k|        IMMER_CATCH (...) {
  747|      0|            heap::deallocate(max_sizeof_leaf, dst);
  748|      0|            IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
  749|      0|        }
  750|  2.69k|        IMMER_TRY {
  ------------------
  |  |   49|  2.69k|#define IMMER_TRY try
  ------------------
  751|  2.69k|            detail::uninitialized_copy(
  752|  2.69k|                src2->leaf(), src2->leaf() + n2, dst->leaf() + n1);
  753|  2.69k|        }
  754|  2.69k|        IMMER_CATCH (...) {
  755|      0|            detail::destroy_n(dst->leaf(), n1);
  756|      0|            heap::deallocate(max_sizeof_leaf, dst);
  757|      0|            IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
  758|      0|        }
  759|  2.69k|        return dst;
  760|  2.69k|    }
_ZN5immer6detail4rbts4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE11copy_leaf_eENS9_5applyIS6_E4type4editEPSB_jj:
  763|  1.32M|    {
  764|  1.32M|        IMMER_ASSERT_TAGGED(src->kind() == kind_t::leaf);
  ------------------
  |  |   68|  1.32M|#define IMMER_ASSERT_TAGGED(assertion) assert(assertion)
  ------------------
  |  Branch (764:9): [True: 1.32M, False: 0]
  ------------------
  765|  1.32M|        auto dst = make_leaf_e(e);
  766|  1.32M|        IMMER_TRY {
  ------------------
  |  |   49|  1.32M|#define IMMER_TRY try
  ------------------
  767|  1.32M|            detail::uninitialized_copy(
  768|  1.32M|                src->leaf() + idx, src->leaf() + last, dst->leaf());
  769|  1.32M|        }
  770|  1.32M|        IMMER_CATCH (...) {
  771|      0|            heap::deallocate(max_sizeof_leaf, dst);
  772|      0|            IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
  773|      0|        }
  774|  1.32M|        return dst;
  775|  1.32M|    }
_ZNK5immer6detail4rbts4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE9can_relaxEv:
  874|  1.31M|    bool can_relax() const { return !embed_relaxed || relaxed(); }
  ------------------
  |  Branch (874:37): [True: 1.31M, Folded]
  |  Branch (874:55): [True: 0, False: 0]
  ------------------
_ZN5immer6detail4rbts4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE24ensure_mutable_relaxed_eENS9_5applyIS6_E4type4editESF_:
  903|   437k|    {
  904|   437k|        auto src_r = relaxed();
  905|   437k|        return static_if<embed_relaxed, relaxed_t*>(
  906|   437k|            [&](auto) { return src_r; },
  907|   437k|            [&](auto) {
  908|   437k|                if (src_r && (node_t::refs(src_r).unique() ||
  909|   437k|                              node_t::ownee(src_r).can_mutate(e))) {
  910|   437k|                    node_t::ownee(src_r) = ec;
  911|   437k|                    return src_r;
  912|   437k|                } else {
  913|   437k|                    auto dst_r = impl.d.data.inner.relaxed =
  914|   437k|                        new (heap::allocate(max_sizeof_relaxed)) relaxed_t;
  915|   437k|                    if (src_r) {
  916|   437k|                        auto n = dst_r->d.count = src_r->d.count;
  917|   437k|                        std::copy(
  918|   437k|                            src_r->d.sizes, src_r->d.sizes + n, dst_r->d.sizes);
  919|   437k|                        if (node_t::refs(src_r).dec())
  920|   437k|                            heap::deallocate(node_t::sizeof_inner_r_n(n),
  921|   437k|                                             src_r);
  922|   437k|                    }
  923|   437k|                    node_t::ownee(dst_r) = ec;
  924|   437k|                    return dst_r;
  925|   437k|                }
  926|   437k|            });
  927|   437k|    }
_ZZN5immer6detail4rbts4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE24ensure_mutable_relaxed_eENS9_5applyIS6_E4type4editESF_ENKUlT_E0_clINS0_7empty_tEEEDaSG_:
  907|   437k|            [&](auto) {
  908|   437k|                if (src_r && (node_t::refs(src_r).unique() ||
  ------------------
  |  Branch (908:21): [True: 430k, False: 7.51k]
  |  Branch (908:31): [True: 0, False: 430k]
  ------------------
  909|   430k|                              node_t::ownee(src_r).can_mutate(e))) {
  ------------------
  |  Branch (909:31): [True: 429k, False: 745]
  ------------------
  910|   429k|                    node_t::ownee(src_r) = ec;
  911|   429k|                    return src_r;
  912|   429k|                } else {
  913|  8.25k|                    auto dst_r = impl.d.data.inner.relaxed =
  914|  8.25k|                        new (heap::allocate(max_sizeof_relaxed)) relaxed_t;
  915|  8.25k|                    if (src_r) {
  ------------------
  |  Branch (915:25): [True: 745, False: 7.51k]
  ------------------
  916|    745|                        auto n = dst_r->d.count = src_r->d.count;
  917|    745|                        std::copy(
  918|    745|                            src_r->d.sizes, src_r->d.sizes + n, dst_r->d.sizes);
  919|    745|                        if (node_t::refs(src_r).dec())
  ------------------
  |  Branch (919:29): [True: 0, False: 745]
  ------------------
  920|      0|                            heap::deallocate(node_t::sizeof_inner_r_n(n),
  921|      0|                                             src_r);
  922|    745|                    }
  923|  8.25k|                    node_t::ownee(dst_r) = ec;
  924|  8.25k|                    return dst_r;
  925|  8.25k|                }
  926|   437k|            });

_ZN5immer6detail4rbts11dec_visitor13visit_relaxedIRNS1_11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEEEEvOT_:
  523|   636k|    {
  524|   636k|        using node_t = node_type<Pos>;
  525|   636k|        auto node    = p.node();
  526|   636k|        if (node->dec()) {
  ------------------
  |  Branch (526:13): [True: 0, False: 636k]
  ------------------
  527|      0|            p.each(this_t{});
  528|      0|            node_t::delete_inner_r(node, p.count());
  529|      0|        }
  530|   636k|    }
_ZN5immer6detail4rbts11dec_visitor13visit_regularIRNS1_15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEEEEvOT_:
  534|  63.8k|    {
  535|  63.8k|        using node_t = node_type<Pos>;
  536|  63.8k|        auto node    = p.node();
  537|  63.8k|        if (node->dec()) {
  ------------------
  |  Branch (537:13): [True: 0, False: 63.8k]
  ------------------
  538|      0|            p.each(this_t{});
  539|      0|            node_t::delete_inner(node, p.count());
  540|      0|        }
  541|  63.8k|    }
_ZN5immer6detail4rbts11dec_visitor10visit_leafIRNS1_13full_leaf_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEEEEvOT_:
  545|  6.29k|    {
  546|  6.29k|        using node_t = node_type<Pos>;
  547|  6.29k|        auto node    = p.node();
  548|  6.29k|        if (node->dec()) {
  ------------------
  |  Branch (548:13): [True: 0, False: 6.29k]
  ------------------
  549|      0|            node_t::delete_leaf(node, p.count());
  550|      0|        }
  551|  6.29k|    }
_ZN5immer6detail4rbts11dec_visitor10visit_leafIRNS1_8leaf_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEEEEvOT_:
  545|  2.37k|    {
  546|  2.37k|        using node_t = node_type<Pos>;
  547|  2.37k|        auto node    = p.node();
  548|  2.37k|        if (node->dec()) {
  ------------------
  |  Branch (548:13): [True: 0, False: 2.37k]
  ------------------
  549|      0|            node_t::delete_leaf(node, p.count());
  550|      0|        }
  551|  2.37k|    }
_ZN5immer6detail4rbts11dec_visitor13visit_regularIRNS1_8full_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEEEEvOT_:
  534|  10.3k|    {
  535|  10.3k|        using node_t = node_type<Pos>;
  536|  10.3k|        auto node    = p.node();
  537|  10.3k|        if (node->dec()) {
  ------------------
  |  Branch (537:13): [True: 0, False: 10.3k]
  ------------------
  538|      0|            p.each(this_t{});
  539|      0|            node_t::delete_inner(node, p.count());
  540|      0|        }
  541|  10.3k|    }
_ZN5immer6detail4rbts11dec_visitor13visit_regularIRNS1_11regular_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEEEEvOT_:
  534|  3.68k|    {
  535|  3.68k|        using node_t = node_type<Pos>;
  536|  3.68k|        auto node    = p.node();
  537|  3.68k|        if (node->dec()) {
  ------------------
  |  Branch (537:13): [True: 0, False: 3.68k]
  ------------------
  538|      0|            p.each(this_t{});
  539|      0|            node_t::delete_inner(node, p.count());
  540|      0|        }
  541|  3.68k|    }
_ZN5immer6detail4rbts11dec_visitor13visit_regularIRNS1_17empty_regular_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEEEEvOT_:
  534|   445k|    {
  535|   445k|        using node_t = node_type<Pos>;
  536|   445k|        auto node    = p.node();
  537|   445k|        if (node->dec()) {
  ------------------
  |  Branch (537:13): [True: 0, False: 445k]
  ------------------
  538|      0|            p.each(this_t{});
  539|      0|            node_t::delete_inner(node, p.count());
  540|      0|        }
  541|   445k|    }
_ZN5immer6detail4rbts11dec_visitor10visit_leafIRNS1_12leaf_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEEEEvOT_:
  545|   517k|    {
  546|   517k|        using node_t = node_type<Pos>;
  547|   517k|        auto node    = p.node();
  548|   517k|        if (node->dec()) {
  ------------------
  |  Branch (548:13): [True: 0, False: 517k]
  ------------------
  549|      0|            node_t::delete_leaf(node, p.count());
  550|      0|        }
  551|   517k|    }
_ZN5immer6detail4rbts11dec_visitor10visit_leafIRNS1_14empty_leaf_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEEEEvOT_:
  545|   389k|    {
  546|   389k|        using node_t = node_type<Pos>;
  547|   389k|        auto node    = p.node();
  548|   389k|        if (node->dec()) {
  ------------------
  |  Branch (548:13): [True: 0, False: 389k]
  ------------------
  549|      0|            node_t::delete_leaf(node, p.count());
  550|      0|        }
  551|   389k|    }
_ZN5immer6detail4rbts17push_tail_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE13visit_relaxedIRNS1_11relaxed_posISC_EEEEPSC_OT_SI_j:
  791|  49.4k|    {
  792|  49.4k|        auto level    = pos.shift();
  793|  49.4k|        auto idx      = pos.count() - 1;
  794|  49.4k|        auto children = pos.size(idx);
  795|  49.4k|        auto new_idx =
  796|  49.4k|            children == size_t{1} << level || level == BL ? idx + 1 : idx;
  ------------------
  |  Branch (796:13): [True: 4.64k, False: 44.7k]
  |  Branch (796:47): [True: 497, False: 44.2k]
  ------------------
  797|  49.4k|        auto new_child = static_cast<node_t*>(nullptr);
  798|  49.4k|        if (new_idx >= branches<B>)
  ------------------
  |  Branch (798:13): [True: 1.02k, False: 48.4k]
  ------------------
  799|  1.02k|            return nullptr;
  800|  48.4k|        else if (idx == new_idx) {
  ------------------
  |  Branch (800:18): [True: 44.2k, False: 4.12k]
  ------------------
  801|  44.2k|            new_child = pos.last_oh_csh(this_t{}, idx, children, tail, ts);
  802|  44.2k|            if (!new_child) {
  ------------------
  |  Branch (802:17): [True: 1.20k, False: 43.0k]
  ------------------
  803|  1.20k|                if (++new_idx < branches<B>)
  ------------------
  |  Branch (803:21): [True: 409, False: 793]
  ------------------
  804|    409|                    new_child = node_t::make_path(level - B, tail);
  805|    793|                else
  806|    793|                    return nullptr;
  807|  1.20k|            }
  808|  44.2k|        } else
  809|  4.12k|            new_child = node_t::make_path(level - B, tail);
  810|  47.6k|        IMMER_TRY {
  ------------------
  |  |   49|  47.6k|#define IMMER_TRY try
  ------------------
  811|  47.6k|            auto count = new_idx + 1;
  812|  47.6k|            auto new_parent =
  813|  47.6k|                node_t::copy_inner_r_n(count, pos.node(), new_idx);
  814|  47.6k|            auto new_relaxed              = new_parent->relaxed();
  815|  47.6k|            new_parent->inner()[new_idx]  = new_child;
  816|  47.6k|            new_relaxed->d.sizes[new_idx] = pos.size() + ts;
  817|  47.6k|            new_relaxed->d.count          = count;
  818|  47.6k|            assert(new_relaxed->d.sizes[new_idx]);
  ------------------
  |  Branch (818:13): [True: 47.6k, False: 0]
  ------------------
  819|  47.6k|            return new_parent;
  820|  47.6k|        }
  821|  47.6k|        IMMER_CATCH (...) {
  822|      0|            auto shift = pos.shift();
  823|      0|            auto size  = new_idx == idx ? children + ts : ts;
  ------------------
  |  Branch (823:26): [True: 0, False: 0]
  ------------------
  824|      0|            if (shift > BL) {
  ------------------
  |  Branch (824:17): [True: 0, False: 0]
  ------------------
  825|      0|                tail->inc();
  826|      0|                dec_inner(new_child, shift - B, size);
  827|      0|            }
  828|      0|            IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
  829|      0|        }
  830|  47.6k|    }
_ZN5immer6detail4rbts17push_tail_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE13visit_regularIRNS1_15regular_sub_posISC_EEJRjEEEPSC_OT_SJ_DpOT0_:
  834|  7.97k|    {
  835|  7.97k|        assert((pos.size() & mask<BL>) == 0);
  ------------------
  |  Branch (835:9): [True: 7.97k, False: 0]
  ------------------
  836|  7.97k|        auto idx        = pos.index(pos.size() - 1);
  837|  7.97k|        auto new_idx    = pos.index(pos.size() + branches<BL> - 1);
  838|  7.97k|        auto count      = new_idx + 1;
  839|  7.97k|        auto new_parent = node_t::make_inner_n(count);
  840|  7.97k|        IMMER_TRY {
  ------------------
  |  |   49|  7.97k|#define IMMER_TRY try
  ------------------
  841|  7.97k|            new_parent->inner()[new_idx] =
  842|  7.97k|                idx == new_idx ? pos.last_oh(this_t{}, idx, tail)
  ------------------
  |  Branch (842:17): [True: 6.31k, False: 1.66k]
  ------------------
  843|       |                               /* otherwise */
  844|  7.97k|                               : node_t::make_path(pos.shift() - B, tail);
  845|  7.97k|        }
  846|  7.97k|        IMMER_CATCH (...) {
  847|      0|            node_t::delete_inner(new_parent, count);
  848|      0|            IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
  849|      0|        }
  850|  7.97k|        return node_t::do_copy_inner(new_parent, pos.node(), new_idx);
  851|  7.97k|    }
_ZN5immer6detail4rbts17push_tail_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE13visit_regularIRNS1_11regular_posISC_EEJEEEPSC_OT_SI_DpOT0_:
  834|  30.6k|    {
  835|  30.6k|        assert((pos.size() & mask<BL>) == 0);
  ------------------
  |  Branch (835:9): [True: 30.6k, False: 0]
  ------------------
  836|  30.6k|        auto idx        = pos.index(pos.size() - 1);
  837|  30.6k|        auto new_idx    = pos.index(pos.size() + branches<BL> - 1);
  838|  30.6k|        auto count      = new_idx + 1;
  839|  30.6k|        auto new_parent = node_t::make_inner_n(count);
  840|  30.6k|        IMMER_TRY {
  ------------------
  |  |   49|  30.6k|#define IMMER_TRY try
  ------------------
  841|  30.6k|            new_parent->inner()[new_idx] =
  842|  30.6k|                idx == new_idx ? pos.last_oh(this_t{}, idx, tail)
  ------------------
  |  Branch (842:17): [True: 21.6k, False: 8.98k]
  ------------------
  843|       |                               /* otherwise */
  844|  30.6k|                               : node_t::make_path(pos.shift() - B, tail);
  845|  30.6k|        }
  846|  30.6k|        IMMER_CATCH (...) {
  847|      0|            node_t::delete_inner(new_parent, count);
  848|      0|            IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
  849|      0|        }
  850|  30.6k|        return node_t::do_copy_inner(new_parent, pos.node(), new_idx);
  851|  30.6k|    }
_ZN5immer6detail4rbts17push_tail_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE13visit_regularIRNS1_15regular_sub_posISC_EEJEEEPSC_OT_SI_DpOT0_:
  834|  4.86k|    {
  835|  4.86k|        assert((pos.size() & mask<BL>) == 0);
  ------------------
  |  Branch (835:9): [True: 4.86k, False: 0]
  ------------------
  836|  4.86k|        auto idx        = pos.index(pos.size() - 1);
  837|  4.86k|        auto new_idx    = pos.index(pos.size() + branches<BL> - 1);
  838|  4.86k|        auto count      = new_idx + 1;
  839|  4.86k|        auto new_parent = node_t::make_inner_n(count);
  840|  4.86k|        IMMER_TRY {
  ------------------
  |  |   49|  4.86k|#define IMMER_TRY try
  ------------------
  841|  4.86k|            new_parent->inner()[new_idx] =
  842|  4.86k|                idx == new_idx ? pos.last_oh(this_t{}, idx, tail)
  ------------------
  |  Branch (842:17): [True: 2.67k, False: 2.18k]
  ------------------
  843|       |                               /* otherwise */
  844|  4.86k|                               : node_t::make_path(pos.shift() - B, tail);
  845|  4.86k|        }
  846|  4.86k|        IMMER_CATCH (...) {
  847|      0|            node_t::delete_inner(new_parent, count);
  848|      0|            IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
  849|      0|        }
  850|  4.86k|        return node_t::do_copy_inner(new_parent, pos.node(), new_idx);
  851|  4.86k|    }
flex-vector-gc.cpp:_ZN5immer6detail4rbts14update_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE10visit_leafIRNS1_12leaf_sub_posISC_EERZZ22LLVMFuzzerTestOneInputENK3$_5clI12fuzzer_inputEEDaRT_EUlSL_E_EEPSC_OSL_mOT0_:
  502|  3.67k|    {
  503|  3.67k|        auto offset = pos.index(idx);
  504|  3.67k|        auto node   = node_t::copy_leaf(pos.node(), pos.count());
  505|  3.67k|        IMMER_TRY {
  ------------------
  |  |   49|  3.67k|#define IMMER_TRY try
  ------------------
  506|  3.67k|            node->leaf()[offset] =
  507|  3.67k|                std::forward<Fn>(fn)(std::move(node->leaf()[offset]));
  508|  3.67k|            return node;
  509|  3.67k|        }
  510|  3.67k|        IMMER_CATCH (...) {
  511|      0|            node_t::delete_leaf(node, pos.count());
  512|      0|            IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
  513|      0|        }
  514|  3.67k|    }
flex-vector-gc.cpp:_ZN5immer6detail4rbts14update_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE13visit_relaxedIRNS1_11relaxed_posISC_EERZZ22LLVMFuzzerTestOneInputENK3$_5clI12fuzzer_inputEEDaRT_EUlSL_E_EEPSC_OSL_mOT0_:
  466|  26.0k|    {
  467|  26.0k|        auto offset = pos.index(idx);
  468|  26.0k|        auto count  = pos.count();
  469|  26.0k|        auto node   = node_t::make_inner_sr_n(count, pos.relaxed());
  470|  26.0k|        IMMER_TRY {
  ------------------
  |  |   49|  26.0k|#define IMMER_TRY try
  ------------------
  471|  26.0k|            auto child = pos.towards_oh(this_t{}, idx, offset, fn);
  472|  26.0k|            node_t::do_copy_inner_replace_sr(
  473|  26.0k|                node, pos.node(), count, offset, child);
  474|  26.0k|            return node;
  475|  26.0k|        }
  476|  26.0k|        IMMER_CATCH (...) {
  477|      0|            node_t::delete_inner_r(node, count);
  478|      0|            IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
  479|      0|        }
  480|  26.0k|    }
flex-vector-gc.cpp:_ZN5immer6detail4rbts14update_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE13visit_regularIRNS1_15regular_sub_posISC_EERZZ22LLVMFuzzerTestOneInputENK3$_5clI12fuzzer_inputEEDaRT_EUlSL_E_EEPSC_OSL_mOT0_:
  484|  1.93k|    {
  485|  1.93k|        auto offset = pos.index(idx);
  486|  1.93k|        auto count  = pos.count();
  487|  1.93k|        auto node   = node_t::make_inner_n(count);
  488|  1.93k|        IMMER_TRY {
  ------------------
  |  |   49|  1.93k|#define IMMER_TRY try
  ------------------
  489|  1.93k|            auto child = pos.towards_oh_ch(this_t{}, idx, offset, count, fn);
  490|  1.93k|            node_t::do_copy_inner_replace(
  491|  1.93k|                node, pos.node(), count, offset, child);
  492|  1.93k|            return node;
  493|  1.93k|        }
  494|  1.93k|        IMMER_CATCH (...) {
  495|      0|            node_t::delete_inner(node, count);
  496|      0|            IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
  497|      0|        }
  498|  1.93k|    }
flex-vector-gc.cpp:_ZN5immer6detail4rbts14update_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE10visit_leafIRNS1_13full_leaf_posISC_EERZZ22LLVMFuzzerTestOneInputENK3$_5clI12fuzzer_inputEEDaRT_EUlSL_E_EEPSC_OSL_mOT0_:
  502|  1.35k|    {
  503|  1.35k|        auto offset = pos.index(idx);
  504|  1.35k|        auto node   = node_t::copy_leaf(pos.node(), pos.count());
  505|  1.35k|        IMMER_TRY {
  ------------------
  |  |   49|  1.35k|#define IMMER_TRY try
  ------------------
  506|  1.35k|            node->leaf()[offset] =
  507|  1.35k|                std::forward<Fn>(fn)(std::move(node->leaf()[offset]));
  508|  1.35k|            return node;
  509|  1.35k|        }
  510|  1.35k|        IMMER_CATCH (...) {
  511|      0|            node_t::delete_leaf(node, pos.count());
  512|      0|            IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
  513|      0|        }
  514|  1.35k|    }
flex-vector-gc.cpp:_ZN5immer6detail4rbts14update_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE13visit_regularIRNS1_8full_posISC_EERZZ22LLVMFuzzerTestOneInputENK3$_5clI12fuzzer_inputEEDaRT_EUlSL_E_EEPSC_OSL_mOT0_:
  484|  1.31k|    {
  485|  1.31k|        auto offset = pos.index(idx);
  486|  1.31k|        auto count  = pos.count();
  487|  1.31k|        auto node   = node_t::make_inner_n(count);
  488|  1.31k|        IMMER_TRY {
  ------------------
  |  |   49|  1.31k|#define IMMER_TRY try
  ------------------
  489|  1.31k|            auto child = pos.towards_oh_ch(this_t{}, idx, offset, count, fn);
  490|  1.31k|            node_t::do_copy_inner_replace(
  491|  1.31k|                node, pos.node(), count, offset, child);
  492|  1.31k|            return node;
  493|  1.31k|        }
  494|  1.31k|        IMMER_CATCH (...) {
  495|      0|            node_t::delete_inner(node, count);
  496|      0|            IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
  497|      0|        }
  498|  1.31k|    }
flex-vector-gc.cpp:_ZN5immer6detail4rbts14update_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE10visit_leafIRNS1_8leaf_posISC_EERZZ22LLVMFuzzerTestOneInputENK3$_5clI12fuzzer_inputEEDaRT_EUlSL_E_EEPSC_OSL_mOT0_:
  502|    579|    {
  503|    579|        auto offset = pos.index(idx);
  504|    579|        auto node   = node_t::copy_leaf(pos.node(), pos.count());
  505|    579|        IMMER_TRY {
  ------------------
  |  |   49|    579|#define IMMER_TRY try
  ------------------
  506|    579|            node->leaf()[offset] =
  507|    579|                std::forward<Fn>(fn)(std::move(node->leaf()[offset]));
  508|    579|            return node;
  509|    579|        }
  510|    579|        IMMER_CATCH (...) {
  511|      0|            node_t::delete_leaf(node, pos.count());
  512|      0|            IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
  513|      0|        }
  514|    579|    }
flex-vector-gc.cpp:_ZN5immer6detail4rbts14update_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE13visit_regularIRNS1_11regular_posISC_EERZZ22LLVMFuzzerTestOneInputENK3$_5clI12fuzzer_inputEEDaRT_EUlSL_E_EEPSC_OSL_mOT0_:
  484|  1.17k|    {
  485|  1.17k|        auto offset = pos.index(idx);
  486|  1.17k|        auto count  = pos.count();
  487|  1.17k|        auto node   = node_t::make_inner_n(count);
  488|  1.17k|        IMMER_TRY {
  ------------------
  |  |   49|  1.17k|#define IMMER_TRY try
  ------------------
  489|  1.17k|            auto child = pos.towards_oh_ch(this_t{}, idx, offset, count, fn);
  490|  1.17k|            node_t::do_copy_inner_replace(
  491|  1.17k|                node, pos.node(), count, offset, child);
  492|  1.17k|            return node;
  493|  1.17k|        }
  494|  1.17k|        IMMER_CATCH (...) {
  495|      0|            node_t::delete_inner(node, count);
  496|      0|            IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
  497|      0|        }
  498|  1.17k|    }
_ZN5immer6detail4rbts19slice_right_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEELb1EE13visit_relaxedIRNS1_11relaxed_posISC_EEEENSt3__15tupleIJjPSC_jSK_EEEOT_m:
 1096|  16.5k|    {
 1097|  16.5k|        auto idx = pos.index(last);
 1098|  16.5k|        if (Collapse && idx == 0) {
  ------------------
  |  Branch (1098:13): [True: 16.5k, Folded]
  |  Branch (1098:25): [True: 12.2k, False: 4.27k]
  ------------------
 1099|  12.2k|            return pos.towards_oh(this_t{}, last, idx);
 1100|  12.2k|        } else {
 1101|  4.27k|            using std::get;
 1102|  4.27k|            auto subs = pos.towards_oh(no_collapse_t{}, last, idx);
 1103|  4.27k|            auto next = get<1>(subs);
 1104|  4.27k|            auto ts   = get<2>(subs);
 1105|  4.27k|            auto tail = get<3>(subs);
 1106|  4.27k|            IMMER_TRY {
  ------------------
  |  |   49|  4.27k|#define IMMER_TRY try
  ------------------
 1107|  4.27k|                if (next) {
  ------------------
  |  Branch (1107:21): [True: 1.96k, False: 2.31k]
  ------------------
 1108|  1.96k|                    auto count = idx + 1;
 1109|  1.96k|                    auto newn  = node_t::copy_inner_r_n(count, pos.node(), idx);
 1110|  1.96k|                    auto newr  = newn->relaxed();
 1111|  1.96k|                    newn->inner()[idx] = next;
 1112|  1.96k|                    newr->d.sizes[idx] = last + 1 - ts;
 1113|  1.96k|                    newr->d.count      = count;
 1114|  1.96k|                    assert(newr->d.sizes[idx]);
  ------------------
  |  Branch (1114:21): [True: 1.96k, False: 0]
  ------------------
 1115|  1.96k|                    return std::make_tuple(pos.shift(), newn, ts, tail);
 1116|  2.31k|                } else if (idx == 0) {
  ------------------
  |  Branch (1116:28): [True: 0, False: 2.31k]
  ------------------
 1117|      0|                    return std::make_tuple(pos.shift(), nullptr, ts, tail);
 1118|  2.31k|                } else if (Collapse && idx == 1 && pos.shift() > BL) {
  ------------------
  |  Branch (1118:28): [True: 2.31k, Folded]
  |  Branch (1118:40): [True: 1.99k, False: 322]
  |  Branch (1118:52): [True: 1.00k, False: 984]
  ------------------
 1119|  1.00k|                    auto newn = pos.node()->inner()[0];
 1120|  1.00k|                    return std::make_tuple(
 1121|  1.00k|                        pos.shift() - B, newn->inc(), ts, tail);
 1122|  1.30k|                } else {
 1123|  1.30k|                    auto newn = node_t::copy_inner_r(pos.node(), idx);
 1124|  1.30k|                    return std::make_tuple(pos.shift(), newn, ts, tail);
 1125|  1.30k|                }
 1126|  4.27k|            }
 1127|  4.27k|            IMMER_CATCH (...) {
 1128|      0|                assert(!next || pos.shift() > BL);
  ------------------
  |  Branch (1128:17): [True: 0, False: 0]
  |  Branch (1128:17): [True: 0, False: 0]
  |  Branch (1128:17): [True: 0, False: 0]
  ------------------
 1129|      0|                if (next)
  ------------------
  |  Branch (1129:21): [True: 0, False: 0]
  ------------------
 1130|      0|                    dec_inner(next,
 1131|      0|                              pos.shift() - B,
 1132|      0|                              last + 1 - ts - pos.size_before(idx));
 1133|      0|                if (tail)
  ------------------
  |  Branch (1133:21): [True: 0, False: 0]
  ------------------
 1134|      0|                    dec_leaf(tail, ts);
 1135|      0|                IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
 1136|      0|            }
 1137|  4.27k|        }
 1138|  16.5k|    }
_ZN5immer6detail4rbts19slice_right_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEELb1EE10visit_leafIRNS1_12leaf_sub_posISC_EEEENSt3__15tupleIJjPSC_jSK_EEEOT_m:
 1181|    798|    {
 1182|    798|        auto old_tail_size = pos.count();
 1183|    798|        auto new_tail_size = pos.index(last) + 1;
 1184|    798|        auto new_tail      = new_tail_size == old_tail_size
  ------------------
  |  Branch (1184:30): [True: 239, False: 559]
  ------------------
 1185|    798|                                 ? pos.node()->inc()
 1186|    798|                                 : node_t::copy_leaf(pos.node(), new_tail_size);
 1187|    798|        return std::make_tuple(0, nullptr, new_tail_size, new_tail);
 1188|    798|    }
_ZN5immer6detail4rbts19slice_right_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEELb0EE10visit_leafIRNS1_12leaf_sub_posISC_EEEENSt3__15tupleIJjPSC_jSK_EEEOT_m:
 1181|  2.94k|    {
 1182|  2.94k|        auto old_tail_size = pos.count();
 1183|  2.94k|        auto new_tail_size = pos.index(last) + 1;
 1184|  2.94k|        auto new_tail      = new_tail_size == old_tail_size
  ------------------
  |  Branch (1184:30): [True: 970, False: 1.97k]
  ------------------
 1185|  2.94k|                                 ? pos.node()->inc()
 1186|  2.94k|                                 : node_t::copy_leaf(pos.node(), new_tail_size);
 1187|  2.94k|        return std::make_tuple(0, nullptr, new_tail_size, new_tail);
 1188|  2.94k|    }
_ZN5immer6detail4rbts19slice_right_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEELb0EE13visit_relaxedIRNS1_11relaxed_posISC_EEEENSt3__15tupleIJjPSC_jSK_EEEOT_m:
 1096|  4.07k|    {
 1097|  4.07k|        auto idx = pos.index(last);
 1098|  4.07k|        if (Collapse && idx == 0) {
  ------------------
  |  Branch (1098:13): [Folded, False: 4.07k]
  |  Branch (1098:25): [True: 0, False: 0]
  ------------------
 1099|      0|            return pos.towards_oh(this_t{}, last, idx);
 1100|  4.07k|        } else {
 1101|  4.07k|            using std::get;
 1102|  4.07k|            auto subs = pos.towards_oh(no_collapse_t{}, last, idx);
 1103|  4.07k|            auto next = get<1>(subs);
 1104|  4.07k|            auto ts   = get<2>(subs);
 1105|  4.07k|            auto tail = get<3>(subs);
 1106|  4.07k|            IMMER_TRY {
  ------------------
  |  |   49|  4.07k|#define IMMER_TRY try
  ------------------
 1107|  4.07k|                if (next) {
  ------------------
  |  Branch (1107:21): [True: 2.07k, False: 2.00k]
  ------------------
 1108|  2.07k|                    auto count = idx + 1;
 1109|  2.07k|                    auto newn  = node_t::copy_inner_r_n(count, pos.node(), idx);
 1110|  2.07k|                    auto newr  = newn->relaxed();
 1111|  2.07k|                    newn->inner()[idx] = next;
 1112|  2.07k|                    newr->d.sizes[idx] = last + 1 - ts;
 1113|  2.07k|                    newr->d.count      = count;
 1114|  2.07k|                    assert(newr->d.sizes[idx]);
  ------------------
  |  Branch (1114:21): [True: 2.07k, False: 0]
  ------------------
 1115|  2.07k|                    return std::make_tuple(pos.shift(), newn, ts, tail);
 1116|  2.07k|                } else if (idx == 0) {
  ------------------
  |  Branch (1116:28): [True: 881, False: 1.12k]
  ------------------
 1117|    881|                    return std::make_tuple(pos.shift(), nullptr, ts, tail);
 1118|  1.12k|                } else if (Collapse && idx == 1 && pos.shift() > BL) {
  ------------------
  |  Branch (1118:28): [Folded, False: 1.12k]
  |  Branch (1118:40): [True: 0, False: 0]
  |  Branch (1118:52): [True: 0, False: 0]
  ------------------
 1119|      0|                    auto newn = pos.node()->inner()[0];
 1120|      0|                    return std::make_tuple(
 1121|      0|                        pos.shift() - B, newn->inc(), ts, tail);
 1122|  1.12k|                } else {
 1123|  1.12k|                    auto newn = node_t::copy_inner_r(pos.node(), idx);
 1124|  1.12k|                    return std::make_tuple(pos.shift(), newn, ts, tail);
 1125|  1.12k|                }
 1126|  4.07k|            }
 1127|  4.07k|            IMMER_CATCH (...) {
 1128|      0|                assert(!next || pos.shift() > BL);
  ------------------
  |  Branch (1128:17): [True: 0, False: 0]
  |  Branch (1128:17): [True: 0, False: 0]
  |  Branch (1128:17): [True: 0, False: 0]
  ------------------
 1129|      0|                if (next)
  ------------------
  |  Branch (1129:21): [True: 0, False: 0]
  ------------------
 1130|      0|                    dec_inner(next,
 1131|      0|                              pos.shift() - B,
 1132|      0|                              last + 1 - ts - pos.size_before(idx));
 1133|      0|                if (tail)
  ------------------
  |  Branch (1133:21): [True: 0, False: 0]
  ------------------
 1134|      0|                    dec_leaf(tail, ts);
 1135|      0|                IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
 1136|      0|            }
 1137|  4.07k|        }
 1138|  4.07k|    }
_ZN5immer6detail4rbts19slice_right_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEELb0EE13visit_regularIRNS1_15regular_sub_posISC_EEEENSt3__15tupleIJjPSC_jSK_EEEOT_m:
 1142|  1.33k|    {
 1143|  1.33k|        auto idx = pos.index(last);
 1144|  1.33k|        if (Collapse && idx == 0) {
  ------------------
  |  Branch (1144:13): [Folded, False: 1.33k]
  |  Branch (1144:25): [True: 0, False: 0]
  ------------------
 1145|      0|            return pos.towards_oh(this_t{}, last, idx);
 1146|  1.33k|        } else {
 1147|  1.33k|            using std::get;
 1148|  1.33k|            auto subs = pos.towards_oh(no_collapse_t{}, last, idx);
 1149|  1.33k|            auto next = get<1>(subs);
 1150|  1.33k|            auto ts   = get<2>(subs);
 1151|  1.33k|            auto tail = get<3>(subs);
 1152|  1.33k|            IMMER_TRY {
  ------------------
  |  |   49|  1.33k|#define IMMER_TRY try
  ------------------
 1153|  1.33k|                if (next) {
  ------------------
  |  Branch (1153:21): [True: 452, False: 879]
  ------------------
 1154|    452|                    auto newn = node_t::copy_inner_n(idx + 1, pos.node(), idx);
 1155|    452|                    newn->inner()[idx] = next;
 1156|    452|                    return std::make_tuple(pos.shift(), newn, ts, tail);
 1157|    879|                } else if (idx == 0) {
  ------------------
  |  Branch (1157:28): [True: 490, False: 389]
  ------------------
 1158|    490|                    return std::make_tuple(pos.shift(), nullptr, ts, tail);
 1159|    490|                } else if (Collapse && idx == 1 && pos.shift() > BL) {
  ------------------
  |  Branch (1159:28): [Folded, False: 389]
  |  Branch (1159:40): [True: 0, False: 0]
  |  Branch (1159:52): [True: 0, False: 0]
  ------------------
 1160|      0|                    auto newn = pos.node()->inner()[0];
 1161|      0|                    return std::make_tuple(
 1162|      0|                        pos.shift() - B, newn->inc(), ts, tail);
 1163|    389|                } else {
 1164|    389|                    auto newn = node_t::copy_inner_n(idx, pos.node(), idx);
 1165|    389|                    return std::make_tuple(pos.shift(), newn, ts, tail);
 1166|    389|                }
 1167|  1.33k|            }
 1168|  1.33k|            IMMER_CATCH (...) {
 1169|      0|                assert(!next || pos.shift() > BL);
  ------------------
  |  Branch (1169:17): [True: 0, False: 0]
  |  Branch (1169:17): [True: 0, False: 0]
  |  Branch (1169:17): [True: 0, False: 0]
  ------------------
 1170|      0|                assert(tail);
  ------------------
  |  Branch (1170:17): [True: 0, False: 0]
  ------------------
 1171|      0|                if (next)
  ------------------
  |  Branch (1171:21): [True: 0, False: 0]
  ------------------
 1172|      0|                    dec_regular(next, pos.shift() - B, last + 1 - ts);
 1173|      0|                dec_leaf(tail, ts);
 1174|      0|                IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
 1175|      0|            }
 1176|  1.33k|        }
 1177|  1.33k|    }
_ZN5immer6detail4rbts19slice_right_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEELb0EE10visit_leafIRNS1_13full_leaf_posISC_EEEENSt3__15tupleIJjPSC_jSK_EEEOT_m:
 1181|  3.21k|    {
 1182|  3.21k|        auto old_tail_size = pos.count();
 1183|  3.21k|        auto new_tail_size = pos.index(last) + 1;
 1184|  3.21k|        auto new_tail      = new_tail_size == old_tail_size
  ------------------
  |  Branch (1184:30): [True: 1.33k, False: 1.87k]
  ------------------
 1185|  3.21k|                                 ? pos.node()->inc()
 1186|  3.21k|                                 : node_t::copy_leaf(pos.node(), new_tail_size);
 1187|  3.21k|        return std::make_tuple(0, nullptr, new_tail_size, new_tail);
 1188|  3.21k|    }
_ZN5immer6detail4rbts19slice_right_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEELb0EE13visit_regularIRNS1_8full_posISC_EEEENSt3__15tupleIJjPSC_jSK_EEEOT_m:
 1142|  2.18k|    {
 1143|  2.18k|        auto idx = pos.index(last);
 1144|  2.18k|        if (Collapse && idx == 0) {
  ------------------
  |  Branch (1144:13): [Folded, False: 2.18k]
  |  Branch (1144:25): [True: 0, False: 0]
  ------------------
 1145|      0|            return pos.towards_oh(this_t{}, last, idx);
 1146|  2.18k|        } else {
 1147|  2.18k|            using std::get;
 1148|  2.18k|            auto subs = pos.towards_oh(no_collapse_t{}, last, idx);
 1149|  2.18k|            auto next = get<1>(subs);
 1150|  2.18k|            auto ts   = get<2>(subs);
 1151|  2.18k|            auto tail = get<3>(subs);
 1152|  2.18k|            IMMER_TRY {
  ------------------
  |  |   49|  2.18k|#define IMMER_TRY try
  ------------------
 1153|  2.18k|                if (next) {
  ------------------
  |  Branch (1153:21): [True: 405, False: 1.78k]
  ------------------
 1154|    405|                    auto newn = node_t::copy_inner_n(idx + 1, pos.node(), idx);
 1155|    405|                    newn->inner()[idx] = next;
 1156|    405|                    return std::make_tuple(pos.shift(), newn, ts, tail);
 1157|  1.78k|                } else if (idx == 0) {
  ------------------
  |  Branch (1157:28): [True: 927, False: 856]
  ------------------
 1158|    927|                    return std::make_tuple(pos.shift(), nullptr, ts, tail);
 1159|    927|                } else if (Collapse && idx == 1 && pos.shift() > BL) {
  ------------------
  |  Branch (1159:28): [Folded, False: 856]
  |  Branch (1159:40): [True: 0, False: 0]
  |  Branch (1159:52): [True: 0, False: 0]
  ------------------
 1160|      0|                    auto newn = pos.node()->inner()[0];
 1161|      0|                    return std::make_tuple(
 1162|      0|                        pos.shift() - B, newn->inc(), ts, tail);
 1163|    856|                } else {
 1164|    856|                    auto newn = node_t::copy_inner_n(idx, pos.node(), idx);
 1165|    856|                    return std::make_tuple(pos.shift(), newn, ts, tail);
 1166|    856|                }
 1167|  2.18k|            }
 1168|  2.18k|            IMMER_CATCH (...) {
 1169|      0|                assert(!next || pos.shift() > BL);
  ------------------
  |  Branch (1169:17): [True: 0, False: 0]
  |  Branch (1169:17): [True: 0, False: 0]
  |  Branch (1169:17): [True: 0, False: 0]
  ------------------
 1170|      0|                assert(tail);
  ------------------
  |  Branch (1170:17): [True: 0, False: 0]
  ------------------
 1171|      0|                if (next)
  ------------------
  |  Branch (1171:21): [True: 0, False: 0]
  ------------------
 1172|      0|                    dec_regular(next, pos.shift() - B, last + 1 - ts);
 1173|      0|                dec_leaf(tail, ts);
 1174|      0|                IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
 1175|      0|            }
 1176|  2.18k|        }
 1177|  2.18k|    }
_ZN5immer6detail4rbts19slice_right_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEELb0EE10visit_leafIRNS1_8leaf_posISC_EEEENSt3__15tupleIJjPSC_jSK_EEEOT_m:
 1181|  1.68k|    {
 1182|  1.68k|        auto old_tail_size = pos.count();
 1183|  1.68k|        auto new_tail_size = pos.index(last) + 1;
 1184|  1.68k|        auto new_tail      = new_tail_size == old_tail_size
  ------------------
  |  Branch (1184:30): [True: 621, False: 1.06k]
  ------------------
 1185|  1.68k|                                 ? pos.node()->inc()
 1186|  1.68k|                                 : node_t::copy_leaf(pos.node(), new_tail_size);
 1187|  1.68k|        return std::make_tuple(0, nullptr, new_tail_size, new_tail);
 1188|  1.68k|    }
_ZN5immer6detail4rbts19slice_right_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEELb0EE13visit_regularIRNS1_11regular_posISC_EEEENSt3__15tupleIJjPSC_jSK_EEEOT_m:
 1142|  2.52k|    {
 1143|  2.52k|        auto idx = pos.index(last);
 1144|  2.52k|        if (Collapse && idx == 0) {
  ------------------
  |  Branch (1144:13): [Folded, False: 2.52k]
  |  Branch (1144:25): [True: 0, False: 0]
  ------------------
 1145|      0|            return pos.towards_oh(this_t{}, last, idx);
 1146|  2.52k|        } else {
 1147|  2.52k|            using std::get;
 1148|  2.52k|            auto subs = pos.towards_oh(no_collapse_t{}, last, idx);
 1149|  2.52k|            auto next = get<1>(subs);
 1150|  2.52k|            auto ts   = get<2>(subs);
 1151|  2.52k|            auto tail = get<3>(subs);
 1152|  2.52k|            IMMER_TRY {
  ------------------
  |  |   49|  2.52k|#define IMMER_TRY try
  ------------------
 1153|  2.52k|                if (next) {
  ------------------
  |  Branch (1153:21): [True: 388, False: 2.13k]
  ------------------
 1154|    388|                    auto newn = node_t::copy_inner_n(idx + 1, pos.node(), idx);
 1155|    388|                    newn->inner()[idx] = next;
 1156|    388|                    return std::make_tuple(pos.shift(), newn, ts, tail);
 1157|  2.13k|                } else if (idx == 0) {
  ------------------
  |  Branch (1157:28): [True: 1.50k, False: 634]
  ------------------
 1158|  1.50k|                    return std::make_tuple(pos.shift(), nullptr, ts, tail);
 1159|  1.50k|                } else if (Collapse && idx == 1 && pos.shift() > BL) {
  ------------------
  |  Branch (1159:28): [Folded, False: 634]
  |  Branch (1159:40): [True: 0, False: 0]
  |  Branch (1159:52): [True: 0, False: 0]
  ------------------
 1160|      0|                    auto newn = pos.node()->inner()[0];
 1161|      0|                    return std::make_tuple(
 1162|      0|                        pos.shift() - B, newn->inc(), ts, tail);
 1163|    634|                } else {
 1164|    634|                    auto newn = node_t::copy_inner_n(idx, pos.node(), idx);
 1165|    634|                    return std::make_tuple(pos.shift(), newn, ts, tail);
 1166|    634|                }
 1167|  2.52k|            }
 1168|  2.52k|            IMMER_CATCH (...) {
 1169|      0|                assert(!next || pos.shift() > BL);
  ------------------
  |  Branch (1169:17): [True: 0, False: 0]
  |  Branch (1169:17): [True: 0, False: 0]
  |  Branch (1169:17): [True: 0, False: 0]
  ------------------
 1170|      0|                assert(tail);
  ------------------
  |  Branch (1170:17): [True: 0, False: 0]
  ------------------
 1171|      0|                if (next)
  ------------------
  |  Branch (1171:21): [True: 0, False: 0]
  ------------------
 1172|      0|                    dec_regular(next, pos.shift() - B, last + 1 - ts);
 1173|      0|                dec_leaf(tail, ts);
 1174|      0|                IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
 1175|      0|            }
 1176|  2.52k|        }
 1177|  2.52k|    }
_ZN5immer6detail4rbts8dec_leafINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEEvPT_j:
  556|  62.8k|{
  557|  62.8k|    make_leaf_sub_pos(node, n).visit(dec_visitor{});
  558|  62.8k|}
_ZN5immer6detail4rbts19slice_right_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEELb1EE13visit_regularIRNS1_15regular_sub_posISC_EEEENSt3__15tupleIJjPSC_jSK_EEEOT_m:
 1142|  5.29k|    {
 1143|  5.29k|        auto idx = pos.index(last);
 1144|  5.29k|        if (Collapse && idx == 0) {
  ------------------
  |  Branch (1144:13): [True: 5.29k, Folded]
  |  Branch (1144:25): [True: 2.89k, False: 2.39k]
  ------------------
 1145|  2.89k|            return pos.towards_oh(this_t{}, last, idx);
 1146|  2.89k|        } else {
 1147|  2.39k|            using std::get;
 1148|  2.39k|            auto subs = pos.towards_oh(no_collapse_t{}, last, idx);
 1149|  2.39k|            auto next = get<1>(subs);
 1150|  2.39k|            auto ts   = get<2>(subs);
 1151|  2.39k|            auto tail = get<3>(subs);
 1152|  2.39k|            IMMER_TRY {
  ------------------
  |  |   49|  2.39k|#define IMMER_TRY try
  ------------------
 1153|  2.39k|                if (next) {
  ------------------
  |  Branch (1153:21): [True: 803, False: 1.59k]
  ------------------
 1154|    803|                    auto newn = node_t::copy_inner_n(idx + 1, pos.node(), idx);
 1155|    803|                    newn->inner()[idx] = next;
 1156|    803|                    return std::make_tuple(pos.shift(), newn, ts, tail);
 1157|  1.59k|                } else if (idx == 0) {
  ------------------
  |  Branch (1157:28): [True: 0, False: 1.59k]
  ------------------
 1158|      0|                    return std::make_tuple(pos.shift(), nullptr, ts, tail);
 1159|  1.59k|                } else if (Collapse && idx == 1 && pos.shift() > BL) {
  ------------------
  |  Branch (1159:28): [True: 1.59k, Folded]
  |  Branch (1159:40): [True: 1.27k, False: 325]
  |  Branch (1159:52): [True: 900, False: 370]
  ------------------
 1160|    900|                    auto newn = pos.node()->inner()[0];
 1161|    900|                    return std::make_tuple(
 1162|    900|                        pos.shift() - B, newn->inc(), ts, tail);
 1163|    900|                } else {
 1164|    695|                    auto newn = node_t::copy_inner_n(idx, pos.node(), idx);
 1165|    695|                    return std::make_tuple(pos.shift(), newn, ts, tail);
 1166|    695|                }
 1167|  2.39k|            }
 1168|  2.39k|            IMMER_CATCH (...) {
 1169|      0|                assert(!next || pos.shift() > BL);
  ------------------
  |  Branch (1169:17): [True: 0, False: 0]
  |  Branch (1169:17): [True: 0, False: 0]
  |  Branch (1169:17): [True: 0, False: 0]
  ------------------
 1170|      0|                assert(tail);
  ------------------
  |  Branch (1170:17): [True: 0, False: 0]
  ------------------
 1171|      0|                if (next)
  ------------------
  |  Branch (1171:21): [True: 0, False: 0]
  ------------------
 1172|      0|                    dec_regular(next, pos.shift() - B, last + 1 - ts);
 1173|      0|                dec_leaf(tail, ts);
 1174|      0|                IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
 1175|      0|            }
 1176|  2.39k|        }
 1177|  5.29k|    }
_ZN5immer6detail4rbts19slice_right_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEELb1EE10visit_leafIRNS1_13full_leaf_posISC_EEEENSt3__15tupleIJjPSC_jSK_EEEOT_m:
 1181|  1.30k|    {
 1182|  1.30k|        auto old_tail_size = pos.count();
 1183|  1.30k|        auto new_tail_size = pos.index(last) + 1;
 1184|  1.30k|        auto new_tail      = new_tail_size == old_tail_size
  ------------------
  |  Branch (1184:30): [True: 473, False: 828]
  ------------------
 1185|  1.30k|                                 ? pos.node()->inc()
 1186|  1.30k|                                 : node_t::copy_leaf(pos.node(), new_tail_size);
 1187|  1.30k|        return std::make_tuple(0, nullptr, new_tail_size, new_tail);
 1188|  1.30k|    }
_ZN5immer6detail4rbts19slice_right_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEELb1EE13visit_regularIRNS1_8full_posISC_EEEENSt3__15tupleIJjPSC_jSK_EEEOT_m:
 1142|  2.02k|    {
 1143|  2.02k|        auto idx = pos.index(last);
 1144|  2.02k|        if (Collapse && idx == 0) {
  ------------------
  |  Branch (1144:13): [True: 2.02k, Folded]
  |  Branch (1144:25): [True: 853, False: 1.17k]
  ------------------
 1145|    853|            return pos.towards_oh(this_t{}, last, idx);
 1146|  1.17k|        } else {
 1147|  1.17k|            using std::get;
 1148|  1.17k|            auto subs = pos.towards_oh(no_collapse_t{}, last, idx);
 1149|  1.17k|            auto next = get<1>(subs);
 1150|  1.17k|            auto ts   = get<2>(subs);
 1151|  1.17k|            auto tail = get<3>(subs);
 1152|  1.17k|            IMMER_TRY {
  ------------------
  |  |   49|  1.17k|#define IMMER_TRY try
  ------------------
 1153|  1.17k|                if (next) {
  ------------------
  |  Branch (1153:21): [True: 235, False: 936]
  ------------------
 1154|    235|                    auto newn = node_t::copy_inner_n(idx + 1, pos.node(), idx);
 1155|    235|                    newn->inner()[idx] = next;
 1156|    235|                    return std::make_tuple(pos.shift(), newn, ts, tail);
 1157|    936|                } else if (idx == 0) {
  ------------------
  |  Branch (1157:28): [True: 0, False: 936]
  ------------------
 1158|      0|                    return std::make_tuple(pos.shift(), nullptr, ts, tail);
 1159|    936|                } else if (Collapse && idx == 1 && pos.shift() > BL) {
  ------------------
  |  Branch (1159:28): [True: 936, Folded]
  |  Branch (1159:40): [True: 738, False: 198]
  |  Branch (1159:52): [True: 419, False: 319]
  ------------------
 1160|    419|                    auto newn = pos.node()->inner()[0];
 1161|    419|                    return std::make_tuple(
 1162|    419|                        pos.shift() - B, newn->inc(), ts, tail);
 1163|    517|                } else {
 1164|    517|                    auto newn = node_t::copy_inner_n(idx, pos.node(), idx);
 1165|    517|                    return std::make_tuple(pos.shift(), newn, ts, tail);
 1166|    517|                }
 1167|  1.17k|            }
 1168|  1.17k|            IMMER_CATCH (...) {
 1169|      0|                assert(!next || pos.shift() > BL);
  ------------------
  |  Branch (1169:17): [True: 0, False: 0]
  |  Branch (1169:17): [True: 0, False: 0]
  |  Branch (1169:17): [True: 0, False: 0]
  ------------------
 1170|      0|                assert(tail);
  ------------------
  |  Branch (1170:17): [True: 0, False: 0]
  ------------------
 1171|      0|                if (next)
  ------------------
  |  Branch (1171:21): [True: 0, False: 0]
  ------------------
 1172|      0|                    dec_regular(next, pos.shift() - B, last + 1 - ts);
 1173|      0|                dec_leaf(tail, ts);
 1174|      0|                IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
 1175|      0|            }
 1176|  1.17k|        }
 1177|  2.02k|    }
_ZN5immer6detail4rbts19slice_right_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEELb1EE10visit_leafIRNS1_8leaf_posISC_EEEENSt3__15tupleIJjPSC_jSK_EEEOT_m:
 1181|    425|    {
 1182|    425|        auto old_tail_size = pos.count();
 1183|    425|        auto new_tail_size = pos.index(last) + 1;
 1184|    425|        auto new_tail      = new_tail_size == old_tail_size
  ------------------
  |  Branch (1184:30): [True: 198, False: 227]
  ------------------
 1185|    425|                                 ? pos.node()->inc()
 1186|    425|                                 : node_t::copy_leaf(pos.node(), new_tail_size);
 1187|    425|        return std::make_tuple(0, nullptr, new_tail_size, new_tail);
 1188|    425|    }
_ZN5immer6detail4rbts18slice_left_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEELb1EE11visit_innerIRNS1_11relaxed_posISC_EEEENSt3__15tupleIJjPSC_EEEOT_m:
 1414|  14.6k|    {
 1415|  14.6k|        auto idx                = pos.subindex(first);
 1416|  14.6k|        auto count              = pos.count();
 1417|  14.6k|        auto left_size          = pos.size_before(idx);
 1418|  14.6k|        auto child_size         = pos.size_sbh(idx, left_size);
 1419|  14.6k|        auto dropped_size       = first;
 1420|  14.6k|        auto child_dropped_size = dropped_size - left_size;
 1421|  14.6k|        if (Collapse && pos.shift() > BL && idx == pos.count() - 1) {
  ------------------
  |  Branch (1421:13): [True: 14.6k, Folded]
  |  Branch (1421:25): [True: 13.5k, False: 1.09k]
  |  Branch (1421:45): [True: 1.37k, False: 12.1k]
  ------------------
 1422|  1.37k|            return pos.towards_sub_oh(this_t{}, first, idx);
 1423|  13.2k|        } else {
 1424|  13.2k|            using std::get;
 1425|  13.2k|            auto n    = pos.node();
 1426|  13.2k|            auto newc = count - idx;
 1427|  13.2k|            auto newn = node_t::make_inner_r_n(newc);
 1428|  13.2k|            IMMER_TRY {
  ------------------
  |  |   49|  13.2k|#define IMMER_TRY try
  ------------------
 1429|  13.2k|                auto subs     = pos.towards_sub_oh(no_collapse_t{}, first, idx);
 1430|  13.2k|                auto newr     = newn->relaxed();
 1431|  13.2k|                newr->d.count = count - idx;
 1432|  13.2k|                newr->d.sizes[0] = child_size - child_dropped_size;
 1433|  13.2k|                assert(newr->d.sizes[0]);
  ------------------
  |  Branch (1433:17): [True: 13.2k, False: 0]
  ------------------
 1434|  13.2k|                pos.copy_sizes(idx + 1,
 1435|  13.2k|                               newr->d.count - 1,
 1436|  13.2k|                               newr->d.sizes[0],
 1437|  13.2k|                               newr->d.sizes + 1);
 1438|  13.2k|                assert(newr->d.sizes[newr->d.count - 1] ==
  ------------------
  |  Branch (1438:17): [True: 13.2k, False: 0]
  ------------------
 1439|  13.2k|                       pos.size() - dropped_size);
 1440|  13.2k|                newn->inner()[0] = get<1>(subs);
 1441|  13.2k|                std::copy(n->inner() + idx + 1,
 1442|  13.2k|                          n->inner() + count,
 1443|  13.2k|                          newn->inner() + 1);
 1444|  13.2k|                node_t::inc_nodes(newn->inner() + 1, newr->d.count - 1);
 1445|  13.2k|                return std::make_tuple(pos.shift(), newn);
 1446|  13.2k|            }
 1447|  13.2k|            IMMER_CATCH (...) {
 1448|      0|                node_t::delete_inner_r(newn, newc);
 1449|      0|                IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
 1450|      0|            }
 1451|  13.2k|        }
 1452|  14.6k|    }
_ZN5immer6detail4rbts18slice_left_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEELb0EE10visit_leafIRNS1_12leaf_sub_posISC_EEEENSt3__15tupleIJjPSC_EEEOT_m:
 1456|  11.7k|    {
 1457|  11.7k|        auto n = node_t::copy_leaf(pos.node(), pos.index(first), pos.count());
 1458|  11.7k|        return std::make_tuple(0, n);
 1459|  11.7k|    }
_ZN5immer6detail4rbts18slice_left_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEELb0EE11visit_innerIRNS1_11relaxed_posISC_EEEENSt3__15tupleIJjPSC_EEEOT_m:
 1414|  92.0k|    {
 1415|  92.0k|        auto idx                = pos.subindex(first);
 1416|  92.0k|        auto count              = pos.count();
 1417|  92.0k|        auto left_size          = pos.size_before(idx);
 1418|  92.0k|        auto child_size         = pos.size_sbh(idx, left_size);
 1419|  92.0k|        auto dropped_size       = first;
 1420|  92.0k|        auto child_dropped_size = dropped_size - left_size;
 1421|  92.0k|        if (Collapse && pos.shift() > BL && idx == pos.count() - 1) {
  ------------------
  |  Branch (1421:13): [Folded, False: 92.0k]
  |  Branch (1421:25): [True: 0, False: 0]
  |  Branch (1421:45): [True: 0, False: 0]
  ------------------
 1422|      0|            return pos.towards_sub_oh(this_t{}, first, idx);
 1423|  92.0k|        } else {
 1424|  92.0k|            using std::get;
 1425|  92.0k|            auto n    = pos.node();
 1426|  92.0k|            auto newc = count - idx;
 1427|  92.0k|            auto newn = node_t::make_inner_r_n(newc);
 1428|  92.0k|            IMMER_TRY {
  ------------------
  |  |   49|  92.0k|#define IMMER_TRY try
  ------------------
 1429|  92.0k|                auto subs     = pos.towards_sub_oh(no_collapse_t{}, first, idx);
 1430|  92.0k|                auto newr     = newn->relaxed();
 1431|  92.0k|                newr->d.count = count - idx;
 1432|  92.0k|                newr->d.sizes[0] = child_size - child_dropped_size;
 1433|  92.0k|                assert(newr->d.sizes[0]);
  ------------------
  |  Branch (1433:17): [True: 92.0k, False: 0]
  ------------------
 1434|  92.0k|                pos.copy_sizes(idx + 1,
 1435|  92.0k|                               newr->d.count - 1,
 1436|  92.0k|                               newr->d.sizes[0],
 1437|  92.0k|                               newr->d.sizes + 1);
 1438|  92.0k|                assert(newr->d.sizes[newr->d.count - 1] ==
  ------------------
  |  Branch (1438:17): [True: 92.0k, False: 0]
  ------------------
 1439|  92.0k|                       pos.size() - dropped_size);
 1440|  92.0k|                newn->inner()[0] = get<1>(subs);
 1441|  92.0k|                std::copy(n->inner() + idx + 1,
 1442|  92.0k|                          n->inner() + count,
 1443|  92.0k|                          newn->inner() + 1);
 1444|  92.0k|                node_t::inc_nodes(newn->inner() + 1, newr->d.count - 1);
 1445|  92.0k|                return std::make_tuple(pos.shift(), newn);
 1446|  92.0k|            }
 1447|  92.0k|            IMMER_CATCH (...) {
 1448|      0|                node_t::delete_inner_r(newn, newc);
 1449|      0|                IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
 1450|      0|            }
 1451|  92.0k|        }
 1452|  92.0k|    }
_ZN5immer6detail4rbts18slice_left_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEELb0EE11visit_innerIRNS1_15regular_sub_posISC_EEEENSt3__15tupleIJjPSC_EEEOT_m:
 1414|  1.47k|    {
 1415|  1.47k|        auto idx                = pos.subindex(first);
 1416|  1.47k|        auto count              = pos.count();
 1417|  1.47k|        auto left_size          = pos.size_before(idx);
 1418|  1.47k|        auto child_size         = pos.size_sbh(idx, left_size);
 1419|  1.47k|        auto dropped_size       = first;
 1420|  1.47k|        auto child_dropped_size = dropped_size - left_size;
 1421|  1.47k|        if (Collapse && pos.shift() > BL && idx == pos.count() - 1) {
  ------------------
  |  Branch (1421:13): [Folded, False: 1.47k]
  |  Branch (1421:25): [True: 0, False: 0]
  |  Branch (1421:45): [True: 0, False: 0]
  ------------------
 1422|      0|            return pos.towards_sub_oh(this_t{}, first, idx);
 1423|  1.47k|        } else {
 1424|  1.47k|            using std::get;
 1425|  1.47k|            auto n    = pos.node();
 1426|  1.47k|            auto newc = count - idx;
 1427|  1.47k|            auto newn = node_t::make_inner_r_n(newc);
 1428|  1.47k|            IMMER_TRY {
  ------------------
  |  |   49|  1.47k|#define IMMER_TRY try
  ------------------
 1429|  1.47k|                auto subs     = pos.towards_sub_oh(no_collapse_t{}, first, idx);
 1430|  1.47k|                auto newr     = newn->relaxed();
 1431|  1.47k|                newr->d.count = count - idx;
 1432|  1.47k|                newr->d.sizes[0] = child_size - child_dropped_size;
 1433|  1.47k|                assert(newr->d.sizes[0]);
  ------------------
  |  Branch (1433:17): [True: 1.47k, False: 0]
  ------------------
 1434|  1.47k|                pos.copy_sizes(idx + 1,
 1435|  1.47k|                               newr->d.count - 1,
 1436|  1.47k|                               newr->d.sizes[0],
 1437|  1.47k|                               newr->d.sizes + 1);
 1438|  1.47k|                assert(newr->d.sizes[newr->d.count - 1] ==
  ------------------
  |  Branch (1438:17): [True: 1.47k, False: 0]
  ------------------
 1439|  1.47k|                       pos.size() - dropped_size);
 1440|  1.47k|                newn->inner()[0] = get<1>(subs);
 1441|  1.47k|                std::copy(n->inner() + idx + 1,
 1442|  1.47k|                          n->inner() + count,
 1443|  1.47k|                          newn->inner() + 1);
 1444|  1.47k|                node_t::inc_nodes(newn->inner() + 1, newr->d.count - 1);
 1445|  1.47k|                return std::make_tuple(pos.shift(), newn);
 1446|  1.47k|            }
 1447|  1.47k|            IMMER_CATCH (...) {
 1448|      0|                node_t::delete_inner_r(newn, newc);
 1449|      0|                IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
 1450|      0|            }
 1451|  1.47k|        }
 1452|  1.47k|    }
_ZN5immer6detail4rbts18slice_left_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEELb0EE10visit_leafIRNS1_13full_leaf_posISC_EEEENSt3__15tupleIJjPSC_EEEOT_m:
 1456|  3.97k|    {
 1457|  3.97k|        auto n = node_t::copy_leaf(pos.node(), pos.index(first), pos.count());
 1458|  3.97k|        return std::make_tuple(0, n);
 1459|  3.97k|    }
_ZN5immer6detail4rbts18slice_left_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEELb0EE11visit_innerIRNS1_8full_posISC_EEEENSt3__15tupleIJjPSC_EEEOT_m:
 1414|  2.33k|    {
 1415|  2.33k|        auto idx                = pos.subindex(first);
 1416|  2.33k|        auto count              = pos.count();
 1417|  2.33k|        auto left_size          = pos.size_before(idx);
 1418|  2.33k|        auto child_size         = pos.size_sbh(idx, left_size);
 1419|  2.33k|        auto dropped_size       = first;
 1420|  2.33k|        auto child_dropped_size = dropped_size - left_size;
 1421|  2.33k|        if (Collapse && pos.shift() > BL && idx == pos.count() - 1) {
  ------------------
  |  Branch (1421:13): [Folded, False: 2.33k]
  |  Branch (1421:25): [True: 0, False: 0]
  |  Branch (1421:45): [True: 0, False: 0]
  ------------------
 1422|      0|            return pos.towards_sub_oh(this_t{}, first, idx);
 1423|  2.33k|        } else {
 1424|  2.33k|            using std::get;
 1425|  2.33k|            auto n    = pos.node();
 1426|  2.33k|            auto newc = count - idx;
 1427|  2.33k|            auto newn = node_t::make_inner_r_n(newc);
 1428|  2.33k|            IMMER_TRY {
  ------------------
  |  |   49|  2.33k|#define IMMER_TRY try
  ------------------
 1429|  2.33k|                auto subs     = pos.towards_sub_oh(no_collapse_t{}, first, idx);
 1430|  2.33k|                auto newr     = newn->relaxed();
 1431|  2.33k|                newr->d.count = count - idx;
 1432|  2.33k|                newr->d.sizes[0] = child_size - child_dropped_size;
 1433|  2.33k|                assert(newr->d.sizes[0]);
  ------------------
  |  Branch (1433:17): [True: 2.33k, False: 0]
  ------------------
 1434|  2.33k|                pos.copy_sizes(idx + 1,
 1435|  2.33k|                               newr->d.count - 1,
 1436|  2.33k|                               newr->d.sizes[0],
 1437|  2.33k|                               newr->d.sizes + 1);
 1438|  2.33k|                assert(newr->d.sizes[newr->d.count - 1] ==
  ------------------
  |  Branch (1438:17): [True: 2.33k, False: 0]
  ------------------
 1439|  2.33k|                       pos.size() - dropped_size);
 1440|  2.33k|                newn->inner()[0] = get<1>(subs);
 1441|  2.33k|                std::copy(n->inner() + idx + 1,
 1442|  2.33k|                          n->inner() + count,
 1443|  2.33k|                          newn->inner() + 1);
 1444|  2.33k|                node_t::inc_nodes(newn->inner() + 1, newr->d.count - 1);
 1445|  2.33k|                return std::make_tuple(pos.shift(), newn);
 1446|  2.33k|            }
 1447|  2.33k|            IMMER_CATCH (...) {
 1448|      0|                node_t::delete_inner_r(newn, newc);
 1449|      0|                IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
 1450|      0|            }
 1451|  2.33k|        }
 1452|  2.33k|    }
_ZN5immer6detail4rbts18slice_left_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEELb1EE11visit_innerIRNS1_15regular_sub_posISC_EEEENSt3__15tupleIJjPSC_EEEOT_m:
 1414|  2.85k|    {
 1415|  2.85k|        auto idx                = pos.subindex(first);
 1416|  2.85k|        auto count              = pos.count();
 1417|  2.85k|        auto left_size          = pos.size_before(idx);
 1418|  2.85k|        auto child_size         = pos.size_sbh(idx, left_size);
 1419|  2.85k|        auto dropped_size       = first;
 1420|  2.85k|        auto child_dropped_size = dropped_size - left_size;
 1421|  2.85k|        if (Collapse && pos.shift() > BL && idx == pos.count() - 1) {
  ------------------
  |  Branch (1421:13): [True: 2.85k, Folded]
  |  Branch (1421:25): [True: 1.92k, False: 927]
  |  Branch (1421:45): [True: 1.30k, False: 620]
  ------------------
 1422|  1.30k|            return pos.towards_sub_oh(this_t{}, first, idx);
 1423|  1.54k|        } else {
 1424|  1.54k|            using std::get;
 1425|  1.54k|            auto n    = pos.node();
 1426|  1.54k|            auto newc = count - idx;
 1427|  1.54k|            auto newn = node_t::make_inner_r_n(newc);
 1428|  1.54k|            IMMER_TRY {
  ------------------
  |  |   49|  1.54k|#define IMMER_TRY try
  ------------------
 1429|  1.54k|                auto subs     = pos.towards_sub_oh(no_collapse_t{}, first, idx);
 1430|  1.54k|                auto newr     = newn->relaxed();
 1431|  1.54k|                newr->d.count = count - idx;
 1432|  1.54k|                newr->d.sizes[0] = child_size - child_dropped_size;
 1433|  1.54k|                assert(newr->d.sizes[0]);
  ------------------
  |  Branch (1433:17): [True: 1.54k, False: 0]
  ------------------
 1434|  1.54k|                pos.copy_sizes(idx + 1,
 1435|  1.54k|                               newr->d.count - 1,
 1436|  1.54k|                               newr->d.sizes[0],
 1437|  1.54k|                               newr->d.sizes + 1);
 1438|  1.54k|                assert(newr->d.sizes[newr->d.count - 1] ==
  ------------------
  |  Branch (1438:17): [True: 1.54k, False: 0]
  ------------------
 1439|  1.54k|                       pos.size() - dropped_size);
 1440|  1.54k|                newn->inner()[0] = get<1>(subs);
 1441|  1.54k|                std::copy(n->inner() + idx + 1,
 1442|  1.54k|                          n->inner() + count,
 1443|  1.54k|                          newn->inner() + 1);
 1444|  1.54k|                node_t::inc_nodes(newn->inner() + 1, newr->d.count - 1);
 1445|  1.54k|                return std::make_tuple(pos.shift(), newn);
 1446|  1.54k|            }
 1447|  1.54k|            IMMER_CATCH (...) {
 1448|      0|                node_t::delete_inner_r(newn, newc);
 1449|      0|                IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
 1450|      0|            }
 1451|  1.54k|        }
 1452|  2.85k|    }
_ZN5immer6detail4rbts18slice_left_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEELb1EE11visit_innerIRNS1_8full_posISC_EEEENSt3__15tupleIJjPSC_EEEOT_m:
 1414|  1.23k|    {
 1415|  1.23k|        auto idx                = pos.subindex(first);
 1416|  1.23k|        auto count              = pos.count();
 1417|  1.23k|        auto left_size          = pos.size_before(idx);
 1418|  1.23k|        auto child_size         = pos.size_sbh(idx, left_size);
 1419|  1.23k|        auto dropped_size       = first;
 1420|  1.23k|        auto child_dropped_size = dropped_size - left_size;
 1421|  1.23k|        if (Collapse && pos.shift() > BL && idx == pos.count() - 1) {
  ------------------
  |  Branch (1421:13): [True: 1.23k, Folded]
  |  Branch (1421:25): [True: 492, False: 738]
  |  Branch (1421:45): [True: 278, False: 214]
  ------------------
 1422|    278|            return pos.towards_sub_oh(this_t{}, first, idx);
 1423|    952|        } else {
 1424|    952|            using std::get;
 1425|    952|            auto n    = pos.node();
 1426|    952|            auto newc = count - idx;
 1427|    952|            auto newn = node_t::make_inner_r_n(newc);
 1428|    952|            IMMER_TRY {
  ------------------
  |  |   49|    952|#define IMMER_TRY try
  ------------------
 1429|    952|                auto subs     = pos.towards_sub_oh(no_collapse_t{}, first, idx);
 1430|    952|                auto newr     = newn->relaxed();
 1431|    952|                newr->d.count = count - idx;
 1432|    952|                newr->d.sizes[0] = child_size - child_dropped_size;
 1433|    952|                assert(newr->d.sizes[0]);
  ------------------
  |  Branch (1433:17): [True: 952, False: 0]
  ------------------
 1434|    952|                pos.copy_sizes(idx + 1,
 1435|    952|                               newr->d.count - 1,
 1436|    952|                               newr->d.sizes[0],
 1437|    952|                               newr->d.sizes + 1);
 1438|    952|                assert(newr->d.sizes[newr->d.count - 1] ==
  ------------------
  |  Branch (1438:17): [True: 952, False: 0]
  ------------------
 1439|    952|                       pos.size() - dropped_size);
 1440|    952|                newn->inner()[0] = get<1>(subs);
 1441|    952|                std::copy(n->inner() + idx + 1,
 1442|    952|                          n->inner() + count,
 1443|    952|                          newn->inner() + 1);
 1444|    952|                node_t::inc_nodes(newn->inner() + 1, newr->d.count - 1);
 1445|    952|                return std::make_tuple(pos.shift(), newn);
 1446|    952|            }
 1447|    952|            IMMER_CATCH (...) {
 1448|      0|                node_t::delete_inner_r(newn, newc);
 1449|      0|                IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
 1450|      0|            }
 1451|    952|        }
 1452|  1.23k|    }
_ZN5immer6detail4rbts12concat_treesINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEENS1_11relaxed_posIT_EEPSE_jSG_jm:
 2001|  3.06k|{
 2002|  3.06k|    return make_singleton_regular_sub_pos(ltail, ltcount)
 2003|  3.06k|        .visit(concat_trees_left_visitor<Node>{},
 2004|  3.06k|               empty_leaf_pos<Node>{},
 2005|  3.06k|               rroot,
 2006|  3.06k|               rshift,
 2007|  3.06k|               rsize)
 2008|  3.06k|        .realize();
 2009|  3.06k|}
_ZN5immer6detail4rbts25concat_trees_left_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE10visit_nodeIRNS1_25singleton_regular_sub_posISC_EENS1_14empty_leaf_posISC_EEJRPSC_RjRmEEENS1_17concat_center_posISC_EEOT_OT0_DpOT1_:
 1971|  3.06k|    {
 1972|  3.06k|        return visit_maybe_relaxed_sub(
 1973|  3.06k|            args..., concat_trees_right_visitor<Node>{}, lpos, tpos);
 1974|  3.06k|    }
_ZN5immer6detail4rbts26concat_trees_right_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE10visit_nodeIRNS1_11relaxed_posISC_EERNS1_25singleton_regular_sub_posISC_EERNS1_14empty_leaf_posISC_EEEENS1_17concat_center_posISC_EEOT_OT0_OT1_:
 1958|  1.78k|    {
 1959|  1.78k|        return concat_inners<Node>(lpos, tpos, rpos);
 1960|  1.78k|    }
_ZN5immer6detail4rbts13concat_innersINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEERNS1_25singleton_regular_sub_posISC_EERNS1_14empty_leaf_posISC_EERNS1_11relaxed_posISC_EEEENS1_17concat_center_posIT_EEOT0_OT1_OT2_:
 1872|  7.17k|{
 1873|  7.17k|    auto lshift = lpos.shift();
 1874|  7.17k|    auto rshift = rpos.shift();
 1875|  7.17k|    if (lshift > rshift) {
  ------------------
  |  Branch (1875:9): [True: 0, False: 7.17k]
  ------------------
 1876|      0|        auto cpos = lpos.last_sub(concat_left_visitor<Node>{}, tpos, rpos);
 1877|      0|        return concat_rebalance<Node>(lpos, cpos, null_sub_pos{});
 1878|  7.17k|    } else if (lshift < rshift) {
  ------------------
  |  Branch (1878:16): [True: 5.59k, False: 1.57k]
  ------------------
 1879|  5.59k|        auto cpos = rpos.first_sub(concat_right_visitor<Node>{}, lpos, tpos);
 1880|  5.59k|        return concat_rebalance<Node>(null_sub_pos{}, cpos, rpos);
 1881|  5.59k|    } else {
 1882|  1.57k|        assert(lshift == rshift);
  ------------------
  |  Branch (1882:9): [True: 1.57k, False: 0]
  ------------------
 1883|  1.57k|        assert(Node::bits_leaf == 0u || lshift > 0);
  ------------------
  |  Branch (1883:9): [Folded, False: 1.57k]
  |  Branch (1883:9): [True: 1.57k, False: 0]
  |  Branch (1883:9): [True: 1.57k, False: 0]
  ------------------
 1884|  1.57k|        auto cpos = lpos.last_sub(concat_both_visitor<Node>{}, tpos, rpos);
 1885|  1.57k|        return concat_rebalance<Node>(lpos, cpos, rpos);
 1886|  1.57k|    }
 1887|  7.17k|}
_ZN5immer6detail4rbts17concat_center_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE8each_subINS1_34concat_rebalance_plan_fill_visitorEJRNS1_21concat_rebalance_planILj2ELj2EEEEEEvT_DpOT0_:
 1512|  1.06M|    {
 1513|  1.06M|        if (shift_ == BL) {
  ------------------
  |  Branch (1513:13): [True: 157k, False: 903k]
  ------------------
 1514|   157k|            auto s = size_t{};
 1515|   619k|            for (auto i = count_t{0}; i < count_; ++i) {
  ------------------
  |  Branch (1515:39): [True: 461k, False: 157k]
  ------------------
 1516|   461k|                make_leaf_sub_pos(nodes_[i], sizes_[i] - s).visit(v, args...);
 1517|   461k|                s = sizes_[i];
 1518|   461k|            }
 1519|   903k|        } else {
 1520|  2.33M|            for (auto i = count_t{0}; i < count_; ++i)
  ------------------
  |  Branch (1520:39): [True: 1.42M, False: 903k]
  ------------------
 1521|  1.42M|                make_relaxed_pos(nodes_[i], shift_ - B, nodes_[i]->relaxed())
 1522|  1.42M|                    .visit(v, args...);
 1523|   903k|        }
 1524|  1.06M|    }
_ZN5immer6detail4rbts34concat_rebalance_plan_fill_visitor10visit_nodeIRNS1_12leaf_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEENS1_21concat_rebalance_planILj2ELj2EEEEEvOT_RT0_:
 1733|   890k|    {
 1734|   890k|        auto count = p.count();
 1735|   890k|        assert(plan.n < Plan::max_children);
  ------------------
  |  Branch (1735:9): [True: 890k, False: 0]
  ------------------
 1736|   890k|        plan.counts[plan.n++] = count;
 1737|   890k|        plan.total += count;
 1738|   890k|    }
_ZN5immer6detail4rbts34concat_rebalance_plan_fill_visitor10visit_nodeIRNS1_11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEENS1_21concat_rebalance_planILj2ELj2EEEEEvOT_RT0_:
 1733|  3.78M|    {
 1734|  3.78M|        auto count = p.count();
 1735|  3.78M|        assert(plan.n < Plan::max_children);
  ------------------
  |  Branch (1735:9): [True: 3.78M, False: 0]
  ------------------
 1736|  3.78M|        plan.counts[plan.n++] = count;
 1737|  3.78M|        plan.total += count;
 1738|  3.78M|    }
_ZN5immer6detail4rbts21concat_rebalance_planILj2ELj2EE7shuffleEj:
 1762|  1.06M|    {
 1763|       |        // gcc seems to not really understand this code... :(
 1764|  1.06M|#if !defined(_MSC_VER)
 1765|  1.06M|#pragma GCC diagnostic push
 1766|  1.06M|#pragma GCC diagnostic ignored "-Warray-bounds"
 1767|  1.06M|#endif
 1768|  1.06M|        constexpr count_t rrb_extras    = 2;
 1769|  1.06M|        constexpr count_t rrb_invariant = 1;
 1770|  1.06M|        const auto bits                 = shift == BL ? BL : B;
  ------------------
  |  Branch (1770:43): [True: 157k, False: 903k]
  ------------------
 1771|  1.06M|        const auto branches             = count_t{1} << bits;
 1772|  1.06M|        const auto optimal              = ((total - 1) >> bits) + 1;
 1773|  1.06M|        count_t i                       = 0;
 1774|  1.12M|        while (n >= optimal + rrb_extras) {
  ------------------
  |  Branch (1774:16): [True: 66.8k, False: 1.06M]
  ------------------
 1775|       |            // skip ok nodes
 1776|   128k|            while (counts[i] > branches - rrb_invariant)
  ------------------
  |  Branch (1776:20): [True: 61.5k, False: 66.8k]
  ------------------
 1777|  61.5k|                i++;
 1778|  66.8k|            assert(i < n);
  ------------------
  |  Branch (1778:13): [True: 66.8k, False: 0]
  ------------------
 1779|       |            // short node, redistribute
 1780|  66.8k|            auto remaining = counts[i];
 1781|   113k|            do {
 1782|   113k|                auto next  = counts[i + 1];
 1783|   113k|                auto count = std::min(remaining + next, branches);
 1784|   113k|                counts[i]  = count;
 1785|   113k|                assert(counts[i]);
  ------------------
  |  Branch (1785:17): [True: 113k, False: 0]
  ------------------
 1786|   113k|                remaining += next - count;
 1787|   113k|                ++i;
 1788|   113k|            } while (remaining > 0);
  ------------------
  |  Branch (1788:22): [True: 46.8k, False: 66.8k]
  ------------------
 1789|       |            // remove node
 1790|  66.8k|            std::move(counts + i + 1, counts + n, counts + i);
 1791|  66.8k|            --n;
 1792|  66.8k|            --i;
 1793|  66.8k|        }
 1794|  1.06M|#if !defined(_MSC_VER)
 1795|  1.06M|#pragma GCC diagnostic pop
 1796|  1.06M|#endif
 1797|  1.06M|    }
_ZNK5immer6detail4rbts17concat_center_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5shiftEv:
 1478|  2.12M|    auto shift() const { return shift_; }
_ZN5immer6detail4rbts13concat_mergerINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEC2EjPjj:
 1577|   251k|        : curr_{counts}
 1578|   251k|        , n_{n}
 1579|   251k|        , result_{
 1580|   251k|              shift + B, node_t::make_inner_r_n(std::min(n_, branches<B>)), 0}
 1581|   251k|    {
 1582|   251k|    }
_ZN5immer6detail4rbts17concat_center_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEC2EjPSC_m:
 1481|  1.06M|        : shift_{s}
 1482|  1.06M|        , count_{1}
 1483|  1.06M|        , nodes_{n0}
 1484|  1.06M|        , sizes_{s0}
 1485|  1.06M|    {
 1486|  1.06M|    }
_ZN5immer6detail4rbts17concat_center_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE8each_subINS1_21concat_merger_visitorEJRNS1_13concat_mergerISC_EEEEEvT_DpOT0_:
 1512|   251k|    {
 1513|   251k|        if (shift_ == BL) {
  ------------------
  |  Branch (1513:13): [True: 50.2k, False: 200k]
  ------------------
 1514|  50.2k|            auto s = size_t{};
 1515|   198k|            for (auto i = count_t{0}; i < count_; ++i) {
  ------------------
  |  Branch (1515:39): [True: 147k, False: 50.2k]
  ------------------
 1516|   147k|                make_leaf_sub_pos(nodes_[i], sizes_[i] - s).visit(v, args...);
 1517|   147k|                s = sizes_[i];
 1518|   147k|            }
 1519|   200k|        } else {
 1520|   599k|            for (auto i = count_t{0}; i < count_; ++i)
  ------------------
  |  Branch (1520:39): [True: 398k, False: 200k]
  ------------------
 1521|   398k|                make_relaxed_pos(nodes_[i], shift_ - B, nodes_[i]->relaxed())
 1522|   398k|                    .visit(v, args...);
 1523|   200k|        }
 1524|   251k|    }
_ZN5immer6detail4rbts21concat_merger_visitor10visit_leafIRNS1_12leaf_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEENS1_13concat_mergerISE_EEEEvOT_RT0_:
 1721|   331k|    {
 1722|   331k|        merger.merge_leaf(p);
 1723|   331k|    }
_ZN5immer6detail4rbts13concat_mergerINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE10merge_leafIRNS1_12leaf_sub_posISC_EEEEvOT_:
 1614|   331k|    {
 1615|   331k|        auto from       = p.node();
 1616|   331k|        auto from_size  = p.size();
 1617|   331k|        auto from_count = p.count();
 1618|   331k|        assert(from_size);
  ------------------
  |  Branch (1618:9): [True: 331k, False: 0]
  ------------------
 1619|   331k|        if (!to_ && *curr_ == from_count) {
  ------------------
  |  Branch (1619:13): [True: 314k, False: 16.3k]
  |  Branch (1619:21): [True: 306k, False: 7.84k]
  ------------------
 1620|   306k|            add_child(from, from_size);
 1621|   306k|            from->inc();
 1622|   306k|        } else {
 1623|  24.2k|            auto from_offset = count_t{};
 1624|  24.2k|            auto from_data   = from->leaf();
 1625|  32.5k|            do {
 1626|  32.5k|                if (!to_) {
  ------------------
  |  Branch (1626:21): [True: 16.1k, False: 16.3k]
  ------------------
 1627|  16.1k|                    to_        = node_t::make_leaf_n(*curr_);
 1628|  16.1k|                    to_offset_ = 0;
 1629|  16.1k|                }
 1630|  32.5k|                auto data = to_->leaf();
 1631|  32.5k|                auto to_copy =
 1632|  32.5k|                    std::min(from_count - from_offset, *curr_ - to_offset_);
 1633|  32.5k|                detail::uninitialized_copy(from_data + from_offset,
 1634|  32.5k|                                           from_data + from_offset + to_copy,
 1635|  32.5k|                                           data + to_offset_);
 1636|  32.5k|                to_offset_ += to_copy;
 1637|  32.5k|                from_offset += to_copy;
 1638|  32.5k|                if (*curr_ == to_offset_) {
  ------------------
  |  Branch (1638:21): [True: 16.1k, False: 16.3k]
  ------------------
 1639|  16.1k|                    add_child(to_, to_offset_);
 1640|  16.1k|                    to_ = nullptr;
 1641|  16.1k|                }
 1642|  32.5k|            } while (from_offset != from_count);
  ------------------
  |  Branch (1642:22): [True: 8.33k, False: 24.2k]
  ------------------
 1643|  24.2k|        }
 1644|   331k|    }
_ZN5immer6detail4rbts13concat_mergerINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE9add_childEPSC_m:
 1589|  1.73M|    {
 1590|  1.73M|        assert(size);
  ------------------
  |  Branch (1590:9): [True: 1.73M, False: 0]
  ------------------
 1591|  1.73M|        ++curr_;
 1592|  1.73M|        auto parent  = result_.nodes_[result_.count_ - 1];
 1593|  1.73M|        auto relaxed = parent->relaxed();
 1594|  1.73M|        if (relaxed->d.count == branches<B>) {
  ------------------
  |  Branch (1594:13): [True: 220k, False: 1.51M]
  ------------------
 1595|   220k|            assert(result_.count_ < result_t::max_children);
  ------------------
  |  Branch (1595:13): [True: 220k, False: 0]
  ------------------
 1596|   220k|            n_ -= branches<B>;
 1597|   220k|            parent  = node_t::make_inner_r_n(std::min(n_, branches<B>));
 1598|   220k|            relaxed = parent->relaxed();
 1599|   220k|            result_.nodes_[result_.count_] = parent;
 1600|   220k|            result_.sizes_[result_.count_] = result_.sizes_[result_.count_ - 1];
 1601|   220k|            assert(result_.sizes_[result_.count_]);
  ------------------
  |  Branch (1601:13): [True: 220k, False: 0]
  ------------------
 1602|   220k|            ++result_.count_;
 1603|   220k|        }
 1604|  1.73M|        auto idx = relaxed->d.count++;
 1605|  1.73M|        result_.sizes_[result_.count_ - 1] += size;
 1606|  1.73M|        assert(result_.sizes_[result_.count_ - 1]);
  ------------------
  |  Branch (1606:9): [True: 1.73M, False: 0]
  ------------------
 1607|  1.73M|        relaxed->d.sizes[idx] = size + (idx ? relaxed->d.sizes[idx - 1] : 0);
  ------------------
  |  Branch (1607:41): [True: 1.26M, False: 471k]
  ------------------
 1608|  1.73M|        assert(relaxed->d.sizes[idx]);
  ------------------
  |  Branch (1608:9): [True: 1.73M, False: 0]
  ------------------
 1609|  1.73M|        parent->inner()[idx] = p;
 1610|  1.73M|    };
_ZN5immer6detail4rbts21concat_merger_visitor11visit_innerIRNS1_11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEENS1_13concat_mergerISE_EEEEvOT_RT0_:
 1715|  1.34M|    {
 1716|  1.34M|        merger.merge_inner(p);
 1717|  1.34M|    }
_ZN5immer6detail4rbts13concat_mergerINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE11merge_innerIRNS1_11relaxed_posISC_EEEEvOT_:
 1648|  1.34M|    {
 1649|  1.34M|        auto from       = p.node();
 1650|  1.34M|        auto from_size  = p.size();
 1651|  1.34M|        auto from_count = p.count();
 1652|  1.34M|        assert(from_size);
  ------------------
  |  Branch (1652:9): [True: 1.34M, False: 0]
  ------------------
 1653|  1.34M|        if (!to_ && *curr_ == from_count) {
  ------------------
  |  Branch (1653:13): [True: 1.34M, False: 7.72k]
  |  Branch (1653:21): [True: 1.33M, False: 3.98k]
  ------------------
 1654|  1.33M|            add_child(from, from_size);
 1655|  1.33M|            from->inc();
 1656|  1.33M|        } else {
 1657|  11.7k|            auto from_offset = count_t{};
 1658|  11.7k|            auto from_data   = from->inner();
 1659|  15.2k|            do {
 1660|  15.2k|                if (!to_) {
  ------------------
  |  Branch (1660:21): [True: 7.48k, False: 7.72k]
  ------------------
 1661|  7.48k|                    to_        = node_t::make_inner_r_n(*curr_);
 1662|  7.48k|                    to_offset_ = 0;
 1663|  7.48k|                    to_size_   = 0;
 1664|  7.48k|                }
 1665|  15.2k|                auto data = to_->inner();
 1666|  15.2k|                auto to_copy =
 1667|  15.2k|                    std::min(from_count - from_offset, *curr_ - to_offset_);
 1668|  15.2k|                std::copy(from_data + from_offset,
 1669|  15.2k|                          from_data + from_offset + to_copy,
 1670|  15.2k|                          data + to_offset_);
 1671|  15.2k|                node_t::inc_nodes(from_data + from_offset, to_copy);
 1672|  15.2k|                auto sizes = to_->relaxed()->d.sizes;
 1673|  15.2k|                p.copy_sizes(
 1674|  15.2k|                    from_offset, to_copy, to_size_, sizes + to_offset_);
 1675|  15.2k|                to_offset_ += to_copy;
 1676|  15.2k|                from_offset += to_copy;
 1677|  15.2k|                to_size_ = sizes[to_offset_ - 1];
 1678|  15.2k|                assert(to_size_);
  ------------------
  |  Branch (1678:17): [True: 15.2k, False: 0]
  ------------------
 1679|  15.2k|                if (*curr_ == to_offset_) {
  ------------------
  |  Branch (1679:21): [True: 7.48k, False: 7.72k]
  ------------------
 1680|  7.48k|                    to_->relaxed()->d.count = to_offset_;
 1681|  7.48k|                    add_child(to_, to_size_);
 1682|  7.48k|                    to_ = nullptr;
 1683|  7.48k|                }
 1684|  15.2k|            } while (from_offset != from_count);
  ------------------
  |  Branch (1684:22): [True: 3.49k, False: 11.7k]
  ------------------
 1685|  11.7k|        }
 1686|  1.34M|    }
_ZNK5immer6detail4rbts13concat_mergerINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE6finishEv:
 1689|   251k|    {
 1690|   251k|        assert(!to_);
  ------------------
  |  Branch (1690:9): [True: 251k, False: 0]
  ------------------
 1691|   251k|        return result_;
 1692|   251k|    }
_ZN5immer6detail4rbts17concat_center_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE8each_subINS1_11dec_visitorEJEEEvT_DpOT0_:
 1512|   251k|    {
 1513|   251k|        if (shift_ == BL) {
  ------------------
  |  Branch (1513:13): [True: 50.2k, False: 200k]
  ------------------
 1514|  50.2k|            auto s = size_t{};
 1515|   198k|            for (auto i = count_t{0}; i < count_; ++i) {
  ------------------
  |  Branch (1515:39): [True: 147k, False: 50.2k]
  ------------------
 1516|   147k|                make_leaf_sub_pos(nodes_[i], sizes_[i] - s).visit(v, args...);
 1517|   147k|                s = sizes_[i];
 1518|   147k|            }
 1519|   200k|        } else {
 1520|   599k|            for (auto i = count_t{0}; i < count_; ++i)
  ------------------
  |  Branch (1520:39): [True: 398k, False: 200k]
  ------------------
 1521|   398k|                make_relaxed_pos(nodes_[i], shift_ - B, nodes_[i]->relaxed())
 1522|   398k|                    .visit(v, args...);
 1523|   200k|        }
 1524|   251k|    }
_ZN5immer6detail4rbts17concat_center_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEC2EjPSC_mSE_mSE_m:
 1503|   146k|        : shift_{s}
 1504|   146k|        , count_{3}
 1505|   146k|        , nodes_{n0, n1, n2}
 1506|   146k|        , sizes_{s0, s0 + s1, s0 + s1 + s2}
 1507|   146k|    {
 1508|   146k|    }
_ZN5immer6detail4rbts17concat_center_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEC2EjPSC_mSE_m:
 1489|  10.4k|        : shift_{s}
 1490|  10.4k|        , count_{2}
 1491|  10.4k|        , nodes_{n0, n1}
 1492|  10.4k|        , sizes_{s0, s0 + s1}
 1493|  10.4k|    {
 1494|  10.4k|    }
_ZN5immer6detail4rbts20concat_right_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE11visit_innerIRNS1_11relaxed_posISC_EERNS1_25singleton_regular_sub_posISC_EERNS1_14empty_leaf_posISC_EEEENS1_17concat_center_posISC_EEOT_OT0_OT1_:
 1917|  5.39k|    {
 1918|  5.39k|        return concat_inners<Node>(lpos, tpos, rpos);
 1919|  5.39k|    }
_ZN5immer6detail4rbts20concat_right_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE11visit_innerIRNS1_15regular_sub_posISC_EERNS1_25singleton_regular_sub_posISC_EERNS1_14empty_leaf_posISC_EEEENS1_17concat_center_posISC_EEOT_OT0_OT1_:
 1917|    202|    {
 1918|    202|        return concat_inners<Node>(lpos, tpos, rpos);
 1919|    202|    }
_ZN5immer6detail4rbts13concat_innersINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEERNS1_25singleton_regular_sub_posISC_EERNS1_14empty_leaf_posISC_EERNS1_15regular_sub_posISC_EEEENS1_17concat_center_posIT_EEOT0_OT1_OT2_:
 1872|  1.48k|{
 1873|  1.48k|    auto lshift = lpos.shift();
 1874|  1.48k|    auto rshift = rpos.shift();
 1875|  1.48k|    if (lshift > rshift) {
  ------------------
  |  Branch (1875:9): [True: 0, False: 1.48k]
  ------------------
 1876|      0|        auto cpos = lpos.last_sub(concat_left_visitor<Node>{}, tpos, rpos);
 1877|      0|        return concat_rebalance<Node>(lpos, cpos, null_sub_pos{});
 1878|  1.48k|    } else if (lshift < rshift) {
  ------------------
  |  Branch (1878:16): [True: 708, False: 779]
  ------------------
 1879|    708|        auto cpos = rpos.first_sub(concat_right_visitor<Node>{}, lpos, tpos);
 1880|    708|        return concat_rebalance<Node>(null_sub_pos{}, cpos, rpos);
 1881|    779|    } else {
 1882|    779|        assert(lshift == rshift);
  ------------------
  |  Branch (1882:9): [True: 779, False: 0]
  ------------------
 1883|    779|        assert(Node::bits_leaf == 0u || lshift > 0);
  ------------------
  |  Branch (1883:9): [Folded, False: 779]
  |  Branch (1883:9): [True: 779, False: 0]
  |  Branch (1883:9): [True: 779, False: 0]
  ------------------
 1884|    779|        auto cpos = lpos.last_sub(concat_both_visitor<Node>{}, tpos, rpos);
 1885|    779|        return concat_rebalance<Node>(lpos, cpos, rpos);
 1886|    779|    }
 1887|  1.48k|}
_ZN5immer6detail4rbts20concat_right_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE11visit_innerIRNS1_8full_posISC_EERNS1_25singleton_regular_sub_posISC_EERNS1_14empty_leaf_posISC_EEEENS1_17concat_center_posISC_EEOT_OT0_OT1_:
 1917|  1.19k|    {
 1918|  1.19k|        return concat_inners<Node>(lpos, tpos, rpos);
 1919|  1.19k|    }
_ZN5immer6detail4rbts13concat_innersINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEERNS1_25singleton_regular_sub_posISC_EERNS1_14empty_leaf_posISC_EERNS1_8full_posISC_EEEENS1_17concat_center_posIT_EEOT0_OT1_OT2_:
 1872|  1.19k|{
 1873|  1.19k|    auto lshift = lpos.shift();
 1874|  1.19k|    auto rshift = rpos.shift();
 1875|  1.19k|    if (lshift > rshift) {
  ------------------
  |  Branch (1875:9): [True: 0, False: 1.19k]
  ------------------
 1876|      0|        auto cpos = lpos.last_sub(concat_left_visitor<Node>{}, tpos, rpos);
 1877|      0|        return concat_rebalance<Node>(lpos, cpos, null_sub_pos{});
 1878|  1.19k|    } else if (lshift < rshift) {
  ------------------
  |  Branch (1878:16): [True: 485, False: 708]
  ------------------
 1879|    485|        auto cpos = rpos.first_sub(concat_right_visitor<Node>{}, lpos, tpos);
 1880|    485|        return concat_rebalance<Node>(null_sub_pos{}, cpos, rpos);
 1881|    708|    } else {
 1882|    708|        assert(lshift == rshift);
  ------------------
  |  Branch (1882:9): [True: 708, False: 0]
  ------------------
 1883|    708|        assert(Node::bits_leaf == 0u || lshift > 0);
  ------------------
  |  Branch (1883:9): [Folded, False: 708]
  |  Branch (1883:9): [True: 708, False: 0]
  |  Branch (1883:9): [True: 708, False: 0]
  ------------------
 1884|    708|        auto cpos = lpos.last_sub(concat_both_visitor<Node>{}, tpos, rpos);
 1885|    708|        return concat_rebalance<Node>(lpos, cpos, rpos);
 1886|    708|    }
 1887|  1.19k|}
_ZN5immer6detail4rbts16concat_rebalanceINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEENS1_12null_sub_posERNS1_17concat_center_posISC_EERNS1_8full_posISC_EEEENSE_IT_EEOT0_OT1_OT2_:
 1823|    998|{
 1824|    998|    auto plan = concat_rebalance_plan<Node::bits, Node::bits_leaf>{};
 1825|    998|    plan.fill(lpos, cpos, rpos);
 1826|    998|    plan.shuffle(cpos.shift());
 1827|    998|    IMMER_TRY {
  ------------------
  |  |   49|    998|#define IMMER_TRY try
  ------------------
 1828|    998|        return plan.merge(lpos, cpos, rpos);
 1829|    998|    }
 1830|    998|    IMMER_CATCH (...) {
 1831|      0|        cpos.each_sub(dec_visitor{});
 1832|      0|        IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
 1833|      0|    }
 1834|    998|}
_ZN5immer6detail4rbts21concat_rebalance_planILj2ELj2EE4fillIRNS1_12null_sub_posERNS1_17concat_center_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEERNS1_8full_posISH_EEEEvOT_OT0_OT1_:
 1752|  2.18k|    {
 1753|  2.18k|        assert(n == 0u);
  ------------------
  |  Branch (1753:9): [True: 2.18k, False: 0]
  ------------------
 1754|  2.18k|        assert(total == 0u);
  ------------------
  |  Branch (1754:9): [True: 2.18k, False: 0]
  ------------------
 1755|  2.18k|        using visitor_t = concat_rebalance_plan_fill_visitor;
 1756|  2.18k|        lpos.each_left_sub(visitor_t{}, *this);
 1757|  2.18k|        cpos.each_sub(visitor_t{}, *this);
 1758|  2.18k|        rpos.each_right_sub(visitor_t{}, *this);
 1759|  2.18k|    }
_ZN5immer6detail4rbts34concat_rebalance_plan_fill_visitor10visit_nodeIRNS1_13full_leaf_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEENS1_21concat_rebalance_planILj2ELj2EEEEEvOT_RT0_:
 1733|   113k|    {
 1734|   113k|        auto count = p.count();
 1735|   113k|        assert(plan.n < Plan::max_children);
  ------------------
  |  Branch (1735:9): [True: 113k, False: 0]
  ------------------
 1736|   113k|        plan.counts[plan.n++] = count;
 1737|   113k|        plan.total += count;
 1738|   113k|    }
_ZN5immer6detail4rbts34concat_rebalance_plan_fill_visitor10visit_nodeIRNS1_8full_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEENS1_21concat_rebalance_planILj2ELj2EEEEEvOT_RT0_:
 1733|   211k|    {
 1734|   211k|        auto count = p.count();
 1735|   211k|        assert(plan.n < Plan::max_children);
  ------------------
  |  Branch (1735:9): [True: 211k, False: 0]
  ------------------
 1736|   211k|        plan.counts[plan.n++] = count;
 1737|   211k|        plan.total += count;
 1738|   211k|    }
_ZN5immer6detail4rbts21concat_rebalance_planILj2ELj2EE5mergeIRNS1_12null_sub_posERNS1_17concat_center_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEERNS1_8full_posISH_EEEENS7_INSt3__15decayIT0_E4type6node_tEEEOT_OSP_OT1_:
 1802|    998|    {
 1803|    998|        using node_t    = node_type<CPos>;
 1804|    998|        using merger_t  = concat_merger<node_t>;
 1805|    998|        using visitor_t = concat_merger_visitor;
 1806|    998|        auto merger     = merger_t{cpos.shift(), counts, n};
 1807|    998|        IMMER_TRY {
  ------------------
  |  |   49|    998|#define IMMER_TRY try
  ------------------
 1808|    998|            lpos.each_left_sub(visitor_t{}, merger);
 1809|    998|            cpos.each_sub(visitor_t{}, merger);
 1810|    998|            rpos.each_right_sub(visitor_t{}, merger);
 1811|    998|            cpos.each_sub(dec_visitor{});
 1812|    998|            return merger.finish();
 1813|    998|        }
 1814|    998|        IMMER_CATCH (...) {
 1815|      0|            merger.abort();
 1816|      0|            IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
 1817|      0|        }
 1818|    998|    }
_ZN5immer6detail4rbts21concat_merger_visitor10visit_leafIRNS1_13full_leaf_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEENS1_13concat_mergerISE_EEEEvOT_RT0_:
 1721|  22.3k|    {
 1722|  22.3k|        merger.merge_leaf(p);
 1723|  22.3k|    }
_ZN5immer6detail4rbts13concat_mergerINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE10merge_leafIRNS1_13full_leaf_posISC_EEEEvOT_:
 1614|  22.3k|    {
 1615|  22.3k|        auto from       = p.node();
 1616|  22.3k|        auto from_size  = p.size();
 1617|  22.3k|        auto from_count = p.count();
 1618|  22.3k|        assert(from_size);
  ------------------
  |  Branch (1618:9): [True: 22.3k, False: 0]
  ------------------
 1619|  22.3k|        if (!to_ && *curr_ == from_count) {
  ------------------
  |  Branch (1619:13): [True: 22.3k, False: 0]
  |  Branch (1619:21): [True: 22.3k, False: 0]
  ------------------
 1620|  22.3k|            add_child(from, from_size);
 1621|  22.3k|            from->inc();
 1622|  22.3k|        } else {
 1623|      0|            auto from_offset = count_t{};
 1624|      0|            auto from_data   = from->leaf();
 1625|      0|            do {
 1626|      0|                if (!to_) {
  ------------------
  |  Branch (1626:21): [True: 0, False: 0]
  ------------------
 1627|      0|                    to_        = node_t::make_leaf_n(*curr_);
 1628|      0|                    to_offset_ = 0;
 1629|      0|                }
 1630|      0|                auto data = to_->leaf();
 1631|      0|                auto to_copy =
 1632|      0|                    std::min(from_count - from_offset, *curr_ - to_offset_);
 1633|      0|                detail::uninitialized_copy(from_data + from_offset,
 1634|      0|                                           from_data + from_offset + to_copy,
 1635|      0|                                           data + to_offset_);
 1636|      0|                to_offset_ += to_copy;
 1637|      0|                from_offset += to_copy;
 1638|      0|                if (*curr_ == to_offset_) {
  ------------------
  |  Branch (1638:21): [True: 0, False: 0]
  ------------------
 1639|      0|                    add_child(to_, to_offset_);
 1640|      0|                    to_ = nullptr;
 1641|      0|                }
 1642|      0|            } while (from_offset != from_count);
  ------------------
  |  Branch (1642:22): [True: 0, False: 0]
  ------------------
 1643|      0|        }
 1644|  22.3k|    }
_ZN5immer6detail4rbts21concat_merger_visitor11visit_innerIRNS1_8full_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEENS1_13concat_mergerISE_EEEEvOT_RT0_:
 1715|  24.8k|    {
 1716|  24.8k|        merger.merge_inner(p);
 1717|  24.8k|    }
_ZN5immer6detail4rbts13concat_mergerINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE11merge_innerIRNS1_8full_posISC_EEEEvOT_:
 1648|  24.8k|    {
 1649|  24.8k|        auto from       = p.node();
 1650|  24.8k|        auto from_size  = p.size();
 1651|  24.8k|        auto from_count = p.count();
 1652|  24.8k|        assert(from_size);
  ------------------
  |  Branch (1652:9): [True: 24.8k, False: 0]
  ------------------
 1653|  24.8k|        if (!to_ && *curr_ == from_count) {
  ------------------
  |  Branch (1653:13): [True: 24.8k, False: 0]
  |  Branch (1653:21): [True: 24.8k, False: 0]
  ------------------
 1654|  24.8k|            add_child(from, from_size);
 1655|  24.8k|            from->inc();
 1656|  24.8k|        } else {
 1657|      0|            auto from_offset = count_t{};
 1658|      0|            auto from_data   = from->inner();
 1659|      0|            do {
 1660|      0|                if (!to_) {
  ------------------
  |  Branch (1660:21): [True: 0, False: 0]
  ------------------
 1661|      0|                    to_        = node_t::make_inner_r_n(*curr_);
 1662|      0|                    to_offset_ = 0;
 1663|      0|                    to_size_   = 0;
 1664|      0|                }
 1665|      0|                auto data = to_->inner();
 1666|      0|                auto to_copy =
 1667|      0|                    std::min(from_count - from_offset, *curr_ - to_offset_);
 1668|      0|                std::copy(from_data + from_offset,
 1669|      0|                          from_data + from_offset + to_copy,
 1670|      0|                          data + to_offset_);
 1671|      0|                node_t::inc_nodes(from_data + from_offset, to_copy);
 1672|      0|                auto sizes = to_->relaxed()->d.sizes;
 1673|      0|                p.copy_sizes(
 1674|      0|                    from_offset, to_copy, to_size_, sizes + to_offset_);
 1675|      0|                to_offset_ += to_copy;
 1676|      0|                from_offset += to_copy;
 1677|      0|                to_size_ = sizes[to_offset_ - 1];
 1678|      0|                assert(to_size_);
  ------------------
  |  Branch (1678:17): [True: 0, False: 0]
  ------------------
 1679|      0|                if (*curr_ == to_offset_) {
  ------------------
  |  Branch (1679:21): [True: 0, False: 0]
  ------------------
 1680|      0|                    to_->relaxed()->d.count = to_offset_;
 1681|      0|                    add_child(to_, to_size_);
 1682|      0|                    to_ = nullptr;
 1683|      0|                }
 1684|      0|            } while (from_offset != from_count);
  ------------------
  |  Branch (1684:22): [True: 0, False: 0]
  ------------------
 1685|      0|        }
 1686|  24.8k|    }
_ZN5immer6detail4rbts19concat_both_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE10visit_leafIRNS1_12leaf_sub_posISC_EERNS1_14empty_leaf_posISC_EERNS1_8full_posISC_EEEENS1_17concat_center_posISC_EEOT_OT0_OT1_:
 1944|    708|    {
 1945|    708|        return rpos.first_sub_leaf(concat_right_visitor<Node>{}, lpos, tpos);
 1946|    708|    }
_ZN5immer6detail4rbts20concat_right_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE10visit_leafIRNS1_13full_leaf_posISC_EERNS1_12leaf_sub_posISC_EERNS1_14empty_leaf_posISC_EEEENS1_17concat_center_posISC_EEOT_OT0_OT1_:
 1924|  1.48k|    {
 1925|  1.48k|        return concat_leafs<Node>(lpos, tpos, rpos);
 1926|  1.48k|    }
_ZN5immer6detail4rbts12concat_leafsINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEERNS1_12leaf_sub_posISC_EERNS1_14empty_leaf_posISC_EERNS1_13full_leaf_posISC_EEEENS1_17concat_center_posIT_EEOT0_OT1_OT2_:
 1838|  1.48k|{
 1839|  1.48k|    static_assert(Node::bits >= 2, "");
 1840|  1.48k|    assert(lpos.shift() == tpos.shift());
  ------------------
  |  Branch (1840:5): [True: 1.48k, False: 0]
  ------------------
 1841|  1.48k|    assert(lpos.shift() == rpos.shift());
  ------------------
  |  Branch (1841:5): [True: 1.48k, False: 0]
  ------------------
 1842|  1.48k|    assert(lpos.shift() == 0);
  ------------------
  |  Branch (1842:5): [True: 1.48k, False: 0]
  ------------------
 1843|  1.48k|    if (tpos.count() > 0)
  ------------------
  |  Branch (1843:9): [True: 0, False: 1.48k]
  ------------------
 1844|      0|        return {
 1845|      0|            Node::bits_leaf,
 1846|      0|            lpos.node()->inc(),
 1847|      0|            lpos.count(),
 1848|      0|            tpos.node()->inc(),
 1849|      0|            tpos.count(),
 1850|      0|            rpos.node()->inc(),
 1851|      0|            rpos.count(),
 1852|      0|        };
 1853|  1.48k|    else
 1854|  1.48k|        return {
 1855|  1.48k|            Node::bits_leaf,
 1856|  1.48k|            lpos.node()->inc(),
 1857|  1.48k|            lpos.count(),
 1858|  1.48k|            rpos.node()->inc(),
 1859|  1.48k|            rpos.count(),
 1860|  1.48k|        };
 1861|  1.48k|}
_ZN5immer6detail4rbts16concat_rebalanceINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEERNS1_25singleton_regular_sub_posISC_EERNS1_17concat_center_posISC_EERNS1_8full_posISC_EEEENSG_IT_EEOT0_OT1_OT2_:
 1823|    708|{
 1824|    708|    auto plan = concat_rebalance_plan<Node::bits, Node::bits_leaf>{};
 1825|    708|    plan.fill(lpos, cpos, rpos);
 1826|    708|    plan.shuffle(cpos.shift());
 1827|    708|    IMMER_TRY {
  ------------------
  |  |   49|    708|#define IMMER_TRY try
  ------------------
 1828|    708|        return plan.merge(lpos, cpos, rpos);
 1829|    708|    }
 1830|    708|    IMMER_CATCH (...) {
 1831|      0|        cpos.each_sub(dec_visitor{});
 1832|      0|        IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
 1833|      0|    }
 1834|    708|}
_ZN5immer6detail4rbts21concat_rebalance_planILj2ELj2EE4fillIRNS1_25singleton_regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEERNS1_17concat_center_posISF_EERNS1_8full_posISF_EEEEvOT_OT0_OT1_:
 1752|  1.84k|    {
 1753|  1.84k|        assert(n == 0u);
  ------------------
  |  Branch (1753:9): [True: 1.84k, False: 0]
  ------------------
 1754|  1.84k|        assert(total == 0u);
  ------------------
  |  Branch (1754:9): [True: 1.84k, False: 0]
  ------------------
 1755|  1.84k|        using visitor_t = concat_rebalance_plan_fill_visitor;
 1756|  1.84k|        lpos.each_left_sub(visitor_t{}, *this);
 1757|  1.84k|        cpos.each_sub(visitor_t{}, *this);
 1758|  1.84k|        rpos.each_right_sub(visitor_t{}, *this);
 1759|  1.84k|    }
_ZN5immer6detail4rbts21concat_rebalance_planILj2ELj2EE5mergeIRNS1_25singleton_regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEERNS1_17concat_center_posISF_EERNS1_8full_posISF_EEEENSI_INSt3__15decayIT0_E4type6node_tEEEOT_OSQ_OT1_:
 1802|    708|    {
 1803|    708|        using node_t    = node_type<CPos>;
 1804|    708|        using merger_t  = concat_merger<node_t>;
 1805|    708|        using visitor_t = concat_merger_visitor;
 1806|    708|        auto merger     = merger_t{cpos.shift(), counts, n};
 1807|    708|        IMMER_TRY {
  ------------------
  |  |   49|    708|#define IMMER_TRY try
  ------------------
 1808|    708|            lpos.each_left_sub(visitor_t{}, merger);
 1809|    708|            cpos.each_sub(visitor_t{}, merger);
 1810|    708|            rpos.each_right_sub(visitor_t{}, merger);
 1811|    708|            cpos.each_sub(dec_visitor{});
 1812|    708|            return merger.finish();
 1813|    708|        }
 1814|    708|        IMMER_CATCH (...) {
 1815|      0|            merger.abort();
 1816|      0|            IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
 1817|      0|        }
 1818|    708|    }
_ZN5immer6detail4rbts16concat_rebalanceINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEENS1_12null_sub_posERNS1_17concat_center_posISC_EERNS1_15regular_sub_posISC_EEEENSE_IT_EEOT0_OT1_OT2_:
 1823|  1.83k|{
 1824|  1.83k|    auto plan = concat_rebalance_plan<Node::bits, Node::bits_leaf>{};
 1825|  1.83k|    plan.fill(lpos, cpos, rpos);
 1826|  1.83k|    plan.shuffle(cpos.shift());
 1827|  1.83k|    IMMER_TRY {
  ------------------
  |  |   49|  1.83k|#define IMMER_TRY try
  ------------------
 1828|  1.83k|        return plan.merge(lpos, cpos, rpos);
 1829|  1.83k|    }
 1830|  1.83k|    IMMER_CATCH (...) {
 1831|      0|        cpos.each_sub(dec_visitor{});
 1832|      0|        IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
 1833|      0|    }
 1834|  1.83k|}
_ZN5immer6detail4rbts21concat_rebalance_planILj2ELj2EE4fillIRNS1_12null_sub_posERNS1_17concat_center_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEERNS1_15regular_sub_posISH_EEEEvOT_OT0_OT1_:
 1752|  4.19k|    {
 1753|  4.19k|        assert(n == 0u);
  ------------------
  |  Branch (1753:9): [True: 4.19k, False: 0]
  ------------------
 1754|  4.19k|        assert(total == 0u);
  ------------------
  |  Branch (1754:9): [True: 4.19k, False: 0]
  ------------------
 1755|  4.19k|        using visitor_t = concat_rebalance_plan_fill_visitor;
 1756|  4.19k|        lpos.each_left_sub(visitor_t{}, *this);
 1757|  4.19k|        cpos.each_sub(visitor_t{}, *this);
 1758|  4.19k|        rpos.each_right_sub(visitor_t{}, *this);
 1759|  4.19k|    }
_ZN5immer6detail4rbts34concat_rebalance_plan_fill_visitor10visit_nodeIRNS1_15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEENS1_21concat_rebalance_planILj2ELj2EEEEEvOT_RT0_:
 1733|   140k|    {
 1734|   140k|        auto count = p.count();
 1735|   140k|        assert(plan.n < Plan::max_children);
  ------------------
  |  Branch (1735:9): [True: 140k, False: 0]
  ------------------
 1736|   140k|        plan.counts[plan.n++] = count;
 1737|   140k|        plan.total += count;
 1738|   140k|    }
_ZN5immer6detail4rbts21concat_rebalance_planILj2ELj2EE5mergeIRNS1_12null_sub_posERNS1_17concat_center_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEERNS1_15regular_sub_posISH_EEEENS7_INSt3__15decayIT0_E4type6node_tEEEOT_OSP_OT1_:
 1802|  1.83k|    {
 1803|  1.83k|        using node_t    = node_type<CPos>;
 1804|  1.83k|        using merger_t  = concat_merger<node_t>;
 1805|  1.83k|        using visitor_t = concat_merger_visitor;
 1806|  1.83k|        auto merger     = merger_t{cpos.shift(), counts, n};
 1807|  1.83k|        IMMER_TRY {
  ------------------
  |  |   49|  1.83k|#define IMMER_TRY try
  ------------------
 1808|  1.83k|            lpos.each_left_sub(visitor_t{}, merger);
 1809|  1.83k|            cpos.each_sub(visitor_t{}, merger);
 1810|  1.83k|            rpos.each_right_sub(visitor_t{}, merger);
 1811|  1.83k|            cpos.each_sub(dec_visitor{});
 1812|  1.83k|            return merger.finish();
 1813|  1.83k|        }
 1814|  1.83k|        IMMER_CATCH (...) {
 1815|      0|            merger.abort();
 1816|      0|            IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
 1817|      0|        }
 1818|  1.83k|    }
_ZN5immer6detail4rbts21concat_merger_visitor11visit_innerIRNS1_15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEENS1_13concat_mergerISE_EEEEvOT_RT0_:
 1715|  16.3k|    {
 1716|  16.3k|        merger.merge_inner(p);
 1717|  16.3k|    }
_ZN5immer6detail4rbts13concat_mergerINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE11merge_innerIRNS1_15regular_sub_posISC_EEEEvOT_:
 1648|  16.3k|    {
 1649|  16.3k|        auto from       = p.node();
 1650|  16.3k|        auto from_size  = p.size();
 1651|  16.3k|        auto from_count = p.count();
 1652|  16.3k|        assert(from_size);
  ------------------
  |  Branch (1652:9): [True: 16.3k, False: 0]
  ------------------
 1653|  16.3k|        if (!to_ && *curr_ == from_count) {
  ------------------
  |  Branch (1653:13): [True: 15.8k, False: 518]
  |  Branch (1653:21): [True: 15.8k, False: 0]
  ------------------
 1654|  15.8k|            add_child(from, from_size);
 1655|  15.8k|            from->inc();
 1656|  15.8k|        } else {
 1657|    518|            auto from_offset = count_t{};
 1658|    518|            auto from_data   = from->inner();
 1659|  1.03k|            do {
 1660|  1.03k|                if (!to_) {
  ------------------
  |  Branch (1660:21): [True: 518, False: 518]
  ------------------
 1661|    518|                    to_        = node_t::make_inner_r_n(*curr_);
 1662|    518|                    to_offset_ = 0;
 1663|    518|                    to_size_   = 0;
 1664|    518|                }
 1665|  1.03k|                auto data = to_->inner();
 1666|  1.03k|                auto to_copy =
 1667|  1.03k|                    std::min(from_count - from_offset, *curr_ - to_offset_);
 1668|  1.03k|                std::copy(from_data + from_offset,
 1669|  1.03k|                          from_data + from_offset + to_copy,
 1670|  1.03k|                          data + to_offset_);
 1671|  1.03k|                node_t::inc_nodes(from_data + from_offset, to_copy);
 1672|  1.03k|                auto sizes = to_->relaxed()->d.sizes;
 1673|  1.03k|                p.copy_sizes(
 1674|  1.03k|                    from_offset, to_copy, to_size_, sizes + to_offset_);
 1675|  1.03k|                to_offset_ += to_copy;
 1676|  1.03k|                from_offset += to_copy;
 1677|  1.03k|                to_size_ = sizes[to_offset_ - 1];
 1678|  1.03k|                assert(to_size_);
  ------------------
  |  Branch (1678:17): [True: 1.03k, False: 0]
  ------------------
 1679|  1.03k|                if (*curr_ == to_offset_) {
  ------------------
  |  Branch (1679:21): [True: 518, False: 518]
  ------------------
 1680|    518|                    to_->relaxed()->d.count = to_offset_;
 1681|    518|                    add_child(to_, to_size_);
 1682|    518|                    to_ = nullptr;
 1683|    518|                }
 1684|  1.03k|            } while (from_offset != from_count);
  ------------------
  |  Branch (1684:22): [True: 518, False: 518]
  ------------------
 1685|    518|        }
 1686|  16.3k|    }
_ZN5immer6detail4rbts19concat_both_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE10visit_leafIRNS1_12leaf_sub_posISC_EERNS1_14empty_leaf_posISC_EERNS1_15regular_sub_posISC_EEEENS1_17concat_center_posISC_EEOT_OT0_OT1_:
 1944|    779|    {
 1945|    779|        return rpos.first_sub_leaf(concat_right_visitor<Node>{}, lpos, tpos);
 1946|    779|    }
_ZN5immer6detail4rbts20concat_right_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE10visit_leafIRNS1_12leaf_sub_posISC_EESH_RNS1_14empty_leaf_posISC_EEEENS1_17concat_center_posISC_EEOT_OT0_OT1_:
 1924|  1.57k|    {
 1925|  1.57k|        return concat_leafs<Node>(lpos, tpos, rpos);
 1926|  1.57k|    }
_ZN5immer6detail4rbts12concat_leafsINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEERNS1_12leaf_sub_posISC_EERNS1_14empty_leaf_posISC_EESF_EENS1_17concat_center_posIT_EEOT0_OT1_OT2_:
 1838|  1.57k|{
 1839|  1.57k|    static_assert(Node::bits >= 2, "");
 1840|  1.57k|    assert(lpos.shift() == tpos.shift());
  ------------------
  |  Branch (1840:5): [True: 1.57k, False: 0]
  ------------------
 1841|  1.57k|    assert(lpos.shift() == rpos.shift());
  ------------------
  |  Branch (1841:5): [True: 1.57k, False: 0]
  ------------------
 1842|  1.57k|    assert(lpos.shift() == 0);
  ------------------
  |  Branch (1842:5): [True: 1.57k, False: 0]
  ------------------
 1843|  1.57k|    if (tpos.count() > 0)
  ------------------
  |  Branch (1843:9): [True: 0, False: 1.57k]
  ------------------
 1844|      0|        return {
 1845|      0|            Node::bits_leaf,
 1846|      0|            lpos.node()->inc(),
 1847|      0|            lpos.count(),
 1848|      0|            tpos.node()->inc(),
 1849|      0|            tpos.count(),
 1850|      0|            rpos.node()->inc(),
 1851|      0|            rpos.count(),
 1852|      0|        };
 1853|  1.57k|    else
 1854|  1.57k|        return {
 1855|  1.57k|            Node::bits_leaf,
 1856|  1.57k|            lpos.node()->inc(),
 1857|  1.57k|            lpos.count(),
 1858|  1.57k|            rpos.node()->inc(),
 1859|  1.57k|            rpos.count(),
 1860|  1.57k|        };
 1861|  1.57k|}
_ZN5immer6detail4rbts16concat_rebalanceINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEERNS1_25singleton_regular_sub_posISC_EERNS1_17concat_center_posISC_EERNS1_15regular_sub_posISC_EEEENSG_IT_EEOT0_OT1_OT2_:
 1823|    779|{
 1824|    779|    auto plan = concat_rebalance_plan<Node::bits, Node::bits_leaf>{};
 1825|    779|    plan.fill(lpos, cpos, rpos);
 1826|    779|    plan.shuffle(cpos.shift());
 1827|    779|    IMMER_TRY {
  ------------------
  |  |   49|    779|#define IMMER_TRY try
  ------------------
 1828|    779|        return plan.merge(lpos, cpos, rpos);
 1829|    779|    }
 1830|    779|    IMMER_CATCH (...) {
 1831|      0|        cpos.each_sub(dec_visitor{});
 1832|      0|        IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
 1833|      0|    }
 1834|    779|}
_ZN5immer6detail4rbts21concat_rebalance_planILj2ELj2EE4fillIRNS1_25singleton_regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEERNS1_17concat_center_posISF_EERNS1_15regular_sub_posISF_EEEEvOT_OT0_OT1_:
 1752|  3.30k|    {
 1753|  3.30k|        assert(n == 0u);
  ------------------
  |  Branch (1753:9): [True: 3.30k, False: 0]
  ------------------
 1754|  3.30k|        assert(total == 0u);
  ------------------
  |  Branch (1754:9): [True: 3.30k, False: 0]
  ------------------
 1755|  3.30k|        using visitor_t = concat_rebalance_plan_fill_visitor;
 1756|  3.30k|        lpos.each_left_sub(visitor_t{}, *this);
 1757|  3.30k|        cpos.each_sub(visitor_t{}, *this);
 1758|  3.30k|        rpos.each_right_sub(visitor_t{}, *this);
 1759|  3.30k|    }
_ZN5immer6detail4rbts21concat_rebalance_planILj2ELj2EE5mergeIRNS1_25singleton_regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEERNS1_17concat_center_posISF_EERNS1_15regular_sub_posISF_EEEENSI_INSt3__15decayIT0_E4type6node_tEEEOT_OSQ_OT1_:
 1802|    779|    {
 1803|    779|        using node_t    = node_type<CPos>;
 1804|    779|        using merger_t  = concat_merger<node_t>;
 1805|    779|        using visitor_t = concat_merger_visitor;
 1806|    779|        auto merger     = merger_t{cpos.shift(), counts, n};
 1807|    779|        IMMER_TRY {
  ------------------
  |  |   49|    779|#define IMMER_TRY try
  ------------------
 1808|    779|            lpos.each_left_sub(visitor_t{}, merger);
 1809|    779|            cpos.each_sub(visitor_t{}, merger);
 1810|    779|            rpos.each_right_sub(visitor_t{}, merger);
 1811|    779|            cpos.each_sub(dec_visitor{});
 1812|    779|            return merger.finish();
 1813|    779|        }
 1814|    779|        IMMER_CATCH (...) {
 1815|      0|            merger.abort();
 1816|      0|            IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
 1817|      0|        }
 1818|    779|    }
_ZN5immer6detail4rbts16concat_rebalanceINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEENS1_12null_sub_posERNS1_17concat_center_posISC_EERNS1_11relaxed_posISC_EEEENSE_IT_EEOT0_OT1_OT2_:
 1823|  9.16k|{
 1824|  9.16k|    auto plan = concat_rebalance_plan<Node::bits, Node::bits_leaf>{};
 1825|  9.16k|    plan.fill(lpos, cpos, rpos);
 1826|  9.16k|    plan.shuffle(cpos.shift());
 1827|  9.16k|    IMMER_TRY {
  ------------------
  |  |   49|  9.16k|#define IMMER_TRY try
  ------------------
 1828|  9.16k|        return plan.merge(lpos, cpos, rpos);
 1829|  9.16k|    }
 1830|  9.16k|    IMMER_CATCH (...) {
 1831|      0|        cpos.each_sub(dec_visitor{});
 1832|      0|        IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
 1833|      0|    }
 1834|  9.16k|}
_ZN5immer6detail4rbts21concat_rebalance_planILj2ELj2EE4fillIRNS1_12null_sub_posERNS1_17concat_center_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEERNS1_11relaxed_posISH_EEEEvOT_OT0_OT1_:
 1752|  77.0k|    {
 1753|  77.0k|        assert(n == 0u);
  ------------------
  |  Branch (1753:9): [True: 77.0k, False: 0]
  ------------------
 1754|  77.0k|        assert(total == 0u);
  ------------------
  |  Branch (1754:9): [True: 77.0k, False: 0]
  ------------------
 1755|  77.0k|        using visitor_t = concat_rebalance_plan_fill_visitor;
 1756|  77.0k|        lpos.each_left_sub(visitor_t{}, *this);
 1757|  77.0k|        cpos.each_sub(visitor_t{}, *this);
 1758|  77.0k|        rpos.each_right_sub(visitor_t{}, *this);
 1759|  77.0k|    }
_ZN5immer6detail4rbts21concat_rebalance_planILj2ELj2EE5mergeIRNS1_12null_sub_posERNS1_17concat_center_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEERNS1_11relaxed_posISH_EEEENS7_INSt3__15decayIT0_E4type6node_tEEEOT_OSP_OT1_:
 1802|  9.16k|    {
 1803|  9.16k|        using node_t    = node_type<CPos>;
 1804|  9.16k|        using merger_t  = concat_merger<node_t>;
 1805|  9.16k|        using visitor_t = concat_merger_visitor;
 1806|  9.16k|        auto merger     = merger_t{cpos.shift(), counts, n};
 1807|  9.16k|        IMMER_TRY {
  ------------------
  |  |   49|  9.16k|#define IMMER_TRY try
  ------------------
 1808|  9.16k|            lpos.each_left_sub(visitor_t{}, merger);
 1809|  9.16k|            cpos.each_sub(visitor_t{}, merger);
 1810|  9.16k|            rpos.each_right_sub(visitor_t{}, merger);
 1811|  9.16k|            cpos.each_sub(dec_visitor{});
 1812|  9.16k|            return merger.finish();
 1813|  9.16k|        }
 1814|  9.16k|        IMMER_CATCH (...) {
 1815|      0|            merger.abort();
 1816|      0|            IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
 1817|      0|        }
 1818|  9.16k|    }
_ZN5immer6detail4rbts19concat_both_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE10visit_leafIRNS1_12leaf_sub_posISC_EERNS1_14empty_leaf_posISC_EERNS1_11relaxed_posISC_EEEENS1_17concat_center_posISC_EEOT_OT0_OT1_:
 1944|  1.57k|    {
 1945|  1.57k|        return rpos.first_sub_leaf(concat_right_visitor<Node>{}, lpos, tpos);
 1946|  1.57k|    }
_ZN5immer6detail4rbts16concat_rebalanceINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEERNS1_25singleton_regular_sub_posISC_EERNS1_17concat_center_posISC_EERNS1_11relaxed_posISC_EEEENSG_IT_EEOT0_OT1_OT2_:
 1823|  1.57k|{
 1824|  1.57k|    auto plan = concat_rebalance_plan<Node::bits, Node::bits_leaf>{};
 1825|  1.57k|    plan.fill(lpos, cpos, rpos);
 1826|  1.57k|    plan.shuffle(cpos.shift());
 1827|  1.57k|    IMMER_TRY {
  ------------------
  |  |   49|  1.57k|#define IMMER_TRY try
  ------------------
 1828|  1.57k|        return plan.merge(lpos, cpos, rpos);
 1829|  1.57k|    }
 1830|  1.57k|    IMMER_CATCH (...) {
 1831|      0|        cpos.each_sub(dec_visitor{});
 1832|      0|        IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
 1833|      0|    }
 1834|  1.57k|}
_ZN5immer6detail4rbts21concat_rebalance_planILj2ELj2EE4fillIRNS1_25singleton_regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEERNS1_17concat_center_posISF_EERNS1_11relaxed_posISF_EEEEvOT_OT0_OT1_:
 1752|  5.32k|    {
 1753|  5.32k|        assert(n == 0u);
  ------------------
  |  Branch (1753:9): [True: 5.32k, False: 0]
  ------------------
 1754|  5.32k|        assert(total == 0u);
  ------------------
  |  Branch (1754:9): [True: 5.32k, False: 0]
  ------------------
 1755|  5.32k|        using visitor_t = concat_rebalance_plan_fill_visitor;
 1756|  5.32k|        lpos.each_left_sub(visitor_t{}, *this);
 1757|  5.32k|        cpos.each_sub(visitor_t{}, *this);
 1758|  5.32k|        rpos.each_right_sub(visitor_t{}, *this);
 1759|  5.32k|    }
_ZN5immer6detail4rbts21concat_rebalance_planILj2ELj2EE5mergeIRNS1_25singleton_regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEERNS1_17concat_center_posISF_EERNS1_11relaxed_posISF_EEEENSI_INSt3__15decayIT0_E4type6node_tEEEOT_OSQ_OT1_:
 1802|  1.57k|    {
 1803|  1.57k|        using node_t    = node_type<CPos>;
 1804|  1.57k|        using merger_t  = concat_merger<node_t>;
 1805|  1.57k|        using visitor_t = concat_merger_visitor;
 1806|  1.57k|        auto merger     = merger_t{cpos.shift(), counts, n};
 1807|  1.57k|        IMMER_TRY {
  ------------------
  |  |   49|  1.57k|#define IMMER_TRY try
  ------------------
 1808|  1.57k|            lpos.each_left_sub(visitor_t{}, merger);
 1809|  1.57k|            cpos.each_sub(visitor_t{}, merger);
 1810|  1.57k|            rpos.each_right_sub(visitor_t{}, merger);
 1811|  1.57k|            cpos.each_sub(dec_visitor{});
 1812|  1.57k|            return merger.finish();
 1813|  1.57k|        }
 1814|  1.57k|        IMMER_CATCH (...) {
 1815|      0|            merger.abort();
 1816|      0|            IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
 1817|      0|        }
 1818|  1.57k|    }
_ZN5immer6detail4rbts26concat_trees_right_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE10visit_nodeIRNS1_15regular_sub_posISC_EERNS1_25singleton_regular_sub_posISC_EERNS1_14empty_leaf_posISC_EEEENS1_17concat_center_posISC_EEOT_OT0_OT1_:
 1958|  1.28k|    {
 1959|  1.28k|        return concat_inners<Node>(lpos, tpos, rpos);
 1960|  1.28k|    }
_ZNO5immer6detail4rbts17concat_center_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE7realizeEv:
 1527|  50.2k|    {
 1528|  50.2k|        if (count_ > 1) {
  ------------------
  |  Branch (1528:13): [True: 22.0k, False: 28.2k]
  ------------------
 1529|  22.0k|            IMMER_TRY {
  ------------------
  |  |   49|  22.0k|#define IMMER_TRY try
  ------------------
 1530|  22.0k|                auto result = node_t::make_inner_r_n(count_);
 1531|  22.0k|                auto r      = result->relaxed();
 1532|  22.0k|                r->d.count  = count_;
 1533|  22.0k|                std::copy(nodes_, nodes_ + count_, result->inner());
 1534|  22.0k|                std::copy(sizes_, sizes_ + count_, r->d.sizes);
 1535|  22.0k|                return {result, shift_, r};
 1536|  22.0k|            }
 1537|  22.0k|            IMMER_CATCH (...) {
 1538|      0|                each_sub(dec_visitor{});
 1539|      0|                IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
 1540|      0|            }
 1541|  28.2k|        } else {
 1542|  28.2k|            assert(shift_ >= B + BL);
  ------------------
  |  Branch (1542:13): [True: 28.2k, False: 0]
  ------------------
 1543|  28.2k|            return {nodes_[0], shift_ - B, nodes_[0]->relaxed()};
 1544|  28.2k|        }
 1545|  50.2k|    }
_ZN5immer6detail4rbts12concat_treesINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEENS1_11relaxed_posIT_EEPSE_jmSG_jSG_jm:
 1986|  47.2k|{
 1987|  47.2k|    return visit_maybe_relaxed_sub(lroot,
 1988|  47.2k|                                   lshift,
 1989|  47.2k|                                   lsize,
 1990|  47.2k|                                   concat_trees_left_visitor<Node>{},
 1991|  47.2k|                                   make_leaf_pos(ltail, ltcount),
 1992|  47.2k|                                   rroot,
 1993|  47.2k|                                   rshift,
 1994|  47.2k|                                   rsize)
 1995|  47.2k|        .realize();
 1996|  47.2k|}
_ZN5immer6detail4rbts25concat_trees_left_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE10visit_nodeIRNS1_11relaxed_posISC_EENS1_8leaf_posISC_EEJRPSC_RjRmEEENS1_17concat_center_posISC_EEOT_OT0_DpOT1_:
 1971|  41.4k|    {
 1972|  41.4k|        return visit_maybe_relaxed_sub(
 1973|  41.4k|            args..., concat_trees_right_visitor<Node>{}, lpos, tpos);
 1974|  41.4k|    }
_ZN5immer6detail4rbts26concat_trees_right_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE10visit_nodeIRNS1_11relaxed_posISC_EESH_RNS1_8leaf_posISC_EEEENS1_17concat_center_posISC_EEOT_OT0_OT1_:
 1958|  38.7k|    {
 1959|  38.7k|        return concat_inners<Node>(lpos, tpos, rpos);
 1960|  38.7k|    }
_ZN5immer6detail4rbts13concat_innersINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEERNS1_11relaxed_posISC_EERNS1_8leaf_posISC_EESF_EENS1_17concat_center_posIT_EEOT0_OT1_OT2_:
 1872|   211k|{
 1873|   211k|    auto lshift = lpos.shift();
 1874|   211k|    auto rshift = rpos.shift();
 1875|   211k|    if (lshift > rshift) {
  ------------------
  |  Branch (1875:9): [True: 2.84k, False: 208k]
  ------------------
 1876|  2.84k|        auto cpos = lpos.last_sub(concat_left_visitor<Node>{}, tpos, rpos);
 1877|  2.84k|        return concat_rebalance<Node>(lpos, cpos, null_sub_pos{});
 1878|   208k|    } else if (lshift < rshift) {
  ------------------
  |  Branch (1878:16): [True: 2.72k, False: 205k]
  ------------------
 1879|  2.72k|        auto cpos = rpos.first_sub(concat_right_visitor<Node>{}, lpos, tpos);
 1880|  2.72k|        return concat_rebalance<Node>(null_sub_pos{}, cpos, rpos);
 1881|   205k|    } else {
 1882|   205k|        assert(lshift == rshift);
  ------------------
  |  Branch (1882:9): [True: 205k, False: 0]
  ------------------
 1883|   205k|        assert(Node::bits_leaf == 0u || lshift > 0);
  ------------------
  |  Branch (1883:9): [Folded, False: 205k]
  |  Branch (1883:9): [True: 205k, False: 0]
  |  Branch (1883:9): [True: 205k, False: 0]
  ------------------
 1884|   205k|        auto cpos = lpos.last_sub(concat_both_visitor<Node>{}, tpos, rpos);
 1885|   205k|        return concat_rebalance<Node>(lpos, cpos, rpos);
 1886|   205k|    }
 1887|   211k|}
_ZN5immer6detail4rbts19concat_left_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE11visit_innerIRNS1_11relaxed_posISC_EERNS1_8leaf_posISC_EESH_EENS1_17concat_center_posISC_EEOT_OT0_OT1_:
 1897|  2.51k|    {
 1898|  2.51k|        return concat_inners<Node>(lpos, tpos, rpos);
 1899|  2.51k|    }
_ZN5immer6detail4rbts19concat_left_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE11visit_innerIRNS1_15regular_sub_posISC_EERNS1_8leaf_posISC_EERNS1_11relaxed_posISC_EEEENS1_17concat_center_posISC_EEOT_OT0_OT1_:
 1897|    799|    {
 1898|    799|        return concat_inners<Node>(lpos, tpos, rpos);
 1899|    799|    }
_ZN5immer6detail4rbts13concat_innersINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEERNS1_15regular_sub_posISC_EERNS1_8leaf_posISC_EERNS1_11relaxed_posISC_EEEENS1_17concat_center_posIT_EEOT0_OT1_OT2_:
 1872|  11.7k|{
 1873|  11.7k|    auto lshift = lpos.shift();
 1874|  11.7k|    auto rshift = rpos.shift();
 1875|  11.7k|    if (lshift > rshift) {
  ------------------
  |  Branch (1875:9): [True: 468, False: 11.3k]
  ------------------
 1876|    468|        auto cpos = lpos.last_sub(concat_left_visitor<Node>{}, tpos, rpos);
 1877|    468|        return concat_rebalance<Node>(lpos, cpos, null_sub_pos{});
 1878|  11.3k|    } else if (lshift < rshift) {
  ------------------
  |  Branch (1878:16): [True: 846, False: 10.4k]
  ------------------
 1879|    846|        auto cpos = rpos.first_sub(concat_right_visitor<Node>{}, lpos, tpos);
 1880|    846|        return concat_rebalance<Node>(null_sub_pos{}, cpos, rpos);
 1881|  10.4k|    } else {
 1882|  10.4k|        assert(lshift == rshift);
  ------------------
  |  Branch (1882:9): [True: 10.4k, False: 0]
  ------------------
 1883|  10.4k|        assert(Node::bits_leaf == 0u || lshift > 0);
  ------------------
  |  Branch (1883:9): [Folded, False: 10.4k]
  |  Branch (1883:9): [True: 10.4k, False: 0]
  |  Branch (1883:9): [True: 10.4k, False: 0]
  ------------------
 1884|  10.4k|        auto cpos = lpos.last_sub(concat_both_visitor<Node>{}, tpos, rpos);
 1885|  10.4k|        return concat_rebalance<Node>(lpos, cpos, rpos);
 1886|  10.4k|    }
 1887|  11.7k|}
_ZN5immer6detail4rbts16concat_rebalanceINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEERNS1_15regular_sub_posISC_EERNS1_17concat_center_posISC_EENS1_12null_sub_posEEENSG_IT_EEOT0_OT1_OT2_:
 1823|  1.43k|{
 1824|  1.43k|    auto plan = concat_rebalance_plan<Node::bits, Node::bits_leaf>{};
 1825|  1.43k|    plan.fill(lpos, cpos, rpos);
 1826|  1.43k|    plan.shuffle(cpos.shift());
 1827|  1.43k|    IMMER_TRY {
  ------------------
  |  |   49|  1.43k|#define IMMER_TRY try
  ------------------
 1828|  1.43k|        return plan.merge(lpos, cpos, rpos);
 1829|  1.43k|    }
 1830|  1.43k|    IMMER_CATCH (...) {
 1831|      0|        cpos.each_sub(dec_visitor{});
 1832|      0|        IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
 1833|      0|    }
 1834|  1.43k|}
_ZN5immer6detail4rbts21concat_rebalance_planILj2ELj2EE4fillIRNS1_15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEERNS1_17concat_center_posISF_EERNS1_12null_sub_posEEEvOT_OT0_OT1_:
 1752|  5.49k|    {
 1753|  5.49k|        assert(n == 0u);
  ------------------
  |  Branch (1753:9): [True: 5.49k, False: 0]
  ------------------
 1754|  5.49k|        assert(total == 0u);
  ------------------
  |  Branch (1754:9): [True: 5.49k, False: 0]
  ------------------
 1755|  5.49k|        using visitor_t = concat_rebalance_plan_fill_visitor;
 1756|  5.49k|        lpos.each_left_sub(visitor_t{}, *this);
 1757|  5.49k|        cpos.each_sub(visitor_t{}, *this);
 1758|  5.49k|        rpos.each_right_sub(visitor_t{}, *this);
 1759|  5.49k|    }
_ZN5immer6detail4rbts21concat_rebalance_planILj2ELj2EE5mergeIRNS1_15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEERNS1_17concat_center_posISF_EERNS1_12null_sub_posEEENSI_INSt3__15decayIT0_E4type6node_tEEEOT_OSP_OT1_:
 1802|  1.43k|    {
 1803|  1.43k|        using node_t    = node_type<CPos>;
 1804|  1.43k|        using merger_t  = concat_merger<node_t>;
 1805|  1.43k|        using visitor_t = concat_merger_visitor;
 1806|  1.43k|        auto merger     = merger_t{cpos.shift(), counts, n};
 1807|  1.43k|        IMMER_TRY {
  ------------------
  |  |   49|  1.43k|#define IMMER_TRY try
  ------------------
 1808|  1.43k|            lpos.each_left_sub(visitor_t{}, merger);
 1809|  1.43k|            cpos.each_sub(visitor_t{}, merger);
 1810|  1.43k|            rpos.each_right_sub(visitor_t{}, merger);
 1811|  1.43k|            cpos.each_sub(dec_visitor{});
 1812|  1.43k|            return merger.finish();
 1813|  1.43k|        }
 1814|  1.43k|        IMMER_CATCH (...) {
 1815|      0|            merger.abort();
 1816|      0|            IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
 1817|      0|        }
 1818|  1.43k|    }
_ZN5immer6detail4rbts20concat_right_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE11visit_innerIRNS1_11relaxed_posISC_EERNS1_15regular_sub_posISC_EERNS1_8leaf_posISC_EEEENS1_17concat_center_posISC_EEOT_OT0_OT1_:
 1917|  10.1k|    {
 1918|  10.1k|        return concat_inners<Node>(lpos, tpos, rpos);
 1919|  10.1k|    }
_ZN5immer6detail4rbts20concat_right_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE11visit_innerIRNS1_15regular_sub_posISC_EESH_RNS1_8leaf_posISC_EEEENS1_17concat_center_posISC_EEOT_OT0_OT1_:
 1917|    852|    {
 1918|    852|        return concat_inners<Node>(lpos, tpos, rpos);
 1919|    852|    }
_ZN5immer6detail4rbts13concat_innersINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEERNS1_15regular_sub_posISC_EERNS1_8leaf_posISC_EESF_EENS1_17concat_center_posIT_EEOT0_OT1_OT2_:
 1872|  7.09k|{
 1873|  7.09k|    auto lshift = lpos.shift();
 1874|  7.09k|    auto rshift = rpos.shift();
 1875|  7.09k|    if (lshift > rshift) {
  ------------------
  |  Branch (1875:9): [True: 967, False: 6.12k]
  ------------------
 1876|    967|        auto cpos = lpos.last_sub(concat_left_visitor<Node>{}, tpos, rpos);
 1877|    967|        return concat_rebalance<Node>(lpos, cpos, null_sub_pos{});
 1878|  6.12k|    } else if (lshift < rshift) {
  ------------------
  |  Branch (1878:16): [True: 558, False: 5.57k]
  ------------------
 1879|    558|        auto cpos = rpos.first_sub(concat_right_visitor<Node>{}, lpos, tpos);
 1880|    558|        return concat_rebalance<Node>(null_sub_pos{}, cpos, rpos);
 1881|  5.57k|    } else {
 1882|  5.57k|        assert(lshift == rshift);
  ------------------
  |  Branch (1882:9): [True: 5.57k, False: 0]
  ------------------
 1883|  5.57k|        assert(Node::bits_leaf == 0u || lshift > 0);
  ------------------
  |  Branch (1883:9): [Folded, False: 5.57k]
  |  Branch (1883:9): [True: 5.57k, False: 0]
  |  Branch (1883:9): [True: 5.57k, False: 0]
  ------------------
 1884|  5.57k|        auto cpos = lpos.last_sub(concat_both_visitor<Node>{}, tpos, rpos);
 1885|  5.57k|        return concat_rebalance<Node>(lpos, cpos, rpos);
 1886|  5.57k|    }
 1887|  7.09k|}
_ZN5immer6detail4rbts19concat_left_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE11visit_innerIRNS1_15regular_sub_posISC_EERNS1_8leaf_posISC_EESH_EENS1_17concat_center_posISC_EEOT_OT0_OT1_:
 1897|  1.30k|    {
 1898|  1.30k|        return concat_inners<Node>(lpos, tpos, rpos);
 1899|  1.30k|    }
_ZN5immer6detail4rbts20concat_right_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE11visit_innerIRNS1_8full_posISC_EERNS1_15regular_sub_posISC_EERNS1_8leaf_posISC_EEEENS1_17concat_center_posISC_EEOT_OT0_OT1_:
 1917|  4.16k|    {
 1918|  4.16k|        return concat_inners<Node>(lpos, tpos, rpos);
 1919|  4.16k|    }
_ZN5immer6detail4rbts13concat_innersINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEERNS1_15regular_sub_posISC_EERNS1_8leaf_posISC_EERNS1_8full_posISC_EEEENS1_17concat_center_posIT_EEOT0_OT1_OT2_:
 1872|  4.16k|{
 1873|  4.16k|    auto lshift = lpos.shift();
 1874|  4.16k|    auto rshift = rpos.shift();
 1875|  4.16k|    if (lshift > rshift) {
  ------------------
  |  Branch (1875:9): [True: 0, False: 4.16k]
  ------------------
 1876|      0|        auto cpos = lpos.last_sub(concat_left_visitor<Node>{}, tpos, rpos);
 1877|      0|        return concat_rebalance<Node>(lpos, cpos, null_sub_pos{});
 1878|  4.16k|    } else if (lshift < rshift) {
  ------------------
  |  Branch (1878:16): [True: 227, False: 3.93k]
  ------------------
 1879|    227|        auto cpos = rpos.first_sub(concat_right_visitor<Node>{}, lpos, tpos);
 1880|    227|        return concat_rebalance<Node>(null_sub_pos{}, cpos, rpos);
 1881|  3.93k|    } else {
 1882|  3.93k|        assert(lshift == rshift);
  ------------------
  |  Branch (1882:9): [True: 3.93k, False: 0]
  ------------------
 1883|  3.93k|        assert(Node::bits_leaf == 0u || lshift > 0);
  ------------------
  |  Branch (1883:9): [Folded, False: 3.93k]
  |  Branch (1883:9): [True: 3.93k, False: 0]
  |  Branch (1883:9): [True: 3.93k, False: 0]
  ------------------
 1884|  3.93k|        auto cpos = lpos.last_sub(concat_both_visitor<Node>{}, tpos, rpos);
 1885|  3.93k|        return concat_rebalance<Node>(lpos, cpos, rpos);
 1886|  3.93k|    }
 1887|  4.16k|}
_ZN5immer6detail4rbts19concat_both_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE10visit_leafIRNS1_12leaf_sub_posISC_EERNS1_8leaf_posISC_EERNS1_8full_posISC_EEEENS1_17concat_center_posISC_EEOT_OT0_OT1_:
 1944|  3.53k|    {
 1945|  3.53k|        return rpos.first_sub_leaf(concat_right_visitor<Node>{}, lpos, tpos);
 1946|  3.53k|    }
_ZN5immer6detail4rbts20concat_right_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE10visit_leafIRNS1_13full_leaf_posISC_EERNS1_12leaf_sub_posISC_EERNS1_8leaf_posISC_EEEENS1_17concat_center_posISC_EEOT_OT0_OT1_:
 1924|  8.75k|    {
 1925|  8.75k|        return concat_leafs<Node>(lpos, tpos, rpos);
 1926|  8.75k|    }
_ZN5immer6detail4rbts12concat_leafsINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEERNS1_12leaf_sub_posISC_EERNS1_8leaf_posISC_EERNS1_13full_leaf_posISC_EEEENS1_17concat_center_posIT_EEOT0_OT1_OT2_:
 1838|  8.75k|{
 1839|  8.75k|    static_assert(Node::bits >= 2, "");
 1840|  8.75k|    assert(lpos.shift() == tpos.shift());
  ------------------
  |  Branch (1840:5): [True: 8.75k, False: 0]
  ------------------
 1841|  8.75k|    assert(lpos.shift() == rpos.shift());
  ------------------
  |  Branch (1841:5): [True: 8.75k, False: 0]
  ------------------
 1842|  8.75k|    assert(lpos.shift() == 0);
  ------------------
  |  Branch (1842:5): [True: 8.75k, False: 0]
  ------------------
 1843|  8.75k|    if (tpos.count() > 0)
  ------------------
  |  Branch (1843:9): [True: 8.75k, False: 0]
  ------------------
 1844|  8.75k|        return {
 1845|  8.75k|            Node::bits_leaf,
 1846|  8.75k|            lpos.node()->inc(),
 1847|  8.75k|            lpos.count(),
 1848|  8.75k|            tpos.node()->inc(),
 1849|  8.75k|            tpos.count(),
 1850|  8.75k|            rpos.node()->inc(),
 1851|  8.75k|            rpos.count(),
 1852|  8.75k|        };
 1853|      0|    else
 1854|      0|        return {
 1855|      0|            Node::bits_leaf,
 1856|      0|            lpos.node()->inc(),
 1857|      0|            lpos.count(),
 1858|      0|            rpos.node()->inc(),
 1859|      0|            rpos.count(),
 1860|      0|        };
 1861|  8.75k|}
_ZN5immer6detail4rbts19concat_both_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE11visit_innerIRNS1_15regular_sub_posISC_EERNS1_8leaf_posISC_EERNS1_8full_posISC_EEEENS1_17concat_center_posISC_EEOT_OT0_OT1_:
 1937|  1.77k|    {
 1938|  1.77k|        return rpos.first_sub(concat_right_visitor<Node>{}, lpos, tpos);
 1939|  1.77k|    }
_ZN5immer6detail4rbts16concat_rebalanceINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEERNS1_15regular_sub_posISC_EERNS1_17concat_center_posISC_EERNS1_8full_posISC_EEEENSG_IT_EEOT0_OT1_OT2_:
 1823|  3.93k|{
 1824|  3.93k|    auto plan = concat_rebalance_plan<Node::bits, Node::bits_leaf>{};
 1825|  3.93k|    plan.fill(lpos, cpos, rpos);
 1826|  3.93k|    plan.shuffle(cpos.shift());
 1827|  3.93k|    IMMER_TRY {
  ------------------
  |  |   49|  3.93k|#define IMMER_TRY try
  ------------------
 1828|  3.93k|        return plan.merge(lpos, cpos, rpos);
 1829|  3.93k|    }
 1830|  3.93k|    IMMER_CATCH (...) {
 1831|      0|        cpos.each_sub(dec_visitor{});
 1832|      0|        IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
 1833|      0|    }
 1834|  3.93k|}
_ZN5immer6detail4rbts21concat_rebalance_planILj2ELj2EE4fillIRNS1_15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEERNS1_17concat_center_posISF_EERNS1_8full_posISF_EEEEvOT_OT0_OT1_:
 1752|  22.2k|    {
 1753|  22.2k|        assert(n == 0u);
  ------------------
  |  Branch (1753:9): [True: 22.2k, False: 0]
  ------------------
 1754|  22.2k|        assert(total == 0u);
  ------------------
  |  Branch (1754:9): [True: 22.2k, False: 0]
  ------------------
 1755|  22.2k|        using visitor_t = concat_rebalance_plan_fill_visitor;
 1756|  22.2k|        lpos.each_left_sub(visitor_t{}, *this);
 1757|  22.2k|        cpos.each_sub(visitor_t{}, *this);
 1758|  22.2k|        rpos.each_right_sub(visitor_t{}, *this);
 1759|  22.2k|    }
_ZN5immer6detail4rbts21concat_rebalance_planILj2ELj2EE5mergeIRNS1_15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEERNS1_17concat_center_posISF_EERNS1_8full_posISF_EEEENSI_INSt3__15decayIT0_E4type6node_tEEEOT_OSQ_OT1_:
 1802|  3.93k|    {
 1803|  3.93k|        using node_t    = node_type<CPos>;
 1804|  3.93k|        using merger_t  = concat_merger<node_t>;
 1805|  3.93k|        using visitor_t = concat_merger_visitor;
 1806|  3.93k|        auto merger     = merger_t{cpos.shift(), counts, n};
 1807|  3.93k|        IMMER_TRY {
  ------------------
  |  |   49|  3.93k|#define IMMER_TRY try
  ------------------
 1808|  3.93k|            lpos.each_left_sub(visitor_t{}, merger);
 1809|  3.93k|            cpos.each_sub(visitor_t{}, merger);
 1810|  3.93k|            rpos.each_right_sub(visitor_t{}, merger);
 1811|  3.93k|            cpos.each_sub(dec_visitor{});
 1812|  3.93k|            return merger.finish();
 1813|  3.93k|        }
 1814|  3.93k|        IMMER_CATCH (...) {
 1815|      0|            merger.abort();
 1816|      0|            IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
 1817|      0|        }
 1818|  3.93k|    }
_ZN5immer6detail4rbts19concat_both_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE10visit_leafIRNS1_12leaf_sub_posISC_EERNS1_8leaf_posISC_EERNS1_15regular_sub_posISC_EEEENS1_17concat_center_posISC_EEOT_OT0_OT1_:
 1944|  5.21k|    {
 1945|  5.21k|        return rpos.first_sub_leaf(concat_right_visitor<Node>{}, lpos, tpos);
 1946|  5.21k|    }
_ZN5immer6detail4rbts20concat_right_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE10visit_leafIRNS1_12leaf_sub_posISC_EESH_RNS1_8leaf_posISC_EEEENS1_17concat_center_posISC_EEOT_OT0_OT1_:
 1924|  38.4k|    {
 1925|  38.4k|        return concat_leafs<Node>(lpos, tpos, rpos);
 1926|  38.4k|    }
_ZN5immer6detail4rbts12concat_leafsINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEERNS1_12leaf_sub_posISC_EERNS1_8leaf_posISC_EESF_EENS1_17concat_center_posIT_EEOT0_OT1_OT2_:
 1838|  38.4k|{
 1839|  38.4k|    static_assert(Node::bits >= 2, "");
 1840|  38.4k|    assert(lpos.shift() == tpos.shift());
  ------------------
  |  Branch (1840:5): [True: 38.4k, False: 0]
  ------------------
 1841|  38.4k|    assert(lpos.shift() == rpos.shift());
  ------------------
  |  Branch (1841:5): [True: 38.4k, False: 0]
  ------------------
 1842|  38.4k|    assert(lpos.shift() == 0);
  ------------------
  |  Branch (1842:5): [True: 38.4k, False: 0]
  ------------------
 1843|  38.4k|    if (tpos.count() > 0)
  ------------------
  |  Branch (1843:9): [True: 38.4k, False: 0]
  ------------------
 1844|  38.4k|        return {
 1845|  38.4k|            Node::bits_leaf,
 1846|  38.4k|            lpos.node()->inc(),
 1847|  38.4k|            lpos.count(),
 1848|  38.4k|            tpos.node()->inc(),
 1849|  38.4k|            tpos.count(),
 1850|  38.4k|            rpos.node()->inc(),
 1851|  38.4k|            rpos.count(),
 1852|  38.4k|        };
 1853|      0|    else
 1854|      0|        return {
 1855|      0|            Node::bits_leaf,
 1856|      0|            lpos.node()->inc(),
 1857|      0|            lpos.count(),
 1858|      0|            rpos.node()->inc(),
 1859|      0|            rpos.count(),
 1860|      0|        };
 1861|  38.4k|}
_ZN5immer6detail4rbts19concat_both_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE11visit_innerIRNS1_15regular_sub_posISC_EERNS1_8leaf_posISC_EESH_EENS1_17concat_center_posISC_EEOT_OT0_OT1_:
 1937|  1.60k|    {
 1938|  1.60k|        return rpos.first_sub(concat_right_visitor<Node>{}, lpos, tpos);
 1939|  1.60k|    }
_ZN5immer6detail4rbts16concat_rebalanceINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEERNS1_15regular_sub_posISC_EERNS1_17concat_center_posISC_EESF_EENSG_IT_EEOT0_OT1_OT2_:
 1823|  5.57k|{
 1824|  5.57k|    auto plan = concat_rebalance_plan<Node::bits, Node::bits_leaf>{};
 1825|  5.57k|    plan.fill(lpos, cpos, rpos);
 1826|  5.57k|    plan.shuffle(cpos.shift());
 1827|  5.57k|    IMMER_TRY {
  ------------------
  |  |   49|  5.57k|#define IMMER_TRY try
  ------------------
 1828|  5.57k|        return plan.merge(lpos, cpos, rpos);
 1829|  5.57k|    }
 1830|  5.57k|    IMMER_CATCH (...) {
 1831|      0|        cpos.each_sub(dec_visitor{});
 1832|      0|        IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
 1833|      0|    }
 1834|  5.57k|}
_ZN5immer6detail4rbts21concat_rebalance_planILj2ELj2EE4fillIRNS1_15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEERNS1_17concat_center_posISF_EESH_EEvOT_OT0_OT1_:
 1752|  11.6k|    {
 1753|  11.6k|        assert(n == 0u);
  ------------------
  |  Branch (1753:9): [True: 11.6k, False: 0]
  ------------------
 1754|  11.6k|        assert(total == 0u);
  ------------------
  |  Branch (1754:9): [True: 11.6k, False: 0]
  ------------------
 1755|  11.6k|        using visitor_t = concat_rebalance_plan_fill_visitor;
 1756|  11.6k|        lpos.each_left_sub(visitor_t{}, *this);
 1757|  11.6k|        cpos.each_sub(visitor_t{}, *this);
 1758|  11.6k|        rpos.each_right_sub(visitor_t{}, *this);
 1759|  11.6k|    }
_ZN5immer6detail4rbts21concat_rebalance_planILj2ELj2EE5mergeIRNS1_15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEERNS1_17concat_center_posISF_EESH_EENSI_INSt3__15decayIT0_E4type6node_tEEEOT_OSN_OT1_:
 1802|  5.57k|    {
 1803|  5.57k|        using node_t    = node_type<CPos>;
 1804|  5.57k|        using merger_t  = concat_merger<node_t>;
 1805|  5.57k|        using visitor_t = concat_merger_visitor;
 1806|  5.57k|        auto merger     = merger_t{cpos.shift(), counts, n};
 1807|  5.57k|        IMMER_TRY {
  ------------------
  |  |   49|  5.57k|#define IMMER_TRY try
  ------------------
 1808|  5.57k|            lpos.each_left_sub(visitor_t{}, merger);
 1809|  5.57k|            cpos.each_sub(visitor_t{}, merger);
 1810|  5.57k|            rpos.each_right_sub(visitor_t{}, merger);
 1811|  5.57k|            cpos.each_sub(dec_visitor{});
 1812|  5.57k|            return merger.finish();
 1813|  5.57k|        }
 1814|  5.57k|        IMMER_CATCH (...) {
 1815|      0|            merger.abort();
 1816|      0|            IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
 1817|      0|        }
 1818|  5.57k|    }
_ZN5immer6detail4rbts19concat_both_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE10visit_leafIRNS1_12leaf_sub_posISC_EERNS1_8leaf_posISC_EERNS1_11relaxed_posISC_EEEENS1_17concat_center_posISC_EEOT_OT0_OT1_:
 1944|  38.4k|    {
 1945|  38.4k|        return rpos.first_sub_leaf(concat_right_visitor<Node>{}, lpos, tpos);
 1946|  38.4k|    }
_ZN5immer6detail4rbts19concat_both_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE11visit_innerIRNS1_15regular_sub_posISC_EERNS1_8leaf_posISC_EERNS1_11relaxed_posISC_EEEENS1_17concat_center_posISC_EEOT_OT0_OT1_:
 1937|  10.1k|    {
 1938|  10.1k|        return rpos.first_sub(concat_right_visitor<Node>{}, lpos, tpos);
 1939|  10.1k|    }
_ZN5immer6detail4rbts16concat_rebalanceINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEERNS1_15regular_sub_posISC_EERNS1_17concat_center_posISC_EERNS1_11relaxed_posISC_EEEENSG_IT_EEOT0_OT1_OT2_:
 1823|  10.4k|{
 1824|  10.4k|    auto plan = concat_rebalance_plan<Node::bits, Node::bits_leaf>{};
 1825|  10.4k|    plan.fill(lpos, cpos, rpos);
 1826|  10.4k|    plan.shuffle(cpos.shift());
 1827|  10.4k|    IMMER_TRY {
  ------------------
  |  |   49|  10.4k|#define IMMER_TRY try
  ------------------
 1828|  10.4k|        return plan.merge(lpos, cpos, rpos);
 1829|  10.4k|    }
 1830|  10.4k|    IMMER_CATCH (...) {
 1831|      0|        cpos.each_sub(dec_visitor{});
 1832|      0|        IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
 1833|      0|    }
 1834|  10.4k|}
_ZN5immer6detail4rbts21concat_rebalance_planILj2ELj2EE4fillIRNS1_15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEERNS1_17concat_center_posISF_EERNS1_11relaxed_posISF_EEEEvOT_OT0_OT1_:
 1752|   116k|    {
 1753|   116k|        assert(n == 0u);
  ------------------
  |  Branch (1753:9): [True: 116k, False: 0]
  ------------------
 1754|   116k|        assert(total == 0u);
  ------------------
  |  Branch (1754:9): [True: 116k, False: 0]
  ------------------
 1755|   116k|        using visitor_t = concat_rebalance_plan_fill_visitor;
 1756|   116k|        lpos.each_left_sub(visitor_t{}, *this);
 1757|   116k|        cpos.each_sub(visitor_t{}, *this);
 1758|   116k|        rpos.each_right_sub(visitor_t{}, *this);
 1759|   116k|    }
_ZN5immer6detail4rbts21concat_rebalance_planILj2ELj2EE5mergeIRNS1_15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEERNS1_17concat_center_posISF_EERNS1_11relaxed_posISF_EEEENSI_INSt3__15decayIT0_E4type6node_tEEEOT_OSQ_OT1_:
 1802|  10.4k|    {
 1803|  10.4k|        using node_t    = node_type<CPos>;
 1804|  10.4k|        using merger_t  = concat_merger<node_t>;
 1805|  10.4k|        using visitor_t = concat_merger_visitor;
 1806|  10.4k|        auto merger     = merger_t{cpos.shift(), counts, n};
 1807|  10.4k|        IMMER_TRY {
  ------------------
  |  |   49|  10.4k|#define IMMER_TRY try
  ------------------
 1808|  10.4k|            lpos.each_left_sub(visitor_t{}, merger);
 1809|  10.4k|            cpos.each_sub(visitor_t{}, merger);
 1810|  10.4k|            rpos.each_right_sub(visitor_t{}, merger);
 1811|  10.4k|            cpos.each_sub(dec_visitor{});
 1812|  10.4k|            return merger.finish();
 1813|  10.4k|        }
 1814|  10.4k|        IMMER_CATCH (...) {
 1815|      0|            merger.abort();
 1816|      0|            IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
 1817|      0|        }
 1818|  10.4k|    }
_ZN5immer6detail4rbts16concat_rebalanceINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEERNS1_11relaxed_posISC_EERNS1_17concat_center_posISC_EENS1_12null_sub_posEEENSG_IT_EEOT0_OT1_OT2_:
 1823|  4.84k|{
 1824|  4.84k|    auto plan = concat_rebalance_plan<Node::bits, Node::bits_leaf>{};
 1825|  4.84k|    plan.fill(lpos, cpos, rpos);
 1826|  4.84k|    plan.shuffle(cpos.shift());
 1827|  4.84k|    IMMER_TRY {
  ------------------
  |  |   49|  4.84k|#define IMMER_TRY try
  ------------------
 1828|  4.84k|        return plan.merge(lpos, cpos, rpos);
 1829|  4.84k|    }
 1830|  4.84k|    IMMER_CATCH (...) {
 1831|      0|        cpos.each_sub(dec_visitor{});
 1832|      0|        IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
 1833|      0|    }
 1834|  4.84k|}
_ZN5immer6detail4rbts21concat_rebalance_planILj2ELj2EE4fillIRNS1_11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEERNS1_17concat_center_posISF_EERNS1_12null_sub_posEEEvOT_OT0_OT1_:
 1752|   322k|    {
 1753|   322k|        assert(n == 0u);
  ------------------
  |  Branch (1753:9): [True: 322k, False: 0]
  ------------------
 1754|   322k|        assert(total == 0u);
  ------------------
  |  Branch (1754:9): [True: 322k, False: 0]
  ------------------
 1755|   322k|        using visitor_t = concat_rebalance_plan_fill_visitor;
 1756|   322k|        lpos.each_left_sub(visitor_t{}, *this);
 1757|   322k|        cpos.each_sub(visitor_t{}, *this);
 1758|   322k|        rpos.each_right_sub(visitor_t{}, *this);
 1759|   322k|    }
_ZN5immer6detail4rbts21concat_rebalance_planILj2ELj2EE5mergeIRNS1_11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEERNS1_17concat_center_posISF_EERNS1_12null_sub_posEEENSI_INSt3__15decayIT0_E4type6node_tEEEOT_OSP_OT1_:
 1802|  4.84k|    {
 1803|  4.84k|        using node_t    = node_type<CPos>;
 1804|  4.84k|        using merger_t  = concat_merger<node_t>;
 1805|  4.84k|        using visitor_t = concat_merger_visitor;
 1806|  4.84k|        auto merger     = merger_t{cpos.shift(), counts, n};
 1807|  4.84k|        IMMER_TRY {
  ------------------
  |  |   49|  4.84k|#define IMMER_TRY try
  ------------------
 1808|  4.84k|            lpos.each_left_sub(visitor_t{}, merger);
 1809|  4.84k|            cpos.each_sub(visitor_t{}, merger);
 1810|  4.84k|            rpos.each_right_sub(visitor_t{}, merger);
 1811|  4.84k|            cpos.each_sub(dec_visitor{});
 1812|  4.84k|            return merger.finish();
 1813|  4.84k|        }
 1814|  4.84k|        IMMER_CATCH (...) {
 1815|      0|            merger.abort();
 1816|      0|            IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
 1817|      0|        }
 1818|  4.84k|    }
_ZN5immer6detail4rbts20concat_right_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE11visit_innerIRNS1_11relaxed_posISC_EESH_RNS1_8leaf_posISC_EEEENS1_17concat_center_posISC_EEOT_OT0_OT1_:
 1917|   170k|    {
 1918|   170k|        return concat_inners<Node>(lpos, tpos, rpos);
 1919|   170k|    }
_ZN5immer6detail4rbts20concat_right_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE11visit_innerIRNS1_15regular_sub_posISC_EERNS1_11relaxed_posISC_EERNS1_8leaf_posISC_EEEENS1_17concat_center_posISC_EEOT_OT0_OT1_:
 1917|    297|    {
 1918|    297|        return concat_inners<Node>(lpos, tpos, rpos);
 1919|    297|    }
_ZN5immer6detail4rbts13concat_innersINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEERNS1_11relaxed_posISC_EERNS1_8leaf_posISC_EERNS1_15regular_sub_posISC_EEEENS1_17concat_center_posIT_EEOT0_OT1_OT2_:
 1872|  4.62k|{
 1873|  4.62k|    auto lshift = lpos.shift();
 1874|  4.62k|    auto rshift = rpos.shift();
 1875|  4.62k|    if (lshift > rshift) {
  ------------------
  |  Branch (1875:9): [True: 2.00k, False: 2.62k]
  ------------------
 1876|  2.00k|        auto cpos = lpos.last_sub(concat_left_visitor<Node>{}, tpos, rpos);
 1877|  2.00k|        return concat_rebalance<Node>(lpos, cpos, null_sub_pos{});
 1878|  2.62k|    } else if (lshift < rshift) {
  ------------------
  |  Branch (1878:16): [True: 568, False: 2.05k]
  ------------------
 1879|    568|        auto cpos = rpos.first_sub(concat_right_visitor<Node>{}, lpos, tpos);
 1880|    568|        return concat_rebalance<Node>(null_sub_pos{}, cpos, rpos);
 1881|  2.05k|    } else {
 1882|  2.05k|        assert(lshift == rshift);
  ------------------
  |  Branch (1882:9): [True: 2.05k, False: 0]
  ------------------
 1883|  2.05k|        assert(Node::bits_leaf == 0u || lshift > 0);
  ------------------
  |  Branch (1883:9): [Folded, False: 2.05k]
  |  Branch (1883:9): [True: 2.05k, False: 0]
  |  Branch (1883:9): [True: 2.05k, False: 0]
  ------------------
 1884|  2.05k|        auto cpos = lpos.last_sub(concat_both_visitor<Node>{}, tpos, rpos);
 1885|  2.05k|        return concat_rebalance<Node>(lpos, cpos, rpos);
 1886|  2.05k|    }
 1887|  4.62k|}
_ZN5immer6detail4rbts19concat_left_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE11visit_innerIRNS1_11relaxed_posISC_EERNS1_8leaf_posISC_EERNS1_15regular_sub_posISC_EEEENS1_17concat_center_posISC_EEOT_OT0_OT1_:
 1897|  1.66k|    {
 1898|  1.66k|        return concat_inners<Node>(lpos, tpos, rpos);
 1899|  1.66k|    }
_ZN5immer6detail4rbts20concat_right_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE11visit_innerIRNS1_8full_posISC_EERNS1_11relaxed_posISC_EERNS1_8leaf_posISC_EEEENS1_17concat_center_posISC_EEOT_OT0_OT1_:
 1917|  2.09k|    {
 1918|  2.09k|        return concat_inners<Node>(lpos, tpos, rpos);
 1919|  2.09k|    }
_ZN5immer6detail4rbts13concat_innersINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEERNS1_11relaxed_posISC_EERNS1_8leaf_posISC_EERNS1_8full_posISC_EEEENS1_17concat_center_posIT_EEOT0_OT1_OT2_:
 1872|  2.09k|{
 1873|  2.09k|    auto lshift = lpos.shift();
 1874|  2.09k|    auto rshift = rpos.shift();
 1875|  2.09k|    if (lshift > rshift) {
  ------------------
  |  Branch (1875:9): [True: 0, False: 2.09k]
  ------------------
 1876|      0|        auto cpos = lpos.last_sub(concat_left_visitor<Node>{}, tpos, rpos);
 1877|      0|        return concat_rebalance<Node>(lpos, cpos, null_sub_pos{});
 1878|  2.09k|    } else if (lshift < rshift) {
  ------------------
  |  Branch (1878:16): [True: 286, False: 1.80k]
  ------------------
 1879|    286|        auto cpos = rpos.first_sub(concat_right_visitor<Node>{}, lpos, tpos);
 1880|    286|        return concat_rebalance<Node>(null_sub_pos{}, cpos, rpos);
 1881|  1.80k|    } else {
 1882|  1.80k|        assert(lshift == rshift);
  ------------------
  |  Branch (1882:9): [True: 1.80k, False: 0]
  ------------------
 1883|  1.80k|        assert(Node::bits_leaf == 0u || lshift > 0);
  ------------------
  |  Branch (1883:9): [Folded, False: 1.80k]
  |  Branch (1883:9): [True: 1.80k, False: 0]
  |  Branch (1883:9): [True: 1.80k, False: 0]
  ------------------
 1884|  1.80k|        auto cpos = lpos.last_sub(concat_both_visitor<Node>{}, tpos, rpos);
 1885|  1.80k|        return concat_rebalance<Node>(lpos, cpos, rpos);
 1886|  1.80k|    }
 1887|  2.09k|}
_ZN5immer6detail4rbts19concat_both_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE11visit_innerIRNS1_11relaxed_posISC_EERNS1_8leaf_posISC_EERNS1_8full_posISC_EEEENS1_17concat_center_posISC_EEOT_OT0_OT1_:
 1937|    430|    {
 1938|    430|        return rpos.first_sub(concat_right_visitor<Node>{}, lpos, tpos);
 1939|    430|    }
_ZN5immer6detail4rbts16concat_rebalanceINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEERNS1_11relaxed_posISC_EERNS1_17concat_center_posISC_EERNS1_8full_posISC_EEEENSG_IT_EEOT0_OT1_OT2_:
 1823|  1.80k|{
 1824|  1.80k|    auto plan = concat_rebalance_plan<Node::bits, Node::bits_leaf>{};
 1825|  1.80k|    plan.fill(lpos, cpos, rpos);
 1826|  1.80k|    plan.shuffle(cpos.shift());
 1827|  1.80k|    IMMER_TRY {
  ------------------
  |  |   49|  1.80k|#define IMMER_TRY try
  ------------------
 1828|  1.80k|        return plan.merge(lpos, cpos, rpos);
 1829|  1.80k|    }
 1830|  1.80k|    IMMER_CATCH (...) {
 1831|      0|        cpos.each_sub(dec_visitor{});
 1832|      0|        IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
 1833|      0|    }
 1834|  1.80k|}
_ZN5immer6detail4rbts21concat_rebalance_planILj2ELj2EE4fillIRNS1_11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEERNS1_17concat_center_posISF_EERNS1_8full_posISF_EEEEvOT_OT0_OT1_:
 1752|  3.98k|    {
 1753|  3.98k|        assert(n == 0u);
  ------------------
  |  Branch (1753:9): [True: 3.98k, False: 0]
  ------------------
 1754|  3.98k|        assert(total == 0u);
  ------------------
  |  Branch (1754:9): [True: 3.98k, False: 0]
  ------------------
 1755|  3.98k|        using visitor_t = concat_rebalance_plan_fill_visitor;
 1756|  3.98k|        lpos.each_left_sub(visitor_t{}, *this);
 1757|  3.98k|        cpos.each_sub(visitor_t{}, *this);
 1758|  3.98k|        rpos.each_right_sub(visitor_t{}, *this);
 1759|  3.98k|    }
_ZN5immer6detail4rbts21concat_rebalance_planILj2ELj2EE5mergeIRNS1_11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEERNS1_17concat_center_posISF_EERNS1_8full_posISF_EEEENSI_INSt3__15decayIT0_E4type6node_tEEEOT_OSQ_OT1_:
 1802|  1.80k|    {
 1803|  1.80k|        using node_t    = node_type<CPos>;
 1804|  1.80k|        using merger_t  = concat_merger<node_t>;
 1805|  1.80k|        using visitor_t = concat_merger_visitor;
 1806|  1.80k|        auto merger     = merger_t{cpos.shift(), counts, n};
 1807|  1.80k|        IMMER_TRY {
  ------------------
  |  |   49|  1.80k|#define IMMER_TRY try
  ------------------
 1808|  1.80k|            lpos.each_left_sub(visitor_t{}, merger);
 1809|  1.80k|            cpos.each_sub(visitor_t{}, merger);
 1810|  1.80k|            rpos.each_right_sub(visitor_t{}, merger);
 1811|  1.80k|            cpos.each_sub(dec_visitor{});
 1812|  1.80k|            return merger.finish();
 1813|  1.80k|        }
 1814|  1.80k|        IMMER_CATCH (...) {
 1815|      0|            merger.abort();
 1816|      0|            IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
 1817|      0|        }
 1818|  1.80k|    }
_ZN5immer6detail4rbts19concat_both_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE11visit_innerIRNS1_11relaxed_posISC_EERNS1_8leaf_posISC_EERNS1_15regular_sub_posISC_EEEENS1_17concat_center_posISC_EEOT_OT0_OT1_:
 1937|    811|    {
 1938|    811|        return rpos.first_sub(concat_right_visitor<Node>{}, lpos, tpos);
 1939|    811|    }
_ZN5immer6detail4rbts16concat_rebalanceINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEERNS1_11relaxed_posISC_EERNS1_17concat_center_posISC_EERNS1_15regular_sub_posISC_EEEENSG_IT_EEOT0_OT1_OT2_:
 1823|  2.05k|{
 1824|  2.05k|    auto plan = concat_rebalance_plan<Node::bits, Node::bits_leaf>{};
 1825|  2.05k|    plan.fill(lpos, cpos, rpos);
 1826|  2.05k|    plan.shuffle(cpos.shift());
 1827|  2.05k|    IMMER_TRY {
  ------------------
  |  |   49|  2.05k|#define IMMER_TRY try
  ------------------
 1828|  2.05k|        return plan.merge(lpos, cpos, rpos);
 1829|  2.05k|    }
 1830|  2.05k|    IMMER_CATCH (...) {
 1831|      0|        cpos.each_sub(dec_visitor{});
 1832|      0|        IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
 1833|      0|    }
 1834|  2.05k|}
_ZN5immer6detail4rbts21concat_rebalance_planILj2ELj2EE4fillIRNS1_11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEERNS1_17concat_center_posISF_EERNS1_15regular_sub_posISF_EEEEvOT_OT0_OT1_:
 1752|  29.7k|    {
 1753|  29.7k|        assert(n == 0u);
  ------------------
  |  Branch (1753:9): [True: 29.7k, False: 0]
  ------------------
 1754|  29.7k|        assert(total == 0u);
  ------------------
  |  Branch (1754:9): [True: 29.7k, False: 0]
  ------------------
 1755|  29.7k|        using visitor_t = concat_rebalance_plan_fill_visitor;
 1756|  29.7k|        lpos.each_left_sub(visitor_t{}, *this);
 1757|  29.7k|        cpos.each_sub(visitor_t{}, *this);
 1758|  29.7k|        rpos.each_right_sub(visitor_t{}, *this);
 1759|  29.7k|    }
_ZN5immer6detail4rbts21concat_rebalance_planILj2ELj2EE5mergeIRNS1_11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEERNS1_17concat_center_posISF_EERNS1_15regular_sub_posISF_EEEENSI_INSt3__15decayIT0_E4type6node_tEEEOT_OSQ_OT1_:
 1802|  2.05k|    {
 1803|  2.05k|        using node_t    = node_type<CPos>;
 1804|  2.05k|        using merger_t  = concat_merger<node_t>;
 1805|  2.05k|        using visitor_t = concat_merger_visitor;
 1806|  2.05k|        auto merger     = merger_t{cpos.shift(), counts, n};
 1807|  2.05k|        IMMER_TRY {
  ------------------
  |  |   49|  2.05k|#define IMMER_TRY try
  ------------------
 1808|  2.05k|            lpos.each_left_sub(visitor_t{}, merger);
 1809|  2.05k|            cpos.each_sub(visitor_t{}, merger);
 1810|  2.05k|            rpos.each_right_sub(visitor_t{}, merger);
 1811|  2.05k|            cpos.each_sub(dec_visitor{});
 1812|  2.05k|            return merger.finish();
 1813|  2.05k|        }
 1814|  2.05k|        IMMER_CATCH (...) {
 1815|      0|            merger.abort();
 1816|      0|            IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
 1817|      0|        }
 1818|  2.05k|    }
_ZN5immer6detail4rbts19concat_both_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE11visit_innerIRNS1_11relaxed_posISC_EERNS1_8leaf_posISC_EESH_EENS1_17concat_center_posISC_EEOT_OT0_OT1_:
 1937|   167k|    {
 1938|   167k|        return rpos.first_sub(concat_right_visitor<Node>{}, lpos, tpos);
 1939|   167k|    }
_ZN5immer6detail4rbts16concat_rebalanceINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEERNS1_11relaxed_posISC_EERNS1_17concat_center_posISC_EESF_EENSG_IT_EEOT0_OT1_OT2_:
 1823|   205k|{
 1824|   205k|    auto plan = concat_rebalance_plan<Node::bits, Node::bits_leaf>{};
 1825|   205k|    plan.fill(lpos, cpos, rpos);
 1826|   205k|    plan.shuffle(cpos.shift());
 1827|   205k|    IMMER_TRY {
  ------------------
  |  |   49|   205k|#define IMMER_TRY try
  ------------------
 1828|   205k|        return plan.merge(lpos, cpos, rpos);
 1829|   205k|    }
 1830|   205k|    IMMER_CATCH (...) {
 1831|      0|        cpos.each_sub(dec_visitor{});
 1832|      0|        IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
 1833|      0|    }
 1834|   205k|}
_ZN5immer6detail4rbts21concat_rebalance_planILj2ELj2EE4fillIRNS1_11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEERNS1_17concat_center_posISF_EESH_EEvOT_OT0_OT1_:
 1752|   454k|    {
 1753|   454k|        assert(n == 0u);
  ------------------
  |  Branch (1753:9): [True: 454k, False: 0]
  ------------------
 1754|   454k|        assert(total == 0u);
  ------------------
  |  Branch (1754:9): [True: 454k, False: 0]
  ------------------
 1755|   454k|        using visitor_t = concat_rebalance_plan_fill_visitor;
 1756|   454k|        lpos.each_left_sub(visitor_t{}, *this);
 1757|   454k|        cpos.each_sub(visitor_t{}, *this);
 1758|   454k|        rpos.each_right_sub(visitor_t{}, *this);
 1759|   454k|    }
_ZN5immer6detail4rbts21concat_rebalance_planILj2ELj2EE5mergeIRNS1_11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEERNS1_17concat_center_posISF_EESH_EENSI_INSt3__15decayIT0_E4type6node_tEEEOT_OSN_OT1_:
 1802|   205k|    {
 1803|   205k|        using node_t    = node_type<CPos>;
 1804|   205k|        using merger_t  = concat_merger<node_t>;
 1805|   205k|        using visitor_t = concat_merger_visitor;
 1806|   205k|        auto merger     = merger_t{cpos.shift(), counts, n};
 1807|   205k|        IMMER_TRY {
  ------------------
  |  |   49|   205k|#define IMMER_TRY try
  ------------------
 1808|   205k|            lpos.each_left_sub(visitor_t{}, merger);
 1809|   205k|            cpos.each_sub(visitor_t{}, merger);
 1810|   205k|            rpos.each_right_sub(visitor_t{}, merger);
 1811|   205k|            cpos.each_sub(dec_visitor{});
 1812|   205k|            return merger.finish();
 1813|   205k|        }
 1814|   205k|        IMMER_CATCH (...) {
 1815|      0|            merger.abort();
 1816|      0|            IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
 1817|      0|        }
 1818|   205k|    }
_ZN5immer6detail4rbts26concat_trees_right_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE10visit_nodeIRNS1_15regular_sub_posISC_EERNS1_11relaxed_posISC_EERNS1_8leaf_posISC_EEEENS1_17concat_center_posISC_EEOT_OT0_OT1_:
 1958|  2.66k|    {
 1959|  2.66k|        return concat_inners<Node>(lpos, tpos, rpos);
 1960|  2.66k|    }
_ZN5immer6detail4rbts25concat_trees_left_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE10visit_nodeIRNS1_15regular_sub_posISC_EENS1_8leaf_posISC_EEJRPSC_RjRmEEENS1_17concat_center_posISC_EEOT_OT0_DpOT1_:
 1971|  5.78k|    {
 1972|  5.78k|        return visit_maybe_relaxed_sub(
 1973|  5.78k|            args..., concat_trees_right_visitor<Node>{}, lpos, tpos);
 1974|  5.78k|    }
_ZN5immer6detail4rbts26concat_trees_right_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE10visit_nodeIRNS1_11relaxed_posISC_EERNS1_15regular_sub_posISC_EERNS1_8leaf_posISC_EEEENS1_17concat_center_posISC_EEOT_OT0_OT1_:
 1958|    840|    {
 1959|    840|        return concat_inners<Node>(lpos, tpos, rpos);
 1960|    840|    }
_ZN5immer6detail4rbts26concat_trees_right_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE10visit_nodeIRNS1_15regular_sub_posISC_EESH_RNS1_8leaf_posISC_EEEENS1_17concat_center_posISC_EEOT_OT0_OT1_:
 1958|  4.94k|    {
 1959|  4.94k|        return concat_inners<Node>(lpos, tpos, rpos);
 1960|  4.94k|    }
_ZN5immer6detail4rbts21push_tail_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEELb1EE13visit_relaxedIRNS1_11relaxed_posISC_EEEEPSC_OT_NSA_5applyIS7_E4type4editESI_j:
  680|   881k|    {
  681|   881k|        auto node     = pos.node();
  682|   881k|        auto level    = pos.shift();
  683|   881k|        auto idx      = pos.count() - 1;
  684|   881k|        auto children = pos.size(idx);
  685|   881k|        auto new_idx =
  686|   881k|            children == size_t{1} << level || level == BL ? idx + 1 : idx;
  ------------------
  |  Branch (686:13): [True: 5.47k, False: 875k]
  |  Branch (686:47): [True: 1.35k, False: 874k]
  ------------------
  687|   881k|        auto new_child = static_cast<node_t*>(nullptr);
  688|   881k|        auto mutate    = Mutating && node->can_mutate(e);
  ------------------
  |  Branch (688:26): [True: 881k, Folded]
  |  Branch (688:38): [True: 875k, False: 5.88k]
  ------------------
  689|       |
  690|   881k|        if (new_idx >= branches<B>)
  ------------------
  |  Branch (690:13): [True: 3.39k, False: 877k]
  ------------------
  691|  3.39k|            return nullptr;
  692|   877k|        else if (idx == new_idx) {
  ------------------
  |  Branch (692:18): [True: 874k, False: 3.44k]
  ------------------
  693|   874k|            new_child =
  694|   874k|                mutate ? pos.last_oh_csh(this_t{}, idx, children, e, tail, ts)
  ------------------
  |  Branch (694:17): [True: 869k, False: 5.13k]
  ------------------
  695|   874k|                       : pos.last_oh_csh(
  696|  5.13k|                             this_no_mut_t{}, idx, children, e, tail, ts);
  697|   874k|            if (!new_child) {
  ------------------
  |  Branch (697:17): [True: 4.26k, False: 870k]
  ------------------
  698|  4.26k|                if (++new_idx < branches<B>)
  ------------------
  |  Branch (698:21): [True: 2.38k, False: 1.87k]
  ------------------
  699|  2.38k|                    new_child = node_t::make_path_e(e, level - B, tail);
  700|  1.87k|                else
  701|  1.87k|                    return nullptr;
  702|  4.26k|            }
  703|   874k|        } else
  704|  3.44k|            new_child = node_t::make_path_e(e, level - B, tail);
  705|       |
  706|   876k|        if (mutate) {
  ------------------
  |  Branch (706:13): [True: 870k, False: 5.16k]
  ------------------
  707|   870k|            auto count             = new_idx + 1;
  708|   870k|            auto relaxed           = node->ensure_mutable_relaxed_n(e, new_idx);
  709|   870k|            node->inner()[new_idx] = new_child;
  710|   870k|            relaxed->d.sizes[new_idx] = pos.size() + ts;
  711|   870k|            relaxed->d.count          = count;
  712|   870k|            assert(relaxed->d.sizes[new_idx]);
  ------------------
  |  Branch (712:13): [True: 870k, False: 0]
  ------------------
  713|   870k|            return node;
  714|   870k|        } else {
  715|  5.16k|            IMMER_TRY {
  ------------------
  |  |   49|  5.16k|#define IMMER_TRY try
  ------------------
  716|  5.16k|                auto count    = new_idx + 1;
  717|  5.16k|                auto new_node = node_t::copy_inner_r_e(e, pos.node(), new_idx);
  718|  5.16k|                auto relaxed  = new_node->relaxed();
  719|  5.16k|                new_node->inner()[new_idx] = new_child;
  720|  5.16k|                relaxed->d.sizes[new_idx]  = pos.size() + ts;
  721|  5.16k|                relaxed->d.count           = count;
  722|  5.16k|                assert(relaxed->d.sizes[new_idx]);
  ------------------
  |  Branch (722:17): [True: 5.16k, False: 0]
  ------------------
  723|  5.16k|                if (Mutating)
  ------------------
  |  Branch (723:21): [True: 5.16k, Folded]
  ------------------
  724|  5.16k|                    pos.visit(dec_visitor{});
  725|  5.16k|                return new_node;
  726|  5.16k|            }
  727|  5.16k|            IMMER_CATCH (...) {
  728|      0|                auto shift = pos.shift();
  729|      0|                auto size  = new_idx == idx ? children + ts : ts;
  ------------------
  |  Branch (729:30): [True: 0, False: 0]
  ------------------
  730|      0|                if (shift > BL) {
  ------------------
  |  Branch (730:21): [True: 0, False: 0]
  ------------------
  731|      0|                    tail->inc();
  732|      0|                    dec_inner(new_child, shift - B, size);
  733|      0|                }
  734|      0|                IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
  735|      0|            }
  736|  5.16k|        }
  737|   876k|    }
_ZN5immer6detail4rbts21push_tail_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEELb1EE13visit_regularIRNS1_15regular_sub_posISC_EEJRjEEEPSC_OT_NSA_5applyIS7_E4type4editESJ_DpOT0_:
  741|   669k|    {
  742|   669k|        assert((pos.size() & mask<BL>) == 0);
  ------------------
  |  Branch (742:9): [True: 669k, False: 0]
  ------------------
  743|   669k|        auto node    = pos.node();
  744|   669k|        auto idx     = pos.index(pos.size() - 1);
  745|   669k|        auto new_idx = pos.index(pos.size() + branches<BL> - 1);
  746|   669k|        auto mutate  = Mutating && node->can_mutate(e);
  ------------------
  |  Branch (746:24): [True: 669k, Folded]
  |  Branch (746:36): [True: 668k, False: 624]
  ------------------
  747|   669k|        if (mutate) {
  ------------------
  |  Branch (747:13): [True: 668k, False: 624]
  ------------------
  748|   668k|            node->inner()[new_idx] =
  749|   668k|                idx == new_idx ? pos.last_oh(this_t{}, idx, e, tail)
  ------------------
  |  Branch (749:17): [True: 662k, False: 6.72k]
  ------------------
  750|       |                               /* otherwise */
  751|   668k|                               : node_t::make_path_e(e, pos.shift() - B, tail);
  752|   668k|            return node;
  753|   668k|        } else {
  754|    624|            auto new_parent = node_t::make_inner_e(e);
  755|    624|            IMMER_TRY {
  ------------------
  |  |   49|    624|#define IMMER_TRY try
  ------------------
  756|    624|                new_parent->inner()[new_idx] =
  757|    624|                    idx == new_idx
  ------------------
  |  Branch (757:21): [True: 267, False: 357]
  ------------------
  758|    624|                        ? pos.last_oh(this_no_mut_t{}, idx, e, tail)
  759|       |                        /* otherwise */
  760|    624|                        : node_t::make_path_e(e, pos.shift() - B, tail);
  761|    624|                node_t::do_copy_inner(new_parent, node, new_idx);
  762|    624|                if (Mutating)
  ------------------
  |  Branch (762:21): [True: 624, Folded]
  ------------------
  763|    624|                    pos.visit(dec_visitor{});
  764|    624|                return new_parent;
  765|    624|            }
  766|    624|            IMMER_CATCH (...) {
  767|      0|                node_t::delete_inner_e(new_parent);
  768|      0|                IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
  769|      0|            }
  770|    624|        }
  771|   669k|    }
_ZN5immer6detail4rbts21push_tail_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEELb1EE13visit_regularIRNS1_11regular_posISC_EEJEEEPSC_OT_NSA_5applyIS7_E4type4editESI_DpOT0_:
  741|  9.05M|    {
  742|  9.05M|        assert((pos.size() & mask<BL>) == 0);
  ------------------
  |  Branch (742:9): [True: 9.05M, False: 0]
  ------------------
  743|  9.05M|        auto node    = pos.node();
  744|  9.05M|        auto idx     = pos.index(pos.size() - 1);
  745|  9.05M|        auto new_idx = pos.index(pos.size() + branches<BL> - 1);
  746|  9.05M|        auto mutate  = Mutating && node->can_mutate(e);
  ------------------
  |  Branch (746:24): [True: 9.05M, Folded]
  |  Branch (746:36): [True: 9.05M, False: 407]
  ------------------
  747|  9.05M|        if (mutate) {
  ------------------
  |  Branch (747:13): [True: 9.05M, False: 407]
  ------------------
  748|  9.05M|            node->inner()[new_idx] =
  749|  9.05M|                idx == new_idx ? pos.last_oh(this_t{}, idx, e, tail)
  ------------------
  |  Branch (749:17): [True: 7.39M, False: 1.66M]
  ------------------
  750|       |                               /* otherwise */
  751|  9.05M|                               : node_t::make_path_e(e, pos.shift() - B, tail);
  752|  9.05M|            return node;
  753|  9.05M|        } else {
  754|    407|            auto new_parent = node_t::make_inner_e(e);
  755|    407|            IMMER_TRY {
  ------------------
  |  |   49|    407|#define IMMER_TRY try
  ------------------
  756|    407|                new_parent->inner()[new_idx] =
  757|    407|                    idx == new_idx
  ------------------
  |  Branch (757:21): [True: 210, False: 197]
  ------------------
  758|    407|                        ? pos.last_oh(this_no_mut_t{}, idx, e, tail)
  759|       |                        /* otherwise */
  760|    407|                        : node_t::make_path_e(e, pos.shift() - B, tail);
  761|    407|                node_t::do_copy_inner(new_parent, node, new_idx);
  762|    407|                if (Mutating)
  ------------------
  |  Branch (762:21): [True: 407, Folded]
  ------------------
  763|    407|                    pos.visit(dec_visitor{});
  764|    407|                return new_parent;
  765|    407|            }
  766|    407|            IMMER_CATCH (...) {
  767|      0|                node_t::delete_inner_e(new_parent);
  768|      0|                IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
  769|      0|            }
  770|    407|        }
  771|  9.05M|    }
_ZN5immer6detail4rbts21push_tail_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEELb0EE13visit_regularIRNS1_11regular_posISC_EEJEEEPSC_OT_NSA_5applyIS7_E4type4editESI_DpOT0_:
  741|  7.98k|    {
  742|  7.98k|        assert((pos.size() & mask<BL>) == 0);
  ------------------
  |  Branch (742:9): [True: 7.98k, False: 0]
  ------------------
  743|  7.98k|        auto node    = pos.node();
  744|  7.98k|        auto idx     = pos.index(pos.size() - 1);
  745|  7.98k|        auto new_idx = pos.index(pos.size() + branches<BL> - 1);
  746|  7.98k|        auto mutate  = Mutating && node->can_mutate(e);
  ------------------
  |  Branch (746:24): [Folded, False: 7.98k]
  |  Branch (746:36): [True: 0, False: 0]
  ------------------
  747|  7.98k|        if (mutate) {
  ------------------
  |  Branch (747:13): [True: 0, False: 7.98k]
  ------------------
  748|      0|            node->inner()[new_idx] =
  749|      0|                idx == new_idx ? pos.last_oh(this_t{}, idx, e, tail)
  ------------------
  |  Branch (749:17): [True: 0, False: 0]
  ------------------
  750|       |                               /* otherwise */
  751|      0|                               : node_t::make_path_e(e, pos.shift() - B, tail);
  752|      0|            return node;
  753|  7.98k|        } else {
  754|  7.98k|            auto new_parent = node_t::make_inner_e(e);
  755|  7.98k|            IMMER_TRY {
  ------------------
  |  |   49|  7.98k|#define IMMER_TRY try
  ------------------
  756|  7.98k|                new_parent->inner()[new_idx] =
  757|  7.98k|                    idx == new_idx
  ------------------
  |  Branch (757:21): [True: 3.83k, False: 4.14k]
  ------------------
  758|  7.98k|                        ? pos.last_oh(this_no_mut_t{}, idx, e, tail)
  759|       |                        /* otherwise */
  760|  7.98k|                        : node_t::make_path_e(e, pos.shift() - B, tail);
  761|  7.98k|                node_t::do_copy_inner(new_parent, node, new_idx);
  762|  7.98k|                if (Mutating)
  ------------------
  |  Branch (762:21): [Folded, False: 7.98k]
  ------------------
  763|      0|                    pos.visit(dec_visitor{});
  764|  7.98k|                return new_parent;
  765|  7.98k|            }
  766|  7.98k|            IMMER_CATCH (...) {
  767|      0|                node_t::delete_inner_e(new_parent);
  768|      0|                IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
  769|      0|            }
  770|  7.98k|        }
  771|  7.98k|    }
_ZN5immer6detail4rbts21push_tail_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEELb0EE13visit_relaxedIRNS1_11relaxed_posISC_EEEEPSC_OT_NSA_5applyIS7_E4type4editESI_j:
  680|  19.1k|    {
  681|  19.1k|        auto node     = pos.node();
  682|  19.1k|        auto level    = pos.shift();
  683|  19.1k|        auto idx      = pos.count() - 1;
  684|  19.1k|        auto children = pos.size(idx);
  685|  19.1k|        auto new_idx =
  686|  19.1k|            children == size_t{1} << level || level == BL ? idx + 1 : idx;
  ------------------
  |  Branch (686:13): [True: 1.99k, False: 17.1k]
  |  Branch (686:47): [True: 208, False: 16.9k]
  ------------------
  687|  19.1k|        auto new_child = static_cast<node_t*>(nullptr);
  688|  19.1k|        auto mutate    = Mutating && node->can_mutate(e);
  ------------------
  |  Branch (688:26): [Folded, False: 19.1k]
  |  Branch (688:38): [True: 0, False: 0]
  ------------------
  689|       |
  690|  19.1k|        if (new_idx >= branches<B>)
  ------------------
  |  Branch (690:13): [True: 710, False: 18.4k]
  ------------------
  691|    710|            return nullptr;
  692|  18.4k|        else if (idx == new_idx) {
  ------------------
  |  Branch (692:18): [True: 16.9k, False: 1.49k]
  ------------------
  693|  16.9k|            new_child =
  694|  16.9k|                mutate ? pos.last_oh_csh(this_t{}, idx, children, e, tail, ts)
  ------------------
  |  Branch (694:17): [True: 0, False: 16.9k]
  ------------------
  695|  16.9k|                       : pos.last_oh_csh(
  696|  16.9k|                             this_no_mut_t{}, idx, children, e, tail, ts);
  697|  16.9k|            if (!new_child) {
  ------------------
  |  Branch (697:17): [True: 1.62k, False: 15.3k]
  ------------------
  698|  1.62k|                if (++new_idx < branches<B>)
  ------------------
  |  Branch (698:21): [True: 254, False: 1.36k]
  ------------------
  699|    254|                    new_child = node_t::make_path_e(e, level - B, tail);
  700|  1.36k|                else
  701|  1.36k|                    return nullptr;
  702|  1.62k|            }
  703|  16.9k|        } else
  704|  1.49k|            new_child = node_t::make_path_e(e, level - B, tail);
  705|       |
  706|  17.0k|        if (mutate) {
  ------------------
  |  Branch (706:13): [True: 0, False: 17.0k]
  ------------------
  707|      0|            auto count             = new_idx + 1;
  708|      0|            auto relaxed           = node->ensure_mutable_relaxed_n(e, new_idx);
  709|      0|            node->inner()[new_idx] = new_child;
  710|      0|            relaxed->d.sizes[new_idx] = pos.size() + ts;
  711|      0|            relaxed->d.count          = count;
  712|      0|            assert(relaxed->d.sizes[new_idx]);
  ------------------
  |  Branch (712:13): [True: 0, False: 0]
  ------------------
  713|      0|            return node;
  714|  17.0k|        } else {
  715|  17.0k|            IMMER_TRY {
  ------------------
  |  |   49|  17.0k|#define IMMER_TRY try
  ------------------
  716|  17.0k|                auto count    = new_idx + 1;
  717|  17.0k|                auto new_node = node_t::copy_inner_r_e(e, pos.node(), new_idx);
  718|  17.0k|                auto relaxed  = new_node->relaxed();
  719|  17.0k|                new_node->inner()[new_idx] = new_child;
  720|  17.0k|                relaxed->d.sizes[new_idx]  = pos.size() + ts;
  721|  17.0k|                relaxed->d.count           = count;
  722|  17.0k|                assert(relaxed->d.sizes[new_idx]);
  ------------------
  |  Branch (722:17): [True: 17.0k, False: 0]
  ------------------
  723|  17.0k|                if (Mutating)
  ------------------
  |  Branch (723:21): [Folded, False: 17.0k]
  ------------------
  724|      0|                    pos.visit(dec_visitor{});
  725|  17.0k|                return new_node;
  726|  17.0k|            }
  727|  17.0k|            IMMER_CATCH (...) {
  728|      0|                auto shift = pos.shift();
  729|      0|                auto size  = new_idx == idx ? children + ts : ts;
  ------------------
  |  Branch (729:30): [True: 0, False: 0]
  ------------------
  730|      0|                if (shift > BL) {
  ------------------
  |  Branch (730:21): [True: 0, False: 0]
  ------------------
  731|      0|                    tail->inc();
  732|      0|                    dec_inner(new_child, shift - B, size);
  733|      0|                }
  734|      0|                IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
  735|      0|            }
  736|  17.0k|        }
  737|  17.0k|    }
_ZN5immer6detail4rbts21push_tail_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEELb0EE13visit_regularIRNS1_15regular_sub_posISC_EEJRjEEEPSC_OT_NSA_5applyIS7_E4type4editESJ_DpOT0_:
  741|  2.93k|    {
  742|  2.93k|        assert((pos.size() & mask<BL>) == 0);
  ------------------
  |  Branch (742:9): [True: 2.93k, False: 0]
  ------------------
  743|  2.93k|        auto node    = pos.node();
  744|  2.93k|        auto idx     = pos.index(pos.size() - 1);
  745|  2.93k|        auto new_idx = pos.index(pos.size() + branches<BL> - 1);
  746|  2.93k|        auto mutate  = Mutating && node->can_mutate(e);
  ------------------
  |  Branch (746:24): [Folded, False: 2.93k]
  |  Branch (746:36): [True: 0, False: 0]
  ------------------
  747|  2.93k|        if (mutate) {
  ------------------
  |  Branch (747:13): [True: 0, False: 2.93k]
  ------------------
  748|      0|            node->inner()[new_idx] =
  749|      0|                idx == new_idx ? pos.last_oh(this_t{}, idx, e, tail)
  ------------------
  |  Branch (749:17): [True: 0, False: 0]
  ------------------
  750|       |                               /* otherwise */
  751|      0|                               : node_t::make_path_e(e, pos.shift() - B, tail);
  752|      0|            return node;
  753|  2.93k|        } else {
  754|  2.93k|            auto new_parent = node_t::make_inner_e(e);
  755|  2.93k|            IMMER_TRY {
  ------------------
  |  |   49|  2.93k|#define IMMER_TRY try
  ------------------
  756|  2.93k|                new_parent->inner()[new_idx] =
  757|  2.93k|                    idx == new_idx
  ------------------
  |  Branch (757:21): [True: 1.82k, False: 1.10k]
  ------------------
  758|  2.93k|                        ? pos.last_oh(this_no_mut_t{}, idx, e, tail)
  759|       |                        /* otherwise */
  760|  2.93k|                        : node_t::make_path_e(e, pos.shift() - B, tail);
  761|  2.93k|                node_t::do_copy_inner(new_parent, node, new_idx);
  762|  2.93k|                if (Mutating)
  ------------------
  |  Branch (762:21): [Folded, False: 2.93k]
  ------------------
  763|      0|                    pos.visit(dec_visitor{});
  764|  2.93k|                return new_parent;
  765|  2.93k|            }
  766|  2.93k|            IMMER_CATCH (...) {
  767|      0|                node_t::delete_inner_e(new_parent);
  768|      0|                IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
  769|      0|            }
  770|  2.93k|        }
  771|  2.93k|    }
_ZN5immer6detail4rbts21push_tail_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEELb1EE13visit_regularIRNS1_15regular_sub_posISC_EEJEEEPSC_OT_NSA_5applyIS7_E4type4editESI_DpOT0_:
  741|  1.01M|    {
  742|  1.01M|        assert((pos.size() & mask<BL>) == 0);
  ------------------
  |  Branch (742:9): [True: 1.01M, False: 0]
  ------------------
  743|  1.01M|        auto node    = pos.node();
  744|  1.01M|        auto idx     = pos.index(pos.size() - 1);
  745|  1.01M|        auto new_idx = pos.index(pos.size() + branches<BL> - 1);
  746|  1.01M|        auto mutate  = Mutating && node->can_mutate(e);
  ------------------
  |  Branch (746:24): [True: 1.01M, Folded]
  |  Branch (746:36): [True: 1.01M, False: 3.61k]
  ------------------
  747|  1.01M|        if (mutate) {
  ------------------
  |  Branch (747:13): [True: 1.01M, False: 3.61k]
  ------------------
  748|  1.01M|            node->inner()[new_idx] =
  749|  1.01M|                idx == new_idx ? pos.last_oh(this_t{}, idx, e, tail)
  ------------------
  |  Branch (749:17): [True: 1.00M, False: 11.5k]
  ------------------
  750|       |                               /* otherwise */
  751|  1.01M|                               : node_t::make_path_e(e, pos.shift() - B, tail);
  752|  1.01M|            return node;
  753|  1.01M|        } else {
  754|  3.61k|            auto new_parent = node_t::make_inner_e(e);
  755|  3.61k|            IMMER_TRY {
  ------------------
  |  |   49|  3.61k|#define IMMER_TRY try
  ------------------
  756|  3.61k|                new_parent->inner()[new_idx] =
  757|  3.61k|                    idx == new_idx
  ------------------
  |  Branch (757:21): [True: 1.83k, False: 1.78k]
  ------------------
  758|  3.61k|                        ? pos.last_oh(this_no_mut_t{}, idx, e, tail)
  759|       |                        /* otherwise */
  760|  3.61k|                        : node_t::make_path_e(e, pos.shift() - B, tail);
  761|  3.61k|                node_t::do_copy_inner(new_parent, node, new_idx);
  762|  3.61k|                if (Mutating)
  ------------------
  |  Branch (762:21): [True: 3.61k, Folded]
  ------------------
  763|  3.61k|                    pos.visit(dec_visitor{});
  764|  3.61k|                return new_parent;
  765|  3.61k|            }
  766|  3.61k|            IMMER_CATCH (...) {
  767|      0|                node_t::delete_inner_e(new_parent);
  768|      0|                IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
  769|      0|            }
  770|  3.61k|        }
  771|  1.01M|    }
_ZN5immer6detail4rbts17dec_empty_regularINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEEvPT_:
  580|  5.07k|{
  581|  5.07k|    make_empty_regular_pos(node).visit(dec_visitor());
  582|  5.07k|}
_ZN5immer6detail4rbts15get_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE13visit_relaxedIRNS1_11relaxed_posISC_EEEERiOT_mNSA_5applyIS7_E4type4editEPPSC_:
  595|  26.7k|    {
  596|  26.7k|        auto offset = pos.index(idx);
  597|  26.7k|        auto count  = pos.count();
  598|  26.7k|        auto node   = pos.node();
  599|  26.7k|        if (node->can_mutate(e)) {
  ------------------
  |  Branch (599:13): [True: 5.39k, False: 21.3k]
  ------------------
  600|  5.39k|            return pos.towards_oh(
  601|  5.39k|                this_t{}, idx, offset, e, &node->inner()[offset]);
  602|  21.3k|        } else {
  603|  21.3k|            auto new_node = node_t::copy_inner_sr_e(e, node, count);
  604|  21.3k|            IMMER_TRY {
  ------------------
  |  |   49|  21.3k|#define IMMER_TRY try
  ------------------
  605|  21.3k|                auto& res = pos.towards_oh(
  606|  21.3k|                    this_t{}, idx, offset, e, &new_node->inner()[offset]);
  607|  21.3k|                pos.visit(dec_visitor{});
  608|  21.3k|                *location = new_node;
  609|  21.3k|                return res;
  610|  21.3k|            }
  611|  21.3k|            IMMER_CATCH (...) {
  612|      0|                dec_relaxed(new_node, pos.shift());
  613|      0|                IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
  614|      0|            }
  615|  21.3k|        }
  616|  26.7k|    }
_ZN5immer6detail4rbts15get_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE10visit_leafIRNS1_12leaf_sub_posISC_EEEERiOT_mNSA_5applyIS7_E4type4editEPPSC_:
  652|  3.64k|    {
  653|  3.64k|        assert(pos.node() == *location);
  ------------------
  |  Branch (653:9): [True: 3.64k, False: 0]
  ------------------
  654|  3.64k|        auto node = pos.node();
  655|  3.64k|        if (node->can_mutate(e)) {
  ------------------
  |  Branch (655:13): [True: 787, False: 2.85k]
  ------------------
  656|    787|            return node->leaf()[pos.index(idx)];
  657|  2.85k|        } else {
  658|  2.85k|            auto new_node = node_t::copy_leaf_e(e, pos.node(), pos.count());
  659|  2.85k|            pos.visit(dec_visitor{});
  660|  2.85k|            *location = new_node;
  661|  2.85k|            return new_node->leaf()[pos.index(idx)];
  662|  2.85k|        }
  663|  3.64k|    }
_ZN5immer6detail4rbts15get_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE13visit_regularIRNS1_15regular_sub_posISC_EEEERiOT_mNSA_5applyIS7_E4type4editEPPSC_:
  621|  6.97k|    {
  622|  6.97k|        assert(pos.node() == *location);
  ------------------
  |  Branch (622:9): [True: 6.97k, False: 0]
  ------------------
  623|  6.97k|        auto offset = pos.index(idx);
  624|  6.97k|        auto count  = pos.count();
  625|  6.97k|        auto node   = pos.node();
  626|  6.97k|        if (node->can_mutate(e)) {
  ------------------
  |  Branch (626:13): [True: 2.57k, False: 4.40k]
  ------------------
  627|  2.57k|            return pos.towards_oh_ch(
  628|  2.57k|                this_t{}, idx, offset, count, e, &node->inner()[offset]);
  629|  4.40k|        } else {
  630|  4.40k|            auto new_node = node_t::copy_inner_e(e, node, count);
  631|  4.40k|            IMMER_TRY {
  ------------------
  |  |   49|  4.40k|#define IMMER_TRY try
  ------------------
  632|  4.40k|                auto& res = pos.towards_oh_ch(this_t{},
  633|  4.40k|                                              idx,
  634|  4.40k|                                              offset,
  635|  4.40k|                                              count,
  636|  4.40k|                                              e,
  637|  4.40k|                                              &new_node->inner()[offset]);
  638|  4.40k|                pos.visit(dec_visitor{});
  639|  4.40k|                *location = new_node;
  640|  4.40k|                return res;
  641|  4.40k|            }
  642|  4.40k|            IMMER_CATCH (...) {
  643|      0|                dec_regular(new_node, pos.shift(), pos.size());
  644|      0|                IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
  645|      0|            }
  646|  4.40k|        }
  647|  6.97k|    }
_ZN5immer6detail4rbts15get_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE10visit_leafIRNS1_13full_leaf_posISC_EEEERiOT_mNSA_5applyIS7_E4type4editEPPSC_:
  652|  5.54k|    {
  653|  5.54k|        assert(pos.node() == *location);
  ------------------
  |  Branch (653:9): [True: 5.54k, False: 0]
  ------------------
  654|  5.54k|        auto node = pos.node();
  655|  5.54k|        if (node->can_mutate(e)) {
  ------------------
  |  Branch (655:13): [True: 1.35k, False: 4.18k]
  ------------------
  656|  1.35k|            return node->leaf()[pos.index(idx)];
  657|  4.18k|        } else {
  658|  4.18k|            auto new_node = node_t::copy_leaf_e(e, pos.node(), pos.count());
  659|  4.18k|            pos.visit(dec_visitor{});
  660|  4.18k|            *location = new_node;
  661|  4.18k|            return new_node->leaf()[pos.index(idx)];
  662|  4.18k|        }
  663|  5.54k|    }
_ZN5immer6detail4rbts15get_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE13visit_regularIRNS1_8full_posISC_EEEERiOT_mNSA_5applyIS7_E4type4editEPPSC_:
  621|  6.63k|    {
  622|  6.63k|        assert(pos.node() == *location);
  ------------------
  |  Branch (622:9): [True: 6.63k, False: 0]
  ------------------
  623|  6.63k|        auto offset = pos.index(idx);
  624|  6.63k|        auto count  = pos.count();
  625|  6.63k|        auto node   = pos.node();
  626|  6.63k|        if (node->can_mutate(e)) {
  ------------------
  |  Branch (626:13): [True: 1.01k, False: 5.61k]
  ------------------
  627|  1.01k|            return pos.towards_oh_ch(
  628|  1.01k|                this_t{}, idx, offset, count, e, &node->inner()[offset]);
  629|  5.61k|        } else {
  630|  5.61k|            auto new_node = node_t::copy_inner_e(e, node, count);
  631|  5.61k|            IMMER_TRY {
  ------------------
  |  |   49|  5.61k|#define IMMER_TRY try
  ------------------
  632|  5.61k|                auto& res = pos.towards_oh_ch(this_t{},
  633|  5.61k|                                              idx,
  634|  5.61k|                                              offset,
  635|  5.61k|                                              count,
  636|  5.61k|                                              e,
  637|  5.61k|                                              &new_node->inner()[offset]);
  638|  5.61k|                pos.visit(dec_visitor{});
  639|  5.61k|                *location = new_node;
  640|  5.61k|                return res;
  641|  5.61k|            }
  642|  5.61k|            IMMER_CATCH (...) {
  643|      0|                dec_regular(new_node, pos.shift(), pos.size());
  644|      0|                IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
  645|      0|            }
  646|  5.61k|        }
  647|  6.63k|    }
_ZN5immer6detail4rbts15get_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE10visit_leafIRNS1_8leaf_posISC_EEEERiOT_mNSA_5applyIS7_E4type4editEPPSC_:
  652|  1.42k|    {
  653|  1.42k|        assert(pos.node() == *location);
  ------------------
  |  Branch (653:9): [True: 1.42k, False: 0]
  ------------------
  654|  1.42k|        auto node = pos.node();
  655|  1.42k|        if (node->can_mutate(e)) {
  ------------------
  |  Branch (655:13): [True: 955, False: 473]
  ------------------
  656|    955|            return node->leaf()[pos.index(idx)];
  657|    955|        } else {
  658|    473|            auto new_node = node_t::copy_leaf_e(e, pos.node(), pos.count());
  659|    473|            pos.visit(dec_visitor{});
  660|    473|            *location = new_node;
  661|    473|            return new_node->leaf()[pos.index(idx)];
  662|    473|        }
  663|  1.42k|    }
_ZN5immer6detail4rbts15get_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE13visit_regularIRNS1_11regular_posISC_EEEERiOT_mNSA_5applyIS7_E4type4editEPPSC_:
  621|  2.13k|    {
  622|  2.13k|        assert(pos.node() == *location);
  ------------------
  |  Branch (622:9): [True: 2.13k, False: 0]
  ------------------
  623|  2.13k|        auto offset = pos.index(idx);
  624|  2.13k|        auto count  = pos.count();
  625|  2.13k|        auto node   = pos.node();
  626|  2.13k|        if (node->can_mutate(e)) {
  ------------------
  |  Branch (626:13): [True: 1.41k, False: 719]
  ------------------
  627|  1.41k|            return pos.towards_oh_ch(
  628|  1.41k|                this_t{}, idx, offset, count, e, &node->inner()[offset]);
  629|  1.41k|        } else {
  630|    719|            auto new_node = node_t::copy_inner_e(e, node, count);
  631|    719|            IMMER_TRY {
  ------------------
  |  |   49|    719|#define IMMER_TRY try
  ------------------
  632|    719|                auto& res = pos.towards_oh_ch(this_t{},
  633|    719|                                              idx,
  634|    719|                                              offset,
  635|    719|                                              count,
  636|    719|                                              e,
  637|    719|                                              &new_node->inner()[offset]);
  638|    719|                pos.visit(dec_visitor{});
  639|    719|                *location = new_node;
  640|    719|                return res;
  641|    719|            }
  642|    719|            IMMER_CATCH (...) {
  643|      0|                dec_regular(new_node, pos.shift(), pos.size());
  644|      0|                IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
  645|      0|            }
  646|    719|        }
  647|  2.13k|    }
_ZN5immer6detail4rbts23slice_right_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEELb1ELb1EE13visit_relaxedIRNS1_11relaxed_posISC_EEEENSt3__15tupleIJjPSC_jSK_EEEOT_mNSA_5applyIS7_E4type4editE:
  913|  52.6k|    {
  914|  52.6k|        auto idx    = pos.index(last);
  915|  52.6k|        auto node   = pos.node();
  916|  52.6k|        auto mutate = Mutating && node->can_mutate(e);
  ------------------
  |  Branch (916:23): [True: 52.6k, Folded]
  |  Branch (916:35): [True: 43.6k, False: 8.97k]
  ------------------
  917|  52.6k|        if (Collapse && idx == 0) {
  ------------------
  |  Branch (917:13): [True: 52.6k, Folded]
  |  Branch (917:25): [True: 41.2k, False: 11.4k]
  ------------------
  918|  41.2k|            auto res = mutate ? pos.towards_oh(this_t{}, last, idx, e)
  ------------------
  |  Branch (918:24): [True: 34.6k, False: 6.56k]
  ------------------
  919|  41.2k|                              : pos.towards_oh(no_mut_t{}, last, idx, e);
  920|  41.2k|            if (Mutating)
  ------------------
  |  Branch (920:17): [True: 41.2k, Folded]
  ------------------
  921|  41.2k|                pos.visit(dec_right_visitor{}, count_t{1});
  922|  41.2k|            return res;
  923|  41.2k|        } else {
  924|  11.4k|            using std::get;
  925|  11.4k|            auto subs =
  926|  11.4k|                mutate ? pos.towards_oh(no_collapse_t{}, last, idx, e)
  ------------------
  |  Branch (926:17): [True: 9.00k, False: 2.40k]
  ------------------
  927|  11.4k|                       : pos.towards_oh(no_collapse_no_mut_t{}, last, idx, e);
  928|  11.4k|            auto next = get<1>(subs);
  929|  11.4k|            auto ts   = get<2>(subs);
  930|  11.4k|            auto tail = get<3>(subs);
  931|  11.4k|            IMMER_TRY {
  ------------------
  |  |   49|  11.4k|#define IMMER_TRY try
  ------------------
  932|  11.4k|                if (next) {
  ------------------
  |  Branch (932:21): [True: 8.38k, False: 3.01k]
  ------------------
  933|  8.38k|                    if (mutate) {
  ------------------
  |  Branch (933:25): [True: 6.58k, False: 1.80k]
  ------------------
  934|  6.58k|                        auto nodr = node->ensure_mutable_relaxed_n(e, idx);
  935|  6.58k|                        pos.each_right(dec_visitor{}, idx + 1);
  936|  6.58k|                        node->inner()[idx] = next;
  937|  6.58k|                        nodr->d.sizes[idx] = last + 1 - ts;
  938|  6.58k|                        nodr->d.count      = idx + 1;
  939|  6.58k|                        assert(nodr->d.sizes[idx]);
  ------------------
  |  Branch (939:25): [True: 6.58k, False: 0]
  ------------------
  940|  6.58k|                        return std::make_tuple(pos.shift(), node, ts, tail);
  941|  6.58k|                    } else {
  942|  1.80k|                        auto newn = node_t::copy_inner_r_e(e, node, idx);
  943|  1.80k|                        auto newr = newn->relaxed();
  944|  1.80k|                        newn->inner()[idx] = next;
  945|  1.80k|                        newr->d.sizes[idx] = last + 1 - ts;
  946|  1.80k|                        newr->d.count      = idx + 1;
  947|  1.80k|                        assert(newr->d.sizes[idx]);
  ------------------
  |  Branch (947:25): [True: 1.80k, False: 0]
  ------------------
  948|  1.80k|                        if (Mutating)
  ------------------
  |  Branch (948:29): [True: 1.80k, Folded]
  ------------------
  949|  1.80k|                            pos.visit(dec_visitor{});
  950|  1.80k|                        return std::make_tuple(pos.shift(), newn, ts, tail);
  951|  1.80k|                    }
  952|  8.38k|                } else if (idx == 0) {
  ------------------
  |  Branch (952:28): [True: 0, False: 3.01k]
  ------------------
  953|      0|                    if (Mutating)
  ------------------
  |  Branch (953:25): [True: 0, Folded]
  ------------------
  954|      0|                        pos.visit(dec_right_visitor{}, count_t{1});
  955|      0|                    return std::make_tuple(pos.shift(), nullptr, ts, tail);
  956|  3.01k|                } else if (Collapse && idx == 1 && pos.shift() > BL) {
  ------------------
  |  Branch (956:28): [True: 3.01k, Folded]
  |  Branch (956:40): [True: 2.07k, False: 939]
  |  Branch (956:52): [True: 1.29k, False: 782]
  ------------------
  957|  1.29k|                    auto newn = pos.node()->inner()[0];
  958|  1.29k|                    if (!mutate)
  ------------------
  |  Branch (958:25): [True: 140, False: 1.15k]
  ------------------
  959|    140|                        newn->inc();
  960|  1.29k|                    if (Mutating)
  ------------------
  |  Branch (960:25): [True: 1.29k, Folded]
  ------------------
  961|  1.29k|                        pos.visit(dec_right_visitor{}, count_t{2});
  962|  1.29k|                    return std::make_tuple(pos.shift() - B, newn, ts, tail);
  963|  1.72k|                } else {
  964|  1.72k|                    if (mutate) {
  ------------------
  |  Branch (964:25): [True: 1.25k, False: 463]
  ------------------
  965|  1.25k|                        pos.each_right(dec_visitor{}, idx + 1);
  966|  1.25k|                        node->ensure_mutable_relaxed_n(e, idx)->d.count = idx;
  967|  1.25k|                        return std::make_tuple(pos.shift(), node, ts, tail);
  968|  1.25k|                    } else {
  969|    463|                        auto newn = node_t::copy_inner_r_e(e, node, idx);
  970|    463|                        if (Mutating)
  ------------------
  |  Branch (970:29): [True: 463, Folded]
  ------------------
  971|    463|                            pos.visit(dec_visitor{});
  972|    463|                        return std::make_tuple(pos.shift(), newn, ts, tail);
  973|    463|                    }
  974|  1.72k|                }
  975|  11.4k|            }
  976|  11.4k|            IMMER_CATCH (...) {
  977|      0|                assert(!mutate);
  ------------------
  |  Branch (977:17): [True: 0, False: 0]
  ------------------
  978|      0|                assert(!next || pos.shift() > BL);
  ------------------
  |  Branch (978:17): [True: 0, False: 0]
  |  Branch (978:17): [True: 0, False: 0]
  |  Branch (978:17): [True: 0, False: 0]
  ------------------
  979|      0|                if (next)
  ------------------
  |  Branch (979:21): [True: 0, False: 0]
  ------------------
  980|      0|                    dec_inner(next,
  981|      0|                              pos.shift() - B,
  982|      0|                              last + 1 - ts - pos.size_before(idx));
  983|      0|                dec_leaf(tail, ts);
  984|      0|                IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
  985|      0|            }
  986|  11.4k|        }
  987|  52.6k|    }
_ZN5immer6detail4rbts23slice_right_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEELb1ELb1EE10visit_leafIRNS1_12leaf_sub_posISC_EEEENSt3__15tupleIJjPSC_jSK_EEEOT_mNSA_5applyIS7_E4type4editE:
 1059|  2.49k|    {
 1060|  2.49k|        auto old_tail_size = pos.count();
 1061|  2.49k|        auto new_tail_size = pos.index(last) + 1;
 1062|  2.49k|        auto node          = pos.node();
 1063|  2.49k|        auto mutate        = Mutating && node->can_mutate(e);
  ------------------
  |  Branch (1063:30): [True: 2.49k, Folded]
  |  Branch (1063:42): [True: 1.77k, False: 716]
  ------------------
 1064|  2.49k|        if (new_tail_size == old_tail_size) {
  ------------------
  |  Branch (1064:13): [True: 1.88k, False: 609]
  ------------------
 1065|  1.88k|            if (!Mutating)
  ------------------
  |  Branch (1065:17): [Folded, False: 1.88k]
  ------------------
 1066|      0|                node->inc();
 1067|  1.88k|            return std::make_tuple(0, nullptr, new_tail_size, node);
 1068|  1.88k|        } else if (mutate) {
  ------------------
  |  Branch (1068:20): [True: 321, False: 288]
  ------------------
 1069|    321|            detail::destroy_n(node->leaf() + new_tail_size,
 1070|    321|                              old_tail_size - new_tail_size);
 1071|    321|            return std::make_tuple(0, nullptr, new_tail_size, node);
 1072|    321|        } else {
 1073|    288|            auto new_tail = node_t::copy_leaf_e(e, node, new_tail_size);
 1074|    288|            if (Mutating)
  ------------------
  |  Branch (1074:17): [True: 288, Folded]
  ------------------
 1075|    288|                pos.visit(dec_visitor{});
 1076|    288|            return std::make_tuple(0, nullptr, new_tail_size, new_tail);
 1077|    288|        }
 1078|  2.49k|    }
_ZN5immer6detail4rbts23slice_right_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEELb1ELb0EE10visit_leafIRNS1_12leaf_sub_posISC_EEEENSt3__15tupleIJjPSC_jSK_EEEOT_mNSA_5applyIS7_E4type4editE:
 1059|  1.68k|    {
 1060|  1.68k|        auto old_tail_size = pos.count();
 1061|  1.68k|        auto new_tail_size = pos.index(last) + 1;
 1062|  1.68k|        auto node          = pos.node();
 1063|  1.68k|        auto mutate        = Mutating && node->can_mutate(e);
  ------------------
  |  Branch (1063:30): [Folded, False: 1.68k]
  |  Branch (1063:42): [True: 0, False: 0]
  ------------------
 1064|  1.68k|        if (new_tail_size == old_tail_size) {
  ------------------
  |  Branch (1064:13): [True: 489, False: 1.20k]
  ------------------
 1065|    489|            if (!Mutating)
  ------------------
  |  Branch (1065:17): [True: 489, Folded]
  ------------------
 1066|    489|                node->inc();
 1067|    489|            return std::make_tuple(0, nullptr, new_tail_size, node);
 1068|  1.20k|        } else if (mutate) {
  ------------------
  |  Branch (1068:20): [True: 0, False: 1.20k]
  ------------------
 1069|      0|            detail::destroy_n(node->leaf() + new_tail_size,
 1070|      0|                              old_tail_size - new_tail_size);
 1071|      0|            return std::make_tuple(0, nullptr, new_tail_size, node);
 1072|  1.20k|        } else {
 1073|  1.20k|            auto new_tail = node_t::copy_leaf_e(e, node, new_tail_size);
 1074|  1.20k|            if (Mutating)
  ------------------
  |  Branch (1074:17): [Folded, False: 1.20k]
  ------------------
 1075|      0|                pos.visit(dec_visitor{});
 1076|  1.20k|            return std::make_tuple(0, nullptr, new_tail_size, new_tail);
 1077|  1.20k|        }
 1078|  1.68k|    }
_ZN5immer6detail4rbts23slice_right_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEELb1ELb0EE13visit_relaxedIRNS1_11relaxed_posISC_EEEENSt3__15tupleIJjPSC_jSK_EEEOT_mNSA_5applyIS7_E4type4editE:
  913|  35.1k|    {
  914|  35.1k|        auto idx    = pos.index(last);
  915|  35.1k|        auto node   = pos.node();
  916|  35.1k|        auto mutate = Mutating && node->can_mutate(e);
  ------------------
  |  Branch (916:23): [Folded, False: 35.1k]
  |  Branch (916:35): [True: 0, False: 0]
  ------------------
  917|  35.1k|        if (Collapse && idx == 0) {
  ------------------
  |  Branch (917:13): [True: 35.1k, Folded]
  |  Branch (917:25): [True: 31.5k, False: 3.63k]
  ------------------
  918|  31.5k|            auto res = mutate ? pos.towards_oh(this_t{}, last, idx, e)
  ------------------
  |  Branch (918:24): [True: 0, False: 31.5k]
  ------------------
  919|  31.5k|                              : pos.towards_oh(no_mut_t{}, last, idx, e);
  920|  31.5k|            if (Mutating)
  ------------------
  |  Branch (920:17): [Folded, False: 31.5k]
  ------------------
  921|      0|                pos.visit(dec_right_visitor{}, count_t{1});
  922|  31.5k|            return res;
  923|  31.5k|        } else {
  924|  3.63k|            using std::get;
  925|  3.63k|            auto subs =
  926|  3.63k|                mutate ? pos.towards_oh(no_collapse_t{}, last, idx, e)
  ------------------
  |  Branch (926:17): [True: 0, False: 3.63k]
  ------------------
  927|  3.63k|                       : pos.towards_oh(no_collapse_no_mut_t{}, last, idx, e);
  928|  3.63k|            auto next = get<1>(subs);
  929|  3.63k|            auto ts   = get<2>(subs);
  930|  3.63k|            auto tail = get<3>(subs);
  931|  3.63k|            IMMER_TRY {
  ------------------
  |  |   49|  3.63k|#define IMMER_TRY try
  ------------------
  932|  3.63k|                if (next) {
  ------------------
  |  Branch (932:21): [True: 1.55k, False: 2.08k]
  ------------------
  933|  1.55k|                    if (mutate) {
  ------------------
  |  Branch (933:25): [True: 0, False: 1.55k]
  ------------------
  934|      0|                        auto nodr = node->ensure_mutable_relaxed_n(e, idx);
  935|      0|                        pos.each_right(dec_visitor{}, idx + 1);
  936|      0|                        node->inner()[idx] = next;
  937|      0|                        nodr->d.sizes[idx] = last + 1 - ts;
  938|      0|                        nodr->d.count      = idx + 1;
  939|      0|                        assert(nodr->d.sizes[idx]);
  ------------------
  |  Branch (939:25): [True: 0, False: 0]
  ------------------
  940|      0|                        return std::make_tuple(pos.shift(), node, ts, tail);
  941|  1.55k|                    } else {
  942|  1.55k|                        auto newn = node_t::copy_inner_r_e(e, node, idx);
  943|  1.55k|                        auto newr = newn->relaxed();
  944|  1.55k|                        newn->inner()[idx] = next;
  945|  1.55k|                        newr->d.sizes[idx] = last + 1 - ts;
  946|  1.55k|                        newr->d.count      = idx + 1;
  947|  1.55k|                        assert(newr->d.sizes[idx]);
  ------------------
  |  Branch (947:25): [True: 1.55k, False: 0]
  ------------------
  948|  1.55k|                        if (Mutating)
  ------------------
  |  Branch (948:29): [Folded, False: 1.55k]
  ------------------
  949|      0|                            pos.visit(dec_visitor{});
  950|  1.55k|                        return std::make_tuple(pos.shift(), newn, ts, tail);
  951|  1.55k|                    }
  952|  2.08k|                } else if (idx == 0) {
  ------------------
  |  Branch (952:28): [True: 0, False: 2.08k]
  ------------------
  953|      0|                    if (Mutating)
  ------------------
  |  Branch (953:25): [Folded, False: 0]
  ------------------
  954|      0|                        pos.visit(dec_right_visitor{}, count_t{1});
  955|      0|                    return std::make_tuple(pos.shift(), nullptr, ts, tail);
  956|  2.08k|                } else if (Collapse && idx == 1 && pos.shift() > BL) {
  ------------------
  |  Branch (956:28): [True: 2.08k, Folded]
  |  Branch (956:40): [True: 1.29k, False: 794]
  |  Branch (956:52): [True: 987, False: 306]
  ------------------
  957|    987|                    auto newn = pos.node()->inner()[0];
  958|    987|                    if (!mutate)
  ------------------
  |  Branch (958:25): [True: 987, False: 0]
  ------------------
  959|    987|                        newn->inc();
  960|    987|                    if (Mutating)
  ------------------
  |  Branch (960:25): [Folded, False: 987]
  ------------------
  961|      0|                        pos.visit(dec_right_visitor{}, count_t{2});
  962|    987|                    return std::make_tuple(pos.shift() - B, newn, ts, tail);
  963|  1.10k|                } else {
  964|  1.10k|                    if (mutate) {
  ------------------
  |  Branch (964:25): [True: 0, False: 1.10k]
  ------------------
  965|      0|                        pos.each_right(dec_visitor{}, idx + 1);
  966|      0|                        node->ensure_mutable_relaxed_n(e, idx)->d.count = idx;
  967|      0|                        return std::make_tuple(pos.shift(), node, ts, tail);
  968|  1.10k|                    } else {
  969|  1.10k|                        auto newn = node_t::copy_inner_r_e(e, node, idx);
  970|  1.10k|                        if (Mutating)
  ------------------
  |  Branch (970:29): [Folded, False: 1.10k]
  ------------------
  971|      0|                            pos.visit(dec_visitor{});
  972|  1.10k|                        return std::make_tuple(pos.shift(), newn, ts, tail);
  973|  1.10k|                    }
  974|  1.10k|                }
  975|  3.63k|            }
  976|  3.63k|            IMMER_CATCH (...) {
  977|      0|                assert(!mutate);
  ------------------
  |  Branch (977:17): [True: 0, False: 0]
  ------------------
  978|      0|                assert(!next || pos.shift() > BL);
  ------------------
  |  Branch (978:17): [True: 0, False: 0]
  |  Branch (978:17): [True: 0, False: 0]
  |  Branch (978:17): [True: 0, False: 0]
  ------------------
  979|      0|                if (next)
  ------------------
  |  Branch (979:21): [True: 0, False: 0]
  ------------------
  980|      0|                    dec_inner(next,
  981|      0|                              pos.shift() - B,
  982|      0|                              last + 1 - ts - pos.size_before(idx));
  983|      0|                dec_leaf(tail, ts);
  984|      0|                IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
  985|      0|            }
  986|  3.63k|        }
  987|  35.1k|    }
_ZN5immer6detail4rbts23slice_right_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEELb1ELb0EE13visit_regularIRNS1_15regular_sub_posISC_EEEENSt3__15tupleIJjPSC_jSK_EEEOT_mNSA_5applyIS7_E4type4editE:
  991|  1.24k|    {
  992|  1.24k|        auto idx    = pos.index(last);
  993|  1.24k|        auto node   = pos.node();
  994|  1.24k|        auto mutate = Mutating && node->can_mutate(e);
  ------------------
  |  Branch (994:23): [Folded, False: 1.24k]
  |  Branch (994:35): [True: 0, False: 0]
  ------------------
  995|  1.24k|        if (Collapse && idx == 0) {
  ------------------
  |  Branch (995:13): [True: 1.24k, Folded]
  |  Branch (995:25): [True: 378, False: 863]
  ------------------
  996|    378|            auto res = mutate ? pos.towards_oh(this_t{}, last, idx, e)
  ------------------
  |  Branch (996:24): [True: 0, False: 378]
  ------------------
  997|    378|                              : pos.towards_oh(no_mut_t{}, last, idx, e);
  998|    378|            if (Mutating)
  ------------------
  |  Branch (998:17): [Folded, False: 378]
  ------------------
  999|      0|                pos.visit(dec_right_visitor{}, count_t{1});
 1000|    378|            return res;
 1001|    863|        } else {
 1002|    863|            using std::get;
 1003|    863|            auto subs =
 1004|    863|                mutate ? pos.towards_oh(no_collapse_t{}, last, idx, e)
  ------------------
  |  Branch (1004:17): [True: 0, False: 863]
  ------------------
 1005|    863|                       : pos.towards_oh(no_collapse_no_mut_t{}, last, idx, e);
 1006|    863|            auto next = get<1>(subs);
 1007|    863|            auto ts   = get<2>(subs);
 1008|    863|            auto tail = get<3>(subs);
 1009|    863|            IMMER_TRY {
  ------------------
  |  |   49|    863|#define IMMER_TRY try
  ------------------
 1010|    863|                if (next) {
  ------------------
  |  Branch (1010:21): [True: 260, False: 603]
  ------------------
 1011|    260|                    if (mutate) {
  ------------------
  |  Branch (1011:25): [True: 0, False: 260]
  ------------------
 1012|      0|                        node->inner()[idx] = next;
 1013|      0|                        pos.each_right(dec_visitor{}, idx + 1);
 1014|      0|                        return std::make_tuple(pos.shift(), node, ts, tail);
 1015|    260|                    } else {
 1016|    260|                        auto newn          = node_t::copy_inner_e(e, node, idx);
 1017|    260|                        newn->inner()[idx] = next;
 1018|    260|                        if (Mutating)
  ------------------
  |  Branch (1018:29): [Folded, False: 260]
  ------------------
 1019|      0|                            pos.visit(dec_visitor{});
 1020|    260|                        return std::make_tuple(pos.shift(), newn, ts, tail);
 1021|    260|                    }
 1022|    603|                } else if (idx == 0) {
  ------------------
  |  Branch (1022:28): [True: 0, False: 603]
  ------------------
 1023|      0|                    if (Mutating)
  ------------------
  |  Branch (1023:25): [Folded, False: 0]
  ------------------
 1024|      0|                        pos.visit(dec_right_visitor{}, count_t{1});
 1025|      0|                    return std::make_tuple(pos.shift(), nullptr, ts, tail);
 1026|    603|                } else if (Collapse && idx == 1 && pos.shift() > BL) {
  ------------------
  |  Branch (1026:28): [True: 603, Folded]
  |  Branch (1026:40): [True: 400, False: 203]
  |  Branch (1026:52): [True: 194, False: 206]
  ------------------
 1027|    194|                    auto newn = pos.node()->inner()[0];
 1028|    194|                    if (!mutate)
  ------------------
  |  Branch (1028:25): [True: 194, False: 0]
  ------------------
 1029|    194|                        newn->inc();
 1030|    194|                    if (Mutating)
  ------------------
  |  Branch (1030:25): [Folded, False: 194]
  ------------------
 1031|      0|                        pos.visit(dec_right_visitor{}, count_t{2});
 1032|    194|                    return std::make_tuple(pos.shift() - B, newn, ts, tail);
 1033|    409|                } else {
 1034|    409|                    if (mutate) {
  ------------------
  |  Branch (1034:25): [True: 0, False: 409]
  ------------------
 1035|      0|                        pos.each_right(dec_visitor{}, idx + 1);
 1036|      0|                        return std::make_tuple(pos.shift(), node, ts, tail);
 1037|    409|                    } else {
 1038|    409|                        auto newn = node_t::copy_inner_e(e, node, idx);
 1039|    409|                        if (Mutating)
  ------------------
  |  Branch (1039:29): [Folded, False: 409]
  ------------------
 1040|      0|                            pos.visit(dec_visitor{});
 1041|    409|                        return std::make_tuple(pos.shift(), newn, ts, tail);
 1042|    409|                    }
 1043|    409|                }
 1044|    863|            }
 1045|    863|            IMMER_CATCH (...) {
 1046|      0|                assert(!mutate);
  ------------------
  |  Branch (1046:17): [True: 0, False: 0]
  ------------------
 1047|      0|                assert(!next || pos.shift() > BL);
  ------------------
  |  Branch (1047:17): [True: 0, False: 0]
  |  Branch (1047:17): [True: 0, False: 0]
  |  Branch (1047:17): [True: 0, False: 0]
  ------------------
 1048|      0|                assert(tail);
  ------------------
  |  Branch (1048:17): [True: 0, False: 0]
  ------------------
 1049|      0|                if (next)
  ------------------
  |  Branch (1049:21): [True: 0, False: 0]
  ------------------
 1050|      0|                    dec_regular(next, pos.shift() - B, last + 1 - ts);
 1051|      0|                dec_leaf(tail, ts);
 1052|      0|                IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
 1053|      0|            }
 1054|    863|        }
 1055|  1.24k|    }
_ZN5immer6detail4rbts23slice_right_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEELb1ELb0EE10visit_leafIRNS1_13full_leaf_posISC_EEEENSt3__15tupleIJjPSC_jSK_EEEOT_mNSA_5applyIS7_E4type4editE:
 1059|  1.71k|    {
 1060|  1.71k|        auto old_tail_size = pos.count();
 1061|  1.71k|        auto new_tail_size = pos.index(last) + 1;
 1062|  1.71k|        auto node          = pos.node();
 1063|  1.71k|        auto mutate        = Mutating && node->can_mutate(e);
  ------------------
  |  Branch (1063:30): [Folded, False: 1.71k]
  |  Branch (1063:42): [True: 0, False: 0]
  ------------------
 1064|  1.71k|        if (new_tail_size == old_tail_size) {
  ------------------
  |  Branch (1064:13): [True: 769, False: 946]
  ------------------
 1065|    769|            if (!Mutating)
  ------------------
  |  Branch (1065:17): [True: 769, Folded]
  ------------------
 1066|    769|                node->inc();
 1067|    769|            return std::make_tuple(0, nullptr, new_tail_size, node);
 1068|    946|        } else if (mutate) {
  ------------------
  |  Branch (1068:20): [True: 0, False: 946]
  ------------------
 1069|      0|            detail::destroy_n(node->leaf() + new_tail_size,
 1070|      0|                              old_tail_size - new_tail_size);
 1071|      0|            return std::make_tuple(0, nullptr, new_tail_size, node);
 1072|    946|        } else {
 1073|    946|            auto new_tail = node_t::copy_leaf_e(e, node, new_tail_size);
 1074|    946|            if (Mutating)
  ------------------
  |  Branch (1074:17): [Folded, False: 946]
  ------------------
 1075|      0|                pos.visit(dec_visitor{});
 1076|    946|            return std::make_tuple(0, nullptr, new_tail_size, new_tail);
 1077|    946|        }
 1078|  1.71k|    }
_ZN5immer6detail4rbts23slice_right_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEELb1ELb0EE13visit_regularIRNS1_8full_posISC_EEEENSt3__15tupleIJjPSC_jSK_EEEOT_mNSA_5applyIS7_E4type4editE:
  991|  2.92k|    {
  992|  2.92k|        auto idx    = pos.index(last);
  993|  2.92k|        auto node   = pos.node();
  994|  2.92k|        auto mutate = Mutating && node->can_mutate(e);
  ------------------
  |  Branch (994:23): [Folded, False: 2.92k]
  |  Branch (994:35): [True: 0, False: 0]
  ------------------
  995|  2.92k|        if (Collapse && idx == 0) {
  ------------------
  |  Branch (995:13): [True: 2.92k, Folded]
  |  Branch (995:25): [True: 1.51k, False: 1.41k]
  ------------------
  996|  1.51k|            auto res = mutate ? pos.towards_oh(this_t{}, last, idx, e)
  ------------------
  |  Branch (996:24): [True: 0, False: 1.51k]
  ------------------
  997|  1.51k|                              : pos.towards_oh(no_mut_t{}, last, idx, e);
  998|  1.51k|            if (Mutating)
  ------------------
  |  Branch (998:17): [Folded, False: 1.51k]
  ------------------
  999|      0|                pos.visit(dec_right_visitor{}, count_t{1});
 1000|  1.51k|            return res;
 1001|  1.51k|        } else {
 1002|  1.41k|            using std::get;
 1003|  1.41k|            auto subs =
 1004|  1.41k|                mutate ? pos.towards_oh(no_collapse_t{}, last, idx, e)
  ------------------
  |  Branch (1004:17): [True: 0, False: 1.41k]
  ------------------
 1005|  1.41k|                       : pos.towards_oh(no_collapse_no_mut_t{}, last, idx, e);
 1006|  1.41k|            auto next = get<1>(subs);
 1007|  1.41k|            auto ts   = get<2>(subs);
 1008|  1.41k|            auto tail = get<3>(subs);
 1009|  1.41k|            IMMER_TRY {
  ------------------
  |  |   49|  1.41k|#define IMMER_TRY try
  ------------------
 1010|  1.41k|                if (next) {
  ------------------
  |  Branch (1010:21): [True: 595, False: 818]
  ------------------
 1011|    595|                    if (mutate) {
  ------------------
  |  Branch (1011:25): [True: 0, False: 595]
  ------------------
 1012|      0|                        node->inner()[idx] = next;
 1013|      0|                        pos.each_right(dec_visitor{}, idx + 1);
 1014|      0|                        return std::make_tuple(pos.shift(), node, ts, tail);
 1015|    595|                    } else {
 1016|    595|                        auto newn          = node_t::copy_inner_e(e, node, idx);
 1017|    595|                        newn->inner()[idx] = next;
 1018|    595|                        if (Mutating)
  ------------------
  |  Branch (1018:29): [Folded, False: 595]
  ------------------
 1019|      0|                            pos.visit(dec_visitor{});
 1020|    595|                        return std::make_tuple(pos.shift(), newn, ts, tail);
 1021|    595|                    }
 1022|    818|                } else if (idx == 0) {
  ------------------
  |  Branch (1022:28): [True: 0, False: 818]
  ------------------
 1023|      0|                    if (Mutating)
  ------------------
  |  Branch (1023:25): [Folded, False: 0]
  ------------------
 1024|      0|                        pos.visit(dec_right_visitor{}, count_t{1});
 1025|      0|                    return std::make_tuple(pos.shift(), nullptr, ts, tail);
 1026|    818|                } else if (Collapse && idx == 1 && pos.shift() > BL) {
  ------------------
  |  Branch (1026:28): [True: 818, Folded]
  |  Branch (1026:40): [True: 562, False: 256]
  |  Branch (1026:52): [True: 258, False: 304]
  ------------------
 1027|    258|                    auto newn = pos.node()->inner()[0];
 1028|    258|                    if (!mutate)
  ------------------
  |  Branch (1028:25): [True: 258, False: 0]
  ------------------
 1029|    258|                        newn->inc();
 1030|    258|                    if (Mutating)
  ------------------
  |  Branch (1030:25): [Folded, False: 258]
  ------------------
 1031|      0|                        pos.visit(dec_right_visitor{}, count_t{2});
 1032|    258|                    return std::make_tuple(pos.shift() - B, newn, ts, tail);
 1033|    560|                } else {
 1034|    560|                    if (mutate) {
  ------------------
  |  Branch (1034:25): [True: 0, False: 560]
  ------------------
 1035|      0|                        pos.each_right(dec_visitor{}, idx + 1);
 1036|      0|                        return std::make_tuple(pos.shift(), node, ts, tail);
 1037|    560|                    } else {
 1038|    560|                        auto newn = node_t::copy_inner_e(e, node, idx);
 1039|    560|                        if (Mutating)
  ------------------
  |  Branch (1039:29): [Folded, False: 560]
  ------------------
 1040|      0|                            pos.visit(dec_visitor{});
 1041|    560|                        return std::make_tuple(pos.shift(), newn, ts, tail);
 1042|    560|                    }
 1043|    560|                }
 1044|  1.41k|            }
 1045|  1.41k|            IMMER_CATCH (...) {
 1046|      0|                assert(!mutate);
  ------------------
  |  Branch (1046:17): [True: 0, False: 0]
  ------------------
 1047|      0|                assert(!next || pos.shift() > BL);
  ------------------
  |  Branch (1047:17): [True: 0, False: 0]
  |  Branch (1047:17): [True: 0, False: 0]
  |  Branch (1047:17): [True: 0, False: 0]
  ------------------
 1048|      0|                assert(tail);
  ------------------
  |  Branch (1048:17): [True: 0, False: 0]
  ------------------
 1049|      0|                if (next)
  ------------------
  |  Branch (1049:21): [True: 0, False: 0]
  ------------------
 1050|      0|                    dec_regular(next, pos.shift() - B, last + 1 - ts);
 1051|      0|                dec_leaf(tail, ts);
 1052|      0|                IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
 1053|      0|            }
 1054|  1.41k|        }
 1055|  2.92k|    }
_ZN5immer6detail4rbts23slice_right_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEELb0ELb1EE10visit_leafIRNS1_13full_leaf_posISC_EEEENSt3__15tupleIJjPSC_jSK_EEEOT_mNSA_5applyIS7_E4type4editE:
 1059|  2.62k|    {
 1060|  2.62k|        auto old_tail_size = pos.count();
 1061|  2.62k|        auto new_tail_size = pos.index(last) + 1;
 1062|  2.62k|        auto node          = pos.node();
 1063|  2.62k|        auto mutate        = Mutating && node->can_mutate(e);
  ------------------
  |  Branch (1063:30): [True: 2.62k, Folded]
  |  Branch (1063:42): [True: 1.19k, False: 1.42k]
  ------------------
 1064|  2.62k|        if (new_tail_size == old_tail_size) {
  ------------------
  |  Branch (1064:13): [True: 1.11k, False: 1.50k]
  ------------------
 1065|  1.11k|            if (!Mutating)
  ------------------
  |  Branch (1065:17): [Folded, False: 1.11k]
  ------------------
 1066|      0|                node->inc();
 1067|  1.11k|            return std::make_tuple(0, nullptr, new_tail_size, node);
 1068|  1.50k|        } else if (mutate) {
  ------------------
  |  Branch (1068:20): [True: 694, False: 812]
  ------------------
 1069|    694|            detail::destroy_n(node->leaf() + new_tail_size,
 1070|    694|                              old_tail_size - new_tail_size);
 1071|    694|            return std::make_tuple(0, nullptr, new_tail_size, node);
 1072|    812|        } else {
 1073|    812|            auto new_tail = node_t::copy_leaf_e(e, node, new_tail_size);
 1074|    812|            if (Mutating)
  ------------------
  |  Branch (1074:17): [True: 812, Folded]
  ------------------
 1075|    812|                pos.visit(dec_visitor{});
 1076|    812|            return std::make_tuple(0, nullptr, new_tail_size, new_tail);
 1077|    812|        }
 1078|  2.62k|    }
_ZN5immer6detail4rbts23slice_right_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEELb0ELb1EE13visit_regularIRNS1_8full_posISC_EEEENSt3__15tupleIJjPSC_jSK_EEEOT_mNSA_5applyIS7_E4type4editE:
  991|  3.13k|    {
  992|  3.13k|        auto idx    = pos.index(last);
  993|  3.13k|        auto node   = pos.node();
  994|  3.13k|        auto mutate = Mutating && node->can_mutate(e);
  ------------------
  |  Branch (994:23): [True: 3.13k, Folded]
  |  Branch (994:35): [True: 979, False: 2.15k]
  ------------------
  995|  3.13k|        if (Collapse && idx == 0) {
  ------------------
  |  Branch (995:13): [Folded, False: 3.13k]
  |  Branch (995:25): [True: 0, False: 0]
  ------------------
  996|      0|            auto res = mutate ? pos.towards_oh(this_t{}, last, idx, e)
  ------------------
  |  Branch (996:24): [True: 0, False: 0]
  ------------------
  997|      0|                              : pos.towards_oh(no_mut_t{}, last, idx, e);
  998|      0|            if (Mutating)
  ------------------
  |  Branch (998:17): [True: 0, Folded]
  ------------------
  999|      0|                pos.visit(dec_right_visitor{}, count_t{1});
 1000|      0|            return res;
 1001|  3.13k|        } else {
 1002|  3.13k|            using std::get;
 1003|  3.13k|            auto subs =
 1004|  3.13k|                mutate ? pos.towards_oh(no_collapse_t{}, last, idx, e)
  ------------------
  |  Branch (1004:17): [True: 979, False: 2.15k]
  ------------------
 1005|  3.13k|                       : pos.towards_oh(no_collapse_no_mut_t{}, last, idx, e);
 1006|  3.13k|            auto next = get<1>(subs);
 1007|  3.13k|            auto ts   = get<2>(subs);
 1008|  3.13k|            auto tail = get<3>(subs);
 1009|  3.13k|            IMMER_TRY {
  ------------------
  |  |   49|  3.13k|#define IMMER_TRY try
  ------------------
 1010|  3.13k|                if (next) {
  ------------------
  |  Branch (1010:21): [True: 798, False: 2.33k]
  ------------------
 1011|    798|                    if (mutate) {
  ------------------
  |  Branch (1011:25): [True: 406, False: 392]
  ------------------
 1012|    406|                        node->inner()[idx] = next;
 1013|    406|                        pos.each_right(dec_visitor{}, idx + 1);
 1014|    406|                        return std::make_tuple(pos.shift(), node, ts, tail);
 1015|    406|                    } else {
 1016|    392|                        auto newn          = node_t::copy_inner_e(e, node, idx);
 1017|    392|                        newn->inner()[idx] = next;
 1018|    392|                        if (Mutating)
  ------------------
  |  Branch (1018:29): [True: 392, Folded]
  ------------------
 1019|    392|                            pos.visit(dec_visitor{});
 1020|    392|                        return std::make_tuple(pos.shift(), newn, ts, tail);
 1021|    392|                    }
 1022|  2.33k|                } else if (idx == 0) {
  ------------------
  |  Branch (1022:28): [True: 278, False: 2.05k]
  ------------------
 1023|    278|                    if (Mutating)
  ------------------
  |  Branch (1023:25): [True: 278, Folded]
  ------------------
 1024|    278|                        pos.visit(dec_right_visitor{}, count_t{1});
 1025|    278|                    return std::make_tuple(pos.shift(), nullptr, ts, tail);
 1026|  2.05k|                } else if (Collapse && idx == 1 && pos.shift() > BL) {
  ------------------
  |  Branch (1026:28): [Folded, False: 2.05k]
  |  Branch (1026:40): [True: 0, False: 0]
  |  Branch (1026:52): [True: 0, False: 0]
  ------------------
 1027|      0|                    auto newn = pos.node()->inner()[0];
 1028|      0|                    if (!mutate)
  ------------------
  |  Branch (1028:25): [True: 0, False: 0]
  ------------------
 1029|      0|                        newn->inc();
 1030|      0|                    if (Mutating)
  ------------------
  |  Branch (1030:25): [True: 0, Folded]
  ------------------
 1031|      0|                        pos.visit(dec_right_visitor{}, count_t{2});
 1032|      0|                    return std::make_tuple(pos.shift() - B, newn, ts, tail);
 1033|  2.05k|                } else {
 1034|  2.05k|                    if (mutate) {
  ------------------
  |  Branch (1034:25): [True: 552, False: 1.50k]
  ------------------
 1035|    552|                        pos.each_right(dec_visitor{}, idx + 1);
 1036|    552|                        return std::make_tuple(pos.shift(), node, ts, tail);
 1037|  1.50k|                    } else {
 1038|  1.50k|                        auto newn = node_t::copy_inner_e(e, node, idx);
 1039|  1.50k|                        if (Mutating)
  ------------------
  |  Branch (1039:29): [True: 1.50k, Folded]
  ------------------
 1040|  1.50k|                            pos.visit(dec_visitor{});
 1041|  1.50k|                        return std::make_tuple(pos.shift(), newn, ts, tail);
 1042|  1.50k|                    }
 1043|  2.05k|                }
 1044|  3.13k|            }
 1045|  3.13k|            IMMER_CATCH (...) {
 1046|      0|                assert(!mutate);
  ------------------
  |  Branch (1046:17): [True: 0, False: 0]
  ------------------
 1047|      0|                assert(!next || pos.shift() > BL);
  ------------------
  |  Branch (1047:17): [True: 0, False: 0]
  |  Branch (1047:17): [True: 0, False: 0]
  |  Branch (1047:17): [True: 0, False: 0]
  ------------------
 1048|      0|                assert(tail);
  ------------------
  |  Branch (1048:17): [True: 0, False: 0]
  ------------------
 1049|      0|                if (next)
  ------------------
  |  Branch (1049:21): [True: 0, False: 0]
  ------------------
 1050|      0|                    dec_regular(next, pos.shift() - B, last + 1 - ts);
 1051|      0|                dec_leaf(tail, ts);
 1052|      0|                IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
 1053|      0|            }
 1054|  3.13k|        }
 1055|  3.13k|    }
_ZN5immer6detail4rbts17dec_right_visitor13visit_regularIRNS1_8full_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEEEEvOT_j:
  878|  1.95k|    {
  879|  1.95k|        using node_t = node_type<Pos>;
  880|  1.95k|        auto node    = p.node();
  881|  1.95k|        if (node->dec()) {
  ------------------
  |  Branch (881:13): [True: 0, False: 1.95k]
  ------------------
  882|      0|            p.each_right(dec_t{}, idx);
  883|      0|            node_t::delete_inner(node, p.count());
  884|      0|        }
  885|  1.95k|    }
_ZN5immer6detail4rbts23slice_right_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEELb0ELb0EE10visit_leafIRNS1_13full_leaf_posISC_EEEENSt3__15tupleIJjPSC_jSK_EEEOT_mNSA_5applyIS7_E4type4editE:
 1059|  8.43k|    {
 1060|  8.43k|        auto old_tail_size = pos.count();
 1061|  8.43k|        auto new_tail_size = pos.index(last) + 1;
 1062|  8.43k|        auto node          = pos.node();
 1063|  8.43k|        auto mutate        = Mutating && node->can_mutate(e);
  ------------------
  |  Branch (1063:30): [Folded, False: 8.43k]
  |  Branch (1063:42): [True: 0, False: 0]
  ------------------
 1064|  8.43k|        if (new_tail_size == old_tail_size) {
  ------------------
  |  Branch (1064:13): [True: 3.40k, False: 5.03k]
  ------------------
 1065|  3.40k|            if (!Mutating)
  ------------------
  |  Branch (1065:17): [True: 3.40k, Folded]
  ------------------
 1066|  3.40k|                node->inc();
 1067|  3.40k|            return std::make_tuple(0, nullptr, new_tail_size, node);
 1068|  5.03k|        } else if (mutate) {
  ------------------
  |  Branch (1068:20): [True: 0, False: 5.03k]
  ------------------
 1069|      0|            detail::destroy_n(node->leaf() + new_tail_size,
 1070|      0|                              old_tail_size - new_tail_size);
 1071|      0|            return std::make_tuple(0, nullptr, new_tail_size, node);
 1072|  5.03k|        } else {
 1073|  5.03k|            auto new_tail = node_t::copy_leaf_e(e, node, new_tail_size);
 1074|  5.03k|            if (Mutating)
  ------------------
  |  Branch (1074:17): [Folded, False: 5.03k]
  ------------------
 1075|      0|                pos.visit(dec_visitor{});
 1076|  5.03k|            return std::make_tuple(0, nullptr, new_tail_size, new_tail);
 1077|  5.03k|        }
 1078|  8.43k|    }
_ZN5immer6detail4rbts23slice_right_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEELb0ELb0EE13visit_regularIRNS1_8full_posISC_EEEENSt3__15tupleIJjPSC_jSK_EEEOT_mNSA_5applyIS7_E4type4editE:
  991|  5.31k|    {
  992|  5.31k|        auto idx    = pos.index(last);
  993|  5.31k|        auto node   = pos.node();
  994|  5.31k|        auto mutate = Mutating && node->can_mutate(e);
  ------------------
  |  Branch (994:23): [Folded, False: 5.31k]
  |  Branch (994:35): [True: 0, False: 0]
  ------------------
  995|  5.31k|        if (Collapse && idx == 0) {
  ------------------
  |  Branch (995:13): [Folded, False: 5.31k]
  |  Branch (995:25): [True: 0, False: 0]
  ------------------
  996|      0|            auto res = mutate ? pos.towards_oh(this_t{}, last, idx, e)
  ------------------
  |  Branch (996:24): [True: 0, False: 0]
  ------------------
  997|      0|                              : pos.towards_oh(no_mut_t{}, last, idx, e);
  998|      0|            if (Mutating)
  ------------------
  |  Branch (998:17): [Folded, False: 0]
  ------------------
  999|      0|                pos.visit(dec_right_visitor{}, count_t{1});
 1000|      0|            return res;
 1001|  5.31k|        } else {
 1002|  5.31k|            using std::get;
 1003|  5.31k|            auto subs =
 1004|  5.31k|                mutate ? pos.towards_oh(no_collapse_t{}, last, idx, e)
  ------------------
  |  Branch (1004:17): [True: 0, False: 5.31k]
  ------------------
 1005|  5.31k|                       : pos.towards_oh(no_collapse_no_mut_t{}, last, idx, e);
 1006|  5.31k|            auto next = get<1>(subs);
 1007|  5.31k|            auto ts   = get<2>(subs);
 1008|  5.31k|            auto tail = get<3>(subs);
 1009|  5.31k|            IMMER_TRY {
  ------------------
  |  |   49|  5.31k|#define IMMER_TRY try
  ------------------
 1010|  5.31k|                if (next) {
  ------------------
  |  Branch (1010:21): [True: 1.20k, False: 4.10k]
  ------------------
 1011|  1.20k|                    if (mutate) {
  ------------------
  |  Branch (1011:25): [True: 0, False: 1.20k]
  ------------------
 1012|      0|                        node->inner()[idx] = next;
 1013|      0|                        pos.each_right(dec_visitor{}, idx + 1);
 1014|      0|                        return std::make_tuple(pos.shift(), node, ts, tail);
 1015|  1.20k|                    } else {
 1016|  1.20k|                        auto newn          = node_t::copy_inner_e(e, node, idx);
 1017|  1.20k|                        newn->inner()[idx] = next;
 1018|  1.20k|                        if (Mutating)
  ------------------
  |  Branch (1018:29): [Folded, False: 1.20k]
  ------------------
 1019|      0|                            pos.visit(dec_visitor{});
 1020|  1.20k|                        return std::make_tuple(pos.shift(), newn, ts, tail);
 1021|  1.20k|                    }
 1022|  4.10k|                } else if (idx == 0) {
  ------------------
  |  Branch (1022:28): [True: 1.11k, False: 2.99k]
  ------------------
 1023|  1.11k|                    if (Mutating)
  ------------------
  |  Branch (1023:25): [Folded, False: 1.11k]
  ------------------
 1024|      0|                        pos.visit(dec_right_visitor{}, count_t{1});
 1025|  1.11k|                    return std::make_tuple(pos.shift(), nullptr, ts, tail);
 1026|  2.99k|                } else if (Collapse && idx == 1 && pos.shift() > BL) {
  ------------------
  |  Branch (1026:28): [Folded, False: 2.99k]
  |  Branch (1026:40): [True: 0, False: 0]
  |  Branch (1026:52): [True: 0, False: 0]
  ------------------
 1027|      0|                    auto newn = pos.node()->inner()[0];
 1028|      0|                    if (!mutate)
  ------------------
  |  Branch (1028:25): [True: 0, False: 0]
  ------------------
 1029|      0|                        newn->inc();
 1030|      0|                    if (Mutating)
  ------------------
  |  Branch (1030:25): [Folded, False: 0]
  ------------------
 1031|      0|                        pos.visit(dec_right_visitor{}, count_t{2});
 1032|      0|                    return std::make_tuple(pos.shift() - B, newn, ts, tail);
 1033|  2.99k|                } else {
 1034|  2.99k|                    if (mutate) {
  ------------------
  |  Branch (1034:25): [True: 0, False: 2.99k]
  ------------------
 1035|      0|                        pos.each_right(dec_visitor{}, idx + 1);
 1036|      0|                        return std::make_tuple(pos.shift(), node, ts, tail);
 1037|  2.99k|                    } else {
 1038|  2.99k|                        auto newn = node_t::copy_inner_e(e, node, idx);
 1039|  2.99k|                        if (Mutating)
  ------------------
  |  Branch (1039:29): [Folded, False: 2.99k]
  ------------------
 1040|      0|                            pos.visit(dec_visitor{});
 1041|  2.99k|                        return std::make_tuple(pos.shift(), newn, ts, tail);
 1042|  2.99k|                    }
 1043|  2.99k|                }
 1044|  5.31k|            }
 1045|  5.31k|            IMMER_CATCH (...) {
 1046|      0|                assert(!mutate);
  ------------------
  |  Branch (1046:17): [True: 0, False: 0]
  ------------------
 1047|      0|                assert(!next || pos.shift() > BL);
  ------------------
  |  Branch (1047:17): [True: 0, False: 0]
  |  Branch (1047:17): [True: 0, False: 0]
  |  Branch (1047:17): [True: 0, False: 0]
  ------------------
 1048|      0|                assert(tail);
  ------------------
  |  Branch (1048:17): [True: 0, False: 0]
  ------------------
 1049|      0|                if (next)
  ------------------
  |  Branch (1049:21): [True: 0, False: 0]
  ------------------
 1050|      0|                    dec_regular(next, pos.shift() - B, last + 1 - ts);
 1051|      0|                dec_leaf(tail, ts);
 1052|      0|                IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
 1053|      0|            }
 1054|  5.31k|        }
 1055|  5.31k|    }
_ZN5immer6detail4rbts23slice_right_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEELb1ELb0EE10visit_leafIRNS1_8leaf_posISC_EEEENSt3__15tupleIJjPSC_jSK_EEEOT_mNSA_5applyIS7_E4type4editE:
 1059|    838|    {
 1060|    838|        auto old_tail_size = pos.count();
 1061|    838|        auto new_tail_size = pos.index(last) + 1;
 1062|    838|        auto node          = pos.node();
 1063|    838|        auto mutate        = Mutating && node->can_mutate(e);
  ------------------
  |  Branch (1063:30): [Folded, False: 838]
  |  Branch (1063:42): [True: 0, False: 0]
  ------------------
 1064|    838|        if (new_tail_size == old_tail_size) {
  ------------------
  |  Branch (1064:13): [True: 322, False: 516]
  ------------------
 1065|    322|            if (!Mutating)
  ------------------
  |  Branch (1065:17): [True: 322, Folded]
  ------------------
 1066|    322|                node->inc();
 1067|    322|            return std::make_tuple(0, nullptr, new_tail_size, node);
 1068|    516|        } else if (mutate) {
  ------------------
  |  Branch (1068:20): [True: 0, False: 516]
  ------------------
 1069|      0|            detail::destroy_n(node->leaf() + new_tail_size,
 1070|      0|                              old_tail_size - new_tail_size);
 1071|      0|            return std::make_tuple(0, nullptr, new_tail_size, node);
 1072|    516|        } else {
 1073|    516|            auto new_tail = node_t::copy_leaf_e(e, node, new_tail_size);
 1074|    516|            if (Mutating)
  ------------------
  |  Branch (1074:17): [Folded, False: 516]
  ------------------
 1075|      0|                pos.visit(dec_visitor{});
 1076|    516|            return std::make_tuple(0, nullptr, new_tail_size, new_tail);
 1077|    516|        }
 1078|    838|    }
_ZN5immer6detail4rbts23slice_right_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEELb0ELb1EE10visit_leafIRNS1_8leaf_posISC_EEEENSt3__15tupleIJjPSC_jSK_EEEOT_mNSA_5applyIS7_E4type4editE:
 1059|  2.70k|    {
 1060|  2.70k|        auto old_tail_size = pos.count();
 1061|  2.70k|        auto new_tail_size = pos.index(last) + 1;
 1062|  2.70k|        auto node          = pos.node();
 1063|  2.70k|        auto mutate        = Mutating && node->can_mutate(e);
  ------------------
  |  Branch (1063:30): [True: 2.70k, Folded]
  |  Branch (1063:42): [True: 976, False: 1.72k]
  ------------------
 1064|  2.70k|        if (new_tail_size == old_tail_size) {
  ------------------
  |  Branch (1064:13): [True: 1.78k, False: 914]
  ------------------
 1065|  1.78k|            if (!Mutating)
  ------------------
  |  Branch (1065:17): [Folded, False: 1.78k]
  ------------------
 1066|      0|                node->inc();
 1067|  1.78k|            return std::make_tuple(0, nullptr, new_tail_size, node);
 1068|  1.78k|        } else if (mutate) {
  ------------------
  |  Branch (1068:20): [True: 442, False: 472]
  ------------------
 1069|    442|            detail::destroy_n(node->leaf() + new_tail_size,
 1070|    442|                              old_tail_size - new_tail_size);
 1071|    442|            return std::make_tuple(0, nullptr, new_tail_size, node);
 1072|    472|        } else {
 1073|    472|            auto new_tail = node_t::copy_leaf_e(e, node, new_tail_size);
 1074|    472|            if (Mutating)
  ------------------
  |  Branch (1074:17): [True: 472, Folded]
  ------------------
 1075|    472|                pos.visit(dec_visitor{});
 1076|    472|            return std::make_tuple(0, nullptr, new_tail_size, new_tail);
 1077|    472|        }
 1078|  2.70k|    }
_ZN5immer6detail4rbts23slice_right_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEELb0ELb1EE13visit_regularIRNS1_11regular_posISC_EEEENSt3__15tupleIJjPSC_jSK_EEEOT_mNSA_5applyIS7_E4type4editE:
  991|  4.55k|    {
  992|  4.55k|        auto idx    = pos.index(last);
  993|  4.55k|        auto node   = pos.node();
  994|  4.55k|        auto mutate = Mutating && node->can_mutate(e);
  ------------------
  |  Branch (994:23): [True: 4.55k, Folded]
  |  Branch (994:35): [True: 4.03k, False: 528]
  ------------------
  995|  4.55k|        if (Collapse && idx == 0) {
  ------------------
  |  Branch (995:13): [Folded, False: 4.55k]
  |  Branch (995:25): [True: 0, False: 0]
  ------------------
  996|      0|            auto res = mutate ? pos.towards_oh(this_t{}, last, idx, e)
  ------------------
  |  Branch (996:24): [True: 0, False: 0]
  ------------------
  997|      0|                              : pos.towards_oh(no_mut_t{}, last, idx, e);
  998|      0|            if (Mutating)
  ------------------
  |  Branch (998:17): [True: 0, Folded]
  ------------------
  999|      0|                pos.visit(dec_right_visitor{}, count_t{1});
 1000|      0|            return res;
 1001|  4.55k|        } else {
 1002|  4.55k|            using std::get;
 1003|  4.55k|            auto subs =
 1004|  4.55k|                mutate ? pos.towards_oh(no_collapse_t{}, last, idx, e)
  ------------------
  |  Branch (1004:17): [True: 4.03k, False: 528]
  ------------------
 1005|  4.55k|                       : pos.towards_oh(no_collapse_no_mut_t{}, last, idx, e);
 1006|  4.55k|            auto next = get<1>(subs);
 1007|  4.55k|            auto ts   = get<2>(subs);
 1008|  4.55k|            auto tail = get<3>(subs);
 1009|  4.55k|            IMMER_TRY {
  ------------------
  |  |   49|  4.55k|#define IMMER_TRY try
  ------------------
 1010|  4.55k|                if (next) {
  ------------------
  |  Branch (1010:21): [True: 1.81k, False: 2.74k]
  ------------------
 1011|  1.81k|                    if (mutate) {
  ------------------
  |  Branch (1011:25): [True: 1.61k, False: 197]
  ------------------
 1012|  1.61k|                        node->inner()[idx] = next;
 1013|  1.61k|                        pos.each_right(dec_visitor{}, idx + 1);
 1014|  1.61k|                        return std::make_tuple(pos.shift(), node, ts, tail);
 1015|  1.61k|                    } else {
 1016|    197|                        auto newn          = node_t::copy_inner_e(e, node, idx);
 1017|    197|                        newn->inner()[idx] = next;
 1018|    197|                        if (Mutating)
  ------------------
  |  Branch (1018:29): [True: 197, Folded]
  ------------------
 1019|    197|                            pos.visit(dec_visitor{});
 1020|    197|                        return std::make_tuple(pos.shift(), newn, ts, tail);
 1021|    197|                    }
 1022|  2.74k|                } else if (idx == 0) {
  ------------------
  |  Branch (1022:28): [True: 1.08k, False: 1.66k]
  ------------------
 1023|  1.08k|                    if (Mutating)
  ------------------
  |  Branch (1023:25): [True: 1.08k, Folded]
  ------------------
 1024|  1.08k|                        pos.visit(dec_right_visitor{}, count_t{1});
 1025|  1.08k|                    return std::make_tuple(pos.shift(), nullptr, ts, tail);
 1026|  1.66k|                } else if (Collapse && idx == 1 && pos.shift() > BL) {
  ------------------
  |  Branch (1026:28): [Folded, False: 1.66k]
  |  Branch (1026:40): [True: 0, False: 0]
  |  Branch (1026:52): [True: 0, False: 0]
  ------------------
 1027|      0|                    auto newn = pos.node()->inner()[0];
 1028|      0|                    if (!mutate)
  ------------------
  |  Branch (1028:25): [True: 0, False: 0]
  ------------------
 1029|      0|                        newn->inc();
 1030|      0|                    if (Mutating)
  ------------------
  |  Branch (1030:25): [True: 0, Folded]
  ------------------
 1031|      0|                        pos.visit(dec_right_visitor{}, count_t{2});
 1032|      0|                    return std::make_tuple(pos.shift() - B, newn, ts, tail);
 1033|  1.66k|                } else {
 1034|  1.66k|                    if (mutate) {
  ------------------
  |  Branch (1034:25): [True: 1.40k, False: 254]
  ------------------
 1035|  1.40k|                        pos.each_right(dec_visitor{}, idx + 1);
 1036|  1.40k|                        return std::make_tuple(pos.shift(), node, ts, tail);
 1037|  1.40k|                    } else {
 1038|    254|                        auto newn = node_t::copy_inner_e(e, node, idx);
 1039|    254|                        if (Mutating)
  ------------------
  |  Branch (1039:29): [True: 254, Folded]
  ------------------
 1040|    254|                            pos.visit(dec_visitor{});
 1041|    254|                        return std::make_tuple(pos.shift(), newn, ts, tail);
 1042|    254|                    }
 1043|  1.66k|                }
 1044|  4.55k|            }
 1045|  4.55k|            IMMER_CATCH (...) {
 1046|      0|                assert(!mutate);
  ------------------
  |  Branch (1046:17): [True: 0, False: 0]
  ------------------
 1047|      0|                assert(!next || pos.shift() > BL);
  ------------------
  |  Branch (1047:17): [True: 0, False: 0]
  |  Branch (1047:17): [True: 0, False: 0]
  |  Branch (1047:17): [True: 0, False: 0]
  ------------------
 1048|      0|                assert(tail);
  ------------------
  |  Branch (1048:17): [True: 0, False: 0]
  ------------------
 1049|      0|                if (next)
  ------------------
  |  Branch (1049:21): [True: 0, False: 0]
  ------------------
 1050|      0|                    dec_regular(next, pos.shift() - B, last + 1 - ts);
 1051|      0|                dec_leaf(tail, ts);
 1052|      0|                IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
 1053|      0|            }
 1054|  4.55k|        }
 1055|  4.55k|    }
_ZN5immer6detail4rbts17dec_right_visitor13visit_regularIRNS1_11regular_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEEEEvOT_j:
  878|  1.08k|    {
  879|  1.08k|        using node_t = node_type<Pos>;
  880|  1.08k|        auto node    = p.node();
  881|  1.08k|        if (node->dec()) {
  ------------------
  |  Branch (881:13): [True: 0, False: 1.08k]
  ------------------
  882|      0|            p.each_right(dec_t{}, idx);
  883|      0|            node_t::delete_inner(node, p.count());
  884|      0|        }
  885|  1.08k|    }
_ZN5immer6detail4rbts23slice_right_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEELb0ELb0EE10visit_leafIRNS1_8leaf_posISC_EEEENSt3__15tupleIJjPSC_jSK_EEEOT_mNSA_5applyIS7_E4type4editE:
 1059|  2.95k|    {
 1060|  2.95k|        auto old_tail_size = pos.count();
 1061|  2.95k|        auto new_tail_size = pos.index(last) + 1;
 1062|  2.95k|        auto node          = pos.node();
 1063|  2.95k|        auto mutate        = Mutating && node->can_mutate(e);
  ------------------
  |  Branch (1063:30): [Folded, False: 2.95k]
  |  Branch (1063:42): [True: 0, False: 0]
  ------------------
 1064|  2.95k|        if (new_tail_size == old_tail_size) {
  ------------------
  |  Branch (1064:13): [True: 1.05k, False: 1.90k]
  ------------------
 1065|  1.05k|            if (!Mutating)
  ------------------
  |  Branch (1065:17): [True: 1.05k, Folded]
  ------------------
 1066|  1.05k|                node->inc();
 1067|  1.05k|            return std::make_tuple(0, nullptr, new_tail_size, node);
 1068|  1.90k|        } else if (mutate) {
  ------------------
  |  Branch (1068:20): [True: 0, False: 1.90k]
  ------------------
 1069|      0|            detail::destroy_n(node->leaf() + new_tail_size,
 1070|      0|                              old_tail_size - new_tail_size);
 1071|      0|            return std::make_tuple(0, nullptr, new_tail_size, node);
 1072|  1.90k|        } else {
 1073|  1.90k|            auto new_tail = node_t::copy_leaf_e(e, node, new_tail_size);
 1074|  1.90k|            if (Mutating)
  ------------------
  |  Branch (1074:17): [Folded, False: 1.90k]
  ------------------
 1075|      0|                pos.visit(dec_visitor{});
 1076|  1.90k|            return std::make_tuple(0, nullptr, new_tail_size, new_tail);
 1077|  1.90k|        }
 1078|  2.95k|    }
_ZN5immer6detail4rbts23slice_right_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEELb0ELb0EE13visit_regularIRNS1_11regular_posISC_EEEENSt3__15tupleIJjPSC_jSK_EEEOT_mNSA_5applyIS7_E4type4editE:
  991|  2.86k|    {
  992|  2.86k|        auto idx    = pos.index(last);
  993|  2.86k|        auto node   = pos.node();
  994|  2.86k|        auto mutate = Mutating && node->can_mutate(e);
  ------------------
  |  Branch (994:23): [Folded, False: 2.86k]
  |  Branch (994:35): [True: 0, False: 0]
  ------------------
  995|  2.86k|        if (Collapse && idx == 0) {
  ------------------
  |  Branch (995:13): [Folded, False: 2.86k]
  |  Branch (995:25): [True: 0, False: 0]
  ------------------
  996|      0|            auto res = mutate ? pos.towards_oh(this_t{}, last, idx, e)
  ------------------
  |  Branch (996:24): [True: 0, False: 0]
  ------------------
  997|      0|                              : pos.towards_oh(no_mut_t{}, last, idx, e);
  998|      0|            if (Mutating)
  ------------------
  |  Branch (998:17): [Folded, False: 0]
  ------------------
  999|      0|                pos.visit(dec_right_visitor{}, count_t{1});
 1000|      0|            return res;
 1001|  2.86k|        } else {
 1002|  2.86k|            using std::get;
 1003|  2.86k|            auto subs =
 1004|  2.86k|                mutate ? pos.towards_oh(no_collapse_t{}, last, idx, e)
  ------------------
  |  Branch (1004:17): [True: 0, False: 2.86k]
  ------------------
 1005|  2.86k|                       : pos.towards_oh(no_collapse_no_mut_t{}, last, idx, e);
 1006|  2.86k|            auto next = get<1>(subs);
 1007|  2.86k|            auto ts   = get<2>(subs);
 1008|  2.86k|            auto tail = get<3>(subs);
 1009|  2.86k|            IMMER_TRY {
  ------------------
  |  |   49|  2.86k|#define IMMER_TRY try
  ------------------
 1010|  2.86k|                if (next) {
  ------------------
  |  Branch (1010:21): [True: 923, False: 1.94k]
  ------------------
 1011|    923|                    if (mutate) {
  ------------------
  |  Branch (1011:25): [True: 0, False: 923]
  ------------------
 1012|      0|                        node->inner()[idx] = next;
 1013|      0|                        pos.each_right(dec_visitor{}, idx + 1);
 1014|      0|                        return std::make_tuple(pos.shift(), node, ts, tail);
 1015|    923|                    } else {
 1016|    923|                        auto newn          = node_t::copy_inner_e(e, node, idx);
 1017|    923|                        newn->inner()[idx] = next;
 1018|    923|                        if (Mutating)
  ------------------
  |  Branch (1018:29): [Folded, False: 923]
  ------------------
 1019|      0|                            pos.visit(dec_visitor{});
 1020|    923|                        return std::make_tuple(pos.shift(), newn, ts, tail);
 1021|    923|                    }
 1022|  1.94k|                } else if (idx == 0) {
  ------------------
  |  Branch (1022:28): [True: 1.01k, False: 934]
  ------------------
 1023|  1.01k|                    if (Mutating)
  ------------------
  |  Branch (1023:25): [Folded, False: 1.01k]
  ------------------
 1024|      0|                        pos.visit(dec_right_visitor{}, count_t{1});
 1025|  1.01k|                    return std::make_tuple(pos.shift(), nullptr, ts, tail);
 1026|  1.01k|                } else if (Collapse && idx == 1 && pos.shift() > BL) {
  ------------------
  |  Branch (1026:28): [Folded, False: 934]
  |  Branch (1026:40): [True: 0, False: 0]
  |  Branch (1026:52): [True: 0, False: 0]
  ------------------
 1027|      0|                    auto newn = pos.node()->inner()[0];
 1028|      0|                    if (!mutate)
  ------------------
  |  Branch (1028:25): [True: 0, False: 0]
  ------------------
 1029|      0|                        newn->inc();
 1030|      0|                    if (Mutating)
  ------------------
  |  Branch (1030:25): [Folded, False: 0]
  ------------------
 1031|      0|                        pos.visit(dec_right_visitor{}, count_t{2});
 1032|      0|                    return std::make_tuple(pos.shift() - B, newn, ts, tail);
 1033|    934|                } else {
 1034|    934|                    if (mutate) {
  ------------------
  |  Branch (1034:25): [True: 0, False: 934]
  ------------------
 1035|      0|                        pos.each_right(dec_visitor{}, idx + 1);
 1036|      0|                        return std::make_tuple(pos.shift(), node, ts, tail);
 1037|    934|                    } else {
 1038|    934|                        auto newn = node_t::copy_inner_e(e, node, idx);
 1039|    934|                        if (Mutating)
  ------------------
  |  Branch (1039:29): [Folded, False: 934]
  ------------------
 1040|      0|                            pos.visit(dec_visitor{});
 1041|    934|                        return std::make_tuple(pos.shift(), newn, ts, tail);
 1042|    934|                    }
 1043|    934|                }
 1044|  2.86k|            }
 1045|  2.86k|            IMMER_CATCH (...) {
 1046|      0|                assert(!mutate);
  ------------------
  |  Branch (1046:17): [True: 0, False: 0]
  ------------------
 1047|      0|                assert(!next || pos.shift() > BL);
  ------------------
  |  Branch (1047:17): [True: 0, False: 0]
  |  Branch (1047:17): [True: 0, False: 0]
  |  Branch (1047:17): [True: 0, False: 0]
  ------------------
 1048|      0|                assert(tail);
  ------------------
  |  Branch (1048:17): [True: 0, False: 0]
  ------------------
 1049|      0|                if (next)
  ------------------
  |  Branch (1049:21): [True: 0, False: 0]
  ------------------
 1050|      0|                    dec_regular(next, pos.shift() - B, last + 1 - ts);
 1051|      0|                dec_leaf(tail, ts);
 1052|      0|                IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
 1053|      0|            }
 1054|  2.86k|        }
 1055|  2.86k|    }
_ZN5immer6detail4rbts17dec_right_visitor13visit_relaxedIRNS1_11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEEEEvOT_j:
  867|  43.6k|    {
  868|  43.6k|        using node_t = node_type<Pos>;
  869|  43.6k|        auto node    = p.node();
  870|  43.6k|        if (node->dec()) {
  ------------------
  |  Branch (870:13): [True: 0, False: 43.6k]
  ------------------
  871|      0|            p.each_right(dec_t{}, idx);
  872|      0|            node_t::delete_inner_r(node, p.count());
  873|      0|        }
  874|  43.6k|    }
_ZN5immer6detail4rbts23slice_right_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEELb0ELb1EE10visit_leafIRNS1_12leaf_sub_posISC_EEEENSt3__15tupleIJjPSC_jSK_EEEOT_mNSA_5applyIS7_E4type4editE:
 1059|  4.51k|    {
 1060|  4.51k|        auto old_tail_size = pos.count();
 1061|  4.51k|        auto new_tail_size = pos.index(last) + 1;
 1062|  4.51k|        auto node          = pos.node();
 1063|  4.51k|        auto mutate        = Mutating && node->can_mutate(e);
  ------------------
  |  Branch (1063:30): [True: 4.51k, Folded]
  |  Branch (1063:42): [True: 1.91k, False: 2.59k]
  ------------------
 1064|  4.51k|        if (new_tail_size == old_tail_size) {
  ------------------
  |  Branch (1064:13): [True: 2.55k, False: 1.96k]
  ------------------
 1065|  2.55k|            if (!Mutating)
  ------------------
  |  Branch (1065:17): [Folded, False: 2.55k]
  ------------------
 1066|      0|                node->inc();
 1067|  2.55k|            return std::make_tuple(0, nullptr, new_tail_size, node);
 1068|  2.55k|        } else if (mutate) {
  ------------------
  |  Branch (1068:20): [True: 977, False: 983]
  ------------------
 1069|    977|            detail::destroy_n(node->leaf() + new_tail_size,
 1070|    977|                              old_tail_size - new_tail_size);
 1071|    977|            return std::make_tuple(0, nullptr, new_tail_size, node);
 1072|    983|        } else {
 1073|    983|            auto new_tail = node_t::copy_leaf_e(e, node, new_tail_size);
 1074|    983|            if (Mutating)
  ------------------
  |  Branch (1074:17): [True: 983, Folded]
  ------------------
 1075|    983|                pos.visit(dec_visitor{});
 1076|    983|            return std::make_tuple(0, nullptr, new_tail_size, new_tail);
 1077|    983|        }
 1078|  4.51k|    }
_ZN5immer6detail4rbts23slice_right_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEELb0ELb1EE13visit_relaxedIRNS1_11relaxed_posISC_EEEENSt3__15tupleIJjPSC_jSK_EEEOT_mNSA_5applyIS7_E4type4editE:
  913|  10.9k|    {
  914|  10.9k|        auto idx    = pos.index(last);
  915|  10.9k|        auto node   = pos.node();
  916|  10.9k|        auto mutate = Mutating && node->can_mutate(e);
  ------------------
  |  Branch (916:23): [True: 10.9k, Folded]
  |  Branch (916:35): [True: 9.30k, False: 1.67k]
  ------------------
  917|  10.9k|        if (Collapse && idx == 0) {
  ------------------
  |  Branch (917:13): [Folded, False: 10.9k]
  |  Branch (917:25): [True: 0, False: 0]
  ------------------
  918|      0|            auto res = mutate ? pos.towards_oh(this_t{}, last, idx, e)
  ------------------
  |  Branch (918:24): [True: 0, False: 0]
  ------------------
  919|      0|                              : pos.towards_oh(no_mut_t{}, last, idx, e);
  920|      0|            if (Mutating)
  ------------------
  |  Branch (920:17): [True: 0, Folded]
  ------------------
  921|      0|                pos.visit(dec_right_visitor{}, count_t{1});
  922|      0|            return res;
  923|  10.9k|        } else {
  924|  10.9k|            using std::get;
  925|  10.9k|            auto subs =
  926|  10.9k|                mutate ? pos.towards_oh(no_collapse_t{}, last, idx, e)
  ------------------
  |  Branch (926:17): [True: 9.30k, False: 1.67k]
  ------------------
  927|  10.9k|                       : pos.towards_oh(no_collapse_no_mut_t{}, last, idx, e);
  928|  10.9k|            auto next = get<1>(subs);
  929|  10.9k|            auto ts   = get<2>(subs);
  930|  10.9k|            auto tail = get<3>(subs);
  931|  10.9k|            IMMER_TRY {
  ------------------
  |  |   49|  10.9k|#define IMMER_TRY try
  ------------------
  932|  10.9k|                if (next) {
  ------------------
  |  Branch (932:21): [True: 6.17k, False: 4.80k]
  ------------------
  933|  6.17k|                    if (mutate) {
  ------------------
  |  Branch (933:25): [True: 5.30k, False: 871]
  ------------------
  934|  5.30k|                        auto nodr = node->ensure_mutable_relaxed_n(e, idx);
  935|  5.30k|                        pos.each_right(dec_visitor{}, idx + 1);
  936|  5.30k|                        node->inner()[idx] = next;
  937|  5.30k|                        nodr->d.sizes[idx] = last + 1 - ts;
  938|  5.30k|                        nodr->d.count      = idx + 1;
  939|  5.30k|                        assert(nodr->d.sizes[idx]);
  ------------------
  |  Branch (939:25): [True: 5.30k, False: 0]
  ------------------
  940|  5.30k|                        return std::make_tuple(pos.shift(), node, ts, tail);
  941|  5.30k|                    } else {
  942|    871|                        auto newn = node_t::copy_inner_r_e(e, node, idx);
  943|    871|                        auto newr = newn->relaxed();
  944|    871|                        newn->inner()[idx] = next;
  945|    871|                        newr->d.sizes[idx] = last + 1 - ts;
  946|    871|                        newr->d.count      = idx + 1;
  947|    871|                        assert(newr->d.sizes[idx]);
  ------------------
  |  Branch (947:25): [True: 871, False: 0]
  ------------------
  948|    871|                        if (Mutating)
  ------------------
  |  Branch (948:29): [True: 871, Folded]
  ------------------
  949|    871|                            pos.visit(dec_visitor{});
  950|    871|                        return std::make_tuple(pos.shift(), newn, ts, tail);
  951|    871|                    }
  952|  6.17k|                } else if (idx == 0) {
  ------------------
  |  Branch (952:28): [True: 1.15k, False: 3.65k]
  ------------------
  953|  1.15k|                    if (Mutating)
  ------------------
  |  Branch (953:25): [True: 1.15k, Folded]
  ------------------
  954|  1.15k|                        pos.visit(dec_right_visitor{}, count_t{1});
  955|  1.15k|                    return std::make_tuple(pos.shift(), nullptr, ts, tail);
  956|  3.65k|                } else if (Collapse && idx == 1 && pos.shift() > BL) {
  ------------------
  |  Branch (956:28): [Folded, False: 3.65k]
  |  Branch (956:40): [True: 0, False: 0]
  |  Branch (956:52): [True: 0, False: 0]
  ------------------
  957|      0|                    auto newn = pos.node()->inner()[0];
  958|      0|                    if (!mutate)
  ------------------
  |  Branch (958:25): [True: 0, False: 0]
  ------------------
  959|      0|                        newn->inc();
  960|      0|                    if (Mutating)
  ------------------
  |  Branch (960:25): [True: 0, Folded]
  ------------------
  961|      0|                        pos.visit(dec_right_visitor{}, count_t{2});
  962|      0|                    return std::make_tuple(pos.shift() - B, newn, ts, tail);
  963|  3.65k|                } else {
  964|  3.65k|                    if (mutate) {
  ------------------
  |  Branch (964:25): [True: 3.02k, False: 627]
  ------------------
  965|  3.02k|                        pos.each_right(dec_visitor{}, idx + 1);
  966|  3.02k|                        node->ensure_mutable_relaxed_n(e, idx)->d.count = idx;
  967|  3.02k|                        return std::make_tuple(pos.shift(), node, ts, tail);
  968|  3.02k|                    } else {
  969|    627|                        auto newn = node_t::copy_inner_r_e(e, node, idx);
  970|    627|                        if (Mutating)
  ------------------
  |  Branch (970:29): [True: 627, Folded]
  ------------------
  971|    627|                            pos.visit(dec_visitor{});
  972|    627|                        return std::make_tuple(pos.shift(), newn, ts, tail);
  973|    627|                    }
  974|  3.65k|                }
  975|  10.9k|            }
  976|  10.9k|            IMMER_CATCH (...) {
  977|      0|                assert(!mutate);
  ------------------
  |  Branch (977:17): [True: 0, False: 0]
  ------------------
  978|      0|                assert(!next || pos.shift() > BL);
  ------------------
  |  Branch (978:17): [True: 0, False: 0]
  |  Branch (978:17): [True: 0, False: 0]
  |  Branch (978:17): [True: 0, False: 0]
  ------------------
  979|      0|                if (next)
  ------------------
  |  Branch (979:21): [True: 0, False: 0]
  ------------------
  980|      0|                    dec_inner(next,
  981|      0|                              pos.shift() - B,
  982|      0|                              last + 1 - ts - pos.size_before(idx));
  983|      0|                dec_leaf(tail, ts);
  984|      0|                IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
  985|      0|            }
  986|  10.9k|        }
  987|  10.9k|    }
_ZN5immer6detail4rbts23slice_right_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEELb0ELb1EE13visit_regularIRNS1_15regular_sub_posISC_EEEENSt3__15tupleIJjPSC_jSK_EEEOT_mNSA_5applyIS7_E4type4editE:
  991|  2.81k|    {
  992|  2.81k|        auto idx    = pos.index(last);
  993|  2.81k|        auto node   = pos.node();
  994|  2.81k|        auto mutate = Mutating && node->can_mutate(e);
  ------------------
  |  Branch (994:23): [True: 2.81k, Folded]
  |  Branch (994:35): [True: 1.85k, False: 958]
  ------------------
  995|  2.81k|        if (Collapse && idx == 0) {
  ------------------
  |  Branch (995:13): [Folded, False: 2.81k]
  |  Branch (995:25): [True: 0, False: 0]
  ------------------
  996|      0|            auto res = mutate ? pos.towards_oh(this_t{}, last, idx, e)
  ------------------
  |  Branch (996:24): [True: 0, False: 0]
  ------------------
  997|      0|                              : pos.towards_oh(no_mut_t{}, last, idx, e);
  998|      0|            if (Mutating)
  ------------------
  |  Branch (998:17): [True: 0, Folded]
  ------------------
  999|      0|                pos.visit(dec_right_visitor{}, count_t{1});
 1000|      0|            return res;
 1001|  2.81k|        } else {
 1002|  2.81k|            using std::get;
 1003|  2.81k|            auto subs =
 1004|  2.81k|                mutate ? pos.towards_oh(no_collapse_t{}, last, idx, e)
  ------------------
  |  Branch (1004:17): [True: 1.85k, False: 958]
  ------------------
 1005|  2.81k|                       : pos.towards_oh(no_collapse_no_mut_t{}, last, idx, e);
 1006|  2.81k|            auto next = get<1>(subs);
 1007|  2.81k|            auto ts   = get<2>(subs);
 1008|  2.81k|            auto tail = get<3>(subs);
 1009|  2.81k|            IMMER_TRY {
  ------------------
  |  |   49|  2.81k|#define IMMER_TRY try
  ------------------
 1010|  2.81k|                if (next) {
  ------------------
  |  Branch (1010:21): [True: 1.20k, False: 1.61k]
  ------------------
 1011|  1.20k|                    if (mutate) {
  ------------------
  |  Branch (1011:25): [True: 758, False: 442]
  ------------------
 1012|    758|                        node->inner()[idx] = next;
 1013|    758|                        pos.each_right(dec_visitor{}, idx + 1);
 1014|    758|                        return std::make_tuple(pos.shift(), node, ts, tail);
 1015|    758|                    } else {
 1016|    442|                        auto newn          = node_t::copy_inner_e(e, node, idx);
 1017|    442|                        newn->inner()[idx] = next;
 1018|    442|                        if (Mutating)
  ------------------
  |  Branch (1018:29): [True: 442, Folded]
  ------------------
 1019|    442|                            pos.visit(dec_visitor{});
 1020|    442|                        return std::make_tuple(pos.shift(), newn, ts, tail);
 1021|    442|                    }
 1022|  1.61k|                } else if (idx == 0) {
  ------------------
  |  Branch (1022:28): [True: 752, False: 865]
  ------------------
 1023|    752|                    if (Mutating)
  ------------------
  |  Branch (1023:25): [True: 752, Folded]
  ------------------
 1024|    752|                        pos.visit(dec_right_visitor{}, count_t{1});
 1025|    752|                    return std::make_tuple(pos.shift(), nullptr, ts, tail);
 1026|    865|                } else if (Collapse && idx == 1 && pos.shift() > BL) {
  ------------------
  |  Branch (1026:28): [Folded, False: 865]
  |  Branch (1026:40): [True: 0, False: 0]
  |  Branch (1026:52): [True: 0, False: 0]
  ------------------
 1027|      0|                    auto newn = pos.node()->inner()[0];
 1028|      0|                    if (!mutate)
  ------------------
  |  Branch (1028:25): [True: 0, False: 0]
  ------------------
 1029|      0|                        newn->inc();
 1030|      0|                    if (Mutating)
  ------------------
  |  Branch (1030:25): [True: 0, Folded]
  ------------------
 1031|      0|                        pos.visit(dec_right_visitor{}, count_t{2});
 1032|      0|                    return std::make_tuple(pos.shift() - B, newn, ts, tail);
 1033|    865|                } else {
 1034|    865|                    if (mutate) {
  ------------------
  |  Branch (1034:25): [True: 395, False: 470]
  ------------------
 1035|    395|                        pos.each_right(dec_visitor{}, idx + 1);
 1036|    395|                        return std::make_tuple(pos.shift(), node, ts, tail);
 1037|    470|                    } else {
 1038|    470|                        auto newn = node_t::copy_inner_e(e, node, idx);
 1039|    470|                        if (Mutating)
  ------------------
  |  Branch (1039:29): [True: 470, Folded]
  ------------------
 1040|    470|                            pos.visit(dec_visitor{});
 1041|    470|                        return std::make_tuple(pos.shift(), newn, ts, tail);
 1042|    470|                    }
 1043|    865|                }
 1044|  2.81k|            }
 1045|  2.81k|            IMMER_CATCH (...) {
 1046|      0|                assert(!mutate);
  ------------------
  |  Branch (1046:17): [True: 0, False: 0]
  ------------------
 1047|      0|                assert(!next || pos.shift() > BL);
  ------------------
  |  Branch (1047:17): [True: 0, False: 0]
  |  Branch (1047:17): [True: 0, False: 0]
  |  Branch (1047:17): [True: 0, False: 0]
  ------------------
 1048|      0|                assert(tail);
  ------------------
  |  Branch (1048:17): [True: 0, False: 0]
  ------------------
 1049|      0|                if (next)
  ------------------
  |  Branch (1049:21): [True: 0, False: 0]
  ------------------
 1050|      0|                    dec_regular(next, pos.shift() - B, last + 1 - ts);
 1051|      0|                dec_leaf(tail, ts);
 1052|      0|                IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
 1053|      0|            }
 1054|  2.81k|        }
 1055|  2.81k|    }
_ZN5immer6detail4rbts17dec_right_visitor13visit_regularIRNS1_15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEEEEvOT_j:
  878|  9.88k|    {
  879|  9.88k|        using node_t = node_type<Pos>;
  880|  9.88k|        auto node    = p.node();
  881|  9.88k|        if (node->dec()) {
  ------------------
  |  Branch (881:13): [True: 0, False: 9.88k]
  ------------------
  882|      0|            p.each_right(dec_t{}, idx);
  883|      0|            node_t::delete_inner(node, p.count());
  884|      0|        }
  885|  9.88k|    }
_ZN5immer6detail4rbts23slice_right_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEELb0ELb0EE10visit_leafIRNS1_12leaf_sub_posISC_EEEENSt3__15tupleIJjPSC_jSK_EEEOT_mNSA_5applyIS7_E4type4editE:
 1059|  5.84k|    {
 1060|  5.84k|        auto old_tail_size = pos.count();
 1061|  5.84k|        auto new_tail_size = pos.index(last) + 1;
 1062|  5.84k|        auto node          = pos.node();
 1063|  5.84k|        auto mutate        = Mutating && node->can_mutate(e);
  ------------------
  |  Branch (1063:30): [Folded, False: 5.84k]
  |  Branch (1063:42): [True: 0, False: 0]
  ------------------
 1064|  5.84k|        if (new_tail_size == old_tail_size) {
  ------------------
  |  Branch (1064:13): [True: 1.78k, False: 4.05k]
  ------------------
 1065|  1.78k|            if (!Mutating)
  ------------------
  |  Branch (1065:17): [True: 1.78k, Folded]
  ------------------
 1066|  1.78k|                node->inc();
 1067|  1.78k|            return std::make_tuple(0, nullptr, new_tail_size, node);
 1068|  4.05k|        } else if (mutate) {
  ------------------
  |  Branch (1068:20): [True: 0, False: 4.05k]
  ------------------
 1069|      0|            detail::destroy_n(node->leaf() + new_tail_size,
 1070|      0|                              old_tail_size - new_tail_size);
 1071|      0|            return std::make_tuple(0, nullptr, new_tail_size, node);
 1072|  4.05k|        } else {
 1073|  4.05k|            auto new_tail = node_t::copy_leaf_e(e, node, new_tail_size);
 1074|  4.05k|            if (Mutating)
  ------------------
  |  Branch (1074:17): [Folded, False: 4.05k]
  ------------------
 1075|      0|                pos.visit(dec_visitor{});
 1076|  4.05k|            return std::make_tuple(0, nullptr, new_tail_size, new_tail);
 1077|  4.05k|        }
 1078|  5.84k|    }
_ZN5immer6detail4rbts23slice_right_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEELb0ELb0EE13visit_relaxedIRNS1_11relaxed_posISC_EEEENSt3__15tupleIJjPSC_jSK_EEEOT_mNSA_5applyIS7_E4type4editE:
  913|  8.14k|    {
  914|  8.14k|        auto idx    = pos.index(last);
  915|  8.14k|        auto node   = pos.node();
  916|  8.14k|        auto mutate = Mutating && node->can_mutate(e);
  ------------------
  |  Branch (916:23): [Folded, False: 8.14k]
  |  Branch (916:35): [True: 0, False: 0]
  ------------------
  917|  8.14k|        if (Collapse && idx == 0) {
  ------------------
  |  Branch (917:13): [Folded, False: 8.14k]
  |  Branch (917:25): [True: 0, False: 0]
  ------------------
  918|      0|            auto res = mutate ? pos.towards_oh(this_t{}, last, idx, e)
  ------------------
  |  Branch (918:24): [True: 0, False: 0]
  ------------------
  919|      0|                              : pos.towards_oh(no_mut_t{}, last, idx, e);
  920|      0|            if (Mutating)
  ------------------
  |  Branch (920:17): [Folded, False: 0]
  ------------------
  921|      0|                pos.visit(dec_right_visitor{}, count_t{1});
  922|      0|            return res;
  923|  8.14k|        } else {
  924|  8.14k|            using std::get;
  925|  8.14k|            auto subs =
  926|  8.14k|                mutate ? pos.towards_oh(no_collapse_t{}, last, idx, e)
  ------------------
  |  Branch (926:17): [True: 0, False: 8.14k]
  ------------------
  927|  8.14k|                       : pos.towards_oh(no_collapse_no_mut_t{}, last, idx, e);
  928|  8.14k|            auto next = get<1>(subs);
  929|  8.14k|            auto ts   = get<2>(subs);
  930|  8.14k|            auto tail = get<3>(subs);
  931|  8.14k|            IMMER_TRY {
  ------------------
  |  |   49|  8.14k|#define IMMER_TRY try
  ------------------
  932|  8.14k|                if (next) {
  ------------------
  |  Branch (932:21): [True: 3.25k, False: 4.88k]
  ------------------
  933|  3.25k|                    if (mutate) {
  ------------------
  |  Branch (933:25): [True: 0, False: 3.25k]
  ------------------
  934|      0|                        auto nodr = node->ensure_mutable_relaxed_n(e, idx);
  935|      0|                        pos.each_right(dec_visitor{}, idx + 1);
  936|      0|                        node->inner()[idx] = next;
  937|      0|                        nodr->d.sizes[idx] = last + 1 - ts;
  938|      0|                        nodr->d.count      = idx + 1;
  939|      0|                        assert(nodr->d.sizes[idx]);
  ------------------
  |  Branch (939:25): [True: 0, False: 0]
  ------------------
  940|      0|                        return std::make_tuple(pos.shift(), node, ts, tail);
  941|  3.25k|                    } else {
  942|  3.25k|                        auto newn = node_t::copy_inner_r_e(e, node, idx);
  943|  3.25k|                        auto newr = newn->relaxed();
  944|  3.25k|                        newn->inner()[idx] = next;
  945|  3.25k|                        newr->d.sizes[idx] = last + 1 - ts;
  946|  3.25k|                        newr->d.count      = idx + 1;
  947|  3.25k|                        assert(newr->d.sizes[idx]);
  ------------------
  |  Branch (947:25): [True: 3.25k, False: 0]
  ------------------
  948|  3.25k|                        if (Mutating)
  ------------------
  |  Branch (948:29): [Folded, False: 3.25k]
  ------------------
  949|      0|                            pos.visit(dec_visitor{});
  950|  3.25k|                        return std::make_tuple(pos.shift(), newn, ts, tail);
  951|  3.25k|                    }
  952|  4.88k|                } else if (idx == 0) {
  ------------------
  |  Branch (952:28): [True: 2.11k, False: 2.77k]
  ------------------
  953|  2.11k|                    if (Mutating)
  ------------------
  |  Branch (953:25): [Folded, False: 2.11k]
  ------------------
  954|      0|                        pos.visit(dec_right_visitor{}, count_t{1});
  955|  2.11k|                    return std::make_tuple(pos.shift(), nullptr, ts, tail);
  956|  2.77k|                } else if (Collapse && idx == 1 && pos.shift() > BL) {
  ------------------
  |  Branch (956:28): [Folded, False: 2.77k]
  |  Branch (956:40): [True: 0, False: 0]
  |  Branch (956:52): [True: 0, False: 0]
  ------------------
  957|      0|                    auto newn = pos.node()->inner()[0];
  958|      0|                    if (!mutate)
  ------------------
  |  Branch (958:25): [True: 0, False: 0]
  ------------------
  959|      0|                        newn->inc();
  960|      0|                    if (Mutating)
  ------------------
  |  Branch (960:25): [Folded, False: 0]
  ------------------
  961|      0|                        pos.visit(dec_right_visitor{}, count_t{2});
  962|      0|                    return std::make_tuple(pos.shift() - B, newn, ts, tail);
  963|  2.77k|                } else {
  964|  2.77k|                    if (mutate) {
  ------------------
  |  Branch (964:25): [True: 0, False: 2.77k]
  ------------------
  965|      0|                        pos.each_right(dec_visitor{}, idx + 1);
  966|      0|                        node->ensure_mutable_relaxed_n(e, idx)->d.count = idx;
  967|      0|                        return std::make_tuple(pos.shift(), node, ts, tail);
  968|  2.77k|                    } else {
  969|  2.77k|                        auto newn = node_t::copy_inner_r_e(e, node, idx);
  970|  2.77k|                        if (Mutating)
  ------------------
  |  Branch (970:29): [Folded, False: 2.77k]
  ------------------
  971|      0|                            pos.visit(dec_visitor{});
  972|  2.77k|                        return std::make_tuple(pos.shift(), newn, ts, tail);
  973|  2.77k|                    }
  974|  2.77k|                }
  975|  8.14k|            }
  976|  8.14k|            IMMER_CATCH (...) {
  977|      0|                assert(!mutate);
  ------------------
  |  Branch (977:17): [True: 0, False: 0]
  ------------------
  978|      0|                assert(!next || pos.shift() > BL);
  ------------------
  |  Branch (978:17): [True: 0, False: 0]
  |  Branch (978:17): [True: 0, False: 0]
  |  Branch (978:17): [True: 0, False: 0]
  ------------------
  979|      0|                if (next)
  ------------------
  |  Branch (979:21): [True: 0, False: 0]
  ------------------
  980|      0|                    dec_inner(next,
  981|      0|                              pos.shift() - B,
  982|      0|                              last + 1 - ts - pos.size_before(idx));
  983|      0|                dec_leaf(tail, ts);
  984|      0|                IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
  985|      0|            }
  986|  8.14k|        }
  987|  8.14k|    }
_ZN5immer6detail4rbts23slice_right_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEELb0ELb0EE13visit_regularIRNS1_15regular_sub_posISC_EEEENSt3__15tupleIJjPSC_jSK_EEEOT_mNSA_5applyIS7_E4type4editE:
  991|  1.87k|    {
  992|  1.87k|        auto idx    = pos.index(last);
  993|  1.87k|        auto node   = pos.node();
  994|  1.87k|        auto mutate = Mutating && node->can_mutate(e);
  ------------------
  |  Branch (994:23): [Folded, False: 1.87k]
  |  Branch (994:35): [True: 0, False: 0]
  ------------------
  995|  1.87k|        if (Collapse && idx == 0) {
  ------------------
  |  Branch (995:13): [Folded, False: 1.87k]
  |  Branch (995:25): [True: 0, False: 0]
  ------------------
  996|      0|            auto res = mutate ? pos.towards_oh(this_t{}, last, idx, e)
  ------------------
  |  Branch (996:24): [True: 0, False: 0]
  ------------------
  997|      0|                              : pos.towards_oh(no_mut_t{}, last, idx, e);
  998|      0|            if (Mutating)
  ------------------
  |  Branch (998:17): [Folded, False: 0]
  ------------------
  999|      0|                pos.visit(dec_right_visitor{}, count_t{1});
 1000|      0|            return res;
 1001|  1.87k|        } else {
 1002|  1.87k|            using std::get;
 1003|  1.87k|            auto subs =
 1004|  1.87k|                mutate ? pos.towards_oh(no_collapse_t{}, last, idx, e)
  ------------------
  |  Branch (1004:17): [True: 0, False: 1.87k]
  ------------------
 1005|  1.87k|                       : pos.towards_oh(no_collapse_no_mut_t{}, last, idx, e);
 1006|  1.87k|            auto next = get<1>(subs);
 1007|  1.87k|            auto ts   = get<2>(subs);
 1008|  1.87k|            auto tail = get<3>(subs);
 1009|  1.87k|            IMMER_TRY {
  ------------------
  |  |   49|  1.87k|#define IMMER_TRY try
  ------------------
 1010|  1.87k|                if (next) {
  ------------------
  |  Branch (1010:21): [True: 710, False: 1.16k]
  ------------------
 1011|    710|                    if (mutate) {
  ------------------
  |  Branch (1011:25): [True: 0, False: 710]
  ------------------
 1012|      0|                        node->inner()[idx] = next;
 1013|      0|                        pos.each_right(dec_visitor{}, idx + 1);
 1014|      0|                        return std::make_tuple(pos.shift(), node, ts, tail);
 1015|    710|                    } else {
 1016|    710|                        auto newn          = node_t::copy_inner_e(e, node, idx);
 1017|    710|                        newn->inner()[idx] = next;
 1018|    710|                        if (Mutating)
  ------------------
  |  Branch (1018:29): [Folded, False: 710]
  ------------------
 1019|      0|                            pos.visit(dec_visitor{});
 1020|    710|                        return std::make_tuple(pos.shift(), newn, ts, tail);
 1021|    710|                    }
 1022|  1.16k|                } else if (idx == 0) {
  ------------------
  |  Branch (1022:28): [True: 422, False: 739]
  ------------------
 1023|    422|                    if (Mutating)
  ------------------
  |  Branch (1023:25): [Folded, False: 422]
  ------------------
 1024|      0|                        pos.visit(dec_right_visitor{}, count_t{1});
 1025|    422|                    return std::make_tuple(pos.shift(), nullptr, ts, tail);
 1026|    739|                } else if (Collapse && idx == 1 && pos.shift() > BL) {
  ------------------
  |  Branch (1026:28): [Folded, False: 739]
  |  Branch (1026:40): [True: 0, False: 0]
  |  Branch (1026:52): [True: 0, False: 0]
  ------------------
 1027|      0|                    auto newn = pos.node()->inner()[0];
 1028|      0|                    if (!mutate)
  ------------------
  |  Branch (1028:25): [True: 0, False: 0]
  ------------------
 1029|      0|                        newn->inc();
 1030|      0|                    if (Mutating)
  ------------------
  |  Branch (1030:25): [Folded, False: 0]
  ------------------
 1031|      0|                        pos.visit(dec_right_visitor{}, count_t{2});
 1032|      0|                    return std::make_tuple(pos.shift() - B, newn, ts, tail);
 1033|    739|                } else {
 1034|    739|                    if (mutate) {
  ------------------
  |  Branch (1034:25): [True: 0, False: 739]
  ------------------
 1035|      0|                        pos.each_right(dec_visitor{}, idx + 1);
 1036|      0|                        return std::make_tuple(pos.shift(), node, ts, tail);
 1037|    739|                    } else {
 1038|    739|                        auto newn = node_t::copy_inner_e(e, node, idx);
 1039|    739|                        if (Mutating)
  ------------------
  |  Branch (1039:29): [Folded, False: 739]
  ------------------
 1040|      0|                            pos.visit(dec_visitor{});
 1041|    739|                        return std::make_tuple(pos.shift(), newn, ts, tail);
 1042|    739|                    }
 1043|    739|                }
 1044|  1.87k|            }
 1045|  1.87k|            IMMER_CATCH (...) {
 1046|      0|                assert(!mutate);
  ------------------
  |  Branch (1046:17): [True: 0, False: 0]
  ------------------
 1047|      0|                assert(!next || pos.shift() > BL);
  ------------------
  |  Branch (1047:17): [True: 0, False: 0]
  |  Branch (1047:17): [True: 0, False: 0]
  |  Branch (1047:17): [True: 0, False: 0]
  ------------------
 1048|      0|                assert(tail);
  ------------------
  |  Branch (1048:17): [True: 0, False: 0]
  ------------------
 1049|      0|                if (next)
  ------------------
  |  Branch (1049:21): [True: 0, False: 0]
  ------------------
 1050|      0|                    dec_regular(next, pos.shift() - B, last + 1 - ts);
 1051|      0|                dec_leaf(tail, ts);
 1052|      0|                IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
 1053|      0|            }
 1054|  1.87k|        }
 1055|  1.87k|    }
_ZN5immer6detail4rbts23slice_right_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEELb1ELb1EE13visit_regularIRNS1_15regular_sub_posISC_EEEENSt3__15tupleIJjPSC_jSK_EEEOT_mNSA_5applyIS7_E4type4editE:
  991|  15.4k|    {
  992|  15.4k|        auto idx    = pos.index(last);
  993|  15.4k|        auto node   = pos.node();
  994|  15.4k|        auto mutate = Mutating && node->can_mutate(e);
  ------------------
  |  Branch (994:23): [True: 15.4k, Folded]
  |  Branch (994:35): [True: 9.15k, False: 6.28k]
  ------------------
  995|  15.4k|        if (Collapse && idx == 0) {
  ------------------
  |  Branch (995:13): [True: 15.4k, Folded]
  |  Branch (995:25): [True: 7.20k, False: 8.23k]
  ------------------
  996|  7.20k|            auto res = mutate ? pos.towards_oh(this_t{}, last, idx, e)
  ------------------
  |  Branch (996:24): [True: 3.83k, False: 3.37k]
  ------------------
  997|  7.20k|                              : pos.towards_oh(no_mut_t{}, last, idx, e);
  998|  7.20k|            if (Mutating)
  ------------------
  |  Branch (998:17): [True: 7.20k, Folded]
  ------------------
  999|  7.20k|                pos.visit(dec_right_visitor{}, count_t{1});
 1000|  7.20k|            return res;
 1001|  8.23k|        } else {
 1002|  8.23k|            using std::get;
 1003|  8.23k|            auto subs =
 1004|  8.23k|                mutate ? pos.towards_oh(no_collapse_t{}, last, idx, e)
  ------------------
  |  Branch (1004:17): [True: 5.32k, False: 2.91k]
  ------------------
 1005|  8.23k|                       : pos.towards_oh(no_collapse_no_mut_t{}, last, idx, e);
 1006|  8.23k|            auto next = get<1>(subs);
 1007|  8.23k|            auto ts   = get<2>(subs);
 1008|  8.23k|            auto tail = get<3>(subs);
 1009|  8.23k|            IMMER_TRY {
  ------------------
  |  |   49|  8.23k|#define IMMER_TRY try
  ------------------
 1010|  8.23k|                if (next) {
  ------------------
  |  Branch (1010:21): [True: 4.31k, False: 3.91k]
  ------------------
 1011|  4.31k|                    if (mutate) {
  ------------------
  |  Branch (1011:25): [True: 3.19k, False: 1.12k]
  ------------------
 1012|  3.19k|                        node->inner()[idx] = next;
 1013|  3.19k|                        pos.each_right(dec_visitor{}, idx + 1);
 1014|  3.19k|                        return std::make_tuple(pos.shift(), node, ts, tail);
 1015|  3.19k|                    } else {
 1016|  1.12k|                        auto newn          = node_t::copy_inner_e(e, node, idx);
 1017|  1.12k|                        newn->inner()[idx] = next;
 1018|  1.12k|                        if (Mutating)
  ------------------
  |  Branch (1018:29): [True: 1.12k, Folded]
  ------------------
 1019|  1.12k|                            pos.visit(dec_visitor{});
 1020|  1.12k|                        return std::make_tuple(pos.shift(), newn, ts, tail);
 1021|  1.12k|                    }
 1022|  4.31k|                } else if (idx == 0) {
  ------------------
  |  Branch (1022:28): [True: 0, False: 3.91k]
  ------------------
 1023|      0|                    if (Mutating)
  ------------------
  |  Branch (1023:25): [True: 0, Folded]
  ------------------
 1024|      0|                        pos.visit(dec_right_visitor{}, count_t{1});
 1025|      0|                    return std::make_tuple(pos.shift(), nullptr, ts, tail);
 1026|  3.91k|                } else if (Collapse && idx == 1 && pos.shift() > BL) {
  ------------------
  |  Branch (1026:28): [True: 3.91k, Folded]
  |  Branch (1026:40): [True: 3.32k, False: 597]
  |  Branch (1026:52): [True: 1.92k, False: 1.39k]
  ------------------
 1027|  1.92k|                    auto newn = pos.node()->inner()[0];
 1028|  1.92k|                    if (!mutate)
  ------------------
  |  Branch (1028:25): [True: 890, False: 1.03k]
  ------------------
 1029|    890|                        newn->inc();
 1030|  1.92k|                    if (Mutating)
  ------------------
  |  Branch (1030:25): [True: 1.92k, Folded]
  ------------------
 1031|  1.92k|                        pos.visit(dec_right_visitor{}, count_t{2});
 1032|  1.92k|                    return std::make_tuple(pos.shift() - B, newn, ts, tail);
 1033|  1.99k|                } else {
 1034|  1.99k|                    if (mutate) {
  ------------------
  |  Branch (1034:25): [True: 1.09k, False: 898]
  ------------------
 1035|  1.09k|                        pos.each_right(dec_visitor{}, idx + 1);
 1036|  1.09k|                        return std::make_tuple(pos.shift(), node, ts, tail);
 1037|  1.09k|                    } else {
 1038|    898|                        auto newn = node_t::copy_inner_e(e, node, idx);
 1039|    898|                        if (Mutating)
  ------------------
  |  Branch (1039:29): [True: 898, Folded]
  ------------------
 1040|    898|                            pos.visit(dec_visitor{});
 1041|    898|                        return std::make_tuple(pos.shift(), newn, ts, tail);
 1042|    898|                    }
 1043|  1.99k|                }
 1044|  8.23k|            }
 1045|  8.23k|            IMMER_CATCH (...) {
 1046|      0|                assert(!mutate);
  ------------------
  |  Branch (1046:17): [True: 0, False: 0]
  ------------------
 1047|      0|                assert(!next || pos.shift() > BL);
  ------------------
  |  Branch (1047:17): [True: 0, False: 0]
  |  Branch (1047:17): [True: 0, False: 0]
  |  Branch (1047:17): [True: 0, False: 0]
  ------------------
 1048|      0|                assert(tail);
  ------------------
  |  Branch (1048:17): [True: 0, False: 0]
  ------------------
 1049|      0|                if (next)
  ------------------
  |  Branch (1049:21): [True: 0, False: 0]
  ------------------
 1050|      0|                    dec_regular(next, pos.shift() - B, last + 1 - ts);
 1051|      0|                dec_leaf(tail, ts);
 1052|      0|                IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
 1053|      0|            }
 1054|  8.23k|        }
 1055|  15.4k|    }
_ZN5immer6detail4rbts23slice_right_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEELb1ELb1EE10visit_leafIRNS1_13full_leaf_posISC_EEEENSt3__15tupleIJjPSC_jSK_EEEOT_mNSA_5applyIS7_E4type4editE:
 1059|  1.38k|    {
 1060|  1.38k|        auto old_tail_size = pos.count();
 1061|  1.38k|        auto new_tail_size = pos.index(last) + 1;
 1062|  1.38k|        auto node          = pos.node();
 1063|  1.38k|        auto mutate        = Mutating && node->can_mutate(e);
  ------------------
  |  Branch (1063:30): [True: 1.38k, Folded]
  |  Branch (1063:42): [True: 766, False: 619]
  ------------------
 1064|  1.38k|        if (new_tail_size == old_tail_size) {
  ------------------
  |  Branch (1064:13): [True: 404, False: 981]
  ------------------
 1065|    404|            if (!Mutating)
  ------------------
  |  Branch (1065:17): [Folded, False: 404]
  ------------------
 1066|      0|                node->inc();
 1067|    404|            return std::make_tuple(0, nullptr, new_tail_size, node);
 1068|    981|        } else if (mutate) {
  ------------------
  |  Branch (1068:20): [True: 546, False: 435]
  ------------------
 1069|    546|            detail::destroy_n(node->leaf() + new_tail_size,
 1070|    546|                              old_tail_size - new_tail_size);
 1071|    546|            return std::make_tuple(0, nullptr, new_tail_size, node);
 1072|    546|        } else {
 1073|    435|            auto new_tail = node_t::copy_leaf_e(e, node, new_tail_size);
 1074|    435|            if (Mutating)
  ------------------
  |  Branch (1074:17): [True: 435, Folded]
  ------------------
 1075|    435|                pos.visit(dec_visitor{});
 1076|    435|            return std::make_tuple(0, nullptr, new_tail_size, new_tail);
 1077|    435|        }
 1078|  1.38k|    }
_ZN5immer6detail4rbts23slice_right_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEELb1ELb1EE13visit_regularIRNS1_8full_posISC_EEEENSt3__15tupleIJjPSC_jSK_EEEOT_mNSA_5applyIS7_E4type4editE:
  991|  2.95k|    {
  992|  2.95k|        auto idx    = pos.index(last);
  993|  2.95k|        auto node   = pos.node();
  994|  2.95k|        auto mutate = Mutating && node->can_mutate(e);
  ------------------
  |  Branch (994:23): [True: 2.95k, Folded]
  |  Branch (994:35): [True: 2.04k, False: 908]
  ------------------
  995|  2.95k|        if (Collapse && idx == 0) {
  ------------------
  |  Branch (995:13): [True: 2.95k, Folded]
  |  Branch (995:25): [True: 1.42k, False: 1.52k]
  ------------------
  996|  1.42k|            auto res = mutate ? pos.towards_oh(this_t{}, last, idx, e)
  ------------------
  |  Branch (996:24): [True: 1.21k, False: 214]
  ------------------
  997|  1.42k|                              : pos.towards_oh(no_mut_t{}, last, idx, e);
  998|  1.42k|            if (Mutating)
  ------------------
  |  Branch (998:17): [True: 1.42k, Folded]
  ------------------
  999|  1.42k|                pos.visit(dec_right_visitor{}, count_t{1});
 1000|  1.42k|            return res;
 1001|  1.52k|        } else {
 1002|  1.52k|            using std::get;
 1003|  1.52k|            auto subs =
 1004|  1.52k|                mutate ? pos.towards_oh(no_collapse_t{}, last, idx, e)
  ------------------
  |  Branch (1004:17): [True: 827, False: 694]
  ------------------
 1005|  1.52k|                       : pos.towards_oh(no_collapse_no_mut_t{}, last, idx, e);
 1006|  1.52k|            auto next = get<1>(subs);
 1007|  1.52k|            auto ts   = get<2>(subs);
 1008|  1.52k|            auto tail = get<3>(subs);
 1009|  1.52k|            IMMER_TRY {
  ------------------
  |  |   49|  1.52k|#define IMMER_TRY try
  ------------------
 1010|  1.52k|                if (next) {
  ------------------
  |  Branch (1010:21): [True: 567, False: 954]
  ------------------
 1011|    567|                    if (mutate) {
  ------------------
  |  Branch (1011:25): [True: 361, False: 206]
  ------------------
 1012|    361|                        node->inner()[idx] = next;
 1013|    361|                        pos.each_right(dec_visitor{}, idx + 1);
 1014|    361|                        return std::make_tuple(pos.shift(), node, ts, tail);
 1015|    361|                    } else {
 1016|    206|                        auto newn          = node_t::copy_inner_e(e, node, idx);
 1017|    206|                        newn->inner()[idx] = next;
 1018|    206|                        if (Mutating)
  ------------------
  |  Branch (1018:29): [True: 206, Folded]
  ------------------
 1019|    206|                            pos.visit(dec_visitor{});
 1020|    206|                        return std::make_tuple(pos.shift(), newn, ts, tail);
 1021|    206|                    }
 1022|    954|                } else if (idx == 0) {
  ------------------
  |  Branch (1022:28): [True: 0, False: 954]
  ------------------
 1023|      0|                    if (Mutating)
  ------------------
  |  Branch (1023:25): [True: 0, Folded]
  ------------------
 1024|      0|                        pos.visit(dec_right_visitor{}, count_t{1});
 1025|      0|                    return std::make_tuple(pos.shift(), nullptr, ts, tail);
 1026|    954|                } else if (Collapse && idx == 1 && pos.shift() > BL) {
  ------------------
  |  Branch (1026:28): [True: 954, Folded]
  |  Branch (1026:40): [True: 662, False: 292]
  |  Branch (1026:52): [True: 248, False: 414]
  ------------------
 1027|    248|                    auto newn = pos.node()->inner()[0];
 1028|    248|                    if (!mutate)
  ------------------
  |  Branch (1028:25): [True: 200, False: 48]
  ------------------
 1029|    200|                        newn->inc();
 1030|    248|                    if (Mutating)
  ------------------
  |  Branch (1030:25): [True: 248, Folded]
  ------------------
 1031|    248|                        pos.visit(dec_right_visitor{}, count_t{2});
 1032|    248|                    return std::make_tuple(pos.shift() - B, newn, ts, tail);
 1033|    706|                } else {
 1034|    706|                    if (mutate) {
  ------------------
  |  Branch (1034:25): [True: 418, False: 288]
  ------------------
 1035|    418|                        pos.each_right(dec_visitor{}, idx + 1);
 1036|    418|                        return std::make_tuple(pos.shift(), node, ts, tail);
 1037|    418|                    } else {
 1038|    288|                        auto newn = node_t::copy_inner_e(e, node, idx);
 1039|    288|                        if (Mutating)
  ------------------
  |  Branch (1039:29): [True: 288, Folded]
  ------------------
 1040|    288|                            pos.visit(dec_visitor{});
 1041|    288|                        return std::make_tuple(pos.shift(), newn, ts, tail);
 1042|    288|                    }
 1043|    706|                }
 1044|  1.52k|            }
 1045|  1.52k|            IMMER_CATCH (...) {
 1046|      0|                assert(!mutate);
  ------------------
  |  Branch (1046:17): [True: 0, False: 0]
  ------------------
 1047|      0|                assert(!next || pos.shift() > BL);
  ------------------
  |  Branch (1047:17): [True: 0, False: 0]
  |  Branch (1047:17): [True: 0, False: 0]
  |  Branch (1047:17): [True: 0, False: 0]
  ------------------
 1048|      0|                assert(tail);
  ------------------
  |  Branch (1048:17): [True: 0, False: 0]
  ------------------
 1049|      0|                if (next)
  ------------------
  |  Branch (1049:21): [True: 0, False: 0]
  ------------------
 1050|      0|                    dec_regular(next, pos.shift() - B, last + 1 - ts);
 1051|      0|                dec_leaf(tail, ts);
 1052|      0|                IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
 1053|      0|            }
 1054|  1.52k|        }
 1055|  2.95k|    }
_ZN5immer6detail4rbts23slice_right_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEELb1ELb1EE10visit_leafIRNS1_8leaf_posISC_EEEENSt3__15tupleIJjPSC_jSK_EEEOT_mNSA_5applyIS7_E4type4editE:
 1059|    713|    {
 1060|    713|        auto old_tail_size = pos.count();
 1061|    713|        auto new_tail_size = pos.index(last) + 1;
 1062|    713|        auto node          = pos.node();
 1063|    713|        auto mutate        = Mutating && node->can_mutate(e);
  ------------------
  |  Branch (1063:30): [True: 713, Folded]
  |  Branch (1063:42): [True: 509, False: 204]
  ------------------
 1064|    713|        if (new_tail_size == old_tail_size) {
  ------------------
  |  Branch (1064:13): [True: 260, False: 453]
  ------------------
 1065|    260|            if (!Mutating)
  ------------------
  |  Branch (1065:17): [Folded, False: 260]
  ------------------
 1066|      0|                node->inc();
 1067|    260|            return std::make_tuple(0, nullptr, new_tail_size, node);
 1068|    453|        } else if (mutate) {
  ------------------
  |  Branch (1068:20): [True: 256, False: 197]
  ------------------
 1069|    256|            detail::destroy_n(node->leaf() + new_tail_size,
 1070|    256|                              old_tail_size - new_tail_size);
 1071|    256|            return std::make_tuple(0, nullptr, new_tail_size, node);
 1072|    256|        } else {
 1073|    197|            auto new_tail = node_t::copy_leaf_e(e, node, new_tail_size);
 1074|    197|            if (Mutating)
  ------------------
  |  Branch (1074:17): [True: 197, Folded]
  ------------------
 1075|    197|                pos.visit(dec_visitor{});
 1076|    197|            return std::make_tuple(0, nullptr, new_tail_size, new_tail);
 1077|    197|        }
 1078|    713|    }
_ZN5immer6detail4rbts16concat_trees_mutINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEENS1_11relaxed_posIT_EENSt3__15decayISE_E4type6node_t6edit_tESL_PSE_jSL_SM_jm:
 2498|  7.40k|{
 2499|  7.40k|    return make_singleton_regular_sub_pos(ltail, ltcount)
 2500|  7.40k|        .visit(concat_trees_left_mut_visitor<Node>{},
 2501|  7.40k|               ec,
 2502|  7.40k|               el,
 2503|  7.40k|               empty_leaf_pos<Node>{},
 2504|  7.40k|               er,
 2505|  7.40k|               rroot,
 2506|  7.40k|               rshift,
 2507|  7.40k|               rsize)
 2508|  7.40k|        .realize_e(ec);
 2509|  7.40k|}
_ZN5immer6detail4rbts29concat_trees_left_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE10visit_nodeIRNS1_25singleton_regular_sub_posISC_EENS1_14empty_leaf_posISC_EEJRPSC_RjRmEEENS1_17concat_center_posISC_EEOT_NSA_5applyIS7_E4type4editESV_OT0_SV_DpOT1_:
 2451|  7.40k|    {
 2452|  7.40k|        return visit_maybe_relaxed_sub(args...,
 2453|  7.40k|                                       concat_trees_right_mut_visitor<Node>{},
 2454|  7.40k|                                       ec,
 2455|  7.40k|                                       el,
 2456|  7.40k|                                       lpos,
 2457|  7.40k|                                       tpos,
 2458|  7.40k|                                       er);
 2459|  7.40k|    }
_ZN5immer6detail4rbts30concat_trees_right_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE10visit_nodeIRNS1_11relaxed_posISC_EERNS1_25singleton_regular_sub_posISC_EERNS1_14empty_leaf_posISC_EEEENS1_17concat_center_posISC_EEOT_NSA_5applyIS7_E4type4editESV_OT0_OT1_SV_:
 2432|  4.01k|    {
 2433|  4.01k|        return concat_inners_mut<Node>(ec, el, lpos, tpos, er, rpos);
 2434|  4.01k|    }
_ZN5immer6detail4rbts17concat_inners_mutINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEERNS1_25singleton_regular_sub_posISC_EERNS1_14empty_leaf_posISC_EERNS1_11relaxed_posISC_EEEENS1_17concat_center_posIT_EENSt3__15decayISN_E4type6node_t6edit_tESU_OT0_OT1_SU_OT2_:
 2333|  17.2k|{
 2334|  17.2k|    auto lshift = lpos.shift();
 2335|  17.2k|    auto rshift = rpos.shift();
 2336|       |    // lpos.node() can be null it is a singleton_regular_sub_pos<...>,
 2337|       |    // this is, when the tree is just a tail...
 2338|  17.2k|    if (lshift > rshift) {
  ------------------
  |  Branch (2338:9): [True: 0, False: 17.2k]
  ------------------
 2339|      0|        auto cpos = lpos.last_sub(
 2340|      0|            concat_left_mut_visitor<Node>{}, ec, el, tpos, er, rpos);
 2341|      0|        return concat_rebalance_mut<Node>(
 2342|      0|            ec, el, lpos, cpos, er, null_sub_pos{});
 2343|  17.2k|    } else if (lshift < rshift) {
  ------------------
  |  Branch (2343:16): [True: 13.5k, False: 3.74k]
  ------------------
 2344|  13.5k|        auto cpos = rpos.first_sub(
 2345|  13.5k|            concat_right_mut_visitor<Node>{}, ec, el, lpos, tpos, er);
 2346|  13.5k|        return concat_rebalance_mut<Node>(
 2347|  13.5k|            ec, el, null_sub_pos{}, cpos, er, rpos);
 2348|  13.5k|    } else {
 2349|  3.74k|        assert(lshift == rshift);
  ------------------
  |  Branch (2349:9): [True: 3.74k, False: 0]
  ------------------
 2350|  3.74k|        assert(Node::bits_leaf == 0u || lshift > 0);
  ------------------
  |  Branch (2350:9): [Folded, False: 3.74k]
  |  Branch (2350:9): [True: 3.74k, False: 0]
  |  Branch (2350:9): [True: 3.74k, False: 0]
  ------------------
 2351|  3.74k|        auto cpos = lpos.last_sub(
 2352|  3.74k|            concat_both_mut_visitor<Node>{}, ec, el, tpos, er, rpos);
 2353|  3.74k|        return concat_rebalance_mut<Node>(ec, el, lpos, cpos, er, rpos);
 2354|  3.74k|    }
 2355|  17.2k|}
_ZN5immer6detail4rbts17concat_merger_mutINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEC2ENSA_5applyIS7_E4type4editEjPjjSH_PSC_:
 2040|   809k|        : ec_{ec}
 2041|   809k|        , curr_{counts}
 2042|   809k|        , n_{n}
 2043|   809k|        , result_{shift + B, nullptr, 0}
 2044|   809k|    {
 2045|   809k|        if (candidate) {
  ------------------
  |  Branch (2045:13): [True: 378k, False: 431k]
  ------------------
 2046|   378k|            candidate->ensure_mutable_relaxed_e(candidate_e, ec);
 2047|   378k|            result_.nodes_[0] = candidate;
 2048|   431k|        } else {
 2049|   431k|            result_.nodes_[0] = node_t::make_inner_r_e(ec);
 2050|   431k|        }
 2051|   809k|    }
_ZN5immer6detail4rbts17concat_center_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE8each_subINS1_25concat_merger_mut_visitorEJRNS1_17concat_merger_mutISC_EERNSA_5applyIS7_E4type4editEEEEvT_DpOT0_:
 1512|   809k|    {
 1513|   809k|        if (shift_ == BL) {
  ------------------
  |  Branch (1513:13): [True: 107k, False: 702k]
  ------------------
 1514|   107k|            auto s = size_t{};
 1515|   421k|            for (auto i = count_t{0}; i < count_; ++i) {
  ------------------
  |  Branch (1515:39): [True: 313k, False: 107k]
  ------------------
 1516|   313k|                make_leaf_sub_pos(nodes_[i], sizes_[i] - s).visit(v, args...);
 1517|   313k|                s = sizes_[i];
 1518|   313k|            }
 1519|   702k|        } else {
 1520|  1.73M|            for (auto i = count_t{0}; i < count_; ++i)
  ------------------
  |  Branch (1520:39): [True: 1.03M, False: 702k]
  ------------------
 1521|  1.03M|                make_relaxed_pos(nodes_[i], shift_ - B, nodes_[i]->relaxed())
 1522|  1.03M|                    .visit(v, args...);
 1523|   702k|        }
 1524|   809k|    }
_ZN5immer6detail4rbts25concat_merger_mut_visitor10visit_leafIRNS1_12leaf_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEENS1_17concat_merger_mutISE_EEEEvOT_RT0_NSt3__15decayISJ_E4type6node_t6edit_tE:
 2227|   559k|    {
 2228|   559k|        merger.merge_leaf(p, e);
 2229|   559k|    }
_ZN5immer6detail4rbts17concat_merger_mutINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE10merge_leafIRNS1_12leaf_sub_posISC_EEEEvOT_NSA_5applyIS7_E4type4editE:
 2097|   559k|    {
 2098|   559k|        auto from       = p.node();
 2099|   559k|        auto from_size  = p.size();
 2100|   559k|        auto from_count = p.count();
 2101|   559k|        assert(from);
  ------------------
  |  Branch (2101:9): [True: 559k, False: 0]
  ------------------
 2102|   559k|        assert(from_size);
  ------------------
  |  Branch (2102:9): [True: 559k, False: 0]
  ------------------
 2103|   559k|        if (!to_ && *curr_ == from_count) {
  ------------------
  |  Branch (2103:13): [True: 530k, False: 28.7k]
  |  Branch (2103:21): [True: 516k, False: 14.4k]
  ------------------
 2104|   516k|            add_child(from, from_size);
 2105|   516k|        } else {
 2106|  43.1k|            auto from_offset = count_t{};
 2107|  43.1k|            auto from_data   = from->leaf();
 2108|  43.1k|            auto from_mutate = from->can_mutate(e);
 2109|  56.3k|            do {
 2110|  56.3k|                if (!to_) {
  ------------------
  |  Branch (2110:21): [True: 27.6k, False: 28.7k]
  ------------------
 2111|  27.6k|                    if (from_mutate) {
  ------------------
  |  Branch (2111:25): [True: 2.98k, False: 24.6k]
  ------------------
 2112|  2.98k|                        node_t::ownee(from) = ec_;
 2113|  2.98k|                        to_                 = from->inc();
 2114|  2.98k|                        assert(from_count);
  ------------------
  |  Branch (2114:25): [True: 2.98k, False: 0]
  ------------------
 2115|  24.6k|                    } else {
 2116|  24.6k|                        to_ = node_t::make_leaf_e(ec_);
 2117|  24.6k|                    }
 2118|  27.6k|                    to_offset_ = 0;
 2119|  27.6k|                }
 2120|  56.3k|                auto data = to_->leaf();
 2121|  56.3k|                auto to_copy =
 2122|  56.3k|                    std::min(from_count - from_offset, *curr_ - to_offset_);
 2123|  56.3k|                if (from == to_) {
  ------------------
  |  Branch (2123:21): [True: 2.98k, False: 53.3k]
  ------------------
 2124|  2.98k|                    if (from_offset != to_offset_)
  ------------------
  |  Branch (2124:25): [True: 373, False: 2.61k]
  ------------------
 2125|    373|                        std::move(from_data + from_offset,
 2126|    373|                                  from_data + from_offset + to_copy,
 2127|    373|                                  data + to_offset_);
 2128|  53.3k|                } else {
 2129|  53.3k|                    if (!from_mutate)
  ------------------
  |  Branch (2129:25): [True: 52.3k, False: 978]
  ------------------
 2130|  52.3k|                        detail::uninitialized_copy(from_data + from_offset,
 2131|  52.3k|                                                   from_data + from_offset +
 2132|  52.3k|                                                       to_copy,
 2133|  52.3k|                                                   data + to_offset_);
 2134|    978|                    else
 2135|    978|                        detail::uninitialized_move(from_data + from_offset,
 2136|    978|                                                   from_data + from_offset +
 2137|    978|                                                       to_copy,
 2138|    978|                                                   data + to_offset_);
 2139|  53.3k|                }
 2140|  56.3k|                to_offset_ += to_copy;
 2141|  56.3k|                from_offset += to_copy;
 2142|  56.3k|                if (*curr_ == to_offset_) {
  ------------------
  |  Branch (2142:21): [True: 27.6k, False: 28.7k]
  ------------------
 2143|  27.6k|                    add_child(to_, to_offset_);
 2144|  27.6k|                    to_ = nullptr;
 2145|  27.6k|                }
 2146|  56.3k|            } while (from_offset != from_count);
  ------------------
  |  Branch (2146:22): [True: 13.2k, False: 43.1k]
  ------------------
 2147|  43.1k|        }
 2148|   559k|    }
_ZN5immer6detail4rbts17concat_merger_mutINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE9add_childEPSC_m:
 2064|  3.34M|    {
 2065|  3.34M|        assert(size);
  ------------------
  |  Branch (2065:9): [True: 3.34M, False: 0]
  ------------------
 2066|  3.34M|        ++curr_;
 2067|  3.34M|        auto parent  = result_.nodes_[result_.count_ - 1];
 2068|  3.34M|        auto relaxed = parent->relaxed();
 2069|  3.34M|        if (count_ == branches<B>) {
  ------------------
  |  Branch (2069:13): [True: 340k, False: 3.00M]
  ------------------
 2070|   340k|            parent->relaxed()->d.count = count_;
 2071|   340k|            assert(result_.count_ < result_t::max_children);
  ------------------
  |  Branch (2071:13): [True: 340k, False: 0]
  ------------------
 2072|   340k|            n_ -= branches<B>;
 2073|   340k|            if (candidate_) {
  ------------------
  |  Branch (2073:17): [True: 19.8k, False: 320k]
  ------------------
 2074|  19.8k|                parent = candidate_;
 2075|  19.8k|                parent->ensure_mutable_relaxed_e(candidate_e_, ec_);
 2076|  19.8k|                candidate_ = nullptr;
 2077|  19.8k|            } else
 2078|   320k|                parent = node_t::make_inner_r_e(ec_);
 2079|   340k|            count_                         = 0;
 2080|   340k|            relaxed                        = parent->relaxed();
 2081|   340k|            result_.nodes_[result_.count_] = parent;
 2082|   340k|            result_.sizes_[result_.count_] = result_.sizes_[result_.count_ - 1];
 2083|   340k|            assert(result_.sizes_[result_.count_]);
  ------------------
  |  Branch (2083:13): [True: 340k, False: 0]
  ------------------
 2084|   340k|            ++result_.count_;
 2085|   340k|        }
 2086|  3.34M|        auto idx = count_++;
 2087|  3.34M|        result_.sizes_[result_.count_ - 1] += size;
 2088|  3.34M|        assert(size);
  ------------------
  |  Branch (2088:9): [True: 3.34M, False: 0]
  ------------------
 2089|  3.34M|        assert(result_.sizes_[result_.count_ - 1]);
  ------------------
  |  Branch (2089:9): [True: 3.34M, False: 0]
  ------------------
 2090|  3.34M|        relaxed->d.sizes[idx] = size + (idx ? relaxed->d.sizes[idx - 1] : 0);
  ------------------
  |  Branch (2090:41): [True: 2.19M, False: 1.14M]
  ------------------
 2091|  3.34M|        assert(relaxed->d.sizes[idx]);
  ------------------
  |  Branch (2091:9): [True: 3.34M, False: 0]
  ------------------
 2092|  3.34M|        parent->inner()[idx] = p;
 2093|  3.34M|    };
_ZN5immer6detail4rbts25concat_merger_mut_visitor11visit_innerIRNS1_11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEENS1_17concat_merger_mutISE_EEEEvOT_RT0_NSt3__15decayISJ_E4type6node_t6edit_tE:
 2221|  2.44M|    {
 2222|  2.44M|        merger.merge_inner(p, e);
 2223|  2.44M|    }
_ZN5immer6detail4rbts17concat_merger_mutINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE11merge_innerIRNS1_11relaxed_posISC_EEEEvOT_NSA_5applyIS7_E4type4editE:
 2152|  2.44M|    {
 2153|  2.44M|        auto from       = p.node();
 2154|  2.44M|        auto from_size  = p.size();
 2155|  2.44M|        auto from_count = p.count();
 2156|  2.44M|        assert(from_size);
  ------------------
  |  Branch (2156:9): [True: 2.44M, False: 0]
  ------------------
 2157|  2.44M|        if (!to_ && *curr_ == from_count) {
  ------------------
  |  Branch (2157:13): [True: 2.38M, False: 58.8k]
  |  Branch (2157:21): [True: 2.34M, False: 37.8k]
  ------------------
 2158|  2.34M|            add_child(from, from_size);
 2159|  2.34M|        } else {
 2160|  96.6k|            auto from_offset = count_t{};
 2161|  96.6k|            auto from_data   = from->inner();
 2162|  96.6k|            auto from_mutate = from->can_relax() && from->can_mutate(e);
  ------------------
  |  Branch (2162:32): [True: 96.6k, False: 0]
  |  Branch (2162:53): [True: 61.7k, False: 34.9k]
  ------------------
 2163|   116k|            do {
 2164|   116k|                if (!to_) {
  ------------------
  |  Branch (2164:21): [True: 57.5k, False: 58.8k]
  ------------------
 2165|  57.5k|                    if (from_mutate) {
  ------------------
  |  Branch (2165:25): [True: 39.4k, False: 18.1k]
  ------------------
 2166|  39.4k|                        node_t::ownee(from) = ec_;
 2167|  39.4k|                        from->ensure_mutable_relaxed_e(e, ec_);
 2168|  39.4k|                        to_ = from;
 2169|  39.4k|                    } else {
 2170|  18.1k|                        to_ = node_t::make_inner_r_e(ec_);
 2171|  18.1k|                    }
 2172|  57.5k|                    to_offset_ = 0;
 2173|  57.5k|                    to_size_   = 0;
 2174|  57.5k|                }
 2175|   116k|                auto data = to_->inner();
 2176|   116k|                auto to_copy =
 2177|   116k|                    std::min(from_count - from_offset, *curr_ - to_offset_);
 2178|   116k|                auto sizes = to_->relaxed()->d.sizes;
 2179|   116k|                if (from != to_ || from_offset != to_offset_) {
  ------------------
  |  Branch (2179:21): [True: 76.9k, False: 39.4k]
  |  Branch (2179:36): [True: 16.0k, False: 23.4k]
  ------------------
 2180|  92.9k|                    std::copy(from_data + from_offset,
 2181|  92.9k|                              from_data + from_offset + to_copy,
 2182|  92.9k|                              data + to_offset_);
 2183|  92.9k|                    p.copy_sizes(
 2184|  92.9k|                        from_offset, to_copy, to_size_, sizes + to_offset_);
 2185|  92.9k|                }
 2186|   116k|                to_offset_ += to_copy;
 2187|   116k|                from_offset += to_copy;
 2188|   116k|                to_size_ = sizes[to_offset_ - 1];
 2189|   116k|                if (*curr_ == to_offset_) {
  ------------------
  |  Branch (2189:21): [True: 57.5k, False: 58.8k]
  ------------------
 2190|  57.5k|                    to_->relaxed()->d.count = to_offset_;
 2191|  57.5k|                    add_child(to_, to_size_);
 2192|  57.5k|                    to_ = nullptr;
 2193|  57.5k|                }
 2194|   116k|            } while (from_offset != from_count);
  ------------------
  |  Branch (2194:22): [True: 19.7k, False: 96.6k]
  ------------------
 2195|  96.6k|        }
 2196|  2.44M|    }
_ZN5immer6detail4rbts17concat_merger_mutINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE13set_candidateENSA_5applyIS7_E4type4editEPSC_:
 2058|  46.9k|    {
 2059|  46.9k|        candidate_   = candidate;
 2060|  46.9k|        candidate_e_ = candidate_e;
 2061|  46.9k|    }
_ZNK5immer6detail4rbts17concat_merger_mutINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE6finishEv:
 2199|   809k|    {
 2200|   809k|        assert(!to_);
  ------------------
  |  Branch (2200:9): [True: 809k, False: 0]
  ------------------
 2201|   809k|        result_.nodes_[result_.count_ - 1]->relaxed()->d.count = count_;
 2202|   809k|        return result_;
 2203|   809k|    }
_ZN5immer6detail4rbts24concat_right_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE11visit_innerIRNS1_11relaxed_posISC_EERNS1_25singleton_regular_sub_posISC_EERNS1_14empty_leaf_posISC_EEEENS1_17concat_center_posISC_EEOT_NSA_5applyIS7_E4type4editESV_OT0_OT1_SV_:
 2387|  13.2k|    {
 2388|  13.2k|        return concat_inners_mut<Node>(ec, el, lpos, tpos, er, rpos);
 2389|  13.2k|    }
_ZN5immer6detail4rbts24concat_right_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE11visit_innerIRNS1_15regular_sub_posISC_EERNS1_25singleton_regular_sub_posISC_EERNS1_14empty_leaf_posISC_EEEENS1_17concat_center_posISC_EEOT_NSA_5applyIS7_E4type4editESV_OT0_OT1_SV_:
 2387|    268|    {
 2388|    268|        return concat_inners_mut<Node>(ec, el, lpos, tpos, er, rpos);
 2389|    268|    }
_ZN5immer6detail4rbts17concat_inners_mutINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEERNS1_25singleton_regular_sub_posISC_EERNS1_14empty_leaf_posISC_EERNS1_15regular_sub_posISC_EEEENS1_17concat_center_posIT_EENSt3__15decayISN_E4type6node_t6edit_tESU_OT0_OT1_SU_OT2_:
 2333|  3.66k|{
 2334|  3.66k|    auto lshift = lpos.shift();
 2335|  3.66k|    auto rshift = rpos.shift();
 2336|       |    // lpos.node() can be null it is a singleton_regular_sub_pos<...>,
 2337|       |    // this is, when the tree is just a tail...
 2338|  3.66k|    if (lshift > rshift) {
  ------------------
  |  Branch (2338:9): [True: 0, False: 3.66k]
  ------------------
 2339|      0|        auto cpos = lpos.last_sub(
 2340|      0|            concat_left_mut_visitor<Node>{}, ec, el, tpos, er, rpos);
 2341|      0|        return concat_rebalance_mut<Node>(
 2342|      0|            ec, el, lpos, cpos, er, null_sub_pos{});
 2343|  3.66k|    } else if (lshift < rshift) {
  ------------------
  |  Branch (2343:16): [True: 1.14k, False: 2.52k]
  ------------------
 2344|  1.14k|        auto cpos = rpos.first_sub(
 2345|  1.14k|            concat_right_mut_visitor<Node>{}, ec, el, lpos, tpos, er);
 2346|  1.14k|        return concat_rebalance_mut<Node>(
 2347|  1.14k|            ec, el, null_sub_pos{}, cpos, er, rpos);
 2348|  2.52k|    } else {
 2349|  2.52k|        assert(lshift == rshift);
  ------------------
  |  Branch (2349:9): [True: 2.52k, False: 0]
  ------------------
 2350|  2.52k|        assert(Node::bits_leaf == 0u || lshift > 0);
  ------------------
  |  Branch (2350:9): [Folded, False: 2.52k]
  |  Branch (2350:9): [True: 2.52k, False: 0]
  |  Branch (2350:9): [True: 2.52k, False: 0]
  ------------------
 2351|  2.52k|        auto cpos = lpos.last_sub(
 2352|  2.52k|            concat_both_mut_visitor<Node>{}, ec, el, tpos, er, rpos);
 2353|  2.52k|        return concat_rebalance_mut<Node>(ec, el, lpos, cpos, er, rpos);
 2354|  2.52k|    }
 2355|  3.66k|}
_ZN5immer6detail4rbts24concat_right_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE11visit_innerIRNS1_8full_posISC_EERNS1_25singleton_regular_sub_posISC_EERNS1_14empty_leaf_posISC_EEEENS1_17concat_center_posISC_EEOT_NSA_5applyIS7_E4type4editESV_OT0_OT1_SV_:
 2387|  1.85k|    {
 2388|  1.85k|        return concat_inners_mut<Node>(ec, el, lpos, tpos, er, rpos);
 2389|  1.85k|    }
_ZN5immer6detail4rbts17concat_inners_mutINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEERNS1_25singleton_regular_sub_posISC_EERNS1_14empty_leaf_posISC_EERNS1_8full_posISC_EEEENS1_17concat_center_posIT_EENSt3__15decayISN_E4type6node_t6edit_tESU_OT0_OT1_SU_OT2_:
 2333|  1.85k|{
 2334|  1.85k|    auto lshift = lpos.shift();
 2335|  1.85k|    auto rshift = rpos.shift();
 2336|       |    // lpos.node() can be null it is a singleton_regular_sub_pos<...>,
 2337|       |    // this is, when the tree is just a tail...
 2338|  1.85k|    if (lshift > rshift) {
  ------------------
  |  Branch (2338:9): [True: 0, False: 1.85k]
  ------------------
 2339|      0|        auto cpos = lpos.last_sub(
 2340|      0|            concat_left_mut_visitor<Node>{}, ec, el, tpos, er, rpos);
 2341|      0|        return concat_rebalance_mut<Node>(
 2342|      0|            ec, el, lpos, cpos, er, null_sub_pos{});
 2343|  1.85k|    } else if (lshift < rshift) {
  ------------------
  |  Branch (2343:16): [True: 711, False: 1.14k]
  ------------------
 2344|    711|        auto cpos = rpos.first_sub(
 2345|    711|            concat_right_mut_visitor<Node>{}, ec, el, lpos, tpos, er);
 2346|    711|        return concat_rebalance_mut<Node>(
 2347|    711|            ec, el, null_sub_pos{}, cpos, er, rpos);
 2348|  1.14k|    } else {
 2349|  1.14k|        assert(lshift == rshift);
  ------------------
  |  Branch (2349:9): [True: 1.14k, False: 0]
  ------------------
 2350|  1.14k|        assert(Node::bits_leaf == 0u || lshift > 0);
  ------------------
  |  Branch (2350:9): [Folded, False: 1.14k]
  |  Branch (2350:9): [True: 1.14k, False: 0]
  |  Branch (2350:9): [True: 1.14k, False: 0]
  ------------------
 2351|  1.14k|        auto cpos = lpos.last_sub(
 2352|  1.14k|            concat_both_mut_visitor<Node>{}, ec, el, tpos, er, rpos);
 2353|  1.14k|        return concat_rebalance_mut<Node>(ec, el, lpos, cpos, er, rpos);
 2354|  1.14k|    }
 2355|  1.85k|}
_ZN5immer6detail4rbts20concat_rebalance_mutINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEENS1_12null_sub_posERNS1_17concat_center_posISC_EERNS1_8full_posISC_EEEENSE_IT_EENSt3__15decayISK_E4type6node_t6edit_tESR_OT0_OT1_SR_OT2_:
 2280|  1.19k|{
 2281|  1.19k|    auto plan = concat_rebalance_plan_mut<Node::bits, Node::bits_leaf>{};
 2282|  1.19k|    plan.fill(lpos, cpos, rpos);
 2283|  1.19k|    plan.shuffle(cpos.shift());
 2284|  1.19k|    return plan.merge(ec, el, lpos, cpos, er, rpos);
 2285|  1.19k|}
_ZN5immer6detail4rbts25concat_rebalance_plan_mutILj2ELj2EE5mergeIRNS1_12null_sub_posERNS1_17concat_center_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEERNS1_8full_posISH_EEEENS7_INSt3__15decayIT0_E4type6node_tEEENSS_6edit_tESU_OT_OSP_SU_OT1_:
 2244|  1.19k|    {
 2245|  1.19k|        using node_t    = node_type<CPos>;
 2246|  1.19k|        using merger_t  = concat_merger_mut<node_t>;
 2247|  1.19k|        using visitor_t = concat_merger_mut_visitor;
 2248|  1.19k|        auto lnode      = ((node_t*) lpos.node());
 2249|  1.19k|        auto rnode      = ((node_t*) rpos.node());
 2250|  1.19k|        auto lmut2      = lnode && lnode->can_relax() && lnode->can_mutate(el);
  ------------------
  |  Branch (2250:27): [True: 0, False: 1.19k]
  |  Branch (2250:36): [True: 0, False: 0]
  |  Branch (2250:58): [True: 0, False: 0]
  ------------------
 2251|  1.19k|        auto rmut2      = rnode && rnode->can_relax() && rnode->can_mutate(er);
  ------------------
  |  Branch (2251:27): [True: 1.19k, False: 0]
  |  Branch (2251:36): [True: 1.19k, False: 0]
  |  Branch (2251:58): [True: 226, False: 964]
  ------------------
 2252|  1.19k|        auto merger     = merger_t{ec,
 2253|  1.19k|                               cpos.shift(),
 2254|  1.19k|                               this->counts,
 2255|  1.19k|                               this->n,
 2256|  1.19k|                               el,
 2257|  1.19k|                               lmut2 ? lnode : nullptr};
  ------------------
  |  Branch (2257:32): [True: 0, False: 1.19k]
  ------------------
 2258|  1.19k|        IMMER_TRY {
  ------------------
  |  |   49|  1.19k|#define IMMER_TRY try
  ------------------
 2259|  1.19k|            lpos.each_left_sub(visitor_t{}, merger, el);
 2260|  1.19k|            cpos.each_sub(visitor_t{}, merger, ec);
 2261|  1.19k|            if (rmut2)
  ------------------
  |  Branch (2261:17): [True: 226, False: 964]
  ------------------
 2262|    226|                merger.set_candidate(er, rnode);
 2263|  1.19k|            rpos.each_right_sub(visitor_t{}, merger, er);
 2264|  1.19k|            return merger.finish();
 2265|  1.19k|        }
 2266|  1.19k|        IMMER_CATCH (...) {
 2267|      0|            merger.abort();
 2268|      0|            IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
 2269|      0|        }
 2270|  1.19k|    }
_ZN5immer6detail4rbts25concat_merger_mut_visitor10visit_leafIRNS1_13full_leaf_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEENS1_17concat_merger_mutISE_EEEEvOT_RT0_NSt3__15decayISJ_E4type6node_t6edit_tE:
 2227|  91.0k|    {
 2228|  91.0k|        merger.merge_leaf(p, e);
 2229|  91.0k|    }
_ZN5immer6detail4rbts17concat_merger_mutINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE10merge_leafIRNS1_13full_leaf_posISC_EEEEvOT_NSA_5applyIS7_E4type4editE:
 2097|  91.0k|    {
 2098|  91.0k|        auto from       = p.node();
 2099|  91.0k|        auto from_size  = p.size();
 2100|  91.0k|        auto from_count = p.count();
 2101|  91.0k|        assert(from);
  ------------------
  |  Branch (2101:9): [True: 91.0k, False: 0]
  ------------------
 2102|  91.0k|        assert(from_size);
  ------------------
  |  Branch (2102:9): [True: 91.0k, False: 0]
  ------------------
 2103|  91.0k|        if (!to_ && *curr_ == from_count) {
  ------------------
  |  Branch (2103:13): [True: 91.0k, False: 0]
  |  Branch (2103:21): [True: 91.0k, False: 0]
  ------------------
 2104|  91.0k|            add_child(from, from_size);
 2105|  91.0k|        } else {
 2106|      0|            auto from_offset = count_t{};
 2107|      0|            auto from_data   = from->leaf();
 2108|      0|            auto from_mutate = from->can_mutate(e);
 2109|      0|            do {
 2110|      0|                if (!to_) {
  ------------------
  |  Branch (2110:21): [True: 0, False: 0]
  ------------------
 2111|      0|                    if (from_mutate) {
  ------------------
  |  Branch (2111:25): [True: 0, False: 0]
  ------------------
 2112|      0|                        node_t::ownee(from) = ec_;
 2113|      0|                        to_                 = from->inc();
 2114|      0|                        assert(from_count);
  ------------------
  |  Branch (2114:25): [True: 0, False: 0]
  ------------------
 2115|      0|                    } else {
 2116|      0|                        to_ = node_t::make_leaf_e(ec_);
 2117|      0|                    }
 2118|      0|                    to_offset_ = 0;
 2119|      0|                }
 2120|      0|                auto data = to_->leaf();
 2121|      0|                auto to_copy =
 2122|      0|                    std::min(from_count - from_offset, *curr_ - to_offset_);
 2123|      0|                if (from == to_) {
  ------------------
  |  Branch (2123:21): [True: 0, False: 0]
  ------------------
 2124|      0|                    if (from_offset != to_offset_)
  ------------------
  |  Branch (2124:25): [True: 0, False: 0]
  ------------------
 2125|      0|                        std::move(from_data + from_offset,
 2126|      0|                                  from_data + from_offset + to_copy,
 2127|      0|                                  data + to_offset_);
 2128|      0|                } else {
 2129|      0|                    if (!from_mutate)
  ------------------
  |  Branch (2129:25): [True: 0, False: 0]
  ------------------
 2130|      0|                        detail::uninitialized_copy(from_data + from_offset,
 2131|      0|                                                   from_data + from_offset +
 2132|      0|                                                       to_copy,
 2133|      0|                                                   data + to_offset_);
 2134|      0|                    else
 2135|      0|                        detail::uninitialized_move(from_data + from_offset,
 2136|      0|                                                   from_data + from_offset +
 2137|      0|                                                       to_copy,
 2138|      0|                                                   data + to_offset_);
 2139|      0|                }
 2140|      0|                to_offset_ += to_copy;
 2141|      0|                from_offset += to_copy;
 2142|      0|                if (*curr_ == to_offset_) {
  ------------------
  |  Branch (2142:21): [True: 0, False: 0]
  ------------------
 2143|      0|                    add_child(to_, to_offset_);
 2144|      0|                    to_ = nullptr;
 2145|      0|                }
 2146|      0|            } while (from_offset != from_count);
  ------------------
  |  Branch (2146:22): [True: 0, False: 0]
  ------------------
 2147|      0|        }
 2148|  91.0k|    }
_ZN5immer6detail4rbts25concat_merger_mut_visitor11visit_innerIRNS1_8full_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEENS1_17concat_merger_mutISE_EEEEvOT_RT0_NSt3__15decayISJ_E4type6node_t6edit_tE:
 2221|   186k|    {
 2222|   186k|        merger.merge_inner(p, e);
 2223|   186k|    }
_ZN5immer6detail4rbts17concat_merger_mutINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE11merge_innerIRNS1_8full_posISC_EEEEvOT_NSA_5applyIS7_E4type4editE:
 2152|   186k|    {
 2153|   186k|        auto from       = p.node();
 2154|   186k|        auto from_size  = p.size();
 2155|   186k|        auto from_count = p.count();
 2156|   186k|        assert(from_size);
  ------------------
  |  Branch (2156:9): [True: 186k, False: 0]
  ------------------
 2157|   186k|        if (!to_ && *curr_ == from_count) {
  ------------------
  |  Branch (2157:13): [True: 186k, False: 0]
  |  Branch (2157:21): [True: 186k, False: 0]
  ------------------
 2158|   186k|            add_child(from, from_size);
 2159|   186k|        } else {
 2160|      0|            auto from_offset = count_t{};
 2161|      0|            auto from_data   = from->inner();
 2162|      0|            auto from_mutate = from->can_relax() && from->can_mutate(e);
  ------------------
  |  Branch (2162:32): [True: 0, False: 0]
  |  Branch (2162:53): [True: 0, False: 0]
  ------------------
 2163|      0|            do {
 2164|      0|                if (!to_) {
  ------------------
  |  Branch (2164:21): [True: 0, False: 0]
  ------------------
 2165|      0|                    if (from_mutate) {
  ------------------
  |  Branch (2165:25): [True: 0, False: 0]
  ------------------
 2166|      0|                        node_t::ownee(from) = ec_;
 2167|      0|                        from->ensure_mutable_relaxed_e(e, ec_);
 2168|      0|                        to_ = from;
 2169|      0|                    } else {
 2170|      0|                        to_ = node_t::make_inner_r_e(ec_);
 2171|      0|                    }
 2172|      0|                    to_offset_ = 0;
 2173|      0|                    to_size_   = 0;
 2174|      0|                }
 2175|      0|                auto data = to_->inner();
 2176|      0|                auto to_copy =
 2177|      0|                    std::min(from_count - from_offset, *curr_ - to_offset_);
 2178|      0|                auto sizes = to_->relaxed()->d.sizes;
 2179|      0|                if (from != to_ || from_offset != to_offset_) {
  ------------------
  |  Branch (2179:21): [True: 0, False: 0]
  |  Branch (2179:36): [True: 0, False: 0]
  ------------------
 2180|      0|                    std::copy(from_data + from_offset,
 2181|      0|                              from_data + from_offset + to_copy,
 2182|      0|                              data + to_offset_);
 2183|      0|                    p.copy_sizes(
 2184|      0|                        from_offset, to_copy, to_size_, sizes + to_offset_);
 2185|      0|                }
 2186|      0|                to_offset_ += to_copy;
 2187|      0|                from_offset += to_copy;
 2188|      0|                to_size_ = sizes[to_offset_ - 1];
 2189|      0|                if (*curr_ == to_offset_) {
  ------------------
  |  Branch (2189:21): [True: 0, False: 0]
  ------------------
 2190|      0|                    to_->relaxed()->d.count = to_offset_;
 2191|      0|                    add_child(to_, to_size_);
 2192|      0|                    to_ = nullptr;
 2193|      0|                }
 2194|      0|            } while (from_offset != from_count);
  ------------------
  |  Branch (2194:22): [True: 0, False: 0]
  ------------------
 2195|      0|        }
 2196|   186k|    }
_ZN5immer6detail4rbts23concat_both_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE10visit_leafIRNS1_12leaf_sub_posISC_EERNS1_14empty_leaf_posISC_EERNS1_8full_posISC_EEEENS1_17concat_center_posISC_EEOT_NSA_5applyIS7_E4type4editESV_OT0_SV_OT1_:
 2416|  1.14k|    {
 2417|  1.14k|        return rpos.first_sub_leaf(
 2418|  1.14k|            concat_right_mut_visitor<Node>{}, ec, el, lpos, tpos, er);
 2419|  1.14k|    }
_ZN5immer6detail4rbts24concat_right_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE10visit_leafIRNS1_13full_leaf_posISC_EERNS1_12leaf_sub_posISC_EERNS1_14empty_leaf_posISC_EEEENS1_17concat_center_posISC_EEOT_NSA_5applyIS7_E4type4editESV_OT0_OT1_SV_:
 2394|  3.66k|    {
 2395|  3.66k|        return concat_leafs_mut<Node>(ec, el, lpos, tpos, er, rpos);
 2396|  3.66k|    }
_ZN5immer6detail4rbts16concat_leafs_mutINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEERNS1_12leaf_sub_posISC_EERNS1_14empty_leaf_posISC_EERNS1_13full_leaf_posISC_EEEENS1_17concat_center_posIT_EENSt3__15decayISN_E4type6node_t6edit_tESU_OT0_OT1_SU_OT2_:
 2294|  3.66k|{
 2295|  3.66k|    static_assert(Node::bits >= 2, "");
 2296|  3.66k|    assert(lpos.shift() == tpos.shift());
  ------------------
  |  Branch (2296:5): [True: 3.66k, False: 0]
  ------------------
 2297|  3.66k|    assert(lpos.shift() == rpos.shift());
  ------------------
  |  Branch (2297:5): [True: 3.66k, False: 0]
  ------------------
 2298|  3.66k|    assert(lpos.shift() == 0);
  ------------------
  |  Branch (2298:5): [True: 3.66k, False: 0]
  ------------------
 2299|  3.66k|    if (tpos.count() > 0)
  ------------------
  |  Branch (2299:9): [True: 0, False: 3.66k]
  ------------------
 2300|      0|        return {
 2301|      0|            Node::bits_leaf,
 2302|      0|            lpos.node(),
 2303|      0|            lpos.count(),
 2304|      0|            tpos.node(),
 2305|      0|            tpos.count(),
 2306|      0|            rpos.node(),
 2307|      0|            rpos.count(),
 2308|      0|        };
 2309|  3.66k|    else
 2310|  3.66k|        return {
 2311|  3.66k|            Node::bits_leaf,
 2312|  3.66k|            lpos.node(),
 2313|  3.66k|            lpos.count(),
 2314|  3.66k|            rpos.node(),
 2315|  3.66k|            rpos.count(),
 2316|  3.66k|        };
 2317|  3.66k|}
_ZN5immer6detail4rbts20concat_rebalance_mutINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEERNS1_25singleton_regular_sub_posISC_EERNS1_17concat_center_posISC_EERNS1_8full_posISC_EEEENSG_IT_EENSt3__15decayISM_E4type6node_t6edit_tEST_OT0_OT1_ST_OT2_:
 2280|  1.14k|{
 2281|  1.14k|    auto plan = concat_rebalance_plan_mut<Node::bits, Node::bits_leaf>{};
 2282|  1.14k|    plan.fill(lpos, cpos, rpos);
 2283|  1.14k|    plan.shuffle(cpos.shift());
 2284|  1.14k|    return plan.merge(ec, el, lpos, cpos, er, rpos);
 2285|  1.14k|}
_ZN5immer6detail4rbts25concat_rebalance_plan_mutILj2ELj2EE5mergeIRNS1_25singleton_regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEERNS1_17concat_center_posISF_EERNS1_8full_posISF_EEEENSI_INSt3__15decayIT0_E4type6node_tEEENST_6edit_tESV_OT_OSQ_SV_OT1_:
 2244|  1.14k|    {
 2245|  1.14k|        using node_t    = node_type<CPos>;
 2246|  1.14k|        using merger_t  = concat_merger_mut<node_t>;
 2247|  1.14k|        using visitor_t = concat_merger_mut_visitor;
 2248|  1.14k|        auto lnode      = ((node_t*) lpos.node());
 2249|  1.14k|        auto rnode      = ((node_t*) rpos.node());
 2250|  1.14k|        auto lmut2      = lnode && lnode->can_relax() && lnode->can_mutate(el);
  ------------------
  |  Branch (2250:27): [True: 0, False: 1.14k]
  |  Branch (2250:36): [True: 0, False: 0]
  |  Branch (2250:58): [True: 0, False: 0]
  ------------------
 2251|  1.14k|        auto rmut2      = rnode && rnode->can_relax() && rnode->can_mutate(er);
  ------------------
  |  Branch (2251:27): [True: 1.14k, False: 0]
  |  Branch (2251:36): [True: 1.14k, False: 0]
  |  Branch (2251:58): [True: 330, False: 810]
  ------------------
 2252|  1.14k|        auto merger     = merger_t{ec,
 2253|  1.14k|                               cpos.shift(),
 2254|  1.14k|                               this->counts,
 2255|  1.14k|                               this->n,
 2256|  1.14k|                               el,
 2257|  1.14k|                               lmut2 ? lnode : nullptr};
  ------------------
  |  Branch (2257:32): [True: 0, False: 1.14k]
  ------------------
 2258|  1.14k|        IMMER_TRY {
  ------------------
  |  |   49|  1.14k|#define IMMER_TRY try
  ------------------
 2259|  1.14k|            lpos.each_left_sub(visitor_t{}, merger, el);
 2260|  1.14k|            cpos.each_sub(visitor_t{}, merger, ec);
 2261|  1.14k|            if (rmut2)
  ------------------
  |  Branch (2261:17): [True: 330, False: 810]
  ------------------
 2262|    330|                merger.set_candidate(er, rnode);
 2263|  1.14k|            rpos.each_right_sub(visitor_t{}, merger, er);
 2264|  1.14k|            return merger.finish();
 2265|  1.14k|        }
 2266|  1.14k|        IMMER_CATCH (...) {
 2267|      0|            merger.abort();
 2268|      0|            IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
 2269|      0|        }
 2270|  1.14k|    }
_ZN5immer6detail4rbts20concat_rebalance_mutINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEENS1_12null_sub_posERNS1_17concat_center_posISC_EERNS1_15regular_sub_posISC_EEEENSE_IT_EENSt3__15decayISK_E4type6node_t6edit_tESR_OT0_OT1_SR_OT2_:
 2280|  2.36k|{
 2281|  2.36k|    auto plan = concat_rebalance_plan_mut<Node::bits, Node::bits_leaf>{};
 2282|  2.36k|    plan.fill(lpos, cpos, rpos);
 2283|  2.36k|    plan.shuffle(cpos.shift());
 2284|  2.36k|    return plan.merge(ec, el, lpos, cpos, er, rpos);
 2285|  2.36k|}
_ZN5immer6detail4rbts25concat_rebalance_plan_mutILj2ELj2EE5mergeIRNS1_12null_sub_posERNS1_17concat_center_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEERNS1_15regular_sub_posISH_EEEENS7_INSt3__15decayIT0_E4type6node_tEEENSS_6edit_tESU_OT_OSP_SU_OT1_:
 2244|  2.36k|    {
 2245|  2.36k|        using node_t    = node_type<CPos>;
 2246|  2.36k|        using merger_t  = concat_merger_mut<node_t>;
 2247|  2.36k|        using visitor_t = concat_merger_mut_visitor;
 2248|  2.36k|        auto lnode      = ((node_t*) lpos.node());
 2249|  2.36k|        auto rnode      = ((node_t*) rpos.node());
 2250|  2.36k|        auto lmut2      = lnode && lnode->can_relax() && lnode->can_mutate(el);
  ------------------
  |  Branch (2250:27): [True: 0, False: 2.36k]
  |  Branch (2250:36): [True: 0, False: 0]
  |  Branch (2250:58): [True: 0, False: 0]
  ------------------
 2251|  2.36k|        auto rmut2      = rnode && rnode->can_relax() && rnode->can_mutate(er);
  ------------------
  |  Branch (2251:27): [True: 2.36k, False: 0]
  |  Branch (2251:36): [True: 2.36k, False: 0]
  |  Branch (2251:58): [True: 382, False: 1.98k]
  ------------------
 2252|  2.36k|        auto merger     = merger_t{ec,
 2253|  2.36k|                               cpos.shift(),
 2254|  2.36k|                               this->counts,
 2255|  2.36k|                               this->n,
 2256|  2.36k|                               el,
 2257|  2.36k|                               lmut2 ? lnode : nullptr};
  ------------------
  |  Branch (2257:32): [True: 0, False: 2.36k]
  ------------------
 2258|  2.36k|        IMMER_TRY {
  ------------------
  |  |   49|  2.36k|#define IMMER_TRY try
  ------------------
 2259|  2.36k|            lpos.each_left_sub(visitor_t{}, merger, el);
 2260|  2.36k|            cpos.each_sub(visitor_t{}, merger, ec);
 2261|  2.36k|            if (rmut2)
  ------------------
  |  Branch (2261:17): [True: 382, False: 1.98k]
  ------------------
 2262|    382|                merger.set_candidate(er, rnode);
 2263|  2.36k|            rpos.each_right_sub(visitor_t{}, merger, er);
 2264|  2.36k|            return merger.finish();
 2265|  2.36k|        }
 2266|  2.36k|        IMMER_CATCH (...) {
 2267|      0|            merger.abort();
 2268|      0|            IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
 2269|      0|        }
 2270|  2.36k|    }
_ZN5immer6detail4rbts25concat_merger_mut_visitor11visit_innerIRNS1_15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEENS1_17concat_merger_mutISE_EEEEvOT_RT0_NSt3__15decayISJ_E4type6node_t6edit_tE:
 2221|   123k|    {
 2222|   123k|        merger.merge_inner(p, e);
 2223|   123k|    }
_ZN5immer6detail4rbts17concat_merger_mutINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE11merge_innerIRNS1_15regular_sub_posISC_EEEEvOT_NSA_5applyIS7_E4type4editE:
 2152|   123k|    {
 2153|   123k|        auto from       = p.node();
 2154|   123k|        auto from_size  = p.size();
 2155|   123k|        auto from_count = p.count();
 2156|   123k|        assert(from_size);
  ------------------
  |  Branch (2156:9): [True: 123k, False: 0]
  ------------------
 2157|   123k|        if (!to_ && *curr_ == from_count) {
  ------------------
  |  Branch (2157:13): [True: 122k, False: 1.59k]
  |  Branch (2157:21): [True: 122k, False: 0]
  ------------------
 2158|   122k|            add_child(from, from_size);
 2159|   122k|        } else {
 2160|  1.59k|            auto from_offset = count_t{};
 2161|  1.59k|            auto from_data   = from->inner();
 2162|  1.59k|            auto from_mutate = from->can_relax() && from->can_mutate(e);
  ------------------
  |  Branch (2162:32): [True: 1.59k, False: 0]
  |  Branch (2162:53): [True: 195, False: 1.40k]
  ------------------
 2163|  3.19k|            do {
 2164|  3.19k|                if (!to_) {
  ------------------
  |  Branch (2164:21): [True: 1.59k, False: 1.59k]
  ------------------
 2165|  1.59k|                    if (from_mutate) {
  ------------------
  |  Branch (2165:25): [True: 195, False: 1.40k]
  ------------------
 2166|    195|                        node_t::ownee(from) = ec_;
 2167|    195|                        from->ensure_mutable_relaxed_e(e, ec_);
 2168|    195|                        to_ = from;
 2169|  1.40k|                    } else {
 2170|  1.40k|                        to_ = node_t::make_inner_r_e(ec_);
 2171|  1.40k|                    }
 2172|  1.59k|                    to_offset_ = 0;
 2173|  1.59k|                    to_size_   = 0;
 2174|  1.59k|                }
 2175|  3.19k|                auto data = to_->inner();
 2176|  3.19k|                auto to_copy =
 2177|  3.19k|                    std::min(from_count - from_offset, *curr_ - to_offset_);
 2178|  3.19k|                auto sizes = to_->relaxed()->d.sizes;
 2179|  3.19k|                if (from != to_ || from_offset != to_offset_) {
  ------------------
  |  Branch (2179:21): [True: 2.99k, False: 195]
  |  Branch (2179:36): [True: 195, False: 0]
  ------------------
 2180|  3.19k|                    std::copy(from_data + from_offset,
 2181|  3.19k|                              from_data + from_offset + to_copy,
 2182|  3.19k|                              data + to_offset_);
 2183|  3.19k|                    p.copy_sizes(
 2184|  3.19k|                        from_offset, to_copy, to_size_, sizes + to_offset_);
 2185|  3.19k|                }
 2186|  3.19k|                to_offset_ += to_copy;
 2187|  3.19k|                from_offset += to_copy;
 2188|  3.19k|                to_size_ = sizes[to_offset_ - 1];
 2189|  3.19k|                if (*curr_ == to_offset_) {
  ------------------
  |  Branch (2189:21): [True: 1.59k, False: 1.59k]
  ------------------
 2190|  1.59k|                    to_->relaxed()->d.count = to_offset_;
 2191|  1.59k|                    add_child(to_, to_size_);
 2192|  1.59k|                    to_ = nullptr;
 2193|  1.59k|                }
 2194|  3.19k|            } while (from_offset != from_count);
  ------------------
  |  Branch (2194:22): [True: 1.59k, False: 1.59k]
  ------------------
 2195|  1.59k|        }
 2196|   123k|    }
_ZN5immer6detail4rbts23concat_both_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE10visit_leafIRNS1_12leaf_sub_posISC_EERNS1_14empty_leaf_posISC_EERNS1_15regular_sub_posISC_EEEENS1_17concat_center_posISC_EEOT_NSA_5applyIS7_E4type4editESV_OT0_SV_OT1_:
 2416|  2.52k|    {
 2417|  2.52k|        return rpos.first_sub_leaf(
 2418|  2.52k|            concat_right_mut_visitor<Node>{}, ec, el, lpos, tpos, er);
 2419|  2.52k|    }
_ZN5immer6detail4rbts24concat_right_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE10visit_leafIRNS1_12leaf_sub_posISC_EESH_RNS1_14empty_leaf_posISC_EEEENS1_17concat_center_posISC_EEOT_NSA_5applyIS7_E4type4editESS_OT0_OT1_SS_:
 2394|  3.74k|    {
 2395|  3.74k|        return concat_leafs_mut<Node>(ec, el, lpos, tpos, er, rpos);
 2396|  3.74k|    }
_ZN5immer6detail4rbts16concat_leafs_mutINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEERNS1_12leaf_sub_posISC_EERNS1_14empty_leaf_posISC_EESF_EENS1_17concat_center_posIT_EENSt3__15decayISK_E4type6node_t6edit_tESR_OT0_OT1_SR_OT2_:
 2294|  3.74k|{
 2295|  3.74k|    static_assert(Node::bits >= 2, "");
 2296|  3.74k|    assert(lpos.shift() == tpos.shift());
  ------------------
  |  Branch (2296:5): [True: 3.74k, False: 0]
  ------------------
 2297|  3.74k|    assert(lpos.shift() == rpos.shift());
  ------------------
  |  Branch (2297:5): [True: 3.74k, False: 0]
  ------------------
 2298|  3.74k|    assert(lpos.shift() == 0);
  ------------------
  |  Branch (2298:5): [True: 3.74k, False: 0]
  ------------------
 2299|  3.74k|    if (tpos.count() > 0)
  ------------------
  |  Branch (2299:9): [True: 0, False: 3.74k]
  ------------------
 2300|      0|        return {
 2301|      0|            Node::bits_leaf,
 2302|      0|            lpos.node(),
 2303|      0|            lpos.count(),
 2304|      0|            tpos.node(),
 2305|      0|            tpos.count(),
 2306|      0|            rpos.node(),
 2307|      0|            rpos.count(),
 2308|      0|        };
 2309|  3.74k|    else
 2310|  3.74k|        return {
 2311|  3.74k|            Node::bits_leaf,
 2312|  3.74k|            lpos.node(),
 2313|  3.74k|            lpos.count(),
 2314|  3.74k|            rpos.node(),
 2315|  3.74k|            rpos.count(),
 2316|  3.74k|        };
 2317|  3.74k|}
_ZN5immer6detail4rbts20concat_rebalance_mutINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEERNS1_25singleton_regular_sub_posISC_EERNS1_17concat_center_posISC_EERNS1_15regular_sub_posISC_EEEENSG_IT_EENSt3__15decayISM_E4type6node_t6edit_tEST_OT0_OT1_ST_OT2_:
 2280|  2.52k|{
 2281|  2.52k|    auto plan = concat_rebalance_plan_mut<Node::bits, Node::bits_leaf>{};
 2282|  2.52k|    plan.fill(lpos, cpos, rpos);
 2283|  2.52k|    plan.shuffle(cpos.shift());
 2284|  2.52k|    return plan.merge(ec, el, lpos, cpos, er, rpos);
 2285|  2.52k|}
_ZN5immer6detail4rbts25concat_rebalance_plan_mutILj2ELj2EE5mergeIRNS1_25singleton_regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEERNS1_17concat_center_posISF_EERNS1_15regular_sub_posISF_EEEENSI_INSt3__15decayIT0_E4type6node_tEEENST_6edit_tESV_OT_OSQ_SV_OT1_:
 2244|  2.52k|    {
 2245|  2.52k|        using node_t    = node_type<CPos>;
 2246|  2.52k|        using merger_t  = concat_merger_mut<node_t>;
 2247|  2.52k|        using visitor_t = concat_merger_mut_visitor;
 2248|  2.52k|        auto lnode      = ((node_t*) lpos.node());
 2249|  2.52k|        auto rnode      = ((node_t*) rpos.node());
 2250|  2.52k|        auto lmut2      = lnode && lnode->can_relax() && lnode->can_mutate(el);
  ------------------
  |  Branch (2250:27): [True: 0, False: 2.52k]
  |  Branch (2250:36): [True: 0, False: 0]
  |  Branch (2250:58): [True: 0, False: 0]
  ------------------
 2251|  2.52k|        auto rmut2      = rnode && rnode->can_relax() && rnode->can_mutate(er);
  ------------------
  |  Branch (2251:27): [True: 2.52k, False: 0]
  |  Branch (2251:36): [True: 2.52k, False: 0]
  |  Branch (2251:58): [True: 393, False: 2.13k]
  ------------------
 2252|  2.52k|        auto merger     = merger_t{ec,
 2253|  2.52k|                               cpos.shift(),
 2254|  2.52k|                               this->counts,
 2255|  2.52k|                               this->n,
 2256|  2.52k|                               el,
 2257|  2.52k|                               lmut2 ? lnode : nullptr};
  ------------------
  |  Branch (2257:32): [True: 0, False: 2.52k]
  ------------------
 2258|  2.52k|        IMMER_TRY {
  ------------------
  |  |   49|  2.52k|#define IMMER_TRY try
  ------------------
 2259|  2.52k|            lpos.each_left_sub(visitor_t{}, merger, el);
 2260|  2.52k|            cpos.each_sub(visitor_t{}, merger, ec);
 2261|  2.52k|            if (rmut2)
  ------------------
  |  Branch (2261:17): [True: 393, False: 2.13k]
  ------------------
 2262|    393|                merger.set_candidate(er, rnode);
 2263|  2.52k|            rpos.each_right_sub(visitor_t{}, merger, er);
 2264|  2.52k|            return merger.finish();
 2265|  2.52k|        }
 2266|  2.52k|        IMMER_CATCH (...) {
 2267|      0|            merger.abort();
 2268|      0|            IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
 2269|      0|        }
 2270|  2.52k|    }
_ZN5immer6detail4rbts20concat_rebalance_mutINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEENS1_12null_sub_posERNS1_17concat_center_posISC_EERNS1_11relaxed_posISC_EEEENSE_IT_EENSt3__15decayISK_E4type6node_t6edit_tESR_OT0_OT1_SR_OT2_:
 2280|  67.8k|{
 2281|  67.8k|    auto plan = concat_rebalance_plan_mut<Node::bits, Node::bits_leaf>{};
 2282|  67.8k|    plan.fill(lpos, cpos, rpos);
 2283|  67.8k|    plan.shuffle(cpos.shift());
 2284|  67.8k|    return plan.merge(ec, el, lpos, cpos, er, rpos);
 2285|  67.8k|}
_ZN5immer6detail4rbts25concat_rebalance_plan_mutILj2ELj2EE5mergeIRNS1_12null_sub_posERNS1_17concat_center_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEERNS1_11relaxed_posISH_EEEENS7_INSt3__15decayIT0_E4type6node_tEEENSS_6edit_tESU_OT_OSP_SU_OT1_:
 2244|  67.8k|    {
 2245|  67.8k|        using node_t    = node_type<CPos>;
 2246|  67.8k|        using merger_t  = concat_merger_mut<node_t>;
 2247|  67.8k|        using visitor_t = concat_merger_mut_visitor;
 2248|  67.8k|        auto lnode      = ((node_t*) lpos.node());
 2249|  67.8k|        auto rnode      = ((node_t*) rpos.node());
 2250|  67.8k|        auto lmut2      = lnode && lnode->can_relax() && lnode->can_mutate(el);
  ------------------
  |  Branch (2250:27): [True: 0, False: 67.8k]
  |  Branch (2250:36): [True: 0, False: 0]
  |  Branch (2250:58): [True: 0, False: 0]
  ------------------
 2251|  67.8k|        auto rmut2      = rnode && rnode->can_relax() && rnode->can_mutate(er);
  ------------------
  |  Branch (2251:27): [True: 67.8k, False: 0]
  |  Branch (2251:36): [True: 67.8k, False: 0]
  |  Branch (2251:58): [True: 28.8k, False: 38.9k]
  ------------------
 2252|  67.8k|        auto merger     = merger_t{ec,
 2253|  67.8k|                               cpos.shift(),
 2254|  67.8k|                               this->counts,
 2255|  67.8k|                               this->n,
 2256|  67.8k|                               el,
 2257|  67.8k|                               lmut2 ? lnode : nullptr};
  ------------------
  |  Branch (2257:32): [True: 0, False: 67.8k]
  ------------------
 2258|  67.8k|        IMMER_TRY {
  ------------------
  |  |   49|  67.8k|#define IMMER_TRY try
  ------------------
 2259|  67.8k|            lpos.each_left_sub(visitor_t{}, merger, el);
 2260|  67.8k|            cpos.each_sub(visitor_t{}, merger, ec);
 2261|  67.8k|            if (rmut2)
  ------------------
  |  Branch (2261:17): [True: 28.8k, False: 38.9k]
  ------------------
 2262|  28.8k|                merger.set_candidate(er, rnode);
 2263|  67.8k|            rpos.each_right_sub(visitor_t{}, merger, er);
 2264|  67.8k|            return merger.finish();
 2265|  67.8k|        }
 2266|  67.8k|        IMMER_CATCH (...) {
 2267|      0|            merger.abort();
 2268|      0|            IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
 2269|      0|        }
 2270|  67.8k|    }
_ZN5immer6detail4rbts23concat_both_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE10visit_leafIRNS1_12leaf_sub_posISC_EERNS1_14empty_leaf_posISC_EERNS1_11relaxed_posISC_EEEENS1_17concat_center_posISC_EEOT_NSA_5applyIS7_E4type4editESV_OT0_SV_OT1_:
 2416|  3.74k|    {
 2417|  3.74k|        return rpos.first_sub_leaf(
 2418|  3.74k|            concat_right_mut_visitor<Node>{}, ec, el, lpos, tpos, er);
 2419|  3.74k|    }
_ZN5immer6detail4rbts20concat_rebalance_mutINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEERNS1_25singleton_regular_sub_posISC_EERNS1_17concat_center_posISC_EERNS1_11relaxed_posISC_EEEENSG_IT_EENSt3__15decayISM_E4type6node_t6edit_tEST_OT0_OT1_ST_OT2_:
 2280|  3.74k|{
 2281|  3.74k|    auto plan = concat_rebalance_plan_mut<Node::bits, Node::bits_leaf>{};
 2282|  3.74k|    plan.fill(lpos, cpos, rpos);
 2283|  3.74k|    plan.shuffle(cpos.shift());
 2284|  3.74k|    return plan.merge(ec, el, lpos, cpos, er, rpos);
 2285|  3.74k|}
_ZN5immer6detail4rbts25concat_rebalance_plan_mutILj2ELj2EE5mergeIRNS1_25singleton_regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEERNS1_17concat_center_posISF_EERNS1_11relaxed_posISF_EEEENSI_INSt3__15decayIT0_E4type6node_tEEENST_6edit_tESV_OT_OSQ_SV_OT1_:
 2244|  3.74k|    {
 2245|  3.74k|        using node_t    = node_type<CPos>;
 2246|  3.74k|        using merger_t  = concat_merger_mut<node_t>;
 2247|  3.74k|        using visitor_t = concat_merger_mut_visitor;
 2248|  3.74k|        auto lnode      = ((node_t*) lpos.node());
 2249|  3.74k|        auto rnode      = ((node_t*) rpos.node());
 2250|  3.74k|        auto lmut2      = lnode && lnode->can_relax() && lnode->can_mutate(el);
  ------------------
  |  Branch (2250:27): [True: 0, False: 3.74k]
  |  Branch (2250:36): [True: 0, False: 0]
  |  Branch (2250:58): [True: 0, False: 0]
  ------------------
 2251|  3.74k|        auto rmut2      = rnode && rnode->can_relax() && rnode->can_mutate(er);
  ------------------
  |  Branch (2251:27): [True: 3.74k, False: 0]
  |  Branch (2251:36): [True: 3.74k, False: 0]
  |  Branch (2251:58): [True: 1.88k, False: 1.86k]
  ------------------
 2252|  3.74k|        auto merger     = merger_t{ec,
 2253|  3.74k|                               cpos.shift(),
 2254|  3.74k|                               this->counts,
 2255|  3.74k|                               this->n,
 2256|  3.74k|                               el,
 2257|  3.74k|                               lmut2 ? lnode : nullptr};
  ------------------
  |  Branch (2257:32): [True: 0, False: 3.74k]
  ------------------
 2258|  3.74k|        IMMER_TRY {
  ------------------
  |  |   49|  3.74k|#define IMMER_TRY try
  ------------------
 2259|  3.74k|            lpos.each_left_sub(visitor_t{}, merger, el);
 2260|  3.74k|            cpos.each_sub(visitor_t{}, merger, ec);
 2261|  3.74k|            if (rmut2)
  ------------------
  |  Branch (2261:17): [True: 1.88k, False: 1.86k]
  ------------------
 2262|  1.88k|                merger.set_candidate(er, rnode);
 2263|  3.74k|            rpos.each_right_sub(visitor_t{}, merger, er);
 2264|  3.74k|            return merger.finish();
 2265|  3.74k|        }
 2266|  3.74k|        IMMER_CATCH (...) {
 2267|      0|            merger.abort();
 2268|      0|            IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
 2269|      0|        }
 2270|  3.74k|    }
_ZN5immer6detail4rbts30concat_trees_right_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE10visit_nodeIRNS1_15regular_sub_posISC_EERNS1_25singleton_regular_sub_posISC_EERNS1_14empty_leaf_posISC_EEEENS1_17concat_center_posISC_EEOT_NSA_5applyIS7_E4type4editESV_OT0_OT1_SV_:
 2432|  3.39k|    {
 2433|  3.39k|        return concat_inners_mut<Node>(ec, el, lpos, tpos, er, rpos);
 2434|  3.39k|    }
_ZN5immer6detail4rbts17concat_center_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE9realize_eENSA_5applyIS7_E4type4editE:
 1548|   107k|    {
 1549|   107k|        if (count_ > 1) {
  ------------------
  |  Branch (1549:13): [True: 11.9k, False: 95.1k]
  ------------------
 1550|  11.9k|            auto result = node_t::make_inner_r_e(e);
 1551|  11.9k|            auto r      = result->relaxed();
 1552|  11.9k|            r->d.count  = count_;
 1553|  11.9k|            std::copy(nodes_, nodes_ + count_, result->inner());
 1554|  11.9k|            std::copy(sizes_, sizes_ + count_, r->d.sizes);
 1555|  11.9k|            return {result, shift_, r};
 1556|  95.1k|        } else {
 1557|  95.1k|            assert(shift_ >= B + BL);
  ------------------
  |  Branch (1557:13): [True: 95.1k, False: 0]
  ------------------
 1558|  95.1k|            return {nodes_[0], shift_ - B, nodes_[0]->relaxed()};
 1559|  95.1k|        }
 1560|   107k|    }
_ZN5immer6detail4rbts16concat_trees_mutINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEENS1_11relaxed_posIT_EENSt3__15decayISE_E4type6node_t6edit_tESL_PSE_jmSM_jSL_SM_jm:
 2474|  99.6k|{
 2475|  99.6k|    return visit_maybe_relaxed_sub(lroot,
 2476|  99.6k|                                   lshift,
 2477|  99.6k|                                   lsize,
 2478|  99.6k|                                   concat_trees_left_mut_visitor<Node>{},
 2479|  99.6k|                                   ec,
 2480|  99.6k|                                   el,
 2481|  99.6k|                                   make_leaf_pos(ltail, ltcount),
 2482|  99.6k|                                   er,
 2483|  99.6k|                                   rroot,
 2484|  99.6k|                                   rshift,
 2485|  99.6k|                                   rsize)
 2486|  99.6k|        .realize_e(ec);
 2487|  99.6k|}
_ZN5immer6detail4rbts29concat_trees_left_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE10visit_nodeIRNS1_11relaxed_posISC_EENS1_8leaf_posISC_EEJRPSC_RjRmEEENS1_17concat_center_posISC_EEOT_NSA_5applyIS7_E4type4editESV_OT0_SV_DpOT1_:
 2451|  93.3k|    {
 2452|  93.3k|        return visit_maybe_relaxed_sub(args...,
 2453|  93.3k|                                       concat_trees_right_mut_visitor<Node>{},
 2454|  93.3k|                                       ec,
 2455|  93.3k|                                       el,
 2456|  93.3k|                                       lpos,
 2457|  93.3k|                                       tpos,
 2458|  93.3k|                                       er);
 2459|  93.3k|    }
_ZN5immer6detail4rbts30concat_trees_right_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE10visit_nodeIRNS1_11relaxed_posISC_EESH_RNS1_8leaf_posISC_EEEENS1_17concat_center_posISC_EEOT_NSA_5applyIS7_E4type4editESS_OT0_OT1_SS_:
 2432|  65.6k|    {
 2433|  65.6k|        return concat_inners_mut<Node>(ec, el, lpos, tpos, er, rpos);
 2434|  65.6k|    }
_ZN5immer6detail4rbts17concat_inners_mutINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEERNS1_11relaxed_posISC_EERNS1_8leaf_posISC_EESF_EENS1_17concat_center_posIT_EENSt3__15decayISK_E4type6node_t6edit_tESR_OT0_OT1_SR_OT2_:
 2333|   495k|{
 2334|   495k|    auto lshift = lpos.shift();
 2335|   495k|    auto rshift = rpos.shift();
 2336|       |    // lpos.node() can be null it is a singleton_regular_sub_pos<...>,
 2337|       |    // this is, when the tree is just a tail...
 2338|   495k|    if (lshift > rshift) {
  ------------------
  |  Branch (2338:9): [True: 201k, False: 294k]
  ------------------
 2339|   201k|        auto cpos = lpos.last_sub(
 2340|   201k|            concat_left_mut_visitor<Node>{}, ec, el, tpos, er, rpos);
 2341|   201k|        return concat_rebalance_mut<Node>(
 2342|   201k|            ec, el, lpos, cpos, er, null_sub_pos{});
 2343|   294k|    } else if (lshift < rshift) {
  ------------------
  |  Branch (2343:16): [True: 45.4k, False: 248k]
  ------------------
 2344|  45.4k|        auto cpos = rpos.first_sub(
 2345|  45.4k|            concat_right_mut_visitor<Node>{}, ec, el, lpos, tpos, er);
 2346|  45.4k|        return concat_rebalance_mut<Node>(
 2347|  45.4k|            ec, el, null_sub_pos{}, cpos, er, rpos);
 2348|   248k|    } else {
 2349|   248k|        assert(lshift == rshift);
  ------------------
  |  Branch (2349:9): [True: 248k, False: 0]
  ------------------
 2350|   248k|        assert(Node::bits_leaf == 0u || lshift > 0);
  ------------------
  |  Branch (2350:9): [Folded, False: 248k]
  |  Branch (2350:9): [True: 248k, False: 0]
  |  Branch (2350:9): [True: 248k, False: 0]
  ------------------
 2351|   248k|        auto cpos = lpos.last_sub(
 2352|   248k|            concat_both_mut_visitor<Node>{}, ec, el, tpos, er, rpos);
 2353|   248k|        return concat_rebalance_mut<Node>(ec, el, lpos, cpos, er, rpos);
 2354|   248k|    }
 2355|   495k|}
_ZN5immer6detail4rbts23concat_left_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE11visit_innerIRNS1_11relaxed_posISC_EERNS1_8leaf_posISC_EESH_EENS1_17concat_center_posISC_EEOT_NSA_5applyIS7_E4type4editESS_OT0_SS_OT1_:
 2366|   199k|    {
 2367|   199k|        return concat_inners_mut<Node>(ec, el, lpos, tpos, er, rpos);
 2368|   199k|    }
_ZN5immer6detail4rbts23concat_left_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE11visit_innerIRNS1_15regular_sub_posISC_EERNS1_8leaf_posISC_EERNS1_11relaxed_posISC_EEEENS1_17concat_center_posISC_EEOT_NSA_5applyIS7_E4type4editESV_OT0_SV_OT1_:
 2366|  3.90k|    {
 2367|  3.90k|        return concat_inners_mut<Node>(ec, el, lpos, tpos, er, rpos);
 2368|  3.90k|    }
_ZN5immer6detail4rbts17concat_inners_mutINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEERNS1_15regular_sub_posISC_EERNS1_8leaf_posISC_EERNS1_11relaxed_posISC_EEEENS1_17concat_center_posIT_EENSt3__15decayISN_E4type6node_t6edit_tESU_OT0_OT1_SU_OT2_:
 2333|   116k|{
 2334|   116k|    auto lshift = lpos.shift();
 2335|   116k|    auto rshift = rpos.shift();
 2336|       |    // lpos.node() can be null it is a singleton_regular_sub_pos<...>,
 2337|       |    // this is, when the tree is just a tail...
 2338|   116k|    if (lshift > rshift) {
  ------------------
  |  Branch (2338:9): [True: 2.20k, False: 114k]
  ------------------
 2339|  2.20k|        auto cpos = lpos.last_sub(
 2340|  2.20k|            concat_left_mut_visitor<Node>{}, ec, el, tpos, er, rpos);
 2341|  2.20k|        return concat_rebalance_mut<Node>(
 2342|  2.20k|            ec, el, lpos, cpos, er, null_sub_pos{});
 2343|   114k|    } else if (lshift < rshift) {
  ------------------
  |  Branch (2343:16): [True: 8.88k, False: 105k]
  ------------------
 2344|  8.88k|        auto cpos = rpos.first_sub(
 2345|  8.88k|            concat_right_mut_visitor<Node>{}, ec, el, lpos, tpos, er);
 2346|  8.88k|        return concat_rebalance_mut<Node>(
 2347|  8.88k|            ec, el, null_sub_pos{}, cpos, er, rpos);
 2348|   105k|    } else {
 2349|   105k|        assert(lshift == rshift);
  ------------------
  |  Branch (2349:9): [True: 105k, False: 0]
  ------------------
 2350|   105k|        assert(Node::bits_leaf == 0u || lshift > 0);
  ------------------
  |  Branch (2350:9): [Folded, False: 105k]
  |  Branch (2350:9): [True: 105k, False: 0]
  |  Branch (2350:9): [True: 105k, False: 0]
  ------------------
 2351|   105k|        auto cpos = lpos.last_sub(
 2352|   105k|            concat_both_mut_visitor<Node>{}, ec, el, tpos, er, rpos);
 2353|   105k|        return concat_rebalance_mut<Node>(ec, el, lpos, cpos, er, rpos);
 2354|   105k|    }
 2355|   116k|}
_ZN5immer6detail4rbts20concat_rebalance_mutINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEERNS1_15regular_sub_posISC_EERNS1_17concat_center_posISC_EENS1_12null_sub_posEEENSG_IT_EENSt3__15decayISK_E4type6node_t6edit_tESR_OT0_OT1_SR_OT2_:
 2280|  4.05k|{
 2281|  4.05k|    auto plan = concat_rebalance_plan_mut<Node::bits, Node::bits_leaf>{};
 2282|  4.05k|    plan.fill(lpos, cpos, rpos);
 2283|  4.05k|    plan.shuffle(cpos.shift());
 2284|  4.05k|    return plan.merge(ec, el, lpos, cpos, er, rpos);
 2285|  4.05k|}
_ZN5immer6detail4rbts25concat_rebalance_plan_mutILj2ELj2EE5mergeIRNS1_15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEERNS1_17concat_center_posISF_EERNS1_12null_sub_posEEENSI_INSt3__15decayIT0_E4type6node_tEEENSS_6edit_tESU_OT_OSP_SU_OT1_:
 2244|  4.05k|    {
 2245|  4.05k|        using node_t    = node_type<CPos>;
 2246|  4.05k|        using merger_t  = concat_merger_mut<node_t>;
 2247|  4.05k|        using visitor_t = concat_merger_mut_visitor;
 2248|  4.05k|        auto lnode      = ((node_t*) lpos.node());
 2249|  4.05k|        auto rnode      = ((node_t*) rpos.node());
 2250|  4.05k|        auto lmut2      = lnode && lnode->can_relax() && lnode->can_mutate(el);
  ------------------
  |  Branch (2250:27): [True: 4.05k, False: 0]
  |  Branch (2250:36): [True: 4.05k, False: 0]
  |  Branch (2250:58): [True: 670, False: 3.38k]
  ------------------
 2251|  4.05k|        auto rmut2      = rnode && rnode->can_relax() && rnode->can_mutate(er);
  ------------------
  |  Branch (2251:27): [True: 0, False: 4.05k]
  |  Branch (2251:36): [True: 0, False: 0]
  |  Branch (2251:58): [True: 0, False: 0]
  ------------------
 2252|  4.05k|        auto merger     = merger_t{ec,
 2253|  4.05k|                               cpos.shift(),
 2254|  4.05k|                               this->counts,
 2255|  4.05k|                               this->n,
 2256|  4.05k|                               el,
 2257|  4.05k|                               lmut2 ? lnode : nullptr};
  ------------------
  |  Branch (2257:32): [True: 670, False: 3.38k]
  ------------------
 2258|  4.05k|        IMMER_TRY {
  ------------------
  |  |   49|  4.05k|#define IMMER_TRY try
  ------------------
 2259|  4.05k|            lpos.each_left_sub(visitor_t{}, merger, el);
 2260|  4.05k|            cpos.each_sub(visitor_t{}, merger, ec);
 2261|  4.05k|            if (rmut2)
  ------------------
  |  Branch (2261:17): [True: 0, False: 4.05k]
  ------------------
 2262|      0|                merger.set_candidate(er, rnode);
 2263|  4.05k|            rpos.each_right_sub(visitor_t{}, merger, er);
 2264|  4.05k|            return merger.finish();
 2265|  4.05k|        }
 2266|  4.05k|        IMMER_CATCH (...) {
 2267|      0|            merger.abort();
 2268|      0|            IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
 2269|      0|        }
 2270|  4.05k|    }
_ZN5immer6detail4rbts24concat_right_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE11visit_innerIRNS1_11relaxed_posISC_EERNS1_15regular_sub_posISC_EERNS1_8leaf_posISC_EEEENS1_17concat_center_posISC_EEOT_NSA_5applyIS7_E4type4editESV_OT0_OT1_SV_:
 2387|   109k|    {
 2388|   109k|        return concat_inners_mut<Node>(ec, el, lpos, tpos, er, rpos);
 2389|   109k|    }
_ZN5immer6detail4rbts24concat_right_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE11visit_innerIRNS1_15regular_sub_posISC_EESH_RNS1_8leaf_posISC_EEEENS1_17concat_center_posISC_EEOT_NSA_5applyIS7_E4type4editESS_OT0_OT1_SS_:
 2387|  2.91k|    {
 2388|  2.91k|        return concat_inners_mut<Node>(ec, el, lpos, tpos, er, rpos);
 2389|  2.91k|    }
_ZN5immer6detail4rbts17concat_inners_mutINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEERNS1_15regular_sub_posISC_EERNS1_8leaf_posISC_EESF_EENS1_17concat_center_posIT_EENSt3__15decayISK_E4type6node_t6edit_tESR_OT0_OT1_SR_OT2_:
 2333|  8.39k|{
 2334|  8.39k|    auto lshift = lpos.shift();
 2335|  8.39k|    auto rshift = rpos.shift();
 2336|       |    // lpos.node() can be null it is a singleton_regular_sub_pos<...>,
 2337|       |    // this is, when the tree is just a tail...
 2338|  8.39k|    if (lshift > rshift) {
  ------------------
  |  Branch (2338:9): [True: 1.85k, False: 6.54k]
  ------------------
 2339|  1.85k|        auto cpos = lpos.last_sub(
 2340|  1.85k|            concat_left_mut_visitor<Node>{}, ec, el, tpos, er, rpos);
 2341|  1.85k|        return concat_rebalance_mut<Node>(
 2342|  1.85k|            ec, el, lpos, cpos, er, null_sub_pos{});
 2343|  6.54k|    } else if (lshift < rshift) {
  ------------------
  |  Branch (2343:16): [True: 475, False: 6.06k]
  ------------------
 2344|    475|        auto cpos = rpos.first_sub(
 2345|    475|            concat_right_mut_visitor<Node>{}, ec, el, lpos, tpos, er);
 2346|    475|        return concat_rebalance_mut<Node>(
 2347|    475|            ec, el, null_sub_pos{}, cpos, er, rpos);
 2348|  6.06k|    } else {
 2349|  6.06k|        assert(lshift == rshift);
  ------------------
  |  Branch (2349:9): [True: 6.06k, False: 0]
  ------------------
 2350|  6.06k|        assert(Node::bits_leaf == 0u || lshift > 0);
  ------------------
  |  Branch (2350:9): [Folded, False: 6.06k]
  |  Branch (2350:9): [True: 6.06k, False: 0]
  |  Branch (2350:9): [True: 6.06k, False: 0]
  ------------------
 2351|  6.06k|        auto cpos = lpos.last_sub(
 2352|  6.06k|            concat_both_mut_visitor<Node>{}, ec, el, tpos, er, rpos);
 2353|  6.06k|        return concat_rebalance_mut<Node>(ec, el, lpos, cpos, er, rpos);
 2354|  6.06k|    }
 2355|  8.39k|}
_ZN5immer6detail4rbts23concat_left_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE11visit_innerIRNS1_15regular_sub_posISC_EERNS1_8leaf_posISC_EESH_EENS1_17concat_center_posISC_EEOT_NSA_5applyIS7_E4type4editESS_OT0_SS_OT1_:
 2366|  2.50k|    {
 2367|  2.50k|        return concat_inners_mut<Node>(ec, el, lpos, tpos, er, rpos);
 2368|  2.50k|    }
_ZN5immer6detail4rbts24concat_right_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE11visit_innerIRNS1_8full_posISC_EERNS1_15regular_sub_posISC_EERNS1_8leaf_posISC_EEEENS1_17concat_center_posISC_EEOT_NSA_5applyIS7_E4type4editESV_OT0_OT1_SV_:
 2387|  18.5k|    {
 2388|  18.5k|        return concat_inners_mut<Node>(ec, el, lpos, tpos, er, rpos);
 2389|  18.5k|    }
_ZN5immer6detail4rbts17concat_inners_mutINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEERNS1_15regular_sub_posISC_EERNS1_8leaf_posISC_EERNS1_8full_posISC_EEEENS1_17concat_center_posIT_EENSt3__15decayISN_E4type6node_t6edit_tESU_OT0_OT1_SU_OT2_:
 2333|  18.5k|{
 2334|  18.5k|    auto lshift = lpos.shift();
 2335|  18.5k|    auto rshift = rpos.shift();
 2336|       |    // lpos.node() can be null it is a singleton_regular_sub_pos<...>,
 2337|       |    // this is, when the tree is just a tail...
 2338|  18.5k|    if (lshift > rshift) {
  ------------------
  |  Branch (2338:9): [True: 0, False: 18.5k]
  ------------------
 2339|      0|        auto cpos = lpos.last_sub(
 2340|      0|            concat_left_mut_visitor<Node>{}, ec, el, tpos, er, rpos);
 2341|      0|        return concat_rebalance_mut<Node>(
 2342|      0|            ec, el, lpos, cpos, er, null_sub_pos{});
 2343|  18.5k|    } else if (lshift < rshift) {
  ------------------
  |  Branch (2343:16): [True: 247, False: 18.3k]
  ------------------
 2344|    247|        auto cpos = rpos.first_sub(
 2345|    247|            concat_right_mut_visitor<Node>{}, ec, el, lpos, tpos, er);
 2346|    247|        return concat_rebalance_mut<Node>(
 2347|    247|            ec, el, null_sub_pos{}, cpos, er, rpos);
 2348|  18.3k|    } else {
 2349|  18.3k|        assert(lshift == rshift);
  ------------------
  |  Branch (2349:9): [True: 18.3k, False: 0]
  ------------------
 2350|  18.3k|        assert(Node::bits_leaf == 0u || lshift > 0);
  ------------------
  |  Branch (2350:9): [Folded, False: 18.3k]
  |  Branch (2350:9): [True: 18.3k, False: 0]
  |  Branch (2350:9): [True: 18.3k, False: 0]
  ------------------
 2351|  18.3k|        auto cpos = lpos.last_sub(
 2352|  18.3k|            concat_both_mut_visitor<Node>{}, ec, el, tpos, er, rpos);
 2353|  18.3k|        return concat_rebalance_mut<Node>(ec, el, lpos, cpos, er, rpos);
 2354|  18.3k|    }
 2355|  18.5k|}
_ZN5immer6detail4rbts23concat_both_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE10visit_leafIRNS1_12leaf_sub_posISC_EERNS1_8leaf_posISC_EERNS1_8full_posISC_EEEENS1_17concat_center_posISC_EEOT_NSA_5applyIS7_E4type4editESV_OT0_SV_OT1_:
 2416|  7.97k|    {
 2417|  7.97k|        return rpos.first_sub_leaf(
 2418|  7.97k|            concat_right_mut_visitor<Node>{}, ec, el, lpos, tpos, er);
 2419|  7.97k|    }
_ZN5immer6detail4rbts24concat_right_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE10visit_leafIRNS1_13full_leaf_posISC_EERNS1_12leaf_sub_posISC_EERNS1_8leaf_posISC_EEEENS1_17concat_center_posISC_EEOT_NSA_5applyIS7_E4type4editESV_OT0_OT1_SV_:
 2394|  34.9k|    {
 2395|  34.9k|        return concat_leafs_mut<Node>(ec, el, lpos, tpos, er, rpos);
 2396|  34.9k|    }
_ZN5immer6detail4rbts16concat_leafs_mutINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEERNS1_12leaf_sub_posISC_EERNS1_8leaf_posISC_EERNS1_13full_leaf_posISC_EEEENS1_17concat_center_posIT_EENSt3__15decayISN_E4type6node_t6edit_tESU_OT0_OT1_SU_OT2_:
 2294|  34.9k|{
 2295|  34.9k|    static_assert(Node::bits >= 2, "");
 2296|  34.9k|    assert(lpos.shift() == tpos.shift());
  ------------------
  |  Branch (2296:5): [True: 34.9k, False: 0]
  ------------------
 2297|  34.9k|    assert(lpos.shift() == rpos.shift());
  ------------------
  |  Branch (2297:5): [True: 34.9k, False: 0]
  ------------------
 2298|  34.9k|    assert(lpos.shift() == 0);
  ------------------
  |  Branch (2298:5): [True: 34.9k, False: 0]
  ------------------
 2299|  34.9k|    if (tpos.count() > 0)
  ------------------
  |  Branch (2299:9): [True: 34.9k, False: 0]
  ------------------
 2300|  34.9k|        return {
 2301|  34.9k|            Node::bits_leaf,
 2302|  34.9k|            lpos.node(),
 2303|  34.9k|            lpos.count(),
 2304|  34.9k|            tpos.node(),
 2305|  34.9k|            tpos.count(),
 2306|  34.9k|            rpos.node(),
 2307|  34.9k|            rpos.count(),
 2308|  34.9k|        };
 2309|      0|    else
 2310|      0|        return {
 2311|      0|            Node::bits_leaf,
 2312|      0|            lpos.node(),
 2313|      0|            lpos.count(),
 2314|      0|            rpos.node(),
 2315|      0|            rpos.count(),
 2316|      0|        };
 2317|  34.9k|}
_ZN5immer6detail4rbts23concat_both_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE11visit_innerIRNS1_15regular_sub_posISC_EERNS1_8leaf_posISC_EERNS1_8full_posISC_EEEENS1_17concat_center_posISC_EEOT_NSA_5applyIS7_E4type4editESV_OT0_SV_OT1_:
 2408|  12.0k|    {
 2409|  12.0k|        return rpos.first_sub(
 2410|  12.0k|            concat_right_mut_visitor<Node>{}, ec, el, lpos, tpos, er);
 2411|  12.0k|    }
_ZN5immer6detail4rbts20concat_rebalance_mutINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEERNS1_15regular_sub_posISC_EERNS1_17concat_center_posISC_EERNS1_8full_posISC_EEEENSG_IT_EENSt3__15decayISM_E4type6node_t6edit_tEST_OT0_OT1_ST_OT2_:
 2280|  18.3k|{
 2281|  18.3k|    auto plan = concat_rebalance_plan_mut<Node::bits, Node::bits_leaf>{};
 2282|  18.3k|    plan.fill(lpos, cpos, rpos);
 2283|  18.3k|    plan.shuffle(cpos.shift());
 2284|  18.3k|    return plan.merge(ec, el, lpos, cpos, er, rpos);
 2285|  18.3k|}
_ZN5immer6detail4rbts25concat_rebalance_plan_mutILj2ELj2EE5mergeIRNS1_15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEERNS1_17concat_center_posISF_EERNS1_8full_posISF_EEEENSI_INSt3__15decayIT0_E4type6node_tEEENST_6edit_tESV_OT_OSQ_SV_OT1_:
 2244|  18.3k|    {
 2245|  18.3k|        using node_t    = node_type<CPos>;
 2246|  18.3k|        using merger_t  = concat_merger_mut<node_t>;
 2247|  18.3k|        using visitor_t = concat_merger_mut_visitor;
 2248|  18.3k|        auto lnode      = ((node_t*) lpos.node());
 2249|  18.3k|        auto rnode      = ((node_t*) rpos.node());
 2250|  18.3k|        auto lmut2      = lnode && lnode->can_relax() && lnode->can_mutate(el);
  ------------------
  |  Branch (2250:27): [True: 18.3k, False: 0]
  |  Branch (2250:36): [True: 18.3k, False: 0]
  |  Branch (2250:58): [True: 419, False: 17.9k]
  ------------------
 2251|  18.3k|        auto rmut2      = rnode && rnode->can_relax() && rnode->can_mutate(er);
  ------------------
  |  Branch (2251:27): [True: 18.3k, False: 0]
  |  Branch (2251:36): [True: 18.3k, False: 0]
  |  Branch (2251:58): [True: 257, False: 18.0k]
  ------------------
 2252|  18.3k|        auto merger     = merger_t{ec,
 2253|  18.3k|                               cpos.shift(),
 2254|  18.3k|                               this->counts,
 2255|  18.3k|                               this->n,
 2256|  18.3k|                               el,
 2257|  18.3k|                               lmut2 ? lnode : nullptr};
  ------------------
  |  Branch (2257:32): [True: 419, False: 17.9k]
  ------------------
 2258|  18.3k|        IMMER_TRY {
  ------------------
  |  |   49|  18.3k|#define IMMER_TRY try
  ------------------
 2259|  18.3k|            lpos.each_left_sub(visitor_t{}, merger, el);
 2260|  18.3k|            cpos.each_sub(visitor_t{}, merger, ec);
 2261|  18.3k|            if (rmut2)
  ------------------
  |  Branch (2261:17): [True: 257, False: 18.0k]
  ------------------
 2262|    257|                merger.set_candidate(er, rnode);
 2263|  18.3k|            rpos.each_right_sub(visitor_t{}, merger, er);
 2264|  18.3k|            return merger.finish();
 2265|  18.3k|        }
 2266|  18.3k|        IMMER_CATCH (...) {
 2267|      0|            merger.abort();
 2268|      0|            IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
 2269|      0|        }
 2270|  18.3k|    }
_ZN5immer6detail4rbts23concat_both_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE10visit_leafIRNS1_12leaf_sub_posISC_EERNS1_8leaf_posISC_EERNS1_15regular_sub_posISC_EEEENS1_17concat_center_posISC_EEOT_NSA_5applyIS7_E4type4editESV_OT0_SV_OT1_:
 2416|  26.9k|    {
 2417|  26.9k|        return rpos.first_sub_leaf(
 2418|  26.9k|            concat_right_mut_visitor<Node>{}, ec, el, lpos, tpos, er);
 2419|  26.9k|    }
_ZN5immer6detail4rbts24concat_right_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE10visit_leafIRNS1_12leaf_sub_posISC_EESH_RNS1_8leaf_posISC_EEEENS1_17concat_center_posISC_EEOT_NSA_5applyIS7_E4type4editESS_OT0_OT1_SS_:
 2394|  64.7k|    {
 2395|  64.7k|        return concat_leafs_mut<Node>(ec, el, lpos, tpos, er, rpos);
 2396|  64.7k|    }
_ZN5immer6detail4rbts16concat_leafs_mutINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEERNS1_12leaf_sub_posISC_EERNS1_8leaf_posISC_EESF_EENS1_17concat_center_posIT_EENSt3__15decayISK_E4type6node_t6edit_tESR_OT0_OT1_SR_OT2_:
 2294|  64.7k|{
 2295|  64.7k|    static_assert(Node::bits >= 2, "");
 2296|  64.7k|    assert(lpos.shift() == tpos.shift());
  ------------------
  |  Branch (2296:5): [True: 64.7k, False: 0]
  ------------------
 2297|  64.7k|    assert(lpos.shift() == rpos.shift());
  ------------------
  |  Branch (2297:5): [True: 64.7k, False: 0]
  ------------------
 2298|  64.7k|    assert(lpos.shift() == 0);
  ------------------
  |  Branch (2298:5): [True: 64.7k, False: 0]
  ------------------
 2299|  64.7k|    if (tpos.count() > 0)
  ------------------
  |  Branch (2299:9): [True: 64.7k, False: 0]
  ------------------
 2300|  64.7k|        return {
 2301|  64.7k|            Node::bits_leaf,
 2302|  64.7k|            lpos.node(),
 2303|  64.7k|            lpos.count(),
 2304|  64.7k|            tpos.node(),
 2305|  64.7k|            tpos.count(),
 2306|  64.7k|            rpos.node(),
 2307|  64.7k|            rpos.count(),
 2308|  64.7k|        };
 2309|      0|    else
 2310|      0|        return {
 2311|      0|            Node::bits_leaf,
 2312|      0|            lpos.node(),
 2313|      0|            lpos.count(),
 2314|      0|            rpos.node(),
 2315|      0|            rpos.count(),
 2316|      0|        };
 2317|  64.7k|}
_ZN5immer6detail4rbts23concat_both_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE11visit_innerIRNS1_15regular_sub_posISC_EERNS1_8leaf_posISC_EESH_EENS1_17concat_center_posISC_EEOT_NSA_5applyIS7_E4type4editESS_OT0_SS_OT1_:
 2408|  5.78k|    {
 2409|  5.78k|        return rpos.first_sub(
 2410|  5.78k|            concat_right_mut_visitor<Node>{}, ec, el, lpos, tpos, er);
 2411|  5.78k|    }
_ZN5immer6detail4rbts20concat_rebalance_mutINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEERNS1_15regular_sub_posISC_EERNS1_17concat_center_posISC_EESF_EENSG_IT_EENSt3__15decayISJ_E4type6node_t6edit_tESQ_OT0_OT1_SQ_OT2_:
 2280|  6.06k|{
 2281|  6.06k|    auto plan = concat_rebalance_plan_mut<Node::bits, Node::bits_leaf>{};
 2282|  6.06k|    plan.fill(lpos, cpos, rpos);
 2283|  6.06k|    plan.shuffle(cpos.shift());
 2284|  6.06k|    return plan.merge(ec, el, lpos, cpos, er, rpos);
 2285|  6.06k|}
_ZN5immer6detail4rbts25concat_rebalance_plan_mutILj2ELj2EE5mergeIRNS1_15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEERNS1_17concat_center_posISF_EESH_EENSI_INSt3__15decayIT0_E4type6node_tEEENSQ_6edit_tESS_OT_OSN_SS_OT1_:
 2244|  6.06k|    {
 2245|  6.06k|        using node_t    = node_type<CPos>;
 2246|  6.06k|        using merger_t  = concat_merger_mut<node_t>;
 2247|  6.06k|        using visitor_t = concat_merger_mut_visitor;
 2248|  6.06k|        auto lnode      = ((node_t*) lpos.node());
 2249|  6.06k|        auto rnode      = ((node_t*) rpos.node());
 2250|  6.06k|        auto lmut2      = lnode && lnode->can_relax() && lnode->can_mutate(el);
  ------------------
  |  Branch (2250:27): [True: 6.06k, False: 0]
  |  Branch (2250:36): [True: 6.06k, False: 0]
  |  Branch (2250:58): [True: 672, False: 5.39k]
  ------------------
 2251|  6.06k|        auto rmut2      = rnode && rnode->can_relax() && rnode->can_mutate(er);
  ------------------
  |  Branch (2251:27): [True: 6.06k, False: 0]
  |  Branch (2251:36): [True: 6.06k, False: 0]
  |  Branch (2251:58): [True: 750, False: 5.31k]
  ------------------
 2252|  6.06k|        auto merger     = merger_t{ec,
 2253|  6.06k|                               cpos.shift(),
 2254|  6.06k|                               this->counts,
 2255|  6.06k|                               this->n,
 2256|  6.06k|                               el,
 2257|  6.06k|                               lmut2 ? lnode : nullptr};
  ------------------
  |  Branch (2257:32): [True: 672, False: 5.39k]
  ------------------
 2258|  6.06k|        IMMER_TRY {
  ------------------
  |  |   49|  6.06k|#define IMMER_TRY try
  ------------------
 2259|  6.06k|            lpos.each_left_sub(visitor_t{}, merger, el);
 2260|  6.06k|            cpos.each_sub(visitor_t{}, merger, ec);
 2261|  6.06k|            if (rmut2)
  ------------------
  |  Branch (2261:17): [True: 750, False: 5.31k]
  ------------------
 2262|    750|                merger.set_candidate(er, rnode);
 2263|  6.06k|            rpos.each_right_sub(visitor_t{}, merger, er);
 2264|  6.06k|            return merger.finish();
 2265|  6.06k|        }
 2266|  6.06k|        IMMER_CATCH (...) {
 2267|      0|            merger.abort();
 2268|      0|            IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
 2269|      0|        }
 2270|  6.06k|    }
_ZN5immer6detail4rbts23concat_both_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE10visit_leafIRNS1_12leaf_sub_posISC_EERNS1_8leaf_posISC_EERNS1_11relaxed_posISC_EEEENS1_17concat_center_posISC_EEOT_NSA_5applyIS7_E4type4editESV_OT0_SV_OT1_:
 2416|  64.7k|    {
 2417|  64.7k|        return rpos.first_sub_leaf(
 2418|  64.7k|            concat_right_mut_visitor<Node>{}, ec, el, lpos, tpos, er);
 2419|  64.7k|    }
_ZN5immer6detail4rbts23concat_both_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE11visit_innerIRNS1_15regular_sub_posISC_EERNS1_8leaf_posISC_EERNS1_11relaxed_posISC_EEEENS1_17concat_center_posISC_EEOT_NSA_5applyIS7_E4type4editESV_OT0_SV_OT1_:
 2408|   103k|    {
 2409|   103k|        return rpos.first_sub(
 2410|   103k|            concat_right_mut_visitor<Node>{}, ec, el, lpos, tpos, er);
 2411|   103k|    }
_ZN5immer6detail4rbts20concat_rebalance_mutINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEERNS1_15regular_sub_posISC_EERNS1_17concat_center_posISC_EERNS1_11relaxed_posISC_EEEENSG_IT_EENSt3__15decayISM_E4type6node_t6edit_tEST_OT0_OT1_ST_OT2_:
 2280|   105k|{
 2281|   105k|    auto plan = concat_rebalance_plan_mut<Node::bits, Node::bits_leaf>{};
 2282|   105k|    plan.fill(lpos, cpos, rpos);
 2283|   105k|    plan.shuffle(cpos.shift());
 2284|   105k|    return plan.merge(ec, el, lpos, cpos, er, rpos);
 2285|   105k|}
_ZN5immer6detail4rbts25concat_rebalance_plan_mutILj2ELj2EE5mergeIRNS1_15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEERNS1_17concat_center_posISF_EERNS1_11relaxed_posISF_EEEENSI_INSt3__15decayIT0_E4type6node_tEEENST_6edit_tESV_OT_OSQ_SV_OT1_:
 2244|   105k|    {
 2245|   105k|        using node_t    = node_type<CPos>;
 2246|   105k|        using merger_t  = concat_merger_mut<node_t>;
 2247|   105k|        using visitor_t = concat_merger_mut_visitor;
 2248|   105k|        auto lnode      = ((node_t*) lpos.node());
 2249|   105k|        auto rnode      = ((node_t*) rpos.node());
 2250|   105k|        auto lmut2      = lnode && lnode->can_relax() && lnode->can_mutate(el);
  ------------------
  |  Branch (2250:27): [True: 105k, False: 0]
  |  Branch (2250:36): [True: 105k, False: 0]
  |  Branch (2250:58): [True: 3.79k, False: 101k]
  ------------------
 2251|   105k|        auto rmut2      = rnode && rnode->can_relax() && rnode->can_mutate(er);
  ------------------
  |  Branch (2251:27): [True: 105k, False: 0]
  |  Branch (2251:36): [True: 105k, False: 0]
  |  Branch (2251:58): [True: 3.28k, False: 102k]
  ------------------
 2252|   105k|        auto merger     = merger_t{ec,
 2253|   105k|                               cpos.shift(),
 2254|   105k|                               this->counts,
 2255|   105k|                               this->n,
 2256|   105k|                               el,
 2257|   105k|                               lmut2 ? lnode : nullptr};
  ------------------
  |  Branch (2257:32): [True: 3.79k, False: 101k]
  ------------------
 2258|   105k|        IMMER_TRY {
  ------------------
  |  |   49|   105k|#define IMMER_TRY try
  ------------------
 2259|   105k|            lpos.each_left_sub(visitor_t{}, merger, el);
 2260|   105k|            cpos.each_sub(visitor_t{}, merger, ec);
 2261|   105k|            if (rmut2)
  ------------------
  |  Branch (2261:17): [True: 3.28k, False: 102k]
  ------------------
 2262|  3.28k|                merger.set_candidate(er, rnode);
 2263|   105k|            rpos.each_right_sub(visitor_t{}, merger, er);
 2264|   105k|            return merger.finish();
 2265|   105k|        }
 2266|   105k|        IMMER_CATCH (...) {
 2267|      0|            merger.abort();
 2268|      0|            IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
 2269|      0|        }
 2270|   105k|    }
_ZN5immer6detail4rbts20concat_rebalance_mutINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEERNS1_11relaxed_posISC_EERNS1_17concat_center_posISC_EENS1_12null_sub_posEEENSG_IT_EENSt3__15decayISK_E4type6node_t6edit_tESR_OT0_OT1_SR_OT2_:
 2280|   318k|{
 2281|   318k|    auto plan = concat_rebalance_plan_mut<Node::bits, Node::bits_leaf>{};
 2282|   318k|    plan.fill(lpos, cpos, rpos);
 2283|   318k|    plan.shuffle(cpos.shift());
 2284|   318k|    return plan.merge(ec, el, lpos, cpos, er, rpos);
 2285|   318k|}
_ZN5immer6detail4rbts25concat_rebalance_plan_mutILj2ELj2EE5mergeIRNS1_11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEERNS1_17concat_center_posISF_EERNS1_12null_sub_posEEENSI_INSt3__15decayIT0_E4type6node_tEEENSS_6edit_tESU_OT_OSP_SU_OT1_:
 2244|   318k|    {
 2245|   318k|        using node_t    = node_type<CPos>;
 2246|   318k|        using merger_t  = concat_merger_mut<node_t>;
 2247|   318k|        using visitor_t = concat_merger_mut_visitor;
 2248|   318k|        auto lnode      = ((node_t*) lpos.node());
 2249|   318k|        auto rnode      = ((node_t*) rpos.node());
 2250|   318k|        auto lmut2      = lnode && lnode->can_relax() && lnode->can_mutate(el);
  ------------------
  |  Branch (2250:27): [True: 318k, False: 0]
  |  Branch (2250:36): [True: 318k, False: 0]
  |  Branch (2250:58): [True: 297k, False: 20.2k]
  ------------------
 2251|   318k|        auto rmut2      = rnode && rnode->can_relax() && rnode->can_mutate(er);
  ------------------
  |  Branch (2251:27): [True: 0, False: 318k]
  |  Branch (2251:36): [True: 0, False: 0]
  |  Branch (2251:58): [True: 0, False: 0]
  ------------------
 2252|   318k|        auto merger     = merger_t{ec,
 2253|   318k|                               cpos.shift(),
 2254|   318k|                               this->counts,
 2255|   318k|                               this->n,
 2256|   318k|                               el,
 2257|   318k|                               lmut2 ? lnode : nullptr};
  ------------------
  |  Branch (2257:32): [True: 297k, False: 20.2k]
  ------------------
 2258|   318k|        IMMER_TRY {
  ------------------
  |  |   49|   318k|#define IMMER_TRY try
  ------------------
 2259|   318k|            lpos.each_left_sub(visitor_t{}, merger, el);
 2260|   318k|            cpos.each_sub(visitor_t{}, merger, ec);
 2261|   318k|            if (rmut2)
  ------------------
  |  Branch (2261:17): [True: 0, False: 318k]
  ------------------
 2262|      0|                merger.set_candidate(er, rnode);
 2263|   318k|            rpos.each_right_sub(visitor_t{}, merger, er);
 2264|   318k|            return merger.finish();
 2265|   318k|        }
 2266|   318k|        IMMER_CATCH (...) {
 2267|      0|            merger.abort();
 2268|      0|            IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
 2269|      0|        }
 2270|   318k|    }
_ZN5immer6detail4rbts24concat_right_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE11visit_innerIRNS1_11relaxed_posISC_EESH_RNS1_8leaf_posISC_EEEENS1_17concat_center_posISC_EEOT_NSA_5applyIS7_E4type4editESS_OT0_OT1_SS_:
 2387|   230k|    {
 2388|   230k|        return concat_inners_mut<Node>(ec, el, lpos, tpos, er, rpos);
 2389|   230k|    }
_ZN5immer6detail4rbts24concat_right_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE11visit_innerIRNS1_15regular_sub_posISC_EERNS1_11relaxed_posISC_EERNS1_8leaf_posISC_EEEENS1_17concat_center_posISC_EEOT_NSA_5applyIS7_E4type4editESV_OT0_OT1_SV_:
 2387|  1.40k|    {
 2388|  1.40k|        return concat_inners_mut<Node>(ec, el, lpos, tpos, er, rpos);
 2389|  1.40k|    }
_ZN5immer6detail4rbts17concat_inners_mutINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEERNS1_11relaxed_posISC_EERNS1_8leaf_posISC_EERNS1_15regular_sub_posISC_EEEENS1_17concat_center_posIT_EENSt3__15decayISN_E4type6node_t6edit_tESU_OT0_OT1_SU_OT2_:
 2333|   145k|{
 2334|   145k|    auto lshift = lpos.shift();
 2335|   145k|    auto rshift = rpos.shift();
 2336|       |    // lpos.node() can be null it is a singleton_regular_sub_pos<...>,
 2337|       |    // this is, when the tree is just a tail...
 2338|   145k|    if (lshift > rshift) {
  ------------------
  |  Branch (2338:9): [True: 116k, False: 28.4k]
  ------------------
 2339|   116k|        auto cpos = lpos.last_sub(
 2340|   116k|            concat_left_mut_visitor<Node>{}, ec, el, tpos, er, rpos);
 2341|   116k|        return concat_rebalance_mut<Node>(
 2342|   116k|            ec, el, lpos, cpos, er, null_sub_pos{});
 2343|   116k|    } else if (lshift < rshift) {
  ------------------
  |  Branch (2343:16): [True: 749, False: 27.6k]
  ------------------
 2344|    749|        auto cpos = rpos.first_sub(
 2345|    749|            concat_right_mut_visitor<Node>{}, ec, el, lpos, tpos, er);
 2346|    749|        return concat_rebalance_mut<Node>(
 2347|    749|            ec, el, null_sub_pos{}, cpos, er, rpos);
 2348|  27.6k|    } else {
 2349|  27.6k|        assert(lshift == rshift);
  ------------------
  |  Branch (2349:9): [True: 27.6k, False: 0]
  ------------------
 2350|  27.6k|        assert(Node::bits_leaf == 0u || lshift > 0);
  ------------------
  |  Branch (2350:9): [Folded, False: 27.6k]
  |  Branch (2350:9): [True: 27.6k, False: 0]
  |  Branch (2350:9): [True: 27.6k, False: 0]
  ------------------
 2351|  27.6k|        auto cpos = lpos.last_sub(
 2352|  27.6k|            concat_both_mut_visitor<Node>{}, ec, el, tpos, er, rpos);
 2353|  27.6k|        return concat_rebalance_mut<Node>(ec, el, lpos, cpos, er, rpos);
 2354|  27.6k|    }
 2355|   145k|}
_ZN5immer6detail4rbts23concat_left_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE11visit_innerIRNS1_11relaxed_posISC_EERNS1_8leaf_posISC_EERNS1_15regular_sub_posISC_EEEENS1_17concat_center_posISC_EEOT_NSA_5applyIS7_E4type4editESV_OT0_SV_OT1_:
 2366|   116k|    {
 2367|   116k|        return concat_inners_mut<Node>(ec, el, lpos, tpos, er, rpos);
 2368|   116k|    }
_ZN5immer6detail4rbts24concat_right_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE11visit_innerIRNS1_8full_posISC_EERNS1_11relaxed_posISC_EERNS1_8leaf_posISC_EEEENS1_17concat_center_posISC_EEOT_NSA_5applyIS7_E4type4editESV_OT0_OT1_SV_:
 2387|  2.40k|    {
 2388|  2.40k|        return concat_inners_mut<Node>(ec, el, lpos, tpos, er, rpos);
 2389|  2.40k|    }
_ZN5immer6detail4rbts17concat_inners_mutINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEERNS1_11relaxed_posISC_EERNS1_8leaf_posISC_EERNS1_8full_posISC_EEEENS1_17concat_center_posIT_EENSt3__15decayISN_E4type6node_t6edit_tESU_OT0_OT1_SU_OT2_:
 2333|  2.40k|{
 2334|  2.40k|    auto lshift = lpos.shift();
 2335|  2.40k|    auto rshift = rpos.shift();
 2336|       |    // lpos.node() can be null it is a singleton_regular_sub_pos<...>,
 2337|       |    // this is, when the tree is just a tail...
 2338|  2.40k|    if (lshift > rshift) {
  ------------------
  |  Branch (2338:9): [True: 0, False: 2.40k]
  ------------------
 2339|      0|        auto cpos = lpos.last_sub(
 2340|      0|            concat_left_mut_visitor<Node>{}, ec, el, tpos, er, rpos);
 2341|      0|        return concat_rebalance_mut<Node>(
 2342|      0|            ec, el, lpos, cpos, er, null_sub_pos{});
 2343|  2.40k|    } else if (lshift < rshift) {
  ------------------
  |  Branch (2343:16): [True: 232, False: 2.17k]
  ------------------
 2344|    232|        auto cpos = rpos.first_sub(
 2345|    232|            concat_right_mut_visitor<Node>{}, ec, el, lpos, tpos, er);
 2346|    232|        return concat_rebalance_mut<Node>(
 2347|    232|            ec, el, null_sub_pos{}, cpos, er, rpos);
 2348|  2.17k|    } else {
 2349|  2.17k|        assert(lshift == rshift);
  ------------------
  |  Branch (2349:9): [True: 2.17k, False: 0]
  ------------------
 2350|  2.17k|        assert(Node::bits_leaf == 0u || lshift > 0);
  ------------------
  |  Branch (2350:9): [Folded, False: 2.17k]
  |  Branch (2350:9): [True: 2.17k, False: 0]
  |  Branch (2350:9): [True: 2.17k, False: 0]
  ------------------
 2351|  2.17k|        auto cpos = lpos.last_sub(
 2352|  2.17k|            concat_both_mut_visitor<Node>{}, ec, el, tpos, er, rpos);
 2353|  2.17k|        return concat_rebalance_mut<Node>(ec, el, lpos, cpos, er, rpos);
 2354|  2.17k|    }
 2355|  2.40k|}
_ZN5immer6detail4rbts23concat_both_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE11visit_innerIRNS1_11relaxed_posISC_EERNS1_8leaf_posISC_EERNS1_8full_posISC_EEEENS1_17concat_center_posISC_EEOT_NSA_5applyIS7_E4type4editESV_OT0_SV_OT1_:
 2408|    461|    {
 2409|    461|        return rpos.first_sub(
 2410|    461|            concat_right_mut_visitor<Node>{}, ec, el, lpos, tpos, er);
 2411|    461|    }
_ZN5immer6detail4rbts20concat_rebalance_mutINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEERNS1_11relaxed_posISC_EERNS1_17concat_center_posISC_EERNS1_8full_posISC_EEEENSG_IT_EENSt3__15decayISM_E4type6node_t6edit_tEST_OT0_OT1_ST_OT2_:
 2280|  2.17k|{
 2281|  2.17k|    auto plan = concat_rebalance_plan_mut<Node::bits, Node::bits_leaf>{};
 2282|  2.17k|    plan.fill(lpos, cpos, rpos);
 2283|  2.17k|    plan.shuffle(cpos.shift());
 2284|  2.17k|    return plan.merge(ec, el, lpos, cpos, er, rpos);
 2285|  2.17k|}
_ZN5immer6detail4rbts25concat_rebalance_plan_mutILj2ELj2EE5mergeIRNS1_11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEERNS1_17concat_center_posISF_EERNS1_8full_posISF_EEEENSI_INSt3__15decayIT0_E4type6node_tEEENST_6edit_tESV_OT_OSQ_SV_OT1_:
 2244|  2.17k|    {
 2245|  2.17k|        using node_t    = node_type<CPos>;
 2246|  2.17k|        using merger_t  = concat_merger_mut<node_t>;
 2247|  2.17k|        using visitor_t = concat_merger_mut_visitor;
 2248|  2.17k|        auto lnode      = ((node_t*) lpos.node());
 2249|  2.17k|        auto rnode      = ((node_t*) rpos.node());
 2250|  2.17k|        auto lmut2      = lnode && lnode->can_relax() && lnode->can_mutate(el);
  ------------------
  |  Branch (2250:27): [True: 2.17k, False: 0]
  |  Branch (2250:36): [True: 2.17k, False: 0]
  |  Branch (2250:58): [True: 832, False: 1.34k]
  ------------------
 2251|  2.17k|        auto rmut2      = rnode && rnode->can_relax() && rnode->can_mutate(er);
  ------------------
  |  Branch (2251:27): [True: 2.17k, False: 0]
  |  Branch (2251:36): [True: 2.17k, False: 0]
  |  Branch (2251:58): [True: 197, False: 1.97k]
  ------------------
 2252|  2.17k|        auto merger     = merger_t{ec,
 2253|  2.17k|                               cpos.shift(),
 2254|  2.17k|                               this->counts,
 2255|  2.17k|                               this->n,
 2256|  2.17k|                               el,
 2257|  2.17k|                               lmut2 ? lnode : nullptr};
  ------------------
  |  Branch (2257:32): [True: 832, False: 1.34k]
  ------------------
 2258|  2.17k|        IMMER_TRY {
  ------------------
  |  |   49|  2.17k|#define IMMER_TRY try
  ------------------
 2259|  2.17k|            lpos.each_left_sub(visitor_t{}, merger, el);
 2260|  2.17k|            cpos.each_sub(visitor_t{}, merger, ec);
 2261|  2.17k|            if (rmut2)
  ------------------
  |  Branch (2261:17): [True: 197, False: 1.97k]
  ------------------
 2262|    197|                merger.set_candidate(er, rnode);
 2263|  2.17k|            rpos.each_right_sub(visitor_t{}, merger, er);
 2264|  2.17k|            return merger.finish();
 2265|  2.17k|        }
 2266|  2.17k|        IMMER_CATCH (...) {
 2267|      0|            merger.abort();
 2268|      0|            IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
 2269|      0|        }
 2270|  2.17k|    }
_ZN5immer6detail4rbts23concat_both_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE11visit_innerIRNS1_11relaxed_posISC_EERNS1_8leaf_posISC_EERNS1_15regular_sub_posISC_EEEENS1_17concat_center_posISC_EEOT_NSA_5applyIS7_E4type4editESV_OT0_SV_OT1_:
 2408|    963|    {
 2409|    963|        return rpos.first_sub(
 2410|    963|            concat_right_mut_visitor<Node>{}, ec, el, lpos, tpos, er);
 2411|    963|    }
_ZN5immer6detail4rbts20concat_rebalance_mutINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEERNS1_11relaxed_posISC_EERNS1_17concat_center_posISC_EERNS1_15regular_sub_posISC_EEEENSG_IT_EENSt3__15decayISM_E4type6node_t6edit_tEST_OT0_OT1_ST_OT2_:
 2280|  27.6k|{
 2281|  27.6k|    auto plan = concat_rebalance_plan_mut<Node::bits, Node::bits_leaf>{};
 2282|  27.6k|    plan.fill(lpos, cpos, rpos);
 2283|  27.6k|    plan.shuffle(cpos.shift());
 2284|  27.6k|    return plan.merge(ec, el, lpos, cpos, er, rpos);
 2285|  27.6k|}
_ZN5immer6detail4rbts25concat_rebalance_plan_mutILj2ELj2EE5mergeIRNS1_11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEERNS1_17concat_center_posISF_EERNS1_15regular_sub_posISF_EEEENSI_INSt3__15decayIT0_E4type6node_tEEENST_6edit_tESV_OT_OSQ_SV_OT1_:
 2244|  27.6k|    {
 2245|  27.6k|        using node_t    = node_type<CPos>;
 2246|  27.6k|        using merger_t  = concat_merger_mut<node_t>;
 2247|  27.6k|        using visitor_t = concat_merger_mut_visitor;
 2248|  27.6k|        auto lnode      = ((node_t*) lpos.node());
 2249|  27.6k|        auto rnode      = ((node_t*) rpos.node());
 2250|  27.6k|        auto lmut2      = lnode && lnode->can_relax() && lnode->can_mutate(el);
  ------------------
  |  Branch (2250:27): [True: 27.6k, False: 0]
  |  Branch (2250:36): [True: 27.6k, False: 0]
  |  Branch (2250:58): [True: 24.8k, False: 2.75k]
  ------------------
 2251|  27.6k|        auto rmut2      = rnode && rnode->can_relax() && rnode->can_mutate(er);
  ------------------
  |  Branch (2251:27): [True: 27.6k, False: 0]
  |  Branch (2251:36): [True: 27.6k, False: 0]
  |  Branch (2251:58): [True: 484, False: 27.1k]
  ------------------
 2252|  27.6k|        auto merger     = merger_t{ec,
 2253|  27.6k|                               cpos.shift(),
 2254|  27.6k|                               this->counts,
 2255|  27.6k|                               this->n,
 2256|  27.6k|                               el,
 2257|  27.6k|                               lmut2 ? lnode : nullptr};
  ------------------
  |  Branch (2257:32): [True: 24.8k, False: 2.75k]
  ------------------
 2258|  27.6k|        IMMER_TRY {
  ------------------
  |  |   49|  27.6k|#define IMMER_TRY try
  ------------------
 2259|  27.6k|            lpos.each_left_sub(visitor_t{}, merger, el);
 2260|  27.6k|            cpos.each_sub(visitor_t{}, merger, ec);
 2261|  27.6k|            if (rmut2)
  ------------------
  |  Branch (2261:17): [True: 484, False: 27.1k]
  ------------------
 2262|    484|                merger.set_candidate(er, rnode);
 2263|  27.6k|            rpos.each_right_sub(visitor_t{}, merger, er);
 2264|  27.6k|            return merger.finish();
 2265|  27.6k|        }
 2266|  27.6k|        IMMER_CATCH (...) {
 2267|      0|            merger.abort();
 2268|      0|            IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
 2269|      0|        }
 2270|  27.6k|    }
_ZN5immer6detail4rbts23concat_both_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE11visit_innerIRNS1_11relaxed_posISC_EERNS1_8leaf_posISC_EESH_EENS1_17concat_center_posISC_EEOT_NSA_5applyIS7_E4type4editESS_OT0_SS_OT1_:
 2408|   186k|    {
 2409|   186k|        return rpos.first_sub(
 2410|   186k|            concat_right_mut_visitor<Node>{}, ec, el, lpos, tpos, er);
 2411|   186k|    }
_ZN5immer6detail4rbts20concat_rebalance_mutINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEERNS1_11relaxed_posISC_EERNS1_17concat_center_posISC_EESF_EENSG_IT_EENSt3__15decayISJ_E4type6node_t6edit_tESQ_OT0_OT1_SQ_OT2_:
 2280|   248k|{
 2281|   248k|    auto plan = concat_rebalance_plan_mut<Node::bits, Node::bits_leaf>{};
 2282|   248k|    plan.fill(lpos, cpos, rpos);
 2283|   248k|    plan.shuffle(cpos.shift());
 2284|   248k|    return plan.merge(ec, el, lpos, cpos, er, rpos);
 2285|   248k|}
_ZN5immer6detail4rbts25concat_rebalance_plan_mutILj2ELj2EE5mergeIRNS1_11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEERNS1_17concat_center_posISF_EESH_EENSI_INSt3__15decayIT0_E4type6node_tEEENSQ_6edit_tESS_OT_OSN_SS_OT1_:
 2244|   248k|    {
 2245|   248k|        using node_t    = node_type<CPos>;
 2246|   248k|        using merger_t  = concat_merger_mut<node_t>;
 2247|   248k|        using visitor_t = concat_merger_mut_visitor;
 2248|   248k|        auto lnode      = ((node_t*) lpos.node());
 2249|   248k|        auto rnode      = ((node_t*) rpos.node());
 2250|   248k|        auto lmut2      = lnode && lnode->can_relax() && lnode->can_mutate(el);
  ------------------
  |  Branch (2250:27): [True: 248k, False: 0]
  |  Branch (2250:36): [True: 248k, False: 0]
  |  Branch (2250:58): [True: 48.8k, False: 200k]
  ------------------
 2251|   248k|        auto rmut2      = rnode && rnode->can_relax() && rnode->can_mutate(er);
  ------------------
  |  Branch (2251:27): [True: 248k, False: 0]
  |  Branch (2251:36): [True: 248k, False: 0]
  |  Branch (2251:58): [True: 9.93k, False: 239k]
  ------------------
 2252|   248k|        auto merger     = merger_t{ec,
 2253|   248k|                               cpos.shift(),
 2254|   248k|                               this->counts,
 2255|   248k|                               this->n,
 2256|   248k|                               el,
 2257|   248k|                               lmut2 ? lnode : nullptr};
  ------------------
  |  Branch (2257:32): [True: 48.8k, False: 200k]
  ------------------
 2258|   248k|        IMMER_TRY {
  ------------------
  |  |   49|   248k|#define IMMER_TRY try
  ------------------
 2259|   248k|            lpos.each_left_sub(visitor_t{}, merger, el);
 2260|   248k|            cpos.each_sub(visitor_t{}, merger, ec);
 2261|   248k|            if (rmut2)
  ------------------
  |  Branch (2261:17): [True: 9.93k, False: 239k]
  ------------------
 2262|  9.93k|                merger.set_candidate(er, rnode);
 2263|   248k|            rpos.each_right_sub(visitor_t{}, merger, er);
 2264|   248k|            return merger.finish();
 2265|   248k|        }
 2266|   248k|        IMMER_CATCH (...) {
 2267|      0|            merger.abort();
 2268|      0|            IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
 2269|      0|        }
 2270|   248k|    }
_ZN5immer6detail4rbts30concat_trees_right_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE10visit_nodeIRNS1_15regular_sub_posISC_EERNS1_11relaxed_posISC_EERNS1_8leaf_posISC_EEEENS1_17concat_center_posISC_EEOT_NSA_5applyIS7_E4type4editESV_OT0_OT1_SV_:
 2432|  27.6k|    {
 2433|  27.6k|        return concat_inners_mut<Node>(ec, el, lpos, tpos, er, rpos);
 2434|  27.6k|    }
_ZN5immer6detail4rbts29concat_trees_left_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE10visit_nodeIRNS1_15regular_sub_posISC_EENS1_8leaf_posISC_EEJRPSC_RjRmEEENS1_17concat_center_posISC_EEOT_NSA_5applyIS7_E4type4editESV_OT0_SV_DpOT1_:
 2451|  6.37k|    {
 2452|  6.37k|        return visit_maybe_relaxed_sub(args...,
 2453|  6.37k|                                       concat_trees_right_mut_visitor<Node>{},
 2454|  6.37k|                                       ec,
 2455|  6.37k|                                       el,
 2456|  6.37k|                                       lpos,
 2457|  6.37k|                                       tpos,
 2458|  6.37k|                                       er);
 2459|  6.37k|    }
_ZN5immer6detail4rbts30concat_trees_right_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE10visit_nodeIRNS1_11relaxed_posISC_EERNS1_15regular_sub_posISC_EERNS1_8leaf_posISC_EEEENS1_17concat_center_posISC_EEOT_NSA_5applyIS7_E4type4editESV_OT0_OT1_SV_:
 2432|  3.39k|    {
 2433|  3.39k|        return concat_inners_mut<Node>(ec, el, lpos, tpos, er, rpos);
 2434|  3.39k|    }
_ZN5immer6detail4rbts30concat_trees_right_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE10visit_nodeIRNS1_15regular_sub_posISC_EESH_RNS1_8leaf_posISC_EEEENS1_17concat_center_posISC_EEOT_NSA_5applyIS7_E4type4editESS_OT0_OT1_SS_:
 2432|  2.97k|    {
 2433|  2.97k|        return concat_inners_mut<Node>(ec, el, lpos, tpos, er, rpos);
 2434|  2.97k|    }

_ZN5immer6detail4rbts23visit_maybe_relaxed_subINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEENS1_11dec_visitorEJEEEDcPT_jmT0_DpOT1_:
 1838|   260k|{
 1839|   260k|    assert(node);
  ------------------
  |  Branch (1839:5): [True: 260k, False: 0]
  ------------------
 1840|   260k|    auto relaxed = node->relaxed();
 1841|   260k|    if (relaxed) {
  ------------------
  |  Branch (1841:9): [True: 208k, False: 52.2k]
  ------------------
 1842|   208k|        assert(size == relaxed->d.sizes[relaxed->d.count - 1]);
  ------------------
  |  Branch (1842:9): [True: 208k, False: 0]
  ------------------
 1843|   208k|        return make_relaxed_pos(node, shift, relaxed)
 1844|   208k|            .visit(v, std::forward<Args>(args)...);
 1845|   208k|    } else {
 1846|  52.2k|        return make_regular_sub_pos(node, shift, size)
 1847|  52.2k|            .visit(v, std::forward<Args>(args)...);
 1848|  52.2k|    }
 1849|   260k|}
_ZN5immer6detail4rbts16make_relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEENS1_11relaxed_posIT_EEPSE_jPNSE_9relaxed_tE:
 1828|  10.8M|{
 1829|  10.8M|    assert(node);
  ------------------
  |  Branch (1829:5): [True: 10.8M, False: 0]
  ------------------
 1830|  10.8M|    assert(relaxed);
  ------------------
  |  Branch (1830:5): [True: 10.8M, False: 0]
  ------------------
 1831|  10.8M|    assert(shift >= NodeT::bits_leaf);
  ------------------
  |  Branch (1831:5): [True: 10.8M, False: 0]
  ------------------
 1832|  10.8M|    return {node, shift, relaxed};
 1833|  10.8M|}
_ZN5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_11dec_visitorEJEEEDcT_DpOT0_:
 1813|   636k|    {
 1814|   636k|        return Visitor::visit_relaxed(*this, std::forward<Args>(args)...);
 1815|   636k|    }
_ZNK5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE4nodeEv:
 1431|  7.00M|    node_t* node() const { return node_; }
_ZNK5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5countEv:
 1430|  9.63M|    count_t count() const { return relaxed_->d.count; }
_ZN5immer6detail4rbts20make_regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEENS1_15regular_sub_posIT_EEPSE_jm:
 1044|  2.27M|{
 1045|  2.27M|    assert(node);
  ------------------
  |  Branch (1045:5): [True: 2.27M, False: 0]
  ------------------
 1046|  2.27M|    assert(shift >= NodeT::bits_leaf);
  ------------------
  |  Branch (1046:5): [True: 2.27M, False: 0]
  ------------------
 1047|  2.27M|    assert(size > 0);
  ------------------
  |  Branch (1047:5): [True: 2.27M, False: 0]
  ------------------
 1048|  2.27M|    assert(size <= (branches<NodeT::bits, size_t> << shift));
  ------------------
  |  Branch (1048:5): [True: 2.27M, False: 0]
  ------------------
 1049|  2.27M|    return {node, shift, size};
 1050|  2.27M|}
_ZN5immer6detail4rbts15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_11dec_visitorEJEEEDcT_DpOT0_:
 1036|  63.8k|    {
 1037|  63.8k|        return Visitor::visit_regular(*this, std::forward<Args>(args)...);
 1038|  63.8k|    }
_ZNK5immer6detail4rbts15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE4nodeEv:
  785|  4.25M|    node_t* node() const { return node_; }
_ZNK5immer6detail4rbts15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5shiftEv:
  787|  4.38M|    shift_t shift() const { return shift_; }
_ZN5immer6detail4rbts18make_full_leaf_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEENS1_13full_leaf_posIT_EEPSE_:
  214|   306k|{
  215|   306k|    assert(node);
  ------------------
  |  Branch (215:5): [True: 306k, False: 0]
  ------------------
  216|   306k|    return {node};
  217|   306k|}
_ZN5immer6detail4rbts13full_leaf_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_11dec_visitorEJEEEDcT_DpOT0_:
  207|  6.29k|    {
  208|  6.29k|        return Visitor::visit_leaf(*this, std::forward<Args>(args)...);
  209|  6.29k|    }
_ZNK5immer6detail4rbts13full_leaf_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE4nodeEv:
  199|   207k|    node_t* node() const { return node_; }
_ZNK5immer6detail4rbts13full_leaf_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5countEv:
  198|   303k|    count_t count() const { return branches<BL>; }
_ZN5immer6detail4rbts13make_leaf_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEENS1_8leaf_posIT_EEPSE_m:
  119|   159k|{
  120|   159k|    assert(node);
  ------------------
  |  Branch (120:5): [True: 159k, False: 0]
  ------------------
  121|   159k|    assert(size > 0);
  ------------------
  |  Branch (121:5): [True: 159k, False: 0]
  ------------------
  122|   159k|    return {node, size};
  123|   159k|}
_ZNK5immer6detail4rbts15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE4sizeEv:
  786|  6.94M|    size_t size() const { return size_; }
_ZN5immer6detail4rbts8leaf_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_11dec_visitorEJEEEDcT_DpOT0_:
  112|  2.37k|    {
  113|  2.37k|        return Visitor::visit_leaf(*this, std::forward<Args>(args)...);
  114|  2.37k|    }
_ZNK5immer6detail4rbts8leaf_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE4nodeEv:
  104|   162k|    node_t* node() const { return node_; }
_ZNK5immer6detail4rbts8leaf_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5countEv:
  103|   304k|    count_t count() const { return index(size_ - 1) + 1; }
_ZNK5immer6detail4rbts8leaf_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5indexEm:
  107|   315k|    count_t index(size_t idx) const { return idx & mask<BL>; }
_ZN5immer6detail4rbts13make_full_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEENS1_8full_posIT_EEPSE_j:
 1412|   484k|{
 1413|   484k|    assert(node);
  ------------------
  |  Branch (1413:5): [True: 484k, False: 0]
  ------------------
 1414|   484k|    assert(shift >= NodeT::bits_leaf);
  ------------------
  |  Branch (1414:5): [True: 484k, False: 0]
  ------------------
 1415|   484k|    return {node, shift};
 1416|   484k|}
_ZN5immer6detail4rbts8full_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_11dec_visitorEJEEEDcT_DpOT0_:
 1405|  10.3k|    {
 1406|  10.3k|        return Visitor::visit_regular(*this, std::forward<Args>(args)...);
 1407|  10.3k|    }
_ZNK5immer6detail4rbts8full_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE4nodeEv:
 1159|   281k|    node_t* node() const { return node_; }
_ZNK5immer6detail4rbts8full_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5countEv:
 1158|   434k|    count_t count() const { return branches<B>; }
_ZN5immer6detail4rbts16make_regular_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEENS1_11regular_posIT_EEPSE_jm:
  690|  9.10M|{
  691|  9.10M|    assert(node);
  ------------------
  |  Branch (691:5): [True: 9.10M, False: 0]
  ------------------
  692|  9.10M|    assert(shift >= NodeT::bits_leaf);
  ------------------
  |  Branch (692:5): [True: 9.10M, False: 0]
  ------------------
  693|  9.10M|    assert(size > 0);
  ------------------
  |  Branch (693:5): [True: 9.10M, False: 0]
  ------------------
  694|  9.10M|    return {node, shift, size};
  695|  9.10M|}
_ZN5immer6detail4rbts11regular_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_11dec_visitorEJEEEDcT_DpOT0_:
  336|  3.68k|    {
  337|  3.68k|        return Visitor::visit_regular(*this, std::forward<Args>(args)...);
  338|  3.68k|    }
_ZNK5immer6detail4rbts11regular_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE4nodeEv:
  231|  16.5M|    node_t* node() const { return node_; }
_ZNK5immer6detail4rbts11regular_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5shiftEv:
  233|  16.5M|    shift_t shift() const { return shift_; }
_ZNK5immer6detail4rbts11regular_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE4sizeEv:
  232|  34.7M|    size_t size() const { return size_; }
_ZNK5immer6detail4rbts11regular_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5countEv:
  230|  7.45M|    count_t count() const { return index(size_ - 1) + 1; }
_ZNK5immer6detail4rbts11regular_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5indexEm:
  234|  25.6M|    count_t index(size_t idx) const { return (idx >> shift_) & mask<B>; }
_ZNK5immer6detail4rbts15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5countEv:
  784|  2.96M|    count_t count() const { return subindex(size_ - 1) + 1; }
_ZNK5immer6detail4rbts15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE8subindexEm:
  789|  2.98M|    count_t subindex(size_t idx) const { return idx >> shift_; }
_ZN5immer6detail4rbts22make_empty_regular_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEENS1_17empty_regular_posIT_EEPSE_:
   64|   445k|{
   65|   445k|    return {node};
   66|   445k|}
_ZN5immer6detail4rbts17empty_regular_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_11dec_visitorEJEEEDcT_DpOT0_:
   57|   445k|    {
   58|   445k|        return Visitor::visit_regular(*this, std::forward<Args>(args)...);
   59|   445k|    }
_ZNK5immer6detail4rbts17empty_regular_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE4nodeEv:
   41|   445k|    node_t* node() const { return node_; }
_ZN5immer6detail4rbts17make_leaf_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEENS1_12leaf_sub_posIT_EEPSE_j:
  151|  2.59M|{
  152|  2.59M|    assert(node);
  ------------------
  |  Branch (152:5): [True: 2.59M, False: 0]
  ------------------
  153|  2.59M|    assert(count <= branches<NodeT::bits_leaf>);
  ------------------
  |  Branch (153:5): [True: 2.59M, False: 0]
  ------------------
  154|  2.59M|    return {node, count};
  155|  2.59M|}
_ZN5immer6detail4rbts12leaf_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_11dec_visitorEJEEEDcT_DpOT0_:
  144|   517k|    {
  145|   517k|        return Visitor::visit_leaf(*this, std::forward<Args>(args)...);
  146|   517k|    }
_ZNK5immer6detail4rbts12leaf_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE4nodeEv:
  136|  1.71M|    node_t* node() const { return node_; }
_ZNK5immer6detail4rbts12leaf_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5countEv:
  135|  2.08M|    count_t count() const { return count_; }
_ZN5immer6detail4rbts19make_empty_leaf_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEENS1_14empty_leaf_posIT_EEPSE_:
   88|   389k|{
   89|   389k|    assert(node);
  ------------------
  |  Branch (89:5): [True: 389k, False: 0]
  ------------------
   90|   389k|    return {node};
   91|   389k|}
_ZN5immer6detail4rbts14empty_leaf_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_11dec_visitorEJEEEDcT_DpOT0_:
   81|   389k|    {
   82|   389k|        return Visitor::visit_leaf(*this, std::forward<Args>(args)...);
   83|   389k|    }
_ZNK5immer6detail4rbts14empty_leaf_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE4nodeEv:
   75|   389k|    node_t* node() const { return node_; }
_ZNK5immer6detail4rbts14empty_leaf_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5countEv:
   74|  10.4k|    count_t count() const { return 0; }
_ZN5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_17push_tail_visitorISC_EEJRPSC_RjEEEDcT_DpOT0_:
 1813|  49.4k|    {
 1814|  49.4k|        return Visitor::visit_relaxed(*this, std::forward<Args>(args)...);
 1815|  49.4k|    }
_ZNK5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5shiftEv:
 1433|  3.10M|    shift_t shift() const { return shift_; }
_ZNK5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE4sizeEj:
 1443|  2.69M|    {
 1444|  2.69M|        return size_sbh(offset, size_before(offset));
 1445|  2.69M|    }
_ZNK5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE8size_sbhEjm:
 1448|  2.80M|    {
 1449|  2.80M|        assert(size_before_hint == size_before(offset));
  ------------------
  |  Branch (1449:9): [True: 2.80M, False: 0]
  ------------------
 1450|  2.80M|        return relaxed_->d.sizes[offset] - size_before_hint;
 1451|  2.80M|    }
_ZNK5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE11size_beforeEj:
 1438|  5.82M|    {
 1439|  5.82M|        return offset ? relaxed_->d.sizes[offset - 1] : 0;
  ------------------
  |  Branch (1439:16): [True: 4.80M, False: 1.01M]
  ------------------
 1440|  5.82M|    }
_ZN5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE11last_oh_cshINS1_17push_tail_visitorISC_EEJRPSC_RjEEEDcT_jmDpOT0_:
 1737|  44.2k|    {
 1738|  44.2k|        assert(offset_hint == count() - 1);
  ------------------
  |  Branch (1738:9): [True: 44.2k, False: 0]
  ------------------
 1739|  44.2k|        assert(child_size_hint == size(offset_hint));
  ------------------
  |  Branch (1739:9): [True: 44.2k, False: 0]
  ------------------
 1740|  44.2k|        auto child   = node_->inner()[offset_hint];
 1741|  44.2k|        auto is_leaf = shift_ == BL;
 1742|  44.2k|        return is_leaf
  ------------------
  |  Branch (1742:16): [True: 0, False: 44.2k]
  ------------------
 1743|  44.2k|                   ? make_leaf_sub_pos(child, child_size_hint).visit(v, args...)
 1744|  44.2k|                   : visit_maybe_relaxed_sub(
 1745|  44.2k|                         child, shift_ - B, child_size_hint, v, args...);
 1746|  44.2k|    }
_ZN5immer6detail4rbts23visit_maybe_relaxed_subINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEENS1_17push_tail_visitorISC_EEJRPSC_RjEEEDcPT_jmT0_DpOT1_:
 1838|  44.2k|{
 1839|  44.2k|    assert(node);
  ------------------
  |  Branch (1839:5): [True: 44.2k, False: 0]
  ------------------
 1840|  44.2k|    auto relaxed = node->relaxed();
 1841|  44.2k|    if (relaxed) {
  ------------------
  |  Branch (1841:9): [True: 36.3k, False: 7.97k]
  ------------------
 1842|  36.3k|        assert(size == relaxed->d.sizes[relaxed->d.count - 1]);
  ------------------
  |  Branch (1842:9): [True: 36.3k, False: 0]
  ------------------
 1843|  36.3k|        return make_relaxed_pos(node, shift, relaxed)
 1844|  36.3k|            .visit(v, std::forward<Args>(args)...);
 1845|  36.3k|    } else {
 1846|  7.97k|        return make_regular_sub_pos(node, shift, size)
 1847|  7.97k|            .visit(v, std::forward<Args>(args)...);
 1848|  7.97k|    }
 1849|  44.2k|}
_ZN5immer6detail4rbts15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_17push_tail_visitorISC_EEJRPSC_RjEEEDcT_DpOT0_:
 1036|  7.97k|    {
 1037|  7.97k|        return Visitor::visit_regular(*this, std::forward<Args>(args)...);
 1038|  7.97k|    }
_ZNK5immer6detail4rbts15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5indexEm:
  788|  3.48M|    count_t index(size_t idx) const { return (idx >> shift_) & mask<B>; }
_ZN5immer6detail4rbts15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE7last_ohINS1_17push_tail_visitorISC_EEJRPSC_EEEDcT_jDpOT0_:
  952|  8.98k|    {
  953|  8.98k|        return last_oh_regular(*this, v, offset_hint, args...);
  954|  8.98k|    }
_ZN5immer6detail4rbts15last_oh_regularIRNS1_15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEENS1_17push_tail_visitorISD_EEJRPSD_EEEDcOT_T0_jDpOT1_:
  677|  8.98k|{
  678|  8.98k|    assert(offset_hint == p.count() - 1);
  ------------------
  |  Branch (678:5): [True: 8.98k, False: 0]
  ------------------
  679|  8.98k|    constexpr auto B  = bits<Pos>;
  680|  8.98k|    constexpr auto BL = bits_leaf<Pos>;
  681|  8.98k|    auto child        = p.node()->inner()[offset_hint];
  682|  8.98k|    auto is_leaf      = p.shift() == BL;
  683|  8.98k|    return is_leaf ? make_leaf_pos(child, p.size()).visit(v, args...)
  ------------------
  |  Branch (683:12): [True: 0, False: 8.98k]
  ------------------
  684|  8.98k|                   : make_regular_pos(child, p.shift() - B, p.size())
  685|  8.98k|                         .visit(v, args...);
  686|  8.98k|}
_ZN5immer6detail4rbts11regular_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_17push_tail_visitorISC_EEJRPSC_EEEDcT_DpOT0_:
  336|  30.6k|    {
  337|  30.6k|        return Visitor::visit_regular(*this, std::forward<Args>(args)...);
  338|  30.6k|    }
_ZN5immer6detail4rbts11regular_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE7last_ohINS1_17push_tail_visitorISC_EEJRPSC_EEEDcT_jDpOT0_:
  330|  21.6k|    {
  331|  21.6k|        return last_oh_regular(*this, v, offset_hint, args...);
  332|  21.6k|    }
_ZN5immer6detail4rbts15last_oh_regularIRNS1_11regular_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEENS1_17push_tail_visitorISD_EEJRPSD_EEEDcOT_T0_jDpOT1_:
  677|  21.6k|{
  678|  21.6k|    assert(offset_hint == p.count() - 1);
  ------------------
  |  Branch (678:5): [True: 21.6k, False: 0]
  ------------------
  679|  21.6k|    constexpr auto B  = bits<Pos>;
  680|  21.6k|    constexpr auto BL = bits_leaf<Pos>;
  681|  21.6k|    auto child        = p.node()->inner()[offset_hint];
  682|  21.6k|    auto is_leaf      = p.shift() == BL;
  683|  21.6k|    return is_leaf ? make_leaf_pos(child, p.size()).visit(v, args...)
  ------------------
  |  Branch (683:12): [True: 0, False: 21.6k]
  ------------------
  684|  21.6k|                   : make_regular_pos(child, p.shift() - B, p.size())
  685|  21.6k|                         .visit(v, args...);
  686|  21.6k|}
_ZNK5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE4sizeEv:
 1432|  4.83M|    size_t size() const { return relaxed_->d.sizes[relaxed_->d.count - 1]; }
_ZN5immer6detail4rbts15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_17push_tail_visitorISC_EEJRPSC_EEEDcT_DpOT0_:
 1036|  4.86k|    {
 1037|  4.86k|        return Visitor::visit_regular(*this, std::forward<Args>(args)...);
 1038|  4.86k|    }
flex-vector-gc.cpp:_ZN5immer6detail4rbts12leaf_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_14update_visitorISC_EEJmRZZ22LLVMFuzzerTestOneInputENK3$_5clI12fuzzer_inputEEDaRT_EUlSK_E_EEEDcSK_DpOT0_:
  144|    591|    {
  145|    591|        return Visitor::visit_leaf(*this, std::forward<Args>(args)...);
  146|    591|    }
_ZNK5immer6detail4rbts12leaf_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5indexEm:
  139|  37.3k|    count_t index(size_t idx) const { return idx & mask<BL>; }
flex-vector-gc.cpp:_ZN5immer6detail4rbts23visit_maybe_relaxed_subINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEENS1_14update_visitorISC_EEJRmRZZ22LLVMFuzzerTestOneInputENK3$_5clI12fuzzer_inputEEDaRT_EUlSJ_E_EEEDcPSJ_jmT0_DpOT1_:
 1838|  28.0k|{
 1839|  28.0k|    assert(node);
  ------------------
  |  Branch (1839:5): [True: 28.0k, False: 0]
  ------------------
 1840|  28.0k|    auto relaxed = node->relaxed();
 1841|  28.0k|    if (relaxed) {
  ------------------
  |  Branch (1841:9): [True: 26.0k, False: 1.93k]
  ------------------
 1842|  26.0k|        assert(size == relaxed->d.sizes[relaxed->d.count - 1]);
  ------------------
  |  Branch (1842:9): [True: 26.0k, False: 0]
  ------------------
 1843|  26.0k|        return make_relaxed_pos(node, shift, relaxed)
 1844|  26.0k|            .visit(v, std::forward<Args>(args)...);
 1845|  26.0k|    } else {
 1846|  1.93k|        return make_regular_sub_pos(node, shift, size)
 1847|  1.93k|            .visit(v, std::forward<Args>(args)...);
 1848|  1.93k|    }
 1849|  28.0k|}
flex-vector-gc.cpp:_ZN5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_14update_visitorISC_EEJRmRZZ22LLVMFuzzerTestOneInputENK3$_5clI12fuzzer_inputEEDaRT_EUlSL_E_EEEDcSL_DpOT0_:
 1813|  26.0k|    {
 1814|  26.0k|        return Visitor::visit_relaxed(*this, std::forward<Args>(args)...);
 1815|  26.0k|    }
_ZNK5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5indexEm:
 1454|   860k|    {
 1455|   860k|        auto offset = idx >> shift_;
 1456|  1.00M|        while (relaxed_->d.sizes[offset] <= idx)
  ------------------
  |  Branch (1456:16): [True: 147k, False: 860k]
  ------------------
 1457|   147k|            ++offset;
 1458|   860k|        return offset;
 1459|   860k|    }
_ZNK5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE7relaxedEv:
 1435|  26.0k|    relaxed_t* relaxed() const { return relaxed_; }
flex-vector-gc.cpp:_ZN5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE10towards_ohINS1_14update_visitorISC_EEJRZZ22LLVMFuzzerTestOneInputENK3$_5clI12fuzzer_inputEEDaRT_EUlSK_E_EEEDcSK_mjDpOT0_:
 1686|  26.0k|    {
 1687|  26.0k|        assert(offset_hint == index(idx));
  ------------------
  |  Branch (1687:9): [True: 26.0k, False: 0]
  ------------------
 1688|  26.0k|        auto left_size = offset_hint ? relaxed_->d.sizes[offset_hint - 1] : 0;
  ------------------
  |  Branch (1688:26): [True: 2.39k, False: 23.6k]
  ------------------
 1689|  26.0k|        return towards_oh_sbh(v, idx, offset_hint, left_size, args...);
 1690|  26.0k|    }
flex-vector-gc.cpp:_ZN5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE14towards_oh_sbhINS1_14update_visitorISC_EEJRZZ22LLVMFuzzerTestOneInputENK3$_5clI12fuzzer_inputEEDaRT_EUlSK_E_EEEDcSK_mjmDpOT0_:
 1698|  26.0k|    {
 1699|  26.0k|        return towards_sub_oh_sbh(v, idx, offset_hint, left_size_hint, args...);
 1700|  26.0k|    }
flex-vector-gc.cpp:_ZN5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE18towards_sub_oh_sbhINS1_14update_visitorISC_EEJRZZ22LLVMFuzzerTestOneInputENK3$_5clI12fuzzer_inputEEDaRT_EUlSK_E_EEEDcSK_mjmDpOT0_:
 1717|  26.0k|    {
 1718|  26.0k|        assert(offset_hint == index(idx));
  ------------------
  |  Branch (1718:9): [True: 26.0k, False: 0]
  ------------------
 1719|  26.0k|        assert(left_size_hint ==
  ------------------
  |  Branch (1719:9): [True: 2.39k, False: 23.6k]
  |  Branch (1719:9): [True: 26.0k, False: 0]
  ------------------
 1720|  26.0k|               (offset_hint ? relaxed_->d.sizes[offset_hint - 1] : 0));
 1721|  26.0k|        auto child     = node_->inner()[offset_hint];
 1722|  26.0k|        auto is_leaf   = shift_ == BL;
 1723|  26.0k|        auto next_size = relaxed_->d.sizes[offset_hint] - left_size_hint;
 1724|  26.0k|        auto next_idx  = idx - left_size_hint;
 1725|  26.0k|        return is_leaf
  ------------------
  |  Branch (1725:16): [True: 3.08k, False: 23.0k]
  ------------------
 1726|  26.0k|                   ? make_leaf_sub_pos(child, next_size)
 1727|  3.08k|                         .visit(v, next_idx, args...)
 1728|  26.0k|                   : visit_maybe_relaxed_sub(
 1729|  23.0k|                         child, shift_ - B, next_size, v, next_idx, args...);
 1730|  26.0k|    }
flex-vector-gc.cpp:_ZN5immer6detail4rbts12leaf_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_14update_visitorISC_EEJRmRZZ22LLVMFuzzerTestOneInputENK3$_5clI12fuzzer_inputEEDaRT_EUlSL_E_EEEDcSL_DpOT0_:
  144|  3.08k|    {
  145|  3.08k|        return Visitor::visit_leaf(*this, std::forward<Args>(args)...);
  146|  3.08k|    }
flex-vector-gc.cpp:_ZN5immer6detail4rbts15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_14update_visitorISC_EEJRmRZZ22LLVMFuzzerTestOneInputENK3$_5clI12fuzzer_inputEEDaRT_EUlSL_E_EEEDcSL_DpOT0_:
 1036|  1.93k|    {
 1037|  1.93k|        return Visitor::visit_regular(*this, std::forward<Args>(args)...);
 1038|  1.93k|    }
flex-vector-gc.cpp:_ZN5immer6detail4rbts15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE13towards_oh_chINS1_14update_visitorISC_EEJRZZ22LLVMFuzzerTestOneInputENK3$_5clI12fuzzer_inputEEDaRT_EUlSK_E_EEEDcSK_mjjDpOT0_:
  938|  1.93k|    {
  939|  1.93k|        return towards_oh_ch_regular(
  940|  1.93k|            *this, v, idx, offset_hint, count(), args...);
  941|  1.93k|    }
flex-vector-gc.cpp:_ZN5immer6detail4rbts21towards_oh_ch_regularIRNS1_15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEENS1_14update_visitorISD_EEJRZZ22LLVMFuzzerTestOneInputENK3$_5clI12fuzzer_inputEEDaRT_EUlSL_E_EEEDcOSL_T0_mjjDpOT1_:
  632|  1.93k|{
  633|  1.93k|    constexpr auto B  = bits<Pos>;
  634|  1.93k|    constexpr auto BL = bits_leaf<Pos>;
  635|  1.93k|    assert(offset_hint == p.index(idx));
  ------------------
  |  Branch (635:5): [True: 1.93k, False: 0]
  ------------------
  636|  1.93k|    assert(count_hint == p.count());
  ------------------
  |  Branch (636:5): [True: 1.93k, False: 0]
  ------------------
  637|  1.93k|    auto is_leaf = p.shift() == BL;
  638|  1.93k|    auto child   = p.node()->inner()[offset_hint];
  639|  1.93k|    auto is_full = offset_hint + 1 != count_hint;
  640|  1.93k|    return is_full
  ------------------
  |  Branch (640:12): [True: 913, False: 1.02k]
  ------------------
  641|  1.93k|               ? (is_leaf ? make_full_leaf_pos(child).visit(v, idx, args...)
  ------------------
  |  Branch (641:19): [True: 326, False: 587]
  ------------------
  642|    913|                          : make_full_pos(child, p.shift() - B)
  643|    587|                                .visit(v, idx, args...))
  644|  1.93k|               : (is_leaf
  ------------------
  |  Branch (644:19): [True: 248, False: 774]
  ------------------
  645|  1.02k|                      ? make_leaf_pos(child, p.size()).visit(v, idx, args...)
  646|  1.02k|                      : make_regular_pos(child, p.shift() - B, p.size())
  647|    774|                            .visit(v, idx, args...));
  648|  1.93k|}
flex-vector-gc.cpp:_ZN5immer6detail4rbts13full_leaf_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_14update_visitorISC_EEJRmRZZ22LLVMFuzzerTestOneInputENK3$_5clI12fuzzer_inputEEDaRT_EUlSL_E_EEEDcSL_DpOT0_:
  207|  1.35k|    {
  208|  1.35k|        return Visitor::visit_leaf(*this, std::forward<Args>(args)...);
  209|  1.35k|    }
_ZNK5immer6detail4rbts13full_leaf_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5indexEm:
  202|  29.5k|    count_t index(size_t idx) const { return idx & mask<BL>; }
flex-vector-gc.cpp:_ZN5immer6detail4rbts8full_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_14update_visitorISC_EEJRmRZZ22LLVMFuzzerTestOneInputENK3$_5clI12fuzzer_inputEEDaRT_EUlSL_E_EEEDcSL_DpOT0_:
 1405|  1.31k|    {
 1406|  1.31k|        return Visitor::visit_regular(*this, std::forward<Args>(args)...);
 1407|  1.31k|    }
_ZNK5immer6detail4rbts8full_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5indexEm:
 1162|  56.5k|    count_t index(size_t idx) const { return (idx >> shift_) & mask<B>; }
flex-vector-gc.cpp:_ZN5immer6detail4rbts8full_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE13towards_oh_chINS1_14update_visitorISC_EEJRZZ22LLVMFuzzerTestOneInputENK3$_5clI12fuzzer_inputEEDaRT_EUlSK_E_EEEDcSK_mjjDpOT0_:
 1329|  1.31k|    {
 1330|  1.31k|        return towards_oh(v, idx, offset_hint, args...);
 1331|  1.31k|    }
flex-vector-gc.cpp:_ZN5immer6detail4rbts8full_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE10towards_ohINS1_14update_visitorISC_EEJRZZ22LLVMFuzzerTestOneInputENK3$_5clI12fuzzer_inputEEDaRT_EUlSK_E_EEEDcSK_mjDpOT0_:
 1336|  1.31k|    {
 1337|  1.31k|        assert(offset_hint == index(idx));
  ------------------
  |  Branch (1337:9): [True: 1.31k, False: 0]
  ------------------
 1338|  1.31k|        auto is_leaf = shift_ == BL;
 1339|  1.31k|        auto child   = node_->inner()[offset_hint];
 1340|  1.31k|        return is_leaf
  ------------------
  |  Branch (1340:16): [True: 791, False: 526]
  ------------------
 1341|  1.31k|                   ? make_full_leaf_pos(child).visit(v, idx, args...)
 1342|  1.31k|                   : make_full_pos(child, shift_ - B).visit(v, idx, args...);
 1343|  1.31k|    }
flex-vector-gc.cpp:_ZN5immer6detail4rbts8leaf_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_14update_visitorISC_EEJRmRZZ22LLVMFuzzerTestOneInputENK3$_5clI12fuzzer_inputEEDaRT_EUlSL_E_EEEDcSL_DpOT0_:
  112|    579|    {
  113|    579|        return Visitor::visit_leaf(*this, std::forward<Args>(args)...);
  114|    579|    }
flex-vector-gc.cpp:_ZN5immer6detail4rbts11regular_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_14update_visitorISC_EEJRmRZZ22LLVMFuzzerTestOneInputENK3$_5clI12fuzzer_inputEEDaRT_EUlSL_E_EEEDcSL_DpOT0_:
  336|  1.17k|    {
  337|  1.17k|        return Visitor::visit_regular(*this, std::forward<Args>(args)...);
  338|  1.17k|    }
flex-vector-gc.cpp:_ZN5immer6detail4rbts11regular_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE13towards_oh_chINS1_14update_visitorISC_EEJRZZ22LLVMFuzzerTestOneInputENK3$_5clI12fuzzer_inputEEDaRT_EUlSK_E_EEEDcSK_mjjDpOT0_:
  316|  1.17k|    {
  317|  1.17k|        return towards_oh_ch_regular(
  318|  1.17k|            *this, v, idx, offset_hint, count(), args...);
  319|  1.17k|    }
flex-vector-gc.cpp:_ZN5immer6detail4rbts21towards_oh_ch_regularIRNS1_11regular_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEENS1_14update_visitorISD_EEJRZZ22LLVMFuzzerTestOneInputENK3$_5clI12fuzzer_inputEEDaRT_EUlSL_E_EEEDcOSL_T0_mjjDpOT1_:
  632|  1.17k|{
  633|  1.17k|    constexpr auto B  = bits<Pos>;
  634|  1.17k|    constexpr auto BL = bits_leaf<Pos>;
  635|  1.17k|    assert(offset_hint == p.index(idx));
  ------------------
  |  Branch (635:5): [True: 1.17k, False: 0]
  ------------------
  636|  1.17k|    assert(count_hint == p.count());
  ------------------
  |  Branch (636:5): [True: 1.17k, False: 0]
  ------------------
  637|  1.17k|    auto is_leaf = p.shift() == BL;
  638|  1.17k|    auto child   = p.node()->inner()[offset_hint];
  639|  1.17k|    auto is_full = offset_hint + 1 != count_hint;
  640|  1.17k|    return is_full
  ------------------
  |  Branch (640:12): [True: 443, False: 727]
  ------------------
  641|  1.17k|               ? (is_leaf ? make_full_leaf_pos(child).visit(v, idx, args...)
  ------------------
  |  Branch (641:19): [True: 239, False: 204]
  ------------------
  642|    443|                          : make_full_pos(child, p.shift() - B)
  643|    204|                                .visit(v, idx, args...))
  644|  1.17k|               : (is_leaf
  ------------------
  |  Branch (644:19): [True: 331, False: 396]
  ------------------
  645|    727|                      ? make_leaf_pos(child, p.size()).visit(v, idx, args...)
  646|    727|                      : make_regular_pos(child, p.shift() - B, p.size())
  647|    396|                            .visit(v, idx, args...));
  648|  1.17k|}
_ZN5immer6detail4rbts23visit_maybe_relaxed_subINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEENS1_19slice_right_visitorISC_Lb1EEEJRmEEEDcPT_jmT0_DpOT1_:
 1838|  21.8k|{
 1839|  21.8k|    assert(node);
  ------------------
  |  Branch (1839:5): [True: 21.8k, False: 0]
  ------------------
 1840|  21.8k|    auto relaxed = node->relaxed();
 1841|  21.8k|    if (relaxed) {
  ------------------
  |  Branch (1841:9): [True: 16.5k, False: 5.29k]
  ------------------
 1842|  16.5k|        assert(size == relaxed->d.sizes[relaxed->d.count - 1]);
  ------------------
  |  Branch (1842:9): [True: 16.5k, False: 0]
  ------------------
 1843|  16.5k|        return make_relaxed_pos(node, shift, relaxed)
 1844|  16.5k|            .visit(v, std::forward<Args>(args)...);
 1845|  16.5k|    } else {
 1846|  5.29k|        return make_regular_sub_pos(node, shift, size)
 1847|  5.29k|            .visit(v, std::forward<Args>(args)...);
 1848|  5.29k|    }
 1849|  21.8k|}
_ZN5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_19slice_right_visitorISC_Lb1EEEJRmEEEDcT_DpOT0_:
 1813|  16.5k|    {
 1814|  16.5k|        return Visitor::visit_relaxed(*this, std::forward<Args>(args)...);
 1815|  16.5k|    }
_ZN5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE10towards_ohINS1_19slice_right_visitorISC_Lb1EEEJEEEDcT_mjDpOT0_:
 1686|  12.2k|    {
 1687|  12.2k|        assert(offset_hint == index(idx));
  ------------------
  |  Branch (1687:9): [True: 12.2k, False: 0]
  ------------------
 1688|  12.2k|        auto left_size = offset_hint ? relaxed_->d.sizes[offset_hint - 1] : 0;
  ------------------
  |  Branch (1688:26): [True: 0, False: 12.2k]
  ------------------
 1689|  12.2k|        return towards_oh_sbh(v, idx, offset_hint, left_size, args...);
 1690|  12.2k|    }
_ZN5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE14towards_oh_sbhINS1_19slice_right_visitorISC_Lb1EEEJEEEDcT_mjmDpOT0_:
 1698|  12.2k|    {
 1699|  12.2k|        return towards_sub_oh_sbh(v, idx, offset_hint, left_size_hint, args...);
 1700|  12.2k|    }
_ZN5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE18towards_sub_oh_sbhINS1_19slice_right_visitorISC_Lb1EEEJEEEDcT_mjmDpOT0_:
 1717|  12.2k|    {
 1718|  12.2k|        assert(offset_hint == index(idx));
  ------------------
  |  Branch (1718:9): [True: 12.2k, False: 0]
  ------------------
 1719|  12.2k|        assert(left_size_hint ==
  ------------------
  |  Branch (1719:9): [True: 0, False: 12.2k]
  |  Branch (1719:9): [True: 12.2k, False: 0]
  ------------------
 1720|  12.2k|               (offset_hint ? relaxed_->d.sizes[offset_hint - 1] : 0));
 1721|  12.2k|        auto child     = node_->inner()[offset_hint];
 1722|  12.2k|        auto is_leaf   = shift_ == BL;
 1723|  12.2k|        auto next_size = relaxed_->d.sizes[offset_hint] - left_size_hint;
 1724|  12.2k|        auto next_idx  = idx - left_size_hint;
 1725|  12.2k|        return is_leaf
  ------------------
  |  Branch (1725:16): [True: 798, False: 11.4k]
  ------------------
 1726|  12.2k|                   ? make_leaf_sub_pos(child, next_size)
 1727|    798|                         .visit(v, next_idx, args...)
 1728|  12.2k|                   : visit_maybe_relaxed_sub(
 1729|  11.4k|                         child, shift_ - B, next_size, v, next_idx, args...);
 1730|  12.2k|    }
_ZN5immer6detail4rbts12leaf_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_19slice_right_visitorISC_Lb1EEEJRmEEEDcT_DpOT0_:
  144|    798|    {
  145|    798|        return Visitor::visit_leaf(*this, std::forward<Args>(args)...);
  146|    798|    }
_ZN5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE10towards_ohINS1_19slice_right_visitorISC_Lb0EEEJEEEDcT_mjDpOT0_:
 1686|  8.34k|    {
 1687|  8.34k|        assert(offset_hint == index(idx));
  ------------------
  |  Branch (1687:9): [True: 8.34k, False: 0]
  ------------------
 1688|  8.34k|        auto left_size = offset_hint ? relaxed_->d.sizes[offset_hint - 1] : 0;
  ------------------
  |  Branch (1688:26): [True: 6.07k, False: 2.27k]
  ------------------
 1689|  8.34k|        return towards_oh_sbh(v, idx, offset_hint, left_size, args...);
 1690|  8.34k|    }
_ZN5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE14towards_oh_sbhINS1_19slice_right_visitorISC_Lb0EEEJEEEDcT_mjmDpOT0_:
 1698|  8.34k|    {
 1699|  8.34k|        return towards_sub_oh_sbh(v, idx, offset_hint, left_size_hint, args...);
 1700|  8.34k|    }
_ZN5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE18towards_sub_oh_sbhINS1_19slice_right_visitorISC_Lb0EEEJEEEDcT_mjmDpOT0_:
 1717|  8.34k|    {
 1718|  8.34k|        assert(offset_hint == index(idx));
  ------------------
  |  Branch (1718:9): [True: 8.34k, False: 0]
  ------------------
 1719|  8.34k|        assert(left_size_hint ==
  ------------------
  |  Branch (1719:9): [True: 6.07k, False: 2.27k]
  |  Branch (1719:9): [True: 8.34k, False: 0]
  ------------------
 1720|  8.34k|               (offset_hint ? relaxed_->d.sizes[offset_hint - 1] : 0));
 1721|  8.34k|        auto child     = node_->inner()[offset_hint];
 1722|  8.34k|        auto is_leaf   = shift_ == BL;
 1723|  8.34k|        auto next_size = relaxed_->d.sizes[offset_hint] - left_size_hint;
 1724|  8.34k|        auto next_idx  = idx - left_size_hint;
 1725|  8.34k|        return is_leaf
  ------------------
  |  Branch (1725:16): [True: 2.94k, False: 5.40k]
  ------------------
 1726|  8.34k|                   ? make_leaf_sub_pos(child, next_size)
 1727|  2.94k|                         .visit(v, next_idx, args...)
 1728|  8.34k|                   : visit_maybe_relaxed_sub(
 1729|  5.40k|                         child, shift_ - B, next_size, v, next_idx, args...);
 1730|  8.34k|    }
_ZN5immer6detail4rbts12leaf_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_19slice_right_visitorISC_Lb0EEEJRmEEEDcT_DpOT0_:
  144|  2.94k|    {
  145|  2.94k|        return Visitor::visit_leaf(*this, std::forward<Args>(args)...);
  146|  2.94k|    }
_ZN5immer6detail4rbts23visit_maybe_relaxed_subINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEENS1_19slice_right_visitorISC_Lb0EEEJRmEEEDcPT_jmT0_DpOT1_:
 1838|  5.40k|{
 1839|  5.40k|    assert(node);
  ------------------
  |  Branch (1839:5): [True: 5.40k, False: 0]
  ------------------
 1840|  5.40k|    auto relaxed = node->relaxed();
 1841|  5.40k|    if (relaxed) {
  ------------------
  |  Branch (1841:9): [True: 4.07k, False: 1.33k]
  ------------------
 1842|  4.07k|        assert(size == relaxed->d.sizes[relaxed->d.count - 1]);
  ------------------
  |  Branch (1842:9): [True: 4.07k, False: 0]
  ------------------
 1843|  4.07k|        return make_relaxed_pos(node, shift, relaxed)
 1844|  4.07k|            .visit(v, std::forward<Args>(args)...);
 1845|  4.07k|    } else {
 1846|  1.33k|        return make_regular_sub_pos(node, shift, size)
 1847|  1.33k|            .visit(v, std::forward<Args>(args)...);
 1848|  1.33k|    }
 1849|  5.40k|}
_ZN5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_19slice_right_visitorISC_Lb0EEEJRmEEEDcT_DpOT0_:
 1813|  4.07k|    {
 1814|  4.07k|        return Visitor::visit_relaxed(*this, std::forward<Args>(args)...);
 1815|  4.07k|    }
_ZN5immer6detail4rbts15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_19slice_right_visitorISC_Lb0EEEJRmEEEDcT_DpOT0_:
 1036|  1.33k|    {
 1037|  1.33k|        return Visitor::visit_regular(*this, std::forward<Args>(args)...);
 1038|  1.33k|    }
_ZN5immer6detail4rbts15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE10towards_ohINS1_19slice_right_visitorISC_Lb0EEEJEEEDcT_mjDpOT0_:
  927|  3.72k|    {
  928|  3.72k|        return towards_oh_ch_regular(
  929|  3.72k|            *this, v, idx, offset_hint, count(), args...);
  930|  3.72k|    }
_ZN5immer6detail4rbts21towards_oh_ch_regularIRNS1_15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEENS1_19slice_right_visitorISD_Lb0EEEJEEEDcOT_T0_mjjDpOT1_:
  632|  3.72k|{
  633|  3.72k|    constexpr auto B  = bits<Pos>;
  634|  3.72k|    constexpr auto BL = bits_leaf<Pos>;
  635|  3.72k|    assert(offset_hint == p.index(idx));
  ------------------
  |  Branch (635:5): [True: 3.72k, False: 0]
  ------------------
  636|  3.72k|    assert(count_hint == p.count());
  ------------------
  |  Branch (636:5): [True: 3.72k, False: 0]
  ------------------
  637|  3.72k|    auto is_leaf = p.shift() == BL;
  638|  3.72k|    auto child   = p.node()->inner()[offset_hint];
  639|  3.72k|    auto is_full = offset_hint + 1 != count_hint;
  640|  3.72k|    return is_full
  ------------------
  |  Branch (640:12): [True: 1.35k, False: 2.37k]
  ------------------
  641|  3.72k|               ? (is_leaf ? make_full_leaf_pos(child).visit(v, idx, args...)
  ------------------
  |  Branch (641:19): [True: 592, False: 763]
  ------------------
  642|  1.35k|                          : make_full_pos(child, p.shift() - B)
  643|    763|                                .visit(v, idx, args...))
  644|  3.72k|               : (is_leaf
  ------------------
  |  Branch (644:19): [True: 695, False: 1.67k]
  ------------------
  645|  2.37k|                      ? make_leaf_pos(child, p.size()).visit(v, idx, args...)
  646|  2.37k|                      : make_regular_pos(child, p.shift() - B, p.size())
  647|  1.67k|                            .visit(v, idx, args...));
  648|  3.72k|}
_ZN5immer6detail4rbts13full_leaf_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_19slice_right_visitorISC_Lb0EEEJRmEEEDcT_DpOT0_:
  207|  3.21k|    {
  208|  3.21k|        return Visitor::visit_leaf(*this, std::forward<Args>(args)...);
  209|  3.21k|    }
_ZN5immer6detail4rbts8full_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_19slice_right_visitorISC_Lb0EEEJRmEEEDcT_DpOT0_:
 1405|  2.18k|    {
 1406|  2.18k|        return Visitor::visit_regular(*this, std::forward<Args>(args)...);
 1407|  2.18k|    }
_ZN5immer6detail4rbts8full_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE10towards_ohINS1_19slice_right_visitorISC_Lb0EEEJEEEDcT_mjDpOT0_:
 1336|  3.35k|    {
 1337|  3.35k|        assert(offset_hint == index(idx));
  ------------------
  |  Branch (1337:9): [True: 3.35k, False: 0]
  ------------------
 1338|  3.35k|        auto is_leaf = shift_ == BL;
 1339|  3.35k|        auto child   = node_->inner()[offset_hint];
 1340|  3.35k|        return is_leaf
  ------------------
  |  Branch (1340:16): [True: 2.15k, False: 1.20k]
  ------------------
 1341|  3.35k|                   ? make_full_leaf_pos(child).visit(v, idx, args...)
 1342|  3.35k|                   : make_full_pos(child, shift_ - B).visit(v, idx, args...);
 1343|  3.35k|    }
_ZNK5immer6detail4rbts8full_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5shiftEv:
 1161|  51.5k|    shift_t shift() const { return shift_; }
_ZN5immer6detail4rbts8leaf_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_19slice_right_visitorISC_Lb0EEEJRmEEEDcT_DpOT0_:
  112|  1.68k|    {
  113|  1.68k|        return Visitor::visit_leaf(*this, std::forward<Args>(args)...);
  114|  1.68k|    }
_ZN5immer6detail4rbts11regular_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_19slice_right_visitorISC_Lb0EEEJRmEEEDcT_DpOT0_:
  336|  2.52k|    {
  337|  2.52k|        return Visitor::visit_regular(*this, std::forward<Args>(args)...);
  338|  2.52k|    }
_ZN5immer6detail4rbts11regular_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE10towards_ohINS1_19slice_right_visitorISC_Lb0EEEJEEEDcT_mjDpOT0_:
  305|  2.52k|    {
  306|  2.52k|        return towards_oh_ch_regular(
  307|  2.52k|            *this, v, idx, offset_hint, count(), args...);
  308|  2.52k|    }
_ZN5immer6detail4rbts21towards_oh_ch_regularIRNS1_11regular_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEENS1_19slice_right_visitorISD_Lb0EEEJEEEDcOT_T0_mjjDpOT1_:
  632|  2.52k|{
  633|  2.52k|    constexpr auto B  = bits<Pos>;
  634|  2.52k|    constexpr auto BL = bits_leaf<Pos>;
  635|  2.52k|    assert(offset_hint == p.index(idx));
  ------------------
  |  Branch (635:5): [True: 2.52k, False: 0]
  ------------------
  636|  2.52k|    assert(count_hint == p.count());
  ------------------
  |  Branch (636:5): [True: 2.52k, False: 0]
  ------------------
  637|  2.52k|    auto is_leaf = p.shift() == BL;
  638|  2.52k|    auto child   = p.node()->inner()[offset_hint];
  639|  2.52k|    auto is_full = offset_hint + 1 != count_hint;
  640|  2.52k|    return is_full
  ------------------
  |  Branch (640:12): [True: 685, False: 1.83k]
  ------------------
  641|  2.52k|               ? (is_leaf ? make_full_leaf_pos(child).visit(v, idx, args...)
  ------------------
  |  Branch (641:19): [True: 465, False: 220]
  ------------------
  642|    685|                          : make_full_pos(child, p.shift() - B)
  643|    220|                                .visit(v, idx, args...))
  644|  2.52k|               : (is_leaf
  ------------------
  |  Branch (644:19): [True: 994, False: 845]
  ------------------
  645|  1.83k|                      ? make_leaf_pos(child, p.size()).visit(v, idx, args...)
  646|  1.83k|                      : make_regular_pos(child, p.shift() - B, p.size())
  647|    845|                            .visit(v, idx, args...));
  648|  2.52k|}
_ZN5immer6detail4rbts15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_19slice_right_visitorISC_Lb1EEEJRmEEEDcT_DpOT0_:
 1036|  5.29k|    {
 1037|  5.29k|        return Visitor::visit_regular(*this, std::forward<Args>(args)...);
 1038|  5.29k|    }
_ZN5immer6detail4rbts15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE10towards_ohINS1_19slice_right_visitorISC_Lb1EEEJEEEDcT_mjDpOT0_:
  927|  2.89k|    {
  928|  2.89k|        return towards_oh_ch_regular(
  929|  2.89k|            *this, v, idx, offset_hint, count(), args...);
  930|  2.89k|    }
_ZN5immer6detail4rbts21towards_oh_ch_regularIRNS1_15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEENS1_19slice_right_visitorISD_Lb1EEEJEEEDcOT_T0_mjjDpOT1_:
  632|  2.89k|{
  633|  2.89k|    constexpr auto B  = bits<Pos>;
  634|  2.89k|    constexpr auto BL = bits_leaf<Pos>;
  635|  2.89k|    assert(offset_hint == p.index(idx));
  ------------------
  |  Branch (635:5): [True: 2.89k, False: 0]
  ------------------
  636|  2.89k|    assert(count_hint == p.count());
  ------------------
  |  Branch (636:5): [True: 2.89k, False: 0]
  ------------------
  637|  2.89k|    auto is_leaf = p.shift() == BL;
  638|  2.89k|    auto child   = p.node()->inner()[offset_hint];
  639|  2.89k|    auto is_full = offset_hint + 1 != count_hint;
  640|  2.89k|    return is_full
  ------------------
  |  Branch (640:12): [True: 2.47k, False: 425]
  ------------------
  641|  2.89k|               ? (is_leaf ? make_full_leaf_pos(child).visit(v, idx, args...)
  ------------------
  |  Branch (641:19): [True: 799, False: 1.67k]
  ------------------
  642|  2.47k|                          : make_full_pos(child, p.shift() - B)
  643|  1.67k|                                .visit(v, idx, args...))
  644|  2.89k|               : (is_leaf
  ------------------
  |  Branch (644:19): [True: 425, False: 0]
  ------------------
  645|    425|                      ? make_leaf_pos(child, p.size()).visit(v, idx, args...)
  646|    425|                      : make_regular_pos(child, p.shift() - B, p.size())
  647|      0|                            .visit(v, idx, args...));
  648|  2.89k|}
_ZN5immer6detail4rbts13full_leaf_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_19slice_right_visitorISC_Lb1EEEJRmEEEDcT_DpOT0_:
  207|  1.30k|    {
  208|  1.30k|        return Visitor::visit_leaf(*this, std::forward<Args>(args)...);
  209|  1.30k|    }
_ZN5immer6detail4rbts8full_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_19slice_right_visitorISC_Lb1EEEJRmEEEDcT_DpOT0_:
 1405|  2.02k|    {
 1406|  2.02k|        return Visitor::visit_regular(*this, std::forward<Args>(args)...);
 1407|  2.02k|    }
_ZN5immer6detail4rbts8full_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE10towards_ohINS1_19slice_right_visitorISC_Lb1EEEJEEEDcT_mjDpOT0_:
 1336|    853|    {
 1337|    853|        assert(offset_hint == index(idx));
  ------------------
  |  Branch (1337:9): [True: 853, False: 0]
  ------------------
 1338|    853|        auto is_leaf = shift_ == BL;
 1339|    853|        auto child   = node_->inner()[offset_hint];
 1340|    853|        return is_leaf
  ------------------
  |  Branch (1340:16): [True: 502, False: 351]
  ------------------
 1341|    853|                   ? make_full_leaf_pos(child).visit(v, idx, args...)
 1342|    853|                   : make_full_pos(child, shift_ - B).visit(v, idx, args...);
 1343|    853|    }
_ZN5immer6detail4rbts8leaf_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_19slice_right_visitorISC_Lb1EEEJRmEEEDcT_DpOT0_:
  112|    425|    {
  113|    425|        return Visitor::visit_leaf(*this, std::forward<Args>(args)...);
  114|    425|    }
_ZN5immer6detail4rbts23visit_maybe_relaxed_subINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEENS1_18slice_left_visitorISC_Lb1EEEJRmEEEDcPT_jmT0_DpOT1_:
 1838|  17.1k|{
 1839|  17.1k|    assert(node);
  ------------------
  |  Branch (1839:5): [True: 17.1k, False: 0]
  ------------------
 1840|  17.1k|    auto relaxed = node->relaxed();
 1841|  17.1k|    if (relaxed) {
  ------------------
  |  Branch (1841:9): [True: 14.6k, False: 2.49k]
  ------------------
 1842|  14.6k|        assert(size == relaxed->d.sizes[relaxed->d.count - 1]);
  ------------------
  |  Branch (1842:9): [True: 14.6k, False: 0]
  ------------------
 1843|  14.6k|        return make_relaxed_pos(node, shift, relaxed)
 1844|  14.6k|            .visit(v, std::forward<Args>(args)...);
 1845|  14.6k|    } else {
 1846|  2.49k|        return make_regular_sub_pos(node, shift, size)
 1847|  2.49k|            .visit(v, std::forward<Args>(args)...);
 1848|  2.49k|    }
 1849|  17.1k|}
_ZN5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_18slice_left_visitorISC_Lb1EEEJRmEEEDcT_DpOT0_:
 1813|  14.6k|    {
 1814|  14.6k|        return Visitor::visit_relaxed(*this, std::forward<Args>(args)...);
 1815|  14.6k|    }
_ZNK5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE8subindexEm:
 1434|   106k|    count_t subindex(size_t idx) const { return index(idx); }
_ZN5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE14towards_sub_ohINS1_18slice_left_visitorISC_Lb1EEEJEEEDcT_mjDpOT0_:
 1705|  1.37k|    {
 1706|  1.37k|        assert(offset_hint == index(idx));
  ------------------
  |  Branch (1706:9): [True: 1.37k, False: 0]
  ------------------
 1707|  1.37k|        auto left_size = offset_hint ? relaxed_->d.sizes[offset_hint - 1] : 0;
  ------------------
  |  Branch (1707:26): [True: 864, False: 513]
  ------------------
 1708|  1.37k|        return towards_sub_oh_sbh(v, idx, offset_hint, left_size, args...);
 1709|  1.37k|    }
_ZN5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE18towards_sub_oh_sbhINS1_18slice_left_visitorISC_Lb1EEEJEEEDcT_mjmDpOT0_:
 1717|  1.37k|    {
 1718|  1.37k|        assert(offset_hint == index(idx));
  ------------------
  |  Branch (1718:9): [True: 1.37k, False: 0]
  ------------------
 1719|  1.37k|        assert(left_size_hint ==
  ------------------
  |  Branch (1719:9): [True: 864, False: 513]
  |  Branch (1719:9): [True: 1.37k, False: 0]
  ------------------
 1720|  1.37k|               (offset_hint ? relaxed_->d.sizes[offset_hint - 1] : 0));
 1721|  1.37k|        auto child     = node_->inner()[offset_hint];
 1722|  1.37k|        auto is_leaf   = shift_ == BL;
 1723|  1.37k|        auto next_size = relaxed_->d.sizes[offset_hint] - left_size_hint;
 1724|  1.37k|        auto next_idx  = idx - left_size_hint;
 1725|  1.37k|        return is_leaf
  ------------------
  |  Branch (1725:16): [True: 0, False: 1.37k]
  ------------------
 1726|  1.37k|                   ? make_leaf_sub_pos(child, next_size)
 1727|      0|                         .visit(v, next_idx, args...)
 1728|  1.37k|                   : visit_maybe_relaxed_sub(
 1729|  1.37k|                         child, shift_ - B, next_size, v, next_idx, args...);
 1730|  1.37k|    }
_ZN5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE14towards_sub_ohINS1_18slice_left_visitorISC_Lb0EEEJEEEDcT_mjDpOT0_:
 1705|   105k|    {
 1706|   105k|        assert(offset_hint == index(idx));
  ------------------
  |  Branch (1706:9): [True: 105k, False: 0]
  ------------------
 1707|   105k|        auto left_size = offset_hint ? relaxed_->d.sizes[offset_hint - 1] : 0;
  ------------------
  |  Branch (1707:26): [True: 19.6k, False: 85.5k]
  ------------------
 1708|   105k|        return towards_sub_oh_sbh(v, idx, offset_hint, left_size, args...);
 1709|   105k|    }
_ZN5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE18towards_sub_oh_sbhINS1_18slice_left_visitorISC_Lb0EEEJEEEDcT_mjmDpOT0_:
 1717|   105k|    {
 1718|   105k|        assert(offset_hint == index(idx));
  ------------------
  |  Branch (1718:9): [True: 105k, False: 0]
  ------------------
 1719|   105k|        assert(left_size_hint ==
  ------------------
  |  Branch (1719:9): [True: 19.6k, False: 85.5k]
  |  Branch (1719:9): [True: 105k, False: 0]
  ------------------
 1720|   105k|               (offset_hint ? relaxed_->d.sizes[offset_hint - 1] : 0));
 1721|   105k|        auto child     = node_->inner()[offset_hint];
 1722|   105k|        auto is_leaf   = shift_ == BL;
 1723|   105k|        auto next_size = relaxed_->d.sizes[offset_hint] - left_size_hint;
 1724|   105k|        auto next_idx  = idx - left_size_hint;
 1725|   105k|        return is_leaf
  ------------------
  |  Branch (1725:16): [True: 11.7k, False: 93.5k]
  ------------------
 1726|   105k|                   ? make_leaf_sub_pos(child, next_size)
 1727|  11.7k|                         .visit(v, next_idx, args...)
 1728|   105k|                   : visit_maybe_relaxed_sub(
 1729|  93.5k|                         child, shift_ - B, next_size, v, next_idx, args...);
 1730|   105k|    }
_ZN5immer6detail4rbts12leaf_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_18slice_left_visitorISC_Lb0EEEJRmEEEDcT_DpOT0_:
  144|  11.7k|    {
  145|  11.7k|        return Visitor::visit_leaf(*this, std::forward<Args>(args)...);
  146|  11.7k|    }
_ZN5immer6detail4rbts23visit_maybe_relaxed_subINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEENS1_18slice_left_visitorISC_Lb0EEEJRmEEEDcPT_jmT0_DpOT1_:
 1838|  93.5k|{
 1839|  93.5k|    assert(node);
  ------------------
  |  Branch (1839:5): [True: 93.5k, False: 0]
  ------------------
 1840|  93.5k|    auto relaxed = node->relaxed();
 1841|  93.5k|    if (relaxed) {
  ------------------
  |  Branch (1841:9): [True: 92.0k, False: 1.47k]
  ------------------
 1842|  92.0k|        assert(size == relaxed->d.sizes[relaxed->d.count - 1]);
  ------------------
  |  Branch (1842:9): [True: 92.0k, False: 0]
  ------------------
 1843|  92.0k|        return make_relaxed_pos(node, shift, relaxed)
 1844|  92.0k|            .visit(v, std::forward<Args>(args)...);
 1845|  92.0k|    } else {
 1846|  1.47k|        return make_regular_sub_pos(node, shift, size)
 1847|  1.47k|            .visit(v, std::forward<Args>(args)...);
 1848|  1.47k|    }
 1849|  93.5k|}
_ZN5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_18slice_left_visitorISC_Lb0EEEJRmEEEDcT_DpOT0_:
 1813|  92.0k|    {
 1814|  92.0k|        return Visitor::visit_relaxed(*this, std::forward<Args>(args)...);
 1815|  92.0k|    }
_ZN5immer6detail4rbts15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_18slice_left_visitorISC_Lb0EEEJRmEEEDcT_DpOT0_:
 1036|  1.47k|    {
 1037|  1.47k|        return Visitor::visit_regular(*this, std::forward<Args>(args)...);
 1038|  1.47k|    }
_ZNK5immer6detail4rbts15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE11size_beforeEj:
  791|  12.9k|    {
  792|  12.9k|        return size_t{offset} << shift_;
  793|  12.9k|    }
_ZN5immer6detail4rbts15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE8size_sbhEjm:
  803|  4.33k|    {
  804|  4.33k|        assert(size_before_hint == size_before(offset));
  ------------------
  |  Branch (804:9): [True: 4.33k, False: 0]
  ------------------
  805|  4.33k|        return offset == subindex(size_ - 1) ? size_ - size_before_hint
  ------------------
  |  Branch (805:16): [True: 2.18k, False: 2.14k]
  ------------------
  806|  4.33k|                                             : size_t{1} << shift_;
  807|  4.33k|    }
_ZN5immer6detail4rbts15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE14towards_sub_ohINS1_18slice_left_visitorISC_Lb0EEEJEEEDcT_mjDpOT0_:
  946|  3.02k|    {
  947|  3.02k|        return towards_sub_oh_regular(*this, v, idx, offset_hint, args...);
  948|  3.02k|    }
_ZN5immer6detail4rbts22towards_sub_oh_regularIRNS1_15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEENS1_18slice_left_visitorISD_Lb0EEEJEEEDcOT_T0_mjDpOT1_:
  653|  3.02k|{
  654|  3.02k|    constexpr auto B  = bits<Pos>;
  655|  3.02k|    constexpr auto BL = bits_leaf<Pos>;
  656|  3.02k|    assert(offset_hint == p.index(idx));
  ------------------
  |  Branch (656:5): [True: 3.02k, False: 0]
  ------------------
  657|  3.02k|    auto is_leaf = p.shift() == BL;
  658|  3.02k|    auto child   = p.node()->inner()[offset_hint];
  659|  3.02k|    auto lsize   = offset_hint << p.shift();
  660|  3.02k|    auto size    = p.this_size();
  661|  3.02k|    auto is_full = (size - lsize) >= (size_t{1} << p.shift());
  662|  3.02k|    return is_full
  ------------------
  |  Branch (662:12): [True: 3.02k, False: 0]
  ------------------
  663|  3.02k|               ? (is_leaf
  ------------------
  |  Branch (663:19): [True: 1.93k, False: 1.08k]
  ------------------
  664|  3.02k|                      ? make_full_leaf_pos(child).visit(v, idx - lsize, args...)
  665|  3.02k|                      : make_full_pos(child, p.shift() - B)
  666|  1.08k|                            .visit(v, idx - lsize, args...))
  667|  3.02k|               : (is_leaf
  ------------------
  |  Branch (667:19): [True: 0, False: 0]
  ------------------
  668|      0|                      ? make_leaf_sub_pos(child, size - lsize)
  669|      0|                            .visit(v, idx - lsize, args...)
  670|      0|                      : make_regular_sub_pos(child, p.shift() - B, size - lsize)
  671|      0|                            .visit(v, idx - lsize, args...));
  672|  3.02k|}
_ZNK5immer6detail4rbts15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE9this_sizeEv:
  794|  4.33k|    size_t this_size() const { return size_; }
_ZN5immer6detail4rbts13full_leaf_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_18slice_left_visitorISC_Lb0EEEJmEEEDcT_DpOT0_:
  207|  3.97k|    {
  208|  3.97k|        return Visitor::visit_leaf(*this, std::forward<Args>(args)...);
  209|  3.97k|    }
_ZN5immer6detail4rbts8full_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_18slice_left_visitorISC_Lb0EEEJmEEEDcT_DpOT0_:
 1405|  2.33k|    {
 1406|  2.33k|        return Visitor::visit_regular(*this, std::forward<Args>(args)...);
 1407|  2.33k|    }
_ZNK5immer6detail4rbts8full_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE8subindexEm:
 1163|  3.56k|    count_t subindex(size_t idx) const { return idx >> shift_; }
_ZNK5immer6detail4rbts8full_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE11size_beforeEj:
 1170|  3.56k|    {
 1171|  3.56k|        return size_t{offset} << shift_;
 1172|  3.56k|    }
_ZNK5immer6detail4rbts8full_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE8size_sbhEjm:
 1166|  3.56k|    {
 1167|  3.56k|        return size_t{1} << shift_;
 1168|  3.56k|    }
_ZN5immer6detail4rbts8full_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE14towards_sub_ohINS1_18slice_left_visitorISC_Lb0EEEJEEEDcT_mjDpOT0_:
 1348|  3.28k|    {
 1349|  3.28k|        assert(offset_hint == index(idx));
  ------------------
  |  Branch (1349:9): [True: 3.28k, False: 0]
  ------------------
 1350|  3.28k|        auto is_leaf = shift_ == BL;
 1351|  3.28k|        auto child   = node_->inner()[offset_hint];
 1352|  3.28k|        auto lsize   = size_t{offset_hint} << shift_;
 1353|  3.28k|        return is_leaf
  ------------------
  |  Branch (1353:16): [True: 2.03k, False: 1.24k]
  ------------------
 1354|  3.28k|                   ? make_full_leaf_pos(child).visit(v, idx - lsize, args...)
 1355|  3.28k|                   : make_full_pos(child, shift_ - B)
 1356|  1.24k|                         .visit(v, idx - lsize, args...);
 1357|  3.28k|    }
_ZN5immer6detail4rbts8full_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE10copy_sizesEjjmPm:
 1175|  3.28k|    {
 1176|  3.28k|        auto e = sizes + n;
 1177|  8.82k|        for (; sizes != e; ++sizes) {
  ------------------
  |  Branch (1177:16): [True: 5.54k, False: 3.28k]
  ------------------
 1178|  5.54k|            init = *sizes = init + (size_t{1} << shift_);
 1179|       |            assert(init);
  ------------------
  |  Branch (1179:13): [True: 5.54k, False: 0]
  ------------------
 1180|  5.54k|        }
 1181|  3.28k|    }
_ZNK5immer6detail4rbts8full_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE4sizeEv:
 1160|   214k|    size_t size() const { return branches<B, size_t> << shift_; }
_ZN5immer6detail4rbts15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE10copy_sizesEjjmPm:
  810|  7.25k|    {
  811|  7.25k|        if (n) {
  ------------------
  |  Branch (811:13): [True: 6.37k, False: 881]
  ------------------
  812|  6.37k|            auto last = offset + n - 1;
  813|  6.37k|            auto e    = sizes + n - 1;
  814|  12.7k|            for (; sizes != e; ++sizes) {
  ------------------
  |  Branch (814:20): [True: 6.32k, False: 6.37k]
  ------------------
  815|  6.32k|                init = *sizes = init + (size_t{1} << shift_);
  816|  6.32k|                assert(init);
  ------------------
  |  Branch (816:17): [True: 6.32k, False: 0]
  ------------------
  817|  6.32k|            }
  818|  6.37k|            *sizes = init + size(last);
  819|       |            assert(*sizes);
  ------------------
  |  Branch (819:13): [True: 6.37k, False: 0]
  ------------------
  820|  6.37k|        }
  821|  7.25k|    }
_ZN5immer6detail4rbts15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE4sizeEj:
  797|  6.37k|    {
  798|  6.37k|        return offset == subindex(size_ - 1) ? size_ - size_before(offset)
  ------------------
  |  Branch (798:16): [True: 4.25k, False: 2.11k]
  ------------------
  799|  6.37k|                                             : size_t{1} << shift_;
  800|  6.37k|    }
_ZN5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE10copy_sizesEjjmPm:
 1462|   213k|    {
 1463|   213k|        auto e     = sizes + n;
 1464|   213k|        auto prev  = size_before(offset);
 1465|   213k|        auto these = relaxed_->d.sizes + offset;
 1466|   578k|        for (; sizes != e; ++sizes, ++these) {
  ------------------
  |  Branch (1466:16): [True: 365k, False: 213k]
  ------------------
 1467|   365k|            auto this_size = *these;
 1468|   365k|            init = *sizes = init + (this_size - prev);
 1469|   365k|            assert(init);
  ------------------
  |  Branch (1469:13): [True: 365k, False: 0]
  ------------------
 1470|   365k|            prev = this_size;
 1471|   365k|        }
 1472|   213k|    }
_ZN5immer6detail4rbts15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_18slice_left_visitorISC_Lb1EEEJRmEEEDcT_DpOT0_:
 1036|  2.49k|    {
 1037|  2.49k|        return Visitor::visit_regular(*this, std::forward<Args>(args)...);
 1038|  2.49k|    }
_ZN5immer6detail4rbts15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE14towards_sub_ohINS1_18slice_left_visitorISC_Lb1EEEJEEEDcT_mjDpOT0_:
  946|  1.30k|    {
  947|  1.30k|        return towards_sub_oh_regular(*this, v, idx, offset_hint, args...);
  948|  1.30k|    }
_ZN5immer6detail4rbts22towards_sub_oh_regularIRNS1_15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEENS1_18slice_left_visitorISD_Lb1EEEJEEEDcOT_T0_mjDpOT1_:
  653|  1.30k|{
  654|  1.30k|    constexpr auto B  = bits<Pos>;
  655|  1.30k|    constexpr auto BL = bits_leaf<Pos>;
  656|  1.30k|    assert(offset_hint == p.index(idx));
  ------------------
  |  Branch (656:5): [True: 1.30k, False: 0]
  ------------------
  657|  1.30k|    auto is_leaf = p.shift() == BL;
  658|  1.30k|    auto child   = p.node()->inner()[offset_hint];
  659|  1.30k|    auto lsize   = offset_hint << p.shift();
  660|  1.30k|    auto size    = p.this_size();
  661|  1.30k|    auto is_full = (size - lsize) >= (size_t{1} << p.shift());
  662|  1.30k|    return is_full
  ------------------
  |  Branch (662:12): [True: 952, False: 353]
  ------------------
  663|  1.30k|               ? (is_leaf
  ------------------
  |  Branch (663:19): [True: 0, False: 952]
  ------------------
  664|    952|                      ? make_full_leaf_pos(child).visit(v, idx - lsize, args...)
  665|    952|                      : make_full_pos(child, p.shift() - B)
  666|    952|                            .visit(v, idx - lsize, args...))
  667|  1.30k|               : (is_leaf
  ------------------
  |  Branch (667:19): [True: 0, False: 353]
  ------------------
  668|    353|                      ? make_leaf_sub_pos(child, size - lsize)
  669|      0|                            .visit(v, idx - lsize, args...)
  670|    353|                      : make_regular_sub_pos(child, p.shift() - B, size - lsize)
  671|    353|                            .visit(v, idx - lsize, args...));
  672|  1.30k|}
_ZN5immer6detail4rbts8full_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_18slice_left_visitorISC_Lb1EEEJmEEEDcT_DpOT0_:
 1405|  1.23k|    {
 1406|  1.23k|        return Visitor::visit_regular(*this, std::forward<Args>(args)...);
 1407|  1.23k|    }
_ZN5immer6detail4rbts8full_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE14towards_sub_ohINS1_18slice_left_visitorISC_Lb1EEEJEEEDcT_mjDpOT0_:
 1348|    278|    {
 1349|    278|        assert(offset_hint == index(idx));
  ------------------
  |  Branch (1349:9): [True: 278, False: 0]
  ------------------
 1350|    278|        auto is_leaf = shift_ == BL;
 1351|    278|        auto child   = node_->inner()[offset_hint];
 1352|    278|        auto lsize   = size_t{offset_hint} << shift_;
 1353|    278|        return is_leaf
  ------------------
  |  Branch (1353:16): [True: 0, False: 278]
  ------------------
 1354|    278|                   ? make_full_leaf_pos(child).visit(v, idx - lsize, args...)
 1355|    278|                   : make_full_pos(child, shift_ - B)
 1356|    278|                         .visit(v, idx - lsize, args...);
 1357|    278|    }
_ZN5immer6detail4rbts15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_18slice_left_visitorISC_Lb1EEEJmEEEDcT_DpOT0_:
 1036|    353|    {
 1037|    353|        return Visitor::visit_regular(*this, std::forward<Args>(args)...);
 1038|    353|    }
_ZN5immer6detail4rbts30make_singleton_regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEEDaPT_j:
  766|  10.4k|{
  767|  10.4k|    assert(leaf);
  ------------------
  |  Branch (767:5): [True: 10.4k, False: 0]
  ------------------
  768|  10.4k|    IMMER_ASSERT_TAGGED(leaf->kind() == NodeT::kind_t::leaf);
  ------------------
  |  |   68|  10.4k|#define IMMER_ASSERT_TAGGED(assertion) assert(assertion)
  ------------------
  |  Branch (768:5): [True: 10.4k, False: 0]
  ------------------
  769|  10.4k|    assert(count > 0);
  ------------------
  |  Branch (769:5): [True: 10.4k, False: 0]
  ------------------
  770|  10.4k|    return singleton_regular_sub_pos<NodeT>{leaf, count};
  771|  10.4k|}
_ZN5immer6detail4rbts25singleton_regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_25concat_trees_left_visitorISC_EEJNS1_14empty_leaf_posISC_EERPSC_RjRmEEEDcT_DpOT0_:
  759|  3.06k|    {
  760|  3.06k|        return Visitor::visit_regular(*this, std::forward<Args>(args)...);
  761|  3.06k|    }
_ZN5immer6detail4rbts23visit_maybe_relaxed_subINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEENS1_26concat_trees_right_visitorISC_EEJRNS1_25singleton_regular_sub_posISC_EERNS1_14empty_leaf_posISC_EEEEEDcPT_jmT0_DpOT1_:
 1838|  3.06k|{
 1839|  3.06k|    assert(node);
  ------------------
  |  Branch (1839:5): [True: 3.06k, False: 0]
  ------------------
 1840|  3.06k|    auto relaxed = node->relaxed();
 1841|  3.06k|    if (relaxed) {
  ------------------
  |  Branch (1841:9): [True: 1.78k, False: 1.28k]
  ------------------
 1842|  1.78k|        assert(size == relaxed->d.sizes[relaxed->d.count - 1]);
  ------------------
  |  Branch (1842:9): [True: 1.78k, False: 0]
  ------------------
 1843|  1.78k|        return make_relaxed_pos(node, shift, relaxed)
 1844|  1.78k|            .visit(v, std::forward<Args>(args)...);
 1845|  1.78k|    } else {
 1846|  1.28k|        return make_regular_sub_pos(node, shift, size)
 1847|  1.28k|            .visit(v, std::forward<Args>(args)...);
 1848|  1.28k|    }
 1849|  3.06k|}
_ZN5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_26concat_trees_right_visitorISC_EEJRNS1_25singleton_regular_sub_posISC_EERNS1_14empty_leaf_posISC_EEEEEDcT_DpOT0_:
 1813|  1.78k|    {
 1814|  1.78k|        return Visitor::visit_relaxed(*this, std::forward<Args>(args)...);
 1815|  1.78k|    }
_ZNK5immer6detail4rbts25singleton_regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5shiftEv:
  735|  32.6k|    shift_t shift() const { return BL; }
_ZN5immer6detail4rbts25singleton_regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE13each_left_subINS1_34concat_rebalance_plan_fill_visitorEJRNS1_21concat_rebalance_planILj2ELj2EEEEEEvT_DpOT0_:
  744|  10.4k|    {
  745|  10.4k|    }
_ZN5immer6detail4rbts12leaf_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_34concat_rebalance_plan_fill_visitorEJRNS1_21concat_rebalance_planILj2ELj2EEEEEEDcT_DpOT0_:
  144|   890k|    {
  145|   890k|        return Visitor::visit_leaf(*this, std::forward<Args>(args)...);
  146|   890k|    }
_ZN5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_34concat_rebalance_plan_fill_visitorEJRNS1_21concat_rebalance_planILj2ELj2EEEEEEDcT_DpOT0_:
 1813|  3.78M|    {
 1814|  3.78M|        return Visitor::visit_relaxed(*this, std::forward<Args>(args)...);
 1815|  3.78M|    }
_ZN5immer6detail4rbts12null_sub_pos14each_right_subINS1_34concat_rebalance_plan_fill_visitorEJRNS1_21concat_rebalance_planILj2ELj2EEEEEEvT_DpOT0_:
  707|   328k|    {
  708|   328k|    }
_ZN5immer6detail4rbts25singleton_regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE13each_left_subINS1_21concat_merger_visitorEJRNS1_13concat_mergerISC_EEEEEvT_DpOT0_:
  744|  3.06k|    {
  745|  3.06k|    }
_ZN5immer6detail4rbts12leaf_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_21concat_merger_visitorEJRNS1_13concat_mergerISC_EEEEEDcT_DpOT0_:
  144|   331k|    {
  145|   331k|        return Visitor::visit_leaf(*this, std::forward<Args>(args)...);
  146|   331k|    }
_ZNK5immer6detail4rbts12leaf_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE4sizeEv:
  137|   890k|    size_t size() const { return count_; }
_ZN5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_21concat_merger_visitorEJRNS1_13concat_mergerISC_EEEEEDcT_DpOT0_:
 1813|  1.34M|    {
 1814|  1.34M|        return Visitor::visit_relaxed(*this, std::forward<Args>(args)...);
 1815|  1.34M|    }
_ZN5immer6detail4rbts12null_sub_pos14each_right_subINS1_21concat_merger_visitorEJRNS1_13concat_mergerINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEEEEEvT_DpOT0_:
  707|  6.27k|    {
  708|  6.27k|    }
_ZN5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE9first_subINS1_20concat_right_visitorISC_EEJRNS1_25singleton_regular_sub_posISC_EERNS1_14empty_leaf_posISC_EEEEEDcT_DpOT0_:
 1762|  5.59k|    {
 1763|  5.59k|        auto child      = node_->inner()[0];
 1764|  5.59k|        auto child_size = relaxed_->d.sizes[0];
 1765|  5.59k|        auto is_leaf    = shift_ == BL;
 1766|  5.59k|        assert(child_size);
  ------------------
  |  Branch (1766:9): [True: 5.59k, False: 0]
  ------------------
 1767|  5.59k|        return is_leaf ? make_leaf_sub_pos(child, child_size).visit(v, args...)
  ------------------
  |  Branch (1767:16): [True: 0, False: 5.59k]
  ------------------
 1768|  5.59k|                       : visit_maybe_relaxed_sub(
 1769|  5.59k|                             child, shift_ - B, child_size, v, args...);
 1770|  5.59k|    }
_ZNK5immer6detail4rbts14empty_leaf_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5shiftEv:
   76|  10.4k|    shift_t shift() const { return 0; }
_ZNK5immer6detail4rbts12leaf_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5shiftEv:
  138|   580k|    shift_t shift() const { return 0; }
_ZNK5immer6detail4rbts25singleton_regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE4nodeEv:
  733|  7.40k|    node_t* node() const { return nullptr; }
_ZN5immer6detail4rbts23visit_maybe_relaxed_subINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEENS1_20concat_right_visitorISC_EEJRNS1_25singleton_regular_sub_posISC_EERNS1_14empty_leaf_posISC_EEEEEDcPT_jmT0_DpOT1_:
 1838|  5.59k|{
 1839|  5.59k|    assert(node);
  ------------------
  |  Branch (1839:5): [True: 5.59k, False: 0]
  ------------------
 1840|  5.59k|    auto relaxed = node->relaxed();
 1841|  5.59k|    if (relaxed) {
  ------------------
  |  Branch (1841:9): [True: 5.39k, False: 202]
  ------------------
 1842|  5.39k|        assert(size == relaxed->d.sizes[relaxed->d.count - 1]);
  ------------------
  |  Branch (1842:9): [True: 5.39k, False: 0]
  ------------------
 1843|  5.39k|        return make_relaxed_pos(node, shift, relaxed)
 1844|  5.39k|            .visit(v, std::forward<Args>(args)...);
 1845|  5.39k|    } else {
 1846|    202|        return make_regular_sub_pos(node, shift, size)
 1847|    202|            .visit(v, std::forward<Args>(args)...);
 1848|    202|    }
 1849|  5.59k|}
_ZN5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_20concat_right_visitorISC_EEJRNS1_25singleton_regular_sub_posISC_EERNS1_14empty_leaf_posISC_EEEEEDcT_DpOT0_:
 1813|  5.39k|    {
 1814|  5.39k|        return Visitor::visit_relaxed(*this, std::forward<Args>(args)...);
 1815|  5.39k|    }
_ZN5immer6detail4rbts15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_20concat_right_visitorISC_EEJRNS1_25singleton_regular_sub_posISC_EERNS1_14empty_leaf_posISC_EEEEEDcT_DpOT0_:
 1036|    202|    {
 1037|    202|        return Visitor::visit_regular(*this, std::forward<Args>(args)...);
 1038|    202|    }
_ZN5immer6detail4rbts15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE9first_subINS1_20concat_right_visitorISC_EEJRNS1_25singleton_regular_sub_posISC_EERNS1_14empty_leaf_posISC_EEEEEDcT_DpOT0_:
  970|    708|    {
  971|    708|        auto is_leaf = shift_ == BL;
  972|    708|        auto child   = node_->inner()[0];
  973|    708|        auto is_full = size_ >= (size_t{1} << shift_);
  974|    708|        return is_full
  ------------------
  |  Branch (974:16): [True: 708, False: 0]
  ------------------
  975|    708|                   ? (is_leaf
  ------------------
  |  Branch (975:23): [True: 0, False: 708]
  ------------------
  976|    708|                          ? make_full_leaf_pos(child).visit(v, args...)
  977|    708|                          : make_full_pos(child, shift_ - B).visit(v, args...))
  978|    708|                   : (is_leaf
  ------------------
  |  Branch (978:23): [True: 0, False: 0]
  ------------------
  979|      0|                          ? make_leaf_sub_pos(child, size_).visit(v, args...)
  980|      0|                          : make_regular_sub_pos(child, shift_ - B, size_)
  981|      0|                                .visit(v, args...));
  982|    708|    }
_ZNK5immer6detail4rbts13full_leaf_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5shiftEv:
  201|  48.8k|    shift_t shift() const { return 0; }
_ZN5immer6detail4rbts8full_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_20concat_right_visitorISC_EEJRNS1_25singleton_regular_sub_posISC_EERNS1_14empty_leaf_posISC_EEEEEDcT_DpOT0_:
 1405|  1.19k|    {
 1406|  1.19k|        return Visitor::visit_regular(*this, std::forward<Args>(args)...);
 1407|  1.19k|    }
_ZN5immer6detail4rbts8full_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE9first_subINS1_20concat_right_visitorISC_EEJRNS1_25singleton_regular_sub_posISC_EERNS1_14empty_leaf_posISC_EEEEEDcT_DpOT0_:
 1361|    485|    {
 1362|    485|        auto is_leaf = shift_ == BL;
 1363|    485|        auto child   = node_->inner()[0];
 1364|    485|        return is_leaf ? make_full_leaf_pos(child).visit(v, args...)
  ------------------
  |  Branch (1364:16): [True: 0, False: 485]
  ------------------
 1365|    485|                       : make_full_pos(child, shift_ - B).visit(v, args...);
 1366|    485|    }
_ZN5immer6detail4rbts12null_sub_pos13each_left_subINS1_34concat_rebalance_plan_fill_visitorEJRNS1_21concat_rebalance_planILj2ELj2EEEEEEvT_DpOT0_:
  711|  83.3k|    {
  712|  83.3k|    }
_ZN5immer6detail4rbts8full_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE14each_right_subINS1_34concat_rebalance_plan_fill_visitorEJRNS1_21concat_rebalance_planILj2ELj2EEEEEEvT_DpOT0_:
 1304|  30.2k|    {
 1305|  30.2k|        each_i(v, 1, branches<B>, args...);
 1306|  30.2k|    }
_ZN5immer6detail4rbts8full_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE6each_iINS1_34concat_rebalance_plan_fill_visitorEJRNS1_21concat_rebalance_planILj2ELj2EEEEEEvT_jjDpOT0_:
 1263|  30.2k|    {
 1264|  30.2k|        auto p = node_->inner() + i;
 1265|  30.2k|        auto e = node_->inner() + n;
 1266|  30.2k|        if (shift_ == BL) {
  ------------------
  |  Branch (1266:13): [True: 13.3k, False: 16.9k]
  ------------------
 1267|  53.4k|            for (; p != e; ++p) {
  ------------------
  |  Branch (1267:20): [True: 40.0k, False: 13.3k]
  ------------------
 1268|  40.0k|                IMMER_PREFETCH(p + 1);
 1269|  40.0k|                make_full_leaf_pos(*p).visit(v, args...);
 1270|  40.0k|            }
 1271|  16.9k|        } else {
 1272|  16.9k|            auto ss = shift_ - B;
 1273|  67.7k|            for (; p != e; ++p)
  ------------------
  |  Branch (1273:20): [True: 50.8k, False: 16.9k]
  ------------------
 1274|  50.8k|                make_full_pos(*p, ss).visit(v, args...);
 1275|  16.9k|        }
 1276|  30.2k|    }
_ZN5immer6detail4rbts13full_leaf_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_34concat_rebalance_plan_fill_visitorEJRNS1_21concat_rebalance_planILj2ELj2EEEEEEDcT_DpOT0_:
  207|   113k|    {
  208|   113k|        return Visitor::visit_leaf(*this, std::forward<Args>(args)...);
  209|   113k|    }
_ZN5immer6detail4rbts8full_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_34concat_rebalance_plan_fill_visitorEJRNS1_21concat_rebalance_planILj2ELj2EEEEEEDcT_DpOT0_:
 1405|   211k|    {
 1406|   211k|        return Visitor::visit_regular(*this, std::forward<Args>(args)...);
 1407|   211k|    }
_ZN5immer6detail4rbts12null_sub_pos13each_left_subINS1_21concat_merger_visitorEJRNS1_13concat_mergerINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEEEEEvT_DpOT0_:
  711|  12.0k|    {
  712|  12.0k|    }
_ZN5immer6detail4rbts8full_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE14each_right_subINS1_21concat_merger_visitorEJRNS1_13concat_mergerISC_EEEEEvT_DpOT0_:
 1304|  7.45k|    {
 1305|  7.45k|        each_i(v, 1, branches<B>, args...);
 1306|  7.45k|    }
_ZN5immer6detail4rbts8full_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE6each_iINS1_21concat_merger_visitorEJRNS1_13concat_mergerISC_EEEEEvT_jjDpOT0_:
 1263|  7.45k|    {
 1264|  7.45k|        auto p = node_->inner() + i;
 1265|  7.45k|        auto e = node_->inner() + n;
 1266|  7.45k|        if (shift_ == BL) {
  ------------------
  |  Branch (1266:13): [True: 4.24k, False: 3.20k]
  ------------------
 1267|  16.9k|            for (; p != e; ++p) {
  ------------------
  |  Branch (1267:20): [True: 12.7k, False: 4.24k]
  ------------------
 1268|  12.7k|                IMMER_PREFETCH(p + 1);
 1269|  12.7k|                make_full_leaf_pos(*p).visit(v, args...);
 1270|  12.7k|            }
 1271|  4.24k|        } else {
 1272|  3.20k|            auto ss = shift_ - B;
 1273|  12.8k|            for (; p != e; ++p)
  ------------------
  |  Branch (1273:20): [True: 9.61k, False: 3.20k]
  ------------------
 1274|  9.61k|                make_full_pos(*p, ss).visit(v, args...);
 1275|  3.20k|        }
 1276|  7.45k|    }
_ZN5immer6detail4rbts13full_leaf_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_21concat_merger_visitorEJRNS1_13concat_mergerISC_EEEEEDcT_DpOT0_:
  207|  22.3k|    {
  208|  22.3k|        return Visitor::visit_leaf(*this, std::forward<Args>(args)...);
  209|  22.3k|    }
_ZNK5immer6detail4rbts13full_leaf_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE4sizeEv:
  200|   113k|    size_t size() const { return branches<BL>; }
_ZN5immer6detail4rbts8full_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_21concat_merger_visitorEJRNS1_13concat_mergerISC_EEEEEDcT_DpOT0_:
 1405|  24.8k|    {
 1406|  24.8k|        return Visitor::visit_regular(*this, std::forward<Args>(args)...);
 1407|  24.8k|    }
_ZN5immer6detail4rbts25singleton_regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE8last_subINS1_19concat_both_visitorISC_EEJRNS1_14empty_leaf_posISC_EERNS1_8full_posISC_EEEEEDcT_DpOT0_:
  753|    708|    {
  754|    708|        return make_leaf_sub_pos(leaf_, count_).visit(v, args...);
  755|    708|    }
_ZN5immer6detail4rbts12leaf_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_19concat_both_visitorISC_EEJRNS1_14empty_leaf_posISC_EERNS1_8full_posISC_EEEEEDcT_DpOT0_:
  144|    708|    {
  145|    708|        return Visitor::visit_leaf(*this, std::forward<Args>(args)...);
  146|    708|    }
_ZN5immer6detail4rbts8full_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE14first_sub_leafINS1_20concat_right_visitorISC_EEJRNS1_12leaf_sub_posISC_EERNS1_14empty_leaf_posISC_EEEEEDcT_DpOT0_:
 1370|    708|    {
 1371|    708|        assert(shift_ == BL);
  ------------------
  |  Branch (1371:9): [True: 708, False: 0]
  ------------------
 1372|    708|        auto child = node_->inner()[0];
 1373|    708|        return make_full_leaf_pos(child).visit(v, args...);
 1374|    708|    }
_ZN5immer6detail4rbts13full_leaf_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_20concat_right_visitorISC_EEJRNS1_12leaf_sub_posISC_EERNS1_14empty_leaf_posISC_EEEEEDcT_DpOT0_:
  207|  1.48k|    {
  208|  1.48k|        return Visitor::visit_leaf(*this, std::forward<Args>(args)...);
  209|  1.48k|    }
_ZN5immer6detail4rbts15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE14each_right_subINS1_34concat_rebalance_plan_fill_visitorEJRNS1_21concat_rebalance_planILj2ELj2EEEEEEvT_DpOT0_:
  906|  48.8k|    {
  907|  48.8k|        if (count() > 1)
  ------------------
  |  Branch (907:13): [True: 21.0k, False: 27.8k]
  ------------------
  908|  21.0k|            each_right_sub_(v, 1, args...);
  909|  48.8k|    }
_ZN5immer6detail4rbts15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE15each_right_sub_INS1_34concat_rebalance_plan_fill_visitorEJRNS1_21concat_rebalance_planILj2ELj2EEEEEEvT_jDpOT0_:
  879|  21.0k|    {
  880|  21.0k|        auto last  = count() - 1;
  881|  21.0k|        auto lsize = size_ - (last << shift_);
  882|  21.0k|        auto n     = node()->inner() + i;
  883|  21.0k|        auto e     = node()->inner() + last;
  884|  21.0k|        if (shift() == BL) {
  ------------------
  |  Branch (884:13): [True: 7.69k, False: 13.3k]
  ------------------
  885|  15.8k|            for (; n != e; ++n) {
  ------------------
  |  Branch (885:20): [True: 8.13k, False: 7.69k]
  ------------------
  886|  8.13k|                IMMER_PREFETCH(n + 1);
  887|  8.13k|                make_full_leaf_pos(*n).visit(v, args...);
  888|  8.13k|            }
  889|  7.69k|            make_leaf_sub_pos(*n, lsize).visit(v, args...);
  890|  13.3k|        } else {
  891|  13.3k|            auto ss = shift_ - B;
  892|  23.7k|            for (; n != e; ++n)
  ------------------
  |  Branch (892:20): [True: 10.3k, False: 13.3k]
  ------------------
  893|  10.3k|                make_full_pos(*n, ss).visit(v, args...);
  894|  13.3k|            make_regular_sub_pos(*n, ss, lsize).visit(v, args...);
  895|  13.3k|        }
  896|  21.0k|    }
_ZN5immer6detail4rbts15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_34concat_rebalance_plan_fill_visitorEJRNS1_21concat_rebalance_planILj2ELj2EEEEEEDcT_DpOT0_:
 1036|   140k|    {
 1037|   140k|        return Visitor::visit_regular(*this, std::forward<Args>(args)...);
 1038|   140k|    }
_ZN5immer6detail4rbts15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE14each_right_subINS1_21concat_merger_visitorEJRNS1_13concat_mergerISC_EEEEEvT_DpOT0_:
  906|  10.2k|    {
  907|  10.2k|        if (count() > 1)
  ------------------
  |  Branch (907:13): [True: 6.36k, False: 3.87k]
  ------------------
  908|  6.36k|            each_right_sub_(v, 1, args...);
  909|  10.2k|    }
_ZN5immer6detail4rbts15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE15each_right_sub_INS1_21concat_merger_visitorEJRNS1_13concat_mergerISC_EEEEEvT_jDpOT0_:
  879|  6.36k|    {
  880|  6.36k|        auto last  = count() - 1;
  881|  6.36k|        auto lsize = size_ - (last << shift_);
  882|  6.36k|        auto n     = node()->inner() + i;
  883|  6.36k|        auto e     = node()->inner() + last;
  884|  6.36k|        if (shift() == BL) {
  ------------------
  |  Branch (884:13): [True: 2.11k, False: 4.24k]
  ------------------
  885|  4.46k|            for (; n != e; ++n) {
  ------------------
  |  Branch (885:20): [True: 2.34k, False: 2.11k]
  ------------------
  886|  2.34k|                IMMER_PREFETCH(n + 1);
  887|  2.34k|                make_full_leaf_pos(*n).visit(v, args...);
  888|  2.34k|            }
  889|  2.11k|            make_leaf_sub_pos(*n, lsize).visit(v, args...);
  890|  4.24k|        } else {
  891|  4.24k|            auto ss = shift_ - B;
  892|  6.24k|            for (; n != e; ++n)
  ------------------
  |  Branch (892:20): [True: 2.00k, False: 4.24k]
  ------------------
  893|  2.00k|                make_full_pos(*n, ss).visit(v, args...);
  894|  4.24k|            make_regular_sub_pos(*n, ss, lsize).visit(v, args...);
  895|  4.24k|        }
  896|  6.36k|    }
_ZN5immer6detail4rbts15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_21concat_merger_visitorEJRNS1_13concat_mergerISC_EEEEEDcT_DpOT0_:
 1036|  16.3k|    {
 1037|  16.3k|        return Visitor::visit_regular(*this, std::forward<Args>(args)...);
 1038|  16.3k|    }
_ZN5immer6detail4rbts25singleton_regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE8last_subINS1_19concat_both_visitorISC_EEJRNS1_14empty_leaf_posISC_EERNS1_15regular_sub_posISC_EEEEEDcT_DpOT0_:
  753|    779|    {
  754|    779|        return make_leaf_sub_pos(leaf_, count_).visit(v, args...);
  755|    779|    }
_ZN5immer6detail4rbts12leaf_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_19concat_both_visitorISC_EEJRNS1_14empty_leaf_posISC_EERNS1_15regular_sub_posISC_EEEEEDcT_DpOT0_:
  144|    779|    {
  145|    779|        return Visitor::visit_leaf(*this, std::forward<Args>(args)...);
  146|    779|    }
_ZN5immer6detail4rbts15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE14first_sub_leafINS1_20concat_right_visitorISC_EEJRNS1_12leaf_sub_posISC_EERNS1_14empty_leaf_posISC_EEEEEDcT_DpOT0_:
  986|    779|    {
  987|    779|        assert(shift_ == BL);
  ------------------
  |  Branch (987:9): [True: 779, False: 0]
  ------------------
  988|    779|        auto child   = node_->inner()[0];
  989|    779|        auto is_full = size_ >= branches<BL>;
  990|    779|        return is_full ? make_full_leaf_pos(child).visit(v, args...)
  ------------------
  |  Branch (990:16): [True: 779, False: 0]
  ------------------
  991|    779|                       : make_leaf_sub_pos(child, size_).visit(v, args...);
  992|    779|    }
_ZN5immer6detail4rbts12leaf_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_20concat_right_visitorISC_EEJRSD_RNS1_14empty_leaf_posISC_EEEEEDcT_DpOT0_:
  144|  1.57k|    {
  145|  1.57k|        return Visitor::visit_leaf(*this, std::forward<Args>(args)...);
  146|  1.57k|    }
_ZN5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE14each_right_subINS1_34concat_rebalance_plan_fill_visitorEJRNS1_21concat_rebalance_planILj2ELj2EEEEEEvT_DpOT0_:
 1647|   653k|    {
 1648|   653k|        each_right(v, 1, std::forward<Args>(args)...);
 1649|   653k|    }
_ZN5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE10each_rightINS1_34concat_rebalance_plan_fill_visitorEJRNS1_21concat_rebalance_planILj2ELj2EEEEEEvT_jDpOT0_:
 1653|   653k|    {
 1654|   653k|        assert(start > 0);
  ------------------
  |  Branch (1654:9): [True: 653k, False: 0]
  ------------------
 1655|   653k|        assert(start <= relaxed_->d.count);
  ------------------
  |  Branch (1655:9): [True: 653k, False: 0]
  ------------------
 1656|   653k|        auto s = relaxed_->d.sizes[start - 1];
 1657|   653k|        auto p = node_->inner();
 1658|   653k|        if (shift_ == BL) {
  ------------------
  |  Branch (1658:13): [True: 108k, False: 544k]
  ------------------
 1659|   369k|            for (auto i = start; i < relaxed_->d.count; ++i) {
  ------------------
  |  Branch (1659:34): [True: 260k, False: 108k]
  ------------------
 1660|   260k|                IMMER_PREFETCH(p + i + 1);
 1661|   260k|                make_leaf_sub_pos(p[i], relaxed_->d.sizes[i] - s)
 1662|   260k|                    .visit(v, args...);
 1663|   260k|                s = relaxed_->d.sizes[i];
 1664|   260k|                assert(s);
  ------------------
  |  Branch (1664:17): [True: 260k, False: 0]
  ------------------
 1665|   260k|            }
 1666|   544k|        } else {
 1667|   544k|            auto ss = shift_ - B;
 1668|  1.84M|            for (auto i = start; i < relaxed_->d.count; ++i) {
  ------------------
  |  Branch (1668:34): [True: 1.30M, False: 544k]
  ------------------
 1669|  1.30M|                visit_maybe_relaxed_sub(
 1670|  1.30M|                    p[i], ss, relaxed_->d.sizes[i] - s, v, args...);
 1671|  1.30M|                s = relaxed_->d.sizes[i];
 1672|       |                assert(s);
  ------------------
  |  Branch (1672:17): [True: 1.30M, False: 0]
  ------------------
 1673|  1.30M|            }
 1674|   544k|        }
 1675|   653k|    }
_ZN5immer6detail4rbts23visit_maybe_relaxed_subINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEENS1_34concat_rebalance_plan_fill_visitorEJRNS1_21concat_rebalance_planILj2ELj2EEEEEEDcPT_jmT0_DpOT1_:
 1838|  2.48M|{
 1839|  2.48M|    assert(node);
  ------------------
  |  Branch (1839:5): [True: 2.48M, False: 0]
  ------------------
 1840|  2.48M|    auto relaxed = node->relaxed();
 1841|  2.48M|    if (relaxed) {
  ------------------
  |  Branch (1841:9): [True: 2.36M, False: 126k]
  ------------------
 1842|  2.36M|        assert(size == relaxed->d.sizes[relaxed->d.count - 1]);
  ------------------
  |  Branch (1842:9): [True: 2.36M, False: 0]
  ------------------
 1843|  2.36M|        return make_relaxed_pos(node, shift, relaxed)
 1844|  2.36M|            .visit(v, std::forward<Args>(args)...);
 1845|  2.36M|    } else {
 1846|   126k|        return make_regular_sub_pos(node, shift, size)
 1847|   126k|            .visit(v, std::forward<Args>(args)...);
 1848|   126k|    }
 1849|  2.48M|}
_ZN5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE14each_right_subINS1_21concat_merger_visitorEJRNS1_13concat_mergerISC_EEEEEvT_DpOT0_:
 1647|   227k|    {
 1648|   227k|        each_right(v, 1, std::forward<Args>(args)...);
 1649|   227k|    }
_ZN5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE10each_rightINS1_21concat_merger_visitorEJRNS1_13concat_mergerISC_EEEEEvT_jDpOT0_:
 1653|   227k|    {
 1654|   227k|        assert(start > 0);
  ------------------
  |  Branch (1654:9): [True: 227k, False: 0]
  ------------------
 1655|   227k|        assert(start <= relaxed_->d.count);
  ------------------
  |  Branch (1655:9): [True: 227k, False: 0]
  ------------------
 1656|   227k|        auto s = relaxed_->d.sizes[start - 1];
 1657|   227k|        auto p = node_->inner();
 1658|   227k|        if (shift_ == BL) {
  ------------------
  |  Branch (1658:13): [True: 40.0k, False: 187k]
  ------------------
 1659|   151k|            for (auto i = start; i < relaxed_->d.count; ++i) {
  ------------------
  |  Branch (1659:34): [True: 110k, False: 40.0k]
  ------------------
 1660|   110k|                IMMER_PREFETCH(p + i + 1);
 1661|   110k|                make_leaf_sub_pos(p[i], relaxed_->d.sizes[i] - s)
 1662|   110k|                    .visit(v, args...);
 1663|   110k|                s = relaxed_->d.sizes[i];
 1664|   110k|                assert(s);
  ------------------
  |  Branch (1664:17): [True: 110k, False: 0]
  ------------------
 1665|   110k|            }
 1666|   187k|        } else {
 1667|   187k|            auto ss = shift_ - B;
 1668|   693k|            for (auto i = start; i < relaxed_->d.count; ++i) {
  ------------------
  |  Branch (1668:34): [True: 506k, False: 187k]
  ------------------
 1669|   506k|                visit_maybe_relaxed_sub(
 1670|   506k|                    p[i], ss, relaxed_->d.sizes[i] - s, v, args...);
 1671|   506k|                s = relaxed_->d.sizes[i];
 1672|       |                assert(s);
  ------------------
  |  Branch (1672:17): [True: 506k, False: 0]
  ------------------
 1673|   506k|            }
 1674|   187k|        }
 1675|   227k|    }
_ZN5immer6detail4rbts23visit_maybe_relaxed_subINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEENS1_21concat_merger_visitorEJRNS1_13concat_mergerISC_EEEEEDcPT_jmT0_DpOT1_:
 1838|   962k|{
 1839|   962k|    assert(node);
  ------------------
  |  Branch (1839:5): [True: 962k, False: 0]
  ------------------
 1840|   962k|    auto relaxed = node->relaxed();
 1841|   962k|    if (relaxed) {
  ------------------
  |  Branch (1841:9): [True: 950k, False: 12.1k]
  ------------------
 1842|   950k|        assert(size == relaxed->d.sizes[relaxed->d.count - 1]);
  ------------------
  |  Branch (1842:9): [True: 950k, False: 0]
  ------------------
 1843|   950k|        return make_relaxed_pos(node, shift, relaxed)
 1844|   950k|            .visit(v, std::forward<Args>(args)...);
 1845|   950k|    } else {
 1846|  12.1k|        return make_regular_sub_pos(node, shift, size)
 1847|  12.1k|            .visit(v, std::forward<Args>(args)...);
 1848|  12.1k|    }
 1849|   962k|}
_ZN5immer6detail4rbts25singleton_regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE8last_subINS1_19concat_both_visitorISC_EEJRNS1_14empty_leaf_posISC_EERNS1_11relaxed_posISC_EEEEEDcT_DpOT0_:
  753|  1.57k|    {
  754|  1.57k|        return make_leaf_sub_pos(leaf_, count_).visit(v, args...);
  755|  1.57k|    }
_ZN5immer6detail4rbts12leaf_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_19concat_both_visitorISC_EEJRNS1_14empty_leaf_posISC_EERNS1_11relaxed_posISC_EEEEEDcT_DpOT0_:
  144|  1.57k|    {
  145|  1.57k|        return Visitor::visit_leaf(*this, std::forward<Args>(args)...);
  146|  1.57k|    }
_ZN5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE14first_sub_leafINS1_20concat_right_visitorISC_EEJRNS1_12leaf_sub_posISC_EERNS1_14empty_leaf_posISC_EEEEEDcT_DpOT0_:
 1774|  1.57k|    {
 1775|  1.57k|        assert(shift_ == BL);
  ------------------
  |  Branch (1775:9): [True: 1.57k, False: 0]
  ------------------
 1776|  1.57k|        auto child      = node_->inner()[0];
 1777|  1.57k|        auto child_size = relaxed_->d.sizes[0];
 1778|  1.57k|        return make_leaf_sub_pos(child, child_size).visit(v, args...);
 1779|  1.57k|    }
_ZN5immer6detail4rbts15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_26concat_trees_right_visitorISC_EEJRNS1_25singleton_regular_sub_posISC_EERNS1_14empty_leaf_posISC_EEEEEDcT_DpOT0_:
 1036|  1.28k|    {
 1037|  1.28k|        return Visitor::visit_regular(*this, std::forward<Args>(args)...);
 1038|  1.28k|    }
_ZN5immer6detail4rbts23visit_maybe_relaxed_subINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEENS1_25concat_trees_left_visitorISC_EEJNS1_8leaf_posISC_EERPSC_RjRmEEEDcPT_jmT0_DpOT1_:
 1838|  47.2k|{
 1839|  47.2k|    assert(node);
  ------------------
  |  Branch (1839:5): [True: 47.2k, False: 0]
  ------------------
 1840|  47.2k|    auto relaxed = node->relaxed();
 1841|  47.2k|    if (relaxed) {
  ------------------
  |  Branch (1841:9): [True: 41.4k, False: 5.78k]
  ------------------
 1842|  41.4k|        assert(size == relaxed->d.sizes[relaxed->d.count - 1]);
  ------------------
  |  Branch (1842:9): [True: 41.4k, False: 0]
  ------------------
 1843|  41.4k|        return make_relaxed_pos(node, shift, relaxed)
 1844|  41.4k|            .visit(v, std::forward<Args>(args)...);
 1845|  41.4k|    } else {
 1846|  5.78k|        return make_regular_sub_pos(node, shift, size)
 1847|  5.78k|            .visit(v, std::forward<Args>(args)...);
 1848|  5.78k|    }
 1849|  47.2k|}
_ZN5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_25concat_trees_left_visitorISC_EEJNS1_8leaf_posISC_EERPSC_RjRmEEEDcT_DpOT0_:
 1813|  41.4k|    {
 1814|  41.4k|        return Visitor::visit_relaxed(*this, std::forward<Args>(args)...);
 1815|  41.4k|    }
_ZN5immer6detail4rbts23visit_maybe_relaxed_subINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEENS1_26concat_trees_right_visitorISC_EEJRNS1_11relaxed_posISC_EERNS1_8leaf_posISC_EEEEEDcPT_jmT0_DpOT1_:
 1838|  41.4k|{
 1839|  41.4k|    assert(node);
  ------------------
  |  Branch (1839:5): [True: 41.4k, False: 0]
  ------------------
 1840|  41.4k|    auto relaxed = node->relaxed();
 1841|  41.4k|    if (relaxed) {
  ------------------
  |  Branch (1841:9): [True: 38.7k, False: 2.66k]
  ------------------
 1842|  38.7k|        assert(size == relaxed->d.sizes[relaxed->d.count - 1]);
  ------------------
  |  Branch (1842:9): [True: 38.7k, False: 0]
  ------------------
 1843|  38.7k|        return make_relaxed_pos(node, shift, relaxed)
 1844|  38.7k|            .visit(v, std::forward<Args>(args)...);
 1845|  38.7k|    } else {
 1846|  2.66k|        return make_regular_sub_pos(node, shift, size)
 1847|  2.66k|            .visit(v, std::forward<Args>(args)...);
 1848|  2.66k|    }
 1849|  41.4k|}
_ZN5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_26concat_trees_right_visitorISC_EEJRSD_RNS1_8leaf_posISC_EEEEEDcT_DpOT0_:
 1813|  38.7k|    {
 1814|  38.7k|        return Visitor::visit_relaxed(*this, std::forward<Args>(args)...);
 1815|  38.7k|    }
_ZN5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE8last_subINS1_19concat_left_visitorISC_EEJRNS1_8leaf_posISC_EERSD_EEEDcT_DpOT0_:
 1750|  2.84k|    {
 1751|  2.84k|        auto offset     = relaxed_->d.count - 1;
 1752|  2.84k|        auto child      = node_->inner()[offset];
 1753|  2.84k|        auto child_size = size(offset);
 1754|  2.84k|        auto is_leaf    = shift_ == BL;
 1755|  2.84k|        return is_leaf ? make_leaf_sub_pos(child, child_size).visit(v, args...)
  ------------------
  |  Branch (1755:16): [True: 0, False: 2.84k]
  ------------------
 1756|  2.84k|                       : visit_maybe_relaxed_sub(
 1757|  2.84k|                             child, shift_ - B, child_size, v, args...);
 1758|  2.84k|    }
_ZN5immer6detail4rbts23visit_maybe_relaxed_subINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEENS1_19concat_left_visitorISC_EEJRNS1_8leaf_posISC_EERNS1_11relaxed_posISC_EEEEEDcPT_jmT0_DpOT1_:
 1838|  2.84k|{
 1839|  2.84k|    assert(node);
  ------------------
  |  Branch (1839:5): [True: 2.84k, False: 0]
  ------------------
 1840|  2.84k|    auto relaxed = node->relaxed();
 1841|  2.84k|    if (relaxed) {
  ------------------
  |  Branch (1841:9): [True: 2.51k, False: 331]
  ------------------
 1842|  2.51k|        assert(size == relaxed->d.sizes[relaxed->d.count - 1]);
  ------------------
  |  Branch (1842:9): [True: 2.51k, False: 0]
  ------------------
 1843|  2.51k|        return make_relaxed_pos(node, shift, relaxed)
 1844|  2.51k|            .visit(v, std::forward<Args>(args)...);
 1845|  2.51k|    } else {
 1846|    331|        return make_regular_sub_pos(node, shift, size)
 1847|    331|            .visit(v, std::forward<Args>(args)...);
 1848|    331|    }
 1849|  2.84k|}
_ZN5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_19concat_left_visitorISC_EEJRNS1_8leaf_posISC_EERSD_EEEDcT_DpOT0_:
 1813|  2.51k|    {
 1814|  2.51k|        return Visitor::visit_relaxed(*this, std::forward<Args>(args)...);
 1815|  2.51k|    }
_ZN5immer6detail4rbts15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_19concat_left_visitorISC_EEJRNS1_8leaf_posISC_EERNS1_11relaxed_posISC_EEEEEDcT_DpOT0_:
 1036|    799|    {
 1037|    799|        return Visitor::visit_regular(*this, std::forward<Args>(args)...);
 1038|    799|    }
_ZN5immer6detail4rbts15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE8last_subINS1_19concat_left_visitorISC_EEJRNS1_8leaf_posISC_EERNS1_11relaxed_posISC_EEEEEDcT_DpOT0_:
  958|    468|    {
  959|    468|        auto offset  = count() - 1;
  960|    468|        auto child   = node_->inner()[offset];
  961|    468|        auto is_leaf = shift_ == BL;
  962|    468|        auto lsize   = size_ - (size_t{offset} << shift_);
  963|    468|        return is_leaf ? make_leaf_sub_pos(child, lsize).visit(v, args...)
  ------------------
  |  Branch (963:16): [True: 0, False: 468]
  ------------------
  964|    468|                       : make_regular_sub_pos(child, shift_ - B, lsize)
  965|    468|                             .visit(v, args...);
  966|    468|    }
_ZN5immer6detail4rbts15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE13each_left_subINS1_34concat_rebalance_plan_fill_visitorEJRNS1_21concat_rebalance_planILj2ELj2EEEEEEvT_DpOT0_:
  913|   155k|    {
  914|   155k|        each_left(v, count() - 1, args...);
  915|   155k|    }
_ZN5immer6detail4rbts15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE9each_leftINS1_34concat_rebalance_plan_fill_visitorEJRNS1_21concat_rebalance_planILj2ELj2EEEEEEvT_jDpOT0_:
  873|   155k|    {
  874|   155k|        return each_left_regular(*this, v, last, args...);
  875|   155k|    }
_ZN5immer6detail4rbts17each_left_regularIRNS1_15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEENS1_34concat_rebalance_plan_fill_visitorEJRNS1_21concat_rebalance_planILj2ELj2EEEEEEvOT_T0_jDpOT1_:
  575|   155k|{
  576|   155k|    constexpr auto B  = bits<Pos>;
  577|   155k|    constexpr auto BL = bits_leaf<Pos>;
  578|   155k|    assert(last < p.count());
  ------------------
  |  Branch (578:5): [True: 155k, False: 0]
  ------------------
  579|   155k|    if (p.shift() == BL) {
  ------------------
  |  Branch (579:9): [True: 53.6k, False: 101k]
  ------------------
  580|  53.6k|        auto n = p.node()->inner();
  581|  53.6k|        auto e = n + last;
  582|   118k|        for (; n != e; ++n) {
  ------------------
  |  Branch (582:16): [True: 65.2k, False: 53.6k]
  ------------------
  583|  65.2k|            IMMER_PREFETCH(n + 1);
  584|  65.2k|            make_full_leaf_pos(*n).visit(v, args...);
  585|  65.2k|        }
  586|   101k|    } else {
  587|   101k|        auto n  = p.node()->inner();
  588|   101k|        auto e  = n + last;
  589|   101k|        auto ss = p.shift() - B;
  590|   251k|        for (; n != e; ++n)
  ------------------
  |  Branch (590:16): [True: 149k, False: 101k]
  ------------------
  591|   149k|            make_full_pos(*n, ss).visit(v, args...);
  592|   101k|    }
  593|   155k|}
_ZN5immer6detail4rbts15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE13each_left_subINS1_21concat_merger_visitorEJRNS1_13concat_mergerISC_EEEEEvT_DpOT0_:
  913|  21.4k|    {
  914|  21.4k|        each_left(v, count() - 1, args...);
  915|  21.4k|    }
_ZN5immer6detail4rbts15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE9each_leftINS1_21concat_merger_visitorEJRNS1_13concat_mergerISC_EEEEEvT_jDpOT0_:
  873|  21.4k|    {
  874|  21.4k|        return each_left_regular(*this, v, last, args...);
  875|  21.4k|    }
_ZN5immer6detail4rbts17each_left_regularIRNS1_15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEENS1_21concat_merger_visitorEJRNS1_13concat_mergerISD_EEEEEvOT_T0_jDpOT1_:
  575|  21.4k|{
  576|  21.4k|    constexpr auto B  = bits<Pos>;
  577|  21.4k|    constexpr auto BL = bits_leaf<Pos>;
  578|  21.4k|    assert(last < p.count());
  ------------------
  |  Branch (578:5): [True: 21.4k, False: 0]
  ------------------
  579|  21.4k|    if (p.shift() == BL) {
  ------------------
  |  Branch (579:9): [True: 10.4k, False: 11.0k]
  ------------------
  580|  10.4k|        auto n = p.node()->inner();
  581|  10.4k|        auto e = n + last;
  582|  17.7k|        for (; n != e; ++n) {
  ------------------
  |  Branch (582:16): [True: 7.30k, False: 10.4k]
  ------------------
  583|  7.30k|            IMMER_PREFETCH(n + 1);
  584|  7.30k|            make_full_leaf_pos(*n).visit(v, args...);
  585|  7.30k|        }
  586|  11.0k|    } else {
  587|  11.0k|        auto n  = p.node()->inner();
  588|  11.0k|        auto e  = n + last;
  589|  11.0k|        auto ss = p.shift() - B;
  590|  24.2k|        for (; n != e; ++n)
  ------------------
  |  Branch (590:16): [True: 13.2k, False: 11.0k]
  ------------------
  591|  13.2k|            make_full_pos(*n, ss).visit(v, args...);
  592|  11.0k|    }
  593|  21.4k|}
_ZN5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE9first_subINS1_20concat_right_visitorISC_EEJRNS1_15regular_sub_posISC_EERNS1_8leaf_posISC_EEEEEDcT_DpOT0_:
 1762|  11.0k|    {
 1763|  11.0k|        auto child      = node_->inner()[0];
 1764|  11.0k|        auto child_size = relaxed_->d.sizes[0];
 1765|  11.0k|        auto is_leaf    = shift_ == BL;
 1766|  11.0k|        assert(child_size);
  ------------------
  |  Branch (1766:9): [True: 11.0k, False: 0]
  ------------------
 1767|  11.0k|        return is_leaf ? make_leaf_sub_pos(child, child_size).visit(v, args...)
  ------------------
  |  Branch (1767:16): [True: 0, False: 11.0k]
  ------------------
 1768|  11.0k|                       : visit_maybe_relaxed_sub(
 1769|  11.0k|                             child, shift_ - B, child_size, v, args...);
 1770|  11.0k|    }
_ZNK5immer6detail4rbts8leaf_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5shiftEv:
  106|   146k|    shift_t shift() const { return 0; }
_ZN5immer6detail4rbts23visit_maybe_relaxed_subINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEENS1_20concat_right_visitorISC_EEJRNS1_15regular_sub_posISC_EERNS1_8leaf_posISC_EEEEEDcPT_jmT0_DpOT1_:
 1838|  11.0k|{
 1839|  11.0k|    assert(node);
  ------------------
  |  Branch (1839:5): [True: 11.0k, False: 0]
  ------------------
 1840|  11.0k|    auto relaxed = node->relaxed();
 1841|  11.0k|    if (relaxed) {
  ------------------
  |  Branch (1841:9): [True: 10.1k, False: 852]
  ------------------
 1842|  10.1k|        assert(size == relaxed->d.sizes[relaxed->d.count - 1]);
  ------------------
  |  Branch (1842:9): [True: 10.1k, False: 0]
  ------------------
 1843|  10.1k|        return make_relaxed_pos(node, shift, relaxed)
 1844|  10.1k|            .visit(v, std::forward<Args>(args)...);
 1845|  10.1k|    } else {
 1846|    852|        return make_regular_sub_pos(node, shift, size)
 1847|    852|            .visit(v, std::forward<Args>(args)...);
 1848|    852|    }
 1849|  11.0k|}
_ZN5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_20concat_right_visitorISC_EEJRNS1_15regular_sub_posISC_EERNS1_8leaf_posISC_EEEEEDcT_DpOT0_:
 1813|  10.1k|    {
 1814|  10.1k|        return Visitor::visit_relaxed(*this, std::forward<Args>(args)...);
 1815|  10.1k|    }
_ZN5immer6detail4rbts15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_20concat_right_visitorISC_EEJRSD_RNS1_8leaf_posISC_EEEEEDcT_DpOT0_:
 1036|    852|    {
 1037|    852|        return Visitor::visit_regular(*this, std::forward<Args>(args)...);
 1038|    852|    }
_ZN5immer6detail4rbts15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE8last_subINS1_19concat_left_visitorISC_EEJRNS1_8leaf_posISC_EERSD_EEEDcT_DpOT0_:
  958|    967|    {
  959|    967|        auto offset  = count() - 1;
  960|    967|        auto child   = node_->inner()[offset];
  961|    967|        auto is_leaf = shift_ == BL;
  962|    967|        auto lsize   = size_ - (size_t{offset} << shift_);
  963|    967|        return is_leaf ? make_leaf_sub_pos(child, lsize).visit(v, args...)
  ------------------
  |  Branch (963:16): [True: 0, False: 967]
  ------------------
  964|    967|                       : make_regular_sub_pos(child, shift_ - B, lsize)
  965|    967|                             .visit(v, args...);
  966|    967|    }
_ZN5immer6detail4rbts15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_19concat_left_visitorISC_EEJRNS1_8leaf_posISC_EERSD_EEEDcT_DpOT0_:
 1036|  1.30k|    {
 1037|  1.30k|        return Visitor::visit_regular(*this, std::forward<Args>(args)...);
 1038|  1.30k|    }
_ZN5immer6detail4rbts15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE9first_subINS1_20concat_right_visitorISC_EEJRSD_RNS1_8leaf_posISC_EEEEEDcT_DpOT0_:
  970|  2.15k|    {
  971|  2.15k|        auto is_leaf = shift_ == BL;
  972|  2.15k|        auto child   = node_->inner()[0];
  973|  2.15k|        auto is_full = size_ >= (size_t{1} << shift_);
  974|  2.15k|        return is_full
  ------------------
  |  Branch (974:16): [True: 2.15k, False: 0]
  ------------------
  975|  2.15k|                   ? (is_leaf
  ------------------
  |  Branch (975:23): [True: 0, False: 2.15k]
  ------------------
  976|  2.15k|                          ? make_full_leaf_pos(child).visit(v, args...)
  977|  2.15k|                          : make_full_pos(child, shift_ - B).visit(v, args...))
  978|  2.15k|                   : (is_leaf
  ------------------
  |  Branch (978:23): [True: 0, False: 0]
  ------------------
  979|      0|                          ? make_leaf_sub_pos(child, size_).visit(v, args...)
  980|      0|                          : make_regular_sub_pos(child, shift_ - B, size_)
  981|      0|                                .visit(v, args...));
  982|  2.15k|    }
_ZN5immer6detail4rbts8full_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_20concat_right_visitorISC_EEJRNS1_15regular_sub_posISC_EERNS1_8leaf_posISC_EEEEEDcT_DpOT0_:
 1405|  4.16k|    {
 1406|  4.16k|        return Visitor::visit_regular(*this, std::forward<Args>(args)...);
 1407|  4.16k|    }
_ZN5immer6detail4rbts8full_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE9first_subINS1_20concat_right_visitorISC_EEJRNS1_15regular_sub_posISC_EERNS1_8leaf_posISC_EEEEEDcT_DpOT0_:
 1361|  2.00k|    {
 1362|  2.00k|        auto is_leaf = shift_ == BL;
 1363|  2.00k|        auto child   = node_->inner()[0];
 1364|  2.00k|        return is_leaf ? make_full_leaf_pos(child).visit(v, args...)
  ------------------
  |  Branch (1364:16): [True: 0, False: 2.00k]
  ------------------
 1365|  2.00k|                       : make_full_pos(child, shift_ - B).visit(v, args...);
 1366|  2.00k|    }
_ZN5immer6detail4rbts15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE8last_subINS1_19concat_both_visitorISC_EEJRNS1_8leaf_posISC_EERNS1_8full_posISC_EEEEEDcT_DpOT0_:
  958|  3.93k|    {
  959|  3.93k|        auto offset  = count() - 1;
  960|  3.93k|        auto child   = node_->inner()[offset];
  961|  3.93k|        auto is_leaf = shift_ == BL;
  962|  3.93k|        auto lsize   = size_ - (size_t{offset} << shift_);
  963|  3.93k|        return is_leaf ? make_leaf_sub_pos(child, lsize).visit(v, args...)
  ------------------
  |  Branch (963:16): [True: 2.36k, False: 1.56k]
  ------------------
  964|  3.93k|                       : make_regular_sub_pos(child, shift_ - B, lsize)
  965|  1.56k|                             .visit(v, args...);
  966|  3.93k|    }
_ZN5immer6detail4rbts12leaf_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_19concat_both_visitorISC_EEJRNS1_8leaf_posISC_EERNS1_8full_posISC_EEEEEDcT_DpOT0_:
  144|  3.53k|    {
  145|  3.53k|        return Visitor::visit_leaf(*this, std::forward<Args>(args)...);
  146|  3.53k|    }
_ZN5immer6detail4rbts8full_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE14first_sub_leafINS1_20concat_right_visitorISC_EEJRNS1_12leaf_sub_posISC_EERNS1_8leaf_posISC_EEEEEDcT_DpOT0_:
 1370|  3.53k|    {
 1371|  3.53k|        assert(shift_ == BL);
  ------------------
  |  Branch (1371:9): [True: 3.53k, False: 0]
  ------------------
 1372|  3.53k|        auto child = node_->inner()[0];
 1373|  3.53k|        return make_full_leaf_pos(child).visit(v, args...);
 1374|  3.53k|    }
_ZN5immer6detail4rbts13full_leaf_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_20concat_right_visitorISC_EEJRNS1_12leaf_sub_posISC_EERNS1_8leaf_posISC_EEEEEDcT_DpOT0_:
  207|  8.75k|    {
  208|  8.75k|        return Visitor::visit_leaf(*this, std::forward<Args>(args)...);
  209|  8.75k|    }
_ZN5immer6detail4rbts15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_19concat_both_visitorISC_EEJRNS1_8leaf_posISC_EERNS1_8full_posISC_EEEEEDcT_DpOT0_:
 1036|  1.77k|    {
 1037|  1.77k|        return Visitor::visit_regular(*this, std::forward<Args>(args)...);
 1038|  1.77k|    }
_ZN5immer6detail4rbts15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE8last_subINS1_19concat_both_visitorISC_EEJRNS1_8leaf_posISC_EERSD_EEEDcT_DpOT0_:
  958|  5.57k|    {
  959|  5.57k|        auto offset  = count() - 1;
  960|  5.57k|        auto child   = node_->inner()[offset];
  961|  5.57k|        auto is_leaf = shift_ == BL;
  962|  5.57k|        auto lsize   = size_ - (size_t{offset} << shift_);
  963|  5.57k|        return is_leaf ? make_leaf_sub_pos(child, lsize).visit(v, args...)
  ------------------
  |  Branch (963:16): [True: 4.53k, False: 1.03k]
  ------------------
  964|  5.57k|                       : make_regular_sub_pos(child, shift_ - B, lsize)
  965|  1.03k|                             .visit(v, args...);
  966|  5.57k|    }
_ZN5immer6detail4rbts12leaf_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_19concat_both_visitorISC_EEJRNS1_8leaf_posISC_EERNS1_15regular_sub_posISC_EEEEEDcT_DpOT0_:
  144|  5.21k|    {
  145|  5.21k|        return Visitor::visit_leaf(*this, std::forward<Args>(args)...);
  146|  5.21k|    }
_ZN5immer6detail4rbts15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE14first_sub_leafINS1_20concat_right_visitorISC_EEJRNS1_12leaf_sub_posISC_EERNS1_8leaf_posISC_EEEEEDcT_DpOT0_:
  986|  5.21k|    {
  987|  5.21k|        assert(shift_ == BL);
  ------------------
  |  Branch (987:9): [True: 5.21k, False: 0]
  ------------------
  988|  5.21k|        auto child   = node_->inner()[0];
  989|  5.21k|        auto is_full = size_ >= branches<BL>;
  990|  5.21k|        return is_full ? make_full_leaf_pos(child).visit(v, args...)
  ------------------
  |  Branch (990:16): [True: 5.21k, False: 0]
  ------------------
  991|  5.21k|                       : make_leaf_sub_pos(child, size_).visit(v, args...);
  992|  5.21k|    }
_ZN5immer6detail4rbts12leaf_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_20concat_right_visitorISC_EEJRSD_RNS1_8leaf_posISC_EEEEEDcT_DpOT0_:
  144|  38.4k|    {
  145|  38.4k|        return Visitor::visit_leaf(*this, std::forward<Args>(args)...);
  146|  38.4k|    }
_ZN5immer6detail4rbts15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_19concat_both_visitorISC_EEJRNS1_8leaf_posISC_EERSD_EEEDcT_DpOT0_:
 1036|  1.60k|    {
 1037|  1.60k|        return Visitor::visit_regular(*this, std::forward<Args>(args)...);
 1038|  1.60k|    }
_ZN5immer6detail4rbts15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE8last_subINS1_19concat_both_visitorISC_EEJRNS1_8leaf_posISC_EERNS1_11relaxed_posISC_EEEEEDcT_DpOT0_:
  958|  10.4k|    {
  959|  10.4k|        auto offset  = count() - 1;
  960|  10.4k|        auto child   = node_->inner()[offset];
  961|  10.4k|        auto is_leaf = shift_ == BL;
  962|  10.4k|        auto lsize   = size_ - (size_t{offset} << shift_);
  963|  10.4k|        return is_leaf ? make_leaf_sub_pos(child, lsize).visit(v, args...)
  ------------------
  |  Branch (963:16): [True: 3.50k, False: 6.97k]
  ------------------
  964|  10.4k|                       : make_regular_sub_pos(child, shift_ - B, lsize)
  965|  6.97k|                             .visit(v, args...);
  966|  10.4k|    }
_ZN5immer6detail4rbts12leaf_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_19concat_both_visitorISC_EEJRNS1_8leaf_posISC_EERNS1_11relaxed_posISC_EEEEEDcT_DpOT0_:
  144|  38.4k|    {
  145|  38.4k|        return Visitor::visit_leaf(*this, std::forward<Args>(args)...);
  146|  38.4k|    }
_ZN5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE14first_sub_leafINS1_20concat_right_visitorISC_EEJRNS1_12leaf_sub_posISC_EERNS1_8leaf_posISC_EEEEEDcT_DpOT0_:
 1774|  38.4k|    {
 1775|  38.4k|        assert(shift_ == BL);
  ------------------
  |  Branch (1775:9): [True: 38.4k, False: 0]
  ------------------
 1776|  38.4k|        auto child      = node_->inner()[0];
 1777|  38.4k|        auto child_size = relaxed_->d.sizes[0];
 1778|  38.4k|        return make_leaf_sub_pos(child, child_size).visit(v, args...);
 1779|  38.4k|    }
_ZN5immer6detail4rbts15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_19concat_both_visitorISC_EEJRNS1_8leaf_posISC_EERNS1_11relaxed_posISC_EEEEEDcT_DpOT0_:
 1036|  10.1k|    {
 1037|  10.1k|        return Visitor::visit_regular(*this, std::forward<Args>(args)...);
 1038|  10.1k|    }
_ZN5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE13each_left_subINS1_34concat_rebalance_plan_fill_visitorEJRNS1_21concat_rebalance_planILj2ELj2EEEEEEvT_DpOT0_:
 1617|   811k|    {
 1618|   811k|        each_left(v, relaxed_->d.count - 1, args...);
 1619|   811k|    }
_ZN5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE9each_leftINS1_34concat_rebalance_plan_fill_visitorEJRNS1_21concat_rebalance_planILj2ELj2EEEEEEvT_jDpOT0_:
 1623|   811k|    {
 1624|   811k|        auto p = node_->inner();
 1625|   811k|        auto s = size_t{};
 1626|   811k|        if (shift_ == BL) {
  ------------------
  |  Branch (1626:13): [True: 93.3k, False: 718k]
  ------------------
 1627|   253k|            for (auto i = count_t{0}; i < n; ++i) {
  ------------------
  |  Branch (1627:39): [True: 160k, False: 93.3k]
  ------------------
 1628|   160k|                IMMER_PREFETCH(p + i + 1);
 1629|   160k|                make_leaf_sub_pos(p[i], relaxed_->d.sizes[i] - s)
 1630|   160k|                    .visit(v, args...);
 1631|   160k|                s = relaxed_->d.sizes[i];
 1632|   160k|                assert(s);
  ------------------
  |  Branch (1632:17): [True: 160k, False: 0]
  ------------------
 1633|   160k|            }
 1634|   718k|        } else {
 1635|   718k|            auto ss = shift_ - B;
 1636|  1.90M|            for (auto i = count_t{0}; i < n; ++i) {
  ------------------
  |  Branch (1636:39): [True: 1.18M, False: 718k]
  ------------------
 1637|  1.18M|                visit_maybe_relaxed_sub(
 1638|  1.18M|                    p[i], ss, relaxed_->d.sizes[i] - s, v, args...);
 1639|  1.18M|                s = relaxed_->d.sizes[i];
 1640|       |                assert(s);
  ------------------
  |  Branch (1640:17): [True: 1.18M, False: 0]
  ------------------
 1641|  1.18M|            }
 1642|   718k|        }
 1643|   811k|    }
_ZN5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE13each_left_subINS1_21concat_merger_visitorEJRNS1_13concat_mergerISC_EEEEEvT_DpOT0_:
 1617|   214k|    {
 1618|   214k|        each_left(v, relaxed_->d.count - 1, args...);
 1619|   214k|    }
_ZN5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE9each_leftINS1_21concat_merger_visitorEJRNS1_13concat_mergerISC_EEEEEvT_jDpOT0_:
 1623|   214k|    {
 1624|   214k|        auto p = node_->inner();
 1625|   214k|        auto s = size_t{};
 1626|   214k|        if (shift_ == BL) {
  ------------------
  |  Branch (1626:13): [True: 36.8k, False: 177k]
  ------------------
 1627|   106k|            for (auto i = count_t{0}; i < n; ++i) {
  ------------------
  |  Branch (1627:39): [True: 70.1k, False: 36.8k]
  ------------------
 1628|  70.1k|                IMMER_PREFETCH(p + i + 1);
 1629|  70.1k|                make_leaf_sub_pos(p[i], relaxed_->d.sizes[i] - s)
 1630|  70.1k|                    .visit(v, args...);
 1631|  70.1k|                s = relaxed_->d.sizes[i];
 1632|  70.1k|                assert(s);
  ------------------
  |  Branch (1632:17): [True: 70.1k, False: 0]
  ------------------
 1633|  70.1k|            }
 1634|   177k|        } else {
 1635|   177k|            auto ss = shift_ - B;
 1636|   634k|            for (auto i = count_t{0}; i < n; ++i) {
  ------------------
  |  Branch (1636:39): [True: 456k, False: 177k]
  ------------------
 1637|   456k|                visit_maybe_relaxed_sub(
 1638|   456k|                    p[i], ss, relaxed_->d.sizes[i] - s, v, args...);
 1639|   456k|                s = relaxed_->d.sizes[i];
 1640|       |                assert(s);
  ------------------
  |  Branch (1640:17): [True: 456k, False: 0]
  ------------------
 1641|   456k|            }
 1642|   177k|        }
 1643|   214k|    }
_ZN5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE9first_subINS1_20concat_right_visitorISC_EEJRSD_RNS1_8leaf_posISC_EEEEEDcT_DpOT0_:
 1762|   170k|    {
 1763|   170k|        auto child      = node_->inner()[0];
 1764|   170k|        auto child_size = relaxed_->d.sizes[0];
 1765|   170k|        auto is_leaf    = shift_ == BL;
 1766|   170k|        assert(child_size);
  ------------------
  |  Branch (1766:9): [True: 170k, False: 0]
  ------------------
 1767|   170k|        return is_leaf ? make_leaf_sub_pos(child, child_size).visit(v, args...)
  ------------------
  |  Branch (1767:16): [True: 0, False: 170k]
  ------------------
 1768|   170k|                       : visit_maybe_relaxed_sub(
 1769|   170k|                             child, shift_ - B, child_size, v, args...);
 1770|   170k|    }
_ZN5immer6detail4rbts23visit_maybe_relaxed_subINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEENS1_20concat_right_visitorISC_EEJRNS1_11relaxed_posISC_EERNS1_8leaf_posISC_EEEEEDcPT_jmT0_DpOT1_:
 1838|   170k|{
 1839|   170k|    assert(node);
  ------------------
  |  Branch (1839:5): [True: 170k, False: 0]
  ------------------
 1840|   170k|    auto relaxed = node->relaxed();
 1841|   170k|    if (relaxed) {
  ------------------
  |  Branch (1841:9): [True: 170k, False: 297]
  ------------------
 1842|   170k|        assert(size == relaxed->d.sizes[relaxed->d.count - 1]);
  ------------------
  |  Branch (1842:9): [True: 170k, False: 0]
  ------------------
 1843|   170k|        return make_relaxed_pos(node, shift, relaxed)
 1844|   170k|            .visit(v, std::forward<Args>(args)...);
 1845|   170k|    } else {
 1846|    297|        return make_regular_sub_pos(node, shift, size)
 1847|    297|            .visit(v, std::forward<Args>(args)...);
 1848|    297|    }
 1849|   170k|}
_ZN5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_20concat_right_visitorISC_EEJRSD_RNS1_8leaf_posISC_EEEEEDcT_DpOT0_:
 1813|   170k|    {
 1814|   170k|        return Visitor::visit_relaxed(*this, std::forward<Args>(args)...);
 1815|   170k|    }
_ZN5immer6detail4rbts15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_20concat_right_visitorISC_EEJRNS1_11relaxed_posISC_EERNS1_8leaf_posISC_EEEEEDcT_DpOT0_:
 1036|    297|    {
 1037|    297|        return Visitor::visit_regular(*this, std::forward<Args>(args)...);
 1038|    297|    }
_ZN5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE8last_subINS1_19concat_left_visitorISC_EEJRNS1_8leaf_posISC_EERNS1_15regular_sub_posISC_EEEEEDcT_DpOT0_:
 1750|  2.00k|    {
 1751|  2.00k|        auto offset     = relaxed_->d.count - 1;
 1752|  2.00k|        auto child      = node_->inner()[offset];
 1753|  2.00k|        auto child_size = size(offset);
 1754|  2.00k|        auto is_leaf    = shift_ == BL;
 1755|  2.00k|        return is_leaf ? make_leaf_sub_pos(child, child_size).visit(v, args...)
  ------------------
  |  Branch (1755:16): [True: 0, False: 2.00k]
  ------------------
 1756|  2.00k|                       : visit_maybe_relaxed_sub(
 1757|  2.00k|                             child, shift_ - B, child_size, v, args...);
 1758|  2.00k|    }
_ZN5immer6detail4rbts23visit_maybe_relaxed_subINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEENS1_19concat_left_visitorISC_EEJRNS1_8leaf_posISC_EERNS1_15regular_sub_posISC_EEEEEDcPT_jmT0_DpOT1_:
 1838|  2.00k|{
 1839|  2.00k|    assert(node);
  ------------------
  |  Branch (1839:5): [True: 2.00k, False: 0]
  ------------------
 1840|  2.00k|    auto relaxed = node->relaxed();
 1841|  2.00k|    if (relaxed) {
  ------------------
  |  Branch (1841:9): [True: 1.66k, False: 336]
  ------------------
 1842|  1.66k|        assert(size == relaxed->d.sizes[relaxed->d.count - 1]);
  ------------------
  |  Branch (1842:9): [True: 1.66k, False: 0]
  ------------------
 1843|  1.66k|        return make_relaxed_pos(node, shift, relaxed)
 1844|  1.66k|            .visit(v, std::forward<Args>(args)...);
 1845|  1.66k|    } else {
 1846|    336|        return make_regular_sub_pos(node, shift, size)
 1847|    336|            .visit(v, std::forward<Args>(args)...);
 1848|    336|    }
 1849|  2.00k|}
_ZN5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_19concat_left_visitorISC_EEJRNS1_8leaf_posISC_EERNS1_15regular_sub_posISC_EEEEEDcT_DpOT0_:
 1813|  1.66k|    {
 1814|  1.66k|        return Visitor::visit_relaxed(*this, std::forward<Args>(args)...);
 1815|  1.66k|    }
_ZN5immer6detail4rbts15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE9first_subINS1_20concat_right_visitorISC_EEJRNS1_11relaxed_posISC_EERNS1_8leaf_posISC_EEEEEDcT_DpOT0_:
  970|  1.37k|    {
  971|  1.37k|        auto is_leaf = shift_ == BL;
  972|  1.37k|        auto child   = node_->inner()[0];
  973|  1.37k|        auto is_full = size_ >= (size_t{1} << shift_);
  974|  1.37k|        return is_full
  ------------------
  |  Branch (974:16): [True: 1.37k, False: 0]
  ------------------
  975|  1.37k|                   ? (is_leaf
  ------------------
  |  Branch (975:23): [True: 0, False: 1.37k]
  ------------------
  976|  1.37k|                          ? make_full_leaf_pos(child).visit(v, args...)
  977|  1.37k|                          : make_full_pos(child, shift_ - B).visit(v, args...))
  978|  1.37k|                   : (is_leaf
  ------------------
  |  Branch (978:23): [True: 0, False: 0]
  ------------------
  979|      0|                          ? make_leaf_sub_pos(child, size_).visit(v, args...)
  980|      0|                          : make_regular_sub_pos(child, shift_ - B, size_)
  981|      0|                                .visit(v, args...));
  982|  1.37k|    }
_ZN5immer6detail4rbts8full_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_20concat_right_visitorISC_EEJRNS1_11relaxed_posISC_EERNS1_8leaf_posISC_EEEEEDcT_DpOT0_:
 1405|  2.09k|    {
 1406|  2.09k|        return Visitor::visit_regular(*this, std::forward<Args>(args)...);
 1407|  2.09k|    }
_ZN5immer6detail4rbts8full_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE9first_subINS1_20concat_right_visitorISC_EEJRNS1_11relaxed_posISC_EERNS1_8leaf_posISC_EEEEEDcT_DpOT0_:
 1361|    716|    {
 1362|    716|        auto is_leaf = shift_ == BL;
 1363|    716|        auto child   = node_->inner()[0];
 1364|    716|        return is_leaf ? make_full_leaf_pos(child).visit(v, args...)
  ------------------
  |  Branch (1364:16): [True: 0, False: 716]
  ------------------
 1365|    716|                       : make_full_pos(child, shift_ - B).visit(v, args...);
 1366|    716|    }
_ZN5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE8last_subINS1_19concat_both_visitorISC_EEJRNS1_8leaf_posISC_EERNS1_8full_posISC_EEEEEDcT_DpOT0_:
 1750|  1.80k|    {
 1751|  1.80k|        auto offset     = relaxed_->d.count - 1;
 1752|  1.80k|        auto child      = node_->inner()[offset];
 1753|  1.80k|        auto child_size = size(offset);
 1754|  1.80k|        auto is_leaf    = shift_ == BL;
 1755|  1.80k|        return is_leaf ? make_leaf_sub_pos(child, child_size).visit(v, args...)
  ------------------
  |  Branch (1755:16): [True: 1.16k, False: 641]
  ------------------
 1756|  1.80k|                       : visit_maybe_relaxed_sub(
 1757|    641|                             child, shift_ - B, child_size, v, args...);
 1758|  1.80k|    }
_ZN5immer6detail4rbts23visit_maybe_relaxed_subINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEENS1_19concat_both_visitorISC_EEJRNS1_8leaf_posISC_EERNS1_8full_posISC_EEEEEDcPT_jmT0_DpOT1_:
 1838|    641|{
 1839|    641|    assert(node);
  ------------------
  |  Branch (1839:5): [True: 641, False: 0]
  ------------------
 1840|    641|    auto relaxed = node->relaxed();
 1841|    641|    if (relaxed) {
  ------------------
  |  Branch (1841:9): [True: 430, False: 211]
  ------------------
 1842|    430|        assert(size == relaxed->d.sizes[relaxed->d.count - 1]);
  ------------------
  |  Branch (1842:9): [True: 430, False: 0]
  ------------------
 1843|    430|        return make_relaxed_pos(node, shift, relaxed)
 1844|    430|            .visit(v, std::forward<Args>(args)...);
 1845|    430|    } else {
 1846|    211|        return make_regular_sub_pos(node, shift, size)
 1847|    211|            .visit(v, std::forward<Args>(args)...);
 1848|    211|    }
 1849|    641|}
_ZN5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_19concat_both_visitorISC_EEJRNS1_8leaf_posISC_EERNS1_8full_posISC_EEEEEDcT_DpOT0_:
 1813|    430|    {
 1814|    430|        return Visitor::visit_relaxed(*this, std::forward<Args>(args)...);
 1815|    430|    }
_ZN5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE8last_subINS1_19concat_both_visitorISC_EEJRNS1_8leaf_posISC_EERNS1_15regular_sub_posISC_EEEEEDcT_DpOT0_:
 1750|  2.05k|    {
 1751|  2.05k|        auto offset     = relaxed_->d.count - 1;
 1752|  2.05k|        auto child      = node_->inner()[offset];
 1753|  2.05k|        auto child_size = size(offset);
 1754|  2.05k|        auto is_leaf    = shift_ == BL;
 1755|  2.05k|        return is_leaf ? make_leaf_sub_pos(child, child_size).visit(v, args...)
  ------------------
  |  Branch (1755:16): [True: 677, False: 1.38k]
  ------------------
 1756|  2.05k|                       : visit_maybe_relaxed_sub(
 1757|  1.38k|                             child, shift_ - B, child_size, v, args...);
 1758|  2.05k|    }
_ZN5immer6detail4rbts23visit_maybe_relaxed_subINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEENS1_19concat_both_visitorISC_EEJRNS1_8leaf_posISC_EERNS1_15regular_sub_posISC_EEEEEDcPT_jmT0_DpOT1_:
 1838|  1.38k|{
 1839|  1.38k|    assert(node);
  ------------------
  |  Branch (1839:5): [True: 1.38k, False: 0]
  ------------------
 1840|  1.38k|    auto relaxed = node->relaxed();
 1841|  1.38k|    if (relaxed) {
  ------------------
  |  Branch (1841:9): [True: 811, False: 569]
  ------------------
 1842|    811|        assert(size == relaxed->d.sizes[relaxed->d.count - 1]);
  ------------------
  |  Branch (1842:9): [True: 811, False: 0]
  ------------------
 1843|    811|        return make_relaxed_pos(node, shift, relaxed)
 1844|    811|            .visit(v, std::forward<Args>(args)...);
 1845|    811|    } else {
 1846|    569|        return make_regular_sub_pos(node, shift, size)
 1847|    569|            .visit(v, std::forward<Args>(args)...);
 1848|    569|    }
 1849|  1.38k|}
_ZN5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_19concat_both_visitorISC_EEJRNS1_8leaf_posISC_EERNS1_15regular_sub_posISC_EEEEEDcT_DpOT0_:
 1813|    811|    {
 1814|    811|        return Visitor::visit_relaxed(*this, std::forward<Args>(args)...);
 1815|    811|    }
_ZN5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE8last_subINS1_19concat_both_visitorISC_EEJRNS1_8leaf_posISC_EERSD_EEEDcT_DpOT0_:
 1750|   205k|    {
 1751|   205k|        auto offset     = relaxed_->d.count - 1;
 1752|   205k|        auto child      = node_->inner()[offset];
 1753|   205k|        auto child_size = size(offset);
 1754|   205k|        auto is_leaf    = shift_ == BL;
 1755|   205k|        return is_leaf ? make_leaf_sub_pos(child, child_size).visit(v, args...)
  ------------------
  |  Branch (1755:16): [True: 34.9k, False: 170k]
  ------------------
 1756|   205k|                       : visit_maybe_relaxed_sub(
 1757|   170k|                             child, shift_ - B, child_size, v, args...);
 1758|   205k|    }
_ZN5immer6detail4rbts23visit_maybe_relaxed_subINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEENS1_19concat_both_visitorISC_EEJRNS1_8leaf_posISC_EERNS1_11relaxed_posISC_EEEEEDcPT_jmT0_DpOT1_:
 1838|   170k|{
 1839|   170k|    assert(node);
  ------------------
  |  Branch (1839:5): [True: 170k, False: 0]
  ------------------
 1840|   170k|    auto relaxed = node->relaxed();
 1841|   170k|    if (relaxed) {
  ------------------
  |  Branch (1841:9): [True: 167k, False: 3.18k]
  ------------------
 1842|   167k|        assert(size == relaxed->d.sizes[relaxed->d.count - 1]);
  ------------------
  |  Branch (1842:9): [True: 167k, False: 0]
  ------------------
 1843|   167k|        return make_relaxed_pos(node, shift, relaxed)
 1844|   167k|            .visit(v, std::forward<Args>(args)...);
 1845|   167k|    } else {
 1846|  3.18k|        return make_regular_sub_pos(node, shift, size)
 1847|  3.18k|            .visit(v, std::forward<Args>(args)...);
 1848|  3.18k|    }
 1849|   170k|}
_ZN5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_19concat_both_visitorISC_EEJRNS1_8leaf_posISC_EERSD_EEEDcT_DpOT0_:
 1813|   167k|    {
 1814|   167k|        return Visitor::visit_relaxed(*this, std::forward<Args>(args)...);
 1815|   167k|    }
_ZN5immer6detail4rbts15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_26concat_trees_right_visitorISC_EEJRNS1_11relaxed_posISC_EERNS1_8leaf_posISC_EEEEEDcT_DpOT0_:
 1036|  2.66k|    {
 1037|  2.66k|        return Visitor::visit_regular(*this, std::forward<Args>(args)...);
 1038|  2.66k|    }
_ZN5immer6detail4rbts15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_25concat_trees_left_visitorISC_EEJNS1_8leaf_posISC_EERPSC_RjRmEEEDcT_DpOT0_:
 1036|  5.78k|    {
 1037|  5.78k|        return Visitor::visit_regular(*this, std::forward<Args>(args)...);
 1038|  5.78k|    }
_ZN5immer6detail4rbts23visit_maybe_relaxed_subINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEENS1_26concat_trees_right_visitorISC_EEJRNS1_15regular_sub_posISC_EERNS1_8leaf_posISC_EEEEEDcPT_jmT0_DpOT1_:
 1838|  5.78k|{
 1839|  5.78k|    assert(node);
  ------------------
  |  Branch (1839:5): [True: 5.78k, False: 0]
  ------------------
 1840|  5.78k|    auto relaxed = node->relaxed();
 1841|  5.78k|    if (relaxed) {
  ------------------
  |  Branch (1841:9): [True: 840, False: 4.94k]
  ------------------
 1842|    840|        assert(size == relaxed->d.sizes[relaxed->d.count - 1]);
  ------------------
  |  Branch (1842:9): [True: 840, False: 0]
  ------------------
 1843|    840|        return make_relaxed_pos(node, shift, relaxed)
 1844|    840|            .visit(v, std::forward<Args>(args)...);
 1845|  4.94k|    } else {
 1846|  4.94k|        return make_regular_sub_pos(node, shift, size)
 1847|  4.94k|            .visit(v, std::forward<Args>(args)...);
 1848|  4.94k|    }
 1849|  5.78k|}
_ZN5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_26concat_trees_right_visitorISC_EEJRNS1_15regular_sub_posISC_EERNS1_8leaf_posISC_EEEEEDcT_DpOT0_:
 1813|    840|    {
 1814|    840|        return Visitor::visit_relaxed(*this, std::forward<Args>(args)...);
 1815|    840|    }
_ZN5immer6detail4rbts15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_26concat_trees_right_visitorISC_EEJRSD_RNS1_8leaf_posISC_EEEEEDcT_DpOT0_:
 1036|  4.94k|    {
 1037|  4.94k|        return Visitor::visit_regular(*this, std::forward<Args>(args)...);
 1038|  4.94k|    }
_ZN5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_21push_tail_mut_visitorISC_Lb1EEEJRNSA_5applyIS7_E4type4editERPSC_RjEEEDcT_DpOT0_:
 1813|   881k|    {
 1814|   881k|        return Visitor::visit_relaxed(*this, std::forward<Args>(args)...);
 1815|   881k|    }
_ZN5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE11last_oh_cshINS1_21push_tail_mut_visitorISC_Lb1EEEJRNSA_5applyIS7_E4type4editERPSC_RjEEEDcT_jmDpOT0_:
 1737|   869k|    {
 1738|   869k|        assert(offset_hint == count() - 1);
  ------------------
  |  Branch (1738:9): [True: 869k, False: 0]
  ------------------
 1739|   869k|        assert(child_size_hint == size(offset_hint));
  ------------------
  |  Branch (1739:9): [True: 869k, False: 0]
  ------------------
 1740|   869k|        auto child   = node_->inner()[offset_hint];
 1741|   869k|        auto is_leaf = shift_ == BL;
 1742|   869k|        return is_leaf
  ------------------
  |  Branch (1742:16): [True: 0, False: 869k]
  ------------------
 1743|   869k|                   ? make_leaf_sub_pos(child, child_size_hint).visit(v, args...)
 1744|   869k|                   : visit_maybe_relaxed_sub(
 1745|   869k|                         child, shift_ - B, child_size_hint, v, args...);
 1746|   869k|    }
_ZN5immer6detail4rbts23visit_maybe_relaxed_subINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEENS1_21push_tail_mut_visitorISC_Lb1EEEJRNSA_5applyIS7_E4type4editERPSC_RjEEEDcPT_jmT0_DpOT1_:
 1838|   869k|{
 1839|   869k|    assert(node);
  ------------------
  |  Branch (1839:5): [True: 869k, False: 0]
  ------------------
 1840|   869k|    auto relaxed = node->relaxed();
 1841|   869k|    if (relaxed) {
  ------------------
  |  Branch (1841:9): [True: 199k, False: 669k]
  ------------------
 1842|   199k|        assert(size == relaxed->d.sizes[relaxed->d.count - 1]);
  ------------------
  |  Branch (1842:9): [True: 199k, False: 0]
  ------------------
 1843|   199k|        return make_relaxed_pos(node, shift, relaxed)
 1844|   199k|            .visit(v, std::forward<Args>(args)...);
 1845|   669k|    } else {
 1846|   669k|        return make_regular_sub_pos(node, shift, size)
 1847|   669k|            .visit(v, std::forward<Args>(args)...);
 1848|   669k|    }
 1849|   869k|}
_ZN5immer6detail4rbts15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_21push_tail_mut_visitorISC_Lb1EEEJRNSA_5applyIS7_E4type4editERPSC_RjEEEDcT_DpOT0_:
 1036|   669k|    {
 1037|   669k|        return Visitor::visit_regular(*this, std::forward<Args>(args)...);
 1038|   669k|    }
_ZN5immer6detail4rbts15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE7last_ohINS1_21push_tail_mut_visitorISC_Lb1EEEJRNSA_5applyIS7_E4type4editERPSC_EEEDcT_jDpOT0_:
  952|  1.66M|    {
  953|  1.66M|        return last_oh_regular(*this, v, offset_hint, args...);
  954|  1.66M|    }
_ZN5immer6detail4rbts15last_oh_regularIRNS1_15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEENS1_21push_tail_mut_visitorISD_Lb1EEEJRNSB_5applyIS8_E4type4editERPSD_EEEDcOT_T0_jDpOT1_:
  677|  1.66M|{
  678|  1.66M|    assert(offset_hint == p.count() - 1);
  ------------------
  |  Branch (678:5): [True: 1.66M, False: 0]
  ------------------
  679|  1.66M|    constexpr auto B  = bits<Pos>;
  680|  1.66M|    constexpr auto BL = bits_leaf<Pos>;
  681|  1.66M|    auto child        = p.node()->inner()[offset_hint];
  682|  1.66M|    auto is_leaf      = p.shift() == BL;
  683|  1.66M|    return is_leaf ? make_leaf_pos(child, p.size()).visit(v, args...)
  ------------------
  |  Branch (683:12): [True: 0, False: 1.66M]
  ------------------
  684|  1.66M|                   : make_regular_pos(child, p.shift() - B, p.size())
  685|  1.66M|                         .visit(v, args...);
  686|  1.66M|}
_ZN5immer6detail4rbts11regular_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_21push_tail_mut_visitorISC_Lb1EEEJRNSA_5applyIS7_E4type4editERPSC_EEEDcT_DpOT0_:
  336|  9.05M|    {
  337|  9.05M|        return Visitor::visit_regular(*this, std::forward<Args>(args)...);
  338|  9.05M|    }
_ZN5immer6detail4rbts11regular_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE7last_ohINS1_21push_tail_mut_visitorISC_Lb1EEEJRNSA_5applyIS7_E4type4editERPSC_EEEDcT_jDpOT0_:
  330|  7.39M|    {
  331|  7.39M|        return last_oh_regular(*this, v, offset_hint, args...);
  332|  7.39M|    }
_ZN5immer6detail4rbts15last_oh_regularIRNS1_11regular_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEENS1_21push_tail_mut_visitorISD_Lb1EEEJRNSB_5applyIS8_E4type4editERPSD_EEEDcOT_T0_jDpOT1_:
  677|  7.39M|{
  678|  7.39M|    assert(offset_hint == p.count() - 1);
  ------------------
  |  Branch (678:5): [True: 7.39M, False: 0]
  ------------------
  679|  7.39M|    constexpr auto B  = bits<Pos>;
  680|  7.39M|    constexpr auto BL = bits_leaf<Pos>;
  681|  7.39M|    auto child        = p.node()->inner()[offset_hint];
  682|  7.39M|    auto is_leaf      = p.shift() == BL;
  683|  7.39M|    return is_leaf ? make_leaf_pos(child, p.size()).visit(v, args...)
  ------------------
  |  Branch (683:12): [True: 0, False: 7.39M]
  ------------------
  684|  7.39M|                   : make_regular_pos(child, p.shift() - B, p.size())
  685|  7.39M|                         .visit(v, args...);
  686|  7.39M|}
_ZN5immer6detail4rbts11regular_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE7last_ohINS1_21push_tail_mut_visitorISC_Lb0EEEJRNSA_5applyIS7_E4type4editERPSC_EEEDcT_jDpOT0_:
  330|  4.04k|    {
  331|  4.04k|        return last_oh_regular(*this, v, offset_hint, args...);
  332|  4.04k|    }
_ZN5immer6detail4rbts15last_oh_regularIRNS1_11regular_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEENS1_21push_tail_mut_visitorISD_Lb0EEEJRNSB_5applyIS8_E4type4editERPSD_EEEDcOT_T0_jDpOT1_:
  677|  4.04k|{
  678|  4.04k|    assert(offset_hint == p.count() - 1);
  ------------------
  |  Branch (678:5): [True: 4.04k, False: 0]
  ------------------
  679|  4.04k|    constexpr auto B  = bits<Pos>;
  680|  4.04k|    constexpr auto BL = bits_leaf<Pos>;
  681|  4.04k|    auto child        = p.node()->inner()[offset_hint];
  682|  4.04k|    auto is_leaf      = p.shift() == BL;
  683|  4.04k|    return is_leaf ? make_leaf_pos(child, p.size()).visit(v, args...)
  ------------------
  |  Branch (683:12): [True: 0, False: 4.04k]
  ------------------
  684|  4.04k|                   : make_regular_pos(child, p.shift() - B, p.size())
  685|  4.04k|                         .visit(v, args...);
  686|  4.04k|}
_ZN5immer6detail4rbts11regular_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_21push_tail_mut_visitorISC_Lb0EEEJRNSA_5applyIS7_E4type4editERPSC_EEEDcT_DpOT0_:
  336|  7.98k|    {
  337|  7.98k|        return Visitor::visit_regular(*this, std::forward<Args>(args)...);
  338|  7.98k|    }
_ZN5immer6detail4rbts15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE7last_ohINS1_21push_tail_mut_visitorISC_Lb0EEEJRNSA_5applyIS7_E4type4editERPSC_EEEDcT_jDpOT0_:
  952|  3.93k|    {
  953|  3.93k|        return last_oh_regular(*this, v, offset_hint, args...);
  954|  3.93k|    }
_ZN5immer6detail4rbts15last_oh_regularIRNS1_15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEENS1_21push_tail_mut_visitorISD_Lb0EEEJRNSB_5applyIS8_E4type4editERPSD_EEEDcOT_T0_jDpOT1_:
  677|  3.93k|{
  678|  3.93k|    assert(offset_hint == p.count() - 1);
  ------------------
  |  Branch (678:5): [True: 3.93k, False: 0]
  ------------------
  679|  3.93k|    constexpr auto B  = bits<Pos>;
  680|  3.93k|    constexpr auto BL = bits_leaf<Pos>;
  681|  3.93k|    auto child        = p.node()->inner()[offset_hint];
  682|  3.93k|    auto is_leaf      = p.shift() == BL;
  683|  3.93k|    return is_leaf ? make_leaf_pos(child, p.size()).visit(v, args...)
  ------------------
  |  Branch (683:12): [True: 0, False: 3.93k]
  ------------------
  684|  3.93k|                   : make_regular_pos(child, p.shift() - B, p.size())
  685|  3.93k|                         .visit(v, args...);
  686|  3.93k|}
_ZN5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE11last_oh_cshINS1_21push_tail_mut_visitorISC_Lb0EEEJRNSA_5applyIS7_E4type4editERPSC_RjEEEDcT_jmDpOT0_:
 1737|  22.0k|    {
 1738|  22.0k|        assert(offset_hint == count() - 1);
  ------------------
  |  Branch (1738:9): [True: 22.0k, False: 0]
  ------------------
 1739|  22.0k|        assert(child_size_hint == size(offset_hint));
  ------------------
  |  Branch (1739:9): [True: 22.0k, False: 0]
  ------------------
 1740|  22.0k|        auto child   = node_->inner()[offset_hint];
 1741|  22.0k|        auto is_leaf = shift_ == BL;
 1742|  22.0k|        return is_leaf
  ------------------
  |  Branch (1742:16): [True: 0, False: 22.0k]
  ------------------
 1743|  22.0k|                   ? make_leaf_sub_pos(child, child_size_hint).visit(v, args...)
 1744|  22.0k|                   : visit_maybe_relaxed_sub(
 1745|  22.0k|                         child, shift_ - B, child_size_hint, v, args...);
 1746|  22.0k|    }
_ZN5immer6detail4rbts23visit_maybe_relaxed_subINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEENS1_21push_tail_mut_visitorISC_Lb0EEEJRNSA_5applyIS7_E4type4editERPSC_RjEEEDcPT_jmT0_DpOT1_:
 1838|  22.0k|{
 1839|  22.0k|    assert(node);
  ------------------
  |  Branch (1839:5): [True: 22.0k, False: 0]
  ------------------
 1840|  22.0k|    auto relaxed = node->relaxed();
 1841|  22.0k|    if (relaxed) {
  ------------------
  |  Branch (1841:9): [True: 19.1k, False: 2.93k]
  ------------------
 1842|  19.1k|        assert(size == relaxed->d.sizes[relaxed->d.count - 1]);
  ------------------
  |  Branch (1842:9): [True: 19.1k, False: 0]
  ------------------
 1843|  19.1k|        return make_relaxed_pos(node, shift, relaxed)
 1844|  19.1k|            .visit(v, std::forward<Args>(args)...);
 1845|  19.1k|    } else {
 1846|  2.93k|        return make_regular_sub_pos(node, shift, size)
 1847|  2.93k|            .visit(v, std::forward<Args>(args)...);
 1848|  2.93k|    }
 1849|  22.0k|}
_ZN5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_21push_tail_mut_visitorISC_Lb0EEEJRNSA_5applyIS7_E4type4editERPSC_RjEEEDcT_DpOT0_:
 1813|  19.1k|    {
 1814|  19.1k|        return Visitor::visit_relaxed(*this, std::forward<Args>(args)...);
 1815|  19.1k|    }
_ZN5immer6detail4rbts15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_21push_tail_mut_visitorISC_Lb0EEEJRNSA_5applyIS7_E4type4editERPSC_RjEEEDcT_DpOT0_:
 1036|  2.93k|    {
 1037|  2.93k|        return Visitor::visit_regular(*this, std::forward<Args>(args)...);
 1038|  2.93k|    }
_ZN5immer6detail4rbts15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_21push_tail_mut_visitorISC_Lb1EEEJRNSA_5applyIS7_E4type4editERPSC_EEEDcT_DpOT0_:
 1036|  1.01M|    {
 1037|  1.01M|        return Visitor::visit_regular(*this, std::forward<Args>(args)...);
 1038|  1.01M|    }
_ZN5immer6detail4rbts23visit_maybe_relaxed_subINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEENS1_15get_mut_visitorISC_EEJRmRNSA_5applyIS7_E4type4editEPPSC_EEEDcPT_jmT0_DpOT1_:
 1838|  10.6k|{
 1839|  10.6k|    assert(node);
  ------------------
  |  Branch (1839:5): [True: 10.6k, False: 0]
  ------------------
 1840|  10.6k|    auto relaxed = node->relaxed();
 1841|  10.6k|    if (relaxed) {
  ------------------
  |  Branch (1841:9): [True: 5.64k, False: 4.97k]
  ------------------
 1842|  5.64k|        assert(size == relaxed->d.sizes[relaxed->d.count - 1]);
  ------------------
  |  Branch (1842:9): [True: 5.64k, False: 0]
  ------------------
 1843|  5.64k|        return make_relaxed_pos(node, shift, relaxed)
 1844|  5.64k|            .visit(v, std::forward<Args>(args)...);
 1845|  5.64k|    } else {
 1846|  4.97k|        return make_regular_sub_pos(node, shift, size)
 1847|  4.97k|            .visit(v, std::forward<Args>(args)...);
 1848|  4.97k|    }
 1849|  10.6k|}
_ZN5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_15get_mut_visitorISC_EEJRmRNSA_5applyIS7_E4type4editEPPSC_EEEDcT_DpOT0_:
 1813|  5.64k|    {
 1814|  5.64k|        return Visitor::visit_relaxed(*this, std::forward<Args>(args)...);
 1815|  5.64k|    }
_ZN5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE10towards_ohINS1_15get_mut_visitorISC_EEJRNSA_5applyIS7_E4type4editEPPSC_EEEDcT_mjDpOT0_:
 1686|  26.7k|    {
 1687|  26.7k|        assert(offset_hint == index(idx));
  ------------------
  |  Branch (1687:9): [True: 26.7k, False: 0]
  ------------------
 1688|  26.7k|        auto left_size = offset_hint ? relaxed_->d.sizes[offset_hint - 1] : 0;
  ------------------
  |  Branch (1688:26): [True: 4.85k, False: 21.8k]
  ------------------
 1689|  26.7k|        return towards_oh_sbh(v, idx, offset_hint, left_size, args...);
 1690|  26.7k|    }
_ZN5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE14towards_oh_sbhINS1_15get_mut_visitorISC_EEJRNSA_5applyIS7_E4type4editERPPSC_EEEDcT_mjmDpOT0_:
 1698|  26.7k|    {
 1699|  26.7k|        return towards_sub_oh_sbh(v, idx, offset_hint, left_size_hint, args...);
 1700|  26.7k|    }
_ZN5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE18towards_sub_oh_sbhINS1_15get_mut_visitorISC_EEJRNSA_5applyIS7_E4type4editERPPSC_EEEDcT_mjmDpOT0_:
 1717|  26.7k|    {
 1718|  26.7k|        assert(offset_hint == index(idx));
  ------------------
  |  Branch (1718:9): [True: 26.7k, False: 0]
  ------------------
 1719|  26.7k|        assert(left_size_hint ==
  ------------------
  |  Branch (1719:9): [True: 4.85k, False: 21.8k]
  |  Branch (1719:9): [True: 26.7k, False: 0]
  ------------------
 1720|  26.7k|               (offset_hint ? relaxed_->d.sizes[offset_hint - 1] : 0));
 1721|  26.7k|        auto child     = node_->inner()[offset_hint];
 1722|  26.7k|        auto is_leaf   = shift_ == BL;
 1723|  26.7k|        auto next_size = relaxed_->d.sizes[offset_hint] - left_size_hint;
 1724|  26.7k|        auto next_idx  = idx - left_size_hint;
 1725|  26.7k|        return is_leaf
  ------------------
  |  Branch (1725:16): [True: 3.64k, False: 23.0k]
  ------------------
 1726|  26.7k|                   ? make_leaf_sub_pos(child, next_size)
 1727|  3.64k|                         .visit(v, next_idx, args...)
 1728|  26.7k|                   : visit_maybe_relaxed_sub(
 1729|  23.0k|                         child, shift_ - B, next_size, v, next_idx, args...);
 1730|  26.7k|    }
_ZN5immer6detail4rbts12leaf_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_15get_mut_visitorISC_EEJRmRNSA_5applyIS7_E4type4editERPPSC_EEEDcT_DpOT0_:
  144|  3.64k|    {
  145|  3.64k|        return Visitor::visit_leaf(*this, std::forward<Args>(args)...);
  146|  3.64k|    }
_ZN5immer6detail4rbts23visit_maybe_relaxed_subINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEENS1_15get_mut_visitorISC_EEJRmRNSA_5applyIS7_E4type4editERPPSC_EEEDcPT_jmT0_DpOT1_:
 1838|  23.0k|{
 1839|  23.0k|    assert(node);
  ------------------
  |  Branch (1839:5): [True: 23.0k, False: 0]
  ------------------
 1840|  23.0k|    auto relaxed = node->relaxed();
 1841|  23.0k|    if (relaxed) {
  ------------------
  |  Branch (1841:9): [True: 21.0k, False: 2.00k]
  ------------------
 1842|  21.0k|        assert(size == relaxed->d.sizes[relaxed->d.count - 1]);
  ------------------
  |  Branch (1842:9): [True: 21.0k, False: 0]
  ------------------
 1843|  21.0k|        return make_relaxed_pos(node, shift, relaxed)
 1844|  21.0k|            .visit(v, std::forward<Args>(args)...);
 1845|  21.0k|    } else {
 1846|  2.00k|        return make_regular_sub_pos(node, shift, size)
 1847|  2.00k|            .visit(v, std::forward<Args>(args)...);
 1848|  2.00k|    }
 1849|  23.0k|}
_ZN5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_15get_mut_visitorISC_EEJRmRNSA_5applyIS7_E4type4editERPPSC_EEEDcT_DpOT0_:
 1813|  21.0k|    {
 1814|  21.0k|        return Visitor::visit_relaxed(*this, std::forward<Args>(args)...);
 1815|  21.0k|    }
_ZN5immer6detail4rbts15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_15get_mut_visitorISC_EEJRmRNSA_5applyIS7_E4type4editERPPSC_EEEDcT_DpOT0_:
 1036|  2.00k|    {
 1037|  2.00k|        return Visitor::visit_regular(*this, std::forward<Args>(args)...);
 1038|  2.00k|    }
_ZN5immer6detail4rbts15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE13towards_oh_chINS1_15get_mut_visitorISC_EEJRNSA_5applyIS7_E4type4editEPPSC_EEEDcT_mjjDpOT0_:
  938|  6.97k|    {
  939|  6.97k|        return towards_oh_ch_regular(
  940|  6.97k|            *this, v, idx, offset_hint, count(), args...);
  941|  6.97k|    }
_ZN5immer6detail4rbts21towards_oh_ch_regularIRNS1_15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEENS1_15get_mut_visitorISD_EEJRNSB_5applyIS8_E4type4editERPPSD_EEEDcOT_T0_mjjDpOT1_:
  632|  6.97k|{
  633|  6.97k|    constexpr auto B  = bits<Pos>;
  634|  6.97k|    constexpr auto BL = bits_leaf<Pos>;
  635|  6.97k|    assert(offset_hint == p.index(idx));
  ------------------
  |  Branch (635:5): [True: 6.97k, False: 0]
  ------------------
  636|  6.97k|    assert(count_hint == p.count());
  ------------------
  |  Branch (636:5): [True: 6.97k, False: 0]
  ------------------
  637|  6.97k|    auto is_leaf = p.shift() == BL;
  638|  6.97k|    auto child   = p.node()->inner()[offset_hint];
  639|  6.97k|    auto is_full = offset_hint + 1 != count_hint;
  640|  6.97k|    return is_full
  ------------------
  |  Branch (640:12): [True: 4.76k, False: 2.20k]
  ------------------
  641|  6.97k|               ? (is_leaf ? make_full_leaf_pos(child).visit(v, idx, args...)
  ------------------
  |  Branch (641:19): [True: 1.08k, False: 3.67k]
  ------------------
  642|  4.76k|                          : make_full_pos(child, p.shift() - B)
  643|  3.67k|                                .visit(v, idx, args...))
  644|  6.97k|               : (is_leaf
  ------------------
  |  Branch (644:19): [True: 766, False: 1.44k]
  ------------------
  645|  2.20k|                      ? make_leaf_pos(child, p.size()).visit(v, idx, args...)
  646|  2.20k|                      : make_regular_pos(child, p.shift() - B, p.size())
  647|  1.44k|                            .visit(v, idx, args...));
  648|  6.97k|}
_ZN5immer6detail4rbts13full_leaf_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_15get_mut_visitorISC_EEJRmRNSA_5applyIS7_E4type4editERPPSC_EEEDcT_DpOT0_:
  207|  5.54k|    {
  208|  5.54k|        return Visitor::visit_leaf(*this, std::forward<Args>(args)...);
  209|  5.54k|    }
_ZN5immer6detail4rbts8full_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_15get_mut_visitorISC_EEJRmRNSA_5applyIS7_E4type4editERPPSC_EEEDcT_DpOT0_:
 1405|  6.63k|    {
 1406|  6.63k|        return Visitor::visit_regular(*this, std::forward<Args>(args)...);
 1407|  6.63k|    }
_ZN5immer6detail4rbts8full_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE13towards_oh_chINS1_15get_mut_visitorISC_EEJRNSA_5applyIS7_E4type4editEPPSC_EEEDcT_mjjDpOT0_:
 1329|  6.63k|    {
 1330|  6.63k|        return towards_oh(v, idx, offset_hint, args...);
 1331|  6.63k|    }
_ZN5immer6detail4rbts8full_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE10towards_ohINS1_15get_mut_visitorISC_EEJRNSA_5applyIS7_E4type4editERPPSC_EEEDcT_mjDpOT0_:
 1336|  6.63k|    {
 1337|  6.63k|        assert(offset_hint == index(idx));
  ------------------
  |  Branch (1337:9): [True: 6.63k, False: 0]
  ------------------
 1338|  6.63k|        auto is_leaf = shift_ == BL;
 1339|  6.63k|        auto child   = node_->inner()[offset_hint];
 1340|  6.63k|        return is_leaf
  ------------------
  |  Branch (1340:16): [True: 3.97k, False: 2.66k]
  ------------------
 1341|  6.63k|                   ? make_full_leaf_pos(child).visit(v, idx, args...)
 1342|  6.63k|                   : make_full_pos(child, shift_ - B).visit(v, idx, args...);
 1343|  6.63k|    }
_ZN5immer6detail4rbts8leaf_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_15get_mut_visitorISC_EEJRmRNSA_5applyIS7_E4type4editERPPSC_EEEDcT_DpOT0_:
  112|  1.42k|    {
  113|  1.42k|        return Visitor::visit_leaf(*this, std::forward<Args>(args)...);
  114|  1.42k|    }
_ZN5immer6detail4rbts11regular_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_15get_mut_visitorISC_EEJRmRNSA_5applyIS7_E4type4editERPPSC_EEEDcT_DpOT0_:
  336|  2.13k|    {
  337|  2.13k|        return Visitor::visit_regular(*this, std::forward<Args>(args)...);
  338|  2.13k|    }
_ZN5immer6detail4rbts11regular_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE13towards_oh_chINS1_15get_mut_visitorISC_EEJRNSA_5applyIS7_E4type4editEPPSC_EEEDcT_mjjDpOT0_:
  316|  2.13k|    {
  317|  2.13k|        return towards_oh_ch_regular(
  318|  2.13k|            *this, v, idx, offset_hint, count(), args...);
  319|  2.13k|    }
_ZN5immer6detail4rbts21towards_oh_ch_regularIRNS1_11regular_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEENS1_15get_mut_visitorISD_EEJRNSB_5applyIS8_E4type4editERPPSD_EEEDcOT_T0_mjjDpOT1_:
  632|  2.13k|{
  633|  2.13k|    constexpr auto B  = bits<Pos>;
  634|  2.13k|    constexpr auto BL = bits_leaf<Pos>;
  635|  2.13k|    assert(offset_hint == p.index(idx));
  ------------------
  |  Branch (635:5): [True: 2.13k, False: 0]
  ------------------
  636|  2.13k|    assert(count_hint == p.count());
  ------------------
  |  Branch (636:5): [True: 2.13k, False: 0]
  ------------------
  637|  2.13k|    auto is_leaf = p.shift() == BL;
  638|  2.13k|    auto child   = p.node()->inner()[offset_hint];
  639|  2.13k|    auto is_full = offset_hint + 1 != count_hint;
  640|  2.13k|    return is_full
  ------------------
  |  Branch (640:12): [True: 780, False: 1.35k]
  ------------------
  641|  2.13k|               ? (is_leaf ? make_full_leaf_pos(child).visit(v, idx, args...)
  ------------------
  |  Branch (641:19): [True: 487, False: 293]
  ------------------
  642|    780|                          : make_full_pos(child, p.shift() - B)
  643|    293|                                .visit(v, idx, args...))
  644|  2.13k|               : (is_leaf
  ------------------
  |  Branch (644:19): [True: 662, False: 693]
  ------------------
  645|  1.35k|                      ? make_leaf_pos(child, p.size()).visit(v, idx, args...)
  646|  1.35k|                      : make_regular_pos(child, p.shift() - B, p.size())
  647|    693|                            .visit(v, idx, args...));
  648|  2.13k|}
_ZN5immer6detail4rbts15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_15get_mut_visitorISC_EEJRmRNSA_5applyIS7_E4type4editEPPSC_EEEDcT_DpOT0_:
 1036|  4.97k|    {
 1037|  4.97k|        return Visitor::visit_regular(*this, std::forward<Args>(args)...);
 1038|  4.97k|    }
_ZN5immer6detail4rbts23visit_maybe_relaxed_subINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEENS1_23slice_right_mut_visitorISC_Lb1ELb1EEEJRmRNSA_5applyIS7_E4type4editEEEEDcPT_jmT0_DpOT1_:
 1838|  68.0k|{
 1839|  68.0k|    assert(node);
  ------------------
  |  Branch (1839:5): [True: 68.0k, False: 0]
  ------------------
 1840|  68.0k|    auto relaxed = node->relaxed();
 1841|  68.0k|    if (relaxed) {
  ------------------
  |  Branch (1841:9): [True: 52.6k, False: 15.4k]
  ------------------
 1842|  52.6k|        assert(size == relaxed->d.sizes[relaxed->d.count - 1]);
  ------------------
  |  Branch (1842:9): [True: 52.6k, False: 0]
  ------------------
 1843|  52.6k|        return make_relaxed_pos(node, shift, relaxed)
 1844|  52.6k|            .visit(v, std::forward<Args>(args)...);
 1845|  52.6k|    } else {
 1846|  15.4k|        return make_regular_sub_pos(node, shift, size)
 1847|  15.4k|            .visit(v, std::forward<Args>(args)...);
 1848|  15.4k|    }
 1849|  68.0k|}
_ZN5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_23slice_right_mut_visitorISC_Lb1ELb1EEEJRmRNSA_5applyIS7_E4type4editEEEEDcT_DpOT0_:
 1813|  52.6k|    {
 1814|  52.6k|        return Visitor::visit_relaxed(*this, std::forward<Args>(args)...);
 1815|  52.6k|    }
_ZN5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE10towards_ohINS1_23slice_right_mut_visitorISC_Lb1ELb1EEEJRNSA_5applyIS7_E4type4editEEEEDcT_mjDpOT0_:
 1686|  34.6k|    {
 1687|  34.6k|        assert(offset_hint == index(idx));
  ------------------
  |  Branch (1687:9): [True: 34.6k, False: 0]
  ------------------
 1688|  34.6k|        auto left_size = offset_hint ? relaxed_->d.sizes[offset_hint - 1] : 0;
  ------------------
  |  Branch (1688:26): [True: 0, False: 34.6k]
  ------------------
 1689|  34.6k|        return towards_oh_sbh(v, idx, offset_hint, left_size, args...);
 1690|  34.6k|    }
_ZN5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE14towards_oh_sbhINS1_23slice_right_mut_visitorISC_Lb1ELb1EEEJRNSA_5applyIS7_E4type4editEEEEDcT_mjmDpOT0_:
 1698|  34.6k|    {
 1699|  34.6k|        return towards_sub_oh_sbh(v, idx, offset_hint, left_size_hint, args...);
 1700|  34.6k|    }
_ZN5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE18towards_sub_oh_sbhINS1_23slice_right_mut_visitorISC_Lb1ELb1EEEJRNSA_5applyIS7_E4type4editEEEEDcT_mjmDpOT0_:
 1717|  34.6k|    {
 1718|  34.6k|        assert(offset_hint == index(idx));
  ------------------
  |  Branch (1718:9): [True: 34.6k, False: 0]
  ------------------
 1719|  34.6k|        assert(left_size_hint ==
  ------------------
  |  Branch (1719:9): [True: 0, False: 34.6k]
  |  Branch (1719:9): [True: 34.6k, False: 0]
  ------------------
 1720|  34.6k|               (offset_hint ? relaxed_->d.sizes[offset_hint - 1] : 0));
 1721|  34.6k|        auto child     = node_->inner()[offset_hint];
 1722|  34.6k|        auto is_leaf   = shift_ == BL;
 1723|  34.6k|        auto next_size = relaxed_->d.sizes[offset_hint] - left_size_hint;
 1724|  34.6k|        auto next_idx  = idx - left_size_hint;
 1725|  34.6k|        return is_leaf
  ------------------
  |  Branch (1725:16): [True: 2.49k, False: 32.1k]
  ------------------
 1726|  34.6k|                   ? make_leaf_sub_pos(child, next_size)
 1727|  2.49k|                         .visit(v, next_idx, args...)
 1728|  34.6k|                   : visit_maybe_relaxed_sub(
 1729|  32.1k|                         child, shift_ - B, next_size, v, next_idx, args...);
 1730|  34.6k|    }
_ZN5immer6detail4rbts12leaf_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_23slice_right_mut_visitorISC_Lb1ELb1EEEJRmRNSA_5applyIS7_E4type4editEEEEDcT_DpOT0_:
  144|  2.49k|    {
  145|  2.49k|        return Visitor::visit_leaf(*this, std::forward<Args>(args)...);
  146|  2.49k|    }
_ZN5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE10towards_ohINS1_23slice_right_mut_visitorISC_Lb1ELb0EEEJRNSA_5applyIS7_E4type4editEEEEDcT_mjDpOT0_:
 1686|  38.0k|    {
 1687|  38.0k|        assert(offset_hint == index(idx));
  ------------------
  |  Branch (1687:9): [True: 38.0k, False: 0]
  ------------------
 1688|  38.0k|        auto left_size = offset_hint ? relaxed_->d.sizes[offset_hint - 1] : 0;
  ------------------
  |  Branch (1688:26): [True: 0, False: 38.0k]
  ------------------
 1689|  38.0k|        return towards_oh_sbh(v, idx, offset_hint, left_size, args...);
 1690|  38.0k|    }
_ZN5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE14towards_oh_sbhINS1_23slice_right_mut_visitorISC_Lb1ELb0EEEJRNSA_5applyIS7_E4type4editEEEEDcT_mjmDpOT0_:
 1698|  38.0k|    {
 1699|  38.0k|        return towards_sub_oh_sbh(v, idx, offset_hint, left_size_hint, args...);
 1700|  38.0k|    }
_ZN5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE18towards_sub_oh_sbhINS1_23slice_right_mut_visitorISC_Lb1ELb0EEEJRNSA_5applyIS7_E4type4editEEEEDcT_mjmDpOT0_:
 1717|  38.0k|    {
 1718|  38.0k|        assert(offset_hint == index(idx));
  ------------------
  |  Branch (1718:9): [True: 38.0k, False: 0]
  ------------------
 1719|  38.0k|        assert(left_size_hint ==
  ------------------
  |  Branch (1719:9): [True: 0, False: 38.0k]
  |  Branch (1719:9): [True: 38.0k, False: 0]
  ------------------
 1720|  38.0k|               (offset_hint ? relaxed_->d.sizes[offset_hint - 1] : 0));
 1721|  38.0k|        auto child     = node_->inner()[offset_hint];
 1722|  38.0k|        auto is_leaf   = shift_ == BL;
 1723|  38.0k|        auto next_size = relaxed_->d.sizes[offset_hint] - left_size_hint;
 1724|  38.0k|        auto next_idx  = idx - left_size_hint;
 1725|  38.0k|        return is_leaf
  ------------------
  |  Branch (1725:16): [True: 1.68k, False: 36.4k]
  ------------------
 1726|  38.0k|                   ? make_leaf_sub_pos(child, next_size)
 1727|  1.68k|                         .visit(v, next_idx, args...)
 1728|  38.0k|                   : visit_maybe_relaxed_sub(
 1729|  36.4k|                         child, shift_ - B, next_size, v, next_idx, args...);
 1730|  38.0k|    }
_ZN5immer6detail4rbts12leaf_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_23slice_right_mut_visitorISC_Lb1ELb0EEEJRmRNSA_5applyIS7_E4type4editEEEEDcT_DpOT0_:
  144|  1.68k|    {
  145|  1.68k|        return Visitor::visit_leaf(*this, std::forward<Args>(args)...);
  146|  1.68k|    }
_ZN5immer6detail4rbts23visit_maybe_relaxed_subINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEENS1_23slice_right_mut_visitorISC_Lb1ELb0EEEJRmRNSA_5applyIS7_E4type4editEEEEDcPT_jmT0_DpOT1_:
 1838|  36.4k|{
 1839|  36.4k|    assert(node);
  ------------------
  |  Branch (1839:5): [True: 36.4k, False: 0]
  ------------------
 1840|  36.4k|    auto relaxed = node->relaxed();
 1841|  36.4k|    if (relaxed) {
  ------------------
  |  Branch (1841:9): [True: 35.1k, False: 1.24k]
  ------------------
 1842|  35.1k|        assert(size == relaxed->d.sizes[relaxed->d.count - 1]);
  ------------------
  |  Branch (1842:9): [True: 35.1k, False: 0]
  ------------------
 1843|  35.1k|        return make_relaxed_pos(node, shift, relaxed)
 1844|  35.1k|            .visit(v, std::forward<Args>(args)...);
 1845|  35.1k|    } else {
 1846|  1.24k|        return make_regular_sub_pos(node, shift, size)
 1847|  1.24k|            .visit(v, std::forward<Args>(args)...);
 1848|  1.24k|    }
 1849|  36.4k|}
_ZN5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_23slice_right_mut_visitorISC_Lb1ELb0EEEJRmRNSA_5applyIS7_E4type4editEEEEDcT_DpOT0_:
 1813|  35.1k|    {
 1814|  35.1k|        return Visitor::visit_relaxed(*this, std::forward<Args>(args)...);
 1815|  35.1k|    }
_ZN5immer6detail4rbts15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_23slice_right_mut_visitorISC_Lb1ELb0EEEJRmRNSA_5applyIS7_E4type4editEEEEDcT_DpOT0_:
 1036|  1.24k|    {
 1037|  1.24k|        return Visitor::visit_regular(*this, std::forward<Args>(args)...);
 1038|  1.24k|    }
_ZN5immer6detail4rbts15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE10towards_ohINS1_23slice_right_mut_visitorISC_Lb1ELb0EEEJRNSA_5applyIS7_E4type4editEEEEDcT_mjDpOT0_:
  927|  3.75k|    {
  928|  3.75k|        return towards_oh_ch_regular(
  929|  3.75k|            *this, v, idx, offset_hint, count(), args...);
  930|  3.75k|    }
_ZN5immer6detail4rbts21towards_oh_ch_regularIRNS1_15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEENS1_23slice_right_mut_visitorISD_Lb1ELb0EEEJRNSB_5applyIS8_E4type4editEEEEDcOT_T0_mjjDpOT1_:
  632|  3.75k|{
  633|  3.75k|    constexpr auto B  = bits<Pos>;
  634|  3.75k|    constexpr auto BL = bits_leaf<Pos>;
  635|  3.75k|    assert(offset_hint == p.index(idx));
  ------------------
  |  Branch (635:5): [True: 3.75k, False: 0]
  ------------------
  636|  3.75k|    assert(count_hint == p.count());
  ------------------
  |  Branch (636:5): [True: 3.75k, False: 0]
  ------------------
  637|  3.75k|    auto is_leaf = p.shift() == BL;
  638|  3.75k|    auto child   = p.node()->inner()[offset_hint];
  639|  3.75k|    auto is_full = offset_hint + 1 != count_hint;
  640|  3.75k|    return is_full
  ------------------
  |  Branch (640:12): [True: 2.91k, False: 838]
  ------------------
  641|  3.75k|               ? (is_leaf ? make_full_leaf_pos(child).visit(v, idx, args...)
  ------------------
  |  Branch (641:19): [True: 702, False: 2.21k]
  ------------------
  642|  2.91k|                          : make_full_pos(child, p.shift() - B)
  643|  2.21k|                                .visit(v, idx, args...))
  644|  3.75k|               : (is_leaf
  ------------------
  |  Branch (644:19): [True: 838, False: 0]
  ------------------
  645|    838|                      ? make_leaf_pos(child, p.size()).visit(v, idx, args...)
  646|    838|                      : make_regular_pos(child, p.shift() - B, p.size())
  647|      0|                            .visit(v, idx, args...));
  648|  3.75k|}
_ZN5immer6detail4rbts13full_leaf_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_23slice_right_mut_visitorISC_Lb1ELb0EEEJRmRNSA_5applyIS7_E4type4editEEEEDcT_DpOT0_:
  207|  1.71k|    {
  208|  1.71k|        return Visitor::visit_leaf(*this, std::forward<Args>(args)...);
  209|  1.71k|    }
_ZN5immer6detail4rbts8full_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_23slice_right_mut_visitorISC_Lb1ELb0EEEJRmRNSA_5applyIS7_E4type4editEEEEDcT_DpOT0_:
 1405|  2.92k|    {
 1406|  2.92k|        return Visitor::visit_regular(*this, std::forward<Args>(args)...);
 1407|  2.92k|    }
_ZN5immer6detail4rbts8full_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE10towards_ohINS1_23slice_right_mut_visitorISC_Lb1ELb0EEEJRNSA_5applyIS7_E4type4editEEEEDcT_mjDpOT0_:
 1336|  1.72k|    {
 1337|  1.72k|        assert(offset_hint == index(idx));
  ------------------
  |  Branch (1337:9): [True: 1.72k, False: 0]
  ------------------
 1338|  1.72k|        auto is_leaf = shift_ == BL;
 1339|  1.72k|        auto child   = node_->inner()[offset_hint];
 1340|  1.72k|        return is_leaf
  ------------------
  |  Branch (1340:16): [True: 1.01k, False: 714]
  ------------------
 1341|  1.72k|                   ? make_full_leaf_pos(child).visit(v, idx, args...)
 1342|  1.72k|                   : make_full_pos(child, shift_ - B).visit(v, idx, args...);
 1343|  1.72k|    }
_ZN5immer6detail4rbts8full_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE10towards_ohINS1_23slice_right_mut_visitorISC_Lb0ELb1EEEJRNSA_5applyIS7_E4type4editEEEEDcT_mjDpOT0_:
 1336|  1.80k|    {
 1337|  1.80k|        assert(offset_hint == index(idx));
  ------------------
  |  Branch (1337:9): [True: 1.80k, False: 0]
  ------------------
 1338|  1.80k|        auto is_leaf = shift_ == BL;
 1339|  1.80k|        auto child   = node_->inner()[offset_hint];
 1340|  1.80k|        return is_leaf
  ------------------
  |  Branch (1340:16): [True: 959, False: 847]
  ------------------
 1341|  1.80k|                   ? make_full_leaf_pos(child).visit(v, idx, args...)
 1342|  1.80k|                   : make_full_pos(child, shift_ - B).visit(v, idx, args...);
 1343|  1.80k|    }
_ZN5immer6detail4rbts13full_leaf_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_23slice_right_mut_visitorISC_Lb0ELb1EEEJRmRNSA_5applyIS7_E4type4editEEEEDcT_DpOT0_:
  207|  2.62k|    {
  208|  2.62k|        return Visitor::visit_leaf(*this, std::forward<Args>(args)...);
  209|  2.62k|    }
_ZN5immer6detail4rbts8full_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_23slice_right_mut_visitorISC_Lb0ELb1EEEJRmRNSA_5applyIS7_E4type4editEEEEDcT_DpOT0_:
 1405|  3.13k|    {
 1406|  3.13k|        return Visitor::visit_regular(*this, std::forward<Args>(args)...);
 1407|  3.13k|    }
_ZN5immer6detail4rbts8full_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_17dec_right_visitorEJjEEEDcT_DpOT0_:
 1405|  1.95k|    {
 1406|  1.95k|        return Visitor::visit_regular(*this, std::forward<Args>(args)...);
 1407|  1.95k|    }
_ZN5immer6detail4rbts8full_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE10towards_ohINS1_23slice_right_mut_visitorISC_Lb0ELb0EEEJRNSA_5applyIS7_E4type4editEEEEDcT_mjDpOT0_:
 1336|  9.57k|    {
 1337|  9.57k|        assert(offset_hint == index(idx));
  ------------------
  |  Branch (1337:9): [True: 9.57k, False: 0]
  ------------------
 1338|  9.57k|        auto is_leaf = shift_ == BL;
 1339|  9.57k|        auto child   = node_->inner()[offset_hint];
 1340|  9.57k|        return is_leaf
  ------------------
  |  Branch (1340:16): [True: 6.62k, False: 2.95k]
  ------------------
 1341|  9.57k|                   ? make_full_leaf_pos(child).visit(v, idx, args...)
 1342|  9.57k|                   : make_full_pos(child, shift_ - B).visit(v, idx, args...);
 1343|  9.57k|    }
_ZN5immer6detail4rbts13full_leaf_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_23slice_right_mut_visitorISC_Lb0ELb0EEEJRmRNSA_5applyIS7_E4type4editEEEEDcT_DpOT0_:
  207|  8.43k|    {
  208|  8.43k|        return Visitor::visit_leaf(*this, std::forward<Args>(args)...);
  209|  8.43k|    }
_ZN5immer6detail4rbts8full_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_23slice_right_mut_visitorISC_Lb0ELb0EEEJRmRNSA_5applyIS7_E4type4editEEEEDcT_DpOT0_:
 1405|  5.31k|    {
 1406|  5.31k|        return Visitor::visit_regular(*this, std::forward<Args>(args)...);
 1407|  5.31k|    }
_ZN5immer6detail4rbts8full_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE10each_rightINS1_11dec_visitorEJEEEvT_jDpOT0_:
 1310|  1.73k|    {
 1311|  1.73k|        each_i(v, start, branches<B>, args...);
 1312|  1.73k|    }
_ZN5immer6detail4rbts8full_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE6each_iINS1_11dec_visitorEJEEEvT_jjDpOT0_:
 1263|  1.73k|    {
 1264|  1.73k|        auto p = node_->inner() + i;
 1265|  1.73k|        auto e = node_->inner() + n;
 1266|  1.73k|        if (shift_ == BL) {
  ------------------
  |  Branch (1266:13): [True: 938, False: 799]
  ------------------
 1267|  1.39k|            for (; p != e; ++p) {
  ------------------
  |  Branch (1267:20): [True: 460, False: 938]
  ------------------
 1268|    460|                IMMER_PREFETCH(p + 1);
 1269|    460|                make_full_leaf_pos(*p).visit(v, args...);
 1270|    460|            }
 1271|    938|        } else {
 1272|    799|            auto ss = shift_ - B;
 1273|  1.67k|            for (; p != e; ++p)
  ------------------
  |  Branch (1273:20): [True: 874, False: 799]
  ------------------
 1274|    874|                make_full_pos(*p, ss).visit(v, args...);
 1275|    799|        }
 1276|  1.73k|    }
_ZN5immer6detail4rbts8leaf_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_23slice_right_mut_visitorISC_Lb1ELb0EEEJRmRNSA_5applyIS7_E4type4editEEEEDcT_DpOT0_:
  112|    838|    {
  113|    838|        return Visitor::visit_leaf(*this, std::forward<Args>(args)...);
  114|    838|    }
_ZN5immer6detail4rbts11regular_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE10towards_ohINS1_23slice_right_mut_visitorISC_Lb0ELb1EEEJRNSA_5applyIS7_E4type4editEEEEDcT_mjDpOT0_:
  305|  4.03k|    {
  306|  4.03k|        return towards_oh_ch_regular(
  307|  4.03k|            *this, v, idx, offset_hint, count(), args...);
  308|  4.03k|    }
_ZN5immer6detail4rbts21towards_oh_ch_regularIRNS1_11regular_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEENS1_23slice_right_mut_visitorISD_Lb0ELb1EEEJRNSB_5applyIS8_E4type4editEEEEDcOT_T0_mjjDpOT1_:
  632|  4.03k|{
  633|  4.03k|    constexpr auto B  = bits<Pos>;
  634|  4.03k|    constexpr auto BL = bits_leaf<Pos>;
  635|  4.03k|    assert(offset_hint == p.index(idx));
  ------------------
  |  Branch (635:5): [True: 4.03k, False: 0]
  ------------------
  636|  4.03k|    assert(count_hint == p.count());
  ------------------
  |  Branch (636:5): [True: 4.03k, False: 0]
  ------------------
  637|  4.03k|    auto is_leaf = p.shift() == BL;
  638|  4.03k|    auto child   = p.node()->inner()[offset_hint];
  639|  4.03k|    auto is_full = offset_hint + 1 != count_hint;
  640|  4.03k|    return is_full
  ------------------
  |  Branch (640:12): [True: 1.60k, False: 2.42k]
  ------------------
  641|  4.03k|               ? (is_leaf ? make_full_leaf_pos(child).visit(v, idx, args...)
  ------------------
  |  Branch (641:19): [True: 846, False: 761]
  ------------------
  642|  1.60k|                          : make_full_pos(child, p.shift() - B)
  643|    761|                                .visit(v, idx, args...))
  644|  4.03k|               : (is_leaf
  ------------------
  |  Branch (644:19): [True: 1.42k, False: 995]
  ------------------
  645|  2.42k|                      ? make_leaf_pos(child, p.size()).visit(v, idx, args...)
  646|  2.42k|                      : make_regular_pos(child, p.shift() - B, p.size())
  647|    995|                            .visit(v, idx, args...));
  648|  4.03k|}
_ZN5immer6detail4rbts8leaf_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_23slice_right_mut_visitorISC_Lb0ELb1EEEJRmRNSA_5applyIS7_E4type4editEEEEDcT_DpOT0_:
  112|  2.70k|    {
  113|  2.70k|        return Visitor::visit_leaf(*this, std::forward<Args>(args)...);
  114|  2.70k|    }
_ZN5immer6detail4rbts11regular_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_23slice_right_mut_visitorISC_Lb0ELb1EEEJRmRNSA_5applyIS7_E4type4editEEEEDcT_DpOT0_:
  336|  4.55k|    {
  337|  4.55k|        return Visitor::visit_regular(*this, std::forward<Args>(args)...);
  338|  4.55k|    }
_ZN5immer6detail4rbts11regular_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_17dec_right_visitorEJjEEEDcT_DpOT0_:
  336|  1.08k|    {
  337|  1.08k|        return Visitor::visit_regular(*this, std::forward<Args>(args)...);
  338|  1.08k|    }
_ZN5immer6detail4rbts11regular_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE10towards_ohINS1_23slice_right_mut_visitorISC_Lb0ELb0EEEJRNSA_5applyIS7_E4type4editEEEEDcT_mjDpOT0_:
  305|  3.39k|    {
  306|  3.39k|        return towards_oh_ch_regular(
  307|  3.39k|            *this, v, idx, offset_hint, count(), args...);
  308|  3.39k|    }
_ZN5immer6detail4rbts21towards_oh_ch_regularIRNS1_11regular_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEENS1_23slice_right_mut_visitorISD_Lb0ELb0EEEJRNSB_5applyIS8_E4type4editEEEEDcOT_T0_mjjDpOT1_:
  632|  3.39k|{
  633|  3.39k|    constexpr auto B  = bits<Pos>;
  634|  3.39k|    constexpr auto BL = bits_leaf<Pos>;
  635|  3.39k|    assert(offset_hint == p.index(idx));
  ------------------
  |  Branch (635:5): [True: 3.39k, False: 0]
  ------------------
  636|  3.39k|    assert(count_hint == p.count());
  ------------------
  |  Branch (636:5): [True: 3.39k, False: 0]
  ------------------
  637|  3.39k|    auto is_leaf = p.shift() == BL;
  638|  3.39k|    auto child   = p.node()->inner()[offset_hint];
  639|  3.39k|    auto is_full = offset_hint + 1 != count_hint;
  640|  3.39k|    return is_full
  ------------------
  |  Branch (640:12): [True: 993, False: 2.40k]
  ------------------
  641|  3.39k|               ? (is_leaf ? make_full_leaf_pos(child).visit(v, idx, args...)
  ------------------
  |  Branch (641:19): [True: 520, False: 473]
  ------------------
  642|    993|                          : make_full_pos(child, p.shift() - B)
  643|    473|                                .visit(v, idx, args...))
  644|  3.39k|               : (is_leaf
  ------------------
  |  Branch (644:19): [True: 1.57k, False: 830]
  ------------------
  645|  2.40k|                      ? make_leaf_pos(child, p.size()).visit(v, idx, args...)
  646|  2.40k|                      : make_regular_pos(child, p.shift() - B, p.size())
  647|    830|                            .visit(v, idx, args...));
  648|  3.39k|}
_ZN5immer6detail4rbts8leaf_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_23slice_right_mut_visitorISC_Lb0ELb0EEEJRmRNSA_5applyIS7_E4type4editEEEEDcT_DpOT0_:
  112|  2.95k|    {
  113|  2.95k|        return Visitor::visit_leaf(*this, std::forward<Args>(args)...);
  114|  2.95k|    }
_ZN5immer6detail4rbts11regular_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_23slice_right_mut_visitorISC_Lb0ELb0EEEJRmRNSA_5applyIS7_E4type4editEEEEDcT_DpOT0_:
  336|  2.86k|    {
  337|  2.86k|        return Visitor::visit_regular(*this, std::forward<Args>(args)...);
  338|  2.86k|    }
_ZN5immer6detail4rbts11regular_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE10each_rightINS1_11dec_visitorEJEEEvT_jDpOT0_:
  285|  3.02k|    {
  286|  3.02k|        return each_right_regular(*this, v, start, args...);
  287|  3.02k|    }
_ZN5immer6detail4rbts18each_right_regularIRNS1_11regular_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEENS1_11dec_visitorEJEEEvOT_T0_jDpOT1_:
  597|  3.02k|{
  598|  3.02k|    constexpr auto B  = bits<Pos>;
  599|  3.02k|    constexpr auto BL = bits_leaf<Pos>;
  600|       |
  601|  3.02k|    if (p.shift() == BL) {
  ------------------
  |  Branch (601:9): [True: 1.38k, False: 1.63k]
  ------------------
  602|  1.38k|        auto n    = p.node()->inner() + start;
  603|  1.38k|        auto last = p.count() - 1;
  604|  1.38k|        auto e    = p.node()->inner() + last;
  605|  1.38k|        if (n <= e) {
  ------------------
  |  Branch (605:13): [True: 455, False: 932]
  ------------------
  606|    649|            for (; n != e; ++n) {
  ------------------
  |  Branch (606:20): [True: 194, False: 455]
  ------------------
  607|    194|                IMMER_PREFETCH(n + 1);
  608|    194|                make_full_leaf_pos(*n).visit(v, args...);
  609|    194|            }
  610|    455|            make_leaf_pos(*n, p.size()).visit(v, args...);
  611|    455|        }
  612|  1.63k|    } else {
  613|  1.63k|        auto n    = p.node()->inner() + start;
  614|  1.63k|        auto last = p.count() - 1;
  615|  1.63k|        auto e    = p.node()->inner() + last;
  616|  1.63k|        auto ss   = p.shift() - B;
  617|  1.63k|        if (n <= e) {
  ------------------
  |  Branch (617:13): [True: 744, False: 894]
  ------------------
  618|  1.44k|            for (; n != e; ++n)
  ------------------
  |  Branch (618:20): [True: 697, False: 744]
  ------------------
  619|    697|                make_full_pos(*n, ss).visit(v, args...);
  620|    744|            make_regular_pos(*n, ss, p.size()).visit(v, args...);
  621|    744|        }
  622|  1.63k|    }
  623|  3.02k|}
_ZN5immer6detail4rbts15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE10towards_ohINS1_23slice_right_mut_visitorISC_Lb0ELb1EEEJRNSA_5applyIS7_E4type4editEEEEDcT_mjDpOT0_:
  927|  7.18k|    {
  928|  7.18k|        return towards_oh_ch_regular(
  929|  7.18k|            *this, v, idx, offset_hint, count(), args...);
  930|  7.18k|    }
_ZN5immer6detail4rbts21towards_oh_ch_regularIRNS1_15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEENS1_23slice_right_mut_visitorISD_Lb0ELb1EEEJRNSB_5applyIS8_E4type4editEEEEDcOT_T0_mjjDpOT1_:
  632|  7.18k|{
  633|  7.18k|    constexpr auto B  = bits<Pos>;
  634|  7.18k|    constexpr auto BL = bits_leaf<Pos>;
  635|  7.18k|    assert(offset_hint == p.index(idx));
  ------------------
  |  Branch (635:5): [True: 7.18k, False: 0]
  ------------------
  636|  7.18k|    assert(count_hint == p.count());
  ------------------
  |  Branch (636:5): [True: 7.18k, False: 0]
  ------------------
  637|  7.18k|    auto is_leaf = p.shift() == BL;
  638|  7.18k|    auto child   = p.node()->inner()[offset_hint];
  639|  7.18k|    auto is_full = offset_hint + 1 != count_hint;
  640|  7.18k|    return is_full
  ------------------
  |  Branch (640:12): [True: 2.34k, False: 4.83k]
  ------------------
  641|  7.18k|               ? (is_leaf ? make_full_leaf_pos(child).visit(v, idx, args...)
  ------------------
  |  Branch (641:19): [True: 817, False: 1.52k]
  ------------------
  642|  2.34k|                          : make_full_pos(child, p.shift() - B)
  643|  1.52k|                                .visit(v, idx, args...))
  644|  7.18k|               : (is_leaf
  ------------------
  |  Branch (644:19): [True: 1.27k, False: 3.56k]
  ------------------
  645|  4.83k|                      ? make_leaf_pos(child, p.size()).visit(v, idx, args...)
  646|  4.83k|                      : make_regular_pos(child, p.shift() - B, p.size())
  647|  3.56k|                            .visit(v, idx, args...));
  648|  7.18k|}
_ZN5immer6detail4rbts15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE10towards_ohINS1_23slice_right_mut_visitorISC_Lb0ELb0EEEJRNSA_5applyIS7_E4type4editEEEEDcT_mjDpOT0_:
  927|  6.60k|    {
  928|  6.60k|        return towards_oh_ch_regular(
  929|  6.60k|            *this, v, idx, offset_hint, count(), args...);
  930|  6.60k|    }
_ZN5immer6detail4rbts21towards_oh_ch_regularIRNS1_15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEENS1_23slice_right_mut_visitorISD_Lb0ELb0EEEJRNSB_5applyIS8_E4type4editEEEEDcOT_T0_mjjDpOT1_:
  632|  6.60k|{
  633|  6.60k|    constexpr auto B  = bits<Pos>;
  634|  6.60k|    constexpr auto BL = bits_leaf<Pos>;
  635|  6.60k|    assert(offset_hint == p.index(idx));
  ------------------
  |  Branch (635:5): [True: 6.60k, False: 0]
  ------------------
  636|  6.60k|    assert(count_hint == p.count());
  ------------------
  |  Branch (636:5): [True: 6.60k, False: 0]
  ------------------
  637|  6.60k|    auto is_leaf = p.shift() == BL;
  638|  6.60k|    auto child   = p.node()->inner()[offset_hint];
  639|  6.60k|    auto is_full = offset_hint + 1 != count_hint;
  640|  6.60k|    return is_full
  ------------------
  |  Branch (640:12): [True: 3.18k, False: 3.42k]
  ------------------
  641|  6.60k|               ? (is_leaf ? make_full_leaf_pos(child).visit(v, idx, args...)
  ------------------
  |  Branch (641:19): [True: 1.29k, False: 1.88k]
  ------------------
  642|  3.18k|                          : make_full_pos(child, p.shift() - B)
  643|  1.88k|                                .visit(v, idx, args...))
  644|  6.60k|               : (is_leaf
  ------------------
  |  Branch (644:19): [True: 1.38k, False: 2.03k]
  ------------------
  645|  3.42k|                      ? make_leaf_pos(child, p.size()).visit(v, idx, args...)
  646|  3.42k|                      : make_regular_pos(child, p.shift() - B, p.size())
  647|  2.03k|                            .visit(v, idx, args...));
  648|  6.60k|}
_ZN5immer6detail4rbts15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE10each_rightINS1_11dec_visitorEJEEEvT_jDpOT0_:
  867|  5.43k|    {
  868|  5.43k|        return each_right_regular(*this, v, start, args...);
  869|  5.43k|    }
_ZN5immer6detail4rbts18each_right_regularIRNS1_15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEENS1_11dec_visitorEJEEEvOT_T0_jDpOT1_:
  597|  5.43k|{
  598|  5.43k|    constexpr auto B  = bits<Pos>;
  599|  5.43k|    constexpr auto BL = bits_leaf<Pos>;
  600|       |
  601|  5.43k|    if (p.shift() == BL) {
  ------------------
  |  Branch (601:9): [True: 1.47k, False: 3.96k]
  ------------------
  602|  1.47k|        auto n    = p.node()->inner() + start;
  603|  1.47k|        auto last = p.count() - 1;
  604|  1.47k|        auto e    = p.node()->inner() + last;
  605|  1.47k|        if (n <= e) {
  ------------------
  |  Branch (605:13): [True: 782, False: 692]
  ------------------
  606|    988|            for (; n != e; ++n) {
  ------------------
  |  Branch (606:20): [True: 206, False: 782]
  ------------------
  607|    206|                IMMER_PREFETCH(n + 1);
  608|    206|                make_full_leaf_pos(*n).visit(v, args...);
  609|    206|            }
  610|    782|            make_leaf_pos(*n, p.size()).visit(v, args...);
  611|    782|        }
  612|  3.96k|    } else {
  613|  3.96k|        auto n    = p.node()->inner() + start;
  614|  3.96k|        auto last = p.count() - 1;
  615|  3.96k|        auto e    = p.node()->inner() + last;
  616|  3.96k|        auto ss   = p.shift() - B;
  617|  3.96k|        if (n <= e) {
  ------------------
  |  Branch (617:13): [True: 1.35k, False: 2.60k]
  ------------------
  618|  2.13k|            for (; n != e; ++n)
  ------------------
  |  Branch (618:20): [True: 772, False: 1.35k]
  ------------------
  619|    772|                make_full_pos(*n, ss).visit(v, args...);
  620|  1.35k|            make_regular_pos(*n, ss, p.size()).visit(v, args...);
  621|  1.35k|        }
  622|  3.96k|    }
  623|  5.43k|}
_ZN5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_17dec_right_visitorEJjEEEDcT_DpOT0_:
 1813|  43.6k|    {
 1814|  43.6k|        return Visitor::visit_relaxed(*this, std::forward<Args>(args)...);
 1815|  43.6k|    }
_ZN5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE10towards_ohINS1_23slice_right_mut_visitorISC_Lb0ELb1EEEJRNSA_5applyIS7_E4type4editEEEEDcT_mjDpOT0_:
 1686|  18.3k|    {
 1687|  18.3k|        assert(offset_hint == index(idx));
  ------------------
  |  Branch (1687:9): [True: 18.3k, False: 0]
  ------------------
 1688|  18.3k|        auto left_size = offset_hint ? relaxed_->d.sizes[offset_hint - 1] : 0;
  ------------------
  |  Branch (1688:26): [True: 15.1k, False: 3.16k]
  ------------------
 1689|  18.3k|        return towards_oh_sbh(v, idx, offset_hint, left_size, args...);
 1690|  18.3k|    }
_ZN5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE14towards_oh_sbhINS1_23slice_right_mut_visitorISC_Lb0ELb1EEEJRNSA_5applyIS7_E4type4editEEEEDcT_mjmDpOT0_:
 1698|  18.3k|    {
 1699|  18.3k|        return towards_sub_oh_sbh(v, idx, offset_hint, left_size_hint, args...);
 1700|  18.3k|    }
_ZN5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE18towards_sub_oh_sbhINS1_23slice_right_mut_visitorISC_Lb0ELb1EEEJRNSA_5applyIS7_E4type4editEEEEDcT_mjmDpOT0_:
 1717|  18.3k|    {
 1718|  18.3k|        assert(offset_hint == index(idx));
  ------------------
  |  Branch (1718:9): [True: 18.3k, False: 0]
  ------------------
 1719|  18.3k|        assert(left_size_hint ==
  ------------------
  |  Branch (1719:9): [True: 15.1k, False: 3.16k]
  |  Branch (1719:9): [True: 18.3k, False: 0]
  ------------------
 1720|  18.3k|               (offset_hint ? relaxed_->d.sizes[offset_hint - 1] : 0));
 1721|  18.3k|        auto child     = node_->inner()[offset_hint];
 1722|  18.3k|        auto is_leaf   = shift_ == BL;
 1723|  18.3k|        auto next_size = relaxed_->d.sizes[offset_hint] - left_size_hint;
 1724|  18.3k|        auto next_idx  = idx - left_size_hint;
 1725|  18.3k|        return is_leaf
  ------------------
  |  Branch (1725:16): [True: 4.51k, False: 13.7k]
  ------------------
 1726|  18.3k|                   ? make_leaf_sub_pos(child, next_size)
 1727|  4.51k|                         .visit(v, next_idx, args...)
 1728|  18.3k|                   : visit_maybe_relaxed_sub(
 1729|  13.7k|                         child, shift_ - B, next_size, v, next_idx, args...);
 1730|  18.3k|    }
_ZN5immer6detail4rbts12leaf_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_23slice_right_mut_visitorISC_Lb0ELb1EEEJRmRNSA_5applyIS7_E4type4editEEEEDcT_DpOT0_:
  144|  4.51k|    {
  145|  4.51k|        return Visitor::visit_leaf(*this, std::forward<Args>(args)...);
  146|  4.51k|    }
_ZN5immer6detail4rbts23visit_maybe_relaxed_subINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEENS1_23slice_right_mut_visitorISC_Lb0ELb1EEEJRmRNSA_5applyIS7_E4type4editEEEEDcPT_jmT0_DpOT1_:
 1838|  13.7k|{
 1839|  13.7k|    assert(node);
  ------------------
  |  Branch (1839:5): [True: 13.7k, False: 0]
  ------------------
 1840|  13.7k|    auto relaxed = node->relaxed();
 1841|  13.7k|    if (relaxed) {
  ------------------
  |  Branch (1841:9): [True: 10.9k, False: 2.81k]
  ------------------
 1842|  10.9k|        assert(size == relaxed->d.sizes[relaxed->d.count - 1]);
  ------------------
  |  Branch (1842:9): [True: 10.9k, False: 0]
  ------------------
 1843|  10.9k|        return make_relaxed_pos(node, shift, relaxed)
 1844|  10.9k|            .visit(v, std::forward<Args>(args)...);
 1845|  10.9k|    } else {
 1846|  2.81k|        return make_regular_sub_pos(node, shift, size)
 1847|  2.81k|            .visit(v, std::forward<Args>(args)...);
 1848|  2.81k|    }
 1849|  13.7k|}
_ZN5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_23slice_right_mut_visitorISC_Lb0ELb1EEEJRmRNSA_5applyIS7_E4type4editEEEEDcT_DpOT0_:
 1813|  10.9k|    {
 1814|  10.9k|        return Visitor::visit_relaxed(*this, std::forward<Args>(args)...);
 1815|  10.9k|    }
_ZN5immer6detail4rbts15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_23slice_right_mut_visitorISC_Lb0ELb1EEEJRmRNSA_5applyIS7_E4type4editEEEEDcT_DpOT0_:
 1036|  2.81k|    {
 1037|  2.81k|        return Visitor::visit_regular(*this, std::forward<Args>(args)...);
 1038|  2.81k|    }
_ZN5immer6detail4rbts15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_17dec_right_visitorEJjEEEDcT_DpOT0_:
 1036|  9.88k|    {
 1037|  9.88k|        return Visitor::visit_regular(*this, std::forward<Args>(args)...);
 1038|  9.88k|    }
_ZN5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE10towards_ohINS1_23slice_right_mut_visitorISC_Lb0ELb0EEEJRNSA_5applyIS7_E4type4editEEEEDcT_mjDpOT0_:
 1686|  15.8k|    {
 1687|  15.8k|        assert(offset_hint == index(idx));
  ------------------
  |  Branch (1687:9): [True: 15.8k, False: 0]
  ------------------
 1688|  15.8k|        auto left_size = offset_hint ? relaxed_->d.sizes[offset_hint - 1] : 0;
  ------------------
  |  Branch (1688:26): [True: 11.4k, False: 4.42k]
  ------------------
 1689|  15.8k|        return towards_oh_sbh(v, idx, offset_hint, left_size, args...);
 1690|  15.8k|    }
_ZN5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE14towards_oh_sbhINS1_23slice_right_mut_visitorISC_Lb0ELb0EEEJRNSA_5applyIS7_E4type4editEEEEDcT_mjmDpOT0_:
 1698|  15.8k|    {
 1699|  15.8k|        return towards_sub_oh_sbh(v, idx, offset_hint, left_size_hint, args...);
 1700|  15.8k|    }
_ZN5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE18towards_sub_oh_sbhINS1_23slice_right_mut_visitorISC_Lb0ELb0EEEJRNSA_5applyIS7_E4type4editEEEEDcT_mjmDpOT0_:
 1717|  15.8k|    {
 1718|  15.8k|        assert(offset_hint == index(idx));
  ------------------
  |  Branch (1718:9): [True: 15.8k, False: 0]
  ------------------
 1719|  15.8k|        assert(left_size_hint ==
  ------------------
  |  Branch (1719:9): [True: 11.4k, False: 4.42k]
  |  Branch (1719:9): [True: 15.8k, False: 0]
  ------------------
 1720|  15.8k|               (offset_hint ? relaxed_->d.sizes[offset_hint - 1] : 0));
 1721|  15.8k|        auto child     = node_->inner()[offset_hint];
 1722|  15.8k|        auto is_leaf   = shift_ == BL;
 1723|  15.8k|        auto next_size = relaxed_->d.sizes[offset_hint] - left_size_hint;
 1724|  15.8k|        auto next_idx  = idx - left_size_hint;
 1725|  15.8k|        return is_leaf
  ------------------
  |  Branch (1725:16): [True: 5.84k, False: 10.0k]
  ------------------
 1726|  15.8k|                   ? make_leaf_sub_pos(child, next_size)
 1727|  5.84k|                         .visit(v, next_idx, args...)
 1728|  15.8k|                   : visit_maybe_relaxed_sub(
 1729|  10.0k|                         child, shift_ - B, next_size, v, next_idx, args...);
 1730|  15.8k|    }
_ZN5immer6detail4rbts12leaf_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_23slice_right_mut_visitorISC_Lb0ELb0EEEJRmRNSA_5applyIS7_E4type4editEEEEDcT_DpOT0_:
  144|  5.84k|    {
  145|  5.84k|        return Visitor::visit_leaf(*this, std::forward<Args>(args)...);
  146|  5.84k|    }
_ZN5immer6detail4rbts23visit_maybe_relaxed_subINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEENS1_23slice_right_mut_visitorISC_Lb0ELb0EEEJRmRNSA_5applyIS7_E4type4editEEEEDcPT_jmT0_DpOT1_:
 1838|  10.0k|{
 1839|  10.0k|    assert(node);
  ------------------
  |  Branch (1839:5): [True: 10.0k, False: 0]
  ------------------
 1840|  10.0k|    auto relaxed = node->relaxed();
 1841|  10.0k|    if (relaxed) {
  ------------------
  |  Branch (1841:9): [True: 8.14k, False: 1.87k]
  ------------------
 1842|  8.14k|        assert(size == relaxed->d.sizes[relaxed->d.count - 1]);
  ------------------
  |  Branch (1842:9): [True: 8.14k, False: 0]
  ------------------
 1843|  8.14k|        return make_relaxed_pos(node, shift, relaxed)
 1844|  8.14k|            .visit(v, std::forward<Args>(args)...);
 1845|  8.14k|    } else {
 1846|  1.87k|        return make_regular_sub_pos(node, shift, size)
 1847|  1.87k|            .visit(v, std::forward<Args>(args)...);
 1848|  1.87k|    }
 1849|  10.0k|}
_ZN5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_23slice_right_mut_visitorISC_Lb0ELb0EEEJRmRNSA_5applyIS7_E4type4editEEEEDcT_DpOT0_:
 1813|  8.14k|    {
 1814|  8.14k|        return Visitor::visit_relaxed(*this, std::forward<Args>(args)...);
 1815|  8.14k|    }
_ZN5immer6detail4rbts15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_23slice_right_mut_visitorISC_Lb0ELb0EEEJRmRNSA_5applyIS7_E4type4editEEEEDcT_DpOT0_:
 1036|  1.87k|    {
 1037|  1.87k|        return Visitor::visit_regular(*this, std::forward<Args>(args)...);
 1038|  1.87k|    }
_ZN5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE10each_rightINS1_11dec_visitorEJEEEvT_jDpOT0_:
 1653|  16.1k|    {
 1654|  16.1k|        assert(start > 0);
  ------------------
  |  Branch (1654:9): [True: 16.1k, False: 0]
  ------------------
 1655|  16.1k|        assert(start <= relaxed_->d.count);
  ------------------
  |  Branch (1655:9): [True: 16.1k, False: 0]
  ------------------
 1656|  16.1k|        auto s = relaxed_->d.sizes[start - 1];
 1657|  16.1k|        auto p = node_->inner();
 1658|  16.1k|        if (shift_ == BL) {
  ------------------
  |  Branch (1658:13): [True: 3.84k, False: 12.3k]
  ------------------
 1659|  7.45k|            for (auto i = start; i < relaxed_->d.count; ++i) {
  ------------------
  |  Branch (1659:34): [True: 3.61k, False: 3.84k]
  ------------------
 1660|  3.61k|                IMMER_PREFETCH(p + i + 1);
 1661|  3.61k|                make_leaf_sub_pos(p[i], relaxed_->d.sizes[i] - s)
 1662|  3.61k|                    .visit(v, args...);
 1663|  3.61k|                s = relaxed_->d.sizes[i];
 1664|  3.61k|                assert(s);
  ------------------
  |  Branch (1664:17): [True: 3.61k, False: 0]
  ------------------
 1665|  3.61k|            }
 1666|  12.3k|        } else {
 1667|  12.3k|            auto ss = shift_ - B;
 1668|  23.9k|            for (auto i = start; i < relaxed_->d.count; ++i) {
  ------------------
  |  Branch (1668:34): [True: 11.5k, False: 12.3k]
  ------------------
 1669|  11.5k|                visit_maybe_relaxed_sub(
 1670|  11.5k|                    p[i], ss, relaxed_->d.sizes[i] - s, v, args...);
 1671|  11.5k|                s = relaxed_->d.sizes[i];
 1672|       |                assert(s);
  ------------------
  |  Branch (1672:17): [True: 11.5k, False: 0]
  ------------------
 1673|  11.5k|            }
 1674|  12.3k|        }
 1675|  16.1k|    }
_ZN5immer6detail4rbts15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_23slice_right_mut_visitorISC_Lb1ELb1EEEJRmRNSA_5applyIS7_E4type4editEEEEDcT_DpOT0_:
 1036|  15.4k|    {
 1037|  15.4k|        return Visitor::visit_regular(*this, std::forward<Args>(args)...);
 1038|  15.4k|    }
_ZN5immer6detail4rbts15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE10towards_ohINS1_23slice_right_mut_visitorISC_Lb1ELb1EEEJRNSA_5applyIS7_E4type4editEEEEDcT_mjDpOT0_:
  927|  3.83k|    {
  928|  3.83k|        return towards_oh_ch_regular(
  929|  3.83k|            *this, v, idx, offset_hint, count(), args...);
  930|  3.83k|    }
_ZN5immer6detail4rbts21towards_oh_ch_regularIRNS1_15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEENS1_23slice_right_mut_visitorISD_Lb1ELb1EEEJRNSB_5applyIS8_E4type4editEEEEDcOT_T0_mjjDpOT1_:
  632|  3.83k|{
  633|  3.83k|    constexpr auto B  = bits<Pos>;
  634|  3.83k|    constexpr auto BL = bits_leaf<Pos>;
  635|  3.83k|    assert(offset_hint == p.index(idx));
  ------------------
  |  Branch (635:5): [True: 3.83k, False: 0]
  ------------------
  636|  3.83k|    assert(count_hint == p.count());
  ------------------
  |  Branch (636:5): [True: 3.83k, False: 0]
  ------------------
  637|  3.83k|    auto is_leaf = p.shift() == BL;
  638|  3.83k|    auto child   = p.node()->inner()[offset_hint];
  639|  3.83k|    auto is_full = offset_hint + 1 != count_hint;
  640|  3.83k|    return is_full
  ------------------
  |  Branch (640:12): [True: 3.12k, False: 713]
  ------------------
  641|  3.83k|               ? (is_leaf ? make_full_leaf_pos(child).visit(v, idx, args...)
  ------------------
  |  Branch (641:19): [True: 593, False: 2.52k]
  ------------------
  642|  3.12k|                          : make_full_pos(child, p.shift() - B)
  643|  2.52k|                                .visit(v, idx, args...))
  644|  3.83k|               : (is_leaf
  ------------------
  |  Branch (644:19): [True: 713, False: 0]
  ------------------
  645|    713|                      ? make_leaf_pos(child, p.size()).visit(v, idx, args...)
  646|    713|                      : make_regular_pos(child, p.shift() - B, p.size())
  647|      0|                            .visit(v, idx, args...));
  648|  3.83k|}
_ZN5immer6detail4rbts13full_leaf_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_23slice_right_mut_visitorISC_Lb1ELb1EEEJRmRNSA_5applyIS7_E4type4editEEEEDcT_DpOT0_:
  207|  1.38k|    {
  208|  1.38k|        return Visitor::visit_leaf(*this, std::forward<Args>(args)...);
  209|  1.38k|    }
_ZN5immer6detail4rbts8full_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_23slice_right_mut_visitorISC_Lb1ELb1EEEJRmRNSA_5applyIS7_E4type4editEEEEDcT_DpOT0_:
 1405|  2.95k|    {
 1406|  2.95k|        return Visitor::visit_regular(*this, std::forward<Args>(args)...);
 1407|  2.95k|    }
_ZN5immer6detail4rbts8full_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE10towards_ohINS1_23slice_right_mut_visitorISC_Lb1ELb1EEEJRNSA_5applyIS7_E4type4editEEEEDcT_mjDpOT0_:
 1336|  1.21k|    {
 1337|  1.21k|        assert(offset_hint == index(idx));
  ------------------
  |  Branch (1337:9): [True: 1.21k, False: 0]
  ------------------
 1338|  1.21k|        auto is_leaf = shift_ == BL;
 1339|  1.21k|        auto child   = node_->inner()[offset_hint];
 1340|  1.21k|        return is_leaf
  ------------------
  |  Branch (1340:16): [True: 792, False: 423]
  ------------------
 1341|  1.21k|                   ? make_full_leaf_pos(child).visit(v, idx, args...)
 1342|  1.21k|                   : make_full_pos(child, shift_ - B).visit(v, idx, args...);
 1343|  1.21k|    }
_ZN5immer6detail4rbts8leaf_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_23slice_right_mut_visitorISC_Lb1ELb1EEEJRmRNSA_5applyIS7_E4type4editEEEEDcT_DpOT0_:
  112|    713|    {
  113|    713|        return Visitor::visit_leaf(*this, std::forward<Args>(args)...);
  114|    713|    }
_ZN5immer6detail4rbts25singleton_regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_29concat_trees_left_mut_visitorISC_EEJRNSA_5applyIS7_E4type4editESL_NS1_14empty_leaf_posISC_EESL_RPSC_RjRmEEEDcT_DpOT0_:
  759|  7.40k|    {
  760|  7.40k|        return Visitor::visit_regular(*this, std::forward<Args>(args)...);
  761|  7.40k|    }
_ZN5immer6detail4rbts23visit_maybe_relaxed_subINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEENS1_30concat_trees_right_mut_visitorISC_EEJRNSA_5applyIS7_E4type4editESJ_RNS1_25singleton_regular_sub_posISC_EERNS1_14empty_leaf_posISC_EESJ_EEEDcPT_jmT0_DpOT1_:
 1838|  7.40k|{
 1839|  7.40k|    assert(node);
  ------------------
  |  Branch (1839:5): [True: 7.40k, False: 0]
  ------------------
 1840|  7.40k|    auto relaxed = node->relaxed();
 1841|  7.40k|    if (relaxed) {
  ------------------
  |  Branch (1841:9): [True: 4.01k, False: 3.39k]
  ------------------
 1842|  4.01k|        assert(size == relaxed->d.sizes[relaxed->d.count - 1]);
  ------------------
  |  Branch (1842:9): [True: 4.01k, False: 0]
  ------------------
 1843|  4.01k|        return make_relaxed_pos(node, shift, relaxed)
 1844|  4.01k|            .visit(v, std::forward<Args>(args)...);
 1845|  4.01k|    } else {
 1846|  3.39k|        return make_regular_sub_pos(node, shift, size)
 1847|  3.39k|            .visit(v, std::forward<Args>(args)...);
 1848|  3.39k|    }
 1849|  7.40k|}
_ZN5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_30concat_trees_right_mut_visitorISC_EEJRNSA_5applyIS7_E4type4editESL_RNS1_25singleton_regular_sub_posISC_EERNS1_14empty_leaf_posISC_EESL_EEEDcT_DpOT0_:
 1813|  4.01k|    {
 1814|  4.01k|        return Visitor::visit_relaxed(*this, std::forward<Args>(args)...);
 1815|  4.01k|    }
_ZNK5immer6detail4rbts12null_sub_pos4nodeEv:
  699|   393k|    auto node() const { return nullptr; }
_ZN5immer6detail4rbts25singleton_regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE13each_left_subINS1_25concat_merger_mut_visitorEJRNS1_17concat_merger_mutISC_EERNSA_5applyIS7_E4type4editEEEEvT_DpOT0_:
  744|  7.40k|    {
  745|  7.40k|    }
_ZN5immer6detail4rbts12leaf_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_25concat_merger_mut_visitorEJRNS1_17concat_merger_mutISC_EERNSA_5applyIS7_E4type4editEEEEDcT_DpOT0_:
  144|   559k|    {
  145|   559k|        return Visitor::visit_leaf(*this, std::forward<Args>(args)...);
  146|   559k|    }
_ZN5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_25concat_merger_mut_visitorEJRNS1_17concat_merger_mutISC_EERNSA_5applyIS7_E4type4editEEEEDcT_DpOT0_:
 1813|  2.44M|    {
 1814|  2.44M|        return Visitor::visit_relaxed(*this, std::forward<Args>(args)...);
 1815|  2.44M|    }
_ZN5immer6detail4rbts12null_sub_pos14each_right_subINS1_25concat_merger_mut_visitorEJRNS1_17concat_merger_mutINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEERNSD_5applyISA_E4type4editEEEEvT_DpOT0_:
  707|   322k|    {
  708|   322k|    }
_ZN5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE9first_subINS1_24concat_right_mut_visitorISC_EEJRNSA_5applyIS7_E4type4editESL_RNS1_25singleton_regular_sub_posISC_EERNS1_14empty_leaf_posISC_EESL_EEEDcT_DpOT0_:
 1762|  13.5k|    {
 1763|  13.5k|        auto child      = node_->inner()[0];
 1764|  13.5k|        auto child_size = relaxed_->d.sizes[0];
 1765|  13.5k|        auto is_leaf    = shift_ == BL;
 1766|  13.5k|        assert(child_size);
  ------------------
  |  Branch (1766:9): [True: 13.5k, False: 0]
  ------------------
 1767|  13.5k|        return is_leaf ? make_leaf_sub_pos(child, child_size).visit(v, args...)
  ------------------
  |  Branch (1767:16): [True: 0, False: 13.5k]
  ------------------
 1768|  13.5k|                       : visit_maybe_relaxed_sub(
 1769|  13.5k|                             child, shift_ - B, child_size, v, args...);
 1770|  13.5k|    }
_ZN5immer6detail4rbts23visit_maybe_relaxed_subINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEENS1_24concat_right_mut_visitorISC_EEJRNSA_5applyIS7_E4type4editESJ_RNS1_25singleton_regular_sub_posISC_EERNS1_14empty_leaf_posISC_EESJ_EEEDcPT_jmT0_DpOT1_:
 1838|  13.5k|{
 1839|  13.5k|    assert(node);
  ------------------
  |  Branch (1839:5): [True: 13.5k, False: 0]
  ------------------
 1840|  13.5k|    auto relaxed = node->relaxed();
 1841|  13.5k|    if (relaxed) {
  ------------------
  |  Branch (1841:9): [True: 13.2k, False: 268]
  ------------------
 1842|  13.2k|        assert(size == relaxed->d.sizes[relaxed->d.count - 1]);
  ------------------
  |  Branch (1842:9): [True: 13.2k, False: 0]
  ------------------
 1843|  13.2k|        return make_relaxed_pos(node, shift, relaxed)
 1844|  13.2k|            .visit(v, std::forward<Args>(args)...);
 1845|  13.2k|    } else {
 1846|    268|        return make_regular_sub_pos(node, shift, size)
 1847|    268|            .visit(v, std::forward<Args>(args)...);
 1848|    268|    }
 1849|  13.5k|}
_ZN5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_24concat_right_mut_visitorISC_EEJRNSA_5applyIS7_E4type4editESL_RNS1_25singleton_regular_sub_posISC_EERNS1_14empty_leaf_posISC_EESL_EEEDcT_DpOT0_:
 1813|  13.2k|    {
 1814|  13.2k|        return Visitor::visit_relaxed(*this, std::forward<Args>(args)...);
 1815|  13.2k|    }
_ZN5immer6detail4rbts15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_24concat_right_mut_visitorISC_EEJRNSA_5applyIS7_E4type4editESL_RNS1_25singleton_regular_sub_posISC_EERNS1_14empty_leaf_posISC_EESL_EEEDcT_DpOT0_:
 1036|    268|    {
 1037|    268|        return Visitor::visit_regular(*this, std::forward<Args>(args)...);
 1038|    268|    }
_ZN5immer6detail4rbts15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE9first_subINS1_24concat_right_mut_visitorISC_EEJRNSA_5applyIS7_E4type4editESL_RNS1_25singleton_regular_sub_posISC_EERNS1_14empty_leaf_posISC_EESL_EEEDcT_DpOT0_:
  970|  1.14k|    {
  971|  1.14k|        auto is_leaf = shift_ == BL;
  972|  1.14k|        auto child   = node_->inner()[0];
  973|  1.14k|        auto is_full = size_ >= (size_t{1} << shift_);
  974|  1.14k|        return is_full
  ------------------
  |  Branch (974:16): [True: 1.14k, False: 0]
  ------------------
  975|  1.14k|                   ? (is_leaf
  ------------------
  |  Branch (975:23): [True: 0, False: 1.14k]
  ------------------
  976|  1.14k|                          ? make_full_leaf_pos(child).visit(v, args...)
  977|  1.14k|                          : make_full_pos(child, shift_ - B).visit(v, args...))
  978|  1.14k|                   : (is_leaf
  ------------------
  |  Branch (978:23): [True: 0, False: 0]
  ------------------
  979|      0|                          ? make_leaf_sub_pos(child, size_).visit(v, args...)
  980|      0|                          : make_regular_sub_pos(child, shift_ - B, size_)
  981|      0|                                .visit(v, args...));
  982|  1.14k|    }
_ZN5immer6detail4rbts8full_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_24concat_right_mut_visitorISC_EEJRNSA_5applyIS7_E4type4editESL_RNS1_25singleton_regular_sub_posISC_EERNS1_14empty_leaf_posISC_EESL_EEEDcT_DpOT0_:
 1405|  1.85k|    {
 1406|  1.85k|        return Visitor::visit_regular(*this, std::forward<Args>(args)...);
 1407|  1.85k|    }
_ZN5immer6detail4rbts8full_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE9first_subINS1_24concat_right_mut_visitorISC_EEJRNSA_5applyIS7_E4type4editESL_RNS1_25singleton_regular_sub_posISC_EERNS1_14empty_leaf_posISC_EESL_EEEDcT_DpOT0_:
 1361|    711|    {
 1362|    711|        auto is_leaf = shift_ == BL;
 1363|    711|        auto child   = node_->inner()[0];
 1364|    711|        return is_leaf ? make_full_leaf_pos(child).visit(v, args...)
  ------------------
  |  Branch (1364:16): [True: 0, False: 711]
  ------------------
 1365|    711|                       : make_full_pos(child, shift_ - B).visit(v, args...);
 1366|    711|    }
_ZN5immer6detail4rbts12null_sub_pos13each_left_subINS1_25concat_merger_mut_visitorEJRNS1_17concat_merger_mutINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEERNSD_5applyISA_E4type4editEEEEvT_DpOT0_:
  711|  71.3k|    {
  712|  71.3k|    }
_ZN5immer6detail4rbts8full_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE14each_right_subINS1_25concat_merger_mut_visitorEJRNS1_17concat_merger_mutISC_EERNSA_5applyIS7_E4type4editEEEEvT_DpOT0_:
 1304|  22.8k|    {
 1305|  22.8k|        each_i(v, 1, branches<B>, args...);
 1306|  22.8k|    }
_ZN5immer6detail4rbts8full_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE6each_iINS1_25concat_merger_mut_visitorEJRNS1_17concat_merger_mutISC_EERNSA_5applyIS7_E4type4editEEEEvT_jjDpOT0_:
 1263|  22.8k|    {
 1264|  22.8k|        auto p = node_->inner() + i;
 1265|  22.8k|        auto e = node_->inner() + n;
 1266|  22.8k|        if (shift_ == BL) {
  ------------------
  |  Branch (1266:13): [True: 9.11k, False: 13.7k]
  ------------------
 1267|  36.4k|            for (; p != e; ++p) {
  ------------------
  |  Branch (1267:20): [True: 27.3k, False: 9.11k]
  ------------------
 1268|  27.3k|                IMMER_PREFETCH(p + 1);
 1269|  27.3k|                make_full_leaf_pos(*p).visit(v, args...);
 1270|  27.3k|            }
 1271|  13.7k|        } else {
 1272|  13.7k|            auto ss = shift_ - B;
 1273|  54.9k|            for (; p != e; ++p)
  ------------------
  |  Branch (1273:20): [True: 41.1k, False: 13.7k]
  ------------------
 1274|  41.1k|                make_full_pos(*p, ss).visit(v, args...);
 1275|  13.7k|        }
 1276|  22.8k|    }
_ZN5immer6detail4rbts13full_leaf_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_25concat_merger_mut_visitorEJRNS1_17concat_merger_mutISC_EERNSA_5applyIS7_E4type4editEEEEDcT_DpOT0_:
  207|  91.0k|    {
  208|  91.0k|        return Visitor::visit_leaf(*this, std::forward<Args>(args)...);
  209|  91.0k|    }
_ZN5immer6detail4rbts8full_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_25concat_merger_mut_visitorEJRNS1_17concat_merger_mutISC_EERNSA_5applyIS7_E4type4editEEEEDcT_DpOT0_:
 1405|   186k|    {
 1406|   186k|        return Visitor::visit_regular(*this, std::forward<Args>(args)...);
 1407|   186k|    }
_ZN5immer6detail4rbts25singleton_regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE8last_subINS1_23concat_both_mut_visitorISC_EEJRNSA_5applyIS7_E4type4editESL_RNS1_14empty_leaf_posISC_EESL_RNS1_8full_posISC_EEEEEDcT_DpOT0_:
  753|  1.14k|    {
  754|  1.14k|        return make_leaf_sub_pos(leaf_, count_).visit(v, args...);
  755|  1.14k|    }
_ZN5immer6detail4rbts12leaf_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_23concat_both_mut_visitorISC_EEJRNSA_5applyIS7_E4type4editESL_RNS1_14empty_leaf_posISC_EESL_RNS1_8full_posISC_EEEEEDcT_DpOT0_:
  144|  1.14k|    {
  145|  1.14k|        return Visitor::visit_leaf(*this, std::forward<Args>(args)...);
  146|  1.14k|    }
_ZN5immer6detail4rbts8full_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE14first_sub_leafINS1_24concat_right_mut_visitorISC_EEJRNSA_5applyIS7_E4type4editESL_RNS1_12leaf_sub_posISC_EERNS1_14empty_leaf_posISC_EESL_EEEDcT_DpOT0_:
 1370|  1.14k|    {
 1371|  1.14k|        assert(shift_ == BL);
  ------------------
  |  Branch (1371:9): [True: 1.14k, False: 0]
  ------------------
 1372|  1.14k|        auto child = node_->inner()[0];
 1373|  1.14k|        return make_full_leaf_pos(child).visit(v, args...);
 1374|  1.14k|    }
_ZN5immer6detail4rbts13full_leaf_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_24concat_right_mut_visitorISC_EEJRNSA_5applyIS7_E4type4editESL_RNS1_12leaf_sub_posISC_EERNS1_14empty_leaf_posISC_EESL_EEEDcT_DpOT0_:
  207|  3.66k|    {
  208|  3.66k|        return Visitor::visit_leaf(*this, std::forward<Args>(args)...);
  209|  3.66k|    }
_ZN5immer6detail4rbts15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE14each_right_subINS1_25concat_merger_mut_visitorEJRNS1_17concat_merger_mutISC_EERNSA_5applyIS7_E4type4editEEEEvT_DpOT0_:
  906|  38.6k|    {
  907|  38.6k|        if (count() > 1)
  ------------------
  |  Branch (907:13): [True: 14.6k, False: 23.9k]
  ------------------
  908|  14.6k|            each_right_sub_(v, 1, args...);
  909|  38.6k|    }
_ZN5immer6detail4rbts15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE15each_right_sub_INS1_25concat_merger_mut_visitorEJRNS1_17concat_merger_mutISC_EERNSA_5applyIS7_E4type4editEEEEvT_jDpOT0_:
  879|  14.6k|    {
  880|  14.6k|        auto last  = count() - 1;
  881|  14.6k|        auto lsize = size_ - (last << shift_);
  882|  14.6k|        auto n     = node()->inner() + i;
  883|  14.6k|        auto e     = node()->inner() + last;
  884|  14.6k|        if (shift() == BL) {
  ------------------
  |  Branch (884:13): [True: 5.57k, False: 9.11k]
  ------------------
  885|  11.3k|            for (; n != e; ++n) {
  ------------------
  |  Branch (885:20): [True: 5.78k, False: 5.57k]
  ------------------
  886|  5.78k|                IMMER_PREFETCH(n + 1);
  887|  5.78k|                make_full_leaf_pos(*n).visit(v, args...);
  888|  5.78k|            }
  889|  5.57k|            make_leaf_sub_pos(*n, lsize).visit(v, args...);
  890|  9.11k|        } else {
  891|  9.11k|            auto ss = shift_ - B;
  892|  17.4k|            for (; n != e; ++n)
  ------------------
  |  Branch (892:20): [True: 8.37k, False: 9.11k]
  ------------------
  893|  8.37k|                make_full_pos(*n, ss).visit(v, args...);
  894|  9.11k|            make_regular_sub_pos(*n, ss, lsize).visit(v, args...);
  895|  9.11k|        }
  896|  14.6k|    }
_ZN5immer6detail4rbts15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_25concat_merger_mut_visitorEJRNS1_17concat_merger_mutISC_EERNSA_5applyIS7_E4type4editEEEEDcT_DpOT0_:
 1036|   123k|    {
 1037|   123k|        return Visitor::visit_regular(*this, std::forward<Args>(args)...);
 1038|   123k|    }
_ZN5immer6detail4rbts25singleton_regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE8last_subINS1_23concat_both_mut_visitorISC_EEJRNSA_5applyIS7_E4type4editESL_RNS1_14empty_leaf_posISC_EESL_RNS1_15regular_sub_posISC_EEEEEDcT_DpOT0_:
  753|  2.52k|    {
  754|  2.52k|        return make_leaf_sub_pos(leaf_, count_).visit(v, args...);
  755|  2.52k|    }
_ZN5immer6detail4rbts12leaf_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_23concat_both_mut_visitorISC_EEJRNSA_5applyIS7_E4type4editESL_RNS1_14empty_leaf_posISC_EESL_RNS1_15regular_sub_posISC_EEEEEDcT_DpOT0_:
  144|  2.52k|    {
  145|  2.52k|        return Visitor::visit_leaf(*this, std::forward<Args>(args)...);
  146|  2.52k|    }
_ZN5immer6detail4rbts15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE14first_sub_leafINS1_24concat_right_mut_visitorISC_EEJRNSA_5applyIS7_E4type4editESL_RNS1_12leaf_sub_posISC_EERNS1_14empty_leaf_posISC_EESL_EEEDcT_DpOT0_:
  986|  2.52k|    {
  987|  2.52k|        assert(shift_ == BL);
  ------------------
  |  Branch (987:9): [True: 2.52k, False: 0]
  ------------------
  988|  2.52k|        auto child   = node_->inner()[0];
  989|  2.52k|        auto is_full = size_ >= branches<BL>;
  990|  2.52k|        return is_full ? make_full_leaf_pos(child).visit(v, args...)
  ------------------
  |  Branch (990:16): [True: 2.52k, False: 0]
  ------------------
  991|  2.52k|                       : make_leaf_sub_pos(child, size_).visit(v, args...);
  992|  2.52k|    }
_ZN5immer6detail4rbts12leaf_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_24concat_right_mut_visitorISC_EEJRNSA_5applyIS7_E4type4editESL_RSD_RNS1_14empty_leaf_posISC_EESL_EEEDcT_DpOT0_:
  144|  3.74k|    {
  145|  3.74k|        return Visitor::visit_leaf(*this, std::forward<Args>(args)...);
  146|  3.74k|    }
_ZN5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE14each_right_subINS1_25concat_merger_mut_visitorEJRNS1_17concat_merger_mutISC_EERNSA_5applyIS7_E4type4editEEEEvT_DpOT0_:
 1647|   426k|    {
 1648|   426k|        each_right(v, 1, std::forward<Args>(args)...);
 1649|   426k|    }
_ZN5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE10each_rightINS1_25concat_merger_mut_visitorEJRNS1_17concat_merger_mutISC_EERNSA_5applyIS7_E4type4editEEEEvT_jDpOT0_:
 1653|   426k|    {
 1654|   426k|        assert(start > 0);
  ------------------
  |  Branch (1654:9): [True: 426k, False: 0]
  ------------------
 1655|   426k|        assert(start <= relaxed_->d.count);
  ------------------
  |  Branch (1655:9): [True: 426k, False: 0]
  ------------------
 1656|   426k|        auto s = relaxed_->d.sizes[start - 1];
 1657|   426k|        auto p = node_->inner();
 1658|   426k|        if (shift_ == BL) {
  ------------------
  |  Branch (1658:13): [True: 68.4k, False: 357k]
  ------------------
 1659|   218k|            for (auto i = start; i < relaxed_->d.count; ++i) {
  ------------------
  |  Branch (1659:34): [True: 149k, False: 68.4k]
  ------------------
 1660|   149k|                IMMER_PREFETCH(p + i + 1);
 1661|   149k|                make_leaf_sub_pos(p[i], relaxed_->d.sizes[i] - s)
 1662|   149k|                    .visit(v, args...);
 1663|   149k|                s = relaxed_->d.sizes[i];
 1664|   149k|                assert(s);
  ------------------
  |  Branch (1664:17): [True: 149k, False: 0]
  ------------------
 1665|   149k|            }
 1666|   357k|        } else {
 1667|   357k|            auto ss = shift_ - B;
 1668|  1.15M|            for (auto i = start; i < relaxed_->d.count; ++i) {
  ------------------
  |  Branch (1668:34): [True: 798k, False: 357k]
  ------------------
 1669|   798k|                visit_maybe_relaxed_sub(
 1670|   798k|                    p[i], ss, relaxed_->d.sizes[i] - s, v, args...);
 1671|   798k|                s = relaxed_->d.sizes[i];
 1672|       |                assert(s);
  ------------------
  |  Branch (1672:17): [True: 798k, False: 0]
  ------------------
 1673|   798k|            }
 1674|   357k|        }
 1675|   426k|    }
_ZN5immer6detail4rbts23visit_maybe_relaxed_subINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEENS1_25concat_merger_mut_visitorEJRNS1_17concat_merger_mutISC_EERNSA_5applyIS7_E4type4editEEEEDcPT_jmT0_DpOT1_:
 1838|  1.52M|{
 1839|  1.52M|    assert(node);
  ------------------
  |  Branch (1839:5): [True: 1.52M, False: 0]
  ------------------
 1840|  1.52M|    auto relaxed = node->relaxed();
 1841|  1.52M|    if (relaxed) {
  ------------------
  |  Branch (1841:9): [True: 1.41M, False: 114k]
  ------------------
 1842|  1.41M|        assert(size == relaxed->d.sizes[relaxed->d.count - 1]);
  ------------------
  |  Branch (1842:9): [True: 1.41M, False: 0]
  ------------------
 1843|  1.41M|        return make_relaxed_pos(node, shift, relaxed)
 1844|  1.41M|            .visit(v, std::forward<Args>(args)...);
 1845|  1.41M|    } else {
 1846|   114k|        return make_regular_sub_pos(node, shift, size)
 1847|   114k|            .visit(v, std::forward<Args>(args)...);
 1848|   114k|    }
 1849|  1.52M|}
_ZN5immer6detail4rbts25singleton_regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE8last_subINS1_23concat_both_mut_visitorISC_EEJRNSA_5applyIS7_E4type4editESL_RNS1_14empty_leaf_posISC_EESL_RNS1_11relaxed_posISC_EEEEEDcT_DpOT0_:
  753|  3.74k|    {
  754|  3.74k|        return make_leaf_sub_pos(leaf_, count_).visit(v, args...);
  755|  3.74k|    }
_ZN5immer6detail4rbts12leaf_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_23concat_both_mut_visitorISC_EEJRNSA_5applyIS7_E4type4editESL_RNS1_14empty_leaf_posISC_EESL_RNS1_11relaxed_posISC_EEEEEDcT_DpOT0_:
  144|  3.74k|    {
  145|  3.74k|        return Visitor::visit_leaf(*this, std::forward<Args>(args)...);
  146|  3.74k|    }
_ZN5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE14first_sub_leafINS1_24concat_right_mut_visitorISC_EEJRNSA_5applyIS7_E4type4editESL_RNS1_12leaf_sub_posISC_EERNS1_14empty_leaf_posISC_EESL_EEEDcT_DpOT0_:
 1774|  3.74k|    {
 1775|  3.74k|        assert(shift_ == BL);
  ------------------
  |  Branch (1775:9): [True: 3.74k, False: 0]
  ------------------
 1776|  3.74k|        auto child      = node_->inner()[0];
 1777|  3.74k|        auto child_size = relaxed_->d.sizes[0];
 1778|  3.74k|        return make_leaf_sub_pos(child, child_size).visit(v, args...);
 1779|  3.74k|    }
_ZN5immer6detail4rbts15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_30concat_trees_right_mut_visitorISC_EEJRNSA_5applyIS7_E4type4editESL_RNS1_25singleton_regular_sub_posISC_EERNS1_14empty_leaf_posISC_EESL_EEEDcT_DpOT0_:
 1036|  3.39k|    {
 1037|  3.39k|        return Visitor::visit_regular(*this, std::forward<Args>(args)...);
 1038|  3.39k|    }
_ZN5immer6detail4rbts23visit_maybe_relaxed_subINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEENS1_29concat_trees_left_mut_visitorISC_EEJRNSA_5applyIS7_E4type4editESJ_NS1_8leaf_posISC_EESJ_RPSC_RjRmEEEDcPT_jmT0_DpOT1_:
 1838|  99.6k|{
 1839|  99.6k|    assert(node);
  ------------------
  |  Branch (1839:5): [True: 99.6k, False: 0]
  ------------------
 1840|  99.6k|    auto relaxed = node->relaxed();
 1841|  99.6k|    if (relaxed) {
  ------------------
  |  Branch (1841:9): [True: 93.3k, False: 6.37k]
  ------------------
 1842|  93.3k|        assert(size == relaxed->d.sizes[relaxed->d.count - 1]);
  ------------------
  |  Branch (1842:9): [True: 93.3k, False: 0]
  ------------------
 1843|  93.3k|        return make_relaxed_pos(node, shift, relaxed)
 1844|  93.3k|            .visit(v, std::forward<Args>(args)...);
 1845|  93.3k|    } else {
 1846|  6.37k|        return make_regular_sub_pos(node, shift, size)
 1847|  6.37k|            .visit(v, std::forward<Args>(args)...);
 1848|  6.37k|    }
 1849|  99.6k|}
_ZN5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_29concat_trees_left_mut_visitorISC_EEJRNSA_5applyIS7_E4type4editESL_NS1_8leaf_posISC_EESL_RPSC_RjRmEEEDcT_DpOT0_:
 1813|  93.3k|    {
 1814|  93.3k|        return Visitor::visit_relaxed(*this, std::forward<Args>(args)...);
 1815|  93.3k|    }
_ZN5immer6detail4rbts23visit_maybe_relaxed_subINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEENS1_30concat_trees_right_mut_visitorISC_EEJRNSA_5applyIS7_E4type4editESJ_RNS1_11relaxed_posISC_EERNS1_8leaf_posISC_EESJ_EEEDcPT_jmT0_DpOT1_:
 1838|  93.3k|{
 1839|  93.3k|    assert(node);
  ------------------
  |  Branch (1839:5): [True: 93.3k, False: 0]
  ------------------
 1840|  93.3k|    auto relaxed = node->relaxed();
 1841|  93.3k|    if (relaxed) {
  ------------------
  |  Branch (1841:9): [True: 65.6k, False: 27.6k]
  ------------------
 1842|  65.6k|        assert(size == relaxed->d.sizes[relaxed->d.count - 1]);
  ------------------
  |  Branch (1842:9): [True: 65.6k, False: 0]
  ------------------
 1843|  65.6k|        return make_relaxed_pos(node, shift, relaxed)
 1844|  65.6k|            .visit(v, std::forward<Args>(args)...);
 1845|  65.6k|    } else {
 1846|  27.6k|        return make_regular_sub_pos(node, shift, size)
 1847|  27.6k|            .visit(v, std::forward<Args>(args)...);
 1848|  27.6k|    }
 1849|  93.3k|}
_ZN5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_30concat_trees_right_mut_visitorISC_EEJRNSA_5applyIS7_E4type4editESL_RSD_RNS1_8leaf_posISC_EESL_EEEDcT_DpOT0_:
 1813|  65.6k|    {
 1814|  65.6k|        return Visitor::visit_relaxed(*this, std::forward<Args>(args)...);
 1815|  65.6k|    }
_ZN5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE8last_subINS1_23concat_left_mut_visitorISC_EEJRNSA_5applyIS7_E4type4editESL_RNS1_8leaf_posISC_EESL_RSD_EEEDcT_DpOT0_:
 1750|   201k|    {
 1751|   201k|        auto offset     = relaxed_->d.count - 1;
 1752|   201k|        auto child      = node_->inner()[offset];
 1753|   201k|        auto child_size = size(offset);
 1754|   201k|        auto is_leaf    = shift_ == BL;
 1755|   201k|        return is_leaf ? make_leaf_sub_pos(child, child_size).visit(v, args...)
  ------------------
  |  Branch (1755:16): [True: 0, False: 201k]
  ------------------
 1756|   201k|                       : visit_maybe_relaxed_sub(
 1757|   201k|                             child, shift_ - B, child_size, v, args...);
 1758|   201k|    }
_ZN5immer6detail4rbts23visit_maybe_relaxed_subINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEENS1_23concat_left_mut_visitorISC_EEJRNSA_5applyIS7_E4type4editESJ_RNS1_8leaf_posISC_EESJ_RNS1_11relaxed_posISC_EEEEEDcPT_jmT0_DpOT1_:
 1838|   201k|{
 1839|   201k|    assert(node);
  ------------------
  |  Branch (1839:5): [True: 201k, False: 0]
  ------------------
 1840|   201k|    auto relaxed = node->relaxed();
 1841|   201k|    if (relaxed) {
  ------------------
  |  Branch (1841:9): [True: 199k, False: 1.69k]
  ------------------
 1842|   199k|        assert(size == relaxed->d.sizes[relaxed->d.count - 1]);
  ------------------
  |  Branch (1842:9): [True: 199k, False: 0]
  ------------------
 1843|   199k|        return make_relaxed_pos(node, shift, relaxed)
 1844|   199k|            .visit(v, std::forward<Args>(args)...);
 1845|   199k|    } else {
 1846|  1.69k|        return make_regular_sub_pos(node, shift, size)
 1847|  1.69k|            .visit(v, std::forward<Args>(args)...);
 1848|  1.69k|    }
 1849|   201k|}
_ZN5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_23concat_left_mut_visitorISC_EEJRNSA_5applyIS7_E4type4editESL_RNS1_8leaf_posISC_EESL_RSD_EEEDcT_DpOT0_:
 1813|   199k|    {
 1814|   199k|        return Visitor::visit_relaxed(*this, std::forward<Args>(args)...);
 1815|   199k|    }
_ZN5immer6detail4rbts15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_23concat_left_mut_visitorISC_EEJRNSA_5applyIS7_E4type4editESL_RNS1_8leaf_posISC_EESL_RNS1_11relaxed_posISC_EEEEEDcT_DpOT0_:
 1036|  3.90k|    {
 1037|  3.90k|        return Visitor::visit_regular(*this, std::forward<Args>(args)...);
 1038|  3.90k|    }
_ZN5immer6detail4rbts15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE8last_subINS1_23concat_left_mut_visitorISC_EEJRNSA_5applyIS7_E4type4editESL_RNS1_8leaf_posISC_EESL_RNS1_11relaxed_posISC_EEEEEDcT_DpOT0_:
  958|  2.20k|    {
  959|  2.20k|        auto offset  = count() - 1;
  960|  2.20k|        auto child   = node_->inner()[offset];
  961|  2.20k|        auto is_leaf = shift_ == BL;
  962|  2.20k|        auto lsize   = size_ - (size_t{offset} << shift_);
  963|  2.20k|        return is_leaf ? make_leaf_sub_pos(child, lsize).visit(v, args...)
  ------------------
  |  Branch (963:16): [True: 0, False: 2.20k]
  ------------------
  964|  2.20k|                       : make_regular_sub_pos(child, shift_ - B, lsize)
  965|  2.20k|                             .visit(v, args...);
  966|  2.20k|    }
_ZN5immer6detail4rbts15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE13each_left_subINS1_25concat_merger_mut_visitorEJRNS1_17concat_merger_mutISC_EERNSA_5applyIS7_E4type4editEEEEvT_DpOT0_:
  913|   133k|    {
  914|   133k|        each_left(v, count() - 1, args...);
  915|   133k|    }
_ZN5immer6detail4rbts15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE9each_leftINS1_25concat_merger_mut_visitorEJRNS1_17concat_merger_mutISC_EERNSA_5applyIS7_E4type4editEEEEvT_jDpOT0_:
  873|   133k|    {
  874|   133k|        return each_left_regular(*this, v, last, args...);
  875|   133k|    }
_ZN5immer6detail4rbts17each_left_regularIRNS1_15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEENS1_25concat_merger_mut_visitorEJRNS1_17concat_merger_mutISD_EERNSB_5applyIS8_E4type4editEEEEvOT_T0_jDpOT1_:
  575|   133k|{
  576|   133k|    constexpr auto B  = bits<Pos>;
  577|   133k|    constexpr auto BL = bits_leaf<Pos>;
  578|   133k|    assert(last < p.count());
  ------------------
  |  Branch (578:5): [True: 133k, False: 0]
  ------------------
  579|   133k|    if (p.shift() == BL) {
  ------------------
  |  Branch (579:9): [True: 43.1k, False: 90.8k]
  ------------------
  580|  43.1k|        auto n = p.node()->inner();
  581|  43.1k|        auto e = n + last;
  582|   101k|        for (; n != e; ++n) {
  ------------------
  |  Branch (582:16): [True: 57.9k, False: 43.1k]
  ------------------
  583|  57.9k|            IMMER_PREFETCH(n + 1);
  584|  57.9k|            make_full_leaf_pos(*n).visit(v, args...);
  585|  57.9k|        }
  586|  90.8k|    } else {
  587|  90.8k|        auto n  = p.node()->inner();
  588|  90.8k|        auto e  = n + last;
  589|  90.8k|        auto ss = p.shift() - B;
  590|   227k|        for (; n != e; ++n)
  ------------------
  |  Branch (590:16): [True: 136k, False: 90.8k]
  ------------------
  591|   136k|            make_full_pos(*n, ss).visit(v, args...);
  592|  90.8k|    }
  593|   133k|}
_ZN5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE9first_subINS1_24concat_right_mut_visitorISC_EEJRNSA_5applyIS7_E4type4editESL_RNS1_15regular_sub_posISC_EERNS1_8leaf_posISC_EESL_EEEDcT_DpOT0_:
 1762|   112k|    {
 1763|   112k|        auto child      = node_->inner()[0];
 1764|   112k|        auto child_size = relaxed_->d.sizes[0];
 1765|   112k|        auto is_leaf    = shift_ == BL;
 1766|   112k|        assert(child_size);
  ------------------
  |  Branch (1766:9): [True: 112k, False: 0]
  ------------------
 1767|   112k|        return is_leaf ? make_leaf_sub_pos(child, child_size).visit(v, args...)
  ------------------
  |  Branch (1767:16): [True: 0, False: 112k]
  ------------------
 1768|   112k|                       : visit_maybe_relaxed_sub(
 1769|   112k|                             child, shift_ - B, child_size, v, args...);
 1770|   112k|    }
_ZN5immer6detail4rbts23visit_maybe_relaxed_subINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEENS1_24concat_right_mut_visitorISC_EEJRNSA_5applyIS7_E4type4editESJ_RNS1_15regular_sub_posISC_EERNS1_8leaf_posISC_EESJ_EEEDcPT_jmT0_DpOT1_:
 1838|   112k|{
 1839|   112k|    assert(node);
  ------------------
  |  Branch (1839:5): [True: 112k, False: 0]
  ------------------
 1840|   112k|    auto relaxed = node->relaxed();
 1841|   112k|    if (relaxed) {
  ------------------
  |  Branch (1841:9): [True: 109k, False: 2.91k]
  ------------------
 1842|   109k|        assert(size == relaxed->d.sizes[relaxed->d.count - 1]);
  ------------------
  |  Branch (1842:9): [True: 109k, False: 0]
  ------------------
 1843|   109k|        return make_relaxed_pos(node, shift, relaxed)
 1844|   109k|            .visit(v, std::forward<Args>(args)...);
 1845|   109k|    } else {
 1846|  2.91k|        return make_regular_sub_pos(node, shift, size)
 1847|  2.91k|            .visit(v, std::forward<Args>(args)...);
 1848|  2.91k|    }
 1849|   112k|}
_ZN5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_24concat_right_mut_visitorISC_EEJRNSA_5applyIS7_E4type4editESL_RNS1_15regular_sub_posISC_EERNS1_8leaf_posISC_EESL_EEEDcT_DpOT0_:
 1813|   109k|    {
 1814|   109k|        return Visitor::visit_relaxed(*this, std::forward<Args>(args)...);
 1815|   109k|    }
_ZN5immer6detail4rbts15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_24concat_right_mut_visitorISC_EEJRNSA_5applyIS7_E4type4editESL_RSD_RNS1_8leaf_posISC_EESL_EEEDcT_DpOT0_:
 1036|  2.91k|    {
 1037|  2.91k|        return Visitor::visit_regular(*this, std::forward<Args>(args)...);
 1038|  2.91k|    }
_ZN5immer6detail4rbts15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE8last_subINS1_23concat_left_mut_visitorISC_EEJRNSA_5applyIS7_E4type4editESL_RNS1_8leaf_posISC_EESL_RSD_EEEDcT_DpOT0_:
  958|  1.85k|    {
  959|  1.85k|        auto offset  = count() - 1;
  960|  1.85k|        auto child   = node_->inner()[offset];
  961|  1.85k|        auto is_leaf = shift_ == BL;
  962|  1.85k|        auto lsize   = size_ - (size_t{offset} << shift_);
  963|  1.85k|        return is_leaf ? make_leaf_sub_pos(child, lsize).visit(v, args...)
  ------------------
  |  Branch (963:16): [True: 0, False: 1.85k]
  ------------------
  964|  1.85k|                       : make_regular_sub_pos(child, shift_ - B, lsize)
  965|  1.85k|                             .visit(v, args...);
  966|  1.85k|    }
_ZN5immer6detail4rbts15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_23concat_left_mut_visitorISC_EEJRNSA_5applyIS7_E4type4editESL_RNS1_8leaf_posISC_EESL_RSD_EEEDcT_DpOT0_:
 1036|  2.50k|    {
 1037|  2.50k|        return Visitor::visit_regular(*this, std::forward<Args>(args)...);
 1038|  2.50k|    }
_ZN5immer6detail4rbts15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE9first_subINS1_24concat_right_mut_visitorISC_EEJRNSA_5applyIS7_E4type4editESL_RSD_RNS1_8leaf_posISC_EESL_EEEDcT_DpOT0_:
  970|  6.26k|    {
  971|  6.26k|        auto is_leaf = shift_ == BL;
  972|  6.26k|        auto child   = node_->inner()[0];
  973|  6.26k|        auto is_full = size_ >= (size_t{1} << shift_);
  974|  6.26k|        return is_full
  ------------------
  |  Branch (974:16): [True: 6.26k, False: 0]
  ------------------
  975|  6.26k|                   ? (is_leaf
  ------------------
  |  Branch (975:23): [True: 0, False: 6.26k]
  ------------------
  976|  6.26k|                          ? make_full_leaf_pos(child).visit(v, args...)
  977|  6.26k|                          : make_full_pos(child, shift_ - B).visit(v, args...))
  978|  6.26k|                   : (is_leaf
  ------------------
  |  Branch (978:23): [True: 0, False: 0]
  ------------------
  979|      0|                          ? make_leaf_sub_pos(child, size_).visit(v, args...)
  980|      0|                          : make_regular_sub_pos(child, shift_ - B, size_)
  981|      0|                                .visit(v, args...));
  982|  6.26k|    }
_ZN5immer6detail4rbts8full_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_24concat_right_mut_visitorISC_EEJRNSA_5applyIS7_E4type4editESL_RNS1_15regular_sub_posISC_EERNS1_8leaf_posISC_EESL_EEEDcT_DpOT0_:
 1405|  18.5k|    {
 1406|  18.5k|        return Visitor::visit_regular(*this, std::forward<Args>(args)...);
 1407|  18.5k|    }
_ZN5immer6detail4rbts8full_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE9first_subINS1_24concat_right_mut_visitorISC_EEJRNSA_5applyIS7_E4type4editESL_RNS1_15regular_sub_posISC_EERNS1_8leaf_posISC_EESL_EEEDcT_DpOT0_:
 1361|  12.3k|    {
 1362|  12.3k|        auto is_leaf = shift_ == BL;
 1363|  12.3k|        auto child   = node_->inner()[0];
 1364|  12.3k|        return is_leaf ? make_full_leaf_pos(child).visit(v, args...)
  ------------------
  |  Branch (1364:16): [True: 0, False: 12.3k]
  ------------------
 1365|  12.3k|                       : make_full_pos(child, shift_ - B).visit(v, args...);
 1366|  12.3k|    }
_ZN5immer6detail4rbts15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE8last_subINS1_23concat_both_mut_visitorISC_EEJRNSA_5applyIS7_E4type4editESL_RNS1_8leaf_posISC_EESL_RNS1_8full_posISC_EEEEEDcT_DpOT0_:
  958|  18.3k|    {
  959|  18.3k|        auto offset  = count() - 1;
  960|  18.3k|        auto child   = node_->inner()[offset];
  961|  18.3k|        auto is_leaf = shift_ == BL;
  962|  18.3k|        auto lsize   = size_ - (size_t{offset} << shift_);
  963|  18.3k|        return is_leaf ? make_leaf_sub_pos(child, lsize).visit(v, args...)
  ------------------
  |  Branch (963:16): [True: 6.52k, False: 11.8k]
  ------------------
  964|  18.3k|                       : make_regular_sub_pos(child, shift_ - B, lsize)
  965|  11.8k|                             .visit(v, args...);
  966|  18.3k|    }
_ZN5immer6detail4rbts12leaf_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_23concat_both_mut_visitorISC_EEJRNSA_5applyIS7_E4type4editESL_RNS1_8leaf_posISC_EESL_RNS1_8full_posISC_EEEEEDcT_DpOT0_:
  144|  7.97k|    {
  145|  7.97k|        return Visitor::visit_leaf(*this, std::forward<Args>(args)...);
  146|  7.97k|    }
_ZN5immer6detail4rbts8full_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE14first_sub_leafINS1_24concat_right_mut_visitorISC_EEJRNSA_5applyIS7_E4type4editESL_RNS1_12leaf_sub_posISC_EERNS1_8leaf_posISC_EESL_EEEDcT_DpOT0_:
 1370|  7.97k|    {
 1371|  7.97k|        assert(shift_ == BL);
  ------------------
  |  Branch (1371:9): [True: 7.97k, False: 0]
  ------------------
 1372|  7.97k|        auto child = node_->inner()[0];
 1373|  7.97k|        return make_full_leaf_pos(child).visit(v, args...);
 1374|  7.97k|    }
_ZN5immer6detail4rbts13full_leaf_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_24concat_right_mut_visitorISC_EEJRNSA_5applyIS7_E4type4editESL_RNS1_12leaf_sub_posISC_EERNS1_8leaf_posISC_EESL_EEEDcT_DpOT0_:
  207|  34.9k|    {
  208|  34.9k|        return Visitor::visit_leaf(*this, std::forward<Args>(args)...);
  209|  34.9k|    }
_ZN5immer6detail4rbts15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_23concat_both_mut_visitorISC_EEJRNSA_5applyIS7_E4type4editESL_RNS1_8leaf_posISC_EESL_RNS1_8full_posISC_EEEEEDcT_DpOT0_:
 1036|  12.0k|    {
 1037|  12.0k|        return Visitor::visit_regular(*this, std::forward<Args>(args)...);
 1038|  12.0k|    }
_ZN5immer6detail4rbts15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE8last_subINS1_23concat_both_mut_visitorISC_EEJRNSA_5applyIS7_E4type4editESL_RNS1_8leaf_posISC_EESL_RSD_EEEDcT_DpOT0_:
  958|  6.06k|    {
  959|  6.06k|        auto offset  = count() - 1;
  960|  6.06k|        auto child   = node_->inner()[offset];
  961|  6.06k|        auto is_leaf = shift_ == BL;
  962|  6.06k|        auto lsize   = size_ - (size_t{offset} << shift_);
  963|  6.06k|        return is_leaf ? make_leaf_sub_pos(child, lsize).visit(v, args...)
  ------------------
  |  Branch (963:16): [True: 3.87k, False: 2.19k]
  ------------------
  964|  6.06k|                       : make_regular_sub_pos(child, shift_ - B, lsize)
  965|  2.19k|                             .visit(v, args...);
  966|  6.06k|    }
_ZN5immer6detail4rbts12leaf_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_23concat_both_mut_visitorISC_EEJRNSA_5applyIS7_E4type4editESL_RNS1_8leaf_posISC_EESL_RNS1_15regular_sub_posISC_EEEEEDcT_DpOT0_:
  144|  26.9k|    {
  145|  26.9k|        return Visitor::visit_leaf(*this, std::forward<Args>(args)...);
  146|  26.9k|    }
_ZN5immer6detail4rbts15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE14first_sub_leafINS1_24concat_right_mut_visitorISC_EEJRNSA_5applyIS7_E4type4editESL_RNS1_12leaf_sub_posISC_EERNS1_8leaf_posISC_EESL_EEEDcT_DpOT0_:
  986|  26.9k|    {
  987|  26.9k|        assert(shift_ == BL);
  ------------------
  |  Branch (987:9): [True: 26.9k, False: 0]
  ------------------
  988|  26.9k|        auto child   = node_->inner()[0];
  989|  26.9k|        auto is_full = size_ >= branches<BL>;
  990|  26.9k|        return is_full ? make_full_leaf_pos(child).visit(v, args...)
  ------------------
  |  Branch (990:16): [True: 26.9k, False: 0]
  ------------------
  991|  26.9k|                       : make_leaf_sub_pos(child, size_).visit(v, args...);
  992|  26.9k|    }
_ZN5immer6detail4rbts12leaf_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_24concat_right_mut_visitorISC_EEJRNSA_5applyIS7_E4type4editESL_RSD_RNS1_8leaf_posISC_EESL_EEEDcT_DpOT0_:
  144|  64.7k|    {
  145|  64.7k|        return Visitor::visit_leaf(*this, std::forward<Args>(args)...);
  146|  64.7k|    }
_ZN5immer6detail4rbts15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_23concat_both_mut_visitorISC_EEJRNSA_5applyIS7_E4type4editESL_RNS1_8leaf_posISC_EESL_RSD_EEEDcT_DpOT0_:
 1036|  5.78k|    {
 1037|  5.78k|        return Visitor::visit_regular(*this, std::forward<Args>(args)...);
 1038|  5.78k|    }
_ZN5immer6detail4rbts15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE8last_subINS1_23concat_both_mut_visitorISC_EEJRNSA_5applyIS7_E4type4editESL_RNS1_8leaf_posISC_EESL_RNS1_11relaxed_posISC_EEEEEDcT_DpOT0_:
  958|   105k|    {
  959|   105k|        auto offset  = count() - 1;
  960|   105k|        auto child   = node_->inner()[offset];
  961|   105k|        auto is_leaf = shift_ == BL;
  962|   105k|        auto lsize   = size_ - (size_t{offset} << shift_);
  963|   105k|        return is_leaf ? make_leaf_sub_pos(child, lsize).visit(v, args...)
  ------------------
  |  Branch (963:16): [True: 32.8k, False: 72.7k]
  ------------------
  964|   105k|                       : make_regular_sub_pos(child, shift_ - B, lsize)
  965|  72.7k|                             .visit(v, args...);
  966|   105k|    }
_ZN5immer6detail4rbts12leaf_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_23concat_both_mut_visitorISC_EEJRNSA_5applyIS7_E4type4editESL_RNS1_8leaf_posISC_EESL_RNS1_11relaxed_posISC_EEEEEDcT_DpOT0_:
  144|  64.7k|    {
  145|  64.7k|        return Visitor::visit_leaf(*this, std::forward<Args>(args)...);
  146|  64.7k|    }
_ZN5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE14first_sub_leafINS1_24concat_right_mut_visitorISC_EEJRNSA_5applyIS7_E4type4editESL_RNS1_12leaf_sub_posISC_EERNS1_8leaf_posISC_EESL_EEEDcT_DpOT0_:
 1774|  64.7k|    {
 1775|  64.7k|        assert(shift_ == BL);
  ------------------
  |  Branch (1775:9): [True: 64.7k, False: 0]
  ------------------
 1776|  64.7k|        auto child      = node_->inner()[0];
 1777|  64.7k|        auto child_size = relaxed_->d.sizes[0];
 1778|  64.7k|        return make_leaf_sub_pos(child, child_size).visit(v, args...);
 1779|  64.7k|    }
_ZN5immer6detail4rbts15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_23concat_both_mut_visitorISC_EEJRNSA_5applyIS7_E4type4editESL_RNS1_8leaf_posISC_EESL_RNS1_11relaxed_posISC_EEEEEDcT_DpOT0_:
 1036|   103k|    {
 1037|   103k|        return Visitor::visit_regular(*this, std::forward<Args>(args)...);
 1038|   103k|    }
_ZN5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE13each_left_subINS1_25concat_merger_mut_visitorEJRNS1_17concat_merger_mutISC_EERNSA_5applyIS7_E4type4editEEEEvT_DpOT0_:
 1617|   596k|    {
 1618|   596k|        each_left(v, relaxed_->d.count - 1, args...);
 1619|   596k|    }
_ZN5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE9each_leftINS1_25concat_merger_mut_visitorEJRNS1_17concat_merger_mutISC_EERNSA_5applyIS7_E4type4editEEEEvT_jDpOT0_:
 1623|   596k|    {
 1624|   596k|        auto p = node_->inner();
 1625|   596k|        auto s = size_t{};
 1626|   596k|        if (shift_ == BL) {
  ------------------
  |  Branch (1626:13): [True: 56.5k, False: 540k]
  ------------------
 1627|   146k|            for (auto i = count_t{0}; i < n; ++i) {
  ------------------
  |  Branch (1627:39): [True: 90.1k, False: 56.5k]
  ------------------
 1628|  90.1k|                IMMER_PREFETCH(p + i + 1);
 1629|  90.1k|                make_leaf_sub_pos(p[i], relaxed_->d.sizes[i] - s)
 1630|  90.1k|                    .visit(v, args...);
 1631|  90.1k|                s = relaxed_->d.sizes[i];
 1632|  90.1k|                assert(s);
  ------------------
  |  Branch (1632:17): [True: 90.1k, False: 0]
  ------------------
 1633|  90.1k|            }
 1634|   540k|        } else {
 1635|   540k|            auto ss = shift_ - B;
 1636|  1.26M|            for (auto i = count_t{0}; i < n; ++i) {
  ------------------
  |  Branch (1636:39): [True: 725k, False: 540k]
  ------------------
 1637|   725k|                visit_maybe_relaxed_sub(
 1638|   725k|                    p[i], ss, relaxed_->d.sizes[i] - s, v, args...);
 1639|   725k|                s = relaxed_->d.sizes[i];
 1640|       |                assert(s);
  ------------------
  |  Branch (1640:17): [True: 725k, False: 0]
  ------------------
 1641|   725k|            }
 1642|   540k|        }
 1643|   596k|    }
_ZN5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE9first_subINS1_24concat_right_mut_visitorISC_EEJRNSA_5applyIS7_E4type4editESL_RSD_RNS1_8leaf_posISC_EESL_EEEDcT_DpOT0_:
 1762|   231k|    {
 1763|   231k|        auto child      = node_->inner()[0];
 1764|   231k|        auto child_size = relaxed_->d.sizes[0];
 1765|   231k|        auto is_leaf    = shift_ == BL;
 1766|   231k|        assert(child_size);
  ------------------
  |  Branch (1766:9): [True: 231k, False: 0]
  ------------------
 1767|   231k|        return is_leaf ? make_leaf_sub_pos(child, child_size).visit(v, args...)
  ------------------
  |  Branch (1767:16): [True: 0, False: 231k]
  ------------------
 1768|   231k|                       : visit_maybe_relaxed_sub(
 1769|   231k|                             child, shift_ - B, child_size, v, args...);
 1770|   231k|    }
_ZN5immer6detail4rbts23visit_maybe_relaxed_subINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEENS1_24concat_right_mut_visitorISC_EEJRNSA_5applyIS7_E4type4editESJ_RNS1_11relaxed_posISC_EERNS1_8leaf_posISC_EESJ_EEEDcPT_jmT0_DpOT1_:
 1838|   231k|{
 1839|   231k|    assert(node);
  ------------------
  |  Branch (1839:5): [True: 231k, False: 0]
  ------------------
 1840|   231k|    auto relaxed = node->relaxed();
 1841|   231k|    if (relaxed) {
  ------------------
  |  Branch (1841:9): [True: 230k, False: 1.40k]
  ------------------
 1842|   230k|        assert(size == relaxed->d.sizes[relaxed->d.count - 1]);
  ------------------
  |  Branch (1842:9): [True: 230k, False: 0]
  ------------------
 1843|   230k|        return make_relaxed_pos(node, shift, relaxed)
 1844|   230k|            .visit(v, std::forward<Args>(args)...);
 1845|   230k|    } else {
 1846|  1.40k|        return make_regular_sub_pos(node, shift, size)
 1847|  1.40k|            .visit(v, std::forward<Args>(args)...);
 1848|  1.40k|    }
 1849|   231k|}
_ZN5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_24concat_right_mut_visitorISC_EEJRNSA_5applyIS7_E4type4editESL_RSD_RNS1_8leaf_posISC_EESL_EEEDcT_DpOT0_:
 1813|   230k|    {
 1814|   230k|        return Visitor::visit_relaxed(*this, std::forward<Args>(args)...);
 1815|   230k|    }
_ZN5immer6detail4rbts15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_24concat_right_mut_visitorISC_EEJRNSA_5applyIS7_E4type4editESL_RNS1_11relaxed_posISC_EERNS1_8leaf_posISC_EESL_EEEDcT_DpOT0_:
 1036|  1.40k|    {
 1037|  1.40k|        return Visitor::visit_regular(*this, std::forward<Args>(args)...);
 1038|  1.40k|    }
_ZN5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE8last_subINS1_23concat_left_mut_visitorISC_EEJRNSA_5applyIS7_E4type4editESL_RNS1_8leaf_posISC_EESL_RNS1_15regular_sub_posISC_EEEEEDcT_DpOT0_:
 1750|   116k|    {
 1751|   116k|        auto offset     = relaxed_->d.count - 1;
 1752|   116k|        auto child      = node_->inner()[offset];
 1753|   116k|        auto child_size = size(offset);
 1754|   116k|        auto is_leaf    = shift_ == BL;
 1755|   116k|        return is_leaf ? make_leaf_sub_pos(child, child_size).visit(v, args...)
  ------------------
  |  Branch (1755:16): [True: 0, False: 116k]
  ------------------
 1756|   116k|                       : visit_maybe_relaxed_sub(
 1757|   116k|                             child, shift_ - B, child_size, v, args...);
 1758|   116k|    }
_ZN5immer6detail4rbts23visit_maybe_relaxed_subINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEENS1_23concat_left_mut_visitorISC_EEJRNSA_5applyIS7_E4type4editESJ_RNS1_8leaf_posISC_EESJ_RNS1_15regular_sub_posISC_EEEEEDcPT_jmT0_DpOT1_:
 1838|   116k|{
 1839|   116k|    assert(node);
  ------------------
  |  Branch (1839:5): [True: 116k, False: 0]
  ------------------
 1840|   116k|    auto relaxed = node->relaxed();
 1841|   116k|    if (relaxed) {
  ------------------
  |  Branch (1841:9): [True: 116k, False: 647]
  ------------------
 1842|   116k|        assert(size == relaxed->d.sizes[relaxed->d.count - 1]);
  ------------------
  |  Branch (1842:9): [True: 116k, False: 0]
  ------------------
 1843|   116k|        return make_relaxed_pos(node, shift, relaxed)
 1844|   116k|            .visit(v, std::forward<Args>(args)...);
 1845|   116k|    } else {
 1846|    647|        return make_regular_sub_pos(node, shift, size)
 1847|    647|            .visit(v, std::forward<Args>(args)...);
 1848|    647|    }
 1849|   116k|}
_ZN5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_23concat_left_mut_visitorISC_EEJRNSA_5applyIS7_E4type4editESL_RNS1_8leaf_posISC_EESL_RNS1_15regular_sub_posISC_EEEEEDcT_DpOT0_:
 1813|   116k|    {
 1814|   116k|        return Visitor::visit_relaxed(*this, std::forward<Args>(args)...);
 1815|   116k|    }
_ZN5immer6detail4rbts15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE9first_subINS1_24concat_right_mut_visitorISC_EEJRNSA_5applyIS7_E4type4editESL_RNS1_11relaxed_posISC_EERNS1_8leaf_posISC_EESL_EEEDcT_DpOT0_:
  970|  1.71k|    {
  971|  1.71k|        auto is_leaf = shift_ == BL;
  972|  1.71k|        auto child   = node_->inner()[0];
  973|  1.71k|        auto is_full = size_ >= (size_t{1} << shift_);
  974|  1.71k|        return is_full
  ------------------
  |  Branch (974:16): [True: 1.71k, False: 0]
  ------------------
  975|  1.71k|                   ? (is_leaf
  ------------------
  |  Branch (975:23): [True: 0, False: 1.71k]
  ------------------
  976|  1.71k|                          ? make_full_leaf_pos(child).visit(v, args...)
  977|  1.71k|                          : make_full_pos(child, shift_ - B).visit(v, args...))
  978|  1.71k|                   : (is_leaf
  ------------------
  |  Branch (978:23): [True: 0, False: 0]
  ------------------
  979|      0|                          ? make_leaf_sub_pos(child, size_).visit(v, args...)
  980|      0|                          : make_regular_sub_pos(child, shift_ - B, size_)
  981|      0|                                .visit(v, args...));
  982|  1.71k|    }
_ZN5immer6detail4rbts8full_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_24concat_right_mut_visitorISC_EEJRNSA_5applyIS7_E4type4editESL_RNS1_11relaxed_posISC_EERNS1_8leaf_posISC_EESL_EEEDcT_DpOT0_:
 1405|  2.40k|    {
 1406|  2.40k|        return Visitor::visit_regular(*this, std::forward<Args>(args)...);
 1407|  2.40k|    }
_ZN5immer6detail4rbts8full_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE9first_subINS1_24concat_right_mut_visitorISC_EEJRNSA_5applyIS7_E4type4editESL_RNS1_11relaxed_posISC_EERNS1_8leaf_posISC_EESL_EEEDcT_DpOT0_:
 1361|    693|    {
 1362|    693|        auto is_leaf = shift_ == BL;
 1363|    693|        auto child   = node_->inner()[0];
 1364|    693|        return is_leaf ? make_full_leaf_pos(child).visit(v, args...)
  ------------------
  |  Branch (1364:16): [True: 0, False: 693]
  ------------------
 1365|    693|                       : make_full_pos(child, shift_ - B).visit(v, args...);
 1366|    693|    }
_ZN5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE8last_subINS1_23concat_both_mut_visitorISC_EEJRNSA_5applyIS7_E4type4editESL_RNS1_8leaf_posISC_EESL_RNS1_8full_posISC_EEEEEDcT_DpOT0_:
 1750|  2.17k|    {
 1751|  2.17k|        auto offset     = relaxed_->d.count - 1;
 1752|  2.17k|        auto child      = node_->inner()[offset];
 1753|  2.17k|        auto child_size = size(offset);
 1754|  2.17k|        auto is_leaf    = shift_ == BL;
 1755|  2.17k|        return is_leaf ? make_leaf_sub_pos(child, child_size).visit(v, args...)
  ------------------
  |  Branch (1755:16): [True: 1.45k, False: 722]
  ------------------
 1756|  2.17k|                       : visit_maybe_relaxed_sub(
 1757|    722|                             child, shift_ - B, child_size, v, args...);
 1758|  2.17k|    }
_ZN5immer6detail4rbts23visit_maybe_relaxed_subINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEENS1_23concat_both_mut_visitorISC_EEJRNSA_5applyIS7_E4type4editESJ_RNS1_8leaf_posISC_EESJ_RNS1_8full_posISC_EEEEEDcPT_jmT0_DpOT1_:
 1838|    722|{
 1839|    722|    assert(node);
  ------------------
  |  Branch (1839:5): [True: 722, False: 0]
  ------------------
 1840|    722|    auto relaxed = node->relaxed();
 1841|    722|    if (relaxed) {
  ------------------
  |  Branch (1841:9): [True: 461, False: 261]
  ------------------
 1842|    461|        assert(size == relaxed->d.sizes[relaxed->d.count - 1]);
  ------------------
  |  Branch (1842:9): [True: 461, False: 0]
  ------------------
 1843|    461|        return make_relaxed_pos(node, shift, relaxed)
 1844|    461|            .visit(v, std::forward<Args>(args)...);
 1845|    461|    } else {
 1846|    261|        return make_regular_sub_pos(node, shift, size)
 1847|    261|            .visit(v, std::forward<Args>(args)...);
 1848|    261|    }
 1849|    722|}
_ZN5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_23concat_both_mut_visitorISC_EEJRNSA_5applyIS7_E4type4editESL_RNS1_8leaf_posISC_EESL_RNS1_8full_posISC_EEEEEDcT_DpOT0_:
 1813|    461|    {
 1814|    461|        return Visitor::visit_relaxed(*this, std::forward<Args>(args)...);
 1815|    461|    }
_ZN5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE8last_subINS1_23concat_both_mut_visitorISC_EEJRNSA_5applyIS7_E4type4editESL_RNS1_8leaf_posISC_EESL_RNS1_15regular_sub_posISC_EEEEEDcT_DpOT0_:
 1750|  27.6k|    {
 1751|  27.6k|        auto offset     = relaxed_->d.count - 1;
 1752|  27.6k|        auto child      = node_->inner()[offset];
 1753|  27.6k|        auto child_size = size(offset);
 1754|  27.6k|        auto is_leaf    = shift_ == BL;
 1755|  27.6k|        return is_leaf ? make_leaf_sub_pos(child, child_size).visit(v, args...)
  ------------------
  |  Branch (1755:16): [True: 23.1k, False: 4.55k]
  ------------------
 1756|  27.6k|                       : visit_maybe_relaxed_sub(
 1757|  4.55k|                             child, shift_ - B, child_size, v, args...);
 1758|  27.6k|    }
_ZN5immer6detail4rbts23visit_maybe_relaxed_subINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEENS1_23concat_both_mut_visitorISC_EEJRNSA_5applyIS7_E4type4editESJ_RNS1_8leaf_posISC_EESJ_RNS1_15regular_sub_posISC_EEEEEDcPT_jmT0_DpOT1_:
 1838|  4.55k|{
 1839|  4.55k|    assert(node);
  ------------------
  |  Branch (1839:5): [True: 4.55k, False: 0]
  ------------------
 1840|  4.55k|    auto relaxed = node->relaxed();
 1841|  4.55k|    if (relaxed) {
  ------------------
  |  Branch (1841:9): [True: 963, False: 3.59k]
  ------------------
 1842|    963|        assert(size == relaxed->d.sizes[relaxed->d.count - 1]);
  ------------------
  |  Branch (1842:9): [True: 963, False: 0]
  ------------------
 1843|    963|        return make_relaxed_pos(node, shift, relaxed)
 1844|    963|            .visit(v, std::forward<Args>(args)...);
 1845|  3.59k|    } else {
 1846|  3.59k|        return make_regular_sub_pos(node, shift, size)
 1847|  3.59k|            .visit(v, std::forward<Args>(args)...);
 1848|  3.59k|    }
 1849|  4.55k|}
_ZN5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_23concat_both_mut_visitorISC_EEJRNSA_5applyIS7_E4type4editESL_RNS1_8leaf_posISC_EESL_RNS1_15regular_sub_posISC_EEEEEDcT_DpOT0_:
 1813|    963|    {
 1814|    963|        return Visitor::visit_relaxed(*this, std::forward<Args>(args)...);
 1815|    963|    }
_ZN5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE8last_subINS1_23concat_both_mut_visitorISC_EEJRNSA_5applyIS7_E4type4editESL_RNS1_8leaf_posISC_EESL_RSD_EEEDcT_DpOT0_:
 1750|   248k|    {
 1751|   248k|        auto offset     = relaxed_->d.count - 1;
 1752|   248k|        auto child      = node_->inner()[offset];
 1753|   248k|        auto child_size = size(offset);
 1754|   248k|        auto is_leaf    = shift_ == BL;
 1755|   248k|        return is_leaf ? make_leaf_sub_pos(child, child_size).visit(v, args...)
  ------------------
  |  Branch (1755:16): [True: 31.9k, False: 217k]
  ------------------
 1756|   248k|                       : visit_maybe_relaxed_sub(
 1757|   217k|                             child, shift_ - B, child_size, v, args...);
 1758|   248k|    }
_ZN5immer6detail4rbts23visit_maybe_relaxed_subINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEENS1_23concat_both_mut_visitorISC_EEJRNSA_5applyIS7_E4type4editESJ_RNS1_8leaf_posISC_EESJ_RNS1_11relaxed_posISC_EEEEEDcPT_jmT0_DpOT1_:
 1838|   217k|{
 1839|   217k|    assert(node);
  ------------------
  |  Branch (1839:5): [True: 217k, False: 0]
  ------------------
 1840|   217k|    auto relaxed = node->relaxed();
 1841|   217k|    if (relaxed) {
  ------------------
  |  Branch (1841:9): [True: 186k, False: 30.6k]
  ------------------
 1842|   186k|        assert(size == relaxed->d.sizes[relaxed->d.count - 1]);
  ------------------
  |  Branch (1842:9): [True: 186k, False: 0]
  ------------------
 1843|   186k|        return make_relaxed_pos(node, shift, relaxed)
 1844|   186k|            .visit(v, std::forward<Args>(args)...);
 1845|   186k|    } else {
 1846|  30.6k|        return make_regular_sub_pos(node, shift, size)
 1847|  30.6k|            .visit(v, std::forward<Args>(args)...);
 1848|  30.6k|    }
 1849|   217k|}
_ZN5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_23concat_both_mut_visitorISC_EEJRNSA_5applyIS7_E4type4editESL_RNS1_8leaf_posISC_EESL_RSD_EEEDcT_DpOT0_:
 1813|   186k|    {
 1814|   186k|        return Visitor::visit_relaxed(*this, std::forward<Args>(args)...);
 1815|   186k|    }
_ZN5immer6detail4rbts15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_30concat_trees_right_mut_visitorISC_EEJRNSA_5applyIS7_E4type4editESL_RNS1_11relaxed_posISC_EERNS1_8leaf_posISC_EESL_EEEDcT_DpOT0_:
 1036|  27.6k|    {
 1037|  27.6k|        return Visitor::visit_regular(*this, std::forward<Args>(args)...);
 1038|  27.6k|    }
_ZN5immer6detail4rbts15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_29concat_trees_left_mut_visitorISC_EEJRNSA_5applyIS7_E4type4editESL_NS1_8leaf_posISC_EESL_RPSC_RjRmEEEDcT_DpOT0_:
 1036|  6.37k|    {
 1037|  6.37k|        return Visitor::visit_regular(*this, std::forward<Args>(args)...);
 1038|  6.37k|    }
_ZN5immer6detail4rbts23visit_maybe_relaxed_subINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEENS1_30concat_trees_right_mut_visitorISC_EEJRNSA_5applyIS7_E4type4editESJ_RNS1_15regular_sub_posISC_EERNS1_8leaf_posISC_EESJ_EEEDcPT_jmT0_DpOT1_:
 1838|  6.37k|{
 1839|  6.37k|    assert(node);
  ------------------
  |  Branch (1839:5): [True: 6.37k, False: 0]
  ------------------
 1840|  6.37k|    auto relaxed = node->relaxed();
 1841|  6.37k|    if (relaxed) {
  ------------------
  |  Branch (1841:9): [True: 3.39k, False: 2.97k]
  ------------------
 1842|  3.39k|        assert(size == relaxed->d.sizes[relaxed->d.count - 1]);
  ------------------
  |  Branch (1842:9): [True: 3.39k, False: 0]
  ------------------
 1843|  3.39k|        return make_relaxed_pos(node, shift, relaxed)
 1844|  3.39k|            .visit(v, std::forward<Args>(args)...);
 1845|  3.39k|    } else {
 1846|  2.97k|        return make_regular_sub_pos(node, shift, size)
 1847|  2.97k|            .visit(v, std::forward<Args>(args)...);
 1848|  2.97k|    }
 1849|  6.37k|}
_ZN5immer6detail4rbts11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_30concat_trees_right_mut_visitorISC_EEJRNSA_5applyIS7_E4type4editESL_RNS1_15regular_sub_posISC_EERNS1_8leaf_posISC_EESL_EEEDcT_DpOT0_:
 1813|  3.39k|    {
 1814|  3.39k|        return Visitor::visit_relaxed(*this, std::forward<Args>(args)...);
 1815|  3.39k|    }
_ZN5immer6detail4rbts15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEE5visitINS1_30concat_trees_right_mut_visitorISC_EEJRNSA_5applyIS7_E4type4editESL_RSD_RNS1_8leaf_posISC_EESL_EEEDcT_DpOT0_:
 1036|  2.97k|    {
 1037|  2.97k|        return Visitor::visit_regular(*this, std::forward<Args>(args)...);
 1038|  2.97k|    }

_ZN5immer6detail4rbts7rrbtreeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEC2Ev:
  114|   375k|        : size{0}
  115|   375k|        , shift{BL}
  116|   375k|        , root{empty_root()}
  117|   375k|        , tail{empty_tail()}
  118|   375k|    {
  119|       |        assert(check_tree());
  ------------------
  |  Branch (119:9): [True: 375k, False: 0]
  ------------------
  120|   375k|    }
_ZN5immer6detail4rbts7rrbtreeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE10empty_rootEv:
   61|   391k|    {
   62|   391k|        static const auto empty_ = [] {
   63|   391k|            constexpr auto size = node_t::sizeof_inner_n(0);
   64|   391k|            static std::aligned_storage_t<size, alignof(std::max_align_t)>
   65|   391k|                storage;
   66|   391k|            return node_t::make_inner_n_into(&storage, size, 0u);
   67|   391k|        }();
   68|   391k|        return empty_->inc();
   69|   391k|    }
_ZZN5immer6detail4rbts7rrbtreeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE10empty_rootEvENKUlvE_clEv:
   62|      1|        static const auto empty_ = [] {
   63|      1|            constexpr auto size = node_t::sizeof_inner_n(0);
   64|      1|            static std::aligned_storage_t<size, alignof(std::max_align_t)>
   65|      1|                storage;
   66|      1|            return node_t::make_inner_n_into(&storage, size, 0u);
   67|      1|        }();
_ZN5immer6detail4rbts7rrbtreeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE10empty_tailEv:
   72|   379k|    {
   73|   379k|        static const auto empty_ = [] {
   74|   379k|            constexpr auto size = node_t::sizeof_leaf_n(0);
   75|   379k|            static std::aligned_storage_t<size, alignof(std::max_align_t)>
   76|   379k|                storage;
   77|   379k|            return node_t::make_leaf_n_into(&storage, size, 0u);
   78|   379k|        }();
   79|   379k|        return empty_->inc();
   80|   379k|    }
_ZZN5immer6detail4rbts7rrbtreeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE10empty_tailEvENKUlvE_clEv:
   73|      1|        static const auto empty_ = [] {
   74|      1|            constexpr auto size = node_t::sizeof_leaf_n(0);
   75|      1|            static std::aligned_storage_t<size, alignof(std::max_align_t)>
   76|      1|                storage;
   77|      1|            return node_t::make_leaf_n_into(&storage, size, 0u);
   78|      1|        }();
_ZNK5immer6detail4rbts7rrbtreeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE10check_treeEv:
 1372|   949k|    {
 1373|   949k|        IMMER_INVALID_STATE_ASSERT(shift <= sizeof(size_t) * 8 - BL);
  ------------------
  |  |   32|   949k|    if (!(expr))                                                               \
  |  |  ------------------
  |  |  |  Branch (32:9): [True: 0, False: 949k]
  |  |  ------------------
  |  |   33|   949k|    IMMER_THROW(invalid_tree{})
  |  |  ------------------
  |  |  |  |   51|      0|#define IMMER_THROW(expr) throw expr
  |  |  ------------------
  ------------------
 1374|   949k|        IMMER_INVALID_STATE_ASSERT(shift >= BL);
  ------------------
  |  |   32|   949k|    if (!(expr))                                                               \
  |  |  ------------------
  |  |  |  Branch (32:9): [True: 0, False: 949k]
  |  |  ------------------
  |  |   33|   949k|    IMMER_THROW(invalid_tree{})
  |  |  ------------------
  |  |  |  |   51|      0|#define IMMER_THROW(expr) throw expr
  |  |  ------------------
  ------------------
 1375|   949k|        IMMER_INVALID_STATE_ASSERT(tail_offset() <= size);
  ------------------
  |  |   32|   949k|    if (!(expr))                                                               \
  |  |  ------------------
  |  |  |  Branch (32:9): [True: 0, False: 949k]
  |  |  ------------------
  |  |   33|   949k|    IMMER_THROW(invalid_tree{})
  |  |  ------------------
  |  |  |  |   51|      0|#define IMMER_THROW(expr) throw expr
  |  |  ------------------
  ------------------
 1376|   949k|        IMMER_INVALID_STATE_ASSERT(tail_size() <= branches<BL>);
  ------------------
  |  |   32|   949k|    if (!(expr))                                                               \
  |  |  ------------------
  |  |  |  Branch (32:9): [True: 0, False: 949k]
  |  |  ------------------
  |  |   33|   949k|    IMMER_THROW(invalid_tree{})
  |  |  ------------------
  |  |  |  |   51|      0|#define IMMER_THROW(expr) throw expr
  |  |  ------------------
  ------------------
 1377|       |#if IMMER_DEBUG_DEEP_CHECK
 1378|       |        IMMER_INVALID_STATE_ASSERT(check_root());
 1379|       |        IMMER_INVALID_STATE_ASSERT(check_tail());
 1380|       |#endif
 1381|   949k|        return true;
 1382|   949k|    }
_ZNK5immer6detail4rbts7rrbtreeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE11tail_offsetEv:
  197|  6.97M|    {
  198|  6.97M|        auto r = root->relaxed();
  199|  6.97M|        assert(r == nullptr || r->d.count);
  ------------------
  |  Branch (199:9): [True: 4.53M, False: 2.43M]
  |  Branch (199:9): [True: 2.43M, False: 0]
  |  Branch (199:9): [True: 6.97M, False: 0]
  ------------------
  200|  6.97M|        return r      ? r->d.sizes[r->d.count - 1]
  ------------------
  |  Branch (200:16): [True: 2.43M, False: 4.53M]
  ------------------
  201|  6.97M|               : size ? (size - 1) & ~mask<BL>
  ------------------
  |  Branch (201:18): [True: 3.34M, False: 1.18M]
  ------------------
  202|       |                      /* otherwise */
  203|  4.53M|                      : 0;
  204|  6.97M|    }
_ZNK5immer6detail4rbts7rrbtreeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE9tail_sizeEv:
  194|  1.06M|    auto tail_size() const { return size - tail_offset(); }
_ZN5immer6detail4rbts7rrbtreeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EED2Ev:
  184|   688k|    ~rrbtree() { dec(); }
_ZNK5immer6detail4rbts7rrbtreeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE3decEv:
  192|   688k|    void dec() const { traverse(dec_visitor()); }
_ZNK5immer6detail4rbts7rrbtreeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE8traverseINS1_11dec_visitorEJEEEvT_DpOT0_:
  208|   688k|    {
  209|   688k|        auto tail_off  = tail_offset();
  210|   688k|        auto tail_size = size - tail_off;
  211|       |
  212|   688k|        if (tail_off)
  ------------------
  |  Branch (212:13): [True: 248k, False: 440k]
  ------------------
  213|   248k|            visit_maybe_relaxed_sub(root, shift, tail_off, v, args...);
  214|   440k|        else
  215|   440k|            make_empty_regular_pos(root).visit(v, args...);
  216|       |
  217|   688k|        if (tail_size)
  ------------------
  |  Branch (217:13): [True: 299k, False: 389k]
  ------------------
  218|   299k|            make_leaf_sub_pos(tail, tail_size).visit(v, args...);
  219|   389k|        else
  220|   389k|            make_empty_leaf_pos(tail).visit(v, args...);
  221|   688k|    }
_ZN5immer6detail4rbts7rrbtreeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEC2ERKSB_:
  151|   148k|        : rrbtree{other.size, other.shift, other.root, other.tail}
  152|   148k|    {
  153|   148k|        inc();
  154|   148k|    }
_ZN5immer6detail4rbts7rrbtreeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEC2EmjPNS1_4nodeIiSA_Lj2ELj2EEESE_:
  127|   313k|        : size{sz}
  128|   313k|        , shift{sh}
  129|   313k|        , root{r}
  130|   313k|        , tail{t}
  131|   313k|    {
  132|   313k|#if IMMER_THROW_ON_INVALID_STATE
  133|       |        // assert only happens in the Debug build, but when
  134|       |        // IMMER_THROW_ON_INVALID_STATE is activated, we want to just check_tree
  135|       |        // even in Release.
  136|   313k|        try {
  137|   313k|            check_tree();
  138|   313k|        } catch (...) {
  139|       |            // This not fully constructed rrbtree owns the nodes already, have
  140|       |            // to dec them.
  141|      0|            if (r && t)
  ------------------
  |  Branch (141:17): [True: 0, False: 0]
  |  Branch (141:22): [True: 0, False: 0]
  ------------------
  142|      0|                dec();
  143|      0|            throw;
  144|      0|        }
  145|       |#else
  146|       |        assert(check_tree());
  147|       |#endif
  148|   313k|    }
_ZNK5immer6detail4rbts7rrbtreeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE3incEv:
  187|   148k|    {
  188|   148k|        root->inc();
  189|   148k|        tail->inc();
  190|   148k|    }
_ZN5immer6detail4rbts7rrbtreeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEC2EOSB_:
  157|   300k|        : rrbtree{}
  158|   300k|    {
  159|   300k|        swap(*this, other);
  160|   300k|    }
_ZN5immer6detail4rbts4swapERNS1_7rrbtreeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEESC_:
  176|   626k|    {
  177|   626k|        using std::swap;
  178|   626k|        swap(x.size, y.size);
  179|   626k|        swap(x.shift, y.shift);
  180|   626k|        swap(x.root, y.root);
  181|   626k|        swap(x.tail, y.tail);
  182|   626k|    }
_ZN5immer6detail4rbts7rrbtreeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEaSEOSB_:
  170|   319k|    {
  171|   319k|        swap(*this, other);
  172|   319k|        return *this;
  173|   319k|    }
_ZNK5immer6detail4rbts7rrbtreeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE9push_backEi:
  500|  67.5k|    {
  501|  67.5k|        auto ts = tail_size();
  502|  67.5k|        if (ts < branches<BL>) {
  ------------------
  |  Branch (502:13): [True: 50.4k, False: 17.1k]
  ------------------
  503|  50.4k|            auto new_tail =
  504|  50.4k|                node_t::copy_leaf_emplace(tail, ts, std::move(value));
  505|  50.4k|            return {size + 1, shift, root->inc(), new_tail};
  506|  50.4k|        } else {
  507|  17.1k|            using std::get;
  508|  17.1k|            auto new_tail = node_t::make_leaf_n(1u, std::move(value));
  509|  17.1k|            auto tail_off = tail_offset();
  510|  17.1k|            IMMER_TRY {
  ------------------
  |  |   49|  17.1k|#define IMMER_TRY try
  ------------------
  511|  17.1k|                auto new_root =
  512|  17.1k|                    push_tail(root, shift, tail_off, tail, size - tail_off);
  513|  17.1k|                tail->inc();
  514|  17.1k|                return {size + 1, get<0>(new_root), get<1>(new_root), new_tail};
  515|  17.1k|            }
  516|  17.1k|            IMMER_CATCH (...) {
  517|      0|                node_t::delete_leaf(new_tail, 1u);
  518|      0|                IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
  519|      0|            }
  520|  17.1k|        }
  521|  67.5k|    }
_ZNK5immer6detail4rbts7rrbtreeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE9push_tailEPNS1_4nodeIiSA_Lj2ELj2EEEjmSE_j:
  369|  25.4k|    {
  370|  25.4k|        if (auto r = root->relaxed()) {
  ------------------
  |  Branch (370:18): [True: 13.1k, False: 12.3k]
  ------------------
  371|  13.1k|            auto new_root =
  372|  13.1k|                make_relaxed_pos(root, shift, r)
  373|  13.1k|                    .visit(push_tail_visitor<node_t>{}, tail, tail_size);
  374|  13.1k|            if (new_root)
  ------------------
  |  Branch (374:17): [True: 12.5k, False: 613]
  ------------------
  375|  12.5k|                return std::make_tuple(shift, new_root);
  376|    613|            else {
  377|    613|                auto new_root = node_t::make_inner_r_n(2);
  378|    613|                IMMER_TRY {
  ------------------
  |  |   49|    613|#define IMMER_TRY try
  ------------------
  379|    613|                    auto new_path        = node_t::make_path(shift, tail);
  380|    613|                    new_root->inner()[0] = root->inc();
  381|    613|                    new_root->inner()[1] = new_path;
  382|    613|                    new_root->relaxed()->d.sizes[0] = size;
  383|    613|                    new_root->relaxed()->d.sizes[1] = size + tail_size;
  384|    613|                    assert(size);
  ------------------
  |  Branch (384:21): [True: 613, False: 0]
  ------------------
  385|    613|                    assert(tail_size);
  ------------------
  |  Branch (385:21): [True: 613, False: 0]
  ------------------
  386|    613|                    new_root->relaxed()->d.count = 2u;
  387|    613|                }
  388|    613|                IMMER_CATCH (...) {
  389|      0|                    node_t::delete_inner_r(new_root, 2);
  390|      0|                    IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
  391|      0|                }
  392|    613|                return std::make_tuple(shift + B, new_root);
  393|    613|            }
  394|  13.1k|        } else if (size == size_t{branches<B>} << shift) {
  ------------------
  |  Branch (394:20): [True: 997, False: 11.3k]
  ------------------
  395|    997|            auto new_root = node_t::make_inner_n(2);
  396|    997|            IMMER_TRY {
  ------------------
  |  |   49|    997|#define IMMER_TRY try
  ------------------
  397|    997|                auto new_path        = node_t::make_path(shift, tail);
  398|    997|                new_root->inner()[0] = root->inc();
  399|    997|                new_root->inner()[1] = new_path;
  400|    997|            }
  401|    997|            IMMER_CATCH (...) {
  402|      0|                node_t::delete_inner(new_root, 2);
  403|      0|                IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
  404|      0|            }
  405|    997|            return std::make_tuple(shift + B, new_root);
  406|  11.3k|        } else if (size) {
  ------------------
  |  Branch (406:20): [True: 4.86k, False: 6.51k]
  ------------------
  407|  4.86k|            auto new_root = make_regular_sub_pos(root, shift, size)
  408|  4.86k|                                .visit(push_tail_visitor<node_t>{}, tail);
  409|  4.86k|            return std::make_tuple(shift, new_root);
  410|  6.51k|        } else {
  411|  6.51k|            return std::make_tuple(shift, node_t::make_path(shift, tail));
  412|  6.51k|        }
  413|  25.4k|    }
flex-vector-gc.cpp:_ZNK5immer6detail4rbts7rrbtreeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE6updateIZZ22LLVMFuzzerTestOneInputENK3$_5clI12fuzzer_inputEEDaRT_EUlSG_E_EESB_mOSG_:
  580|  5.60k|    {
  581|  5.60k|        auto tail_off = tail_offset();
  582|  5.60k|        if (idx >= tail_off) {
  ------------------
  |  Branch (582:13): [True: 591, False: 5.01k]
  ------------------
  583|    591|            auto tail_size = size - tail_off;
  584|    591|            auto new_tail =
  585|    591|                make_leaf_sub_pos(tail, tail_size)
  586|    591|                    .visit(update_visitor<node_t>{}, idx - tail_off, fn);
  587|    591|            return {size, shift, root->inc(), new_tail};
  588|  5.01k|        } else {
  589|  5.01k|            auto new_root = visit_maybe_relaxed_sub(
  590|  5.01k|                root, shift, tail_off, update_visitor<node_t>{}, idx, fn);
  591|  5.01k|            return {size, shift, new_root, tail->inc()};
  592|  5.01k|        }
  593|  5.60k|    }
_ZNK5immer6detail4rbts7rrbtreeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE4takeEm:
  647|  12.5k|    {
  648|  12.5k|        auto tail_off = tail_offset();
  649|  12.5k|        if (new_size == 0) {
  ------------------
  |  Branch (649:13): [True: 1.60k, False: 10.9k]
  ------------------
  650|  1.60k|            return {};
  651|  10.9k|        } else if (new_size >= size) {
  ------------------
  |  Branch (651:20): [True: 355, False: 10.6k]
  ------------------
  652|    355|            return *this;
  653|  10.6k|        } else if (new_size > tail_off) {
  ------------------
  |  Branch (653:20): [True: 270, False: 10.3k]
  ------------------
  654|    270|            auto new_tail = node_t::copy_leaf(tail, new_size - tail_off);
  655|    270|            return {new_size, shift, root->inc(), new_tail};
  656|  10.3k|        } else {
  657|  10.3k|            using std::get;
  658|  10.3k|            auto l = new_size - 1;
  659|  10.3k|            auto v = slice_right_visitor<node_t>();
  660|  10.3k|            auto r = visit_maybe_relaxed_sub(root, shift, tail_off, v, l);
  661|  10.3k|            auto new_shift = get<0>(r);
  662|  10.3k|            auto new_root  = get<1>(r);
  663|  10.3k|            auto new_tail  = get<3>(r);
  664|  10.3k|            if (new_root) {
  ------------------
  |  Branch (664:17): [True: 7.84k, False: 2.52k]
  ------------------
  665|  7.84k|                IMMER_ASSERT_TAGGED(new_root->compute_shift() == get<0>(r));
  ------------------
  |  |   68|  7.84k|#define IMMER_ASSERT_TAGGED(assertion) assert(assertion)
  ------------------
  |  Branch (665:17): [True: 7.84k, False: 0]
  ------------------
  666|  7.84k|                assert(new_root->check(new_shift, new_size - get<2>(r)));
  ------------------
  |  Branch (666:17): [True: 7.84k, False: 0]
  ------------------
  667|  7.84k|                return {new_size, new_shift, new_root, new_tail};
  668|  7.84k|            } else {
  669|  2.52k|                return {new_size, BL, empty_root(), new_tail};
  670|  2.52k|            }
  671|  10.3k|        }
  672|  12.5k|    }
_ZNK5immer6detail4rbts7rrbtreeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE4dropEm:
  711|  18.0k|    {
  712|  18.0k|        if (elems == 0) {
  ------------------
  |  Branch (712:13): [True: 1.44k, False: 16.6k]
  ------------------
  713|  1.44k|            return *this;
  714|  16.6k|        } else if (elems >= size) {
  ------------------
  |  Branch (714:20): [True: 213, False: 16.4k]
  ------------------
  715|    213|            return {};
  716|  16.4k|        } else if (elems == tail_offset()) {
  ------------------
  |  Branch (716:20): [True: 200, False: 16.2k]
  ------------------
  717|    200|            return {size - elems, BL, empty_root(), tail->inc()};
  718|  16.2k|        } else if (elems > tail_offset()) {
  ------------------
  |  Branch (718:20): [True: 481, False: 15.7k]
  ------------------
  719|    481|            auto tail_off = tail_offset();
  720|    481|            auto new_tail =
  721|    481|                node_t::copy_leaf(tail, elems - tail_off, size - tail_off);
  722|    481|            return {size - elems, BL, empty_root(), new_tail};
  723|  15.7k|        } else {
  724|  15.7k|            using std::get;
  725|  15.7k|            auto v = slice_left_visitor<node_t>();
  726|  15.7k|            auto r =
  727|  15.7k|                visit_maybe_relaxed_sub(root, shift, tail_offset(), v, elems);
  728|  15.7k|            auto new_root  = get<1>(r);
  729|  15.7k|            auto new_shift = get<0>(r);
  730|  15.7k|            return {size - elems, new_shift, new_root, tail->inc()};
  731|  15.7k|        }
  732|  18.0k|    }
_ZN5immer6detail4rbts7rrbtreeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE8max_sizeEv:
   54|  1.99M|    {
   55|  1.99M|        auto S = sizeof(size_t) * 8;
   56|  1.99M|        return ((size_t{1} << BL) - std::min(size_t{BL}, size_t{2})) *
   57|  1.99M|               ipow((size_t{1} << B) - 2, (S - BL) / B);
   58|  1.99M|    }
_ZNK5immer6detail4rbts7rrbtreeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE6concatERKSB_:
  735|  57.8k|    {
  736|  57.8k|        assert(r.size + size <= max_size());
  ------------------
  |  Branch (736:9): [True: 57.8k, False: 0]
  ------------------
  737|  57.8k|        using std::get;
  738|  57.8k|        if (size == 0)
  ------------------
  |  Branch (738:13): [True: 760, False: 57.0k]
  ------------------
  739|    760|            return r;
  740|  57.0k|        else if (r.size == 0)
  ------------------
  |  Branch (740:18): [True: 343, False: 56.7k]
  ------------------
  741|    343|            return *this;
  742|  56.7k|        else if (r.tail_offset() == 0) {
  ------------------
  |  Branch (742:18): [True: 6.45k, False: 50.2k]
  ------------------
  743|       |            // just concat the tail, similar to push_back
  744|  6.45k|            auto tail_offst = tail_offset();
  745|  6.45k|            auto tail_size  = size - tail_offst;
  746|  6.45k|            if (tail_size == branches<BL>) {
  ------------------
  |  Branch (746:17): [True: 2.40k, False: 4.05k]
  ------------------
  747|  2.40k|                auto new_root =
  748|  2.40k|                    push_tail(root, shift, tail_offst, tail, tail_size);
  749|  2.40k|                tail->inc();
  750|  2.40k|                return {size + r.size,
  751|  2.40k|                        get<0>(new_root),
  752|  2.40k|                        get<1>(new_root),
  753|  2.40k|                        r.tail->inc()};
  754|  4.05k|            } else if (tail_size + r.size <= branches<BL>) {
  ------------------
  |  Branch (754:24): [True: 2.46k, False: 1.58k]
  ------------------
  755|  2.46k|                auto new_tail =
  756|  2.46k|                    node_t::copy_leaf(tail, tail_size, r.tail, r.size);
  757|  2.46k|                return {size + r.size, shift, root->inc(), new_tail};
  758|  2.46k|            } else {
  759|  1.58k|                auto remaining = branches<BL> - tail_size;
  760|  1.58k|                auto add_tail =
  761|  1.58k|                    node_t::copy_leaf(tail, tail_size, r.tail, remaining);
  762|  1.58k|                IMMER_TRY {
  ------------------
  |  |   49|  1.58k|#define IMMER_TRY try
  ------------------
  763|  1.58k|                    auto new_tail =
  764|  1.58k|                        node_t::copy_leaf(r.tail, remaining, r.size);
  765|  1.58k|                    IMMER_TRY {
  ------------------
  |  |   49|  1.58k|#define IMMER_TRY try
  ------------------
  766|  1.58k|                        auto new_root = push_tail(
  767|  1.58k|                            root, shift, tail_offst, add_tail, branches<BL>);
  768|  1.58k|                        return {size + r.size,
  769|  1.58k|                                get<0>(new_root),
  770|  1.58k|                                get<1>(new_root),
  771|  1.58k|                                new_tail};
  772|  1.58k|                    }
  773|  1.58k|                    IMMER_CATCH (...) {
  774|      0|                        node_t::delete_leaf(new_tail, r.size - remaining);
  775|      0|                        IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
  776|      0|                    }
  777|  1.58k|                }
  778|  1.58k|                IMMER_CATCH (...) {
  779|      0|                    node_t::delete_leaf(add_tail, branches<BL>);
  780|      0|                    IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
  781|      0|                }
  782|  1.58k|            }
  783|  50.2k|        } else if (tail_offset() == 0) {
  ------------------
  |  Branch (783:20): [True: 3.06k, False: 47.2k]
  ------------------
  784|  3.06k|            auto tail_offst = tail_offset();
  785|  3.06k|            auto tail_size  = size - tail_offst;
  786|  3.06k|            auto concated =
  787|  3.06k|                concat_trees(tail, tail_size, r.root, r.shift, r.tail_offset());
  788|  3.06k|            auto new_shift = concated.shift();
  789|  3.06k|            auto new_root  = concated.node();
  790|  3.06k|            IMMER_ASSERT_TAGGED(new_shift == new_root->compute_shift());
  ------------------
  |  |   68|  3.06k|#define IMMER_ASSERT_TAGGED(assertion) assert(assertion)
  ------------------
  |  Branch (790:13): [True: 3.06k, False: 0]
  ------------------
  791|  3.06k|            assert(new_root->check(new_shift, size + r.tail_offset()));
  ------------------
  |  Branch (791:13): [True: 3.06k, False: 0]
  ------------------
  792|  3.06k|            return {size + r.size, new_shift, new_root, r.tail->inc()};
  793|  47.2k|        } else {
  794|  47.2k|            auto tail_offst = tail_offset();
  795|  47.2k|            auto tail_size  = size - tail_offst;
  796|  47.2k|            auto concated   = concat_trees(root,
  797|  47.2k|                                         shift,
  798|  47.2k|                                         tail_offst,
  799|  47.2k|                                         tail,
  800|  47.2k|                                         tail_size,
  801|  47.2k|                                         r.root,
  802|  47.2k|                                         r.shift,
  803|  47.2k|                                         r.tail_offset());
  804|  47.2k|            auto new_shift  = concated.shift();
  805|  47.2k|            auto new_root   = concated.node();
  806|  47.2k|            IMMER_ASSERT_TAGGED(new_shift == new_root->compute_shift());
  ------------------
  |  |   68|  47.2k|#define IMMER_ASSERT_TAGGED(assertion) assert(assertion)
  ------------------
  |  Branch (806:13): [True: 47.2k, False: 0]
  ------------------
  807|  47.2k|            assert(new_root->check(new_shift, size + r.tail_offset()));
  ------------------
  |  Branch (807:13): [True: 47.2k, False: 0]
  ------------------
  808|  47.2k|            return {size + r.size, new_shift, new_root, r.tail->inc()};
  809|  47.2k|        }
  810|  57.8k|    }
_ZN5immer6detail4rbts7rrbtreeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE13push_back_mutENS9_5applyIS6_E4type4editEi:
  478|  49.0k|    {
  479|  49.0k|        auto ts = tail_size();
  480|  49.0k|        if (ts < branches<BL>) {
  ------------------
  |  Branch (480:13): [True: 31.8k, False: 17.1k]
  ------------------
  481|  31.8k|            ensure_mutable_tail(e, ts);
  482|  31.8k|            new (&tail->leaf()[ts]) T(std::move(value));
  483|  31.8k|        } else {
  484|  17.1k|            using std::get;
  485|  17.1k|            auto new_tail = node_t::make_leaf_e(e, std::move(value));
  486|  17.1k|            auto tail_off = tail_offset();
  487|  17.1k|            IMMER_TRY {
  ------------------
  |  |   49|  17.1k|#define IMMER_TRY try
  ------------------
  488|  17.1k|                push_tail_mut(e, tail_off, tail, ts);
  489|  17.1k|                tail = new_tail;
  490|  17.1k|            }
  491|  17.1k|            IMMER_CATCH (...) {
  492|      0|                node_t::delete_leaf(new_tail, 1u);
  493|      0|                IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
  494|      0|            }
  495|  17.1k|        }
  496|  49.0k|        ++size;
  497|  49.0k|    }
_ZN5immer6detail4rbts7rrbtreeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE19ensure_mutable_tailENS9_5applyIS6_E4type4editEj:
  469|  1.36M|    {
  470|  1.36M|        if (!tail->can_mutate(e)) {
  ------------------
  |  Branch (470:13): [True: 26.6k, False: 1.33M]
  ------------------
  471|  26.6k|            auto new_tail = node_t::copy_leaf_e(e, tail, n);
  472|  26.6k|            dec_leaf(tail, n);
  473|  26.6k|            tail = new_tail;
  474|  26.6k|        }
  475|  1.36M|    }
_ZN5immer6detail4rbts7rrbtreeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE13push_tail_mutENS9_5applyIS6_E4type4editEmPNS1_4nodeIiSA_Lj2ELj2EEEj:
  417|  1.70M|    {
  418|  1.70M|        if (auto r = root->relaxed()) {
  ------------------
  |  Branch (418:18): [True: 681k, False: 1.02M]
  ------------------
  419|   681k|            auto new_root =
  420|   681k|                make_relaxed_pos(root, shift, r)
  421|   681k|                    .visit(push_tail_mut_visitor<node_t>{}, e, tail, tail_size);
  422|   681k|            if (new_root) {
  ------------------
  |  Branch (422:17): [True: 679k, False: 1.46k]
  ------------------
  423|   679k|                root = new_root;
  424|   679k|            } else {
  425|  1.46k|                auto new_root = node_t::make_inner_r_e(e);
  426|  1.46k|                IMMER_TRY {
  ------------------
  |  |   49|  1.46k|#define IMMER_TRY try
  ------------------
  427|  1.46k|                    auto new_path        = node_t::make_path_e(e, shift, tail);
  428|  1.46k|                    new_root->inner()[0] = root;
  429|  1.46k|                    new_root->inner()[1] = new_path;
  430|  1.46k|                    new_root->relaxed()->d.sizes[0] = tail_off;
  431|  1.46k|                    new_root->relaxed()->d.sizes[1] = tail_off + tail_size;
  432|  1.46k|                    assert(tail_off);
  ------------------
  |  Branch (432:21): [True: 1.46k, False: 0]
  ------------------
  433|  1.46k|                    assert(tail_size);
  ------------------
  |  Branch (433:21): [True: 1.46k, False: 0]
  ------------------
  434|  1.46k|                    new_root->relaxed()->d.count = 2u;
  435|  1.46k|                    root                         = new_root;
  436|  1.46k|                    shift += B;
  437|  1.46k|                }
  438|  1.46k|                IMMER_CATCH (...) {
  439|      0|                    node_t::delete_inner_r_e(new_root);
  440|      0|                    IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
  441|      0|                }
  442|  1.46k|            }
  443|  1.02M|        } else if (tail_off == size_t{branches<B>} << shift) {
  ------------------
  |  Branch (443:20): [True: 5.13k, False: 1.02M]
  ------------------
  444|  5.13k|            auto new_root = node_t::make_inner_e(e);
  445|  5.13k|            IMMER_TRY {
  ------------------
  |  |   49|  5.13k|#define IMMER_TRY try
  ------------------
  446|  5.13k|                auto new_path        = node_t::make_path_e(e, shift, tail);
  447|  5.13k|                new_root->inner()[0] = root;
  448|  5.13k|                new_root->inner()[1] = new_path;
  449|  5.13k|                root                 = new_root;
  450|  5.13k|                shift += B;
  451|  5.13k|            }
  452|  5.13k|            IMMER_CATCH (...) {
  453|      0|                node_t::delete_inner_e(new_root);
  454|      0|                IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
  455|      0|            }
  456|  1.02M|        } else if (tail_off) {
  ------------------
  |  Branch (456:20): [True: 1.01M, False: 5.07k]
  ------------------
  457|  1.01M|            auto new_root =
  458|  1.01M|                make_regular_sub_pos(root, shift, tail_off)
  459|  1.01M|                    .visit(push_tail_mut_visitor<node_t>{}, e, tail);
  460|  1.01M|            root = new_root;
  461|  1.01M|        } else {
  462|  5.07k|            auto new_root = node_t::make_path_e(e, shift, tail);
  463|  5.07k|            dec_empty_regular(root);
  464|  5.07k|            root = new_root;
  465|  5.07k|        }
  466|  1.70M|    }
flex-vector-gc.cpp:_ZN5immer6detail4rbts7rrbtreeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE10update_mutIZZ22LLVMFuzzerTestOneInputENK3$_5clI12fuzzer_inputEEDaRT_EUlSG_E0_EEvNS9_5applyIS6_E4type4editEmOSG_:
  573|  11.4k|    {
  574|  11.4k|        auto& elem = get_mut(e, idx);
  575|  11.4k|        elem       = std::forward<FnT>(fn)(std::move(elem));
  576|  11.4k|    }
_ZN5immer6detail4rbts7rrbtreeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE7get_mutENS9_5applyIS6_E4type4editEm:
  539|  11.4k|    {
  540|  11.4k|        auto tail_off = tail_offset();
  541|  11.4k|        if (idx >= tail_off) {
  ------------------
  |  Branch (541:13): [True: 846, False: 10.6k]
  ------------------
  542|    846|            ensure_mutable_tail(e, size - tail_off);
  543|    846|            return tail->leaf()[(idx - tail_off) & mask<BL>];
  544|  10.6k|        } else {
  545|  10.6k|            return visit_maybe_relaxed_sub(root,
  546|  10.6k|                                           shift,
  547|  10.6k|                                           tail_off,
  548|  10.6k|                                           get_mut_visitor<node_t>{},
  549|  10.6k|                                           idx,
  550|  10.6k|                                           e,
  551|  10.6k|                                           &root);
  552|  10.6k|        }
  553|  11.4k|    }
_ZN5immer6detail4rbts7rrbtreeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE8take_mutENS9_5applyIS6_E4type4editEm:
  606|  40.4k|    {
  607|  40.4k|        auto tail_off = tail_offset();
  608|  40.4k|        if (new_size == 0) {
  ------------------
  |  Branch (608:13): [True: 846, False: 39.5k]
  ------------------
  609|    846|            *this = {};
  610|  39.5k|        } else if (new_size >= size) {
  ------------------
  |  Branch (610:20): [True: 2.94k, False: 36.6k]
  ------------------
  611|  2.94k|            return;
  612|  36.6k|        } else if (new_size > tail_off) {
  ------------------
  |  Branch (612:20): [True: 733, False: 35.9k]
  ------------------
  613|    733|            auto ts    = size - tail_off;
  614|    733|            auto newts = new_size - tail_off;
  615|    733|            if (tail->can_mutate(e)) {
  ------------------
  |  Branch (615:17): [True: 428, False: 305]
  ------------------
  616|    428|                detail::destroy_n(tail->leaf() + newts, ts - newts);
  617|    428|            } else {
  618|    305|                auto new_tail = node_t::copy_leaf_e(e, tail, newts);
  619|    305|                dec_leaf(tail, ts);
  620|    305|                tail = new_tail;
  621|    305|            }
  622|    733|            size = new_size;
  623|    733|            return;
  624|  35.9k|        } else {
  625|  35.9k|            using std::get;
  626|  35.9k|            auto l = new_size - 1;
  627|  35.9k|            auto v = slice_right_mut_visitor<node_t>();
  628|  35.9k|            auto r = visit_maybe_relaxed_sub(root, shift, tail_off, v, l, e);
  629|  35.9k|            auto new_shift = get<0>(r);
  630|  35.9k|            auto new_root  = get<1>(r);
  631|  35.9k|            auto new_tail  = get<3>(r);
  632|  35.9k|            if (new_root) {
  ------------------
  |  Branch (632:17): [True: 27.0k, False: 8.83k]
  ------------------
  633|  27.0k|                root  = new_root;
  634|  27.0k|                shift = new_shift;
  635|  27.0k|            } else {
  636|  8.83k|                root  = empty_root();
  637|  8.83k|                shift = BL;
  638|  8.83k|            }
  639|  35.9k|            dec_leaf(tail, size - tail_off);
  640|  35.9k|            size = new_size;
  641|  35.9k|            tail = new_tail;
  642|  35.9k|            return;
  643|  35.9k|        }
  644|  40.4k|    }
_ZN5immer6detail4rbts12concat_mut_rERKNS1_7rrbtreeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEERSB_NS9_5applyIS6_E4type4editE:
  942|  33.8k|    {
  943|  33.8k|        assert(&l != &r);
  ------------------
  |  Branch (943:9): [True: 33.8k, False: 0]
  ------------------
  944|  33.8k|        assert(r.size < (std::numeric_limits<size_t>::max() - l.size));
  ------------------
  |  Branch (944:9): [True: 33.8k, False: 0]
  ------------------
  945|  33.8k|        using std::get;
  946|  33.8k|        if (r.size == 0)
  ------------------
  |  Branch (946:13): [True: 3.25k, False: 30.5k]
  ------------------
  947|  3.25k|            r = std::move(l);
  948|  30.5k|        else if (l.size == 0)
  ------------------
  |  Branch (948:18): [True: 634, False: 29.9k]
  ------------------
  949|    634|            return;
  950|  29.9k|        else if (r.tail_offset() == 0) {
  ------------------
  |  Branch (950:18): [True: 7.00k, False: 22.9k]
  ------------------
  951|       |            // just concat the tail, similar to push_back
  952|  7.00k|            auto tail_offst = l.tail_offset();
  953|  7.00k|            auto tail_size  = l.size - tail_offst;
  954|  7.00k|            if (tail_size == branches<BL>) {
  ------------------
  |  Branch (954:17): [True: 1.25k, False: 5.74k]
  ------------------
  955|       |                // this could be improved by making sure that the
  956|       |                // newly created nodes as part of the `push_tail()`
  957|       |                // are tagged with `er`
  958|  1.25k|                auto res =
  959|  1.25k|                    l.push_tail(l.root, l.shift, tail_offst, l.tail, tail_size);
  960|  1.25k|                l.tail->inc(); // note: leak if mutably concatenated
  961|       |                               // with itself, but this is forbidden
  962|       |                               // by the interface
  963|  1.25k|                r = {l.size + r.size, get<0>(res), get<1>(res), r.tail->inc()};
  964|  1.25k|                return;
  965|  5.74k|            } else if (tail_size + r.size <= branches<BL>) {
  ------------------
  |  Branch (965:24): [True: 3.34k, False: 2.39k]
  ------------------
  966|       |                // doing this in a exception way mutating way is very
  967|       |                // tricky while potential performance gains are
  968|       |                // minimal (we need to move every element of the right
  969|       |                // tail anyways to make space for the left tail)
  970|       |                //
  971|       |                // we could however improve this by at least moving the
  972|       |                // elements of the right tail...
  973|  3.34k|                auto new_tail =
  974|  3.34k|                    node_t::copy_leaf(l.tail, tail_size, r.tail, r.size);
  975|  3.34k|                r = {l.size + r.size, l.shift, l.root->inc(), new_tail};
  976|  3.34k|                return;
  977|  3.34k|            } else {
  978|       |                // like the immutable version
  979|  2.39k|                auto remaining = branches<BL> - tail_size;
  980|  2.39k|                auto add_tail  = node_t::copy_leaf_e(
  981|  2.39k|                    er, l.tail, tail_size, r.tail, remaining);
  982|  2.39k|                IMMER_TRY {
  ------------------
  |  |   49|  2.39k|#define IMMER_TRY try
  ------------------
  983|  2.39k|                    auto new_tail =
  984|  2.39k|                        node_t::copy_leaf_e(er, r.tail, remaining, r.size);
  985|  2.39k|                    IMMER_TRY {
  ------------------
  |  |   49|  2.39k|#define IMMER_TRY try
  ------------------
  986|       |                        // this could be improved by making sure that the
  987|       |                        // newly created nodes as part of the `push_tail()`
  988|       |                        // are tagged with `er`
  989|  2.39k|                        auto new_root = l.push_tail(l.root,
  990|  2.39k|                                                    l.shift,
  991|  2.39k|                                                    tail_offst,
  992|  2.39k|                                                    add_tail,
  993|  2.39k|                                                    branches<BL>);
  994|  2.39k|                        r             = {l.size + r.size,
  995|  2.39k|                                         get<0>(new_root),
  996|  2.39k|                                         get<1>(new_root),
  997|  2.39k|                                         new_tail};
  998|  2.39k|                        return;
  999|  2.39k|                    }
 1000|  2.39k|                    IMMER_CATCH (...) {
 1001|      0|                        node_t::delete_leaf(new_tail, r.size - remaining);
 1002|      0|                        IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
 1003|      0|                    }
 1004|  2.39k|                }
 1005|  2.39k|                IMMER_CATCH (...) {
 1006|      0|                    node_t::delete_leaf(add_tail, branches<BL>);
 1007|      0|                    IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
 1008|      0|                }
 1009|  2.39k|            }
 1010|  22.9k|        } else if (l.tail_offset() == 0) {
  ------------------
  |  Branch (1010:20): [True: 2.56k, False: 20.3k]
  ------------------
 1011|  2.56k|            if (supports_transient_concat) {
  ------------------
  |  Branch (1011:17): [True: 2.56k, Folded]
  ------------------
 1012|  2.56k|                auto tail_offst = l.tail_offset();
 1013|  2.56k|                auto tail_size  = l.size - tail_offst;
 1014|  2.56k|                auto concated =
 1015|  2.56k|                    concat_trees_mut(er,
 1016|  2.56k|                                     MemoryPolicy::transience_t::noone,
 1017|  2.56k|                                     l.tail,
 1018|  2.56k|                                     tail_size,
 1019|  2.56k|                                     er,
 1020|  2.56k|                                     r.root,
 1021|  2.56k|                                     r.shift,
 1022|  2.56k|                                     r.tail_offset());
 1023|  2.56k|                IMMER_ASSERT_TAGGED(concated.shift() ==
  ------------------
  |  |   68|  2.56k|#define IMMER_ASSERT_TAGGED(assertion) assert(assertion)
  ------------------
  |  Branch (1023:17): [True: 2.56k, False: 0]
  ------------------
 1024|  2.56k|                                    concated.node()->compute_shift());
 1025|  2.56k|                r.size += l.size;
 1026|  2.56k|                r.shift = concated.shift();
 1027|  2.56k|                r.root  = concated.node();
 1028|  2.56k|                assert(r.check_tree());
  ------------------
  |  Branch (1028:17): [True: 2.56k, False: 0]
  ------------------
 1029|  2.56k|            } else {
 1030|      0|                auto tail_offst = l.tail_offset();
 1031|      0|                auto tail_size  = l.size - tail_offst;
 1032|      0|                auto concated   = concat_trees(
 1033|      0|                    l.tail, tail_size, r.root, r.shift, r.tail_offset());
 1034|      0|                r = {l.size + r.size,
 1035|      0|                     concated.shift(),
 1036|      0|                     concated.node(),
 1037|      0|                     r.tail->inc()};
 1038|      0|                return;
 1039|      0|            }
 1040|  20.3k|        } else {
 1041|  20.3k|            if (supports_transient_concat) {
  ------------------
  |  Branch (1041:17): [True: 20.3k, Folded]
  ------------------
 1042|  20.3k|                auto tail_offst = l.tail_offset();
 1043|  20.3k|                auto tail_size  = l.size - tail_offst;
 1044|  20.3k|                auto concated =
 1045|  20.3k|                    concat_trees_mut(er,
 1046|  20.3k|                                     MemoryPolicy::transience_t::noone,
 1047|  20.3k|                                     l.root,
 1048|  20.3k|                                     l.shift,
 1049|  20.3k|                                     tail_offst,
 1050|  20.3k|                                     l.tail,
 1051|  20.3k|                                     tail_size,
 1052|  20.3k|                                     er,
 1053|  20.3k|                                     r.root,
 1054|  20.3k|                                     r.shift,
 1055|  20.3k|                                     r.tail_offset());
 1056|  20.3k|                IMMER_ASSERT_TAGGED(concated.shift() ==
  ------------------
  |  |   68|  20.3k|#define IMMER_ASSERT_TAGGED(assertion) assert(assertion)
  ------------------
  |  Branch (1056:17): [True: 20.3k, False: 0]
  ------------------
 1057|  20.3k|                                    concated.node()->compute_shift());
 1058|  20.3k|                r.size += l.size;
 1059|  20.3k|                r.shift = concated.shift();
 1060|  20.3k|                r.root  = concated.node();
 1061|  20.3k|                assert(r.check_tree());
  ------------------
  |  Branch (1061:17): [True: 20.3k, False: 0]
  ------------------
 1062|  20.3k|                return;
 1063|  20.3k|            } else {
 1064|      0|                auto tail_offst = l.tail_offset();
 1065|      0|                auto tail_size  = l.size - tail_offst;
 1066|      0|                auto concated   = concat_trees(l.root,
 1067|      0|                                             l.shift,
 1068|      0|                                             tail_offst,
 1069|      0|                                             l.tail,
 1070|      0|                                             tail_size,
 1071|      0|                                             r.root,
 1072|      0|                                             r.shift,
 1073|      0|                                             r.tail_offset());
 1074|      0|                r               = {l.size + r.size,
 1075|      0|                                   concated.shift(),
 1076|      0|                                   concated.node(),
 1077|      0|                                   r.tail->inc()};
 1078|      0|                return;
 1079|      0|            }
 1080|  20.3k|        }
 1081|  33.8k|    }
_ZN5immer6detail4rbts7rrbtreeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEaSERKSB_:
  163|  6.83k|    {
  164|  6.83k|        auto next{other};
  165|  6.83k|        swap(*this, next);
  166|  6.83k|        return *this;
  167|  6.83k|    }
_ZN5immer6detail4rbts15concat_mut_lr_rERNS1_7rrbtreeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEENS9_5applyIS6_E4type4editESC_SG_:
 1220|  4.19k|    {
 1221|  4.19k|        assert(&l != &r);
  ------------------
  |  Branch (1221:9): [True: 4.19k, False: 0]
  ------------------
 1222|  4.19k|        assert(r.size < (std::numeric_limits<size_t>::max() - l.size));
  ------------------
  |  Branch (1222:9): [True: 4.19k, False: 0]
  ------------------
 1223|  4.19k|        using std::get;
 1224|  4.19k|        if (r.size == 0)
  ------------------
  |  Branch (1224:13): [True: 279, False: 3.91k]
  ------------------
 1225|    279|            r = l;
 1226|  3.91k|        else if (l.size == 0)
  ------------------
  |  Branch (1226:18): [True: 487, False: 3.43k]
  ------------------
 1227|    487|            return;
 1228|  3.43k|        else if (r.tail_offset() == 0) {
  ------------------
  |  Branch (1228:18): [True: 1.36k, False: 2.06k]
  ------------------
 1229|       |            // just concat the tail, similar to push_back
 1230|  1.36k|            auto tail_offst = l.tail_offset();
 1231|  1.36k|            auto tail_size  = l.size - tail_offst;
 1232|  1.36k|            if (tail_size == branches<BL>) {
  ------------------
  |  Branch (1232:17): [True: 405, False: 964]
  ------------------
 1233|       |                // this could be improved by making sure that the
 1234|       |                // newly created nodes as part of the `push_tail()`
 1235|       |                // are tagged with `er`
 1236|    405|                auto res =
 1237|    405|                    l.push_tail(l.root, l.shift, tail_offst, l.tail, tail_size);
 1238|    405|                r = {l.size + r.size, get<0>(res), get<1>(res), r.tail->inc()};
 1239|    405|                return;
 1240|    964|            } else if (tail_size + r.size <= branches<BL>) {
  ------------------
  |  Branch (1240:24): [True: 667, False: 297]
  ------------------
 1241|       |                // doing this in a exception way mutating way is very
 1242|       |                // tricky while potential performance gains are
 1243|       |                // minimal (we need to move every element of the right
 1244|       |                // tail anyways to make space for the left tail)
 1245|       |                //
 1246|       |                // we could however improve this by at least moving the
 1247|       |                // elements of the mutable tails...
 1248|    667|                auto new_tail =
 1249|    667|                    node_t::copy_leaf(l.tail, tail_size, r.tail, r.size);
 1250|    667|                r = {l.size + r.size, l.shift, l.root->inc(), new_tail};
 1251|    667|                return;
 1252|    667|            } else {
 1253|       |                // like the immutable version.
 1254|       |                // we could improve this also by moving elements
 1255|       |                // instead of just copying them
 1256|    297|                auto remaining = branches<BL> - tail_size;
 1257|    297|                auto add_tail  = node_t::copy_leaf_e(
 1258|    297|                    er, l.tail, tail_size, r.tail, remaining);
 1259|    297|                IMMER_TRY {
  ------------------
  |  |   49|    297|#define IMMER_TRY try
  ------------------
 1260|    297|                    auto new_tail =
 1261|    297|                        node_t::copy_leaf_e(er, r.tail, remaining, r.size);
 1262|    297|                    IMMER_TRY {
  ------------------
  |  |   49|    297|#define IMMER_TRY try
  ------------------
 1263|       |                        // this could be improved by making sure that the
 1264|       |                        // newly created nodes as part of the `push_tail()`
 1265|       |                        // are tagged with `er`
 1266|    297|                        auto new_root = l.push_tail(l.root,
 1267|    297|                                                    l.shift,
 1268|    297|                                                    tail_offst,
 1269|    297|                                                    add_tail,
 1270|    297|                                                    branches<BL>);
 1271|    297|                        r             = {l.size + r.size,
 1272|    297|                                         get<0>(new_root),
 1273|    297|                                         get<1>(new_root),
 1274|    297|                                         new_tail};
 1275|    297|                        return;
 1276|    297|                    }
 1277|    297|                    IMMER_CATCH (...) {
 1278|      0|                        node_t::delete_leaf(new_tail, r.size - remaining);
 1279|      0|                        IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
 1280|      0|                    }
 1281|    297|                }
 1282|    297|                IMMER_CATCH (...) {
 1283|      0|                    node_t::delete_leaf(add_tail, branches<BL>);
 1284|      0|                    IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
 1285|      0|                }
 1286|    297|            }
 1287|  2.06k|        } else if (l.tail_offset() == 0) {
  ------------------
  |  Branch (1287:20): [True: 810, False: 1.25k]
  ------------------
 1288|    810|            if (supports_transient_concat) {
  ------------------
  |  Branch (1288:17): [True: 810, Folded]
  ------------------
 1289|    810|                auto tail_offst = l.tail_offset();
 1290|    810|                auto tail_size  = l.size - tail_offst;
 1291|    810|                auto concated   = concat_trees_mut(er,
 1292|    810|                                                 el,
 1293|    810|                                                 l.tail,
 1294|    810|                                                 tail_size,
 1295|    810|                                                 er,
 1296|    810|                                                 r.root,
 1297|    810|                                                 r.shift,
 1298|    810|                                                 r.tail_offset());
 1299|    810|                IMMER_ASSERT_TAGGED(concated.shift() ==
  ------------------
  |  |   68|    810|#define IMMER_ASSERT_TAGGED(assertion) assert(assertion)
  ------------------
  |  Branch (1299:17): [True: 810, False: 0]
  ------------------
 1300|    810|                                    concated.node()->compute_shift());
 1301|    810|                assert(concated.node()->check(concated.shift(),
  ------------------
  |  Branch (1301:17): [True: 810, False: 0]
  ------------------
 1302|    810|                                              l.size + r.tail_offset()));
 1303|    810|                r.size += l.size;
 1304|    810|                r.shift = concated.shift();
 1305|    810|                r.root  = concated.node();
 1306|    810|                assert(r.check_tree());
  ------------------
  |  Branch (1306:17): [True: 810, False: 0]
  ------------------
 1307|    810|                l.hard_reset();
 1308|    810|            } else {
 1309|      0|                auto tail_offst = l.tail_offset();
 1310|      0|                auto tail_size  = l.size - tail_offst;
 1311|      0|                auto concated   = concat_trees(
 1312|      0|                    l.tail, tail_size, r.root, r.shift, r.tail_offset());
 1313|      0|                r = {l.size + r.size,
 1314|      0|                     concated.shift(),
 1315|      0|                     concated.node(),
 1316|      0|                     r.tail->inc()};
 1317|      0|                return;
 1318|      0|            }
 1319|  1.25k|        } else {
 1320|  1.25k|            if (supports_transient_concat) {
  ------------------
  |  Branch (1320:17): [True: 1.25k, Folded]
  ------------------
 1321|  1.25k|                auto tail_offst = l.tail_offset();
 1322|  1.25k|                auto tail_size  = l.size - tail_offst;
 1323|  1.25k|                auto concated   = concat_trees_mut(er,
 1324|  1.25k|                                                 el,
 1325|  1.25k|                                                 l.root,
 1326|  1.25k|                                                 l.shift,
 1327|  1.25k|                                                 tail_offst,
 1328|  1.25k|                                                 l.tail,
 1329|  1.25k|                                                 tail_size,
 1330|  1.25k|                                                 er,
 1331|  1.25k|                                                 r.root,
 1332|  1.25k|                                                 r.shift,
 1333|  1.25k|                                                 r.tail_offset());
 1334|  1.25k|                IMMER_ASSERT_TAGGED(concated.shift() ==
  ------------------
  |  |   68|  1.25k|#define IMMER_ASSERT_TAGGED(assertion) assert(assertion)
  ------------------
  |  Branch (1334:17): [True: 1.25k, False: 0]
  ------------------
 1335|  1.25k|                                    concated.node()->compute_shift());
 1336|  1.25k|                assert(concated.node()->check(concated.shift(),
  ------------------
  |  Branch (1336:17): [True: 1.25k, False: 0]
  ------------------
 1337|  1.25k|                                              l.size + r.tail_offset()));
 1338|  1.25k|                r.size += l.size;
 1339|  1.25k|                r.shift = concated.shift();
 1340|  1.25k|                r.root  = concated.node();
 1341|  1.25k|                assert(r.check_tree());
  ------------------
  |  Branch (1341:17): [True: 1.25k, False: 0]
  ------------------
 1342|  1.25k|                l.hard_reset();
 1343|  1.25k|            } else {
 1344|      0|                auto tail_offst = l.tail_offset();
 1345|      0|                auto tail_size  = l.size - tail_offst;
 1346|      0|                auto concated   = concat_trees(l.root,
 1347|      0|                                             l.shift,
 1348|      0|                                             tail_offst,
 1349|      0|                                             l.tail,
 1350|      0|                                             tail_size,
 1351|      0|                                             r.root,
 1352|      0|                                             r.shift,
 1353|      0|                                             r.tail_offset());
 1354|      0|                r               = {l.size + r.size,
 1355|      0|                                   concated.shift(),
 1356|      0|                                   concated.node(),
 1357|      0|                                   r.tail->inc()};
 1358|      0|            }
 1359|  1.25k|        }
 1360|  4.19k|    }
_ZN5immer6detail4rbts7rrbtreeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE10hard_resetEv:
 1363|  4.35k|    {
 1364|  4.35k|        assert(supports_transient_concat);
  ------------------
  |  Branch (1364:9): [True: 4.35k, Folded]
  ------------------
 1365|  4.35k|        size  = 0;
 1366|  4.35k|        shift = BL;
 1367|  4.35k|        root  = empty_root();
 1368|  4.35k|        tail  = empty_tail();
 1369|  4.35k|    }
_ZN5immer6detail4rbts12concat_mut_lERNS1_7rrbtreeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEENS9_5applyIS6_E4type4editERKSB_:
  816|  1.79M|    {
  817|  1.79M|        assert(&l != &r);
  ------------------
  |  Branch (817:9): [True: 1.79M, False: 0]
  ------------------
  818|  1.79M|        assert(r.size < (std::numeric_limits<size_t>::max() - l.size));
  ------------------
  |  Branch (818:9): [True: 1.79M, False: 0]
  ------------------
  819|  1.79M|        using std::get;
  820|  1.79M|        if (l.size == 0)
  ------------------
  |  Branch (820:13): [True: 2.62k, False: 1.79M]
  ------------------
  821|  2.62k|            l = r;
  822|  1.79M|        else if (r.size == 0)
  ------------------
  |  Branch (822:18): [True: 14.1k, False: 1.78M]
  ------------------
  823|  14.1k|            return;
  824|  1.78M|        else if (r.tail_offset() == 0) {
  ------------------
  |  Branch (824:18): [True: 1.70M, False: 79.8k]
  ------------------
  825|       |            // just concat the tail, similar to push_back
  826|  1.70M|            auto tail_offst = l.tail_offset();
  827|  1.70M|            auto tail_size  = l.size - tail_offst;
  828|  1.70M|            if (tail_size == branches<BL>) {
  ------------------
  |  Branch (828:17): [True: 369k, False: 1.33M]
  ------------------
  829|   369k|                l.push_tail_mut(el, tail_offst, l.tail, tail_size);
  830|   369k|                l.tail = r.tail->inc();
  831|   369k|                l.size += r.size;
  832|   369k|                return;
  833|  1.33M|            } else if (tail_size + r.size <= branches<BL>) {
  ------------------
  |  Branch (833:24): [True: 11.4k, False: 1.31M]
  ------------------
  834|  11.4k|                l.ensure_mutable_tail(el, tail_size);
  835|  11.4k|                detail::uninitialized_copy(r.tail->leaf(),
  836|  11.4k|                                           r.tail->leaf() + r.size,
  837|  11.4k|                                           l.tail->leaf() + tail_size);
  838|  11.4k|                l.size += r.size;
  839|  11.4k|                return;
  840|  1.31M|            } else {
  841|  1.31M|                auto remaining = branches<BL> - tail_size;
  842|  1.31M|                l.ensure_mutable_tail(el, tail_size);
  843|  1.31M|                detail::uninitialized_copy(r.tail->leaf(),
  844|  1.31M|                                           r.tail->leaf() + remaining,
  845|  1.31M|                                           l.tail->leaf() + tail_size);
  846|  1.31M|                IMMER_TRY {
  ------------------
  |  |   49|  1.31M|#define IMMER_TRY try
  ------------------
  847|  1.31M|                    auto new_tail =
  848|  1.31M|                        node_t::copy_leaf_e(el, r.tail, remaining, r.size);
  849|  1.31M|                    IMMER_TRY {
  ------------------
  |  |   49|  1.31M|#define IMMER_TRY try
  ------------------
  850|  1.31M|                        l.push_tail_mut(el, tail_offst, l.tail, branches<BL>);
  851|  1.31M|                        l.tail = new_tail;
  852|  1.31M|                        l.size += r.size;
  853|  1.31M|                        return;
  854|  1.31M|                    }
  855|  1.31M|                    IMMER_CATCH (...) {
  856|      0|                        node_t::delete_leaf(new_tail, r.size - remaining);
  857|      0|                        IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
  858|      0|                    }
  859|  1.31M|                }
  860|  1.31M|                IMMER_CATCH (...) {
  861|      0|                    detail::destroy_n(r.tail->leaf() + tail_size, remaining);
  862|      0|                    IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
  863|      0|                }
  864|  1.31M|            }
  865|  1.70M|        } else if (l.tail_offset() == 0) {
  ------------------
  |  Branch (865:20): [True: 3.20k, False: 76.6k]
  ------------------
  866|  3.20k|            if (supports_transient_concat) {
  ------------------
  |  Branch (866:17): [True: 3.20k, Folded]
  ------------------
  867|  3.20k|                auto tail_offst = l.tail_offset();
  868|  3.20k|                auto tail_size  = l.size - tail_offst;
  869|  3.20k|                auto concated =
  870|  3.20k|                    concat_trees_mut(el,
  871|  3.20k|                                     el,
  872|  3.20k|                                     l.tail,
  873|  3.20k|                                     tail_size,
  874|  3.20k|                                     MemoryPolicy::transience_t::noone,
  875|  3.20k|                                     r.root,
  876|  3.20k|                                     r.shift,
  877|  3.20k|                                     r.tail_offset());
  878|  3.20k|                IMMER_ASSERT_TAGGED(concated.shift() ==
  ------------------
  |  |   68|  3.20k|#define IMMER_ASSERT_TAGGED(assertion) assert(assertion)
  ------------------
  |  Branch (878:17): [True: 3.20k, False: 0]
  ------------------
  879|  3.20k|                                    concated.node()->compute_shift());
  880|  3.20k|                l.size += r.size;
  881|  3.20k|                l.shift = concated.shift();
  882|  3.20k|                l.root  = concated.node();
  883|  3.20k|                l.tail  = r.tail;
  884|  3.20k|                assert(l.check_tree());
  ------------------
  |  Branch (884:17): [True: 3.20k, False: 0]
  ------------------
  885|  3.20k|            } else {
  886|      0|                auto tail_offst = l.tail_offset();
  887|      0|                auto tail_size  = l.size - tail_offst;
  888|      0|                auto concated   = concat_trees(
  889|      0|                    l.tail, tail_size, r.root, r.shift, r.tail_offset());
  890|      0|                l = {l.size + r.size,
  891|      0|                     concated.shift(),
  892|      0|                     concated.node(),
  893|      0|                     r.tail->inc()};
  894|      0|                assert(l.check_tree());
  ------------------
  |  Branch (894:17): [True: 0, False: 0]
  ------------------
  895|      0|                return;
  896|      0|            }
  897|  76.6k|        } else {
  898|  76.6k|            if (supports_transient_concat) {
  ------------------
  |  Branch (898:17): [True: 76.6k, Folded]
  ------------------
  899|  76.6k|                auto tail_offst = l.tail_offset();
  900|  76.6k|                auto tail_size  = l.size - tail_offst;
  901|  76.6k|                assert(l.check_tree());
  ------------------
  |  Branch (901:17): [True: 76.6k, False: 0]
  ------------------
  902|  76.6k|                assert(r.check_tree());
  ------------------
  |  Branch (902:17): [True: 76.6k, False: 0]
  ------------------
  903|  76.6k|                auto concated =
  904|  76.6k|                    concat_trees_mut(el,
  905|  76.6k|                                     el,
  906|  76.6k|                                     l.root,
  907|  76.6k|                                     l.shift,
  908|  76.6k|                                     tail_offst,
  909|  76.6k|                                     l.tail,
  910|  76.6k|                                     tail_size,
  911|  76.6k|                                     MemoryPolicy::transience_t::noone,
  912|  76.6k|                                     r.root,
  913|  76.6k|                                     r.shift,
  914|  76.6k|                                     r.tail_offset());
  915|  76.6k|                IMMER_ASSERT_TAGGED(concated.shift() ==
  ------------------
  |  |   68|  76.6k|#define IMMER_ASSERT_TAGGED(assertion) assert(assertion)
  ------------------
  |  Branch (915:17): [True: 76.6k, False: 0]
  ------------------
  916|  76.6k|                                    concated.node()->compute_shift());
  917|  76.6k|                l.size += r.size;
  918|  76.6k|                l.shift = concated.shift();
  919|  76.6k|                l.root  = concated.node();
  920|  76.6k|                l.tail  = r.tail;
  921|  76.6k|                assert(l.check_tree());
  ------------------
  |  Branch (921:17): [True: 76.6k, False: 0]
  ------------------
  922|  76.6k|            } else {
  923|      0|                auto tail_offst = l.tail_offset();
  924|      0|                auto tail_size  = l.size - tail_offst;
  925|      0|                auto concated   = concat_trees(l.root,
  926|      0|                                             l.shift,
  927|      0|                                             tail_offst,
  928|      0|                                             l.tail,
  929|      0|                                             tail_size,
  930|      0|                                             r.root,
  931|      0|                                             r.shift,
  932|      0|                                             r.tail_offset());
  933|      0|                l               = {l.size + r.size,
  934|      0|                                   concated.shift(),
  935|      0|                                   concated.node(),
  936|      0|                                   r.tail->inc()};
  937|      0|            }
  938|  76.6k|        }
  939|  1.79M|    }
_ZN5immer6detail4rbts15concat_mut_lr_lERNS1_7rrbtreeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEENS9_5applyIS6_E4type4editESC_SG_:
 1084|  5.91k|    {
 1085|  5.91k|        assert(&l != &r);
  ------------------
  |  Branch (1085:9): [True: 5.91k, False: 0]
  ------------------
 1086|  5.91k|        assert(r.size < (std::numeric_limits<size_t>::max() - l.size));
  ------------------
  |  Branch (1086:9): [True: 5.91k, False: 0]
  ------------------
 1087|  5.91k|        using std::get;
 1088|  5.91k|        if (l.size == 0)
  ------------------
  |  Branch (1088:13): [True: 672, False: 5.24k]
  ------------------
 1089|    672|            l = r;
 1090|  5.24k|        else if (r.size == 0)
  ------------------
  |  Branch (1090:18): [True: 418, False: 4.82k]
  ------------------
 1091|    418|            return;
 1092|  4.82k|        else if (r.tail_offset() == 0) {
  ------------------
  |  Branch (1092:18): [True: 2.53k, False: 2.28k]
  ------------------
 1093|       |            // just concat the tail, similar to push_back
 1094|  2.53k|            auto tail_offst = l.tail_offset();
 1095|  2.53k|            auto tail_size  = l.size - tail_offst;
 1096|  2.53k|            if (tail_size == branches<BL>) {
  ------------------
  |  Branch (1096:17): [True: 456, False: 2.07k]
  ------------------
 1097|    456|                l.push_tail_mut(el, tail_offst, l.tail, tail_size);
 1098|    456|                l.tail = r.tail->inc();
 1099|    456|                l.size += r.size;
 1100|    456|                return;
 1101|  2.07k|            } else if (tail_size + r.size <= branches<BL>) {
  ------------------
  |  Branch (1101:24): [True: 1.29k, False: 781]
  ------------------
 1102|  1.29k|                l.ensure_mutable_tail(el, tail_size);
 1103|  1.29k|                if (r.tail->can_mutate(er))
  ------------------
  |  Branch (1103:21): [True: 855, False: 442]
  ------------------
 1104|    855|                    detail::uninitialized_move(r.tail->leaf(),
 1105|    855|                                               r.tail->leaf() + r.size,
 1106|    855|                                               l.tail->leaf() + tail_size);
 1107|    442|                else
 1108|    442|                    detail::uninitialized_copy(r.tail->leaf(),
 1109|    442|                                               r.tail->leaf() + r.size,
 1110|    442|                                               l.tail->leaf() + tail_size);
 1111|  1.29k|                l.size += r.size;
 1112|  1.29k|                return;
 1113|  1.29k|            } else {
 1114|    781|                auto remaining = branches<BL> - tail_size;
 1115|    781|                l.ensure_mutable_tail(el, tail_size);
 1116|    781|                if (r.tail->can_mutate(er))
  ------------------
  |  Branch (1116:21): [True: 205, False: 576]
  ------------------
 1117|    205|                    detail::uninitialized_move(r.tail->leaf(),
 1118|    205|                                               r.tail->leaf() + remaining,
 1119|    205|                                               l.tail->leaf() + tail_size);
 1120|    576|                else
 1121|    576|                    detail::uninitialized_copy(r.tail->leaf(),
 1122|    576|                                               r.tail->leaf() + remaining,
 1123|    576|                                               l.tail->leaf() + tail_size);
 1124|    781|                IMMER_TRY {
  ------------------
  |  |   49|    781|#define IMMER_TRY try
  ------------------
 1125|    781|                    auto new_tail =
 1126|    781|                        node_t::copy_leaf_e(el, r.tail, remaining, r.size);
 1127|    781|                    IMMER_TRY {
  ------------------
  |  |   49|    781|#define IMMER_TRY try
  ------------------
 1128|    781|                        l.push_tail_mut(el, tail_offst, l.tail, branches<BL>);
 1129|    781|                        l.tail = new_tail;
 1130|    781|                        l.size += r.size;
 1131|    781|                        return;
 1132|    781|                    }
 1133|    781|                    IMMER_CATCH (...) {
 1134|      0|                        node_t::delete_leaf(new_tail, r.size - remaining);
 1135|      0|                        IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
 1136|      0|                    }
 1137|    781|                }
 1138|    781|                IMMER_CATCH (...) {
 1139|      0|                    detail::destroy_n(r.tail->leaf() + tail_size, remaining);
 1140|      0|                    IMMER_RETHROW;
  ------------------
  |  |   52|      0|#define IMMER_RETHROW throw
  ------------------
 1141|      0|                }
 1142|    781|            }
 1143|  2.53k|        } else if (l.tail_offset() == 0) {
  ------------------
  |  Branch (1143:20): [True: 825, False: 1.46k]
  ------------------
 1144|    825|            if (supports_transient_concat) {
  ------------------
  |  Branch (1144:17): [True: 825, Folded]
  ------------------
 1145|    825|                auto tail_offst = l.tail_offset();
 1146|    825|                auto tail_size  = l.size - tail_offst;
 1147|    825|                auto concated   = concat_trees_mut(el,
 1148|    825|                                                 el,
 1149|    825|                                                 l.tail,
 1150|    825|                                                 tail_size,
 1151|    825|                                                 er,
 1152|    825|                                                 r.root,
 1153|    825|                                                 r.shift,
 1154|    825|                                                 r.tail_offset());
 1155|    825|                IMMER_ASSERT_TAGGED(concated.shift() ==
  ------------------
  |  |   68|    825|#define IMMER_ASSERT_TAGGED(assertion) assert(assertion)
  ------------------
  |  Branch (1155:17): [True: 825, False: 0]
  ------------------
 1156|    825|                                    concated.node()->compute_shift());
 1157|    825|                l.size += r.size;
 1158|    825|                l.shift = concated.shift();
 1159|    825|                l.root  = concated.node();
 1160|    825|                l.tail  = r.tail;
 1161|    825|                assert(l.check_tree());
  ------------------
  |  Branch (1161:17): [True: 825, False: 0]
  ------------------
 1162|    825|                r.hard_reset();
 1163|    825|                return;
 1164|    825|            } else {
 1165|      0|                auto tail_offst = l.tail_offset();
 1166|      0|                auto tail_size  = l.size - tail_offst;
 1167|      0|                auto concated   = concat_trees(
 1168|      0|                    l.tail, tail_size, r.root, r.shift, r.tail_offset());
 1169|      0|                l = {l.size + r.size,
 1170|      0|                     concated.shift(),
 1171|      0|                     concated.node(),
 1172|      0|                     r.tail->inc()};
 1173|      0|                return;
 1174|      0|            }
 1175|  1.46k|        } else {
 1176|  1.46k|            if (supports_transient_concat) {
  ------------------
  |  Branch (1176:17): [True: 1.46k, Folded]
  ------------------
 1177|  1.46k|                auto tail_offst = l.tail_offset();
 1178|  1.46k|                auto tail_size  = l.size - tail_offst;
 1179|  1.46k|                auto concated   = concat_trees_mut(el,
 1180|  1.46k|                                                 el,
 1181|  1.46k|                                                 l.root,
 1182|  1.46k|                                                 l.shift,
 1183|  1.46k|                                                 tail_offst,
 1184|  1.46k|                                                 l.tail,
 1185|  1.46k|                                                 tail_size,
 1186|  1.46k|                                                 er,
 1187|  1.46k|                                                 r.root,
 1188|  1.46k|                                                 r.shift,
 1189|  1.46k|                                                 r.tail_offset());
 1190|  1.46k|                IMMER_ASSERT_TAGGED(concated.shift() ==
  ------------------
  |  |   68|  1.46k|#define IMMER_ASSERT_TAGGED(assertion) assert(assertion)
  ------------------
  |  Branch (1190:17): [True: 1.46k, False: 0]
  ------------------
 1191|  1.46k|                                    concated.node()->compute_shift());
 1192|  1.46k|                l.size += r.size;
 1193|  1.46k|                l.shift = concated.shift();
 1194|  1.46k|                l.root  = concated.node();
 1195|  1.46k|                l.tail  = r.tail;
 1196|  1.46k|                assert(l.check_tree());
  ------------------
  |  Branch (1196:17): [True: 1.46k, False: 0]
  ------------------
 1197|  1.46k|                r.hard_reset();
 1198|  1.46k|                return;
 1199|  1.46k|            } else {
 1200|      0|                auto tail_offst = l.tail_offset();
 1201|      0|                auto tail_size  = l.size - tail_offst;
 1202|      0|                auto concated   = concat_trees(l.root,
 1203|      0|                                             l.shift,
 1204|      0|                                             tail_offst,
 1205|      0|                                             l.tail,
 1206|      0|                                             tail_size,
 1207|      0|                                             r.root,
 1208|      0|                                             r.shift,
 1209|      0|                                             r.tail_offset());
 1210|      0|                l               = {l.size + r.size,
 1211|      0|                                   concated.shift(),
 1212|      0|                                   concated.node(),
 1213|      0|                                   r.tail->inc()};
 1214|      0|                return;
 1215|      0|            }
 1216|  1.46k|        }
 1217|  5.91k|    }

_ZN5immer6detail4rbts12visitor_baseINS1_18slice_left_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEELb1EEEE13visit_relaxedIJRNS1_11relaxed_posISD_EERmEEEDcDpOT_:
   31|  14.6k|    {
   32|  14.6k|        return Deriv::visit_inner(std::forward<Args>(args)...);
   33|  14.6k|    }
_ZN5immer6detail4rbts12visitor_baseINS1_18slice_left_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEELb0EEEE13visit_relaxedIJRNS1_11relaxed_posISD_EERmEEEDcDpOT_:
   31|  92.0k|    {
   32|  92.0k|        return Deriv::visit_inner(std::forward<Args>(args)...);
   33|  92.0k|    }
_ZN5immer6detail4rbts12visitor_baseINS1_18slice_left_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEELb0EEEE13visit_regularIJRNS1_15regular_sub_posISD_EERmEEEDcDpOT_:
   37|  1.47k|    {
   38|  1.47k|        return Deriv::visit_inner(std::forward<Args>(args)...);
   39|  1.47k|    }
_ZN5immer6detail4rbts12visitor_baseINS1_18slice_left_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEELb0EEEE13visit_regularIJRNS1_8full_posISD_EEmEEEDcDpOT_:
   37|  2.33k|    {
   38|  2.33k|        return Deriv::visit_inner(std::forward<Args>(args)...);
   39|  2.33k|    }
_ZN5immer6detail4rbts12visitor_baseINS1_18slice_left_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEELb1EEEE13visit_regularIJRNS1_15regular_sub_posISD_EERmEEEDcDpOT_:
   37|  2.49k|    {
   38|  2.49k|        return Deriv::visit_inner(std::forward<Args>(args)...);
   39|  2.49k|    }
_ZN5immer6detail4rbts12visitor_baseINS1_18slice_left_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEELb1EEEE13visit_regularIJRNS1_8full_posISD_EEmEEEDcDpOT_:
   37|  1.23k|    {
   38|  1.23k|        return Deriv::visit_inner(std::forward<Args>(args)...);
   39|  1.23k|    }
_ZN5immer6detail4rbts12visitor_baseINS1_18slice_left_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEELb1EEEE13visit_regularIJRNS1_15regular_sub_posISD_EEmEEEDcDpOT_:
   37|    353|    {
   38|    353|        return Deriv::visit_inner(std::forward<Args>(args)...);
   39|    353|    }
_ZN5immer6detail4rbts12visitor_baseINS1_25concat_trees_left_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEEE13visit_regularIJRNS1_25singleton_regular_sub_posISD_EENS1_14empty_leaf_posISD_EERPSD_RjRmEEEDcDpOT_:
   37|  3.06k|    {
   38|  3.06k|        return Deriv::visit_inner(std::forward<Args>(args)...);
   39|  3.06k|    }
_ZN5immer6detail4rbts12visitor_baseINS1_25concat_trees_left_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEEE11visit_innerIJRNS1_25singleton_regular_sub_posISD_EENS1_14empty_leaf_posISD_EERPSD_RjRmEEEDcDpOT_:
   43|  3.06k|    {
   44|  3.06k|        return Deriv::visit_node(std::forward<Args>(args)...);
   45|  3.06k|    }
_ZN5immer6detail4rbts12visitor_baseINS1_26concat_trees_right_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEEE13visit_relaxedIJRNS1_11relaxed_posISD_EERNS1_25singleton_regular_sub_posISD_EERNS1_14empty_leaf_posISD_EEEEEDcDpOT_:
   31|  1.78k|    {
   32|  1.78k|        return Deriv::visit_inner(std::forward<Args>(args)...);
   33|  1.78k|    }
_ZN5immer6detail4rbts12visitor_baseINS1_26concat_trees_right_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEEE11visit_innerIJRNS1_11relaxed_posISD_EERNS1_25singleton_regular_sub_posISD_EERNS1_14empty_leaf_posISD_EEEEEDcDpOT_:
   43|  1.78k|    {
   44|  1.78k|        return Deriv::visit_node(std::forward<Args>(args)...);
   45|  1.78k|    }
_ZN5immer6detail4rbts12visitor_baseINS1_34concat_rebalance_plan_fill_visitorEE10visit_leafIJRNS1_12leaf_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEERNS1_21concat_rebalance_planILj2ELj2EEEEEEDcDpOT_:
   49|   890k|    {
   50|   890k|        return Deriv::visit_node(std::forward<Args>(args)...);
   51|   890k|    }
_ZN5immer6detail4rbts12visitor_baseINS1_34concat_rebalance_plan_fill_visitorEE13visit_relaxedIJRNS1_11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEERNS1_21concat_rebalance_planILj2ELj2EEEEEEDcDpOT_:
   31|  3.78M|    {
   32|  3.78M|        return Deriv::visit_inner(std::forward<Args>(args)...);
   33|  3.78M|    }
_ZN5immer6detail4rbts12visitor_baseINS1_34concat_rebalance_plan_fill_visitorEE11visit_innerIJRNS1_11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEERNS1_21concat_rebalance_planILj2ELj2EEEEEEDcDpOT_:
   43|  3.78M|    {
   44|  3.78M|        return Deriv::visit_node(std::forward<Args>(args)...);
   45|  3.78M|    }
_ZN5immer6detail4rbts12visitor_baseINS1_21concat_merger_visitorEE13visit_relaxedIJRNS1_11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEERNS1_13concat_mergerISG_EEEEEDcDpOT_:
   31|  1.34M|    {
   32|  1.34M|        return Deriv::visit_inner(std::forward<Args>(args)...);
   33|  1.34M|    }
_ZN5immer6detail4rbts12visitor_baseINS1_20concat_right_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEEE13visit_relaxedIJRNS1_11relaxed_posISD_EERNS1_25singleton_regular_sub_posISD_EERNS1_14empty_leaf_posISD_EEEEEDcDpOT_:
   31|  5.39k|    {
   32|  5.39k|        return Deriv::visit_inner(std::forward<Args>(args)...);
   33|  5.39k|    }
_ZN5immer6detail4rbts12visitor_baseINS1_20concat_right_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEEE13visit_regularIJRNS1_15regular_sub_posISD_EERNS1_25singleton_regular_sub_posISD_EERNS1_14empty_leaf_posISD_EEEEEDcDpOT_:
   37|    202|    {
   38|    202|        return Deriv::visit_inner(std::forward<Args>(args)...);
   39|    202|    }
_ZN5immer6detail4rbts12visitor_baseINS1_20concat_right_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEEE13visit_regularIJRNS1_8full_posISD_EERNS1_25singleton_regular_sub_posISD_EERNS1_14empty_leaf_posISD_EEEEEDcDpOT_:
   37|  1.19k|    {
   38|  1.19k|        return Deriv::visit_inner(std::forward<Args>(args)...);
   39|  1.19k|    }
_ZN5immer6detail4rbts12visitor_baseINS1_34concat_rebalance_plan_fill_visitorEE10visit_leafIJRNS1_13full_leaf_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEERNS1_21concat_rebalance_planILj2ELj2EEEEEEDcDpOT_:
   49|   113k|    {
   50|   113k|        return Deriv::visit_node(std::forward<Args>(args)...);
   51|   113k|    }
_ZN5immer6detail4rbts12visitor_baseINS1_34concat_rebalance_plan_fill_visitorEE13visit_regularIJRNS1_8full_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEERNS1_21concat_rebalance_planILj2ELj2EEEEEEDcDpOT_:
   37|   211k|    {
   38|   211k|        return Deriv::visit_inner(std::forward<Args>(args)...);
   39|   211k|    }
_ZN5immer6detail4rbts12visitor_baseINS1_34concat_rebalance_plan_fill_visitorEE11visit_innerIJRNS1_8full_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEERNS1_21concat_rebalance_planILj2ELj2EEEEEEDcDpOT_:
   43|   211k|    {
   44|   211k|        return Deriv::visit_node(std::forward<Args>(args)...);
   45|   211k|    }
_ZN5immer6detail4rbts12visitor_baseINS1_21concat_merger_visitorEE13visit_regularIJRNS1_8full_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEERNS1_13concat_mergerISG_EEEEEDcDpOT_:
   37|  24.8k|    {
   38|  24.8k|        return Deriv::visit_inner(std::forward<Args>(args)...);
   39|  24.8k|    }
_ZN5immer6detail4rbts12visitor_baseINS1_34concat_rebalance_plan_fill_visitorEE13visit_regularIJRNS1_15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEERNS1_21concat_rebalance_planILj2ELj2EEEEEEDcDpOT_:
   37|   140k|    {
   38|   140k|        return Deriv::visit_inner(std::forward<Args>(args)...);
   39|   140k|    }
_ZN5immer6detail4rbts12visitor_baseINS1_34concat_rebalance_plan_fill_visitorEE11visit_innerIJRNS1_15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEERNS1_21concat_rebalance_planILj2ELj2EEEEEEDcDpOT_:
   43|   140k|    {
   44|   140k|        return Deriv::visit_node(std::forward<Args>(args)...);
   45|   140k|    }
_ZN5immer6detail4rbts12visitor_baseINS1_21concat_merger_visitorEE13visit_regularIJRNS1_15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEERNS1_13concat_mergerISG_EEEEEDcDpOT_:
   37|  16.3k|    {
   38|  16.3k|        return Deriv::visit_inner(std::forward<Args>(args)...);
   39|  16.3k|    }
_ZN5immer6detail4rbts12visitor_baseINS1_26concat_trees_right_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEEE13visit_regularIJRNS1_15regular_sub_posISD_EERNS1_25singleton_regular_sub_posISD_EERNS1_14empty_leaf_posISD_EEEEEDcDpOT_:
   37|  1.28k|    {
   38|  1.28k|        return Deriv::visit_inner(std::forward<Args>(args)...);
   39|  1.28k|    }
_ZN5immer6detail4rbts12visitor_baseINS1_26concat_trees_right_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEEE11visit_innerIJRNS1_15regular_sub_posISD_EERNS1_25singleton_regular_sub_posISD_EERNS1_14empty_leaf_posISD_EEEEEDcDpOT_:
   43|  1.28k|    {
   44|  1.28k|        return Deriv::visit_node(std::forward<Args>(args)...);
   45|  1.28k|    }
_ZN5immer6detail4rbts12visitor_baseINS1_25concat_trees_left_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEEE13visit_relaxedIJRNS1_11relaxed_posISD_EENS1_8leaf_posISD_EERPSD_RjRmEEEDcDpOT_:
   31|  41.4k|    {
   32|  41.4k|        return Deriv::visit_inner(std::forward<Args>(args)...);
   33|  41.4k|    }
_ZN5immer6detail4rbts12visitor_baseINS1_25concat_trees_left_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEEE11visit_innerIJRNS1_11relaxed_posISD_EENS1_8leaf_posISD_EERPSD_RjRmEEEDcDpOT_:
   43|  41.4k|    {
   44|  41.4k|        return Deriv::visit_node(std::forward<Args>(args)...);
   45|  41.4k|    }
_ZN5immer6detail4rbts12visitor_baseINS1_26concat_trees_right_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEEE13visit_relaxedIJRNS1_11relaxed_posISD_EESJ_RNS1_8leaf_posISD_EEEEEDcDpOT_:
   31|  38.7k|    {
   32|  38.7k|        return Deriv::visit_inner(std::forward<Args>(args)...);
   33|  38.7k|    }
_ZN5immer6detail4rbts12visitor_baseINS1_26concat_trees_right_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEEE11visit_innerIJRNS1_11relaxed_posISD_EESJ_RNS1_8leaf_posISD_EEEEEDcDpOT_:
   43|  38.7k|    {
   44|  38.7k|        return Deriv::visit_node(std::forward<Args>(args)...);
   45|  38.7k|    }
_ZN5immer6detail4rbts12visitor_baseINS1_19concat_left_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEEE13visit_relaxedIJRNS1_11relaxed_posISD_EERNS1_8leaf_posISD_EESJ_EEEDcDpOT_:
   31|  2.51k|    {
   32|  2.51k|        return Deriv::visit_inner(std::forward<Args>(args)...);
   33|  2.51k|    }
_ZN5immer6detail4rbts12visitor_baseINS1_19concat_left_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEEE13visit_regularIJRNS1_15regular_sub_posISD_EERNS1_8leaf_posISD_EERNS1_11relaxed_posISD_EEEEEDcDpOT_:
   37|    799|    {
   38|    799|        return Deriv::visit_inner(std::forward<Args>(args)...);
   39|    799|    }
_ZN5immer6detail4rbts12visitor_baseINS1_20concat_right_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEEE13visit_relaxedIJRNS1_11relaxed_posISD_EERNS1_15regular_sub_posISD_EERNS1_8leaf_posISD_EEEEEDcDpOT_:
   31|  10.1k|    {
   32|  10.1k|        return Deriv::visit_inner(std::forward<Args>(args)...);
   33|  10.1k|    }
_ZN5immer6detail4rbts12visitor_baseINS1_20concat_right_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEEE13visit_regularIJRNS1_15regular_sub_posISD_EESJ_RNS1_8leaf_posISD_EEEEEDcDpOT_:
   37|    852|    {
   38|    852|        return Deriv::visit_inner(std::forward<Args>(args)...);
   39|    852|    }
_ZN5immer6detail4rbts12visitor_baseINS1_19concat_left_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEEE13visit_regularIJRNS1_15regular_sub_posISD_EERNS1_8leaf_posISD_EESJ_EEEDcDpOT_:
   37|  1.30k|    {
   38|  1.30k|        return Deriv::visit_inner(std::forward<Args>(args)...);
   39|  1.30k|    }
_ZN5immer6detail4rbts12visitor_baseINS1_20concat_right_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEEE13visit_regularIJRNS1_8full_posISD_EERNS1_15regular_sub_posISD_EERNS1_8leaf_posISD_EEEEEDcDpOT_:
   37|  4.16k|    {
   38|  4.16k|        return Deriv::visit_inner(std::forward<Args>(args)...);
   39|  4.16k|    }
_ZN5immer6detail4rbts12visitor_baseINS1_19concat_both_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEEE13visit_regularIJRNS1_15regular_sub_posISD_EERNS1_8leaf_posISD_EERNS1_8full_posISD_EEEEEDcDpOT_:
   37|  1.77k|    {
   38|  1.77k|        return Deriv::visit_inner(std::forward<Args>(args)...);
   39|  1.77k|    }
_ZN5immer6detail4rbts12visitor_baseINS1_19concat_both_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEEE13visit_regularIJRNS1_15regular_sub_posISD_EERNS1_8leaf_posISD_EESJ_EEEDcDpOT_:
   37|  1.60k|    {
   38|  1.60k|        return Deriv::visit_inner(std::forward<Args>(args)...);
   39|  1.60k|    }
_ZN5immer6detail4rbts12visitor_baseINS1_19concat_both_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEEE13visit_regularIJRNS1_15regular_sub_posISD_EERNS1_8leaf_posISD_EERNS1_11relaxed_posISD_EEEEEDcDpOT_:
   37|  10.1k|    {
   38|  10.1k|        return Deriv::visit_inner(std::forward<Args>(args)...);
   39|  10.1k|    }
_ZN5immer6detail4rbts12visitor_baseINS1_20concat_right_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEEE13visit_relaxedIJRNS1_11relaxed_posISD_EESJ_RNS1_8leaf_posISD_EEEEEDcDpOT_:
   31|   170k|    {
   32|   170k|        return Deriv::visit_inner(std::forward<Args>(args)...);
   33|   170k|    }
_ZN5immer6detail4rbts12visitor_baseINS1_20concat_right_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEEE13visit_regularIJRNS1_15regular_sub_posISD_EERNS1_11relaxed_posISD_EERNS1_8leaf_posISD_EEEEEDcDpOT_:
   37|    297|    {
   38|    297|        return Deriv::visit_inner(std::forward<Args>(args)...);
   39|    297|    }
_ZN5immer6detail4rbts12visitor_baseINS1_19concat_left_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEEE13visit_relaxedIJRNS1_11relaxed_posISD_EERNS1_8leaf_posISD_EERNS1_15regular_sub_posISD_EEEEEDcDpOT_:
   31|  1.66k|    {
   32|  1.66k|        return Deriv::visit_inner(std::forward<Args>(args)...);
   33|  1.66k|    }
_ZN5immer6detail4rbts12visitor_baseINS1_20concat_right_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEEE13visit_regularIJRNS1_8full_posISD_EERNS1_11relaxed_posISD_EERNS1_8leaf_posISD_EEEEEDcDpOT_:
   37|  2.09k|    {
   38|  2.09k|        return Deriv::visit_inner(std::forward<Args>(args)...);
   39|  2.09k|    }
_ZN5immer6detail4rbts12visitor_baseINS1_19concat_both_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEEE13visit_relaxedIJRNS1_11relaxed_posISD_EERNS1_8leaf_posISD_EERNS1_8full_posISD_EEEEEDcDpOT_:
   31|    430|    {
   32|    430|        return Deriv::visit_inner(std::forward<Args>(args)...);
   33|    430|    }
_ZN5immer6detail4rbts12visitor_baseINS1_19concat_both_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEEE13visit_relaxedIJRNS1_11relaxed_posISD_EERNS1_8leaf_posISD_EERNS1_15regular_sub_posISD_EEEEEDcDpOT_:
   31|    811|    {
   32|    811|        return Deriv::visit_inner(std::forward<Args>(args)...);
   33|    811|    }
_ZN5immer6detail4rbts12visitor_baseINS1_19concat_both_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEEE13visit_relaxedIJRNS1_11relaxed_posISD_EERNS1_8leaf_posISD_EESJ_EEEDcDpOT_:
   31|   167k|    {
   32|   167k|        return Deriv::visit_inner(std::forward<Args>(args)...);
   33|   167k|    }
_ZN5immer6detail4rbts12visitor_baseINS1_26concat_trees_right_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEEE13visit_regularIJRNS1_15regular_sub_posISD_EERNS1_11relaxed_posISD_EERNS1_8leaf_posISD_EEEEEDcDpOT_:
   37|  2.66k|    {
   38|  2.66k|        return Deriv::visit_inner(std::forward<Args>(args)...);
   39|  2.66k|    }
_ZN5immer6detail4rbts12visitor_baseINS1_26concat_trees_right_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEEE11visit_innerIJRNS1_15regular_sub_posISD_EERNS1_11relaxed_posISD_EERNS1_8leaf_posISD_EEEEEDcDpOT_:
   43|  2.66k|    {
   44|  2.66k|        return Deriv::visit_node(std::forward<Args>(args)...);
   45|  2.66k|    }
_ZN5immer6detail4rbts12visitor_baseINS1_25concat_trees_left_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEEE13visit_regularIJRNS1_15regular_sub_posISD_EENS1_8leaf_posISD_EERPSD_RjRmEEEDcDpOT_:
   37|  5.78k|    {
   38|  5.78k|        return Deriv::visit_inner(std::forward<Args>(args)...);
   39|  5.78k|    }
_ZN5immer6detail4rbts12visitor_baseINS1_25concat_trees_left_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEEE11visit_innerIJRNS1_15regular_sub_posISD_EENS1_8leaf_posISD_EERPSD_RjRmEEEDcDpOT_:
   43|  5.78k|    {
   44|  5.78k|        return Deriv::visit_node(std::forward<Args>(args)...);
   45|  5.78k|    }
_ZN5immer6detail4rbts12visitor_baseINS1_26concat_trees_right_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEEE13visit_relaxedIJRNS1_11relaxed_posISD_EERNS1_15regular_sub_posISD_EERNS1_8leaf_posISD_EEEEEDcDpOT_:
   31|    840|    {
   32|    840|        return Deriv::visit_inner(std::forward<Args>(args)...);
   33|    840|    }
_ZN5immer6detail4rbts12visitor_baseINS1_26concat_trees_right_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEEE11visit_innerIJRNS1_11relaxed_posISD_EERNS1_15regular_sub_posISD_EERNS1_8leaf_posISD_EEEEEDcDpOT_:
   43|    840|    {
   44|    840|        return Deriv::visit_node(std::forward<Args>(args)...);
   45|    840|    }
_ZN5immer6detail4rbts12visitor_baseINS1_26concat_trees_right_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEEE13visit_regularIJRNS1_15regular_sub_posISD_EESJ_RNS1_8leaf_posISD_EEEEEDcDpOT_:
   37|  4.94k|    {
   38|  4.94k|        return Deriv::visit_inner(std::forward<Args>(args)...);
   39|  4.94k|    }
_ZN5immer6detail4rbts12visitor_baseINS1_26concat_trees_right_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEEE11visit_innerIJRNS1_15regular_sub_posISD_EESJ_RNS1_8leaf_posISD_EEEEEDcDpOT_:
   43|  4.94k|    {
   44|  4.94k|        return Deriv::visit_node(std::forward<Args>(args)...);
   45|  4.94k|    }
_ZN5immer6detail4rbts12visitor_baseINS1_29concat_trees_left_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEEE13visit_regularIJRNS1_25singleton_regular_sub_posISD_EERNSB_5applyIS8_E4type4editESO_NS1_14empty_leaf_posISD_EESO_RPSD_RjRmEEEDcDpOT_:
   37|  7.40k|    {
   38|  7.40k|        return Deriv::visit_inner(std::forward<Args>(args)...);
   39|  7.40k|    }
_ZN5immer6detail4rbts12visitor_baseINS1_29concat_trees_left_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEEE11visit_innerIJRNS1_25singleton_regular_sub_posISD_EERNSB_5applyIS8_E4type4editESO_NS1_14empty_leaf_posISD_EESO_RPSD_RjRmEEEDcDpOT_:
   43|  7.40k|    {
   44|  7.40k|        return Deriv::visit_node(std::forward<Args>(args)...);
   45|  7.40k|    }
_ZN5immer6detail4rbts12visitor_baseINS1_30concat_trees_right_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEEE13visit_relaxedIJRNS1_11relaxed_posISD_EERNSB_5applyIS8_E4type4editESO_RNS1_25singleton_regular_sub_posISD_EERNS1_14empty_leaf_posISD_EESO_EEEDcDpOT_:
   31|  4.01k|    {
   32|  4.01k|        return Deriv::visit_inner(std::forward<Args>(args)...);
   33|  4.01k|    }
_ZN5immer6detail4rbts12visitor_baseINS1_30concat_trees_right_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEEE11visit_innerIJRNS1_11relaxed_posISD_EERNSB_5applyIS8_E4type4editESO_RNS1_25singleton_regular_sub_posISD_EERNS1_14empty_leaf_posISD_EESO_EEEDcDpOT_:
   43|  4.01k|    {
   44|  4.01k|        return Deriv::visit_node(std::forward<Args>(args)...);
   45|  4.01k|    }
_ZN5immer6detail4rbts12visitor_baseINS1_25concat_merger_mut_visitorEE13visit_relaxedIJRNS1_11relaxed_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEERNS1_17concat_merger_mutISG_EERNSE_5applyISB_E4type4editEEEEDcDpOT_:
   31|  2.44M|    {
   32|  2.44M|        return Deriv::visit_inner(std::forward<Args>(args)...);
   33|  2.44M|    }
_ZN5immer6detail4rbts12visitor_baseINS1_24concat_right_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEEE13visit_relaxedIJRNS1_11relaxed_posISD_EERNSB_5applyIS8_E4type4editESO_RNS1_25singleton_regular_sub_posISD_EERNS1_14empty_leaf_posISD_EESO_EEEDcDpOT_:
   31|  13.2k|    {
   32|  13.2k|        return Deriv::visit_inner(std::forward<Args>(args)...);
   33|  13.2k|    }
_ZN5immer6detail4rbts12visitor_baseINS1_24concat_right_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEEE13visit_regularIJRNS1_15regular_sub_posISD_EERNSB_5applyIS8_E4type4editESO_RNS1_25singleton_regular_sub_posISD_EERNS1_14empty_leaf_posISD_EESO_EEEDcDpOT_:
   37|    268|    {
   38|    268|        return Deriv::visit_inner(std::forward<Args>(args)...);
   39|    268|    }
_ZN5immer6detail4rbts12visitor_baseINS1_24concat_right_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEEE13visit_regularIJRNS1_8full_posISD_EERNSB_5applyIS8_E4type4editESO_RNS1_25singleton_regular_sub_posISD_EERNS1_14empty_leaf_posISD_EESO_EEEDcDpOT_:
   37|  1.85k|    {
   38|  1.85k|        return Deriv::visit_inner(std::forward<Args>(args)...);
   39|  1.85k|    }
_ZN5immer6detail4rbts12visitor_baseINS1_25concat_merger_mut_visitorEE13visit_regularIJRNS1_8full_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEERNS1_17concat_merger_mutISG_EERNSE_5applyISB_E4type4editEEEEDcDpOT_:
   37|   186k|    {
   38|   186k|        return Deriv::visit_inner(std::forward<Args>(args)...);
   39|   186k|    }
_ZN5immer6detail4rbts12visitor_baseINS1_25concat_merger_mut_visitorEE13visit_regularIJRNS1_15regular_sub_posINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEERNS1_17concat_merger_mutISG_EERNSE_5applyISB_E4type4editEEEEDcDpOT_:
   37|   123k|    {
   38|   123k|        return Deriv::visit_inner(std::forward<Args>(args)...);
   39|   123k|    }
_ZN5immer6detail4rbts12visitor_baseINS1_30concat_trees_right_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEEE13visit_regularIJRNS1_15regular_sub_posISD_EERNSB_5applyIS8_E4type4editESO_RNS1_25singleton_regular_sub_posISD_EERNS1_14empty_leaf_posISD_EESO_EEEDcDpOT_:
   37|  3.39k|    {
   38|  3.39k|        return Deriv::visit_inner(std::forward<Args>(args)...);
   39|  3.39k|    }
_ZN5immer6detail4rbts12visitor_baseINS1_30concat_trees_right_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEEE11visit_innerIJRNS1_15regular_sub_posISD_EERNSB_5applyIS8_E4type4editESO_RNS1_25singleton_regular_sub_posISD_EERNS1_14empty_leaf_posISD_EESO_EEEDcDpOT_:
   43|  3.39k|    {
   44|  3.39k|        return Deriv::visit_node(std::forward<Args>(args)...);
   45|  3.39k|    }
_ZN5immer6detail4rbts12visitor_baseINS1_29concat_trees_left_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEEE13visit_relaxedIJRNS1_11relaxed_posISD_EERNSB_5applyIS8_E4type4editESO_NS1_8leaf_posISD_EESO_RPSD_RjRmEEEDcDpOT_:
   31|  93.3k|    {
   32|  93.3k|        return Deriv::visit_inner(std::forward<Args>(args)...);
   33|  93.3k|    }
_ZN5immer6detail4rbts12visitor_baseINS1_29concat_trees_left_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEEE11visit_innerIJRNS1_11relaxed_posISD_EERNSB_5applyIS8_E4type4editESO_NS1_8leaf_posISD_EESO_RPSD_RjRmEEEDcDpOT_:
   43|  93.3k|    {
   44|  93.3k|        return Deriv::visit_node(std::forward<Args>(args)...);
   45|  93.3k|    }
_ZN5immer6detail4rbts12visitor_baseINS1_30concat_trees_right_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEEE13visit_relaxedIJRNS1_11relaxed_posISD_EERNSB_5applyIS8_E4type4editESO_SJ_RNS1_8leaf_posISD_EESO_EEEDcDpOT_:
   31|  65.6k|    {
   32|  65.6k|        return Deriv::visit_inner(std::forward<Args>(args)...);
   33|  65.6k|    }
_ZN5immer6detail4rbts12visitor_baseINS1_30concat_trees_right_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEEE11visit_innerIJRNS1_11relaxed_posISD_EERNSB_5applyIS8_E4type4editESO_SJ_RNS1_8leaf_posISD_EESO_EEEDcDpOT_:
   43|  65.6k|    {
   44|  65.6k|        return Deriv::visit_node(std::forward<Args>(args)...);
   45|  65.6k|    }
_ZN5immer6detail4rbts12visitor_baseINS1_23concat_left_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEEE13visit_relaxedIJRNS1_11relaxed_posISD_EERNSB_5applyIS8_E4type4editESO_RNS1_8leaf_posISD_EESO_SJ_EEEDcDpOT_:
   31|   199k|    {
   32|   199k|        return Deriv::visit_inner(std::forward<Args>(args)...);
   33|   199k|    }
_ZN5immer6detail4rbts12visitor_baseINS1_23concat_left_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEEE13visit_regularIJRNS1_15regular_sub_posISD_EERNSB_5applyIS8_E4type4editESO_RNS1_8leaf_posISD_EESO_RNS1_11relaxed_posISD_EEEEEDcDpOT_:
   37|  3.90k|    {
   38|  3.90k|        return Deriv::visit_inner(std::forward<Args>(args)...);
   39|  3.90k|    }
_ZN5immer6detail4rbts12visitor_baseINS1_24concat_right_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEEE13visit_relaxedIJRNS1_11relaxed_posISD_EERNSB_5applyIS8_E4type4editESO_RNS1_15regular_sub_posISD_EERNS1_8leaf_posISD_EESO_EEEDcDpOT_:
   31|   109k|    {
   32|   109k|        return Deriv::visit_inner(std::forward<Args>(args)...);
   33|   109k|    }
_ZN5immer6detail4rbts12visitor_baseINS1_24concat_right_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEEE13visit_regularIJRNS1_15regular_sub_posISD_EERNSB_5applyIS8_E4type4editESO_SJ_RNS1_8leaf_posISD_EESO_EEEDcDpOT_:
   37|  2.91k|    {
   38|  2.91k|        return Deriv::visit_inner(std::forward<Args>(args)...);
   39|  2.91k|    }
_ZN5immer6detail4rbts12visitor_baseINS1_23concat_left_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEEE13visit_regularIJRNS1_15regular_sub_posISD_EERNSB_5applyIS8_E4type4editESO_RNS1_8leaf_posISD_EESO_SJ_EEEDcDpOT_:
   37|  2.50k|    {
   38|  2.50k|        return Deriv::visit_inner(std::forward<Args>(args)...);
   39|  2.50k|    }
_ZN5immer6detail4rbts12visitor_baseINS1_24concat_right_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEEE13visit_regularIJRNS1_8full_posISD_EERNSB_5applyIS8_E4type4editESO_RNS1_15regular_sub_posISD_EERNS1_8leaf_posISD_EESO_EEEDcDpOT_:
   37|  18.5k|    {
   38|  18.5k|        return Deriv::visit_inner(std::forward<Args>(args)...);
   39|  18.5k|    }
_ZN5immer6detail4rbts12visitor_baseINS1_23concat_both_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEEE13visit_regularIJRNS1_15regular_sub_posISD_EERNSB_5applyIS8_E4type4editESO_RNS1_8leaf_posISD_EESO_RNS1_8full_posISD_EEEEEDcDpOT_:
   37|  12.0k|    {
   38|  12.0k|        return Deriv::visit_inner(std::forward<Args>(args)...);
   39|  12.0k|    }
_ZN5immer6detail4rbts12visitor_baseINS1_23concat_both_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEEE13visit_regularIJRNS1_15regular_sub_posISD_EERNSB_5applyIS8_E4type4editESO_RNS1_8leaf_posISD_EESO_SJ_EEEDcDpOT_:
   37|  5.78k|    {
   38|  5.78k|        return Deriv::visit_inner(std::forward<Args>(args)...);
   39|  5.78k|    }
_ZN5immer6detail4rbts12visitor_baseINS1_23concat_both_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEEE13visit_regularIJRNS1_15regular_sub_posISD_EERNSB_5applyIS8_E4type4editESO_RNS1_8leaf_posISD_EESO_RNS1_11relaxed_posISD_EEEEEDcDpOT_:
   37|   103k|    {
   38|   103k|        return Deriv::visit_inner(std::forward<Args>(args)...);
   39|   103k|    }
_ZN5immer6detail4rbts12visitor_baseINS1_24concat_right_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEEE13visit_relaxedIJRNS1_11relaxed_posISD_EERNSB_5applyIS8_E4type4editESO_SJ_RNS1_8leaf_posISD_EESO_EEEDcDpOT_:
   31|   230k|    {
   32|   230k|        return Deriv::visit_inner(std::forward<Args>(args)...);
   33|   230k|    }
_ZN5immer6detail4rbts12visitor_baseINS1_24concat_right_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEEE13visit_regularIJRNS1_15regular_sub_posISD_EERNSB_5applyIS8_E4type4editESO_RNS1_11relaxed_posISD_EERNS1_8leaf_posISD_EESO_EEEDcDpOT_:
   37|  1.40k|    {
   38|  1.40k|        return Deriv::visit_inner(std::forward<Args>(args)...);
   39|  1.40k|    }
_ZN5immer6detail4rbts12visitor_baseINS1_23concat_left_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEEE13visit_relaxedIJRNS1_11relaxed_posISD_EERNSB_5applyIS8_E4type4editESO_RNS1_8leaf_posISD_EESO_RNS1_15regular_sub_posISD_EEEEEDcDpOT_:
   31|   116k|    {
   32|   116k|        return Deriv::visit_inner(std::forward<Args>(args)...);
   33|   116k|    }
_ZN5immer6detail4rbts12visitor_baseINS1_24concat_right_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEEE13visit_regularIJRNS1_8full_posISD_EERNSB_5applyIS8_E4type4editESO_RNS1_11relaxed_posISD_EERNS1_8leaf_posISD_EESO_EEEDcDpOT_:
   37|  2.40k|    {
   38|  2.40k|        return Deriv::visit_inner(std::forward<Args>(args)...);
   39|  2.40k|    }
_ZN5immer6detail4rbts12visitor_baseINS1_23concat_both_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEEE13visit_relaxedIJRNS1_11relaxed_posISD_EERNSB_5applyIS8_E4type4editESO_RNS1_8leaf_posISD_EESO_RNS1_8full_posISD_EEEEEDcDpOT_:
   31|    461|    {
   32|    461|        return Deriv::visit_inner(std::forward<Args>(args)...);
   33|    461|    }
_ZN5immer6detail4rbts12visitor_baseINS1_23concat_both_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEEE13visit_relaxedIJRNS1_11relaxed_posISD_EERNSB_5applyIS8_E4type4editESO_RNS1_8leaf_posISD_EESO_RNS1_15regular_sub_posISD_EEEEEDcDpOT_:
   31|    963|    {
   32|    963|        return Deriv::visit_inner(std::forward<Args>(args)...);
   33|    963|    }
_ZN5immer6detail4rbts12visitor_baseINS1_23concat_both_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEEE13visit_relaxedIJRNS1_11relaxed_posISD_EERNSB_5applyIS8_E4type4editESO_RNS1_8leaf_posISD_EESO_SJ_EEEDcDpOT_:
   31|   186k|    {
   32|   186k|        return Deriv::visit_inner(std::forward<Args>(args)...);
   33|   186k|    }
_ZN5immer6detail4rbts12visitor_baseINS1_30concat_trees_right_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEEE13visit_regularIJRNS1_15regular_sub_posISD_EERNSB_5applyIS8_E4type4editESO_RNS1_11relaxed_posISD_EERNS1_8leaf_posISD_EESO_EEEDcDpOT_:
   37|  27.6k|    {
   38|  27.6k|        return Deriv::visit_inner(std::forward<Args>(args)...);
   39|  27.6k|    }
_ZN5immer6detail4rbts12visitor_baseINS1_30concat_trees_right_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEEE11visit_innerIJRNS1_15regular_sub_posISD_EERNSB_5applyIS8_E4type4editESO_RNS1_11relaxed_posISD_EERNS1_8leaf_posISD_EESO_EEEDcDpOT_:
   43|  27.6k|    {
   44|  27.6k|        return Deriv::visit_node(std::forward<Args>(args)...);
   45|  27.6k|    }
_ZN5immer6detail4rbts12visitor_baseINS1_29concat_trees_left_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEEE13visit_regularIJRNS1_15regular_sub_posISD_EERNSB_5applyIS8_E4type4editESO_NS1_8leaf_posISD_EESO_RPSD_RjRmEEEDcDpOT_:
   37|  6.37k|    {
   38|  6.37k|        return Deriv::visit_inner(std::forward<Args>(args)...);
   39|  6.37k|    }
_ZN5immer6detail4rbts12visitor_baseINS1_29concat_trees_left_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEEE11visit_innerIJRNS1_15regular_sub_posISD_EERNSB_5applyIS8_E4type4editESO_NS1_8leaf_posISD_EESO_RPSD_RjRmEEEDcDpOT_:
   43|  6.37k|    {
   44|  6.37k|        return Deriv::visit_node(std::forward<Args>(args)...);
   45|  6.37k|    }
_ZN5immer6detail4rbts12visitor_baseINS1_30concat_trees_right_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEEE13visit_relaxedIJRNS1_11relaxed_posISD_EERNSB_5applyIS8_E4type4editESO_RNS1_15regular_sub_posISD_EERNS1_8leaf_posISD_EESO_EEEDcDpOT_:
   31|  3.39k|    {
   32|  3.39k|        return Deriv::visit_inner(std::forward<Args>(args)...);
   33|  3.39k|    }
_ZN5immer6detail4rbts12visitor_baseINS1_30concat_trees_right_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEEE11visit_innerIJRNS1_11relaxed_posISD_EERNSB_5applyIS8_E4type4editESO_RNS1_15regular_sub_posISD_EERNS1_8leaf_posISD_EESO_EEEDcDpOT_:
   43|  3.39k|    {
   44|  3.39k|        return Deriv::visit_node(std::forward<Args>(args)...);
   45|  3.39k|    }
_ZN5immer6detail4rbts12visitor_baseINS1_30concat_trees_right_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEEE13visit_regularIJRNS1_15regular_sub_posISD_EERNSB_5applyIS8_E4type4editESO_SJ_RNS1_8leaf_posISD_EESO_EEEDcDpOT_:
   37|  2.97k|    {
   38|  2.97k|        return Deriv::visit_inner(std::forward<Args>(args)...);
   39|  2.97k|    }
_ZN5immer6detail4rbts12visitor_baseINS1_30concat_trees_right_mut_visitorINS1_4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEEEE11visit_innerIJRNS1_15regular_sub_posISD_EERNSB_5applyIS8_E4type4editESO_SJ_RNS1_8leaf_posISD_EESO_EEEDcDpOT_:
   43|  2.97k|    {
   44|  2.97k|        return Deriv::visit_node(std::forward<Args>(args)...);
   45|  2.97k|    }

_ZN5immer6detail21with_trailing_storageINS0_4rbts4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE7inner_tEPSC_Lb0EE18get_storage_offsetEv:
  127|   898k|    {
  128|   898k|        check_base();
  129|   898k|        return sizeof(Derived);
  130|   898k|    }
_ZN5immer6detail21with_trailing_storageINS0_4rbts4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE7inner_tEPSC_Lb0EE10check_baseEv:
  134|  36.6M|    {
  135|  36.6M|        static_assert(std::is_standard_layout<Derived>::value &&
  136|  36.6M|                          !std::is_empty<Derived>::value,
  137|  36.6M|                      "Please add 'true' if the derived class is emtpy");
  138|  36.6M|    }
_ZN5immer6detail15auto_const_castINS_18no_refcount_policyEEERT_RKS3_:
  143|  22.1M|{
  144|  22.1M|    return const_cast<T&>(x);
  145|  22.1M|}
_ZN5immer6detail21with_trailing_storageINS0_4rbts4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE6leaf_tEiLb1EE18get_storage_offsetEv:
   87|   366k|    {
   88|   366k|        check_base();
   89|   366k|        return 0;
   90|   366k|    }
_ZN5immer6detail21with_trailing_storageINS0_4rbts4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE6leaf_tEiLb1EE10check_baseEv:
   94|  9.09M|    {
   95|       |        // is_standard_layout requires that only one class in the hierarchy
   96|       |        // contains non-static data members. Since this class contains one
   97|       |        // member, the static_assert will only hold when the derived class is
   98|       |        // empty.
   99|  9.09M|        static_assert(std::is_standard_layout<Derived>::value,
  100|  9.09M|                      "Please remove 'true' if the derived class is non emtpy");
  101|  9.09M|    }
_ZN5immer6detail21with_trailing_storageINS0_4rbts4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE7inner_tEPSC_Lb0EE15get_storage_ptrEv:
  113|  35.7M|    {
  114|  35.7M|        check_base();
  115|  35.7M|        auto* base = static_cast<Derived*>(this);
  116|  35.7M|        return reinterpret_cast<T*>(base + 1);
  117|  35.7M|    }
_ZN5immer6detail9destroy_nIPijEENSt3__19enable_ifIX20can_trivially_detroyIT_EES5_E4typeES5_T0_:
  188|  3.23k|{
  189|  3.23k|    return first + n;
  190|  3.23k|}
_ZN5immer6detail21with_trailing_storageINS0_4rbts4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE6leaf_tEiLb1EE15get_storage_ptrEv:
   75|  8.73M|    {
   76|  8.73M|        check_base();
   77|  8.73M|        return reinterpret_cast<T*>(this);
   78|  8.73M|    }
_ZN5immer6detail18uninitialized_copyIPiS2_S2_EENSt3__19enable_ifIX18can_trivially_copyIT_T1_EES6_E4typeES5_T0_S6_:
  236|  2.89M|{
  237|  2.89M|    return std::copy(first, last, out);
  238|  2.89M|}
_ZN5immer6detail9static_ifILb0EPNS0_4rbts4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEZNSC_15make_inner_sr_nEjPNS0_3csl10member_twoINSC_14relaxed_data_tENSE_7inheritIS8_NSE_6memberINSA_5applyIS7_E4type5owneeEvE4typeEE4typeEE4typeEEUlT_E_ZNSC_15make_inner_sr_nEjST_EUlSU_E0_EENSt3__19enable_ifIXntT_ET0_E4typeEOT1_OT2_:
  344|  26.0k|{
  345|  26.0k|    return std::forward<F2>(f2)(empty_t{});
  346|  26.0k|}
_ZN5immer6detail4ipowImEET_S2_j:
  323|  63.7M|{
  324|  63.7M|    return pow == 0 ? 1 : num * ipow(num, pow - 1);
  ------------------
  |  Branch (324:12): [True: 1.99M, False: 61.7M]
  ------------------
  325|  63.7M|}
_ZN5immer6detail9static_ifILb0EPNS0_3csl10member_twoINS0_4rbts4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE14relaxed_data_tENS2_7inheritISA_NS2_6memberINSC_5applyIS9_E4type5owneeEvE4typeEE4typeEE4typeEZNSE_24ensure_mutable_relaxed_nENSK_4editEjEUlT_E_ZNSE_24ensure_mutable_relaxed_nEST_jEUlSU_E0_EENSt3__19enable_ifIXntT_ET0_E4typeEOT1_OT2_:
  344|   887k|{
  345|   887k|    return std::forward<F2>(f2)(empty_t{});
  346|   887k|}
_ZN5immer6detail9static_ifILb1EZNS0_4rbts4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE14make_inner_r_eENSA_5applyIS7_E4type4editEEUlT_E_EENSt3__19enable_ifIXT_EvE4typeEOT0_:
  329|   819k|{
  330|   819k|    std::forward<F>(f)(empty_t{});
  331|   819k|}
_ZN5immer6detail9static_ifILb0EPNS0_4rbts4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEEZNSC_15make_inner_sr_eENSA_5applyIS7_E4type4editEPNS0_3csl10member_twoINSC_14relaxed_data_tENSI_7inheritIS8_NSI_6memberINSG_5owneeEvE4typeEE4typeEE4typeEEUlT_E_ZNSC_15make_inner_sr_eESH_SU_EUlSV_E0_EENSt3__19enable_ifIXntT_ET0_E4typeEOT1_OT2_:
  344|  21.3k|{
  345|  21.3k|    return std::forward<F2>(f2)(empty_t{});
  346|  21.3k|}
_ZN5immer6detail9destroy_nIPimEENSt3__19enable_ifIX20can_trivially_detroyIT_EES5_E4typeES5_T0_:
  188|    428|{
  189|    428|    return first + n;
  190|    428|}
_ZN5immer6detail9static_ifILb0EPNS0_3csl10member_twoINS0_4rbts4nodeIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE14relaxed_data_tENS2_7inheritISA_NS2_6memberINSC_5applyIS9_E4type5owneeEvE4typeEE4typeEE4typeEZNSE_24ensure_mutable_relaxed_eENSK_4editEST_EUlT_E_ZNSE_24ensure_mutable_relaxed_eEST_ST_EUlSU_E0_EENSt3__19enable_ifIXntT_ET0_E4typeEOT1_OT2_:
  344|   437k|{
  345|   437k|    return std::forward<F2>(f2)(empty_t{});
  346|   437k|}
_ZN5immer6detail18uninitialized_moveIPiS2_EENSt3__19enable_ifIX18can_trivially_copyIT_T0_EES6_E4typeES5_S5_S6_:
  210|  2.03k|{
  211|  2.03k|    return std::copy(first, last, out);
  212|  2.03k|}

_ZN5immer11flex_vectorIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEC2Ev:
   96|  31.1k|    flex_vector() = default;
_ZNKR5immer11flex_vectorIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE9transientEv:
  507|   116k|    IMMER_NODISCARD transient_type transient() const& { return impl_; }
_ZN5immer11flex_vectorIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEC2ENS_6detail4rbts7rrbtreeIiS8_Lj2ELj2EEE:
  536|   183k|        : impl_(std::move(impl))
  537|   183k|    {
  538|       |#if IMMER_DEBUG_PRINT
  539|       |        // force the compiler to generate debug_print, so we can call
  540|       |        // it from a debugger
  541|       |        [](volatile auto) {}(&flex_vector::debug_print);
  542|       |#endif
  543|   183k|    }
_ZNKR5immer11flex_vectorIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE9push_backEi:
  246|  67.5k|    {
  247|  67.5k|        return impl_.push_back(std::move(value));
  248|  67.5k|    }
_ZNK5immer11flex_vectorIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE4sizeEv:
  181|   178k|    IMMER_NODISCARD size_type size() const { return impl_.size; }
flex-vector-gc.cpp:_ZNKR5immer11flex_vectorIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE6updateIZZ22LLVMFuzzerTestOneInputENK3$_5clI12fuzzer_inputEEDaRT_EUlSE_E_EES9_mOSE_:
  323|  5.60k|    {
  324|  5.60k|        return impl_.update(index, std::forward<FnT>(fn));
  325|  5.60k|    }
_ZNKR5immer11flex_vectorIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE4takeEm:
  350|  12.5k|    {
  351|  12.5k|        return impl_.take(elems);
  352|  12.5k|    }
_ZNKR5immer11flex_vectorIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE4dropEm:
  376|  18.0k|    {
  377|  18.0k|        return impl_.drop(elems);
  378|  18.0k|    }
_ZN5immer11flex_vectorIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE8max_sizeEv:
   90|  1.93M|    constexpr static size_type max_size() { return impl_t::max_size(); }
_ZN5immerplERKNS_11flex_vectorIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEESB_:
  403|  57.8k|    {
  404|  57.8k|        return l.impl_.concat(r.impl_);
  405|  57.8k|    }

_ZN5immer21flex_vector_transientIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEC2Ev:
   71|  41.2k|    flex_vector_transient() = default;
_ZN5immer21flex_vector_transientIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EEC2ENS_6detail4rbts7rrbtreeIiS8_Lj2ELj2EEE:
  243|   116k|        : impl_(std::move(impl))
  244|   116k|    {
  245|   116k|    }
_ZNR5immer21flex_vector_transientIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE10persistentEv:
  233|  21.5k|    {
  234|  21.5k|        this->owner_t::operator=(owner_t{});
  235|  21.5k|        return impl_;
  236|  21.5k|    }
_ZN5immer21flex_vector_transientIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE9push_backEi:
  156|  49.0k|    {
  157|  49.0k|        impl_.push_back_mut(*this, std::move(value));
  158|  49.0k|    }
_ZNK5immer21flex_vector_transientIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE4sizeEv:
  127|  3.80M|    IMMER_NODISCARD size_type size() const { return impl_.size; }
flex-vector-gc.cpp:_ZN5immer21flex_vector_transientIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE6updateIZZ22LLVMFuzzerTestOneInputENK3$_5clI12fuzzer_inputEEDaRT_EUlSE_E0_EEvmOSE_:
  180|  11.4k|    {
  181|  11.4k|        impl_.update_mut(*this, index, std::forward<FnT>(fn));
  182|  11.4k|    }
_ZN5immer21flex_vector_transientIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE4takeEm:
  189|  40.4k|    void take(size_type elems) { impl_.take_mut(*this, elems); }
_ZN5immer21flex_vector_transientIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE7prependERS9_:
  219|  33.8k|    {
  220|  33.8k|        l.owner_t::operator=(owner_t{});
  221|  33.8k|        concat_mut_r(l.impl_, impl_, *this);
  222|  33.8k|    }
_ZN5immer21flex_vector_transientIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE7prependEOS9_:
  224|  4.19k|    {
  225|  4.19k|        concat_mut_lr_r(l.impl_, l, impl_, *this);
  226|  4.19k|    }
_ZN5immer21flex_vector_transientIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE6appendERS9_:
  204|  1.79M|    {
  205|  1.79M|        r.owner_t::operator=(owner_t{});
  206|  1.79M|        concat_mut_l(impl_, *this, r.impl_);
  207|  1.79M|    }
_ZN5immer21flex_vector_transientIiNS_13memory_policyINS_11heap_policyINS_7gc_heapEEENS_18no_refcount_policyENS_15spinlock_policyENS_20gc_transience_policyELb0ELb0EEELj2ELj2EE6appendEOS9_:
  209|  5.91k|    {
  210|  5.91k|        concat_mut_lr_l(impl_, *this, r.impl_, r);
  211|  5.91k|    }

_ZN5immer16gc_disable_guardC2Ev:
  137|  7.78k|    gc_disable_guard() { GC_disable(); }
_ZN5immer7gc_heap8allocateEmNS_10norefs_tagE:
  115|  3.49M|    {
  116|  3.49M|        IMMER_GC_INIT_GUARD_;
  117|  3.49M|        auto p = GC_malloc_atomic(n);
  118|  3.49M|        if (IMMER_UNLIKELY(!p))
  ------------------
  |  |  116|  3.49M|#define IMMER_UNLIKELY(cond) __builtin_expect(!!(cond), 0)
  |  |  ------------------
  |  |  |  Branch (116:30): [True: 0, False: 3.49M]
  |  |  ------------------
  ------------------
  119|      0|            IMMER_THROW(std::bad_alloc{});
  ------------------
  |  |   51|      0|#define IMMER_THROW(expr) throw expr
  ------------------
  120|  3.49M|        return p;
  121|  3.49M|    }
_ZN5immer16gc_disable_guardD2Ev:
  140|  7.78k|    {
  141|  7.78k|        GC_enable();
  142|  7.78k|        GC_gcollect();
  143|  7.78k|    }
_ZN5immer7gc_heap8allocateEm:
  106|  3.77M|    {
  107|  3.77M|        IMMER_GC_INIT_GUARD_;
  108|  3.77M|        auto p = GC_malloc(n);
  109|  3.77M|        if (IMMER_UNLIKELY(!p))
  ------------------
  |  |  116|  3.77M|#define IMMER_UNLIKELY(cond) __builtin_expect(!!(cond), 0)
  |  |  ------------------
  |  |  |  Branch (116:30): [True: 0, False: 3.77M]
  |  |  ------------------
  ------------------
  110|      0|            IMMER_THROW(std::bad_alloc{});
  ------------------
  |  |   51|      0|#define IMMER_THROW(expr) throw expr
  ------------------
  111|  3.77M|        return p;
  112|  3.77M|    }

_ZN5immer18no_refcount_policyC2Ev:
   22|  5.26M|    no_refcount_policy(){};
_ZN5immer18no_refcount_policy3incEv:
   25|  4.14M|    void inc() {}
_ZN5immer18no_refcount_policy3decEv:
   26|  2.13M|    bool dec() { return false; }
_ZN5immer18no_refcount_policy6uniqueEv:
   27|  15.8M|    bool unique() { return false; }

_ZN5immer20gc_transience_policy5applyINS_11heap_policyINS_7gc_heapEEEE4type5ownerC2Ev:
   60|  2.01M|                    : token_{make_token_()}
   61|  2.01M|                {
   62|  2.01M|                }
_ZN5immer20gc_transience_policy5applyINS_11heap_policyINS_7gc_heapEEEE4type5owner11make_token_Ev:
   51|  2.01M|                {
   52|  2.01M|                    return heap_::allocate(1, norefs_tag{});
   53|  2.01M|                };
_ZNK5immer20gc_transience_policy5applyINS_11heap_policyINS_7gc_heapEEEE4type4editneES7_:
   45|  4.18M|                bool operator!=(edit x) const { return v != x.v; }
_ZN5immer20gc_transience_policy5applyINS_11heap_policyINS_7gc_heapEEEE4type5owneraSEOS7_:
   79|  1.97M|                {
   80|  1.97M|                    token_ = o.token_.load();
   81|  1.97M|                    return *this;
   82|  1.97M|                }
_ZNK5immer20gc_transience_policy5applyINS_11heap_policyINS_7gc_heapEEEE4type5ownee10can_mutateENS6_4editE:
   99|  15.8M|                bool can_mutate(edit t) const { return token_ == t; }
_ZNK5immer20gc_transience_policy5applyINS_11heap_policyINS_7gc_heapEEEE4type4editeqES7_:
   44|  15.8M|                bool operator==(edit x) const { return v == x.v; }
_ZN5immer20gc_transience_policy5applyINS_11heap_policyINS_7gc_heapEEEE4type5owneeaSENS6_4editE:
   90|  4.18M|                {
   91|  4.18M|                    assert(e != noone);
  ------------------
  |  Branch (91:21): [True: 4.18M, False: 0]
  ------------------
   92|       |                    // This would be a nice safety plug but it sadly
   93|       |                    // does not hold during transient concatenation.
   94|       |                    // assert(token_ == e || token_ == edit{nullptr});
   95|  4.18M|                    token_ = e;
   96|  4.18M|                    return *this;
   97|  4.18M|                }
_ZN5immer20gc_transience_policy5applyINS_11heap_policyINS_7gc_heapEEEE4type5ownercvNS6_4editEEv:
   57|  7.04M|                operator edit() { return {token_}; }

