datasketches-cpp
CouponHashSet.hpp
1 /*
2  * Licensed to the Apache Software Foundation (ASF) under one
3  * or more contributor license agreements. See the NOTICE file
4  * distributed with this work for additional information
5  * regarding copyright ownership. The ASF licenses this file
6  * to you under the Apache License, Version 2.0 (the
7  * "License"); you may not use this file except in compliance
8  * with the License. You may obtain a copy of the License at
9  *
10  * http://www.apache.org/licenses/LICENSE-2.0
11  *
12  * Unless required by applicable law or agreed to in writing,
13  * software distributed under the License is distributed on an
14  * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
15  * KIND, either express or implied. See the License for the
16  * specific language governing permissions and limitations
17  * under the License.
18  */
19 
20 #ifndef _COUPONHASHSET_HPP_
21 #define _COUPONHASHSET_HPP_
22 
23 #include "CouponList.hpp"
24 
25 namespace datasketches {
26 
27 template<typename A>
28 class CouponHashSet : public CouponList<A> {
29  public:
30  static CouponHashSet* newSet(const void* bytes, size_t len, const A& allocator);
31  static CouponHashSet* newSet(std::istream& is, const A& allocator);
32  CouponHashSet(uint8_t lgConfigK, target_hll_type tgtHllType, const A& allocator);
33  CouponHashSet(const CouponHashSet& that, target_hll_type tgtHllType);
34 
35  virtual ~CouponHashSet() = default;
36  virtual std::function<void(HllSketchImpl<A>*)> get_deleter() const;
37 
38  protected:
39  using vector_int = std::vector<uint32_t, typename std::allocator_traits<A>::template rebind_alloc<uint32_t>>;
40 
41  virtual CouponHashSet* copy() const;
42  virtual CouponHashSet* copyAs(target_hll_type tgtHllType) const;
43 
44  virtual HllSketchImpl<A>* couponUpdate(uint32_t coupon);
45 
46  virtual uint32_t getMemDataStart() const;
47  virtual uint8_t getPreInts() const;
48 
49  friend class HllSketchImplFactory<A>;
50 
51  private:
52  using ChsAlloc = typename std::allocator_traits<A>::template rebind_alloc<CouponHashSet<A>>;
53  bool checkGrowOrPromote();
54  void growHashSet(uint8_t tgtLgCoupArrSize);
55 };
56 
57 }
58 
59 #endif /* _COUPONHASHSET_HPP_ */
DataSketches namespace.
Definition: binomial_bounds.hpp:38
target_hll_type
Specifies the target type of HLL sketch to be created.
Definition: hll.hpp:72