data:image/s3,"s3://crabby-images/42376/42376f6a2480a747496c3eb3aee4d9b635d887e3" alt=""
On Tue, 23 Jul 2013, at 10:10 AM, Sensei wrote:
On 7/22/13 7:47pm, Daniel James wrote:
You can use a custom hash function. Here's an example. I made the modulo dynamic, but if it's a compile time constant, then the container will be a tad bit smaller, and you won't need to pass the hash function and equality predicate as parameters.
Thanks Daniel. I have a question, though. Forgive me if I'm being too naive, but I'm trying to understand what's going on here! :)
The code you posted seems to be bound at compile time to the integer p chosen as modulus (i.e., 53).
The modulus is bound at construction, you can also overwrite it by assignment or swapping.
How can I, for instance, find all values that are equal modulo 2 now, without instantiating another unordered_map? Finding elements modulo p, with p given at runtime, is the "something" I'm trying to do here :)
Currently, you'd need to create a new unordered_multimap, e.g.
typedef std::unordered_multimap
The reason I was looking into MultiIndex is this: decoupling the hashing from the actual "equal" predicate.
You can't decouple the hash and the equal predicate - they must always match. I suppose using a modulo hash and normal equality is sort of okay, since you will get equal hash values for equal elements, but you might get very poor performance and you won't be able to assume that unequal hash values will map to different buckets - even if the number of buckets is greater than the number of hash values.