Skip to content

amikha33/Image-Segmentation

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

71 Commits
 
 
 
 

Repository files navigation

Assignment(Image Segmentation):

Image segmentation is the classification of an image into different groups. Many researches have been done in the area of image segmentation using clustering. There are different methods and one of the most popular methods is k-means clustering algorithm. K -means clustering algorithm is an unsupervised algorithm and it is used to segment the interest area from the background.

Berkeley Segmentation Data Set and Benchmarks 500 (BSDS500):

Best Practice Guidelines: The dataset consists of 500 natural images, ground-truth human annotations and benchmarking code. The data is explicitly separated into disjoint train, validation and test subsets. In order to preserve the integrity of the evaluation and obtain a direct and fair comparison of your results with existing methods Exemplary-segmentation-results-on-Berkeley-BSDS-500-obtained-on-the-optimal-database

Train only on trainval:

All the learning, parameter tuning, model selection, etc. should be done exclusively on the train and validation subsets of the data.

Run once on test:

After training, your algorithm should be run only once with fixed parameters on the test subset of the data. The images and ground-truth segmentations of the test set cannot be used for tuning your algorithm.

the evaluation results:

Evaluate your results on the test subset with the Kmeans code. In order to assess quantitatively different aspects of performance of contour detection and segmentation algorithms, the BSDS500 provides a suite of evaluation measures.

Original Image

image

Ground Truth :

Ground truth: That is the reality you want your model to predict.

It may have some noise but you want your model to learn the underlying pattern in data that’s causing this ground truth. Practically, your model will never be able to predict the ground truth as ground truth will also have some noise and no model gives hundred percent accuracy but you want your model to be as close as possible.

4 1 2

K-Means clustering algorithm for RGB Images :

K-Means clustering algorithm is an unsupervised algorithm and it is used to segment the interest area from the background. It clusters, or partitions the given data into K-clusters or parts based on the K-centroids. The algorithm is used when you have unlabeled data(i.e. data without defined categories or groups). The goal is to find certain groups based on some kind of similarity in the data with the number of groups represented by K , chosen Values For K =[3,5,7,9,11]

For K = 3

image

Kmeans Results :

image

image

image

F1 Score

is needed when you want to seek a balance between Precision and Recall. Right…so what is the difference between F1 Score and Accuracy then? We have previously seen that accuracy can be largely contributed by a large number of True Negatives which in most business circumstances, we do not focus on much whereas False Negative and False Positive usually has business costs (tangible & intangible) thus F1 Score might be a better measure to use if we need to seek a balance between Precision and Recall AND there is an uneven class distribution (large number of Actual Negatives). image

image

Entropy :

We used shannon entropy to ignore the ZERO probability leads to Nan in results There are essentially two cases and it is not clear from your sample which one applies here. (1) Your probability distribution is discrete. Then you have to translate what appear to be relative frequencies to probabilities (2) Your probability distribution is continuous. In that case the values in your input needn't sum to one. Assuming that the input is sampled regularly from the entire space, you'd get

Big Image

A-Normalized Cut

Affinity matrix: Affinity matrix is a matrix with each element the affinity between data point $ In this project we use intensity-based affinity and distance-based affinity. The kernel size sigma of these two affinity is tricky. For intensity based affinity, the kernel should be small, because two data points with large intensity difference should not be in same cluster by all means. for distance-based affinity, the kernel should not be too small, because even two data points are far away, they can still be in same cluster, hence the restriction of distance affinity should be looser. we Chose 5 Random Pictures Comparing their Kmeans Clustering and Normalized Cut

Picture Number 47

47 47new

Picture Number 25

25 25a

Picture Number 7

output-onlinepngtools 7 siiiiiiiiiooooooo sio siooooooooooo sioooooooooooooooooo si siooiooioo

Picture Number 14

hhhhhhooooooo hhihihih hohoho hohoooooooooooo hohohoohoho

Picture Number 32

a32 32 smlsamdam;d shbasheb shabaaaaaaahseeeeee shabahshefefns shab sjnsanlan

Refreces :

http://www.sci.utah.edu/~weiliu/class/aip/p6/

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published