-
Notifications
You must be signed in to change notification settings - Fork 608
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
[MEMORY] Reduce file descriptors memory footprint in the ImageCache #4436
Comments
Yes, I agree that we want to store the ImageSpec per subimage, and the individual MIP levels really only need to know their resolutions and tile sizes, I think those are the only things that meaningfully differ from one MIP level to the next. They don't all need their own ImageSpec's at all. |
Additionally, even at the subimage level, we currently store both a "spec" and a "nativespec". The original concept was that nativespec reflects what was in the file, whereas spec describes what's in memory in the cache. The main way they can differ is (a) in the cache, only a few pixel data types are allowed (uint8, uint16, half, float) and all channels must be the same data type, whereas in the file they can be other types and can differ among the channels; (b) in the cache, the image always appears "tiled", sometimes the real tiling of the file, sometimes looking like one big tile for the whole image, sometimes looking tiled even though it's not ("autotile"). But the real metadata will not change. (In my defense, when this was designed, we saw a lot less metadata in files, certainly not big things like ICC profiles, thumbnails, or other big things. So having a second ImageSpec didn't seem like a big deal, but now it is.) OK, so what I'm thinking is that we could store only ONE ImageSpec per subimage, and then only the couple of fields that explain how it differs between the file and the buffer. I'm not yet of a strong opinion whether the one spec should be the file, with separate fields for the data format and tile size of the buffer? Or if the spec should be the buffer, with additional fields saying what the data formats and tiling was like in the file? (Probably the first option, but I'm not 100% sure.) The question is what to do about the get_imagespec() and imagespec() methods, both of which take a IC::get_imagespec makes a copy, so it could copy the one imagespec and then modify those few extra fields if they're asking for the other kind. IC::imagespec() is a lot trickier because it returns a pointer. This is where I got stuck before. One thing we could do is decide that henceforth, the nativespec parameter is simply ignored, and the spec pointer that is returned is always the file one (? or the memory one?) and add a separate new API call to retrieve the in-memory data type or tile size. It may also be instructive to see how in ImageSpec itself, there is a copy_dimensions() method, which is a very lightweight way of copying only a few important fields from one spec to another. Maybe there is something analogous that we need in ImageCache. |
…ion#4436 Signed-off-by: Basile Fraboni <[email protected]>
No worries - we are just trying to link things up for tracking. Feel free to tag other PRs |
…ion#4436 Signed-off-by: Basile Fraboni <[email protected]>
First draft of front end changes for issue #4436. The end goal is to remove redundant ImageSpec from ImageCache internals (issue #4436). But that necessarily changes some assumptions about what is accessible through the public APIs for ImageCache and TextureSystem. This PR contains the API-side changes, but without the internals overhaul that will come later. * `get_imagespec()` and `imagespec()` lose their miplevel and native parameters. We are now assuming now that there is no arbitrary metadata varying per-mip-level. Also, loss of native param means that it's always copying an ImageSpec that reflects the file. * New `get_cache_dimensions()` is a lighter-weight function that can retrieve the limited items that really do vary between MIP levels, and may differ between the file and the in-cache pixels: resolution, tile size, pixel data format. * Harmonize the order of parameters in the analogous functions exposed by IC and TS (they confusingly differed before). * For now, API-backward-compatible wrappers for the old functions, which will eventually be deprecated and then removed. --------- Signed-off-by: Basile Fraboni <[email protected]>
Re-opening. The PR should not have been tagged as closing this issue. It was just one necessary step along the way. |
Hey there, picking up on where this has been left back in October. ProblemThe internal For the quick history on the Frontend work (done)We changed the imagespec API to always reflect what is in the file at mip level 0, i.e. the "nativespec", and we introduced a new function get_cache_dimensions to override the dimensions of an Backend work (todo)Now that the API has changed the remaining work consists in:
//! LevelSpec is a minified ImageSpec to describe a miplevel image in the ImageCache.
//! This only hold fields that can differ from the ImageSpec of the associated subimage,
//! or not constant across all mip levels.
struct LevelSpec
{
//! TODO: filter out any unnecessary fields:
//! * extra_attribs -> same as native spec
//! * channelnames -> same as native spec
//! * channelformats -> the image cache only allows one single format for all channels
//! * alpha_channel -> same as native spec
//! * deep -> same as native spec
//! * z_channel -> same as native spec
//! * n_channels -> same as native spec, but maybe convenient to have locally
//! * format -> constant for all channels of all mip levels; should be stored in subimage once only
//! fields that changes for each miplevels
int width; ///< width of the pixel data window
int height; ///< height of the pixel data window
int depth; ///< depth of pixel data, >1 indicates a "volume"
int tile_width; ///< tile width (0 for a non-tiled image)
int tile_height; ///< tile height (0 for a non-tiled image)
int tile_depth; ///< tile depth (0 for a non-tiled image,
//< 1 for a non-volume image)
//! TODO: fields we are not sure about
int x; ///< origin (upper left corner) of pixel data
int y; ///< origin (upper left corner) of pixel data
int z; ///< origin (upper left corner) of pixel data
int full_x; ///< origin of the full (display) window
int full_y; ///< origin of the full (display) window
int full_z; ///< origin of the full (display) window
int full_width; ///< width of the full (display) window
int full_height; ///< height of the full (display) window
int full_depth; ///< depth of the full (display) window
};
|
We would like to reduce the memory usage of file descriptors in the
ImageCache
as we observed a large amount of duplicated data. This is mainly due to image descriptors (ImageSpec
) being stored for each mip map (LevelInfo
) of each sub-image (SubImageInfo
).Clearing up some memory should be possible in that area (
LevelInfo / SubImageInfo
) but needs a bit a refactor, that I'm happy to start during DevDays with help from @lgritz.More to come in the next comments about the approach to follow.
Tasks
The text was updated successfully, but these errors were encountered: