Solution proposal - exercise 11
Task 1
We have several design options for detecting gaps in lines, one such set could be
kh:0001−21000,kv:0100−20010,kd:1000−20001,ka:0010−20100.We can use these to detect gaps in horizontal, vertical, diagonal, and antidiagonal lines, respectively. We illustrate this by the dummy image shown in Figure 1.1.
Below, we show the results after convolving the above image with the respective filters. The result to the left is the result of the convolution, and the result to the right is thresholded at 2, and can be used to detect the gaps.
Task 2
The image in problem 10.36 has a number of objects that are brighter than the background. We are given the information that the mean intensity of the backgroud is 60, while the mean intensity of the objects are 170 on a [0 255] scale.
We follow the procedure explained in section 10.4.1 in G&W on region-based segmentation. First, we choose to use foreground-seeds of 170, then use 8-connectivecty to “grow” our regions iteratively if the neighbouring pixel is for example larger than 115.
- Threshold the image at 170 to create a seed image of the foreground.
- For every connected foreground region, add a pixel to this region if:
- The new pixel has gray level above 115
- The new pixel is connected (with 8 connectivity) to the region.
- Continue from 2. until the regions stop growing.
As an example, I have used region growing on the image shown in Figure 2.1 (I could not find the image used in the book).
If we try a simple thresholding by Otsu, we get the result shown in Figure 2.2. We see that we also include some bright spots that we do not want. Note that there are probably simpler and/or better methods to segment this particular image, but it gives a simple illustration of the region growing.
The gray level intensity distribution is shown in Figure 2.2, and from it, we choose the seed level to be 240, and the proposed region threshold to be at 150
Using region growing of the seed image until convergence yields the final result shown in Figure 2.4.
Task 3
The image we are to segment look like this.
Splitting each quadrant not satisfying the criteria that every value in the region needs to be the same, results in a tree shown in Figure 3.2.
With this, we can merge regions satisfying the criterion. In our case, this will result in a perfect segmentation.
Task 4
The one-dimensional intensity cross section given.
data=(0,0,2,7,4,4,5,6,5,2,2,4,2,1,0)The step by step implementation would look something like this.
- Start with n=1. (n=min(data)+1)
- Two minimums: [1,2] and [15]
- Increase n to 2.
- Basin [15] will catch 14
- Current basins: [1,2] and [14,15]
- Increase n to 3.
- Basin [1,2] will catch 3.
- New minimum: [10,11]
- Basin [14,15] will catch 13.
- Current basins: [1,2,3], [10,11] and [13,14,15]
- Increase n to 4.
- Nothing happens.
- Increase n to 5.
- New minimum: [5,6]
- New dam: 12
- Current basins: [1,2,3], [5,6], [10,11] and [13,14,15]
- Current dams: 12
- Increase n to 6.
- Basin [5,6] will catch 7.
- Basin [10,11] will catch 9.
- Current basins: [1,2,3], [5,6,7], [9,10,11] and [13,14,15]
- Current dams: 12
- Increase n to 7.
- New dam: 8
- Current basins: [1,2,3], [5,6,7], [9,10,11] and [13,14,15]
- Current dams: 8 and 12
- Increase n to 8.
- New dam: 4
- Current basins: [1,2,3], [5,6,7], [9,10,11] and [13,14,15]
- Current dams: 4, 8 and 12
- Finished! (n=max(data)+1)
Alternatively with a step prior to n=1 where a dam is created at each end of the function, i.e. at n=1 and n=15, to prevent the rising water from running off the ends. The remaining steps will be similar, only that the first and last basins won’t include 1 and 15, respectively.
Task 5
Task 6
First, the grayscale version of the pear image.
This gives quite nice gradients, but some additional things are needed before we can use it for watershed.
The simple morphological opening follows.
Which can be compared by the opening-by-reconstruction.
The one we are actually going to use is the closing-by-reconstruction of the opening-by-reconstruction.
By using some maximum filters, we can find the regional maxima, and use them as sure foreground.
But first, we clean them a bit.
The backgorund in the thresholded image can be used as sure background.
Finally, the watershed results.
Now, if you did compute the SKIZ, you will see that it did not make any significant contribution. The results are as the one above, but with SKIZ.