@itwin/core-geometry 5.0.0-dev.11 → 5.0.0-dev.111

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 (1066) hide show
  1. package/CHANGELOG.md +71 -1
  2. package/lib/cjs/Constant.js +17 -17
  3. package/lib/cjs/Constant.js.map +1 -1
  4. package/lib/cjs/Geometry.d.ts +13 -4
  5. package/lib/cjs/Geometry.d.ts.map +1 -1
  6. package/lib/cjs/Geometry.js +51 -39
  7. package/lib/cjs/Geometry.js.map +1 -1
  8. package/lib/cjs/bspline/AkimaCurve3d.js +3 -1
  9. package/lib/cjs/bspline/AkimaCurve3d.js.map +1 -1
  10. package/lib/cjs/bspline/BSpline1dNd.d.ts +90 -54
  11. package/lib/cjs/bspline/BSpline1dNd.d.ts.map +1 -1
  12. package/lib/cjs/bspline/BSpline1dNd.js +137 -84
  13. package/lib/cjs/bspline/BSpline1dNd.js.map +1 -1
  14. package/lib/cjs/bspline/BSplineCurve.d.ts +193 -155
  15. package/lib/cjs/bspline/BSplineCurve.d.ts.map +1 -1
  16. package/lib/cjs/bspline/BSplineCurve.js +249 -181
  17. package/lib/cjs/bspline/BSplineCurve.js.map +1 -1
  18. package/lib/cjs/bspline/BSplineCurve3dH.js +1 -0
  19. package/lib/cjs/bspline/BSplineCurve3dH.js.map +1 -1
  20. package/lib/cjs/bspline/BSplineCurveOps.d.ts.map +1 -1
  21. package/lib/cjs/bspline/BSplineCurveOps.js +18 -21
  22. package/lib/cjs/bspline/BSplineCurveOps.js.map +1 -1
  23. package/lib/cjs/bspline/BSplineSurface.js +22 -2
  24. package/lib/cjs/bspline/BSplineSurface.js.map +1 -1
  25. package/lib/cjs/bspline/Bezier1dNd.js +6 -0
  26. package/lib/cjs/bspline/Bezier1dNd.js.map +1 -1
  27. package/lib/cjs/bspline/BezierCurve3d.d.ts +3 -1
  28. package/lib/cjs/bspline/BezierCurve3d.d.ts.map +1 -1
  29. package/lib/cjs/bspline/BezierCurve3d.js +5 -5
  30. package/lib/cjs/bspline/BezierCurve3d.js.map +1 -1
  31. package/lib/cjs/bspline/BezierCurve3dH.js +2 -0
  32. package/lib/cjs/bspline/BezierCurve3dH.js.map +1 -1
  33. package/lib/cjs/bspline/BezierCurveBase.d.ts.map +1 -1
  34. package/lib/cjs/bspline/BezierCurveBase.js +21 -2
  35. package/lib/cjs/bspline/BezierCurveBase.js.map +1 -1
  36. package/lib/cjs/bspline/InterpolationCurve3d.js +12 -1
  37. package/lib/cjs/bspline/InterpolationCurve3d.js.map +1 -1
  38. package/lib/cjs/bspline/KnotVector.d.ts +82 -60
  39. package/lib/cjs/bspline/KnotVector.d.ts.map +1 -1
  40. package/lib/cjs/bspline/KnotVector.js +144 -84
  41. package/lib/cjs/bspline/KnotVector.js.map +1 -1
  42. package/lib/cjs/bspline/SurfaceLocationDetail.js +12 -0
  43. package/lib/cjs/bspline/SurfaceLocationDetail.js.map +1 -1
  44. package/lib/cjs/clipping/AlternatingConvexClipTree.js +14 -13
  45. package/lib/cjs/clipping/AlternatingConvexClipTree.js.map +1 -1
  46. package/lib/cjs/clipping/BooleanClipFactory.js.map +1 -1
  47. package/lib/cjs/clipping/BooleanClipNode.js +4 -0
  48. package/lib/cjs/clipping/BooleanClipNode.js.map +1 -1
  49. package/lib/cjs/clipping/ClipPlane.js +10 -1
  50. package/lib/cjs/clipping/ClipPlane.js.map +1 -1
  51. package/lib/cjs/clipping/ClipPrimitive.js +19 -0
  52. package/lib/cjs/clipping/ClipPrimitive.js.map +1 -1
  53. package/lib/cjs/clipping/ClipUtils.js +5 -1
  54. package/lib/cjs/clipping/ClipUtils.js.map +1 -1
  55. package/lib/cjs/clipping/ClipVector.js +11 -8
  56. package/lib/cjs/clipping/ClipVector.js.map +1 -1
  57. package/lib/cjs/clipping/ConvexClipPlaneSet.js +5 -3
  58. package/lib/cjs/clipping/ConvexClipPlaneSet.js.map +1 -1
  59. package/lib/cjs/clipping/UnionOfConvexClipPlaneSets.js +2 -1
  60. package/lib/cjs/clipping/UnionOfConvexClipPlaneSets.js.map +1 -1
  61. package/lib/cjs/clipping/internalContexts/LineStringOffsetClipperContext.js +3 -0
  62. package/lib/cjs/clipping/internalContexts/LineStringOffsetClipperContext.js.map +1 -1
  63. package/lib/cjs/core-geometry.d.ts +1 -0
  64. package/lib/cjs/core-geometry.d.ts.map +1 -1
  65. package/lib/cjs/core-geometry.js +1 -0
  66. package/lib/cjs/core-geometry.js.map +1 -1
  67. package/lib/cjs/curve/Arc3d.d.ts +20 -4
  68. package/lib/cjs/curve/Arc3d.d.ts.map +1 -1
  69. package/lib/cjs/curve/Arc3d.js +86 -21
  70. package/lib/cjs/curve/Arc3d.js.map +1 -1
  71. package/lib/cjs/curve/ConstructCurveBetweenCurves.js +3 -0
  72. package/lib/cjs/curve/ConstructCurveBetweenCurves.js.map +1 -1
  73. package/lib/cjs/curve/CoordinateXYZ.js +3 -2
  74. package/lib/cjs/curve/CoordinateXYZ.js.map +1 -1
  75. package/lib/cjs/curve/CurveChainWithDistanceIndex.d.ts +0 -2
  76. package/lib/cjs/curve/CurveChainWithDistanceIndex.d.ts.map +1 -1
  77. package/lib/cjs/curve/CurveChainWithDistanceIndex.js +25 -10
  78. package/lib/cjs/curve/CurveChainWithDistanceIndex.js.map +1 -1
  79. package/lib/cjs/curve/CurveCollection.d.ts +10 -0
  80. package/lib/cjs/curve/CurveCollection.d.ts.map +1 -1
  81. package/lib/cjs/curve/CurveCollection.js +35 -9
  82. package/lib/cjs/curve/CurveCollection.js.map +1 -1
  83. package/lib/cjs/curve/CurveCurve.js.map +1 -1
  84. package/lib/cjs/curve/CurveExtendMode.d.ts +13 -5
  85. package/lib/cjs/curve/CurveExtendMode.d.ts.map +1 -1
  86. package/lib/cjs/curve/CurveExtendMode.js +19 -15
  87. package/lib/cjs/curve/CurveExtendMode.js.map +1 -1
  88. package/lib/cjs/curve/CurveFactory.d.ts +87 -53
  89. package/lib/cjs/curve/CurveFactory.d.ts.map +1 -1
  90. package/lib/cjs/curve/CurveFactory.js +213 -135
  91. package/lib/cjs/curve/CurveFactory.js.map +1 -1
  92. package/lib/cjs/curve/CurveLocationDetail.js +44 -0
  93. package/lib/cjs/curve/CurveLocationDetail.js.map +1 -1
  94. package/lib/cjs/curve/CurveOps.js.map +1 -1
  95. package/lib/cjs/curve/CurvePrimitive.d.ts +74 -18
  96. package/lib/cjs/curve/CurvePrimitive.d.ts.map +1 -1
  97. package/lib/cjs/curve/CurvePrimitive.js +86 -18
  98. package/lib/cjs/curve/CurvePrimitive.js.map +1 -1
  99. package/lib/cjs/curve/CurveProcessor.js +2 -0
  100. package/lib/cjs/curve/CurveProcessor.js.map +1 -1
  101. package/lib/cjs/curve/CurveTypes.js.map +1 -1
  102. package/lib/cjs/curve/CurveWireMomentsXYZ.js +2 -0
  103. package/lib/cjs/curve/CurveWireMomentsXYZ.js.map +1 -1
  104. package/lib/cjs/curve/GeometryQuery.js.map +1 -1
  105. package/lib/cjs/curve/LineSegment3d.js +6 -2
  106. package/lib/cjs/curve/LineSegment3d.js.map +1 -1
  107. package/lib/cjs/curve/LineString3d.d.ts +8 -7
  108. package/lib/cjs/curve/LineString3d.d.ts.map +1 -1
  109. package/lib/cjs/curve/LineString3d.js +52 -29
  110. package/lib/cjs/curve/LineString3d.js.map +1 -1
  111. package/lib/cjs/curve/Loop.js +12 -4
  112. package/lib/cjs/curve/Loop.js.map +1 -1
  113. package/lib/cjs/curve/OffsetOptions.js +25 -21
  114. package/lib/cjs/curve/OffsetOptions.js.map +1 -1
  115. package/lib/cjs/curve/ParityRegion.js +4 -2
  116. package/lib/cjs/curve/ParityRegion.js.map +1 -1
  117. package/lib/cjs/curve/Path.js +2 -2
  118. package/lib/cjs/curve/Path.js.map +1 -1
  119. package/lib/cjs/curve/PointString3d.js +3 -2
  120. package/lib/cjs/curve/PointString3d.js.map +1 -1
  121. package/lib/cjs/curve/ProxyCurve.js +1 -0
  122. package/lib/cjs/curve/ProxyCurve.js.map +1 -1
  123. package/lib/cjs/curve/Query/ConsolidateAdjacentPrimitivesContext.js +1 -0
  124. package/lib/cjs/curve/Query/ConsolidateAdjacentPrimitivesContext.js.map +1 -1
  125. package/lib/cjs/curve/Query/CurveSplitContext.js +3 -0
  126. package/lib/cjs/curve/Query/CurveSplitContext.js.map +1 -1
  127. package/lib/cjs/curve/Query/CylindricalRange.js +6 -2
  128. package/lib/cjs/curve/Query/CylindricalRange.js.map +1 -1
  129. package/lib/cjs/curve/Query/InOutTests.js.map +1 -1
  130. package/lib/cjs/curve/Query/PlanarSubdivision.js +4 -6
  131. package/lib/cjs/curve/Query/PlanarSubdivision.js.map +1 -1
  132. package/lib/cjs/curve/Query/StrokeCountChain.js +12 -0
  133. package/lib/cjs/curve/Query/StrokeCountChain.js.map +1 -1
  134. package/lib/cjs/curve/Query/StrokeCountMap.js +14 -0
  135. package/lib/cjs/curve/Query/StrokeCountMap.js.map +1 -1
  136. package/lib/cjs/curve/RegionMomentsXY.js +4 -5
  137. package/lib/cjs/curve/RegionMomentsXY.js.map +1 -1
  138. package/lib/cjs/curve/RegionOps.js +9 -10
  139. package/lib/cjs/curve/RegionOps.js.map +1 -1
  140. package/lib/cjs/curve/RegionOpsClassificationSweeps.js +24 -1
  141. package/lib/cjs/curve/RegionOpsClassificationSweeps.js.map +1 -1
  142. package/lib/cjs/curve/StrokeOptions.d.ts +10 -5
  143. package/lib/cjs/curve/StrokeOptions.d.ts.map +1 -1
  144. package/lib/cjs/curve/StrokeOptions.js +30 -8
  145. package/lib/cjs/curve/StrokeOptions.js.map +1 -1
  146. package/lib/cjs/curve/UnionRegion.js +4 -2
  147. package/lib/cjs/curve/UnionRegion.js.map +1 -1
  148. package/lib/cjs/curve/internalContexts/AnnounceTangentStrokeHandler.d.ts +71 -0
  149. package/lib/cjs/curve/internalContexts/AnnounceTangentStrokeHandler.d.ts.map +1 -0
  150. package/lib/cjs/curve/internalContexts/AnnounceTangentStrokeHandler.js +181 -0
  151. package/lib/cjs/curve/internalContexts/AnnounceTangentStrokeHandler.js.map +1 -0
  152. package/lib/cjs/curve/internalContexts/AppendPlaneIntersectionStrokeHandler.js +13 -7
  153. package/lib/cjs/curve/internalContexts/AppendPlaneIntersectionStrokeHandler.js.map +1 -1
  154. package/lib/cjs/curve/internalContexts/ChainCollectorContext.js +6 -0
  155. package/lib/cjs/curve/internalContexts/ChainCollectorContext.js.map +1 -1
  156. package/lib/cjs/curve/internalContexts/CloneCurvesContext.js +2 -0
  157. package/lib/cjs/curve/internalContexts/CloneCurvesContext.js.map +1 -1
  158. package/lib/cjs/curve/internalContexts/CloneWithExpandedLineStrings.js.map +1 -1
  159. package/lib/cjs/curve/internalContexts/ClosestPointStrokeHandler.d.ts +21 -5
  160. package/lib/cjs/curve/internalContexts/ClosestPointStrokeHandler.d.ts.map +1 -1
  161. package/lib/cjs/curve/internalContexts/ClosestPointStrokeHandler.js +53 -20
  162. package/lib/cjs/curve/internalContexts/ClosestPointStrokeHandler.js.map +1 -1
  163. package/lib/cjs/curve/internalContexts/CountLinearPartsSearchContext.js +3 -0
  164. package/lib/cjs/curve/internalContexts/CountLinearPartsSearchContext.js.map +1 -1
  165. package/lib/cjs/curve/internalContexts/CurveCurveCloseApproachXY.js +18 -5
  166. package/lib/cjs/curve/internalContexts/CurveCurveCloseApproachXY.js.map +1 -1
  167. package/lib/cjs/curve/internalContexts/CurveCurveIntersectXY.js +26 -13
  168. package/lib/cjs/curve/internalContexts/CurveCurveIntersectXY.js.map +1 -1
  169. package/lib/cjs/curve/internalContexts/CurveCurveIntersectXYZ.js +11 -5
  170. package/lib/cjs/curve/internalContexts/CurveCurveIntersectXYZ.js.map +1 -1
  171. package/lib/cjs/curve/internalContexts/CurveLengthContext.js +6 -0
  172. package/lib/cjs/curve/internalContexts/CurveLengthContext.js.map +1 -1
  173. package/lib/cjs/curve/internalContexts/CurveOffsetXYHandler.js +8 -6
  174. package/lib/cjs/curve/internalContexts/CurveOffsetXYHandler.js.map +1 -1
  175. package/lib/cjs/curve/internalContexts/EllipticalArcApproximationContext.js +38 -5
  176. package/lib/cjs/curve/internalContexts/EllipticalArcApproximationContext.js.map +1 -1
  177. package/lib/cjs/curve/internalContexts/GapSearchContext.js +1 -0
  178. package/lib/cjs/curve/internalContexts/GapSearchContext.js.map +1 -1
  179. package/lib/cjs/curve/internalContexts/MultiChainCollector.js +12 -0
  180. package/lib/cjs/curve/internalContexts/MultiChainCollector.js.map +1 -1
  181. package/lib/cjs/curve/internalContexts/NewtonRtoRStrokeHandler.d.ts +5 -3
  182. package/lib/cjs/curve/internalContexts/NewtonRtoRStrokeHandler.d.ts.map +1 -1
  183. package/lib/cjs/curve/internalContexts/NewtonRtoRStrokeHandler.js +6 -3
  184. package/lib/cjs/curve/internalContexts/NewtonRtoRStrokeHandler.js.map +1 -1
  185. package/lib/cjs/curve/internalContexts/PlaneAltitudeRangeContext.js +7 -0
  186. package/lib/cjs/curve/internalContexts/PlaneAltitudeRangeContext.js.map +1 -1
  187. package/lib/cjs/curve/internalContexts/PolygonOffsetContext.js +22 -4
  188. package/lib/cjs/curve/internalContexts/PolygonOffsetContext.js.map +1 -1
  189. package/lib/cjs/curve/internalContexts/SumLengthsContext.js +1 -0
  190. package/lib/cjs/curve/internalContexts/SumLengthsContext.js.map +1 -1
  191. package/lib/cjs/curve/internalContexts/TransformInPlaceContext.js +3 -0
  192. package/lib/cjs/curve/internalContexts/TransformInPlaceContext.js.map +1 -1
  193. package/lib/cjs/curve/spiral/AustralianRailCorpXYEvaluator.js +2 -0
  194. package/lib/cjs/curve/spiral/AustralianRailCorpXYEvaluator.js.map +1 -1
  195. package/lib/cjs/curve/spiral/ClothoidSeries.js +4 -0
  196. package/lib/cjs/curve/spiral/ClothoidSeries.js.map +1 -1
  197. package/lib/cjs/curve/spiral/CubicEvaluator.js +2 -0
  198. package/lib/cjs/curve/spiral/CubicEvaluator.js.map +1 -1
  199. package/lib/cjs/curve/spiral/CzechSpiralEvaluator.js +4 -0
  200. package/lib/cjs/curve/spiral/CzechSpiralEvaluator.js.map +1 -1
  201. package/lib/cjs/curve/spiral/DirectHalfCosineSpiralEvaluator.js +5 -0
  202. package/lib/cjs/curve/spiral/DirectHalfCosineSpiralEvaluator.js.map +1 -1
  203. package/lib/cjs/curve/spiral/DirectSpiral3d.js +12 -2
  204. package/lib/cjs/curve/spiral/DirectSpiral3d.js.map +1 -1
  205. package/lib/cjs/curve/spiral/IntegratedSpiral3d.js +24 -4
  206. package/lib/cjs/curve/spiral/IntegratedSpiral3d.js.map +1 -1
  207. package/lib/cjs/curve/spiral/MXCubicAlongArcSpiralEvaluator.js +2 -0
  208. package/lib/cjs/curve/spiral/MXCubicAlongArcSpiralEvaluator.js.map +1 -1
  209. package/lib/cjs/curve/spiral/NormalizedTransition.js +5 -0
  210. package/lib/cjs/curve/spiral/NormalizedTransition.js.map +1 -1
  211. package/lib/cjs/curve/spiral/PolishCubicSpiralEvaluator.js +2 -0
  212. package/lib/cjs/curve/spiral/PolishCubicSpiralEvaluator.js.map +1 -1
  213. package/lib/cjs/curve/spiral/TransitionConditionalProperties.js +10 -0
  214. package/lib/cjs/curve/spiral/TransitionConditionalProperties.js.map +1 -1
  215. package/lib/cjs/curve/spiral/TransitionSpiral3d.js +10 -0
  216. package/lib/cjs/curve/spiral/TransitionSpiral3d.js.map +1 -1
  217. package/lib/cjs/curve/spiral/XYCurveEvaluator.js +6 -0
  218. package/lib/cjs/curve/spiral/XYCurveEvaluator.js.map +1 -1
  219. package/lib/cjs/geometry3d/Angle.js +18 -16
  220. package/lib/cjs/geometry3d/Angle.js.map +1 -1
  221. package/lib/cjs/geometry3d/AngleSweep.d.ts +8 -3
  222. package/lib/cjs/geometry3d/AngleSweep.d.ts.map +1 -1
  223. package/lib/cjs/geometry3d/AngleSweep.js +22 -10
  224. package/lib/cjs/geometry3d/AngleSweep.js.map +1 -1
  225. package/lib/cjs/geometry3d/BarycentricTriangle.js +25 -0
  226. package/lib/cjs/geometry3d/BarycentricTriangle.js.map +1 -1
  227. package/lib/cjs/geometry3d/BilinearPatch.js +8 -0
  228. package/lib/cjs/geometry3d/BilinearPatch.js.map +1 -1
  229. package/lib/cjs/geometry3d/CoincidentGeometryOps.js +5 -0
  230. package/lib/cjs/geometry3d/CoincidentGeometryOps.js.map +1 -1
  231. package/lib/cjs/geometry3d/Ellipsoid.d.ts +8 -7
  232. package/lib/cjs/geometry3d/Ellipsoid.d.ts.map +1 -1
  233. package/lib/cjs/geometry3d/Ellipsoid.js +63 -14
  234. package/lib/cjs/geometry3d/Ellipsoid.js.map +1 -1
  235. package/lib/cjs/geometry3d/FrameBuilder.js +12 -4
  236. package/lib/cjs/geometry3d/FrameBuilder.js.map +1 -1
  237. package/lib/cjs/geometry3d/FrustumAnimation.js +7 -0
  238. package/lib/cjs/geometry3d/FrustumAnimation.js.map +1 -1
  239. package/lib/cjs/geometry3d/GeometryHandler.d.ts +15 -16
  240. package/lib/cjs/geometry3d/GeometryHandler.d.ts.map +1 -1
  241. package/lib/cjs/geometry3d/GeometryHandler.js.map +1 -1
  242. package/lib/cjs/geometry3d/GrowableBlockedArray.js +12 -0
  243. package/lib/cjs/geometry3d/GrowableBlockedArray.js.map +1 -1
  244. package/lib/cjs/geometry3d/GrowableFloat64Array.js +3 -0
  245. package/lib/cjs/geometry3d/GrowableFloat64Array.js.map +1 -1
  246. package/lib/cjs/geometry3d/GrowableXYArray.d.ts +0 -5
  247. package/lib/cjs/geometry3d/GrowableXYArray.d.ts.map +1 -1
  248. package/lib/cjs/geometry3d/GrowableXYArray.js +16 -7
  249. package/lib/cjs/geometry3d/GrowableXYArray.js.map +1 -1
  250. package/lib/cjs/geometry3d/GrowableXYZArray.d.ts +32 -10
  251. package/lib/cjs/geometry3d/GrowableXYZArray.d.ts.map +1 -1
  252. package/lib/cjs/geometry3d/GrowableXYZArray.js +70 -16
  253. package/lib/cjs/geometry3d/GrowableXYZArray.js.map +1 -1
  254. package/lib/cjs/geometry3d/IndexedCollectionInterval.js +6 -0
  255. package/lib/cjs/geometry3d/IndexedCollectionInterval.js.map +1 -1
  256. package/lib/cjs/geometry3d/IndexedXYCollection.js +1 -0
  257. package/lib/cjs/geometry3d/IndexedXYCollection.js.map +1 -1
  258. package/lib/cjs/geometry3d/IndexedXYZCollection.d.ts +13 -2
  259. package/lib/cjs/geometry3d/IndexedXYZCollection.d.ts.map +1 -1
  260. package/lib/cjs/geometry3d/IndexedXYZCollection.js +26 -11
  261. package/lib/cjs/geometry3d/IndexedXYZCollection.js.map +1 -1
  262. package/lib/cjs/geometry3d/LongitudeLatitudeAltitude.js +3 -0
  263. package/lib/cjs/geometry3d/LongitudeLatitudeAltitude.js.map +1 -1
  264. package/lib/cjs/geometry3d/Matrix3d.d.ts +13 -15
  265. package/lib/cjs/geometry3d/Matrix3d.d.ts.map +1 -1
  266. package/lib/cjs/geometry3d/Matrix3d.js +47 -26
  267. package/lib/cjs/geometry3d/Matrix3d.js.map +1 -1
  268. package/lib/cjs/geometry3d/OrderedRotationAngles.js +10 -2
  269. package/lib/cjs/geometry3d/OrderedRotationAngles.js.map +1 -1
  270. package/lib/cjs/geometry3d/Plane3d.js.map +1 -1
  271. package/lib/cjs/geometry3d/Plane3dByOriginAndUnitNormal.js +2 -0
  272. package/lib/cjs/geometry3d/Plane3dByOriginAndUnitNormal.js.map +1 -1
  273. package/lib/cjs/geometry3d/Plane3dByOriginAndVectors.js +7 -0
  274. package/lib/cjs/geometry3d/Plane3dByOriginAndVectors.js.map +1 -1
  275. package/lib/cjs/geometry3d/Point2dArrayCarrier.js +2 -0
  276. package/lib/cjs/geometry3d/Point2dArrayCarrier.js.map +1 -1
  277. package/lib/cjs/geometry3d/Point2dVector2d.js +4 -0
  278. package/lib/cjs/geometry3d/Point2dVector2d.js.map +1 -1
  279. package/lib/cjs/geometry3d/Point3dArrayCarrier.js +3 -1
  280. package/lib/cjs/geometry3d/Point3dArrayCarrier.js.map +1 -1
  281. package/lib/cjs/geometry3d/Point3dVector3d.d.ts +7 -10
  282. package/lib/cjs/geometry3d/Point3dVector3d.d.ts.map +1 -1
  283. package/lib/cjs/geometry3d/Point3dVector3d.js +16 -10
  284. package/lib/cjs/geometry3d/Point3dVector3d.js.map +1 -1
  285. package/lib/cjs/geometry3d/PointHelpers.d.ts +15 -4
  286. package/lib/cjs/geometry3d/PointHelpers.d.ts.map +1 -1
  287. package/lib/cjs/geometry3d/PointHelpers.js +29 -8
  288. package/lib/cjs/geometry3d/PointHelpers.js.map +1 -1
  289. package/lib/cjs/geometry3d/PointStreaming.js +12 -4
  290. package/lib/cjs/geometry3d/PointStreaming.js.map +1 -1
  291. package/lib/cjs/geometry3d/PolygonOps.d.ts +2 -2
  292. package/lib/cjs/geometry3d/PolygonOps.js +62 -25
  293. package/lib/cjs/geometry3d/PolygonOps.js.map +1 -1
  294. package/lib/cjs/geometry3d/PolylineCompressionByEdgeOffset.js +7 -3
  295. package/lib/cjs/geometry3d/PolylineCompressionByEdgeOffset.js.map +1 -1
  296. package/lib/cjs/geometry3d/PolylineOps.d.ts +9 -5
  297. package/lib/cjs/geometry3d/PolylineOps.d.ts.map +1 -1
  298. package/lib/cjs/geometry3d/PolylineOps.js +12 -5
  299. package/lib/cjs/geometry3d/PolylineOps.js.map +1 -1
  300. package/lib/cjs/geometry3d/Range.js +21 -4
  301. package/lib/cjs/geometry3d/Range.js.map +1 -1
  302. package/lib/cjs/geometry3d/Ray2d.js +2 -0
  303. package/lib/cjs/geometry3d/Ray2d.js.map +1 -1
  304. package/lib/cjs/geometry3d/Ray3d.d.ts +2 -2
  305. package/lib/cjs/geometry3d/Ray3d.d.ts.map +1 -1
  306. package/lib/cjs/geometry3d/Ray3d.js +20 -11
  307. package/lib/cjs/geometry3d/Ray3d.js.map +1 -1
  308. package/lib/cjs/geometry3d/ReusableObjectCache.js +4 -0
  309. package/lib/cjs/geometry3d/ReusableObjectCache.js.map +1 -1
  310. package/lib/cjs/geometry3d/Segment1d.js +4 -0
  311. package/lib/cjs/geometry3d/Segment1d.js.map +1 -1
  312. package/lib/cjs/geometry3d/SortablePolygon.js +11 -0
  313. package/lib/cjs/geometry3d/SortablePolygon.js.map +1 -1
  314. package/lib/cjs/geometry3d/Transform.d.ts +1 -1
  315. package/lib/cjs/geometry3d/Transform.js +4 -1
  316. package/lib/cjs/geometry3d/Transform.js.map +1 -1
  317. package/lib/cjs/geometry3d/UVSurfaceOps.js.map +1 -1
  318. package/lib/cjs/geometry3d/XYZProps.js.map +1 -1
  319. package/lib/cjs/geometry3d/YawPitchRollAngles.js +6 -0
  320. package/lib/cjs/geometry3d/YawPitchRollAngles.js.map +1 -1
  321. package/lib/cjs/geometry4d/Map4d.js +2 -0
  322. package/lib/cjs/geometry4d/Map4d.js.map +1 -1
  323. package/lib/cjs/geometry4d/Matrix4d.js +1 -0
  324. package/lib/cjs/geometry4d/Matrix4d.js.map +1 -1
  325. package/lib/cjs/geometry4d/MomentData.d.ts +72 -73
  326. package/lib/cjs/geometry4d/MomentData.d.ts.map +1 -1
  327. package/lib/cjs/geometry4d/MomentData.js +90 -66
  328. package/lib/cjs/geometry4d/MomentData.js.map +1 -1
  329. package/lib/cjs/geometry4d/PlaneByOriginAndVectors4d.js +6 -0
  330. package/lib/cjs/geometry4d/PlaneByOriginAndVectors4d.js.map +1 -1
  331. package/lib/cjs/geometry4d/Point4d.js +2 -0
  332. package/lib/cjs/geometry4d/Point4d.js.map +1 -1
  333. package/lib/cjs/numerics/BandedSystem.js.map +1 -1
  334. package/lib/cjs/numerics/BezierPolynomials.js +8 -0
  335. package/lib/cjs/numerics/BezierPolynomials.js.map +1 -1
  336. package/lib/cjs/numerics/ClusterableArray.js +29 -13
  337. package/lib/cjs/numerics/ClusterableArray.js.map +1 -1
  338. package/lib/cjs/numerics/Complex.js +2 -0
  339. package/lib/cjs/numerics/Complex.js.map +1 -1
  340. package/lib/cjs/numerics/ConvexPolygon2d.js +3 -0
  341. package/lib/cjs/numerics/ConvexPolygon2d.js.map +1 -1
  342. package/lib/cjs/numerics/Newton.js +59 -4
  343. package/lib/cjs/numerics/Newton.js.map +1 -1
  344. package/lib/cjs/numerics/PascalCoefficients.js +1 -1
  345. package/lib/cjs/numerics/PascalCoefficients.js.map +1 -1
  346. package/lib/cjs/numerics/PolarData.js +13 -1
  347. package/lib/cjs/numerics/PolarData.js.map +1 -1
  348. package/lib/cjs/numerics/Polynomials.js +64 -26
  349. package/lib/cjs/numerics/Polynomials.js.map +1 -1
  350. package/lib/cjs/numerics/Quadrature.js +26 -20
  351. package/lib/cjs/numerics/Quadrature.js.map +1 -1
  352. package/lib/cjs/numerics/Range1dArray.js.map +1 -1
  353. package/lib/cjs/numerics/SmallSystem.js.map +1 -1
  354. package/lib/cjs/numerics/TriDiagonalSystem.js +11 -0
  355. package/lib/cjs/numerics/TriDiagonalSystem.js.map +1 -1
  356. package/lib/cjs/numerics/UnionFind.js +1 -0
  357. package/lib/cjs/numerics/UnionFind.js.map +1 -1
  358. package/lib/cjs/numerics/UsageSums.js +10 -0
  359. package/lib/cjs/numerics/UsageSums.js.map +1 -1
  360. package/lib/cjs/polyface/AuxData.js +16 -0
  361. package/lib/cjs/polyface/AuxData.js.map +1 -1
  362. package/lib/cjs/polyface/BoxTopology.js +67 -67
  363. package/lib/cjs/polyface/BoxTopology.js.map +1 -1
  364. package/lib/cjs/polyface/FacetFaceData.d.ts +1 -1
  365. package/lib/cjs/polyface/FacetFaceData.js +3 -1
  366. package/lib/cjs/polyface/FacetFaceData.js.map +1 -1
  367. package/lib/cjs/polyface/FacetLocationDetail.js +30 -0
  368. package/lib/cjs/polyface/FacetLocationDetail.js.map +1 -1
  369. package/lib/cjs/polyface/FacetOrientation.js +12 -1
  370. package/lib/cjs/polyface/FacetOrientation.js.map +1 -1
  371. package/lib/cjs/polyface/GreedyTriangulationBetweenLineStrings.js +18 -2
  372. package/lib/cjs/polyface/GreedyTriangulationBetweenLineStrings.js.map +1 -1
  373. package/lib/cjs/polyface/IndexedEdgeMatcher.d.ts +33 -23
  374. package/lib/cjs/polyface/IndexedEdgeMatcher.d.ts.map +1 -1
  375. package/lib/cjs/polyface/IndexedEdgeMatcher.js +63 -33
  376. package/lib/cjs/polyface/IndexedEdgeMatcher.js.map +1 -1
  377. package/lib/cjs/polyface/IndexedPolyfaceVisitor.d.ts +4 -3
  378. package/lib/cjs/polyface/IndexedPolyfaceVisitor.d.ts.map +1 -1
  379. package/lib/cjs/polyface/IndexedPolyfaceVisitor.js +16 -5
  380. package/lib/cjs/polyface/IndexedPolyfaceVisitor.js.map +1 -1
  381. package/lib/cjs/polyface/IndexedPolyfaceWalker.d.ts +233 -0
  382. package/lib/cjs/polyface/IndexedPolyfaceWalker.d.ts.map +1 -0
  383. package/lib/cjs/polyface/IndexedPolyfaceWalker.js +353 -0
  384. package/lib/cjs/polyface/IndexedPolyfaceWalker.js.map +1 -0
  385. package/lib/cjs/polyface/Polyface.d.ts +43 -14
  386. package/lib/cjs/polyface/Polyface.d.ts.map +1 -1
  387. package/lib/cjs/polyface/Polyface.js +90 -19
  388. package/lib/cjs/polyface/Polyface.js.map +1 -1
  389. package/lib/cjs/polyface/PolyfaceBuilder.d.ts +14 -27
  390. package/lib/cjs/polyface/PolyfaceBuilder.d.ts.map +1 -1
  391. package/lib/cjs/polyface/PolyfaceBuilder.js +47 -79
  392. package/lib/cjs/polyface/PolyfaceBuilder.js.map +1 -1
  393. package/lib/cjs/polyface/PolyfaceClip.js +8 -0
  394. package/lib/cjs/polyface/PolyfaceClip.js.map +1 -1
  395. package/lib/cjs/polyface/PolyfaceData.d.ts +36 -3
  396. package/lib/cjs/polyface/PolyfaceData.d.ts.map +1 -1
  397. package/lib/cjs/polyface/PolyfaceData.js +114 -8
  398. package/lib/cjs/polyface/PolyfaceData.js.map +1 -1
  399. package/lib/cjs/polyface/PolyfaceQuery.js +47 -7
  400. package/lib/cjs/polyface/PolyfaceQuery.js.map +1 -1
  401. package/lib/cjs/polyface/RangeLengthData.js +7 -0
  402. package/lib/cjs/polyface/RangeLengthData.js.map +1 -1
  403. package/lib/cjs/polyface/RangeTree/LineString3dRangeTreeContext.js +12 -0
  404. package/lib/cjs/polyface/RangeTree/LineString3dRangeTreeContext.js.map +1 -1
  405. package/lib/cjs/polyface/RangeTree/MinimumValueTester.js +5 -2
  406. package/lib/cjs/polyface/RangeTree/MinimumValueTester.js.map +1 -1
  407. package/lib/cjs/polyface/RangeTree/Point3dArrayRangeTreeContext.js +12 -0
  408. package/lib/cjs/polyface/RangeTree/Point3dArrayRangeTreeContext.js.map +1 -1
  409. package/lib/cjs/polyface/RangeTree/PolyfaceRangeTreeContext.js +14 -0
  410. package/lib/cjs/polyface/RangeTree/PolyfaceRangeTreeContext.js.map +1 -1
  411. package/lib/cjs/polyface/RangeTree/RangeTreeNode.js +5 -0
  412. package/lib/cjs/polyface/RangeTree/RangeTreeNode.js.map +1 -1
  413. package/lib/cjs/polyface/RangeTree/RangeTreeSearchHandlers.js +43 -0
  414. package/lib/cjs/polyface/RangeTree/RangeTreeSearchHandlers.js.map +1 -1
  415. package/lib/cjs/polyface/TaggedNumericData.js +8 -0
  416. package/lib/cjs/polyface/TaggedNumericData.js.map +1 -1
  417. package/lib/cjs/polyface/TriangleCandidate.js +3 -0
  418. package/lib/cjs/polyface/TriangleCandidate.js.map +1 -1
  419. package/lib/cjs/polyface/multiclip/BuildAverageNormalsContext.js +7 -0
  420. package/lib/cjs/polyface/multiclip/BuildAverageNormalsContext.js.map +1 -1
  421. package/lib/cjs/polyface/multiclip/GriddedRaggedRange2dSet.js +6 -0
  422. package/lib/cjs/polyface/multiclip/GriddedRaggedRange2dSet.js.map +1 -1
  423. package/lib/cjs/polyface/multiclip/GriddedRaggedRange2dSetWithOverflow.js +3 -0
  424. package/lib/cjs/polyface/multiclip/GriddedRaggedRange2dSetWithOverflow.js.map +1 -1
  425. package/lib/cjs/polyface/multiclip/LinearSearchRange2dArray.js +3 -0
  426. package/lib/cjs/polyface/multiclip/LinearSearchRange2dArray.js.map +1 -1
  427. package/lib/cjs/polyface/multiclip/OffsetMeshContext.js +32 -0
  428. package/lib/cjs/polyface/multiclip/OffsetMeshContext.js.map +1 -1
  429. package/lib/cjs/polyface/multiclip/Range2dSearchInterface.js.map +1 -1
  430. package/lib/cjs/polyface/multiclip/RangeSearch.js +5 -5
  431. package/lib/cjs/polyface/multiclip/RangeSearch.js.map +1 -1
  432. package/lib/cjs/polyface/multiclip/SweepLineStringToFacetContext.js +21 -8
  433. package/lib/cjs/polyface/multiclip/SweepLineStringToFacetContext.js.map +1 -1
  434. package/lib/cjs/polyface/multiclip/XYPointBuckets.js +6 -0
  435. package/lib/cjs/polyface/multiclip/XYPointBuckets.js.map +1 -1
  436. package/lib/cjs/serialization/BGFBAccessors.d.ts +35 -9
  437. package/lib/cjs/serialization/BGFBAccessors.d.ts.map +1 -1
  438. package/lib/cjs/serialization/BGFBAccessors.js +141 -179
  439. package/lib/cjs/serialization/BGFBAccessors.js.map +1 -1
  440. package/lib/cjs/serialization/BGFBReader.d.ts +2 -2
  441. package/lib/cjs/serialization/BGFBReader.d.ts.map +1 -1
  442. package/lib/cjs/serialization/BGFBReader.js +75 -62
  443. package/lib/cjs/serialization/BGFBReader.js.map +1 -1
  444. package/lib/cjs/serialization/BGFBWriter.d.ts +5 -1
  445. package/lib/cjs/serialization/BGFBWriter.d.ts.map +1 -1
  446. package/lib/cjs/serialization/BGFBWriter.js +18 -3
  447. package/lib/cjs/serialization/BGFBWriter.js.map +1 -1
  448. package/lib/cjs/serialization/BentleyGeometryFlatBuffer.js +1 -0
  449. package/lib/cjs/serialization/BentleyGeometryFlatBuffer.js.map +1 -1
  450. package/lib/cjs/serialization/DeepCompare.js +17 -17
  451. package/lib/cjs/serialization/DeepCompare.js.map +1 -1
  452. package/lib/cjs/serialization/GeometrySamples.d.ts +5 -5
  453. package/lib/cjs/serialization/GeometrySamples.d.ts.map +1 -1
  454. package/lib/cjs/serialization/GeometrySamples.js +113 -112
  455. package/lib/cjs/serialization/GeometrySamples.js.map +1 -1
  456. package/lib/cjs/serialization/IModelJsonSchema.d.ts +78 -64
  457. package/lib/cjs/serialization/IModelJsonSchema.d.ts.map +1 -1
  458. package/lib/cjs/serialization/IModelJsonSchema.js +107 -83
  459. package/lib/cjs/serialization/IModelJsonSchema.js.map +1 -1
  460. package/lib/cjs/serialization/SerializationHelpers.d.ts +36 -0
  461. package/lib/cjs/serialization/SerializationHelpers.d.ts.map +1 -1
  462. package/lib/cjs/serialization/SerializationHelpers.js +117 -0
  463. package/lib/cjs/serialization/SerializationHelpers.js.map +1 -1
  464. package/lib/cjs/solid/Box.js +7 -2
  465. package/lib/cjs/solid/Box.js.map +1 -1
  466. package/lib/cjs/solid/Cone.d.ts +39 -14
  467. package/lib/cjs/solid/Cone.d.ts.map +1 -1
  468. package/lib/cjs/solid/Cone.js +52 -16
  469. package/lib/cjs/solid/Cone.js.map +1 -1
  470. package/lib/cjs/solid/LinearSweep.js +4 -2
  471. package/lib/cjs/solid/LinearSweep.js.map +1 -1
  472. package/lib/cjs/solid/RotationalSweep.d.ts +17 -17
  473. package/lib/cjs/solid/RotationalSweep.d.ts.map +1 -1
  474. package/lib/cjs/solid/RotationalSweep.js +38 -25
  475. package/lib/cjs/solid/RotationalSweep.js.map +1 -1
  476. package/lib/cjs/solid/RuledSweep.d.ts +26 -23
  477. package/lib/cjs/solid/RuledSweep.d.ts.map +1 -1
  478. package/lib/cjs/solid/RuledSweep.js +32 -24
  479. package/lib/cjs/solid/RuledSweep.js.map +1 -1
  480. package/lib/cjs/solid/SolidPrimitive.d.ts +12 -11
  481. package/lib/cjs/solid/SolidPrimitive.d.ts.map +1 -1
  482. package/lib/cjs/solid/SolidPrimitive.js +11 -6
  483. package/lib/cjs/solid/SolidPrimitive.js.map +1 -1
  484. package/lib/cjs/solid/Sphere.d.ts +36 -17
  485. package/lib/cjs/solid/Sphere.d.ts.map +1 -1
  486. package/lib/cjs/solid/Sphere.js +53 -24
  487. package/lib/cjs/solid/Sphere.js.map +1 -1
  488. package/lib/cjs/solid/SweepContour.d.ts +24 -15
  489. package/lib/cjs/solid/SweepContour.d.ts.map +1 -1
  490. package/lib/cjs/solid/SweepContour.js +33 -15
  491. package/lib/cjs/solid/SweepContour.js.map +1 -1
  492. package/lib/cjs/solid/TorusPipe.js +7 -2
  493. package/lib/cjs/solid/TorusPipe.js.map +1 -1
  494. package/lib/cjs/topology/ChainMerge.js +16 -4
  495. package/lib/cjs/topology/ChainMerge.js.map +1 -1
  496. package/lib/cjs/topology/Graph.js +41 -6
  497. package/lib/cjs/topology/Graph.js.map +1 -1
  498. package/lib/cjs/topology/HalfEdgeGraphFromIndexedLoopsContext.d.ts +1 -1
  499. package/lib/cjs/topology/HalfEdgeGraphFromIndexedLoopsContext.js +5 -1
  500. package/lib/cjs/topology/HalfEdgeGraphFromIndexedLoopsContext.js.map +1 -1
  501. package/lib/cjs/topology/HalfEdgeGraphSearch.js +2 -0
  502. package/lib/cjs/topology/HalfEdgeGraphSearch.js.map +1 -1
  503. package/lib/cjs/topology/HalfEdgeGraphSpineContext.js +9 -2
  504. package/lib/cjs/topology/HalfEdgeGraphSpineContext.js.map +1 -1
  505. package/lib/cjs/topology/HalfEdgeGraphValidation.js +7 -9
  506. package/lib/cjs/topology/HalfEdgeGraphValidation.js.map +1 -1
  507. package/lib/cjs/topology/HalfEdgeMarkSet.js +5 -0
  508. package/lib/cjs/topology/HalfEdgeMarkSet.js.map +1 -1
  509. package/lib/cjs/topology/HalfEdgeNodeXYZUV.js +6 -0
  510. package/lib/cjs/topology/HalfEdgeNodeXYZUV.js.map +1 -1
  511. package/lib/cjs/topology/HalfEdgePointInGraphSearch.js +1 -0
  512. package/lib/cjs/topology/HalfEdgePointInGraphSearch.js.map +1 -1
  513. package/lib/cjs/topology/HalfEdgePositionDetail.js +16 -0
  514. package/lib/cjs/topology/HalfEdgePositionDetail.js.map +1 -1
  515. package/lib/cjs/topology/HalfEdgePriorityQueue.js +2 -0
  516. package/lib/cjs/topology/HalfEdgePriorityQueue.js.map +1 -1
  517. package/lib/cjs/topology/InsertAndRetriangulateContext.js +4 -0
  518. package/lib/cjs/topology/InsertAndRetriangulateContext.js.map +1 -1
  519. package/lib/cjs/topology/MaskManager.js +3 -0
  520. package/lib/cjs/topology/MaskManager.js.map +1 -1
  521. package/lib/cjs/topology/Merging.js +11 -6
  522. package/lib/cjs/topology/Merging.js.map +1 -1
  523. package/lib/cjs/topology/RegularizeFace.js +22 -0
  524. package/lib/cjs/topology/RegularizeFace.js.map +1 -1
  525. package/lib/cjs/topology/SignedDataSummary.js +22 -0
  526. package/lib/cjs/topology/SignedDataSummary.js.map +1 -1
  527. package/lib/cjs/topology/SpaceTriangulation.js.map +1 -1
  528. package/lib/cjs/topology/Triangulation.d.ts +3 -3
  529. package/lib/cjs/topology/Triangulation.d.ts.map +1 -1
  530. package/lib/cjs/topology/Triangulation.js +28 -18
  531. package/lib/cjs/topology/Triangulation.js.map +1 -1
  532. package/lib/cjs/topology/XYParitySearchContext.js +13 -0
  533. package/lib/cjs/topology/XYParitySearchContext.js.map +1 -1
  534. package/lib/esm/Constant.js +17 -17
  535. package/lib/esm/Constant.js.map +1 -1
  536. package/lib/esm/Geometry.d.ts +13 -4
  537. package/lib/esm/Geometry.d.ts.map +1 -1
  538. package/lib/esm/Geometry.js +51 -39
  539. package/lib/esm/Geometry.js.map +1 -1
  540. package/lib/esm/bspline/AkimaCurve3d.js +3 -1
  541. package/lib/esm/bspline/AkimaCurve3d.js.map +1 -1
  542. package/lib/esm/bspline/BSpline1dNd.d.ts +90 -54
  543. package/lib/esm/bspline/BSpline1dNd.d.ts.map +1 -1
  544. package/lib/esm/bspline/BSpline1dNd.js +137 -84
  545. package/lib/esm/bspline/BSpline1dNd.js.map +1 -1
  546. package/lib/esm/bspline/BSplineCurve.d.ts +193 -155
  547. package/lib/esm/bspline/BSplineCurve.d.ts.map +1 -1
  548. package/lib/esm/bspline/BSplineCurve.js +249 -181
  549. package/lib/esm/bspline/BSplineCurve.js.map +1 -1
  550. package/lib/esm/bspline/BSplineCurve3dH.js +1 -0
  551. package/lib/esm/bspline/BSplineCurve3dH.js.map +1 -1
  552. package/lib/esm/bspline/BSplineCurveOps.d.ts.map +1 -1
  553. package/lib/esm/bspline/BSplineCurveOps.js +18 -21
  554. package/lib/esm/bspline/BSplineCurveOps.js.map +1 -1
  555. package/lib/esm/bspline/BSplineSurface.js +22 -2
  556. package/lib/esm/bspline/BSplineSurface.js.map +1 -1
  557. package/lib/esm/bspline/Bezier1dNd.js +6 -0
  558. package/lib/esm/bspline/Bezier1dNd.js.map +1 -1
  559. package/lib/esm/bspline/BezierCurve3d.d.ts +3 -1
  560. package/lib/esm/bspline/BezierCurve3d.d.ts.map +1 -1
  561. package/lib/esm/bspline/BezierCurve3d.js +5 -5
  562. package/lib/esm/bspline/BezierCurve3d.js.map +1 -1
  563. package/lib/esm/bspline/BezierCurve3dH.js +2 -0
  564. package/lib/esm/bspline/BezierCurve3dH.js.map +1 -1
  565. package/lib/esm/bspline/BezierCurveBase.d.ts.map +1 -1
  566. package/lib/esm/bspline/BezierCurveBase.js +21 -2
  567. package/lib/esm/bspline/BezierCurveBase.js.map +1 -1
  568. package/lib/esm/bspline/InterpolationCurve3d.js +12 -1
  569. package/lib/esm/bspline/InterpolationCurve3d.js.map +1 -1
  570. package/lib/esm/bspline/KnotVector.d.ts +82 -60
  571. package/lib/esm/bspline/KnotVector.d.ts.map +1 -1
  572. package/lib/esm/bspline/KnotVector.js +144 -84
  573. package/lib/esm/bspline/KnotVector.js.map +1 -1
  574. package/lib/esm/bspline/SurfaceLocationDetail.js +12 -0
  575. package/lib/esm/bspline/SurfaceLocationDetail.js.map +1 -1
  576. package/lib/esm/clipping/AlternatingConvexClipTree.js +14 -13
  577. package/lib/esm/clipping/AlternatingConvexClipTree.js.map +1 -1
  578. package/lib/esm/clipping/BooleanClipFactory.js.map +1 -1
  579. package/lib/esm/clipping/BooleanClipNode.js +4 -0
  580. package/lib/esm/clipping/BooleanClipNode.js.map +1 -1
  581. package/lib/esm/clipping/ClipPlane.js +10 -1
  582. package/lib/esm/clipping/ClipPlane.js.map +1 -1
  583. package/lib/esm/clipping/ClipPrimitive.js +19 -0
  584. package/lib/esm/clipping/ClipPrimitive.js.map +1 -1
  585. package/lib/esm/clipping/ClipUtils.js +5 -1
  586. package/lib/esm/clipping/ClipUtils.js.map +1 -1
  587. package/lib/esm/clipping/ClipVector.js +11 -8
  588. package/lib/esm/clipping/ClipVector.js.map +1 -1
  589. package/lib/esm/clipping/ConvexClipPlaneSet.js +5 -3
  590. package/lib/esm/clipping/ConvexClipPlaneSet.js.map +1 -1
  591. package/lib/esm/clipping/UnionOfConvexClipPlaneSets.js +2 -1
  592. package/lib/esm/clipping/UnionOfConvexClipPlaneSets.js.map +1 -1
  593. package/lib/esm/clipping/internalContexts/LineStringOffsetClipperContext.js +3 -0
  594. package/lib/esm/clipping/internalContexts/LineStringOffsetClipperContext.js.map +1 -1
  595. package/lib/esm/core-geometry.d.ts +1 -0
  596. package/lib/esm/core-geometry.d.ts.map +1 -1
  597. package/lib/esm/core-geometry.js +1 -0
  598. package/lib/esm/core-geometry.js.map +1 -1
  599. package/lib/esm/curve/Arc3d.d.ts +20 -4
  600. package/lib/esm/curve/Arc3d.d.ts.map +1 -1
  601. package/lib/esm/curve/Arc3d.js +86 -21
  602. package/lib/esm/curve/Arc3d.js.map +1 -1
  603. package/lib/esm/curve/ConstructCurveBetweenCurves.js +3 -0
  604. package/lib/esm/curve/ConstructCurveBetweenCurves.js.map +1 -1
  605. package/lib/esm/curve/CoordinateXYZ.js +3 -2
  606. package/lib/esm/curve/CoordinateXYZ.js.map +1 -1
  607. package/lib/esm/curve/CurveChainWithDistanceIndex.d.ts +0 -2
  608. package/lib/esm/curve/CurveChainWithDistanceIndex.d.ts.map +1 -1
  609. package/lib/esm/curve/CurveChainWithDistanceIndex.js +25 -10
  610. package/lib/esm/curve/CurveChainWithDistanceIndex.js.map +1 -1
  611. package/lib/esm/curve/CurveCollection.d.ts +10 -0
  612. package/lib/esm/curve/CurveCollection.d.ts.map +1 -1
  613. package/lib/esm/curve/CurveCollection.js +35 -9
  614. package/lib/esm/curve/CurveCollection.js.map +1 -1
  615. package/lib/esm/curve/CurveCurve.js.map +1 -1
  616. package/lib/esm/curve/CurveExtendMode.d.ts +13 -5
  617. package/lib/esm/curve/CurveExtendMode.d.ts.map +1 -1
  618. package/lib/esm/curve/CurveExtendMode.js +19 -15
  619. package/lib/esm/curve/CurveExtendMode.js.map +1 -1
  620. package/lib/esm/curve/CurveFactory.d.ts +87 -53
  621. package/lib/esm/curve/CurveFactory.d.ts.map +1 -1
  622. package/lib/esm/curve/CurveFactory.js +213 -135
  623. package/lib/esm/curve/CurveFactory.js.map +1 -1
  624. package/lib/esm/curve/CurveLocationDetail.js +44 -0
  625. package/lib/esm/curve/CurveLocationDetail.js.map +1 -1
  626. package/lib/esm/curve/CurveOps.js.map +1 -1
  627. package/lib/esm/curve/CurvePrimitive.d.ts +74 -18
  628. package/lib/esm/curve/CurvePrimitive.d.ts.map +1 -1
  629. package/lib/esm/curve/CurvePrimitive.js +86 -18
  630. package/lib/esm/curve/CurvePrimitive.js.map +1 -1
  631. package/lib/esm/curve/CurveProcessor.js +2 -0
  632. package/lib/esm/curve/CurveProcessor.js.map +1 -1
  633. package/lib/esm/curve/CurveTypes.js.map +1 -1
  634. package/lib/esm/curve/CurveWireMomentsXYZ.js +2 -0
  635. package/lib/esm/curve/CurveWireMomentsXYZ.js.map +1 -1
  636. package/lib/esm/curve/GeometryQuery.js.map +1 -1
  637. package/lib/esm/curve/LineSegment3d.js +6 -2
  638. package/lib/esm/curve/LineSegment3d.js.map +1 -1
  639. package/lib/esm/curve/LineString3d.d.ts +8 -7
  640. package/lib/esm/curve/LineString3d.d.ts.map +1 -1
  641. package/lib/esm/curve/LineString3d.js +52 -29
  642. package/lib/esm/curve/LineString3d.js.map +1 -1
  643. package/lib/esm/curve/Loop.js +12 -4
  644. package/lib/esm/curve/Loop.js.map +1 -1
  645. package/lib/esm/curve/OffsetOptions.js +25 -21
  646. package/lib/esm/curve/OffsetOptions.js.map +1 -1
  647. package/lib/esm/curve/ParityRegion.js +4 -2
  648. package/lib/esm/curve/ParityRegion.js.map +1 -1
  649. package/lib/esm/curve/Path.js +2 -2
  650. package/lib/esm/curve/Path.js.map +1 -1
  651. package/lib/esm/curve/PointString3d.js +3 -2
  652. package/lib/esm/curve/PointString3d.js.map +1 -1
  653. package/lib/esm/curve/ProxyCurve.js +1 -0
  654. package/lib/esm/curve/ProxyCurve.js.map +1 -1
  655. package/lib/esm/curve/Query/ConsolidateAdjacentPrimitivesContext.js +1 -0
  656. package/lib/esm/curve/Query/ConsolidateAdjacentPrimitivesContext.js.map +1 -1
  657. package/lib/esm/curve/Query/CurveSplitContext.js +3 -0
  658. package/lib/esm/curve/Query/CurveSplitContext.js.map +1 -1
  659. package/lib/esm/curve/Query/CylindricalRange.js +6 -2
  660. package/lib/esm/curve/Query/CylindricalRange.js.map +1 -1
  661. package/lib/esm/curve/Query/InOutTests.js.map +1 -1
  662. package/lib/esm/curve/Query/PlanarSubdivision.js +4 -6
  663. package/lib/esm/curve/Query/PlanarSubdivision.js.map +1 -1
  664. package/lib/esm/curve/Query/StrokeCountChain.js +12 -0
  665. package/lib/esm/curve/Query/StrokeCountChain.js.map +1 -1
  666. package/lib/esm/curve/Query/StrokeCountMap.js +14 -0
  667. package/lib/esm/curve/Query/StrokeCountMap.js.map +1 -1
  668. package/lib/esm/curve/RegionMomentsXY.js +4 -5
  669. package/lib/esm/curve/RegionMomentsXY.js.map +1 -1
  670. package/lib/esm/curve/RegionOps.js +9 -10
  671. package/lib/esm/curve/RegionOps.js.map +1 -1
  672. package/lib/esm/curve/RegionOpsClassificationSweeps.js +24 -1
  673. package/lib/esm/curve/RegionOpsClassificationSweeps.js.map +1 -1
  674. package/lib/esm/curve/StrokeOptions.d.ts +10 -5
  675. package/lib/esm/curve/StrokeOptions.d.ts.map +1 -1
  676. package/lib/esm/curve/StrokeOptions.js +30 -8
  677. package/lib/esm/curve/StrokeOptions.js.map +1 -1
  678. package/lib/esm/curve/UnionRegion.js +4 -2
  679. package/lib/esm/curve/UnionRegion.js.map +1 -1
  680. package/lib/esm/curve/internalContexts/AnnounceTangentStrokeHandler.d.ts +71 -0
  681. package/lib/esm/curve/internalContexts/AnnounceTangentStrokeHandler.d.ts.map +1 -0
  682. package/lib/esm/curve/internalContexts/AnnounceTangentStrokeHandler.js +177 -0
  683. package/lib/esm/curve/internalContexts/AnnounceTangentStrokeHandler.js.map +1 -0
  684. package/lib/esm/curve/internalContexts/AppendPlaneIntersectionStrokeHandler.js +13 -7
  685. package/lib/esm/curve/internalContexts/AppendPlaneIntersectionStrokeHandler.js.map +1 -1
  686. package/lib/esm/curve/internalContexts/ChainCollectorContext.js +6 -0
  687. package/lib/esm/curve/internalContexts/ChainCollectorContext.js.map +1 -1
  688. package/lib/esm/curve/internalContexts/CloneCurvesContext.js +2 -0
  689. package/lib/esm/curve/internalContexts/CloneCurvesContext.js.map +1 -1
  690. package/lib/esm/curve/internalContexts/CloneWithExpandedLineStrings.js.map +1 -1
  691. package/lib/esm/curve/internalContexts/ClosestPointStrokeHandler.d.ts +21 -5
  692. package/lib/esm/curve/internalContexts/ClosestPointStrokeHandler.d.ts.map +1 -1
  693. package/lib/esm/curve/internalContexts/ClosestPointStrokeHandler.js +53 -20
  694. package/lib/esm/curve/internalContexts/ClosestPointStrokeHandler.js.map +1 -1
  695. package/lib/esm/curve/internalContexts/CountLinearPartsSearchContext.js +3 -0
  696. package/lib/esm/curve/internalContexts/CountLinearPartsSearchContext.js.map +1 -1
  697. package/lib/esm/curve/internalContexts/CurveCurveCloseApproachXY.js +18 -5
  698. package/lib/esm/curve/internalContexts/CurveCurveCloseApproachXY.js.map +1 -1
  699. package/lib/esm/curve/internalContexts/CurveCurveIntersectXY.js +26 -13
  700. package/lib/esm/curve/internalContexts/CurveCurveIntersectXY.js.map +1 -1
  701. package/lib/esm/curve/internalContexts/CurveCurveIntersectXYZ.js +11 -5
  702. package/lib/esm/curve/internalContexts/CurveCurveIntersectXYZ.js.map +1 -1
  703. package/lib/esm/curve/internalContexts/CurveLengthContext.js +6 -0
  704. package/lib/esm/curve/internalContexts/CurveLengthContext.js.map +1 -1
  705. package/lib/esm/curve/internalContexts/CurveOffsetXYHandler.js +8 -6
  706. package/lib/esm/curve/internalContexts/CurveOffsetXYHandler.js.map +1 -1
  707. package/lib/esm/curve/internalContexts/EllipticalArcApproximationContext.js +38 -5
  708. package/lib/esm/curve/internalContexts/EllipticalArcApproximationContext.js.map +1 -1
  709. package/lib/esm/curve/internalContexts/GapSearchContext.js +1 -0
  710. package/lib/esm/curve/internalContexts/GapSearchContext.js.map +1 -1
  711. package/lib/esm/curve/internalContexts/MultiChainCollector.js +12 -0
  712. package/lib/esm/curve/internalContexts/MultiChainCollector.js.map +1 -1
  713. package/lib/esm/curve/internalContexts/NewtonRtoRStrokeHandler.d.ts +5 -3
  714. package/lib/esm/curve/internalContexts/NewtonRtoRStrokeHandler.d.ts.map +1 -1
  715. package/lib/esm/curve/internalContexts/NewtonRtoRStrokeHandler.js +6 -3
  716. package/lib/esm/curve/internalContexts/NewtonRtoRStrokeHandler.js.map +1 -1
  717. package/lib/esm/curve/internalContexts/PlaneAltitudeRangeContext.js +7 -0
  718. package/lib/esm/curve/internalContexts/PlaneAltitudeRangeContext.js.map +1 -1
  719. package/lib/esm/curve/internalContexts/PolygonOffsetContext.js +22 -4
  720. package/lib/esm/curve/internalContexts/PolygonOffsetContext.js.map +1 -1
  721. package/lib/esm/curve/internalContexts/SumLengthsContext.js +1 -0
  722. package/lib/esm/curve/internalContexts/SumLengthsContext.js.map +1 -1
  723. package/lib/esm/curve/internalContexts/TransformInPlaceContext.js +3 -0
  724. package/lib/esm/curve/internalContexts/TransformInPlaceContext.js.map +1 -1
  725. package/lib/esm/curve/spiral/AustralianRailCorpXYEvaluator.js +2 -0
  726. package/lib/esm/curve/spiral/AustralianRailCorpXYEvaluator.js.map +1 -1
  727. package/lib/esm/curve/spiral/ClothoidSeries.js +4 -0
  728. package/lib/esm/curve/spiral/ClothoidSeries.js.map +1 -1
  729. package/lib/esm/curve/spiral/CubicEvaluator.js +2 -0
  730. package/lib/esm/curve/spiral/CubicEvaluator.js.map +1 -1
  731. package/lib/esm/curve/spiral/CzechSpiralEvaluator.js +4 -0
  732. package/lib/esm/curve/spiral/CzechSpiralEvaluator.js.map +1 -1
  733. package/lib/esm/curve/spiral/DirectHalfCosineSpiralEvaluator.js +5 -0
  734. package/lib/esm/curve/spiral/DirectHalfCosineSpiralEvaluator.js.map +1 -1
  735. package/lib/esm/curve/spiral/DirectSpiral3d.js +12 -2
  736. package/lib/esm/curve/spiral/DirectSpiral3d.js.map +1 -1
  737. package/lib/esm/curve/spiral/IntegratedSpiral3d.js +24 -4
  738. package/lib/esm/curve/spiral/IntegratedSpiral3d.js.map +1 -1
  739. package/lib/esm/curve/spiral/MXCubicAlongArcSpiralEvaluator.js +2 -0
  740. package/lib/esm/curve/spiral/MXCubicAlongArcSpiralEvaluator.js.map +1 -1
  741. package/lib/esm/curve/spiral/NormalizedTransition.js +5 -0
  742. package/lib/esm/curve/spiral/NormalizedTransition.js.map +1 -1
  743. package/lib/esm/curve/spiral/PolishCubicSpiralEvaluator.js +2 -0
  744. package/lib/esm/curve/spiral/PolishCubicSpiralEvaluator.js.map +1 -1
  745. package/lib/esm/curve/spiral/TransitionConditionalProperties.js +10 -0
  746. package/lib/esm/curve/spiral/TransitionConditionalProperties.js.map +1 -1
  747. package/lib/esm/curve/spiral/TransitionSpiral3d.js +10 -0
  748. package/lib/esm/curve/spiral/TransitionSpiral3d.js.map +1 -1
  749. package/lib/esm/curve/spiral/XYCurveEvaluator.js +6 -0
  750. package/lib/esm/curve/spiral/XYCurveEvaluator.js.map +1 -1
  751. package/lib/esm/geometry3d/Angle.js +18 -16
  752. package/lib/esm/geometry3d/Angle.js.map +1 -1
  753. package/lib/esm/geometry3d/AngleSweep.d.ts +8 -3
  754. package/lib/esm/geometry3d/AngleSweep.d.ts.map +1 -1
  755. package/lib/esm/geometry3d/AngleSweep.js +22 -10
  756. package/lib/esm/geometry3d/AngleSweep.js.map +1 -1
  757. package/lib/esm/geometry3d/BarycentricTriangle.js +25 -0
  758. package/lib/esm/geometry3d/BarycentricTriangle.js.map +1 -1
  759. package/lib/esm/geometry3d/BilinearPatch.js +8 -0
  760. package/lib/esm/geometry3d/BilinearPatch.js.map +1 -1
  761. package/lib/esm/geometry3d/CoincidentGeometryOps.js +5 -0
  762. package/lib/esm/geometry3d/CoincidentGeometryOps.js.map +1 -1
  763. package/lib/esm/geometry3d/Ellipsoid.d.ts +8 -7
  764. package/lib/esm/geometry3d/Ellipsoid.d.ts.map +1 -1
  765. package/lib/esm/geometry3d/Ellipsoid.js +63 -14
  766. package/lib/esm/geometry3d/Ellipsoid.js.map +1 -1
  767. package/lib/esm/geometry3d/FrameBuilder.js +12 -4
  768. package/lib/esm/geometry3d/FrameBuilder.js.map +1 -1
  769. package/lib/esm/geometry3d/FrustumAnimation.js +7 -0
  770. package/lib/esm/geometry3d/FrustumAnimation.js.map +1 -1
  771. package/lib/esm/geometry3d/GeometryHandler.d.ts +15 -16
  772. package/lib/esm/geometry3d/GeometryHandler.d.ts.map +1 -1
  773. package/lib/esm/geometry3d/GeometryHandler.js.map +1 -1
  774. package/lib/esm/geometry3d/GrowableBlockedArray.js +12 -0
  775. package/lib/esm/geometry3d/GrowableBlockedArray.js.map +1 -1
  776. package/lib/esm/geometry3d/GrowableFloat64Array.js +3 -0
  777. package/lib/esm/geometry3d/GrowableFloat64Array.js.map +1 -1
  778. package/lib/esm/geometry3d/GrowableXYArray.d.ts +0 -5
  779. package/lib/esm/geometry3d/GrowableXYArray.d.ts.map +1 -1
  780. package/lib/esm/geometry3d/GrowableXYArray.js +16 -7
  781. package/lib/esm/geometry3d/GrowableXYArray.js.map +1 -1
  782. package/lib/esm/geometry3d/GrowableXYZArray.d.ts +32 -10
  783. package/lib/esm/geometry3d/GrowableXYZArray.d.ts.map +1 -1
  784. package/lib/esm/geometry3d/GrowableXYZArray.js +70 -16
  785. package/lib/esm/geometry3d/GrowableXYZArray.js.map +1 -1
  786. package/lib/esm/geometry3d/IndexedCollectionInterval.js +6 -0
  787. package/lib/esm/geometry3d/IndexedCollectionInterval.js.map +1 -1
  788. package/lib/esm/geometry3d/IndexedXYCollection.js +1 -0
  789. package/lib/esm/geometry3d/IndexedXYCollection.js.map +1 -1
  790. package/lib/esm/geometry3d/IndexedXYZCollection.d.ts +13 -2
  791. package/lib/esm/geometry3d/IndexedXYZCollection.d.ts.map +1 -1
  792. package/lib/esm/geometry3d/IndexedXYZCollection.js +26 -11
  793. package/lib/esm/geometry3d/IndexedXYZCollection.js.map +1 -1
  794. package/lib/esm/geometry3d/LongitudeLatitudeAltitude.js +3 -0
  795. package/lib/esm/geometry3d/LongitudeLatitudeAltitude.js.map +1 -1
  796. package/lib/esm/geometry3d/Matrix3d.d.ts +13 -15
  797. package/lib/esm/geometry3d/Matrix3d.d.ts.map +1 -1
  798. package/lib/esm/geometry3d/Matrix3d.js +47 -26
  799. package/lib/esm/geometry3d/Matrix3d.js.map +1 -1
  800. package/lib/esm/geometry3d/OrderedRotationAngles.js +10 -2
  801. package/lib/esm/geometry3d/OrderedRotationAngles.js.map +1 -1
  802. package/lib/esm/geometry3d/Plane3d.js.map +1 -1
  803. package/lib/esm/geometry3d/Plane3dByOriginAndUnitNormal.js +2 -0
  804. package/lib/esm/geometry3d/Plane3dByOriginAndUnitNormal.js.map +1 -1
  805. package/lib/esm/geometry3d/Plane3dByOriginAndVectors.js +7 -0
  806. package/lib/esm/geometry3d/Plane3dByOriginAndVectors.js.map +1 -1
  807. package/lib/esm/geometry3d/Point2dArrayCarrier.js +2 -0
  808. package/lib/esm/geometry3d/Point2dArrayCarrier.js.map +1 -1
  809. package/lib/esm/geometry3d/Point2dVector2d.js +4 -0
  810. package/lib/esm/geometry3d/Point2dVector2d.js.map +1 -1
  811. package/lib/esm/geometry3d/Point3dArrayCarrier.js +3 -1
  812. package/lib/esm/geometry3d/Point3dArrayCarrier.js.map +1 -1
  813. package/lib/esm/geometry3d/Point3dVector3d.d.ts +7 -10
  814. package/lib/esm/geometry3d/Point3dVector3d.d.ts.map +1 -1
  815. package/lib/esm/geometry3d/Point3dVector3d.js +16 -10
  816. package/lib/esm/geometry3d/Point3dVector3d.js.map +1 -1
  817. package/lib/esm/geometry3d/PointHelpers.d.ts +15 -4
  818. package/lib/esm/geometry3d/PointHelpers.d.ts.map +1 -1
  819. package/lib/esm/geometry3d/PointHelpers.js +29 -8
  820. package/lib/esm/geometry3d/PointHelpers.js.map +1 -1
  821. package/lib/esm/geometry3d/PointStreaming.js +12 -4
  822. package/lib/esm/geometry3d/PointStreaming.js.map +1 -1
  823. package/lib/esm/geometry3d/PolygonOps.d.ts +2 -2
  824. package/lib/esm/geometry3d/PolygonOps.js +62 -25
  825. package/lib/esm/geometry3d/PolygonOps.js.map +1 -1
  826. package/lib/esm/geometry3d/PolylineCompressionByEdgeOffset.js +7 -3
  827. package/lib/esm/geometry3d/PolylineCompressionByEdgeOffset.js.map +1 -1
  828. package/lib/esm/geometry3d/PolylineOps.d.ts +9 -5
  829. package/lib/esm/geometry3d/PolylineOps.d.ts.map +1 -1
  830. package/lib/esm/geometry3d/PolylineOps.js +12 -5
  831. package/lib/esm/geometry3d/PolylineOps.js.map +1 -1
  832. package/lib/esm/geometry3d/Range.js +21 -4
  833. package/lib/esm/geometry3d/Range.js.map +1 -1
  834. package/lib/esm/geometry3d/Ray2d.js +2 -0
  835. package/lib/esm/geometry3d/Ray2d.js.map +1 -1
  836. package/lib/esm/geometry3d/Ray3d.d.ts +2 -2
  837. package/lib/esm/geometry3d/Ray3d.d.ts.map +1 -1
  838. package/lib/esm/geometry3d/Ray3d.js +20 -11
  839. package/lib/esm/geometry3d/Ray3d.js.map +1 -1
  840. package/lib/esm/geometry3d/ReusableObjectCache.js +4 -0
  841. package/lib/esm/geometry3d/ReusableObjectCache.js.map +1 -1
  842. package/lib/esm/geometry3d/Segment1d.js +4 -0
  843. package/lib/esm/geometry3d/Segment1d.js.map +1 -1
  844. package/lib/esm/geometry3d/SortablePolygon.js +11 -0
  845. package/lib/esm/geometry3d/SortablePolygon.js.map +1 -1
  846. package/lib/esm/geometry3d/Transform.d.ts +1 -1
  847. package/lib/esm/geometry3d/Transform.js +4 -1
  848. package/lib/esm/geometry3d/Transform.js.map +1 -1
  849. package/lib/esm/geometry3d/UVSurfaceOps.js.map +1 -1
  850. package/lib/esm/geometry3d/XYZProps.js.map +1 -1
  851. package/lib/esm/geometry3d/YawPitchRollAngles.js +6 -0
  852. package/lib/esm/geometry3d/YawPitchRollAngles.js.map +1 -1
  853. package/lib/esm/geometry4d/Map4d.js +2 -0
  854. package/lib/esm/geometry4d/Map4d.js.map +1 -1
  855. package/lib/esm/geometry4d/Matrix4d.js +1 -0
  856. package/lib/esm/geometry4d/Matrix4d.js.map +1 -1
  857. package/lib/esm/geometry4d/MomentData.d.ts +72 -73
  858. package/lib/esm/geometry4d/MomentData.d.ts.map +1 -1
  859. package/lib/esm/geometry4d/MomentData.js +90 -66
  860. package/lib/esm/geometry4d/MomentData.js.map +1 -1
  861. package/lib/esm/geometry4d/PlaneByOriginAndVectors4d.js +6 -0
  862. package/lib/esm/geometry4d/PlaneByOriginAndVectors4d.js.map +1 -1
  863. package/lib/esm/geometry4d/Point4d.js +2 -0
  864. package/lib/esm/geometry4d/Point4d.js.map +1 -1
  865. package/lib/esm/numerics/BandedSystem.js.map +1 -1
  866. package/lib/esm/numerics/BezierPolynomials.js +8 -0
  867. package/lib/esm/numerics/BezierPolynomials.js.map +1 -1
  868. package/lib/esm/numerics/ClusterableArray.js +29 -13
  869. package/lib/esm/numerics/ClusterableArray.js.map +1 -1
  870. package/lib/esm/numerics/Complex.js +2 -0
  871. package/lib/esm/numerics/Complex.js.map +1 -1
  872. package/lib/esm/numerics/ConvexPolygon2d.js +3 -0
  873. package/lib/esm/numerics/ConvexPolygon2d.js.map +1 -1
  874. package/lib/esm/numerics/Newton.js +59 -4
  875. package/lib/esm/numerics/Newton.js.map +1 -1
  876. package/lib/esm/numerics/PascalCoefficients.js +1 -1
  877. package/lib/esm/numerics/PascalCoefficients.js.map +1 -1
  878. package/lib/esm/numerics/PolarData.js +13 -1
  879. package/lib/esm/numerics/PolarData.js.map +1 -1
  880. package/lib/esm/numerics/Polynomials.js +64 -26
  881. package/lib/esm/numerics/Polynomials.js.map +1 -1
  882. package/lib/esm/numerics/Quadrature.js +26 -20
  883. package/lib/esm/numerics/Quadrature.js.map +1 -1
  884. package/lib/esm/numerics/Range1dArray.js.map +1 -1
  885. package/lib/esm/numerics/SmallSystem.js.map +1 -1
  886. package/lib/esm/numerics/TriDiagonalSystem.js +11 -0
  887. package/lib/esm/numerics/TriDiagonalSystem.js.map +1 -1
  888. package/lib/esm/numerics/UnionFind.js +1 -0
  889. package/lib/esm/numerics/UnionFind.js.map +1 -1
  890. package/lib/esm/numerics/UsageSums.js +10 -0
  891. package/lib/esm/numerics/UsageSums.js.map +1 -1
  892. package/lib/esm/polyface/AuxData.js +16 -0
  893. package/lib/esm/polyface/AuxData.js.map +1 -1
  894. package/lib/esm/polyface/BoxTopology.js +67 -67
  895. package/lib/esm/polyface/BoxTopology.js.map +1 -1
  896. package/lib/esm/polyface/FacetFaceData.d.ts +1 -1
  897. package/lib/esm/polyface/FacetFaceData.js +3 -1
  898. package/lib/esm/polyface/FacetFaceData.js.map +1 -1
  899. package/lib/esm/polyface/FacetLocationDetail.js +30 -0
  900. package/lib/esm/polyface/FacetLocationDetail.js.map +1 -1
  901. package/lib/esm/polyface/FacetOrientation.js +12 -1
  902. package/lib/esm/polyface/FacetOrientation.js.map +1 -1
  903. package/lib/esm/polyface/GreedyTriangulationBetweenLineStrings.js +18 -2
  904. package/lib/esm/polyface/GreedyTriangulationBetweenLineStrings.js.map +1 -1
  905. package/lib/esm/polyface/IndexedEdgeMatcher.d.ts +33 -23
  906. package/lib/esm/polyface/IndexedEdgeMatcher.d.ts.map +1 -1
  907. package/lib/esm/polyface/IndexedEdgeMatcher.js +63 -33
  908. package/lib/esm/polyface/IndexedEdgeMatcher.js.map +1 -1
  909. package/lib/esm/polyface/IndexedPolyfaceVisitor.d.ts +4 -3
  910. package/lib/esm/polyface/IndexedPolyfaceVisitor.d.ts.map +1 -1
  911. package/lib/esm/polyface/IndexedPolyfaceVisitor.js +16 -5
  912. package/lib/esm/polyface/IndexedPolyfaceVisitor.js.map +1 -1
  913. package/lib/esm/polyface/IndexedPolyfaceWalker.d.ts +233 -0
  914. package/lib/esm/polyface/IndexedPolyfaceWalker.d.ts.map +1 -0
  915. package/lib/esm/polyface/IndexedPolyfaceWalker.js +349 -0
  916. package/lib/esm/polyface/IndexedPolyfaceWalker.js.map +1 -0
  917. package/lib/esm/polyface/Polyface.d.ts +43 -14
  918. package/lib/esm/polyface/Polyface.d.ts.map +1 -1
  919. package/lib/esm/polyface/Polyface.js +90 -19
  920. package/lib/esm/polyface/Polyface.js.map +1 -1
  921. package/lib/esm/polyface/PolyfaceBuilder.d.ts +14 -27
  922. package/lib/esm/polyface/PolyfaceBuilder.d.ts.map +1 -1
  923. package/lib/esm/polyface/PolyfaceBuilder.js +48 -80
  924. package/lib/esm/polyface/PolyfaceBuilder.js.map +1 -1
  925. package/lib/esm/polyface/PolyfaceClip.js +8 -0
  926. package/lib/esm/polyface/PolyfaceClip.js.map +1 -1
  927. package/lib/esm/polyface/PolyfaceData.d.ts +36 -3
  928. package/lib/esm/polyface/PolyfaceData.d.ts.map +1 -1
  929. package/lib/esm/polyface/PolyfaceData.js +114 -8
  930. package/lib/esm/polyface/PolyfaceData.js.map +1 -1
  931. package/lib/esm/polyface/PolyfaceQuery.js +47 -7
  932. package/lib/esm/polyface/PolyfaceQuery.js.map +1 -1
  933. package/lib/esm/polyface/RangeLengthData.js +7 -0
  934. package/lib/esm/polyface/RangeLengthData.js.map +1 -1
  935. package/lib/esm/polyface/RangeTree/LineString3dRangeTreeContext.js +12 -0
  936. package/lib/esm/polyface/RangeTree/LineString3dRangeTreeContext.js.map +1 -1
  937. package/lib/esm/polyface/RangeTree/MinimumValueTester.js +5 -2
  938. package/lib/esm/polyface/RangeTree/MinimumValueTester.js.map +1 -1
  939. package/lib/esm/polyface/RangeTree/Point3dArrayRangeTreeContext.js +12 -0
  940. package/lib/esm/polyface/RangeTree/Point3dArrayRangeTreeContext.js.map +1 -1
  941. package/lib/esm/polyface/RangeTree/PolyfaceRangeTreeContext.js +14 -0
  942. package/lib/esm/polyface/RangeTree/PolyfaceRangeTreeContext.js.map +1 -1
  943. package/lib/esm/polyface/RangeTree/RangeTreeNode.js +5 -0
  944. package/lib/esm/polyface/RangeTree/RangeTreeNode.js.map +1 -1
  945. package/lib/esm/polyface/RangeTree/RangeTreeSearchHandlers.js +43 -0
  946. package/lib/esm/polyface/RangeTree/RangeTreeSearchHandlers.js.map +1 -1
  947. package/lib/esm/polyface/TaggedNumericData.js +8 -0
  948. package/lib/esm/polyface/TaggedNumericData.js.map +1 -1
  949. package/lib/esm/polyface/TriangleCandidate.js +3 -0
  950. package/lib/esm/polyface/TriangleCandidate.js.map +1 -1
  951. package/lib/esm/polyface/multiclip/BuildAverageNormalsContext.js +7 -0
  952. package/lib/esm/polyface/multiclip/BuildAverageNormalsContext.js.map +1 -1
  953. package/lib/esm/polyface/multiclip/GriddedRaggedRange2dSet.js +6 -0
  954. package/lib/esm/polyface/multiclip/GriddedRaggedRange2dSet.js.map +1 -1
  955. package/lib/esm/polyface/multiclip/GriddedRaggedRange2dSetWithOverflow.js +3 -0
  956. package/lib/esm/polyface/multiclip/GriddedRaggedRange2dSetWithOverflow.js.map +1 -1
  957. package/lib/esm/polyface/multiclip/LinearSearchRange2dArray.js +3 -0
  958. package/lib/esm/polyface/multiclip/LinearSearchRange2dArray.js.map +1 -1
  959. package/lib/esm/polyface/multiclip/OffsetMeshContext.js +32 -0
  960. package/lib/esm/polyface/multiclip/OffsetMeshContext.js.map +1 -1
  961. package/lib/esm/polyface/multiclip/Range2dSearchInterface.js.map +1 -1
  962. package/lib/esm/polyface/multiclip/RangeSearch.js +5 -5
  963. package/lib/esm/polyface/multiclip/RangeSearch.js.map +1 -1
  964. package/lib/esm/polyface/multiclip/SweepLineStringToFacetContext.js +21 -8
  965. package/lib/esm/polyface/multiclip/SweepLineStringToFacetContext.js.map +1 -1
  966. package/lib/esm/polyface/multiclip/XYPointBuckets.js +6 -0
  967. package/lib/esm/polyface/multiclip/XYPointBuckets.js.map +1 -1
  968. package/lib/esm/serialization/BGFBAccessors.d.ts +35 -9
  969. package/lib/esm/serialization/BGFBAccessors.d.ts.map +1 -1
  970. package/lib/esm/serialization/BGFBAccessors.js +141 -179
  971. package/lib/esm/serialization/BGFBAccessors.js.map +1 -1
  972. package/lib/esm/serialization/BGFBReader.d.ts +2 -2
  973. package/lib/esm/serialization/BGFBReader.d.ts.map +1 -1
  974. package/lib/esm/serialization/BGFBReader.js +75 -62
  975. package/lib/esm/serialization/BGFBReader.js.map +1 -1
  976. package/lib/esm/serialization/BGFBWriter.d.ts +5 -1
  977. package/lib/esm/serialization/BGFBWriter.d.ts.map +1 -1
  978. package/lib/esm/serialization/BGFBWriter.js +18 -3
  979. package/lib/esm/serialization/BGFBWriter.js.map +1 -1
  980. package/lib/esm/serialization/BentleyGeometryFlatBuffer.js +1 -0
  981. package/lib/esm/serialization/BentleyGeometryFlatBuffer.js.map +1 -1
  982. package/lib/esm/serialization/DeepCompare.js +17 -17
  983. package/lib/esm/serialization/DeepCompare.js.map +1 -1
  984. package/lib/esm/serialization/GeometrySamples.d.ts +5 -5
  985. package/lib/esm/serialization/GeometrySamples.d.ts.map +1 -1
  986. package/lib/esm/serialization/GeometrySamples.js +113 -112
  987. package/lib/esm/serialization/GeometrySamples.js.map +1 -1
  988. package/lib/esm/serialization/IModelJsonSchema.d.ts +78 -64
  989. package/lib/esm/serialization/IModelJsonSchema.d.ts.map +1 -1
  990. package/lib/esm/serialization/IModelJsonSchema.js +107 -83
  991. package/lib/esm/serialization/IModelJsonSchema.js.map +1 -1
  992. package/lib/esm/serialization/SerializationHelpers.d.ts +36 -0
  993. package/lib/esm/serialization/SerializationHelpers.d.ts.map +1 -1
  994. package/lib/esm/serialization/SerializationHelpers.js +117 -0
  995. package/lib/esm/serialization/SerializationHelpers.js.map +1 -1
  996. package/lib/esm/solid/Box.js +7 -2
  997. package/lib/esm/solid/Box.js.map +1 -1
  998. package/lib/esm/solid/Cone.d.ts +39 -14
  999. package/lib/esm/solid/Cone.d.ts.map +1 -1
  1000. package/lib/esm/solid/Cone.js +53 -17
  1001. package/lib/esm/solid/Cone.js.map +1 -1
  1002. package/lib/esm/solid/LinearSweep.js +4 -2
  1003. package/lib/esm/solid/LinearSweep.js.map +1 -1
  1004. package/lib/esm/solid/RotationalSweep.d.ts +17 -17
  1005. package/lib/esm/solid/RotationalSweep.d.ts.map +1 -1
  1006. package/lib/esm/solid/RotationalSweep.js +38 -25
  1007. package/lib/esm/solid/RotationalSweep.js.map +1 -1
  1008. package/lib/esm/solid/RuledSweep.d.ts +26 -23
  1009. package/lib/esm/solid/RuledSweep.d.ts.map +1 -1
  1010. package/lib/esm/solid/RuledSweep.js +32 -24
  1011. package/lib/esm/solid/RuledSweep.js.map +1 -1
  1012. package/lib/esm/solid/SolidPrimitive.d.ts +12 -11
  1013. package/lib/esm/solid/SolidPrimitive.d.ts.map +1 -1
  1014. package/lib/esm/solid/SolidPrimitive.js +11 -6
  1015. package/lib/esm/solid/SolidPrimitive.js.map +1 -1
  1016. package/lib/esm/solid/Sphere.d.ts +36 -17
  1017. package/lib/esm/solid/Sphere.d.ts.map +1 -1
  1018. package/lib/esm/solid/Sphere.js +54 -25
  1019. package/lib/esm/solid/Sphere.js.map +1 -1
  1020. package/lib/esm/solid/SweepContour.d.ts +24 -15
  1021. package/lib/esm/solid/SweepContour.d.ts.map +1 -1
  1022. package/lib/esm/solid/SweepContour.js +33 -15
  1023. package/lib/esm/solid/SweepContour.js.map +1 -1
  1024. package/lib/esm/solid/TorusPipe.js +7 -2
  1025. package/lib/esm/solid/TorusPipe.js.map +1 -1
  1026. package/lib/esm/topology/ChainMerge.js +16 -4
  1027. package/lib/esm/topology/ChainMerge.js.map +1 -1
  1028. package/lib/esm/topology/Graph.js +41 -6
  1029. package/lib/esm/topology/Graph.js.map +1 -1
  1030. package/lib/esm/topology/HalfEdgeGraphFromIndexedLoopsContext.d.ts +1 -1
  1031. package/lib/esm/topology/HalfEdgeGraphFromIndexedLoopsContext.js +5 -1
  1032. package/lib/esm/topology/HalfEdgeGraphFromIndexedLoopsContext.js.map +1 -1
  1033. package/lib/esm/topology/HalfEdgeGraphSearch.js +2 -0
  1034. package/lib/esm/topology/HalfEdgeGraphSearch.js.map +1 -1
  1035. package/lib/esm/topology/HalfEdgeGraphSpineContext.js +9 -2
  1036. package/lib/esm/topology/HalfEdgeGraphSpineContext.js.map +1 -1
  1037. package/lib/esm/topology/HalfEdgeGraphValidation.js +7 -9
  1038. package/lib/esm/topology/HalfEdgeGraphValidation.js.map +1 -1
  1039. package/lib/esm/topology/HalfEdgeMarkSet.js +5 -0
  1040. package/lib/esm/topology/HalfEdgeMarkSet.js.map +1 -1
  1041. package/lib/esm/topology/HalfEdgeNodeXYZUV.js +6 -0
  1042. package/lib/esm/topology/HalfEdgeNodeXYZUV.js.map +1 -1
  1043. package/lib/esm/topology/HalfEdgePointInGraphSearch.js +1 -0
  1044. package/lib/esm/topology/HalfEdgePointInGraphSearch.js.map +1 -1
  1045. package/lib/esm/topology/HalfEdgePositionDetail.js +16 -0
  1046. package/lib/esm/topology/HalfEdgePositionDetail.js.map +1 -1
  1047. package/lib/esm/topology/HalfEdgePriorityQueue.js +2 -0
  1048. package/lib/esm/topology/HalfEdgePriorityQueue.js.map +1 -1
  1049. package/lib/esm/topology/InsertAndRetriangulateContext.js +4 -0
  1050. package/lib/esm/topology/InsertAndRetriangulateContext.js.map +1 -1
  1051. package/lib/esm/topology/MaskManager.js +3 -0
  1052. package/lib/esm/topology/MaskManager.js.map +1 -1
  1053. package/lib/esm/topology/Merging.js +11 -6
  1054. package/lib/esm/topology/Merging.js.map +1 -1
  1055. package/lib/esm/topology/RegularizeFace.js +22 -0
  1056. package/lib/esm/topology/RegularizeFace.js.map +1 -1
  1057. package/lib/esm/topology/SignedDataSummary.js +22 -0
  1058. package/lib/esm/topology/SignedDataSummary.js.map +1 -1
  1059. package/lib/esm/topology/SpaceTriangulation.js.map +1 -1
  1060. package/lib/esm/topology/Triangulation.d.ts +3 -3
  1061. package/lib/esm/topology/Triangulation.d.ts.map +1 -1
  1062. package/lib/esm/topology/Triangulation.js +28 -18
  1063. package/lib/esm/topology/Triangulation.js.map +1 -1
  1064. package/lib/esm/topology/XYParitySearchContext.js +13 -0
  1065. package/lib/esm/topology/XYParitySearchContext.js.map +1 -1
  1066. package/package.json +9 -9
@@ -1 +1 @@
1
- {"version":3,"file":"XYCurveEvaluator.js","sourceRoot":"","sources":["../../../../src/curve/spiral/XYCurveEvaluator.ts"],"names":[],"mappings":"AAAA;;;+FAG+F;AAE/F;;GAEG;AACH,OAAO,EAAE,QAAQ,EAAE,MAAM,gBAAgB,CAAC;AAC1C,OAAO,EAAE,yBAAyB,EAAE,MAAM,4CAA4C,CAAC;AACvF,OAAO,EAAE,OAAO,EAAY,MAAM,kCAAkC,CAAC;AACrE,OAAO,EAAE,KAAK,EAAE,MAAM,wBAAwB,CAAC;AAC/C,OAAO,EAAE,UAAU,EAAE,MAAM,2BAA2B,CAAC;AACvD,OAAO,EAAE,YAAY,EAAE,MAAM,uBAAuB,CAAC;AACrD;;;;;;;GAOG;AACH,MAAM,OAAgB,gBAAgB;IAsBpC,iFAAiF;IAC1E,eAAe,CAAC,QAAgB,EAAE,MAAgB;QACvD,OAAO,OAAO,CAAC,MAAM,CAAC,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,EAAE,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,EAAE,GAAG,EAAE,MAAM,CAAC,CAAC;IAC7F,CAAC;IACD,4IAA4I;IACrI,4BAA4B,CAAC,QAAgB,EAAE,MAAc;QAClE,OAAO,KAAK,CAAC,YAAY,CAAC,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,EAAE,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,EAAE,GAAG,EACnF,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,EAAE,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,EAAE,CAAC,EAC3D,MAAM,CAAC,CAAC;IACZ,CAAC;IACD,+IAA+I;IACxI,8BAA8B,CAAC,QAAgB,EAAE,MAAkC;QACxF,OAAO,yBAAyB,CAAC,yBAAyB,CACxD,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,EAAE,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,EAAE,GAAG,EAC3D,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,EAAE,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,EAAE,CAAC,EAC3D,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,EAAE,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,EAAE,CAAC,EAC7D,MAAM,CAAC,CAAC;IACZ,CAAC;IACD;;;OAGG;IACI,0BAA0B,CAAC,QAAgB;QAChD,MAAM,CAAC,GAAG,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,CAAC;QACtC,MAAM,CAAC,GAAG,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,CAAC;QACtC,OAAO,QAAQ,CAAC,YAAY,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;IACrC,CAAC;IAWM,MAAM,CAAC,aAAa;QACzB,gBAAgB,CAAC,OAAO,GAAG,IAAI,YAAY,CAAC,CAAC,CAAC,CAAC;QAC/C,gBAAgB,CAAC,YAAY,GAAG,IAAI,YAAY,CAAC,CAAC,CAAC,CAAC;QACpD,gBAAgB,CAAC,YAAY,GAAG,CAAC,EAAE,EAAE,EAAE,EAAE,OAAO,EAAE,OAAO,EAAE,EAAE,CAAC,UAAU,CAAC,WAAW,CAAC,EAAE,EAAE,EAAE,EAAE,OAAO,EAAE,OAAO,CAAC,CAAC;IACjH,CAAC;IACD;;;;;OAKG;IACI,iCAAiC,CAAC,SAAiB,EAAE,SAAiB;QAC3E,MAAM,MAAM,GAAG,gBAAgB,CAAC,OAAO,CAAC;QACxC,MAAM,WAAW,GAAG,gBAAgB,CAAC,YAAY,CAAC;QAClD,MAAM,OAAO,GAAG,gBAAgB,CAAC,YAAY,CAAC,SAAS,EAAE,SAAS,EAAE,MAAM,EAAE,WAAW,CAAC,CAAC;QACzF,IAAI,GAAG,GAAG,CAAC,CAAC;QACZ,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,OAAO,EAAE,CAAC,EAAE,EAAE,CAAC;YACjC,GAAG,IAAI,WAAW,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,0BAA0B,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC;QACrE,CAAC;QACD,OAAO,GAAG,CAAC;IACb,CAAC;IACD;;;;;;;OAOG;IACI,uBAAuB,CAAC,SAAiB,EAAE,SAAiB,EAAE,SAAiB,EAAE,SAAiB,EAAE,cAAsB;QAC/H,MAAM,aAAa,GAAG,QAAQ,CAAC,kBAAkB,CAAC,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,cAAc,CAAC,CAAC;QAC9G,IAAI,aAAa,KAAK,SAAS,EAAE,CAAC;YAChC,OAAO,YAAY,CAAC,WAAW,CAAC,aAAa,EAC3C,CAAC,QAAgB,EAAE,EAAE;gBACnB,MAAM,CAAC,GAAG,IAAI,CAAC,iCAAiC,CAAC,SAAS,EAAE,QAAQ,CAAC,CAAC;gBACtE,OAAO,SAAS,GAAG,CAAC,GAAG,cAAc,CAAC;YACxC,CAAC,EACD,CAAC,QAAgB,EAAE,EAAE,CAAC,IAAI,CAAC,0BAA0B,CAAC,QAAQ,CAAC,CAAC,CAAC;QACrE,CAAC;QACD,OAAO,SAAS,CAAC;IACnB,CAAC;IAED;;;;;;;OAOG;IACI,8BAA8B,CAAC,QAAgB,EAAE,EAAW,EAAE,IAAe,EAAE,IAAe,EAAE,IAAe;QACpH,EAAE,CAAC,GAAG,CAAC,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,EAAE,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC,CAAC;QAClE,IAAI,IAAI;YACN,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,EAAE,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC,CAAC;QACxE,IAAI,IAAI;YACN,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,EAAE,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC,CAAC;QAC1E,IAAI,IAAI;YACN,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,EAAE,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC,CAAC;IAC5E,CAAC;CAGF;AACD,sDAAsD;AACtD,gBAAgB,CAAC,aAAa,EAAE,CAAC","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 Curve\r\n */\r\nimport { Geometry } from \"../../Geometry\";\r\nimport { Plane3dByOriginAndVectors } from \"../../geometry3d/Plane3dByOriginAndVectors\";\r\nimport { Point3d, Vector3d } from \"../../geometry3d/Point3dVector3d\";\r\nimport { Ray3d } from \"../../geometry3d/Ray3d\";\r\nimport { Quadrature } from \"../../numerics/Quadrature\";\r\nimport { SimpleNewton } from \"../../numerics/Newton\";\r\n/**\r\n * XYCurveEvaluator is an abstract with methods for evaluating X and Y parts of a curve parameterized by a fraction.\r\n * * The required methods call for independent X and Y evaluation.\r\n * * Base class methods package those (multiple) calls into point, ray, and plane structures.\r\n * * A implementation that has evaluation substantial cost that can be shared among x,y parts or between\r\n * primary functions and derivatives might choose to implement the point and derivative methods directly.\r\n * @internal\r\n */\r\nexport abstract class XYCurveEvaluator {\r\n /** return a deep copy of the evaluator */\r\n public abstract clone(): XYCurveEvaluator;\r\n /** test for near identical evaluator */\r\n public abstract isAlmostEqual(other: any): boolean;\r\n /** Evaluate X at fractional position. */\r\n public abstract fractionToX(fraction: number): number;\r\n /** Evaluate Y at fractional position. */\r\n public abstract fractionToY(fraction: number): number;\r\n /** Evaluate derivative of X with respect to fraction at fractional position. */\r\n public abstract fractionToDX(fraction: number): number;\r\n /** Evaluate derivative of Y with respect to fraction at fractional position. */\r\n public abstract fractionToDY(fraction: number): number;\r\n /** Evaluate second derivative of X with respect to fraction at fractional position. */\r\n public abstract fractionToDDX(fraction: number): number;\r\n /** Evaluate second derivative of Y with respect to fraction at fractional position. */\r\n public abstract fractionToDDY(fraction: number): number;\r\n /** Evaluate both X and Y at fractional coordinate, return bundled as a point. */\r\n /** Evaluate second derivative of X with respect to fraction at fractional position. */\r\n public abstract fractionToD3X(fraction: number): number;\r\n /** Evaluate second derivative of Y with respect to fraction at fractional position. */\r\n public abstract fractionToD3Y(fraction: number): number;\r\n /** Evaluate both X and Y at fractional coordinate, return bundled as a point. */\r\n public fractionToPoint(fraction: number, result?: Point3d): Point3d {\r\n return Point3d.create(this.fractionToX(fraction), this.fractionToY(fraction), 0.0, result);\r\n }\r\n /** Evaluate both X and Y and their first derivatives at fractional coordinate, return bundled as origin and (non-unit) direction vector. */\r\n public fractionToPointAndDerivative(fraction: number, result?: Ray3d): Ray3d {\r\n return Ray3d.createXYZUVW(this.fractionToX(fraction), this.fractionToY(fraction), 0.0,\r\n this.fractionToDX(fraction), this.fractionToDY(fraction), 0,\r\n result);\r\n }\r\n /** Evaluate both X and Y and their second derivatives at fractional coordinate, return bundled as origin and (non-unit) vectorU an vectorV. */\r\n public fractionToPointAnd2Derivatives(fraction: number, result?: Plane3dByOriginAndVectors): Plane3dByOriginAndVectors {\r\n return Plane3dByOriginAndVectors.createOriginAndVectorsXYZ(\r\n this.fractionToX(fraction), this.fractionToY(fraction), 0.0,\r\n this.fractionToDX(fraction), this.fractionToDY(fraction), 0,\r\n this.fractionToDDX(fraction), this.fractionToDDY(fraction), 0,\r\n result);\r\n }\r\n /**\r\n * Return the magnitude of the tangent vector at fraction.\r\n * @param fraction fractional position along the curve\r\n */\r\n public fractionToTangentMagnitude(fraction: number): number {\r\n const u = this.fractionToDX(fraction);\r\n const v = this.fractionToDY(fraction);\r\n return Geometry.hypotenuseXY(u, v);\r\n }\r\n\r\n /** Invert the fractionToX function for given X. */\r\n\r\n public abstract xToFraction(x: number): number | undefined;\r\n /** Initialize class level work arrays for 5 point Gaussian Quadrature. */\r\n // Class resources for integration . . .\r\n // These static variables are reused on calls to integrateFromStartFraction\r\n protected static _gaussX: Float64Array;\r\n protected static _gaussWeight: Float64Array;\r\n protected static _gaussMapper: (xA: number, xB: number, arrayX: Float64Array, arrayW: Float64Array) => number;\r\n public static initWorkSpace() {\r\n XYCurveEvaluator._gaussX = new Float64Array(5);\r\n XYCurveEvaluator._gaussWeight = new Float64Array(5);\r\n XYCurveEvaluator._gaussMapper = (xA, xB, xMapped, wMapped) => Quadrature.setupGauss5(xA, xB, xMapped, wMapped);\r\n }\r\n /**\r\n * Integrate between nominal fractions with default gauss rule.\r\n * * The caller is expected to choose nearby fractions so that the single gauss interval accuracy is good.\r\n * @param fraction0\r\n * @param fraction1\r\n */\r\n public integrateDistanceBetweenFractions(fraction0: number, fraction1: number): number {\r\n const gaussX = XYCurveEvaluator._gaussX;\r\n const gaussWeight = XYCurveEvaluator._gaussWeight;\r\n const numEval = XYCurveEvaluator._gaussMapper(fraction0, fraction1, gaussX, gaussWeight);\r\n let sum = 0;\r\n for (let k = 0; k < numEval; k++) {\r\n sum += gaussWeight[k] * this.fractionToTangentMagnitude(gaussX[k]);\r\n }\r\n return sum;\r\n }\r\n /**\r\n * Inverse integrated distance\r\n * @param fraction0 start of fraction interval\r\n * @param fraction1 end of fraction interval\r\n * @param distance0 distance at start\r\n * @param distance1 distance at end\r\n * @param targetDistance intermediate distance.\r\n */\r\n public inverseDistanceFraction(fraction0: number, fraction1: number, distance0: number, distance1: number, targetDistance: number): number | undefined {\r\n const startFraction = Geometry.inverseInterpolate(fraction0, distance0, fraction1, distance1, targetDistance);\r\n if (startFraction !== undefined) {\r\n return SimpleNewton.runNewton1D(startFraction,\r\n (fraction: number) => {\r\n const d = this.integrateDistanceBetweenFractions(fraction0, fraction);\r\n return distance0 + d - targetDistance;\r\n },\r\n (fraction: number) => this.fractionToTangentMagnitude(fraction));\r\n }\r\n return undefined;\r\n }\r\n\r\n /**\r\n *\r\n * @param fraction fractional position along x axis\r\n * @param xy xy coordinates of point on the curve\r\n * @param d1xy\r\n * @param d2xy\r\n * @param d3xy\r\n */\r\n public fractionToPointAnd3Derivatives(fraction: number, xy: Point3d, d1xy?: Vector3d, d2xy?: Vector3d, d3xy?: Vector3d) {\r\n xy.set(this.fractionToX(fraction), this.fractionToY(fraction), 0);\r\n if (d1xy)\r\n d1xy.set(this.fractionToDX(fraction), this.fractionToDY(fraction), 0);\r\n if (d2xy)\r\n d2xy.set(this.fractionToDDX(fraction), this.fractionToDDY(fraction), 0);\r\n if (d3xy)\r\n d3xy.set(this.fractionToD3X(fraction), this.fractionToD3Y(fraction), 0);\r\n }\r\n /** Apply a uniform scale around the origin. */\r\n public abstract scaleInPlace(scaleFactor: number): void;\r\n}\r\n// at load time, initialize gauss quadrature workspace\r\nXYCurveEvaluator.initWorkSpace();\r\n"]}
1
+ {"version":3,"file":"XYCurveEvaluator.js","sourceRoot":"","sources":["../../../../src/curve/spiral/XYCurveEvaluator.ts"],"names":[],"mappings":"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","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 Curve\n */\nimport { Geometry } from \"../../Geometry\";\nimport { Plane3dByOriginAndVectors } from \"../../geometry3d/Plane3dByOriginAndVectors\";\nimport { Point3d, Vector3d } from \"../../geometry3d/Point3dVector3d\";\nimport { Ray3d } from \"../../geometry3d/Ray3d\";\nimport { Quadrature } from \"../../numerics/Quadrature\";\nimport { SimpleNewton } from \"../../numerics/Newton\";\n/**\n * XYCurveEvaluator is an abstract with methods for evaluating X and Y parts of a curve parameterized by a fraction.\n * * The required methods call for independent X and Y evaluation.\n * * Base class methods package those (multiple) calls into point, ray, and plane structures.\n * * A implementation that has evaluation substantial cost that can be shared among x,y parts or between\n * primary functions and derivatives might choose to implement the point and derivative methods directly.\n * @internal\n */\nexport abstract class XYCurveEvaluator {\n /** return a deep copy of the evaluator */\n public abstract clone(): XYCurveEvaluator;\n /** test for near identical evaluator */\n public abstract isAlmostEqual(other: any): boolean;\n /** Evaluate X at fractional position. */\n public abstract fractionToX(fraction: number): number;\n /** Evaluate Y at fractional position. */\n public abstract fractionToY(fraction: number): number;\n /** Evaluate derivative of X with respect to fraction at fractional position. */\n public abstract fractionToDX(fraction: number): number;\n /** Evaluate derivative of Y with respect to fraction at fractional position. */\n public abstract fractionToDY(fraction: number): number;\n /** Evaluate second derivative of X with respect to fraction at fractional position. */\n public abstract fractionToDDX(fraction: number): number;\n /** Evaluate second derivative of Y with respect to fraction at fractional position. */\n public abstract fractionToDDY(fraction: number): number;\n /** Evaluate both X and Y at fractional coordinate, return bundled as a point. */\n /** Evaluate second derivative of X with respect to fraction at fractional position. */\n public abstract fractionToD3X(fraction: number): number;\n /** Evaluate second derivative of Y with respect to fraction at fractional position. */\n public abstract fractionToD3Y(fraction: number): number;\n /** Evaluate both X and Y at fractional coordinate, return bundled as a point. */\n public fractionToPoint(fraction: number, result?: Point3d): Point3d {\n return Point3d.create(this.fractionToX(fraction), this.fractionToY(fraction), 0.0, result);\n }\n /** Evaluate both X and Y and their first derivatives at fractional coordinate, return bundled as origin and (non-unit) direction vector. */\n public fractionToPointAndDerivative(fraction: number, result?: Ray3d): Ray3d {\n return Ray3d.createXYZUVW(this.fractionToX(fraction), this.fractionToY(fraction), 0.0,\n this.fractionToDX(fraction), this.fractionToDY(fraction), 0,\n result);\n }\n /** Evaluate both X and Y and their second derivatives at fractional coordinate, return bundled as origin and (non-unit) vectorU an vectorV. */\n public fractionToPointAnd2Derivatives(fraction: number, result?: Plane3dByOriginAndVectors): Plane3dByOriginAndVectors {\n return Plane3dByOriginAndVectors.createOriginAndVectorsXYZ(\n this.fractionToX(fraction), this.fractionToY(fraction), 0.0,\n this.fractionToDX(fraction), this.fractionToDY(fraction), 0,\n this.fractionToDDX(fraction), this.fractionToDDY(fraction), 0,\n result);\n }\n /**\n * Return the magnitude of the tangent vector at fraction.\n * @param fraction fractional position along the curve\n */\n public fractionToTangentMagnitude(fraction: number): number {\n const u = this.fractionToDX(fraction);\n const v = this.fractionToDY(fraction);\n return Geometry.hypotenuseXY(u, v);\n }\n\n /** Invert the fractionToX function for given X. */\n\n public abstract xToFraction(x: number): number | undefined;\n /** Initialize class level work arrays for 5 point Gaussian Quadrature. */\n // Class resources for integration . . .\n // These static variables are reused on calls to integrateFromStartFraction\n protected static _gaussX: Float64Array;\n protected static _gaussWeight: Float64Array;\n protected static _gaussMapper: (xA: number, xB: number, arrayX: Float64Array, arrayW: Float64Array) => number;\n public static initWorkSpace() {\n XYCurveEvaluator._gaussX = new Float64Array(5);\n XYCurveEvaluator._gaussWeight = new Float64Array(5);\n XYCurveEvaluator._gaussMapper = (xA, xB, xMapped, wMapped) => Quadrature.setupGauss5(xA, xB, xMapped, wMapped);\n }\n /**\n * Integrate between nominal fractions with default gauss rule.\n * * The caller is expected to choose nearby fractions so that the single gauss interval accuracy is good.\n * @param fraction0\n * @param fraction1\n */\n public integrateDistanceBetweenFractions(fraction0: number, fraction1: number): number {\n const gaussX = XYCurveEvaluator._gaussX;\n const gaussWeight = XYCurveEvaluator._gaussWeight;\n const numEval = XYCurveEvaluator._gaussMapper(fraction0, fraction1, gaussX, gaussWeight);\n let sum = 0;\n for (let k = 0; k < numEval; k++) {\n sum += gaussWeight[k] * this.fractionToTangentMagnitude(gaussX[k]);\n }\n return sum;\n }\n /**\n * Inverse integrated distance\n * @param fraction0 start of fraction interval\n * @param fraction1 end of fraction interval\n * @param distance0 distance at start\n * @param distance1 distance at end\n * @param targetDistance intermediate distance.\n */\n public inverseDistanceFraction(fraction0: number, fraction1: number, distance0: number, distance1: number, targetDistance: number): number | undefined {\n const startFraction = Geometry.inverseInterpolate(fraction0, distance0, fraction1, distance1, targetDistance);\n if (startFraction !== undefined) {\n return SimpleNewton.runNewton1D(startFraction,\n (fraction: number) => {\n const d = this.integrateDistanceBetweenFractions(fraction0, fraction);\n return distance0 + d - targetDistance;\n },\n (fraction: number) => this.fractionToTangentMagnitude(fraction));\n }\n return undefined;\n }\n\n /**\n *\n * @param fraction fractional position along x axis\n * @param xy xy coordinates of point on the curve\n * @param d1xy\n * @param d2xy\n * @param d3xy\n */\n public fractionToPointAnd3Derivatives(fraction: number, xy: Point3d, d1xy?: Vector3d, d2xy?: Vector3d, d3xy?: Vector3d) {\n xy.set(this.fractionToX(fraction), this.fractionToY(fraction), 0);\n if (d1xy)\n d1xy.set(this.fractionToDX(fraction), this.fractionToDY(fraction), 0);\n if (d2xy)\n d2xy.set(this.fractionToDDX(fraction), this.fractionToDDY(fraction), 0);\n if (d3xy)\n d3xy.set(this.fractionToD3X(fraction), this.fractionToD3Y(fraction), 0);\n }\n /** Apply a uniform scale around the origin. */\n public abstract scaleInPlace(scaleFactor: number): void;\n}\n// at load time, initialize gauss quadrature workspace\nXYCurveEvaluator.initWorkSpace();\n"]}
@@ -17,6 +17,24 @@ import { Geometry } from "../Geometry";
17
17
  * @public
18
18
  */
19
19
  export class Angle {
20
+ /** maximal accuracy value of pi/12 (15 degrees), in radians */
21
+ static piOver12Radians = 0.26179938779914946;
22
+ /** maximal accuracy value of pi/4 (45 degrees), in radians */
23
+ static piOver4Radians = 7.853981633974483e-001;
24
+ /** maximal accuracy value of pi/2 (90 degrees), in radians */
25
+ static piOver2Radians = 1.5707963267948966e+000;
26
+ /** maximal accuracy value of pi (180 degrees), in radians */
27
+ static piRadians = 3.141592653589793e+000;
28
+ /** maximal accuracy value of 3*pi/2 (270 degrees), in radians */
29
+ static pi3Over2Radians = 4.71238898038469e+000;
30
+ /** maximal accuracy value of 2*pi (360 degrees), in radians */
31
+ static pi2Radians = 6.283185307179586e+000;
32
+ /** scale factor for converting radians to degrees */
33
+ static degreesPerRadian = (45.0 / Angle.piOver4Radians);
34
+ /** scale factor for converting degrees to radians */
35
+ static radiansPerDegree = (Angle.piOver4Radians / 45.0);
36
+ _radians;
37
+ _degrees;
20
38
  constructor(radians = 0, degrees) {
21
39
  this._radians = radians;
22
40
  this._degrees = degrees;
@@ -531,20 +549,4 @@ export class Angle {
531
549
  }
532
550
  }
533
551
  }
534
- /** maximal accuracy value of pi/12 (15 degrees), in radians */
535
- Angle.piOver12Radians = 0.26179938779914946;
536
- /** maximal accuracy value of pi/4 (45 degrees), in radians */
537
- Angle.piOver4Radians = 7.853981633974483e-001;
538
- /** maximal accuracy value of pi/2 (90 degrees), in radians */
539
- Angle.piOver2Radians = 1.5707963267948966e+000;
540
- /** maximal accuracy value of pi (180 degrees), in radians */
541
- Angle.piRadians = 3.141592653589793e+000;
542
- /** maximal accuracy value of 3*pi/2 (270 degrees), in radians */
543
- Angle.pi3Over2Radians = 4.71238898038469e+000;
544
- /** maximal accuracy value of 2*pi (360 degrees), in radians */
545
- Angle.pi2Radians = 6.283185307179586e+000;
546
- /** scale factor for converting radians to degrees */
547
- Angle.degreesPerRadian = (45.0 / Angle.piOver4Radians);
548
- /** scale factor for converting degrees to radians */
549
- Angle.radiansPerDegree = (Angle.piOver4Radians / 45.0);
550
552
  //# sourceMappingURL=Angle.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"Angle.js","sourceRoot":"","sources":["../../../src/geometry3d/Angle.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/** @packageDocumentation\r\n * @module CartesianGeometry\r\n */\r\n\r\nimport { AngleProps, BeJSONFunctions, Geometry, TrigValues } from \"../Geometry\";\r\n\r\n/**\r\n * An `Angle` carries the numeric value of an angle, with methods to allow (require!) callers to\r\n * be clear about whether their angle is degrees or radians.\r\n * * After the Angle object is created, the callers should not know or care whether it is stored in\r\n * `degrees` or `radians` because both are available if requested by caller.\r\n * * The various access method are named so that callers can specify whether untyped numbers passed in or\r\n * out are degrees or radians.\r\n * * Visualization can be found at https://www.itwinjs.org/sandbox/SaeedTorabi/AngleSweep\r\n * @public\r\n */\r\nexport class Angle implements BeJSONFunctions {\r\n /** maximal accuracy value of pi/12 (15 degrees), in radians */\r\n public static readonly piOver12Radians = 0.26179938779914946;\r\n /** maximal accuracy value of pi/4 (45 degrees), in radians */\r\n public static readonly piOver4Radians = 7.853981633974483e-001;\r\n /** maximal accuracy value of pi/2 (90 degrees), in radians */\r\n public static readonly piOver2Radians = 1.5707963267948966e+000;\r\n /** maximal accuracy value of pi (180 degrees), in radians */\r\n public static readonly piRadians = 3.141592653589793e+000;\r\n /** maximal accuracy value of 3*pi/2 (270 degrees), in radians */\r\n public static readonly pi3Over2Radians = 4.71238898038469e+000;\r\n /** maximal accuracy value of 2*pi (360 degrees), in radians */\r\n public static readonly pi2Radians = 6.283185307179586e+000;\r\n /** scale factor for converting radians to degrees */\r\n public static readonly degreesPerRadian = (45.0 / Angle.piOver4Radians);\r\n /** scale factor for converting degrees to radians */\r\n public static readonly radiansPerDegree = (Angle.piOver4Radians / 45.0);\r\n private _radians: number;\r\n private _degrees?: number;\r\n private constructor(radians = 0, degrees?: number) {\r\n this._radians = radians;\r\n this._degrees = degrees;\r\n }\r\n /** Return a new angle with the same content. */\r\n public clone(): Angle {\r\n return new Angle(this._radians, this._degrees);\r\n }\r\n /** Freeze this instance so it is read-only */\r\n public freeze(): Readonly<this> {\r\n return Object.freeze(this);\r\n }\r\n /**\r\n * Return a new Angle object for angle given in degrees.\r\n * @param degrees angle in degrees\r\n */\r\n public static createDegrees(degrees: number): Angle {\r\n return new Angle(Angle.degreesToRadians(degrees), degrees);\r\n }\r\n /**\r\n * Return a (new) Angle object for a value given in radians.\r\n * @param radians angle in radians\r\n */\r\n public static createRadians(radians: number): Angle {\r\n return new Angle(radians);\r\n }\r\n /**\r\n * Return a new `Angle` object with the default \"small\" angle measurement specified by [[Geometry.smallAngleRadians]].\r\n */\r\n public static createSmallAngle(): Angle {\r\n return new Angle(Geometry.smallAngleRadians);\r\n }\r\n /**\r\n * Return a (new) Angle object that is interpolated between two inputs (based on a fraction)\r\n * @param angle0 first angle in radians\r\n * @param fraction the interpolation fraction\r\n * @param angle1 second angle in radians\r\n */\r\n public static createInterpolate(angle0: Angle, fraction: number, angle1: Angle): Angle {\r\n return new Angle(Geometry.interpolate(angle0.radians, fraction, angle1.radians));\r\n }\r\n /**\r\n * Return a (new) Angle object, with angle scaled from existing angle.\r\n * @param scale scale factor to apply to angle.\r\n */\r\n public cloneScaled(scale: number): Angle {\r\n return new Angle(this.radians * scale);\r\n }\r\n /**\r\n * Set this angle to a value given in radians.\r\n * @param radians angle given in radians\r\n */\r\n public setRadians(radians: number) {\r\n this._radians = radians;\r\n this._degrees = undefined;\r\n }\r\n /**\r\n * Set this angle to a value given in degrees.\r\n * @param degrees angle given in degrees.\r\n */\r\n public setDegrees(degrees: number) {\r\n this._radians = Angle.degreesToRadians(degrees);\r\n this._degrees = degrees;\r\n }\r\n /** Create an angle for a full circle. */\r\n public static create360(): Angle {\r\n return new Angle(Math.PI * 2.0, 360.0);\r\n }\r\n /**\r\n * Create a (strongly typed) Angle whose tangent is `numerator/denominator`, using the signs of both in\r\n * determining the (otherwise ambiguous) quadrant.\r\n * @param numerator numerator for tangent\r\n * @param denominator denominator for tangent\r\n */\r\n public static createAtan2(numerator: number, denominator: number): Angle {\r\n return new Angle(Math.atan2(numerator, denominator));\r\n }\r\n /**\r\n * Copy all contents of `other` to this Angle.\r\n * @param other source data\r\n */\r\n public setFrom(other: Angle) {\r\n this._radians = other._radians;\r\n this._degrees = other._degrees;\r\n }\r\n /**\r\n * Set an Angle from a JSON object\r\n * * A simple number is considered as degrees.\r\n * * specified `json.degrees` or `json._degrees` is degree value.\r\n * * specified `son.radians` or `json._radians` is radians value.\r\n * @param json object from JSON.parse. If a number, value is in *DEGREES*\r\n * @param defaultValRadians if json is undefined, default value in radians.\r\n */\r\n public setFromJSON(json?: AngleProps, defaultValRadians?: number) {\r\n this._radians = defaultValRadians ? defaultValRadians : 0;\r\n if (!json)\r\n return;\r\n if (typeof json === \"number\") {\r\n this.setDegrees(json);\r\n } else if (typeof (json as any).degrees === \"number\") {\r\n this.setDegrees((json as any).degrees);\r\n } else if (typeof (json as any)._degrees === \"number\") {\r\n this.setDegrees((json as any)._degrees);\r\n } else if (typeof (json as any).radians === \"number\") {\r\n this.setRadians((json as any).radians);\r\n } else if (typeof (json as any)._radians === \"number\") {\r\n this.setRadians((json as any)._radians);\r\n }\r\n }\r\n /**\r\n * Create an Angle from a JSON object\r\n * @param json object from JSON.parse. If a number, value is in *DEGREES*\r\n * @param defaultValRadians if json is undefined, default value in radians.\r\n * @return a new Angle\r\n */\r\n public static fromJSON(json?: AngleProps, defaultValRadians?: number): Angle {\r\n const val = new Angle();\r\n val.setFromJSON(json, defaultValRadians);\r\n return val;\r\n }\r\n /** Convert an Angle to a JSON object as a number in degrees */\r\n public toJSON(): AngleProps {\r\n return this.degrees;\r\n }\r\n /** Return a json object with radians keyword, e.g. `{ radians: 0.10}` */\r\n public toJSONRadians(): AngleProps {\r\n return { radians: this.radians };\r\n }\r\n /** Return the angle measured in radians. */\r\n public get radians(): number {\r\n return this._radians;\r\n }\r\n /** Return the angle measured in degrees. */\r\n public get degrees(): number {\r\n return this._degrees !== undefined ? this._degrees : Angle.radiansToDegrees(this._radians);\r\n }\r\n /**\r\n * Convert an angle in degrees to radians.\r\n * @param degrees angle in degrees\r\n */\r\n public static degreesToRadians(degrees: number): number {\r\n return degrees * Math.PI / 180;\r\n }\r\n /**\r\n * Convert an angle in radians to degrees.\r\n * @param degrees angle in radians\r\n */\r\n public static radiansToDegrees(radians: number): number {\r\n if (radians < 0)\r\n return -Angle.radiansToDegrees(-radians);\r\n // Now radians is positive ...\r\n const pi = Math.PI;\r\n const factor = 180.0 / pi;\r\n /* the following if statements are for round-off reasons. The problem is that no IEEE number is\r\n * an exact hit for any primary multiple of pi (90, 180, etc). The following is supposed to have\r\n * a better chance that if the input was computed by direct assignment from 90, 180, etc degrees\r\n * it will return exactly 90,180 etc.\r\n */\r\n if (radians <= 0.25 * pi)\r\n return factor * radians;\r\n if (radians < 0.75 * pi)\r\n return 90.0 + 180 * ((radians - 0.5 * pi) / pi);\r\n if (radians <= 1.25 * pi)\r\n return 180.0 + 180 * ((radians - pi) / pi);\r\n if (radians <= 1.75 * pi)\r\n return 270.0 + 180 * ((radians - 1.5 * pi) / pi);\r\n // all larger radians reference from 360 degrees (2PI)\r\n return 360.0 + 180 * ((radians - 2.0 * pi) / pi);\r\n }\r\n /** Return the cosine of this Angle object's angle */\r\n public cos(): number {\r\n return Math.cos(this._radians);\r\n }\r\n /** Return the sine of this Angle object's angle */\r\n public sin(): number {\r\n return Math.sin(this._radians);\r\n }\r\n /** Return the tangent of this Angle object's angle */\r\n public tan(): number {\r\n return Math.tan(this._radians);\r\n }\r\n /** Test if a radians (absolute) value is nearly 2PI or larger. */\r\n public static isFullCircleRadians(radians: number): boolean {\r\n return Math.abs(radians) >= Geometry.fullCircleRadiansMinusSmallAngle;\r\n }\r\n /** Test if the radians value is a half circle */\r\n public static isHalfCircleRadians(radians: number): boolean {\r\n return Math.abs(Math.abs(radians) - Math.PI) <= Geometry.smallAngleRadians;\r\n }\r\n /** Test if the angle is a full circle */\r\n public get isFullCircle(): boolean {\r\n return Angle.isFullCircleRadians(this._radians);\r\n }\r\n /** Test if the angle is a half circle (in either direction) */\r\n public get isHalfCircle(): boolean {\r\n return Angle.isHalfCircleRadians(this._radians);\r\n }\r\n /**\r\n * Adjust a degrees value so it is in [0, 360].\r\n * * Positive multiples of 360 return 0; negative multiples return 360.\r\n */\r\n public static adjustDegrees0To360(degrees: number): number {\r\n if (degrees >= 0) {\r\n const period = 360.0;\r\n if (degrees < period)\r\n return degrees;\r\n const numPeriods = Math.floor(degrees / period);\r\n return degrees - numPeriods * period;\r\n } else if (degrees < 0) {\r\n // negative angle ...\r\n return 360.0 - Angle.adjustDegrees0To360(-degrees);\r\n }\r\n // fall through for Nan (disaster) !!!\r\n return 0;\r\n }\r\n /** Adjust a degrees value so it is in [-180, 180]. */\r\n public static adjustDegreesSigned180(degrees: number): number {\r\n if (Math.abs(degrees) <= 180.0)\r\n return degrees;\r\n if (degrees >= 0) {\r\n const period = 360.0;\r\n const numPeriods = 1 + Math.floor((degrees - 180.0) / period);\r\n return degrees - numPeriods * period;\r\n } else if (degrees < 0) {\r\n // negative angle ...\r\n return -Angle.adjustDegreesSigned180(-degrees);\r\n }\r\n // fall through for NaN disaster.\r\n return 0;\r\n }\r\n /**\r\n * Adjust a radians value so it is in [0, 2pi].\r\n * * Nonnegative multiples of 2pi return 0; negative multiples return 2pi.\r\n */\r\n public static adjustRadians0To2Pi(radians: number): number {\r\n if (radians >= 0) {\r\n const period = Math.PI * 2.0;\r\n if (radians < period)\r\n return radians;\r\n const numPeriods = Math.floor(radians / period);\r\n return radians - numPeriods * period;\r\n } else if (radians < 0) {\r\n // negative angle ...\r\n return Math.PI * 2.0 - Angle.adjustRadians0To2Pi(-radians);\r\n }\r\n // fall through for NaN disaster.\r\n return 0;\r\n }\r\n /**\r\n * Adjust a radians value so it is in [0, 2pi).\r\n * * All multiples of 2pi (within `Geometry.smallAngleRadians`) return 0.\r\n */\r\n public static adjustRadians0ToLessThan2Pi(radians: number): number {\r\n if (Angle.isAlmostEqualRadiansAllowPeriodShift(radians, 0))\r\n radians = 0;\r\n return this.adjustRadians0To2Pi(radians);\r\n }\r\n /** Adjust a radians value so it is in [-pi, pi] */\r\n public static adjustRadiansMinusPiPlusPi(radians: number): number {\r\n if (Math.abs(radians) <= Math.PI)\r\n return radians;\r\n if (radians >= 0) {\r\n const period = Math.PI * 2.0;\r\n const numPeriods = 1 + Math.floor((radians - Math.PI) / period);\r\n return radians - numPeriods * period;\r\n } else if (radians < 0) {\r\n // negative angle ...\r\n return -Angle.adjustRadiansMinusPiPlusPi(-radians);\r\n }\r\n // fall through for NaN disaster.\r\n return 0;\r\n }\r\n /** Return a (newly allocated) Angle object with value 0 radians */\r\n public static zero(): Angle {\r\n return new Angle(0);\r\n }\r\n /** Test if the angle is exactly zero. */\r\n public get isExactZero(): boolean {\r\n return this.radians === 0;\r\n }\r\n /** Test if the angle is almost zero (within tolerance `Geometry.smallAngleRadians`) */\r\n public get isAlmostZero(): boolean {\r\n return Math.abs(this.radians) < Geometry.smallAngleRadians;\r\n }\r\n /** Test if the angle is almost a north or south pole (within tolerance `Geometry.smallAngleRadians`) */\r\n public get isAlmostNorthOrSouthPole(): boolean {\r\n return Angle.isHalfCircleRadians(this.radians * 2.0);\r\n }\r\n /** Create an angle object with degrees adjusted into 0..360. */\r\n public static createDegreesAdjustPositive(degrees: number): Angle {\r\n return Angle.createDegrees(Angle.adjustDegrees0To360(degrees));\r\n }\r\n /** Create an angle object with degrees adjusted into -180..180. */\r\n public static createDegreesAdjustSigned180(degrees: number): Angle {\r\n return Angle.createDegrees(Angle.adjustDegreesSigned180(degrees));\r\n }\r\n /**\r\n * Test if two radian values are equivalent, allowing shift by full circle (i.e. by a multiple of `2*PI`)\r\n * @param radiansA first radians value\r\n * @param radiansB second radians value\r\n * @param radianTol radian tolerance with default value of Geometry.smallAngleRadians\r\n */\r\n public static isAlmostEqualRadiansAllowPeriodShift(radiansA: number, radiansB: number,\r\n radianTol: number = Geometry.smallAngleRadians): boolean {\r\n const delta = Math.abs(radiansA - radiansB);\r\n if (delta <= radianTol)\r\n return true;\r\n const period = Math.PI * 2.0;\r\n if (Math.abs(delta - period) <= radianTol)\r\n return true;\r\n const numPeriod = Math.round(delta / period);\r\n const delta1 = delta - numPeriod * period;\r\n return Math.abs(delta1) <= radianTol;\r\n }\r\n /**\r\n * Test if this angle has magnitude no greater than that of `other`.\r\n * @param other the other angle\r\n */\r\n public isMagnitudeLessThanOrEqual(other: Angle): boolean {\r\n return Math.abs(this.radians) <= Math.abs(other.radians);\r\n }\r\n\r\n /**\r\n * Test if this angle and `other` are equivalent, allowing shift by full circle (i.e., multiples of `2 * PI`).\r\n * @param other the other angle\r\n * @param radianTol radian tolerance with default value of Geometry.smallAngleRadians\r\n */\r\n public isAlmostEqualAllowPeriodShift(other: Angle, radianTol: number = Geometry.smallAngleRadians): boolean {\r\n return Angle.isAlmostEqualRadiansAllowPeriodShift(this._radians, other._radians, radianTol);\r\n }\r\n /**\r\n * Test if two angles (in radians) are almost equal, NOT allowing shift by full circle (i.e., multiples of `2 * PI`).\r\n * @param radiansA first radians value\r\n * @param radiansB second radians value\r\n * @param radianTol radian tolerance with default value of Geometry.smallAngleRadians\r\n */\r\n public static isAlmostEqualRadiansNoPeriodShift(radiansA: number, radiansB: number,\r\n radianTol: number = Geometry.smallAngleRadians): boolean {\r\n return Math.abs(radiansA - radiansB) < radianTol;\r\n }\r\n /**\r\n * Test if this angle and `other` are almost equal, NOT allowing shift by full circle (i.e., multiples of `2 * PI`).\r\n * @param other the other angle\r\n * @param radianTol radian tolerance with default value of Geometry.smallAngleRadians\r\n */\r\n public isAlmostEqualNoPeriodShift(other: Angle, radianTol: number = Geometry.smallAngleRadians): boolean {\r\n return Angle.isAlmostEqualRadiansNoPeriodShift(this._radians, other._radians, radianTol);\r\n }\r\n /**\r\n * Test if this angle and `other` are almost equal, NOT allowing shift by full circle (i.e., multiples of `2 * PI`).\r\n * * This function is same as isAlmostEqualRadiansNoPeriodShift. Please use isAlmostEqualRadiansNoPeriodShift.\r\n * @param other the other angle\r\n * @param radianTol radian tolerance with default value of Geometry.smallAngleRadians\r\n */\r\n public isAlmostEqual(other: Angle, radianTol: number = Geometry.smallAngleRadians): boolean {\r\n return this.isAlmostEqualNoPeriodShift(other, radianTol);\r\n }\r\n /**\r\n * Test if dot product values indicate non-zero length perpendicular vectors.\r\n * @param dotUU dot product of vectorU with itself\r\n * @param dotVV dot product of vectorV with itself\r\n * @param dotUV dot product of vectorU with vectorV\r\n */\r\n public static isPerpendicularDotSet(dotUU: number, dotVV: number, dotUV: number): boolean {\r\n return dotUU > Geometry.smallMetricDistanceSquared\r\n && dotVV > Geometry.smallMetricDistanceSquared\r\n && dotUV * dotUV <= Geometry.smallAngleRadiansSquared * dotUU * dotVV;\r\n }\r\n /**\r\n * Compute the angle A given r*cos(2A) and r*sin(2A) for some nonnegative scalar r.\r\n * * This function assumes the input arguments are related to an angle between -PI and PI.\r\n * * This function returns an angle between -PI and PI.\r\n * @param rCos2A scaled cosine value of twice the angle A.\r\n * @param rSin2A scaled sine value of twice the angle A.\r\n * @return cos(A), sin(A) and A in radians\r\n */\r\n public static trigValuesToHalfAngleTrigValues(rCos2A: number, rSin2A: number): TrigValues {\r\n const r = Geometry.hypotenuseXY(rCos2A, rSin2A);\r\n if (r < Geometry.smallMetricDistance) {\r\n return { c: 1.0, s: 0.0, radians: 0.0 }; // angle = 0\r\n } else {\r\n /* If the caller really gave you sine and cosine values, r should be 1. However,\r\n * to allow scaled values -- e.g. the x and y components of any vector -- we normalize\r\n * right here. This adds an extra sqrt and two divisions, but improves\r\n * both the usefulness and robustness of the computation.\r\n */\r\n let cosA;\r\n let sinA = 0.0;\r\n const cos2A = rCos2A / r;\r\n const sin2A = rSin2A / r;\r\n if (cos2A >= 0.0) { // 2A is in NE and SE quadrants, A in same quadrant\r\n cosA = Math.sqrt(0.5 * (1.0 + cos2A)); // half angle formula. Use +root since cosA >= 0\r\n sinA = sin2A / (2.0 * cosA); // double angle formula\r\n } else {\r\n if (sin2A > 0.0) { // 2A in NW quadrant. A in NE quadrant\r\n sinA = Math.sqrt(0.5 * (1.0 - cos2A)); // half angle formula. Use +root since sinA > 0\r\n } else { // 2A in SW quadrant. A in SE quadrant\r\n sinA = -Math.sqrt(0.5 * (1.0 - cos2A)); // half angle formula. Use -root since sinA <= 0\r\n }\r\n cosA = sin2A / (2.0 * sinA); // double angle formula\r\n }\r\n return { c: cosA, s: sinA, radians: Math.atan2(sinA, cosA) };\r\n }\r\n }\r\n /** If value is close to -1, -0.5, 0, 0.5, 1, adjust it to the exact value. */\r\n public static cleanupTrigValue(value: number, tolerance: number = Geometry.smallFloatingPoint): number {\r\n const absValue = Math.abs(value);\r\n if (absValue <= tolerance)\r\n return 0;\r\n let a = Math.abs(absValue - 0.5);\r\n if (a <= tolerance)\r\n return value < 0.0 ? -0.5 : 0.5;\r\n a = Math.abs(absValue - 1.0);\r\n if (a <= tolerance)\r\n return value < 0.0 ? -1.0 : 1.0;\r\n return value;\r\n }\r\n /**\r\n * Return the half angle cosine, sine, and radians for the given vector dot products.\r\n * * These values arise e.g. in the computation performed in `Arc3d.toScaledMatrix3d`.\r\n * * Let vectors U and V define the ellipse x(t) = c + U cos(t) + V sin(t). We seek an angle t0\r\n * such that the radial vector W(t0) := x(t0) - c is perpendicular to the ellipse.\r\n * * Then 0 = W(t0).x'(t0) = (U cos(t0) + V sin(t0)).(V cos(t0) - U sin(t0)) = U.V cos(2t0) + 0.5 (V.V - U.U) sin(2t0)\r\n * implies tan(2t0) = sin(2t0) / cos(2t0) = 2 U.V / (U.U - V.V), i.e., t0 can be computed given the input dot products.\r\n * Math details can be found at docs/learning/geometry/Angle.md\r\n * @param dotUU dot product of vectorU with itself\r\n * @param dotVV dot product of vectorV with itself\r\n * @param dotUV dot product of vectorU with vectorV\r\n * @param favorZero whether to allow a tight tolerance for returning t0 = 0 (default true).\r\n * When dotUV is near zero, U and V are nearly perpendicular, and the returned angle is near zero.\r\n * @return the angle t0 and its cosine and sine.\r\n */\r\n public static dotProductsToHalfAngleTrigValues(\r\n dotUU: number, dotVV: number, dotUV: number, favorZero: boolean = true,\r\n ): TrigValues {\r\n const cos2t0 = dotUU - dotVV;\r\n const sin2t0 = 2.0 * dotUV;\r\n if (favorZero && Math.abs(sin2t0) < Geometry.smallAngleRadians * (Math.abs(dotUU) + Math.abs(dotVV)))\r\n return { c: 1.0, s: 0.0, radians: 0.0 };\r\n return Angle.trigValuesToHalfAngleTrigValues(cos2t0, sin2t0);\r\n }\r\n /**\r\n * Returns the angle between two vectors, with the vectors given as xyz components\r\n * * The returned angle is between 0 and PI\r\n * @param ux x component of vector u\r\n * @param uy y component of vector u\r\n * @param uz z component of vector u\r\n * @param vx x component of vector v\r\n * @param vy y component of vector v\r\n * @param vz z component of vector v\r\n */\r\n public static radiansBetweenVectorsXYZ(\r\n ux: number, uy: number, uz: number, vx: number, vy: number, vz: number,\r\n ): number {\r\n const uDotV = ux * vx + uy * vy + uz * vz;\r\n return Math.atan2(Geometry.crossProductMagnitude(ux, uy, uz, vx, vy, vz), uDotV);\r\n }\r\n /**\r\n * Returns the angle between two vectors, with the vectors given as xyz components, and an up vector to resolve\r\n * angle to a full 2PI range.\r\n * * The returned angle is (-PI < radians <= PI) or (0 <= radians < 2 * PI)\r\n * * The angle is in the plane of the U and V vectors.\r\n * * The upVector determines a positive side of the plane but need not be strictly perpendicular to the plane.\r\n * @param ux x component of vector u\r\n * @param uy y component of vector u\r\n * @param uz z component of vector u\r\n * @param vx x component of vector v\r\n * @param vy y component of vector v\r\n * @param vz z component of vector v\r\n * @param upVectorX x component of vector to positive side of plane.\r\n * @param upVectorY y component of vector to positive side of plane.\r\n * @param upVectorZ z component of vector to positive side of plane.\r\n * @param adjustToAllPositive if true, return strictly non-negative sweep (0 <= radians < 2*PI). If false, return\r\n * signed (-PI < radians <= PI)\r\n */\r\n public static orientedRadiansBetweenVectorsXYZ(\r\n ux: number, uy: number, uz: number,\r\n vx: number, vy: number, vz: number,\r\n upVectorX: number, upVectorY: number, upVectorZ: number,\r\n adjustToPositive: boolean = false,\r\n ): number {\r\n const uDotV = ux * vx + uy * vy + uz * vz;\r\n const wx = uy * vz - uz * vy;\r\n const wy = uz * vx - ux * vz;\r\n const wz = ux * vy - uy * vx;\r\n const upDotW = upVectorX * wx + upVectorY * wy + upVectorZ * wz;\r\n const crossMagnitude = Geometry.hypotenuseXYZ(wx, wy, wz);\r\n if (upDotW < 0.0) {\r\n if (adjustToPositive) {\r\n // The turn is greater than 180 degrees. Take a peculiarly oriented atan2 to get the excess-180 part as\r\n // addition to PI. This gives the smoothest numerical transition passing PI.\r\n return Math.PI + Math.atan2(crossMagnitude, -uDotV);\r\n } else {\r\n return -Math.atan2(crossMagnitude, uDotV);\r\n }\r\n } else {\r\n return Math.atan2(crossMagnitude, uDotV);\r\n }\r\n }\r\n /**\r\n * Add a multiple of a full circle angle (360 degrees, 2PI) in place.\r\n * @param multiple multiplier factor\r\n */\r\n public addMultipleOf2PiInPlace(multiple: number) {\r\n if (this._degrees !== undefined) {\r\n this._degrees += multiple * 360.0;\r\n this._radians = Angle.degreesToRadians(this._degrees);\r\n } else {\r\n this._radians += multiple * Angle.pi2Radians;\r\n }\r\n }\r\n}\r\n"]}
1
+ {"version":3,"file":"Angle.js","sourceRoot":"","sources":["../../../src/geometry3d/Angle.ts"],"names":[],"mappings":"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","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/** @packageDocumentation\n * @module CartesianGeometry\n */\n\nimport { AngleProps, BeJSONFunctions, Geometry, TrigValues } from \"../Geometry\";\n\n/**\n * An `Angle` carries the numeric value of an angle, with methods to allow (require!) callers to\n * be clear about whether their angle is degrees or radians.\n * * After the Angle object is created, the callers should not know or care whether it is stored in\n * `degrees` or `radians` because both are available if requested by caller.\n * * The various access method are named so that callers can specify whether untyped numbers passed in or\n * out are degrees or radians.\n * * Visualization can be found at https://www.itwinjs.org/sandbox/SaeedTorabi/AngleSweep\n * @public\n */\nexport class Angle implements BeJSONFunctions {\n /** maximal accuracy value of pi/12 (15 degrees), in radians */\n public static readonly piOver12Radians = 0.26179938779914946;\n /** maximal accuracy value of pi/4 (45 degrees), in radians */\n public static readonly piOver4Radians = 7.853981633974483e-001;\n /** maximal accuracy value of pi/2 (90 degrees), in radians */\n public static readonly piOver2Radians = 1.5707963267948966e+000;\n /** maximal accuracy value of pi (180 degrees), in radians */\n public static readonly piRadians = 3.141592653589793e+000;\n /** maximal accuracy value of 3*pi/2 (270 degrees), in radians */\n public static readonly pi3Over2Radians = 4.71238898038469e+000;\n /** maximal accuracy value of 2*pi (360 degrees), in radians */\n public static readonly pi2Radians = 6.283185307179586e+000;\n /** scale factor for converting radians to degrees */\n public static readonly degreesPerRadian = (45.0 / Angle.piOver4Radians);\n /** scale factor for converting degrees to radians */\n public static readonly radiansPerDegree = (Angle.piOver4Radians / 45.0);\n private _radians: number;\n private _degrees?: number;\n private constructor(radians = 0, degrees?: number) {\n this._radians = radians;\n this._degrees = degrees;\n }\n /** Return a new angle with the same content. */\n public clone(): Angle {\n return new Angle(this._radians, this._degrees);\n }\n /** Freeze this instance so it is read-only */\n public freeze(): Readonly<this> {\n return Object.freeze(this);\n }\n /**\n * Return a new Angle object for angle given in degrees.\n * @param degrees angle in degrees\n */\n public static createDegrees(degrees: number): Angle {\n return new Angle(Angle.degreesToRadians(degrees), degrees);\n }\n /**\n * Return a (new) Angle object for a value given in radians.\n * @param radians angle in radians\n */\n public static createRadians(radians: number): Angle {\n return new Angle(radians);\n }\n /**\n * Return a new `Angle` object with the default \"small\" angle measurement specified by [[Geometry.smallAngleRadians]].\n */\n public static createSmallAngle(): Angle {\n return new Angle(Geometry.smallAngleRadians);\n }\n /**\n * Return a (new) Angle object that is interpolated between two inputs (based on a fraction)\n * @param angle0 first angle in radians\n * @param fraction the interpolation fraction\n * @param angle1 second angle in radians\n */\n public static createInterpolate(angle0: Angle, fraction: number, angle1: Angle): Angle {\n return new Angle(Geometry.interpolate(angle0.radians, fraction, angle1.radians));\n }\n /**\n * Return a (new) Angle object, with angle scaled from existing angle.\n * @param scale scale factor to apply to angle.\n */\n public cloneScaled(scale: number): Angle {\n return new Angle(this.radians * scale);\n }\n /**\n * Set this angle to a value given in radians.\n * @param radians angle given in radians\n */\n public setRadians(radians: number) {\n this._radians = radians;\n this._degrees = undefined;\n }\n /**\n * Set this angle to a value given in degrees.\n * @param degrees angle given in degrees.\n */\n public setDegrees(degrees: number) {\n this._radians = Angle.degreesToRadians(degrees);\n this._degrees = degrees;\n }\n /** Create an angle for a full circle. */\n public static create360(): Angle {\n return new Angle(Math.PI * 2.0, 360.0);\n }\n /**\n * Create a (strongly typed) Angle whose tangent is `numerator/denominator`, using the signs of both in\n * determining the (otherwise ambiguous) quadrant.\n * @param numerator numerator for tangent\n * @param denominator denominator for tangent\n */\n public static createAtan2(numerator: number, denominator: number): Angle {\n return new Angle(Math.atan2(numerator, denominator));\n }\n /**\n * Copy all contents of `other` to this Angle.\n * @param other source data\n */\n public setFrom(other: Angle) {\n this._radians = other._radians;\n this._degrees = other._degrees;\n }\n /**\n * Set an Angle from a JSON object\n * * A simple number is considered as degrees.\n * * specified `json.degrees` or `json._degrees` is degree value.\n * * specified `son.radians` or `json._radians` is radians value.\n * @param json object from JSON.parse. If a number, value is in *DEGREES*\n * @param defaultValRadians if json is undefined, default value in radians.\n */\n public setFromJSON(json?: AngleProps, defaultValRadians?: number) {\n this._radians = defaultValRadians ? defaultValRadians : 0;\n if (!json)\n return;\n if (typeof json === \"number\") {\n this.setDegrees(json);\n } else if (typeof (json as any).degrees === \"number\") {\n this.setDegrees((json as any).degrees);\n } else if (typeof (json as any)._degrees === \"number\") {\n this.setDegrees((json as any)._degrees);\n } else if (typeof (json as any).radians === \"number\") {\n this.setRadians((json as any).radians);\n } else if (typeof (json as any)._radians === \"number\") {\n this.setRadians((json as any)._radians);\n }\n }\n /**\n * Create an Angle from a JSON object\n * @param json object from JSON.parse. If a number, value is in *DEGREES*\n * @param defaultValRadians if json is undefined, default value in radians.\n * @return a new Angle\n */\n public static fromJSON(json?: AngleProps, defaultValRadians?: number): Angle {\n const val = new Angle();\n val.setFromJSON(json, defaultValRadians);\n return val;\n }\n /** Convert an Angle to a JSON object as a number in degrees */\n public toJSON(): AngleProps {\n return this.degrees;\n }\n /** Return a json object with radians keyword, e.g. `{ radians: 0.10}` */\n public toJSONRadians(): AngleProps {\n return { radians: this.radians };\n }\n /** Return the angle measured in radians. */\n public get radians(): number {\n return this._radians;\n }\n /** Return the angle measured in degrees. */\n public get degrees(): number {\n return this._degrees !== undefined ? this._degrees : Angle.radiansToDegrees(this._radians);\n }\n /**\n * Convert an angle in degrees to radians.\n * @param degrees angle in degrees\n */\n public static degreesToRadians(degrees: number): number {\n return degrees * Math.PI / 180;\n }\n /**\n * Convert an angle in radians to degrees.\n * @param degrees angle in radians\n */\n public static radiansToDegrees(radians: number): number {\n if (radians < 0)\n return -Angle.radiansToDegrees(-radians);\n // Now radians is positive ...\n const pi = Math.PI;\n const factor = 180.0 / pi;\n /* the following if statements are for round-off reasons. The problem is that no IEEE number is\n * an exact hit for any primary multiple of pi (90, 180, etc). The following is supposed to have\n * a better chance that if the input was computed by direct assignment from 90, 180, etc degrees\n * it will return exactly 90,180 etc.\n */\n if (radians <= 0.25 * pi)\n return factor * radians;\n if (radians < 0.75 * pi)\n return 90.0 + 180 * ((radians - 0.5 * pi) / pi);\n if (radians <= 1.25 * pi)\n return 180.0 + 180 * ((radians - pi) / pi);\n if (radians <= 1.75 * pi)\n return 270.0 + 180 * ((radians - 1.5 * pi) / pi);\n // all larger radians reference from 360 degrees (2PI)\n return 360.0 + 180 * ((radians - 2.0 * pi) / pi);\n }\n /** Return the cosine of this Angle object's angle */\n public cos(): number {\n return Math.cos(this._radians);\n }\n /** Return the sine of this Angle object's angle */\n public sin(): number {\n return Math.sin(this._radians);\n }\n /** Return the tangent of this Angle object's angle */\n public tan(): number {\n return Math.tan(this._radians);\n }\n /** Test if a radians (absolute) value is nearly 2PI or larger. */\n public static isFullCircleRadians(radians: number): boolean {\n return Math.abs(radians) >= Geometry.fullCircleRadiansMinusSmallAngle;\n }\n /** Test if the radians value is a half circle */\n public static isHalfCircleRadians(radians: number): boolean {\n return Math.abs(Math.abs(radians) - Math.PI) <= Geometry.smallAngleRadians;\n }\n /** Test if the angle is a full circle */\n public get isFullCircle(): boolean {\n return Angle.isFullCircleRadians(this._radians);\n }\n /** Test if the angle is a half circle (in either direction) */\n public get isHalfCircle(): boolean {\n return Angle.isHalfCircleRadians(this._radians);\n }\n /**\n * Adjust a degrees value so it is in [0, 360].\n * * Positive multiples of 360 return 0; negative multiples return 360.\n */\n public static adjustDegrees0To360(degrees: number): number {\n if (degrees >= 0) {\n const period = 360.0;\n if (degrees < period)\n return degrees;\n const numPeriods = Math.floor(degrees / period);\n return degrees - numPeriods * period;\n } else if (degrees < 0) {\n // negative angle ...\n return 360.0 - Angle.adjustDegrees0To360(-degrees);\n }\n // fall through for Nan (disaster) !!!\n return 0;\n }\n /** Adjust a degrees value so it is in [-180, 180]. */\n public static adjustDegreesSigned180(degrees: number): number {\n if (Math.abs(degrees) <= 180.0)\n return degrees;\n if (degrees >= 0) {\n const period = 360.0;\n const numPeriods = 1 + Math.floor((degrees - 180.0) / period);\n return degrees - numPeriods * period;\n } else if (degrees < 0) {\n // negative angle ...\n return -Angle.adjustDegreesSigned180(-degrees);\n }\n // fall through for NaN disaster.\n return 0;\n }\n /**\n * Adjust a radians value so it is in [0, 2pi].\n * * Nonnegative multiples of 2pi return 0; negative multiples return 2pi.\n */\n public static adjustRadians0To2Pi(radians: number): number {\n if (radians >= 0) {\n const period = Math.PI * 2.0;\n if (radians < period)\n return radians;\n const numPeriods = Math.floor(radians / period);\n return radians - numPeriods * period;\n } else if (radians < 0) {\n // negative angle ...\n return Math.PI * 2.0 - Angle.adjustRadians0To2Pi(-radians);\n }\n // fall through for NaN disaster.\n return 0;\n }\n /**\n * Adjust a radians value so it is in [0, 2pi).\n * * All multiples of 2pi (within `Geometry.smallAngleRadians`) return 0.\n */\n public static adjustRadians0ToLessThan2Pi(radians: number): number {\n if (Angle.isAlmostEqualRadiansAllowPeriodShift(radians, 0))\n radians = 0;\n return this.adjustRadians0To2Pi(radians);\n }\n /** Adjust a radians value so it is in [-pi, pi] */\n public static adjustRadiansMinusPiPlusPi(radians: number): number {\n if (Math.abs(radians) <= Math.PI)\n return radians;\n if (radians >= 0) {\n const period = Math.PI * 2.0;\n const numPeriods = 1 + Math.floor((radians - Math.PI) / period);\n return radians - numPeriods * period;\n } else if (radians < 0) {\n // negative angle ...\n return -Angle.adjustRadiansMinusPiPlusPi(-radians);\n }\n // fall through for NaN disaster.\n return 0;\n }\n /** Return a (newly allocated) Angle object with value 0 radians */\n public static zero(): Angle {\n return new Angle(0);\n }\n /** Test if the angle is exactly zero. */\n public get isExactZero(): boolean {\n return this.radians === 0;\n }\n /** Test if the angle is almost zero (within tolerance `Geometry.smallAngleRadians`) */\n public get isAlmostZero(): boolean {\n return Math.abs(this.radians) < Geometry.smallAngleRadians;\n }\n /** Test if the angle is almost a north or south pole (within tolerance `Geometry.smallAngleRadians`) */\n public get isAlmostNorthOrSouthPole(): boolean {\n return Angle.isHalfCircleRadians(this.radians * 2.0);\n }\n /** Create an angle object with degrees adjusted into 0..360. */\n public static createDegreesAdjustPositive(degrees: number): Angle {\n return Angle.createDegrees(Angle.adjustDegrees0To360(degrees));\n }\n /** Create an angle object with degrees adjusted into -180..180. */\n public static createDegreesAdjustSigned180(degrees: number): Angle {\n return Angle.createDegrees(Angle.adjustDegreesSigned180(degrees));\n }\n /**\n * Test if two radian values are equivalent, allowing shift by full circle (i.e. by a multiple of `2*PI`)\n * @param radiansA first radians value\n * @param radiansB second radians value\n * @param radianTol radian tolerance with default value of Geometry.smallAngleRadians\n */\n public static isAlmostEqualRadiansAllowPeriodShift(radiansA: number, radiansB: number,\n radianTol: number = Geometry.smallAngleRadians): boolean {\n const delta = Math.abs(radiansA - radiansB);\n if (delta <= radianTol)\n return true;\n const period = Math.PI * 2.0;\n if (Math.abs(delta - period) <= radianTol)\n return true;\n const numPeriod = Math.round(delta / period);\n const delta1 = delta - numPeriod * period;\n return Math.abs(delta1) <= radianTol;\n }\n /**\n * Test if this angle has magnitude no greater than that of `other`.\n * @param other the other angle\n */\n public isMagnitudeLessThanOrEqual(other: Angle): boolean {\n return Math.abs(this.radians) <= Math.abs(other.radians);\n }\n\n /**\n * Test if this angle and `other` are equivalent, allowing shift by full circle (i.e., multiples of `2 * PI`).\n * @param other the other angle\n * @param radianTol radian tolerance with default value of Geometry.smallAngleRadians\n */\n public isAlmostEqualAllowPeriodShift(other: Angle, radianTol: number = Geometry.smallAngleRadians): boolean {\n return Angle.isAlmostEqualRadiansAllowPeriodShift(this._radians, other._radians, radianTol);\n }\n /**\n * Test if two angles (in radians) are almost equal, NOT allowing shift by full circle (i.e., multiples of `2 * PI`).\n * @param radiansA first radians value\n * @param radiansB second radians value\n * @param radianTol radian tolerance with default value of Geometry.smallAngleRadians\n */\n public static isAlmostEqualRadiansNoPeriodShift(radiansA: number, radiansB: number,\n radianTol: number = Geometry.smallAngleRadians): boolean {\n return Math.abs(radiansA - radiansB) < radianTol;\n }\n /**\n * Test if this angle and `other` are almost equal, NOT allowing shift by full circle (i.e., multiples of `2 * PI`).\n * @param other the other angle\n * @param radianTol radian tolerance with default value of Geometry.smallAngleRadians\n */\n public isAlmostEqualNoPeriodShift(other: Angle, radianTol: number = Geometry.smallAngleRadians): boolean {\n return Angle.isAlmostEqualRadiansNoPeriodShift(this._radians, other._radians, radianTol);\n }\n /**\n * Test if this angle and `other` are almost equal, NOT allowing shift by full circle (i.e., multiples of `2 * PI`).\n * * This function is same as isAlmostEqualRadiansNoPeriodShift. Please use isAlmostEqualRadiansNoPeriodShift.\n * @param other the other angle\n * @param radianTol radian tolerance with default value of Geometry.smallAngleRadians\n */\n public isAlmostEqual(other: Angle, radianTol: number = Geometry.smallAngleRadians): boolean {\n return this.isAlmostEqualNoPeriodShift(other, radianTol);\n }\n /**\n * Test if dot product values indicate non-zero length perpendicular vectors.\n * @param dotUU dot product of vectorU with itself\n * @param dotVV dot product of vectorV with itself\n * @param dotUV dot product of vectorU with vectorV\n */\n public static isPerpendicularDotSet(dotUU: number, dotVV: number, dotUV: number): boolean {\n return dotUU > Geometry.smallMetricDistanceSquared\n && dotVV > Geometry.smallMetricDistanceSquared\n && dotUV * dotUV <= Geometry.smallAngleRadiansSquared * dotUU * dotVV;\n }\n /**\n * Compute the angle A given r*cos(2A) and r*sin(2A) for some nonnegative scalar r.\n * * This function assumes the input arguments are related to an angle between -PI and PI.\n * * This function returns an angle between -PI and PI.\n * @param rCos2A scaled cosine value of twice the angle A.\n * @param rSin2A scaled sine value of twice the angle A.\n * @return cos(A), sin(A) and A in radians\n */\n public static trigValuesToHalfAngleTrigValues(rCos2A: number, rSin2A: number): TrigValues {\n const r = Geometry.hypotenuseXY(rCos2A, rSin2A);\n if (r < Geometry.smallMetricDistance) {\n return { c: 1.0, s: 0.0, radians: 0.0 }; // angle = 0\n } else {\n /* If the caller really gave you sine and cosine values, r should be 1. However,\n * to allow scaled values -- e.g. the x and y components of any vector -- we normalize\n * right here. This adds an extra sqrt and two divisions, but improves\n * both the usefulness and robustness of the computation.\n */\n let cosA;\n let sinA = 0.0;\n const cos2A = rCos2A / r;\n const sin2A = rSin2A / r;\n if (cos2A >= 0.0) { // 2A is in NE and SE quadrants, A in same quadrant\n cosA = Math.sqrt(0.5 * (1.0 + cos2A)); // half angle formula. Use +root since cosA >= 0\n sinA = sin2A / (2.0 * cosA); // double angle formula\n } else {\n if (sin2A > 0.0) { // 2A in NW quadrant. A in NE quadrant\n sinA = Math.sqrt(0.5 * (1.0 - cos2A)); // half angle formula. Use +root since sinA > 0\n } else { // 2A in SW quadrant. A in SE quadrant\n sinA = -Math.sqrt(0.5 * (1.0 - cos2A)); // half angle formula. Use -root since sinA <= 0\n }\n cosA = sin2A / (2.0 * sinA); // double angle formula\n }\n return { c: cosA, s: sinA, radians: Math.atan2(sinA, cosA) };\n }\n }\n /** If value is close to -1, -0.5, 0, 0.5, 1, adjust it to the exact value. */\n public static cleanupTrigValue(value: number, tolerance: number = Geometry.smallFloatingPoint): number {\n const absValue = Math.abs(value);\n if (absValue <= tolerance)\n return 0;\n let a = Math.abs(absValue - 0.5);\n if (a <= tolerance)\n return value < 0.0 ? -0.5 : 0.5;\n a = Math.abs(absValue - 1.0);\n if (a <= tolerance)\n return value < 0.0 ? -1.0 : 1.0;\n return value;\n }\n /**\n * Return the half angle cosine, sine, and radians for the given vector dot products.\n * * These values arise e.g. in the computation performed in `Arc3d.toScaledMatrix3d`.\n * * Let vectors U and V define the ellipse x(t) = c + U cos(t) + V sin(t). We seek an angle t0\n * such that the radial vector W(t0) := x(t0) - c is perpendicular to the ellipse.\n * * Then 0 = W(t0).x'(t0) = (U cos(t0) + V sin(t0)).(V cos(t0) - U sin(t0)) = U.V cos(2t0) + 0.5 (V.V - U.U) sin(2t0)\n * implies tan(2t0) = sin(2t0) / cos(2t0) = 2 U.V / (U.U - V.V), i.e., t0 can be computed given the input dot products.\n * Math details can be found at docs/learning/geometry/Angle.md\n * @param dotUU dot product of vectorU with itself\n * @param dotVV dot product of vectorV with itself\n * @param dotUV dot product of vectorU with vectorV\n * @param favorZero whether to allow a tight tolerance for returning t0 = 0 (default true).\n * When dotUV is near zero, U and V are nearly perpendicular, and the returned angle is near zero.\n * @return the angle t0 and its cosine and sine.\n */\n public static dotProductsToHalfAngleTrigValues(\n dotUU: number, dotVV: number, dotUV: number, favorZero: boolean = true,\n ): TrigValues {\n const cos2t0 = dotUU - dotVV;\n const sin2t0 = 2.0 * dotUV;\n if (favorZero && Math.abs(sin2t0) < Geometry.smallAngleRadians * (Math.abs(dotUU) + Math.abs(dotVV)))\n return { c: 1.0, s: 0.0, radians: 0.0 };\n return Angle.trigValuesToHalfAngleTrigValues(cos2t0, sin2t0);\n }\n /**\n * Returns the angle between two vectors, with the vectors given as xyz components\n * * The returned angle is between 0 and PI\n * @param ux x component of vector u\n * @param uy y component of vector u\n * @param uz z component of vector u\n * @param vx x component of vector v\n * @param vy y component of vector v\n * @param vz z component of vector v\n */\n public static radiansBetweenVectorsXYZ(\n ux: number, uy: number, uz: number, vx: number, vy: number, vz: number,\n ): number {\n const uDotV = ux * vx + uy * vy + uz * vz;\n return Math.atan2(Geometry.crossProductMagnitude(ux, uy, uz, vx, vy, vz), uDotV);\n }\n /**\n * Returns the angle between two vectors, with the vectors given as xyz components, and an up vector to resolve\n * angle to a full 2PI range.\n * * The returned angle is (-PI < radians <= PI) or (0 <= radians < 2 * PI)\n * * The angle is in the plane of the U and V vectors.\n * * The upVector determines a positive side of the plane but need not be strictly perpendicular to the plane.\n * @param ux x component of vector u\n * @param uy y component of vector u\n * @param uz z component of vector u\n * @param vx x component of vector v\n * @param vy y component of vector v\n * @param vz z component of vector v\n * @param upVectorX x component of vector to positive side of plane.\n * @param upVectorY y component of vector to positive side of plane.\n * @param upVectorZ z component of vector to positive side of plane.\n * @param adjustToAllPositive if true, return strictly non-negative sweep (0 <= radians < 2*PI). If false, return\n * signed (-PI < radians <= PI)\n */\n public static orientedRadiansBetweenVectorsXYZ(\n ux: number, uy: number, uz: number,\n vx: number, vy: number, vz: number,\n upVectorX: number, upVectorY: number, upVectorZ: number,\n adjustToPositive: boolean = false,\n ): number {\n const uDotV = ux * vx + uy * vy + uz * vz;\n const wx = uy * vz - uz * vy;\n const wy = uz * vx - ux * vz;\n const wz = ux * vy - uy * vx;\n const upDotW = upVectorX * wx + upVectorY * wy + upVectorZ * wz;\n const crossMagnitude = Geometry.hypotenuseXYZ(wx, wy, wz);\n if (upDotW < 0.0) {\n if (adjustToPositive) {\n // The turn is greater than 180 degrees. Take a peculiarly oriented atan2 to get the excess-180 part as\n // addition to PI. This gives the smoothest numerical transition passing PI.\n return Math.PI + Math.atan2(crossMagnitude, -uDotV);\n } else {\n return -Math.atan2(crossMagnitude, uDotV);\n }\n } else {\n return Math.atan2(crossMagnitude, uDotV);\n }\n }\n /**\n * Add a multiple of a full circle angle (360 degrees, 2PI) in place.\n * @param multiple multiplier factor\n */\n public addMultipleOf2PiInPlace(multiple: number) {\n if (this._degrees !== undefined) {\n this._degrees += multiple * 360.0;\n this._radians = Angle.degreesToRadians(this._degrees);\n } else {\n this._radians += multiple * Angle.pi2Radians;\n }\n }\n}\n"]}
@@ -99,9 +99,14 @@ export declare class AngleSweep implements BeJSONFunctions {
99
99
  * @param reverseDirection true to move backwards (CW) from start to end, false to more forwards (CCW) from start to end.
100
100
  */
101
101
  cloneComplement(reverseDirection?: boolean, result?: AngleSweep): AngleSweep;
102
- /** Restrict start and end angles into the range (-90,+90) in degrees */
102
+ /** Restrict start and end angles to the degree range [-90,+90]. */
103
103
  capLatitudeInPlace(): void;
104
- /** Ask if the sweep is counterclockwise, i.e. positive sweep */
104
+ /**
105
+ * Restrict [[sweepDegrees]] to the range [-360, 360].
106
+ * The start angle and sign of the sweep angle are unchanged.
107
+ */
108
+ clampToFullCircle(result?: AngleSweep): AngleSweep;
109
+ /** Ask if the sweep is counterclockwise, i.e. positive sweep. */
105
110
  get isCCW(): boolean;
106
111
  /** Ask if the sweep is a full circle. */
107
112
  get isFullCircle(): boolean;
@@ -114,7 +119,7 @@ export declare class AngleSweep implements BeJSONFunctions {
114
119
  /** Convert fractional position in the sweep to strongly typed Angle object. */
115
120
  fractionToAngle(fraction: number): Angle;
116
121
  /**
117
- * Return 2PI divided by the sweep radians (i.e. 360 degrees divided by sweep angle).
122
+ * Return 2PI divided by the sweep radians.
118
123
  * * This is the number of fractional intervals required to cover a whole circle.
119
124
  * @returns period of the sweep, or 1 if sweep is empty.
120
125
  */
@@ -1 +1 @@
1
- {"version":3,"file":"AngleSweep.d.ts","sourceRoot":"","sources":["../../../src/geometry3d/AngleSweep.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"AngleSweep.d.ts","sourceRoot":"","sources":["../../../src/geometry3d/AngleSweep.ts"],"names":[],"mappings":"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"}
@@ -24,6 +24,8 @@ import { Angle } from "./Angle";
24
24
  * @public
25
25
  */
26
26
  export class AngleSweep {
27
+ _radians0;
28
+ _radians1;
27
29
  /** Read-property for degrees at the start of this AngleSweep. */
28
30
  get startDegrees() {
29
31
  return Angle.radiansToDegrees(this._radians0);
@@ -34,7 +36,7 @@ export class AngleSweep {
34
36
  }
35
37
  /** Read-property for signed start-to-end sweep in degrees. */
36
38
  get sweepDegrees() {
37
- return Angle.radiansToDegrees(this._radians1 - this._radians0);
39
+ return Angle.radiansToDegrees(this.sweepRadians);
38
40
  }
39
41
  /** Read-property for degrees at the start of this AngleSweep. */
40
42
  get startRadians() {
@@ -176,13 +178,23 @@ export class AngleSweep {
176
178
  else
177
179
  return AngleSweep.createStartEndRadians(this.endRadians, this.startRadians + s * Math.PI, result);
178
180
  }
179
- /** Restrict start and end angles into the range (-90,+90) in degrees */
181
+ /** Restrict start and end angles to the degree range [-90,+90]. */
180
182
  capLatitudeInPlace() {
181
183
  const limit = 0.5 * Math.PI;
182
184
  this._radians0 = Geometry.clampToStartEnd(this._radians0, -limit, limit);
183
185
  this._radians1 = Geometry.clampToStartEnd(this._radians1, -limit, limit);
184
186
  }
185
- /** Ask if the sweep is counterclockwise, i.e. positive sweep */
187
+ /**
188
+ * Restrict [[sweepDegrees]] to the range [-360, 360].
189
+ * The start angle and sign of the sweep angle are unchanged.
190
+ */
191
+ clampToFullCircle(result) {
192
+ result = result ?? new AngleSweep();
193
+ const sweepRadians = Geometry.clampToStartEnd(this.sweepRadians, -Angle.pi2Radians, Angle.pi2Radians);
194
+ result.setStartEndRadians(this._radians0, this._radians0 + sweepRadians);
195
+ return result;
196
+ }
197
+ /** Ask if the sweep is counterclockwise, i.e. positive sweep. */
186
198
  get isCCW() {
187
199
  return this._radians1 >= this._radians0;
188
200
  }
@@ -203,20 +215,20 @@ export class AngleSweep {
203
215
  /** Convert fractional position in the sweep to radians. */
204
216
  fractionToRadians(fraction) {
205
217
  return fraction < 0.5 ?
206
- this._radians0 + fraction * (this._radians1 - this._radians0) :
207
- this._radians1 + (fraction - 1.0) * (this._radians1 - this._radians0);
218
+ this._radians0 + fraction * this.sweepRadians :
219
+ this._radians1 + (fraction - 1.0) * this.sweepRadians;
208
220
  }
209
221
  /** Convert fractional position in the sweep to strongly typed Angle object. */
210
222
  fractionToAngle(fraction) {
211
223
  return Angle.createRadians(this.fractionToRadians(fraction));
212
224
  }
213
225
  /**
214
- * Return 2PI divided by the sweep radians (i.e. 360 degrees divided by sweep angle).
226
+ * Return 2PI divided by the sweep radians.
215
227
  * * This is the number of fractional intervals required to cover a whole circle.
216
228
  * @returns period of the sweep, or 1 if sweep is empty.
217
229
  */
218
230
  fractionPeriod() {
219
- return this.isEmpty ? 1.0 : Angle.pi2Radians / Math.abs(this._radians1 - this._radians0);
231
+ return this.isEmpty ? 1.0 : Angle.pi2Radians / Math.abs(this.sweepRadians);
220
232
  }
221
233
  /**
222
234
  * Return the fractionalized position of the given angle (as Angle) computed without consideration of
@@ -232,7 +244,7 @@ export class AngleSweep {
232
244
  * @returns unbounded fraction, or 1 if sweep is empty.
233
245
  */
234
246
  angleToUnboundedFraction(theta) {
235
- return this.isEmpty ? 1.0 : (theta.radians - this._radians0) / (this._radians1 - this._radians0);
247
+ return this.isEmpty ? 1.0 : (theta.radians - this._radians0) / this.sweepRadians;
236
248
  }
237
249
  /**
238
250
  * Convert a sweep fraction to the equivalent period-shifted fraction inside the sweep, or within one period of zero
@@ -526,7 +538,7 @@ export class AngleSweep {
526
538
  isAlmostEqualAllowPeriodShift(other, radianTol = Geometry.smallAngleRadians) {
527
539
  return this.isCCW === other.isCCW // this rules out equating opposite sweeps like [0,-100] and [0,260]
528
540
  && Angle.isAlmostEqualRadiansAllowPeriodShift(this._radians0, other._radians0, radianTol)
529
- && Angle.isAlmostEqualRadiansAllowPeriodShift(this._radians1 - this._radians0, other._radians1 - other._radians0, radianTol);
541
+ && Angle.isAlmostEqualRadiansAllowPeriodShift(this.sweepRadians, other.sweepRadians, radianTol);
530
542
  }
531
543
  /**
532
544
  * Test if two angle sweeps match within the given tolerance.
@@ -536,7 +548,7 @@ export class AngleSweep {
536
548
  */
537
549
  isAlmostEqualNoPeriodShift(other, radianTol = Geometry.smallAngleRadians) {
538
550
  return Angle.isAlmostEqualRadiansNoPeriodShift(this._radians0, other._radians0, radianTol)
539
- && Angle.isAlmostEqualRadiansNoPeriodShift(this._radians1 - this._radians0, other._radians1 - other._radians0, radianTol);
551
+ && Angle.isAlmostEqualRadiansNoPeriodShift(this.sweepRadians, other.sweepRadians, radianTol);
540
552
  }
541
553
  /**
542
554
  * Test if start and end angles match with radians tolerance.