-
Notifications
You must be signed in to change notification settings - Fork 9
/
Copy pathtest_uniqueness.m
110 lines (98 loc) · 4.69 KB
/
test_uniqueness.m
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
%{
* Copyright (C) 2013-2025, The Regents of The University of Michigan.
* All rights reserved.
* This software was developed in the Biped Lab (https://www.biped.solutions/)
* under the direction of Jessy Grizzle, grizzle@umich.edu. This software may
* be available under alternative licensing terms; contact the address above.
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are met:
* 1. Redistributions of source code must retain the above copyright notice, this
* list of conditions and the following disclaimer.
* 2. Redistributions in binary form must reproduce the above copyright notice,
* this list of conditions and the following disclaimer in the documentation
* and/or other materials provided with the distribution.
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
* WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
* DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR
* ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
* ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
* The views and conclusions contained in the software and documentation are those
* of the authors and should not be interpreted as representing official policies,
* either expressed or implied, of the Regents of The University of Michigan.
*
* AUTHOR: Bruce JK Huang (bjhuang[at]umich.edu)
* WEBSITE: https://www.brucerobot.com/
%}
%%
clear, clc
target_size = 10;
objects1 = genShape("polygon", target_size, 4);
object1_mat = convertXYZstructToXYZmatrix(objects1);
object1_mat_h = converToHomogeneousCoord(object1_mat);
rpy = [0 0 0]; % in degree
xyz = [3 0 0];
moved_obj1_mat_h = moveByRPYXYZ(object1_mat_h, rpy, xyz);
objects(1).object_vertices = convertXYZmatrixToXYZstruct(moved_obj1_mat_h);
objects(1).points = [];
rpy = [0 0 90]; % in degree
xyz = [3 2 0];
moved_obj2_mat_h = moveByRPYXYZ(object1_mat_h, rpy, xyz);
objects(2).object_vertices = convertXYZmatrixToXYZstruct(moved_obj2_mat_h);
objects(2).points = [];
rpy = [0 45 45]; % in degree
xyz = [3 2 0];
moved_obj3_mat_h = moveByRPYXYZ(object1_mat_h, rpy, xyz);
objects(3).object_vertices = convertXYZmatrixToXYZstruct(moved_obj3_mat_h);
objects(3).points = [];
fig_handles = createFigHandleWithNumber(1, 1, "test");
hold(fig_handles(1), 'on')
plotMultiplePolygonsVertices(fig_handles(1), objects)
plotOriginalAxis(fig_handles(1), eye(4))
[normal1, centroid1] = computePlane(objects(1));
[normal2, centroid2] = computePlane(objects(2));
[normal3, centroid3] = computePlane(objects(3));
[P1, L1, check1] = intersectPlane(normal1, centroid1 ,normal2, centroid2);
[P2, L2, check2] = intersectPlane(normal2, centroid2 ,normal3, centroid3);
plane_intersect_point = intersect3DLine(P1,L1,P2,L2);
ring_intersect_point = plane_intersect_point + [0;0;1];
az_res = deg2rad(0.2);
r = norm(ring_intersect_point);
el = asin(ring_intersect_point(3)/r);
num_point = (2*pi/az_res);
points = zeros(4, num_point);
objects;
for i = 1:num_point
az = az_res * (i-1);
[x, y, z] = sph2cart(az, el, r);
points(:, i) = [x;y;z;1];
for j = 1:size(objects,2)
[point_in, inside_polygon] = checkInsideInsidePolygonGivenPlaneAndLine(objects(j), [0,0,0,0], [x, y, z,1]);
if inside_polygon
objects(j).points = [objects(j).points, makeColumn(point_in)];
end
end
end
%%
s = 3;
H = [s*eye(3) (1-s)*(plane_intersect_point+[0; 0; 0]); zeros(1,3), 1];
color_list = [".k", ".c", ".b"];
for i = 1:length(objects)
if isempty(objects(i).points)
continue
end
moved_points = H * objects(i).points;
scatter3(fig_handles(1), objects(i).points(1, :), objects(i).points(2, :), objects(i).points(3, :), color_list(i))
scatter3(fig_handles(1), moved_points(1, :), moved_points(2, :), moved_points(3, :), 'r.')
end
scatter3(fig_handles(1), points(1, :), points(2, :), points(3, :), 'm.')
scatter3(fig_handles(1), plane_intersect_point(1), plane_intersect_point(2), plane_intersect_point(3), 'om', 'fill')
scatter3(fig_handles(1), ring_intersect_point(1), ring_intersect_point(2), ring_intersect_point(3), 'og', 'fill')
plotALine(fig_handles(1), L1, P1, -5, 5)
plotALine(fig_handles(1), L2, P2, 0, 10)
viewCurrentPlot(fig_handles(1), [],[-34,19])
disp("done")