10939

Accelerating Sequential Computer Vision Algorithms Using Commodity Parallel Hardware

Jacob (Jaap) van de Loosdrecht
Limerick Institute of Technology
Limerick Institute of Technology, 2013
@article{van2013accelerating,

   title={Accelerating Sequential Computer Vision Algorithms Using Commodity Parallel Hardware},

   author={Van de Loosdrecht, J},

   journal={Proceedings of NIOC2013},

   year={2013}

}

Download Download (PDF)   View View   Source Source   

398

views

Since 2004, the clock frequency of CPUs has not increased significantly. Computer Vision applications have an increasing demand for more processing power and are limited by the performance capabilities of sequential processor architectures. The only way to get better performance using commodity hardware is to adopt parallel programming. Many other related research projects have considered using one domain specific algorithm to compare the best sequential implementation with the best parallel implementation on a specific hardware platform. This project is distinctive because it investigated how to speed up a whole library by parallelizing the algorithms in an economical way and execute them on multiple platforms. In this work the author has: – Examined, compared and evaluated 22 programming languages and environments for parallel computing on multi-core CPUs and GPUs. – Chosen to use OpenMP as the standard for multi-core CPU programming and OpenCL for GPU programming. – Re-implemented a number of standard and well-known algorithms in Computer Vision using both standards. – Tested the performance of the implemented parallel algorithms and compared the performance to the sequential implementations of the commercially available software package VisionLab. – Evaluated the test results with a view to assessing: – Appropriateness of multi-core CPU and GPU architectures in Computer Vision. – Benefits and costs of parallel approaches to implementation of Computer Vision algorithms. Both the literature review and the results of the benchmarks in this work have confirmed that both multi-core CPU and GPU architectures are appropriate for accelerating sequential Computer Vision algorithms. Using OpenMP it was demonstrated that many algorithms of a library could be parallelized in an economical way and that adequate speedups were achieved on two multi-core CPU platforms. With a considerable amount of extra effort, OpenCL was used to achieve much higher speedups for specific algorithms on dedicated GPUs. At the end of the project, the choice of standards was re-evaluated including newly emerged ones. Recommendations are given for using standards in the future, and for future research and development. The following algorithmic improvements appear to be novel. The literature search has not found any previous use of them: – Vectorization of Convolution on grayscale images with variable sized mask utilizing padding width of vector with zeros. – Few-core Connect Component Labelling. – Optimization of a recent many-core Connect Component Labelling approach.
VN:F [1.9.22_1171]
Rating: 0.0/5 (0 votes cast)

* * *

* * *

Like us on Facebook

HGPU group

149 people like HGPU on Facebook

Follow us on Twitter

HGPU group

1243 peoples are following HGPU @twitter

* * *

Free GPU computing nodes at hgpu.org

Registered users can now run their OpenCL application at hgpu.org. We provide 1 minute of computer time per each run on two nodes with two AMD and one nVidia graphics processing units, correspondingly. There are no restrictions on the number of starts.

The platforms are

Node 1
  • GPU device 0: AMD/ATI Radeon HD 5870 2GB, 850MHz
  • GPU device 1: AMD/ATI Radeon HD 6970 2GB, 880MHz
  • CPU: AMD Phenom II X6 @ 2.8GHz 1055T
  • RAM: 12GB
  • OS: OpenSUSE 13.1
  • SDK: AMD APP SDK 2.9
Node 2
  • GPU device 0: AMD/ATI Radeon HD 7970 3GB, 1000MHz
  • GPU device 1: nVidia GeForce GTX 560 Ti 2GB, 822MHz
  • CPU: Intel Core i7-2600 @ 3.4GHz
  • RAM: 16GB
  • OS: OpenSUSE 12.2
  • SDK: nVidia CUDA Toolkit 6.0.1, AMD APP SDK 2.9

Completed OpenCL project should be uploaded via User dashboard (see instructions and example there), compilation and execution terminal output logs will be provided to the user.

The information send to hgpu.org will be treated according to our Privacy Policy

HGPU group © 2010-2014 hgpu.org

All rights belong to the respective authors

Contact us: