青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

eryar

PipeCAD - Plant Piping Design Software.
PlantAssistant - Translate AVEVA RVM/SP3D VUE to glTF, STEP, etc.
posts - 606, comments - 590, trackbacks - 0, articles - 0

布爾數(shù)據(jù) 邊的相交

Posted on 2023-09-27 21:52 eryar 閱讀(917) 評論(0)  編輯 收藏 引用 所屬分類: 2.OpenCASCADE

布爾數(shù)據(jù) 邊的相交

eryar@163.com

1 Introduction

在OpenCASCADE中對于邊的相交分為三類:邊與點,邊與邊,邊與面,邊與點的相交已經(jīng)歸結為點與邊的相交處理了,邊的相交主要處理邊與邊,邊與面的相交。邊與邊、邊與面的相交會引入一個新的數(shù)據(jù)結構-公共部分Common Part,用于保存重疊的公共部分數(shù)據(jù)。

2 Edge/Edge Interferences

對于兩條邊的相交是指在兩條邊的某些地方的距離小于邊的容差之和,主要分為兩種情況,一種是兩條邊只有一個交點的情況;一種是有重疊部分的情況;先看只有一個交點情況:

我們在DRAW中通過腳本構造最簡單的情況來測試。

在處理邊與邊相交的函數(shù)BOPAlgo_PaveFiller::PerformEE()中,對每兩條邊調(diào)用BOPAlgo_EdgeEdge進行求交。從這里可以看到Pave Block的使用,相當于對每兩條邊上的每對Pave Block部分進行求交。這里有一些優(yōu)化空間,目前是使用的兩個循環(huán)處理,可以嘗試使用BVH來提升一些性能。當每對Pave Block對應的點的索引號一致時,即每對Pave Block的端點重疊時,使用快速計算的算法來判斷是否有重疊。

對于邊的求交結果保存到BOPDS_InterfEE中,都會保存是哪兩條邊相交及相交的公共部分。對于相交于一點的公共部分的類型為TopAbs_VERTEX,對于有重疊部分的公共部分類型為TopAbs_EDGE:

當兩邊條有重疊部分時,如下圖所示:

如何檢測兩條邊的公共部分呢?在函數(shù)IntTools_EdgeEdge::IsCoincident()中實現(xiàn):

//=======================================================================
//function :  IsCoincident
//purpose  : 
//=======================================================================
Standard_Boolean IntTools_EdgeEdge::IsCoincident() 
{
  Standard_Integer i, iCnt, aNbSeg, aNbP2;
  Standard_Real dT, aT1, aCoeff, aTresh, aD;
  Standard_Real aT11, aT12, aT21, aT22;
  GeomAPI_ProjectPointOnCurve aProjPC;
  gp_Pnt aP1;
  //
  aTresh=0.5;
  aNbSeg=23;
  myRange1.Range(aT11, aT12);
  myRange2.Range(aT21, aT22);
  //
  aProjPC.Init(myGeom2, aT21, aT22);
  //
  dT=(aT12-aT11)/aNbSeg;
  //
  iCnt=0;
  for(i=0; i <= aNbSeg; ++i) {
    aT1 = aT11+i*dT;
    myGeom1->D0(aT1, aP1);
    //
    aProjPC.Perform(aP1);
    aNbP2=aProjPC.NbPoints();
    if (!aNbP2) {
      continue;
    }
    //
    aD=aProjPC.LowerDistance();
    if(aD < myTol) {
      ++iCnt; 
    }
  }
  //
  aCoeff=(Standard_Real)iCnt/((Standard_Real)aNbSeg+1);
  return aCoeff > aTresh;
}

從上述代碼可以看出,對于重疊部分的檢測是將一條邊根據(jù)檢測范圍分成23段采樣點,計算每個點到另一條邊的距離,滿足條件的采樣點的數(shù)量超過12個,基本認為是重疊的。從這里可以看出這樣檢測重疊稍微有點不嚴謹。固定采樣點數(shù)量對于小段曲線來說數(shù)量過大,對于很長的曲線來說數(shù)量又偏小,這里有待提高。如果重疊,則將公共部分的數(shù)據(jù)保存起來:

對于測試的TCL腳本不會走這個通用的判斷流程,會直接有IntTools_EdgeEdge::ComputeLineLine()函數(shù)來處理這種特殊情況:

從保存的數(shù)據(jù)可以看出,公共部分的相交類型為TopAbs_VERTEX,及交點分別在兩條邊上的參數(shù)。關于有重疊部分的兩條邊相交,同學們可以自行使用DRAW腳本來測試一下。

3 Edge/Face Interferences

邊與面的相交會遇到和邊與邊相交類似的情況,即會有重疊部分Common Part。也分為兩種情況,一種情況是邊與面只有一個交點的情況,交點可能會有多個;一種情況是有重疊部分的情況。

我們可以在使用腳本來測試一下重疊的情況:

從代碼中可以看出當邊的端點在面上時,則會判斷邊與面會不會重疊Coincidence。判斷邏輯與判斷邊是否重疊類似,都是使用固定23個采樣點的方式處理,并加上定位器來判斷點是否在面上,因為面上可能會有孔洞:

//=======================================================================
//function :  IsCoincident
//purpose  : 
//=======================================================================
Standard_Boolean IntTools_EdgeFace::IsCoincident() 
{
  Standard_Integer i, iCnt;
  Standard_Real dT, aT, aD, aT1, aT2, aU, aV;
  gp_Pnt aP;
  TopAbs_State aState;
  gp_Pnt2d aP2d;
  //
  GeomAPI_ProjectPointOnSurf& aProjector=myContext->ProjPS(myFace);
  Standard_Integer aNbSeg=23;
  if (myC.GetType() == GeomAbs_Line &&
      myS.GetType() == GeomAbs_Plane)
    aNbSeg = 2; // Check only three points for Line/Plane intersection
  const Standard_Real aTresh = 0.5;
  const Standard_Integer aTreshIdxF = RealToInt((aNbSeg+1)*0.25),
                         aTreshIdxL = RealToInt((aNbSeg+1)*0.75);
  const Handle(Geom_Surface) aSurf = BRep_Tool::Surface(myFace);
  aT1=myRange.First();
  aT2=myRange.Last();
  Standard_Real aBndShift = 0.01 * (aT2 - aT1);
  //Shifting first and last curve points in order to avoid projection
  //on surface boundary and rejection projection point with minimal distance
  aT1 += aBndShift;
  aT2 -= aBndShift;
  dT=(aT2-aT1)/aNbSeg;
  //
  Standard_Boolean isClassified = Standard_False;
  iCnt=0;
  for(i=0; i <= aNbSeg; ++i) {
    aT = aT1+i*dT;
    aP=myC.Value(aT);
    //
    aProjector.Perform(aP);
    if (!aProjector.IsDone()) {
      continue;
    }
    //
    aD=aProjector.LowerDistance();
    if (aD > myCriteria) {
      if (aD > 100. * myCriteria)
        return Standard_False;
      else
        continue;
    }
    //
    ++iCnt; 
    //We classify only three points: in the begin, in the 
    //end and in the middle of the edge.
    //However, exact middle point (when i == (aNbSeg + 1)/2)
    //can be unprojectable. Therefore, it will not be able to
    //be classified. Therefore, points with indexes in 
    //[aTreshIdxF, aTreshIdxL] range are made available 
    //for classification.
    //isClassified == TRUE if MIDDLE point has been chosen and
    //classified correctly.
    if(((0 < i) && (i < aTreshIdxF)) || ((aTreshIdxL < i ) && (i < aNbSeg)))
      continue;
    if(isClassified && (i != aNbSeg))
      continue;
    aProjector.LowerDistanceParameters(aU, aV);
    aP2d.SetX(aU);
    aP2d.SetY(aV);
    IntTools_FClass2d& aClass2d=myContext->FClass2d(myFace);
    aState = aClass2d.Perform(aP2d);
    if(aState == TopAbs_OUT)
      return Standard_False;
    if(i != 0)
      isClassified = Standard_True;
  }
  //
  const Standard_Real aCoeff=(Standard_Real)iCnt/((Standard_Real)aNbSeg+1);
  return (aCoeff > aTresh);
}

求交結果與邊與邊相交類型,會保存邊與面的索引,及公共部分的數(shù)據(jù)。除了保存這些數(shù)據(jù)以外,還和點與面相交一樣,更新面上的信息FaceInfo,即有哪些邊在面上。

4 Conclusion

綜上所述,邊與邊、邊與面相交會得到公共部分Common Part,公共部分可能是點,也可能是重疊的邊。在過濾相交的邊與邊、邊與面時都有一定的優(yōu)化空間,即使用BVH來加速檢測相交部分。在快速判斷邊與邊是否重疊、邊與面是否重疊部分的代碼采用固定數(shù)量的采樣點的處理方式不太嚴謹。將相交的結果及過程數(shù)據(jù)都保存到BOPDS_DS中作為后面算法使用。

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            亚洲一区在线观看免费观看电影高清| 亚洲欧美精品在线观看| 久久久久久久波多野高潮日日| 一区二区毛片| 国产日韩免费| 玖玖视频精品| 欧美成人精品激情在线观看 | 亚洲天堂男人| 国产精品天美传媒入口| 久久国产精品毛片| 玖玖综合伊人| 中国亚洲黄色| 欧美在线高清视频| 亚洲青色在线| 一区二区三区你懂的| 国产伦一区二区三区色一情| 麻豆精品精华液| 欧美精品18videos性欧美| 亚洲欧美激情在线视频| 亚洲欧美在线另类| 亚洲国产日本| 亚洲视频自拍偷拍| 在线观看一区二区精品视频| 亚洲精品欧美激情| 国内精品嫩模av私拍在线观看| 亚洲高清视频一区| 国产精品免费观看在线| 欧美国产日韩精品| 国产精品一区二区久久精品| 亚洲福利专区| 国产一二三精品| 日韩亚洲视频在线| 亚洲二区在线视频| 亚洲自拍电影| 亚洲性xxxx| 亚洲国产成人精品女人久久久| 这里只有精品视频在线| 亚洲第一福利视频| 欧美一区二区三区四区在线观看地址| 亚洲精品国产品国语在线app| 午夜欧美大尺度福利影院在线看 | 国产精品高潮在线| 亚洲国产精品热久久| 国产亚洲精品一区二区| 一本色道久久综合亚洲精品婷婷| 1024亚洲| 久久精品一区中文字幕| 亚洲男同1069视频| 欧美屁股在线| 亚洲国产精品毛片| 18成人免费观看视频| 欧美亚洲一级| 欧美有码在线视频| 国产精品日韩欧美一区二区三区 | 欧美成人精品在线播放| 国产欧美一区二区三区久久 | 久久婷婷国产综合国色天香 | 在线欧美日韩| 久久黄色影院| 久久久伊人欧美| 国产亚洲人成a一在线v站| 中文国产成人精品| 亚洲在线观看| 欧美午夜电影在线| 中文在线一区| 亚洲欧美激情视频| 国产精品亚洲网站| 午夜欧美理论片| 久久精品国产亚洲高清剧情介绍| 国产伦精品一区二区三区四区免费| 夜夜嗨一区二区三区| 亚洲一区精彩视频| 国产久一道中文一区| 新狼窝色av性久久久久久| 久久精品国产视频| 狠狠色狠狠色综合日日小说| 久久久精彩视频| 欧美va亚洲va香蕉在线| 亚洲国产日韩在线一区模特| 欧美成人精品影院| 亚洲乱码精品一二三四区日韩在线| 亚洲最新色图| 国产伦精品一区二区三区高清版| 香蕉久久国产| 欧美高清成人| 亚洲午夜av| 国产一区二区三区视频在线观看| 久久久久久网址| 亚洲人成人一区二区三区| 亚洲天堂网在线观看| 国产欧美视频一区二区三区| 久久久精品国产一区二区三区 | 久久久精品性| 亚洲激情六月丁香| 欧美午夜不卡视频| 久久精品国产免费看久久精品| 亚洲福利免费| 亚洲欧美日韩一区二区三区在线观看| 国产欧美一区视频| 欧美成人精品福利| 亚洲一级黄色| 欧美福利视频在线| 午夜精品久久久久影视| 伊人久久噜噜噜躁狠狠躁| 欧美日韩国产一级片| 欧美一区在线直播| 99精品国产在热久久| 美女国产一区| 性亚洲最疯狂xxxx高清| 亚洲精品国产精品国产自| 国产欧美日韩一区二区三区| 模特精品裸拍一区| 久久国产66| 亚洲色图在线视频| 亚洲国产成人在线| 久久中文字幕导航| 午夜影院日韩| av成人免费| 亚洲国产精品悠悠久久琪琪| 国产人成一区二区三区影院| 欧美日韩一区二区三区视频| 久久青青草综合| 欧美亚洲网站| 亚洲免费人成在线视频观看| 亚洲激情国产| 亚洲成人中文| 看欧美日韩国产| 久久精品国产清自在天天线| 亚洲永久精品国产| 一区二区三区视频在线播放| 亚洲精品日日夜夜| 亚洲福利av| 亚洲高清在线观看| 国内精品久久久久久影视8| 国产精品国产福利国产秒拍| 欧美日本在线播放| 欧美激情一区三区| 男人的天堂亚洲在线| 葵司免费一区二区三区四区五区| 久久精品99久久香蕉国产色戒| 亚洲在线视频观看| 亚洲欧美另类综合偷拍| 亚洲午夜在线| 亚洲男人天堂2024| 午夜欧美不卡精品aaaaa| 亚洲欧美在线另类| 欧美一区二区三区成人| 欧美在线视屏| 久久先锋影音av| 欧美aaaaaaaa牛牛影院| 欧美电影专区| 欧美日韩视频一区二区三区| 欧美日韩在线播| 国产精品久久一区二区三区| 国产精品人人做人人爽人人添| 国产精品久久久久久久午夜| 国产欧美日韩专区发布| 红桃视频一区| 亚洲国产三级在线| 夜夜爽av福利精品导航| 亚洲一区二区三区四区中文 | 91久久精品国产91性色| 日韩亚洲视频在线| 亚洲午夜久久久| 久久成人这里只有精品| 蜜臀av性久久久久蜜臀aⅴ四虎| 欧美岛国在线观看| 日韩午夜中文字幕| 亚洲一级一区| 久久麻豆一区二区| 欧美理论电影在线播放| 国产精品高清一区二区三区| 国产一区二区三区自拍| 亚洲国产一区二区a毛片| 国产精品99久久久久久人| 欧美一区观看| 亚洲高清在线观看一区| 中文亚洲免费| 久久理论片午夜琪琪电影网| 欧美乱大交xxxxx| 国产亚洲综合精品| 一区二区电影免费在线观看| 久久精品一区二区国产| 亚洲欧洲综合| 久久国产66| 欧美网站在线| 亚洲精品欧美日韩| 欧美在线三级| 亚洲精品视频免费| 久久久久久久999精品视频| 欧美小视频在线| 亚洲国产精品国自产拍av秋霞| 亚洲一区二区四区| 欧美高清成人| 久久爱www| 国产精品香蕉在线观看| 99re热这里只有精品视频| 久久天天躁狠狠躁夜夜av| 在线一区二区日韩| 欧美精品自拍偷拍动漫精品|