Skip to content

Latest commit

 

History

History
81 lines (43 loc) · 5.92 KB

README.md

File metadata and controls

81 lines (43 loc) · 5.92 KB

Worms Detection Report

Reading Image Channels

Both channels are loaded as 16 bit grayscale matrices. Images are normalised in order to preserve the data in the images. They are then subject to a division in order to make the values fit within an 8 bit matrix.

Image and Background segmentation

GFP (W2) - is segmented starting with a Gaussian blur, followed by Adaptive Mean Thresholding. In the event that a border is still present, A mask is created by segmenting the background, eroding it, and merging the mask and the base image. Non-worm objects are removed using contours.

Images from left to right: Normalised, Through thresholding, and Sanitised

Brightfield (W1) - Is subject to a Gaussian blur, followed by a Binary Threshold. Like W2, it is checked for particles. There has been difficulty in extracting as many worms as possible due to image lacking sufficient worm data.

Most of the worms in W1 (Left) are absent, but some worms found in w1 are not found in W2 (Right).

W2 is used as the base file, and W1 is used as a complimentary assistance file. In the event that worm information is absent in W2 as a result of processing, information from W1 may assist in recovering it.

W1 and W2 are then merged together; W1 is in gray, W2 is white.

Overall, this methods works very well, but there have been exceptions; most notably in A03 where a large trail was included in the segmentation. This method detects all objects, however.

The line in A03 is included during segmentation.

Worms Detection

A skeleton of the workspace image is created using Zhang Suen's Algorithm [1][2]. This is cached locally.

The skeleton, in pink.

Object Labelling

Worm blobs are used as a mask to retrieve its skeleton. The skeleton is used to find endpoints. If there is 2 or less endpoints, then it is a worm. (1 end point assumes that the worm is balled in a circle.) Each individual worm blob is saved locally.

Counting

Counting is deduced with the number of worm endpoints. The formula no_worms = Math.floor(len(endpoints)/2) assumes that each worm has two endpoints. This is provided that the skeleton produced is very accurate.

There is a cluster of worms (in purple box) in this image where the formula counts only one worm. This is related to the fact that the skeleton has detected only 3 endpoints. A more precise skeleton would improve results. Otherwise, it counts well.

Detection of Clustered Worms

Each skeleton's pixels are checked for its number of pixel neighbours. 1 Neighbouring pixel is an endpoint. Two pixels means it's in the middle of the worm. More than 2 suggests an intersection. There have been issues with this method, where the skeleton uses more than two pixels to create a curve in the worm. This could be solved by giving the neighbouring worm base a checking library, allowing it to check for patterns.

Intersections are found, but include curves.

Collisions are detected in green; the actual collision in the image is in the red circle. Spots of collisions are most prominent when the worms curve.

Live/dead Worm Classification

Shape Detection is done by using skeleton endpoints. A length is deduced with the endpoints using Pythagoras. This is compared to the number of pixels in the skeleton. A percentage can be deduced. The higher the percentage, The straighter the worm, and the more likely it is to be dead. If there is one endpoint, then the worm is in a circle - it is definitely alive.

Shape detection recognises this worm to be straight with an accuracy of 99%.

Texture Detection - Worms are checked against its Gaussian blur by calculating the euclidean distance. The results (A percentage of difference) are highly volatile due to lighting amongst other issues affecting the image. The higher the difference, the more uneven in texture it is.

Texture detection shows that this worm's pattern difference is 41%

The two percentages are weighted and combined to give a dead_percentage. If this value is greater than the death_threshold it is classified as dead. Each worm's contour is coloured and displayed on a image (which is saved locally for displaying later).

Worms highlighted in green are alive, red is dead, and orange is a cluster.

Evaluation

Results are saved in a .csv file, which can be found in /data/results_data/ directory from where the scripts are run. Coverage and Worm Count are checked against the ground truths. Overall Coverage is measured using pixel checking.

Overall Coverage Percentage Overall Classified Worm Count Percentage Overall Worm Count Percentage (Including Clusters)
93.30927835 60.43298969 90.80412371

Overall, the segmentation coverage is fairly accurate, having a 93% accuracy. This could be improved with better source material. Classifiable Worm count is fairly low due to the number of clustered worms. The image has a good percentage of worms counted (including clusters). Verification on the status of the biological status of a worm is absent, so checking our statistics on dead worms is not possible.

References

[1] T.Y. Zhang and C.Y. Suen. A fast parallel algorithm for thinning digital patterns. Image Processing and Computer Vision, 27:235–239, 1984. [2] Linbo Jin, Skeletonization by Zhang-Suen Thinning Algorithm, Python and Matlab Implementation. 2014. https://github.com/linbojin/Skeletonization-by-Zhang-Suen-Thinning-Algorithm