File: PR670measxyz.m

package info (click to toggle)
psychtoolbox-3 3.0.14.20170103%2Bgit6-g605ff5c.dfsg1-1
  • links: PTS, VCS
  • area: main
  • in suites: stretch
  • size: 103,044 kB
  • ctags: 69,483
  • sloc: ansic: 167,371; cpp: 11,232; objc: 4,708; sh: 1,875; python: 383; php: 344; makefile: 207; java: 113
file content (60 lines) | stat: -rwxr-xr-x 1,227 bytes parent folder | download | duplicates (6)
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
function [xyz, qual] = PR670measxyz
% PR670measxyz - Make an XYZ measurement with the PR-670.
%
% Syntax:
% [xyz, qual] = PR670measxyz
%
% Output:
% xyz (3x1) - Measured XYZ values.
% qual (scalar) - Measurement quality code.  Will be 0 for successful
%     measurements, -8 if too little light.

global g_serialPort;

% Check for initialization
if isempty(g_serialPort)
   error('Meter has not been initialized.');
end

% Set the response timeout in seconds.
timeout = 30;

% See if we can sync to the source and set sync mode appropriately.
syncFreq = PR670getsyncfreq;
if ~isempty(syncFreq) && syncFreq ~= 0
	PR670write('SS1');
else
	disp('Warning: Could not sync to source.');
    PR670write('SS0');
end

% Make measurement and get the string;
readStr = PR670rawxyz(timeout);

% Extract the returned data.
C = textscan(readStr, '%d,%d,%f,%f,%f');

% Check returned data.
qual = C{1};

switch qual
	% Measurement OK
	case 0
		% Make sure the units look OK.
		units = C{2};
		assert(units == 0, 'Units not returned as cd/m2');
		
		% Extract the XYZ values.
		X = C{3};
		Y = C{4};
		Z = C{5};
		
		xyz = [X;Y;Z];
		
	% Low light
	case -8
		xyz = zeros(3,1);
		
	otherwise
		error('Bad return code %g from meter', qual);
end