datasketches-cpp
Loading...
Searching...
No Matches
Public Types | Public Member Functions | Static Public Member Functions | List of all members
req_sketch< T, Comparator, Allocator > Class Template Reference

Relative Error Quantiles Sketch. More...

#include <req_sketch.hpp>

Public Types

using quantile_return_type = typename quantiles_sorted_view< T, Comparator, Allocator >::quantile_return_type
 Quantile return type.
 

Public Member Functions

 req_sketch (uint16_t k, bool hra=true, const Comparator &comparator=Comparator(), const Allocator &allocator=Allocator())
 Constructor.
 
 req_sketch (const req_sketch &other)
 Copy constructor.
 
 req_sketch (req_sketch &&other) noexcept
 Move constructor.
 
req_sketchoperator= (const req_sketch &other)
 Copy assignment.
 
req_sketchoperator= (req_sketch &&other)
 Move assignment.
 
template<typename TT , typename CC , typename AA >
 req_sketch (const req_sketch< TT, CC, AA > &other, const Comparator &comparator=Comparator(), const Allocator &allocator=Allocator())
 Type converting constructor.
 
uint16_t get_k () const
 Returns configured parameter K.
 
bool is_HRA () const
 Returns configured parameter High Rank Accuracy.
 
bool is_empty () const
 Returns true if this sketch is empty.
 
uint64_t get_n () const
 Returns the length of the input stream.
 
uint32_t get_num_retained () const
 Returns the number of retained items in the sketch.
 
bool is_estimation_mode () const
 Returns true if this sketch is in estimation mode.
 
template<typename FwdT >
void update (FwdT &&item)
 Updates this sketch with the given data item.
 
template<typename FwdSk >
void merge (FwdSk &&other)
 Merges another sketch into this one.
 
const T & get_min_item () const
 Returns the min item of the stream.
 
const T & get_max_item () const
 Returns the max item of the stream.
 
Comparator get_comparator () const
 Returns an instance of the comparator for this sketch.
 
Allocator get_allocator () const
 Returns an instance of the allocator for this sketch.
 
double get_rank (const T &item, bool inclusive=true) const
 Returns an approximation to the normalized rank of the given item from 0 to 1 inclusive.
 
vector_double get_PMF (const T *split_points, uint32_t size, bool inclusive=true) const
 Returns an approximation to the Probability Mass Function (PMF) of the input stream given a set of split points (items).
 
vector_double get_CDF (const T *split_points, uint32_t size, bool inclusive=true) const
 Returns an approximation to the Cumulative Distribution Function (CDF), which is the cumulative analog of the PMF, of the input stream given a set of split points (items).
 
quantile_return_type get_quantile (double rank, bool inclusive=true) const
 Returns an approximate quantile of the given normalized rank.
 
double get_rank_lower_bound (double rank, uint8_t num_std_dev) const
 Returns an approximate lower bound of the given normalized rank.
 
double get_rank_upper_bound (double rank, uint8_t num_std_dev) const
 Returns an approximate upper bound of the given normalized rank.
 
template<typename TT = T, typename SerDe = serde<T>, typename std::enable_if< std::is_arithmetic< TT >::value, int >::type = 0>
size_t get_serialized_size_bytes (const SerDe &sd=SerDe()) const
 Computes size needed to serialize the current state of the sketch.
 
template<typename TT = T, typename SerDe = serde<T>, typename std::enable_if<!std::is_arithmetic< TT >::value, int >::type = 0>
size_t get_serialized_size_bytes (const SerDe &sd=SerDe()) const
 Computes size needed to serialize the current state of the sketch.
 
template<typename SerDe = serde<T>>
void serialize (std::ostream &os, const SerDe &sd=SerDe()) const
 This method serializes the sketch into a given stream in a binary form.
 
template<typename SerDe = serde<T>>
vector_bytes serialize (unsigned header_size_bytes=0, const SerDe &sd=SerDe()) const
 This method serializes the sketch as a vector of bytes.
 
string< Allocator > to_string (bool print_levels=false, bool print_items=false) const
 Prints a summary of the sketch.
 
const_iterator begin () const
 Iterator pointing to the first item in the sketch.
 
const_iterator end () const
 Iterator pointing to the past-the-end item in the sketch.
 
quantiles_sorted_view< T, Comparator, Allocator > get_sorted_view () const
 Gets the sorted view of this sketch.
 

Static Public Member Functions

static double get_RSE (uint16_t k, double rank, bool hra, uint64_t n)
 Returns an a priori estimate of relative standard error (RSE, expressed as a number in [0,1]).
 
template<typename SerDe = serde<T>>
static req_sketch deserialize (std::istream &is, const SerDe &sd=SerDe(), const Comparator &comparator=Comparator(), const Allocator &allocator=Allocator())
 This method deserializes a sketch from a given stream.
 
template<typename SerDe = serde<T>>
static req_sketch deserialize (const void *bytes, size_t size, const SerDe &sd=SerDe(), const Comparator &comparator=Comparator(), const Allocator &allocator=Allocator())
 This method deserializes a sketch from a given array of bytes.
 

Detailed Description

template<typename T, typename Comparator = std::less<T>, typename Allocator = std::allocator<T>>
class datasketches::req_sketch< T, Comparator, Allocator >

Relative Error Quantiles Sketch.

This is an implementation based on the paper "Relative Error Streaming Quantiles" by Graham Cormode, Zohar Karnin, Edo Liberty, Justin Thaler, Pavel VeselĂ˝, and loosely derived from a Python prototype written by Pavel VeselĂ˝.

Reference: https://arxiv.org/abs/2004.01668

This implementation differs from the algorithm described in the paper in the following:

This implementation provides a number of capabilities not discussed in the paper or provided in the Python prototype.

Member Typedef Documentation

◆ quantile_return_type

template<typename T , typename Comparator = std::less<T>, typename Allocator = std::allocator<T>>
using quantile_return_type = typename quantiles_sorted_view<T, Comparator, Allocator>::quantile_return_type

Quantile return type.

This is to return quantiles either by value (for arithmetic types) or by const reference (for all other types)

Constructor & Destructor Documentation

◆ req_sketch() [1/4]

template<typename T , typename Comparator = std::less<T>, typename Allocator = std::allocator<T>>
req_sketch ( uint16_t  k,
bool  hra = true,
const Comparator &  comparator = Comparator(),
const Allocator &  allocator = Allocator() 
)
explicit

Constructor.

Parameters
kControls the size and error of the sketch. It must be even and in the range [4, 1024], inclusive. Value of 12 roughly corresponds to 1% relative error guarantee at 95% confidence.
hraif true, the default, the high ranks are prioritized for better accuracy. Otherwise the low ranks are prioritized for better accuracy.
comparatorstrict weak ordering function (see C++ named requirements: Compare)
allocatorused by this sketch to allocate memory

◆ req_sketch() [2/4]

template<typename T , typename C , typename A >
req_sketch ( const req_sketch< T, Comparator, Allocator > &  other)

Copy constructor.

Parameters
othersketch to be copied

◆ req_sketch() [3/4]

template<typename T , typename C , typename A >
req_sketch ( req_sketch< T, Comparator, Allocator > &&  other)
noexcept

Move constructor.

Parameters
othersketch to be moved

◆ req_sketch() [4/4]

template<typename T , typename Comparator = std::less<T>, typename Allocator = std::allocator<T>>
template<typename TT , typename CC , typename AA >
req_sketch ( const req_sketch< TT, CC, AA > &  other,
const Comparator &  comparator = Comparator(),
const Allocator &  allocator = Allocator() 
)
explicit

Type converting constructor.

Parameters
othersketch of a different type
comparatorinstance of a Comparator
allocatorinstance of an Allocator

Member Function Documentation

◆ operator=() [1/2]

template<typename T , typename C , typename A >
req_sketch< T, C, A > & operator= ( const req_sketch< T, Comparator, Allocator > &  other)

Copy assignment.

Parameters
othersketch to be copied
Returns
reference to this sketch

◆ operator=() [2/2]

template<typename T , typename C , typename A >
req_sketch< T, C, A > & operator= ( req_sketch< T, Comparator, Allocator > &&  other)

Move assignment.

Parameters
othersketch to be moved
Returns
reference to this sketch

◆ get_k()

template<typename T , typename C , typename A >
uint16_t get_k ( ) const

Returns configured parameter K.

Returns
parameter K

◆ is_HRA()

template<typename T , typename C , typename A >
bool is_HRA ( ) const

Returns configured parameter High Rank Accuracy.

Returns
parameter HRA

◆ is_empty()

template<typename T , typename C , typename A >
bool is_empty ( ) const

Returns true if this sketch is empty.

Returns
empty flag

◆ get_n()

template<typename T , typename C , typename A >
uint64_t get_n ( ) const

Returns the length of the input stream.

Returns
stream length

◆ get_num_retained()

template<typename T , typename C , typename A >
uint32_t get_num_retained ( ) const

Returns the number of retained items in the sketch.

Returns
number of retained items

◆ is_estimation_mode()

template<typename T , typename C , typename A >
bool is_estimation_mode ( ) const

Returns true if this sketch is in estimation mode.

Returns
estimation mode flag

◆ update()

template<typename T , typename C , typename A >
template<typename FwdT >
void update ( FwdT &&  item)

Updates this sketch with the given data item.

Parameters
itemfrom a stream of items

◆ merge()

template<typename T , typename C , typename A >
template<typename FwdSk >
void merge ( FwdSk &&  other)

Merges another sketch into this one.

Parameters
othersketch to merge into this one

◆ get_min_item()

template<typename T , typename C , typename A >
const T & get_min_item ( ) const

Returns the min item of the stream.

If the sketch is empty this throws std::runtime_error.

Returns
the min item of the stream

◆ get_max_item()

template<typename T , typename C , typename A >
const T & get_max_item ( ) const

Returns the max item of the stream.

If the sketch is empty this throws std::runtime_error.

Returns
the max item of the stream

◆ get_comparator()

template<typename T , typename C , typename A >
C get_comparator ( ) const

Returns an instance of the comparator for this sketch.

Returns
comparator

◆ get_allocator()

template<typename T , typename C , typename A >
A get_allocator ( ) const

Returns an instance of the allocator for this sketch.

Returns
allocator

◆ get_rank()

template<typename T , typename C , typename A >
double get_rank ( const T &  item,
bool  inclusive = true 
) const

Returns an approximation to the normalized rank of the given item from 0 to 1 inclusive.

If the sketch is empty this throws std::runtime_error.

Parameters
itemto be ranked.
inclusiveif true the weight of the given item is included into the rank. Otherwise the rank equals the sum of the weights of all items that are less than the given item according to the comparator C.
Returns
an approximate rank of the given item

◆ get_PMF()

template<typename T , typename C , typename A >
auto get_PMF ( const T *  split_points,
uint32_t  size,
bool  inclusive = true 
) const

Returns an approximation to the Probability Mass Function (PMF) of the input stream given a set of split points (items).

If the sketch is empty this throws std::runtime_error.

Parameters
split_pointsan array of m unique, monotonically increasing items that divide the input domain into m+1 consecutive disjoint intervals (bins).
sizethe number of split points in the array
inclusiveif true the rank of an item includes its own weight, and therefore if the sketch contains items equal to a slit point, then in PMF such items are included into the interval to the left of split point. Otherwise they are included into the interval to the right of split point.
Returns
an array of m+1 doubles each of which is an approximation to the fraction of the input stream items (the mass) that fall into one of those intervals.

◆ get_CDF()

template<typename T , typename C , typename A >
auto get_CDF ( const T *  split_points,
uint32_t  size,
bool  inclusive = true 
) const

Returns an approximation to the Cumulative Distribution Function (CDF), which is the cumulative analog of the PMF, of the input stream given a set of split points (items).

If the sketch is empty this throws std::runtime_error.

Parameters
split_pointsan array of m unique, monotonically increasing items that divide the input domain into m+1 consecutive disjoint intervals.
sizethe number of split points in the array
inclusiveif true the rank of an item includes its own weight, and therefore if the sketch contains items equal to a slit point, then in CDF such items are included into the interval to the left of split point. Otherwise they are included into the interval to the right of split point.
Returns
an array of m+1 doubles, which are a consecutive approximation to the CDF of the input stream given the split_points. The value at array position j of the returned CDF array is the sum of the returned values in positions 0 through j of the returned PMF array. This can be viewed as array of ranks of the given split points plus one more value that is always 1.

◆ get_quantile()

template<typename T , typename C , typename A >
auto get_quantile ( double  rank,
bool  inclusive = true 
) const

Returns an approximate quantile of the given normalized rank.

The normalized rank must be in the range [0.0, 1.0] (both inclusive).

If the sketch is empty this throws std::runtime_error.

Parameters
rankof an item in the hypothetical sorted stream.
inclusiveif true, the given rank is considered inclusive (includes weight of an item)
Returns
approximate quantile associated with the given rank

◆ get_rank_lower_bound()

template<typename T , typename C , typename A >
double get_rank_lower_bound ( double  rank,
uint8_t  num_std_dev 
) const

Returns an approximate lower bound of the given normalized rank.

Parameters
rankthe given rank, a value between 0 and 1.0.
num_std_devthe number of standard deviations. Must be 1, 2, or 3.
Returns
an approximate lower bound rank.

◆ get_rank_upper_bound()

template<typename T , typename C , typename A >
double get_rank_upper_bound ( double  rank,
uint8_t  num_std_dev 
) const

Returns an approximate upper bound of the given normalized rank.

Parameters
rankthe given rank, a value between 0 and 1.0.
num_std_devthe number of standard deviations. Must be 1, 2, or 3.
Returns
an approximate upper bound rank.

◆ get_RSE()

template<typename T , typename C , typename A >
double get_RSE ( uint16_t  k,
double  rank,
bool  hra,
uint64_t  n 
)
static

Returns an a priori estimate of relative standard error (RSE, expressed as a number in [0,1]).

Derived from Lemma 12 in https://arxiv.org/abs/2004.01668v2, but the constant factors were modified based on empirical measurements.

Parameters
kthe given value of k
rankthe given normalized rank, a number in [0,1].
hraif true High Rank Accuracy mode is being selected, otherwise, Low Rank Accuracy.
nan estimate of the total number of items submitted to the sketch.
Returns
an a priori estimate of relative standard error (RSE, expressed as a number in [0,1]).

◆ get_serialized_size_bytes() [1/2]

template<typename T , typename C , typename A >
template<typename TT , typename SerDe , typename std::enable_if<!std::is_arithmetic< TT >::value, int >::type >
size_t get_serialized_size_bytes ( const SerDe &  sd = SerDe()) const

Computes size needed to serialize the current state of the sketch.

This version is for fixed-size arithmetic types (integral and floating point).

Parameters
sdinstance of a SerDe
Returns
size in bytes needed to serialize this sketch

◆ get_serialized_size_bytes() [2/2]

template<typename T , typename Comparator = std::less<T>, typename Allocator = std::allocator<T>>
template<typename TT = T, typename SerDe = serde<T>, typename std::enable_if<!std::is_arithmetic< TT >::value, int >::type = 0>
size_t get_serialized_size_bytes ( const SerDe &  sd = SerDe()) const

Computes size needed to serialize the current state of the sketch.

This version is for all other types and can be expensive since every item needs to be looked at.

Parameters
sdinstance of a SerDe
Returns
size in bytes needed to serialize this sketch

◆ serialize() [1/2]

template<typename T , typename C , typename A >
template<typename SerDe >
void serialize ( std::ostream &  os,
const SerDe &  sd = SerDe() 
) const

This method serializes the sketch into a given stream in a binary form.

Parameters
osoutput stream
sdinstance of a SerDe

◆ serialize() [2/2]

template<typename T , typename Comparator = std::less<T>, typename Allocator = std::allocator<T>>
template<typename SerDe = serde<T>>
vector_bytes serialize ( unsigned  header_size_bytes = 0,
const SerDe &  sd = SerDe() 
) const

This method serializes the sketch as a vector of bytes.

An optional header can be reserved in front of the sketch. It is a blank space of a given size. This header is used in Datasketches PostgreSQL extension.

Parameters
header_size_bytesspace to reserve in front of the sketch
sdinstance of a SerDe

◆ deserialize() [1/2]

template<typename T , typename Comparator = std::less<T>, typename Allocator = std::allocator<T>>
template<typename SerDe = serde<T>>
static req_sketch deserialize ( std::istream &  is,
const SerDe &  sd = SerDe(),
const Comparator &  comparator = Comparator(),
const Allocator &  allocator = Allocator() 
)
static

This method deserializes a sketch from a given stream.

Parameters
isinput stream
sdinstance of a SerDe
comparatorinstance of a Comparator
allocatorinstance of an Allocator
Returns
an instance of a sketch

◆ deserialize() [2/2]

template<typename T , typename Comparator = std::less<T>, typename Allocator = std::allocator<T>>
template<typename SerDe = serde<T>>
static req_sketch deserialize ( const void *  bytes,
size_t  size,
const SerDe &  sd = SerDe(),
const Comparator &  comparator = Comparator(),
const Allocator &  allocator = Allocator() 
)
static

This method deserializes a sketch from a given array of bytes.

Parameters
bytespointer to the array of bytes
sizethe size of the array
sdinstance of a SerDe
comparatorinstance of a Comparator
allocatorinstance of an Allocator
Returns
an instance of a sketch

◆ to_string()

template<typename T , typename C , typename A >
string< A > to_string ( bool  print_levels = false,
bool  print_items = false 
) const

Prints a summary of the sketch.

Parameters
print_levelsif true include information about levels
print_itemsif true include sketch data

◆ begin()

template<typename T , typename C , typename A >
auto begin ( ) const

Iterator pointing to the first item in the sketch.

If the sketch is empty, the returned iterator must not be dereferenced or incremented.

Returns
iterator pointing to the first item in the sketch

◆ end()

template<typename T , typename C , typename A >
auto end ( ) const

Iterator pointing to the past-the-end item in the sketch.

The past-the-end item is the hypothetical item that would follow the last item. It does not point to any item, and must not be dereferenced or incremented.

Returns
iterator pointing to the past-the-end item in the sketch

◆ get_sorted_view()

template<typename T , typename C , typename A >
quantiles_sorted_view< T, C, A > get_sorted_view ( ) const

Gets the sorted view of this sketch.

Returns
the sorted view of this sketch

The documentation for this class was generated from the following files: