Translate 3D coordinates on a known surface

Hi. I would like to know if there is a way to translate each 3D coordinate (blue dots) such that they lie on a known red surface.
Below is the code:
Nodes_XFix = load("Nodes_XFix.mat");
Nodes_XFix = Nodes_XFix.Nodes_XFix;
Faces_XFix = load("Faces_XFix.mat");
Faces_XFix = Faces_XFix.Faces_XFix;
coord_XMov = load("coord_XMov.mat");
coord_XMov = coord_XMov.coord_XMov;
figure
plot3(Nodes_XFix(:,1), Nodes_XFix(:,2), Nodes_XFix(:,3),'r.','Markersize',12)
hold on
trimesh(Faces_XFix(:,:),Nodes_XFix(:,1),Nodes_XFix(:,2),Nodes_XFix(:,3),'EdgeColor','r','Linewidth',1,'Facecolor','w')
plot3(coord_XMov(:,1), coord_XMov(:,2), coord_XMov(:,3),'b.','Markersize',12)
hold off
grid off
axis equal
xlabel('x')
ylabel('y')
zlabel('z')
view([15,50,30])

7 Kommentare

Image Analyst
Image Analyst am 14 Jan. 2023
I know I've told you this before but, if you have any more questions, then attach your data and code to read it in with the paperclip icon after you read this:
We'll check back later for your attached data and screenshots of your plot(s).
Alberto Acri
Alberto Acri am 14 Jan. 2023
Bearbeitet: Alberto Acri am 14 Jan. 2023
Sorry! I forgot to attach the files!
What do you want to do with them?
LD1 = load(websave('','https://www.mathworks.com/matlabcentral/answers/uploaded_files/1263470/Nodes_XFix.mat'));
Nodes_XFix = LD1.Nodes_XFix;
LD2 = load(websave('','https://www.mathworks.com/matlabcentral/answers/uploaded_files/1263465/Faces_XFix.mat'));
Faces_XFix = LD2.Faces_XFix;
LD3 = load(websave('','https://www.mathworks.com/matlabcentral/answers/uploaded_files/1263475/coord_XMov.mat'));
coord_XMov = LD3.coord_XMov;
figure
scatter3(Nodes_XFix(:,1), Nodes_XFix(:,2), Nodes_XFix(:,3), 50, 'r.', 'MarkerFaceAlpha',0.5)
hold on
trimesh(Faces_XFix(:,:),Nodes_XFix(:,1),Nodes_XFix(:,2),Nodes_XFix(:,3),'EdgeColor','r','Linewidth',1,'Facecolor','w')
plot3(coord_XMov(:,1), coord_XMov(:,2), coord_XMov(:,3),'b.','Markersize',12)
hold off
grid off
axis equal
xlabel('x')
ylabel('y')
zlabel('z')
view([15,50,30])
.
Alberto Acri
Alberto Acri am 14 Jan. 2023
I would like the blue coordinates to be positioned on the red triangular surface.
Matt J
Matt J am 14 Jan. 2023
Hi. I would like to know if there is a way to translate each 3D coordinate (blue dots) such that they lie on a known red surface.
Do all the blue points have to translate as a single rigid body, or do they all translate independently of each other? If the latter, which point on the red surface should a blue point move to? The closest point?
Alberto Acri
Alberto Acri am 15 Jan. 2023
Do all the blue points have to translate as a single rigid body, or do they all translate independently of each other?
Each blue dot must move independently of each other.
If the latter, which point on the red surface should a blue point move to? The closest point?
Yes, each blue dot must move across the red surface to the nearest point.
Matt J
Matt J am 15 Jan. 2023
In future, please consolidate your variables into a single .mat file, as I have done here. This reduces the amount of work needed for us to download and import all your variables.

Melden Sie sich an, um zu kommentieren.

 Akzeptierte Antwort

Matt J
Matt J am 16 Jan. 2023

0 Stimmen

4 Kommentare

Hi! Thank you for your reply.
I tried using this code, but I am not sure if the input data is correct. Could you please check the code below?
Nodes_XFix = load("Nodes_XFix.mat");
Nodes_XFix = Nodes_XFix.Nodes_XFix;
Faces_XFix = load("Faces_XFix.mat");
Faces_XFix = Faces_XFix.Faces_XFix;
coord_XMov = load("coord_XMov.mat");
coord_XMov = coord_XMov.coord_XMov;
[faces2, vertices2] = point2trimesh(Faces_XFix, Nodes_XFix, 'QueryPoints', coord_XMov);
figure
plot3(Nodes_XFix(:,1), Nodes_XFix(:,2), Nodes_XFix(:,3),'r.','Markersize',12)
hold on
trimesh(Faces_XFix(:,:),Nodes_XFix(:,1),Nodes_XFix(:,2),Nodes_XFix(:,3),'EdgeColor','r','Linewidth',1,'Facecolor','w')
plot3(vertices2(:,1), vertices2(:,2), vertices2(:,3),'b.','Markersize',30)
hold off
grid off
axis equal
xlabel('x')
ylabel('y')
zlabel('z')
view([15,50,30])
because I am getting the following error:
Error using point2trimesh
Expected a string scalar or character vector for the parameter name.
Error in point2trimesh (line 127)
parser.parse(varargin{:});
I think it should be,
[faces2, vertices2] = point2trimesh('Faces',Faces_XFix,...
'Vertices',Nodes_XFix,...
'QueryPoints', coord_XMov);
Yes it works!
I also tried with another dataset (closed surface) however it gives me the following "warning":
Warning: Some input points are not referenced by the triangulation.
Do you have any idea how to solve it?
Matt J
Matt J am 17 Jan. 2023
I don't. Like I said, I've never used it before. It might help to see the complete warning message, though.

Melden Sie sich an, um zu kommentieren.

Weitere Antworten (1)

Matt J
Matt J am 15 Jan. 2023

1 Stimme

[~,I]=pdist2( Nodes_XFix, coord_XMov,'euc','Smallest',1)
coord_XMov = Nodes_XFix(I,:);

2 Kommentare

Alberto Acri
Alberto Acri am 16 Jan. 2023
Thank you for your reply @Matt J! I observed that each blue point moves to the nearest red point.
Is there a possibility to move the blue points also on the surface of the triangles (red mesh) and not only on the vertices ? See, for example, the green dots in the figure below:
Matt J
Matt J am 16 Jan. 2023
Bearbeitet: Matt J am 16 Jan. 2023
It's going to be a lot more computation. Are you sure you need a rigorous projection? Obviously as the mesh gets finer, the difference diminishes.

Melden Sie sich an, um zu kommentieren.

Produkte

Version

R2021b

Gefragt:

am 14 Jan. 2023

Kommentiert:

am 17 Jan. 2023

Community Treasure Hunt

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

Start Hunting!

Translated by