How do I apply a fitgeotrans output or similar to points NOT an image?

3 Ansichten (letzte 30 Tage)
Right Grievous
Right Grievous am 18 Jun. 2016
Bearbeitet: kuroshiba am 2 Dez. 2022
Hi everybody,
I have been using the fitgeotrans function to find the best linear weighted mean transformation between two sets of points.
This works really well when I use the imwarp function to warp an image, however, I also need to perform the same transformation on x,y points - this is proving difficult.
The tform output of fitgeotrans does not seem to have any transformPointsForward method, all it has is a transformPointsInverse method, which is not useful for me.
I think I must be missing something, the fitgeotrans function is using point coordinates to calculate the transformation, so surely it should be as easy to apply this to coordinates as well as images, if not easier?
Thanks for any help,
Rod.

Antworten (1)

Catalina Vajiac
Catalina Vajiac am 24 Jun. 2016
There is a transformPointsForward function that you can use on your data points. The issue is that they are then defined in world coordinates, not intrinsic coordinates, so you must also use the worldToIntrinsic function, like this:
[B,RB]=imwarp(A,tform);
[xdataT,ydataT]=transformPointsForward(tform,xdata,ydata);
[xdataI,ydataI]=worldToIntrinsic(RB,xdataT,ydataT);
where tform is the output from fitgeotrans and RB is a spacial referencing object.
  5 Kommentare
Sudip Paudel
Sudip Paudel am 27 Mai 2020
Bearbeitet: Sudip Paudel am 27 Mai 2020
I ran into the same issue and tried this method. However, it did not work for me because I am using transformation type 'lwm'. Is there another approach to solve this issue?
kuroshiba
kuroshiba am 2 Dez. 2022
Bearbeitet: kuroshiba am 2 Dez. 2022
Thank you gentleman! I was helped by you!

Melden Sie sich an, um zu kommentieren.

Kategorien

Mehr zu Statistics and Machine Learning Toolbox finden Sie in Help Center und File Exchange

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by