Circle detection for eye
    7 ビュー (過去 30 日間)
  
       古いコメントを表示
    
Hi everyone, I am stuck with this for weeks. After I input a face image, 
First: I perform the viola jones eye region detection by using the vision.CascadeObjectDetector
Second: I perform the Canny edge detection based on the eye region that was detected during the first stage.
a = imread('face.jpg');
imshow(a);
detector = vision.CascadeObjectDetector('EyePairSmall');
bbox = step(detector,a);
out = insertObjectAnnotation (a,'rectangle',bbox,'detection');
subplot(2,2,1),subimage(out);
outb = imcrop(out,bbox);
[hog1,visualization] = extractHOGFeatures(outb,'CellSize',[8 8]);
subplot(2,2,2),subimage(outb);
I  = rgb2gray(outb);
BW = edge(I,'canny');
subplot(2,2,3);
imshow(BW);
After that, the image shown is like this:

May I know how can I detect the iris (circle shape) based on the output of Canny edge detection ? 
As the region has will only have two circles detected, how is it possible to be implemented ?
I read about the imfindcircle before, but it doesn't work out. Might need the community helps and some guidance on this.
Much appreciated. Thank you !
回答 (1 件)
  Image Analyst
      
      
 2019 年 11 月 19 日
        Why are you using edge detection???  
I'd first try thresholding the red channel, and if that is not robust enough, try imfindcircles().
4 件のコメント
  Image Analyst
      
      
 2019 年 11 月 19 日
				OK, what is the name of your image?  What did you call the variable?
Can you attach the cropped eye image alone?  (Use imwrite()).
参考
カテゴリ
				Help Center および File Exchange で Computer Vision with Simulink についてさらに検索
			
	Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!


