Parallel Implementation of the Simplex Growing Algorithm for Hyperspectral Unmixing Using OpenCL

Sergio Bernabe,Guillermo Botella,Jose M. R. Navarro,Carlos Orueta,Manuel Prieto-Matias,Antonio Plaza
DOI: https://doi.org/10.1109/igarss.2016.7730607
2016-01-01
Abstract:Many algorithms for spectral unmixing have been proposed in the last years applied on hyperspectral imaging. This process is composed by three stages where the extraction of endmembers is the most consuming step. However, endmember extraction algorithms (EEAs) can be computationally very expensive and its acceleration on parallel architectures is still an interesting and open problem. In this paper, we present a parallel implementation of the simplex growing algorithm for hyperspectral unmixing called P-SGA on different platforms using the OpenCL framework. The proposed implementation exploits the memory hierarchy to accelerate the parts of this method which are more time-consuming. The proposed algorithm is evaluated in terms of both accuracy and computational performance through Monte Carlo simulations using the following architectures: multi-core Xeon CPU, NVidia GeForce GTX 980 GPU and Intel Xeon Phi accelerator. Experiments are conducted using real hyperspectral data set revealing considerable acceleration factors, which satisfies the real-time constraints given by the data acquisition rate.
What problem does this paper attempt to address?