@itwin/core-geometry 5.3.0-dev.6 → 5.3.0-dev.7

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (451) hide show
  1. package/lib/cjs/Constant.js.map +1 -1
  2. package/lib/cjs/Geometry.js.map +1 -1
  3. package/lib/cjs/bspline/AkimaCurve3d.js.map +1 -1
  4. package/lib/cjs/bspline/BSpline1dNd.js.map +1 -1
  5. package/lib/cjs/bspline/BSplineCurve.js.map +1 -1
  6. package/lib/cjs/bspline/BSplineCurve3dH.js.map +1 -1
  7. package/lib/cjs/bspline/BSplineCurveOps.js.map +1 -1
  8. package/lib/cjs/bspline/BSplineSurface.js.map +1 -1
  9. package/lib/cjs/bspline/Bezier1dNd.js.map +1 -1
  10. package/lib/cjs/bspline/BezierCurve3d.js.map +1 -1
  11. package/lib/cjs/bspline/BezierCurve3dH.js.map +1 -1
  12. package/lib/cjs/bspline/BezierCurveBase.js.map +1 -1
  13. package/lib/cjs/bspline/InterpolationCurve3d.js.map +1 -1
  14. package/lib/cjs/bspline/KnotVector.js.map +1 -1
  15. package/lib/cjs/bspline/SurfaceLocationDetail.js.map +1 -1
  16. package/lib/cjs/clipping/AlternatingConvexClipTree.js.map +1 -1
  17. package/lib/cjs/clipping/BooleanClipFactory.js.map +1 -1
  18. package/lib/cjs/clipping/BooleanClipNode.js.map +1 -1
  19. package/lib/cjs/clipping/ClipPlane.js.map +1 -1
  20. package/lib/cjs/clipping/ClipPrimitive.js.map +1 -1
  21. package/lib/cjs/clipping/ClipUtils.js.map +1 -1
  22. package/lib/cjs/clipping/ClipVector.js.map +1 -1
  23. package/lib/cjs/clipping/ConvexClipPlaneSet.js.map +1 -1
  24. package/lib/cjs/clipping/UnionOfConvexClipPlaneSets.js.map +1 -1
  25. package/lib/cjs/clipping/internalContexts/LineStringOffsetClipperContext.js.map +1 -1
  26. package/lib/cjs/core-geometry.js.map +1 -1
  27. package/lib/cjs/curve/Arc3d.js.map +1 -1
  28. package/lib/cjs/curve/ConstructCurveBetweenCurves.js.map +1 -1
  29. package/lib/cjs/curve/CoordinateXYZ.js.map +1 -1
  30. package/lib/cjs/curve/CurveChainWithDistanceIndex.js.map +1 -1
  31. package/lib/cjs/curve/CurveCollection.js.map +1 -1
  32. package/lib/cjs/curve/CurveCurve.js.map +1 -1
  33. package/lib/cjs/curve/CurveExtendMode.js.map +1 -1
  34. package/lib/cjs/curve/CurveFactory.js.map +1 -1
  35. package/lib/cjs/curve/CurveLocationDetail.js.map +1 -1
  36. package/lib/cjs/curve/CurveOps.js.map +1 -1
  37. package/lib/cjs/curve/CurvePrimitive.js.map +1 -1
  38. package/lib/cjs/curve/CurveProcessor.js.map +1 -1
  39. package/lib/cjs/curve/CurveTypes.js.map +1 -1
  40. package/lib/cjs/curve/CurveWireMomentsXYZ.js.map +1 -1
  41. package/lib/cjs/curve/GeometryQuery.js.map +1 -1
  42. package/lib/cjs/curve/LineSegment3d.js.map +1 -1
  43. package/lib/cjs/curve/LineString3d.js.map +1 -1
  44. package/lib/cjs/curve/Loop.js.map +1 -1
  45. package/lib/cjs/curve/OffsetOptions.js.map +1 -1
  46. package/lib/cjs/curve/ParityRegion.js.map +1 -1
  47. package/lib/cjs/curve/Path.js.map +1 -1
  48. package/lib/cjs/curve/PointString3d.js.map +1 -1
  49. package/lib/cjs/curve/ProxyCurve.js.map +1 -1
  50. package/lib/cjs/curve/Query/ConsolidateAdjacentPrimitivesContext.js.map +1 -1
  51. package/lib/cjs/curve/Query/CurveSplitContext.js.map +1 -1
  52. package/lib/cjs/curve/Query/CylindricalRange.js.map +1 -1
  53. package/lib/cjs/curve/Query/InOutTests.js.map +1 -1
  54. package/lib/cjs/curve/Query/PlanarSubdivision.js.map +1 -1
  55. package/lib/cjs/curve/Query/StrokeCountChain.js.map +1 -1
  56. package/lib/cjs/curve/Query/StrokeCountMap.js.map +1 -1
  57. package/lib/cjs/curve/RegionMomentsXY.js.map +1 -1
  58. package/lib/cjs/curve/RegionOps.js.map +1 -1
  59. package/lib/cjs/curve/RegionOpsClassificationSweeps.js.map +1 -1
  60. package/lib/cjs/curve/StrokeOptions.js.map +1 -1
  61. package/lib/cjs/curve/UnionRegion.js.map +1 -1
  62. package/lib/cjs/curve/internalContexts/AnnounceTangentStrokeHandler.js.map +1 -1
  63. package/lib/cjs/curve/internalContexts/AppendPlaneIntersectionStrokeHandler.js.map +1 -1
  64. package/lib/cjs/curve/internalContexts/ChainCollectorContext.js.map +1 -1
  65. package/lib/cjs/curve/internalContexts/CloneCurvesContext.js.map +1 -1
  66. package/lib/cjs/curve/internalContexts/CloneWithExpandedLineStrings.js.map +1 -1
  67. package/lib/cjs/curve/internalContexts/ClosestPointStrokeHandler.js.map +1 -1
  68. package/lib/cjs/curve/internalContexts/CountLinearPartsSearchContext.js.map +1 -1
  69. package/lib/cjs/curve/internalContexts/CurveCurveCloseApproachXY.js.map +1 -1
  70. package/lib/cjs/curve/internalContexts/CurveCurveIntersectXY.js.map +1 -1
  71. package/lib/cjs/curve/internalContexts/CurveCurveIntersectXYZ.js.map +1 -1
  72. package/lib/cjs/curve/internalContexts/CurveLengthContext.js.map +1 -1
  73. package/lib/cjs/curve/internalContexts/CurveOffsetXYHandler.js.map +1 -1
  74. package/lib/cjs/curve/internalContexts/EllipticalArcApproximationContext.js.map +1 -1
  75. package/lib/cjs/curve/internalContexts/GapSearchContext.js.map +1 -1
  76. package/lib/cjs/curve/internalContexts/MultiChainCollector.js.map +1 -1
  77. package/lib/cjs/curve/internalContexts/NewtonRtoRStrokeHandler.js.map +1 -1
  78. package/lib/cjs/curve/internalContexts/PlaneAltitudeRangeContext.js.map +1 -1
  79. package/lib/cjs/curve/internalContexts/PolygonOffsetContext.js.map +1 -1
  80. package/lib/cjs/curve/internalContexts/SumLengthsContext.js.map +1 -1
  81. package/lib/cjs/curve/internalContexts/TransferWithSplitArcs.js.map +1 -1
  82. package/lib/cjs/curve/internalContexts/TransformInPlaceContext.js.map +1 -1
  83. package/lib/cjs/curve/spiral/AustralianRailCorpXYEvaluator.js.map +1 -1
  84. package/lib/cjs/curve/spiral/ClothoidSeries.js.map +1 -1
  85. package/lib/cjs/curve/spiral/CubicEvaluator.js.map +1 -1
  86. package/lib/cjs/curve/spiral/CzechSpiralEvaluator.js.map +1 -1
  87. package/lib/cjs/curve/spiral/DirectHalfCosineSpiralEvaluator.js.map +1 -1
  88. package/lib/cjs/curve/spiral/DirectSpiral3d.js.map +1 -1
  89. package/lib/cjs/curve/spiral/IntegratedSpiral3d.js.map +1 -1
  90. package/lib/cjs/curve/spiral/MXCubicAlongArcSpiralEvaluator.js.map +1 -1
  91. package/lib/cjs/curve/spiral/NormalizedTransition.js.map +1 -1
  92. package/lib/cjs/curve/spiral/PolishCubicSpiralEvaluator.js.map +1 -1
  93. package/lib/cjs/curve/spiral/TransitionConditionalProperties.js.map +1 -1
  94. package/lib/cjs/curve/spiral/TransitionSpiral3d.js.map +1 -1
  95. package/lib/cjs/curve/spiral/XYCurveEvaluator.js.map +1 -1
  96. package/lib/cjs/geometry3d/Angle.js.map +1 -1
  97. package/lib/cjs/geometry3d/AngleSweep.js.map +1 -1
  98. package/lib/cjs/geometry3d/BarycentricTriangle.js.map +1 -1
  99. package/lib/cjs/geometry3d/BilinearPatch.js.map +1 -1
  100. package/lib/cjs/geometry3d/CoincidentGeometryOps.js.map +1 -1
  101. package/lib/cjs/geometry3d/Ellipsoid.js.map +1 -1
  102. package/lib/cjs/geometry3d/FrameBuilder.js.map +1 -1
  103. package/lib/cjs/geometry3d/FrustumAnimation.js.map +1 -1
  104. package/lib/cjs/geometry3d/GeometryHandler.js.map +1 -1
  105. package/lib/cjs/geometry3d/GrowableBlockedArray.js.map +1 -1
  106. package/lib/cjs/geometry3d/GrowableFloat64Array.js.map +1 -1
  107. package/lib/cjs/geometry3d/GrowableXYArray.js.map +1 -1
  108. package/lib/cjs/geometry3d/GrowableXYZArray.js.map +1 -1
  109. package/lib/cjs/geometry3d/IndexedCollectionInterval.js.map +1 -1
  110. package/lib/cjs/geometry3d/IndexedXYCollection.js.map +1 -1
  111. package/lib/cjs/geometry3d/IndexedXYZCollection.js.map +1 -1
  112. package/lib/cjs/geometry3d/LongitudeLatitudeAltitude.js.map +1 -1
  113. package/lib/cjs/geometry3d/Matrix3d.js.map +1 -1
  114. package/lib/cjs/geometry3d/OrderedRotationAngles.js.map +1 -1
  115. package/lib/cjs/geometry3d/Plane3d.js.map +1 -1
  116. package/lib/cjs/geometry3d/Plane3dByOriginAndUnitNormal.js.map +1 -1
  117. package/lib/cjs/geometry3d/Plane3dByOriginAndVectors.js.map +1 -1
  118. package/lib/cjs/geometry3d/Point2dArrayCarrier.js.map +1 -1
  119. package/lib/cjs/geometry3d/Point2dVector2d.js.map +1 -1
  120. package/lib/cjs/geometry3d/Point3dArrayCarrier.js.map +1 -1
  121. package/lib/cjs/geometry3d/Point3dVector3d.js.map +1 -1
  122. package/lib/cjs/geometry3d/PointHelpers.js.map +1 -1
  123. package/lib/cjs/geometry3d/PointStreaming.js.map +1 -1
  124. package/lib/cjs/geometry3d/PolygonOps.js.map +1 -1
  125. package/lib/cjs/geometry3d/PolylineCompressionByEdgeOffset.js.map +1 -1
  126. package/lib/cjs/geometry3d/PolylineOps.js.map +1 -1
  127. package/lib/cjs/geometry3d/Range.js.map +1 -1
  128. package/lib/cjs/geometry3d/Ray2d.js.map +1 -1
  129. package/lib/cjs/geometry3d/Ray3d.js.map +1 -1
  130. package/lib/cjs/geometry3d/ReusableObjectCache.js.map +1 -1
  131. package/lib/cjs/geometry3d/Segment1d.js.map +1 -1
  132. package/lib/cjs/geometry3d/SortablePolygon.js.map +1 -1
  133. package/lib/cjs/geometry3d/Transform.js.map +1 -1
  134. package/lib/cjs/geometry3d/UVSurfaceOps.js.map +1 -1
  135. package/lib/cjs/geometry3d/XYZProps.js.map +1 -1
  136. package/lib/cjs/geometry3d/YawPitchRollAngles.js.map +1 -1
  137. package/lib/cjs/geometry4d/Map4d.js.map +1 -1
  138. package/lib/cjs/geometry4d/Matrix4d.js.map +1 -1
  139. package/lib/cjs/geometry4d/MomentData.js.map +1 -1
  140. package/lib/cjs/geometry4d/PlaneByOriginAndVectors4d.js.map +1 -1
  141. package/lib/cjs/geometry4d/Point4d.js.map +1 -1
  142. package/lib/cjs/numerics/BandedSystem.js.map +1 -1
  143. package/lib/cjs/numerics/BezierPolynomials.js.map +1 -1
  144. package/lib/cjs/numerics/ClusterableArray.js.map +1 -1
  145. package/lib/cjs/numerics/Complex.js.map +1 -1
  146. package/lib/cjs/numerics/ConvexPolygon2d.js.map +1 -1
  147. package/lib/cjs/numerics/Newton.js.map +1 -1
  148. package/lib/cjs/numerics/PascalCoefficients.js.map +1 -1
  149. package/lib/cjs/numerics/PolarData.js.map +1 -1
  150. package/lib/cjs/numerics/Polynomials.js.map +1 -1
  151. package/lib/cjs/numerics/Quadrature.js.map +1 -1
  152. package/lib/cjs/numerics/Range1dArray.js.map +1 -1
  153. package/lib/cjs/numerics/SmallSystem.js.map +1 -1
  154. package/lib/cjs/numerics/TriDiagonalSystem.js.map +1 -1
  155. package/lib/cjs/numerics/UnionFind.js.map +1 -1
  156. package/lib/cjs/numerics/UsageSums.js.map +1 -1
  157. package/lib/cjs/polyface/AuxData.js.map +1 -1
  158. package/lib/cjs/polyface/BoxTopology.js.map +1 -1
  159. package/lib/cjs/polyface/FacetFaceData.js.map +1 -1
  160. package/lib/cjs/polyface/FacetLocationDetail.js.map +1 -1
  161. package/lib/cjs/polyface/FacetOrientation.js.map +1 -1
  162. package/lib/cjs/polyface/GreedyTriangulationBetweenLineStrings.js.map +1 -1
  163. package/lib/cjs/polyface/IndexedEdgeMatcher.js.map +1 -1
  164. package/lib/cjs/polyface/IndexedPolyfaceVisitor.js.map +1 -1
  165. package/lib/cjs/polyface/IndexedPolyfaceWalker.js.map +1 -1
  166. package/lib/cjs/polyface/Polyface.js.map +1 -1
  167. package/lib/cjs/polyface/PolyfaceBuilder.js.map +1 -1
  168. package/lib/cjs/polyface/PolyfaceClip.js.map +1 -1
  169. package/lib/cjs/polyface/PolyfaceData.js.map +1 -1
  170. package/lib/cjs/polyface/PolyfaceQuery.js.map +1 -1
  171. package/lib/cjs/polyface/RangeLengthData.js.map +1 -1
  172. package/lib/cjs/polyface/RangeTree/LineString3dRangeTreeContext.js.map +1 -1
  173. package/lib/cjs/polyface/RangeTree/MinimumValueTester.js.map +1 -1
  174. package/lib/cjs/polyface/RangeTree/Point3dArrayRangeTreeContext.js.map +1 -1
  175. package/lib/cjs/polyface/RangeTree/PolyfaceRangeTreeContext.js.map +1 -1
  176. package/lib/cjs/polyface/RangeTree/RangeTreeNode.js.map +1 -1
  177. package/lib/cjs/polyface/RangeTree/RangeTreeSearchHandlers.js.map +1 -1
  178. package/lib/cjs/polyface/TaggedNumericData.js.map +1 -1
  179. package/lib/cjs/polyface/TriangleCandidate.js.map +1 -1
  180. package/lib/cjs/polyface/multiclip/BuildAverageNormalsContext.js.map +1 -1
  181. package/lib/cjs/polyface/multiclip/GriddedRaggedRange2dSet.js.map +1 -1
  182. package/lib/cjs/polyface/multiclip/GriddedRaggedRange2dSetWithOverflow.js.map +1 -1
  183. package/lib/cjs/polyface/multiclip/LinearSearchRange2dArray.js.map +1 -1
  184. package/lib/cjs/polyface/multiclip/OffsetMeshContext.js.map +1 -1
  185. package/lib/cjs/polyface/multiclip/Range2dSearchInterface.js.map +1 -1
  186. package/lib/cjs/polyface/multiclip/RangeSearch.js.map +1 -1
  187. package/lib/cjs/polyface/multiclip/SweepLineStringToFacetContext.js.map +1 -1
  188. package/lib/cjs/polyface/multiclip/XYPointBuckets.js.map +1 -1
  189. package/lib/cjs/serialization/BGFBAccessors.js.map +1 -1
  190. package/lib/cjs/serialization/BGFBReader.js.map +1 -1
  191. package/lib/cjs/serialization/BGFBWriter.js.map +1 -1
  192. package/lib/cjs/serialization/BentleyGeometryFlatBuffer.js.map +1 -1
  193. package/lib/cjs/serialization/DeepCompare.js.map +1 -1
  194. package/lib/cjs/serialization/GeometrySamples.js.map +1 -1
  195. package/lib/cjs/serialization/IModelJsonSchema.js.map +1 -1
  196. package/lib/cjs/serialization/SerializationHelpers.js.map +1 -1
  197. package/lib/cjs/solid/Box.js.map +1 -1
  198. package/lib/cjs/solid/Cone.js.map +1 -1
  199. package/lib/cjs/solid/LinearSweep.js.map +1 -1
  200. package/lib/cjs/solid/RotationalSweep.js.map +1 -1
  201. package/lib/cjs/solid/RuledSweep.js.map +1 -1
  202. package/lib/cjs/solid/SolidPrimitive.js.map +1 -1
  203. package/lib/cjs/solid/Sphere.js.map +1 -1
  204. package/lib/cjs/solid/SweepContour.js.map +1 -1
  205. package/lib/cjs/solid/TorusPipe.js.map +1 -1
  206. package/lib/cjs/topology/ChainMerge.js.map +1 -1
  207. package/lib/cjs/topology/Graph.js.map +1 -1
  208. package/lib/cjs/topology/HalfEdgeGraphFromIndexedLoopsContext.js.map +1 -1
  209. package/lib/cjs/topology/HalfEdgeGraphSearch.js.map +1 -1
  210. package/lib/cjs/topology/HalfEdgeGraphSpineContext.js.map +1 -1
  211. package/lib/cjs/topology/HalfEdgeGraphValidation.js.map +1 -1
  212. package/lib/cjs/topology/HalfEdgeMarkSet.js.map +1 -1
  213. package/lib/cjs/topology/HalfEdgeNodeXYZUV.js.map +1 -1
  214. package/lib/cjs/topology/HalfEdgePointInGraphSearch.js.map +1 -1
  215. package/lib/cjs/topology/HalfEdgePositionDetail.js.map +1 -1
  216. package/lib/cjs/topology/HalfEdgePriorityQueue.js.map +1 -1
  217. package/lib/cjs/topology/InsertAndRetriangulateContext.js.map +1 -1
  218. package/lib/cjs/topology/MaskManager.js.map +1 -1
  219. package/lib/cjs/topology/Merging.js.map +1 -1
  220. package/lib/cjs/topology/RegularizeFace.js.map +1 -1
  221. package/lib/cjs/topology/SignedDataSummary.js.map +1 -1
  222. package/lib/cjs/topology/SpaceTriangulation.js.map +1 -1
  223. package/lib/cjs/topology/Triangulation.js.map +1 -1
  224. package/lib/cjs/topology/Voronoi.js.map +1 -1
  225. package/lib/cjs/topology/XYParitySearchContext.js.map +1 -1
  226. package/lib/esm/Constant.js.map +1 -1
  227. package/lib/esm/Geometry.js.map +1 -1
  228. package/lib/esm/bspline/AkimaCurve3d.js.map +1 -1
  229. package/lib/esm/bspline/BSpline1dNd.js.map +1 -1
  230. package/lib/esm/bspline/BSplineCurve.js.map +1 -1
  231. package/lib/esm/bspline/BSplineCurve3dH.js.map +1 -1
  232. package/lib/esm/bspline/BSplineCurveOps.js.map +1 -1
  233. package/lib/esm/bspline/BSplineSurface.js.map +1 -1
  234. package/lib/esm/bspline/Bezier1dNd.js.map +1 -1
  235. package/lib/esm/bspline/BezierCurve3d.js.map +1 -1
  236. package/lib/esm/bspline/BezierCurve3dH.js.map +1 -1
  237. package/lib/esm/bspline/BezierCurveBase.js.map +1 -1
  238. package/lib/esm/bspline/InterpolationCurve3d.js.map +1 -1
  239. package/lib/esm/bspline/KnotVector.js.map +1 -1
  240. package/lib/esm/bspline/SurfaceLocationDetail.js.map +1 -1
  241. package/lib/esm/clipping/AlternatingConvexClipTree.js.map +1 -1
  242. package/lib/esm/clipping/BooleanClipFactory.js.map +1 -1
  243. package/lib/esm/clipping/BooleanClipNode.js.map +1 -1
  244. package/lib/esm/clipping/ClipPlane.js.map +1 -1
  245. package/lib/esm/clipping/ClipPrimitive.js.map +1 -1
  246. package/lib/esm/clipping/ClipUtils.js.map +1 -1
  247. package/lib/esm/clipping/ClipVector.js.map +1 -1
  248. package/lib/esm/clipping/ConvexClipPlaneSet.js.map +1 -1
  249. package/lib/esm/clipping/UnionOfConvexClipPlaneSets.js.map +1 -1
  250. package/lib/esm/clipping/internalContexts/LineStringOffsetClipperContext.js.map +1 -1
  251. package/lib/esm/core-geometry.js.map +1 -1
  252. package/lib/esm/curve/Arc3d.js.map +1 -1
  253. package/lib/esm/curve/ConstructCurveBetweenCurves.js.map +1 -1
  254. package/lib/esm/curve/CoordinateXYZ.js.map +1 -1
  255. package/lib/esm/curve/CurveChainWithDistanceIndex.js.map +1 -1
  256. package/lib/esm/curve/CurveCollection.js.map +1 -1
  257. package/lib/esm/curve/CurveCurve.js.map +1 -1
  258. package/lib/esm/curve/CurveExtendMode.js.map +1 -1
  259. package/lib/esm/curve/CurveFactory.js.map +1 -1
  260. package/lib/esm/curve/CurveLocationDetail.js.map +1 -1
  261. package/lib/esm/curve/CurveOps.js.map +1 -1
  262. package/lib/esm/curve/CurvePrimitive.js.map +1 -1
  263. package/lib/esm/curve/CurveProcessor.js.map +1 -1
  264. package/lib/esm/curve/CurveTypes.js.map +1 -1
  265. package/lib/esm/curve/CurveWireMomentsXYZ.js.map +1 -1
  266. package/lib/esm/curve/GeometryQuery.js.map +1 -1
  267. package/lib/esm/curve/LineSegment3d.js.map +1 -1
  268. package/lib/esm/curve/LineString3d.js.map +1 -1
  269. package/lib/esm/curve/Loop.js.map +1 -1
  270. package/lib/esm/curve/OffsetOptions.js.map +1 -1
  271. package/lib/esm/curve/ParityRegion.js.map +1 -1
  272. package/lib/esm/curve/Path.js.map +1 -1
  273. package/lib/esm/curve/PointString3d.js.map +1 -1
  274. package/lib/esm/curve/ProxyCurve.js.map +1 -1
  275. package/lib/esm/curve/Query/ConsolidateAdjacentPrimitivesContext.js.map +1 -1
  276. package/lib/esm/curve/Query/CurveSplitContext.js.map +1 -1
  277. package/lib/esm/curve/Query/CylindricalRange.js.map +1 -1
  278. package/lib/esm/curve/Query/InOutTests.js.map +1 -1
  279. package/lib/esm/curve/Query/PlanarSubdivision.js.map +1 -1
  280. package/lib/esm/curve/Query/StrokeCountChain.js.map +1 -1
  281. package/lib/esm/curve/Query/StrokeCountMap.js.map +1 -1
  282. package/lib/esm/curve/RegionMomentsXY.js.map +1 -1
  283. package/lib/esm/curve/RegionOps.js.map +1 -1
  284. package/lib/esm/curve/RegionOpsClassificationSweeps.js.map +1 -1
  285. package/lib/esm/curve/StrokeOptions.js.map +1 -1
  286. package/lib/esm/curve/UnionRegion.js.map +1 -1
  287. package/lib/esm/curve/internalContexts/AnnounceTangentStrokeHandler.js.map +1 -1
  288. package/lib/esm/curve/internalContexts/AppendPlaneIntersectionStrokeHandler.js.map +1 -1
  289. package/lib/esm/curve/internalContexts/ChainCollectorContext.js.map +1 -1
  290. package/lib/esm/curve/internalContexts/CloneCurvesContext.js.map +1 -1
  291. package/lib/esm/curve/internalContexts/CloneWithExpandedLineStrings.js.map +1 -1
  292. package/lib/esm/curve/internalContexts/ClosestPointStrokeHandler.js.map +1 -1
  293. package/lib/esm/curve/internalContexts/CountLinearPartsSearchContext.js.map +1 -1
  294. package/lib/esm/curve/internalContexts/CurveCurveCloseApproachXY.js.map +1 -1
  295. package/lib/esm/curve/internalContexts/CurveCurveIntersectXY.js.map +1 -1
  296. package/lib/esm/curve/internalContexts/CurveCurveIntersectXYZ.js.map +1 -1
  297. package/lib/esm/curve/internalContexts/CurveLengthContext.js.map +1 -1
  298. package/lib/esm/curve/internalContexts/CurveOffsetXYHandler.js.map +1 -1
  299. package/lib/esm/curve/internalContexts/EllipticalArcApproximationContext.js.map +1 -1
  300. package/lib/esm/curve/internalContexts/GapSearchContext.js.map +1 -1
  301. package/lib/esm/curve/internalContexts/MultiChainCollector.js.map +1 -1
  302. package/lib/esm/curve/internalContexts/NewtonRtoRStrokeHandler.js.map +1 -1
  303. package/lib/esm/curve/internalContexts/PlaneAltitudeRangeContext.js.map +1 -1
  304. package/lib/esm/curve/internalContexts/PolygonOffsetContext.js.map +1 -1
  305. package/lib/esm/curve/internalContexts/SumLengthsContext.js.map +1 -1
  306. package/lib/esm/curve/internalContexts/TransferWithSplitArcs.js.map +1 -1
  307. package/lib/esm/curve/internalContexts/TransformInPlaceContext.js.map +1 -1
  308. package/lib/esm/curve/spiral/AustralianRailCorpXYEvaluator.js.map +1 -1
  309. package/lib/esm/curve/spiral/ClothoidSeries.js.map +1 -1
  310. package/lib/esm/curve/spiral/CubicEvaluator.js.map +1 -1
  311. package/lib/esm/curve/spiral/CzechSpiralEvaluator.js.map +1 -1
  312. package/lib/esm/curve/spiral/DirectHalfCosineSpiralEvaluator.js.map +1 -1
  313. package/lib/esm/curve/spiral/DirectSpiral3d.js.map +1 -1
  314. package/lib/esm/curve/spiral/IntegratedSpiral3d.js.map +1 -1
  315. package/lib/esm/curve/spiral/MXCubicAlongArcSpiralEvaluator.js.map +1 -1
  316. package/lib/esm/curve/spiral/NormalizedTransition.js.map +1 -1
  317. package/lib/esm/curve/spiral/PolishCubicSpiralEvaluator.js.map +1 -1
  318. package/lib/esm/curve/spiral/TransitionConditionalProperties.js.map +1 -1
  319. package/lib/esm/curve/spiral/TransitionSpiral3d.js.map +1 -1
  320. package/lib/esm/curve/spiral/XYCurveEvaluator.js.map +1 -1
  321. package/lib/esm/geometry3d/Angle.js.map +1 -1
  322. package/lib/esm/geometry3d/AngleSweep.js.map +1 -1
  323. package/lib/esm/geometry3d/BarycentricTriangle.js.map +1 -1
  324. package/lib/esm/geometry3d/BilinearPatch.js.map +1 -1
  325. package/lib/esm/geometry3d/CoincidentGeometryOps.js.map +1 -1
  326. package/lib/esm/geometry3d/Ellipsoid.js.map +1 -1
  327. package/lib/esm/geometry3d/FrameBuilder.js.map +1 -1
  328. package/lib/esm/geometry3d/FrustumAnimation.js.map +1 -1
  329. package/lib/esm/geometry3d/GeometryHandler.js.map +1 -1
  330. package/lib/esm/geometry3d/GrowableBlockedArray.js.map +1 -1
  331. package/lib/esm/geometry3d/GrowableFloat64Array.js.map +1 -1
  332. package/lib/esm/geometry3d/GrowableXYArray.js.map +1 -1
  333. package/lib/esm/geometry3d/GrowableXYZArray.js.map +1 -1
  334. package/lib/esm/geometry3d/IndexedCollectionInterval.js.map +1 -1
  335. package/lib/esm/geometry3d/IndexedXYCollection.js.map +1 -1
  336. package/lib/esm/geometry3d/IndexedXYZCollection.js.map +1 -1
  337. package/lib/esm/geometry3d/LongitudeLatitudeAltitude.js.map +1 -1
  338. package/lib/esm/geometry3d/Matrix3d.js.map +1 -1
  339. package/lib/esm/geometry3d/OrderedRotationAngles.js.map +1 -1
  340. package/lib/esm/geometry3d/Plane3d.js.map +1 -1
  341. package/lib/esm/geometry3d/Plane3dByOriginAndUnitNormal.js.map +1 -1
  342. package/lib/esm/geometry3d/Plane3dByOriginAndVectors.js.map +1 -1
  343. package/lib/esm/geometry3d/Point2dArrayCarrier.js.map +1 -1
  344. package/lib/esm/geometry3d/Point2dVector2d.js.map +1 -1
  345. package/lib/esm/geometry3d/Point3dArrayCarrier.js.map +1 -1
  346. package/lib/esm/geometry3d/Point3dVector3d.js.map +1 -1
  347. package/lib/esm/geometry3d/PointHelpers.js.map +1 -1
  348. package/lib/esm/geometry3d/PointStreaming.js.map +1 -1
  349. package/lib/esm/geometry3d/PolygonOps.js.map +1 -1
  350. package/lib/esm/geometry3d/PolylineCompressionByEdgeOffset.js.map +1 -1
  351. package/lib/esm/geometry3d/PolylineOps.js.map +1 -1
  352. package/lib/esm/geometry3d/Range.js.map +1 -1
  353. package/lib/esm/geometry3d/Ray2d.js.map +1 -1
  354. package/lib/esm/geometry3d/Ray3d.js.map +1 -1
  355. package/lib/esm/geometry3d/ReusableObjectCache.js.map +1 -1
  356. package/lib/esm/geometry3d/Segment1d.js.map +1 -1
  357. package/lib/esm/geometry3d/SortablePolygon.js.map +1 -1
  358. package/lib/esm/geometry3d/Transform.js.map +1 -1
  359. package/lib/esm/geometry3d/UVSurfaceOps.js.map +1 -1
  360. package/lib/esm/geometry3d/XYZProps.js.map +1 -1
  361. package/lib/esm/geometry3d/YawPitchRollAngles.js.map +1 -1
  362. package/lib/esm/geometry4d/Map4d.js.map +1 -1
  363. package/lib/esm/geometry4d/Matrix4d.js.map +1 -1
  364. package/lib/esm/geometry4d/MomentData.js.map +1 -1
  365. package/lib/esm/geometry4d/PlaneByOriginAndVectors4d.js.map +1 -1
  366. package/lib/esm/geometry4d/Point4d.js.map +1 -1
  367. package/lib/esm/numerics/BandedSystem.js.map +1 -1
  368. package/lib/esm/numerics/BezierPolynomials.js.map +1 -1
  369. package/lib/esm/numerics/ClusterableArray.js.map +1 -1
  370. package/lib/esm/numerics/Complex.js.map +1 -1
  371. package/lib/esm/numerics/ConvexPolygon2d.js.map +1 -1
  372. package/lib/esm/numerics/Newton.js.map +1 -1
  373. package/lib/esm/numerics/PascalCoefficients.js.map +1 -1
  374. package/lib/esm/numerics/PolarData.js.map +1 -1
  375. package/lib/esm/numerics/Polynomials.js.map +1 -1
  376. package/lib/esm/numerics/Quadrature.js.map +1 -1
  377. package/lib/esm/numerics/Range1dArray.js.map +1 -1
  378. package/lib/esm/numerics/SmallSystem.js.map +1 -1
  379. package/lib/esm/numerics/TriDiagonalSystem.js.map +1 -1
  380. package/lib/esm/numerics/UnionFind.js.map +1 -1
  381. package/lib/esm/numerics/UsageSums.js.map +1 -1
  382. package/lib/esm/polyface/AuxData.js.map +1 -1
  383. package/lib/esm/polyface/BoxTopology.js.map +1 -1
  384. package/lib/esm/polyface/FacetFaceData.js.map +1 -1
  385. package/lib/esm/polyface/FacetLocationDetail.js.map +1 -1
  386. package/lib/esm/polyface/FacetOrientation.js.map +1 -1
  387. package/lib/esm/polyface/GreedyTriangulationBetweenLineStrings.js.map +1 -1
  388. package/lib/esm/polyface/IndexedEdgeMatcher.js.map +1 -1
  389. package/lib/esm/polyface/IndexedPolyfaceVisitor.js.map +1 -1
  390. package/lib/esm/polyface/IndexedPolyfaceWalker.js.map +1 -1
  391. package/lib/esm/polyface/Polyface.js.map +1 -1
  392. package/lib/esm/polyface/PolyfaceBuilder.js.map +1 -1
  393. package/lib/esm/polyface/PolyfaceClip.js.map +1 -1
  394. package/lib/esm/polyface/PolyfaceData.js.map +1 -1
  395. package/lib/esm/polyface/PolyfaceQuery.js.map +1 -1
  396. package/lib/esm/polyface/RangeLengthData.js.map +1 -1
  397. package/lib/esm/polyface/RangeTree/LineString3dRangeTreeContext.js.map +1 -1
  398. package/lib/esm/polyface/RangeTree/MinimumValueTester.js.map +1 -1
  399. package/lib/esm/polyface/RangeTree/Point3dArrayRangeTreeContext.js.map +1 -1
  400. package/lib/esm/polyface/RangeTree/PolyfaceRangeTreeContext.js.map +1 -1
  401. package/lib/esm/polyface/RangeTree/RangeTreeNode.js.map +1 -1
  402. package/lib/esm/polyface/RangeTree/RangeTreeSearchHandlers.js.map +1 -1
  403. package/lib/esm/polyface/TaggedNumericData.js.map +1 -1
  404. package/lib/esm/polyface/TriangleCandidate.js.map +1 -1
  405. package/lib/esm/polyface/multiclip/BuildAverageNormalsContext.js.map +1 -1
  406. package/lib/esm/polyface/multiclip/GriddedRaggedRange2dSet.js.map +1 -1
  407. package/lib/esm/polyface/multiclip/GriddedRaggedRange2dSetWithOverflow.js.map +1 -1
  408. package/lib/esm/polyface/multiclip/LinearSearchRange2dArray.js.map +1 -1
  409. package/lib/esm/polyface/multiclip/OffsetMeshContext.js.map +1 -1
  410. package/lib/esm/polyface/multiclip/Range2dSearchInterface.js.map +1 -1
  411. package/lib/esm/polyface/multiclip/RangeSearch.js.map +1 -1
  412. package/lib/esm/polyface/multiclip/SweepLineStringToFacetContext.js.map +1 -1
  413. package/lib/esm/polyface/multiclip/XYPointBuckets.js.map +1 -1
  414. package/lib/esm/serialization/BGFBAccessors.js.map +1 -1
  415. package/lib/esm/serialization/BGFBReader.js.map +1 -1
  416. package/lib/esm/serialization/BGFBWriter.js.map +1 -1
  417. package/lib/esm/serialization/BentleyGeometryFlatBuffer.js.map +1 -1
  418. package/lib/esm/serialization/DeepCompare.js.map +1 -1
  419. package/lib/esm/serialization/GeometrySamples.js.map +1 -1
  420. package/lib/esm/serialization/IModelJsonSchema.js.map +1 -1
  421. package/lib/esm/serialization/SerializationHelpers.js.map +1 -1
  422. package/lib/esm/solid/Box.js.map +1 -1
  423. package/lib/esm/solid/Cone.js.map +1 -1
  424. package/lib/esm/solid/LinearSweep.js.map +1 -1
  425. package/lib/esm/solid/RotationalSweep.js.map +1 -1
  426. package/lib/esm/solid/RuledSweep.js.map +1 -1
  427. package/lib/esm/solid/SolidPrimitive.js.map +1 -1
  428. package/lib/esm/solid/Sphere.js.map +1 -1
  429. package/lib/esm/solid/SweepContour.js.map +1 -1
  430. package/lib/esm/solid/TorusPipe.js.map +1 -1
  431. package/lib/esm/topology/ChainMerge.js.map +1 -1
  432. package/lib/esm/topology/Graph.js.map +1 -1
  433. package/lib/esm/topology/HalfEdgeGraphFromIndexedLoopsContext.js.map +1 -1
  434. package/lib/esm/topology/HalfEdgeGraphSearch.js.map +1 -1
  435. package/lib/esm/topology/HalfEdgeGraphSpineContext.js.map +1 -1
  436. package/lib/esm/topology/HalfEdgeGraphValidation.js.map +1 -1
  437. package/lib/esm/topology/HalfEdgeMarkSet.js.map +1 -1
  438. package/lib/esm/topology/HalfEdgeNodeXYZUV.js.map +1 -1
  439. package/lib/esm/topology/HalfEdgePointInGraphSearch.js.map +1 -1
  440. package/lib/esm/topology/HalfEdgePositionDetail.js.map +1 -1
  441. package/lib/esm/topology/HalfEdgePriorityQueue.js.map +1 -1
  442. package/lib/esm/topology/InsertAndRetriangulateContext.js.map +1 -1
  443. package/lib/esm/topology/MaskManager.js.map +1 -1
  444. package/lib/esm/topology/Merging.js.map +1 -1
  445. package/lib/esm/topology/RegularizeFace.js.map +1 -1
  446. package/lib/esm/topology/SignedDataSummary.js.map +1 -1
  447. package/lib/esm/topology/SpaceTriangulation.js.map +1 -1
  448. package/lib/esm/topology/Triangulation.js.map +1 -1
  449. package/lib/esm/topology/Voronoi.js.map +1 -1
  450. package/lib/esm/topology/XYParitySearchContext.js.map +1 -1
  451. package/package.json +3 -3
@@ -1 +1 @@
1
- {"version":3,"file":"Triangulation.js","sourceRoot":"","sources":["../../../src/topology/Triangulation.ts"],"names":[],"mappings":"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","sourcesContent":["/*---------------------------------------------------------------------------------------------\r\n* Copyright (c) Bentley Systems, Incorporated. All rights reserved.\r\n* See LICENSE.md in the project root for license terms and full copyright notice.\r\n*--------------------------------------------------------------------------------------------*/\r\n\r\n/** @packageDocumentation\r\n * @module Topology\r\n */\r\n\r\nimport { ClipUtilities } from \"../clipping/ClipUtils\";\r\nimport { Geometry } from \"../Geometry\";\r\nimport { FrameBuilder } from \"../geometry3d/FrameBuilder\";\r\nimport { IndexedXYZCollection, LineStringDataVariant, MultiLineStringDataVariant } from \"../geometry3d/IndexedXYZCollection\";\r\nimport { Plane3dByOriginAndUnitNormal } from \"../geometry3d/Plane3dByOriginAndUnitNormal\";\r\nimport { Point3d } from \"../geometry3d/Point3dVector3d\";\r\nimport { Point3dArray } from \"../geometry3d/PointHelpers\";\r\nimport { PointStreamXYZXYZHandlerBase, VariantPointDataStream } from \"../geometry3d/PointStreaming\";\r\nimport { Range1d, Range2d } from \"../geometry3d/Range\";\r\nimport { Transform } from \"../geometry3d/Transform\";\r\nimport { XAndY } from \"../geometry3d/XYZProps\";\r\nimport { HalfEdge, HalfEdgeGraph, HalfEdgeMask } from \"./Graph\";\r\nimport { MarkedEdgeSet } from \"./HalfEdgeMarkSet\";\r\nimport { InsertAndRetriangulateContext, InsertedVertexZOptions } from \"./InsertAndRetriangulateContext\";\r\n\r\n/**\r\n * Static methods for triangulating polygons and points.\r\n * * Tolerances and tolerance usage are currently inconsistent, and not exposed to callers.\r\n * * @internal\r\n */\r\nexport class Triangulator {\r\n\r\n /** Given the six nodes that make up two bordering triangles, \"pinch\" and relocate the nodes to flip them\r\n * * The shared edge mates are c and e.\r\n * * (abc) are a triangle in CCW order\r\n * * (dfe) are a triangle in CCW order. (Note: dfe instead of def!!)\r\n */\r\n private static flipEdgeBetweenTriangles(a: HalfEdge, b: HalfEdge, c: HalfEdge, d: HalfEdge, e: HalfEdge, f: HalfEdge) {\r\n // Reassign all of the pointers\r\n HalfEdge.pinch(a, e);\r\n HalfEdge.pinch(c, d);\r\n HalfEdge.pinch(f, c);\r\n HalfEdge.pinch(e, b);\r\n\r\n // Move alpha and beta into the xy coordinates of their predecessors\r\n e.x = b.x;\r\n e.y = b.y;\r\n e.z = b.z;\r\n e.i = b.i;\r\n c.i = f.i;\r\n c.x = f.x;\r\n c.y = f.y;\r\n c.z = f.z;\r\n }\r\n /**\r\n * Given a node in triangle A on the edge shared by triangle B, test whether the far vertex of B lies inside the circumcircle of A.\r\n * @param nodeA node on the shared edge between triangles A and B.\r\n * @return The following are equivalent:\r\n * * return true\r\n * * the computed determinant is strongly positive (greater than epsilon)\r\n * * the far vertex of B lies strictly inside the circumcircle of A\r\n * * the quad AB fails the Delaunay condition\r\n * * the quad CD obtained from AB by switching to the other diagonal satisfies the Delaunay condition\r\n * * to satisfy Delaunay, the caller should flip the diagonal of AB (obtaining CD)\r\n */\r\n public static computeCircumcircleDeterminantIsStrongPositive(nodeA: HalfEdge): boolean {\r\n // Confusingly enough, what we are actually doing here is testing the quad CD.\r\n // * CD satisfies the Delaunay condition if and only if AB does not.\r\n // * So let AB be convex, with CCW triangles (A,A1,A2) and (B,B1,B2) where A and B are edge mates.\r\n // Then CD consists of two CCW triangles that share an edge between the vertices at A2 and B2.\r\n // We only have to test one of the two triangles of CD---whether its circumcircle contains the far vertex.\r\n // By a beautiful theorem (Corollary 5.7.1 in O'Rourke, Computational Geometry in C, 2nd ed.), the following\r\n // are equivalent based on the radial symmetry and convexity of the paraboloid P defined by z = x*x + y*y,\r\n // and the CCW triangle orientation:\r\n // * A is outside the circumcircle of the CCW triangle with vertices (A1,A2,B2).\r\n // * The volume of the tetrahedron (determinant) formed by the projections of the quad points to P is negative.\r\n // * The volume of the parallelepiped (triple product) formed by vectors u=A1-A, v=A2-A, w=B2-A projected to P is negative.\r\n // * The triple product u.(v x w) is negative.\r\n // * The triple product w.(v x u) is positive <-- this is what we compute below.\r\n // * The quad CD satisfies the Delaunay condition.\r\n // * The quad AB fails the Delaunay condition.\r\n // * Return true.\r\n // * When AB is non-convex, CD is convex and consists of a large CCW triangle that contains the other CW triangle.\r\n // This containment causes the triple product to be positive, which implies CD fails (and thus AB satisfies)\r\n // the Delaunay condition, so this method returns false.\r\n const nodeA1 = nodeA.faceSuccessor;\r\n const nodeA2 = nodeA1.faceSuccessor;\r\n if (nodeA2.faceSuccessor !== nodeA)\r\n return false;\r\n const nodeB = nodeA.edgeMate;\r\n const nodeB1 = nodeB.faceSuccessor;\r\n const nodeB2 = nodeB1.faceSuccessor;\r\n if (nodeB2.faceSuccessor !== nodeB)\r\n return false;\r\n const ux = nodeA1.x - nodeA.x;\r\n const uy = nodeA1.y - nodeA.y;\r\n const vx = nodeA2.x - nodeA.x;\r\n const vy = nodeA2.y - nodeA.y;\r\n if (Geometry.crossProductXYXY(ux, uy, vx, vy) < 0)\r\n return false;\r\n // we assume identical coordinates in pairs (nodeA, nodeB1) and (nodeA1, nodeB)\r\n const wx = nodeB2.x - nodeA.x;\r\n const wy = nodeB2.y - nodeA.y;\r\n const tx = wx * wx + wy * wy;\r\n const ty = vx * vx + vy * vy;\r\n const tz = ux * ux + uy * uy;\r\n const q = Geometry.tripleProduct(\r\n wx, wy, tx,\r\n vx, vy, ty,\r\n ux, uy, tz,\r\n );\r\n if (q < 0)\r\n return false;\r\n const denom = Math.abs(wx * vy * tz) + Math.abs(wy * ty * ux) + Math.abs(tx * vx * uy)\r\n + Math.abs(wx * ty * uy) + Math.abs(wy * vx * tz) + Math.abs(tx * vy * ux);\r\n return q > 1.0e-12 * denom;\r\n }\r\n\r\n /**\r\n * * Visit each node of the graph array\r\n * * If a flip would be possible, test the results of flipping using circumcircle condition\r\n * * If revealed to be an improvement, conduct the flip, mark involved nodes as unvisited, and repeat until all nodes are visited\r\n */\r\n public static flipTriangles(graph: HalfEdgeGraph): number {\r\n const edgeSet = MarkedEdgeSet.create(graph)!;\r\n for (const node of graph.allHalfEdges)\r\n edgeSet.addToSet(node);\r\n const numFlip = this.flipTrianglesInEdgeSet(graph, edgeSet);\r\n edgeSet.teardown();\r\n return numFlip;\r\n }\r\n\r\n /**\r\n * * Visit each node of the graph array\r\n * * If a flip would be possible, test the results of flipping using circumcircle condition\r\n * * If revealed to be an improvement, conduct the flip, mark involved nodes as unvisited, and repeat until all nodes are visited\r\n */\r\n public static flipTrianglesInEdgeSet(graph: HalfEdgeGraph, edgeSet: MarkedEdgeSet): number {\r\n const barrierMasks = HalfEdgeMask.EXTERIOR | HalfEdgeMask.PRIMARY_EDGE | HalfEdgeMask.BOUNDARY_EDGE;\r\n\r\n const nodeArray = graph.allHalfEdges;\r\n const maxTest = 10.0 * nodeArray.length;\r\n let numFlip = 0;\r\n let numOK = 0;\r\n let node;\r\n while (undefined !== (node = edgeSet.chooseAndRemoveAny())) {\r\n\r\n if (node.isMaskSet(barrierMasks)) // Flip not allowed\r\n continue;\r\n\r\n if (Triangulator.computeCircumcircleDeterminantIsStrongPositive(node)) {\r\n // Flip the triangles\r\n Triangulator.flipEdgeBetweenTriangles(node.edgeMate.faceSuccessor, node.edgeMate.facePredecessor, node.edgeMate, node.faceSuccessor, node, node.facePredecessor);\r\n // keep looking at the 2 faces\r\n edgeSet.addAroundFace(node);\r\n edgeSet.addAroundFace(node.edgeMate);\r\n numFlip++;\r\n } else {\r\n numOK++;\r\n }\r\n if (numFlip + numOK > maxTest)\r\n break;\r\n }\r\n return numFlip;\r\n }\r\n\r\n /**\r\n * Create a graph from an xy-triangulation of the given points. The triangulation is Delaunay.\r\n * * The outer boundary of the graph is the xy-convex hull of the points; it is marked `HalfEdgeMask.EXTERIOR`.\r\n * @param points the points to triangulate.\r\n * @param zRule optional rule for updating the z-coordinate of an existing vertex when an xy-duplicate point is\r\n * inserted into the graph. Default is `InsertedVertexZOptions.ReplaceIfLarger`.\r\n * @param pointTolerance optional xy-distance tolerance for equating vertices. Default is `Geometry.smallMetricDistance`.\r\n */\r\n public static createTriangulatedGraphFromPoints(\r\n points: Point3d[],\r\n zRule: InsertedVertexZOptions = InsertedVertexZOptions.ReplaceIfLarger,\r\n pointTolerance: number = Geometry.smallMetricDistance,\r\n ): HalfEdgeGraph | undefined {\r\n if (points.length < 3)\r\n return undefined;\r\n const hull: Point3d[] = [];\r\n const interior: Point3d[] = [];\r\n Point3dArray.computeConvexHullXY(points, hull, interior, true);\r\n const graph = new HalfEdgeGraph();\r\n const context = InsertAndRetriangulateContext.create(graph, pointTolerance);\r\n const face0 = Triangulator.createFaceLoopFromCoordinates(graph, hull, true, true);\r\n if (undefined === face0)\r\n return undefined;\r\n // HalfEdgeGraphMerge.clusterAndMergeXYTheta(graph);\r\n let numInsert = 0;\r\n for (const p of interior) {\r\n context.insertAndRetriangulate(p, zRule);\r\n numInsert++; // eslint-disable-line @typescript-eslint/no-unused-vars\r\n }\r\n if (face0.countEdgesAroundFace() > 3) // no strictly interior vertices to split the hull polygon, so triangulate it\r\n return Triangulator.createTriangulatedGraphFromSingleLoop(hull);\r\n return graph;\r\n }\r\n /**\r\n * * Only one outer loop permitted.\r\n * * Largest area loop is assumed outer.\r\n * @param loops an array of loops\r\n * @returns triangulated graph, or undefined if bad data.\r\n */\r\n public static createTriangulatedGraphFromLoops(loops: LineStringDataVariant[]): HalfEdgeGraph | undefined {\r\n if (loops.length < 1)\r\n return undefined;\r\n const mask = HalfEdgeMask.BOUNDARY_EDGE | HalfEdgeMask.PRIMARY_EDGE;\r\n const graph = new HalfEdgeGraph();\r\n const holeSeeds: HalfEdge[] = [];\r\n let maxArea = -10000.0;\r\n let maxAreaIndex = -1;\r\n // collect all the loops with pointers to the positive (inside)\r\n // remember which one has largest area.\r\n for (let i = 0; i < loops.length; i++) {\r\n let seed = Triangulator.directCreateFaceLoopFromCoordinates(graph, loops[i]);\r\n if (seed) {\r\n seed = seed.faceSuccessor; // directCreate returns tail\r\n const mate = seed.vertexSuccessor;\r\n seed.setMaskAroundFace(mask);\r\n mate.setMaskAroundFace(mask);\r\n const signedFaceArea = seed.signedFaceArea();\r\n const area = Math.abs(signedFaceArea);\r\n holeSeeds.push(signedFaceArea >= 0 ? seed : mate);\r\n if (i === 0 || area > maxArea) {\r\n maxArea = area;\r\n maxAreaIndex = i;\r\n }\r\n }\r\n }\r\n if (holeSeeds.length === 0)\r\n return undefined;\r\n // extract the max area seed ...\r\n const maxAreaFace = holeSeeds[maxAreaIndex];\r\n holeSeeds[maxAreaIndex] = holeSeeds[holeSeeds.length - 1];\r\n holeSeeds.pop();\r\n maxAreaFace.vertexSuccessor.setMaskAroundFace(HalfEdgeMask.EXTERIOR);\r\n // The hole seeds all have inside nodes. Set mask there and jump to outside.\r\n for (let i = 0; i < holeSeeds.length; i++) {\r\n const seed = holeSeeds[i];\r\n seed.setMaskAroundFace(HalfEdgeMask.EXTERIOR);\r\n holeSeeds[i] = this.getLeftmost(seed.vertexSuccessor);\r\n }\r\n\r\n const startingNode = Triangulator.spliceLeftMostNodesOfHoles(graph, maxAreaFace, holeSeeds);\r\n if (startingNode) {\r\n if (Triangulator.triangulateSingleFace(graph, startingNode))\r\n return graph;\r\n }\r\n return undefined;\r\n }\r\n /**\r\n * Triangulate all positive area faces of a (planar) graph.\r\n * * Area is computed using `HalfEdge.signedFaceArea`, which ignores z-coordinates.\r\n * @returns whether all indicated faces were triangulated successfully\r\n * @see [[triangulateAllInteriorFaces]]\r\n */\r\n public static triangulateAllPositiveAreaFaces(graph: HalfEdgeGraph): boolean {\r\n const seeds = graph.collectFaceLoops();\r\n let numFail = 0;\r\n for (const face of seeds) {\r\n if (face.countEdgesAroundFace() > 3) {\r\n const area = face.signedFaceArea();\r\n if (area > 0.0)\r\n if (!Triangulator.triangulateSingleFace(graph, face))\r\n numFail++;\r\n }\r\n }\r\n return numFail === 0;\r\n }\r\n\r\n private static _workTransform?: Transform;\r\n\r\n /**\r\n * Triangulate all interior faces of a graph.\r\n * * A random node is checked for each face; if it has the `HalfEdgeMask.EXTERIOR` mask, the face is ignored.\r\n * @param useLocalCoords whether to transform each face into local coords before triangulating.\r\n * This is useful if the graph has z-coordinates.\r\n * @param noFlips if false (default) perform edge-flipping after each ear cut for better aspect ratio.\r\n * Ignored if `useLocalCoords` is true, in which case flipping is not performed to avoid out-of-plane effects.\r\n * @returns whether all indicated faces were triangulated successfully\r\n * @see [[triangulateAllPositiveAreaFaces]]\r\n */\r\n public static triangulateAllInteriorFaces(graph: HalfEdgeGraph, useLocalCoords?: boolean, noFlips?: boolean): boolean {\r\n const seeds = graph.collectFaceLoops();\r\n const visited = useLocalCoords ? graph.grabMask() : HalfEdgeMask.NULL_MASK;\r\n noFlips = useLocalCoords || noFlips; // don't flip if using local coords\r\n let localToWorld: Transform | undefined;\r\n let nodes: Point3d[] | undefined;\r\n let nodeCount = 0;\r\n let numFail = 0;\r\n for (const face of seeds) {\r\n if (face.countEdgesAroundFace() > 3) {\r\n if (face.getMask(HalfEdgeMask.EXTERIOR))\r\n continue;\r\n if (useLocalCoords) {\r\n nodeCount = graph.countNodes();\r\n nodes = face.collectAroundFace();\r\n localToWorld = this._workTransform = FrameBuilder.createRightHandedLocalToWorld(nodes, this._workTransform);\r\n localToWorld?.multiplyInversePoint3dArrayInPlace(nodes);\r\n }\r\n if (!Triangulator.triangulateSingleFace(graph, face, noFlips))\r\n numFail++;\r\n if (localToWorld && nodes) {\r\n for (let iNewNode = nodeCount; iNewNode < graph.countNodes(); ++iNewNode)\r\n nodes.push(graph.allHalfEdges[iNewNode] as any);\r\n localToWorld.multiplyPoint3dArrayInPlace(nodes);\r\n }\r\n }\r\n }\r\n graph.dropMask(visited);\r\n return numFail === 0;\r\n }\r\n\r\n /**\r\n * Triangulate the polygon made up of by a series of points. The triangulation is Delaunay.\r\n * * The loop may be either CCW or CW -- CCW order will be used for triangles.\r\n * * To triangulate a polygon with holes, use createTriangulatedGraphFromLoops.\r\n */\r\n public static createTriangulatedGraphFromSingleLoop(data: LineStringDataVariant): HalfEdgeGraph | undefined {\r\n const graph = new HalfEdgeGraph();\r\n const startingNode = Triangulator.createFaceLoopFromCoordinates(graph, data, true, true);\r\n if (!startingNode || graph.countNodes() < 6)\r\n return undefined;\r\n if (!Triangulator.triangulateSingleFace(graph, startingNode))\r\n return undefined;\r\n Triangulator.flipTriangles(graph);\r\n return graph;\r\n }\r\n\r\n /**\r\n * cautiously split the edge starting at baseNode.\r\n * * If baseNode is null, create a trivial loop with the single vertex at xy\r\n * * if xy is distinct from the coordinates at both baseNode and its successor, insert xy as a new node within that edge.\r\n * * also include z coordinate if present.\r\n */\r\n private static interiorEdgeSplit(graph: HalfEdgeGraph, baseNode: HalfEdge | undefined, xy: XAndY | number[]): HalfEdge | undefined {\r\n let x = 0, y = 0, z = 0;\r\n if (Array.isArray(xy)) {\r\n x = xy[0];\r\n y = xy[1];\r\n z = xy.length > 2 ? xy[3] : 0.0;\r\n } else {\r\n const q = xy as any;\r\n if (q.hasOwnProperty(\"x\")) x = q.x;\r\n if (q.hasOwnProperty(\"y\")) y = q.y;\r\n if (q.hasOwnProperty(\"z\")) z = q.z;\r\n }\r\n if (!baseNode)\r\n return graph.splitEdge(baseNode, x, y, z);\r\n if (Triangulator.isAlmostEqualXAndYXY(baseNode, x, y))\r\n return baseNode;\r\n return graph.splitEdge(baseNode, x, y, z);\r\n }\r\n /** Return length of data without wraparound point(s), if present */\r\n private static getUnwrappedLength(data: LineStringDataVariant): number {\r\n let n = data.length;\r\n let x0: number, y0: number, x1: number, y1: number;\r\n while (n > 1) {\r\n if (data instanceof IndexedXYZCollection) {\r\n x0 = data.getXAtUncheckedPointIndex(0);\r\n y0 = data.getYAtUncheckedPointIndex(0);\r\n x1 = data.getXAtUncheckedPointIndex(n - 1);\r\n y1 = data.getYAtUncheckedPointIndex(n - 1);\r\n } else if (Geometry.isArrayOfNumberArray(data, n, 2)) {\r\n x0 = data[0][0];\r\n y0 = data[0][1];\r\n x1 = data[n - 1][0];\r\n y1 = data[n - 1][1];\r\n } else {\r\n x0 = data[0].x;\r\n y0 = data[0].y;\r\n x1 = data[n - 1].x;\r\n y1 = data[n - 1].y;\r\n }\r\n if (Geometry.isAlmostEqualNumber(x0, x1) && Geometry.isAlmostEqualNumber(y0, y1))\r\n --n;\r\n else\r\n break;\r\n }\r\n return n;\r\n }\r\n /** Create a loop from coordinates.\r\n * * Return a pointer to any node on the loop.\r\n * * no masking or other markup is applied.\r\n */\r\n public static directCreateFaceLoopFromCoordinates(graph: HalfEdgeGraph, data: LineStringDataVariant): HalfEdge | undefined {\r\n const n = this.getUnwrappedLength(data); // open it up to allow starting at a bridge edge\r\n let baseNode: HalfEdge | undefined;\r\n if (data instanceof IndexedXYZCollection) {\r\n const xyz = Point3d.create();\r\n for (let i = 0; i < n; i++) {\r\n data.getPoint3dAtCheckedPointIndex(i, xyz);\r\n baseNode = Triangulator.interiorEdgeSplit(graph, baseNode, xyz);\r\n }\r\n } else {\r\n for (let i = 0; i < n; i++)\r\n baseNode = Triangulator.interiorEdgeSplit(graph, baseNode, data[i]);\r\n }\r\n return baseNode;\r\n }\r\n\r\n /** Create chains from coordinates.\r\n * * Return array of pointers to base node of the chains.\r\n * * no masking or other markup is applied (save id).\r\n * @param graph New edges are built in this graph\r\n * @param data coordinate data\r\n * @param id id to attach to (both side of all) edges\r\n */\r\n public static directCreateChainsFromCoordinates(graph: HalfEdgeGraph, data: MultiLineStringDataVariant, id: number = 0): HalfEdge[] {\r\n const assembler = new AssembleXYZXYZChains(graph, id);\r\n VariantPointDataStream.streamXYZ(data, assembler);\r\n return assembler.claimSeeds();\r\n }\r\n\r\n /**\r\n * @param graph the containing graph\r\n * @param base The last node of a newly created loop. (i.e. its `faceSuccessor` has the start xy)\r\n * @param returnPositiveAreaLoop if true, return the start node on the side with positive area. otherwise return the left side as given.\r\n * @param maskForBothSides mask to apply on both sides.\r\n * @param maskForOtherSide mask to apply to the \"other\" side of the loop.\r\n * @return the loop's start node or its vertex successor, chosen to be the positive or negative loop per request.\r\n */\r\n private static maskAndOrientNewFaceLoop(_graph: HalfEdgeGraph, base: HalfEdge | undefined, returnPositiveAreaLoop: boolean,\r\n maskForBothSides: HalfEdgeMask,\r\n maskForOtherSide: HalfEdgeMask): HalfEdge | undefined {\r\n // base is the final coordinates\r\n if (base) {\r\n base = base.faceSuccessor; // because typical construction process leaves the \"live\" edge at the end of the loop.\r\n const area = base.signedFaceArea();\r\n const mate = base.edgeMate;\r\n if (maskForBothSides !== HalfEdgeMask.NULL_MASK) {\r\n base.setMaskAroundFace(maskForBothSides);\r\n mate.setMaskAroundFace(maskForBothSides);\r\n }\r\n\r\n let preferredNode = base;\r\n if (returnPositiveAreaLoop && (area < 0))\r\n preferredNode = mate;\r\n const otherNode = preferredNode.vertexSuccessor;\r\n\r\n if (maskForOtherSide !== HalfEdgeMask.NULL_MASK)\r\n otherNode.setMaskAroundFace(maskForOtherSide);\r\n return preferredNode;\r\n }\r\n return undefined;\r\n }\r\n /**\r\n * Create a circular doubly linked list of internal and external nodes from polygon points in the specified winding order.\r\n * * This applies the masks used by typical applications:\r\n * * HalfEdgeMask.BOUNDARY on both sides.\r\n * * HalfEdgeMask.PRIMARY_EDGE on both sides.\r\n * * Use [[createFaceLoopFromCoordinatesAndMasks]] for detailed control of masks.\r\n */\r\n public static createFaceLoopFromCoordinates(\r\n graph: HalfEdgeGraph, data: LineStringDataVariant, returnPositiveAreaLoop: boolean, markExterior: boolean,\r\n ): HalfEdge | undefined {\r\n const base = Triangulator.directCreateFaceLoopFromCoordinates(graph, data);\r\n return Triangulator.maskAndOrientNewFaceLoop(\r\n graph,\r\n base,\r\n returnPositiveAreaLoop,\r\n HalfEdgeMask.BOUNDARY_EDGE | HalfEdgeMask.PRIMARY_EDGE,\r\n markExterior ? HalfEdgeMask.EXTERIOR : HalfEdgeMask.NULL_MASK,\r\n );\r\n }\r\n /**\r\n * create a circular doubly linked list of internal and external nodes from polygon points.\r\n * * Optionally jump to the \"other\" side so the returned loop has positive area\r\n * @param graph graph to receive the new edges\r\n * @param data array with x,y coordinates\r\n * @param returnPositiveAreaLoop if false, return an edge proceeding around the loop in the order given. If true, compute the loop area and flip return the side with positive area.\r\n * @param maskForBothSides mask to apply on both sides.\r\n * @param maskForOtherSide mask to apply on the \"other\" side from the returned loop.\r\n */\r\n public static createFaceLoopFromCoordinatesAndMasks(graph: HalfEdgeGraph, data: LineStringDataVariant, returnPositiveAreaLoop: boolean,\r\n maskForBothSides: HalfEdgeMask,\r\n maskForOtherSide: HalfEdgeMask): HalfEdge | undefined {\r\n const base = Triangulator.directCreateFaceLoopFromCoordinates(graph, data);\r\n return Triangulator.maskAndOrientNewFaceLoop(graph, base, returnPositiveAreaLoop, maskForBothSides, maskForOtherSide);\r\n }\r\n\r\n /** Cut off an ear, forming a new face loop of nodes\r\n * @param ear the vertex being cut off.\r\n * * Form two new nodes, alpha and beta, which have the coordinates one step away from the ear vertex.\r\n * * Reassigns the pointers such that beta is left behind with the new face created\r\n * * Reassigns the pointers such that alpha becomes the resulting missing node from the remaining polygon\r\n * * Reassigns prevZ and nextZ pointers\r\n */\r\n private static joinNeighborsOfEar(graph: HalfEdgeGraph, ear: HalfEdge) {\r\n const alpha = graph.createEdgeXYZXYZ(\r\n ear.facePredecessor.x, ear.facePredecessor.y, ear.facePredecessor.z, ear.facePredecessor.i,\r\n ear.faceSuccessor.x, ear.faceSuccessor.y, ear.faceSuccessor.z, ear.faceSuccessor.i);\r\n const beta = alpha.edgeMate;\r\n\r\n // Add two nodes alpha and beta and reassign pointers (also mark triangle nodes as part of triangle)\r\n HalfEdge.pinch(ear.faceSuccessor, beta);\r\n HalfEdge.pinch(ear.facePredecessor, alpha);\r\n ear.setMaskAroundFace(HalfEdgeMask.TRIANGULATED_FACE);\r\n }\r\n private static isInteriorTriangle(a: HalfEdge) {\r\n if (!a.isMaskSet(HalfEdgeMask.TRIANGULATED_FACE) || a.isMaskSet(HalfEdgeMask.EXTERIOR))\r\n return false;\r\n const b = a.faceSuccessor;\r\n if (!b.isMaskSet(HalfEdgeMask.TRIANGULATED_FACE) || b.isMaskSet(HalfEdgeMask.EXTERIOR))\r\n return false;\r\n const c = b.faceSuccessor;\r\n if (!c.isMaskSet(HalfEdgeMask.TRIANGULATED_FACE) || c.isMaskSet(HalfEdgeMask.EXTERIOR))\r\n return false;\r\n return c.faceSuccessor === a;\r\n }\r\n\r\n /**\r\n * Perform 0, 1, or more edge flips to improve aspect ratio just behind an ear that was just cut.\r\n * @param ear the triangle corner which just served as the ear node.\r\n * @returns the node at the back corner after flipping, \"appropriately positioned\" for the usual advance to `ear.faceSuccessor.edgeMate.faceSuccessor`.\r\n */\r\n private static doPostCutFlips(ear: HalfEdge): HalfEdge {\r\n // B0 is at the ear vertex, inside ear triangle T = A0 B0 C.\r\n // C is the recently cut edge added to form the ear cap.\r\n // A0/B1 is the quad diagonal edge candidate to be flipped.\r\n // Triangle T' = B1 A1 D1 is on the other side of the quad diagonal.\r\n // The conditions for flipping are:\r\n // * both triangles T, T' must be masked with TRIANGULATED_FACE\r\n // * the Delaunay circumcircle condition flags the vertex at D1 as in the circumcircle of T\r\n // After flip, node A0 becomes D1.vertexSuccessor, and is the effective \"ear\", with (same) cap edge C.\r\n // The next quad diagonal edge candidate to consider in the loop is A1/D0.\r\n //\r\n // * *\r\n // . C| . / |\r\n // . | . C/B1|\r\n // . | . / |\r\n // . | . / |\r\n // . A0 ----> B0| . / |\r\n // *=====================* --> * A1 / B0 *\r\n // \\ A1 <---- B1 / \\ / /\r\n // \\ / \\ / /\r\n // \\ / \\ / /\r\n // \\ / \\ A0/D1/\r\n // D0 \\D1/ D0 \\/ /\r\n // * *\r\n let b0 = ear;\r\n let a0 = b0.facePredecessor;\r\n let b1 = a0.edgeMate;\r\n while (Triangulator.isInteriorTriangle(a0) && Triangulator.isInteriorTriangle(b1)) {\r\n const detA = Triangulator.computeCircumcircleDeterminantIsStrongPositive(a0);\r\n if (!detA)\r\n break;\r\n // Flip the triangles\r\n const a1 = b1.faceSuccessor;\r\n Triangulator.flipEdgeBetweenTriangles(a1, a1.faceSuccessor, a1.facePredecessor, b0, b0.facePredecessor, b0.faceSuccessor);\r\n b0 = a0;\r\n a0 = b0.facePredecessor;\r\n b1 = a0.edgeMate;\r\n // Move to next quad with diagonal a0/b1\r\n }\r\n return b0;\r\n }\r\n\r\n /**\r\n * Main ear slicing loop which triangulates the face starting at `ear`.\r\n * @param graph containing graph to receive new edges\r\n * @param ear sector at which to start triangulation of the containing face.\r\n * @param noFlips if false (default) perform edge-flipping after each ear cut for better aspect ratio.\r\n * Pass true if your graph isn't planar; otherwise, an edge can be flipped out of plane if the neighboring triangle is non-coplanar.\r\n */\r\n private static triangulateSingleFace(graph: HalfEdgeGraph, ear?: HalfEdge, noFlips: boolean = false): boolean {\r\n if (!ear) {\r\n Triangulator.setDebugGraph(graph);\r\n return false;\r\n }\r\n let next;\r\n let next2;\r\n let pred;\r\n let maxCandidate = ear.countEdgesAroundFace();\r\n let numCandidate = 0;\r\n ear.clearMaskAroundFace(HalfEdgeMask.TRIANGULATED_FACE);\r\n // iterate through ears, slicing them one by one\r\n while (!ear.isMaskSet(HalfEdgeMask.TRIANGULATED_FACE)) {\r\n pred = ear?.facePredecessor;\r\n next = ear.faceSuccessor;\r\n next2 = next.faceSuccessor;\r\n if (next === ear || next2 === ear)\r\n return true;\r\n if (next2.faceSuccessor === ear) {\r\n // if triangle, mask it so that its edges can potentially be flipped by doPostCutFlips()\r\n ear.setMaskAroundFace(HalfEdgeMask.TRIANGULATED_FACE);\r\n return true;\r\n }\r\n // The earcut algorithm does not support self intersections, however we do handle the re-entrant triangle\r\n // case by pinching a bridge/hole into existence when vertices i and i+3 live in the same face loop, but not\r\n // the same vertex loop. Earcut whittles larger faces down into triangles, so this is the only case needed.\r\n if (Triangulator.isAlmostEqualXAndYXY(next2, pred.x, pred.y) && !next2.findAroundVertex(pred)) {\r\n const next3 = next2.faceSuccessor;\r\n const hasBridgeEdgeOrHoleInside = this.nodeInTriangle(pred, ear, next, next3);\r\n if (hasBridgeEdgeOrHoleInside) {\r\n const nullOrHoleFace = next2.vertexPredecessor;\r\n HalfEdge.pinch(pred.vertexSuccessor, nullOrHoleFace); // keep pred and next2 in their face loop\r\n } else {\r\n HalfEdge.pinch(pred, next2); // pred and next2 split into different face loops\r\n ear.setMaskAroundFace(HalfEdgeMask.TRIANGULATED_FACE);\r\n }\r\n ear = next2;\r\n continue;\r\n }\r\n if (++numCandidate > maxCandidate) {\r\n Triangulator.setDebugGraph(graph);\r\n return false;\r\n }\r\n if (Triangulator.isEar(ear)) {\r\n maxCandidate--;\r\n numCandidate = 0;\r\n\r\n // skipping the next vertices leads to less sliver triangles\r\n\r\n // If we already have a separated triangle, do not join\r\n if (ear.faceSuccessor.faceSuccessor !== ear.facePredecessor) {\r\n Triangulator.joinNeighborsOfEar(graph, ear);\r\n if (!noFlips)\r\n ear = Triangulator.doPostCutFlips(ear);\r\n ear = ear.faceSuccessor.edgeMate.faceSuccessor;\r\n // another step? Nate's 2017 code went one more.\r\n } else {\r\n ear.setMaskAroundFace(HalfEdgeMask.TRIANGULATED_FACE);\r\n ear = next.faceSuccessor;\r\n }\r\n continue;\r\n }\r\n ear = next;\r\n }\r\n return true; // um .. I'm not sure what this state is.\r\n }\r\n /** @internal */\r\n private static sDebugGraph: HalfEdgeGraph | undefined;\r\n /** @internal */\r\n private static sEnableDebugGraphCapture = false;\r\n\r\n /**\r\n * * returns the (possibly undefined) debug graph.\r\n * * sets the debug graph to undefined.\r\n * * disables subsequent saving.\r\n * @internal */\r\n public static claimDebugGraph(): HalfEdgeGraph | undefined {\r\n const g = Triangulator.sDebugGraph;\r\n Triangulator.sDebugGraph = undefined;\r\n Triangulator.sEnableDebugGraphCapture = false;\r\n return g;\r\n }\r\n /** Call (from within the triangulator) to announce a graph to be saved for debug.\r\n * * If debug graph capture is not enabled, do nothing.\r\n * * If debug graph capture is enabled, save this graph.\r\n * * This is called by internal steps at point of failure to preserve the failing graph for unit test examination.\r\n * @internal */\r\n public static setDebugGraph(graph: HalfEdgeGraph | undefined) { if (Triangulator.sEnableDebugGraphCapture) Triangulator.sDebugGraph = graph; }\r\n /**\r\n * * Clear the debug graph\r\n * * Set capture enabled to indicated value.\r\n * * Intended use:\r\n * * By default \"enabled\" is false so there is no activity in the debug graph.\r\n * * A unit test which needs to see graph after failure calls clearAndEnableDebugGraphCapture (true)\r\n * * run the triangulation step\r\n * * call claimDebugGraph.\r\n * * claimDebugGraph reverts everything to default no-capture state.\r\n * @internal */\r\n public static clearAndEnableDebugGraphCapture(value: boolean) {\r\n Triangulator.sEnableDebugGraphCapture = value;\r\n Triangulator.sDebugGraph = undefined;\r\n }\r\n\r\n /**\r\n * Whether a and b are in same vertex loop, or at the same xy location.\r\n * @internal\r\n */\r\n private static findAroundOrAtVertex(a: HalfEdge, b: HalfEdge): boolean {\r\n if (a.findAroundVertex(b))\r\n return true;\r\n return Triangulator.isAlmostEqualXAndYXY(a, b.x, b.y);\r\n }\r\n\r\n // for reuse over all calls to isEar ....\r\n private static _edgeInterval = Range1d.createNull();\r\n private static _earRange = Range2d.createNull();\r\n private static _edgeRange = Range2d.createNull();\r\n private static _planes: Plane3dByOriginAndUnitNormal[] = [\r\n Plane3dByOriginAndUnitNormal.createXYPlane(),\r\n Plane3dByOriginAndUnitNormal.createXYPlane(),\r\n Plane3dByOriginAndUnitNormal.createXYPlane(),\r\n ];\r\n /** Check whether a polygon node forms a valid ear with adjacent nodes */\r\n private static isEar(ear: HalfEdge) {\r\n const a = ear.facePredecessor;\r\n const b = ear;\r\n const c = ear.faceSuccessor;\r\n const area = Triangulator.signedTolerancedCCWTriangleArea(a, b, c);\r\n if (area <= 0)\r\n return false; // reflex, can't be an ear\r\n const planes = this._planes;\r\n if (!Plane3dByOriginAndUnitNormal.createOriginAndTargetXY(a, b, planes[0])\r\n || !Plane3dByOriginAndUnitNormal.createOriginAndTargetXY(b, c, planes[1])\r\n || !Plane3dByOriginAndUnitNormal.createOriginAndTargetXY(c, a, planes[2]))\r\n return false;\r\n\r\n // now make sure we don't have other points inside the potential ear, or edges crossing.\r\n const earRange = this._earRange;\r\n const edgeRange = this._edgeRange;\r\n const edgeInterval = this._edgeInterval;\r\n Range2d.createXYXYXY(a.x, a.y, b.x, b.y, c.x, c.y, earRange);\r\n earRange.expandInPlace(Geometry.smallMetricDistance);\r\n let p = c;\r\n const zeroPlus = 1.0e-8;\r\n const zeroMinus = -zeroPlus;\r\n const onePlus = 1.0 + zeroPlus;\r\n const oneMinus = 1.0 - zeroPlus;\r\n const clipTolerance = 1.0e-10 * area;\r\n while (p !== a) {\r\n const q = p.faceSuccessor;\r\n Range2d.createXYXY(p.x, p.y, q.x, q.y, edgeRange);\r\n if (earRange.intersectsRange(edgeRange)) {\r\n // Does pq impinge on the triangle abc?\r\n Range1d.createXX(zeroMinus, onePlus, edgeInterval);\r\n ClipUtilities.clipSegmentBelowPlanesXY(planes, p, q, edgeInterval, clipTolerance);\r\n if (!edgeInterval.isNull) {\r\n if (edgeInterval.low > oneMinus) {\r\n // only q touches triangle abc, so b might still be an ear if q lies at a vertex\r\n if (!this.findAroundOrAtVertex(a, q)\r\n && !this.findAroundOrAtVertex(b, q)\r\n && !this.findAroundOrAtVertex(c, q))\r\n return false;\r\n } else if (edgeInterval.high < zeroPlus) {\r\n // only p touches triangle abc, so b might still be an ear if p lies at a vertex\r\n if (!this.findAroundOrAtVertex(a, p)\r\n && !this.findAroundOrAtVertex(b, p)\r\n && !this.findAroundOrAtVertex(c, p))\r\n return false;\r\n } else if (this.findAroundOrAtVertex(b, q) && this.findAroundOrAtVertex(c, p)) {\r\n // edge pq is the back side of bridge edge bc, so b might still be an ear\r\n } else if (this.findAroundOrAtVertex(a, q) && this.findAroundOrAtVertex(b, p)) {\r\n // edge pq is the back side of bridge edge ab, so b might still be an ear\r\n } else {\r\n return false; // edge pq intrudes into triangle abc, so b cannot be an ear\r\n }\r\n }\r\n }\r\n p = p.faceSuccessor;\r\n }\r\n return true;\r\n }\r\n /** link holeLoopNodes[1], holeLoopNodes[2] etc into the outer loop, producing a single-ring polygon without holes\r\n *\r\n */\r\n private static spliceLeftMostNodesOfHoles(graph: HalfEdgeGraph, outerNode: HalfEdge, leftMostHoleLoopNode: HalfEdge[]): HalfEdge | undefined {\r\n\r\n leftMostHoleLoopNode.sort((a, b) => Triangulator.compareX(a, b));\r\n let numFail = 0;\r\n // process holes from left to right\r\n for (const holeStart of leftMostHoleLoopNode) {\r\n if (!Triangulator.eliminateHole(graph, holeStart, outerNode))\r\n numFail++;\r\n }\r\n\r\n return numFail === 0 ? outerNode : undefined;\r\n }\r\n /** For use in sorting -- return (signed) difference (a.x - b.x) */\r\n private static compareX(a: HalfEdge, b: HalfEdge) {\r\n return a.x - b.x;\r\n }\r\n\r\n /** find a bridge between vertices that connects hole with an outer ring and and link it */\r\n private static eliminateHole(graph: HalfEdgeGraph, hole: HalfEdge, outerNode: HalfEdge): boolean {\r\n const outerNodeA = Triangulator.findHoleBridge(hole, outerNode);\r\n if (outerNodeA) {\r\n return Triangulator.splitFace(graph, outerNodeA, hole) !== undefined;\r\n }\r\n return false;\r\n }\r\n // cspell:word Eberly\r\n /**\r\n * David Eberly algorithm for finding a bridge between hole and outer polygon:\r\n * https://www.geometrictools.com/Documentation/TriangulationByEarClipping.pdf\r\n */\r\n private static findHoleBridge(hole: HalfEdge, outerNode?: HalfEdge): HalfEdge | undefined {\r\n let p = outerNode;\r\n\r\n if (!p)\r\n return undefined;\r\n\r\n const hx = hole.x;\r\n const hy = hole.y;\r\n let qx = -Infinity;\r\n let m;\r\n\r\n // find a segment intersected by a ray from the hole's leftmost point to the left;\r\n // segment's endpoint with lesser x will be potential connection point\r\n do {\r\n if (hy <= p.y && hy >= p.faceSuccessor.y && p.faceSuccessor.y !== p.y) {\r\n const x = p.x + (hy - p.y) * (p.faceSuccessor.x - p.x) / (p.faceSuccessor.y - p.y);\r\n if (x <= hx && x > qx) {\r\n qx = x;\r\n if (x === hx) {\r\n if (hy === p.y) return p;\r\n if (hy === p.faceSuccessor.y) return p.faceSuccessor;\r\n }\r\n m = p.x < p.faceSuccessor.x ? p : p.faceSuccessor;\r\n }\r\n }\r\n p = p.faceSuccessor;\r\n } while (p !== outerNode);\r\n\r\n if (!m) return undefined;\r\n\r\n if (hx === qx) return m.facePredecessor; // hole touches outer segment; pick lower endpoint\r\n\r\n // look for outer loop points p inside the triangle of hole point h, outer segment intersection (qx,hy), and outer segment endpoint m;\r\n // if there are no points found, we have a valid connection (m);\r\n // otherwise choose the point p with minimum angle with the ray as connection point\r\n\r\n const stop = m;\r\n const mx = m.x;\r\n const my = m.y;\r\n let tanMin = Infinity;\r\n let tan;\r\n\r\n p = m.faceSuccessor;\r\n\r\n while (p !== stop) {\r\n if (hx >= p.x && p.x >= mx && hx !== p.x &&\r\n Triangulator.pointInTriangle(hy < my ? hx : qx, hy, mx, my, hy < my ? qx : hx, hy, p.x, p.y)) {\r\n\r\n tan = Math.abs(hy - p.y) / (hx - p.x); // tangential\r\n\r\n if ((tan < tanMin || (tan === tanMin && p.x > m.x)) && Triangulator.locallyInside(p, hole)) {\r\n m = p;\r\n tanMin = tan;\r\n }\r\n }\r\n\r\n p = p.faceSuccessor;\r\n }\r\n\r\n return m;\r\n }\r\n\r\n // find the leftmost node of a polygon ring\r\n private static getLeftmost(start: HalfEdge) {\r\n let p = start;\r\n let leftmost = start;\r\n do {\r\n if (p.x < leftmost.x) leftmost = p;\r\n p = p.faceSuccessor;\r\n } while (p !== start);\r\n\r\n return leftmost;\r\n }\r\n\r\n /**\r\n * Check if a point lies within or on a triangle.\r\n * * In other words, the areas of the 3 triangles formed by an edge of abc and p all have zero or positive area.\r\n */\r\n private static pointInTriangle(ax: number, ay: number, bx: number, by: number, cx: number, cy: number, px: number, py: number) {\r\n return (cx - px) * (ay - py) - (ax - px) * (cy - py) >= 0 &&\r\n (ax - px) * (by - py) - (bx - px) * (ay - py) >= 0 &&\r\n (bx - px) * (cy - py) - (cx - px) * (by - py) >= 0;\r\n }\r\n /** Check if node p lies strictly inside the triangle abc. */\r\n private static nodeInTriangle(a: HalfEdge, b: HalfEdge, c: HalfEdge, p: HalfEdge) {\r\n return Triangulator.signedTolerancedCCWTriangleArea(a, b, p) > 0\r\n && Triangulator.signedTolerancedCCWTriangleArea(b, c, p) > 0\r\n && Triangulator.signedTolerancedCCWTriangleArea(c, a, p) > 0;\r\n }\r\n /** signed area of a triangle\r\n * EDL 2/21 This is negative of usual CCW area. Beware in callers !!!\r\n * (This originates in classic earcut code.)\r\n */\r\n private static signedCWTriangleArea(p: HalfEdge, q: HalfEdge, r: HalfEdge) {\r\n return 0.5 * ((q.y - p.y) * (r.x - q.x) - (q.x - p.x) * (r.y - q.y));\r\n }\r\n\r\n /** signed area of a triangle, with small positive corrected to zero by relTol */\r\n private static signedTolerancedCCWTriangleArea(p: HalfEdge, q: HalfEdge, r: HalfEdge, relTol: number = 1.0e-12) {\r\n const ux = q.x - p.x;\r\n const uy = q.y - p.y;\r\n const vx = r.x - p.x;\r\n const vy = r.y - p.y;\r\n const area = 0.5 * (ux * vy - uy * vx);\r\n if (area < 0.0)\r\n return area;\r\n const uu = ux * ux + uy * uy;\r\n const vv = vx * vx + vy * vy;\r\n if (area < relTol * (uu + vv))\r\n return 0.0;\r\n return area;\r\n }\r\n\r\n /** check if two points are equal */\r\n private static isAlmostEqualXAndYXY(p1: XAndY, x: number, y: number) {\r\n return Geometry.isAlmostEqualNumber(p1.x, x) && Geometry.isAlmostEqualNumber(p1.y, y);\r\n }\r\n\r\n /** check if a b is inside the sector around a */\r\n private static locallyInside(a: HalfEdge, b: HalfEdge) {\r\n return Triangulator.signedCWTriangleArea(a.facePredecessor, a, a.faceSuccessor) < 0 ?\r\n Triangulator.signedCWTriangleArea(a, b, a.faceSuccessor) >= 0 && Triangulator.signedCWTriangleArea(a, a.facePredecessor, b) >= 0 :\r\n Triangulator.signedCWTriangleArea(a, b, a.facePredecessor) < 0 || Triangulator.signedCWTriangleArea(a, a.faceSuccessor, b) < 0;\r\n }\r\n\r\n /**\r\n * link two polygon vertices with a bridge; if the vertices belong to the same ring, it splits polygon into two;\r\n * if one belongs to the outer ring and another to a hole, it merges it into a single ring\r\n * * Returns the base of the new edge at the \"a\" end.\r\n * * \"a\" and \"b\" still represent the same physical pieces of edges\r\n * @returns Returns the (base of) the new half edge, at the \"a\" end.\r\n */\r\n private static splitFace(graph: HalfEdgeGraph, a: HalfEdge, b: HalfEdge): HalfEdge | undefined {\r\n if (HalfEdge.isNodeVisibleInSector(a, b) && HalfEdge.isNodeVisibleInSector(b, a)) {\r\n const a2 = graph.createEdgeXYZXYZ(a.x, a.y, a.z, a.i, b.x, b.y, b.z, b.i);\r\n const b2 = a2.faceSuccessor;\r\n HalfEdge.pinch(a, a2);\r\n HalfEdge.pinch(b, b2);\r\n return a2;\r\n }\r\n return undefined;\r\n }\r\n\r\n /**\r\n * Triangulate a single face with (linear time) logic applicable only if the lowNode is the lowest node.\r\n * @returns false if any monotonicity condition is violated.\r\n */\r\n public static triangulateSingleMonotoneFace(graph: HalfEdgeGraph, start: HalfEdge): boolean {\r\n let left = start.facePredecessor;\r\n let right = start.faceSuccessor;\r\n // P0, P1, P2 are successive edges along evolving chain\r\n let upperSideOfNewEdge;\r\n while (left !== right\r\n && right !== start\r\n && right.faceSuccessor !== left) {\r\n /** These should not happen if face is monotone . .. */\r\n if (HalfEdge.crossProductXYAlongChain(left, start, right) <= 0)\r\n return false;\r\n if (!start.belowYX(left))\r\n return false;\r\n if (!start.belowYX(right))\r\n return false;\r\n if (left.belowYX(right)) {\r\n /* Triangulate to all left side edges that\r\n are below right */\r\n\r\n /* Phase 1: move upward, adding back edges\r\n when prior nodes are visible. */\r\n let P0 = left;\r\n let P1 = start;\r\n let P2 = right;\r\n /* Invariant: the path from P0 back to P1 is concave.\r\n Each loop pass moves P0 up the left side, filling in\r\n edges as needed. The right side edge\r\n (following start) is never altered.\r\n */\r\n while (P0 !== P2 && P0.belowYX(right)) {\r\n while (P2 !== right\r\n && P2 !== P0\r\n && P2 !== P1\r\n && HalfEdge.crossProductXYAlongChain(P0, P1, P2) > 0) {\r\n upperSideOfNewEdge = Triangulator.splitFace(graph, P0, P2);\r\n if (upperSideOfNewEdge === undefined)\r\n return false;\r\n P0 = upperSideOfNewEdge;\r\n P1 = P0.faceSuccessor;\r\n P2 = P1.faceSuccessor;\r\n }\r\n P2 = P1;\r\n P1 = P0;\r\n P0 = P0.facePredecessor;\r\n }\r\n /* Phase 2: Fan out edges from right to the\r\n left side. P0.P1.P2 describes a pair of\r\n adjacent edges at the bottom. */\r\n left = P1;\r\n P2 = right;\r\n P1 = P2.facePredecessor;\r\n P0 = P1.facePredecessor;\r\n while (P2.faceSuccessor !== P0 && P0 !== left) {\r\n upperSideOfNewEdge = Triangulator.splitFace(graph, P0, P2);\r\n if (upperSideOfNewEdge === undefined)\r\n return false;\r\n P1 = upperSideOfNewEdge;\r\n P0 = P1.facePredecessor;\r\n }\r\n /* Finish off with the last stroke from the\r\n left node to the right, except when already\r\n topped out */\r\n if (P2.faceSuccessor !== P0) {\r\n upperSideOfNewEdge = Triangulator.splitFace(graph, P0, P2);\r\n if (upperSideOfNewEdge === undefined)\r\n return false;\r\n P0 = upperSideOfNewEdge;\r\n }\r\n start = P0;\r\n right = start.faceSuccessor;\r\n left = start.facePredecessor;\r\n\r\n } else {\r\n /* Triangulate to all right side edges that\r\n are below left */\r\n\r\n /* Phase 1: move upward, adding back edges\r\n when prior nodes are visible. */\r\n let P0 = left;\r\n let P1 = start;\r\n let P2 = right;\r\n /* Invariant: the path up to P1 is concave.\r\n Each loop pass advances P1, filling in\r\n edges as needed. Note that the\r\n start edge may get hidden, so the\r\n bottom node must be referenced as\r\n left.faceSuccessor rather than as start.\r\n */\r\n while (P0 !== P2 && P2.belowYX(left)) {\r\n while (P0 !== left\r\n && P2 !== P0\r\n && P2 !== P1\r\n && HalfEdge.crossProductXYAlongChain(P0, P1, P2) > 0) {\r\n upperSideOfNewEdge = Triangulator.splitFace(graph, P0, P2);\r\n if (upperSideOfNewEdge === undefined)\r\n return false;\r\n\r\n P0 = upperSideOfNewEdge.facePredecessor;\r\n P1 = upperSideOfNewEdge;\r\n }\r\n P0 = P1;\r\n P1 = P2;\r\n P2 = P2.faceSuccessor;\r\n }\r\n /* Phase 2: Fan out edges from left to the\r\n right side. P0.P1.P2 describes a pair of\r\n adjacent edges at the bottom. */\r\n right = P1;\r\n P0 = left;\r\n P1 = P0.faceSuccessor;\r\n P2 = P1.faceSuccessor;\r\n while (P2.faceSuccessor !== P0 && P2 !== right) {\r\n upperSideOfNewEdge = Triangulator.splitFace(graph, P0, P2);\r\n if (upperSideOfNewEdge === undefined)\r\n return false;\r\n P0 = upperSideOfNewEdge;\r\n // P1 = P2; // original code (ported from native) carefully maintained P1..P2 relationship. But code analyzer says P1 is not used again. So skip it.\r\n P2 = P2.faceSuccessor;\r\n }\r\n /* Finish off with the last stroke from the\r\n left node to the right, except when already\r\n topped out */\r\n if (P2.faceSuccessor !== P0) {\r\n const newEdge = Triangulator.splitFace(graph, P0, P2);\r\n if (newEdge === undefined)\r\n return false;\r\n }\r\n start = right;\r\n right = start.faceSuccessor;\r\n left = start.facePredecessor;\r\n }\r\n }\r\n return true;\r\n }\r\n\r\n}\r\n\r\n/**\r\n * Internal class for assembling chains\r\n * @internal\r\n */\r\nclass AssembleXYZXYZChains extends PointStreamXYZXYZHandlerBase {\r\n // Add the starting nodes as the boundary, and apply initial masks to the primary edge and exteriors\r\n private _seeds?: HalfEdge[];\r\n private _baseNode: HalfEdge | undefined;\r\n private _nodeB: HalfEdge | undefined;\r\n private _nodeC: HalfEdge | undefined;\r\n private _graph: HalfEdgeGraph;\r\n private _id: any;\r\n public constructor(graph: HalfEdgeGraph, id: any) {\r\n super();\r\n this._graph = graph;\r\n this._id = id;\r\n }\r\n public override startChain(chainData: MultiLineStringDataVariant, isLeaf: boolean): void {\r\n super.startChain(chainData, isLeaf);\r\n this._baseNode = undefined;\r\n this._nodeB = undefined;\r\n }\r\n public override handleXYZXYZ(x0: number, y0: number, z0: number, x1: number, y1: number, z1: number) {\r\n this._nodeC = this._graph.createEdgeXYZXYZ(x0, y0, z0, this._id, x1, y1, z1, this._id);\r\n if (this._baseNode === undefined) {\r\n this._baseNode = this._nodeC;\r\n this._nodeB = this._baseNode.faceSuccessor;\r\n } else {\r\n HalfEdge.pinch(this._nodeB!, this._nodeC);\r\n this._nodeB = this._nodeC.faceSuccessor;\r\n }\r\n }\r\n public override endChain(chainData: MultiLineStringDataVariant, isLeaf: boolean): void {\r\n super.endChain(chainData, isLeaf);\r\n if (this._baseNode !== undefined) {\r\n if (this._seeds === undefined)\r\n this._seeds = [];\r\n this._seeds.push(this._baseNode);\r\n }\r\n this._baseNode = undefined;\r\n this._nodeB = undefined;\r\n this._nodeC = undefined;\r\n }\r\n public claimSeeds(): HalfEdge[] {\r\n if (this._seeds === undefined)\r\n return [];\r\n return this._seeds;\r\n }\r\n}\r\n"]}
1
+ {"version":3,"file":"Triangulation.js","sourceRoot":"","sources":["../../../src/topology/Triangulation.ts"],"names":[],"mappings":"AAAA;;;+FAG+F;AAE/F;;GAEG;AAEH,OAAO,EAAE,aAAa,EAAE,MAAM,uBAAuB,CAAC;AACtD,OAAO,EAAE,QAAQ,EAAE,MAAM,aAAa,CAAC;AACvC,OAAO,EAAE,YAAY,EAAE,MAAM,4BAA4B,CAAC;AAC1D,OAAO,EAAE,oBAAoB,EAAqD,MAAM,oCAAoC,CAAC;AAC7H,OAAO,EAAE,4BAA4B,EAAE,MAAM,4CAA4C,CAAC;AAC1F,OAAO,EAAE,OAAO,EAAE,MAAM,+BAA+B,CAAC;AACxD,OAAO,EAAE,YAAY,EAAE,MAAM,4BAA4B,CAAC;AAC1D,OAAO,EAAE,4BAA4B,EAAE,sBAAsB,EAAE,MAAM,8BAA8B,CAAC;AACpG,OAAO,EAAE,OAAO,EAAE,OAAO,EAAE,MAAM,qBAAqB,CAAC;AAGvD,OAAO,EAAE,QAAQ,EAAE,aAAa,EAAE,YAAY,EAAE,MAAM,SAAS,CAAC;AAChE,OAAO,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAC;AAClD,OAAO,EAAE,6BAA6B,EAAE,sBAAsB,EAAE,MAAM,iCAAiC,CAAC;AAExG;;;;GAIG;AACH,MAAM,OAAO,YAAY;IAEvB;;;;OAIG;IACK,MAAM,CAAC,wBAAwB,CAAC,CAAW,EAAE,CAAW,EAAE,CAAW,EAAE,CAAW,EAAE,CAAW,EAAE,CAAW;QAClH,+BAA+B;QAC/B,QAAQ,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;QACrB,QAAQ,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;QACrB,QAAQ,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;QACrB,QAAQ,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;QAErB,oEAAoE;QACpE,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;QACV,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;QACV,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;QACV,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;QACV,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;QACV,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;QACV,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;QACV,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;IACZ,CAAC;IACD;;;;;;;;;;OAUG;IACI,MAAM,CAAC,8CAA8C,CAAC,KAAe;QAC1E,8EAA8E;QAC9E,oEAAoE;QACpE,kGAAkG;QAClG,gGAAgG;QAChG,4GAA4G;QAC5G,8GAA8G;QAC9G,4GAA4G;QAC5G,sCAAsC;QACtC,kFAAkF;QAClF,iHAAiH;QACjH,6HAA6H;QAC7H,gDAAgD;QAChD,kFAAkF;QAClF,oDAAoD;QACpD,gDAAgD;QAChD,mBAAmB;QACnB,kHAAkH;QAClH,8GAA8G;QAC9G,0DAA0D;QAC1D,MAAM,MAAM,GAAG,KAAK,CAAC,aAAa,CAAC;QACnC,MAAM,MAAM,GAAG,MAAM,CAAC,aAAa,CAAC;QACpC,IAAI,MAAM,CAAC,aAAa,KAAK,KAAK;YAChC,OAAO,KAAK,CAAC;QACf,MAAM,KAAK,GAAG,KAAK,CAAC,QAAQ,CAAC;QAC7B,MAAM,MAAM,GAAG,KAAK,CAAC,aAAa,CAAC;QACnC,MAAM,MAAM,GAAG,MAAM,CAAC,aAAa,CAAC;QACpC,IAAI,MAAM,CAAC,aAAa,KAAK,KAAK;YAChC,OAAO,KAAK,CAAC;QACf,MAAM,EAAE,GAAG,MAAM,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC;QAC9B,MAAM,EAAE,GAAG,MAAM,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC;QAC9B,MAAM,EAAE,GAAG,MAAM,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC;QAC9B,MAAM,EAAE,GAAG,MAAM,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC;QAC9B,IAAI,QAAQ,CAAC,gBAAgB,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,GAAG,CAAC;YAC/C,OAAO,KAAK,CAAC;QACf,gFAAgF;QAChF,MAAM,EAAE,GAAG,MAAM,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC;QAC9B,MAAM,EAAE,GAAG,MAAM,CAAC,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC;QAC9B,MAAM,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC;QAC7B,MAAM,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC;QAC7B,MAAM,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC;QAC7B,MAAM,CAAC,GAAG,QAAQ,CAAC,aAAa,CAC9B,EAAE,EAAE,EAAE,EAAE,EAAE,EACV,EAAE,EAAE,EAAE,EAAE,EAAE,EACV,EAAE,EAAE,EAAE,EAAE,EAAE,CACX,CAAC;QACF,IAAI,CAAC,GAAG,CAAC;YACP,OAAO,KAAK,CAAC;QACf,MAAM,KAAK,GAAG,IAAI,CAAC,GAAG,CAAC,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC;cAClF,IAAI,CAAC,GAAG,CAAC,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC,CAAC;QAC7E,OAAO,CAAC,GAAG,OAAO,GAAG,KAAK,CAAC;IAC7B,CAAC;IAED;;;;OAIG;IACI,MAAM,CAAC,aAAa,CAAC,KAAoB;QAC9C,MAAM,OAAO,GAAG,aAAa,CAAC,MAAM,CAAC,KAAK,CAAE,CAAC;QAC7C,KAAK,MAAM,IAAI,IAAI,KAAK,CAAC,YAAY;YACnC,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;QACzB,MAAM,OAAO,GAAG,IAAI,CAAC,sBAAsB,CAAC,KAAK,EAAE,OAAO,CAAC,CAAC;QAC5D,OAAO,CAAC,QAAQ,EAAE,CAAC;QACnB,OAAO,OAAO,CAAC;IACjB,CAAC;IAED;;;;OAIG;IACI,MAAM,CAAC,sBAAsB,CAAC,KAAoB,EAAE,OAAsB;QAC/E,MAAM,YAAY,GAAG,YAAY,CAAC,QAAQ,GAAG,YAAY,CAAC,YAAY,GAAG,YAAY,CAAC,aAAa,CAAC;QAEpG,MAAM,SAAS,GAAG,KAAK,CAAC,YAAY,CAAC;QACrC,MAAM,OAAO,GAAG,IAAI,GAAG,SAAS,CAAC,MAAM,CAAC;QACxC,IAAI,OAAO,GAAG,CAAC,CAAC;QAChB,IAAI,KAAK,GAAG,CAAC,CAAC;QACd,IAAI,IAAI,CAAC;QACT,OAAO,SAAS,KAAK,CAAC,IAAI,GAAG,OAAO,CAAC,kBAAkB,EAAE,CAAC,EAAE,CAAC;YAE3D,IAAI,IAAI,CAAC,SAAS,CAAC,YAAY,CAAC,EAAE,mBAAmB;gBACnD,SAAS;YAEX,IAAI,YAAY,CAAC,8CAA8C,CAAC,IAAI,CAAC,EAAE,CAAC;gBACtE,qBAAqB;gBACrB,YAAY,CAAC,wBAAwB,CAAC,IAAI,CAAC,QAAQ,CAAC,aAAa,EAAE,IAAI,CAAC,QAAQ,CAAC,eAAe,EAAE,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC,aAAa,EAAE,IAAI,EAAE,IAAI,CAAC,eAAe,CAAC,CAAC;gBACjK,8BAA8B;gBAC9B,OAAO,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;gBAC5B,OAAO,CAAC,aAAa,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;gBACrC,OAAO,EAAE,CAAC;YACZ,CAAC;iBAAM,CAAC;gBACN,KAAK,EAAE,CAAC;YACV,CAAC;YACD,IAAI,OAAO,GAAG,KAAK,GAAG,OAAO;gBAC3B,MAAM;QACV,CAAC;QACD,OAAO,OAAO,CAAC;IACjB,CAAC;IAED;;;;;;;OAOG;IACI,MAAM,CAAC,iCAAiC,CAC7C,MAAiB,EACjB,QAAgC,sBAAsB,CAAC,eAAe,EACtE,iBAAyB,QAAQ,CAAC,mBAAmB;QAErD,IAAI,MAAM,CAAC,MAAM,GAAG,CAAC;YACnB,OAAO,SAAS,CAAC;QACnB,MAAM,IAAI,GAAc,EAAE,CAAC;QAC3B,MAAM,QAAQ,GAAc,EAAE,CAAC;QAC/B,YAAY,CAAC,mBAAmB,CAAC,MAAM,EAAE,IAAI,EAAE,QAAQ,EAAE,IAAI,CAAC,CAAC;QAC/D,MAAM,KAAK,GAAG,IAAI,aAAa,EAAE,CAAC;QAClC,MAAM,OAAO,GAAG,6BAA6B,CAAC,MAAM,CAAC,KAAK,EAAE,cAAc,CAAC,CAAC;QAC5E,MAAM,KAAK,GAAG,YAAY,CAAC,6BAA6B,CAAC,KAAK,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC;QAClF,IAAI,SAAS,KAAK,KAAK;YACrB,OAAO,SAAS,CAAC;QACnB,oDAAoD;QACpD,IAAI,SAAS,GAAG,CAAC,CAAC;QAClB,KAAK,MAAM,CAAC,IAAI,QAAQ,EAAE,CAAC;YACzB,OAAO,CAAC,sBAAsB,CAAC,CAAC,EAAE,KAAK,CAAC,CAAC;YACzC,SAAS,EAAE,CAAC,CAAC,wDAAwD;QACvE,CAAC;QACD,IAAI,KAAK,CAAC,oBAAoB,EAAE,GAAG,CAAC,EAAE,6EAA6E;YACjH,OAAO,YAAY,CAAC,qCAAqC,CAAC,IAAI,CAAC,CAAC;QAClE,OAAO,KAAK,CAAC;IACf,CAAC;IACD;;;;;OAKG;IACI,MAAM,CAAC,gCAAgC,CAAC,KAA8B;QAC3E,IAAI,KAAK,CAAC,MAAM,GAAG,CAAC;YAClB,OAAO,SAAS,CAAC;QACnB,MAAM,IAAI,GAAG,YAAY,CAAC,aAAa,GAAG,YAAY,CAAC,YAAY,CAAC;QACpE,MAAM,KAAK,GAAG,IAAI,aAAa,EAAE,CAAC;QAClC,MAAM,SAAS,GAAe,EAAE,CAAC;QACjC,IAAI,OAAO,GAAG,CAAC,OAAO,CAAC;QACvB,IAAI,YAAY,GAAG,CAAC,CAAC,CAAC;QACtB,+DAA+D;QAC/D,uCAAuC;QACvC,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,KAAK,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC;YACtC,IAAI,IAAI,GAAG,YAAY,CAAC,mCAAmC,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;YAC7E,IAAI,IAAI,EAAE,CAAC;gBACT,IAAI,GAAG,IAAI,CAAC,aAAa,CAAC,CAAE,4BAA4B;gBACxD,MAAM,IAAI,GAAG,IAAI,CAAC,eAAe,CAAC;gBAClC,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,CAAC;gBAC7B,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,CAAC;gBAC7B,MAAM,cAAc,GAAG,IAAI,CAAC,cAAc,EAAE,CAAC;gBAC7C,MAAM,IAAI,GAAG,IAAI,CAAC,GAAG,CAAC,cAAc,CAAC,CAAC;gBACtC,SAAS,CAAC,IAAI,CAAC,cAAc,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC;gBAClD,IAAI,CAAC,KAAK,CAAC,IAAI,IAAI,GAAG,OAAO,EAAE,CAAC;oBAC9B,OAAO,GAAG,IAAI,CAAC;oBACf,YAAY,GAAG,CAAC,CAAC;gBACnB,CAAC;YACH,CAAC;QACH,CAAC;QACD,IAAI,SAAS,CAAC,MAAM,KAAK,CAAC;YACxB,OAAO,SAAS,CAAC;QACnB,gCAAgC;QAChC,MAAM,WAAW,GAAG,SAAS,CAAC,YAAY,CAAC,CAAC;QAC5C,SAAS,CAAC,YAAY,CAAC,GAAG,SAAS,CAAC,SAAS,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;QAC1D,SAAS,CAAC,GAAG,EAAE,CAAC;QAChB,WAAW,CAAC,eAAe,CAAC,iBAAiB,CAAC,YAAY,CAAC,QAAQ,CAAC,CAAC;QACrE,6EAA6E;QAC7E,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,SAAS,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC;YAC1C,MAAM,IAAI,GAAG,SAAS,CAAC,CAAC,CAAC,CAAC;YAC1B,IAAI,CAAC,iBAAiB,CAAC,YAAY,CAAC,QAAQ,CAAC,CAAC;YAC9C,SAAS,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;QACxD,CAAC;QAED,MAAM,YAAY,GAAG,YAAY,CAAC,0BAA0B,CAAC,KAAK,EAAE,WAAW,EAAE,SAAS,CAAC,CAAC;QAC5F,IAAI,YAAY,EAAE,CAAC;YACjB,IAAI,YAAY,CAAC,qBAAqB,CAAC,KAAK,EAAE,YAAY,CAAC;gBACzD,OAAO,KAAK,CAAC;QACjB,CAAC;QACD,OAAO,SAAS,CAAC;IACnB,CAAC;IACD;;;;;OAKG;IACI,MAAM,CAAC,+BAA+B,CAAC,KAAoB;QAChE,MAAM,KAAK,GAAG,KAAK,CAAC,gBAAgB,EAAE,CAAC;QACvC,IAAI,OAAO,GAAG,CAAC,CAAC;QAChB,KAAK,MAAM,IAAI,IAAI,KAAK,EAAE,CAAC;YACzB,IAAI,IAAI,CAAC,oBAAoB,EAAE,GAAG,CAAC,EAAE,CAAC;gBACpC,MAAM,IAAI,GAAG,IAAI,CAAC,cAAc,EAAE,CAAC;gBACnC,IAAI,IAAI,GAAG,GAAG;oBACZ,IAAI,CAAC,YAAY,CAAC,qBAAqB,CAAC,KAAK,EAAE,IAAI,CAAC;wBAClD,OAAO,EAAE,CAAC;YAChB,CAAC;QACH,CAAC;QACD,OAAO,OAAO,KAAK,CAAC,CAAC;IACvB,CAAC;IAEO,MAAM,CAAC,cAAc,CAAa;IAE1C;;;;;;;;;OASG;IACI,MAAM,CAAC,2BAA2B,CAAC,KAAoB,EAAE,cAAwB,EAAE,OAAiB;QACzG,MAAM,KAAK,GAAG,KAAK,CAAC,gBAAgB,EAAE,CAAC;QACvC,MAAM,OAAO,GAAG,cAAc,CAAC,CAAC,CAAC,KAAK,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC,YAAY,CAAC,SAAS,CAAC;QAC3E,OAAO,GAAG,cAAc,IAAI,OAAO,CAAC,CAAC,mCAAmC;QACxE,IAAI,YAAmC,CAAC;QACxC,IAAI,KAA4B,CAAC;QACjC,IAAI,SAAS,GAAG,CAAC,CAAC;QAClB,IAAI,OAAO,GAAG,CAAC,CAAC;QAChB,KAAK,MAAM,IAAI,IAAI,KAAK,EAAE,CAAC;YACzB,IAAI,IAAI,CAAC,oBAAoB,EAAE,GAAG,CAAC,EAAE,CAAC;gBACpC,IAAI,IAAI,CAAC,OAAO,CAAC,YAAY,CAAC,QAAQ,CAAC;oBACrC,SAAS;gBACX,IAAI,cAAc,EAAE,CAAC;oBACnB,SAAS,GAAG,KAAK,CAAC,UAAU,EAAE,CAAC;oBAC/B,KAAK,GAAG,IAAI,CAAC,iBAAiB,EAAE,CAAC;oBACjC,YAAY,GAAG,IAAI,CAAC,cAAc,GAAG,YAAY,CAAC,6BAA6B,CAAC,KAAK,EAAE,IAAI,CAAC,cAAc,CAAC,CAAC;oBAC5G,YAAY,EAAE,kCAAkC,CAAC,KAAK,CAAC,CAAC;gBAC1D,CAAC;gBACD,IAAI,CAAC,YAAY,CAAC,qBAAqB,CAAC,KAAK,EAAE,IAAI,EAAE,OAAO,CAAC;oBAC3D,OAAO,EAAE,CAAC;gBACZ,IAAI,YAAY,IAAI,KAAK,EAAE,CAAC;oBAC1B,KAAK,IAAI,QAAQ,GAAG,SAAS,EAAE,QAAQ,GAAG,KAAK,CAAC,UAAU,EAAE,EAAE,EAAE,QAAQ;wBACtE,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,QAAQ,CAAQ,CAAC,CAAC;oBAClD,YAAY,CAAC,2BAA2B,CAAC,KAAK,CAAC,CAAC;gBAClD,CAAC;YACH,CAAC;QACH,CAAC;QACD,KAAK,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC;QACxB,OAAO,OAAO,KAAK,CAAC,CAAC;IACvB,CAAC;IAED;;;;OAIG;IACI,MAAM,CAAC,qCAAqC,CAAC,IAA2B;QAC7E,MAAM,KAAK,GAAG,IAAI,aAAa,EAAE,CAAC;QAClC,MAAM,YAAY,GAAG,YAAY,CAAC,6BAA6B,CAAC,KAAK,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC;QACzF,IAAI,CAAC,YAAY,IAAI,KAAK,CAAC,UAAU,EAAE,GAAG,CAAC;YACzC,OAAO,SAAS,CAAC;QACnB,IAAI,CAAC,YAAY,CAAC,qBAAqB,CAAC,KAAK,EAAE,YAAY,CAAC;YAC1D,OAAO,SAAS,CAAC;QACnB,YAAY,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;QAClC,OAAO,KAAK,CAAC;IACf,CAAC;IAED;;;;;OAKG;IACK,MAAM,CAAC,iBAAiB,CAAC,KAAoB,EAAE,QAA8B,EAAE,EAAoB;QACzG,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC;QACxB,IAAI,KAAK,CAAC,OAAO,CAAC,EAAE,CAAC,EAAE,CAAC;YACtB,CAAC,GAAG,EAAE,CAAC,CAAC,CAAC,CAAC;YACV,CAAC,GAAG,EAAE,CAAC,CAAC,CAAC,CAAC;YACV,CAAC,GAAG,EAAE,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC;QAClC,CAAC;aAAM,CAAC;YACN,MAAM,CAAC,GAAG,EAAS,CAAC;YACpB,IAAI,CAAC,CAAC,cAAc,CAAC,GAAG,CAAC;gBAAE,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;YACnC,IAAI,CAAC,CAAC,cAAc,CAAC,GAAG,CAAC;gBAAE,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;YACnC,IAAI,CAAC,CAAC,cAAc,CAAC,GAAG,CAAC;gBAAE,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;QACrC,CAAC;QACD,IAAI,CAAC,QAAQ;YACX,OAAO,KAAK,CAAC,SAAS,CAAC,QAAQ,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;QAC5C,IAAI,YAAY,CAAC,oBAAoB,CAAC,QAAQ,EAAE,CAAC,EAAE,CAAC,CAAC;YACnD,OAAO,QAAQ,CAAC;QAClB,OAAO,KAAK,CAAC,SAAS,CAAC,QAAQ,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;IAC5C,CAAC;IACD,oEAAoE;IAC5D,MAAM,CAAC,kBAAkB,CAAC,IAA2B;QAC3D,IAAI,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC;QACpB,IAAI,EAAU,EAAE,EAAU,EAAE,EAAU,EAAE,EAAU,CAAC;QACnD,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC;YACb,IAAI,IAAI,YAAY,oBAAoB,EAAE,CAAC;gBACzC,EAAE,GAAG,IAAI,CAAC,yBAAyB,CAAC,CAAC,CAAC,CAAC;gBACvC,EAAE,GAAG,IAAI,CAAC,yBAAyB,CAAC,CAAC,CAAC,CAAC;gBACvC,EAAE,GAAG,IAAI,CAAC,yBAAyB,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;gBAC3C,EAAE,GAAG,IAAI,CAAC,yBAAyB,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;YAC7C,CAAC;iBAAM,IAAI,QAAQ,CAAC,oBAAoB,CAAC,IAAI,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC;gBACrD,EAAE,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;gBAChB,EAAE,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;gBAChB,EAAE,GAAG,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;gBACpB,EAAE,GAAG,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;YACtB,CAAC;iBAAM,CAAC;gBACN,EAAE,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;gBACf,EAAE,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;gBACf,EAAE,GAAG,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;gBACnB,EAAE,GAAG,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;YACrB,CAAC;YACD,IAAI,QAAQ,CAAC,mBAAmB,CAAC,EAAE,EAAE,EAAE,CAAC,IAAI,QAAQ,CAAC,mBAAmB,CAAC,EAAE,EAAE,EAAE,CAAC;gBAC9E,EAAE,CAAC,CAAC;;gBAEJ,MAAM;QACV,CAAC;QACD,OAAO,CAAC,CAAC;IACX,CAAC;IACD;;;OAGG;IACI,MAAM,CAAC,mCAAmC,CAAC,KAAoB,EAAE,IAA2B;QACjG,MAAM,CAAC,GAAG,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,CAAC,CAAE,gDAAgD;QAC1F,IAAI,QAA8B,CAAC;QACnC,IAAI,IAAI,YAAY,oBAAoB,EAAE,CAAC;YACzC,MAAM,GAAG,GAAG,OAAO,CAAC,MAAM,EAAE,CAAC;YAC7B,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC;gBAC3B,IAAI,CAAC,6BAA6B,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC;gBAC3C,QAAQ,GAAG,YAAY,CAAC,iBAAiB,CAAC,KAAK,EAAE,QAAQ,EAAE,GAAG,CAAC,CAAC;YAClE,CAAC;QACH,CAAC;aAAM,CAAC;YACN,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE;gBACxB,QAAQ,GAAG,YAAY,CAAC,iBAAiB,CAAC,KAAK,EAAE,QAAQ,EAAE,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC;QACxE,CAAC;QACD,OAAO,QAAQ,CAAC;IAClB,CAAC;IAED;;;;;;OAMG;IACI,MAAM,CAAC,iCAAiC,CAAC,KAAoB,EAAE,IAAgC,EAAE,KAAa,CAAC;QACpH,MAAM,SAAS,GAAG,IAAI,oBAAoB,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;QACtD,sBAAsB,CAAC,SAAS,CAAC,IAAI,EAAE,SAAS,CAAC,CAAC;QAClD,OAAO,SAAS,CAAC,UAAU,EAAE,CAAC;IAChC,CAAC;IAED;;;;;;;OAOG;IACK,MAAM,CAAC,wBAAwB,CAAC,MAAqB,EAAE,IAA0B,EAAE,sBAA+B,EACxH,gBAA8B,EAC9B,gBAA8B;QAC9B,gCAAgC;QAChC,IAAI,IAAI,EAAE,CAAC;YACT,IAAI,GAAG,IAAI,CAAC,aAAa,CAAC,CAAC,sFAAsF;YACjH,MAAM,IAAI,GAAG,IAAI,CAAC,cAAc,EAAE,CAAC;YACnC,MAAM,IAAI,GAAG,IAAI,CAAC,QAAQ,CAAC;YAC3B,IAAI,gBAAgB,KAAK,YAAY,CAAC,SAAS,EAAE,CAAC;gBAChD,IAAI,CAAC,iBAAiB,CAAC,gBAAgB,CAAC,CAAC;gBACzC,IAAI,CAAC,iBAAiB,CAAC,gBAAgB,CAAC,CAAC;YAC3C,CAAC;YAED,IAAI,aAAa,GAAG,IAAI,CAAC;YACzB,IAAI,sBAAsB,IAAI,CAAC,IAAI,GAAG,CAAC,CAAC;gBACtC,aAAa,GAAG,IAAI,CAAC;YACvB,MAAM,SAAS,GAAG,aAAa,CAAC,eAAe,CAAC;YAEhD,IAAI,gBAAgB,KAAK,YAAY,CAAC,SAAS;gBAC7C,SAAS,CAAC,iBAAiB,CAAC,gBAAgB,CAAC,CAAC;YAChD,OAAO,aAAa,CAAC;QACvB,CAAC;QACD,OAAO,SAAS,CAAC;IACnB,CAAC;IACD;;;;;;OAMG;IACI,MAAM,CAAC,6BAA6B,CACzC,KAAoB,EAAE,IAA2B,EAAE,sBAA+B,EAAE,YAAqB;QAEzG,MAAM,IAAI,GAAG,YAAY,CAAC,mCAAmC,CAAC,KAAK,EAAE,IAAI,CAAC,CAAC;QAC3E,OAAO,YAAY,CAAC,wBAAwB,CAC1C,KAAK,EACL,IAAI,EACJ,sBAAsB,EACtB,YAAY,CAAC,aAAa,GAAG,YAAY,CAAC,YAAY,EACtD,YAAY,CAAC,CAAC,CAAC,YAAY,CAAC,QAAQ,CAAC,CAAC,CAAC,YAAY,CAAC,SAAS,CAC9D,CAAC;IACJ,CAAC;IACD;;;;;;;;OAQG;IACI,MAAM,CAAC,qCAAqC,CAAC,KAAoB,EAAE,IAA2B,EAAE,sBAA+B,EACpI,gBAA8B,EAC9B,gBAA8B;QAC9B,MAAM,IAAI,GAAG,YAAY,CAAC,mCAAmC,CAAC,KAAK,EAAE,IAAI,CAAC,CAAC;QAC3E,OAAO,YAAY,CAAC,wBAAwB,CAAC,KAAK,EAAE,IAAI,EAAE,sBAAsB,EAAE,gBAAgB,EAAE,gBAAgB,CAAC,CAAC;IACxH,CAAC;IAED;;;;;;OAMG;IACK,MAAM,CAAC,kBAAkB,CAAC,KAAoB,EAAE,GAAa;QACnE,MAAM,KAAK,GAAG,KAAK,CAAC,gBAAgB,CAClC,GAAG,CAAC,eAAe,CAAC,CAAC,EAAE,GAAG,CAAC,eAAe,CAAC,CAAC,EAAE,GAAG,CAAC,eAAe,CAAC,CAAC,EAAE,GAAG,CAAC,eAAe,CAAC,CAAC,EAC1F,GAAG,CAAC,aAAa,CAAC,CAAC,EAAE,GAAG,CAAC,aAAa,CAAC,CAAC,EAAE,GAAG,CAAC,aAAa,CAAC,CAAC,EAAE,GAAG,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC;QACtF,MAAM,IAAI,GAAG,KAAK,CAAC,QAAQ,CAAC;QAE5B,oGAAoG;QACpG,QAAQ,CAAC,KAAK,CAAC,GAAG,CAAC,aAAa,EAAE,IAAI,CAAC,CAAC;QACxC,QAAQ,CAAC,KAAK,CAAC,GAAG,CAAC,eAAe,EAAE,KAAK,CAAC,CAAC;QAC3C,GAAG,CAAC,iBAAiB,CAAC,YAAY,CAAC,iBAAiB,CAAC,CAAC;IACxD,CAAC;IACO,MAAM,CAAC,kBAAkB,CAAC,CAAW;QAC3C,IAAI,CAAC,CAAC,CAAC,SAAS,CAAC,YAAY,CAAC,iBAAiB,CAAC,IAAI,CAAC,CAAC,SAAS,CAAC,YAAY,CAAC,QAAQ,CAAC;YACpF,OAAO,KAAK,CAAC;QACf,MAAM,CAAC,GAAG,CAAC,CAAC,aAAa,CAAC;QAC1B,IAAI,CAAC,CAAC,CAAC,SAAS,CAAC,YAAY,CAAC,iBAAiB,CAAC,IAAI,CAAC,CAAC,SAAS,CAAC,YAAY,CAAC,QAAQ,CAAC;YACpF,OAAO,KAAK,CAAC;QACf,MAAM,CAAC,GAAG,CAAC,CAAC,aAAa,CAAC;QAC1B,IAAI,CAAC,CAAC,CAAC,SAAS,CAAC,YAAY,CAAC,iBAAiB,CAAC,IAAI,CAAC,CAAC,SAAS,CAAC,YAAY,CAAC,QAAQ,CAAC;YACpF,OAAO,KAAK,CAAC;QACf,OAAO,CAAC,CAAC,aAAa,KAAK,CAAC,CAAC;IAC/B,CAAC;IAED;;;;OAIG;IACK,MAAM,CAAC,cAAc,CAAC,GAAa;QACzC,4DAA4D;QAC5D,wDAAwD;QACxD,2DAA2D;QAC3D,oEAAoE;QACpE,mCAAmC;QACnC,iEAAiE;QACjE,6FAA6F;QAC7F,sGAAsG;QACtG,0EAA0E;QAC1E,EAAE;QACF,8DAA8D;QAC9D,8DAA8D;QAC9D,8DAA8D;QAC9D,8DAA8D;QAC9D,8DAA8D;QAC9D,8DAA8D;QAC9D,8DAA8D;QAC9D,4DAA4D;QAC5D,0DAA0D;QAC1D,wDAAwD;QACxD,sDAAsD;QACtD,oDAAoD;QACpD,kDAAkD;QAClD,IAAI,EAAE,GAAG,GAAG,CAAC;QACb,IAAI,EAAE,GAAG,EAAE,CAAC,eAAe,CAAC;QAC5B,IAAI,EAAE,GAAG,EAAE,CAAC,QAAQ,CAAC;QACrB,OAAO,YAAY,CAAC,kBAAkB,CAAC,EAAE,CAAC,IAAI,YAAY,CAAC,kBAAkB,CAAC,EAAE,CAAC,EAAE,CAAC;YAClF,MAAM,IAAI,GAAG,YAAY,CAAC,8CAA8C,CAAC,EAAE,CAAC,CAAC;YAC7E,IAAI,CAAC,IAAI;gBACP,MAAM;YACR,qBAAqB;YACrB,MAAM,EAAE,GAAG,EAAE,CAAC,aAAa,CAAC;YAC5B,YAAY,CAAC,wBAAwB,CAAC,EAAE,EAAE,EAAE,CAAC,aAAa,EAAE,EAAE,CAAC,eAAe,EAAE,EAAE,EAAE,EAAE,CAAC,eAAe,EAAE,EAAE,CAAC,aAAa,CAAC,CAAC;YAC1H,EAAE,GAAG,EAAE,CAAC;YACR,EAAE,GAAG,EAAE,CAAC,eAAe,CAAC;YACxB,EAAE,GAAG,EAAE,CAAC,QAAQ,CAAC;YACjB,wCAAwC;QAC1C,CAAC;QACD,OAAO,EAAE,CAAC;IACZ,CAAC;IAED;;;;;;OAMG;IACK,MAAM,CAAC,qBAAqB,CAAC,KAAoB,EAAE,GAAc,EAAE,UAAmB,KAAK;QACjG,IAAI,CAAC,GAAG,EAAE,CAAC;YACT,YAAY,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;YAClC,OAAO,KAAK,CAAC;QACf,CAAC;QACD,IAAI,IAAI,CAAC;QACT,IAAI,KAAK,CAAC;QACV,IAAI,IAAI,CAAC;QACT,IAAI,YAAY,GAAG,GAAG,CAAC,oBAAoB,EAAE,CAAC;QAC9C,IAAI,YAAY,GAAG,CAAC,CAAC;QACrB,GAAG,CAAC,mBAAmB,CAAC,YAAY,CAAC,iBAAiB,CAAC,CAAC;QACxD,gDAAgD;QAChD,OAAO,CAAC,GAAG,CAAC,SAAS,CAAC,YAAY,CAAC,iBAAiB,CAAC,EAAE,CAAC;YACtD,IAAI,GAAG,GAAG,EAAE,eAAe,CAAC;YAC5B,IAAI,GAAG,GAAG,CAAC,aAAa,CAAC;YACzB,KAAK,GAAG,IAAI,CAAC,aAAa,CAAC;YAC3B,IAAI,IAAI,KAAK,GAAG,IAAI,KAAK,KAAK,GAAG;gBAC/B,OAAO,IAAI,CAAC;YACd,IAAI,KAAK,CAAC,aAAa,KAAK,GAAG,EAAE,CAAC;gBAChC,wFAAwF;gBACxF,GAAG,CAAC,iBAAiB,CAAC,YAAY,CAAC,iBAAiB,CAAC,CAAC;gBACtD,OAAO,IAAI,CAAC;YACd,CAAC;YACD,yGAAyG;YACzG,4GAA4G;YAC5G,2GAA2G;YAC3G,IAAI,YAAY,CAAC,oBAAoB,CAAC,KAAK,EAAE,IAAI,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,gBAAgB,CAAC,IAAI,CAAC,EAAE,CAAC;gBAC9F,MAAM,KAAK,GAAG,KAAK,CAAC,aAAa,CAAC;gBAClC,MAAM,yBAAyB,GAAG,IAAI,CAAC,cAAc,CAAC,IAAI,EAAE,GAAG,EAAE,IAAI,EAAE,KAAK,CAAC,CAAC;gBAC9E,IAAI,yBAAyB,EAAE,CAAC;oBAC9B,MAAM,cAAc,GAAG,KAAK,CAAC,iBAAiB,CAAC;oBAC/C,QAAQ,CAAC,KAAK,CAAC,IAAI,CAAC,eAAe,EAAE,cAAc,CAAC,CAAC,CAAC,yCAAyC;gBACjG,CAAC;qBAAM,CAAC;oBACN,QAAQ,CAAC,KAAK,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC,CAAE,iDAAiD;oBAC/E,GAAG,CAAC,iBAAiB,CAAC,YAAY,CAAC,iBAAiB,CAAC,CAAC;gBACxD,CAAC;gBACD,GAAG,GAAG,KAAK,CAAC;gBACZ,SAAS;YACX,CAAC;YACD,IAAI,EAAE,YAAY,GAAG,YAAY,EAAE,CAAC;gBAClC,YAAY,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;gBAClC,OAAO,KAAK,CAAC;YACf,CAAC;YACD,IAAI,YAAY,CAAC,KAAK,CAAC,GAAG,CAAC,EAAE,CAAC;gBAC5B,YAAY,EAAE,CAAC;gBACf,YAAY,GAAG,CAAC,CAAC;gBAEjB,4DAA4D;gBAE5D,uDAAuD;gBACvD,IAAI,GAAG,CAAC,aAAa,CAAC,aAAa,KAAK,GAAG,CAAC,eAAe,EAAE,CAAC;oBAC5D,YAAY,CAAC,kBAAkB,CAAC,KAAK,EAAE,GAAG,CAAC,CAAC;oBAC5C,IAAI,CAAC,OAAO;wBACV,GAAG,GAAG,YAAY,CAAC,cAAc,CAAC,GAAG,CAAC,CAAC;oBACzC,GAAG,GAAG,GAAG,CAAC,aAAa,CAAC,QAAQ,CAAC,aAAa,CAAC;oBAC/C,kDAAkD;gBACpD,CAAC;qBAAM,CAAC;oBACN,GAAG,CAAC,iBAAiB,CAAC,YAAY,CAAC,iBAAiB,CAAC,CAAC;oBACtD,GAAG,GAAG,IAAI,CAAC,aAAa,CAAC;gBAC3B,CAAC;gBACD,SAAS;YACX,CAAC;YACD,GAAG,GAAG,IAAI,CAAC;QACb,CAAC;QACD,OAAO,IAAI,CAAC,CAAE,yCAAyC;IACzD,CAAC;IACD,iBAAiB;IACT,MAAM,CAAC,WAAW,CAA4B;IACtD,gBAAgB;IACR,MAAM,CAAC,wBAAwB,GAAG,KAAK,CAAC;IAEhD;;;;mBAIe;IACR,MAAM,CAAC,eAAe;QAC3B,MAAM,CAAC,GAAG,YAAY,CAAC,WAAW,CAAC;QACnC,YAAY,CAAC,WAAW,GAAG,SAAS,CAAC;QACrC,YAAY,CAAC,wBAAwB,GAAG,KAAK,CAAC;QAC9C,OAAO,CAAC,CAAC;IACX,CAAC;IACD;;;;mBAIe;IACR,MAAM,CAAC,aAAa,CAAC,KAAgC,IAAI,IAAI,YAAY,CAAC,wBAAwB;QAAE,YAAY,CAAC,WAAW,GAAG,KAAK,CAAC,CAAC,CAAC;IAC9I;;;;;;;;;mBASe;IACR,MAAM,CAAC,+BAA+B,CAAC,KAAc;QAC1D,YAAY,CAAC,wBAAwB,GAAG,KAAK,CAAC;QAC9C,YAAY,CAAC,WAAW,GAAG,SAAS,CAAC;IACvC,CAAC;IAED;;;OAGG;IACK,MAAM,CAAC,oBAAoB,CAAC,CAAW,EAAE,CAAW;QAC1D,IAAI,CAAC,CAAC,gBAAgB,CAAC,CAAC,CAAC;YACvB,OAAO,IAAI,CAAC;QACd,OAAO,YAAY,CAAC,oBAAoB,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;IACxD,CAAC;IAED,yCAAyC;IACjC,MAAM,CAAC,aAAa,GAAG,OAAO,CAAC,UAAU,EAAE,CAAC;IAC5C,MAAM,CAAC,SAAS,GAAG,OAAO,CAAC,UAAU,EAAE,CAAC;IACxC,MAAM,CAAC,UAAU,GAAG,OAAO,CAAC,UAAU,EAAE,CAAC;IACzC,MAAM,CAAC,OAAO,GAAmC;QACvD,4BAA4B,CAAC,aAAa,EAAE;QAC5C,4BAA4B,CAAC,aAAa,EAAE;QAC5C,4BAA4B,CAAC,aAAa,EAAE;KAC7C,CAAC;IACF,yEAAyE;IACjE,MAAM,CAAC,KAAK,CAAC,GAAa;QAChC,MAAM,CAAC,GAAG,GAAG,CAAC,eAAe,CAAC;QAC9B,MAAM,CAAC,GAAG,GAAG,CAAC;QACd,MAAM,CAAC,GAAG,GAAG,CAAC,aAAa,CAAC;QAC5B,MAAM,IAAI,GAAG,YAAY,CAAC,+BAA+B,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;QACnE,IAAI,IAAI,IAAI,CAAC;YACX,OAAO,KAAK,CAAC,CAAC,0BAA0B;QAC1C,MAAM,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC;QAC5B,IAAI,CAAC,4BAA4B,CAAC,uBAAuB,CAAC,CAAC,EAAE,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC,CAAC;eACrE,CAAC,4BAA4B,CAAC,uBAAuB,CAAC,CAAC,EAAE,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC,CAAC;eACtE,CAAC,4BAA4B,CAAC,uBAAuB,CAAC,CAAC,EAAE,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC,CAAC;YACzE,OAAO,KAAK,CAAC;QAEf,wFAAwF;QACxF,MAAM,QAAQ,GAAG,IAAI,CAAC,SAAS,CAAC;QAChC,MAAM,SAAS,GAAG,IAAI,CAAC,UAAU,CAAC;QAClC,MAAM,YAAY,GAAG,IAAI,CAAC,aAAa,CAAC;QACxC,OAAO,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,QAAQ,CAAC,CAAC;QAC7D,QAAQ,CAAC,aAAa,CAAC,QAAQ,CAAC,mBAAmB,CAAC,CAAC;QACrD,IAAI,CAAC,GAAG,CAAC,CAAC;QACV,MAAM,QAAQ,GAAG,MAAM,CAAC;QACxB,MAAM,SAAS,GAAG,CAAC,QAAQ,CAAC;QAC5B,MAAM,OAAO,GAAG,GAAG,GAAG,QAAQ,CAAC;QAC/B,MAAM,QAAQ,GAAG,GAAG,GAAG,QAAQ,CAAC;QAChC,MAAM,aAAa,GAAG,OAAO,GAAG,IAAI,CAAC;QACrC,OAAO,CAAC,KAAK,CAAC,EAAE,CAAC;YACf,MAAM,CAAC,GAAG,CAAC,CAAC,aAAa,CAAC;YAC1B,OAAO,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,SAAS,CAAC,CAAC;YAClD,IAAI,QAAQ,CAAC,eAAe,CAAC,SAAS,CAAC,EAAE,CAAC;gBACxC,uCAAuC;gBACvC,OAAO,CAAC,QAAQ,CAAC,SAAS,EAAE,OAAO,EAAE,YAAY,CAAC,CAAC;gBACnD,aAAa,CAAC,wBAAwB,CAAC,MAAM,EAAE,CAAC,EAAE,CAAC,EAAE,YAAY,EAAE,aAAa,CAAC,CAAC;gBAClF,IAAI,CAAC,YAAY,CAAC,MAAM,EAAE,CAAC;oBACzB,IAAI,YAAY,CAAC,GAAG,GAAG,QAAQ,EAAE,CAAC;wBAChC,gFAAgF;wBAChF,IAAI,CAAC,IAAI,CAAC,oBAAoB,CAAC,CAAC,EAAE,CAAC,CAAC;+BAC/B,CAAC,IAAI,CAAC,oBAAoB,CAAC,CAAC,EAAE,CAAC,CAAC;+BAChC,CAAC,IAAI,CAAC,oBAAoB,CAAC,CAAC,EAAE,CAAC,CAAC;4BACnC,OAAO,KAAK,CAAC;oBACjB,CAAC;yBAAM,IAAI,YAAY,CAAC,IAAI,GAAG,QAAQ,EAAE,CAAC;wBACxC,gFAAgF;wBAChF,IAAI,CAAC,IAAI,CAAC,oBAAoB,CAAC,CAAC,EAAE,CAAC,CAAC;+BAC/B,CAAC,IAAI,CAAC,oBAAoB,CAAC,CAAC,EAAE,CAAC,CAAC;+BAChC,CAAC,IAAI,CAAC,oBAAoB,CAAC,CAAC,EAAE,CAAC,CAAC;4BACnC,OAAO,KAAK,CAAC;oBACjB,CAAC;yBAAM,IAAI,IAAI,CAAC,oBAAoB,CAAC,CAAC,EAAE,CAAC,CAAC,IAAI,IAAI,CAAC,oBAAoB,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC;wBAC9E,yEAAyE;oBAC3E,CAAC;yBAAM,IAAI,IAAI,CAAC,oBAAoB,CAAC,CAAC,EAAE,CAAC,CAAC,IAAI,IAAI,CAAC,oBAAoB,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC;wBAC9E,yEAAyE;oBAC3E,CAAC;yBAAM,CAAC;wBACN,OAAO,KAAK,CAAC,CAAC,4DAA4D;oBAC5E,CAAC;gBACH,CAAC;YACH,CAAC;YACD,CAAC,GAAG,CAAC,CAAC,aAAa,CAAC;QACtB,CAAC;QACD,OAAO,IAAI,CAAC;IACd,CAAC;IACD;;OAEG;IACK,MAAM,CAAC,0BAA0B,CAAC,KAAoB,EAAE,SAAmB,EAAE,oBAAgC;QAEnH,oBAAoB,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,YAAY,CAAC,QAAQ,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACjE,IAAI,OAAO,GAAG,CAAC,CAAC;QAChB,mCAAmC;QACnC,KAAK,MAAM,SAAS,IAAI,oBAAoB,EAAE,CAAC;YAC7C,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC,KAAK,EAAE,SAAS,EAAE,SAAS,CAAC;gBAC1D,OAAO,EAAE,CAAC;QACd,CAAC;QAED,OAAO,OAAO,KAAK,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC;IAC/C,CAAC;IACD,mEAAmE;IAC3D,MAAM,CAAC,QAAQ,CAAC,CAAW,EAAE,CAAW;QAC9C,OAAO,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;IACnB,CAAC;IAED,2FAA2F;IACnF,MAAM,CAAC,aAAa,CAAC,KAAoB,EAAE,IAAc,EAAE,SAAmB;QACpF,MAAM,UAAU,GAAG,YAAY,CAAC,cAAc,CAAC,IAAI,EAAE,SAAS,CAAC,CAAC;QAChE,IAAI,UAAU,EAAE,CAAC;YACf,OAAO,YAAY,CAAC,SAAS,CAAC,KAAK,EAAE,UAAU,EAAE,IAAI,CAAC,KAAK,SAAS,CAAC;QACvE,CAAC;QACD,OAAO,KAAK,CAAC;IACf,CAAC;IACD,qBAAqB;IACrB;;;OAGG;IACK,MAAM,CAAC,cAAc,CAAC,IAAc,EAAE,SAAoB;QAChE,IAAI,CAAC,GAAG,SAAS,CAAC;QAElB,IAAI,CAAC,CAAC;YACJ,OAAO,SAAS,CAAC;QAEnB,MAAM,EAAE,GAAG,IAAI,CAAC,CAAC,CAAC;QAClB,MAAM,EAAE,GAAG,IAAI,CAAC,CAAC,CAAC;QAClB,IAAI,EAAE,GAAG,CAAC,QAAQ,CAAC;QACnB,IAAI,CAAC,CAAC;QAEN,kFAAkF;QAClF,sEAAsE;QACtE,GAAG,CAAC;YACF,IAAI,EAAE,IAAI,CAAC,CAAC,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC,aAAa,CAAC,CAAC,IAAI,CAAC,CAAC,aAAa,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC;gBACtE,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;gBACnF,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,GAAG,EAAE,EAAE,CAAC;oBACtB,EAAE,GAAG,CAAC,CAAC;oBACP,IAAI,CAAC,KAAK,EAAE,EAAE,CAAC;wBACb,IAAI,EAAE,KAAK,CAAC,CAAC,CAAC;4BAAE,OAAO,CAAC,CAAC;wBACzB,IAAI,EAAE,KAAK,CAAC,CAAC,aAAa,CAAC,CAAC;4BAAE,OAAO,CAAC,CAAC,aAAa,CAAC;oBACvD,CAAC;oBACD,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,aAAa,CAAC;gBACpD,CAAC;YACH,CAAC;YACD,CAAC,GAAG,CAAC,CAAC,aAAa,CAAC;QACtB,CAAC,QAAQ,CAAC,KAAK,SAAS,EAAE;QAE1B,IAAI,CAAC,CAAC;YAAE,OAAO,SAAS,CAAC;QAEzB,IAAI,EAAE,KAAK,EAAE;YAAE,OAAO,CAAC,CAAC,eAAe,CAAC,CAAC,kDAAkD;QAE3F,sIAAsI;QACtI,gEAAgE;QAChE,mFAAmF;QAEnF,MAAM,IAAI,GAAG,CAAC,CAAC;QACf,MAAM,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC;QACf,MAAM,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC;QACf,IAAI,MAAM,GAAG,QAAQ,CAAC;QACtB,IAAI,GAAG,CAAC;QAER,CAAC,GAAG,CAAC,CAAC,aAAa,CAAC;QAEpB,OAAO,CAAC,KAAK,IAAI,EAAE,CAAC;YAClB,IAAI,EAAE,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,EAAE,IAAI,EAAE,KAAK,CAAC,CAAC,CAAC;gBACtC,YAAY,CAAC,eAAe,CAAC,EAAE,GAAG,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,GAAG,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;gBAE/F,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,aAAa;gBAEpD,IAAI,CAAC,GAAG,GAAG,MAAM,IAAI,CAAC,GAAG,KAAK,MAAM,IAAI,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,YAAY,CAAC,aAAa,CAAC,CAAC,EAAE,IAAI,CAAC,EAAE,CAAC;oBAC3F,CAAC,GAAG,CAAC,CAAC;oBACN,MAAM,GAAG,GAAG,CAAC;gBACf,CAAC;YACH,CAAC;YAED,CAAC,GAAG,CAAC,CAAC,aAAa,CAAC;QACtB,CAAC;QAED,OAAO,CAAC,CAAC;IACX,CAAC;IAED,2CAA2C;IACnC,MAAM,CAAC,WAAW,CAAC,KAAe;QACxC,IAAI,CAAC,GAAG,KAAK,CAAC;QACd,IAAI,QAAQ,GAAG,KAAK,CAAC;QACrB,GAAG,CAAC;YACF,IAAI,CAAC,CAAC,CAAC,GAAG,QAAQ,CAAC,CAAC;gBAAE,QAAQ,GAAG,CAAC,CAAC;YACnC,CAAC,GAAG,CAAC,CAAC,aAAa,CAAC;QACtB,CAAC,QAAQ,CAAC,KAAK,KAAK,EAAE;QAEtB,OAAO,QAAQ,CAAC;IAClB,CAAC;IAED;;;OAGG;IACK,MAAM,CAAC,eAAe,CAAC,EAAU,EAAE,EAAU,EAAE,EAAU,EAAE,EAAU,EAAE,EAAU,EAAE,EAAU,EAAE,EAAU,EAAE,EAAU;QAC3H,OAAO,CAAC,EAAE,GAAG,EAAE,CAAC,GAAG,CAAC,EAAE,GAAG,EAAE,CAAC,GAAG,CAAC,EAAE,GAAG,EAAE,CAAC,GAAG,CAAC,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC;YACvD,CAAC,EAAE,GAAG,EAAE,CAAC,GAAG,CAAC,EAAE,GAAG,EAAE,CAAC,GAAG,CAAC,EAAE,GAAG,EAAE,CAAC,GAAG,CAAC,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC;YAClD,CAAC,EAAE,GAAG,EAAE,CAAC,GAAG,CAAC,EAAE,GAAG,EAAE,CAAC,GAAG,CAAC,EAAE,GAAG,EAAE,CAAC,GAAG,CAAC,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,CAAC;IACvD,CAAC;IACD,6DAA6D;IACrD,MAAM,CAAC,cAAc,CAAC,CAAW,EAAE,CAAW,EAAE,CAAW,EAAE,CAAW;QAC9E,OAAO,YAAY,CAAC,+BAA+B,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,GAAG,CAAC;eAC3D,YAAY,CAAC,+BAA+B,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,GAAG,CAAC;eACzD,YAAY,CAAC,+BAA+B,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC;IACjE,CAAC;IACD;;;MAGE;IACM,MAAM,CAAC,oBAAoB,CAAC,CAAW,EAAE,CAAW,EAAE,CAAW;QACvE,OAAO,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;IACvE,CAAC;IAED,iFAAiF;IACzE,MAAM,CAAC,+BAA+B,CAAC,CAAW,EAAE,CAAW,EAAE,CAAW,EAAE,SAAiB,OAAO;QAC5G,MAAM,EAAE,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;QACrB,MAAM,EAAE,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;QACrB,MAAM,EAAE,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;QACrB,MAAM,EAAE,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;QACrB,MAAM,IAAI,GAAG,GAAG,GAAG,CAAC,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC,CAAC;QACvC,IAAI,IAAI,GAAG,GAAG;YACZ,OAAO,IAAI,CAAC;QACd,MAAM,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC;QAC7B,MAAM,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC;QAC7B,IAAI,IAAI,GAAG,MAAM,GAAG,CAAC,EAAE,GAAG,EAAE,CAAC;YAC3B,OAAO,GAAG,CAAC;QACb,OAAO,IAAI,CAAC;IACd,CAAC;IAED,oCAAoC;IAC5B,MAAM,CAAC,oBAAoB,CAAC,EAAS,EAAE,CAAS,EAAE,CAAS;QACjE,OAAO,QAAQ,CAAC,mBAAmB,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,IAAI,QAAQ,CAAC,mBAAmB,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;IACxF,CAAC;IAED,iDAAiD;IACzC,MAAM,CAAC,aAAa,CAAC,CAAW,EAAE,CAAW;QACnD,OAAO,YAAY,CAAC,oBAAoB,CAAC,CAAC,CAAC,eAAe,EAAE,CAAC,EAAE,CAAC,CAAC,aAAa,CAAC,GAAG,CAAC,CAAC,CAAC;YACnF,YAAY,CAAC,oBAAoB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,aAAa,CAAC,IAAI,CAAC,IAAI,YAAY,CAAC,oBAAoB,CAAC,CAAC,EAAE,CAAC,CAAC,eAAe,EAAE,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC;YAClI,YAAY,CAAC,oBAAoB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,eAAe,CAAC,GAAG,CAAC,IAAI,YAAY,CAAC,oBAAoB,CAAC,CAAC,EAAE,CAAC,CAAC,aAAa,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC;IACnI,CAAC;IAED;;;;;;OAMG;IACK,MAAM,CAAC,SAAS,CAAC,KAAoB,EAAE,CAAW,EAAE,CAAW;QACrE,IAAI,QAAQ,CAAC,qBAAqB,CAAC,CAAC,EAAE,CAAC,CAAC,IAAI,QAAQ,CAAC,qBAAqB,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC;YACjF,MAAM,EAAE,GAAG,KAAK,CAAC,gBAAgB,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;YAC1E,MAAM,EAAE,GAAG,EAAE,CAAC,aAAa,CAAC;YAC5B,QAAQ,CAAC,KAAK,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;YACtB,QAAQ,CAAC,KAAK,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;YACtB,OAAO,EAAE,CAAC;QACZ,CAAC;QACD,OAAO,SAAS,CAAC;IACnB,CAAC;IAED;;;OAGG;IACI,MAAM,CAAC,6BAA6B,CAAC,KAAoB,EAAE,KAAe;QAC/E,IAAI,IAAI,GAAG,KAAK,CAAC,eAAe,CAAC;QACjC,IAAI,KAAK,GAAG,KAAK,CAAC,aAAa,CAAC;QAChC,uDAAuD;QACvD,IAAI,kBAAkB,CAAC;QACvB,OAAO,IAAI,KAAK,KAAK;eAChB,KAAK,KAAK,KAAK;eACf,KAAK,CAAC,aAAa,KAAK,IAAI,EAAE,CAAC;YAClC,uDAAuD;YACvD,IAAI,QAAQ,CAAC,wBAAwB,CAAC,IAAI,EAAE,KAAK,EAAE,KAAK,CAAC,IAAI,CAAC;gBAC5D,OAAO,KAAK,CAAC;YACf,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC;gBACtB,OAAO,KAAK,CAAC;YACf,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC;gBACvB,OAAO,KAAK,CAAC;YACf,IAAI,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE,CAAC;gBACxB;qCACqB;gBAErB;mDACmC;gBACnC,IAAI,EAAE,GAAG,IAAI,CAAC;gBACd,IAAI,EAAE,GAAG,KAAK,CAAC;gBACf,IAAI,EAAE,GAAG,KAAK,CAAC;gBACf;;;;mBAIG;gBACH,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE,CAAC;oBACtC,OAAO,EAAE,KAAK,KAAK;2BACd,EAAE,KAAK,EAAE;2BACT,EAAE,KAAK,EAAE;2BACT,QAAQ,CAAC,wBAAwB,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC;wBACvD,kBAAkB,GAAG,YAAY,CAAC,SAAS,CAAC,KAAK,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC;wBAC3D,IAAI,kBAAkB,KAAK,SAAS;4BAClC,OAAO,KAAK,CAAC;wBACf,EAAE,GAAG,kBAAkB,CAAC;wBACxB,EAAE,GAAG,EAAE,CAAC,aAAa,CAAC;wBACtB,EAAE,GAAG,EAAE,CAAC,aAAa,CAAC;oBACxB,CAAC;oBACD,EAAE,GAAG,EAAE,CAAC;oBACR,EAAE,GAAG,EAAE,CAAC;oBACR,EAAE,GAAG,EAAE,CAAC,eAAe,CAAC;gBAC1B,CAAC;gBACD;;mDAEmC;gBACnC,IAAI,GAAG,EAAE,CAAC;gBACV,EAAE,GAAG,KAAK,CAAC;gBACX,EAAE,GAAG,EAAE,CAAC,eAAe,CAAC;gBACxB,EAAE,GAAG,EAAE,CAAC,eAAe,CAAC;gBACxB,OAAO,EAAE,CAAC,aAAa,KAAK,EAAE,IAAI,EAAE,KAAK,IAAI,EAAE,CAAC;oBAC9C,kBAAkB,GAAG,YAAY,CAAC,SAAS,CAAC,KAAK,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC;oBAC3D,IAAI,kBAAkB,KAAK,SAAS;wBAClC,OAAO,KAAK,CAAC;oBACf,EAAE,GAAG,kBAAkB,CAAC;oBACxB,EAAE,GAAG,EAAE,CAAC,eAAe,CAAC;gBAC1B,CAAC;gBACD;;gCAEgB;gBAChB,IAAI,EAAE,CAAC,aAAa,KAAK,EAAE,EAAE,CAAC;oBAC5B,kBAAkB,GAAG,YAAY,CAAC,SAAS,CAAC,KAAK,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC;oBAC3D,IAAI,kBAAkB,KAAK,SAAS;wBAClC,OAAO,KAAK,CAAC;oBACf,EAAE,GAAG,kBAAkB,CAAC;gBAC1B,CAAC;gBACD,KAAK,GAAG,EAAE,CAAC;gBACX,KAAK,GAAG,KAAK,CAAC,aAAa,CAAC;gBAC5B,IAAI,GAAG,KAAK,CAAC,eAAe,CAAC;YAE/B,CAAC;iBAAM,CAAC;gBACN;oCACoB;gBAEpB;mDACmC;gBACnC,IAAI,EAAE,GAAG,IAAI,CAAC;gBACd,IAAI,EAAE,GAAG,KAAK,CAAC;gBACf,IAAI,EAAE,GAAG,KAAK,CAAC;gBACf;;;;;;mBAMG;gBACH,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,CAAC;oBACrC,OAAO,EAAE,KAAK,IAAI;2BACb,EAAE,KAAK,EAAE;2BACT,EAAE,KAAK,EAAE;2BACT,QAAQ,CAAC,wBAAwB,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC;wBACvD,kBAAkB,GAAG,YAAY,CAAC,SAAS,CAAC,KAAK,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC;wBAC3D,IAAI,kBAAkB,KAAK,SAAS;4BAClC,OAAO,KAAK,CAAC;wBAEf,EAAE,GAAG,kBAAkB,CAAC,eAAe,CAAC;wBACxC,EAAE,GAAG,kBAAkB,CAAC;oBAC1B,CAAC;oBACD,EAAE,GAAG,EAAE,CAAC;oBACR,EAAE,GAAG,EAAE,CAAC;oBACR,EAAE,GAAG,EAAE,CAAC,aAAa,CAAC;gBACxB,CAAC;gBACD;;mDAEmC;gBACnC,KAAK,GAAG,EAAE,CAAC;gBACX,EAAE,GAAG,IAAI,CAAC;gBACV,EAAE,GAAG,EAAE,CAAC,aAAa,CAAC;gBACtB,EAAE,GAAG,EAAE,CAAC,aAAa,CAAC;gBACtB,OAAO,EAAE,CAAC,aAAa,KAAK,EAAE,IAAI,EAAE,KAAK,KAAK,EAAE,CAAC;oBAC/C,kBAAkB,GAAG,YAAY,CAAC,SAAS,CAAC,KAAK,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC;oBAC3D,IAAI,kBAAkB,KAAK,SAAS;wBAClC,OAAO,KAAK,CAAC;oBACf,EAAE,GAAG,kBAAkB,CAAC;oBACxB,wJAAwJ;oBACxJ,EAAE,GAAG,EAAE,CAAC,aAAa,CAAC;gBACxB,CAAC;gBACD;;gCAEgB;gBAChB,IAAI,EAAE,CAAC,aAAa,KAAK,EAAE,EAAE,CAAC;oBAC5B,MAAM,OAAO,GAAG,YAAY,CAAC,SAAS,CAAC,KAAK,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC;oBACtD,IAAI,OAAO,KAAK,SAAS;wBACvB,OAAO,KAAK,CAAC;gBACjB,CAAC;gBACD,KAAK,GAAG,KAAK,CAAC;gBACd,KAAK,GAAG,KAAK,CAAC,aAAa,CAAC;gBAC5B,IAAI,GAAG,KAAK,CAAC,eAAe,CAAC;YAC/B,CAAC;QACH,CAAC;QACD,OAAO,IAAI,CAAC;IACd,CAAC;;AAIH;;;GAGG;AACH,MAAM,oBAAqB,SAAQ,4BAA4B;IAC7D,oGAAoG;IAC5F,MAAM,CAAc;IACpB,SAAS,CAAuB;IAChC,MAAM,CAAuB;IAC7B,MAAM,CAAuB;IAC7B,MAAM,CAAgB;IACtB,GAAG,CAAM;IACjB,YAAmB,KAAoB,EAAE,EAAO;QAC9C,KAAK,EAAE,CAAC;QACR,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;QACpB,IAAI,CAAC,GAAG,GAAG,EAAE,CAAC;IAChB,CAAC;IACe,UAAU,CAAC,SAAqC,EAAE,MAAe;QAC/E,KAAK,CAAC,UAAU,CAAC,SAAS,EAAE,MAAM,CAAC,CAAC;QACpC,IAAI,CAAC,SAAS,GAAG,SAAS,CAAC;QAC3B,IAAI,CAAC,MAAM,GAAG,SAAS,CAAC;IAC1B,CAAC;IACe,YAAY,CAAC,EAAU,EAAE,EAAU,EAAE,EAAU,EAAE,EAAU,EAAE,EAAU,EAAE,EAAU;QACjG,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC,gBAAgB,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,IAAI,CAAC,GAAG,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC;QACvF,IAAI,IAAI,CAAC,SAAS,KAAK,SAAS,EAAE,CAAC;YACjC,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,MAAM,CAAC;YAC7B,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC;QAC7C,CAAC;aAAM,CAAC;YACN,QAAQ,CAAC,KAAK,CAAC,IAAI,CAAC,MAAO,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC;YAC1C,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC,aAAa,CAAC;QAC1C,CAAC;IACH,CAAC;IACe,QAAQ,CAAC,SAAqC,EAAE,MAAe;QAC7E,KAAK,CAAC,QAAQ,CAAC,SAAS,EAAE,MAAM,CAAC,CAAC;QAClC,IAAI,IAAI,CAAC,SAAS,KAAK,SAAS,EAAE,CAAC;YACjC,IAAI,IAAI,CAAC,MAAM,KAAK,SAAS;gBAC3B,IAAI,CAAC,MAAM,GAAG,EAAE,CAAC;YACnB,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QACnC,CAAC;QACD,IAAI,CAAC,SAAS,GAAG,SAAS,CAAC;QAC3B,IAAI,CAAC,MAAM,GAAG,SAAS,CAAC;QACxB,IAAI,CAAC,MAAM,GAAG,SAAS,CAAC;IAC1B,CAAC;IACM,UAAU;QACf,IAAI,IAAI,CAAC,MAAM,KAAK,SAAS;YAC3B,OAAO,EAAE,CAAC;QACZ,OAAO,IAAI,CAAC,MAAM,CAAC;IACrB,CAAC;CACF","sourcesContent":["/*---------------------------------------------------------------------------------------------\n* Copyright (c) Bentley Systems, Incorporated. All rights reserved.\n* See LICENSE.md in the project root for license terms and full copyright notice.\n*--------------------------------------------------------------------------------------------*/\n\n/** @packageDocumentation\n * @module Topology\n */\n\nimport { ClipUtilities } from \"../clipping/ClipUtils\";\nimport { Geometry } from \"../Geometry\";\nimport { FrameBuilder } from \"../geometry3d/FrameBuilder\";\nimport { IndexedXYZCollection, LineStringDataVariant, MultiLineStringDataVariant } from \"../geometry3d/IndexedXYZCollection\";\nimport { Plane3dByOriginAndUnitNormal } from \"../geometry3d/Plane3dByOriginAndUnitNormal\";\nimport { Point3d } from \"../geometry3d/Point3dVector3d\";\nimport { Point3dArray } from \"../geometry3d/PointHelpers\";\nimport { PointStreamXYZXYZHandlerBase, VariantPointDataStream } from \"../geometry3d/PointStreaming\";\nimport { Range1d, Range2d } from \"../geometry3d/Range\";\nimport { Transform } from \"../geometry3d/Transform\";\nimport { XAndY } from \"../geometry3d/XYZProps\";\nimport { HalfEdge, HalfEdgeGraph, HalfEdgeMask } from \"./Graph\";\nimport { MarkedEdgeSet } from \"./HalfEdgeMarkSet\";\nimport { InsertAndRetriangulateContext, InsertedVertexZOptions } from \"./InsertAndRetriangulateContext\";\n\n/**\n * Static methods for triangulating polygons and points.\n * * Tolerances and tolerance usage are currently inconsistent, and not exposed to callers.\n * * @internal\n */\nexport class Triangulator {\n\n /** Given the six nodes that make up two bordering triangles, \"pinch\" and relocate the nodes to flip them\n * * The shared edge mates are c and e.\n * * (abc) are a triangle in CCW order\n * * (dfe) are a triangle in CCW order. (Note: dfe instead of def!!)\n */\n private static flipEdgeBetweenTriangles(a: HalfEdge, b: HalfEdge, c: HalfEdge, d: HalfEdge, e: HalfEdge, f: HalfEdge) {\n // Reassign all of the pointers\n HalfEdge.pinch(a, e);\n HalfEdge.pinch(c, d);\n HalfEdge.pinch(f, c);\n HalfEdge.pinch(e, b);\n\n // Move alpha and beta into the xy coordinates of their predecessors\n e.x = b.x;\n e.y = b.y;\n e.z = b.z;\n e.i = b.i;\n c.i = f.i;\n c.x = f.x;\n c.y = f.y;\n c.z = f.z;\n }\n /**\n * Given a node in triangle A on the edge shared by triangle B, test whether the far vertex of B lies inside the circumcircle of A.\n * @param nodeA node on the shared edge between triangles A and B.\n * @return The following are equivalent:\n * * return true\n * * the computed determinant is strongly positive (greater than epsilon)\n * * the far vertex of B lies strictly inside the circumcircle of A\n * * the quad AB fails the Delaunay condition\n * * the quad CD obtained from AB by switching to the other diagonal satisfies the Delaunay condition\n * * to satisfy Delaunay, the caller should flip the diagonal of AB (obtaining CD)\n */\n public static computeCircumcircleDeterminantIsStrongPositive(nodeA: HalfEdge): boolean {\n // Confusingly enough, what we are actually doing here is testing the quad CD.\n // * CD satisfies the Delaunay condition if and only if AB does not.\n // * So let AB be convex, with CCW triangles (A,A1,A2) and (B,B1,B2) where A and B are edge mates.\n // Then CD consists of two CCW triangles that share an edge between the vertices at A2 and B2.\n // We only have to test one of the two triangles of CD---whether its circumcircle contains the far vertex.\n // By a beautiful theorem (Corollary 5.7.1 in O'Rourke, Computational Geometry in C, 2nd ed.), the following\n // are equivalent based on the radial symmetry and convexity of the paraboloid P defined by z = x*x + y*y,\n // and the CCW triangle orientation:\n // * A is outside the circumcircle of the CCW triangle with vertices (A1,A2,B2).\n // * The volume of the tetrahedron (determinant) formed by the projections of the quad points to P is negative.\n // * The volume of the parallelepiped (triple product) formed by vectors u=A1-A, v=A2-A, w=B2-A projected to P is negative.\n // * The triple product u.(v x w) is negative.\n // * The triple product w.(v x u) is positive <-- this is what we compute below.\n // * The quad CD satisfies the Delaunay condition.\n // * The quad AB fails the Delaunay condition.\n // * Return true.\n // * When AB is non-convex, CD is convex and consists of a large CCW triangle that contains the other CW triangle.\n // This containment causes the triple product to be positive, which implies CD fails (and thus AB satisfies)\n // the Delaunay condition, so this method returns false.\n const nodeA1 = nodeA.faceSuccessor;\n const nodeA2 = nodeA1.faceSuccessor;\n if (nodeA2.faceSuccessor !== nodeA)\n return false;\n const nodeB = nodeA.edgeMate;\n const nodeB1 = nodeB.faceSuccessor;\n const nodeB2 = nodeB1.faceSuccessor;\n if (nodeB2.faceSuccessor !== nodeB)\n return false;\n const ux = nodeA1.x - nodeA.x;\n const uy = nodeA1.y - nodeA.y;\n const vx = nodeA2.x - nodeA.x;\n const vy = nodeA2.y - nodeA.y;\n if (Geometry.crossProductXYXY(ux, uy, vx, vy) < 0)\n return false;\n // we assume identical coordinates in pairs (nodeA, nodeB1) and (nodeA1, nodeB)\n const wx = nodeB2.x - nodeA.x;\n const wy = nodeB2.y - nodeA.y;\n const tx = wx * wx + wy * wy;\n const ty = vx * vx + vy * vy;\n const tz = ux * ux + uy * uy;\n const q = Geometry.tripleProduct(\n wx, wy, tx,\n vx, vy, ty,\n ux, uy, tz,\n );\n if (q < 0)\n return false;\n const denom = Math.abs(wx * vy * tz) + Math.abs(wy * ty * ux) + Math.abs(tx * vx * uy)\n + Math.abs(wx * ty * uy) + Math.abs(wy * vx * tz) + Math.abs(tx * vy * ux);\n return q > 1.0e-12 * denom;\n }\n\n /**\n * * Visit each node of the graph array\n * * If a flip would be possible, test the results of flipping using circumcircle condition\n * * If revealed to be an improvement, conduct the flip, mark involved nodes as unvisited, and repeat until all nodes are visited\n */\n public static flipTriangles(graph: HalfEdgeGraph): number {\n const edgeSet = MarkedEdgeSet.create(graph)!;\n for (const node of graph.allHalfEdges)\n edgeSet.addToSet(node);\n const numFlip = this.flipTrianglesInEdgeSet(graph, edgeSet);\n edgeSet.teardown();\n return numFlip;\n }\n\n /**\n * * Visit each node of the graph array\n * * If a flip would be possible, test the results of flipping using circumcircle condition\n * * If revealed to be an improvement, conduct the flip, mark involved nodes as unvisited, and repeat until all nodes are visited\n */\n public static flipTrianglesInEdgeSet(graph: HalfEdgeGraph, edgeSet: MarkedEdgeSet): number {\n const barrierMasks = HalfEdgeMask.EXTERIOR | HalfEdgeMask.PRIMARY_EDGE | HalfEdgeMask.BOUNDARY_EDGE;\n\n const nodeArray = graph.allHalfEdges;\n const maxTest = 10.0 * nodeArray.length;\n let numFlip = 0;\n let numOK = 0;\n let node;\n while (undefined !== (node = edgeSet.chooseAndRemoveAny())) {\n\n if (node.isMaskSet(barrierMasks)) // Flip not allowed\n continue;\n\n if (Triangulator.computeCircumcircleDeterminantIsStrongPositive(node)) {\n // Flip the triangles\n Triangulator.flipEdgeBetweenTriangles(node.edgeMate.faceSuccessor, node.edgeMate.facePredecessor, node.edgeMate, node.faceSuccessor, node, node.facePredecessor);\n // keep looking at the 2 faces\n edgeSet.addAroundFace(node);\n edgeSet.addAroundFace(node.edgeMate);\n numFlip++;\n } else {\n numOK++;\n }\n if (numFlip + numOK > maxTest)\n break;\n }\n return numFlip;\n }\n\n /**\n * Create a graph from an xy-triangulation of the given points. The triangulation is Delaunay.\n * * The outer boundary of the graph is the xy-convex hull of the points; it is marked `HalfEdgeMask.EXTERIOR`.\n * @param points the points to triangulate.\n * @param zRule optional rule for updating the z-coordinate of an existing vertex when an xy-duplicate point is\n * inserted into the graph. Default is `InsertedVertexZOptions.ReplaceIfLarger`.\n * @param pointTolerance optional xy-distance tolerance for equating vertices. Default is `Geometry.smallMetricDistance`.\n */\n public static createTriangulatedGraphFromPoints(\n points: Point3d[],\n zRule: InsertedVertexZOptions = InsertedVertexZOptions.ReplaceIfLarger,\n pointTolerance: number = Geometry.smallMetricDistance,\n ): HalfEdgeGraph | undefined {\n if (points.length < 3)\n return undefined;\n const hull: Point3d[] = [];\n const interior: Point3d[] = [];\n Point3dArray.computeConvexHullXY(points, hull, interior, true);\n const graph = new HalfEdgeGraph();\n const context = InsertAndRetriangulateContext.create(graph, pointTolerance);\n const face0 = Triangulator.createFaceLoopFromCoordinates(graph, hull, true, true);\n if (undefined === face0)\n return undefined;\n // HalfEdgeGraphMerge.clusterAndMergeXYTheta(graph);\n let numInsert = 0;\n for (const p of interior) {\n context.insertAndRetriangulate(p, zRule);\n numInsert++; // eslint-disable-line @typescript-eslint/no-unused-vars\n }\n if (face0.countEdgesAroundFace() > 3) // no strictly interior vertices to split the hull polygon, so triangulate it\n return Triangulator.createTriangulatedGraphFromSingleLoop(hull);\n return graph;\n }\n /**\n * * Only one outer loop permitted.\n * * Largest area loop is assumed outer.\n * @param loops an array of loops\n * @returns triangulated graph, or undefined if bad data.\n */\n public static createTriangulatedGraphFromLoops(loops: LineStringDataVariant[]): HalfEdgeGraph | undefined {\n if (loops.length < 1)\n return undefined;\n const mask = HalfEdgeMask.BOUNDARY_EDGE | HalfEdgeMask.PRIMARY_EDGE;\n const graph = new HalfEdgeGraph();\n const holeSeeds: HalfEdge[] = [];\n let maxArea = -10000.0;\n let maxAreaIndex = -1;\n // collect all the loops with pointers to the positive (inside)\n // remember which one has largest area.\n for (let i = 0; i < loops.length; i++) {\n let seed = Triangulator.directCreateFaceLoopFromCoordinates(graph, loops[i]);\n if (seed) {\n seed = seed.faceSuccessor; // directCreate returns tail\n const mate = seed.vertexSuccessor;\n seed.setMaskAroundFace(mask);\n mate.setMaskAroundFace(mask);\n const signedFaceArea = seed.signedFaceArea();\n const area = Math.abs(signedFaceArea);\n holeSeeds.push(signedFaceArea >= 0 ? seed : mate);\n if (i === 0 || area > maxArea) {\n maxArea = area;\n maxAreaIndex = i;\n }\n }\n }\n if (holeSeeds.length === 0)\n return undefined;\n // extract the max area seed ...\n const maxAreaFace = holeSeeds[maxAreaIndex];\n holeSeeds[maxAreaIndex] = holeSeeds[holeSeeds.length - 1];\n holeSeeds.pop();\n maxAreaFace.vertexSuccessor.setMaskAroundFace(HalfEdgeMask.EXTERIOR);\n // The hole seeds all have inside nodes. Set mask there and jump to outside.\n for (let i = 0; i < holeSeeds.length; i++) {\n const seed = holeSeeds[i];\n seed.setMaskAroundFace(HalfEdgeMask.EXTERIOR);\n holeSeeds[i] = this.getLeftmost(seed.vertexSuccessor);\n }\n\n const startingNode = Triangulator.spliceLeftMostNodesOfHoles(graph, maxAreaFace, holeSeeds);\n if (startingNode) {\n if (Triangulator.triangulateSingleFace(graph, startingNode))\n return graph;\n }\n return undefined;\n }\n /**\n * Triangulate all positive area faces of a (planar) graph.\n * * Area is computed using `HalfEdge.signedFaceArea`, which ignores z-coordinates.\n * @returns whether all indicated faces were triangulated successfully\n * @see [[triangulateAllInteriorFaces]]\n */\n public static triangulateAllPositiveAreaFaces(graph: HalfEdgeGraph): boolean {\n const seeds = graph.collectFaceLoops();\n let numFail = 0;\n for (const face of seeds) {\n if (face.countEdgesAroundFace() > 3) {\n const area = face.signedFaceArea();\n if (area > 0.0)\n if (!Triangulator.triangulateSingleFace(graph, face))\n numFail++;\n }\n }\n return numFail === 0;\n }\n\n private static _workTransform?: Transform;\n\n /**\n * Triangulate all interior faces of a graph.\n * * A random node is checked for each face; if it has the `HalfEdgeMask.EXTERIOR` mask, the face is ignored.\n * @param useLocalCoords whether to transform each face into local coords before triangulating.\n * This is useful if the graph has z-coordinates.\n * @param noFlips if false (default) perform edge-flipping after each ear cut for better aspect ratio.\n * Ignored if `useLocalCoords` is true, in which case flipping is not performed to avoid out-of-plane effects.\n * @returns whether all indicated faces were triangulated successfully\n * @see [[triangulateAllPositiveAreaFaces]]\n */\n public static triangulateAllInteriorFaces(graph: HalfEdgeGraph, useLocalCoords?: boolean, noFlips?: boolean): boolean {\n const seeds = graph.collectFaceLoops();\n const visited = useLocalCoords ? graph.grabMask() : HalfEdgeMask.NULL_MASK;\n noFlips = useLocalCoords || noFlips; // don't flip if using local coords\n let localToWorld: Transform | undefined;\n let nodes: Point3d[] | undefined;\n let nodeCount = 0;\n let numFail = 0;\n for (const face of seeds) {\n if (face.countEdgesAroundFace() > 3) {\n if (face.getMask(HalfEdgeMask.EXTERIOR))\n continue;\n if (useLocalCoords) {\n nodeCount = graph.countNodes();\n nodes = face.collectAroundFace();\n localToWorld = this._workTransform = FrameBuilder.createRightHandedLocalToWorld(nodes, this._workTransform);\n localToWorld?.multiplyInversePoint3dArrayInPlace(nodes);\n }\n if (!Triangulator.triangulateSingleFace(graph, face, noFlips))\n numFail++;\n if (localToWorld && nodes) {\n for (let iNewNode = nodeCount; iNewNode < graph.countNodes(); ++iNewNode)\n nodes.push(graph.allHalfEdges[iNewNode] as any);\n localToWorld.multiplyPoint3dArrayInPlace(nodes);\n }\n }\n }\n graph.dropMask(visited);\n return numFail === 0;\n }\n\n /**\n * Triangulate the polygon made up of by a series of points. The triangulation is Delaunay.\n * * The loop may be either CCW or CW -- CCW order will be used for triangles.\n * * To triangulate a polygon with holes, use createTriangulatedGraphFromLoops.\n */\n public static createTriangulatedGraphFromSingleLoop(data: LineStringDataVariant): HalfEdgeGraph | undefined {\n const graph = new HalfEdgeGraph();\n const startingNode = Triangulator.createFaceLoopFromCoordinates(graph, data, true, true);\n if (!startingNode || graph.countNodes() < 6)\n return undefined;\n if (!Triangulator.triangulateSingleFace(graph, startingNode))\n return undefined;\n Triangulator.flipTriangles(graph);\n return graph;\n }\n\n /**\n * cautiously split the edge starting at baseNode.\n * * If baseNode is null, create a trivial loop with the single vertex at xy\n * * if xy is distinct from the coordinates at both baseNode and its successor, insert xy as a new node within that edge.\n * * also include z coordinate if present.\n */\n private static interiorEdgeSplit(graph: HalfEdgeGraph, baseNode: HalfEdge | undefined, xy: XAndY | number[]): HalfEdge | undefined {\n let x = 0, y = 0, z = 0;\n if (Array.isArray(xy)) {\n x = xy[0];\n y = xy[1];\n z = xy.length > 2 ? xy[3] : 0.0;\n } else {\n const q = xy as any;\n if (q.hasOwnProperty(\"x\")) x = q.x;\n if (q.hasOwnProperty(\"y\")) y = q.y;\n if (q.hasOwnProperty(\"z\")) z = q.z;\n }\n if (!baseNode)\n return graph.splitEdge(baseNode, x, y, z);\n if (Triangulator.isAlmostEqualXAndYXY(baseNode, x, y))\n return baseNode;\n return graph.splitEdge(baseNode, x, y, z);\n }\n /** Return length of data without wraparound point(s), if present */\n private static getUnwrappedLength(data: LineStringDataVariant): number {\n let n = data.length;\n let x0: number, y0: number, x1: number, y1: number;\n while (n > 1) {\n if (data instanceof IndexedXYZCollection) {\n x0 = data.getXAtUncheckedPointIndex(0);\n y0 = data.getYAtUncheckedPointIndex(0);\n x1 = data.getXAtUncheckedPointIndex(n - 1);\n y1 = data.getYAtUncheckedPointIndex(n - 1);\n } else if (Geometry.isArrayOfNumberArray(data, n, 2)) {\n x0 = data[0][0];\n y0 = data[0][1];\n x1 = data[n - 1][0];\n y1 = data[n - 1][1];\n } else {\n x0 = data[0].x;\n y0 = data[0].y;\n x1 = data[n - 1].x;\n y1 = data[n - 1].y;\n }\n if (Geometry.isAlmostEqualNumber(x0, x1) && Geometry.isAlmostEqualNumber(y0, y1))\n --n;\n else\n break;\n }\n return n;\n }\n /** Create a loop from coordinates.\n * * Return a pointer to any node on the loop.\n * * no masking or other markup is applied.\n */\n public static directCreateFaceLoopFromCoordinates(graph: HalfEdgeGraph, data: LineStringDataVariant): HalfEdge | undefined {\n const n = this.getUnwrappedLength(data); // open it up to allow starting at a bridge edge\n let baseNode: HalfEdge | undefined;\n if (data instanceof IndexedXYZCollection) {\n const xyz = Point3d.create();\n for (let i = 0; i < n; i++) {\n data.getPoint3dAtCheckedPointIndex(i, xyz);\n baseNode = Triangulator.interiorEdgeSplit(graph, baseNode, xyz);\n }\n } else {\n for (let i = 0; i < n; i++)\n baseNode = Triangulator.interiorEdgeSplit(graph, baseNode, data[i]);\n }\n return baseNode;\n }\n\n /** Create chains from coordinates.\n * * Return array of pointers to base node of the chains.\n * * no masking or other markup is applied (save id).\n * @param graph New edges are built in this graph\n * @param data coordinate data\n * @param id id to attach to (both side of all) edges\n */\n public static directCreateChainsFromCoordinates(graph: HalfEdgeGraph, data: MultiLineStringDataVariant, id: number = 0): HalfEdge[] {\n const assembler = new AssembleXYZXYZChains(graph, id);\n VariantPointDataStream.streamXYZ(data, assembler);\n return assembler.claimSeeds();\n }\n\n /**\n * @param graph the containing graph\n * @param base The last node of a newly created loop. (i.e. its `faceSuccessor` has the start xy)\n * @param returnPositiveAreaLoop if true, return the start node on the side with positive area. otherwise return the left side as given.\n * @param maskForBothSides mask to apply on both sides.\n * @param maskForOtherSide mask to apply to the \"other\" side of the loop.\n * @return the loop's start node or its vertex successor, chosen to be the positive or negative loop per request.\n */\n private static maskAndOrientNewFaceLoop(_graph: HalfEdgeGraph, base: HalfEdge | undefined, returnPositiveAreaLoop: boolean,\n maskForBothSides: HalfEdgeMask,\n maskForOtherSide: HalfEdgeMask): HalfEdge | undefined {\n // base is the final coordinates\n if (base) {\n base = base.faceSuccessor; // because typical construction process leaves the \"live\" edge at the end of the loop.\n const area = base.signedFaceArea();\n const mate = base.edgeMate;\n if (maskForBothSides !== HalfEdgeMask.NULL_MASK) {\n base.setMaskAroundFace(maskForBothSides);\n mate.setMaskAroundFace(maskForBothSides);\n }\n\n let preferredNode = base;\n if (returnPositiveAreaLoop && (area < 0))\n preferredNode = mate;\n const otherNode = preferredNode.vertexSuccessor;\n\n if (maskForOtherSide !== HalfEdgeMask.NULL_MASK)\n otherNode.setMaskAroundFace(maskForOtherSide);\n return preferredNode;\n }\n return undefined;\n }\n /**\n * Create a circular doubly linked list of internal and external nodes from polygon points in the specified winding order.\n * * This applies the masks used by typical applications:\n * * HalfEdgeMask.BOUNDARY on both sides.\n * * HalfEdgeMask.PRIMARY_EDGE on both sides.\n * * Use [[createFaceLoopFromCoordinatesAndMasks]] for detailed control of masks.\n */\n public static createFaceLoopFromCoordinates(\n graph: HalfEdgeGraph, data: LineStringDataVariant, returnPositiveAreaLoop: boolean, markExterior: boolean,\n ): HalfEdge | undefined {\n const base = Triangulator.directCreateFaceLoopFromCoordinates(graph, data);\n return Triangulator.maskAndOrientNewFaceLoop(\n graph,\n base,\n returnPositiveAreaLoop,\n HalfEdgeMask.BOUNDARY_EDGE | HalfEdgeMask.PRIMARY_EDGE,\n markExterior ? HalfEdgeMask.EXTERIOR : HalfEdgeMask.NULL_MASK,\n );\n }\n /**\n * create a circular doubly linked list of internal and external nodes from polygon points.\n * * Optionally jump to the \"other\" side so the returned loop has positive area\n * @param graph graph to receive the new edges\n * @param data array with x,y coordinates\n * @param returnPositiveAreaLoop if false, return an edge proceeding around the loop in the order given. If true, compute the loop area and flip return the side with positive area.\n * @param maskForBothSides mask to apply on both sides.\n * @param maskForOtherSide mask to apply on the \"other\" side from the returned loop.\n */\n public static createFaceLoopFromCoordinatesAndMasks(graph: HalfEdgeGraph, data: LineStringDataVariant, returnPositiveAreaLoop: boolean,\n maskForBothSides: HalfEdgeMask,\n maskForOtherSide: HalfEdgeMask): HalfEdge | undefined {\n const base = Triangulator.directCreateFaceLoopFromCoordinates(graph, data);\n return Triangulator.maskAndOrientNewFaceLoop(graph, base, returnPositiveAreaLoop, maskForBothSides, maskForOtherSide);\n }\n\n /** Cut off an ear, forming a new face loop of nodes\n * @param ear the vertex being cut off.\n * * Form two new nodes, alpha and beta, which have the coordinates one step away from the ear vertex.\n * * Reassigns the pointers such that beta is left behind with the new face created\n * * Reassigns the pointers such that alpha becomes the resulting missing node from the remaining polygon\n * * Reassigns prevZ and nextZ pointers\n */\n private static joinNeighborsOfEar(graph: HalfEdgeGraph, ear: HalfEdge) {\n const alpha = graph.createEdgeXYZXYZ(\n ear.facePredecessor.x, ear.facePredecessor.y, ear.facePredecessor.z, ear.facePredecessor.i,\n ear.faceSuccessor.x, ear.faceSuccessor.y, ear.faceSuccessor.z, ear.faceSuccessor.i);\n const beta = alpha.edgeMate;\n\n // Add two nodes alpha and beta and reassign pointers (also mark triangle nodes as part of triangle)\n HalfEdge.pinch(ear.faceSuccessor, beta);\n HalfEdge.pinch(ear.facePredecessor, alpha);\n ear.setMaskAroundFace(HalfEdgeMask.TRIANGULATED_FACE);\n }\n private static isInteriorTriangle(a: HalfEdge) {\n if (!a.isMaskSet(HalfEdgeMask.TRIANGULATED_FACE) || a.isMaskSet(HalfEdgeMask.EXTERIOR))\n return false;\n const b = a.faceSuccessor;\n if (!b.isMaskSet(HalfEdgeMask.TRIANGULATED_FACE) || b.isMaskSet(HalfEdgeMask.EXTERIOR))\n return false;\n const c = b.faceSuccessor;\n if (!c.isMaskSet(HalfEdgeMask.TRIANGULATED_FACE) || c.isMaskSet(HalfEdgeMask.EXTERIOR))\n return false;\n return c.faceSuccessor === a;\n }\n\n /**\n * Perform 0, 1, or more edge flips to improve aspect ratio just behind an ear that was just cut.\n * @param ear the triangle corner which just served as the ear node.\n * @returns the node at the back corner after flipping, \"appropriately positioned\" for the usual advance to `ear.faceSuccessor.edgeMate.faceSuccessor`.\n */\n private static doPostCutFlips(ear: HalfEdge): HalfEdge {\n // B0 is at the ear vertex, inside ear triangle T = A0 B0 C.\n // C is the recently cut edge added to form the ear cap.\n // A0/B1 is the quad diagonal edge candidate to be flipped.\n // Triangle T' = B1 A1 D1 is on the other side of the quad diagonal.\n // The conditions for flipping are:\n // * both triangles T, T' must be masked with TRIANGULATED_FACE\n // * the Delaunay circumcircle condition flags the vertex at D1 as in the circumcircle of T\n // After flip, node A0 becomes D1.vertexSuccessor, and is the effective \"ear\", with (same) cap edge C.\n // The next quad diagonal edge candidate to consider in the loop is A1/D0.\n //\n // * *\n // . C| . / |\n // . | . C/B1|\n // . | . / |\n // . | . / |\n // . A0 ----> B0| . / |\n // *=====================* --> * A1 / B0 *\n // \\ A1 <---- B1 / \\ / /\n // \\ / \\ / /\n // \\ / \\ / /\n // \\ / \\ A0/D1/\n // D0 \\D1/ D0 \\/ /\n // * *\n let b0 = ear;\n let a0 = b0.facePredecessor;\n let b1 = a0.edgeMate;\n while (Triangulator.isInteriorTriangle(a0) && Triangulator.isInteriorTriangle(b1)) {\n const detA = Triangulator.computeCircumcircleDeterminantIsStrongPositive(a0);\n if (!detA)\n break;\n // Flip the triangles\n const a1 = b1.faceSuccessor;\n Triangulator.flipEdgeBetweenTriangles(a1, a1.faceSuccessor, a1.facePredecessor, b0, b0.facePredecessor, b0.faceSuccessor);\n b0 = a0;\n a0 = b0.facePredecessor;\n b1 = a0.edgeMate;\n // Move to next quad with diagonal a0/b1\n }\n return b0;\n }\n\n /**\n * Main ear slicing loop which triangulates the face starting at `ear`.\n * @param graph containing graph to receive new edges\n * @param ear sector at which to start triangulation of the containing face.\n * @param noFlips if false (default) perform edge-flipping after each ear cut for better aspect ratio.\n * Pass true if your graph isn't planar; otherwise, an edge can be flipped out of plane if the neighboring triangle is non-coplanar.\n */\n private static triangulateSingleFace(graph: HalfEdgeGraph, ear?: HalfEdge, noFlips: boolean = false): boolean {\n if (!ear) {\n Triangulator.setDebugGraph(graph);\n return false;\n }\n let next;\n let next2;\n let pred;\n let maxCandidate = ear.countEdgesAroundFace();\n let numCandidate = 0;\n ear.clearMaskAroundFace(HalfEdgeMask.TRIANGULATED_FACE);\n // iterate through ears, slicing them one by one\n while (!ear.isMaskSet(HalfEdgeMask.TRIANGULATED_FACE)) {\n pred = ear?.facePredecessor;\n next = ear.faceSuccessor;\n next2 = next.faceSuccessor;\n if (next === ear || next2 === ear)\n return true;\n if (next2.faceSuccessor === ear) {\n // if triangle, mask it so that its edges can potentially be flipped by doPostCutFlips()\n ear.setMaskAroundFace(HalfEdgeMask.TRIANGULATED_FACE);\n return true;\n }\n // The earcut algorithm does not support self intersections, however we do handle the re-entrant triangle\n // case by pinching a bridge/hole into existence when vertices i and i+3 live in the same face loop, but not\n // the same vertex loop. Earcut whittles larger faces down into triangles, so this is the only case needed.\n if (Triangulator.isAlmostEqualXAndYXY(next2, pred.x, pred.y) && !next2.findAroundVertex(pred)) {\n const next3 = next2.faceSuccessor;\n const hasBridgeEdgeOrHoleInside = this.nodeInTriangle(pred, ear, next, next3);\n if (hasBridgeEdgeOrHoleInside) {\n const nullOrHoleFace = next2.vertexPredecessor;\n HalfEdge.pinch(pred.vertexSuccessor, nullOrHoleFace); // keep pred and next2 in their face loop\n } else {\n HalfEdge.pinch(pred, next2); // pred and next2 split into different face loops\n ear.setMaskAroundFace(HalfEdgeMask.TRIANGULATED_FACE);\n }\n ear = next2;\n continue;\n }\n if (++numCandidate > maxCandidate) {\n Triangulator.setDebugGraph(graph);\n return false;\n }\n if (Triangulator.isEar(ear)) {\n maxCandidate--;\n numCandidate = 0;\n\n // skipping the next vertices leads to less sliver triangles\n\n // If we already have a separated triangle, do not join\n if (ear.faceSuccessor.faceSuccessor !== ear.facePredecessor) {\n Triangulator.joinNeighborsOfEar(graph, ear);\n if (!noFlips)\n ear = Triangulator.doPostCutFlips(ear);\n ear = ear.faceSuccessor.edgeMate.faceSuccessor;\n // another step? Nate's 2017 code went one more.\n } else {\n ear.setMaskAroundFace(HalfEdgeMask.TRIANGULATED_FACE);\n ear = next.faceSuccessor;\n }\n continue;\n }\n ear = next;\n }\n return true; // um .. I'm not sure what this state is.\n }\n /** @internal */\n private static sDebugGraph: HalfEdgeGraph | undefined;\n /** @internal */\n private static sEnableDebugGraphCapture = false;\n\n /**\n * * returns the (possibly undefined) debug graph.\n * * sets the debug graph to undefined.\n * * disables subsequent saving.\n * @internal */\n public static claimDebugGraph(): HalfEdgeGraph | undefined {\n const g = Triangulator.sDebugGraph;\n Triangulator.sDebugGraph = undefined;\n Triangulator.sEnableDebugGraphCapture = false;\n return g;\n }\n /** Call (from within the triangulator) to announce a graph to be saved for debug.\n * * If debug graph capture is not enabled, do nothing.\n * * If debug graph capture is enabled, save this graph.\n * * This is called by internal steps at point of failure to preserve the failing graph for unit test examination.\n * @internal */\n public static setDebugGraph(graph: HalfEdgeGraph | undefined) { if (Triangulator.sEnableDebugGraphCapture) Triangulator.sDebugGraph = graph; }\n /**\n * * Clear the debug graph\n * * Set capture enabled to indicated value.\n * * Intended use:\n * * By default \"enabled\" is false so there is no activity in the debug graph.\n * * A unit test which needs to see graph after failure calls clearAndEnableDebugGraphCapture (true)\n * * run the triangulation step\n * * call claimDebugGraph.\n * * claimDebugGraph reverts everything to default no-capture state.\n * @internal */\n public static clearAndEnableDebugGraphCapture(value: boolean) {\n Triangulator.sEnableDebugGraphCapture = value;\n Triangulator.sDebugGraph = undefined;\n }\n\n /**\n * Whether a and b are in same vertex loop, or at the same xy location.\n * @internal\n */\n private static findAroundOrAtVertex(a: HalfEdge, b: HalfEdge): boolean {\n if (a.findAroundVertex(b))\n return true;\n return Triangulator.isAlmostEqualXAndYXY(a, b.x, b.y);\n }\n\n // for reuse over all calls to isEar ....\n private static _edgeInterval = Range1d.createNull();\n private static _earRange = Range2d.createNull();\n private static _edgeRange = Range2d.createNull();\n private static _planes: Plane3dByOriginAndUnitNormal[] = [\n Plane3dByOriginAndUnitNormal.createXYPlane(),\n Plane3dByOriginAndUnitNormal.createXYPlane(),\n Plane3dByOriginAndUnitNormal.createXYPlane(),\n ];\n /** Check whether a polygon node forms a valid ear with adjacent nodes */\n private static isEar(ear: HalfEdge) {\n const a = ear.facePredecessor;\n const b = ear;\n const c = ear.faceSuccessor;\n const area = Triangulator.signedTolerancedCCWTriangleArea(a, b, c);\n if (area <= 0)\n return false; // reflex, can't be an ear\n const planes = this._planes;\n if (!Plane3dByOriginAndUnitNormal.createOriginAndTargetXY(a, b, planes[0])\n || !Plane3dByOriginAndUnitNormal.createOriginAndTargetXY(b, c, planes[1])\n || !Plane3dByOriginAndUnitNormal.createOriginAndTargetXY(c, a, planes[2]))\n return false;\n\n // now make sure we don't have other points inside the potential ear, or edges crossing.\n const earRange = this._earRange;\n const edgeRange = this._edgeRange;\n const edgeInterval = this._edgeInterval;\n Range2d.createXYXYXY(a.x, a.y, b.x, b.y, c.x, c.y, earRange);\n earRange.expandInPlace(Geometry.smallMetricDistance);\n let p = c;\n const zeroPlus = 1.0e-8;\n const zeroMinus = -zeroPlus;\n const onePlus = 1.0 + zeroPlus;\n const oneMinus = 1.0 - zeroPlus;\n const clipTolerance = 1.0e-10 * area;\n while (p !== a) {\n const q = p.faceSuccessor;\n Range2d.createXYXY(p.x, p.y, q.x, q.y, edgeRange);\n if (earRange.intersectsRange(edgeRange)) {\n // Does pq impinge on the triangle abc?\n Range1d.createXX(zeroMinus, onePlus, edgeInterval);\n ClipUtilities.clipSegmentBelowPlanesXY(planes, p, q, edgeInterval, clipTolerance);\n if (!edgeInterval.isNull) {\n if (edgeInterval.low > oneMinus) {\n // only q touches triangle abc, so b might still be an ear if q lies at a vertex\n if (!this.findAroundOrAtVertex(a, q)\n && !this.findAroundOrAtVertex(b, q)\n && !this.findAroundOrAtVertex(c, q))\n return false;\n } else if (edgeInterval.high < zeroPlus) {\n // only p touches triangle abc, so b might still be an ear if p lies at a vertex\n if (!this.findAroundOrAtVertex(a, p)\n && !this.findAroundOrAtVertex(b, p)\n && !this.findAroundOrAtVertex(c, p))\n return false;\n } else if (this.findAroundOrAtVertex(b, q) && this.findAroundOrAtVertex(c, p)) {\n // edge pq is the back side of bridge edge bc, so b might still be an ear\n } else if (this.findAroundOrAtVertex(a, q) && this.findAroundOrAtVertex(b, p)) {\n // edge pq is the back side of bridge edge ab, so b might still be an ear\n } else {\n return false; // edge pq intrudes into triangle abc, so b cannot be an ear\n }\n }\n }\n p = p.faceSuccessor;\n }\n return true;\n }\n /** link holeLoopNodes[1], holeLoopNodes[2] etc into the outer loop, producing a single-ring polygon without holes\n *\n */\n private static spliceLeftMostNodesOfHoles(graph: HalfEdgeGraph, outerNode: HalfEdge, leftMostHoleLoopNode: HalfEdge[]): HalfEdge | undefined {\n\n leftMostHoleLoopNode.sort((a, b) => Triangulator.compareX(a, b));\n let numFail = 0;\n // process holes from left to right\n for (const holeStart of leftMostHoleLoopNode) {\n if (!Triangulator.eliminateHole(graph, holeStart, outerNode))\n numFail++;\n }\n\n return numFail === 0 ? outerNode : undefined;\n }\n /** For use in sorting -- return (signed) difference (a.x - b.x) */\n private static compareX(a: HalfEdge, b: HalfEdge) {\n return a.x - b.x;\n }\n\n /** find a bridge between vertices that connects hole with an outer ring and and link it */\n private static eliminateHole(graph: HalfEdgeGraph, hole: HalfEdge, outerNode: HalfEdge): boolean {\n const outerNodeA = Triangulator.findHoleBridge(hole, outerNode);\n if (outerNodeA) {\n return Triangulator.splitFace(graph, outerNodeA, hole) !== undefined;\n }\n return false;\n }\n // cspell:word Eberly\n /**\n * David Eberly algorithm for finding a bridge between hole and outer polygon:\n * https://www.geometrictools.com/Documentation/TriangulationByEarClipping.pdf\n */\n private static findHoleBridge(hole: HalfEdge, outerNode?: HalfEdge): HalfEdge | undefined {\n let p = outerNode;\n\n if (!p)\n return undefined;\n\n const hx = hole.x;\n const hy = hole.y;\n let qx = -Infinity;\n let m;\n\n // find a segment intersected by a ray from the hole's leftmost point to the left;\n // segment's endpoint with lesser x will be potential connection point\n do {\n if (hy <= p.y && hy >= p.faceSuccessor.y && p.faceSuccessor.y !== p.y) {\n const x = p.x + (hy - p.y) * (p.faceSuccessor.x - p.x) / (p.faceSuccessor.y - p.y);\n if (x <= hx && x > qx) {\n qx = x;\n if (x === hx) {\n if (hy === p.y) return p;\n if (hy === p.faceSuccessor.y) return p.faceSuccessor;\n }\n m = p.x < p.faceSuccessor.x ? p : p.faceSuccessor;\n }\n }\n p = p.faceSuccessor;\n } while (p !== outerNode);\n\n if (!m) return undefined;\n\n if (hx === qx) return m.facePredecessor; // hole touches outer segment; pick lower endpoint\n\n // look for outer loop points p inside the triangle of hole point h, outer segment intersection (qx,hy), and outer segment endpoint m;\n // if there are no points found, we have a valid connection (m);\n // otherwise choose the point p with minimum angle with the ray as connection point\n\n const stop = m;\n const mx = m.x;\n const my = m.y;\n let tanMin = Infinity;\n let tan;\n\n p = m.faceSuccessor;\n\n while (p !== stop) {\n if (hx >= p.x && p.x >= mx && hx !== p.x &&\n Triangulator.pointInTriangle(hy < my ? hx : qx, hy, mx, my, hy < my ? qx : hx, hy, p.x, p.y)) {\n\n tan = Math.abs(hy - p.y) / (hx - p.x); // tangential\n\n if ((tan < tanMin || (tan === tanMin && p.x > m.x)) && Triangulator.locallyInside(p, hole)) {\n m = p;\n tanMin = tan;\n }\n }\n\n p = p.faceSuccessor;\n }\n\n return m;\n }\n\n // find the leftmost node of a polygon ring\n private static getLeftmost(start: HalfEdge) {\n let p = start;\n let leftmost = start;\n do {\n if (p.x < leftmost.x) leftmost = p;\n p = p.faceSuccessor;\n } while (p !== start);\n\n return leftmost;\n }\n\n /**\n * Check if a point lies within or on a triangle.\n * * In other words, the areas of the 3 triangles formed by an edge of abc and p all have zero or positive area.\n */\n private static pointInTriangle(ax: number, ay: number, bx: number, by: number, cx: number, cy: number, px: number, py: number) {\n return (cx - px) * (ay - py) - (ax - px) * (cy - py) >= 0 &&\n (ax - px) * (by - py) - (bx - px) * (ay - py) >= 0 &&\n (bx - px) * (cy - py) - (cx - px) * (by - py) >= 0;\n }\n /** Check if node p lies strictly inside the triangle abc. */\n private static nodeInTriangle(a: HalfEdge, b: HalfEdge, c: HalfEdge, p: HalfEdge) {\n return Triangulator.signedTolerancedCCWTriangleArea(a, b, p) > 0\n && Triangulator.signedTolerancedCCWTriangleArea(b, c, p) > 0\n && Triangulator.signedTolerancedCCWTriangleArea(c, a, p) > 0;\n }\n /** signed area of a triangle\n * EDL 2/21 This is negative of usual CCW area. Beware in callers !!!\n * (This originates in classic earcut code.)\n */\n private static signedCWTriangleArea(p: HalfEdge, q: HalfEdge, r: HalfEdge) {\n return 0.5 * ((q.y - p.y) * (r.x - q.x) - (q.x - p.x) * (r.y - q.y));\n }\n\n /** signed area of a triangle, with small positive corrected to zero by relTol */\n private static signedTolerancedCCWTriangleArea(p: HalfEdge, q: HalfEdge, r: HalfEdge, relTol: number = 1.0e-12) {\n const ux = q.x - p.x;\n const uy = q.y - p.y;\n const vx = r.x - p.x;\n const vy = r.y - p.y;\n const area = 0.5 * (ux * vy - uy * vx);\n if (area < 0.0)\n return area;\n const uu = ux * ux + uy * uy;\n const vv = vx * vx + vy * vy;\n if (area < relTol * (uu + vv))\n return 0.0;\n return area;\n }\n\n /** check if two points are equal */\n private static isAlmostEqualXAndYXY(p1: XAndY, x: number, y: number) {\n return Geometry.isAlmostEqualNumber(p1.x, x) && Geometry.isAlmostEqualNumber(p1.y, y);\n }\n\n /** check if a b is inside the sector around a */\n private static locallyInside(a: HalfEdge, b: HalfEdge) {\n return Triangulator.signedCWTriangleArea(a.facePredecessor, a, a.faceSuccessor) < 0 ?\n Triangulator.signedCWTriangleArea(a, b, a.faceSuccessor) >= 0 && Triangulator.signedCWTriangleArea(a, a.facePredecessor, b) >= 0 :\n Triangulator.signedCWTriangleArea(a, b, a.facePredecessor) < 0 || Triangulator.signedCWTriangleArea(a, a.faceSuccessor, b) < 0;\n }\n\n /**\n * link two polygon vertices with a bridge; if the vertices belong to the same ring, it splits polygon into two;\n * if one belongs to the outer ring and another to a hole, it merges it into a single ring\n * * Returns the base of the new edge at the \"a\" end.\n * * \"a\" and \"b\" still represent the same physical pieces of edges\n * @returns Returns the (base of) the new half edge, at the \"a\" end.\n */\n private static splitFace(graph: HalfEdgeGraph, a: HalfEdge, b: HalfEdge): HalfEdge | undefined {\n if (HalfEdge.isNodeVisibleInSector(a, b) && HalfEdge.isNodeVisibleInSector(b, a)) {\n const a2 = graph.createEdgeXYZXYZ(a.x, a.y, a.z, a.i, b.x, b.y, b.z, b.i);\n const b2 = a2.faceSuccessor;\n HalfEdge.pinch(a, a2);\n HalfEdge.pinch(b, b2);\n return a2;\n }\n return undefined;\n }\n\n /**\n * Triangulate a single face with (linear time) logic applicable only if the lowNode is the lowest node.\n * @returns false if any monotonicity condition is violated.\n */\n public static triangulateSingleMonotoneFace(graph: HalfEdgeGraph, start: HalfEdge): boolean {\n let left = start.facePredecessor;\n let right = start.faceSuccessor;\n // P0, P1, P2 are successive edges along evolving chain\n let upperSideOfNewEdge;\n while (left !== right\n && right !== start\n && right.faceSuccessor !== left) {\n /** These should not happen if face is monotone . .. */\n if (HalfEdge.crossProductXYAlongChain(left, start, right) <= 0)\n return false;\n if (!start.belowYX(left))\n return false;\n if (!start.belowYX(right))\n return false;\n if (left.belowYX(right)) {\n /* Triangulate to all left side edges that\n are below right */\n\n /* Phase 1: move upward, adding back edges\n when prior nodes are visible. */\n let P0 = left;\n let P1 = start;\n let P2 = right;\n /* Invariant: the path from P0 back to P1 is concave.\n Each loop pass moves P0 up the left side, filling in\n edges as needed. The right side edge\n (following start) is never altered.\n */\n while (P0 !== P2 && P0.belowYX(right)) {\n while (P2 !== right\n && P2 !== P0\n && P2 !== P1\n && HalfEdge.crossProductXYAlongChain(P0, P1, P2) > 0) {\n upperSideOfNewEdge = Triangulator.splitFace(graph, P0, P2);\n if (upperSideOfNewEdge === undefined)\n return false;\n P0 = upperSideOfNewEdge;\n P1 = P0.faceSuccessor;\n P2 = P1.faceSuccessor;\n }\n P2 = P1;\n P1 = P0;\n P0 = P0.facePredecessor;\n }\n /* Phase 2: Fan out edges from right to the\n left side. P0.P1.P2 describes a pair of\n adjacent edges at the bottom. */\n left = P1;\n P2 = right;\n P1 = P2.facePredecessor;\n P0 = P1.facePredecessor;\n while (P2.faceSuccessor !== P0 && P0 !== left) {\n upperSideOfNewEdge = Triangulator.splitFace(graph, P0, P2);\n if (upperSideOfNewEdge === undefined)\n return false;\n P1 = upperSideOfNewEdge;\n P0 = P1.facePredecessor;\n }\n /* Finish off with the last stroke from the\n left node to the right, except when already\n topped out */\n if (P2.faceSuccessor !== P0) {\n upperSideOfNewEdge = Triangulator.splitFace(graph, P0, P2);\n if (upperSideOfNewEdge === undefined)\n return false;\n P0 = upperSideOfNewEdge;\n }\n start = P0;\n right = start.faceSuccessor;\n left = start.facePredecessor;\n\n } else {\n /* Triangulate to all right side edges that\n are below left */\n\n /* Phase 1: move upward, adding back edges\n when prior nodes are visible. */\n let P0 = left;\n let P1 = start;\n let P2 = right;\n /* Invariant: the path up to P1 is concave.\n Each loop pass advances P1, filling in\n edges as needed. Note that the\n start edge may get hidden, so the\n bottom node must be referenced as\n left.faceSuccessor rather than as start.\n */\n while (P0 !== P2 && P2.belowYX(left)) {\n while (P0 !== left\n && P2 !== P0\n && P2 !== P1\n && HalfEdge.crossProductXYAlongChain(P0, P1, P2) > 0) {\n upperSideOfNewEdge = Triangulator.splitFace(graph, P0, P2);\n if (upperSideOfNewEdge === undefined)\n return false;\n\n P0 = upperSideOfNewEdge.facePredecessor;\n P1 = upperSideOfNewEdge;\n }\n P0 = P1;\n P1 = P2;\n P2 = P2.faceSuccessor;\n }\n /* Phase 2: Fan out edges from left to the\n right side. P0.P1.P2 describes a pair of\n adjacent edges at the bottom. */\n right = P1;\n P0 = left;\n P1 = P0.faceSuccessor;\n P2 = P1.faceSuccessor;\n while (P2.faceSuccessor !== P0 && P2 !== right) {\n upperSideOfNewEdge = Triangulator.splitFace(graph, P0, P2);\n if (upperSideOfNewEdge === undefined)\n return false;\n P0 = upperSideOfNewEdge;\n // P1 = P2; // original code (ported from native) carefully maintained P1..P2 relationship. But code analyzer says P1 is not used again. So skip it.\n P2 = P2.faceSuccessor;\n }\n /* Finish off with the last stroke from the\n left node to the right, except when already\n topped out */\n if (P2.faceSuccessor !== P0) {\n const newEdge = Triangulator.splitFace(graph, P0, P2);\n if (newEdge === undefined)\n return false;\n }\n start = right;\n right = start.faceSuccessor;\n left = start.facePredecessor;\n }\n }\n return true;\n }\n\n}\n\n/**\n * Internal class for assembling chains\n * @internal\n */\nclass AssembleXYZXYZChains extends PointStreamXYZXYZHandlerBase {\n // Add the starting nodes as the boundary, and apply initial masks to the primary edge and exteriors\n private _seeds?: HalfEdge[];\n private _baseNode: HalfEdge | undefined;\n private _nodeB: HalfEdge | undefined;\n private _nodeC: HalfEdge | undefined;\n private _graph: HalfEdgeGraph;\n private _id: any;\n public constructor(graph: HalfEdgeGraph, id: any) {\n super();\n this._graph = graph;\n this._id = id;\n }\n public override startChain(chainData: MultiLineStringDataVariant, isLeaf: boolean): void {\n super.startChain(chainData, isLeaf);\n this._baseNode = undefined;\n this._nodeB = undefined;\n }\n public override handleXYZXYZ(x0: number, y0: number, z0: number, x1: number, y1: number, z1: number) {\n this._nodeC = this._graph.createEdgeXYZXYZ(x0, y0, z0, this._id, x1, y1, z1, this._id);\n if (this._baseNode === undefined) {\n this._baseNode = this._nodeC;\n this._nodeB = this._baseNode.faceSuccessor;\n } else {\n HalfEdge.pinch(this._nodeB!, this._nodeC);\n this._nodeB = this._nodeC.faceSuccessor;\n }\n }\n public override endChain(chainData: MultiLineStringDataVariant, isLeaf: boolean): void {\n super.endChain(chainData, isLeaf);\n if (this._baseNode !== undefined) {\n if (this._seeds === undefined)\n this._seeds = [];\n this._seeds.push(this._baseNode);\n }\n this._baseNode = undefined;\n this._nodeB = undefined;\n this._nodeC = undefined;\n }\n public claimSeeds(): HalfEdge[] {\n if (this._seeds === undefined)\n return [];\n return this._seeds;\n }\n}\n"]}