File: WlsToS.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 (36 lines) | stat: -rw-r--r-- 881 bytes parent folder | download | duplicates (7)
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
function S = WlsToS(wls)
% S = WlsToS(wls)
%
% Converts a list of wavelengths to a [start delta num]
% description.  Wavelengths must be evenly spaced.
%
% 4/17/02  dhb  Handle special case of one wavelength passed.
%               Delta argument is arbitrarily set to 0 for this case.
% 7/11/03  dhb  Handle case the wls is passed in struct format.
% 1/3/12   dhb  Fix check for evenly spaced wavelengths. 

% Check format.
if (isstruct(wls))
	S = [wls.start wls.step wls.numberSamples];
else
	[m,n] = size(wls);
	if (n ~= 1)
	  error('Passed wavelengths is not a column vector');
	end
	
	% Figure out S vector.
	S = zeros(1,3);
	if (n == 1 && m == 1)
		S(1) = wls;
		S(2) = 0;
		S(3) = 1;
	else	
		S(1) = wls(1);
		S(2) = wls(2)-wls(1);
		S(3) = m;
		chk_wls = SToWls(S);
		if ( any(abs(wls-chk_wls) > 1e-6))
		  error('Passed wavelengths are not evenly spaced');
		end
	end
end