#

Name

EXT_texture_lod_bias

Name Strings

GL_EXT_texture_lod_bias

Notice

Copyright NVIDIA Corporation, 1999, 2000.

Contact

Mark Kilgard, NVIDIA (mjk 'at' nvidia.com)

Status

Shipping since late 1999.

The texture LOD bias functionality in OpenGL 1.4 is based on this
extension though the OpenGL 1.4 functionality added the ability to
specify a second per-texture object bias term.  The OpenGL 1.4 enum
values match the EXT enum values.

Version

Last Modified Date: June 23, 2009

Number

OpenGL Extension #186
OpenGL ES Extension #60

Dependencies

Written based on the wording of the OpenGL 1.2 specification.

Affects ARB_multitexture.

Interacts with OpenGL ES 1.1.

Overview

OpenGL computes a texture level-of-detail parameter, called lambda
in the GL specification, that determines which mipmap levels and
their relative mipmap weights for use in mipmapped texture filtering.

This extension provides a means to bias the lambda computation
by a constant (signed) value.  This bias can provide a way to blur
or pseudo-sharpen OpenGL's standard texture filtering.

This blurring or pseudo-sharpening may be useful for special effects
(such as depth-of-field effects) or image processing techniques
(where the mipmap levels act as pre-downsampled image versions).
On some implementations, increasing the texture lod bias may improve
texture filtering performance (at the cost of texture bluriness).

The extension mimics functionality found in Direct3D.

Issues

Should the texture LOD bias be settable per-texture object or
per-texture stage?

  RESOLUTION:  Per-texture stage.  This matches the Direct3D
  semantics for texture lod bias.  Note that this differs from
  the semantics of SGI's SGIX_texture_lod_bias extension that
  has the biases per-texture object.

  This also allows the same texture object to be used by two different
  texture units for different blurring.  This is useful for
  extrapolating detail between various levels of detail in a
  mipmapped texture.

  For example, you can extrapolate texture detail with
  ARB_multitexture and EXT_texture_env_combine by computing

    (B0 - B2) * 2 + B2

  where B0 is a non-biased texture (normal sharpness) and B2 is
  the same texture but bias by 2 levels-of-detail (fairly blurry).
  This has the effect of increasing the high-frequency information
  in the texture.  There are immediate Earth Sciences and medical
  imaging applications for this technique.

  Per-texture stage control of the LOD bias is also useful for
  allowing an application to control overall texture bluriness.
  This can be used in games to simulate disorientation (note that
  only textures will blur, not edges).  It can also be used to
  globally control texturing performance.  An application may be
  able to sustain a constant frame rate by avoiding texture fetch
  stalls by using slightly blurrier textures.

How does EXT_texture_lod_bias differ from SGIX_texture_lod bias?

  EXT_texture_lod_bias adds a bias to lambda.  The
  SGIX_texture_lod_bias extension changes the computation of rho (the
  log2 of which is lambda).  The SGIX extension provides separate
  biases in each texture dimension.  The EXT extension does not
  provide an "directionality" in the LOD control.

Does the texture lod bias occur before or after the TEXTURE_MAX_LOD
and TEXTURE_MIN_LOD clamping?

  RESOLUTION:  BEFORE.  This allows the texture lod bias to still
  be clamped within the max/min lod range.

Does anything special have to be said to keep the biased lambda value
from being less than zero or greater than the maximum number of
mipmap levels?

  RESOLUTION:  NO.  The existing clamping in the specification
  handles these situations.

The texture lod bias is specified to be a float.  In practice, what
sort of range is assumed for the texture lod bias?

  RESOLUTION:  The MAX_TEXTURE_LOD_BIAS_EXT implementation constant
  advertises the maximum absolute value of the supported texture
  lod bias.  The value is recommended to be at least the maximum
  mipmap level supported by the implementation.

The texture lod bias is specified to be a float.  In practice, what
sort of precision is assumed for the texture lod bias?

  RESOLUTION;  This is implementation dependent.  Presumably,
  hardware would implement the texture lod bias as a fractional bias
  but the exact fractional precision supported is implementation
  dependent.  At least 4 fractional bits is recommended.

New Procedures and Functions

None

New Tokens

Accepted by the <target> parameters of GetTexEnvfv, GetTexEnviv,
TexEnvi, TexEnvf, Texenviv, and TexEnvfv:

    TEXTURE_FILTER_CONTROL_EXT          0x8500

When the <target> parameter of GetTexEnvfv, GetTexEnviv, TexEnvi,
TexEnvf, TexEnviv, and TexEnvfv is TEXTURE_FILTER_CONTROL_EXT, then
the value of <pname> may be:
    
    TEXTURE_LOD_BIAS_EXT                0x8501

Accepted by the <pname> parameters of GetBooleanv, GetIntegerv,
GetFloatv, and GetDoublev:

    MAX_TEXTURE_LOD_BIAS_EXT            0x84FD

Additions to Chapter 2 of the 1.2 Specification (OpenGL Operation)

 None

Additions to Chapter 3 of the 1.2 Specification (Rasterization)

– Section 3.8.5 "Texture Minification"

 Change the first formula under "Scale Factor and Level of Detail" to read:

 "The choice is governed by a scale factor p(x,y), the level of detail
 parameter lambda(x,y), defined as

             lambda'(x,y) = log2[p(x,y)] + lodBias

 where lodBias is the texture unit's (signed) texture lod bias parameter
 (as described in Section 3.8.9) clamped between the positive and negative
 values of the implementation defined constant MAX_TEXTURE_LOD_BIAS_EXT."

– Section 3.8.9 "Texture Environments and Texture Functions"

 Change the first paragraph to read:

 "The command

    void TexEnv{if}(enum target, enum pname, T param);
    void TexEnv{if}v(enum target, enum pname, T params);

 sets parameters of the texture environment that specifies how texture
 values are interepreted when texturing a fragment or sets per-texture
 unit texture filtering parameters.  The possible target parameters
 are TEXTURE_ENV or TEXTURE_FILTER_CONTROL_EXT.  ...  When target is
 TEXTURE_ENV, the possible environment parameters are TEXTURE_ENV_MODE
 and TEXTURE_ENV_COLOR. ... When target is TEXTURE_FILTER_CONTROL_EXT,
 the only possible texture filter parameter is TEXTURE_LOD_BIAS_EXT.
 TEXTURE_LOD_BIAS_EXT is set to a signed floating point value that
 is used to bias the level of detail parameter, lambda, as described
 in Section 3.8.5."

 Add a final paragraph at the end of the section:

 "The state required for the per-texture unit filtering parameters
 consists of one floating-point value."

Additions to Chapter 4 of the 1.2 Specification (Per-Fragment Operations and the Frame Buffer)

 None

Additions to Chapter 5 of the 1.2 Specification (Special Functions)

 None

Additions to Chapter 6 of the 1.2 Specification (State and State Requests)

– Section 6.1.3 "Texture Environments and Texture Functions"

 Change the third sentence of the third paragraph to read:

 "The env argument to GetTexEnv must be either TEXTURE_ENV or
 TEXTURE_FILTER_CONTROL_EXT."

Additions to the GLX Specification

 None

Dependencies on OpenGL ES 1.1

 If the GL is OpenGL ES 1.1, omit reference to GetDoublev.

Errors

 INVALID_ENUM is generated when TexEnv is called with a <pname> of
 TEXTURE_FILTER_CONTROL_EXT and the value of <param> or what is pointed to
 by <params> is not TEXTURE_LOD_BIAS_EXT.

New State

(table 6.14, p204) add the entry:

Get Value Type Get Command Initial Value Description Sec Attribute ———————– —- ———– ————– ————— —– ——— TEXTURE_LOD_BIAS_EXT R GetTexEnvfv 0.0 Biases texture 3.8.9 texture level of detail

(When ARB_multitexture is supported, the TEXTURE_LOD_BIAS_EXT state is per-texture unit.)

New Implementation State

(table 6.24, p214) add the following entries:

Get Value Type Get Command Minimum Value Description Sec Attribute ————————– —- ———– ————- —————– —— ————– MAX_TEXTURE_LOD_BIAS_EXT R+ GetFloatv 4.0 Maximum 3.8.9 - absolute texture lod bias

Revision History

6/23/09 (Jon Leech) - assign OpenGL ES extension number.

4/29/09 (Benj Lipchak) - add interaction with OpenGL ES 1.1.

8/27/03 - updated status to mention OpenGL 1.4 functionality.

8/26/03 - fixed incorrect enum name (TEXTURE_FILTER_CONTROL_EXT is
correct) in the Errors section.

6/2/00 - add spec language to allow GetTexEnv to accept
TEXTURE_FILTER_CONTROL_EXT.