-
Notifications
You must be signed in to change notification settings - Fork 88
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Feature Request: key_watermark() API #113
Comments
Side tables are definitely an important use case. Is |
Note that by using the |
I haven't double checked the memory growth strategy for Vec but I'd expect some variation of exponential growth which could lead to really large overestimates of the required storage using capacity. Although capacity can be used for this, any overestimate of the required storage can then cause a significant number of secondary values to need to be initialised. The entities length may also be an overestimate but to a much lesser extent on average, and since the value is just as readily available (except the current lack of api) then it seems like the ideal choice here. Considering meshes with 100s of thousands of vertices, edges and faces then this level of redundant work wouldn't be ideal. |
Although I'd expect the possibility that the length may be an over estimate (which is ok, here and the hope is to just minimize any over estimate that will lead to the redundant initialisation of secondary values), surely even after (or during) a compact then no (valid) key can be greater than this length? Keys index into the entities vector so keys greater than (or equal to) this length would implicitly lead to an out of bounds panic no? From looking at the implementation of compact it looks like it iteratively pops key/values and swaps them into a hole until the slab length matches the entities length, and I guess out of bound keys should only remain if the user doesn't uphold their side of the remapping? |
Ah, sorry, you are right, that doesn't happen. I had confused it with the |
This can be used to more efficiently manage secondary storage with the same keys as a primary Slab. Knowing the largest valid key helps avoid any redundant work associated with unused keys. Alternatively, using the `capacity` instead of this watermark may result in redundantly initializing large numbers of secondary entries - considering that the backing vector is likely to grow exponentially each time it fills. Closes: tokio-rs#113
I've been looking for this feature for my own project. The context is that I have an unordered collection of elements that I want to name by their index, and I occasionally want to remove some of the elements without having to re-index any of the others. However, element removals are occur within batches of processing, where I scan over each element in the collection, mutate it a bit, and possibly remove it and transfer some of its data into another element. To continue scanning over the collection while removing some elements, I would ordinarily use |
I'm currently using Slabs as part of a Mesh data structure for vertices, edges, loops + faces (based on the design of Blender's BMesh API) and as part of that I'm looking to have secondary vectors of data that are indexed with keys from the slab.
I'm looking to store ancillary attributes (these may be per-vertex, or per-edge etc) within
Vec
vectors where I'd really like to avoid any memory overhead per value (meshes can be pretty huge), and the corresponding Slab (e.g. vertex slab for a per-vertex attribute) would be the authority on what keys are valid for indexing into those vectors.To make this work I'd like to be able to maintain the attribute vector lengths according to the length of the Slab
entries
vector as a simple way of ensuring that all possible slab keys will be valid for indexing in to these attribute vectors.To not be confused with querying the length of the slab as the number of current values, 'key_watermark' seems like it could get across what it is that I'd like to query here; like this...
I can look at creating a pull request if something like this sounds reasonable?
The text was updated successfully, but these errors were encountered: