aboutsummaryrefslogtreecommitdiffstats
path: root/yql/essentials/minikql/mkql_rh_hash_utils.cpp
blob: c620e7af436afa00a40902417d22691f527e4b0e (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
#include "mkql_rh_hash_utils.h"

namespace NKikimr {
namespace NMiniKQL {

ui64 RHHashTableNeedsGrow(ui64 size, ui64 capacity) {
    return size * 2 >= capacity;
}

ui64 CalculateRHHashTableGrowFactor(ui64 currentCapacity) {
    ui64 growFactor;
    if (currentCapacity < 100'000) {
        growFactor = 8;
    } else if (currentCapacity < 1'000'000) {
        growFactor = 4;
    } else {
        growFactor = 2;
    }

    return growFactor;
}

ui64 CalculateRHHashTableCapacity(ui64 targetSize) {
    ui64 capacity = 256;
    while (RHHashTableNeedsGrow(targetSize, capacity)) {
        capacity *= CalculateRHHashTableGrowFactor(capacity);
    }

    return capacity;
}

} // namespace NMiniKQL
} // namespace NKikimr