This file is indexed.

/usr/share/psychtoolbox-3/PsychHardware/BitsPlusToolbox/BitsPlusPackMonoImage.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
function [theColorImage,reconNewWay,reconOldWay] = BitsPlusPackMonoImage(theMonoImage)
% [theColorImage,reconNewWay,reconOldWay] = BitsPlusPackMonoImage(theMonoImage)
%
% In Mono++ mode, the Bits++ box uses the red and green
% channels to provide 14-bits per pixel true intensity
% resolution.  The blue channel is set to 0 to let the
% monochromatic image through.   Empirically, we concluded
% that the packing is left adjusted.  That is, the 8 MSB
% of the 14-bit input go into the red channel, and the 
% 6 LSB get left aligned in the green channel, with
% the remaining two bits set to 0.
%
% This routine packs the bits properly for this function.
%
% 11/17/03  dhb, ip	Wrote it.
% 8/13/04	dhb		Fix bug, the data were not packed quite right.
% 2/26/07   mk      Bugfix for LSB conversion: Added modulo operation.
% 3/01/07   mk      Bugfix for MSB conversion: Added floor operation.
% 3/04/07   dhb     Modified to return some debugging information and
%                   compare original with recent version.

[m,n] = size(theMonoImage);
theColorImage = uint8(zeros(m,n,3));

% Red channel gets high 8 bits
theColorImage(:,:,1) = uint8(floor(theMonoImage/256));

% Green channel gets low 6 bits, left justified
theColorImage(:,:,2) = uint8(mod(theMonoImage, 256));

% Optionally create debug images for testing:
if nargout > 1
    % This is the code from the original OS 9 version.  Buggy?
    oldRed = uint8(bitshift(theMonoImage,-6));
    oldGreen = uint8(bitshift(theMonoImage,2));

    % Reconstruct input vales from the two bytes produced for the packing
    reconNewWay = double(theColorImage(:,:,1))*256+double(theColorImage(:,:,2));
    reconNewWay = bitshift(reconNewWay,-2);
    reconOldWay = double(oldRed)*256+double(oldGreen);
    reconOldWay = bitshift(reconOldWay,-2);
end