I am using ITK-Snap’s 3D segmentation and exporting as surface mesh. I was wondering how I could “Conserve” the approximate coordinates for a specific pixel on the original object. That way I can choose a pixel with an (X,Y,Z) coordinate and then know the respective coordinates on the surface mesh after being imported into MATLAB
All proper medical image computing software applications, including ITK-Snap, saves images and meshes accurately in physical coordinate system.
You need to be careful with mesh files, because coordinate system axis directions are not standardized. The directions are almost always LPS, but there are a few exceptions. For example, ITK-Snap is an exception, it appears to save meshes in RAS coordinate system. Therefore when you load the mesh into Slicer then you need to enable “Show options” and choose “Coordinate system: RAS”. When you load the mesh file into your software then you need to convert the mesh to the physical coordinate system of your choice (which should be LPS).
You can convert between voxel (IJK) and physical (LPS) coordinate systems by multiplying homogeneous coordinates using LPSToIJK 4x4 matrix. SlicerMatlabBridge’s NRRD reader computes the matrix for you, see here.
Just a not on Matlab: We developed the Slicer Matlab Bridge for Slicer more than 10 years ago. It made sense then. Nowadays, I would recommend everyone who works in medical image computing to switch to Python. Python has larger community, more libraries, more transparency, and less limitations. Matlab is also generally unaffordable outside academia, so if you develop something at a university in Matlab, it is unlikely that you can use it later when you work for a company.
Wow! Thank you for the amazing reply. I am still a little confused though. Let’s say I start with an image series in the LPS coordinate and then I slice it to a smaller mesh. Even if you converted the coordinates of the original image to the coordinates of the mesh, they are still distorted because the coordinate grid changed (its now smaller since the mesh is just a small part of the original image). I am wondering how I can go from a known coordinate in ITK snap, say (0,0,0) to a coordinate on the mesh. The origin of the original image is no longer contained in the mesh so (0,0,0) for ITK Snap will not be (0,0,0) for the mesh
Thanks again
Images and meshes still remain in the correct physical position, regardless of how you resample or reslice. There is no distortion of any kind.
You convert from IJK coordinates to LPS by multiplying the [I, J, K, 1]
vector by IJKToLPS matrix from the left. You can get point ID from physical LPS coordinates by using a locator (that can tell point ID closest to a point position).