[Insight-users] image orientation and registration, current status ? : STATUS UPDATE

Luis Ibanez luis.ibanez at kitware.com
Fri Feb 1 15:31:09 EST 2008



Just to clarify on the status of this problem:


1) Today: itkImage accepts, and carries Direction
    but *does not* take it into account when
    converting between indexes and physical points.


2) Today: itkOrientedImage accepts, and carries
    Direction *and* takes it into account when
    converting between indexes and physical points.


3) Today: Computation of derivatives *by default*
    do not take image direction into account. BUT,
    if you turn the following CMake option ON:

        ITK_USE_ORIENTED_IMAGE_DIRECTION

    Then they will offer the option of

          UseImageDirectionOn / Off

    *and* if you use them on itkOrientedImages
    then they will compute the derivatives by
    taking orientation into account.


4) The comments regarding the inconsistency of
    the API are justified, and we can simply say
    "shame on use" because we failed to retain
    image direction into the image when we removed
    the default affine transform that was originally
    mapping from indexes to points in the very early
    stage of the project.


5) Image registration of oriented images can be done
    correctly today in ITK by doing:

     A) Turn  "ITK_USE_ORIENTED_IMAGE_DIRECTION"   ON
     B) Using itkOrientedImage instead of itkImage

             ...It is not ideal...
             ...It is not pretty...

    But it is the compromise we reached when trying to
    fix the bug and at the same time maintain backward
    compatibility.


6) Registration of oriented images is tested Nightly
    in all machines that have the above CMake flag
    turned on. (e.g. Zion, Redwall).



7) This is the behavior that we are planning to
    ship with ITK 3.6.


8) If there is enough support from the users community,
    it will be great to fix this the right way in ITK 4.0.

    [That means that some level of backward compatibility
     may need to be sacrificed in the interest of removing
     the current misleading/inconsistent API]




   Regards,


       Luis



--------------------
Rupert Brooks wrote:
> Yes the OrientedImage derivative problem is troublesome.
> 
> If your images are small enough, and your transformation is simple
> enough, the easiest way around it is to use an optimizer that does not
> need derivatives.  Powell's would probably be my choice.  This
> approach gets slow for any sort of complex problem, unfortunately.
> 
> I wrote an Insight Journal paper on the topic that may interest you,
> with some code.  I use the classes in it on a daily basis, so i am
> quite confident in them.  However, you would have to modify the code
> of your metrics.
> http://insight-journal.org/midas/handle.php?handle=1926/1293
> 
> I've also been poring over the code for the multithreaded/optimized
> metrics (it is now in the Review directory in CVS)  It seems to have a
> general gradient method where the problem probably COULD be corrected.
> (http://hdl.handle.net/1926/566)
> 
> Please understand, i am just reading, not developing those
> multithreaded metrics, so I cannot say for sure if they correct this
> problem or not. Perhaps someone working on that project can advise.
> 
> Cheers,
> Rupert B.
> 
> 
> 
> 
> 
>>Date: Fri, 1 Feb 2008 08:17:34 -0500
>>From: "Bill Lorensen" <bill.lorensen at gmail.com>
>>Subject: Re: [Insight-users] image orientation and registration,
>>       current status ?
>>To: "Stefan Klein" <stefan at isi.uu.nl>
>>Cc: insight-users at itk.org
>>Message-ID:
>>       <4db4735c0802010517pc6f45bdw7506c29200b1d64d at mail.gmail.com>
>>Content-Type: text/plain; charset="iso-8859-1"
>>
>>The gradient problem is being corrected for itkOrientedImage. See:
>>http://public.kitware.com/Bug/view.php?id=5081
>>
>>If you need to take into account orientation, you should use
>>itkOrientedImage. Another option is to use itkImage and reorient the series
>>with itkOrientImageFilter so that both series have the same orientation.
>>
>>Bill
> 
> 


More information about the Insight-users mailing list