1
Fork 0
mirror of https://github.com/Steffo99/unimore-hpc-assignments.git synced 2024-11-26 01:54:22 +00:00
hpc-2022-g3/hls/assignment/sobel/sobel.cpp
Gattopandacorno 585fce92d0 Reformat code
Co-authored-by: Stefano Pigozzi <me@steffo.eu>
Co-authored-by: Fabio Zanichelli <ZukkerinoSugar@users.noreply.github.com>
2022-12-19 09:30:44 +01:00

31 lines
780 B
C++

#include <math.h>
#include "sobel.h"
void sobel(uint8_t *__restrict__ out, uint8_t *__restrict__ in, int width, int height)
{
int sobelFilter[3][3] = {
{-1, 0, 1},
{-2, 0, 2},
{-1, 0, 1}
};
for (int y = 1; y < height - 1; y++)
{
for (int x = 1; x < width - 1; x++)
{
int dx = 0;
int dy = 0;
for (int k = 0; k < 3; k++)
{
for (int z = 0; z < 3; z++)
{
dx += sobelFilter[k][z] * in[(y + k - 1) * width + x + z - 1];
dy += sobelFilter[z][k] * in[(y + k - 1) * width + x + z - 1];
}
}
out[y * width + x] = sqrt((float)((dx * dx) + (dy * dy)));
}
}
}