datasketches-cpp
theta_comparators.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 THETA_COMPARATORS_HPP_
21 #define THETA_COMPARATORS_HPP_
22 
23 namespace datasketches {
24 
25 template<typename ExtractKey>
26 struct compare_by_key {
27  template<typename Entry1, typename Entry2>
28  bool operator()(Entry1&& a, Entry2&& b) const {
29  return ExtractKey()(std::forward<Entry1>(a)) < ExtractKey()(std::forward<Entry2>(b));
30  }
31 };
32 
33 // less than
34 
35 template<typename Key, typename Entry, typename ExtractKey>
36 class key_less_than {
37 public:
38  explicit key_less_than(const Key& key): key(key) {}
39  bool operator()(const Entry& entry) const {
40  return ExtractKey()(entry) < this->key;
41  }
42 private:
43  Key key;
44 };
45 
46 } /* namespace datasketches */
47 
48 #endif
DataSketches namespace.
Definition: binomial_bounds.hpp:38