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

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.

主站蜘蛛池模板: 福州市| 正安县| 廊坊市| 广昌县| 铁岭市| 望都县| 陵川县| 岚皋县| 陆河县| 古丈县| 禹州市| 建德市| 嘉义县| 江北区| 杭锦旗| 化州市| 陵川县| 林州市| 罗城| 凤冈县| 扎囊县| 嘉祥县| 鹿泉市| 湘潭县| 涿州市| 江西省| 枣阳市| 台东县| 朔州市| 南通市| 南川市| 天门市| 岑巩县| 萨迦县| 施甸县| 女性| 镇远县| 喜德县| 永州市| 任丘市| 拉萨市|