data:image/s3,"s3://crabby-images/09b70/09b70de3de4f11762f729d9e30629d44aa837072" alt=""
Rotate the 3D point data about Z axis , and // OX OY
2 次查看(过去 30 天)
显示 更早的评论
Let's say: I have matrix A=[x y z] with ~60.000 point data . Please see attachment file, and figure:
data:image/s3,"s3://crabby-images/3286e/3286ee3e39de13aac5664f1013848f7a9e2fc9a9" alt=""
data:image/s3,"s3://crabby-images/2624a/2624abdf190671c449982f9926ee33e53ca07442" alt=""
data:image/s3,"s3://crabby-images/4a039/4a03971af9070a5501c4c2399d9948837eb3a860" alt=""
Question: How can I rotate the 3D point data about Z axis , and // OX OY (as illustration)? Additional, we don't know the rotation angel. I do hope the result will be like below figure.
data:image/s3,"s3://crabby-images/2ac0c/2ac0cdd5f7fa053e7d2a5c79e4b411e40ec4ec2a" alt=""
0 个评论
采纳的回答
Bruno Luong
2018-11-24
编辑:Bruno Luong
2018-11-24
xyz=load('data.txt');
xyzc = mean(xyz,1);
xyzr = xyz - xyzc;
[~,~,V] = svd(xyzr,0);
% Rotate 90°: so that the long size // to y_axis
V = V*[0 -1 0;
1 0 0;
0 0 1];
xyzr = xyzc + xyzr*V;
close all
hold on
plot3(xyz(:,1),xyz(:,2),xyz(:,3),'.b');
plot3(xyzr(:,1),xyzr(:,2),xyzr(:,3),'.r');
axis equal
xlabel('x')
ylabel('y')
zlabel('z')
view(3)
data:image/s3,"s3://crabby-images/09b70/09b70de3de4f11762f729d9e30629d44aa837072" alt=""
更多回答(0 个)
另请参阅
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!