[Insight-users] Parameter scales for registration (second try)
Bradley Lowekamp
blowekamp at mail.nih.gov
Tue May 7 06:59:53 EDT 2013
Hello Joel,
I have encountered the same issue. I ended up creating my own "ScaledRegularStepGradientDescentOptimizer" derived from the an ITK one. Please find it attached. Please note, I don't think I have migrated this code to ITKv4.... but I not certain.
I reported this issue to the ITKv4 registration team, but I am not sure what happened to it.
I also tried to make the change in ITK a while ago, and a large number of the registration tests failed... not sure if the results were better or worse, they were just different.
Brad
-------------- next part --------------
A non-text attachment was scrubbed...
Name: itkScaledRegularStepGradientDescentOptimizer.h
Type: application/octet-stream
Size: 3117 bytes
Desc: not available
URL: <http://www.itk.org/pipermail/insight-users/attachments/20130507/ceb54efe/attachment-0001.obj>
-------------- next part --------------
On Apr 25, 2013, at 11:10 AM, Jo?l Schaerer <joel.schaerer at gmail.com> wrote:
> Hi all,
>
> Certain registration transforms have parameters with very different ranges of acceptable values. If uncorrected, this leads to serious problems with simple optimizers such as ITK's regular step gradient optimizer. Fortunately, ITK provides a parameter scale scheme to cope with this problem.
>
> Currently, this scheme is implemented by multiplying components of the parameter gradient by the parameter scales. The gradient vector is then uniformly scaled so that its norm is equal to the current step size.
>
> The problem with this is that it would make more sense to make larger steps in the directions along which the metric varies slowly (eg. the translations in the affine transform).
>
> My solution so far is to re-use the scale parameters to re-scale the resulting vector in the StepAlongGradient method of the itkRegularStepGradientOptimizer class:
>
> for ( unsigned int j = 0; j < spaceDimension; j++ )
> {
> newPosition[j] = currentPosition[j] + transformedGradient[j] * factor / scales[j];
> }
>
> I've made a little graph to explain the situation: http://i.imgur.com/DE6xqQ5.png
>
> Does this sound reasonable? I have good results on the particular (unfortunately confidential) transform I am currently using. However if there is interest I could test the effect on affine registration.
>
> Joel
>
> PS: I've looked briefly at the v4 optimizers. There is now a way to set the scales automatically, but the way they are used doesn't seem to have changed.
> _____________________________________
> Powered by www.kitware.com
>
> Visit other Kitware open-source projects at
> http://www.kitware.com/opensource/opensource.html
>
> Kitware offers ITK Training Courses, for more information visit:
> http://www.kitware.com/products/protraining.php
>
> Please keep messages on-topic and check the ITK FAQ at:
> http://www.itk.org/Wiki/ITK_FAQ
>
> Follow this link to subscribe/unsubscribe:
> http://www.itk.org/mailman/listinfo/insight-users
More information about the Insight-users
mailing list