@itwin/core-geometry 5.9.0-dev.8 → 5.9.0

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 (646) hide show
  1. package/CHANGELOG.md +27 -1
  2. package/lib/cjs/Constant.js.map +1 -1
  3. package/lib/cjs/Geometry.d.ts +8 -6
  4. package/lib/cjs/Geometry.d.ts.map +1 -1
  5. package/lib/cjs/Geometry.js +8 -6
  6. package/lib/cjs/Geometry.js.map +1 -1
  7. package/lib/cjs/bspline/AkimaCurve3d.js.map +1 -1
  8. package/lib/cjs/bspline/BSpline1dNd.js.map +1 -1
  9. package/lib/cjs/bspline/BSplineCurve.js.map +1 -1
  10. package/lib/cjs/bspline/BSplineCurve3dH.js.map +1 -1
  11. package/lib/cjs/bspline/BSplineCurveOps.js.map +1 -1
  12. package/lib/cjs/bspline/BSplineSurface.js.map +1 -1
  13. package/lib/cjs/bspline/Bezier1dNd.js.map +1 -1
  14. package/lib/cjs/bspline/BezierCurve3d.js.map +1 -1
  15. package/lib/cjs/bspline/BezierCurve3dH.js.map +1 -1
  16. package/lib/cjs/bspline/BezierCurveBase.js.map +1 -1
  17. package/lib/cjs/bspline/InterpolationCurve3d.js.map +1 -1
  18. package/lib/cjs/bspline/KnotVector.js.map +1 -1
  19. package/lib/cjs/bspline/SurfaceLocationDetail.js.map +1 -1
  20. package/lib/cjs/clipping/AlternatingConvexClipTree.js.map +1 -1
  21. package/lib/cjs/clipping/BooleanClipFactory.js.map +1 -1
  22. package/lib/cjs/clipping/BooleanClipNode.js.map +1 -1
  23. package/lib/cjs/clipping/ClipPlane.js.map +1 -1
  24. package/lib/cjs/clipping/ClipPrimitive.js.map +1 -1
  25. package/lib/cjs/clipping/ClipUtils.js.map +1 -1
  26. package/lib/cjs/clipping/ClipVector.js.map +1 -1
  27. package/lib/cjs/clipping/ConvexClipPlaneSet.js.map +1 -1
  28. package/lib/cjs/clipping/UnionOfConvexClipPlaneSets.js.map +1 -1
  29. package/lib/cjs/clipping/internalContexts/LineStringOffsetClipperContext.js.map +1 -1
  30. package/lib/cjs/core-geometry.js.map +1 -1
  31. package/lib/cjs/curve/Arc3d.d.ts +7 -0
  32. package/lib/cjs/curve/Arc3d.d.ts.map +1 -1
  33. package/lib/cjs/curve/Arc3d.js +11 -0
  34. package/lib/cjs/curve/Arc3d.js.map +1 -1
  35. package/lib/cjs/curve/ConstrainedCurve2d.js.map +1 -1
  36. package/lib/cjs/curve/ConstructCurveBetweenCurves.js.map +1 -1
  37. package/lib/cjs/curve/CoordinateXYZ.js.map +1 -1
  38. package/lib/cjs/curve/CurveChainWithDistanceIndex.d.ts +11 -2
  39. package/lib/cjs/curve/CurveChainWithDistanceIndex.d.ts.map +1 -1
  40. package/lib/cjs/curve/CurveChainWithDistanceIndex.js +25 -15
  41. package/lib/cjs/curve/CurveChainWithDistanceIndex.js.map +1 -1
  42. package/lib/cjs/curve/CurveCollection.d.ts +15 -6
  43. package/lib/cjs/curve/CurveCollection.d.ts.map +1 -1
  44. package/lib/cjs/curve/CurveCollection.js +15 -6
  45. package/lib/cjs/curve/CurveCollection.js.map +1 -1
  46. package/lib/cjs/curve/CurveCurve.d.ts +1 -1
  47. package/lib/cjs/curve/CurveCurve.d.ts.map +1 -1
  48. package/lib/cjs/curve/CurveCurve.js +2 -1
  49. package/lib/cjs/curve/CurveCurve.js.map +1 -1
  50. package/lib/cjs/curve/CurveExtendMode.js.map +1 -1
  51. package/lib/cjs/curve/CurveFactory.js.map +1 -1
  52. package/lib/cjs/curve/CurveLocationDetail.d.ts +21 -0
  53. package/lib/cjs/curve/CurveLocationDetail.d.ts.map +1 -1
  54. package/lib/cjs/curve/CurveLocationDetail.js +59 -0
  55. package/lib/cjs/curve/CurveLocationDetail.js.map +1 -1
  56. package/lib/cjs/curve/CurveOps.js.map +1 -1
  57. package/lib/cjs/curve/CurvePrimitive.d.ts +13 -12
  58. package/lib/cjs/curve/CurvePrimitive.d.ts.map +1 -1
  59. package/lib/cjs/curve/CurvePrimitive.js +12 -11
  60. package/lib/cjs/curve/CurvePrimitive.js.map +1 -1
  61. package/lib/cjs/curve/CurveProcessor.js.map +1 -1
  62. package/lib/cjs/curve/CurveTypes.js.map +1 -1
  63. package/lib/cjs/curve/CurveWireMomentsXYZ.js.map +1 -1
  64. package/lib/cjs/curve/GeometryQuery.js.map +1 -1
  65. package/lib/cjs/curve/LineSegment3d.js.map +1 -1
  66. package/lib/cjs/curve/LineString3d.js.map +1 -1
  67. package/lib/cjs/curve/Loop.d.ts.map +1 -1
  68. package/lib/cjs/curve/Loop.js +3 -1
  69. package/lib/cjs/curve/Loop.js.map +1 -1
  70. package/lib/cjs/curve/OffsetOptions.js.map +1 -1
  71. package/lib/cjs/curve/ParityRegion.js.map +1 -1
  72. package/lib/cjs/curve/Path.js.map +1 -1
  73. package/lib/cjs/curve/PointString3d.js.map +1 -1
  74. package/lib/cjs/curve/ProxyCurve.js.map +1 -1
  75. package/lib/cjs/curve/Query/ConsolidateAdjacentPrimitivesContext.js.map +1 -1
  76. package/lib/cjs/curve/Query/CurveSplitContext.js.map +1 -1
  77. package/lib/cjs/curve/Query/CylindricalRange.js.map +1 -1
  78. package/lib/cjs/curve/Query/InOutTests.js.map +1 -1
  79. package/lib/cjs/curve/Query/PlanarSubdivision.js.map +1 -1
  80. package/lib/cjs/curve/Query/StrokeCountChain.js.map +1 -1
  81. package/lib/cjs/curve/Query/StrokeCountMap.js.map +1 -1
  82. package/lib/cjs/curve/RegionMomentsXY.js.map +1 -1
  83. package/lib/cjs/curve/RegionOps.d.ts +17 -4
  84. package/lib/cjs/curve/RegionOps.d.ts.map +1 -1
  85. package/lib/cjs/curve/RegionOps.js +114 -18
  86. package/lib/cjs/curve/RegionOps.js.map +1 -1
  87. package/lib/cjs/curve/RegionOpsClassificationSweeps.d.ts +3 -11
  88. package/lib/cjs/curve/RegionOpsClassificationSweeps.d.ts.map +1 -1
  89. package/lib/cjs/curve/RegionOpsClassificationSweeps.js +1 -91
  90. package/lib/cjs/curve/RegionOpsClassificationSweeps.js.map +1 -1
  91. package/lib/cjs/curve/StrokeOptions.d.ts +13 -6
  92. package/lib/cjs/curve/StrokeOptions.d.ts.map +1 -1
  93. package/lib/cjs/curve/StrokeOptions.js +13 -6
  94. package/lib/cjs/curve/StrokeOptions.js.map +1 -1
  95. package/lib/cjs/curve/UnionRegion.js.map +1 -1
  96. package/lib/cjs/curve/internalContexts/AnnounceTangentStrokeHandler.d.ts +1 -1
  97. package/lib/cjs/curve/internalContexts/AnnounceTangentStrokeHandler.d.ts.map +1 -1
  98. package/lib/cjs/curve/internalContexts/AnnounceTangentStrokeHandler.js +1 -2
  99. package/lib/cjs/curve/internalContexts/AnnounceTangentStrokeHandler.js.map +1 -1
  100. package/lib/cjs/curve/internalContexts/AppendPlaneIntersectionStrokeHandler.d.ts +1 -1
  101. package/lib/cjs/curve/internalContexts/AppendPlaneIntersectionStrokeHandler.d.ts.map +1 -1
  102. package/lib/cjs/curve/internalContexts/AppendPlaneIntersectionStrokeHandler.js +1 -2
  103. package/lib/cjs/curve/internalContexts/AppendPlaneIntersectionStrokeHandler.js.map +1 -1
  104. package/lib/cjs/curve/internalContexts/ChainCollectorContext.js.map +1 -1
  105. package/lib/cjs/curve/internalContexts/CloneCurvesContext.js.map +1 -1
  106. package/lib/cjs/curve/internalContexts/CloneWithExpandedLineStrings.js.map +1 -1
  107. package/lib/cjs/curve/internalContexts/ClosestPointStrokeHandler.d.ts +1 -1
  108. package/lib/cjs/curve/internalContexts/ClosestPointStrokeHandler.d.ts.map +1 -1
  109. package/lib/cjs/curve/internalContexts/ClosestPointStrokeHandler.js +1 -2
  110. package/lib/cjs/curve/internalContexts/ClosestPointStrokeHandler.js.map +1 -1
  111. package/lib/cjs/curve/internalContexts/CountLinearPartsSearchContext.js.map +1 -1
  112. package/lib/cjs/curve/internalContexts/CurveCurveCloseApproachXY.d.ts +113 -109
  113. package/lib/cjs/curve/internalContexts/CurveCurveCloseApproachXY.d.ts.map +1 -1
  114. package/lib/cjs/curve/internalContexts/CurveCurveCloseApproachXY.js +361 -385
  115. package/lib/cjs/curve/internalContexts/CurveCurveCloseApproachXY.js.map +1 -1
  116. package/lib/cjs/curve/internalContexts/CurveCurveIntersectXY.d.ts +17 -17
  117. package/lib/cjs/curve/internalContexts/CurveCurveIntersectXY.d.ts.map +1 -1
  118. package/lib/cjs/curve/internalContexts/CurveCurveIntersectXY.js +153 -184
  119. package/lib/cjs/curve/internalContexts/CurveCurveIntersectXY.js.map +1 -1
  120. package/lib/cjs/curve/internalContexts/CurveCurveIntersectXYZ.js.map +1 -1
  121. package/lib/cjs/curve/internalContexts/CurveLengthContext.js.map +1 -1
  122. package/lib/cjs/curve/internalContexts/CurveOffsetXYHandler.js.map +1 -1
  123. package/lib/cjs/curve/internalContexts/EllipticalArcApproximationContext.js.map +1 -1
  124. package/lib/cjs/curve/internalContexts/GapSearchContext.js.map +1 -1
  125. package/lib/cjs/curve/internalContexts/MultiChainCollector.js.map +1 -1
  126. package/lib/cjs/curve/internalContexts/PlaneAltitudeRangeContext.js.map +1 -1
  127. package/lib/cjs/curve/internalContexts/PointToCurveTangentHandler.js.map +1 -1
  128. package/lib/cjs/curve/internalContexts/PolygonOffsetContext.js.map +1 -1
  129. package/lib/cjs/curve/internalContexts/SumLengthsContext.js.map +1 -1
  130. package/lib/cjs/curve/internalContexts/TransferWithSplitArcs.js.map +1 -1
  131. package/lib/cjs/curve/internalContexts/TransformInPlaceContext.js.map +1 -1
  132. package/lib/cjs/curve/internalContexts/geometry2d/ConstrainedImplicitCurve2d.js.map +1 -1
  133. package/lib/cjs/curve/internalContexts/geometry2d/ConstraintSet.js.map +1 -1
  134. package/lib/cjs/curve/internalContexts/geometry2d/ImplicitCurve2d.js.map +1 -1
  135. package/lib/cjs/curve/internalContexts/geometry2d/ImplicitCurve2dConverter.js.map +1 -1
  136. package/lib/cjs/curve/internalContexts/geometry2d/UnboundedCircle2d.js.map +1 -1
  137. package/lib/cjs/curve/internalContexts/geometry2d/UnboundedEllipse2d.js.map +1 -1
  138. package/lib/cjs/curve/internalContexts/geometry2d/UnboundedHyperbola2d.js.map +1 -1
  139. package/lib/cjs/curve/internalContexts/geometry2d/UnboundedLine2d.js.map +1 -1
  140. package/lib/cjs/curve/internalContexts/geometry2d/UnboundedParabola2d.js.map +1 -1
  141. package/lib/cjs/curve/spiral/AustralianRailCorpXYEvaluator.js.map +1 -1
  142. package/lib/cjs/curve/spiral/ClothoidSeries.js.map +1 -1
  143. package/lib/cjs/curve/spiral/CubicEvaluator.js.map +1 -1
  144. package/lib/cjs/curve/spiral/CzechSpiralEvaluator.js.map +1 -1
  145. package/lib/cjs/curve/spiral/DirectHalfCosineSpiralEvaluator.js.map +1 -1
  146. package/lib/cjs/curve/spiral/DirectSpiral3d.d.ts +1 -2
  147. package/lib/cjs/curve/spiral/DirectSpiral3d.d.ts.map +1 -1
  148. package/lib/cjs/curve/spiral/DirectSpiral3d.js +9 -3
  149. package/lib/cjs/curve/spiral/DirectSpiral3d.js.map +1 -1
  150. package/lib/cjs/curve/spiral/IntegratedSpiral3d.d.ts +1 -2
  151. package/lib/cjs/curve/spiral/IntegratedSpiral3d.d.ts.map +1 -1
  152. package/lib/cjs/curve/spiral/IntegratedSpiral3d.js +10 -4
  153. package/lib/cjs/curve/spiral/IntegratedSpiral3d.js.map +1 -1
  154. package/lib/cjs/curve/spiral/MXCubicAlongArcSpiralEvaluator.js.map +1 -1
  155. package/lib/cjs/curve/spiral/NormalizedTransition.js.map +1 -1
  156. package/lib/cjs/curve/spiral/PolishCubicSpiralEvaluator.js.map +1 -1
  157. package/lib/cjs/curve/spiral/TransitionConditionalProperties.js.map +1 -1
  158. package/lib/cjs/curve/spiral/TransitionSpiral3d.js.map +1 -1
  159. package/lib/cjs/curve/spiral/XYCurveEvaluator.js.map +1 -1
  160. package/lib/cjs/geometry3d/Angle.js.map +1 -1
  161. package/lib/cjs/geometry3d/AngleSweep.d.ts +3 -1
  162. package/lib/cjs/geometry3d/AngleSweep.d.ts.map +1 -1
  163. package/lib/cjs/geometry3d/AngleSweep.js +6 -2
  164. package/lib/cjs/geometry3d/AngleSweep.js.map +1 -1
  165. package/lib/cjs/geometry3d/BarycentricTriangle.js.map +1 -1
  166. package/lib/cjs/geometry3d/BilinearPatch.js.map +1 -1
  167. package/lib/cjs/geometry3d/CoincidentGeometryOps.js.map +1 -1
  168. package/lib/cjs/geometry3d/Ellipsoid.js.map +1 -1
  169. package/lib/cjs/geometry3d/FrameBuilder.js.map +1 -1
  170. package/lib/cjs/geometry3d/FrustumAnimation.js.map +1 -1
  171. package/lib/cjs/geometry3d/GeometryHandler.d.ts +33 -4
  172. package/lib/cjs/geometry3d/GeometryHandler.d.ts.map +1 -1
  173. package/lib/cjs/geometry3d/GeometryHandler.js +79 -1
  174. package/lib/cjs/geometry3d/GeometryHandler.js.map +1 -1
  175. package/lib/cjs/geometry3d/GrowableBlockedArray.js.map +1 -1
  176. package/lib/cjs/geometry3d/GrowableFloat64Array.js.map +1 -1
  177. package/lib/cjs/geometry3d/GrowableXYArray.d.ts +9 -6
  178. package/lib/cjs/geometry3d/GrowableXYArray.d.ts.map +1 -1
  179. package/lib/cjs/geometry3d/GrowableXYArray.js +20 -10
  180. package/lib/cjs/geometry3d/GrowableXYArray.js.map +1 -1
  181. package/lib/cjs/geometry3d/GrowableXYZArray.d.ts +9 -6
  182. package/lib/cjs/geometry3d/GrowableXYZArray.d.ts.map +1 -1
  183. package/lib/cjs/geometry3d/GrowableXYZArray.js +20 -10
  184. package/lib/cjs/geometry3d/GrowableXYZArray.js.map +1 -1
  185. package/lib/cjs/geometry3d/IndexedCollectionInterval.js.map +1 -1
  186. package/lib/cjs/geometry3d/IndexedXYCollection.js.map +1 -1
  187. package/lib/cjs/geometry3d/IndexedXYZCollection.js.map +1 -1
  188. package/lib/cjs/geometry3d/LongitudeLatitudeAltitude.js.map +1 -1
  189. package/lib/cjs/geometry3d/Matrix3d.d.ts +4 -4
  190. package/lib/cjs/geometry3d/Matrix3d.d.ts.map +1 -1
  191. package/lib/cjs/geometry3d/Matrix3d.js +5 -4
  192. package/lib/cjs/geometry3d/Matrix3d.js.map +1 -1
  193. package/lib/cjs/geometry3d/OrderedRotationAngles.js.map +1 -1
  194. package/lib/cjs/geometry3d/Plane3d.js.map +1 -1
  195. package/lib/cjs/geometry3d/Plane3dByOriginAndUnitNormal.js.map +1 -1
  196. package/lib/cjs/geometry3d/Plane3dByOriginAndVectors.js.map +1 -1
  197. package/lib/cjs/geometry3d/Point2dArrayCarrier.js.map +1 -1
  198. package/lib/cjs/geometry3d/Point2dVector2d.js.map +1 -1
  199. package/lib/cjs/geometry3d/Point3dArrayCarrier.js.map +1 -1
  200. package/lib/cjs/geometry3d/Point3dVector3d.js.map +1 -1
  201. package/lib/cjs/geometry3d/PointHelpers.d.ts.map +1 -1
  202. package/lib/cjs/geometry3d/PointHelpers.js +6 -7
  203. package/lib/cjs/geometry3d/PointHelpers.js.map +1 -1
  204. package/lib/cjs/geometry3d/PointStreaming.js.map +1 -1
  205. package/lib/cjs/geometry3d/PolygonOps.js.map +1 -1
  206. package/lib/cjs/geometry3d/PolylineCompressionByEdgeOffset.js.map +1 -1
  207. package/lib/cjs/geometry3d/PolylineOps.js.map +1 -1
  208. package/lib/cjs/geometry3d/Range.js.map +1 -1
  209. package/lib/cjs/geometry3d/Ray2d.js.map +1 -1
  210. package/lib/cjs/geometry3d/Ray3d.js.map +1 -1
  211. package/lib/cjs/geometry3d/ReusableObjectCache.js.map +1 -1
  212. package/lib/cjs/geometry3d/Segment1d.js.map +1 -1
  213. package/lib/cjs/geometry3d/SortablePolygon.js.map +1 -1
  214. package/lib/cjs/geometry3d/Transform.js.map +1 -1
  215. package/lib/cjs/geometry3d/UVSurfaceOps.js.map +1 -1
  216. package/lib/cjs/geometry3d/XYZProps.js.map +1 -1
  217. package/lib/cjs/geometry3d/YawPitchRollAngles.js.map +1 -1
  218. package/lib/cjs/geometry4d/Map4d.js.map +1 -1
  219. package/lib/cjs/geometry4d/Matrix4d.js.map +1 -1
  220. package/lib/cjs/geometry4d/MomentData.js.map +1 -1
  221. package/lib/cjs/geometry4d/PlaneByOriginAndVectors4d.js.map +1 -1
  222. package/lib/cjs/geometry4d/Point4d.js.map +1 -1
  223. package/lib/cjs/numerics/BandedSystem.js.map +1 -1
  224. package/lib/cjs/numerics/BezierPolynomials.d.ts.map +1 -1
  225. package/lib/cjs/numerics/BezierPolynomials.js +1 -1
  226. package/lib/cjs/numerics/BezierPolynomials.js.map +1 -1
  227. package/lib/cjs/numerics/ClusterableArray.js.map +1 -1
  228. package/lib/cjs/numerics/Complex.js.map +1 -1
  229. package/lib/cjs/numerics/ConvexPolygon2d.js.map +1 -1
  230. package/lib/cjs/numerics/Newton.d.ts +52 -13
  231. package/lib/cjs/numerics/Newton.d.ts.map +1 -1
  232. package/lib/cjs/numerics/Newton.js +73 -23
  233. package/lib/cjs/numerics/Newton.js.map +1 -1
  234. package/lib/cjs/numerics/PascalCoefficients.js.map +1 -1
  235. package/lib/cjs/numerics/PolarData.js.map +1 -1
  236. package/lib/cjs/numerics/Polynomials.js.map +1 -1
  237. package/lib/cjs/numerics/Quadrature.js.map +1 -1
  238. package/lib/cjs/numerics/Range1dArray.js.map +1 -1
  239. package/lib/cjs/numerics/SmallSystem.js.map +1 -1
  240. package/lib/cjs/numerics/TriDiagonalSystem.js.map +1 -1
  241. package/lib/cjs/numerics/UnionFind.js.map +1 -1
  242. package/lib/cjs/numerics/UsageSums.js.map +1 -1
  243. package/lib/cjs/polyface/AuxData.js.map +1 -1
  244. package/lib/cjs/polyface/BoxTopology.js.map +1 -1
  245. package/lib/cjs/polyface/FacetFaceData.js.map +1 -1
  246. package/lib/cjs/polyface/FacetLocationDetail.js.map +1 -1
  247. package/lib/cjs/polyface/FacetOrientation.js.map +1 -1
  248. package/lib/cjs/polyface/GreedyTriangulationBetweenLineStrings.js.map +1 -1
  249. package/lib/cjs/polyface/IndexedEdgeMatcher.js.map +1 -1
  250. package/lib/cjs/polyface/IndexedPolyfaceVisitor.js.map +1 -1
  251. package/lib/cjs/polyface/IndexedPolyfaceWalker.js.map +1 -1
  252. package/lib/cjs/polyface/Polyface.js.map +1 -1
  253. package/lib/cjs/polyface/PolyfaceBuilder.js.map +1 -1
  254. package/lib/cjs/polyface/PolyfaceClip.js.map +1 -1
  255. package/lib/cjs/polyface/PolyfaceData.js.map +1 -1
  256. package/lib/cjs/polyface/PolyfaceQuery.d.ts +14 -14
  257. package/lib/cjs/polyface/PolyfaceQuery.d.ts.map +1 -1
  258. package/lib/cjs/polyface/PolyfaceQuery.js +14 -14
  259. package/lib/cjs/polyface/PolyfaceQuery.js.map +1 -1
  260. package/lib/cjs/polyface/RangeLengthData.js.map +1 -1
  261. package/lib/cjs/polyface/RangeTree/LineString3dRangeTreeContext.js.map +1 -1
  262. package/lib/cjs/polyface/RangeTree/MinimumValueTester.js.map +1 -1
  263. package/lib/cjs/polyface/RangeTree/Point3dArrayRangeTreeContext.js.map +1 -1
  264. package/lib/cjs/polyface/RangeTree/PolyfaceRangeTreeContext.js.map +1 -1
  265. package/lib/cjs/polyface/RangeTree/RangeTreeNode.js.map +1 -1
  266. package/lib/cjs/polyface/RangeTree/RangeTreeSearchHandlers.js.map +1 -1
  267. package/lib/cjs/polyface/TaggedNumericData.js.map +1 -1
  268. package/lib/cjs/polyface/TriangleCandidate.js.map +1 -1
  269. package/lib/cjs/polyface/multiclip/BuildAverageNormalsContext.js.map +1 -1
  270. package/lib/cjs/polyface/multiclip/GriddedRaggedRange2dSet.js.map +1 -1
  271. package/lib/cjs/polyface/multiclip/GriddedRaggedRange2dSetWithOverflow.js.map +1 -1
  272. package/lib/cjs/polyface/multiclip/LinearSearchRange2dArray.js.map +1 -1
  273. package/lib/cjs/polyface/multiclip/OffsetMeshContext.js.map +1 -1
  274. package/lib/cjs/polyface/multiclip/Range2dSearchInterface.js.map +1 -1
  275. package/lib/cjs/polyface/multiclip/RangeSearch.js.map +1 -1
  276. package/lib/cjs/polyface/multiclip/SweepLineStringToFacetContext.js.map +1 -1
  277. package/lib/cjs/polyface/multiclip/XYPointBuckets.js.map +1 -1
  278. package/lib/cjs/serialization/BGFBAccessors.js.map +1 -1
  279. package/lib/cjs/serialization/BGFBReader.js +2 -2
  280. package/lib/cjs/serialization/BGFBReader.js.map +1 -1
  281. package/lib/cjs/serialization/BGFBWriter.js.map +1 -1
  282. package/lib/cjs/serialization/BentleyGeometryFlatBuffer.js.map +1 -1
  283. package/lib/cjs/serialization/DeepCompare.js.map +1 -1
  284. package/lib/cjs/serialization/IModelJsonSchema.js.map +1 -1
  285. package/lib/cjs/serialization/SerializationHelpers.js.map +1 -1
  286. package/lib/cjs/solid/Box.js.map +1 -1
  287. package/lib/cjs/solid/Cone.js.map +1 -1
  288. package/lib/cjs/solid/LinearSweep.js.map +1 -1
  289. package/lib/cjs/solid/RotationalSweep.js.map +1 -1
  290. package/lib/cjs/solid/RuledSweep.js.map +1 -1
  291. package/lib/cjs/solid/SolidPrimitive.js.map +1 -1
  292. package/lib/cjs/solid/Sphere.js.map +1 -1
  293. package/lib/cjs/solid/SweepContour.js.map +1 -1
  294. package/lib/cjs/solid/TorusPipe.js.map +1 -1
  295. package/lib/cjs/topology/ChainMerge.js.map +1 -1
  296. package/lib/cjs/topology/Graph.d.ts +15 -15
  297. package/lib/cjs/topology/Graph.d.ts.map +1 -1
  298. package/lib/cjs/topology/Graph.js +1 -1
  299. package/lib/cjs/topology/Graph.js.map +1 -1
  300. package/lib/cjs/topology/HalfEdgeGraphFromIndexedLoopsContext.js.map +1 -1
  301. package/lib/cjs/topology/HalfEdgeGraphSearch.d.ts +3 -3
  302. package/lib/cjs/topology/HalfEdgeGraphSearch.d.ts.map +1 -1
  303. package/lib/cjs/topology/HalfEdgeGraphSearch.js.map +1 -1
  304. package/lib/cjs/topology/HalfEdgeGraphSpineContext.js.map +1 -1
  305. package/lib/cjs/topology/HalfEdgeGraphValidation.js.map +1 -1
  306. package/lib/cjs/topology/HalfEdgeMarkSet.js.map +1 -1
  307. package/lib/cjs/topology/HalfEdgeNodeXYZUV.js.map +1 -1
  308. package/lib/cjs/topology/HalfEdgePointInGraphSearch.js.map +1 -1
  309. package/lib/cjs/topology/HalfEdgePositionDetail.js.map +1 -1
  310. package/lib/cjs/topology/HalfEdgePriorityQueue.js.map +1 -1
  311. package/lib/cjs/topology/InsertAndRetriangulateContext.js.map +1 -1
  312. package/lib/cjs/topology/MaskManager.js.map +1 -1
  313. package/lib/cjs/topology/Merging.js.map +1 -1
  314. package/lib/cjs/topology/RegularizeFace.js.map +1 -1
  315. package/lib/cjs/topology/SignedDataSummary.js.map +1 -1
  316. package/lib/cjs/topology/SpaceTriangulation.js.map +1 -1
  317. package/lib/cjs/topology/Triangulation.js.map +1 -1
  318. package/lib/cjs/topology/Voronoi.js.map +1 -1
  319. package/lib/cjs/topology/XYParitySearchContext.js.map +1 -1
  320. package/lib/esm/Constant.js.map +1 -1
  321. package/lib/esm/Geometry.d.ts +8 -6
  322. package/lib/esm/Geometry.d.ts.map +1 -1
  323. package/lib/esm/Geometry.js +8 -6
  324. package/lib/esm/Geometry.js.map +1 -1
  325. package/lib/esm/bspline/AkimaCurve3d.js.map +1 -1
  326. package/lib/esm/bspline/BSpline1dNd.js.map +1 -1
  327. package/lib/esm/bspline/BSplineCurve.js.map +1 -1
  328. package/lib/esm/bspline/BSplineCurve3dH.js.map +1 -1
  329. package/lib/esm/bspline/BSplineCurveOps.js.map +1 -1
  330. package/lib/esm/bspline/BSplineSurface.js.map +1 -1
  331. package/lib/esm/bspline/Bezier1dNd.js.map +1 -1
  332. package/lib/esm/bspline/BezierCurve3d.js.map +1 -1
  333. package/lib/esm/bspline/BezierCurve3dH.js.map +1 -1
  334. package/lib/esm/bspline/BezierCurveBase.js.map +1 -1
  335. package/lib/esm/bspline/InterpolationCurve3d.js.map +1 -1
  336. package/lib/esm/bspline/KnotVector.js.map +1 -1
  337. package/lib/esm/bspline/SurfaceLocationDetail.js.map +1 -1
  338. package/lib/esm/clipping/AlternatingConvexClipTree.js.map +1 -1
  339. package/lib/esm/clipping/BooleanClipFactory.js.map +1 -1
  340. package/lib/esm/clipping/BooleanClipNode.js.map +1 -1
  341. package/lib/esm/clipping/ClipPlane.js.map +1 -1
  342. package/lib/esm/clipping/ClipPrimitive.js.map +1 -1
  343. package/lib/esm/clipping/ClipUtils.js.map +1 -1
  344. package/lib/esm/clipping/ClipVector.js.map +1 -1
  345. package/lib/esm/clipping/ConvexClipPlaneSet.js.map +1 -1
  346. package/lib/esm/clipping/UnionOfConvexClipPlaneSets.js.map +1 -1
  347. package/lib/esm/clipping/internalContexts/LineStringOffsetClipperContext.js.map +1 -1
  348. package/lib/esm/core-geometry.js.map +1 -1
  349. package/lib/esm/curve/Arc3d.d.ts +7 -0
  350. package/lib/esm/curve/Arc3d.d.ts.map +1 -1
  351. package/lib/esm/curve/Arc3d.js +11 -0
  352. package/lib/esm/curve/Arc3d.js.map +1 -1
  353. package/lib/esm/curve/ConstrainedCurve2d.js.map +1 -1
  354. package/lib/esm/curve/ConstructCurveBetweenCurves.js.map +1 -1
  355. package/lib/esm/curve/CoordinateXYZ.js.map +1 -1
  356. package/lib/esm/curve/CurveChainWithDistanceIndex.d.ts +11 -2
  357. package/lib/esm/curve/CurveChainWithDistanceIndex.d.ts.map +1 -1
  358. package/lib/esm/curve/CurveChainWithDistanceIndex.js +25 -15
  359. package/lib/esm/curve/CurveChainWithDistanceIndex.js.map +1 -1
  360. package/lib/esm/curve/CurveCollection.d.ts +15 -6
  361. package/lib/esm/curve/CurveCollection.d.ts.map +1 -1
  362. package/lib/esm/curve/CurveCollection.js +15 -6
  363. package/lib/esm/curve/CurveCollection.js.map +1 -1
  364. package/lib/esm/curve/CurveCurve.d.ts +1 -1
  365. package/lib/esm/curve/CurveCurve.d.ts.map +1 -1
  366. package/lib/esm/curve/CurveCurve.js +2 -1
  367. package/lib/esm/curve/CurveCurve.js.map +1 -1
  368. package/lib/esm/curve/CurveExtendMode.js.map +1 -1
  369. package/lib/esm/curve/CurveFactory.js.map +1 -1
  370. package/lib/esm/curve/CurveLocationDetail.d.ts +21 -0
  371. package/lib/esm/curve/CurveLocationDetail.d.ts.map +1 -1
  372. package/lib/esm/curve/CurveLocationDetail.js +59 -0
  373. package/lib/esm/curve/CurveLocationDetail.js.map +1 -1
  374. package/lib/esm/curve/CurveOps.js.map +1 -1
  375. package/lib/esm/curve/CurvePrimitive.d.ts +13 -12
  376. package/lib/esm/curve/CurvePrimitive.d.ts.map +1 -1
  377. package/lib/esm/curve/CurvePrimitive.js +12 -11
  378. package/lib/esm/curve/CurvePrimitive.js.map +1 -1
  379. package/lib/esm/curve/CurveProcessor.js.map +1 -1
  380. package/lib/esm/curve/CurveTypes.js.map +1 -1
  381. package/lib/esm/curve/CurveWireMomentsXYZ.js.map +1 -1
  382. package/lib/esm/curve/GeometryQuery.js.map +1 -1
  383. package/lib/esm/curve/LineSegment3d.js.map +1 -1
  384. package/lib/esm/curve/LineString3d.js.map +1 -1
  385. package/lib/esm/curve/Loop.d.ts.map +1 -1
  386. package/lib/esm/curve/Loop.js +3 -1
  387. package/lib/esm/curve/Loop.js.map +1 -1
  388. package/lib/esm/curve/OffsetOptions.js.map +1 -1
  389. package/lib/esm/curve/ParityRegion.js.map +1 -1
  390. package/lib/esm/curve/Path.js.map +1 -1
  391. package/lib/esm/curve/PointString3d.js.map +1 -1
  392. package/lib/esm/curve/ProxyCurve.js.map +1 -1
  393. package/lib/esm/curve/Query/ConsolidateAdjacentPrimitivesContext.js.map +1 -1
  394. package/lib/esm/curve/Query/CurveSplitContext.js.map +1 -1
  395. package/lib/esm/curve/Query/CylindricalRange.js.map +1 -1
  396. package/lib/esm/curve/Query/InOutTests.js.map +1 -1
  397. package/lib/esm/curve/Query/PlanarSubdivision.js.map +1 -1
  398. package/lib/esm/curve/Query/StrokeCountChain.js.map +1 -1
  399. package/lib/esm/curve/Query/StrokeCountMap.js.map +1 -1
  400. package/lib/esm/curve/RegionMomentsXY.js.map +1 -1
  401. package/lib/esm/curve/RegionOps.d.ts +17 -4
  402. package/lib/esm/curve/RegionOps.d.ts.map +1 -1
  403. package/lib/esm/curve/RegionOps.js +116 -20
  404. package/lib/esm/curve/RegionOps.js.map +1 -1
  405. package/lib/esm/curve/RegionOpsClassificationSweeps.d.ts +3 -11
  406. package/lib/esm/curve/RegionOpsClassificationSweeps.d.ts.map +1 -1
  407. package/lib/esm/curve/RegionOpsClassificationSweeps.js +2 -92
  408. package/lib/esm/curve/RegionOpsClassificationSweeps.js.map +1 -1
  409. package/lib/esm/curve/StrokeOptions.d.ts +13 -6
  410. package/lib/esm/curve/StrokeOptions.d.ts.map +1 -1
  411. package/lib/esm/curve/StrokeOptions.js +13 -6
  412. package/lib/esm/curve/StrokeOptions.js.map +1 -1
  413. package/lib/esm/curve/UnionRegion.js.map +1 -1
  414. package/lib/esm/curve/internalContexts/AnnounceTangentStrokeHandler.d.ts +1 -1
  415. package/lib/esm/curve/internalContexts/AnnounceTangentStrokeHandler.d.ts.map +1 -1
  416. package/lib/esm/curve/internalContexts/AnnounceTangentStrokeHandler.js +1 -2
  417. package/lib/esm/curve/internalContexts/AnnounceTangentStrokeHandler.js.map +1 -1
  418. package/lib/esm/curve/internalContexts/AppendPlaneIntersectionStrokeHandler.d.ts +1 -1
  419. package/lib/esm/curve/internalContexts/AppendPlaneIntersectionStrokeHandler.d.ts.map +1 -1
  420. package/lib/esm/curve/internalContexts/AppendPlaneIntersectionStrokeHandler.js +1 -2
  421. package/lib/esm/curve/internalContexts/AppendPlaneIntersectionStrokeHandler.js.map +1 -1
  422. package/lib/esm/curve/internalContexts/ChainCollectorContext.js.map +1 -1
  423. package/lib/esm/curve/internalContexts/CloneCurvesContext.js.map +1 -1
  424. package/lib/esm/curve/internalContexts/CloneWithExpandedLineStrings.js.map +1 -1
  425. package/lib/esm/curve/internalContexts/ClosestPointStrokeHandler.d.ts +1 -1
  426. package/lib/esm/curve/internalContexts/ClosestPointStrokeHandler.d.ts.map +1 -1
  427. package/lib/esm/curve/internalContexts/ClosestPointStrokeHandler.js +1 -2
  428. package/lib/esm/curve/internalContexts/ClosestPointStrokeHandler.js.map +1 -1
  429. package/lib/esm/curve/internalContexts/CountLinearPartsSearchContext.js.map +1 -1
  430. package/lib/esm/curve/internalContexts/CurveCurveCloseApproachXY.d.ts +113 -109
  431. package/lib/esm/curve/internalContexts/CurveCurveCloseApproachXY.d.ts.map +1 -1
  432. package/lib/esm/curve/internalContexts/CurveCurveCloseApproachXY.js +364 -388
  433. package/lib/esm/curve/internalContexts/CurveCurveCloseApproachXY.js.map +1 -1
  434. package/lib/esm/curve/internalContexts/CurveCurveIntersectXY.d.ts +17 -17
  435. package/lib/esm/curve/internalContexts/CurveCurveIntersectXY.d.ts.map +1 -1
  436. package/lib/esm/curve/internalContexts/CurveCurveIntersectXY.js +153 -184
  437. package/lib/esm/curve/internalContexts/CurveCurveIntersectXY.js.map +1 -1
  438. package/lib/esm/curve/internalContexts/CurveCurveIntersectXYZ.js.map +1 -1
  439. package/lib/esm/curve/internalContexts/CurveLengthContext.js.map +1 -1
  440. package/lib/esm/curve/internalContexts/CurveOffsetXYHandler.js.map +1 -1
  441. package/lib/esm/curve/internalContexts/EllipticalArcApproximationContext.js.map +1 -1
  442. package/lib/esm/curve/internalContexts/GapSearchContext.js.map +1 -1
  443. package/lib/esm/curve/internalContexts/MultiChainCollector.js.map +1 -1
  444. package/lib/esm/curve/internalContexts/PlaneAltitudeRangeContext.js.map +1 -1
  445. package/lib/esm/curve/internalContexts/PointToCurveTangentHandler.js.map +1 -1
  446. package/lib/esm/curve/internalContexts/PolygonOffsetContext.js.map +1 -1
  447. package/lib/esm/curve/internalContexts/SumLengthsContext.js.map +1 -1
  448. package/lib/esm/curve/internalContexts/TransferWithSplitArcs.js.map +1 -1
  449. package/lib/esm/curve/internalContexts/TransformInPlaceContext.js.map +1 -1
  450. package/lib/esm/curve/internalContexts/geometry2d/ConstrainedImplicitCurve2d.js.map +1 -1
  451. package/lib/esm/curve/internalContexts/geometry2d/ConstraintSet.js.map +1 -1
  452. package/lib/esm/curve/internalContexts/geometry2d/ImplicitCurve2d.js.map +1 -1
  453. package/lib/esm/curve/internalContexts/geometry2d/ImplicitCurve2dConverter.js.map +1 -1
  454. package/lib/esm/curve/internalContexts/geometry2d/UnboundedCircle2d.js.map +1 -1
  455. package/lib/esm/curve/internalContexts/geometry2d/UnboundedEllipse2d.js.map +1 -1
  456. package/lib/esm/curve/internalContexts/geometry2d/UnboundedHyperbola2d.js.map +1 -1
  457. package/lib/esm/curve/internalContexts/geometry2d/UnboundedLine2d.js.map +1 -1
  458. package/lib/esm/curve/internalContexts/geometry2d/UnboundedParabola2d.js.map +1 -1
  459. package/lib/esm/curve/spiral/AustralianRailCorpXYEvaluator.js.map +1 -1
  460. package/lib/esm/curve/spiral/ClothoidSeries.js.map +1 -1
  461. package/lib/esm/curve/spiral/CubicEvaluator.js.map +1 -1
  462. package/lib/esm/curve/spiral/CzechSpiralEvaluator.js.map +1 -1
  463. package/lib/esm/curve/spiral/DirectHalfCosineSpiralEvaluator.js.map +1 -1
  464. package/lib/esm/curve/spiral/DirectSpiral3d.d.ts +1 -2
  465. package/lib/esm/curve/spiral/DirectSpiral3d.d.ts.map +1 -1
  466. package/lib/esm/curve/spiral/DirectSpiral3d.js +9 -3
  467. package/lib/esm/curve/spiral/DirectSpiral3d.js.map +1 -1
  468. package/lib/esm/curve/spiral/IntegratedSpiral3d.d.ts +1 -2
  469. package/lib/esm/curve/spiral/IntegratedSpiral3d.d.ts.map +1 -1
  470. package/lib/esm/curve/spiral/IntegratedSpiral3d.js +10 -4
  471. package/lib/esm/curve/spiral/IntegratedSpiral3d.js.map +1 -1
  472. package/lib/esm/curve/spiral/MXCubicAlongArcSpiralEvaluator.js.map +1 -1
  473. package/lib/esm/curve/spiral/NormalizedTransition.js.map +1 -1
  474. package/lib/esm/curve/spiral/PolishCubicSpiralEvaluator.js.map +1 -1
  475. package/lib/esm/curve/spiral/TransitionConditionalProperties.js.map +1 -1
  476. package/lib/esm/curve/spiral/TransitionSpiral3d.js.map +1 -1
  477. package/lib/esm/curve/spiral/XYCurveEvaluator.js.map +1 -1
  478. package/lib/esm/geometry3d/Angle.js.map +1 -1
  479. package/lib/esm/geometry3d/AngleSweep.d.ts +3 -1
  480. package/lib/esm/geometry3d/AngleSweep.d.ts.map +1 -1
  481. package/lib/esm/geometry3d/AngleSweep.js +6 -2
  482. package/lib/esm/geometry3d/AngleSweep.js.map +1 -1
  483. package/lib/esm/geometry3d/BarycentricTriangle.js.map +1 -1
  484. package/lib/esm/geometry3d/BilinearPatch.js.map +1 -1
  485. package/lib/esm/geometry3d/CoincidentGeometryOps.js.map +1 -1
  486. package/lib/esm/geometry3d/Ellipsoid.js.map +1 -1
  487. package/lib/esm/geometry3d/FrameBuilder.js.map +1 -1
  488. package/lib/esm/geometry3d/FrustumAnimation.js.map +1 -1
  489. package/lib/esm/geometry3d/GeometryHandler.d.ts +33 -4
  490. package/lib/esm/geometry3d/GeometryHandler.d.ts.map +1 -1
  491. package/lib/esm/geometry3d/GeometryHandler.js +77 -0
  492. package/lib/esm/geometry3d/GeometryHandler.js.map +1 -1
  493. package/lib/esm/geometry3d/GrowableBlockedArray.js.map +1 -1
  494. package/lib/esm/geometry3d/GrowableFloat64Array.js.map +1 -1
  495. package/lib/esm/geometry3d/GrowableXYArray.d.ts +9 -6
  496. package/lib/esm/geometry3d/GrowableXYArray.d.ts.map +1 -1
  497. package/lib/esm/geometry3d/GrowableXYArray.js +20 -10
  498. package/lib/esm/geometry3d/GrowableXYArray.js.map +1 -1
  499. package/lib/esm/geometry3d/GrowableXYZArray.d.ts +9 -6
  500. package/lib/esm/geometry3d/GrowableXYZArray.d.ts.map +1 -1
  501. package/lib/esm/geometry3d/GrowableXYZArray.js +20 -10
  502. package/lib/esm/geometry3d/GrowableXYZArray.js.map +1 -1
  503. package/lib/esm/geometry3d/IndexedCollectionInterval.js.map +1 -1
  504. package/lib/esm/geometry3d/IndexedXYCollection.js.map +1 -1
  505. package/lib/esm/geometry3d/IndexedXYZCollection.js.map +1 -1
  506. package/lib/esm/geometry3d/LongitudeLatitudeAltitude.js.map +1 -1
  507. package/lib/esm/geometry3d/Matrix3d.d.ts +4 -4
  508. package/lib/esm/geometry3d/Matrix3d.d.ts.map +1 -1
  509. package/lib/esm/geometry3d/Matrix3d.js +5 -4
  510. package/lib/esm/geometry3d/Matrix3d.js.map +1 -1
  511. package/lib/esm/geometry3d/OrderedRotationAngles.js.map +1 -1
  512. package/lib/esm/geometry3d/Plane3d.js.map +1 -1
  513. package/lib/esm/geometry3d/Plane3dByOriginAndUnitNormal.js.map +1 -1
  514. package/lib/esm/geometry3d/Plane3dByOriginAndVectors.js.map +1 -1
  515. package/lib/esm/geometry3d/Point2dArrayCarrier.js.map +1 -1
  516. package/lib/esm/geometry3d/Point2dVector2d.js.map +1 -1
  517. package/lib/esm/geometry3d/Point3dArrayCarrier.js.map +1 -1
  518. package/lib/esm/geometry3d/Point3dVector3d.js.map +1 -1
  519. package/lib/esm/geometry3d/PointHelpers.d.ts.map +1 -1
  520. package/lib/esm/geometry3d/PointHelpers.js +6 -7
  521. package/lib/esm/geometry3d/PointHelpers.js.map +1 -1
  522. package/lib/esm/geometry3d/PointStreaming.js.map +1 -1
  523. package/lib/esm/geometry3d/PolygonOps.js.map +1 -1
  524. package/lib/esm/geometry3d/PolylineCompressionByEdgeOffset.js.map +1 -1
  525. package/lib/esm/geometry3d/PolylineOps.js.map +1 -1
  526. package/lib/esm/geometry3d/Range.js.map +1 -1
  527. package/lib/esm/geometry3d/Ray2d.js.map +1 -1
  528. package/lib/esm/geometry3d/Ray3d.js.map +1 -1
  529. package/lib/esm/geometry3d/ReusableObjectCache.js.map +1 -1
  530. package/lib/esm/geometry3d/Segment1d.js.map +1 -1
  531. package/lib/esm/geometry3d/SortablePolygon.js.map +1 -1
  532. package/lib/esm/geometry3d/Transform.js.map +1 -1
  533. package/lib/esm/geometry3d/UVSurfaceOps.js.map +1 -1
  534. package/lib/esm/geometry3d/XYZProps.js.map +1 -1
  535. package/lib/esm/geometry3d/YawPitchRollAngles.js.map +1 -1
  536. package/lib/esm/geometry4d/Map4d.js.map +1 -1
  537. package/lib/esm/geometry4d/Matrix4d.js.map +1 -1
  538. package/lib/esm/geometry4d/MomentData.js.map +1 -1
  539. package/lib/esm/geometry4d/PlaneByOriginAndVectors4d.js.map +1 -1
  540. package/lib/esm/geometry4d/Point4d.js.map +1 -1
  541. package/lib/esm/numerics/BandedSystem.js.map +1 -1
  542. package/lib/esm/numerics/BezierPolynomials.d.ts.map +1 -1
  543. package/lib/esm/numerics/BezierPolynomials.js +1 -1
  544. package/lib/esm/numerics/BezierPolynomials.js.map +1 -1
  545. package/lib/esm/numerics/ClusterableArray.js.map +1 -1
  546. package/lib/esm/numerics/Complex.js.map +1 -1
  547. package/lib/esm/numerics/ConvexPolygon2d.js.map +1 -1
  548. package/lib/esm/numerics/Newton.d.ts +52 -13
  549. package/lib/esm/numerics/Newton.d.ts.map +1 -1
  550. package/lib/esm/numerics/Newton.js +71 -22
  551. package/lib/esm/numerics/Newton.js.map +1 -1
  552. package/lib/esm/numerics/PascalCoefficients.js.map +1 -1
  553. package/lib/esm/numerics/PolarData.js.map +1 -1
  554. package/lib/esm/numerics/Polynomials.js.map +1 -1
  555. package/lib/esm/numerics/Quadrature.js.map +1 -1
  556. package/lib/esm/numerics/Range1dArray.js.map +1 -1
  557. package/lib/esm/numerics/SmallSystem.js.map +1 -1
  558. package/lib/esm/numerics/TriDiagonalSystem.js.map +1 -1
  559. package/lib/esm/numerics/UnionFind.js.map +1 -1
  560. package/lib/esm/numerics/UsageSums.js.map +1 -1
  561. package/lib/esm/polyface/AuxData.js.map +1 -1
  562. package/lib/esm/polyface/BoxTopology.js.map +1 -1
  563. package/lib/esm/polyface/FacetFaceData.js.map +1 -1
  564. package/lib/esm/polyface/FacetLocationDetail.js.map +1 -1
  565. package/lib/esm/polyface/FacetOrientation.js.map +1 -1
  566. package/lib/esm/polyface/GreedyTriangulationBetweenLineStrings.js.map +1 -1
  567. package/lib/esm/polyface/IndexedEdgeMatcher.js.map +1 -1
  568. package/lib/esm/polyface/IndexedPolyfaceVisitor.js.map +1 -1
  569. package/lib/esm/polyface/IndexedPolyfaceWalker.js.map +1 -1
  570. package/lib/esm/polyface/Polyface.js.map +1 -1
  571. package/lib/esm/polyface/PolyfaceBuilder.js.map +1 -1
  572. package/lib/esm/polyface/PolyfaceClip.js.map +1 -1
  573. package/lib/esm/polyface/PolyfaceData.js.map +1 -1
  574. package/lib/esm/polyface/PolyfaceQuery.d.ts +14 -14
  575. package/lib/esm/polyface/PolyfaceQuery.d.ts.map +1 -1
  576. package/lib/esm/polyface/PolyfaceQuery.js +14 -14
  577. package/lib/esm/polyface/PolyfaceQuery.js.map +1 -1
  578. package/lib/esm/polyface/RangeLengthData.js.map +1 -1
  579. package/lib/esm/polyface/RangeTree/LineString3dRangeTreeContext.js.map +1 -1
  580. package/lib/esm/polyface/RangeTree/MinimumValueTester.js.map +1 -1
  581. package/lib/esm/polyface/RangeTree/Point3dArrayRangeTreeContext.js.map +1 -1
  582. package/lib/esm/polyface/RangeTree/PolyfaceRangeTreeContext.js.map +1 -1
  583. package/lib/esm/polyface/RangeTree/RangeTreeNode.js.map +1 -1
  584. package/lib/esm/polyface/RangeTree/RangeTreeSearchHandlers.js.map +1 -1
  585. package/lib/esm/polyface/TaggedNumericData.js.map +1 -1
  586. package/lib/esm/polyface/TriangleCandidate.js.map +1 -1
  587. package/lib/esm/polyface/multiclip/BuildAverageNormalsContext.js.map +1 -1
  588. package/lib/esm/polyface/multiclip/GriddedRaggedRange2dSet.js.map +1 -1
  589. package/lib/esm/polyface/multiclip/GriddedRaggedRange2dSetWithOverflow.js.map +1 -1
  590. package/lib/esm/polyface/multiclip/LinearSearchRange2dArray.js.map +1 -1
  591. package/lib/esm/polyface/multiclip/OffsetMeshContext.js.map +1 -1
  592. package/lib/esm/polyface/multiclip/Range2dSearchInterface.js.map +1 -1
  593. package/lib/esm/polyface/multiclip/RangeSearch.js.map +1 -1
  594. package/lib/esm/polyface/multiclip/SweepLineStringToFacetContext.js.map +1 -1
  595. package/lib/esm/polyface/multiclip/XYPointBuckets.js.map +1 -1
  596. package/lib/esm/serialization/BGFBAccessors.js.map +1 -1
  597. package/lib/esm/serialization/BGFBReader.js +2 -2
  598. package/lib/esm/serialization/BGFBReader.js.map +1 -1
  599. package/lib/esm/serialization/BGFBWriter.js.map +1 -1
  600. package/lib/esm/serialization/BentleyGeometryFlatBuffer.js.map +1 -1
  601. package/lib/esm/serialization/DeepCompare.js.map +1 -1
  602. package/lib/esm/serialization/IModelJsonSchema.js.map +1 -1
  603. package/lib/esm/serialization/SerializationHelpers.js.map +1 -1
  604. package/lib/esm/solid/Box.js.map +1 -1
  605. package/lib/esm/solid/Cone.js.map +1 -1
  606. package/lib/esm/solid/LinearSweep.js.map +1 -1
  607. package/lib/esm/solid/RotationalSweep.js.map +1 -1
  608. package/lib/esm/solid/RuledSweep.js.map +1 -1
  609. package/lib/esm/solid/SolidPrimitive.js.map +1 -1
  610. package/lib/esm/solid/Sphere.js.map +1 -1
  611. package/lib/esm/solid/SweepContour.js.map +1 -1
  612. package/lib/esm/solid/TorusPipe.js.map +1 -1
  613. package/lib/esm/topology/ChainMerge.js.map +1 -1
  614. package/lib/esm/topology/Graph.d.ts +15 -15
  615. package/lib/esm/topology/Graph.d.ts.map +1 -1
  616. package/lib/esm/topology/Graph.js +1 -1
  617. package/lib/esm/topology/Graph.js.map +1 -1
  618. package/lib/esm/topology/HalfEdgeGraphFromIndexedLoopsContext.js.map +1 -1
  619. package/lib/esm/topology/HalfEdgeGraphSearch.d.ts +3 -3
  620. package/lib/esm/topology/HalfEdgeGraphSearch.d.ts.map +1 -1
  621. package/lib/esm/topology/HalfEdgeGraphSearch.js.map +1 -1
  622. package/lib/esm/topology/HalfEdgeGraphSpineContext.js.map +1 -1
  623. package/lib/esm/topology/HalfEdgeGraphValidation.js.map +1 -1
  624. package/lib/esm/topology/HalfEdgeMarkSet.js.map +1 -1
  625. package/lib/esm/topology/HalfEdgeNodeXYZUV.js.map +1 -1
  626. package/lib/esm/topology/HalfEdgePointInGraphSearch.js.map +1 -1
  627. package/lib/esm/topology/HalfEdgePositionDetail.js.map +1 -1
  628. package/lib/esm/topology/HalfEdgePriorityQueue.js.map +1 -1
  629. package/lib/esm/topology/InsertAndRetriangulateContext.js.map +1 -1
  630. package/lib/esm/topology/MaskManager.js.map +1 -1
  631. package/lib/esm/topology/Merging.js.map +1 -1
  632. package/lib/esm/topology/RegularizeFace.js.map +1 -1
  633. package/lib/esm/topology/SignedDataSummary.js.map +1 -1
  634. package/lib/esm/topology/SpaceTriangulation.js.map +1 -1
  635. package/lib/esm/topology/Triangulation.js.map +1 -1
  636. package/lib/esm/topology/Voronoi.js.map +1 -1
  637. package/lib/esm/topology/XYParitySearchContext.js.map +1 -1
  638. package/package.json +3 -3
  639. package/lib/cjs/curve/internalContexts/NewtonRtoRStrokeHandler.d.ts +0 -23
  640. package/lib/cjs/curve/internalContexts/NewtonRtoRStrokeHandler.d.ts.map +0 -1
  641. package/lib/cjs/curve/internalContexts/NewtonRtoRStrokeHandler.js +0 -37
  642. package/lib/cjs/curve/internalContexts/NewtonRtoRStrokeHandler.js.map +0 -1
  643. package/lib/esm/curve/internalContexts/NewtonRtoRStrokeHandler.d.ts +0 -23
  644. package/lib/esm/curve/internalContexts/NewtonRtoRStrokeHandler.d.ts.map +0 -1
  645. package/lib/esm/curve/internalContexts/NewtonRtoRStrokeHandler.js +0 -33
  646. package/lib/esm/curve/internalContexts/NewtonRtoRStrokeHandler.js.map +0 -1
@@ -20,12 +20,13 @@ import { SortablePolygon } from "../geometry3d/SortablePolygon";
20
20
  import { Transform } from "../geometry3d/Transform";
21
21
  import { MomentData } from "../geometry4d/MomentData";
22
22
  import { PolyfaceBuilder } from "../polyface/PolyfaceBuilder";
23
- import { HalfEdgeMask } from "../topology/Graph";
23
+ import { HalfEdge, HalfEdgeMask } from "../topology/Graph";
24
24
  import { HalfEdgeGraphSearch } from "../topology/HalfEdgeGraphSearch";
25
25
  import { HalfEdgeGraphOps } from "../topology/Merging";
26
26
  import { Triangulator } from "../topology/Triangulation";
27
27
  import { BagOfCurves, CurveChain, CurveCollection } from "./CurveCollection";
28
28
  import { CurveCurve } from "./CurveCurve";
29
+ import { CurveLocationDetail } from "./CurveLocationDetail";
29
30
  import { CurveOps } from "./CurveOps";
30
31
  import { CurvePrimitive } from "./CurvePrimitive";
31
32
  import { CurveWireMomentsXYZ } from "./CurveWireMomentsXYZ";
@@ -44,7 +45,7 @@ import { CurveSplitContext } from "./Query/CurveSplitContext";
44
45
  import { PointInOnOutContext } from "./Query/InOutTests";
45
46
  import { PlanarSubdivision } from "./Query/PlanarSubdivision";
46
47
  import { RegionMomentsXY } from "./RegionMomentsXY";
47
- import { RegionBooleanContext, RegionGroupOpType, RegionOpsFaceToFaceSearch } from "./RegionOpsClassificationSweeps";
48
+ import { RegionBooleanContext, RegionGroupMember, RegionGroupOpType, RegionOpsFaceToFaceSearch } from "./RegionOpsClassificationSweeps";
48
49
  import { UnionRegion } from "./UnionRegion";
49
50
  /**
50
51
  * * Options to control method [[RegionOps.consolidateAdjacentPrimitives]].
@@ -743,27 +744,113 @@ export class RegionOps {
743
744
  }
744
745
  return SortablePolygon.sortAsAnyRegion(loopAndArea);
745
746
  }
747
+ /**
748
+ * Simplify the graph by removing bridge edges that do not serve to connect inner and outer loops.
749
+ * * If edgeTags are `CurveLocationDetail`s, e.g., as set by `PlanarSubdivision.assembleHalfEdgeGraph`, attempt to heal edges split by removed bridge edges.
750
+ * @param graph half edges to process.
751
+ * @param isBridgeEdge optional function to identify a bridge edge. Default looks for `HalfEdgeMask.BRIDGE_EDGE`.
752
+ * @param faceToArea optional function to compute face area. Default is `HalfEdgeGraphSearch.signedFaceArea`.
753
+ * @returns the number of extraneous bridge edges removed from the graph.
754
+ * @internal
755
+ */
756
+ static removeExtraneousBridgeEdges(graph, isBridgeEdge, faceToArea) {
757
+ const toHeal = [];
758
+ const interiorBridges = [];
759
+ if (!faceToArea)
760
+ faceToArea = (node) => HalfEdgeGraphSearch.signedFaceArea(node);
761
+ if (!isBridgeEdge)
762
+ isBridgeEdge = (node) => node.isMaskSet(HalfEdgeMask.BRIDGE_EDGE);
763
+ // isolate dangling bridges, bridges separating different faces, and "exterior" bridges in the negative area face
764
+ graph.announceEdges((_g, node) => {
765
+ if (isBridgeEdge(node)) {
766
+ if (node.isDangling || node.edgeMate.isDangling || !node.findAroundFace(node.edgeMate) || faceToArea(node) < 0.0) {
767
+ toHeal.push(node.vertexSuccessor);
768
+ toHeal.push(node.edgeMate.vertexSuccessor);
769
+ node.isolateEdge();
770
+ }
771
+ else {
772
+ interiorBridges.push(node);
773
+ }
774
+ }
775
+ return true;
776
+ });
777
+ // Relies only on face loop orientation. Doesn't use static HalfEdgeMasks!
778
+ const isBoundaryEdge = (node) => {
779
+ if (faceToArea(node) < 0.0)
780
+ return true; // exterior face
781
+ if (node.findAroundFace(node.edgeMate))
782
+ return false; // interior washer face
783
+ return faceToArea(node.edgeMate) < 0.0; // adjacent to exterior face
784
+ };
785
+ // All bridges in the negative area face were isolated, but this may have promoted other bridges to the
786
+ // negative area face. Keep isolating these bridge edges until none remain.
787
+ let numIsolatedThisPass;
788
+ do {
789
+ numIsolatedThisPass = 0;
790
+ for (const node of interiorBridges) {
791
+ if (!node.isIsolatedEdge && isBoundaryEdge(node)) {
792
+ toHeal.push(node.vertexSuccessor);
793
+ toHeal.push(node.edgeMate.vertexSuccessor);
794
+ node.isolateEdge();
795
+ numIsolatedThisPass++;
796
+ }
797
+ }
798
+ } while (numIsolatedThisPass > 0);
799
+ // lambda to extend the detail interval on a side of a healed edge
800
+ const mergeDetails = (he, newFraction, newPoint) => {
801
+ if (he && he.edgeTag instanceof CurveLocationDetail && he.sortData !== undefined && newFraction !== undefined && newPoint) {
802
+ if (he.sortData > 0)
803
+ he.edgeTag.captureFraction1Point1(newFraction, newPoint);
804
+ else
805
+ he.edgeTag.captureFractionPoint(newFraction, newPoint);
806
+ }
807
+ };
808
+ // At this point all removable bridges are isolated. Clean up their original vertex loops, if possible.
809
+ for (const doomedA of toHeal) {
810
+ const doomedB = doomedA.vertexSuccessor;
811
+ if ( // are the geometries mergeable?
812
+ doomedA !== doomedB &&
813
+ doomedA.edgeTag instanceof CurveLocationDetail && doomedA.sortData !== undefined &&
814
+ doomedB.edgeTag instanceof CurveLocationDetail && doomedB.sortData !== undefined &&
815
+ doomedA.edgeTag.curve === doomedB.edgeTag.curve &&
816
+ doomedA.edgeTag.isInterval() && doomedB.edgeTag.isInterval() &&
817
+ doomedA.sortData * doomedB.sortData < 0 &&
818
+ ((doomedA.sortData > 0 && Geometry.isSmallRelative(doomedA.edgeTag.fraction - doomedB.edgeTag.fraction1)) ||
819
+ (doomedA.sortData < 0 && Geometry.isSmallRelative(doomedA.edgeTag.fraction1 - doomedB.edgeTag.fraction)))) {
820
+ const survivorA = HalfEdge.healEdge(doomedA, false);
821
+ if (survivorA) {
822
+ const endFractionA = (doomedA.sortData > 0) ? doomedA.edgeTag.fraction1 : doomedA.edgeTag.fraction;
823
+ const endPointA = (doomedA.sortData > 0) ? doomedA.edgeTag.point1 : doomedA.edgeTag.point;
824
+ mergeDetails(survivorA, endFractionA, endPointA);
825
+ const endFractionB = (doomedB.sortData > 0) ? doomedB.edgeTag.fraction1 : doomedB.edgeTag.fraction;
826
+ const endPointB = (doomedB.sortData > 0) ? doomedB.edgeTag.point1 : doomedB.edgeTag.point;
827
+ mergeDetails(survivorA.edgeMate, endFractionB, endPointB);
828
+ }
829
+ }
830
+ }
831
+ return graph.deleteIsolatedEdges();
832
+ }
746
833
  /**
747
834
  * Collect inputs that are nominally closed: regions, and physically closed curves.
748
835
  * * Physically closed input curves are each returned wrapped in a Loop to facilitate xy-algorithms,
749
836
  * but outside this limited context, these Loops only makes sense if they are planar.
837
+ * @param curves inputs
838
+ * @param openCurves optional array to receive open input curves that were not returned as regions.
839
+ * @param tolerance optional distance tolerance for determining physical closure. Default is [[Geometry.smallMetricDistance]].
750
840
  */
751
- static collectRegionsAndClosedPrimitives(curves, tolerance = Geometry.smallMetricDistance) {
841
+ static collectRegionsAndClosedPrimitives(curves, openCurves, tolerance = Geometry.smallMetricDistance) {
752
842
  const regions = [];
753
843
  if (!Array.isArray(curves))
754
844
  curves = [curves];
755
845
  for (const curve of curves) {
756
- if (curve instanceof Loop || curve instanceof ParityRegion || curve instanceof UnionRegion) {
846
+ if (curve instanceof Loop || curve instanceof ParityRegion || curve instanceof UnionRegion)
757
847
  regions.push(curve);
758
- }
759
- else if (curve instanceof Path) {
760
- if (curve.isPhysicallyClosedCurve(tolerance))
761
- regions.push(Loop.create(...curve.children));
762
- }
763
- else if (curve instanceof CurvePrimitive) {
764
- if (curve.isPhysicallyClosedCurve(tolerance))
765
- regions.push(Loop.create(curve));
766
- }
848
+ else if (curve instanceof Path && curve.isPhysicallyClosedCurve(tolerance))
849
+ regions.push(Loop.create(...curve.children));
850
+ else if (curve instanceof CurvePrimitive && curve.isPhysicallyClosedCurve(tolerance))
851
+ regions.push(Loop.create(curve));
852
+ else if (openCurves)
853
+ openCurves.push(curve);
767
854
  }
768
855
  return regions;
769
856
  }
@@ -773,9 +860,9 @@ export class RegionOps {
773
860
  * * "Holes" implied/bounded by inputs are _not_ preserved/discovered in output; in particular [[ParityRegion]]
774
861
  * hole loops are treated like any other positive area loops.
775
862
  * * A common use case of this method is to assemble the bounding negative-area "exterior" loop for each connected
776
- * component of input curves. Passing `addBridges = true` decreases the number of connected components for nested
777
- * input [[Loop]]s, and thus increases the likelihood of returning exactly one exterior loop. (This is why the
778
- * default value for `addBridges` is `true`.)
863
+ * component of input curves. Passing addBridges = true adds "bridge" segments to connect unconnected input [[Loops]]s
864
+ * and thereby increases the likelihood that a single connected component is returned. (This is why the default value
865
+ * for addBridges is true.)
779
866
  * @param curvesAndRegions Any collection of curves. Each [[AnyRegion]] contributes its children _stripped of
780
867
  * parity context_.
781
868
  * @param tolerance optional distance tolerance for coincidence. Default is [[Geometry.smallMetricDistance]].
@@ -794,21 +881,30 @@ export class RegionOps {
794
881
  primitives = TransferWithSplitArcs.clone(BagOfCurves.create(...primitives)).children;
795
882
  const range = this.curveArrayRange(primitives);
796
883
  const areaTol = this.computeXYAreaTolerance(range, tolerance);
797
- if (addBridges) { // generate a temp graph to extract its bridge edges
884
+ let hasOpenCurve = false;
885
+ if (addBridges) { // generate a temp graph from ONLY the closed inputs to extract its bridge edges
798
886
  const context = RegionBooleanContext.create(RegionGroupOpType.Union, RegionGroupOpType.Union);
799
- const regions = this.collectRegionsAndClosedPrimitives(curvesAndRegions, tolerance);
887
+ const openCurves = [];
888
+ const regions = this.collectRegionsAndClosedPrimitives(curvesAndRegions, openCurves, tolerance);
889
+ hasOpenCurve = openCurves.length > 0;
800
890
  if (regions.length > 0) {
801
891
  context.addMembers(regions, undefined);
802
892
  context.annotateAndMergeCurvesInGraph(tolerance);
803
893
  context.graph.announceEdges((_graph, edge) => {
804
- if (edge.isMaskSet(HalfEdgeMask.BRIDGE_EDGE))
805
- primitives.push(LineSegment3d.create(edge.getPoint3d(), edge.faceSuccessor.getPoint3d()));
894
+ if (edge.isMaskSet(HalfEdgeMask.BRIDGE_EDGE)) {
895
+ // ensure the bridge edge roundtrips thru assembleHalfEdgeGraph so that we can filter it later if necessary
896
+ const bridgeSegment = LineSegment3d.create(edge.getPoint3d(), edge.faceSuccessor.getPoint3d());
897
+ bridgeSegment.parent = new RegionGroupMember(bridgeSegment, context.extraGeometry);
898
+ primitives.push(bridgeSegment);
899
+ }
806
900
  return true;
807
901
  });
808
902
  }
809
903
  }
810
904
  const intersections = CurveCurve.allIntersectionsAmongPrimitivesXY(primitives, tolerance);
811
905
  const graph = PlanarSubdivision.assembleHalfEdgeGraph(primitives, intersections, tolerance);
906
+ if (addBridges && hasOpenCurve)
907
+ RegionOps.removeExtraneousBridgeEdges(graph);
812
908
  return PlanarSubdivision.collectSignedLoopSetsInHalfEdgeGraph(graph, areaTol);
813
909
  }
814
910
  /**