Publications

Implementing face recognition using a parallel image processing environment based on algorithmic skeletons.

Image processing is widely used in many applications, including medical imaging, industrial manufacturing, and security systems. Often the size of the image is very large, the processing time has to be very small and usually real-time constraints have to be met. Therefore, during the last decades there has been an increasing interest in the development and the use of parallel algorithms in image processing. This paper presents and evaluates a method for introducing parallelism into an image processing application. The method is based on algorithmic skeletons for low, medium and high level image processing operations. They provide an easy-to-use parallel programming interface. To evaluate this approach, face recognition is implemented twice on a highly parallel processing platform, once via skeletons, once directly and highly optimized. It is demonstrated that the skeleton approach is extremely convenient from a programmers point of view, while the performance penalty of using skeletons is well below 10% in our case study.