I want to implement some image-processing algorithms which are intended to run on a beagleboard. These algorithms use convolutions extensively. I’m trying to find a good C implementation for 2D convolution (probably using the Fast Fourier Transform). I also want the algorithm to be able to run on the beagleboard’s DSP, because I’ve heard that the DSP is optimized for these kinds of operations (with its multiply-accumulate instruction).
I have no background in the field so I think it won’t be a good idea to implement the convolution myself (I probably won’t do it as good as someone who understands all the math behind it). I believe a good C convolution implementation for DSP exists somewhere but I wasn’t able find it?
Could someone help?
EDIT: Turns out the kernel is pretty small. Its dimensions are either 2X2 or 3X3. So I guess I’m not looking for an FFT-based implementation. I was searching for convolution on the web to see its definition so I can implement it in a straight forward way (I don’t really know what convolution is). All I’ve found is something with multiplied integrals and I have no idea how to do it with matrices. Could somebody give me a piece of code (or pseudo code) for the 2X2 kernel case?
What are the dimensions of the image and the kernel ? If the kernel is large then you can use FFT-based convolution, otherwise for small kernels just use direct convolution.
The DSP might not be the best way to do this though – just because it has a MAC instruction doesn’t mean that it will be more efficient. Does the ARM CPU on the Beagle Board have NEON SIMD ? If so then that might be the way to go (and more fun too).
For a small kernel, you can do direct convolution like this:
You can modify this to support even values of K – it just takes a little care with the upper/lower limits on the two inner loops.