This software is associated with the publication titled "Comparison of Supervised Learning and Changepoint Detection for Insect Detection in Lidar Data" by authors T. C. Vannoy, N. B. Sweeney, J. A. Shaw, and B. M. Whitaker." by authors T. C. Vannoy, N. B. Sweeney, J. A. Shaw, and B. M. Whitaker.
The associated dataset can be found at https://zenodo.org/doi/10.5281/zenodo.10055762.
You can specify the locations of the data and results folders in the beehiveDataSetup.m
script. By default, the scripts uses the following relative path setup, where code
is a folder containing this repository:
βββ code
βββ data
βΒ Β βββ combined
βΒ Β βββ preprocessed
βΒ Β βββ raw
βΒ Β βΒ Β βββ 2022-06-23
βΒ Β βΒ Β βββ 2022-06-24
βΒ Β βΒ Β βββ 2022-07-28
βΒ Β βΒ Β βββ 2022-07-29
βΒ Β βββ testing
βΒ Β βββ training
βΒ Β βββ validation
βββ results
βββ changepoint-results
βΒ Β βββ runtimes
βββ testing
βββ training
βββ classifiers
βββ data-sampling
βββ default-params
βββ hyperparameter-tuning
In the above setup, the dataset goes into the raw
folder. The dataset can be downloaded from the Zenodo archive.
Important
In general, you need to call pathSetup.m
first before running anything, as that script adds all the folders in this repo to your MATLAB path. Additionally, if you use the default relative data path setup described above, you must run all of your code from the root of this repository, not the subfolders; if you specify full paths in beehiveDataSetup.m
, then you can run the code from anywhere.
Tip
This code is designed to run on a computing cluster. If you have access to a computing cluster that uses slurm, you can update and use the scripts in the slurm
folder. The code will still run perfectly fine on a normal desktop computerβit will just take longer.
The folder icons (π) after the headings link to the relevant folder in the repository.
There are three main portions of code, listed below. You have to run the data preparation first, but the supervised learning and changepoint detection sections are independent. Use the following links to jump to the sections.
Data preparation π
- (optional) Convert the csv label files into .mat files using
convertAllLabels.m
; this has already been done in the archived dataset. - Combine the individual raw data files into larger groups that can then be split into training and testing sets; this is done with
combineDataForTrainingTesting.m
- Preprocess the data using
preprocess.m
- Split the preprocessed data into the training, validation, and testing sets.
spiltData.m
Using slurm
If you have access to a slurm cluster, these steps can be done by running prepare-data.sh
.
Supervised learning π
Feature extraction π
Before training any of the feature-based algorithms, we need to precompute the features:
- training data:
precomputeTrainingFeatures.m
- validation data:
precomputeValidationFeatures.m
- testing data:
precomputeTestingFeatures.m
Using slurm
If you have access to a slurm cluster, these steps can be done by running precompute-features.sh
.
Training π
Using slurm
If you have access to a slurm cluster, all the training and testing can be launched using run-row-methods.sh
and run-image-methods.sh
.
For the row-based methods, we first need to create the grid search parameters using createDataSamplingGrid.m
. Once that is done, we can perform the grid search.
For the feature-based methods, call the evalSamplingGridRowFeatureMethod
function with the grid search index, e.g.
evalSamplingGridRowFeatureMethod(@AdaBoost,1,UseParallel=true,UseGPU=true)
For the deep learning methods, call the evalSamplingGridRowDataMethod
function with the grid search index, e.g.
evalSamplingGridRowDataMethod(@CNN1d,1,UseParallel=true,UseGPU=true)
This grid search was designed to run in parallel on a computing cluster, specifically using slurm job arrays. See the samplingGridSearch*.slurm
scripts for full details of the function calls for each of the classifiers. In particular, for the neural networks that had more than one hidden layer, we have to pass in the parameters (e.g., layer sizes) into the evalSamplingGrid*
functions.
If you don't have access to a computing cluster, you run the grid search methods in a for loop:
for gridIdx = 1:16
evalSamplingGridRowFeatureMethod(@AdaBoost,1,UseParallel=true,UseGPU=true)
end
You could also use a parallel for loop, which may or may not be faster than running each iteration with parallel feature extraction and training (UseParallel=true
):
parfor gridIdx = 1:16
evalSamplingGridRowFeatureMethod(@AdaBoost,1,UseParallel=false,UseGPU=true)
end
Once the grid search for an algorithm is done, run the selectBestSamplingParams
function to save the sampling parameters that resulted in the best MCC value, e.g.:
selectBestSamplingParams("AdaBoost")
Train default 2D CNNs (image methods only) π
For the image-based methods (2D CNNs), we need to train networks with the default hyperparameters. This is because the default hyperparameters might perform better than the parameters found during tuning, and thus we would prefer to use the default parameters for the final training.
The default 2D CNNS can be trained with the trainCNN2dManualParams
function. See the trainDefaultCNN2d*.slurm scripts to see the relevant function call for each 2D CNN.
For example, here's the code used to train the default 3-layer 2D CNN:
p.FilterSize=[16,2;,16,2;16,2];
p.Nfilters=[20,20,20];
trainCNN2dManualParams(@CNN2d,UseGPU=true,ClassifierParams=p)
Model hyperparameter tuning π
First, we need to create mat files that contain the model's hyperparameter search values. Each model has a separate function to create it's associated hyperparameter search values, except AdaBoost and RUSBoost, which use the same search values.
Examples:
# For AdaBoost and RUSBoost
createBoostTreesHyperparamSearchRange
createCNN2d1LayerHyperparamSearchRange
See hyperparameter-tuning for the functions that create the hyperparameter search values.
There are three different hyperparameter tuning functions, one for each of the algorithm types:
- feature engineering methods:
tuneHyperparamsRowFeatureMethod
- 1D CNNs:
tuneHyperparamsRowDataMethod
- 2D CNNs:
tuneHyperparamsImageMethod
Examples:
tuneHyperparamsRowFeatureMethod("StatsNeuralNetwork1Layer",@StatsNeuralNetwork,UseParallel=true);
tuneHyperparamsRowDataMethod("CNN1d1Layer",@CNN1d,UseGPU=true,UseParallel=true);
tuneHyperparamsImageMethod("CNN2d3Layer",@CNN2d,UseGPU=true);
See the tuneHyperparams*.slurm scripts in the slurm
folder to see the function calls for each method.
Final training π
After hyperparameter tuning is done, the algorithms need to be trained one final time on the entire training/validation set.
Similar to the hyperparameter tuning, there are three different training functions, one for each of the algorithm types:
- feature engineering methods:
trainRowFeatureMethod
- 1D CNNs:
trainRowDataMethod
- 2D CNNs:
trainImageMethod
Each of the methods take the classifier name as a string.
Examples:
trainRowFeatureMethod("AdaBoost");
trainRowDataMethod("CNN1d5Layer");
trainImageMethod("CNN2d3Layer");
Testing π
Using slurm
Again, if you have access to a slurm cluster, all the training and testing code can be launched using run-row-methods.sh
and run-image-methods.sh
.
Similar to the hyperparameter tuning, there are three different testing functions, one for each of the algorithm types:
- feature engineering methods:
testRowFeatureMethod
- 1D CNNs:
testRowDataMethod
- 2D CNNs:
testImageMethod
Each of the methods take the classifier name as a string.
Examples:
testRowFeatureMethod("AdaBoost");
testRowDataMethod("CNN1d5Layer");
testImageMethod("CNN2d3Layer");
See the train*.slurm scripts in the slurm
folder to see the function calls for each method.
Changepoint detection π
There are two different changepoint detection methods (gfpop and MATLAB's findchangepts
); for each method, there are three different procedures: analyzing the rows, analyzing the columns, or analyzing both the rows and columns.
Using slurm
If you have access to a slurm cluster, you can run all the changepoint algorithms with run-changepoint-methods.sh
. The gfpop
mex wrapper still needs to be compiled before launching the slurm jobs.
findchangepts
requires MATLAB's Signal Processing Toolbox. To run the algorithms, the data must be prepared already.
The row, column, and "both" algorithms are run with the following scripts:
- rows:
matlabChptsRows
- columns:
matlabChptsCols
- both:
matlabChptsBoth
gfpop π
Before running the gfpop
algorithm, you must compile the mex file, gfpop_mex.cpp
. This can be done by going to the changepoint-detection/gfpop
folder and running mex
:
cd changepoint-detection/gfpop
mex gfpop_mex.cpp
Once the mex file is compiled, you can run the row, column, and "both" algorithms:
- rows:
gfpopRows
- columns:
gfpopCols
- both:
gfpopBoth
Once all the scripts have been run, the results can be analyzed and collected by running changepointAnalysis.m
.
Figures π
For information on recreating the figures, please see the figures folder.
You can cite this code as follows:
@software{trevor_vannoy_2023_10055810,
author = {Trevor C. Vannoy and
Nathaniel B. Sweeney and
Bradley M. Whitaker},
title = {{BMW-lab-MSU/insect-detection-remote-sensing-mdpi
}},
month = oct,
year = 2023,
publisher = {Zenodo},
doi = {10.5281/zenodo.10055809},
url = {https://zenodo.org/doi/10.5281/zenodo.10055809}
}
All code in this repository, except the gfpop
code, is licensed under the BSD 3-Clause License. gfpop
is licensed under the MIT License.