Next Article in Journal
Implication between Geophysical Events and the Variation of Seasonal Signal Determined in GNSS Position Time Series
Next Article in Special Issue
Oil Spill Identification from SAR Images for Low Power Embedded Systems Using CNN
Previous Article in Journal
Axle Configuration and Weight Sensing for Moving Vehicles on Bridges Based on the Clustering and Gradient Method
Previous Article in Special Issue
An FPGA-Based Hardware Accelerator for CNNs Inference on Board Satellites: Benchmarking with Myriad 2-Based Solution for the CloudScout Case Study
 
 
Font Type:
Arial Georgia Verdana
Font Size:
Aa Aa Aa
Line Spacing:
Column Width:
Background:
Technical Note

On-Board Volcanic Eruption Detection through CNNs and Satellite Multispectral Imagery

by
Maria Pia Del Rosso
1,*,†,
Alessandro Sebastianelli
1,†,
Dario Spiller
2,†,
Pierre Philippe Mathieu
2,† and
Silvia Liberata Ullo
1,†
1
Engineering Department, University of Sannio, 82100 Benevento, Italy
2
Φ-Lab, ASI-ESA, 00044 Frascati, Italy
*
Author to whom correspondence should be addressed.
These authors contributed equally to this work.
Remote Sens. 2021, 13(17), 3479; https://doi.org/10.3390/rs13173479
Submission received: 23 July 2021 / Revised: 27 August 2021 / Accepted: 30 August 2021 / Published: 2 September 2021

Abstract

:
In recent years, the growth of Machine Learning (ML) algorithms has raised the number of studies including their applicability in a variety of different scenarios. Among all, one of the hardest ones is the aerospace, due to its peculiar physical requirements. In this context, a feasibility study, with a prototype of an on board Artificial Intelligence (AI) model, and realistic testing equipment and scenario are presented in this work. As a case study, the detection of volcanic eruptions has been investigated with the objective to swiftly produce alerts and allow immediate interventions. Two Convolutional Neural Networks (CNNs) have been designed and realized from scratch, showing how to efficiently implement them for identifying the eruptions and at the same time adapting their complexity in order to fit on board requirements. The CNNs are then tested with experimental hardware, by means of a drone with a paylod composed of a generic processing unit (Raspberry PI), an AI processing unit (Movidius stick) and a camera. The hardware employed to build the prototype is low-cost, easy to found and to use. Moreover, the dataset has been published on GitHub, made available to everyone. The results are promising and encouraging toward the employment of the proposed system in future missions, given that ESA has already moved the first steps of AI on board with the Phisat-1 satellite, launched on September 2020.

Graphical Abstract

1. Introduction

Nowadays, Remote Sensing (RS) is seeing its maximum expanse in terms of applicability and use cases, because of the extremely large availability of remote-sensed images, mostly satellite-based, allowing many scientists from different research fields to approach RS applications [1,2,3]. Among all the possible fields of RS, this manuscript focuses on the object/event detection in satellite imagery with the final goal to implement related AI-based algorithms on board the satellites.
In recent years, the peculiar field of object/event detection in RS has been largely explored with several works employing Synthetic Aperture Radar (SAR) data, for instance for ship detection [4,5,6,7,8,9], and other works using optical data for landslide detection [10,11] or cloud detection [12], just to cite a few. A notable example is the increasing use of this type of data in Earth science and geological fields for monitoring parameters which by their nature are or may become difficult to measure, or that need a lot of time and efforts to be recorded with classical instruments [13].
Although most of the data processing is usually carried out on ground, there have been in the last years some attempts on bringing the computation effort, or at least a part of it, on board the satellites [14]. The ultimate frontier of satellite RS is right represented by the implementation of AI algorithms on board the satellites for scene classification, cloud masking, and hazard detection, which has seen the European Space Agency (ESA) as a pioneer in moving the first steps with the Phisat-1 satellite, launched on September the 3rd 2020 [15,16]. With this mission, it has been shown how AI models can help recognizing too cloudy images thus avoiding to download them toward the Ground Stations and therefore reducing the data transmission load [12]. Another example of AI on board system has been presented in [17], where authors proposed an on board real-time ship detector using SAR data and based on Deep Learning.
Unlike the previous work, the aim of our study has been to investigate the possibility of using optical/multispectral satellite images to monitor hazardous events, specifically volcanic eruption, by means of AI techniques and on board computing resources [18]. The results achieved for the classification of volcanic eruptions could be suitable for future satellite missions such as the next ones from the ESA Phisat program.
It is worth to highlight that, to the best of the authors’ knowledge, there are no similar algorithms in the literature for volcanic eruption detection, also making use of free optical/multispectral images. Indeed, many researchers have made use of satellite images, and SAR data in particular, to monitor ground movements in proximity of a volcano’s crater just before the eruption, which appears interesting but it is something completely different from our approach. An example of AI techniques used to recognize volcano-seismic events is given in [19], where the authors are using two Deep Neural Networks and volcano-seismic data, together with a combined feature vector of linear prediction coefficients and statistical properties, for the classification of seismic events. Other similar approaches can be found in [20,21,22], where respectively real and simulated Interferometric SAR (InSAR) data have been used for detecting volcano surface deformation. Another very interesting work shows how AI plays a key role in monitoring a variety of volcanic processes when multiple sensors are exploited (Sentinel-1 SAR, Sentinel-2 Short-Wave InfraRed (SWIR), Sentinel-5P TROPOMI, with and without the presence of S O 2 gas emission) [23].
In our manuscript, we propose two different CNNs for the detection of volcanic eruptions by using satellite optical/multispectral images, and the main objective is the leveraging of an on board CNN, that is not considered in the current state-of-the-art.
It is worth to underline that the chosen use case, the volcanic eruption detection, should be considered independent from the on board analysis. Indeed, a similar study for AI on board may be conducted on a different use case. Moreover it is noteworthy to highlight that volcanic ejecta including Sulfur oxides can be detected with SWIR radiometer and so among possible future developments there can be also the exploration of SWIR radiometer data at this end [23,24,25,26].
In our work Sentinel-2 and Landsat-7 optical data have been considered, and the main contributions are the following:
  • The on board detection of volcanic eruptions by CNN approaches has never been taken into consideration so far, to the best of the authors’ knowledge.
  • The proposed CNN is discussed with regard to the constraints imposed by the on board implementation, which means that the starting network has been optimized and modified in order to be consistent with the target hardware architectures.
  • The performances of the CNN deployed on the target hardware are analyzed and discussed after the execution of experimental tests.
The paper is organized as follows: Section 2 deals with the description of the volcanic eruptions dataset, while Section 3 presents the CNN models explored in this study. In Section 4 the on board implementation of the proposed detection approach is analyzed. Results and discussion are presented in Section 5. Conclusions are given at the end.

2. Dataset

The chosen use case, as above underlined, focuses on volcanic eruptions by using remote sensing data, hence the first necessary step consists in building the suitable dataset.
Since no ready-to-use data were found to perfectly fit the specific task of this work, a specific dataset was built by using an online catalog of volcanic events including geolocalization information [27]. Satellite images acquired for the place and the date of interest were collected and labeled using the open-access Python tool presented in [28].

2.1. The Volcanic Eruptions Catalog

The dataset has been created by selecting the most recent volcanic eruptions reported in the Volcanoes of the World (VOTW) catalog by the Global Volcanism Program of the Smithsonian Institution. This is a catalog of Holocene and Pleistocene volcanoes and eruptions from the past 10,000 years [27] up to today. An example of information available in the catalog is reported in Table 1. For the purpose of the dataset creation, the only useful information is the starting date of the eruption, the geographic coordinates and the volcano name. Therefore, this information has been extracted and stored apart.
The images used to create the dataset were collected by using the Landsat-7 and Sentinel-2 products, accessed through Google Earth Engine(GEE) [29]. Specifically, Landsat-7 images have been downloaded considering the period 1999–2015, whereas Sentinel-2 images are related to the period 2015–2019.
For the Sentinel-2 data, the level 1-C was selected, comprising 13 spectral bands representing TOA (Top Of Atmosphere) reflectance scaled by 10,000 and 3 QA bands, including a bitmask band with cloud mask information. The only product of Landsat-7 available in the GEE Catalog is instead level 2.
It is worth to underline that, even though the authors have limited this research to Landsat-7 and Sentinel-2, as they cover the entire period of interest, the same approach can be extended to other remote sensing optical products presenting the same bands required for this study, e.g., blue, green, red, and the two SWIR (short-wave infrared) bands located approximately at 1650 nm and 2200 nm. The SWIR bands have been considered in order to better locate and inspect the volcanic eruptions. Indeed, volcanic eruptions can be easily located in RGB wavelengths when they are captured by the satellite camera during the eruptive event, which however is not always the case. After the eruption, the initially red lava gets darker and darker, even though its temperature remains very high. In order to highlight high temperature soil, infrared bands have to be included. The extension to SWIR radiometer data for the volcanic eruption detection will be also examined in order to improve the dataset since the presence of S O 2 (included in volcanic ejecta) can be in this way identified at an early-stage.
It is worthy to highlight that there are some differences between the Sentinel-2 and Landsat-7 products, both in terms of spatial resolution and bandwidths, as shown in Table 2 and Table 3. These differences will be addressed in the next sections.

2.2. Data Preparation and Manipulation

Satellite data have been downloaded with the above cited tool [28] that allows to automatically create small patches of images. For this work, the obtained patches cover an overall area of 7.5 km2.
After downloading the data, some pre-processing procedures have been applied. Firstly, the images have been resized to 512 × 512 pixels using the Bicubic Interpolation method of Python OpenCV. This procedure mitigates the difference of spatial resolution between Sentinel-2 and Landsat-7. Secondly, infrared bands are combined with RGB bands, in order to visually highlight the color of the volcanic lava, regardless of its color (which is typically red during the eruption and darker a few hours later). Finally, in the experimental phase the proposed algorithm has been adapted and deployed on a Raspberry PI board with a PI camera [30]. Since the PI camera only acquires RGB data, the bands’ combination has become necessary to simulate RGB-like images. The bands’ combination for highlighting IR spectral answers is given by the equations [31]:
RED = α 1 · B 4 + max ( 0 , SWIR 2 0.1 )
GREEN = α 2 · B 3 + max ( 0 , SWIR 1 0.1 )
BLUE = α 3 · B 2
Namely, red and green bands are mixed with SWIR1 and SWIR2 bands, in order to enhance the pixels with high temperature. The multiplicative factor α x is used to adjust the scale of the image and it is set to 2.5. In practice, the infrared bands change the red and green bands, so that the heat information is highlighted and visible to the human eye. In this way, it was possible to create a quantitatively correct dataset since, during the labeling, the eruptions were easily distinguishable from non-eruptions. In Figure 1 the difference between a simple RGB image and the one highlighting IR is shown.

2.3. Dataset Expansion

Since the task addressed in this paper is a typical binary classification problem, images have been downloaded in order to fill both the eruption and the no-eruption classes. To have a high variability and to reach better results the no-eruption images have been downloaded by focusing on five sub-classes: (1) non-erupting volcanoes, (2) cities, (3) mountains, (4) cloudy images and (5) completely random images. The presence of cloudy images is really important, in order to make the CNN learn to distinguish between eruption smoke and clouds. An example of comparison is shown in Figure 2.
The same pre-processing step has been applied to the new data, since in the deep learning context a homogeneous dataset is preferable for reducing the sensitivity of the model to variations in the distribution of the input data [32,33]. The final dataset contains 260 images for the class eruption and 1500 for the class non-eruption. Due to the type of event analyzed, the dataset appears to be unbalanced, as an acquisition with an eruption is a rare event. The problem of the imbalanced dataset is addressed in the next sections.
In Figure 3 some images from the downloaded and pre-processed dataset are shown. Moreover, it is worth to highlight that the final dataset has been made freely available on GitHub [34].

3. Proposed Model

The detection task has been addressed by implementing a binary classifier where the first class is assigned to images with eruptions and the second one addresses all the other scenarios. The overall CNN architecture is shown in Figure 4. The proposed CNN can be divided in two sub-networks: the first convolutional network is responsible for the features extraction and the second fully connected network is responsible for the classification task [32,33,35]. The architecture used to build from scratch the proposed model can be derived from classical models frequently used by the Computer Vision (CV) community, for example the AlexNet/VggF [36] or the LeNet-5 [37]. The main differences with the these architectures are in the number of convolutional and dense layers and in the use of a Global Average Pooling layer instead of a classical flatten layer.
The first sub-network consists of seven convolutional layers, each one followed by a batch normalization layer, a ReLU activation function and a max pooling layer. Each convolutional layer has a stride value equal to (1,1) and an increasing number of filters, from 16 to 512. Each max pooling layer (with size (2,2) for both kernel and stride) halves the feature map dimension. The second sub-network consists of five fully-connected layers, where each layer is followed by a ReLU activation function and a dropout layer. In this case the number of elements of each layer decreases. In the proposed architecture the two sub-networks are connected with a global average pooling layer that, compared to a flatten layer, drastically reduces the number of trainable parameters, speeding up the training process.

3.1. Image Loader and Data Balancing

Given the nature of the analyzed hazard, the dataset results unbalanced. An unbalanced dataset, with a number of examples of one class much greater than the other, will lead the model to recognize only the dominant class. To solve this issue, an external function called Image Loader from the Phi-Lab ai4eo.preprocessing library has been used [38].
This library allows the user to define a much more efficient image loader than the already existing Keras version. Furthermore, it is possible to implement a data augmentator that allows the user to define further transformations. The most powerful feature of this library is the one related to the balancing of the dataset through the oversampling technique. In particular, each class is weighted independently using a value based on the number of the class samples. The oversampling mechanism acts on the minority class, in this case the eruption class, by applying the data augmentation. This latter generates new images by applying transformations of starting images (e.g., rotations, crops, etc.) until the minority class reaches a number of samples equals to the majority class. This well known strategy [39], increases the computational cost for the training but helps the classifier, during the learning phase, not to strengthen on a specific class, since after this procedure it will have an equal number of data available for each class.

3.2. Training

During the training phase, for each epoch the error between the real output and the prediction is calculated both on the training and on the validation datasets. The metric used for the error has been the accuracy and it is worth to underline that this metric works precisely only if there is an equal number of samples belonging to both classes. The model has been trained for 100 epochs, using the Adam optimizer and the binary cross-entropy as loss function.
The training dataset is composed of 1215 examples, among which 334 are with eruptions and 818 are without eruptions. The validation dataset contains 75 eruption samples and 94 no eruption images. Both datasets have been subjected to the data augmentation and to the addition of white Gaussian noise to each channel to increase the robustness of the model and to solve the spectral diversity between Sentinel-2 and Landsat-7.
The model was trained on the Google Colaboratory platform, where each user can count on: (1) a GPU Tesla K80, having 2496 CUDA cores, compute 3.7, 12G GDDR5 VRAM, (2) a CPU single core hyper threaded i.e., (1 core, 2 threads) Xeon Processors @2.3 Ghz (No Turbo Boost), (3) 45MB Cache, (4) 12.6 GB of available RAM and (5) 320 GB of available disk. With such an architecture, each training epoch required about 370 s. The trends of the accuracy on training and validation dataset are shown in Figure 5.

3.3. Model Pruning

Since the final goal is to realize a model to be uploaded on an on-board system, its optimization is necessary in terms of network complexity, number of parameters and inference execution time. The choice of using a small chip led to limitations of executing the specific classification model, due to the chip’s limited elaboration power, thus it was necessary to derive a proper model. Model pruning was driven by the goal of minimizing inference time, because its value represents a strict requirement for our experimental setup. An alternative interesting procedure for model pruning and optimization has been proposed by [40], where authors developed a <1-MB Lightweight CNN detector. Yet, in this manuscript, the work proposed by [12] has been used as a reference paradigm for the on board AI system, since more suitable.
Hence, starting from the first feasible network, a second and smaller network was built by pruning the former one, as shown in Figure 6. The convolutional sub-network has been reduced by removing three layers and the fully connected sub-network has been drastically reduced to only two layers. The choice on the number of layers to remove has been a trade off between the number of network parameters and its capability of extracting useful features. For this reason, the choice relapsed on discarding the last two convolutional layers and the very first one. This choice led to quite good results, revealing a good compromise between memory weight, computational load and performances. The new modified network has shown to be still capable of discriminating or classifying data correctly, with an accuracy of 0.83%.
The smaller model has been trained with the same configuration of the original one. The trends of the training and the validation loss and accuracy functions are shown in Figure 7.

4. Going on Board, a First Prototype

In order to evaluate the proposed methodology, a prototype for running the experimental analysis has been realized. Firstly, the model has been adapted to work with the selected hardware and to carry out the on board volcanic eruption detection. The hardware is composed of a drone, used a RS platform, of a Raspberry PI used as main on board computer, a PI camera used as acquiring sensor and a Movidius stick used as Deep Learning accelerator [41,42,43]. The experimental setup is shown in Figure 8. The description of the architecture of the drone system is out of the scope of this work since the drone has only been used for simulation purposes, thus its subsystems are not included in the schematic.
The peculiarity of the proposed system, apart from the drone, is the availability of the low-cost user-friendly components used to realize it. Moreover the components are almost ready to use and are easy to install. These aspects allow the proposed system to be easily replicable, allowing interested researchers to repeat the experiments proposed in this manuscript.
The functiong pipeline is handled by the Raspberry PI, with the Raspbian Operating System (OS), that is the on board computer. This board will process the images acquired through the PI camera and send them to the Movidius Stick in order to run the classification algorithm, based on the selected CNN model.
In the next subsections, all the components used for the experimental setup are briefly described, to give the reader some useful information about their main characteristics.

4.1. Raspberry PI

The Raspberry adopted for this use case is the Raspberry Pi 3 Model B, the earliest model of the third-generation Raspberry Pi. Table 4 shows its main specifications.

4.2. Camera

The Raspberry Pi Camera Module v2, is a high quality 8-megapixel Sony IMX219 image sensor custom designed add-on board for Raspberry Pi, featuring a fixed focus lens. It is capable of 3280 × 2464 pixel static images, and supports 1080p30, 720p60 and 640 × 480p90 video. The camera can be plugged using the dedicated socket and CSi interface. The main specifications for PI camera are listed in Table 5.

4.3. Movidius Stick

The Intel Movidius Neural Compute Stick is a small fanless deep learning USB drive designed to learn AI programming. The stick is powered by the low power high performance Movidius Visual Processing Unit. It contains an Intel Movidius Myriad 2 Vision Processing Unit 4GB. The main specifications are:
  • Supporting CNN profiling, prototyping and tuning workflow
  • Real-time on device inference (Cloud connectivity not required)
  • Features the Movidius Vision Processing Unit with energy-efficient CNN processing
  • All data and power provided over a single USB type A port
  • Run multiple devices on the same platform to scale performance

4.4. Implementation on Raspberry and Movidius Stick

This subsection summarizes the pipeline for running experiments and for implementing the software components on the hardware setup.
In order to run the experiments with the Raspeberry PI and the Movidius Stick, two preliminary steps are necessary: (1) the CNN must be converted from the original format (e.g., Keras model) to an OpenVino format, using the OpenVino library; (2) an appropriate operating system must be install on the Raspberry (e.g., the Rasbian OS through the NOOBS installer). The implementation process is schematized in Figure 9.

OpenVINO Library

For deep learning, the current Raspberry PI hardware is inherently resource constrained. The Movidius Stick allows faster inference with the deep learning coprocessor that is plugged into the USB socket. In order to transfer the CNN on the Movidius, the network should be optimized, using the OpenVINO Intel library for hardware optimized computer vision.
The OpenVINO toolkit is an Intel Distribution and is extremely simple to use. Indeed, after setting the target processor, the OpenVINO-optimized OpenCV can handle the overal setup [44]. Based on CNN, the toolkit extends workloads across Intel hardware (including accelerators) and maximizes performance by:
  • enabling deep learning inference at the edge
  • supporting heterogeneous execution across computer vision accelerators (e.g., CPU, GPU, Intel Movidius Neural Compute Stick, and FPGA) using a common API
  • speeding up time to market via a library of functions and pre-optimized kernels
  • including optimized calls for OpenCV.
After implementation on Raspberry and Movidius, the models were tested by acquiring images using a drone flying over a print made with Sentinel-2 data of an erupting volcano, as shown in Figure 10. The printed image has been processed with the same settings used for the training and validation dataset.

5. Results and Discussion

5.1. Training on the PC

The models’ performances have been computed on the testing dataset. The big extended model reached an accuracy of 85%, while the smaller and lighter model reached an accuracy of 83%.
In Figure 11, as an example, a subset of the testing dataset is shown, while in Table 6 the corresponding ground truth and prediction labels are reported. A low value for a predicted label indicates a low probability of eruption, so the image is classified as no eruption; a high value for a predicted label indicates a high probability of eruption, so the image is classified as eruption; a value next to 0.5 indicates an inconclusive prediction. Since the problem is a binary classification, a threshold value of 0.5 was selected to identify the class based on the prediction: a value lower that 0.5 was rounded to 0 (non-eruption class), while a value higher than the 0.5 was rounded to 1 (eruption class).
The performances have been computed also for the second model, the one obtained after the pruning process. The same samples shown in Figure 11 have been used to make the comparison with the original model. Table 7 shows the results.
The training of the two proposed CNNs has been made with the same machine and for 100 epochs each. As stated before, the platform used for the training is Google Colaboratory that presents a GPU xTesla K80, having 2496 CUDA cores, compute 3.7, a 12 Gb (11.439 Usable) GDDR5 VRAM, a CPU 1xsingle core hyper threaded i.e., (1 core 2 threads) Xeon Processor 2.3 Ghz (No Turbo Boost), 45 Mb of Cache, 12.6 Gb of RAM and 320 Gb of available disk. Details about models size and training time can be found in Table 8, while details about models scores and inference time can be found in Table 9.

5.2. Results on the Movidius

The confusion matrix, the classifications scores and the architecture computational speed, for the two models, are reported in Table 9, where is evident that the performances in terms of good prediction are slightly changed after the model pruning, but the most important aspect is that the images per second that the model and the hardware can handle is increased from 1 to 7.
The values of accuracy, precision, recall and F1 score reported in Table 9 are defined as follows,
Accuracy = T P + T N T P + F P + F N + T N , Precision = T P T P + F P Recall = T P T P + F N , F 1 Score = 2 Recall Precision Recall + Precision
where T P , T N , F P , F N are the number of True Positive cases, True Negative cases, False Positive cases, and False Negative cases, respectively.
The results shown in Table 9 are fundamental, since good performances are maintained and the small model can allow to respect the constraints imposed by the dynamics and mission of the drone used in the experimental phase. It is worth to underline that, although the Raspberry system has to carry out several operations: image acquisition, image pre-processing, communication with the movidius stick, inference, wireless communication with the on ground station, and so on, despite the limited amount of processing power, the overall inference time has been reduced by a factor of 7.
This result is perfectly transferable to the satellite domain, obviously considering the constraints imposed by these platforms. The results are promising, demonstrating the correctness of the proposed pipeline and justifying further analysis and investigation.

6. Conclusions

This work aimed to present a first workflow on how to develop and implement an AI model to be suitable for being carried on board satellites for Earth Observation. In particular, two detectors of volcanic eruptions have been developed and discussed.
AI on board is a very challenging field of research which has seen the ESA as a pioneer in moving the first steps with the Phisat-1 satellite launched on September the 3rd 2020. The possibility to process data on board a satellite can drastically reduce the time between the image acquisition and its analysis, completely deleting the time for downlinking and reducing the total latency. In this way, it is possible to produce fast alerts and interventions when hazardous events are going to happen.
A prototype and a simulation process, keeping a low-cost kind of implementation, were realized. The experiment and the development chain were completed with commercial and ready-to-use hardware components, and a drone was also employed for simulations and testing. The AI processor had no problem in recognizing the eruption in the printed image used for testing. The results are encouraging, showing that even the pruned model can reach a good performance in detecting the eruptions. Further studies will help to understand possible extensions and improvements.

Author Contributions

Conceptualization, M.P.D.R., A.S., D.S., P.P.M. and S.L.U.; Data curation, M.P.D.R., A.S., D.S., P.P.M. and S.L.U.; Formal analysis, M.P.D.R., A.S., D.S., P.P.M. and S.L.U.; Investigation, M.P.D.R., A.S., D.S., P.P.M. and S.L.U.; Methodology, M.P.D.R., A.S., D.S., P.P.M. and S.L.U.; Project administration, S.L.U.; Software, M.P.D.R., A.S., D.S. and P.P.M.; Supervision, P.P.M. and S.L.U.; Validation, M.P.D.R., A.S., D.S. and P.P.M.; Visualization, S.L.U.; Writing—original draft, M.P.D.R., A.S., D.S. and S.L.U.; Writing—review and editing, M.P.D.R., A.S., D.S., P.P.M. and S.L.U. All authors have read and agreed to the published version of the manuscript.

Funding

This research received no external funding.

Institutional Review Board Statement

Not applicable.

Informed Consent Statement

Not applicable.

Data Availability Statement

The dataset realised and used for this study can be found in open access at https://github.com/Sebbyraft/OnBoardVolcanicEruptionDetection (accessed on 29 August 2021).

Acknowledgments

The research work published in this manuscript has been developed in collaboration with the European Space Agency (ESA) Φ -lab [45] during the traineeship of Maria Pia Del Rosso and Alessandro Sebastianelli started in 2019. This research is also supported by the ongoing Open Space Innovation Platform (OSIP) project started in June 2020 and titled “Al powered cross-modal adaptation techniques applied to Sentinel-1 and -2 data”, under a joint collaboration between the ESA Φ -Lab and the University of Sannio. The results achieved for the classification of volcanic eruptions could be suitable for future missions of the ϕ -sat program that represents the first experiment carried out by ESA to demonstrate how AI on board the satellites can be used for Earth Observation [16].

Conflicts of Interest

The authors declare no conflict of interest.

References

  1. Karthikeyan, L.; Chawla, I.; Mishra, A.K. A review of remote sensing applications in agriculture for food security: Crop growth and yield, irrigation, and crop losses. J. Hydrol. 2020, 586, 124905. [Google Scholar] [CrossRef]
  2. Sepuru, T.K.; Dube, T. An appraisal on the progress of remote sensing applications in soil erosion mapping and monitoring. Remote Sens. Appl. Soc. Environ. 2018, 9, 1–9. [Google Scholar] [CrossRef]
  3. Chong, K.L.; Kanniah, K.D.; Pohl, C.; Tan, K.P. A review of remote sensing applications for oil palm studies. Geo-Spat. Inf. Sci. 2017, 20, 184–200. [Google Scholar] [CrossRef] [Green Version]
  4. Ding, L.; Ma, L.; Li, L.; Liu, C.; Li, N.; Yang, Z.; Yao, Y.; Lu, H. A Survey of Remote Sensing and Geographic Information System Applications for Flash Floods. Remote Sens. 2021, 13, 1818. [Google Scholar] [CrossRef]
  5. Li, J.; Qu, C.; Shao, J. Ship detection in SAR images based on an improved faster R-CNN. In Proceedings of the 2017 SAR in Big Data Era: Models, Methods and Applications (BIGSARDATA), Beijing, China, 13–14 November 2017; pp. 1–6. [Google Scholar]
  6. Zhang, T.; Zhang, X.; Ke, X.; Liu, C.; Xu, X.; Zhan, X.; Wang, C.; Ahmad, I.; Zhou, Y.; Pan, D.; et al. HOG-ShipCLSNet: A Novel Deep Learning Network with HOG Feature Fusion for SAR Ship Classification. IEEE Trans. Geosci. Remote Sens. 2021. [Google Scholar] [CrossRef]
  7. Bentes, C.; Frost, A.; Velotto, D.; Tings, B. Ship-iceberg discrimination with convolutional neural networks in high resolution SAR images. In Proceedings of the EUSAR 2016: 11th European Conference on Synthetic Aperture Radar, Hamburg, Germany, 6–9 June 2016; pp. 1–4. [Google Scholar]
  8. Mao, Y.; Yang, Y.; Ma, Z.; Li, M.; Su, H.; Zhang, J. Efficient low-cost ship detection for SAR imagery based on simplified U-net. IEEE Access 2020, 8, 69742–69753. [Google Scholar] [CrossRef]
  9. Mao, Y.; Li, X.; Su, H.; Zhou, Y.; Li, J. Ship Detection for SAR Imagery Based on Deep Learning: A Benchmark. In Proceedings of the 2020 IEEE 9th Joint International Information Technology and Artificial Intelligence Conference (ITAIC), Chongqing, China, 11–13 December 2020; Volume 9, pp. 1934–1940. [Google Scholar]
  10. Ullo, S.L.; Mohan, A.; Sebastianelli, A.; Ahamed, S.E.; Kumar, B.; Dwivedi, R.; Sinha, G.R. A New Mask R-CNN-Based Method for Improved Landslide Detection. IEEE J. Sel. Top. Appl. Earth Obs. Remote Sens. 2021, 14, 3799–3810. [Google Scholar] [CrossRef]
  11. Ullo, S.L.; Langenkamp, M.S.; Oikarinen, T.P.; DelRosso, M.P.; Sebastianelli, A.; Sica, S. Landslide geohazard assessment with convolutional neural networks using sentinel-2 imagery data. In Proceedings of the IGARSS 2019—2019 IEEE International Geoscience and Remote Sensing Symposium, Yokohama, Japan, 28 July–2 August 2019; pp. 9646–9649. [Google Scholar]
  12. Giuffrida, G.; Diana, L.; de Gioia, F.; Benelli, G.; Meoni, G.; Donati, M.; Fanucci, L. CloudScout: A Deep Neural Network for On-Board Cloud Detection on Hyperspectral Images. Remote Sens. 2020, 12, 2205. [Google Scholar] [CrossRef]
  13. Wu, X.; Sahoo, D.; Hoi, S.C. Recent advances in deep learning for object detection. Neurocomputing 2020, 396, 39–64. [Google Scholar] [CrossRef] [Green Version]
  14. Esposito, M.; Marchi, A.Z. In-orbit demonstration of the first hyperspectral imager for nanosatellites. In International Conference on Space Optics—ICSO 2018; Sodnik, Z., Karafolas, N., Cugny, B., Eds.; International Society for Optics and Photonics, SPIE: Bellingham, WA, USA, 2019; Volume 11180, pp. 760–770. [Google Scholar]
  15. Esposito, M.; Conticello, S.S.; Pastena, M.; Domínguez, B.C. In-orbit demonstration of artificial intelligence applied to hyperspectral and thermal sensing from space. In CubeSats and SmallSats for Remote Sensing III; Pagano, T.S., Norton, C.D., Babu, S.R., Eds.; International Society for Optics and Photonics, SPIE: Bellingham, WA, USA, 2019; Volume 11131, pp. 88–96. [Google Scholar]
  16. European Space Agency (ESA). Φ-sat Artificial Intelligence for Earth Observation. Available online: https://www.esa.int/Applications/Observing_the_Earth/Ph-sat (accessed on 24 June 2021).
  17. Xu, P.; Li, Q.; Zhang, B.; Wu, F.; Zhao, K.; Du, X.; Yang, C.; Zhong, R. On-Board Real-Time Ship Detection in HISEA-1 SAR Images Based on CFAR and Lightweight Deep Learning. Remote Sens. 2021, 13, 1995. [Google Scholar] [CrossRef]
  18. Del Rosso, M.P.; Sebastianelli, A.; Ullo, S.L. Artificial Intelligence Applied to Satellite-Based Remote Sensing Data for Earth Observation; The Institution of Engineering and Technology (IET): London, UK, 2021. [Google Scholar]
  19. Titos, M.; Bueno, A.; Garcia, L.; Benitez, C. A deep neural networks approach to automatic recognition systems for volcano-seismic events. IEEE J. Sel. Top. Appl. Earth Obs. Remote Sens. 2018, 11, 1533–1544. [Google Scholar] [CrossRef]
  20. Anantrasirichai, N.; Albino, F.; Hill, P.; Bull, D.; Biggs, J. Detecting Volcano Deformation in InSAR using Deep learning. arXiv 2018, arXiv:1803.00380. [Google Scholar]
  21. Anantrasirichai, N.; Biggs, J.; Albino, F.; Bull, D. A deep learning approach to detecting volcano deformation from satellite imagery using synthetic datasets. Remote Sens. Environ. 2019, 230, 111179. [Google Scholar] [CrossRef] [Green Version]
  22. Sun, J.; Wauthier, C.; Stephens, K.; Gervais, M.; Cervone, G.; La Femina, P.; Higgins, M. Automatic Detection of Volcanic Surface Deformation Using Deep Learning. J. Geophys. Res. Solid Earth 2020, 125, e2020JB019840. [Google Scholar] [CrossRef]
  23. Valade, S.; Ley, A.; Massimetti, F.; D’Hondt, O.; Laiolo, M.; Coppola, D.; Loibl, D.; Hellwich, O.; Walter, T.R. Towards global volcano monitoring using multisensor sentinel missions and artificial intelligence: The MOUNTS monitoring system. Remote Sens. 2019, 11, 1528. [Google Scholar] [CrossRef] [Green Version]
  24. Buongiorno, M.F.; Romaniello, V.; Silvestri, M.; Musacchio, M.; Rabuffi, F. Analysis of first PRISMA acquisitions on volcanoes and geothermal areas in Italy; comparisons with model simulations, past Hyperion data and field campaigns. AGU Fall Meet. Abstr. 2020, 2020, GC029-03. [Google Scholar]
  25. Urai, M. Sulfur dioxide flux estimation from volcanoes using advanced spaceborne thermal emission and reflection radiometer—A case study of Miyakejima volcano, Japan. J. Volcanol. Geotherm. Res. 2004, 134, 1–13. [Google Scholar] [CrossRef]
  26. Colini, L.; Spinetti, C.; Doumaz, F.; Amici, S.; Ananasso, C.; Buongiorno, M.F.; Cafaro, P.; Caltabiano, T.; Curci, G.; D’Andrea, S.; et al. 2012 hyperspectral airborne campaign on Etna: Multi data acquisition for ASI-PRISMA project. In Proceedings of the 2013 IEEE International Geoscience and Remote Sensing Symposium-IGARSS, Melbourne, Australia, 21–26 July 2013; pp. 4427–4430. [Google Scholar]
  27. Volcanoes of the World, Smithsonian Institution, National Museum of Natural History, Global Volcanism Program. Available online: http://volcano.si.edu/database/search_eruption_results.cfm (accessed on 24 June 2021).
  28. Sebastianelli, A.; Del Rosso, M.P.; Ullo, S.L. Automatic Dataset Builder for Machine Learning Applications to Satellite Imagery. Elsevier Softw.-X 2021, 15, 100739. [Google Scholar]
  29. Gorelick, N.; Hancher, M.; Dixon, M.; Ilyushchenko, S.; Thau, D.; Moore, R. Google Earth Engine: Planetary-scale geospatial analysis for everyone. Remote Sens. Environ. 2017, 202, 18–27. [Google Scholar] [CrossRef]
  30. Raspberry Pi Foundation. Raspberry Pi. Available online: https://www.raspberrypi.org/ (accessed on 17 July 2021).
  31. Sentinel Hub Blog. Active Volcanoes as Seen from Space. Available online: https://medium.com/sentinel-hub/active-volcanoes-as-seen-from-space-9d1de0133733 (accessed on 17 July 2021).
  32. LeCun, Y.; Bengio, Y.; Hinton, G. Deep learning. Nature 2015, 521, 436–444. [Google Scholar] [CrossRef]
  33. Goodfellow, I.; Bengio, Y.; Courville, A. Deep Learning; MIT Press: Cambridge, UK, 2016; Volume 1. [Google Scholar]
  34. Del Rosso, M.P.; Sebastianelli, A.; Spiller, D.; Mathieu, P.P.; Ullo, S.L. On Board Volcanic Eruption Detection Git-Hub Repository. Available online: https://github.com/Sebbyraft/OnBoardVolcanicEruptionDetection (accessed on 25 August 2021).
  35. Kim, P. Convolutional neural network. In MATLAB Deep Learning; Apress: Berkeley, CA, USA, 2017; pp. 121–147. [Google Scholar]
  36. Krizhevsky, A.; Sutskever, I.; Hinton, G.E. Imagenet classification with deep convolutional neural networks. Adv. Neural Inf. Process. Syst. 2012, 25, 1097–1105. [Google Scholar] [CrossRef]
  37. LeCun, Y. LeNet-5, Convolutional Neural Networks. Available online: http://yann.Lecun.Com/exdb/lenet (accessed on 20 August 2021).
  38. ESA Φ-Lab. AI4EO Git-Hub Page. Available online: https://github.com/ESA-PhiLab/ai4eo (accessed on 24 June 2021).
  39. Mohammed, R.; Rawashdeh, J.; Abdullah, M. Machine learning with oversampling and undersampling techniques: Overview study and experimental results. In Proceedings of the 2020 11th International Conference on Information and Communication Systems (ICICS), Irbid, Jordan, 7–9 April 2020; pp. 243–248. [Google Scholar]
  40. Zhang, T.; Zhang, X. ShipDeNet-20: An only 20 convolution layers and <1-MB lightweight SAR ship detector. IEEE Geosci. Remote Sens. Lett. 2020, 18, 1234–1238. [Google Scholar]
  41. Intel. Neural Compute Stick. Available online: https://software.intel.com/content/dam/develop/public/us/en/documents/ncs2-data-sheet.pdf (accessed on 17 July 2021).
  42. RaspberryPI. RaspberryPI Camera Module Datasheet. Available online: https://www.raspberrypi.org/documentation/hardware/camera/ (accessed on 17 July 2021).
  43. RaspberryPI. RaspberryPI Datasheet. Available online: https://datasheets.raspberrypi.org/bcm2711/bcm2711-peripherals.pdf (accessed on 17 July 2021).
  44. OpenVINO. OpenVINO Toolkit Website. Available online: https://docs.openvinotoolkit.org/latest/index.html (accessed on 17 July 2021).
  45. European Space Agency (ESA). Φ-Lab. Available online: https://philab.phi.esa.int/ (accessed on 24 June 2021).
Figure 1. True RGB color image (left) and IR highlighted image (right).
Figure 1. True RGB color image (left) and IR highlighted image (right).
Remotesensing 13 03479 g001
Figure 2. Volcano surrounded by clouds (left) vs. Eruption smoke (right).
Figure 2. Volcano surrounded by clouds (left) vs. Eruption smoke (right).
Remotesensing 13 03479 g002
Figure 3. A set of 9 images from the downloaded and pre-processed dataset.
Figure 3. A set of 9 images from the downloaded and pre-processed dataset.
Remotesensing 13 03479 g003
Figure 4. Network architecture.
Figure 4. Network architecture.
Remotesensing 13 03479 g004
Figure 5. Training and validation accuracy for the proposed model.
Figure 5. Training and validation accuracy for the proposed model.
Remotesensing 13 03479 g005
Figure 6. Smaller network architecture.
Figure 6. Smaller network architecture.
Remotesensing 13 03479 g006
Figure 7. Training and validation accuracy for the proposed reduced model.
Figure 7. Training and validation accuracy for the proposed reduced model.
Remotesensing 13 03479 g007
Figure 8. Schematic for the prototype.
Figure 8. Schematic for the prototype.
Remotesensing 13 03479 g008
Figure 9. Block diagram for the implementation on Raspberry and Movidius stick.
Figure 9. Block diagram for the implementation on Raspberry and Movidius stick.
Remotesensing 13 03479 g009
Figure 10. Sentinel-2 printed image for on board model evaluation.
Figure 10. Sentinel-2 printed image for on board model evaluation.
Remotesensing 13 03479 g010
Figure 11. Sample from the testing dataset.
Figure 11. Sample from the testing dataset.
Remotesensing 13 03479 g011
Table 1. Sample from the volcanoes of the world (VOTW) [27].
Table 1. Sample from the volcanoes of the world (VOTW) [27].
Eruption Start TimeVolcano NameLatitude (deg)Longitude (deg)
26 June 2019Ulawun−5.050151.330
24 June 2019Ubinas−16.355151.330
22 June 2019Raikoke48.292153.250
11 June 2019Piton de la Fournaise−21.24455.708
1 June 2019Great Sitkin52.076−176.130
Table 2. Description of Landsat-7 bands.
Table 2. Description of Landsat-7 bands.
Band NameDescriptionWavelength (nm)Bandwidth (nm)Spatial Resolution (m)
B1Blue4857030
B2Green5608030
B3Red6607030
B5SWIR 1165020030
B7SWIR 2222026030
Table 3. Description of Sentinel-2 bands.
Table 3. Description of Sentinel-2 bands.
Band NameDescriptionWavelength (nm)Bandwidth (nm)Spatial Resolution (m)
B2Blue496.6 (S2A)/492.1 (S2B)6610
B3Green560 (S2A)/559 (S2B)3610
B4Red664.5 (S2A)/665 (S2B)3110
B11SWIR 11613.7 (S2A)/1610.4 (S2B)91 (S2A)/94 (S2B)20
B12SWIR 22202.4 (S2A)/2185.7 (S2B)175 (S2A)/185 (S2B)20
Table 4. Raspberry PI 3 specifications.
Table 4. Raspberry PI 3 specifications.
ComponentSpecifications
ProcessorQuad Core 1.2 GHz Broadcom BCM2837 64bit CPU 1GB RAM
Wireless systemsBCM43438 wireless LAN and Bluetooth Low Energy (BLE) on board
Hardware sysetms100 Base Ethernet
Hardware connectors40-pin extended GPIO
USB Ports4 USB 2.0 ports
Video Ports (1)4 Pole stereo output and composite video port
Video Ports (2)Full size HDMI
Camera PortCSI camera port for connecting a Raspberry Pi camera
Display PortDSI display port for connecting a Raspberry Pi touchscreen display
External Memory PortMicro SD port for loading your operating system and storing data
Power Supply PoprtUpgraded switched Micro USB power source up to 2.5A
Table 5. Raspberry Pi RGB camera specifications.
Table 5. Raspberry Pi RGB camera specifications.
ComponentSpecifications
FocusFixed focus lens on board
Resolution8 megapixel native resolution sensor
Frame size3280 × 2464 pixel static images
Video SupportSupports 1080p30, 720p60 and 640 × 480p90 video
Physical DimensionSize 25 mm × 23 mm × 9 mm
WeightsWeight just over 3 g
Table 6. Model results on testing dataset.
Table 6. Model results on testing dataset.
ColumnRow 1Row 2Row 3
Ground TruthPredictedGround TruthPredictedGround TruthPredicted
11.000.130.000.030.000.00
21.000.991.000.991.000.99
31.000.991.000.990.000.00
41.000.950.000.001.000.99
51.000.981.000.990.000.00
61.000.991.000.990.000.02
70.000.000.000.001.000.99
80.000.000.000.260.000.88
90.000.001.000.990.000.01
Table 7. Small model results on the testing dataset.
Table 7. Small model results on the testing dataset.
ColumnRow 1Row 2Row 3
Ground TruthPredictedGround TruthPredictedGround TruthPredicted
11.000.990.000.560.000.08
21.000.991.000.940.000.00
31.000.991.000.970.000.01
41.000.010.000.010.000.64
51.000.991.000.990.000.00
61.000.971.000.991.000.97
70.000.000.000.991.000.00
80.000.990.000.000.000.00
90.000.001.000.000.000.00
Table 8. Performances comparison considering the big and the small models.
Table 8. Performances comparison considering the big and the small models.
Big ModelSmall Model
Trainable Parameter2,136,385243,541
Non-trainable Parameter2272704
Model weight24.6 Mb1.9 Mb
Training Time∼10 h∼3 h
Table 9. Performances comparison considering the big and the small models (in details).
Table 9. Performances comparison considering the big and the small models (in details).
ScoreBig ModelSmall Model
True Positive (TP)0.850.83
True Negative (TN)0.850.83
False Positive (FP)0.150.17
False Negative (FN)0.150.17
Overall accuracy0.850.83
Precision0.850.83
Recall0.850.83
F1 Score0.850.83
images/second17
Publisher’s Note: MDPI stays neutral with regard to jurisdictional claims in published maps and institutional affiliations.

Share and Cite

MDPI and ACS Style

Del Rosso, M.P.; Sebastianelli, A.; Spiller, D.; Mathieu, P.P.; Ullo, S.L. On-Board Volcanic Eruption Detection through CNNs and Satellite Multispectral Imagery. Remote Sens. 2021, 13, 3479. https://doi.org/10.3390/rs13173479

AMA Style

Del Rosso MP, Sebastianelli A, Spiller D, Mathieu PP, Ullo SL. On-Board Volcanic Eruption Detection through CNNs and Satellite Multispectral Imagery. Remote Sensing. 2021; 13(17):3479. https://doi.org/10.3390/rs13173479

Chicago/Turabian Style

Del Rosso, Maria Pia, Alessandro Sebastianelli, Dario Spiller, Pierre Philippe Mathieu, and Silvia Liberata Ullo. 2021. "On-Board Volcanic Eruption Detection through CNNs and Satellite Multispectral Imagery" Remote Sensing 13, no. 17: 3479. https://doi.org/10.3390/rs13173479

Note that from the first issue of 2016, this journal uses article numbers instead of page numbers. See further details here.

Article Metrics

Back to TopTop