18 static const unsigned int MAX_BLOOM_FILTER_SIZE = 36000;
19 static const unsigned int MAX_HASH_FUNCS = 50;
48 std::vector<unsigned char>
vData;
55 unsigned int Hash(
unsigned int nHashNum,
const std::vector<unsigned char>& vDataToHash)
const;
58 CBloomFilter(
const unsigned int nElements,
const double nFPRate,
const unsigned int nTweak);
71 CBloomFilter(
const unsigned int nElements,
const double nFPRate,
const unsigned int nTweak,
unsigned char nFlagsIn);
72 CBloomFilter() : isFull(true), isEmpty(false), nHashFuncs(0), nTweak(0), nFlags(0) {}
76 template <
typename Stream,
typename Operation>
84 void insert(
const std::vector<unsigned char>& vKey);
88 bool contains(
const std::vector<unsigned char>& vKey)
const;
93 void reset(
const unsigned int nNewTweak);
128 void insert(
const std::vector<unsigned char>& vKey);
130 bool contains(
const std::vector<unsigned char>& vKey)
const;
144 #endif // RAVEN_BLOOM_H bloomflags
First two bits of nFlags control how much IsRelevantAndUpdate actually updates The remaining bits are...
bool IsRelevantAndUpdate(const CTransaction &tx)
Also adds any outputs which match the filter to the filter (to match their spending txes) ...
BloomFilter is a probabilistic filter which SPV clients provide so that we can filter the transaction...
RollingBloomFilter is a probabilistic "keep track of most recently inserted" set. ...
std::vector< unsigned char > vData
unsigned int Hash(unsigned int nHashNum, const std::vector< unsigned char > &vDataToHash) const
void reset(const unsigned int nNewTweak)
void insert(const std::vector< unsigned char > &vKey)
An outpoint - a combination of a transaction hash and an index n into its vout.
std::vector< uint64_t > data
int nEntriesThisGeneration
friend class CRollingBloomFilter
void UpdateEmptyFull()
Checks for empty and full filters to avoid wasting cpu.
The basic transaction that is broadcasted on the network and contained in blocks. ...
void SerializationOp(Stream &s, Operation ser_action)
bool IsWithinSizeConstraints() const
True if the size is <= MAX_BLOOM_FILTER_SIZE and the number of hash functions is <= MAX_HASH_FUNCS (c...
bool contains(const std::vector< unsigned char > &vKey) const
int nEntriesPerGeneration