Museum

Home

Lab Overview

Retrotechnology Articles

Online Manuals

⇒ glconvolutionfilter2dext(3G) — IRIX 6.5.3f

Media Vault

Software Library

Restoration Projects

Artifacts Sought



glConvolutionFilter2DEXT(3G)   OpenGL Reference   glConvolutionFilter2DEXT(3G)



NAME
     glConvolutionFilter2DEXT - define a two-dimensional convolution filter


C SPECIFICATION
     void glConvolutionFilter2DEXT( GLenum target,
                                    GLenum internalformat,
                                    GLsizei width,
                                    GLsizei height,
                                    GLenum format,
                                    GLenum type,
                                    const GLvoid *image )


PARAMETERS
     target          Must be GLCONVOLUTION2DEXT.

     internalformat  The internal format of the convolution filter kernel.
                     The allowable values are GLALPHA, GLLUMINANCE,
                     GLLUMINANCEALPHA, GLINTENSITYEXT, GLRGB, and
                     GLRGBA.

     width           The width of the pixel array referenced by image.

     height          The height of the pixel array referenced by image.

     format          The format of the pixel data in image.  The allowable
                     values are GLRGBA, GLABGREXT, GLRED, GLGREEN,
                     GLBLUE, GLALPHA, GLRGB, GLLUMINANCE,
                     GLLUMINANCEALPHA and GLYCRCB422SGIX are accepted.

     type            The type of the pixel data in image.  The allowable
                     values are GLUNSIGNEDBYTE, GLBYTE, GLUNSIGNEDSHORT,
                     GLSHORT, GLUNSIGNEDINT, GLINT, GLFLOAT,
                     GLUNSIGNEDBYTE332EXT,
                     GLUNSIGNEDSHORT4444EXT,
                     GLUNSIGNEDSHORT5551EXT,
                     GLUNSIGNEDINT8888EXT, and
                     GLUNSIGNEDINT1010102EXT.

     image           Pointer to a two-dimensional array of pixel data that is
                     processed to build the convolution filter kernel.

DESCRIPTION
     glConvolutionFilter2DEXT builds a two-dimensional convolution filter
     kernel from an array of pixels.

     The pixel array specified by width, height, format, type, and image is
     extracted from memory and processed just as if glDrawPixels were called,
     but processing stops after the final expansion to RGBA is completed.

     The R, G, B, and A components of each pixel are next scaled by the four



                                                                        Page 1





glConvolutionFilter2DEXT(3G)   OpenGL Reference   glConvolutionFilter2DEXT(3G)



     2D GLCONVOLUTIONFILTERSCALEEXT parameters and biased by the four 2D
     GLCONVOLUTIONFILTERBIASEXT parameters.  (The scale and bias
     parameters are set by glConvolutionParameterEXT using the
     GLCONVOLUTION2DEXT target and the names
     GLCONVOLUTIONFILTERSCALEEXT and GLCONVOLUTIONFILTERBIASEXT.  The
     parameters themselves are vectors of four values that are applied to red,
     green, blue, and alpha, in that order.)  The R, G, B, and A values are
     not clamped to [0,1] at any time during this process.

     Each pixel is then converted to the internal format specified by
     internalformat.  This conversion simply maps the component values of the
     pixel (R, G, B, and A) to the values included in the internal format
     (red, green, blue, alpha, luminance, and intensity).  The mapping is as
     follows:

      Internal Format      Red   Green   Blue   Alpha   Luminance   Intensity
      _______________________________________________________________________
      GLALPHA                                    A
      GLLUMINANCE                                R
      GLLUMINANCEALPHA                  A       R
      GLINTENSITYEXT                                                  R
      GLRGB                R      G      B
      GLRGBA               R      G      B       A

     The red, green, blue, alpha, luminance, and/or intensity components of
     the resulting pixels are stored in floating-point rather than integer
     format.  They form a two-dimensional filter kernel image indexed with
     coordinates i and j such that i starts at zero and increases from left to
     right, and j starts at zero and increases from bottom to top.  Kernel
     location i,j is derived from the Nth pixel, where N is i+j*width.

     Note that after a convolution is performed, the resulting color
     components are also scaled by their corresponding
     GLPOSTCONVOLUTIONcSCALEEXT parameters and biased by their
     corresponding GLPOSTCONVOLUTIONcBIASEXT parameters (where c takes on
     the values RED, GREEN, BLUE, and ALPHA).  These parameters are set by
     glPixelTransfer.

ERRORS
     GLINVALIDENUM is generated if target is not GLCONVOLUTION2DEXT.

     GLINVALIDENUM is generated if internalformat is not one of the
     allowable values.

     GLINVALIDVALUE is generated if width is less than zero or greater than
     the maximum supported value.  This value may be queried with
     glGetConvolutionParameterEXT using target GLCONVOLUTION2DEXT and name
     GLMAXCONVOLUTIONWIDTHEXT.

     GLINVALIDVALUE is generated if height is less than zero or greater than
     the maximum supported value.  This value may be queried with
     glGetConvolutionParameterEXT using target GLCONVOLUTION2DEXT and name



                                                                        Page 2





glConvolutionFilter2DEXT(3G)   OpenGL Reference   glConvolutionFilter2DEXT(3G)



     GLMAXCONVOLUTIONHEIGHTEXT.

     GLINVALIDENUM is generated if format is not one of the allowable
     values.

     GLINVALIDENUM is generated if type is not one of the allowable values.

     GLINVALIDOPERATION is generated if glConvolutionFilter2DEXT is executed
     between the execution of glBegin and the corresponding execution of
     glEnd.

     If type is set to GLUNSIGNEDBYTE332EXT,
     GLUNSIGNEDSHORT4444EXT, GLUNSIGNEDSHORT5551EXT,
     GLUNSIGNEDINT8888EXT, or GLUNSIGNEDINT1010102EXT and the
     EXTpackedpixels extension is not supported then a GLINVALIDENUM error
     is generated.

ASSOCIATED GETS
     glGetConvolutionParameterEXT, glGetConvolutionFilterEXT


MACHINE DEPENDENCIES
     On RealityEngine, RealityEngine2, and VTX systems convolution may not be
     used in the following circumstances:

          1.  When rendering to pixmaps.

          2.  When fragment processing (texturing, depth buffering, alpha
              testing, multisampling, fog) is enabled.

          3.  When histogramming or minmax is enabled.

          4.  When either of the pixel zoom factors has a value other than 1.0
              or -1.0.

     In these cases, glDrawPixels and glCopyPixels report a
     GLINVALIDOPERATION error and do not transfer any pixels.


SEE ALSO
     glConvolutionFilter1DEXT, glSeparableFilter2DEXT,
     glConvolutionParameterEXT, glEnable with parameter GLCONVOLUTION2DEXT,
     glPixelTransfer.












                                                                        Page 3



Typewritten Software • bear@typewritten.org • Edmonds, WA 98026