<html>
<head>
<style>
P
{
margin:0px;
padding:0px
}
body
{
FONT-SIZE: 10pt;
FONT-FAMILY:Tahoma
}
</style>
</head>
<body><div style="text-align: left;">Richard and Gaëtan,<br><br>Thanks for the useful comments. Here are some sample images:<br><br>http://www.photogrammetry.ethz.ch/research/ptv/ptv.html<br>http://www.me.cmu.edu/faculty1/higgs/images/gran6-balls2.jpg<br>http://www.cvgpr.uni-mannheim.de/ruhnau/pivresearch.html<br><br>As I described before, the images can be assumed as an ensemble of randomly distributed Gaussian profiles. They are actually images of sphere particles which are, in principle, in the form of airy disks, however, a Gaussian profile makes life easier by approximating the Bessel function in the Airy disks.<br><br>All I want to find from these images are (1) position and (2) diameter of each particle-image. If would be more useful if the comment are less abstract, ie, which itk filter to use in practice.<br><br><br>Thanks<br><br><br></div><hr id="stopSpelling">&gt; Date: Mon, 8 Jan 2007 09:12:19 +1100<br>&gt; From: richard.beare@gmail.com<br>&gt; To: gaetan.lehmann@jouy.inra.fr<br>&gt; Subject: Re: [Insight-users] Circle detection in itk<br>&gt; CC: saveez@hotmail.com; luis.ibanez@kitware.com; insight-users@itk.org<br>&gt; <br>&gt; Hi everyone,<br>&gt; <br>&gt; I think Gaetan is likely to be right, but it would be good to see an<br>&gt; example image. When you are dealing with small objects, such as 3-10<br>&gt; pixel radii, it is often not very useful to assume too much about the<br>&gt; shape - basically every natural object of that size will look like a<br>&gt; circle to a human observer until they zoom in.<br>&gt; <br>&gt; The critical issues I'd want to know about before tackling the problem are:<br>&gt; 1) What do you want to measure - do you want to count the particles,<br>&gt; measure their brightness, look at spatial distribution or something<br>&gt; else entirely. If you only want to count them then you could think<br>&gt; about stereological approaches that are very fast. If you want spatial<br>&gt; distribution then you could look at peaks. If you want brightness<br>&gt; information then you need to segment them and use a method that<br>&gt; corresponds well enough with what an expert observer would do.<br>&gt; <br>&gt; 2) How well controlled is the problem? Is there a nice clean<br>&gt; background or are there other objects that you want to ignore? Do the<br>&gt; objects cluster together in groups that will make separating them<br>&gt; necessary. These factors are extremely critical - people are really<br>&gt; good at ignoring distractors but it is often much harder to design<br>&gt; procedures that deal with such problems.<br>&gt; <br>&gt; 3) Don't worry too much about speed, especially when getting started.<br>&gt; In most cases the performance will depend on the image size and<br>&gt; possibly the size of filter kernels, rather than the number of items<br>&gt; in the image.<br>&gt; <br>&gt; If the background is smooth, and there are no distractors or problems<br>&gt; with touching objects then Gaetan's suggestions are definitely a good<br>&gt; way to start.<br>&gt; <br>&gt; <br>&gt; On 1/7/07, Gaëtan Lehmann &lt;gaetan.lehmann@jouy.inra.fr&gt; wrote:<br>&gt; &gt;<br>&gt; &gt; Hi Ali,<br>&gt; &gt; Hi Luis,<br>&gt; &gt;<br>&gt; &gt; I guess this mail reply to some of the question I wanted to ask after your<br>&gt; &gt; last mail about particle detection - great :-)<br>&gt; &gt;<br>&gt; &gt; Le Sat, 06 Jan 2007 14:10:53 +0100, Ali - &lt;saveez@hotmail.com&gt; a écrit:<br>&gt; &gt;<br>&gt; &gt; &gt; Hi Luis,<br>&gt; &gt; &gt; Thanks for the reply, I thought the itk community was dead in the new<br>&gt; &gt; &gt; year.<br>&gt; &gt;<br>&gt; &gt; some of us may have survived to their holidays ;-)<br>&gt; &gt;<br>&gt; &gt; &gt; I need to detect the position and diameter of randomly distributed<br>&gt; &gt; &gt; particle-images where it is assumed each particle-image has a Gaussian<br>&gt; &gt; &gt; profile.  &gt; 1) How fast do you need the circle detection to be ?<br>&gt; &gt; &gt; The circle detection algorithm must be fast, it is applied to an<br>&gt; &gt; &gt; ensemble of particle-images with Gaussian profile. Each image may<br>&gt; &gt; &gt; contain tens to hundreds of particle-images.<br>&gt; &gt;<br>&gt; &gt; Are there only circluar particles in your image or also other shapes ?<br>&gt; &gt; In the case there are only circular particules, a simple thresholding and<br>&gt; &gt; a labelisation of the connected components may be enough. If the particles<br>&gt; &gt; are on a non uniform background, you can first apply a top-hat to remove<br>&gt; &gt; it. If the intensity of the particules is not uniform from image to image,<br>&gt; &gt; it may be difficult to find a good threshold value, but some automatic<br>&gt; &gt; thresholding methods may give good results.<br>&gt; &gt; If there are other shapes, what are they ? How big are they compared to<br>&gt; &gt; the particules ?<br>&gt; &gt; It would help if you can give a link to an example.<br>&gt; &gt;<br>&gt; &gt; Gaetan<br>&gt; &gt;<br>&gt; &gt;<br>&gt; &gt;<br>&gt; &gt; &gt;&gt; 2) How big are your images ?<br>&gt; &gt; &gt; About 1k X 1k. Each particle-image could have a diameter from 3 to 10<br>&gt; &gt; &gt; pixels.<br>&gt; &gt; &gt;&gt; 3) Are you looking for full circles ?&gt; or only for circumferences ?<br>&gt; &gt; &gt; The circle (particle-image) centre and diameter (Gaussian profile<br>&gt; &gt; &gt; diameter) are desirable to be detected.<br>&gt; &gt; &gt;&gt; &gt; 4) Do you expect to find multiple circles per image ?<br>&gt; &gt; &gt; As described, yes.<br>&gt; &gt; &gt;&gt; &gt; 5) Do you have any priori information about the circle ?&gt; (eg.<br>&gt; &gt; &gt;&gt; expected positions, expected radius, expected&gt; intensities)<br>&gt; &gt; &gt; Positions are random, diameters are variable (3 to 10 pixels) the<br>&gt; &gt; &gt; intensities are variable too. The only prior knowledge could be the<br>&gt; &gt; &gt; assumed Gaussian profile of each particle-image. Correlation-based<br>&gt; &gt; &gt; methods may work, but I am sure there are faster methods around. The use<br>&gt; &gt; &gt; of the existing code in the library is preferred.<br>&gt; &gt; &gt;&gt;&gt; 6) Have you profiled the time that it takes to run the&gt; Hough circle<br>&gt; &gt; &gt;&gt;&gt; detection in a release (optimized) build ?&gt;<br>&gt; &gt; &gt; No, but the following is a quote from 'Practical Algorithms for Image<br>&gt; &gt; &gt; Processing', Seul et al, Cambridge University Press 2000, 4.10.2:<br>&gt; &gt; &gt; '..., and it is for this reason that the Hough transform is far less<br>&gt; &gt; &gt; popular for geometrical objects than the line'.<br>&gt; &gt; &gt; _________________________________________________________________<br>&gt; &gt; &gt; Be one of the first to try Windows Live Mail.<br>&gt; &gt; &gt; http://ideas.live.com/programpage.aspx?versionId=5d21c51a-b161-4314-9b0e-4911fb2b2e6d<br>&gt; &gt;<br>&gt; &gt;<br>&gt; &gt;<br>&gt; &gt; --<br>&gt; &gt; Gaëtan Lehmann<br>&gt; &gt; Biologie du Développement et de la Reproduction<br>&gt; &gt; INRA de Jouy-en-Josas (France)<br>&gt; &gt; tel: +33 1 34 65 29 66    fax: 01 34 65 29 09<br>&gt; &gt; http://voxel.jouy.inra.fr<br>&gt; &gt; _______________________________________________<br>&gt; &gt; Insight-users mailing list<br>&gt; &gt; Insight-users@itk.org<br>&gt; &gt; http://www.itk.org/mailman/listinfo/insight-users<br>&gt; &gt;<br><br /><hr />Be one of the first to try  <a href='http://ideas.live.com/programpage.aspx?versionId=5d21c51a-b161-4314-9b0e-4911fb2b2e6d' target='_new'>Windows Live Mail.</a></body>
</html>