Title: | Soundscape Ecology |
---|---|
Description: | Functions to calculate indices for soundscape ecology and other ecology research that uses audio recordings. |
Authors: | Luis J. Villanueva-Rivera and Bryan C. Pijanowski |
Maintainer: | Luis J. Villanueva-Rivera <[email protected]> |
License: | GPL-3 |
Version: | 1.3.2 |
Built: | 2025-01-12 04:20:17 UTC |
Source: | https://github.com/ljvillanueva/soundecology |
Acoustic Complexity Index (ACI) from Pieretti, et al. 2011. The ACI is based on the "observation that many biotic sounds, such as bird songs, are characterized by an intrinsic variability of intensities, while some types of human generated noise (such as car passing or airplane transit) present very constant intensity values" (Pieretti, et al. 2011).
The index was tested to the ACItot calculated using SoundscapeMeter v 1.0.14.05.2012, courtesy of A. Farina.
The results given are accumulative. Very long samples will return very large values for ACI. I recommend to divide by number of minutes to get a range of values easier to compare.
acoustic_complexity(soundfile, min_freq = NA, max_freq = NA, j = 5, fft_w = 512)
acoustic_complexity(soundfile, min_freq = NA, max_freq = NA, j = 5, fft_w = 512)
soundfile |
an object of class |
min_freq |
miminum frequency to use when calculating the value, in Hertz. The default is |
max_freq |
maximum frequency to use when calculating the value, in Hertz. The default is the maximum for the file. |
j |
the cluster size, in seconds. |
fft_w |
FFT window to use. |
Returns a list with three objects per channel
AciTotAll_left |
the ACI total for the left channel |
AciTotAll_right |
the ACI total for the right channel |
AciTotAll_left_bymin |
the ACI total for the left channel divided by the number of minutes |
AciTotAll_right_bymin |
the ACI total for the right channel divided by the number of minutes |
aci_fl_left_vals |
values of ACI(fl) for the left channel |
aci_fl_right_vals |
values of ACI(fl) for the right channel |
aci_left_matrix |
Matrix of all values before calculating ACI(fl) for the left channel |
aci_right_matrix |
Matrix of all values before calculating ACI(fl) for the right channel |
Pieretti, N., A. Farina, and D. Morri. 2011. A new methodology to infer the singing activity of an avian community: The Acoustic Complexity Index (ACI). Ecological Indicators 11: 868-873. doi: 10.1016/j.ecolind.2010.11.005
data(tropicalsound) ACI <- acoustic_complexity(tropicalsound) print(ACI$AciTotAll_left) summary(ACI)
data(tropicalsound) ACI <- acoustic_complexity(tropicalsound) print(ACI$AciTotAll_left) summary(ACI)
Acoustic Diversity Index from Villanueva-Rivera et al. 2011. The ADI is calculated by dividing the spectrogram into bins (default 10) and taking the proportion of the signals in each bin above a threshold (default -50 dBFS). The ADI is the result of the Shannon index applied to these bins.
acoustic_diversity(soundfile, max_freq = 10000, db_threshold = -50, freq_step = 1000, shannon = TRUE)
acoustic_diversity(soundfile, max_freq = 10000, db_threshold = -50, freq_step = 1000, shannon = TRUE)
soundfile |
an object of class |
max_freq |
maximum frequency to use when calculating the value, in Hertz. |
db_threshold |
threshold to use in the calculation. |
freq_step |
size of frequency bands. |
shannon |
TRUE to use the Shannon's diversity index to calculate the ADI (default). |
Returns a list with five objects per channel
adi_left |
ADI value for the left channel |
adi_right |
ADI value for the right channel |
left_band_values |
vector of proportion values for each band for the left channel |
right_band_values |
vector of proportion values for each band for the right channel |
left_bandrange_values |
vector of frequency values for each band for the left channel |
right_bandrange_values |
vector of frequency values for each band for the right channel |
The code to calculate the ADI has changed due to an error we detected in the original scripts in which the value was calculated using a different equation. In a test of ~38k files, both ways to calculate were highly correlated. This version of the function uses the Shannon's Diversity Index. To obtain a result using the old calculation, set the argument shannon
to FALSE
. Please check the vignette "Changes in the Acoustic Diversity Index", included in the package, for more details.
For audio files with one channel, the results are showed as the left channel, the right channel returns NA
.
Villanueva-Rivera, L. J., B. C. Pijanowski, J. Doucette, and B. Pekin. 2011. A primer of acoustic analysis for landscape ecologists. Landscape Ecology 26: 1233-1246. doi: 10.1007/s10980-011-9636-9.
data(tropicalsound) result <- acoustic_diversity(tropicalsound) print(result$adi_left) summary(result)
data(tropicalsound) result <- acoustic_diversity(tropicalsound) print(result$adi_left) summary(result)
Acoustic Evenness Index from Villanueva-Rivera et al. 2011 (band evenness using the Gini index). The AEI is calculated by dividing the spectrogram into bins (default 10) and taking the proportion of the signals in each bin above a threshold (default -50 dBFS). The AEI is the result of the Gini index applied to these bins.
acoustic_evenness(soundfile, max_freq = 10000, db_threshold = -50, freq_step = 1000)
acoustic_evenness(soundfile, max_freq = 10000, db_threshold = -50, freq_step = 1000)
soundfile |
an object of class |
max_freq |
maximum frequency to use when calculating the value, in Hertz. |
db_threshold |
threshold to use in the calculation. |
freq_step |
size of frequency bands. |
Returns a list with five objects per channel
aei_left |
AEI for the left channel |
aei_right |
AEI for the right channel |
For audio files with one channel, the results are showed as the left channel, the right channel returns NA
.
Villanueva-Rivera, L. J., B. C. Pijanowski, J. Doucette, and B. Pekin. 2011. A primer of acoustic analysis for landscape ecologists. Landscape Ecology 26: 1233-1246. doi: 10.1007/s10980-011-9636-9.
data(tropicalsound) result <- acoustic_evenness(tropicalsound) print(result$aei_left) summary(result)
data(tropicalsound) result <- acoustic_evenness(tropicalsound) print(result$aei_left) summary(result)
Bioacoustic Index from Boelman, et al. 2007. Inspired on Matlab code courtesy of NT Boelman. Several parts where changed, in particular log math, so this won't be directly comparable to the original code in the paper.
The Bioacoustic Index is calculated as the "area under each curve included all frequency bands associated with the dB value that was greater than the minimum dB value for each curve. The area values are thus a function of both the sound level and the number of frequency bands used by the avifauna" (Boelman, et al. 2007).
bioacoustic_index(soundfile, min_freq = 2000, max_freq = 8000, fft_w = 512)
bioacoustic_index(soundfile, min_freq = 2000, max_freq = 8000, fft_w = 512)
soundfile |
an object of class |
min_freq |
minimum frequency to use when calculating the value, in Hertz. |
max_freq |
maximum frequency to use when calculating the value, in Hertz. |
fft_w |
FFT window size. |
Returns a list with one object per channel
left_area |
area under the curve for the left channel |
right_area |
area under the curve for the right channel |
Boelman NT, Asner GP, Hart PJ, Martin RE. 2007. Multi-trophic invasion resistance in Hawaii: bioacoustics, field surveys, and airborne remote sensing. Ecological Applications 17: 2137-2144.
data(tropicalsound) bioindex <- bioacoustic_index(tropicalsound) print(bioindex$left_area) summary(bioindex)
data(tropicalsound) bioindex <- bioacoustic_index(tropicalsound) print(bioindex$left_area) summary(bioindex)
This function lets the user select bounding boxes to get statistics of the signals of interest in a sound file.
measure_signals(wavfile, wl = 512, min_freq = NA, max_freq = NA, min_time = NA, max_time = NA, plot_range = 50, dBFS_range = 30, sample_size = 1, resultfile = NA, channel = "left")
measure_signals(wavfile, wl = 512, min_freq = NA, max_freq = NA, min_time = NA, max_time = NA, plot_range = 50, dBFS_range = 30, sample_size = 1, resultfile = NA, channel = "left")
wavfile |
a sound file in wav format. |
wl |
window length for the spectrogram. |
min_freq |
minimum frequency to draw the spectrogram, in kiloHertz. |
max_freq |
maximum frequency to draw the spectrogram, in kiloHertz. |
min_time |
minimum time to draw the spectrogram, in seconds. |
max_time |
maximum time to draw the spectrogram, in seconds. |
plot_range |
lower limit of values to plot the spectrogram. |
dBFS_range |
range of values that is considered a signal, based on the maximum that is calculated. See notes below. |
sample_size |
number of samples to measure in the spectrogram. |
resultfile |
name of the file to save the results. |
channel |
which channel to plot. |
The function will open a spectrogram plot to allow the user to click on the regions of interest. Once all the samples are selected, the function saves a file with the values measured in each sample. In addition, the results of the function dfreq
of the package seewave
are saved on a folder named the same as the wavfile, without the .wav extension.
For the dBFS_range
argument, the code uses the maximum of the values inside the selected region and saves as a resulting signal the values that fall between (maximum - dBFS_range)
and the maximum. A selected region with a maximum value of -5 and dBFS_range
set to 30 will consider the area with values between -35 and -5 dBFS as a signal.
The function creates a folder dfreq
where it saves csv files with the results of the function dfreq
from seewave
. The name of each file is coded as: wavfile.samplenumber.csv
## Not run: #Take 5 samples of the file file.wav between 1 - 4 kHz, from 10 to 30 seconds. measure_signals(wavfile="file.wav", wl=2048, min_freq=1, max_freq=4, dBFS_range=30, min_time=10, max_time=30, sample_size=5, resultfile="results.csv", plot_range=70) ## End(Not run)
## Not run: #Take 5 samples of the file file.wav between 1 - 4 kHz, from 10 to 30 seconds. measure_signals(wavfile="file.wav", wl=2048, min_freq=1, max_freq=4, dBFS_range=30, min_time=10, max_time=30, sample_size=5, resultfile="results.csv", plot_range=70) ## End(Not run)
Function to extract the specified index from all the wav or flac files in a directory. The results, including the filename and wave technical details, are saved to a csv file. If the computer has multiple cores, it can run files in parallel.
multiple_sounds(directory, resultfile, soundindex, no_cores = 1, flac = FALSE, from = NA, to = NA, units = NA, ...)
multiple_sounds(directory, resultfile, soundindex, no_cores = 1, flac = FALSE, from = NA, to = NA, units = NA, ...)
directory |
a valid directory, readable by the user, that contains the wav files. |
resultfile |
name of the text file to which write the results in comma-separated values format. |
soundindex |
which index to calculate:
|
no_cores |
number of cores to use when calculating the indices. Can be |
flac |
logical variable to indicate that the files are in FLAC format. FLAC must be installed in the system (see note below). Uses the function |
from |
tells |
to |
tells |
units |
tells |
... |
additional variables to pass to the selected function. See each function's help for details. |
FLAC stands for Free Lossless Audio Codec. Files in FLAC format have been compressed without destruction of data, which happens in lossy compression codecs like the popular MP3. Files can be between 40-60% of the size of the original wav file, although this value depends on the contents. For more information and to download FLAC, visit http://xiph.org/flac/
## Not run: #Calculate the ACI of all the wav # files in the directory "/home/user/wavs/" # using the function acoustic_complexity multiple_sounds(directory = "/home/user/wavs/", resultfile = "/home/user/results.csv", soundindex = "acoustic_complexity") #Calculate the same as above using 12000Hz as the # maximum frequency instead of the default. multiple_sounds(directory = "/home/user/wavs/", resultfile = "/home/user/results.csv", soundindex = "acoustic_complexity", max_freq = 12000) #Calculate the same as above using two cores multiple_sounds(directory = "/home/user/wavs/", resultfile = "/home/user/results.csv", soundindex = "acoustic_complexity", no_cores = 2) #Calculate the same as above using all the cores # the computer has multiple_sounds(directory="/home/user/wavs/", resultfile = "/home/user/results.csv", soundindex = "acoustic_complexity", no_cores = "max") #Calculate the same as above using all but one cores multiple_sounds(directory = "/home/user/wavs/", resultfile = "/home/user/results.csv", soundindex = "acoustic_complexity", no_cores = -1) ## End(Not run)
## Not run: #Calculate the ACI of all the wav # files in the directory "/home/user/wavs/" # using the function acoustic_complexity multiple_sounds(directory = "/home/user/wavs/", resultfile = "/home/user/results.csv", soundindex = "acoustic_complexity") #Calculate the same as above using 12000Hz as the # maximum frequency instead of the default. multiple_sounds(directory = "/home/user/wavs/", resultfile = "/home/user/results.csv", soundindex = "acoustic_complexity", max_freq = 12000) #Calculate the same as above using two cores multiple_sounds(directory = "/home/user/wavs/", resultfile = "/home/user/results.csv", soundindex = "acoustic_complexity", no_cores = 2) #Calculate the same as above using all the cores # the computer has multiple_sounds(directory="/home/user/wavs/", resultfile = "/home/user/results.csv", soundindex = "acoustic_complexity", no_cores = "max") #Calculate the same as above using all but one cores multiple_sounds(directory = "/home/user/wavs/", resultfile = "/home/user/results.csv", soundindex = "acoustic_complexity", no_cores = -1) ## End(Not run)
Normalized Difference Soundscape Index (NDSI) from REAL and Kasten, et al. 2012. The NDSI seeks to "estimate the level of anthropogenic disturbance on the soundscape by computing the ratio of human-generated (anthrophony) to biological (biophony) acoustic components found in field collected sound samples" (Kasten, et al. 2012).
Tested with Matlab code courtesy of S. Gage.
ndsi(soundfile, fft_w = 1024, anthro_min = 1000, anthro_max = 2000, bio_min = 2000, bio_max = 11000)
ndsi(soundfile, fft_w = 1024, anthro_min = 1000, anthro_max = 2000, bio_min = 2000, bio_max = 11000)
soundfile |
an object of class |
fft_w |
FFT window size. |
anthro_min |
minimum value of the range of frequencies of the anthrophony. |
anthro_max |
maximum value of the range of frequencies of the anthrophony. |
bio_min |
minimum value of the range of frequencies of the biophony. |
bio_max |
maximum value of the range of frequencies of the biophony. |
The bin size is determined as the difference between anthro_max and anthro_min, by default 1000 Hz.
Returns a list with one object per channel
ndsi_left |
NDSI value for the left channel |
ndsi_right |
NDSI value for the right channel |
biophony_left |
value for the biophony for the left channel |
anthrophony_left |
value for the anthrophony for the left channel |
biophony_right |
value for the biophony for the right channel |
anthrophony_right |
value for the anthrophony for the right channel |
Remote Environmental Assessment Laboratory. http://www.real.msu.edu
Kasten, Eric P., Stuart H. Gage, Jordan Fox, and Wooyeong Joo. 2012. The Remote Environmental Assessment Laboratory's Acoustic Library: An Archive for Studying Soundscape Ecology. Ecological Informatics 12: 50-67. doi: 10.1016/j.ecoinf.2012.08.001
data(tropicalsound) NDSI <- ndsi(tropicalsound) print(NDSI$ndsi_left) summary(NDSI)
data(tropicalsound) NDSI <- ndsi(tropicalsound) print(NDSI$ndsi_left) summary(NDSI)
This function creates a raster file in ASCII format from the spectrogram of a soundfile. This file can be opened in ArcGIS or any other GIS software. For more details see the tutorial of Villanueva-Rivera et al. 2011.
sound_raster(wavfile = NA, wav_directory = NA, max_freq = 10000, no_cores = 1)
sound_raster(wavfile = NA, wav_directory = NA, max_freq = 10000, no_cores = 1)
wavfile |
a single sound file in wav format. |
max_freq |
maximum frequency to draw the spectrogram, in Hertz. |
wav_directory |
a directory that contains wav files. To specify the working directory, use |
no_cores |
number of cores to use when working in a directory. Can be |
The function will save a file for each channel, in the same directory where the files are at, with the extension .asc.
To get a raster file for a single file, use the argument wavfile
. For many files, use the argument wav_directory
. Do not use both at the same time or the function will return an error.
This function was released with the version 1.3 of the tutorial of the primer paper, available at:
http://ltm.agriculture.purdue.edu/soundscapes/primer/
and at the website of the package:
http://ljvillanueva.github.io/soundecology/
Villanueva-Rivera, L. J., B. C. Pijanowski, J. Doucette, and B. Pekin. 2011. A primer of acoustic analysis for landscape ecologists. Landscape Ecology 26: 1233-1246. doi: 10.1007/s10980-011-9636-9.
## Not run: sound_raster(wavfile = "file1.wav") sound_raster(wav_directory = "/home/user/wavdirectory") sound_raster(wav_directory = "/home/user/wavdirectory", no_cores = 4) ## End(Not run)
## Not run: sound_raster(wavfile = "file1.wav") sound_raster(wav_directory = "/home/user/wavdirectory") sound_raster(wav_directory = "/home/user/wavdirectory", no_cores = 4) ## End(Not run)
Functions to calculate indices for soundscape ecology and other ecology research that uses audio recordings.
Package: | soundecology |
Type: | Package |
Version: | 1.3.2 |
Date: | 2016-07-21 |
License: | GPLv3 |
Luis J. Villanueva-Rivera and Bryan C. Pijanowski
Sample sound of a digital recording of a chorus of tropical frogs.
data(tropicalsound)
data(tropicalsound)
A Wave
object.
Duration = 20 sec. Sampling rate = 22050 Hz.
Recording made at a tropical rainforest in Puerto Rico by Luis J. Villanueva-Rivera.
data(tropicalsound) tropicalsound
data(tropicalsound) tropicalsound