This discussion has been locked.
You can no longer post new replies to this discussion. If you have a question you can start a new discussion

Encoding FP16/FP32 textures with astcenc

Hello,

How can I compress raw binary floating point (16 or 32) textures using astcenc tool?

I have these binary files with array of floats which is basically a raw data to be consumed by glTexImage2D. It has no headers with any information about texture dimensions, etc.

How should I consume such data into astcenc tool?

The only thing mentioned in documentation is that astcenc supports *.exr and *.hdr files for HDR source images.

Parents
  • Hello Peter!

    Sorry for such late response, I was busy with other projects.

    Thank you for suggestion. I've tried to configure encoder and feed it my source FP16 data.

    In my modification of this example I've noticed some strange behavior.

    My data has only 3 channels (RGB) of FP16 (2 bytes) data per texel. So, for example, 10x10 texture is 2*3*10*10 = 600 bytes. With block size 4x4 for the best quality this should compress really nicely into just 144 bytes of compressed HDR ASTC texture.

    According to documentation, data must be 4-component so I added 2 bytes padding so each texel is now 4-component RGBA and can be processed by library.

    I've modified example with {ASTCENC_SWZ_R, ASTCENC_SWZ_G, ASTCENC_SWZ_B, ASTCENC_SWZ_0} swizzle, ASTCENC_PRF_HDR profile and ASTCENC_TYPE_F16 image data_type.

    However, after decoding compressed data, I see that all channels except B are zeros, and even B channel values seems to be incorrect.

    Left is original, right is uncompressed:

    Is this a problem of decoder or is something wrong with setup?

    How can I test decoding of FP16 data (except of decoding it on ASTC HDR-capable GPU)?

Reply
  • Hello Peter!

    Sorry for such late response, I was busy with other projects.

    Thank you for suggestion. I've tried to configure encoder and feed it my source FP16 data.

    In my modification of this example I've noticed some strange behavior.

    My data has only 3 channels (RGB) of FP16 (2 bytes) data per texel. So, for example, 10x10 texture is 2*3*10*10 = 600 bytes. With block size 4x4 for the best quality this should compress really nicely into just 144 bytes of compressed HDR ASTC texture.

    According to documentation, data must be 4-component so I added 2 bytes padding so each texel is now 4-component RGBA and can be processed by library.

    I've modified example with {ASTCENC_SWZ_R, ASTCENC_SWZ_G, ASTCENC_SWZ_B, ASTCENC_SWZ_0} swizzle, ASTCENC_PRF_HDR profile and ASTCENC_TYPE_F16 image data_type.

    However, after decoding compressed data, I see that all channels except B are zeros, and even B channel values seems to be incorrect.

    Left is original, right is uncompressed:

    Is this a problem of decoder or is something wrong with setup?

    How can I test decoding of FP16 data (except of decoding it on ASTC HDR-capable GPU)?

Children