This file is indexed.

/usr/share/psychtoolbox-3/PsychOpenGL/moglMakeGLHDRTexture.m is in psychtoolbox-3-common 3.0.12.20160126.dfsg1-1ubuntu1.

This file is owned by root:root, with mode 0o644.

The actual contents of the file can be viewed below.

  1
  2
  3
  4
  5
  6
  7
  8
  9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 36
 37
 38
 39
 40
 41
 42
 43
 44
 45
 46
 47
 48
 49
 50
 51
 52
 53
 54
 55
 56
 57
 58
 59
 60
 61
 62
 63
 64
 65
 66
 67
 68
 69
 70
 71
 72
 73
 74
 75
 76
 77
 78
 79
 80
 81
 82
 83
 84
 85
 86
 87
 88
 89
 90
 91
 92
 93
 94
 95
 96
 97
 98
 99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
function gltexId = moglMakeGLHDRTexture(hdrImage, gltextarget, halffloat)
% gltexId = moglMakeGLHDRTexture(hdrImage, gltextarget [, halffloat])
%
% Create a high dynamic range OpenGL texture from the given
% Matlab/Octave high dynamic range image matrix 'hdrImage' and attach
% it to the OpenGL texture target of type 'gltextarget'.
%
% Before calling this function you must have called Screen('BeginOpenGL', win);
% with 'win' being the window handle for the onscreen window to
% which the texture should be attached.
%
% Returns an OpenGL texture handle 'gltexId' for the created texture.
% The texture can be used like any other OpenGL texture, just
% with the difference that it represents its color values with 32 bit
% floating point precision instead of 8 bpc fixed point precision.
%
% 'hdrImage' must be a (height, width, 4) matrix of type 'double' or
% 'single', where channel 1=Red, 2=Green, 3=Blue, 4=Alpha. The numeric
% range (0.0 - 1.0) maps to (minimum intensity - maximum intensity).
%
% If 'halffloat' is set to 1 (default is 0), then the texture is created as
% half-precision floating point texture, ie 16 bpc floats. This saves
% memory and bandwidth and allows for floating point filtering on Geforce
% 6000 and 7000 series.
%
% If you want to create a pure 2D texture and use it with Psychtoolbox'
% standard Screen() drawing command, then call moglMakeHDRTexture() instead.
%
% This function is most useful if you want to create textures not handled
% by Psychtoolbox, i.e., cube map textures for environment mapping and
% texture based lighting.

% History:
% 7.8.2006 Created (MK)

persistent alreadychecked;
global GL;

if isempty(GL)
   InitializeMatlabOpenGL;
end;

if isempty(alreadychecked)
   % Check if required OpenGL extensions are available.
   try
      extensions = glGetString(GL.EXTENSIONS);
   catch
      error('MakeGLHDRTexture called before caling Screen(''BeginOpenGL'') on an onscreen window! This will not work...');
   end;

   if isempty(findstr(extensions, 'GL_ARB_texture_float'))
      error('This combination of driver and graphics hardware does not support floating point textures as required for HDR.');
   end;

   alreadychecked = 1;
end

if nargin < 1
   error('Required input ''hdrImage'' matrix is missing.');
end

if nargin < 2
   error('Required OpenGL texture target ''gltextarget'' is missing.');
end

if nargin < 3
    halffloat = 0;
end

if size(hdrImage,1)<1 || size(hdrImage,2)<1
   error('Passed ''hdrImage'' does not have required minimum width x height of at least 1 by 1 pixels.');
end

if size(hdrImage,3)~=4
   error('Passed ''hdrImage'' does not have required number of 4 layers (R,G,B,A).');
end

% Convert into single precision floating-point, whatever it was before.
hdrImage = moglsingle(hdrImage);

% Transpose it and merge from multi-layer to multi-component-per-pixel format:
% Also flip it vertically to match OpenGL style.
for i=1:4
  glImage(i,:,:)=transpose(flipud(hdrImage(:,:,i)));
end

% Build a proper OpenGL texture:

% Generate texture object:
gltexId=glGenTextures(1);

% Hack, needs to be improved...
if IsLinux
    % Redefine vor NVidia:
    GL.RGBA_FLOAT32_APPLE = hex2dec('8883');
end;

% Bind the new texture object:
glBindTexture(gltextarget, gltexId);

if halffloat
    intformat = GL.RGBA_FLOAT16_APPLE;
else
    intformat = GL.RGBA_FLOAT32_APPLE;
end

% Assign the transformed HDR image as mipmap level zero:
glTexImage2D(gltextarget, 0, intformat, size(hdrImage,2), size(hdrImage,1), 0, GL.RGBA, GL.FLOAT, glImage);

% Setup texture wrapping behaviour to clamp, as other behaviours are
% unsupported on many gfx-cards for rectangle textures:
glTexParameterfv(gltextarget,GL.TEXTURE_WRAP_S,GL.CLAMP);
glTexParameterfv(gltextarget,GL.TEXTURE_WRAP_T,GL.CLAMP);

% Setup filtering for the texture - Use nearest neighbour as floating
% point filtering usually unsupported.
glTexParameterfv(gltextarget,GL.TEXTURE_MAG_FILTER,GL.NEAREST);
glTexParameterfv(gltextarget,GL.TEXTURE_MIN_FILTER,GL.NEAREST);

% Unbind texture after setup:
glBindTexture(gltextarget, 0);

% Texture should be ready for use now. Return its handle in 'gltexId':
return;