On 11/29/06, <b class="gmail_sendername">Arne Hansen</b> <<a href="mailto:bsd.diverse@gmail.com">bsd.diverse@gmail.com</a>> wrote:<div><span class="gmail_quote"></span><blockquote class="gmail_quote" style="border-left: 1px solid rgb(204, 204, 204); margin: 0pt 0pt 0pt 0.8ex; padding-left: 1ex;">
<div>Okay, i have been investigeting the matter a bit more.</div>
<div>It seems that it actually has an effect when i set the <br>optimizer->SetMaximumNumberOfIterations</div>
<div> </div>
<div>It moves in intervals of 9. So if i set the MaximumNumberOfIterations = 1 it corresponds to 17 iterations.</div></blockquote><div><br>Not always.... Try to set the verbose flag on the amoeba optimizer to see what's going on.. 
<br>    itkAmoebaOpt->GetOptimizer()->verbose = 2;<br><br>The amoeba is a simplex optimizer that optimizes by expanding / shrinking / reflecting from the initial simplex.<br><br>The cost function is evaluated at each end point of the simplex. The larger the number of endpoints (= no: of parameters in the cost function = no: of paramters in your transform), the more the evaluations.
<br><br>One iteration involves one or more combinations of operations on the simplex (expand/reflect/shrink). The number of such combinations depends the function evaluations. For instance if the contraction point is really good, it would hold it there and that would be the end of that iteration. If it is bad, it might try reflecting...
<br><br>See the source of vnl_amoeba.cxx<br><br>So do not be worried if you do not see a direct mathematical relationship between the number of cost-function evaluations and the number of parameters in your transform.<br>
<br><br>-karthik<br></div><br><blockquote class="gmail_quote" style="border-left: 1px solid rgb(204, 204, 204); margin: 0pt 0pt 0pt 0.8ex; padding-left: 1ex;"><div>if i set it to 10 it corresponds to 26 and so on.</div>
<div>In short:</div>
<div>value:    </div>
<div>1-9    : 17 iterations</div>
<div>
<div>10-18 : 26 iterations</div>
<div>
<div>19-27 : 35 iterations</div>
<div>
<div>28-36 : 44 iterations</div>
<div>
<div>37-46 : 53 iterations</div>
<div>etc.</div>
<div> </div>
<div>I find this very odd.</div>
<div>I read this reply made by Luis once:</div>
<div> </div>
<div>><i> The Amoeba optimizer in ITK is a wrapper around the vnl<br></i>><i> amoeba optimizer. Since VNL does not send any events during<br></i>><i> the iterations of its optimizers, ITK implemented a trick in 
</i>><i> the following way:<br></i>><i><br></i>><i>     itkAmoebaOptimizer  wraps vnl_amoeba<br></i>><i><br></i>><i>    SingleValuedVnlCostFunctionAdaptor<br></i>><i>                         wraps vnl_cost_function
<br></i>><i><br></i>><i><br></i>><i> vnl_amoeba calls the f() method of the vnl_cost_function,<br></i>><i> that in turn calls the GetValue() method of the ITK<br></i>><i> SingleValuedVnlCostFunctionAdaptor.
<br></i>><i><br></i>><i> The SingleValuedVnlCostFunctionAdaptor sends events that<br></i>><i> are "observed" by the itkAmoebaOptimizer and resent as<br></i>><i> iteration events.<br></i>><i><br></i>
><i> In this way, we get events *per evaluation* of the cost<br></i>><i> function. Note that this is not completely equivalent<br></i>><i> to events per iteration of the amoeba_optimizer,.... but<br></i>><i> it is better than nothing.
<br></i>><i><br></i>><i> as a rule of thumb you could expect that N evaluations of<br></i>><i> the cost_function are equivalent to one iteration of the<br></i>><i> amoeba optimizer, where N is the dimensionality of the
<br></i>><i> parametric space of the cost function.<br></i></div>
<div>
<div>So i should expect that my amount of parameters is 9. The problem is that it is only 7, since i use the </div>
<div>itkSimilarity3DTransform ie. (Rx,Ry,Rz,Tx,Ty,Tz,S = 7)</div>
<div>So i cannot understand why the iteration count behaves like this.</div>
<div> </div>
<div>Any suggestions?</div></div>
<div><i> </i></div></div></div></div></div>
<div> </div>
<div><br> </div>
<div><span class="gmail_quote">2006/11/29, Arne Hansen <<a href="mailto:bsd.diverse@gmail.com" target="_blank" onclick="return top.js.OpenExtLink(window,event,this)">bsd.diverse@gmail.com</a>>:</span>
<div><span class="e" id="q_10f348b5542b683c_1"><blockquote class="gmail_quote" style="border-left: 1px solid rgb(204, 204, 204); margin: 0px 0px 0px 0.8ex; padding-left: 1ex;">
<div>Hello.</div>
<div>I am using an amoeba optimizer to minimize overlap (itkKappaStatistic) between 2 binary volumes.</div>
<div> </div>
<div>My problem is that it seems that when i set parameters </div>
<div>optimizer->SetMaximumNumberOfIterations(1);</div>
<div>optimizer->SetParametersConvergenceTolerance(10);<br>optimizer->SetFunctionConvergenceTolerance(10);</div>
<div> </div>
<div>they dont seem to have any affect at all. Even though i tell it to maximal do 1 iteration, it still does 17 iterations in the first layer of my itkMultiResolutionImageRegistrationMethod.</div>
<div> </div>
<div>Furthermore, as i am doing kappastatistic, the maximum function value is of course 1 for perfectly</div>
<div>gemetric aligned images. So the function value is -1 all the time(Because i told the optimizer to maximize and not nminimize. But still, it does first convergeafter the 17 iterationss in the top pyramid. And the same for the rest of the pyramid. 
</div>
<div>Here is the result from a 2-layered pyramid.......</div>
<div> </div>
<div><font size="2">
</font><p><font size="2">Iteration count : 0</font></p>
<p><font size="2">///////////////////////////////////////////////////////////</font></p>
<p><font size="2">Pyramid level0</font></p>
<p><font size="2">///////////////////////////////////////////////////////////</font></p>
<p><font size="2">-1:</font></p>
<p><font size="2">//[]</font></p>
<p><font size="2">[0, 0, 0, 0, 0, 0, 1]</font></p>
<p><font size="2">-1:</font></p>
<p><font size="2">[0.00025, 0, 0, 0, 0, 0, 1]</font></p>
<p><font size="2">-1:</font></p>
<p><font size="2">[0, 0.00025, 0, 0, 0, 0, 1]</font></p>
<p><font size="2">-1:</font></p>
<p><font size="2">[0, 0, 0.00025, 0, 0, 0, 1]</font></p>
<p><font size="2">-1:</font></p>
<p><font size="2">[0, 0, 0, 0.025, 0, 0, 1]</font></p>
<p><font size="2">-1:</font></p>
<p><font size="2">[0, 0, 0, 0, 0.025, 0, 1]</font></p>
<p><font size="2">-1:</font></p>
<p><font size="2">[0, 0, 0, 0, 0, 0.025, 1]</font></p>
<p><font size="2">-1:</font></p>
<p><font size="2">[0, 0, 0, 0, 0, 0, 1.05]</font></p>
<p><font size="2">-1:</font></p>
<p><font size="2">[7.1428571429e-005, 7.1428571429e-005, 7.1428571429e-005, 0.0071428571429, 0.0071428571429, 0.0071428571429, 1.0142857143]</font></p>
<p><font size="2">-1:</font></p>
<p><font size="2">[1.7857142857e-005, 1.7857142857e-005, 1.7857142857e-005, 0.0017857142857, 0.0017857142857, 0.0017857142857, 1.0035714286]</font></p>
<p><font size="2">-1:</font></p><font size="2">
</font><p><font size="2">[0.000125, 0.000125, 0, 0, 0, 0, 1]</font></p>
<p><font size="2">-1:</font></p>
<p><font size="2">[0.000125, 0, 0.000125, 0, 0, 0, 1]</font></p>
<p><font size="2">-1:</font></p>
<p><font size="2">[0.000125, 0, 0, 0.0125, 0, 0, 1]</font></p>
<p><font size="2">-1:</font></p>
<p><font size="2">[0.000125, 0, 0, 0, 0.0125, 0, 1]</font></p>
<p><font size="2">-1:</font></p>
<p><font size="2">[0.000125, 0, 0, 0, 0, 0.0125, 1]</font></p>
<p><font size="2">-1:</font></p>
<p><font size="2">[0.000125, 0, 0, 0, 0, 0, 1.025]</font></p>
<p><font size="2">-1:</font></p>
<p><font size="2">[0.000125, 0, 0, 0, 0, 0, 1]</font></p>
<p><font size="2">Iteration count : 17</font></p>
<p><font size="2">///////////////////////////////////////////////////////////</font></p>
<p><font size="2">Pyramid level1</font></p>
<p><font size="2">///////////////////////////////////////////////////////////</font></p>
<p><font size="2">-1:</font></p>
<p><font size="2">[0.000125, 0.000125, 0, 0, 0, 0, 1]</font></p>
<p><font size="2">-1:</font></p>
<p><font size="2">[0.00025, 0.000125, 0, 0, 0, 0, 1]</font></p>
<p><font size="2">-1:</font></p>
<p><font size="2">[0.000125, 0.00025, 0, 0, 0, 0, 1]</font></p>
<p><font size="2">-1:</font></p>
<p><font size="2">[0.000125, 0.000125, 0.00025, 0, 0, 0, 1]</font></p>
<p><font size="2">-1:</font></p>
<p><font size="2">[0.000125, 0.000125, 0, 0.025, 0, 0, 1]</font></p>
<p><font size="2">-1:</font></p>
<p><font size="2">[0.000125, 0.000125, 0, 0, 0.025, 0, 1]</font></p>
<p><font size="2">-1:</font></p>
<p><font size="2">[0.000125, 0.000125, 0, 0, 0, 0.025, 1]</font></p>
<p><font size="2">-0.97433615191:</font></p>
<p><font size="2">[0.000125, 0.000125, 0, 0, 0, 0, 1.05]</font></p>
<p><font size="2">-0.96254003621:</font></p>
<p><font size="2">[0.00016071428571, 0.00016071428571, 7.1428571429e-005, 0.0071428571429, 0.0071428571429, 0.0071428571429, 0.95]</font></p>
<p><font size="2">-1:</font></p>
<p><font size="2">[0.00013392857143, 0.00013392857143, 1.7857142857e-005, 0.0017857142857, 0.0017857142857, 0.0017857142857, 1.025]</font></p>
<p><font size="2">-1:</font></p>
<p><font size="2">[0.0001875, 0.0001875, 0, 0, 0, 0, 1]</font></p>
<p><font size="2">-1:</font></p>
<p><font size="2">[0.0001875, 0.000125, 0.000125, 0, 0, 0, 1]</font></p>
<p><font size="2">-1:</font></p>
<p><font size="2">[0.0001875, 0.000125, 0, 0.0125, 0, 0, 1]</font></p>
<p><font size="2">-1:</font></p>
<p><font size="2">[0.0001875, 0.000125, 0, 0, 0.0125, 0, 1]</font></p>
<p><font size="2">-1:</font></p>
<p><font size="2">[0.0001875, 0.000125, 0, 0, 0, 0.0125, 1]</font></p>
<p><font size="2">-1:</font></p>
<p><font size="2">[0.0001875, 0.000125, 0, 0, 0, 0, 1]</font></p>
<p><font size="2">-1:</font></p>
<p><font size="2">[0.0001875, 0.000125, 0, 0, 0, 0, 1.025]</font></p>
<p><font size="2">----------------------------Registration completed-------------------</font></p>
<p><font size="2"> </font></p>
<p><font size="2">Result : </font></p>
<p><font size="2">Translation X = 0</font></p>
<p><font size="2">Translation Y = 0</font></p>
<p><font size="2">Translation Z = 0</font></p>
<p><font size="2">Rotation X = 0.70710678119</font></p>
<p><font size="2">Rotation Y = 0.70710678119</font></p>
<p><font size="2">Rotation Z = 0</font></p>
<p><font size="2">GetAngle = 0.0005303300921</font></p>
<p><font size="2">Offset = -0.021839980215 0.021839980215 -0.0025979353519</font></p>
<p><font size="2">Matrix = </font></p>
<p><font size="2">0.99999992969 7.03125e-008 0.00037499998682</font></p>
<p><font size="2">7.03125e-008 0.99999992969 -0.00037499998682</font></p>
<p><font size="2">-0.00037499998682 0.00037499998682 0.99999985938</font></p>
<p><font size="2">Offset = </font></p>
<p><font size="2">[-0.021839980215, 0.021839980215, -0.0025979353519]</font></p></div>
<div> </div>
<div>Culd someone help my. Than you very much</div></blockquote></span></div></div><br>
<br>_______________________________________________<br>Insight-users mailing list<br><a onclick="return top.js.OpenExtLink(window,event,this)" href="mailto:Insight-users@itk.org">Insight-users@itk.org</a><br><a onclick="return top.js.OpenExtLink(window,event,this)" href="http://www.itk.org/mailman/listinfo/insight-users" target="_blank">
http://www.itk.org/mailman/listinfo/insight-users</a><br><br><br></blockquote></div>