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

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.

主站蜘蛛池模板: 乌审旗| 庐江县| 灵宝市| 齐齐哈尔市| 玛纳斯县| 磐安县| 成都市| 肃宁县| 蛟河市| 天台县| 辽阳市| 绥滨县| 瑞安市| 洛川县| 邵阳市| 自治县| 青海省| 独山县| 福泉市| 广汉市| 扬中市| 河曲县| 翁源县| 新郑市| 汪清县| 高尔夫| 文山县| 寿光市| 葫芦岛市| 南和县| 中山市| 涞水县| 河东区| 宁乡县| 景宁| 胶州市| 天镇县| 长汀县| 伊宁市| 黑山县| 金堂县|