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

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 閱讀(926) 評論(0)  編輯 收藏 引用 所屬分類: 2.OpenCASCADE

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

eryar@163.com

1 Introduction

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

2 Edge/Edge Interferences

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

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

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

對于邊的求交結(jié)果保存到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ù)。關(guān)于有重疊部分的兩條邊相交,同學(xué)們可以自行使用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);
}

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

4 Conclusion

綜上所述,邊與邊、邊與面相交會得到公共部分Common Part,公共部分可能是點,也可能是重疊的邊。在過濾相交的邊與邊、邊與面時都有一定的優(yōu)化空間,即使用BVH來加速檢測相交部分。在快速判斷邊與邊是否重疊、邊與面是否重疊部分的代碼采用固定數(shù)量的采樣點的處理方式不太嚴謹。將相交的結(jié)果及過程數(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>
            激情五月***国产精品| 国产在线成人| 亚洲国产精品成人精品| 久久av二区| 亚洲欧美日本日韩| 欧美日韩ab片| 9i看片成人免费高清| 亚洲高清一区二| 欧美在线播放一区| 国产精品99久久久久久人| 欧美激情亚洲| 中文网丁香综合网| 亚洲美女色禁图| 欧美日韩午夜视频在线观看| 亚洲伊人网站| 欧美一级一区| 亚洲国产视频一区| 亚洲欧洲三级电影| 欧美日韩调教| 亚洲日本久久| 国产色婷婷国产综合在线理论片a| 久久久久国产精品一区三寸| 久久久久一区| 日韩视频在线免费观看| 亚洲视频碰碰| 亚洲欧美资源在线| 久久人人爽人人爽爽久久| 亚洲精品视频中文字幕| 一本到高清视频免费精品| 国产一区二区三区在线播放免费观看 | 欧美激情乱人伦| 夜夜嗨av一区二区三区网站四季av | 欧美jjzz| 欧美精品免费在线| 亚洲日本欧美天堂| 中国成人在线视频| 国产精品国产三级国产aⅴ入口| 久久精品国产欧美亚洲人人爽| 欧美88av| 性高湖久久久久久久久| 欧美α欧美αv大片| 欧美在线黄色| 狠狠色丁香久久综合频道| 一区二区日韩免费看| 亚洲第一视频| 欧美在线一二三区| 亚洲视频久久| 国产精品男gay被猛男狂揉视频| 亚洲高清视频在线观看| 一区二区动漫| 欧美激情第8页| 99在线|亚洲一区二区| 欧美一区二区三区精品电影| 国产日本欧美一区二区| 亚洲欧洲一区二区天堂久久| 国产精品99久久久久久白浆小说| 国产精品麻豆欧美日韩ww| 性欧美18~19sex高清播放| 亚洲小说春色综合另类电影| 欧美国产先锋| 亚洲自拍16p| 亚洲免费一区二区| 欧美日产一区二区三区在线观看| 一区二区毛片| 噜噜噜躁狠狠躁狠狠精品视频| 国产精品成人一区二区网站软件| 午夜视频精品| 亚洲国产日韩欧美在线图片| 亚洲欧洲在线一区| 另类亚洲自拍| 午夜一区在线| 亚洲精品久久久久久久久久久| 国产精品剧情在线亚洲| 久久久久久久综合色一本| 亚洲美女诱惑| 欧美电影免费| 在线播放日韩欧美| 老巨人导航500精品| 亚洲一区二区三区三| 亚洲专区国产精品| 亚洲国产裸拍裸体视频在线观看乱了中文| 欧美先锋影音| 亚洲综合日韩中文字幕v在线| 欧美华人在线视频| 亚洲欧洲一区二区在线观看| 国产日韩欧美综合一区| 欧美视频一区| 亚洲欧美综合国产精品一区| 亚洲精品久久久久中文字幕欢迎你 | 亚洲免费一在线| 日韩一区二区精品| 在线观看视频欧美| 国产欧美日韩一区二区三区在线| 欧美日韩久久精品| 欧美国产日韩一区| 久久综合伊人77777麻豆| 午夜久久资源| 亚洲一区二区三区视频播放| 999亚洲国产精| 亚洲精品一区二区在线观看| 亚洲欧美日韩精品久久亚洲区 | 99精品视频免费观看视频| 欧美v日韩v国产v| 久久久久亚洲综合| 亚洲国产成人一区| 韩国av一区二区三区在线观看| 欧美日韩在线视频一区二区| 欧美精品一区在线播放| 欧美一区二区三区免费在线看| 亚洲视频一区在线| 久久成人免费电影| 欧美一级二级三级蜜桃| 亚洲嫩草精品久久| 午夜精品一区二区在线观看| 午夜视频一区在线观看| 亚洲欧美一区二区三区极速播放 | 欧美一区二区三区婷婷月色| 亚洲永久免费| 欧美一区二区三区免费看| 午夜欧美精品| 久久久久久久久伊人| 久久久久九九九| 欧美成年人视频网站| 亚洲电影免费在线观看| 最新69国产成人精品视频免费| 亚洲国产成人午夜在线一区| 亚洲美女毛片| 亚洲一区二区三区中文字幕 | 宅男噜噜噜66一区二区 | 欧美在线影院在线视频| 久久精品视频在线免费观看| 亚洲天堂免费观看| 亚洲欧美一区在线| 久久精品色图| 欧美日本韩国一区| 国产精品任我爽爆在线播放| 欧美日韩国产a| 欧美视频中文字幕| 国产性做久久久久久| 亚洲国产精品成人精品| 在线性视频日韩欧美| 欧美亚洲在线视频| 欧美91福利在线观看| 99re6热在线精品视频播放速度| 亚洲一区二区三区三| 久久香蕉国产线看观看av| 欧美日韩一区自拍| 黄色在线成人| 亚洲一区在线播放| 免播放器亚洲一区| 久久久久99精品国产片| 亚洲第一区在线观看| 亚洲一区免费看| 免费在线欧美黄色| 国产精品视频一| 99视频精品| 玖玖国产精品视频| 亚洲视频一区在线观看| 欧美jjzz| 国产亚洲综合在线| 中文国产亚洲喷潮| 免费在线欧美视频| 亚洲一级黄色| 欧美激情第10页| 亚洲成人资源网| 欧美一区二区三区在线播放| 亚洲人成网站在线播| 久久精品人人做人人综合| 国产精品久久二区| 亚洲精品一区二区在线| 最新精品在线| 久久久国产成人精品| 亚洲一区二区三区乱码aⅴ| 欧美精品18+| 亚洲国产精品va在看黑人| 久久久人成影片一区二区三区观看 | 午夜日韩视频| 99re66热这里只有精品4| 免费不卡亚洲欧美| 韩日精品中文字幕| 久久精品日产第一区二区| 一区二区三区|亚洲午夜| 欧美精品一区二区三区四区| 亚洲国产综合91精品麻豆| 免费h精品视频在线播放| 欧美在线播放视频| 国产欧美一区二区三区在线看蜜臀| 亚洲在线视频一区| 日韩视频不卡| 欧美日韩调教| 亚洲综合99| 亚洲一区在线观看视频| 国产精品普通话对白| 亚洲一区二区精品在线| 一区二区三区四区蜜桃| 欧美调教视频| 午夜精品久久久久久99热| 亚洲欧美99| 国产午夜亚洲精品羞羞网站 | 久久激五月天综合精品|