ESP32 motion
convolution.c File Reference
#include "convolution.h"
#include <stdbool.h>
#include <stdint.h>
#include <math.h>
#include <stdlib.h>

Functions

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...
 

Detailed Description

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

Function Documentation

◆ 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
infloat* image
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
inuint8* image
Returns
big if true

◆ convV()

bool convV ( float *  in,
float *  out,
int  dataSizeX,
int  dataSizeY,
const float *  kernelY,
int  kSizeY 
)

Vertical 1D convolution.