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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? quadtree.m

?? 一個功能強大的非結構網格劃分程序,可實現網格的自動剖分,及局部加密與質量控制
?? M
?? 第 1 頁 / 共 2 頁
字號:
      if h(n1)>h(n2)                                                       % Ensure grad(h)<=dhmax
         dh = (h(n1)-h(n2))/L(k);
         if dh>dhmax
            h(n1) = h(n2) + dhmax*L(k);
         end
      else
         dh = (h(n2)-h(n1))/L(k);
         if dh>dhmax
            h(n2) = h(n1) + dhmax*L(k);
         end
      end
   end
   if norm((h-h_old)./h,inf)<tol                                           % Test convergence
      break
   end
end

waitbar(0.75,wbar,'Triangulating quadtree');

t = MyDelaunayn(p);

waitbar(1,wbar);


%% SUB-FUNCTIONS
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
function L = dist2poly(p,edgexy,lim)

% Find the minimum distance from the points in P to the polygon defined by
% the edges in EDGEXY. LIM is an optional argument that defines an upper
% bound on the distance for each point.

% 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<3
   lim = [];
end
np = size(p,1);
ne = size(edgexy,1);
if isempty(lim)
   lim = inf*ones(np,1);
end

% 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]);
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
[i,i]          = sort(edgexy(:,2));                                        % Sort edges by lower y value
edgexy_lower   = edgexy(i,:);
[i,i]          = sort(edgexy(:,4));                                        % Sort edges by upper y value
edgexy_upper   = edgexy(i,:);

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

% Alloc output
L = zeros(np,1);

% Loop through points
tol = 100*eps*max(dxy);
for k = 1:np

   x = p(k,1);
   y = p(k,2);
   d = lim(k);

   if y<ymean

      % Loop through edges bottom up
      for j = 1:ne
         ymax = edgexy_lower(j,4);
         if ymax>=(y-d)
            ymin = edgexy_lower(j,2);
            if ymin<=(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;
               y1 = ymin;              y2my1 = ymax-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

               dj = (x1+r*x2mx1-x)^2+(y1+r*y2my1-y)^2;
               if (dj<d^2) && (dj>tol)
                  d = sqrt(dj);
               end

            else
               break
            end
         end
      end

   else

      % Loop through edges top down
      for j = ne:-1:1
         ymin = edgexy_upper(j,2);
         if ymin<=(y+d)
            ymax = edgexy_upper(j,4);
            if ymax>=(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;
               y1 = ymin;              y2my1 = ymax-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

               dj = (x1+r*x2mx1-x)^2+(y1+r*y2my1-y)^2;
               if (dj<d^2) && (dj>tol)
                  d = sqrt(dj);
               end

            else
               break
            end
         end
      end

   end

   L(k) = d;

end

%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
function h = userhfun(x,y,fun,args,hmax,xymin,xymax)

% Evaluate user defined size function.

if ~isempty(fun)
   h = feval(fun,x,y,args{:});
   if size(h)~=size(x)
      error('Incorrect user defined size function. SIZE(H) must equal SIZE(X).');
   end
else
   h = inf*ones(size(x));
end
h = min(h,hmax);

% Limit to domain
out = (x>xymax(1))|(x<xymin(1))|(y>xymax(2))|(y<xymin(2));
h(out) = inf;

if any(h<=0)
   error('Incorrect user defined size function. H must be positive.');
end

%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
function [hmax,edgeh,fun,args] = gethdata(hdata)

% Check the user defined size functions

if ~isempty(hdata)
   if ~isstruct(hdata)
      error('HDATA must be a structure');
   end
   if numel(hdata)~=1
      error('HDATA cannot be an array of structures');
   end
   fields = fieldnames(hdata);
   names = {'hmax','edgeh','fun','args'};
   for k = 1:length(fields)
      if ~any(strcmp(fields{k},names))
         error('Invalid field in HDATA');
      end
   end
   if isfield(hdata,'hmax')
      if (numel(hdata.hmax)~=1) || (hdata.hmax<=0)
         error('HDATA.HMAX must be a positive scalar');
      else
         hmax = hdata.hmax;
      end
   else
      hmax = inf;
   end
   if isfield(hdata,'edgeh')
      if (numel(hdata.edgeh)~=2*size(hdata.edgeh,1)) || any(hdata.edgeh(:)<0)
         error('HDATA.EDGEH must be a positive Kx2 array');
      else
         edgeh = hdata.edgeh;
      end
   else
      edgeh = [];
   end
   if isfield(hdata,'fun')
      if ~ischar(hdata.fun) && ~isa(hdata.fun,'function_handle')
         error('HDATA.FUN must be a function name or a function handle');
      else
         fun = hdata.fun;
      end
   else
      fun = '';
   end
   if isfield(hdata,'args')
      if ~iscell(hdata.args)
         error(['HDATA.ARGS must be a cell array of additional' ...
            'inputs for HDATA.FUN']);
      else
         args = hdata.args;
      end
   else
      args = {};
   end
else
   hmax = inf;
   edgeh = [];
   fun = '';
   args = {};
end

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
av在线播放一区二区三区| 尤物av一区二区| 国产在线看一区| 欧美一级欧美一级在线播放| 亚洲h在线观看| 欧美性大战久久| 五月天欧美精品| 91高清视频在线| 偷窥国产亚洲免费视频| 欧美日韩午夜精品| 日产国产欧美视频一区精品| 欧美日韩激情一区二区三区| 日韩高清不卡一区二区三区| 欧美一级理论片| 午夜精品免费在线| 久久久影视传媒| 99久久国产综合精品女不卡| 综合激情成人伊人| 欧美亚洲动漫制服丝袜| 亚洲国产中文字幕在线视频综合| 色婷婷综合在线| 偷窥国产亚洲免费视频| 精品日本一线二线三线不卡| 国产精品一卡二卡在线观看| 欧美极品少妇xxxxⅹ高跟鞋| 97久久超碰国产精品| 精品国产乱码久久久久久1区2区| 国产精品99久久久| 综合久久久久久| 欧美夫妻性生活| 成人永久免费视频| 亚洲成人精品一区二区| 精品欧美黑人一区二区三区| 久久av资源网| 国产精品伦一区二区三级视频| 91黄视频在线| 韩国一区二区在线观看| 中文字幕在线观看不卡| 欧美巨大另类极品videosbest | 97se亚洲国产综合自在线不卡| 亚洲综合色在线| 精品免费99久久| 97se亚洲国产综合自在线| 久久99国产精品久久99| 亚洲女人小视频在线观看| 精品成人一区二区三区四区| 欧美日韩情趣电影| 成人99免费视频| 韩国精品久久久| 亚洲1区2区3区4区| 樱桃国产成人精品视频| 久久久久久毛片| 欧美不卡视频一区| 在线播放中文字幕一区| 在线亚洲高清视频| 成人app在线观看| 国产精品原创巨作av| 九色|91porny| 蜜臀av性久久久久av蜜臀妖精| 亚洲国产成人高清精品| 伊人一区二区三区| 亚洲色图19p| 亚洲欧美乱综合| 最近中文字幕一区二区三区| 亚洲国产精品成人综合色在线婷婷| 91精品在线观看入口| 欧美性色黄大片| 在线观看中文字幕不卡| 99久久伊人网影院| 99久久久久久99| 91麻豆文化传媒在线观看| 91在线视频在线| 91视频xxxx| 欧美性xxxxx极品少妇| 99久久99精品久久久久久| 99久久国产免费看| 色综合视频在线观看| 成人深夜视频在线观看| 不卡的av电影| 99re66热这里只有精品3直播| 国产.欧美.日韩| 国产传媒日韩欧美成人| 国产精品99久久久久久久女警| 国产久卡久卡久卡久卡视频精品| 国产一区二区三区电影在线观看| 国产精品99久久久| 99久久精品情趣| 在线观看视频91| 欧美少妇性性性| 欧美一区二区久久久| 久久久久久亚洲综合影院红桃| 国产欧美一区二区精品性色| 中日韩免费视频中文字幕| 一区在线观看免费| 午夜激情久久久| 久久99九九99精品| 成人午夜电影小说| 91小视频在线观看| 91精品国产综合久久久久久久久久 | 91精品国产综合久久精品麻豆| 在线播放欧美女士性生活| 91精品国产综合久久久久久漫画| 久久女同精品一区二区| 亚洲视频狠狠干| 免费看黄色91| 不卡的av电影在线观看| 欧美精品乱人伦久久久久久| 欧美videos大乳护士334| 国产欧美日韩视频一区二区| 一区二区不卡在线视频 午夜欧美不卡在| 亚洲国产精品久久人人爱| 精品中文字幕一区二区小辣椒| 成+人+亚洲+综合天堂| 欧美美女一区二区| 中文字幕精品一区二区精品绿巨人| 一区二区免费看| 国产一区高清在线| 在线观看日韩高清av| 久久久蜜桃精品| 午夜电影网亚洲视频| 成人免费视频免费观看| 4438x成人网最大色成网站| 国产精品人成在线观看免费| 香蕉成人伊视频在线观看| 成人精品电影在线观看| 日韩一区二区免费高清| 亚洲日本在线天堂| 国产一区二区三区免费| 在线播放视频一区| 亚洲人成亚洲人成在线观看图片| 久久爱www久久做| 欧美日韩国产中文| 中文字幕亚洲一区二区av在线| 日韩成人精品在线观看| 91理论电影在线观看| 久久久久亚洲蜜桃| 琪琪一区二区三区| 欧美日韩免费观看一区三区| 国产精品白丝在线| 国产精品一二三四| 日韩欧美国产系列| 丝袜诱惑制服诱惑色一区在线观看| 国产专区综合网| 欧美日本国产一区| 欧美日韩一二三区| 亚洲欧美成aⅴ人在线观看| 国产suv精品一区二区三区 | 欧美影院一区二区三区| 日韩精品电影一区亚洲| 色婷婷久久一区二区三区麻豆| 欧美国产成人精品| 国产美女av一区二区三区| 欧美一级国产精品| 免费成人深夜小野草| 欧美午夜精品理论片a级按摩| 成人欧美一区二区三区白人 | 日韩国产精品大片| 欧美人狂配大交3d怪物一区| 亚洲影院免费观看| 色综合久久88色综合天天| 日韩美女视频19| 99re热这里只有精品视频| 中文字幕中文字幕一区二区| 国产成+人+日韩+欧美+亚洲| 欧美大片国产精品| 精品一区二区三区的国产在线播放| 欧美视频一区二| 日韩国产在线观看| 欧美一区二区成人6969| 日韩成人一级大片| 51精品秘密在线观看| 天堂精品中文字幕在线| 在线成人av网站| 久久er精品视频| 国产片一区二区| av成人老司机| 亚洲精品视频在线观看免费 | 成人国产精品免费网站| 中文字幕中文在线不卡住| 91麻豆福利精品推荐| 一区二区三区不卡视频在线观看| 欧美中文字幕一二三区视频| 亚洲va欧美va国产va天堂影院| 欧美年轻男男videosbes| 裸体歌舞表演一区二区| 久久久av毛片精品| 99麻豆久久久国产精品免费| 亚洲综合丁香婷婷六月香| 欧美精品v日韩精品v韩国精品v| 男男视频亚洲欧美| 久久久www成人免费无遮挡大片| 成人高清视频在线| 午夜精品久久久久久久99樱桃| 日韩亚洲欧美在线观看| 国产精品91xxx| 一片黄亚洲嫩模| 欧美电影精品一区二区| av激情亚洲男人天堂| 丝袜国产日韩另类美女| 久久中文字幕电影|