Citizen science has become a powerful force for scientific inquiry, providing researchers with access to a vast array of data points while connecting non scientists to the real process of science. This citizen-researcher relationship creates a very interesting synergy, allowing for the creation, execution, and analysis of research projects. With this in mind, a Convolutional Neural Network has been trained to identify conus marine snails at species level  in collaboration with the Natural Science Museum of Madrid. The taxonomy of these snails has changed significantly several times during recent years and the introduction of Deep Learning techniques allowing to classify them is a very valuable tool for the experts.
This Docker container contains a trained Convolutional Neural network optimized for conus snails identification using images. The architecture used is an Xception  network using Keras on top of Tensorflow.
The training dataset has been provided by the Natural Science Museum of Madrid and it consists on a dataset containing images of 68 species of conus covering three different regions: the Panamic region; the South African region; and the Western atlantic and mediterranean region.
This service is based in the Image Classification with Tensorflow model.
: Puillandre, N.; Duda, T.F.; Meyer, C.; Olivera, B.M.; Bouchet, P. (2014). One, four or 100 genera? A new classification of the cone snails. Journal of Molluscan Studies. 81 (1): 1–23. doi:10.1093/mollus/eyu055. PMC 4541476. PMID 26300576.
: Chollet, François. Xception: Deep learning with depthwise separable convolutions arXiv preprint (2017): 1610-02357.
Run locally on your computer
You can run this module directly on your computer, assuming that you have Docker installed, by following these steps:
$ docker pull deephdc/deep-oc-conus-classification-tf $ docker run -ti -p 5000:5000 deephdc/deep-oc-conus-classification-tf
If you do not have Docker available or you do not want to install it, you can use udocker within a Python virtualenv:
$ virtualenv udocker $ source udocker/bin/activate $ git clone https://github.com/indigo-dc/udocker $ cd udocker $ pip install . $ udocker pull deephdc/deep-oc-conus-classification-tf $ udocker create deephdc/deep-oc-conus-classification-tf $ udocker run -p 5000:5000 deephdc/deep-oc-conus-classification-tf
Once running, point your browser to
and you will see the API documentation, where you can test the module
functionality, as well as perform other actions (such as training).
For more information, refer to the user documentation.