Skip to content

Compressed Texture Formats #122

@progschj

Description

@progschj

The question of compressed texture formats came up in relation to https://www.khronos.org/ktx/
I started WIP json definitions here: KhronosGroup/ANARI-SDK#186

The gist is that a new sampler type "compressedImage2D" is introduced that takes a plain Array1D of bytes instead of a 2D array as its image and the format and image size are set via the sampler instead of being derived from the array. The alternative would be to have ANARIDataType of compressed texture blocks and then use these in Array2D as before. This however creates surprising relationships between pixel sizes and byte sizes of the array. For example a 5x5 pixel texture would consist of 4 BC1 blocks (4x4 each) and therefore have the same byte size as a 8x8 texture. Introducing this kind of information at the sampler stage avoids this complication.

It would however make sense to add a type ANARI_COMPRESSED_BYTES to the data type list to indicate the intent of the data. The jsons as drafted above use uint8/int8 however the data can't actually meaningfully interpreted as that and is effectively opaque.

In addition to the compressed sampler extension there are multiple extensions that simply add allowed compression formats (BC, ETC, ASTC, etc.) to said samplers format parameter.

Metadata

Metadata

Assignees

No one assigned

    Type

    No type

    Projects

    No projects

    Milestone

    No milestone

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions