Skip to content

Commit

Permalink
Optimization: avoid a memory allocation when padding RGB u8 to RGBA (#…
Browse files Browse the repository at this point in the history
…2345)

### What
Helps #2306 a bit

### Checklist
* [x] I have read and agree to [Contributor
Guide](https://github.com/rerun-io/rerun/blob/main/CONTRIBUTING.md) and
the [Code of
Conduct](https://github.com/rerun-io/rerun/blob/main/CODE_OF_CONDUCT.md)

<!-- This line will get updated when the PR build summary job finishes.
-->
PR Build Summary: https://build.rerun.io/pr/2345

<!-- pr-link-docs:start -->
Docs preview: https://rerun.io/preview/7bed2a1/docs
Examples preview: https://rerun.io/preview/7bed2a1/examples
<!-- pr-link-docs:end -->
  • Loading branch information
emilk authored Jun 9, 2023
1 parent c482cac commit e4f5f4b
Showing 1 changed file with 6 additions and 4 deletions.
10 changes: 6 additions & 4 deletions crates/re_viewer_context/src/gpu_bridge/tensor_to_gpu.rs
Original file line number Diff line number Diff line change
Expand Up @@ -72,9 +72,10 @@ fn color_tensor_to_gpu(
// Normalize sRGB(A) textures to 0-1 range, and let the GPU premultiply alpha.
// Why? Because premul must happen _before_ sRGB decode, so we can't
// use a "Srgb-aware" texture like `Rgba8UnormSrgb` for RGBA.
(3, TensorData::U8(buf)) => {
(pad_and_cast(buf.as_slice(), 255), TextureFormat::Rgba8Unorm)
}
(3, TensorData::U8(buf)) => (
pad_rgb_to_rgba(buf.as_slice(), u8::MAX).into(),
TextureFormat::Rgba8Unorm,
),
(4, TensorData::U8(buf)) => {
(cast_slice_to_cow(buf.as_slice()), TextureFormat::Rgba8Unorm)
}
Expand Down Expand Up @@ -318,7 +319,7 @@ fn general_texture_creation_desc_from_tensor<'a>(
// TODO(emilk): tell the shader to ignore the alpha channel instead!
match &tensor.data {
TensorData::U8(buf) => (
pad_and_cast(buf.as_slice(), u8::MAX),
pad_rgb_to_rgba(buf.as_slice(), u8::MAX).into(),
TextureFormat::Rgba8Uint,
),
TensorData::U16(buf) => (pad_and_cast(buf, u16::MAX), TextureFormat::Rgba16Uint),
Expand Down Expand Up @@ -428,6 +429,7 @@ fn narrow_f64_to_f32s(slice: &[f64]) -> Cow<'static, [u8]> {

fn pad_and_cast<T: Copy + Pod>(data: &[T], pad: T) -> Cow<'static, [u8]> {
re_tracing::profile_function!();
// TODO(emilk): optimize by combining the two steps into one; avoiding one allocation and memcpy
let padded: Vec<T> = pad_rgb_to_rgba(data, pad);
let bytes: Vec<u8> = pod_collect_to_vec(&padded);
bytes.into()
Expand Down

0 comments on commit e4f5f4b

Please sign in to comment.