官术网_书友最值得收藏!

Implementing a Gaussian blur with two-dimensional convolution

A Gaussian blur is implemented by convolving the image with a kernel of Gaussian values. Two- dimensional convolution is something that is used very widely in image processing. Usually, we have a big picture (let's look at a 5 x 5 subsection of that particular image), and we have a kernel (or filter) that is another matrix of a smaller size (in our example, 3 x 3).

In order to get the convolution values, let's suppose that we want to get the value at location (2, 3). We place the kernel centered at the location (2, 3), and we calculate the pointwise product of the overlay matrix (highlighted area, in the following image (red color)) with the kernel and take the overall sum. The resulting value (that is, 158.4) is the value we write on the other matrix at the location (2, 3).

We repeat this process for all elements, and the resulting matrix (the matrix on the right) is the convolution of the kernel with the image. In the following diagram, on the left, you can see the original image with the pixel values in the boxes (values higher than 100). We also see an orange filter with values in the bottom right of each cell (a collection of 0.1 or 0.2 that sum to 1). In the matrix on the right, you see the values when the filter is applied to the image on the left:

Note that, for points on the boundaries, the kernel is not aligned with the matrix, so we have to figure out a strategy to give values for those points. There is no single good strategy that works for everything; some of the approaches are to either extend the border with zeros or extend with border values.

Let's take a look at how to transform a normal picture into a pencil sketch.

主站蜘蛛池模板: 喀喇| 云林县| 扬中市| 平山县| 长沙市| 台江县| 城步| 黔南| 天镇县| 万年县| 台山市| 安塞县| 昭觉县| 岳阳市| 达州市| 綦江县| 兴国县| 永吉县| 珠海市| 漳平市| 景宁| 邵东县| 鄂伦春自治旗| 郁南县| 安泽县| 佛冈县| 南开区| 旺苍县| 菏泽市| 财经| 阿克苏市| 加查县| 鄂州市| 新安县| 英超| 安达市| 东安县| 新密市| 邵武市| 桦甸市| 铜陵市|