#include "convolution.h"
#include <stdbool.h>
#include <stdint.h>
#include <math.h>
#include <stdlib.h>
|
bool | convolve2DSeparable8 (unsigned char *in, unsigned char *out, int dataSizeX, int dataSizeY, float *kernelX, int kSizeX, float *kernelY, int kSizeY) |
| 8bit version composite 2D convolution More...
|
|
bool | convolve2DSeparable (float *in, float *out, int dataSizeX, int dataSizeY, const float *kernelX, int kSizeX, const float *kernelY, int kSizeY) |
| composite 2D convolution More...
|
|
bool | convV (float *in, float *out, int dataSizeX, int dataSizeY, const float *kernelY, int kSizeY) |
| Vertical 1D convolution. More...
|
|
bool | convH (float *in, float *out, int dataSizeX, int dataSizeY, const float *kernelX, int kSizeX) |
| Horizontal 1D convolution. More...
|
|
Code extracted from : http://www.songho.ca/dsp/convolution/convolution.html And modified such as it perform a composition of 1D convolution horiz + vertical for separable filter
◆ convH()
bool convH |
( |
float * |
in, |
|
|
float * |
out, |
|
|
int |
dataSizeX, |
|
|
int |
dataSizeY, |
|
|
const float * |
kernelX, |
|
|
int |
kSizeX |
|
) |
| |
Horizontal 1D convolution.
◆ convolve2DSeparable()
bool convolve2DSeparable |
( |
float * |
in, |
|
|
float * |
out, |
|
|
int |
dataSizeX, |
|
|
int |
dataSizeY, |
|
|
const float * |
kernelX, |
|
|
int |
kSizeX, |
|
|
const float * |
kernelY, |
|
|
int |
kSizeY |
|
) |
| |
composite 2D convolution
- Parameters
-
- Returns
- big if true
◆ convolve2DSeparable8()
bool convolve2DSeparable8 |
( |
unsigned char * |
in, |
|
|
unsigned char * |
out, |
|
|
int |
dataSizeX, |
|
|
int |
dataSizeY, |
|
|
float * |
kernelX, |
|
|
int |
kSizeX, |
|
|
float * |
kernelY, |
|
|
int |
kSizeY |
|
) |
| |
8bit version composite 2D convolution
- Parameters
-
- Returns
- big if true
◆ convV()
bool convV |
( |
float * |
in, |
|
|
float * |
out, |
|
|
int |
dataSizeX, |
|
|
int |
dataSizeY, |
|
|
const float * |
kernelY, |
|
|
int |
kSizeY |
|
) |
| |