Species-specific audio detection: a comparison of three template-based detection algorithms using random forests

View article
PeerJ Computer Science
Note that a Preprint of this article also exists, first published January 11, 2017.

Introduction

Monitoring fauna is an important task for ecologists, natural resource managers, and conservationists. Historically, most data were collected manually by scientists that went to the field and annotated their observations (Terborgh et al., 1990). This generally limited the spatial and temporal extend of the data. Furthermore, given that the data were based on an individual’s observations, the information was difficult to verify, reducing its utility for understanding long-term ecological processes (Acevedo & Villanueva-Rivera, 2006).

To understand the impacts of climate change and deforestation on the fauna, the scientific community needs long-term, wide-spread and frequent data (Walther et al., 2002). Passive acoustic monitoring (PAM) can contribute to this need because it facilitates the collection of large amounts of data from many sites simultaneously, and with virtually no impact to the fauna and environment (Brandes, 2008; Lammers et al., 2008; Tricas & Boyle, 2009; Celis-Murillo, Deppe & Ward, 2012). In general, PAM systems include a microphone or a hydrophone connected to a self powered system and enough memory to store various weeks or months of recordings, but there are also permanent systems that use solar panels and an Internet connection to upload recordings in real time to a cloud based analytical platform (Aide et al., 2013).

Passive recorders can easily create a very large data set (e.g., 100,000s of recordings) that is overwhelming to manage and analyze. Although researchers often collect recordings twenty-four hours a day for weeks or months (Acevedo & Villanueva-Rivera, 2006; Brandes, 2008; Lammers et al., 2008; Sueur et al., 2008; Marques et al., 2013; Blumstein et al., 2011), in practice, most studies have only analyzed a small percentage of the total number of recordings.

Web-based applications have been developed to facilitate data management of these increasingly large datasets (Aide et al., 2013; Villanueva-Rivera & Pijanowski, 2012), but the biggest challenge is to develop efficient and accurate algorithms for detecting the presence or absence of a species in many recordings. Algorithms for species identification have been developed using spectrogram matched filtering (Clark, Marler & Beeman, 1987; Chabot, 1988), statistical feature extraction (Taylor, 1995; Grigg et al., 1996), k-Nearest neighbor algorithm (Han, Muniandy & Dayou, 2011; Gunasekaran & Revathy, 2010), Support Vector Machine (Fagerlund, 2007; Acevedo et al., 2009), tree-based classifiers (Adams, Law & Gibson, 2010; Henderson, Hildebrand & Smith 2011) and template based detection (Anderson, Dave & Margoliash, 1996; Mellinger & Clark, 2000), but most of these algorithms are built for a specific species and there was no infrastructure provided for the user to create models for other species.

In this study, we developed a method that detects the presence or absence of a species’ specific call type in recordings with a response time that allows researchers to create, run, tune and re-run models in real time as well as detect hundreds of thousands of recordings in a reasonable time. The main objective of the study was to compare the performance (e.g., efficiency and accuracy) of three variants of a template-based detection algorithm and incorporate the best into the ARBIMON II bioacoustics platform. The first variant is the Structural Similarity Index described in Wang et al. (2004), a widely use method to find how similar two images are (in our case the template with the tested recording). The second method filters the recordings with the dynamic thresholding method described in Van der Walt et al. (2014) and then use the Frobenius norm to find similarities with the template. The final method uses the Structural Similarity Index, but it is only applied to regions with high match probability determined by the OpenCV’s matchTemplate procedure (Bradski, 2000).

Materials and Methods

Passive acoustic data acquisition

We gathered recordings from five locations: four in Puerto Rico and one in Peru. Some of the recordings were acquired using the Automated Remote Biodiversity Monitoring Network (ARBIMON) data acquisition system described in Aide et al. (2013), while others were acquired using the newest version of ARBIMON permanent recording station, which uses an Android cell phone and transmits the recorded data through a cellular network. All recordings have a sampling rate of 44.1 kHz, a sampling depth of 16-bit and an approximate duration of 60 s (±.5 s)

The locations in Puerto Rico were the Sabana Seca permanent station in Toa Baja, the Casa la Selva station in Carite Mountains (Patillas), El Yunque National Forest in Rio Grande and Mona Island (see Fig. 1). The location in Peru was the Amarakaeri Communal Reserve in the Madre de Dios Region (see Fig. 2). In all the locations, the recorders were programmed to record one minute of audio every 10 min. The complete dataset has more than 100,000 1-minute recordings. We randomly chose 362 recordings from Puerto Rico and 547 recordings from Peru for comparing the three algorithm variants.

Recording locations in Puerto Rico.

Figure 1: Recording locations in Puerto Rico.

Map data: Google, Image—Landsat/Copernicus and Data—SIO, NOAA, US Navy, NGA and GEBCO.
Recording location in Peru.

Figure 2: Recording location in Peru.

Map data: Google, US Dept. of State Geographer, Image—Landsat/Copernicus and Data—SIO, NOAA, US Navy, NGA and GEBCO.

We used the ARBIMON II web application interface to annotate the presence or absence of 21 species in all the recordings. Regions in the recording where a species emits a sound were also marked using the web interface. Each region of interest (ROI) is a rectangle delimited by starting time, ending time, lowest frequency and highest frequency along with a species and sound type. The species included in the analysis are listed in Table 1, along with the number of total recordings and the number of recordings where the species is present or absent.

Table 1:
Species, class, location and count of recordings with validated data.
Species Group Total Presence Absence Location
Eleutherodactylus cooki Amphibian 38 19 19 Carite
Eleutherodactylus brittoni Amphibian 38 17 21 Sabana Seca
Eleutherodactylus cochranae Amphibian 54 30 24 Sabana Seca
Eleutherodactylus coqui Amphibian 53 41 12 Sabana Seca
Eleutherodactylus juanariveroi Amphibian 35 14 21 Sabana Seca
Unknown Insect Insect 48 22 26 Sabana Seca
Epinephelus guttatus Fish 152 76 76 Mona Island
Megascops nudipes Bird 100 50 50 El Yunque
Microcerculus marginatus Bird 80 40 40 Peru
Basileuterus chrysogaster Bird 60 30 30 Peru
Myrmoborus leucophrys Bird 160 80 80 Peru
Basileuterus bivittatus Bird 100 50 50 Peru
Liosceles thoracicus Bird 76 38 38 Peru
Chlorothraupis carmioli Bird 112 56 56 Peru
Megascops guatemalae Bird 28 8 20 Peru
Saltator grossus Bird 68 34 34 Peru
Myrmeciza hemimelaena Bird 180 90 90 Peru
Thamnophilus schistaceus Bird 60 30 30 Peru
Hypocnemis subflava Bird 140 70 70 Peru
Percnostola lophotes Bird 100 50 50 Peru
Formicarius analis Bird 80 40 40 Peru
DOI: 10.7717/peerjcs.113/table-1

Algorithm

The algorithm recognition process is divided into three phases: (1) Template Computation, (2) Model Training and (3) Detection (see Fig. 3). In Template computation, all ROIs submitted by the user in the training set are aggregated into a template. In Model Training the template is used to compute recognition functions from validated audio recordings and features from the resulting vector V are computed. These features are used to train a random forest model. In the Detection phase the template is used to compute the features, but this time the features are fed to the trained random forest model to compute a prediction of presence or absence.

The three phases of the algorithm to create the species-specific models.

Figure 3: The three phases of the algorithm to create the species-specific models.

In the Model Training phase Reci is a recording, Vi is the vector generated by the recognition function on Reci and in the Detection phase V is the vector generated by the recognition function on the incoming recording.

In the following sections the Template Computation process will be explained, then the process of using the Template to extract features from a recording is presented and finally, the procedures to use the features to train the model and to detect recordings are discussed.

Template computation

The template refers to the combination of all ROIs in the training data. To create a template, we first start with the examples of the specific call of interest (i.e., ROIs) that were annotated from a set of recordings for a given species and a specific call type (e.g., common, alarm). Each ROI encompasses an example of the call, and is an instance of time between time t1 and time t2 of a given recording and low and high boundary frequencies of f1 and f2, where t1 < t2 and f1 < f2. In a general sense, we combine these examples to produce a template of a specific song type of a single species.

Specifically, for each recording that has an annotated ROI, a spectrogram matrix (SM) is computed using the Short Time Fourier Transform with a frame size of 1024 samples, 512 samples of overlap and a Hann analysis window, thus the matrices have 512 rows. For a recording with a sampling rate of 44,100 Hz, the matrix bin bandwidth is approximately 43.06 Hz. The SM is arranged so that the row of index 0 represents the lowest frequency and the row with index 511 represents the highest frequency of the spectrum. Properly stated the columns c1 to c2 and the rows from r1 to r2 of SM were extracted, where: c 1 = t 1 × 44 , 100 , c 2 = t 2 × 44 , 100 , r 1 = f 1 43 . 06 and r 2 = f 2 43 . 06 . The rows and columns that represent the ROI in the recording (between frequencies f1 and f2 and between times t1 and t2) are extracted. The submatrix of SM that contains only the area bounded by the ROI is define as SMROI and refer in the manuscript as the ROI matrix.

Since the ROI matrices can vary in size, to compute the aggregation from the ROI matrices we have to take into account the difference in the number of rows and columns of the matrices. All recordings have the same sampling rate, 44,100 Hz. Thus, the rows from different SMs, computed with the same parameters, will represent the same frequencies, i.e., rows with same indexes represent the same frequency. After the ROI matrix, SMROI, has been extracted from SM, the rows of SMROI will also represent specific frequencies. Thus, if we were to perform an element-wise matrix sum between two ROI matrices with potentially different number of rows, we should only sum rows that represent the same frequency.

To take into account the difference in the number of columns of the ROI matrices, we use the Frobenius norm to optimize the alignment of the smaller ROI matrices and perform element-wise sums between rows that represent the same frequency. We present that algorithm in the following section and a flow chart of the process in Fig. 4.

Flowchart of the algorithm to generate the template of each species.
Figure 4: Flowchart of the algorithm to generate the template of each species.

Template computation algorithm:

  1. Generate the set of SMROI matrices by computing the short time Fourier Transform of all the user generated ROIs.

  2. Create matrix SMmax, a duplicate of the first created matrix among the matrices with the largest number of columns.

  3. Set cmax as the number of columns in SMmax.

  4. Create matrix Ttemp, with the same dimensions as SMmax and all entries equal to 0. This matrix will contain the element-wise addition of all the extracted SMROI matrices.

  5. Create matrix W with the same dimensions of SMmax and all entries equal to 0. This matrix will hold the count on the number of SMROI matrices that participate in the calculation of each element of Ttemp.

  6. For each one of the SMi ROI matrices in SMROI:

    1. If SMi has the same number of columns as Ttemp:

      1. Align the rows of SMi and Ttemp so they represent equivalent frequencies and perform an element-wise addition of the matrices and put the result in Ttemp.

      2. Add one to all the elements of the W matrix where the previous addition participated.

    2. If the number of columns differs between SMi and Ttemp, then find the optimal alignment with SMmax as follows:

      1. Set ci as the number of columns in SMi.

      2. Define (SMmax)I as the set of all submatrices of SMmax with the same dimensions as SMi. Note that the cardinality of (SMmax)I is cmax − ci.

      3. For each Subk ∈ (SMmax)I:

        1. Compute dk = NORM(Subk − SMi) where NORM is the Frobenius norm defined as: N O R M A = i , j | a i , j 2 | where ai,j are the elements of matrix A.

      4. Define Submin{dk} as the Subk matrix with the minimum dk. This is the optimal alignment of SMi with SMmax.

      5. Align the rows of Submin{dk} and Ttemp so they represent equivalent frequencies, perform an element-wise addition of the matrices and put the result in Ttemp.

      6. Add one to all the elements of the W matrix where the previous addition participated.

  7. Define the matrix Ttemplate as the element-wise division between the Ttemp matrix and the W matrix.

The resulting Ttemplate matrix summarizes the information available in the ROI matrices submitted by the user and it will be used to extract information from the audio recordings that are to be analyzed. In this article each species Ttemplate was created using five ROIs.

In Fig. 5A a training set for the Eleutherodactylus coqui is presented and in Fig. 5B the resulting template can be seen. This tool is very useful because the user can see immediately the effect of adding or subtracting a specific sample to the training set.

Figure 5: (A) A training set with 16 examples of the call of E. coqui. (B) The resulting template from the training set.
Flowchart of the algorithm to generate the similarity vector of each recording.
Figure 6: Flowchart of the algorithm to generate the similarity vector of each recording.

Model training

The goal of this phase is to train a random forest model. The input to train the random forest are a series of statistical features extracted from vectors Vi that are created by computing a recognition function (similarity measure) between the computed Ttemplate and submatrices of the spectrogram matrices of a series of recordings.

In the following section, we present the details of the algorithm that processes a recording to create the recognition function vector, and in Fig. 6 we present a flowchart of the process.

Algorithm to Create the Similarity Vector:

  1. Compute matrix SPEC, the submatrix of the spectrogram matrix that contains the frequencies in Ttemplate. Note that we are dealing with recordings that have the same sample rate as the recordings used to compute the Ttemplate.

  2. Define cSPEC, the number of columns of SPEC.

  3. Define ctemplate, the number of columns of Ttemplate. Note that cSPEC ≫ ctemplate since the SPEC matrix have the same number of columns as the whole spectrogram and that the Ttemplate matrix fits c = cSPEC − ctemplate + 1 times inside the SPEC matrix. There are c submatrices of SPEC with the same dimensions as Ttemplate.

  4. Define step, the step factor by which Ttemplate will progressed over the SPEC matrix.

  5. Define n = c S P E C c t e m p l a t e s t e p + 1 . Note that if step = 1 then n = c. In this work, however, this parameter was selected as step = 16 as a trade-off for speed.1

  6. Define SPECi as the submatrix of SPEC that spans the columns from i × step to i × step + ctemplate.

  7. Set i = 1.

  8. While i ≤ n

    1. Compute the similarity measure measi for SPECi (the definition of measi for each of the three variants is provided in the following section).

    2. Increase i by 1. Note that this is equivalent to progressing step columns in the SPEC matrix.

  9. Define the vector V as the vector containing the n similarity measures resulting from the previous steps. That is, V = [meas1meas2meas3, …, measn].

Recognition function

We used three variations of a pattern match procedure to define the similarity measure vector V. First, the Structural Similarity Index described in Wang et al. (2004) and implemented in Van der Walt et al. (2014) as compare_ssim with the default window size of seven unless the generated pattern is smaller. It will be referred in the rest of the manuscript as the SSIM variant. For the SSIM variant we define measi as: m e a s i = S S I T t e m p l a t e , S P E C i , where SPECi is the submatrix of SPEC that spans the columns from i × step to i × step + ctemplate and the same number of rows as Ttemplate and V = [meas1meas2meas3, …, measn] with n = c S P E C c t e m p l a t e s t e p + 1 .

Second, the dynamic thresholding method (threshold_adaptive) described in Van der Walt et al. (2014) with a block size of 127 and an arithmetic mean filter is used over both Ttemplate and SPECi before multiplying them and applying the Frobenius norm and normalized by the norm of a matrix with same dimensions as Ttemplate and all elements equal to one. Therefore, measi for the NORM variant is defined as: m e a s i = F N D T M T t e m p l a t e . D T M S P E C i F N U , where again SPECi is the submatrix of SPEC that spans the columns from i × step to i × step + ctemplate, FN is the Frobenius norm, DTM is the dynamic thresholding method, U is a matrix with same dimensions as Ttemplate with all elements equal to one and .∗ performs an element-wise multiplication of the matrices. Again, V = [meas1meas2meas3, …, measn] with n = c S P E C c t e m p l a t e s t e p + 1 .

Finally, for the CORR variation we first apply the OpenCV’s matchTemplate procedure (Bradski, 2000) with the Normalized Correlation Coefficient option to SPECi, the submatrix of SPEC that spans the columns from i × step to i × step + ctemplate. However, for this variant, SPECi includes two additions rows above and below, thus it is slightly larger than the Ttemplate. With these we can define: m e a s j , i = C O R R T t e m p l a t e , S P E C j , i where SPECj,i is the submatrix of SPECi that starts at row j (note that there are five such SPECj,i matrices).

Now, we select five points at random from all the points above the 98.5 percentile of measj,i and apply the Structural Similarity Index to the 5 strongly-matching regions. The size of these regions is eight thirds (8∕3) of the length of Ttemplate, 4∕3 before and 4∕3 after the strongly-matched point that was selected. Then, define FilterSPEC as the matrix that contains these 5 strongly-matching regions and FilterSPECi as the submatrix of FilterSPEC that spans the columns from i to i + ctemplate then, the similarity measure for this variant is define as: m e a s i = S S I T t e m p l a t e , F i l t e r S P E C i and the resulting vector V = [meas1meas2meas3, …, measn] but this time with n = 5 × 8 3 × c t e m p l a t e + 1 .

It is important to note that no matter which variant is used to calculate the similarity measures, the result will always be a vector of measurements V. The idea is that the statistical properties of these computed recognition functions have enough information to distinguish between a recording that has the target species present and a recording that does not have the target species present. However, notice that since cSPEC, the length of SPEC, is much larger that ctemplate the length of the vector V for the CORR variant is much smaller than the other two.

Random forest model creation

After calculating V for many recordings we can train a random forest model. First, we need a set of validated recordings with the specific species vocalization present in some recordings and absent in others. Then for each recording we compute a vector Vi as described in the previous section and extract the statistical features presented in Table 2. These statistical features represent the dataset used to train the random forest model, which will be used to detect recordings for presence or absence of a species call event. These 12 features along with the species presence information are used as input to a random forest classifier with a 1,000 trees.

Table 2:
The statistical features extracted from vector V.
Features
1. mean
2. median
3. minimum
4. maximum
5. standard deviation
6. maximum–minimum
7. skewness
8. kurtosis
9. hyper-skewness
10. hyper-kurtosis
11. Histogram
12. Cumulative frequency histogram
DOI: 10.7717/peerjcs.113/table-2

Recording detection

Now that we have a trained model to detect a recording, we have to compute the statistical features from the similarity vector V of the selected recording. This is performed in the same way as it was described in the previous section. These features are then used as the input dataset to the previously trained random forest classifier and a label indicating presence or absence of the species in the recording is given as output.

The experiment

In order to decide which of the three variants should be incorporated into the ARBIMON web-based system, we performed the algorithm explained in the previous section with each of the similarity measures. We computed 10-fold validations on each of the variants to obtained measurements of the performance of the algorithm. In each validation, 90% of the data is used as training and 10% of the data is used as validation data. Each algorithm variant used the same 10-fold validation partition for each species. The measures calculated were the area under the receiver operating characteristic (ROC) curve (AUC), accuracy or correct detection rate (Ac), negative predictive value (Npv), precision or positive predictive value (Pr), sensitivity, recall or true positive rate (Se) and specificity or true negative rate (Sp). To calculate the AUC, the ROC curve is created by plotting the false positive rate (which can be calculated as 1 − specificity) against the true positive rate (sensitivity), then, the AUC is created by calculating the area under that curve. Notice that the further the AUC is from 0.5 the better. The rest of the measures are defined as follows: A c = t p + t n t p + t n + f p + f n , N p v = t n t n + f n , P r = t p t p + f p , S e = t p t p + f n and S p = t n t n + f p with tp the number of true positives (number of times both the expert and the algorithm agree that the species is present), tn the number of true negatives (number of times both the expert and the algorithm agree that the species is not present), fp the number of false positives (number of times the algorithm states that the species is present while the expert states is absent) and fn the number of false negatives (number of times the algorithm states that the species is not present while the expert states it is present). Note that accuracy is a weighted average of the sensitivity and the specificity.

Although we present and discuss all measures, we gave accuracy and the AUC more importance because they include information on the true positive and true negative rates. Specifically, AUC is important when the number of positives is different than the number of negatives as is the case with some of the species.

The experiment was performed in a computer with an Intel i7 4790K 4 cores processor at 4.00 GHz with 32 GB of RAM and running Ubuntu Linux. The execution time needed to detect each recording was registered and the mean and standard deviation of the execution times were calculated for each variant of the algorithm. We also computed the quantity of pixels on all the Ttemplate matrices and correlated with the execution time of each of the variants.

A global one-way analysis of variance (ANOVA) was performed on the five calculated measures across all of the 10-fold validations to identify if there was a significant difference between the variants of the algorithm. Then, a post-hoc Tukey HSD comparison test was performed to identify which one of the variants was significantly different at the 95% confidence level. Additionally, an ANOVA was performed locally between the 10-fold validation of each species and on the mean execution time for each species across the algorithm variants to identify if there was any significant execution time difference at the 95% confidence level. Similarly, a post-hoc Tukey HSD comparison test was performed on the execution times.

Results

The six measurements (area under the ROC curve—AUC, accuracy, negative predictive value, precision, sensitivity and specificity) computed to compared the model across the three variants varied greatly among the 21 species. The lowest scores were among bird species while most of the highest scores came from amphibian species. Table 3 presents a summary of the results of the measurements comparing the three variants of the algorithm (for a detail presentation, see Appendix 1). The NORM variant did not have the highest value for any of the measures summarized in Table 3, while the CORR variant had a greater number of species with 80% or greater for all the measures and an overall median accuracy of 81%. We considered these two facts fundamental for a general-purpose species detection system.

Table 3:
Summary of the measures of the three variants of the algorithm.
Best values are in bold.
Summary of measures SSIM NORM CORR
Number of species with an Area under the curve of 80% or greater 8 7 12
Number of species with statistically significant Area under the curve 0 0 0
Mean Area under the curve 0.76 0.71 0.78
Median Area under the curve 0.75 0.72 0.81
Standard Deviation of Area under the curve 0.20 0.21 0.21
Number of species with an Accuracy of 80% or greater 8 7 12
Number of species with statistically significant Accuracy 3 0 3
Mean Accuracy 0.77 0.73 0.77
Median Accuracy 0.76 0.75 0.81
Standard Deviation of Accuracy 0.12 0.14 0.14
Number of species with a Negative predictive value of 80% or greater 7 5 10
Number of species with statistically significant Negative predictive value 0 0 0
Mean Negative predictive value 0.73 0.71 0.74
Median Negative predictive value 0.71 0.75 0.79
Standard Deviation of Negative predictive value 0.08 0.12 0.13
Number of species with a Precision of 80% or greater 5 5 9
Number of species with statistically significant Precision 2 0 2
Mean Precision 0.73 0.68 0.72
Median Precision 0.75 0.73 0.74
Standard Deviation of Precision 0.12 0.13 0.16
Number of species with a Sensitivity of 80% or greater 8 6 11
Number of species with statistically significant Sensitivity 0 0 0
Mean Sensitivity 0.77 0.70 0.74
Median Sensitivity 0.79 0.73 0.80
Standard Deviation of Sensitivity 0.12 0.16 0.17
Number of species with a Specificity of 80% or greater 4 6 7
Number of species with statistically significant Specificity 3 0 0
Mean Specificity 0.69 0.68 0.72
Median Specificity 0.67 0.70 0.75
Standard Deviation of Specificity 0.13 0.15 0.16
Ratio of False positive to True positive 0.37 0.47 0.39
Ratio of False negative to True positive 0.45 0.47 0.39
Ratio of False positive to True negative 0.3 0.43 0.35
Ratio of False negative to True negative 0.37 0.43 0.35
DOI: 10.7717/peerjcs.113/table-3

The local species ANOVA suggested that there are significant accuracy differences at the 95% significance level for six of the 21 species studied as well as four in terms of precision and three in terms of specificity (see https://doi.org/10.6084/m9.figshare.4488149.v1). The algorithm variant CORR had a higher mean and median AUC at 78% and 81% respectively, but the SSIM variant seems to be more stable with a standard deviation of 20%. In terms of accuracy, both the SSIM and CORR have higher mean accuracy than the NORM variant. Nevertheless, variant CORR had the highest median accuracy of 81%, which is slightly higher than the median accuracy of the SSIM variant at 76%. In addition, variant CORR had more species with an accuracy of 80% or greater.

In terms of median precision, the three variants had similar values, although in terms of mean precision variants SSIM and CORR have greater values than the NORM variant. Moreover, the median and mean precision of the SSIM variant were only 1% higher than the median and mean precision of the CORR variant. In terms of sensitivity, variants SSIM and CORR had greater values than the NORM variant. It is only in terms of specificity that the CORR variant has greater values than all other variants. Figures 7 and 8 present a summary of these results with whisker graphs.

Figure 7: Whisker boxes of the 10-fold validations for the three variants of the presented algorithm for: (A) Area under the ROC curve and (B) Accuracy.
Figure 8: Whisker boxes of the 10-fold validations for the three variants of the presented algorithm for: (A) Negative predictive value, (B) Precision, (C) Sensitivity and (D) Specificity.

In terms of execution times, an ANOVA analysis on the mean execution time suggests a difference between the variants (F = 9.9341e + 30, df = 3, p < 2.2e–16). The CORR variant had the lowest mean execution time at 0.255 s followed closely by the NORM variant with 0.271 s, while the SSIM variant had the slowest mean execution time of 2.269 s (Fig. 9). The Tukey HSD test suggests that there was no statistical significant difference between the mean execution times of the NORM and CORR variants (p = 0.999). However, there was a statistical significant difference at the 95% confidence level between the mean execution times of all other pairs of variants, specifically variants SSIM and CORR (p < .2e–16).

Figure 9: (A) Whisker boxes of the execution times of the three algorithms. (B) Execution times as a function of the size of the template in number of pixels.

Moreover, the mean execution time of the SSIM variant increased as the number of pixels in the Ttemplate matrix increases (Fig. 9B). There was no statistically significant relationship between the Ttemplate pixel size and the execution time for the other two variants (Table 4).

Table 4:
Summary of the execution times of the three variants of the algorithm.
Best values are in bold. PPMCC is the Pearson product-moment correlation coefficient.
Summary of execution times SSIM NORM CORR
Mean Execution Time 2.27 0.27 0.26
Standard Deviation of Execution Time 3.04 0.06 0.07
PPMCC between Execution Time and size of template 0.96 0.33 0.11
DOI: 10.7717/peerjcs.113/table-4

In summary, variants SSIM and CORR outperform the NORM variant in most of the statistical measures computed having statistically significant high accuracy for three species each. In terms of execution time, the CORR variant was faster than the SSIM variant (Table 3), and the mean execution time of CORR variant did not increase with increasing Ttemplate size (Table 4).

Discussion

The algorithm used by the ARBIMON system was selected by comparing three variants of a template-based method for the detection of presence or absence of a species vocalization in recordings. The most important features for selecting the algorithm were that it works well for many types of species calls and that it can process hundreds of thousands of recordings in a reasonable amount of time. The CORR algorithm was selected because of its speed and its comparable performance in terms of detection efficiency with the SSIM variant. It achieved AUC and accuracy of 0.80 or better in 12 of the 21 species and sensitivity of 0.80 or more in 11 of the 21 species and the average execution time of 0.26 s per minute of recording means that it can process around 14,000 minutes of recordings per hour.

The difference in execution time between the SSIM variant and the other two was due to a memory management issue in the SSIM algorithm. An analysis revealed that all the algorithms have time complexity of O c S P E C c t e m p l a t e × c t e m p l a t e × r t e m p l a t e where cSPEC and ctemplate are the number of columns in SPEC and Ttemplate respectively and rtemplate is the number of rows in Ttemplate. The only explanation we can give is that the SSIM function uses an uniformly distributed filter (uniform_filter) that has a limit on the size of the memory buffer (4,000 64-bit doubles divided by the number of elements in the dimension been process). Therefore, as the size of Ttemplate increases the number of calls to allocate the buffer, free and allocate again can become a burden since it has a smaller locality of reference even when the machine has enough memory and cache to handle the process. Further investigation is required to confirm this.

An interesting comparison is the method described in the work by Fodor (2013) and adapted and tested by Lasseck (2013). This method was design for the Neural Information Processing Scaled for Bioacoustics (NIPS4B) competition, and although the results are very good they do not report on time of execution. As we have mentioned, it is very important to us to have a method that provides good response times and the execution time of Lasseck’s method seems to be greater than ours given the extensive pre-processing that the method performs.

Conclusions and Future Work

Now that passive autonomous acoustic recorders are readily available the amount of data is growing exponentially. For example, one permanent station recording one minute of every 10 minutes every day of the year generates 52,560 one minute recordings. If this is multiplied by the need to monitor thousands of locations across the planet, one can understand the magnitude of the task at hand.

We have shown how the algorithm used in the ARBIMON II web-based cloud-hosted system was selected. We compared the performance in terms of the ability to detect and the efficiency in terms of time execution of three variants of a template-based detection algorithm. The result was a method that uses the power of a widely use method to determine the similarity between two images (Structural Similarity Index (Wang et al., 2004)), but to accelerate the detection process, the analysis was only done in regions where there was a strong-match determined by the OpenCV’s matchTemplate procedure (Bradski, 2000). The results show that this method performed better both in terms of ability to detect as well as in terms of execution time.

A fast and accurate general-purpose algorithm for detecting presence or absence of a species complements the other tools of the ARBIMON system, such as options for creating playlists based on many different parameters including user-created tags (see Table 5). For example, the system currently has 1,749,551 1-minute recordings uploaded by 453 users and 659 species specific models have been created and run over 3,780,552 min of recordings of which 723,054 are distinct recordings.

Table 5:
Summary of the usage of the ARBIMON2 system and its model creation feature.
Number of users in the system 453
Number of recordings in the system 1,749,551
Number of models created by users 659
Total number of detected recordings 3,780,552
Number of distinct detected recordings 723,054
Average times a recording is detected 5.22
Standard deviation of the number of times a recording is detected 7.78
Maximum number of times a recordings has been detected 58
DOI: 10.7717/peerjcs.113/table-5

While this research was a prove of concept, we provide the tools and encourage users to increase the size of the training data set as this should improve the performance of the algorithm. In addition, we will pursue other approaches, such as multi-label learning (Xie et al., 2016; Zhang et al., 2016; Briggs et al., 2012).

As a society, it is fundamental that we study the effects of climate change and deforestation on the fauna and we have to do it with the best possible tools. We are collecting a lot of data, but until recently there was not an intuitive and user-friendly system that allowed scientists to manage and analyze large number of recordings. Here we presented a web-based cloud-hosted system that provides a simple way to manage large quantities of recordings with a general-purpose method to detect their presence in recordings.

Note that for recordings with a sample rate of 44,100 when we calculate the STFT with a window of size 512 and a 50% overlap, one step is equivalent to 5.8 ms; therefore, 16 steps is less than 100 ms. Although this procedure may miss the strongest match, the length of the calls are much longer than the step interval; therefore, there is a high probability of detecting the species-specific call.
18 Citations   Views   Downloads