-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmapDSO.m
75 lines (65 loc) · 1.97 KB
/
mapDSO.m
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
%% mapDSO.m MN 2020-07-14
% Maps available digital oscilloscopes to their VISA resources and other attributes
%
% Requirements:
% - None
%
% Usage: dsoStruct = mapDSO(dsoID)
% Returns:
% dsoStruct: Laser information:
% .ID: string to use as dsoID
% .type: string containing the model/manufacturer to select correct SCPI commands
% .interface: function handle to interface function
% .visaAddr: string containing the typical VISA connection address
% .serial: serial number/string
% .bandwidth: maximum bandwidth in Hz
% .channels: number of input channels
% .description: string with a description of the laser
%
% Parameters:
% dsoID: DSO ID; pass 'list' for a cell array of available IDs,
% 'types' for available types
%
% TODO:
% -
function dsoStruct = mapDSO(dsoID)
%% Validate and initialize
if ~ischar(dsoID)
if isnumeric(dsoID)
dsoID = num2str(dsoID);
else
dsoID = char(dsoID);
end
end
dsos = cell(0);
%% List of DSOs
% DSO on Station 2 setup
% USB connection is about 2.5x faster
dsoStruct = struct;
dsoStruct.ID = 'Station2USB';
dsoStruct.type = 'DSO6104A';
dsoStruct.interface = @instDSO_A6000;
dsoStruct.visaAddr = 'USB0::0x0957::0x1754::MY44003501::0::INSTR';
dsoStruct.serial = '44003501';
dsoStruct.bandwidth = 1e9;
dsoStruct.channels = 4;
dsoStruct.description = 'Agilent 4ch 1GHz DSO, USB connection';
dsos{end+1} = dsoStruct;
% Same DSO, but via GPIB
dsoStruct.ID = 'Station2GPIB';
dsoStruct.visaAddr = 'GPIB0::7::INSTR';
dsoStruct.description = 'Agilent 4ch 1GHz DSO, GPIB connection';
dsos{end+1} = dsoStruct;
%% Return desired DSO
if strcmpi(dsoID, 'list')
dsoStruct = cellfun(@(x) x.ID, dsos, 'UniformOutput', 0);
elseif strcmpi(dsoID, 'types')
else
ii = find(cellfun(@(x) strcmpi(x.ID, dsoID), dsos) | cellfun(@(x) strcmpi(x.serial, dsoID), dsos));
if ii>0
dsoStruct = dsos{ii};
else
error('DSO %s not found!', dsoID);
end
end
end