Releases: drivendataorg/zamba
v2.2.0
Model releases and new features
- The default
time_distributed
model (African species classification) has been retrained on over 250,000 videos. This 16x increase in training data significantly improves accuracy. This new version replaces the previous one. (PR #226, PR #232) - A new default model option is added:
blank_nonblank
. This model only does blank detection. This binary model can be trained and finetuned in the same way as the species classification models. This model was trained on both African and European data, totaling over 263,000 training videos. (PR #228) - Detect if a user is training in a binary model and preprocess the labels accordingly (PR #215)
Bug fixes and improvements
- Add a validator to ensure that using a model’s default labels is only possible when the species in the provided labels file are a subset of those (PR #229)
- Refactor the logic in
instantiate_model
for clarity (PR #229) - Use pqdm to check for missing files in parallel (PR #224)
- Set
model_name
based on the provided checkpoint so that user-trained models use the appropriate video loader config (PR #221) - Leave
data_dir
as a relative path (PR #219) - Ensure hparams yaml files get included in the source distribution (PR #210)
- Hold back setuptools so mkdocstrings works (PR #207)
- Factor out
get_cached_array_path
(PR #202)
v2.1.0
v2.0.4
v2.0.3
v2.0.2
v2.0.1
v2.0.0
Releases new version v2 of the zamba
package including:
- New and improved models
- Additional species and habitats
- Model finetuning and training
Previous model: Machine learning competition
The algorithms used by zamba
v1 were based on the winning solution from the Pri-matrix Factorization machine learning competition, hosted by DrivenData. Data for the competition was provided by the Chimp&See project and manually labeled by volunteers. The competition had over 300 participants and over 450 submissions throughout the three month challenge. The v1 algorithm was adapted from the winning competition submission, with some aspects changed during development to improve performance.
The core algorithm in zamba
v1 was a stacked ensemble which consisted of a first layer of models that were then combined into a final prediction in a second layer. The first level of the stack consisted of 5 keras
deep learning models, whose individual predictions were combined in the second level of the stack to form the final prediction.
In v2, the stacked ensemble algorithm from v1 is replaced with three more powerful single-model options: time_distributed
, slowfast
, and european
. The new models utilize state-of-the-art image and video classification architectures, and are able to outperform the much more computationally intensive stacked ensemble model.
New geographies and species
zamba
v2 incorporates data from western Europe (Germany). The new data is packaged in the pretrained european
model, which can predict 11 common European species not present in zamba
v1.
zamba
v2 also incorporates new training data from 15 countries in central and west Africa, and adds 12 additional species to the pretrained African models.
Retraining flexibility
Model training is made available zamba
v2, so users can finetune a pretrained model using their own data to improve performance for a specific ecology or set of sites. zamba
v2 also allows users to retrain a model on completely new species labels.