forked from MarineBioAcousticsRC/DetEdit
-
Notifications
You must be signed in to change notification settings - Fork 0
/
mkTPWS_from_SBP.m
117 lines (99 loc) · 4.43 KB
/
mkTPWS_from_SBP.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
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
% mkTPWS.m
% CAUTION: This script can produce multi-GB files if you have large numbers
% of clicks in one directory
% Script takes output from Simone/Marie's click detector and puts it into
% a format for use in detEdit.
% Expects standard HARP xwav drive directory structure.
% Output:
% A TTPP.m file containing 5 variables:
% MTT: An Nx2 vector of detection start and end times, where N is the
% number of detections
% MPP: An Nx1 vector of recieved level (RL) amplitudes.
% MSP: An NxF vector of detection spectra, where F is dictated by the
% parameters of the fft used to generate the spectra and any
% normalization preferences.
% MSN:
% f = An Fx1 frequency vector associated with MSP
clearvars
% Setup variables:
baseDir = 'D:\USWTR01A_clickparams\mat'; % directory containing de_detector output
outDir = 'D:\USWTR01A_clickparams\TPWS'; % directory where you want to save your TPWS files
siteName = 'USWTRTest'; % site name, only used to name the output file
ppThresh = 0; % minimum RL in dBpp. If detections have RL below this
% threshold, they will be excluded from the output file. Useful if you have
% an unmanageable number of detections.
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
% check if the output file exists, if not, make it
if exist(outDir,'dir')~=7
fprintf('Creating output directory %s',outDir)
mkdir(outDir)
end
MTT = [];
MPP = [];
MSP = [];
MSN = [];
f = [];
dirSet = dir(baseDir);
[~,outName] = fileparts(outDir);
for itr0 = 1:length(dirSet)
if ~strcmp(dirSet(itr0).name,'.')&&~strcmp(dirSet(itr0).name,'..')...
&& ~strcmp(dirSet(itr0).name,outName)
inDir = fullfile(baseDir,dirSet(itr0).name);
fileSet = what(inDir);
lfs = length(fileSet.mat);
for itr2 = 1:lfs
thisFile = fileSet.mat(itr2);
load(fullfile(inDir,char(thisFile)),'-mat','pos','rawStart',...
'ppSignal','specClickTf','fs','yFilt')
if ~isempty(pos)
% Prune detections with low received level if needed.
keepers = find(ppSignal >= ppThresh);
ppSignal = ppSignal(keepers);
pos = pos(keepers,:);
rawIdxStart = floor(pos(:,1)./75);
% rawIdx start should go from 0 to 29, since there are 30
% raw files per .xwav. However, sometimes it's going to 30.
% This shouldn't happen? It may be a rounding error in the
% conversion of rawStart to a date vector (lose decimal
% seconds?)
% If this happens, assume the last start
% time available in rawIdxStart is the right one to use
rawIdxStart(rawIdxStart>=size(rawStart,1)) = size(rawStart,1)-1;
% create vector of raw file starts for each detection time:
rawStartDnum = datenum(rawStart);
% calculate detection times based on associated raw file start:
posDnum = (pos(:,1)-(rawIdxStart*75))/(24*60*60) + rawStartDnum(rawIdxStart+1);
% fileStart = datenum(rawStart(1,:));
%
% % ATTN: Calculating detection times.
% % This assumes that times in the position vector "pos"
% % are relative to the start time of the first raw file.
% posDnum = (pos(:,1)/(60*60*24)) + fileStart +...
% datenum([2000,0,0,0,0,0]);
% store to vectors:
MTT = [MTT; posDnum];
MPP = [MPP; ppSignal];
MSP = [MSP; specClickTf(keepers,:)];
MSN = [MSN; yFilt(keepers,:)];
if isempty(f)
f = 0:(fs/(2*1000))/(size(specClickTf,2)-1):(fs/(2*1000));
end
clickTimes = [];
hdr = [];
specClickTf = [];
ppSignal = [];
yFilt = [];
end
fprintf('Done with file %d of %d \n',itr2,lfs)
end
fprintf('Done with directory %d of %d \n',itr0,length(dirSet))
outFileName = sprintf('%s_%s_TPWS1.mat',siteName,dirSet(itr0).name);
%changed was outFileName = sprintf('%s_TPWS1.mat',dirSet(itr0).name);
save(fullfile(outDir,outFileName),'MTT','MPP','MSP','MSN','f',...
'-v7.3')
end
MTT = [];
MPP = [];
MSP = [];
MSN = [];
end