I am using image registration toolbox to register two 3D images. I register the moving image to the fixed image. I use "imregtform" to save tform.
tform = imregtform(moving,fixed,transformType,optimizer,metric)
for example this is my 'tform':
    1.0235    0.0022   -0.0607         0
   -0.0276    1.0002    0.0089         0
   -0.0170   -0.0141    1.1685         0
   12.8777    5.0311  -70.0325    1.0000
then I use 'Imwarp' to transfer moving image to the fixed image. In my code it is,
nii=load_untouch_nii(['mypath image.nii' ]);
I = nii.img; 
dii=nii.hdr.dime.pixdim(2:4);
Rfixed=imref3d(size(I),dii(2),dii(1),dii(3)); 
timg= imwarp(I, Rfixed, tform, 'OutputView', Rfixed);
'timg' is transfered image of source image.I checked it and it is working fine, but I need control points or displacement field of this transformation now. In another word, I need to know each voxel(3d pixel) moved to which position. If I know this I can draw vector field. In deformable image registartion methods such as NiftyReg package, control point command is provided to make it easy for users but I do not know how to do it in simple 3d affine in Matlab. Any help will be appreciated too much
You can apply your geometric transform to a single point very easily.
You just need to have your point defined as p=[x;y;z;1]
and then obtain pt by pt=p*tform; pt=pt(1:3)./pt(4); (search for homogeneous coordinates for explanation of this last division). This is what imwarp does in the inside. It performs the said multiplication for each pixel p.
To then obtain the displacement, you would need just to disp=pt-p;. Note that the displacements are most likely not integer.
Note that in the field of deformable image registration, generally you will have a different tform for each control point (that is why it is called deformable and not rigid)
EDIT: as @Ashish Uthama suggests in the comments, you can also do it with Matlab inbuilt function transformpointsforward(). I will always be a promoter of "writing your own code" philosophy, specially the first time, so you do understand what are you actually doing.
http://uk.mathworks.com/help/images/ref/affine3d.transformpointsforward.html
来源:https://stackoverflow.com/questions/30240436/how-to-get-displacement-field-or-control-point-vector-when-we-have-tfrom