“GL_HALF_FLOAT” with OpenGL Rendering and GLSL

前端 未结 1 720
庸人自扰
庸人自扰 2021-01-07 03:08

I am programming an OpenGL renderer in C++. I want it to be as efficient as possible and each vertex/normal/UV tex coord/tangents/etc to take up as little memory as possible

1条回答
  •  攒了一身酷
    2021-01-07 03:21

    In full OpenGL (unlike in OpenGL ES), shader code always operates with 32-bit floats. Starting with OpenGL 3.0, specifying vertex data as half-floats is supported, though. If the precision is sufficient for your needs, this can reduce memory usage for your vertex data, and reduce the bandwidth needed for vertex fetching.

    Keep in mind that the precision of a half-float is only about 3-4 decimal digits. So the accuracy really is seriously limited.

    As for how to use them, it's quite straightforward. If you have a pointer to half-float values, you store them in a VBO using glBufferData() or glBufferSubData(), just like you would for any other type. The glVertexAttribPointer() call will then look like this, using an attribute with 3 components as an example:

    glVertexAttribPointer(loc, 3, GL_HALF_FLOAT, GL_FALSE, 0);
    

    The format of the data itself is defined in the ARB_texture_float extension. While it's not officially named, it looks at least very similar to the IEEE 754-2008 format. I wrote conversion code based on that Wikipedia format description before, and it worked fine for OpenGL usage.

    Most languages don't have built-in types for half-floats. So you either will have to write a few lines of code to do the conversion from float to half-float, or use code that somebody else wrote.

    The following resources about half-float conversion are from a quick search. I have no personal experience with any of them, and you should do your own search to find the one most suitable for your needs:

    • Interesting article from Intel, explaining possible performance benefits: https://software.intel.com/en-us/articles/performance-benefits-of-half-precision-floats. This also mentions that Intel processors have instructions for the conversion (e.g. there's a _mm256_cvtps_ph intrinsic to convert from float to half-float).
    • Open source library for half-float operations and conversions: http://half.sourceforge.net/.
    • gcc documentation saying that it supports a half-float type (__fp16) for ARM targets.

    0 讨论(0)
提交回复
热议问题