datasketches-cpp
Loading...
Searching...
No Matches
Public Member Functions | List of all members
tuple_intersection< Summary, Policy, Allocator > Class Template Reference

Tuple intersection. More...

#include <tuple_intersection.hpp>

Inheritance diagram for tuple_intersection< Summary, Policy, Allocator >:
array_tuple_intersection< Array, Policy, Allocator >

Public Member Functions

 tuple_intersection (uint64_t seed=DEFAULT_SEED, const Policy &policy=Policy(), const Allocator &allocator=Allocator())
 Constructor.
 
template<typename FwdSketch >
void update (FwdSketch &&sketch)
 Updates the intersection with a given sketch.
 
CompactSketch get_result (bool ordered=true) const
 Produces a copy of the current state of the intersection.
 
bool has_result () const
 Returns true if the state of the intersection is defined (not infinite "universe").
 

Detailed Description

template<typename Summary, typename Policy, typename Allocator = std::allocator<Summary>>
class datasketches::tuple_intersection< Summary, Policy, Allocator >

Tuple intersection.

Computes intersection of Tuple sketches.

Constructor & Destructor Documentation

◆ tuple_intersection()

template<typename Summary , typename Policy , typename Allocator = std::allocator<Summary>>
tuple_intersection ( uint64_t  seed = DEFAULT_SEED,
const Policy &  policy = Policy(),
const Allocator &  allocator = Allocator() 
)
explicit

Constructor.

Parameters
seedfor the hash function that was used to create the sketch
policyuser-defined way of combining Summary during intersection
allocatorto use for allocating and deallocating memory

Member Function Documentation

◆ update()

template<typename Summary , typename Policy , typename Allocator = std::allocator<Summary>>
template<typename FwdSketch >
void update ( FwdSketch &&  sketch)

Updates the intersection with a given sketch.

The intersection can be viewed as starting from the "universe" set, and every update can reduce the current set to leave the overlapping subset only.

Parameters
sketchrepresents input set for the intersection

◆ get_result()

template<typename S , typename P , typename A >
auto get_result ( bool  ordered = true) const

Produces a copy of the current state of the intersection.

If update() was not called, the state is the infinite "universe", which is considered an undefined state, and throws an exception.

Parameters
orderedoptional flag to specify if an ordered sketch should be produced
Returns
the result of the intersection

◆ has_result()

template<typename S , typename P , typename A >
bool has_result ( ) const

Returns true if the state of the intersection is defined (not infinite "universe").

Returns
true if the state is valid

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