Exercise 3 for the course "Parallel and distributed systems" of THMMY in AUTH university.
 
 
 
 
 
anapt 7412827fd6 Revert "const char *" 7 years ago
code MATLAB code 7 years ago
data Calculate norm using GPU, Add 32-dimensions dataset 7 years ago
mean_shift_cuda Revert "const char *" 7 years ago
mean_shift_cuda_shared_mem Minor kernel fixes 7 years ago
mean_shift_serial Revert "s4 serial loceye server" 7 years ago
output/visualization Fixed memory management, Add more datasets, Fixed Processing script 7 years ago
stats stats 7 years ago
testers test cuda code 7 years ago
.gitignore output/ ignored 7 years ago
README.md Code clean-up, vars rename, loops merge, matrix saving function 7 years ago

README.md

Mean-shift

Mean-shift is a mathematical procedure, adopted in algorithms, designed in the 70's by Fukunaga and Hostetler. The algorithm is used for:

  • Cluster analysis
  • Computer vision
  • Image processing

Repository

This repository provides a serial implementation of the algorithm in C language, as well as the parallel equivalent in CUDA. The project was undertaken as part of the "Parallel and distributed systems" course of AUTH university.

A Gaussian kernel was used for the weighting function. The code was tested for different data sets and information regarding the execution time and correctness were extracted. In addition, two versions of the parallel algorithm were tested and compared, with and without the usage of shared memory respectively.

Compilation

To compile make sure all necessary packages and dependencies are installed. Then run:

$ make

Usage

blah blah, arguments needed etc

Free Software, Hell Yeah!