生成网格并优化三角形的网格

时间:2019-12-17 21:50:52

标签: matlab math matrix physics-engine

我需要找到一种方法来对三角形进行网格划分,然后使用优化进行优化。 我原始三角形的顶点存储在大小为nb_points * 2的矩阵内。 我的脸部存储在nb_faces * 3矩阵中。 每个面部的数据存储在nb_face * 1矩阵中。 网格划分是通过使用三角形线段的中间对区域进行潜水来完成的。

示例: 来源:

vertices = [0 1 ; 
            2 3 ; 
            4 1 ;
            4 5];
faces = [1 2 3;
         2 3 4];
data = [1 2]; 

Picture of the figure

啮合后预期结果:

vertices = [0 1; 
            2 3; 
            4 1;
            4 5;
            1 2;
            3 2;
            2 1;
            3 4;
            4 3];
faces = [1 5 7;
         2 5 6;
         5 6 7;
         7 6 3;
         2 6 8;
         6 8 9;
         6 9 3;
         8 4 9];
data = [1 1 1 1 2 2 2 2];

Picture of the new figure

我正在使用:

FV.Vertices = vertices; 
FV.Faces = faces; 
FV.FaceVertexCData = data;
figure; hold on; axis equal; grid on;
patch(FV,'FaceColor','flat');

精度: 我不想使用下面的函数,这些函数会导致过多的顶点和面:

数据是温度,因为这是传热的模拟。

1 个答案:

答案 0 :(得分:0)

使用for循环可以很容易地完成,这是一种解决方案:

% Dummy data
vertices = [0 1 ; 
            2 3 ; 
            4 1 ;
            4 5];
faces = [1 2 3;
         2 3 4];
data = [1 2]; 

% Number of vertices
vnum = size(vertices,1);

% new faces empty vector
nfaces = [];

% triangular shift
tshift = [2,-1,-1].';

% Run the algorithm
for ii = 1:size(faces,1)
    % For each triangle get the 3 pairs of vertices
    nsk = [faces(ii,1), faces(ii,2);faces(ii,2), faces(ii,3);faces(ii,3), faces(ii,1)];
    % Compute the center of each pair of vertices
    cmiddle = (vertices(nsk(:,1),:)+vertices(nsk(:,2),:))/2
    % Compute the new faces
    nfaces = [nfaces;[nsk(:,1),vnum+(ii*3-3+[1:3].'),vnum+(ii*3-3+[1:3].')+tshift];[(vnum+(ii*3-2)):(vnum+(ii*3))]]
    % Add the new vertices
    vertices = [vertices;cmiddle];
end

% Delete the duplicate vertices
[vertices,~,ind] = unique(vertices,'rows');
faces = ind(nfaces);

% Plot
figure; hold on; axis equal; grid on;
patch('Faces',faces,'Vertices',vertices,'FaceVertexCData',kron(data,ones(1,4)).','FaceColor','flat')
colorbar

如果您找到了一种无需for循环即可生成nsk向量的方法,那么您甚至可以摆脱循环。该代码仅适用于三角形,但是可以根据需要进行修改。

结果:

enter image description here

您可以重复操作:

enter image description here