亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? mesh2d.m

?? 一個(gè)功能強(qiáng)大的非結(jié)構(gòu)網(wǎng)格劃分程序,可實(shí)現(xiàn)網(wǎng)格的自動剖分,及局部加密與質(zhì)量控制
?? M
?? 第 1 頁 / 共 2 頁
字號:
[p,wndx] = project2poly(p,find(~in&ok),edgexy);     

% Find the closest node in P for each FIXED node and replace P(i,:) with
% FIXED(i,:)
fix = zeros(size(fixed,1),1);
for k = 1:size(ndx,1)
   
   x = fixed(k,1);
   y = fixed(k,2);

   if isnan(ndx(k))
      % Slow search for all p(ok,:)
      [tmp,tmp] = min( (p(ok,1)-x).^2+(p(ok,2)-y).^2 );
      fix(k) = tmp;
   else
      % Search nodes in ndx(k)
      d = inf;
      j = 1;
      while j<=3
         cn = t(ndx(k),j);
         if ok(cn)
            dkj = (p(cn,1)-x)^2+(p(cn,2)-y)^2;
            if dkj<d
               fix(k) = cn;
               d = dkj;
            end
         end
         j = j+1;
      end
   end
   
   if fix(k)==0      
      % Slow search for all p(ok,:)
      [tmp,tmp] = min( (p(ok,1)-x).^2+(p(ok,2)-y).^2 );
      fix(k) = tmp;
   end

end
p(fix,:) = fixed;

% Take internal nodes
p = p(ok,:);

% Re-index to keeps lists consistent
wndx = wndx(ok);
j = zeros(length(ok),1);
j(ok) = 1;
j = cumsum(j);
t = j(t(tin,:));
fix = j(fix);
tndx = zeros(size(p,1),1);


%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
function [e,bnd] = getedges(t,n)

% Get the unique edges and boundary nodes in a triangulation.

e = [t(:,[1,2]); t(:,[1,3]); t(:,[2,3])];                                  % Non-unique edges

swap = e(:,2)<e(:,1);                                                      % Ensure e(:,1) contains the lower value
e(swap,:) = e(swap,[2,1]);

e = sortrows(e);
idx = all(diff(e,1)==0,2);                                                 % Find shared edges
idx = [idx;false]|[false;idx];                                             % True for all shared edges
bnde = e(~idx,:);                                                          % Boundary edges
e = e(idx,:);                                                              % Internal edges
e = [bnde; e(1:2:end-1,:)];                                                % Unique edges and bnd edges for tri's

bnd = false(n,1);                                                          % True for boundary nodes
bnd(bnde) = true;


%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
function [p,ndxnew] = project2poly(p,bnd,edgexy,ndx)

% Project the points in P(BND) onto the closest edge of the polygon defined
% by the edge segments in EDGEXY. NDX is an optional argument defining
% the edge to project onto: P(BND) is projected onto EDGEXY(NDX(BND)).

% Uses (something like?) a double sweep-line approach to reduce the number
% of edges that are required to be tested in order to determine the closest
% edge for each point. On average only size(EDGEXY)/4 comparisons need to
% be made for each point.

if nargin<4 || isempty(ndx)
   ndx = zeros(size(p,1),1);
end
ndxnew = zeros(size(p,1),1);
todo = true(size(bnd));

% Check NDX first
for k = 1:length(bnd)
   cn = bnd(k);
   if ndx(cn)>0
      j = ndx(cn);

      x1 = edgexy(j,1); x2mx1 = edgexy(j,3)-x1;
      y1 = edgexy(j,2); y2my1 = edgexy(j,4)-y1;

      r = ((p(cn,1)-x1)*x2mx1+(p(cn,2)-y1)*y2my1)/(x2mx1^2+y2my1^2);
      if (r>0) && (r<1)
         todo(k) = false;
         p(cn,1) = x1+r*x2mx1;
         p(cn,2) = y1+r*y2my1;
         ndxnew(cn) = j;
      end

   end
end

% Do a full search for points not already projected
if any(todo)

   bnd = bnd(todo);

   % Choose the direction with the biggest range as the "y-coordinate" for the
   % test. This should ensure that the sorting is done along the best
   % direction for long and skinny problems wrt either the x or y axes.
   dxy = max(p)-min(p);
   if dxy(1)>dxy(2)
      % Flip co-ords if x range is bigger
      p = p(:,[2,1]);
      edgexy  = edgexy(:,[2,1,4,3]);
      flip = true;
   else
      flip = false;
   end

   % Ensure edgexy(:,[1,2]) contains the lower y value
   swap = edgexy(:,4)<edgexy(:,2);
   edgexy(swap,:) = edgexy(swap,[3,4,1,2]);

   % Sort edges
   [ilower,ilower] = sort(edgexy(:,2));                                    % Sort edges by lower y value
   edgexy_lower = edgexy(ilower,:);
   [iupper,iupper] = sort(edgexy(:,4));                                    % Sort edges by upper y value
   edgexy_upper = edgexy(iupper,:);

   % Mean edge y value
   ne = size(edgexy,1);
   ymean = 0.5*( sum(sum(edgexy(:,[2,4]))) )/ne;

   % Loop through points
   for k = 1:length(bnd)

      cn = bnd(k);
      x = p(cn,1);
      y = p(cn,2);
      d = inf;

      if y<ymean

         % Loop through edges bottom up
         for j = 1:ne
            y2 = edgexy_lower(j,4);
            if y2>=(y-d)
               y1 = edgexy_lower(j,2);
               if y1<=(y+d)

                  % Calculate the distance along the normal projection from [x,y] to the jth edge
                  x1 = edgexy_lower(j,1); 
                  x2mx1 = edgexy_lower(j,3)-x1;
                  y2my1 = y2-y1;

                  r = ((x-x1)*x2mx1+(y-y1)*y2my1)/(x2mx1^2+y2my1^2);
                  if r>1                                                   % Limit to wall endpoints
                     r = 1;
                  elseif r<0
                     r = 0;
                  end
                  xn = x1+r*x2mx1;
                  yn = y1+r*y2my1;

                  dj = (xn-x)^2+(yn-y)^2;
                  if ( dj<d^2 )
                     d = sqrt(dj);
                     p(cn,1) = xn;
                     p(cn,2) = yn;
                     ndxnew(cn) = ilower(j);
                  end

               else
                  break
               end
            end
         end

      else

         % Loop through edges top down
         for j = ne:-1:1
            y1 = edgexy_upper(j,2);
            if y1<=(y+d)
               y2 = edgexy_upper(j,4);
               if y2>=(y-d)

                  % Calculate the distance along the normal projection from [x,y] to the jth edge
                  x1 = edgexy_upper(j,1); 
                  x2mx1 = edgexy_upper(j,3)-x1;
                  y2my1 = y2-y1;

                  r = ((x-x1)*x2mx1+(y-y1)*y2my1)/(x2mx1^2+y2my1^2);
                  if r>1                                                   % Limit to wall endpoints
                     r = 1;
                  elseif r<0
                     r = 0;
                  end
                  xn = x1+r*x2mx1;
                  yn = y1+r*y2my1;

                  dj = (xn-x)^2+(yn-y)^2;
                  if ( dj<d^2 )
                     d = sqrt(dj);
                     p(cn,1) = xn;
                     p(cn,2) = yn;
                     ndxnew(cn) = iupper(j);
                  end

               else
                  break
               end
            end
         end

      end

   end

   if flip
      p = p(:,[2,1]);
   end

end


%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
function [mlim,maxit,dhmax,output] = getoptions(options)

% Extract the user defined options

if ~isempty(options)
   if ~isstruct(options)
      error('OPTIONS must be a structure array');
   end
   if numel(options)~=1
      error('Options cannot be an array of structures');
   end
   fields = fieldnames(options);
   names = {'mlim','maxit','dhmax','output'};
   for k = 1:length(fields)
      if strcmp(fields{k},names)
         error('Invalid field in OPTIONS');
      end
   end
   if isfield(options,'mlim')                                              % Movement tolerance
      mlim = checkposscalar(options.mlim,'options.mlim');
   else
      mlim = 0.05;
   end
   if isfield(options,'maxit')                                             % Maximum iterations
      maxit = round(checkposscalar(options.maxit,'options.maxit'));
   else
      maxit = 20;
   end
   if isfield(options,'dhmax')                                             % Size function gradient limit
      dhmax = checkposscalar(options.dhmax,'options.dhmax');
   else
      dhmax = 0.3;
   end
   if isfield(options,'output')                                            % Output on/off
      output = checklogicalscalar(options.output,'options.output');
   else
      output = true;
   end
else                                                                       % Default values
   mlim = 0.05;
   maxit = 20;
   dhmax = 0.3;
   output = true;
end


%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
function var = checkposscalar(var,name)

% Helper function to check if var is a positive scalar.

if var<0 || any(size(var)>1)
   error([name,' must be a positive scalar']);
end


%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
function var = checklogicalscalar(var,name)

% Helper function to check if var is a logical scalar.

if ~islogical(var) || any(size(var)>1)
   error([name,' must be a logical scalar']);
end

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
蜜臀av一区二区三区| 国产精品大尺度| av电影在线观看不卡| 视频一区中文字幕| 中文子幕无线码一区tr| 欧美变态口味重另类| 在线免费精品视频| hitomi一区二区三区精品| 麻豆精品一区二区| 午夜电影久久久| 亚洲精品中文在线观看| 国产日韩欧美在线一区| 91精品国产一区二区三区香蕉| 成人一区二区三区视频| 韩国毛片一区二区三区| 日韩不卡免费视频| 亚洲狠狠爱一区二区三区| 一色屋精品亚洲香蕉网站| 久久久久久久久久久电影| 欧美久久久久久久久久| 欧美最猛性xxxxx直播| 成人h精品动漫一区二区三区| 久久99热这里只有精品| 日韩精品免费视频人成| 亚洲1区2区3区4区| 亚洲第一电影网| 亚洲综合一区二区| 亚洲日本免费电影| 亚洲黄网站在线观看| 中文字幕一区二区不卡| 1区2区3区欧美| 中文字幕一区二区三区四区不卡| 中文字幕国产一区| 中文在线资源观看网站视频免费不卡| 久久久精品中文字幕麻豆发布| 精品少妇一区二区三区免费观看 | 国产酒店精品激情| 另类调教123区| 加勒比av一区二区| 精品一区二区三区在线观看| 精久久久久久久久久久| 国产精品18久久久久久久久久久久 | 久久99国产精品麻豆| 久久精品久久久精品美女| 日韩av网站免费在线| 日本vs亚洲vs韩国一区三区| 麻豆一区二区99久久久久| 精品在线亚洲视频| 国产伦精品一区二区三区免费迷| 国产米奇在线777精品观看| 国产一区二区三区在线看麻豆| 国产美女视频91| 不卡的av电影| 91福利资源站| 欧美一级免费观看| 久久中文字幕电影| 国产精品久久久久久妇女6080| 中文字幕在线观看一区二区| 亚洲欧美日韩小说| 亚洲精品日日夜夜| 午夜精品视频在线观看| 久久97超碰色| 成人av一区二区三区| 欧美性高清videossexo| 日韩欧美一二三四区| 国产女人水真多18毛片18精品视频| 综合电影一区二区三区| 亚洲福中文字幕伊人影院| 久久精品999| av激情亚洲男人天堂| 欧美日韩大陆一区二区| 精品国产乱码久久久久久影片| 国产婷婷精品av在线| 亚洲一区中文在线| 黄色资源网久久资源365| 99久久精品免费观看| 91麻豆精品国产91久久久久久 | 亚洲综合视频网| 国精产品一区一区三区mba桃花| 岛国精品在线观看| 911精品国产一区二区在线| 久久精品一区四区| 亚洲激情在线播放| 奇米一区二区三区| 99re这里只有精品首页| 91久久精品一区二区二区| 色综合天天性综合| 日韩欧美国产综合一区| 国产精品久久久久久久久免费相片 | 亚洲午夜精品一区二区三区他趣| 久久国产精品72免费观看| 91浏览器打开| 精品粉嫩aⅴ一区二区三区四区 | 丁香婷婷综合激情五月色| 精品视频1区2区| 中文字幕精品综合| 精品一区二区三区视频| 欧美在线综合视频| 中文字幕不卡一区| 久久电影网站中文字幕| 欧美午夜视频网站| 亚洲三级视频在线观看| 激情五月播播久久久精品| 欧美日韩国产区一| 亚洲六月丁香色婷婷综合久久 | 一区二区三区蜜桃网| 国产精品一卡二卡| 欧美一级高清片| 午夜精品一区二区三区电影天堂 | 蜜臀av一区二区| 欧美性生活影院| 亚洲私人影院在线观看| 成人久久久精品乱码一区二区三区 | 国产中文字幕精品| 日韩欧美视频一区| 日韩福利电影在线| 在线这里只有精品| 亚洲精品高清在线| 91丨九色丨国产丨porny| 国产欧美一区二区精品婷婷| 国模套图日韩精品一区二区 | 在线综合+亚洲+欧美中文字幕| 一区二区三区不卡在线观看| 国产91综合网| 国产欧美日韩中文久久| 国产一区免费电影| 久久嫩草精品久久久精品| 激情综合色丁香一区二区| 91精品国产综合久久精品app| 香蕉加勒比综合久久| 欧美一a一片一级一片| 夜夜嗨av一区二区三区网页| 色综合天天做天天爱| 亚洲精品免费在线播放| 91小宝寻花一区二区三区| 亚洲美腿欧美偷拍| 色综合久久中文字幕| 亚洲精品成人a在线观看| 欧洲一区二区av| 亚洲大片精品永久免费| 欧美疯狂做受xxxx富婆| 男男gaygay亚洲| 亚洲精品一区二区三区四区高清| 久久www免费人成看片高清| 欧美精品一区二区三区很污很色的| 久久精品久久久精品美女| 久久精品夜夜夜夜久久| 国产a区久久久| 亚洲乱码国产乱码精品精的特点| 欧美性色综合网| 日本不卡视频一二三区| 久久久久久**毛片大全| 99久久国产综合精品色伊| 亚洲精品国久久99热| 欧美日本乱大交xxxxx| 久久草av在线| 国产精品久久久久久久岛一牛影视| 色伊人久久综合中文字幕| 亚洲va国产天堂va久久en| 欧美一卡2卡三卡4卡5免费| 国产一区二区看久久| 亚洲美腿欧美偷拍| 欧美一区二区三区四区在线观看| 韩国v欧美v日本v亚洲v| 综合色中文字幕| 538prom精品视频线放| 国产一区二三区| 亚洲影院理伦片| 久久综合九色综合欧美98| 99久久久国产精品免费蜜臀| 舔着乳尖日韩一区| 国产片一区二区| 91官网在线免费观看| 狠狠网亚洲精品| 亚洲综合清纯丝袜自拍| 日韩免费电影一区| 97国产精品videossex| 日本中文字幕不卡| 中文字幕一区在线| 日韩女优视频免费观看| av不卡免费在线观看| 免费观看成人av| 中文字幕日韩一区| 欧美电影免费观看完整版| 972aa.com艺术欧美| 狠狠久久亚洲欧美| 亚洲午夜私人影院| 国产精品色在线观看| 欧美一区二区日韩一区二区| 福利电影一区二区三区| 日本不卡在线视频| 亚洲另类春色校园小说| 久久新电视剧免费观看| 欧美色网一区二区| 国产福利视频一区二区三区| 日本欧洲一区二区| 亚洲麻豆国产自偷在线| 久久久蜜桃精品| 欧美男男青年gay1069videost | 久久众筹精品私拍模特|