<div dir="ltr"><div><div>Nice job Dirk.<br><br></div>If you add GetMeasurement, leave GetBinMax for backward compatibility.<br><br></div>Bill<br></div><div class="gmail_extra"><br><br><div class="gmail_quote">On Tue, Jul 9, 2013 at 11:22 AM, Padfield, Dirk R (GE Global Research) <span dir="ltr"><<a href="mailto:padfield@research.ge.com" target="_blank">padfield@research.ge.com</a>></span> wrote:<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">Hi All,<br>
<br>
Sorry for my delayed reply; I wanted to go through the code so that I could give an accurate answer about the differences.  I have now had the chance to carefully compare the Otsu and OtsuMultiple code, and I found a number of discrepancies that I have fixed.  Here is a summary:<br>
<br>
First of all, the equations used for the two filters are different because the Otsu uses a simplified mathematical representation that only holds when there is one threshold.  I derived the equations to check that they lead to the same mathematical representation, and they do.<br>
<br>
For all of the tests, I used the 8-bit image ExternalData/Testing/Data/Input/cthead1.png.  For each code line below, the original line is shown with a "-" first, and the new line is shown with a "+" first.  All of the comments are about the Otsu because the MultipleOtsu is implemented more accurately.<br>
<br>
In Otsu, the global mean was being computed incorrectly.  We can measure this because we can compare the value computed from the histogram to the true mean of the image pixels, which is 77.76.  The original and corrected code are as follows:<br>
-    totalMean += ( j + 1 ) * relativeFrequency[j];<br>
+    totalMean += histogram->GetMeasurementVector(j)[0] * relativeFrequency[j];<br>
<br>
Here is a comparison of the mean calculated for different bin values.  Clearly, it should be close to 77.76 for all of them.  Before it was a monotonically increasing value, but now it is more consistent (it is never exactly 77.76 because of how the histogram bins store the image pixels).<br>
Bins: 4,8,16,32,64,128,256,512,1024<br>
Old Mean: 1.95, 3.07, 5.42, 10.36, 20.12, 39.66, 78.76, 156.92, 312.99<br>
New Mean: 92.95, 81.90, 78.38, 78.56, 78.18, 78.03, 77.96, 77.91, 77.82<br>
<br>
The initial left mean was being computed incorrectly.  By mathematical definition, when the leftMean is computed from only the first bin of the histogram, it is equal to the bin value itself.<br>
-  double meanLeft = 1.0;<br>
+  double meanLeft = histogram->GetMeasurementVector(0)[0];<br>
<br>
The left mean was computed incorrectly in the loop.  It only made sense when the number of bins was the same as the number of gray levels of the image itself.<br>
-                   + ( j + 1 ) * relativeFrequency[j] ) / freqLeft;<br>
+                   + ( histogram->GetMeasurementVector(j)[0] ) * relativeFrequency[j] ) / freqLeft;<br>
<br>
The offset of 1 was incorrect in the GetMeasurement call.<br>
-  this->GetOutput()->Set( static_cast<OutputType>( histogram->GetMeasurement( maxBinNumber + 1, 0 ) ) );<br>
+  this->GetOutput()->Set( static_cast<OutputType>( histogram->GetMeasurement( maxBinNumber, 0 ) ) );<br>
<br>
Finally, there is a discrepancy in that Otsu uses GetMeasurement (as shown above), but OtsuMultiple uses GetBinMax to get the final threshold.  The difference is that GetMeasurement is the average of GetBinMax and GetBinMin.  When the number of bins is large, this makes almost no difference because the GetBinMin and GetBinMax are almost the same.  But for small numbers of bins, the GetMeasurement is more stable.  Here are some example results:<br>
<br>
Bins: 4,8,16,32,64,128,256,512,1024<br>
GetBinMin:            63.91, 63.83, 63.79, 79.71, 79.70, 81.69, 83.68, 83.67, 83.92<br>
GetBinMax:         127.82, 95.74, 79.74, 87.68, 83.68, 83.68, 84.67, 84.17, 84.17<br>
GetMeasurement: 95.86, 79.79, 71.76, 83.70, 81.69, 82.68, 84.17, 83.92, 84.05<br>
<br>
Finally, the thresholds should be rounded at the end of the calculator so that they are not truncated by the corresponding ImageFilters.<br>
<br>
I recommend making all of the changes to the Otsu listed above and changing the GetBinMax to GetMeasurement in the OtsuMultiple.  This will make the two completely consistent.  The results are as follows for different number of bins:<br>
<br>
Bins: 4,8,16,32,64,128,256,512,1024<br>
Old Otsu threshold: 159.77, 111.70, 87.71, 91.67, 85.68, 84.67, 85.17, 84.42, 84.30<br>
New threshold:          95.86, 79.79, 71.76, 83.70, 81.69, 82.68, 84.17, 83.92, 84.05<br>
<br>
The ImageJ Otsu plugin (<a href="http://rsbweb.nih.gov/ij/plugins/otsu-thresholding.html" target="_blank">http://rsbweb.nih.gov/ij/plugins/otsu-thresholding.html</a>) outputs a threshold of 79.<br>
The ImageJ MultipleOtsu plugin (<a href="http://rsbweb.nih.gov/ij/plugins/multi-otsu-threshold.html" target="_blank">http://rsbweb.nih.gov/ij/plugins/multi-otsu-threshold.html</a>) with 1 threshold outputs a threshold of 87.<br>
Using Matlab, I get 84.<br>
So they are not consistent, but they are all close.<br>
<br>
Thanks,<br>
<div class="im">Dirk<br>
<br>
________________________________<br>
From: Richard Beare [<a href="mailto:richard.beare@gmail.com">richard.beare@gmail.com</a>]<br>
</div>Sent: Wednesday, July 03, 2013 6:01 PM<br>
<div class="im">To: Padfield, Dirk R (GE Global Research)<br>
</div>Cc: Johnson, Hans J; Matt McCormick; Bradley Lowekamp; <<a href="mailto:insight-developers@itk.org">insight-developers@itk.org</a>> Developers; Gaëtan Lehmann<br>
<div class="im">Subject: Re: [Insight-developers] OtsuThresholdCalculator versus OtsuMultipleThresholdsCalculator<br>
<br>
</div><div class="im">Is the difference in threshold when there are a small number of bins explainable via the one bin difference? If it isn't then that is cause for concern. Otherwise it is just another side effect of the original difference. Small numbers of bins can easily break the assumptions in many of the histogram based methods, as can data with features like large numbers of zeros or maximum values.<br>
<br>
<br>
</div><div class="im">On Thu, Jul 4, 2013 at 6:17 AM, Padfield, Dirk R (GE Global Research) <<a href="mailto:padfield@research.ge.com">padfield@research.ge.com</a><mailto:<a href="mailto:padfield@research.ge.com">padfield@research.ge.com</a>>> wrote:<br>
Exactly.  It seems crazy to use more than 256 bins in that case.  But the goal of that test was simply timing, and the best way to increase the computation time is to increase the number of bins.<br>
<br>
The real takeaway message is: either implementation is equally fast for reasonably-sized inputs, so there is no timing-based concern for replacing one for the other.<br>
<br>
Dirk<br>
<br>
<br>
________________________________________<br>
</div>From: Johnson, Hans J [<a href="mailto:hans-johnson@uiowa.edu">hans-johnson@uiowa.edu</a><mailto:<a href="mailto:hans-johnson@uiowa.edu">hans-johnson@uiowa.edu</a>>]<br>
<div class="im">Sent: Wednesday, July 03, 2013 3:04 PM<br>
To: Padfield, Dirk R (GE Global Research); Matt McCormick<br>
</div>Cc: Bradley Lowekamp; <<a href="mailto:insight-developers@itk.org">insight-developers@itk.org</a><mailto:<a href="mailto:insight-developers@itk.org">insight-developers@itk.org</a>>> Developers; <a href="mailto:Richard.Beare@ieee.org">Richard.Beare@ieee.org</a><mailto:<a href="mailto:Richard.Beare@ieee.org">Richard.Beare@ieee.org</a>>; Gaëtan Lehmann<br>
<div class="im">Subject: Re: [Insight-developers] OtsuThresholdCalculator versus OtsuMultipleThresholdsCalculator<br>
<br>
Dirk,<br>
<br>
With 10,000,000 bins, and an unsigned char data set this seems suspicious.<br>
 Are there real needs for such a large number of bins?<br>
<br>
I'd hate to spend a lot of time doing optimizations for 10,000,000 bins if<br>
there is no real-world use case for it.<br>
<br>
Hans<br>
<br>
<br>
-----Original Message-----<br>
From: <Padfield>, "Dirk R   (GE Global Research)"<br>
</div><div class="im"><<a href="mailto:padfield@research.ge.com">padfield@research.ge.com</a><mailto:<a href="mailto:padfield@research.ge.com">padfield@research.ge.com</a>>><br>
Date: Wednesday, July 3, 2013 1:27 PM<br>
</div><div><div class="h5">To: Matt McCormick <<a href="mailto:matt.mccormick@kitware.com">matt.mccormick@kitware.com</a><mailto:<a href="mailto:matt.mccormick@kitware.com">matt.mccormick@kitware.com</a>>>, Hans Johnson<br>
<<a href="mailto:hans-johnson@uiowa.edu">hans-johnson@uiowa.edu</a><mailto:<a href="mailto:hans-johnson@uiowa.edu">hans-johnson@uiowa.edu</a>>><br>
Cc: Bradley Lowekamp <<a href="mailto:blowekamp@mail.nih.gov">blowekamp@mail.nih.gov</a><mailto:<a href="mailto:blowekamp@mail.nih.gov">blowekamp@mail.nih.gov</a>>>, ITK<br>
<<a href="mailto:insight-developers@itk.org">insight-developers@itk.org</a><mailto:<a href="mailto:insight-developers@itk.org">insight-developers@itk.org</a>>>, "<a href="mailto:Richard.Beare@ieee.org">Richard.Beare@ieee.org</a><mailto:<a href="mailto:Richard.Beare@ieee.org">Richard.Beare@ieee.org</a>>"<br>
<<a href="mailto:Richard.Beare@ieee.org">Richard.Beare@ieee.org</a><mailto:<a href="mailto:Richard.Beare@ieee.org">Richard.Beare@ieee.org</a>>>, Gaëtan Lehmann <<a href="mailto:gaetan.lehmann@gmail.com">gaetan.lehmann@gmail.com</a><mailto:<a href="mailto:gaetan.lehmann@gmail.com">gaetan.lehmann@gmail.com</a>>><br>
Subject: RE: [Insight-developers] OtsuThresholdCalculator versus<br>
OtsuMultipleThresholdsCalculator<br>
<br>
Hi Folks,<br>
<br>
I agree as well that we should merge the two implementations and provide<br>
an update on the migration guide.<br>
<br>
I looked in a little more detail at the two implementations.  If I run<br>
both algorithms for a large range of numberOfHistogramBins, they produce<br>
very different results when the number is small, but very similar results<br>
when the number of bins is large.  This is disturbing in itself, so I am<br>
looking into the implementations to see why this happens.<br>
<br>
In terms of the timing, they are both very fast for normal bin sizes.  But<br>
when I push the numberOfHistogramBins up to 1,000,000 and 10,000,000, I<br>
get some differences:<br>
<br>
numberOfHistogramBins = 1,000,000:<br>
Otsu = 5 sec<br>
OtsuMultiple = 0.5 sec<br>
<br>
numberOfHistogramBins = 10,000,000:<br>
Otsu = 45.80 sec<br>
OtsuMultiple = 4.58 sec<br>
<br>
Thus, when the numberOfHistogramBins is very large, the difference is<br>
significant: the OtsuMultiple is about 10 times faster.  This is<br>
encouraging since the OtsuMultiple is the more general implementation.<br>
<br>
All of these tests are on the cthead1.png image that was used for the<br>
ctest.<br>
<br>
My plan is to carefully compare the implementations to see how to make<br>
them report the same results.  And then I will merge them so that the Otsu<br>
is just a shell that inherits from OtsuMultiple.<br>
<br>
Thanks,<br>
Dirk<br>
<br>
<br>
________________________________________<br>
</div></div>From: Matt McCormick [<a href="mailto:matt.mccormick@kitware.com">matt.mccormick@kitware.com</a><mailto:<a href="mailto:matt.mccormick@kitware.com">matt.mccormick@kitware.com</a>>]<br>
<div class="im">Sent: Tuesday, July 02, 2013 3:44 PM<br>
To: Johnson, Hans J<br>
Cc: Bradley Lowekamp; Padfield, Dirk R (GE Global Research);<br>
</div><<a href="mailto:insight-developers@itk.org">insight-developers@itk.org</a><mailto:<a href="mailto:insight-developers@itk.org">insight-developers@itk.org</a>>> Developers; <a href="mailto:Richard.Beare@ieee.org">Richard.Beare@ieee.org</a><mailto:<a href="mailto:Richard.Beare@ieee.org">Richard.Beare@ieee.org</a>>; Gaëtan<br>
<div class="im">Lehmann<br>
Subject: Re: [Insight-developers] OtsuThresholdCalculator versus<br>
OtsuMultipleThresholdsCalculator<br>
<br>
I concur with Brad and Hans.<br>
<br>
Adding Gaëtan in CC.<br>
<br>
Thanks,<br>
Matt<br>
<br>
</div>On Tue, Jul 2, 2013 at 5:08 PM, Johnson, Hans J <<a href="mailto:hans-johnson@uiowa.edu">hans-johnson@uiowa.edu</a><mailto:<a href="mailto:hans-johnson@uiowa.edu">hans-johnson@uiowa.edu</a>>><br>
<div class="im">wrote:<br>
> I agree with brad.  The two should produce the same results, even tough<br>
>it<br>
> may introduce a different numerical result in the<br>
> OtsuMultipleThresholdCalculator.<br>
><br>
> -----Original Message-----<br>
</div><div class="im">> From: Bradley Lowekamp <<a href="mailto:blowekamp@mail.nih.gov">blowekamp@mail.nih.gov</a><mailto:<a href="mailto:blowekamp@mail.nih.gov">blowekamp@mail.nih.gov</a>>><br>
> Date: Tuesday, July 2, 2013 12:01 PM<br>
</div><div class="im">> To: "Padfield, Dirk R (GE Global Research)" <<a href="mailto:padfield@research.ge.com">padfield@research.ge.com</a><mailto:<a href="mailto:padfield@research.ge.com">padfield@research.ge.com</a>>><br>
> Cc: ITK <<a href="mailto:insight-developers@itk.org">insight-developers@itk.org</a><mailto:<a href="mailto:insight-developers@itk.org">insight-developers@itk.org</a>>>, "<a href="mailto:Richard.Beare@ieee.org">Richard.Beare@ieee.org</a><mailto:<a href="mailto:Richard.Beare@ieee.org">Richard.Beare@ieee.org</a>>"<br>
> <<a href="mailto:Richard.Beare@ieee.org">Richard.Beare@ieee.org</a><mailto:<a href="mailto:Richard.Beare@ieee.org">Richard.Beare@ieee.org</a>>><br>
> Subject: Re: [Insight-developers] OtsuThresholdCalculator<br>
> versus  OtsuMultipleThresholdsCalculator<br>
><br>
> Dirk,<br>
><br>
> I would vote to have the two produce the same results, and create a<br>
>little<br>
> migration guide which notes the change.<br>
><br>
> Regarding, the refactoring, is there any difference in the algorithm<br>
> complexity of the two? Any measurements of the performance difference<br>
> between the two?<br>
><br>
> Brad<br>
><br>
> On Jul 2, 2013, at 11:04 AM, "Padfield, Dirk R (GE Global Research)"<br>
</div><div class="im">> <<a href="mailto:padfield@research.ge.com">padfield@research.ge.com</a><mailto:<a href="mailto:padfield@research.ge.com">padfield@research.ge.com</a>>> wrote:<br>
><br>
>> Hi Richard,<br>
>><br>
>> Thank you for your response and insight.  If anything would need to be<br>
>>changed, I would also lean towards changing the OtsuMultiple because I<br>
>>think we shouldn't change Otsu since I am sure many more people are using<br>
>>the Otsu because it is a standard thresholding algorithm.  I will do some<br>
>>comparisons of the two against other implementations to see what I find.<br>
>><br>
>> But the question still remains: is it okay to change the OtsuMultiple to<br>
>>give the same output as Otsu for one threshold?  I am thinking in terms<br>
>>of those people who use OtsuMultiple whose results will then be slightly<br>
>>different.  Here are the advantages and disadvantages for keeping things<br>
>>the same:<br>
>><br>
>> Advantages: everyone's code still works as it did before<br>
>> Disadvantages: the two implementations are inconsistent with each other<br>
>>even though they are the same algorithm.  The overlapping code cannot be<br>
>>merged (inheritance).  And future enhancements will need to be made in<br>
>>both places.<br>
>><br>
>> My vote is: change OtsuMultiple to be consistent with Otsu.<br>
>><br>
>> What do others think?<br>
>><br>
>> Dirk<br>
>><br>
>><br>
>> ________________________________<br>
</div>>> From: Richard Beare [<a href="mailto:richard.beare@gmail.com">richard.beare@gmail.com</a><mailto:<a href="mailto:richard.beare@gmail.com">richard.beare@gmail.com</a>>]<br>
<div class="im">>> Sent: Monday, July 01, 2013 5:40 PM<br>
>> To: Bradley Lowekamp<br>
</div>>> Cc: Padfield, Dirk R (GE Global Research); <<a href="mailto:insight-developers@itk.org">insight-developers@itk.org</a><mailto:<a href="mailto:insight-developers@itk.org">insight-developers@itk.org</a>>><br>
<div class="im">>>Developers<br>
>> Subject: Re: [Insight-developers] OtsuThresholdCalculator versus<br>
>>OtsuMultipleThresholdsCalculator<br>
>><br>
>> Hi,<br>
>> I think the order was - I introduced new filters copied from ImageJ,<br>
>>then Gaetan started refactoring to use the histogram framework. We both<br>
>>did some work to make that correspond to old versions. I don't remember<br>
>>working on the MultipleThreshold  version, but the code does look<br>
>>similar, so perhaps it was done somewhere along the way - will need to<br>
>>check the logs.<br>
>><br>
>> I'm pretty sure that Otsu was producing the same results that it used to<br>
>>- I didn't compare to other implementations. Thus, if the original Otsu<br>
>>was correct then the current one should be too, which would suggest that<br>
>>the MultipleThresholds version should probably change.<br>
>><br>
>> Not sure when I'll get a chance to look at this in detail.<br>
>><br>
>> I don't have a current email for Gaetan to CC for confirmation.<br>
>><br>
>><br>
>> On Mon, Jul 1, 2013 at 11:02 PM, Bradley Lowekamp<br>
</div><div class="im">>><<a href="mailto:blowekamp@mail.nih.gov">blowekamp@mail.nih.gov</a><mailto:<a href="mailto:blowekamp@mail.nih.gov">blowekamp@mail.nih.gov</a>><mailto:<a href="mailto:blowekamp@mail.nih.gov">blowekamp@mail.nih.gov</a><mailto:<a href="mailto:blowekamp@mail.nih.gov">blowekamp@mail.nih.gov</a>>>> wrote:<br>
>> Dirk,<br>
>><br>
>> I believe Richard Beare did the refactoring of the thresholding<br>
>>framework an Insight Journal Article. He will likely know why it is this<br>
>>way better than anyone else.<br>
>><br>
>> You also didn't say which implementation is correct.<br>
>><br>
>> Brad<br>
>><br>
>><br>
>> On Jun 30, 2013, at 10:03 PM, "Padfield, Dirk R (GE Global Research)"<br>
</div><div><div class="h5">>><<a href="mailto:padfield@research.ge.com">padfield@research.ge.com</a><mailto:<a href="mailto:padfield@research.ge.com">padfield@research.ge.com</a>><mailto:<a href="mailto:padfield@research.ge.com">padfield@research.ge.com</a><mailto:<a href="mailto:padfield@research.ge.com">padfield@research.ge.com</a>>>> wrote:<br>
>><br>
>>> Hi ITK Developers,<br>
>>><br>
>>> I was just looking through the OtsuThresholdCalculator and<br>
>>>OtsuMultipleThresholdsCalculator to see whether I could refactor them so<br>
>>>that the Otsu inherits from the OtsuMultiple since the latter is a more<br>
>>>general case of the former.  Currently, the code for these two filters<br>
>>>is totally different resulting in significant code duplication and a<br>
>>>need to keep both filters in sync.<br>
>>><br>
>>> As a first step, I wrote a CMake test to check that the output of the<br>
>>>OtsuMultiple with 1 threshold is the same as the output of the Otsu.<br>
>>>Unfortunately, they are not!  The two filters output thresholds that are<br>
>>>different by 1 histogram bin!  This can be a quite extreme difference<br>
>>>when the numberOfHistogramBins is low, and it leads to different<br>
>>>thresholds even when the numberOfHistogramBins is reasonably high (say<br>
>>>256).  I tracked it down to this code in the Calculators:<br>
>>><br>
>>> The relevant code from Otsu:<br>
>>>  const double tolerance = 0.00001;<br>
>>>  if ( (varBetween - tolerance) > maxVarBetween )<br>
>>>    {<br>
>>>    maxVarBetween = varBetween;<br>
>>>    maxBinNumber = j;<br>
>>>    }<br>
>>>  }<br>
>>> this->GetOutput()->Set( static_cast<OutputType>(<br>
>>>histogram->GetMeasurement( maxBinNumber + 1, 0 ) ) );<br>
>>><br>
>>> The relevant code from MultipleOtsu:<br>
>>>  if ( varBetween > maxVarBetween )<br>
>>>    {<br>
>>>    maxVarBetween = varBetween;<br>
>>>    maxVarThresholdIndexes = thresholdIndexes;<br>
>>>    }<br>
>>>  }<br>
>>> for ( j = 0; j < m_NumberOfThresholds; j++ )<br>
>>>  {<br>
>>>  m_Output[j] = histogram->GetBinMax(0, maxVarThresholdIndexes[j]);<br>
>>>  }<br>
>>><br>
>>> The difference is that the Otsu adds one to the computed threshold<br>
>>>whereas the MultipleOtsu does not.  This is problematic because users<br>
>>>would expect them to give the same result.<br>
>>><br>
>>> My question is: how should we proceed?  If we change one or the other,<br>
>>>people's code that use the changed one will give slightly different<br>
>>>answers.  If we don't change them, the two filters will give different<br>
>>>outputs for the same input, and it will not be possible to refactor them<br>
>>>to share code.<br>
>>><br>
>>> What are your thoughts?<br>
>>><br>
>>> Thanks,<br>
>>> Dirk<br>
>>> _______________________________________________<br>
</div></div>>>> Powered by <a href="http://www.kitware.com" target="_blank">www.kitware.com</a><<a href="http://www.kitware.com" target="_blank">http://www.kitware.com</a>><<a href="http://www.kitware.com" target="_blank">http://www.kitware.com</a>><br>
<div class="im HOEnZb">>>><br>
>>> Visit other Kitware open-source projects at<br>
>>> <a href="http://www.kitware.com/opensource/opensource.html" target="_blank">http://www.kitware.com/opensource/opensource.html</a><br>
>>><br>
>>> Kitware offers ITK Training Courses, for more information visit:<br>
>>> <a href="http://kitware.com/products/protraining.php" target="_blank">http://kitware.com/products/protraining.php</a><br>
>>><br>
>>> Please keep messages on-topic and check the ITK FAQ at:<br>
>>> <a href="http://www.itk.org/Wiki/ITK_FAQ" target="_blank">http://www.itk.org/Wiki/ITK_FAQ</a><br>
>>><br>
>>> Follow this link to subscribe/unsubscribe:<br>
>>> <a href="http://www.itk.org/mailman/listinfo/insight-developers" target="_blank">http://www.itk.org/mailman/listinfo/insight-developers</a><br>
>><br>
>><br>
><br>
> _______________________________________________<br>
> Powered by <a href="http://www.kitware.com" target="_blank">www.kitware.com</a><<a href="http://www.kitware.com" target="_blank">http://www.kitware.com</a>><br>
><br>
> Visit other Kitware open-source projects at<br>
> <a href="http://www.kitware.com/opensource/opensource.html" target="_blank">http://www.kitware.com/opensource/opensource.html</a><br>
><br>
> Kitware offers ITK Training Courses, for more information visit:<br>
> <a href="http://kitware.com/products/protraining.php" target="_blank">http://kitware.com/products/protraining.php</a><br>
><br>
> Please keep messages on-topic and check the ITK FAQ at:<br>
> <a href="http://www.itk.org/Wiki/ITK_FAQ" target="_blank">http://www.itk.org/Wiki/ITK_FAQ</a><br>
><br>
> Follow this link to subscribe/unsubscribe:<br>
> <a href="http://www.itk.org/mailman/listinfo/insight-developers" target="_blank">http://www.itk.org/mailman/listinfo/insight-developers</a><br>
><br>
><br>
><br>
</div><div class="im HOEnZb">> ________________________________<br>
> Notice: This UI Health Care e-mail (including attachments) is covered by<br>
>the Electronic Communications Privacy Act, 18 U.S.C. 2510-2521, is<br>
>confidential and may be legally privileged.  If you are not the intended<br>
>recipient, you are hereby notified that any retention, dissemination,<br>
>distribution, or copying of this communication is strictly prohibited.<br>
>Please reply to the sender that you have received the message in error,<br>
>then delete it.  Thank you.<br>
> ________________________________<br>
> _______________________________________________<br>
</div><div class="im HOEnZb">> Powered by <a href="http://www.kitware.com" target="_blank">www.kitware.com</a><<a href="http://www.kitware.com" target="_blank">http://www.kitware.com</a>><br>
><br>
> Visit other Kitware open-source projects at<br>
> <a href="http://www.kitware.com/opensource/opensource.html" target="_blank">http://www.kitware.com/opensource/opensource.html</a><br>
><br>
> Kitware offers ITK Training Courses, for more information visit:<br>
> <a href="http://kitware.com/products/protraining.php" target="_blank">http://kitware.com/products/protraining.php</a><br>
><br>
> Please keep messages on-topic and check the ITK FAQ at:<br>
> <a href="http://www.itk.org/Wiki/ITK_FAQ" target="_blank">http://www.itk.org/Wiki/ITK_FAQ</a><br>
><br>
> Follow this link to subscribe/unsubscribe:<br>
> <a href="http://www.itk.org/mailman/listinfo/insight-developers" target="_blank">http://www.itk.org/mailman/listinfo/insight-developers</a><br>
<br>
<br>
<br>
</div><div class="HOEnZb"><div class="h5">________________________________<br>
Notice: This UI Health Care e-mail (including attachments) is covered by the Electronic Communications Privacy Act, 18 U.S.C. 2510-2521, is confidential and may be legally privileged.  If you are not the intended recipient, you are hereby notified that any retention, dissemination, distribution, or copying of this communication is strictly prohibited.  Please reply to the sender that you have received the message in error, then delete it.  Thank you.<br>
________________________________<br>
<br>
_______________________________________________<br>
Powered by <a href="http://www.kitware.com" target="_blank">www.kitware.com</a><br>
<br>
Visit other Kitware open-source projects at<br>
<a href="http://www.kitware.com/opensource/opensource.html" target="_blank">http://www.kitware.com/opensource/opensource.html</a><br>
<br>
Kitware offers ITK Training Courses, for more information visit:<br>
<a href="http://kitware.com/products/protraining.php" target="_blank">http://kitware.com/products/protraining.php</a><br>
<br>
Please keep messages on-topic and check the ITK FAQ at:<br>
<a href="http://www.itk.org/Wiki/ITK_FAQ" target="_blank">http://www.itk.org/Wiki/ITK_FAQ</a><br>
<br>
Follow this link to subscribe/unsubscribe:<br>
<a href="http://www.itk.org/mailman/listinfo/insight-developers" target="_blank">http://www.itk.org/mailman/listinfo/insight-developers</a><br>
</div></div></blockquote></div><br><br clear="all"><br>-- <br>Unpaid intern in BillsBasement at noware dot com<br>
</div>