label.m
来自「五点差分型多重网格方法:各种插值算子的比较)」· M 代码 · 共 38 行
M
38 行
function elem = label(node,elem)% LABEL label the longest edge of each triangle as the base% % USAGE% elem = label(node,elem)%% Input:% node: coordinates of nodes% elem: element array%% Output:% elem: elem(t,1) is opposite to the longest edge%% L. Chen 10-12-2006%--------------------------------------------------------------------------% Compute length of each edge%--------------------------------------------------------------------------edgelength = zeros(size(elem)); % initialize to accelerate accessedgelength(:,1) = (node(elem(:,3),1)-node(elem(:,2),1)).^2 ... + (node(elem(:,3),2)-node(elem(:,2),2)).^2;edgelength(:,2) = (node(elem(:,1),1)-node(elem(:,3),1)).^2 ... + (node(elem(:,1),2)-node(elem(:,3),2)).^2;edgelength(:,3) = (node(elem(:,1),1)-node(elem(:,2),1)).^2 ... + (node(elem(:,1),2)-node(elem(:,2),2)).^2;%--------------------------------------------------------------------------% Re-labelling according the longest edge%--------------------------------------------------------------------------[temp,I] = max(edgelength,[],2);elem((I==2),[1 2 3]) = elem((I==2), [2 3 1]);elem((I==3),[1 2 3]) = elem((I==3), [3 1 2]);%--------------------------------------------------------------------------% End of function LABEL%--------------------------------------------------------------------------
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?