-
Notifications
You must be signed in to change notification settings - Fork 27
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
meaning of the "MIN. Seconds/Average"(in GUI) or REMORA.sm.cmpt.perc (in code) setting? #98
Comments
Dear chuetz,
The min seconds/average is used to discard minutes when only few seconds are available in a given minute. We wrote the remora to work with an initial 1s/1Hz resolution LTSA (the latest recommendation, not quite a final standard). Looking at your parameters, you already average to 1 minute in your initial LTSA computation, hence the later step might trip up on that. But since you found a workaround then you’re probably fine. You may want to check on a smaller chunk of data (I assume that you won’t be able to cram 16 days with 1s resolution into 1 LTSA) how different the results turn out being.
Best,
Simone
… On Sep 12, 2023, at 00:19, chuetz ***@***.***> wrote:
Hi all,
Sorry in advance for this long post, but I'm trying to be as precise as possible...
I'm having some issues finding the correct settings to compute metrics with the soundscape metrics Remora.
More specifically with the "MIN. Seconds/Average" settings.
Here are the parameters I use to compute the LTSA :
PARAMS.ltsa.tave = 60; % averaging time [seconds]
PARAMS.ltsa.dfreq = 1; % frequency bin size [Hz]
PARAMS.ltsa.ndays = 16; % length of LTSA [days]
PARAMS.ltsa.nstart = 1; % start number of LTSA file (e.g. want to start at week 2)
% experiment defined (in WAV/XWAV file):
PARAMS.ltsa.fs = 22000; % sample rate [Hz]
PARAMS.ltsa.ftype = 1; % 1= WAVE, 2=XWAV
PARAMS.ltsa.dtype = 1; % 1 = HARP, 2 = ARP, 3 = OBS, 4 = towed array or sonobuoy, 5 = SoundTrap
PARAMS.ltsa.ch= 1; % channel to do ltsa on for multichannel wav files
And here are the parameters used for the metrics :
REMORA.sm.cmpt.ltsaout = 0; % yes/no for a new average LTSA output
REMORA.sm.cmpt.csvout = 1; % yes/no for a csv output
REMORA.sm.cmpt.fstart = 1; % LTSA file number to start with for calculation
%% Analysis Options
% Bandpass Edges
REMORA.sm.cmpt.lfreq = 20; % low frequency cut off (Hz)
REMORA.sm.cmpt.hfreq = 10000; % hight frequency cut off (Hz)
% Analysis Type
REMORA.sm.cmpt.bb= 0; % yes/no broadband level
REMORA.sm.cmpt.ol = 0; % yes/no octave level
REMORA.sm.cmpt.tol = 0; % yes/no third octave level
REMORA.sm.cmpt.psd = 1; % yes/no power spectral density
% Averaging
REMORA.sm.cmpt.avgt = 60; % bin size of time average in seconds
REMORA.sm.cmpt.avgf = 1; % bin size of frequency average in Hz
REMORA.sm.cmpt.perc = 0.01; % percentage of seconds with good data / time average
REMORA.sm.cmpt.mean = 1; % mean averaging type
REMORA.sm.cmpt.median = 0; % median averaging type
REMORA.sm.cmpt.prctile = 0; % percentiles averaging type
% Remove Erroneous Data
REMORA.sm.cmpt.fifo = 0; % yes/no remove fifo noise
REMORA.sm.cmpt.dw = 0; % yes/no remove disk writes in HARP data
REMORA.sm.cmpt.strum = 0; % yes/no remove flow or strumming noise
With the data I’m analyzing at the moment, anything else than 1 for the REMORA.sm.cmpt.perc parameter does not work, and the output says Time average NOT computed.
I tried to see where the problem comes from, and it appears that any other value than 1 puts the condition in line 85 of sm_cmpt_avgs.m
if (length(hidx) + length(REMORA.sm.cmpt.pre.timeavgs)) >= REMORA.sm.cmpt.avgt*REMORA.sm.cmpt.perc || last_avg == 1
being always false. Therefore, the program never goes into the sm_cmpt_writeout(tidx) line and therefore all outputs are empty.
The variable hidx is incremented by one at each loop turn and that timeavgs is always empty. Therefore length(hidx) + length(REMORA.sm.cmpt.pre.timeavgs)) is always 1 and never > REMORA.sm.cmpt.avgt*REMORA.sm.cmpt.perc except if REMORA.sm.cmpt.perc > 1/ REMORA.sm.cmpt.avgt, which, in my case is equal to 60 seconds.
With this parameter equals to 1% (ie REMORA.sm.cmpt.perc=0.01), it seems that all the averages are done correctly, without skiping LTSA data. Is that correct?
If so, what is the purpose of this parameter?
Thank you very much for any help on this issue!
—
Reply to this email directly, view it on GitHub <https://urldefense.com/v3/__https://github.com/MarineBioAcousticsRC/Triton/issues/98__;!!Mih3wA!HcKizK475-ILevFFZB9irfQLygPSyGAMLVyU2FtaZz_wOj-K4Bur4UEZnBTLvasoEgPS5pinEmgTrlTPrzvVpKJj$>, or unsubscribe <https://urldefense.com/v3/__https://github.com/notifications/unsubscribe-auth/AIFJ573KZEDSLQRPOGGMGATX2AEIDANCNFSM6AAAAAA4UM26BE__;!!Mih3wA!HcKizK475-ILevFFZB9irfQLygPSyGAMLVyU2FtaZz_wOj-K4Bur4UEZnBTLvasoEgPS5pinEmgTrlTPr1QzOSyR$>.
You are receiving this because you are subscribed to this thread.
______________________________________________________________
Simone Baumann-Pickering (she/her/hers) // Professor
Ritter Hall 200F // Scripps Institution of Oceanography // University of California San Diego
(858) 534-7280 // ***@***.*** // sael.ucsd.edu // mbarc.ucsd.edu
|
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Hi all,
Sorry in advance for this long post, but I'm trying to be as precise as possible...
I'm having some issues finding the correct settings to compute metrics with the soundscape metrics Remora.
More specifically with the "MIN. Seconds/Average" settings.
Here are the parameters I use to compute the LTSA :
PARAMS.ltsa.tave = 60; % averaging time [seconds]
PARAMS.ltsa.dfreq = 1; % frequency bin size [Hz]
PARAMS.ltsa.ndays = 16; % length of LTSA [days]
PARAMS.ltsa.nstart = 1; % start number of LTSA file (e.g. want to start at week 2)
% experiment defined (in WAV/XWAV file):
PARAMS.ltsa.fs = 22000; % sample rate [Hz]
PARAMS.ltsa.ftype = 1; % 1= WAVE, 2=XWAV
PARAMS.ltsa.dtype = 1; % 1 = HARP, 2 = ARP, 3 = OBS, 4 = towed array or sonobuoy, 5 = SoundTrap
PARAMS.ltsa.ch= 1; % channel to do ltsa on for multichannel wav files
And here are the parameters used for the metrics :
REMORA.sm.cmpt.ltsaout = 0; % yes/no for a new average LTSA output
REMORA.sm.cmpt.csvout = 1; % yes/no for a csv output
REMORA.sm.cmpt.fstart = 1; % LTSA file number to start with for calculation
%% Analysis Options
% Bandpass Edges
REMORA.sm.cmpt.lfreq = 20; % low frequency cut off (Hz)
REMORA.sm.cmpt.hfreq = 10000; % hight frequency cut off (Hz)
% Analysis Type
REMORA.sm.cmpt.bb= 0; % yes/no broadband level
REMORA.sm.cmpt.ol = 0; % yes/no octave level
REMORA.sm.cmpt.tol = 0; % yes/no third octave level
REMORA.sm.cmpt.psd = 1; % yes/no power spectral density
% Averaging
REMORA.sm.cmpt.avgt = 60; % bin size of time average in seconds
REMORA.sm.cmpt.avgf = 1; % bin size of frequency average in Hz
REMORA.sm.cmpt.perc = 0.01; % percentage of seconds with good data / time average
REMORA.sm.cmpt.mean = 1; % mean averaging type
REMORA.sm.cmpt.median = 0; % median averaging type
REMORA.sm.cmpt.prctile = 0; % percentiles averaging type
% Remove Erroneous Data
REMORA.sm.cmpt.fifo = 0; % yes/no remove fifo noise
REMORA.sm.cmpt.dw = 0; % yes/no remove disk writes in HARP data
REMORA.sm.cmpt.strum = 0; % yes/no remove flow or strumming noise
With the data I’m analyzing at the moment, anything else than 1 for the REMORA.sm.cmpt.perc parameter does not work, and the output says Time average NOT computed.
I tried to see where the problem comes from, and it appears that any other value than 1 puts the condition in line 85 of sm_cmpt_avgs.m
if (length(hidx) + length(REMORA.sm.cmpt.pre.timeavgs)) >= REMORA.sm.cmpt.avgt*REMORA.sm.cmpt.perc || last_avg == 1
being always false. Therefore, the program never goes into the sm_cmpt_writeout(tidx) line and therefore all outputs are empty.
The variable hidx is incremented by one at each loop turn and that timeavgs is always empty. Therefore length(hidx) + length(REMORA.sm.cmpt.pre.timeavgs)) is always 1 and never > REMORA.sm.cmpt.avgt*REMORA.sm.cmpt.perc except if REMORA.sm.cmpt.perc > 1/ REMORA.sm.cmpt.avgt, which, in my case is equal to 60 seconds.
With this parameter equals to 1% (ie REMORA.sm.cmpt.perc=0.01), it seems that all the averages are done correctly, without skiping LTSA data. Is that correct?
If so, what is the purpose of this parameter?
Thank you very much for any help on this issue!
The text was updated successfully, but these errors were encountered: