@itwin/core-geometry 4.6.0-dev.21 → 4.6.0-dev.23

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 (508) hide show
  1. package/lib/cjs/Constant.js +1 -1
  2. package/lib/cjs/Constant.js.map +1 -1
  3. package/lib/cjs/Geometry.d.ts +1 -1
  4. package/lib/cjs/Geometry.d.ts.map +1 -1
  5. package/lib/cjs/Geometry.js +6 -6
  6. package/lib/cjs/Geometry.js.map +1 -1
  7. package/lib/cjs/bspline/AkimaCurve3d.js.map +1 -1
  8. package/lib/cjs/bspline/BSpline1dNd.js.map +1 -1
  9. package/lib/cjs/bspline/BSplineCurve.js.map +1 -1
  10. package/lib/cjs/bspline/BSplineCurve3dH.js.map +1 -1
  11. package/lib/cjs/bspline/BSplineCurveOps.js +1 -1
  12. package/lib/cjs/bspline/BSplineCurveOps.js.map +1 -1
  13. package/lib/cjs/bspline/BSplineSurface.js +4 -4
  14. package/lib/cjs/bspline/BSplineSurface.js.map +1 -1
  15. package/lib/cjs/bspline/Bezier1dNd.js.map +1 -1
  16. package/lib/cjs/bspline/BezierCurve3d.js.map +1 -1
  17. package/lib/cjs/bspline/BezierCurve3dH.js.map +1 -1
  18. package/lib/cjs/bspline/BezierCurveBase.js.map +1 -1
  19. package/lib/cjs/bspline/InterpolationCurve3d.js.map +1 -1
  20. package/lib/cjs/bspline/KnotVector.js +2 -2
  21. package/lib/cjs/bspline/KnotVector.js.map +1 -1
  22. package/lib/cjs/clipping/AlternatingConvexClipTree.js +1 -1
  23. package/lib/cjs/clipping/AlternatingConvexClipTree.js.map +1 -1
  24. package/lib/cjs/clipping/BooleanClipFactory.d.ts +1 -1
  25. package/lib/cjs/clipping/BooleanClipFactory.d.ts.map +1 -1
  26. package/lib/cjs/clipping/BooleanClipFactory.js.map +1 -1
  27. package/lib/cjs/clipping/BooleanClipNode.js.map +1 -1
  28. package/lib/cjs/clipping/ClipPlane.js +1 -1
  29. package/lib/cjs/clipping/ClipPlane.js.map +1 -1
  30. package/lib/cjs/clipping/ClipPrimitive.js +1 -1
  31. package/lib/cjs/clipping/ClipPrimitive.js.map +1 -1
  32. package/lib/cjs/clipping/ClipUtils.js +4 -4
  33. package/lib/cjs/clipping/ClipUtils.js.map +1 -1
  34. package/lib/cjs/clipping/ClipVector.js +2 -2
  35. package/lib/cjs/clipping/ClipVector.js.map +1 -1
  36. package/lib/cjs/clipping/ConvexClipPlaneSet.js +1 -1
  37. package/lib/cjs/clipping/ConvexClipPlaneSet.js.map +1 -1
  38. package/lib/cjs/clipping/UnionOfConvexClipPlaneSets.js +1 -1
  39. package/lib/cjs/clipping/UnionOfConvexClipPlaneSets.js.map +1 -1
  40. package/lib/cjs/clipping/internalContexts/LineStringOffsetClipperContext.js.map +1 -1
  41. package/lib/cjs/curve/Arc3d.js +1 -1
  42. package/lib/cjs/curve/Arc3d.js.map +1 -1
  43. package/lib/cjs/curve/ConstructCurveBetweenCurves.js.map +1 -1
  44. package/lib/cjs/curve/CurveChainWithDistanceIndex.js +1 -1
  45. package/lib/cjs/curve/CurveChainWithDistanceIndex.js.map +1 -1
  46. package/lib/cjs/curve/CurveCollection.js.map +1 -1
  47. package/lib/cjs/curve/CurveCurve.js.map +1 -1
  48. package/lib/cjs/curve/CurveExtendMode.js +1 -1
  49. package/lib/cjs/curve/CurveExtendMode.js.map +1 -1
  50. package/lib/cjs/curve/CurveFactory.js +1 -1
  51. package/lib/cjs/curve/CurveFactory.js.map +1 -1
  52. package/lib/cjs/curve/CurveLocationDetail.js +3 -3
  53. package/lib/cjs/curve/CurveLocationDetail.js.map +1 -1
  54. package/lib/cjs/curve/CurveOps.js.map +1 -1
  55. package/lib/cjs/curve/CurvePrimitive.js.map +1 -1
  56. package/lib/cjs/curve/CurveProcessor.js.map +1 -1
  57. package/lib/cjs/curve/CurveWireMomentsXYZ.js.map +1 -1
  58. package/lib/cjs/curve/GeometryQuery.js.map +1 -1
  59. package/lib/cjs/curve/LineSegment3d.js.map +1 -1
  60. package/lib/cjs/curve/LineString3d.js +1 -1
  61. package/lib/cjs/curve/LineString3d.js.map +1 -1
  62. package/lib/cjs/curve/Loop.js.map +1 -1
  63. package/lib/cjs/curve/OffsetOptions.js.map +1 -1
  64. package/lib/cjs/curve/ParityRegion.js.map +1 -1
  65. package/lib/cjs/curve/Path.js.map +1 -1
  66. package/lib/cjs/curve/PointString3d.js.map +1 -1
  67. package/lib/cjs/curve/Query/ConsolidateAdjacentPrimitivesContext.js.map +1 -1
  68. package/lib/cjs/curve/Query/CurveSplitContext.js.map +1 -1
  69. package/lib/cjs/curve/Query/CylindricalRange.js.map +1 -1
  70. package/lib/cjs/curve/Query/InOutTests.js.map +1 -1
  71. package/lib/cjs/curve/Query/PlanarSubdivision.js.map +1 -1
  72. package/lib/cjs/curve/Query/StrokeCountChain.js.map +1 -1
  73. package/lib/cjs/curve/Query/StrokeCountMap.js.map +1 -1
  74. package/lib/cjs/curve/RegionMomentsXY.js.map +1 -1
  75. package/lib/cjs/curve/RegionOps.js +1 -1
  76. package/lib/cjs/curve/RegionOps.js.map +1 -1
  77. package/lib/cjs/curve/RegionOpsClassificationSweeps.js +2 -2
  78. package/lib/cjs/curve/RegionOpsClassificationSweeps.js.map +1 -1
  79. package/lib/cjs/curve/StrokeOptions.js.map +1 -1
  80. package/lib/cjs/curve/UnionRegion.js.map +1 -1
  81. package/lib/cjs/curve/internalContexts/AppendPlaneIntersectionStrokeHandler.js.map +1 -1
  82. package/lib/cjs/curve/internalContexts/ChainCollectorContext.js.map +1 -1
  83. package/lib/cjs/curve/internalContexts/CloneCurvesContext.js.map +1 -1
  84. package/lib/cjs/curve/internalContexts/CloneWithExpandedLineStrings.js.map +1 -1
  85. package/lib/cjs/curve/internalContexts/ClosestPointStrokeHandler.js.map +1 -1
  86. package/lib/cjs/curve/internalContexts/CurveCurveCloseApproachXY.js +1 -1
  87. package/lib/cjs/curve/internalContexts/CurveCurveCloseApproachXY.js.map +1 -1
  88. package/lib/cjs/curve/internalContexts/CurveCurveIntersectXY.js +1 -1
  89. package/lib/cjs/curve/internalContexts/CurveCurveIntersectXY.js.map +1 -1
  90. package/lib/cjs/curve/internalContexts/CurveCurveIntersectXYZ.js +1 -1
  91. package/lib/cjs/curve/internalContexts/CurveCurveIntersectXYZ.js.map +1 -1
  92. package/lib/cjs/curve/internalContexts/CurveLengthContext.js.map +1 -1
  93. package/lib/cjs/curve/internalContexts/CurveOffsetXYHandler.js.map +1 -1
  94. package/lib/cjs/curve/internalContexts/GapSearchContext.js.map +1 -1
  95. package/lib/cjs/curve/internalContexts/MultiChainCollector.js.map +1 -1
  96. package/lib/cjs/curve/internalContexts/PlaneAltitudeRangeContext.js.map +1 -1
  97. package/lib/cjs/curve/internalContexts/PolygonOffsetContext.js +1 -1
  98. package/lib/cjs/curve/internalContexts/PolygonOffsetContext.js.map +1 -1
  99. package/lib/cjs/curve/spiral/AustralianRailCorpXYEvaluator.js.map +1 -1
  100. package/lib/cjs/curve/spiral/ClothoidSeries.js.map +1 -1
  101. package/lib/cjs/curve/spiral/CzechSpiralEvaluator.js.map +1 -1
  102. package/lib/cjs/curve/spiral/DirectHalfCosineSpiralEvaluator.js.map +1 -1
  103. package/lib/cjs/curve/spiral/DirectSpiral3d.js.map +1 -1
  104. package/lib/cjs/curve/spiral/IntegratedSpiral3d.js +1 -1
  105. package/lib/cjs/curve/spiral/IntegratedSpiral3d.js.map +1 -1
  106. package/lib/cjs/curve/spiral/MXCubicAlongArcSpiralEvaluator.js.map +1 -1
  107. package/lib/cjs/curve/spiral/PolishCubicSpiralEvaluator.js.map +1 -1
  108. package/lib/cjs/curve/spiral/TransitionConditionalProperties.js.map +1 -1
  109. package/lib/cjs/curve/spiral/TransitionSpiral3d.js.map +1 -1
  110. package/lib/cjs/curve/spiral/XYCurveEvaluator.js.map +1 -1
  111. package/lib/cjs/geometry3d/Angle.js +1 -1
  112. package/lib/cjs/geometry3d/Angle.js.map +1 -1
  113. package/lib/cjs/geometry3d/AngleSweep.js.map +1 -1
  114. package/lib/cjs/geometry3d/BarycentricTriangle.js.map +1 -1
  115. package/lib/cjs/geometry3d/BilinearPatch.js.map +1 -1
  116. package/lib/cjs/geometry3d/CoincidentGeometryOps.js.map +1 -1
  117. package/lib/cjs/geometry3d/Ellipsoid.js.map +1 -1
  118. package/lib/cjs/geometry3d/FrameBuilder.js.map +1 -1
  119. package/lib/cjs/geometry3d/FrustumAnimation.js.map +1 -1
  120. package/lib/cjs/geometry3d/GeometryHandler.js.map +1 -1
  121. package/lib/cjs/geometry3d/GrowableBlockedArray.js.map +1 -1
  122. package/lib/cjs/geometry3d/GrowableFloat64Array.js.map +1 -1
  123. package/lib/cjs/geometry3d/GrowableXYArray.js.map +1 -1
  124. package/lib/cjs/geometry3d/GrowableXYZArray.js.map +1 -1
  125. package/lib/cjs/geometry3d/IndexedCollectionInterval.js.map +1 -1
  126. package/lib/cjs/geometry3d/IndexedXYCollection.js.map +1 -1
  127. package/lib/cjs/geometry3d/IndexedXYZCollection.js.map +1 -1
  128. package/lib/cjs/geometry3d/LongitudeLatitudeAltitude.js.map +1 -1
  129. package/lib/cjs/geometry3d/Matrix3d.js +2 -2
  130. package/lib/cjs/geometry3d/Matrix3d.js.map +1 -1
  131. package/lib/cjs/geometry3d/OrderedRotationAngles.js +1 -1
  132. package/lib/cjs/geometry3d/OrderedRotationAngles.js.map +1 -1
  133. package/lib/cjs/geometry3d/Plane3dByOriginAndUnitNormal.js.map +1 -1
  134. package/lib/cjs/geometry3d/Plane3dByOriginAndVectors.js.map +1 -1
  135. package/lib/cjs/geometry3d/Point2dArrayCarrier.js.map +1 -1
  136. package/lib/cjs/geometry3d/Point2dVector2d.js.map +1 -1
  137. package/lib/cjs/geometry3d/Point3dArrayCarrier.js.map +1 -1
  138. package/lib/cjs/geometry3d/Point3dVector3d.js.map +1 -1
  139. package/lib/cjs/geometry3d/PointHelpers.js +2 -2
  140. package/lib/cjs/geometry3d/PointHelpers.js.map +1 -1
  141. package/lib/cjs/geometry3d/PointStreaming.js.map +1 -1
  142. package/lib/cjs/geometry3d/PolygonOps.js +3 -3
  143. package/lib/cjs/geometry3d/PolygonOps.js.map +1 -1
  144. package/lib/cjs/geometry3d/PolylineCompressionByEdgeOffset.js +1 -1
  145. package/lib/cjs/geometry3d/PolylineCompressionByEdgeOffset.js.map +1 -1
  146. package/lib/cjs/geometry3d/PolylineOps.js.map +1 -1
  147. package/lib/cjs/geometry3d/Range.js +1 -1
  148. package/lib/cjs/geometry3d/Range.js.map +1 -1
  149. package/lib/cjs/geometry3d/Ray2d.js.map +1 -1
  150. package/lib/cjs/geometry3d/Ray3d.js.map +1 -1
  151. package/lib/cjs/geometry3d/ReusableObjectCache.js.map +1 -1
  152. package/lib/cjs/geometry3d/Segment1d.js.map +1 -1
  153. package/lib/cjs/geometry3d/SortablePolygon.js.map +1 -1
  154. package/lib/cjs/geometry3d/Transform.js.map +1 -1
  155. package/lib/cjs/geometry3d/UVSurfaceOps.js.map +1 -1
  156. package/lib/cjs/geometry3d/XYZProps.js +1 -1
  157. package/lib/cjs/geometry3d/XYZProps.js.map +1 -1
  158. package/lib/cjs/geometry3d/YawPitchRollAngles.js.map +1 -1
  159. package/lib/cjs/geometry4d/Map4d.js.map +1 -1
  160. package/lib/cjs/geometry4d/Matrix4d.js.map +1 -1
  161. package/lib/cjs/geometry4d/MomentData.js.map +1 -1
  162. package/lib/cjs/geometry4d/PlaneByOriginAndVectors4d.js.map +1 -1
  163. package/lib/cjs/geometry4d/Point4d.js.map +1 -1
  164. package/lib/cjs/numerics/BandedSystem.js.map +1 -1
  165. package/lib/cjs/numerics/BezierPolynomials.js.map +1 -1
  166. package/lib/cjs/numerics/ClusterableArray.js +1 -1
  167. package/lib/cjs/numerics/ClusterableArray.js.map +1 -1
  168. package/lib/cjs/numerics/Complex.js.map +1 -1
  169. package/lib/cjs/numerics/ConvexPolygon2d.js.map +1 -1
  170. package/lib/cjs/numerics/Newton.js.map +1 -1
  171. package/lib/cjs/numerics/PascalCoefficients.js +1 -1
  172. package/lib/cjs/numerics/PascalCoefficients.js.map +1 -1
  173. package/lib/cjs/numerics/PolarData.js +2 -2
  174. package/lib/cjs/numerics/PolarData.js.map +1 -1
  175. package/lib/cjs/numerics/Polynomials.js +2 -2
  176. package/lib/cjs/numerics/Polynomials.js.map +1 -1
  177. package/lib/cjs/numerics/Quadrature.js +1 -1
  178. package/lib/cjs/numerics/Quadrature.js.map +1 -1
  179. package/lib/cjs/numerics/Range1dArray.js.map +1 -1
  180. package/lib/cjs/numerics/TriDiagonalSystem.js.map +1 -1
  181. package/lib/cjs/numerics/UnionFind.js.map +1 -1
  182. package/lib/cjs/polyface/AuxData.js +1 -1
  183. package/lib/cjs/polyface/AuxData.js.map +1 -1
  184. package/lib/cjs/polyface/BoxTopology.js +1 -1
  185. package/lib/cjs/polyface/BoxTopology.js.map +1 -1
  186. package/lib/cjs/polyface/FacetFaceData.js.map +1 -1
  187. package/lib/cjs/polyface/FacetLocationDetail.js.map +1 -1
  188. package/lib/cjs/polyface/FacetOrientation.js.map +1 -1
  189. package/lib/cjs/polyface/GreedyTriangulationBetweenLineStrings.js +1 -1
  190. package/lib/cjs/polyface/GreedyTriangulationBetweenLineStrings.js.map +1 -1
  191. package/lib/cjs/polyface/IndexedEdgeMatcher.js.map +1 -1
  192. package/lib/cjs/polyface/IndexedPolyfaceVisitor.js.map +1 -1
  193. package/lib/cjs/polyface/Polyface.d.ts +1 -1
  194. package/lib/cjs/polyface/Polyface.d.ts.map +1 -1
  195. package/lib/cjs/polyface/Polyface.js.map +1 -1
  196. package/lib/cjs/polyface/PolyfaceBuilder.js +1 -1
  197. package/lib/cjs/polyface/PolyfaceBuilder.js.map +1 -1
  198. package/lib/cjs/polyface/PolyfaceClip.js.map +1 -1
  199. package/lib/cjs/polyface/PolyfaceData.js +1 -1
  200. package/lib/cjs/polyface/PolyfaceData.js.map +1 -1
  201. package/lib/cjs/polyface/PolyfaceQuery.js +2 -2
  202. package/lib/cjs/polyface/PolyfaceQuery.js.map +1 -1
  203. package/lib/cjs/polyface/RangeTree/MinimumValueTester.js.map +1 -1
  204. package/lib/cjs/polyface/RangeTree/RangeTreeNode.js.map +1 -1
  205. package/lib/cjs/polyface/RangeTree/RangeTreeSearchHandlers.js.map +1 -1
  206. package/lib/cjs/polyface/TaggedNumericData.js +1 -1
  207. package/lib/cjs/polyface/TaggedNumericData.js.map +1 -1
  208. package/lib/cjs/polyface/TriangleCandidate.js.map +1 -1
  209. package/lib/cjs/polyface/multiclip/BuildAverageNormalsContext.js.map +1 -1
  210. package/lib/cjs/polyface/multiclip/GriddedRaggedRange2dSet.js.map +1 -1
  211. package/lib/cjs/polyface/multiclip/GriddedRaggedRange2dSetWithOverflow.js.map +1 -1
  212. package/lib/cjs/polyface/multiclip/LinearSearchRange2dArray.js.map +1 -1
  213. package/lib/cjs/polyface/multiclip/OffsetMeshContext.js +2 -2
  214. package/lib/cjs/polyface/multiclip/OffsetMeshContext.js.map +1 -1
  215. package/lib/cjs/polyface/multiclip/RangeSearch.js +1 -1
  216. package/lib/cjs/polyface/multiclip/RangeSearch.js.map +1 -1
  217. package/lib/cjs/polyface/multiclip/SweepLineStringToFacetContext.js.map +1 -1
  218. package/lib/cjs/polyface/multiclip/XYPointBuckets.js.map +1 -1
  219. package/lib/cjs/serialization/BGFBAccessors.js +1 -1
  220. package/lib/cjs/serialization/BGFBAccessors.js.map +1 -1
  221. package/lib/cjs/serialization/BGFBReader.js +1 -1
  222. package/lib/cjs/serialization/BGFBReader.js.map +1 -1
  223. package/lib/cjs/serialization/BGFBWriter.js.map +1 -1
  224. package/lib/cjs/serialization/DeepCompare.js.map +1 -1
  225. package/lib/cjs/serialization/GeometrySamples.js +1 -1
  226. package/lib/cjs/serialization/GeometrySamples.js.map +1 -1
  227. package/lib/cjs/serialization/IModelJsonSchema.js +1 -1
  228. package/lib/cjs/serialization/IModelJsonSchema.js.map +1 -1
  229. package/lib/cjs/serialization/SerializationHelpers.js +1 -1
  230. package/lib/cjs/serialization/SerializationHelpers.js.map +1 -1
  231. package/lib/cjs/solid/Box.js.map +1 -1
  232. package/lib/cjs/solid/Cone.js.map +1 -1
  233. package/lib/cjs/solid/LinearSweep.js.map +1 -1
  234. package/lib/cjs/solid/RotationalSweep.js.map +1 -1
  235. package/lib/cjs/solid/RuledSweep.js.map +1 -1
  236. package/lib/cjs/solid/Sphere.js.map +1 -1
  237. package/lib/cjs/solid/SweepContour.js.map +1 -1
  238. package/lib/cjs/solid/TorusPipe.js.map +1 -1
  239. package/lib/cjs/topology/ChainMerge.js.map +1 -1
  240. package/lib/cjs/topology/Graph.js +2 -2
  241. package/lib/cjs/topology/Graph.js.map +1 -1
  242. package/lib/cjs/topology/HalfEdgeGraphFromIndexedLoopsContext.js.map +1 -1
  243. package/lib/cjs/topology/HalfEdgeGraphSearch.js.map +1 -1
  244. package/lib/cjs/topology/HalfEdgeGraphSpineContext.js +1 -1
  245. package/lib/cjs/topology/HalfEdgeGraphSpineContext.js.map +1 -1
  246. package/lib/cjs/topology/HalfEdgeGraphValidation.js.map +1 -1
  247. package/lib/cjs/topology/HalfEdgeMarkSet.js.map +1 -1
  248. package/lib/cjs/topology/HalfEdgePointInGraphSearch.js +1 -1
  249. package/lib/cjs/topology/HalfEdgePointInGraphSearch.js.map +1 -1
  250. package/lib/cjs/topology/HalfEdgePositionDetail.js +1 -1
  251. package/lib/cjs/topology/HalfEdgePositionDetail.js.map +1 -1
  252. package/lib/cjs/topology/HalfEdgePriorityQueue.js.map +1 -1
  253. package/lib/cjs/topology/InsertAndRetriangulateContext.js.map +1 -1
  254. package/lib/cjs/topology/MaskManager.js.map +1 -1
  255. package/lib/cjs/topology/Merging.js.map +1 -1
  256. package/lib/cjs/topology/RegularizeFace.js.map +1 -1
  257. package/lib/cjs/topology/SignedDataSummary.js.map +1 -1
  258. package/lib/cjs/topology/SpaceTriangulation.js.map +1 -1
  259. package/lib/cjs/topology/Triangulation.js +1 -1
  260. package/lib/cjs/topology/Triangulation.js.map +1 -1
  261. package/lib/cjs/topology/XYParitySearchContext.js.map +1 -1
  262. package/lib/esm/Constant.js +1 -2
  263. package/lib/esm/Constant.js.map +1 -1
  264. package/lib/esm/Geometry.d.ts +1 -1
  265. package/lib/esm/Geometry.d.ts.map +1 -1
  266. package/lib/esm/Geometry.js +1 -2
  267. package/lib/esm/Geometry.js.map +1 -1
  268. package/lib/esm/bspline/AkimaCurve3d.js.map +1 -1
  269. package/lib/esm/bspline/BSpline1dNd.js.map +1 -1
  270. package/lib/esm/bspline/BSplineCurve.js.map +1 -1
  271. package/lib/esm/bspline/BSplineCurve3dH.js.map +1 -1
  272. package/lib/esm/bspline/BSplineCurveOps.js.map +1 -1
  273. package/lib/esm/bspline/BSplineSurface.js +2 -2
  274. package/lib/esm/bspline/BSplineSurface.js.map +1 -1
  275. package/lib/esm/bspline/Bezier1dNd.js.map +1 -1
  276. package/lib/esm/bspline/BezierCurve3d.js.map +1 -1
  277. package/lib/esm/bspline/BezierCurve3dH.js.map +1 -1
  278. package/lib/esm/bspline/BezierCurveBase.js.map +1 -1
  279. package/lib/esm/bspline/InterpolationCurve3d.js.map +1 -1
  280. package/lib/esm/bspline/KnotVector.js +1 -2
  281. package/lib/esm/bspline/KnotVector.js.map +1 -1
  282. package/lib/esm/clipping/AlternatingConvexClipTree.js +1 -2
  283. package/lib/esm/clipping/AlternatingConvexClipTree.js.map +1 -1
  284. package/lib/esm/clipping/BooleanClipFactory.d.ts +1 -1
  285. package/lib/esm/clipping/BooleanClipFactory.d.ts.map +1 -1
  286. package/lib/esm/clipping/BooleanClipFactory.js.map +1 -1
  287. package/lib/esm/clipping/BooleanClipNode.js.map +1 -1
  288. package/lib/esm/clipping/ClipPlane.js +1 -2
  289. package/lib/esm/clipping/ClipPlane.js.map +1 -1
  290. package/lib/esm/clipping/ClipPrimitive.js.map +1 -1
  291. package/lib/esm/clipping/ClipUtils.js +1 -2
  292. package/lib/esm/clipping/ClipUtils.js.map +1 -1
  293. package/lib/esm/clipping/ClipVector.js +1 -2
  294. package/lib/esm/clipping/ClipVector.js.map +1 -1
  295. package/lib/esm/clipping/ConvexClipPlaneSet.js +1 -2
  296. package/lib/esm/clipping/ConvexClipPlaneSet.js.map +1 -1
  297. package/lib/esm/clipping/UnionOfConvexClipPlaneSets.js +1 -2
  298. package/lib/esm/clipping/UnionOfConvexClipPlaneSets.js.map +1 -1
  299. package/lib/esm/clipping/internalContexts/LineStringOffsetClipperContext.js.map +1 -1
  300. package/lib/esm/curve/Arc3d.js +1 -2
  301. package/lib/esm/curve/Arc3d.js.map +1 -1
  302. package/lib/esm/curve/ConstructCurveBetweenCurves.js.map +1 -1
  303. package/lib/esm/curve/CurveChainWithDistanceIndex.js +1 -2
  304. package/lib/esm/curve/CurveChainWithDistanceIndex.js.map +1 -1
  305. package/lib/esm/curve/CurveCollection.js.map +1 -1
  306. package/lib/esm/curve/CurveCurve.js.map +1 -1
  307. package/lib/esm/curve/CurveExtendMode.js.map +1 -1
  308. package/lib/esm/curve/CurveFactory.js.map +1 -1
  309. package/lib/esm/curve/CurveLocationDetail.js.map +1 -1
  310. package/lib/esm/curve/CurveOps.js.map +1 -1
  311. package/lib/esm/curve/CurvePrimitive.js.map +1 -1
  312. package/lib/esm/curve/CurveProcessor.js.map +1 -1
  313. package/lib/esm/curve/CurveWireMomentsXYZ.js.map +1 -1
  314. package/lib/esm/curve/GeometryQuery.js.map +1 -1
  315. package/lib/esm/curve/LineSegment3d.js.map +1 -1
  316. package/lib/esm/curve/LineString3d.js +1 -2
  317. package/lib/esm/curve/LineString3d.js.map +1 -1
  318. package/lib/esm/curve/Loop.js.map +1 -1
  319. package/lib/esm/curve/OffsetOptions.js.map +1 -1
  320. package/lib/esm/curve/ParityRegion.js.map +1 -1
  321. package/lib/esm/curve/Path.js.map +1 -1
  322. package/lib/esm/curve/PointString3d.js.map +1 -1
  323. package/lib/esm/curve/Query/ConsolidateAdjacentPrimitivesContext.js.map +1 -1
  324. package/lib/esm/curve/Query/CurveSplitContext.js.map +1 -1
  325. package/lib/esm/curve/Query/CylindricalRange.js.map +1 -1
  326. package/lib/esm/curve/Query/InOutTests.js.map +1 -1
  327. package/lib/esm/curve/Query/PlanarSubdivision.js.map +1 -1
  328. package/lib/esm/curve/Query/StrokeCountChain.js.map +1 -1
  329. package/lib/esm/curve/Query/StrokeCountMap.js.map +1 -1
  330. package/lib/esm/curve/RegionMomentsXY.js.map +1 -1
  331. package/lib/esm/curve/RegionOps.js.map +1 -1
  332. package/lib/esm/curve/RegionOpsClassificationSweeps.js +1 -2
  333. package/lib/esm/curve/RegionOpsClassificationSweeps.js.map +1 -1
  334. package/lib/esm/curve/StrokeOptions.js.map +1 -1
  335. package/lib/esm/curve/UnionRegion.js.map +1 -1
  336. package/lib/esm/curve/internalContexts/AppendPlaneIntersectionStrokeHandler.js.map +1 -1
  337. package/lib/esm/curve/internalContexts/ChainCollectorContext.js.map +1 -1
  338. package/lib/esm/curve/internalContexts/CloneCurvesContext.js.map +1 -1
  339. package/lib/esm/curve/internalContexts/CloneWithExpandedLineStrings.js.map +1 -1
  340. package/lib/esm/curve/internalContexts/ClosestPointStrokeHandler.js.map +1 -1
  341. package/lib/esm/curve/internalContexts/CurveCurveCloseApproachXY.js +1 -2
  342. package/lib/esm/curve/internalContexts/CurveCurveCloseApproachXY.js.map +1 -1
  343. package/lib/esm/curve/internalContexts/CurveCurveIntersectXY.js +1 -2
  344. package/lib/esm/curve/internalContexts/CurveCurveIntersectXY.js.map +1 -1
  345. package/lib/esm/curve/internalContexts/CurveCurveIntersectXYZ.js +1 -2
  346. package/lib/esm/curve/internalContexts/CurveCurveIntersectXYZ.js.map +1 -1
  347. package/lib/esm/curve/internalContexts/CurveLengthContext.js.map +1 -1
  348. package/lib/esm/curve/internalContexts/CurveOffsetXYHandler.js.map +1 -1
  349. package/lib/esm/curve/internalContexts/GapSearchContext.js.map +1 -1
  350. package/lib/esm/curve/internalContexts/MultiChainCollector.js.map +1 -1
  351. package/lib/esm/curve/internalContexts/PlaneAltitudeRangeContext.js.map +1 -1
  352. package/lib/esm/curve/internalContexts/PolygonOffsetContext.js +1 -2
  353. package/lib/esm/curve/internalContexts/PolygonOffsetContext.js.map +1 -1
  354. package/lib/esm/curve/spiral/AustralianRailCorpXYEvaluator.js.map +1 -1
  355. package/lib/esm/curve/spiral/ClothoidSeries.js.map +1 -1
  356. package/lib/esm/curve/spiral/CzechSpiralEvaluator.js.map +1 -1
  357. package/lib/esm/curve/spiral/DirectHalfCosineSpiralEvaluator.js.map +1 -1
  358. package/lib/esm/curve/spiral/DirectSpiral3d.js.map +1 -1
  359. package/lib/esm/curve/spiral/IntegratedSpiral3d.js +1 -2
  360. package/lib/esm/curve/spiral/IntegratedSpiral3d.js.map +1 -1
  361. package/lib/esm/curve/spiral/MXCubicAlongArcSpiralEvaluator.js.map +1 -1
  362. package/lib/esm/curve/spiral/PolishCubicSpiralEvaluator.js.map +1 -1
  363. package/lib/esm/curve/spiral/TransitionConditionalProperties.js.map +1 -1
  364. package/lib/esm/curve/spiral/TransitionSpiral3d.js.map +1 -1
  365. package/lib/esm/curve/spiral/XYCurveEvaluator.js.map +1 -1
  366. package/lib/esm/geometry3d/Angle.js +1 -2
  367. package/lib/esm/geometry3d/Angle.js.map +1 -1
  368. package/lib/esm/geometry3d/AngleSweep.js.map +1 -1
  369. package/lib/esm/geometry3d/BarycentricTriangle.js.map +1 -1
  370. package/lib/esm/geometry3d/BilinearPatch.js.map +1 -1
  371. package/lib/esm/geometry3d/CoincidentGeometryOps.js.map +1 -1
  372. package/lib/esm/geometry3d/Ellipsoid.js.map +1 -1
  373. package/lib/esm/geometry3d/FrameBuilder.js.map +1 -1
  374. package/lib/esm/geometry3d/FrustumAnimation.js.map +1 -1
  375. package/lib/esm/geometry3d/GeometryHandler.js.map +1 -1
  376. package/lib/esm/geometry3d/GrowableBlockedArray.js.map +1 -1
  377. package/lib/esm/geometry3d/GrowableFloat64Array.js.map +1 -1
  378. package/lib/esm/geometry3d/GrowableXYArray.js.map +1 -1
  379. package/lib/esm/geometry3d/GrowableXYZArray.js.map +1 -1
  380. package/lib/esm/geometry3d/IndexedCollectionInterval.js.map +1 -1
  381. package/lib/esm/geometry3d/IndexedXYCollection.js.map +1 -1
  382. package/lib/esm/geometry3d/IndexedXYZCollection.js.map +1 -1
  383. package/lib/esm/geometry3d/LongitudeLatitudeAltitude.js.map +1 -1
  384. package/lib/esm/geometry3d/Matrix3d.js +1 -2
  385. package/lib/esm/geometry3d/Matrix3d.js.map +1 -1
  386. package/lib/esm/geometry3d/OrderedRotationAngles.js +1 -2
  387. package/lib/esm/geometry3d/OrderedRotationAngles.js.map +1 -1
  388. package/lib/esm/geometry3d/Plane3dByOriginAndUnitNormal.js.map +1 -1
  389. package/lib/esm/geometry3d/Plane3dByOriginAndVectors.js.map +1 -1
  390. package/lib/esm/geometry3d/Point2dArrayCarrier.js.map +1 -1
  391. package/lib/esm/geometry3d/Point2dVector2d.js.map +1 -1
  392. package/lib/esm/geometry3d/Point3dArrayCarrier.js.map +1 -1
  393. package/lib/esm/geometry3d/Point3dVector3d.js.map +1 -1
  394. package/lib/esm/geometry3d/PointHelpers.js +2 -4
  395. package/lib/esm/geometry3d/PointHelpers.js.map +1 -1
  396. package/lib/esm/geometry3d/PointStreaming.js.map +1 -1
  397. package/lib/esm/geometry3d/PolygonOps.js +3 -6
  398. package/lib/esm/geometry3d/PolygonOps.js.map +1 -1
  399. package/lib/esm/geometry3d/PolylineCompressionByEdgeOffset.js +1 -2
  400. package/lib/esm/geometry3d/PolylineCompressionByEdgeOffset.js.map +1 -1
  401. package/lib/esm/geometry3d/PolylineOps.js.map +1 -1
  402. package/lib/esm/geometry3d/Range.js +1 -2
  403. package/lib/esm/geometry3d/Range.js.map +1 -1
  404. package/lib/esm/geometry3d/Ray2d.js.map +1 -1
  405. package/lib/esm/geometry3d/Ray3d.js.map +1 -1
  406. package/lib/esm/geometry3d/ReusableObjectCache.js.map +1 -1
  407. package/lib/esm/geometry3d/Segment1d.js.map +1 -1
  408. package/lib/esm/geometry3d/SortablePolygon.js.map +1 -1
  409. package/lib/esm/geometry3d/Transform.js.map +1 -1
  410. package/lib/esm/geometry3d/UVSurfaceOps.js.map +1 -1
  411. package/lib/esm/geometry3d/YawPitchRollAngles.js.map +1 -1
  412. package/lib/esm/geometry4d/Map4d.js.map +1 -1
  413. package/lib/esm/geometry4d/Matrix4d.js.map +1 -1
  414. package/lib/esm/geometry4d/MomentData.js.map +1 -1
  415. package/lib/esm/geometry4d/PlaneByOriginAndVectors4d.js.map +1 -1
  416. package/lib/esm/geometry4d/Point4d.js.map +1 -1
  417. package/lib/esm/numerics/BandedSystem.js.map +1 -1
  418. package/lib/esm/numerics/BezierPolynomials.js.map +1 -1
  419. package/lib/esm/numerics/ClusterableArray.js +1 -2
  420. package/lib/esm/numerics/ClusterableArray.js.map +1 -1
  421. package/lib/esm/numerics/Complex.js.map +1 -1
  422. package/lib/esm/numerics/ConvexPolygon2d.js.map +1 -1
  423. package/lib/esm/numerics/Newton.js.map +1 -1
  424. package/lib/esm/numerics/PascalCoefficients.js +1 -2
  425. package/lib/esm/numerics/PascalCoefficients.js.map +1 -1
  426. package/lib/esm/numerics/PolarData.js +1 -2
  427. package/lib/esm/numerics/PolarData.js.map +1 -1
  428. package/lib/esm/numerics/Polynomials.js +2 -4
  429. package/lib/esm/numerics/Polynomials.js.map +1 -1
  430. package/lib/esm/numerics/Quadrature.js +1 -2
  431. package/lib/esm/numerics/Quadrature.js.map +1 -1
  432. package/lib/esm/numerics/Range1dArray.js.map +1 -1
  433. package/lib/esm/numerics/TriDiagonalSystem.js.map +1 -1
  434. package/lib/esm/numerics/UnionFind.js.map +1 -1
  435. package/lib/esm/polyface/AuxData.js.map +1 -1
  436. package/lib/esm/polyface/BoxTopology.js +1 -2
  437. package/lib/esm/polyface/BoxTopology.js.map +1 -1
  438. package/lib/esm/polyface/FacetFaceData.js.map +1 -1
  439. package/lib/esm/polyface/FacetLocationDetail.js.map +1 -1
  440. package/lib/esm/polyface/FacetOrientation.js.map +1 -1
  441. package/lib/esm/polyface/GreedyTriangulationBetweenLineStrings.js +1 -2
  442. package/lib/esm/polyface/GreedyTriangulationBetweenLineStrings.js.map +1 -1
  443. package/lib/esm/polyface/IndexedEdgeMatcher.js.map +1 -1
  444. package/lib/esm/polyface/IndexedPolyfaceVisitor.js.map +1 -1
  445. package/lib/esm/polyface/Polyface.d.ts +1 -1
  446. package/lib/esm/polyface/Polyface.d.ts.map +1 -1
  447. package/lib/esm/polyface/Polyface.js.map +1 -1
  448. package/lib/esm/polyface/PolyfaceBuilder.js +1 -2
  449. package/lib/esm/polyface/PolyfaceBuilder.js.map +1 -1
  450. package/lib/esm/polyface/PolyfaceClip.js.map +1 -1
  451. package/lib/esm/polyface/PolyfaceData.js +1 -2
  452. package/lib/esm/polyface/PolyfaceData.js.map +1 -1
  453. package/lib/esm/polyface/PolyfaceQuery.js +1 -2
  454. package/lib/esm/polyface/PolyfaceQuery.js.map +1 -1
  455. package/lib/esm/polyface/RangeTree/MinimumValueTester.js.map +1 -1
  456. package/lib/esm/polyface/RangeTree/RangeTreeNode.js.map +1 -1
  457. package/lib/esm/polyface/RangeTree/RangeTreeSearchHandlers.js.map +1 -1
  458. package/lib/esm/polyface/TaggedNumericData.js.map +1 -1
  459. package/lib/esm/polyface/TriangleCandidate.js.map +1 -1
  460. package/lib/esm/polyface/multiclip/BuildAverageNormalsContext.js.map +1 -1
  461. package/lib/esm/polyface/multiclip/GriddedRaggedRange2dSet.js.map +1 -1
  462. package/lib/esm/polyface/multiclip/GriddedRaggedRange2dSetWithOverflow.js.map +1 -1
  463. package/lib/esm/polyface/multiclip/LinearSearchRange2dArray.js.map +1 -1
  464. package/lib/esm/polyface/multiclip/OffsetMeshContext.js +2 -2
  465. package/lib/esm/polyface/multiclip/OffsetMeshContext.js.map +1 -1
  466. package/lib/esm/polyface/multiclip/RangeSearch.js +1 -2
  467. package/lib/esm/polyface/multiclip/RangeSearch.js.map +1 -1
  468. package/lib/esm/polyface/multiclip/SweepLineStringToFacetContext.js.map +1 -1
  469. package/lib/esm/polyface/multiclip/XYPointBuckets.js.map +1 -1
  470. package/lib/esm/serialization/BGFBAccessors.js.map +1 -1
  471. package/lib/esm/serialization/BGFBReader.js +1 -2
  472. package/lib/esm/serialization/BGFBReader.js.map +1 -1
  473. package/lib/esm/serialization/BGFBWriter.js.map +1 -1
  474. package/lib/esm/serialization/DeepCompare.js.map +1 -1
  475. package/lib/esm/serialization/GeometrySamples.js +1 -2
  476. package/lib/esm/serialization/GeometrySamples.js.map +1 -1
  477. package/lib/esm/serialization/IModelJsonSchema.js.map +1 -1
  478. package/lib/esm/serialization/SerializationHelpers.js.map +1 -1
  479. package/lib/esm/solid/Box.js.map +1 -1
  480. package/lib/esm/solid/Cone.js.map +1 -1
  481. package/lib/esm/solid/LinearSweep.js.map +1 -1
  482. package/lib/esm/solid/RotationalSweep.js.map +1 -1
  483. package/lib/esm/solid/RuledSweep.js.map +1 -1
  484. package/lib/esm/solid/Sphere.js.map +1 -1
  485. package/lib/esm/solid/SweepContour.js.map +1 -1
  486. package/lib/esm/solid/TorusPipe.js.map +1 -1
  487. package/lib/esm/topology/ChainMerge.js.map +1 -1
  488. package/lib/esm/topology/Graph.js +1 -2
  489. package/lib/esm/topology/Graph.js.map +1 -1
  490. package/lib/esm/topology/HalfEdgeGraphFromIndexedLoopsContext.js.map +1 -1
  491. package/lib/esm/topology/HalfEdgeGraphSearch.js.map +1 -1
  492. package/lib/esm/topology/HalfEdgeGraphSpineContext.js +1 -2
  493. package/lib/esm/topology/HalfEdgeGraphSpineContext.js.map +1 -1
  494. package/lib/esm/topology/HalfEdgeGraphValidation.js.map +1 -1
  495. package/lib/esm/topology/HalfEdgeMarkSet.js.map +1 -1
  496. package/lib/esm/topology/HalfEdgePointInGraphSearch.js.map +1 -1
  497. package/lib/esm/topology/HalfEdgePositionDetail.js.map +1 -1
  498. package/lib/esm/topology/HalfEdgePriorityQueue.js.map +1 -1
  499. package/lib/esm/topology/InsertAndRetriangulateContext.js.map +1 -1
  500. package/lib/esm/topology/MaskManager.js.map +1 -1
  501. package/lib/esm/topology/Merging.js.map +1 -1
  502. package/lib/esm/topology/RegularizeFace.js.map +1 -1
  503. package/lib/esm/topology/SignedDataSummary.js.map +1 -1
  504. package/lib/esm/topology/SpaceTriangulation.js.map +1 -1
  505. package/lib/esm/topology/Triangulation.js +1 -2
  506. package/lib/esm/topology/Triangulation.js.map +1 -1
  507. package/lib/esm/topology/XYParitySearchContext.js.map +1 -1
  508. package/package.json +5 -5
@@ -1 +1 @@
1
- {"version":3,"file":"GriddedRaggedRange2dSet.js","sourceRoot":"","sources":["../../../../src/polyface/multiclip/GriddedRaggedRange2dSet.ts"],"names":[],"mappings":"AAAA;;;+FAG+F;AAC/F;;GAEG;AAEH,OAAO,EAAE,OAAO,EAAW,MAAM,wBAAwB,CAAC;AAE1D,OAAO,EAAE,wBAAwB,EAAE,MAAM,4BAA4B,CAAC;AAStE;;;;;;;;GAQG;AACH,MAAM,OAAO,uBAAuB;IAOlC,YAAoB,KAAc,EAAE,QAAgB,EAAE,QAAgB;QACpE,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;QACpB,IAAI,CAAC,SAAS,GAAG,QAAQ,CAAC;QAC1B,IAAI,CAAC,SAAS,GAAG,QAAQ,CAAC;QAC1B,IAAI,CAAC,cAAc,GAAG,EAAE,CAAC;QACzB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,SAAS,EAAE,CAAC,EAAE,EAAE;YACvC,MAAM,OAAO,GAA6C,EAAE,CAAC;YAC7D,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,SAAS,EAAE,CAAC,EAAE,EAAE;gBACvC,OAAO,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;aACzB;YACD,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;SACnC;IACH,CAAC;IACD;;;;;OAKG;IACI,MAAM,CAAC,MAAM,CAAI,KAAc,EAAE,QAAgB,EAAE,QAAgB;QACxE,IAAI,QAAQ,GAAG,CAAC,IAAI,QAAQ,GAAG,CAAC,IAAI,KAAK,CAAC,MAAM,IAAI,KAAK,CAAC,aAAa;YACrE,OAAO,SAAS,CAAC;QACnB,OAAO,IAAI,uBAAuB,CAAC,KAAK,CAAC,KAAK,EAAE,EAAE,QAAQ,EAAE,QAAQ,CAAC,CAAC;IACxE,CAAC;IACO,MAAM,CAAC,CAAS;QACtB,MAAM,QAAQ,GAAG,CAAC,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;QACpF,OAAO,IAAI,CAAC,KAAK,CAAC,QAAQ,GAAG,IAAI,CAAC,SAAS,CAAC,CAAC;IAC/C,CAAC;IACO,MAAM,CAAC,CAAS;QACtB,MAAM,QAAQ,GAAG,CAAC,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;QACpF,OAAO,IAAI,CAAC,KAAK,CAAC,QAAQ,GAAG,IAAI,CAAC,SAAS,CAAC,CAAC;IAC/C,CAAC;IACO,QAAQ,CAAC,CAAS,EAAE,CAAS;QACnC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC,SAAS,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC,SAAS,EAAE;YAChE,IAAI,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;gBAC5B,IAAI,CAAC,cAAc,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,IAAI,wBAAwB,EAAE,CAAC;YAC7D,OAAO,IAAI,CAAC,cAAc,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;SAClC;QACD,OAAO,SAAS,CAAC;IACnB,CAAC;IACD;;;;;OAKG;IACI,iBAAiB,CAAC,KAAuC,EAAE,GAAM;QACtE,IAAI,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC;YACvB,OAAO,KAAK,CAAC;QACf,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,aAAa,CAAC,KAAK,CAAC;YACnC,OAAO,KAAK,CAAC;QACf,MAAM,OAAO,GAAG,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;QACzC,MAAM,OAAO,GAAG,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QAC1C,MAAM,OAAO,GAAG,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;QACzC,MAAM,OAAO,GAAG,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QAC1C,IAAI,CAAC,CAAC,OAAO,KAAK,OAAO,IAAI,OAAO,GAAG,CAAC,KAAK,OAAO,CAAC;YACnD,OAAO,KAAK,CAAC;QACf,IAAI,CAAC,CAAC,OAAO,KAAK,OAAO,IAAI,OAAO,GAAG,CAAC,KAAK,OAAO,CAAC;YACnD,OAAO,KAAK,CAAC;QACf,MAAM,aAAa,GAAG,IAAI,CAAC,QAAQ,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC;QACtD,IAAI,aAAa,EAAE;YACjB,aAAa,CAAC,QAAQ,CAAC,KAAK,EAAE,GAAG,CAAC,CAAC;YACnC,OAAO,IAAI,CAAC;SACb;QACD,OAAO,KAAK,CAAC;IACf,CAAC;IACD,qCAAqC;IAC9B,QAAQ,CAAC,KAAmB,EAAE,GAAM;QACzC,IAAI,CAAC,iBAAiB,CAAC,KAAK,EAAE,GAAG,CAAC,CAAC;IACrC,CAAC;IACD;;;;;;;OAOG;IACK,sBAAsB,CAAC,CAAS,EAAE,CAAS,EAAE,CAAS,EAAE,CAAS,EAAE,OAA4C;QACrH,MAAM,aAAa,GAAG,IAAI,CAAC,QAAQ,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;QAC1C,IAAI,CAAC,aAAa;YAChB,OAAO,IAAI,CAAC;QACd,OAAO,aAAa,CAAC,QAAQ,CAAC,CAAC,EAAE,CAAC,EAAE,OAAO,CAAC,CAAC;IAC/C,CAAC;IACD;;;;;;;OAOG;IACK,2BAA2B,CAAC,CAAS,EAAE,CAAS,EAAE,SAAuB,EAAE,OAA4C;QAC7H,MAAM,aAAa,GAAG,IAAI,CAAC,QAAQ,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;QAC1C,IAAI,CAAC,aAAa;YAChB,OAAO,IAAI,CAAC;QACd,OAAO,aAAa,CAAC,aAAa,CAAC,SAAS,EAAE,OAAO,CAAC,CAAC;IACzD,CAAC;IACD;;;;;;;OAOG;IACI,QAAQ,CAAC,CAAS,EAAE,CAAS,EAAE,OAA4C;QAChF,MAAM,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;QACzB,MAAM,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;QACzB,OAAO,IAAI,CAAC,sBAAsB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,OAAO,CAAC;eAClD,IAAI,CAAC,sBAAsB,CAAC,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,OAAO,CAAC;eACpD,IAAI,CAAC,sBAAsB,CAAC,CAAC,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,OAAO,CAAC;eACpD,IAAI,CAAC,sBAAsB,CAAC,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,OAAO,CAAC,CAAC;IAChE,CAAC;IACD;;;;;;;OAOG;IACI,aAAa,CAAC,SAAuB,EAAE,OAA4C;QACxF,MAAM,OAAO,GAAG,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC;QACjD,MAAM,OAAO,GAAG,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QAC9C,MAAM,OAAO,GAAG,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC;QACjD,MAAM,OAAO,GAAG,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QAC9C,KAAK,IAAI,CAAC,GAAG,OAAO,EAAE,CAAC,IAAI,OAAO,EAAE,CAAC,EAAE,EAAE;YACvC,KAAK,IAAI,CAAC,GAAG,OAAO,EAAE,CAAC,IAAI,OAAO,EAAE,CAAC,EAAE,EAAE;gBACvC,IAAI,CAAC,IAAI,CAAC,2BAA2B,CAAC,CAAC,EAAE,CAAC,EAAE,SAAS,EAAE,OAAO,CAAC;oBAC7D,OAAO,KAAK,CAAC;aAChB;SACF;QACD,OAAO,IAAI,CAAC;IACd,CAAC;IACD,+CAA+C;IACxC,UAAU,CAAC,MAAgB;QAChC,IAAI,MAAM;YACR,MAAM,CAAC,OAAO,EAAE,CAAC;;YAEjB,MAAM,GAAG,OAAO,CAAC,UAAU,EAAE,CAAC;QAChC,IAAI,CAAC,aAAa,CAAC,CAAC,EAAE,CAAC,MAAM,EAAE,KAAK,EAAE,EAAE;YACtC,MAAM,UAAU,GAAG,uBAAuB,CAAC,UAAU,GAAG,KAAK,CAAC,UAAU,CAAC,uBAAuB,CAAC,UAAU,CAAC,CAAC;YAC7G,MAAO,CAAC,WAAW,CAAC,UAAU,CAAC,CAAC;QAClC,CAAC,CAAC,CAAC;QACH,OAAO,MAAM,CAAC;IAChB,CAAC;IACD,0DAA0D;IACnD,aAAa,CAAC,YAAoB,EAAE,OAAkE;QAC3G,KAAK,MAAM,GAAG,IAAI,IAAI,CAAC,cAAc,EAAE;YACrC,KAAK,MAAM,KAAK,IAAI,GAAG,EAAE;gBACvB,IAAI,KAAK;oBACP,OAAO,CAAC,YAAY,EAAE,KAAK,CAAC,CAAC;aAChC;SACF;IACH,CAAC;CACF","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 RangeSearch\r\n */\r\n\r\nimport { Range2d, Range3d } from \"../../geometry3d/Range\";\r\nimport { LowAndHighXY } from \"../../geometry3d/XYZProps\";\r\nimport { LinearSearchRange2dArray } from \"./LinearSearchRange2dArray\";\r\nimport { Range2dSearchInterface } from \"./Range2dSearchInterface\";\r\n\r\n/**\r\n * Type abbreviation to allow undefined as a Range2dSearchInterface parameter.\r\n * @internal\r\n */\r\nexport type OptionalRange2dSearchInterface<T> = Range2dSearchInterface<T> | undefined;\r\n\r\n/**\r\n * A GriddedRaggedRange2dSet is:\r\n * * A doubly dimensioned array of Range2dSearchInterface.\r\n * * Each entry represents a block in a uniform grid within the master range.\r\n * * Member ranges are noted in the grid block containing the range's lower left corner.\r\n * * Member ranges larger than twice the grid size are rejected by the insert method.\r\n * * Hence a search involving a point in grid block (i,j) must examine ranges in grid blocks left and below, i.e. (i-1,j-1), (i-1,j), (i,j-1)\r\n * @public\r\n */\r\nexport class GriddedRaggedRange2dSet<T> implements Range2dSearchInterface<T> {\r\n private _range: Range2d;\r\n private _numXEdge: number;\r\n private _numYEdge: number;\r\n /** Each grid block is a simple linear search set */\r\n private _rangesInBlock: Array<Array<OptionalRange2dSearchInterface<T>>>;\r\n private static _workRange?: Range2d;\r\n private constructor(range: Range2d, numXEdge: number, numYEdge: number) {\r\n this._range = range;\r\n this._numXEdge = numXEdge;\r\n this._numYEdge = numYEdge;\r\n this._rangesInBlock = [];\r\n for (let j = 0; j < this._numYEdge; j++) {\r\n const thisRow: Array<OptionalRange2dSearchInterface<T>> = [];\r\n for (let i = 0; i < this._numXEdge; i++) {\r\n thisRow.push(undefined);\r\n }\r\n this._rangesInBlock.push(thisRow);\r\n }\r\n }\r\n /**\r\n * Create an (empty) set of ranges.\r\n * @param range master range\r\n * @param numXEdge size of grid in x direction\r\n * @param numYEdge size of grid in y direction\r\n */\r\n public static create<T>(range: Range2d, numXEdge: number, numYEdge: number): GriddedRaggedRange2dSet<T> | undefined {\r\n if (numXEdge < 1 || numYEdge < 1 || range.isNull || range.isSinglePoint)\r\n return undefined;\r\n return new GriddedRaggedRange2dSet(range.clone(), numXEdge, numYEdge);\r\n }\r\n private xIndex(x: number): number {\r\n const fraction = (x - this._range.low.x) / (this._range.high.x - this._range.low.x);\r\n return Math.floor(fraction * this._numXEdge);\r\n }\r\n private yIndex(y: number): number {\r\n const fraction = (y - this._range.low.y) / (this._range.high.y - this._range.low.y);\r\n return Math.floor(fraction * this._numXEdge);\r\n }\r\n private getBlock(i: number, j: number): OptionalRange2dSearchInterface<T> {\r\n if (i >= 0 && i < this._numXEdge && j >= 0 && j < this._numYEdge) {\r\n if (!this._rangesInBlock[j][i])\r\n this._rangesInBlock[j][i] = new LinearSearchRange2dArray();\r\n return this._rangesInBlock[j][i];\r\n }\r\n return undefined;\r\n }\r\n /** If possible, insert a range into the set.\r\n * * Decline to insert (and return false) if:\r\n * * range is null\r\n * * range is not completely contained in the overall range of this set\r\n * * range x or y extent is larger than 2 grid blocks\r\n */\r\n public conditionalInsert(range: Range2d | Range3d | LowAndHighXY, tag: T): boolean {\r\n if (Range2d.isNull(range))\r\n return false;\r\n if (!this._range.containsRange(range))\r\n return false;\r\n const xIndex0 = this.xIndex(range.low.x);\r\n const xIndex1 = this.xIndex(range.high.x);\r\n const yIndex0 = this.yIndex(range.low.y);\r\n const yIndex1 = this.yIndex(range.high.y);\r\n if (!(xIndex0 === xIndex1 || xIndex0 + 1 === xIndex1))\r\n return false;\r\n if (!(yIndex0 === yIndex1 || yIndex0 + 1 === yIndex1))\r\n return false;\r\n const rangesInBlock = this.getBlock(xIndex0, yIndex0);\r\n if (rangesInBlock) {\r\n rangesInBlock.addRange(range, tag);\r\n return true;\r\n }\r\n return false;\r\n }\r\n /** Add a range to the search set. */\r\n public addRange(range: LowAndHighXY, tag: T): void {\r\n this.conditionalInsert(range, tag);\r\n }\r\n /**\r\n * * Search a single block\r\n * * Pass each range and tag to handler\r\n * * and return false if bad cell or if handler returns false.\r\n * @param testRange search range.\r\n * @param handler function to receive range and tag hits.\r\n * @return false if search terminated by handler. Return true if no handler returned false.\r\n */\r\n private searchXYInIndexedBlock(i: number, j: number, x: number, y: number, handler: (range: Range2d, tag: T) => boolean): boolean {\r\n const rangesInBlock = this.getBlock(i, j);\r\n if (!rangesInBlock)\r\n return true;\r\n return rangesInBlock.searchXY(x, y, handler);\r\n }\r\n /**\r\n * * Search a single block\r\n * * Pass each range and tag to handler\r\n * * and return false if bad cell or if handler returns false.\r\n * @param testRange search range.\r\n * @param handler function to receive range and tag hits.\r\n * @return false if search terminated by handler. Return true if no handler returned false.\r\n */\r\n private searchRange2dInIndexedBlock(i: number, j: number, testRange: LowAndHighXY, handler: (range: Range2d, tag: T) => boolean): boolean {\r\n const rangesInBlock = this.getBlock(i, j);\r\n if (!rangesInBlock)\r\n return true;\r\n return rangesInBlock.searchRange2d(testRange, handler);\r\n }\r\n /**\r\n * * Search for ranges containing testRange\r\n * * Pass each range and tag to handler\r\n * * terminate search if handler returns false.\r\n * @param testRange search range.\r\n * @param handler function to receive range and tag hits.\r\n * @return false if search terminated by handler. Return true if no handler returned false.\r\n */\r\n public searchXY(x: number, y: number, handler: (range: Range2d, tag: T) => boolean): boolean {\r\n const i = this.xIndex(x);\r\n const j = this.yIndex(y);\r\n return this.searchXYInIndexedBlock(i, j, x, y, handler)\r\n && this.searchXYInIndexedBlock(i - 1, j, x, y, handler)\r\n && this.searchXYInIndexedBlock(i, j - 1, x, y, handler)\r\n && this.searchXYInIndexedBlock(i - 1, j - 1, x, y, handler);\r\n }\r\n /**\r\n * * Search for ranges overlapping testRange\r\n * * Pass each range and tag to handler\r\n * * terminate search if handler returns false.\r\n * @param testRange search range.\r\n * @param handler function to receive range and tag hits.\r\n * @return false if search terminated by handler. Return true if no handler returned false.\r\n */\r\n public searchRange2d(testRange: LowAndHighXY, handler: (range: Range2d, tag: T) => boolean): boolean {\r\n const xIndex0 = this.xIndex(testRange.low.x) - 1;\r\n const xIndex1 = this.xIndex(testRange.high.x);\r\n const yIndex0 = this.yIndex(testRange.low.y) - 1;\r\n const yIndex1 = this.yIndex(testRange.high.y);\r\n for (let i = xIndex0; i <= xIndex1; i++) {\r\n for (let j = yIndex0; j <= yIndex1; j++) {\r\n if (!this.searchRange2dInIndexedBlock(i, j, testRange, handler))\r\n return false;\r\n }\r\n }\r\n return true;\r\n }\r\n /** Return the overall range of all members. */\r\n public totalRange(result?: Range2d): Range2d {\r\n if (result)\r\n result.setNull();\r\n else\r\n result = Range2d.createNull();\r\n this.visitChildren(0, (_depth, child) => {\r\n const childRange = GriddedRaggedRange2dSet._workRange = child.totalRange(GriddedRaggedRange2dSet._workRange);\r\n result!.extendRange(childRange);\r\n });\r\n return result;\r\n }\r\n /** Call the handler on each defined block in the grid. */\r\n public visitChildren(initialDepth: number, handler: (depth: number, child: Range2dSearchInterface<T>) => void) {\r\n for (const row of this._rangesInBlock) {\r\n for (const block of row) {\r\n if (block)\r\n handler(initialDepth, block);\r\n }\r\n }\r\n }\r\n}\r\n"]}
1
+ {"version":3,"file":"GriddedRaggedRange2dSet.js","sourceRoot":"","sources":["../../../../src/polyface/multiclip/GriddedRaggedRange2dSet.ts"],"names":[],"mappings":"AAAA;;;+FAG+F;AAC/F;;GAEG;AAEH,OAAO,EAAE,OAAO,EAAW,MAAM,wBAAwB,CAAC;AAE1D,OAAO,EAAE,wBAAwB,EAAE,MAAM,4BAA4B,CAAC;AAStE;;;;;;;;GAQG;AACH,MAAM,OAAO,uBAAuB;IAOlC,YAAoB,KAAc,EAAE,QAAgB,EAAE,QAAgB;QACpE,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;QACpB,IAAI,CAAC,SAAS,GAAG,QAAQ,CAAC;QAC1B,IAAI,CAAC,SAAS,GAAG,QAAQ,CAAC;QAC1B,IAAI,CAAC,cAAc,GAAG,EAAE,CAAC;QACzB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,SAAS,EAAE,CAAC,EAAE,EAAE,CAAC;YACxC,MAAM,OAAO,GAA6C,EAAE,CAAC;YAC7D,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,SAAS,EAAE,CAAC,EAAE,EAAE,CAAC;gBACxC,OAAO,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;YAC1B,CAAC;YACD,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QACpC,CAAC;IACH,CAAC;IACD;;;;;OAKG;IACI,MAAM,CAAC,MAAM,CAAI,KAAc,EAAE,QAAgB,EAAE,QAAgB;QACxE,IAAI,QAAQ,GAAG,CAAC,IAAI,QAAQ,GAAG,CAAC,IAAI,KAAK,CAAC,MAAM,IAAI,KAAK,CAAC,aAAa;YACrE,OAAO,SAAS,CAAC;QACnB,OAAO,IAAI,uBAAuB,CAAC,KAAK,CAAC,KAAK,EAAE,EAAE,QAAQ,EAAE,QAAQ,CAAC,CAAC;IACxE,CAAC;IACO,MAAM,CAAC,CAAS;QACtB,MAAM,QAAQ,GAAG,CAAC,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;QACpF,OAAO,IAAI,CAAC,KAAK,CAAC,QAAQ,GAAG,IAAI,CAAC,SAAS,CAAC,CAAC;IAC/C,CAAC;IACO,MAAM,CAAC,CAAS;QACtB,MAAM,QAAQ,GAAG,CAAC,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;QACpF,OAAO,IAAI,CAAC,KAAK,CAAC,QAAQ,GAAG,IAAI,CAAC,SAAS,CAAC,CAAC;IAC/C,CAAC;IACO,QAAQ,CAAC,CAAS,EAAE,CAAS;QACnC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC,SAAS,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC,SAAS,EAAE,CAAC;YACjE,IAAI,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;gBAC5B,IAAI,CAAC,cAAc,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,IAAI,wBAAwB,EAAE,CAAC;YAC7D,OAAO,IAAI,CAAC,cAAc,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QACnC,CAAC;QACD,OAAO,SAAS,CAAC;IACnB,CAAC;IACD;;;;;OAKG;IACI,iBAAiB,CAAC,KAAuC,EAAE,GAAM;QACtE,IAAI,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC;YACvB,OAAO,KAAK,CAAC;QACf,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,aAAa,CAAC,KAAK,CAAC;YACnC,OAAO,KAAK,CAAC;QACf,MAAM,OAAO,GAAG,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;QACzC,MAAM,OAAO,GAAG,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QAC1C,MAAM,OAAO,GAAG,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;QACzC,MAAM,OAAO,GAAG,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QAC1C,IAAI,CAAC,CAAC,OAAO,KAAK,OAAO,IAAI,OAAO,GAAG,CAAC,KAAK,OAAO,CAAC;YACnD,OAAO,KAAK,CAAC;QACf,IAAI,CAAC,CAAC,OAAO,KAAK,OAAO,IAAI,OAAO,GAAG,CAAC,KAAK,OAAO,CAAC;YACnD,OAAO,KAAK,CAAC;QACf,MAAM,aAAa,GAAG,IAAI,CAAC,QAAQ,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC;QACtD,IAAI,aAAa,EAAE,CAAC;YAClB,aAAa,CAAC,QAAQ,CAAC,KAAK,EAAE,GAAG,CAAC,CAAC;YACnC,OAAO,IAAI,CAAC;QACd,CAAC;QACD,OAAO,KAAK,CAAC;IACf,CAAC;IACD,qCAAqC;IAC9B,QAAQ,CAAC,KAAmB,EAAE,GAAM;QACzC,IAAI,CAAC,iBAAiB,CAAC,KAAK,EAAE,GAAG,CAAC,CAAC;IACrC,CAAC;IACD;;;;;;;OAOG;IACK,sBAAsB,CAAC,CAAS,EAAE,CAAS,EAAE,CAAS,EAAE,CAAS,EAAE,OAA4C;QACrH,MAAM,aAAa,GAAG,IAAI,CAAC,QAAQ,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;QAC1C,IAAI,CAAC,aAAa;YAChB,OAAO,IAAI,CAAC;QACd,OAAO,aAAa,CAAC,QAAQ,CAAC,CAAC,EAAE,CAAC,EAAE,OAAO,CAAC,CAAC;IAC/C,CAAC;IACD;;;;;;;OAOG;IACK,2BAA2B,CAAC,CAAS,EAAE,CAAS,EAAE,SAAuB,EAAE,OAA4C;QAC7H,MAAM,aAAa,GAAG,IAAI,CAAC,QAAQ,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;QAC1C,IAAI,CAAC,aAAa;YAChB,OAAO,IAAI,CAAC;QACd,OAAO,aAAa,CAAC,aAAa,CAAC,SAAS,EAAE,OAAO,CAAC,CAAC;IACzD,CAAC;IACD;;;;;;;OAOG;IACI,QAAQ,CAAC,CAAS,EAAE,CAAS,EAAE,OAA4C;QAChF,MAAM,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;QACzB,MAAM,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;QACzB,OAAO,IAAI,CAAC,sBAAsB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,OAAO,CAAC;eAClD,IAAI,CAAC,sBAAsB,CAAC,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,OAAO,CAAC;eACpD,IAAI,CAAC,sBAAsB,CAAC,CAAC,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,OAAO,CAAC;eACpD,IAAI,CAAC,sBAAsB,CAAC,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,OAAO,CAAC,CAAC;IAChE,CAAC;IACD;;;;;;;OAOG;IACI,aAAa,CAAC,SAAuB,EAAE,OAA4C;QACxF,MAAM,OAAO,GAAG,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC;QACjD,MAAM,OAAO,GAAG,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QAC9C,MAAM,OAAO,GAAG,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC;QACjD,MAAM,OAAO,GAAG,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QAC9C,KAAK,IAAI,CAAC,GAAG,OAAO,EAAE,CAAC,IAAI,OAAO,EAAE,CAAC,EAAE,EAAE,CAAC;YACxC,KAAK,IAAI,CAAC,GAAG,OAAO,EAAE,CAAC,IAAI,OAAO,EAAE,CAAC,EAAE,EAAE,CAAC;gBACxC,IAAI,CAAC,IAAI,CAAC,2BAA2B,CAAC,CAAC,EAAE,CAAC,EAAE,SAAS,EAAE,OAAO,CAAC;oBAC7D,OAAO,KAAK,CAAC;YACjB,CAAC;QACH,CAAC;QACD,OAAO,IAAI,CAAC;IACd,CAAC;IACD,+CAA+C;IACxC,UAAU,CAAC,MAAgB;QAChC,IAAI,MAAM;YACR,MAAM,CAAC,OAAO,EAAE,CAAC;;YAEjB,MAAM,GAAG,OAAO,CAAC,UAAU,EAAE,CAAC;QAChC,IAAI,CAAC,aAAa,CAAC,CAAC,EAAE,CAAC,MAAM,EAAE,KAAK,EAAE,EAAE;YACtC,MAAM,UAAU,GAAG,uBAAuB,CAAC,UAAU,GAAG,KAAK,CAAC,UAAU,CAAC,uBAAuB,CAAC,UAAU,CAAC,CAAC;YAC7G,MAAO,CAAC,WAAW,CAAC,UAAU,CAAC,CAAC;QAClC,CAAC,CAAC,CAAC;QACH,OAAO,MAAM,CAAC;IAChB,CAAC;IACD,0DAA0D;IACnD,aAAa,CAAC,YAAoB,EAAE,OAAkE;QAC3G,KAAK,MAAM,GAAG,IAAI,IAAI,CAAC,cAAc,EAAE,CAAC;YACtC,KAAK,MAAM,KAAK,IAAI,GAAG,EAAE,CAAC;gBACxB,IAAI,KAAK;oBACP,OAAO,CAAC,YAAY,EAAE,KAAK,CAAC,CAAC;YACjC,CAAC;QACH,CAAC;IACH,CAAC;CACF","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 RangeSearch\r\n */\r\n\r\nimport { Range2d, Range3d } from \"../../geometry3d/Range\";\r\nimport { LowAndHighXY } from \"../../geometry3d/XYZProps\";\r\nimport { LinearSearchRange2dArray } from \"./LinearSearchRange2dArray\";\r\nimport { Range2dSearchInterface } from \"./Range2dSearchInterface\";\r\n\r\n/**\r\n * Type abbreviation to allow undefined as a Range2dSearchInterface parameter.\r\n * @internal\r\n */\r\nexport type OptionalRange2dSearchInterface<T> = Range2dSearchInterface<T> | undefined;\r\n\r\n/**\r\n * A GriddedRaggedRange2dSet is:\r\n * * A doubly dimensioned array of Range2dSearchInterface.\r\n * * Each entry represents a block in a uniform grid within the master range.\r\n * * Member ranges are noted in the grid block containing the range's lower left corner.\r\n * * Member ranges larger than twice the grid size are rejected by the insert method.\r\n * * Hence a search involving a point in grid block (i,j) must examine ranges in grid blocks left and below, i.e. (i-1,j-1), (i-1,j), (i,j-1)\r\n * @public\r\n */\r\nexport class GriddedRaggedRange2dSet<T> implements Range2dSearchInterface<T> {\r\n private _range: Range2d;\r\n private _numXEdge: number;\r\n private _numYEdge: number;\r\n /** Each grid block is a simple linear search set */\r\n private _rangesInBlock: Array<Array<OptionalRange2dSearchInterface<T>>>;\r\n private static _workRange?: Range2d;\r\n private constructor(range: Range2d, numXEdge: number, numYEdge: number) {\r\n this._range = range;\r\n this._numXEdge = numXEdge;\r\n this._numYEdge = numYEdge;\r\n this._rangesInBlock = [];\r\n for (let j = 0; j < this._numYEdge; j++) {\r\n const thisRow: Array<OptionalRange2dSearchInterface<T>> = [];\r\n for (let i = 0; i < this._numXEdge; i++) {\r\n thisRow.push(undefined);\r\n }\r\n this._rangesInBlock.push(thisRow);\r\n }\r\n }\r\n /**\r\n * Create an (empty) set of ranges.\r\n * @param range master range\r\n * @param numXEdge size of grid in x direction\r\n * @param numYEdge size of grid in y direction\r\n */\r\n public static create<T>(range: Range2d, numXEdge: number, numYEdge: number): GriddedRaggedRange2dSet<T> | undefined {\r\n if (numXEdge < 1 || numYEdge < 1 || range.isNull || range.isSinglePoint)\r\n return undefined;\r\n return new GriddedRaggedRange2dSet(range.clone(), numXEdge, numYEdge);\r\n }\r\n private xIndex(x: number): number {\r\n const fraction = (x - this._range.low.x) / (this._range.high.x - this._range.low.x);\r\n return Math.floor(fraction * this._numXEdge);\r\n }\r\n private yIndex(y: number): number {\r\n const fraction = (y - this._range.low.y) / (this._range.high.y - this._range.low.y);\r\n return Math.floor(fraction * this._numXEdge);\r\n }\r\n private getBlock(i: number, j: number): OptionalRange2dSearchInterface<T> {\r\n if (i >= 0 && i < this._numXEdge && j >= 0 && j < this._numYEdge) {\r\n if (!this._rangesInBlock[j][i])\r\n this._rangesInBlock[j][i] = new LinearSearchRange2dArray();\r\n return this._rangesInBlock[j][i];\r\n }\r\n return undefined;\r\n }\r\n /** If possible, insert a range into the set.\r\n * * Decline to insert (and return false) if:\r\n * * range is null\r\n * * range is not completely contained in the overall range of this set\r\n * * range x or y extent is larger than 2 grid blocks\r\n */\r\n public conditionalInsert(range: Range2d | Range3d | LowAndHighXY, tag: T): boolean {\r\n if (Range2d.isNull(range))\r\n return false;\r\n if (!this._range.containsRange(range))\r\n return false;\r\n const xIndex0 = this.xIndex(range.low.x);\r\n const xIndex1 = this.xIndex(range.high.x);\r\n const yIndex0 = this.yIndex(range.low.y);\r\n const yIndex1 = this.yIndex(range.high.y);\r\n if (!(xIndex0 === xIndex1 || xIndex0 + 1 === xIndex1))\r\n return false;\r\n if (!(yIndex0 === yIndex1 || yIndex0 + 1 === yIndex1))\r\n return false;\r\n const rangesInBlock = this.getBlock(xIndex0, yIndex0);\r\n if (rangesInBlock) {\r\n rangesInBlock.addRange(range, tag);\r\n return true;\r\n }\r\n return false;\r\n }\r\n /** Add a range to the search set. */\r\n public addRange(range: LowAndHighXY, tag: T): void {\r\n this.conditionalInsert(range, tag);\r\n }\r\n /**\r\n * * Search a single block\r\n * * Pass each range and tag to handler\r\n * * and return false if bad cell or if handler returns false.\r\n * @param testRange search range.\r\n * @param handler function to receive range and tag hits.\r\n * @return false if search terminated by handler. Return true if no handler returned false.\r\n */\r\n private searchXYInIndexedBlock(i: number, j: number, x: number, y: number, handler: (range: Range2d, tag: T) => boolean): boolean {\r\n const rangesInBlock = this.getBlock(i, j);\r\n if (!rangesInBlock)\r\n return true;\r\n return rangesInBlock.searchXY(x, y, handler);\r\n }\r\n /**\r\n * * Search a single block\r\n * * Pass each range and tag to handler\r\n * * and return false if bad cell or if handler returns false.\r\n * @param testRange search range.\r\n * @param handler function to receive range and tag hits.\r\n * @return false if search terminated by handler. Return true if no handler returned false.\r\n */\r\n private searchRange2dInIndexedBlock(i: number, j: number, testRange: LowAndHighXY, handler: (range: Range2d, tag: T) => boolean): boolean {\r\n const rangesInBlock = this.getBlock(i, j);\r\n if (!rangesInBlock)\r\n return true;\r\n return rangesInBlock.searchRange2d(testRange, handler);\r\n }\r\n /**\r\n * * Search for ranges containing testRange\r\n * * Pass each range and tag to handler\r\n * * terminate search if handler returns false.\r\n * @param testRange search range.\r\n * @param handler function to receive range and tag hits.\r\n * @return false if search terminated by handler. Return true if no handler returned false.\r\n */\r\n public searchXY(x: number, y: number, handler: (range: Range2d, tag: T) => boolean): boolean {\r\n const i = this.xIndex(x);\r\n const j = this.yIndex(y);\r\n return this.searchXYInIndexedBlock(i, j, x, y, handler)\r\n && this.searchXYInIndexedBlock(i - 1, j, x, y, handler)\r\n && this.searchXYInIndexedBlock(i, j - 1, x, y, handler)\r\n && this.searchXYInIndexedBlock(i - 1, j - 1, x, y, handler);\r\n }\r\n /**\r\n * * Search for ranges overlapping testRange\r\n * * Pass each range and tag to handler\r\n * * terminate search if handler returns false.\r\n * @param testRange search range.\r\n * @param handler function to receive range and tag hits.\r\n * @return false if search terminated by handler. Return true if no handler returned false.\r\n */\r\n public searchRange2d(testRange: LowAndHighXY, handler: (range: Range2d, tag: T) => boolean): boolean {\r\n const xIndex0 = this.xIndex(testRange.low.x) - 1;\r\n const xIndex1 = this.xIndex(testRange.high.x);\r\n const yIndex0 = this.yIndex(testRange.low.y) - 1;\r\n const yIndex1 = this.yIndex(testRange.high.y);\r\n for (let i = xIndex0; i <= xIndex1; i++) {\r\n for (let j = yIndex0; j <= yIndex1; j++) {\r\n if (!this.searchRange2dInIndexedBlock(i, j, testRange, handler))\r\n return false;\r\n }\r\n }\r\n return true;\r\n }\r\n /** Return the overall range of all members. */\r\n public totalRange(result?: Range2d): Range2d {\r\n if (result)\r\n result.setNull();\r\n else\r\n result = Range2d.createNull();\r\n this.visitChildren(0, (_depth, child) => {\r\n const childRange = GriddedRaggedRange2dSet._workRange = child.totalRange(GriddedRaggedRange2dSet._workRange);\r\n result!.extendRange(childRange);\r\n });\r\n return result;\r\n }\r\n /** Call the handler on each defined block in the grid. */\r\n public visitChildren(initialDepth: number, handler: (depth: number, child: Range2dSearchInterface<T>) => void) {\r\n for (const row of this._rangesInBlock) {\r\n for (const block of row) {\r\n if (block)\r\n handler(initialDepth, block);\r\n }\r\n }\r\n }\r\n}\r\n"]}
@@ -1 +1 @@
1
- {"version":3,"file":"GriddedRaggedRange2dSetWithOverflow.js","sourceRoot":"","sources":["../../../../src/polyface/multiclip/GriddedRaggedRange2dSetWithOverflow.ts"],"names":[],"mappings":"AAAA;;;+FAG+F;AAC/F;;GAEG;AAEH,OAAO,EAAE,OAAO,EAAE,MAAM,wBAAwB,CAAC;AAEjD,OAAO,EAAE,uBAAuB,EAAE,MAAM,2BAA2B,CAAC;AACpE,OAAO,EAAE,wBAAwB,EAAE,MAAM,4BAA4B,CAAC;AAGtE;;;;;;;GAOG;AACH,MAAM,OAAO,mCAAmC;IAI9C,YAAoB,OAAmC,EAAE,WAAsC;QAC7F,IAAI,CAAC,QAAQ,GAAG,OAAO,CAAC;QACxB,IAAI,CAAC,YAAY,GAAG,WAAW,CAAC;IAClC,CAAC;IACD;;;;;OAKG;IACI,MAAM,CAAC,MAAM,CAAI,KAAc,EAAE,QAAgB,EAAE,QAAgB;QACxE,MAAM,KAAK,GAAG,uBAAuB,CAAC,MAAM,CAAI,KAAK,CAAC,KAAK,EAAE,EAAE,QAAQ,EAAE,QAAQ,CAAC,CAAC;QACnF,IAAI,KAAK;YACP,OAAO,IAAI,mCAAmC,CAAI,KAAK,EAAE,IAAI,wBAAwB,EAAK,CAAC,CAAC;QAC9F,OAAO,SAAS,CAAC;IACnB,CAAC;IACD;;;;;;;OAOG;IACI,QAAQ,CAAC,CAAS,EAAE,CAAS,EAAE,OAA4C;QAChF,OAAO,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC,EAAE,CAAC,EAAE,OAAO,CAAC,IAAI,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,CAAC,EAAE,CAAC,EAAE,OAAO,CAAC,CAAC;IAC5F,CAAC;IACD;;;;;;;OAOG;IACI,aAAa,CAAC,SAAuB,EAAE,OAA4C;QACxF,OAAO,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC,SAAS,EAAE,OAAO,CAAC,IAAI,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC,SAAS,EAAE,OAAO,CAAC,CAAC;IAChH,CAAC;IACD;;;;;OAKG;IACI,QAAQ,CAAC,KAAmB,EAAE,GAAM;QACzC,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE;YAC1B,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,iBAAiB,CAAC,KAAK,EAAE,GAAG,CAAC;gBAC9C,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,KAAK,EAAE,GAAG,CAAC,CAAC;SAC1C;IACH,CAAC;IACD,+CAA+C;IACxC,UAAU,CAAC,MAAgB;QAChC,IAAI,MAAM;YACR,MAAM,CAAC,OAAO,EAAE,CAAC;;YAEjB,MAAM,GAAG,OAAO,CAAC,UAAU,EAAE,CAAC;QAChC,IAAI,CAAC,aAAa,CAAC,CAAC,EAAE,CAAC,MAAM,EAAE,KAAK,EAAE,EAAE;YACtC,MAAM,UAAU,GAAG,mCAAmC,CAAC,UAAU,GAAG,KAAK,CAAC,UAAU,CAAC,mCAAmC,CAAC,UAAU,CAAC,CAAC;YACrI,MAAO,CAAC,WAAW,CAAC,UAAU,CAAC,CAAC;QAClC,CAAC,CAAC,CAAC;QACH,OAAO,MAAM,CAAC;IAChB,CAAC;IACD,mFAAmF;IAC5E,aAAa,CAAC,YAAoB,EAAE,OAAkE;QAC3G,OAAO,CAAC,YAAY,EAAE,IAAI,CAAC,YAAY,CAAC,CAAC;QACzC,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC,YAAY,GAAG,CAAC,EAAE,OAAO,CAAC,CAAC;IACzD,CAAC;CACF","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 RangeSearch\r\n */\r\n\r\nimport { Range2d } from \"../../geometry3d/Range\";\r\nimport { LowAndHighXY } from \"../../geometry3d/XYZProps\";\r\nimport { GriddedRaggedRange2dSet } from \"./GriddedRaggedRange2dSet\";\r\nimport { LinearSearchRange2dArray } from \"./LinearSearchRange2dArray\";\r\nimport { Range2dSearchInterface } from \"./Range2dSearchInterface\";\r\n\r\n/**\r\n * Use GriddedRaggedRange2dSetWithOverflow for searching among many ranges for which:\r\n * * Most ranges are of somewhat consistent size.\r\n * * A modest number of oversizes.\r\n * * Maintain the smallish ones in a GriddedRaggedRange2dSet.\r\n * * Maintain the overflows in a Range2dSearchInterface.\r\n * @public\r\n */\r\nexport class GriddedRaggedRange2dSetWithOverflow<T> implements Range2dSearchInterface<T> {\r\n private _gridSet: GriddedRaggedRange2dSet<T>;\r\n private _overflowSet: Range2dSearchInterface<T>;\r\n private static _workRange?: Range2d;\r\n private constructor(gridSet: GriddedRaggedRange2dSet<T>, overflowSet: Range2dSearchInterface<T>) {\r\n this._gridSet = gridSet;\r\n this._overflowSet = overflowSet;\r\n }\r\n /**\r\n * Create an (empty) set of ranges.\r\n * @param range\r\n * @param numXEdge\r\n * @param numYEdge\r\n */\r\n public static create<T>(range: Range2d, numXEdge: number, numYEdge: number): GriddedRaggedRange2dSetWithOverflow<T> | undefined {\r\n const grids = GriddedRaggedRange2dSet.create<T>(range.clone(), numXEdge, numYEdge);\r\n if (grids)\r\n return new GriddedRaggedRange2dSetWithOverflow<T>(grids, new LinearSearchRange2dArray<T>());\r\n return undefined;\r\n }\r\n /**\r\n * * Search for ranges containing testRange\r\n * * Pass each range and tag to handler\r\n * * terminate search if handler returns false.\r\n * @param testRange search range.\r\n * @param handler function to receive range and tag hits.\r\n * @return false if search terminated by handler. Return true if no handler returned false.\r\n */\r\n public searchXY(x: number, y: number, handler: (range: Range2d, tag: T) => boolean): boolean {\r\n return this._gridSet.searchXY(x, y, handler) && this._overflowSet.searchXY(x, y, handler);\r\n }\r\n /**\r\n * * Search for ranges overlapping testRange\r\n * * Pass each range and tag to handler\r\n * * terminate search if handler returns false.\r\n * @param testRange search range.\r\n * @param handler function to receive range and tag hits.\r\n * @return false if search terminated by handler. Return true if no handler returned false.\r\n */\r\n public searchRange2d(testRange: LowAndHighXY, handler: (range: Range2d, tag: T) => boolean): boolean {\r\n return this._gridSet.searchRange2d(testRange, handler) && this._overflowSet.searchRange2d(testRange, handler);\r\n }\r\n /** If possible, insert a range into the set.\r\n * * Decline to insert (and return false) if\r\n * * range is null\r\n * * range is not completely contained in the overall range of this set.\r\n * * range x or y extent is larger than 2 grid blocks.\r\n */\r\n public addRange(range: LowAndHighXY, tag: T): void {\r\n if (!Range2d.isNull(range)) {\r\n if (!this._gridSet.conditionalInsert(range, tag))\r\n this._overflowSet.addRange(range, tag);\r\n }\r\n }\r\n /** Return the overall range of all members. */\r\n public totalRange(result?: Range2d): Range2d {\r\n if (result)\r\n result.setNull();\r\n else\r\n result = Range2d.createNull();\r\n this.visitChildren(0, (_depth, child) => {\r\n const childRange = GriddedRaggedRange2dSetWithOverflow._workRange = child.totalRange(GriddedRaggedRange2dSetWithOverflow._workRange);\r\n result!.extendRange(childRange);\r\n });\r\n return result;\r\n }\r\n /** Call the handler on the overflow set, and on each defined block in the grid. */\r\n public visitChildren(initialDepth: number, handler: (depth: number, child: Range2dSearchInterface<T>) => void) {\r\n handler(initialDepth, this._overflowSet);\r\n this._gridSet.visitChildren(initialDepth + 1, handler);\r\n }\r\n}\r\n"]}
1
+ {"version":3,"file":"GriddedRaggedRange2dSetWithOverflow.js","sourceRoot":"","sources":["../../../../src/polyface/multiclip/GriddedRaggedRange2dSetWithOverflow.ts"],"names":[],"mappings":"AAAA;;;+FAG+F;AAC/F;;GAEG;AAEH,OAAO,EAAE,OAAO,EAAE,MAAM,wBAAwB,CAAC;AAEjD,OAAO,EAAE,uBAAuB,EAAE,MAAM,2BAA2B,CAAC;AACpE,OAAO,EAAE,wBAAwB,EAAE,MAAM,4BAA4B,CAAC;AAGtE;;;;;;;GAOG;AACH,MAAM,OAAO,mCAAmC;IAI9C,YAAoB,OAAmC,EAAE,WAAsC;QAC7F,IAAI,CAAC,QAAQ,GAAG,OAAO,CAAC;QACxB,IAAI,CAAC,YAAY,GAAG,WAAW,CAAC;IAClC,CAAC;IACD;;;;;OAKG;IACI,MAAM,CAAC,MAAM,CAAI,KAAc,EAAE,QAAgB,EAAE,QAAgB;QACxE,MAAM,KAAK,GAAG,uBAAuB,CAAC,MAAM,CAAI,KAAK,CAAC,KAAK,EAAE,EAAE,QAAQ,EAAE,QAAQ,CAAC,CAAC;QACnF,IAAI,KAAK;YACP,OAAO,IAAI,mCAAmC,CAAI,KAAK,EAAE,IAAI,wBAAwB,EAAK,CAAC,CAAC;QAC9F,OAAO,SAAS,CAAC;IACnB,CAAC;IACD;;;;;;;OAOG;IACI,QAAQ,CAAC,CAAS,EAAE,CAAS,EAAE,OAA4C;QAChF,OAAO,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC,EAAE,CAAC,EAAE,OAAO,CAAC,IAAI,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,CAAC,EAAE,CAAC,EAAE,OAAO,CAAC,CAAC;IAC5F,CAAC;IACD;;;;;;;OAOG;IACI,aAAa,CAAC,SAAuB,EAAE,OAA4C;QACxF,OAAO,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC,SAAS,EAAE,OAAO,CAAC,IAAI,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC,SAAS,EAAE,OAAO,CAAC,CAAC;IAChH,CAAC;IACD;;;;;OAKG;IACI,QAAQ,CAAC,KAAmB,EAAE,GAAM;QACzC,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE,CAAC;YAC3B,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,iBAAiB,CAAC,KAAK,EAAE,GAAG,CAAC;gBAC9C,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,KAAK,EAAE,GAAG,CAAC,CAAC;QAC3C,CAAC;IACH,CAAC;IACD,+CAA+C;IACxC,UAAU,CAAC,MAAgB;QAChC,IAAI,MAAM;YACR,MAAM,CAAC,OAAO,EAAE,CAAC;;YAEjB,MAAM,GAAG,OAAO,CAAC,UAAU,EAAE,CAAC;QAChC,IAAI,CAAC,aAAa,CAAC,CAAC,EAAE,CAAC,MAAM,EAAE,KAAK,EAAE,EAAE;YACtC,MAAM,UAAU,GAAG,mCAAmC,CAAC,UAAU,GAAG,KAAK,CAAC,UAAU,CAAC,mCAAmC,CAAC,UAAU,CAAC,CAAC;YACrI,MAAO,CAAC,WAAW,CAAC,UAAU,CAAC,CAAC;QAClC,CAAC,CAAC,CAAC;QACH,OAAO,MAAM,CAAC;IAChB,CAAC;IACD,mFAAmF;IAC5E,aAAa,CAAC,YAAoB,EAAE,OAAkE;QAC3G,OAAO,CAAC,YAAY,EAAE,IAAI,CAAC,YAAY,CAAC,CAAC;QACzC,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC,YAAY,GAAG,CAAC,EAAE,OAAO,CAAC,CAAC;IACzD,CAAC;CACF","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 RangeSearch\r\n */\r\n\r\nimport { Range2d } from \"../../geometry3d/Range\";\r\nimport { LowAndHighXY } from \"../../geometry3d/XYZProps\";\r\nimport { GriddedRaggedRange2dSet } from \"./GriddedRaggedRange2dSet\";\r\nimport { LinearSearchRange2dArray } from \"./LinearSearchRange2dArray\";\r\nimport { Range2dSearchInterface } from \"./Range2dSearchInterface\";\r\n\r\n/**\r\n * Use GriddedRaggedRange2dSetWithOverflow for searching among many ranges for which:\r\n * * Most ranges are of somewhat consistent size.\r\n * * A modest number of oversizes.\r\n * * Maintain the smallish ones in a GriddedRaggedRange2dSet.\r\n * * Maintain the overflows in a Range2dSearchInterface.\r\n * @public\r\n */\r\nexport class GriddedRaggedRange2dSetWithOverflow<T> implements Range2dSearchInterface<T> {\r\n private _gridSet: GriddedRaggedRange2dSet<T>;\r\n private _overflowSet: Range2dSearchInterface<T>;\r\n private static _workRange?: Range2d;\r\n private constructor(gridSet: GriddedRaggedRange2dSet<T>, overflowSet: Range2dSearchInterface<T>) {\r\n this._gridSet = gridSet;\r\n this._overflowSet = overflowSet;\r\n }\r\n /**\r\n * Create an (empty) set of ranges.\r\n * @param range\r\n * @param numXEdge\r\n * @param numYEdge\r\n */\r\n public static create<T>(range: Range2d, numXEdge: number, numYEdge: number): GriddedRaggedRange2dSetWithOverflow<T> | undefined {\r\n const grids = GriddedRaggedRange2dSet.create<T>(range.clone(), numXEdge, numYEdge);\r\n if (grids)\r\n return new GriddedRaggedRange2dSetWithOverflow<T>(grids, new LinearSearchRange2dArray<T>());\r\n return undefined;\r\n }\r\n /**\r\n * * Search for ranges containing testRange\r\n * * Pass each range and tag to handler\r\n * * terminate search if handler returns false.\r\n * @param testRange search range.\r\n * @param handler function to receive range and tag hits.\r\n * @return false if search terminated by handler. Return true if no handler returned false.\r\n */\r\n public searchXY(x: number, y: number, handler: (range: Range2d, tag: T) => boolean): boolean {\r\n return this._gridSet.searchXY(x, y, handler) && this._overflowSet.searchXY(x, y, handler);\r\n }\r\n /**\r\n * * Search for ranges overlapping testRange\r\n * * Pass each range and tag to handler\r\n * * terminate search if handler returns false.\r\n * @param testRange search range.\r\n * @param handler function to receive range and tag hits.\r\n * @return false if search terminated by handler. Return true if no handler returned false.\r\n */\r\n public searchRange2d(testRange: LowAndHighXY, handler: (range: Range2d, tag: T) => boolean): boolean {\r\n return this._gridSet.searchRange2d(testRange, handler) && this._overflowSet.searchRange2d(testRange, handler);\r\n }\r\n /** If possible, insert a range into the set.\r\n * * Decline to insert (and return false) if\r\n * * range is null\r\n * * range is not completely contained in the overall range of this set.\r\n * * range x or y extent is larger than 2 grid blocks.\r\n */\r\n public addRange(range: LowAndHighXY, tag: T): void {\r\n if (!Range2d.isNull(range)) {\r\n if (!this._gridSet.conditionalInsert(range, tag))\r\n this._overflowSet.addRange(range, tag);\r\n }\r\n }\r\n /** Return the overall range of all members. */\r\n public totalRange(result?: Range2d): Range2d {\r\n if (result)\r\n result.setNull();\r\n else\r\n result = Range2d.createNull();\r\n this.visitChildren(0, (_depth, child) => {\r\n const childRange = GriddedRaggedRange2dSetWithOverflow._workRange = child.totalRange(GriddedRaggedRange2dSetWithOverflow._workRange);\r\n result!.extendRange(childRange);\r\n });\r\n return result;\r\n }\r\n /** Call the handler on the overflow set, and on each defined block in the grid. */\r\n public visitChildren(initialDepth: number, handler: (depth: number, child: Range2dSearchInterface<T>) => void) {\r\n handler(initialDepth, this._overflowSet);\r\n this._gridSet.visitChildren(initialDepth + 1, handler);\r\n }\r\n}\r\n"]}
@@ -1 +1 @@
1
- {"version":3,"file":"LinearSearchRange2dArray.js","sourceRoot":"","sources":["../../../../src/polyface/multiclip/LinearSearchRange2dArray.ts"],"names":[],"mappings":"AAAA;;;+FAG+F;AAC/F;;GAEG;AAEH,OAAO,EAAE,OAAO,EAAE,MAAM,wBAAwB,CAAC;AAIjD;;;;;;GAMG;AACH,MAAM,OAAO,wBAAwB;IAInC;QACE,IAAI,CAAC,WAAW,GAAG,EAAE,CAAC;QACtB,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;QACtB,IAAI,CAAC,eAAe,GAAG,OAAO,CAAC,UAAU,EAAE,CAAC;IAC9C,CAAC;IACD,+BAA+B;IACvB,eAAe;QACrB,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;IACxB,CAAC;IACD,+CAA+C;IACxC,UAAU,CAAC,MAAgB;QAChC,OAAO,IAAI,CAAC,eAAe,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;IAC5C,CAAC;IACD,qCAAqC;IAC9B,QAAQ,CAAC,KAAmB,EAAE,GAAM;QACzC,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;QACrB,MAAM,OAAO,GAAG,OAAO,CAAC,UAAU,EAAE,CAAC;QACpC,OAAe,CAAC,GAAG,GAAG,GAAG,CAAC;QAC3B,OAAO,CAAC,QAAQ,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,EAAE,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;QAC3C,OAAO,CAAC,QAAQ,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,EAAE,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QAC7C,IAAI,CAAC,eAAe,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC;QAC1C,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IACjC,CAAC;IACD;;;;;;;OAOG;IACI,QAAQ,CAAC,CAAS,EAAE,CAAS,EAAE,OAA4C;QAChF,IAAI,IAAI,CAAC,QAAQ;YACf,IAAI,CAAC,eAAe,EAAE,CAAC;QACzB,+CAA+C;QAC/C,KAAK,MAAM,SAAS,IAAI,IAAI,CAAC,WAAW,EAAE;YACxC,IAAI,SAAS,CAAC,UAAU,CAAC,CAAC,EAAE,CAAC,CAAC;gBAC5B,IAAI,CAAC,OAAO,CAAC,SAAS,EAAG,SAAiB,CAAC,GAAG,CAAC;oBAC7C,OAAO,KAAK,CAAC;SAClB;QACD,OAAO,IAAI,CAAC;IACd,CAAC;IACD;;;;;;;OAOG;IACI,aAAa,CAAC,SAAuB,EAAE,OAA4C;QACxF,IAAI,IAAI,CAAC,QAAQ;YACf,IAAI,CAAC,eAAe,EAAE,CAAC;QACzB,KAAK,MAAM,SAAS,IAAI,IAAI,CAAC,WAAW,EAAE;YACxC,IAAI,SAAS,CAAC,eAAe,CAAC,SAAS,CAAC;gBACtC,IAAI,CAAC,OAAO,CAAC,SAAS,EAAG,SAAiB,CAAC,GAAG,CAAC;oBAC7C,OAAO,KAAK,CAAC;SAClB;QACD,OAAO,IAAI,CAAC;IACd,CAAC;CACF","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 RangeSearch\r\n */\r\n\r\nimport { Range2d } from \"../../geometry3d/Range\";\r\nimport { LowAndHighXY } from \"../../geometry3d/XYZProps\";\r\nimport { Range2dSearchInterface } from \"./Range2dSearchInterface\";\r\n\r\n/**\r\n * An array of decorated Range2d.\r\n * * User data is attached to each range via `(myRange as any).tag = myTag`.\r\n * * Search operations are simple linear.\r\n * * This class can be used directly for \"smallish\" range sets, or as the leaf level of hierarchical structures for larger range sets.\r\n * @internal\r\n */\r\nexport class LinearSearchRange2dArray<T> implements Range2dSearchInterface<T> {\r\n private _rangeArray: Range2d[];\r\n private _isDirty: boolean;\r\n private _compositeRange: Range2d;\r\n public constructor() {\r\n this._rangeArray = [];\r\n this._isDirty = false;\r\n this._compositeRange = Range2d.createNull();\r\n }\r\n // TODO: build search structure\r\n private updateForSearch() {\r\n this._isDirty = false;\r\n }\r\n /** Return the overall range of all members. */\r\n public totalRange(result?: Range2d): Range2d {\r\n return this._compositeRange.clone(result);\r\n }\r\n /** Add a range to the search set. */\r\n public addRange(range: LowAndHighXY, tag: T): void {\r\n this._isDirty = true;\r\n const myRange = Range2d.createNull();\r\n (myRange as any).tag = tag;\r\n myRange.extendXY(range.low.x, range.low.y);\r\n myRange.extendXY(range.high.x, range.high.y);\r\n this._compositeRange.extendRange(myRange);\r\n this._rangeArray.push(myRange);\r\n }\r\n /**\r\n * * Search for ranges containing testRange\r\n * * Pass each range and tag to handler\r\n * * terminate search if handler returns false.\r\n * @param testRange search range.\r\n * @param handler function to receive range and tag hits.\r\n * @return false if search terminated by handler. Return true if no handler returned false.\r\n */\r\n public searchXY(x: number, y: number, handler: (range: Range2d, tag: T) => boolean): boolean {\r\n if (this._isDirty)\r\n this.updateForSearch();\r\n // NEEDS WORK: Linear search here -- do better!\r\n for (const candidate of this._rangeArray) {\r\n if (candidate.containsXY(x, y))\r\n if (!handler(candidate, (candidate as any).tag))\r\n return false;\r\n }\r\n return true;\r\n }\r\n /**\r\n * * Search for ranges overlapping testRange\r\n * * Pass each range and tag to handler\r\n * * terminate search if handler returns false.\r\n * @param testRange search range.\r\n * @param handler function to receive range and tag hits.\r\n * @return false if search terminated by handler. Return true if no handler returned false.\r\n */\r\n public searchRange2d(testRange: LowAndHighXY, handler: (range: Range2d, tag: T) => boolean): boolean {\r\n if (this._isDirty)\r\n this.updateForSearch();\r\n for (const candidate of this._rangeArray) {\r\n if (candidate.intersectsRange(testRange))\r\n if (!handler(candidate, (candidate as any).tag))\r\n return false;\r\n }\r\n return true;\r\n }\r\n}\r\n"]}
1
+ {"version":3,"file":"LinearSearchRange2dArray.js","sourceRoot":"","sources":["../../../../src/polyface/multiclip/LinearSearchRange2dArray.ts"],"names":[],"mappings":"AAAA;;;+FAG+F;AAC/F;;GAEG;AAEH,OAAO,EAAE,OAAO,EAAE,MAAM,wBAAwB,CAAC;AAIjD;;;;;;GAMG;AACH,MAAM,OAAO,wBAAwB;IAInC;QACE,IAAI,CAAC,WAAW,GAAG,EAAE,CAAC;QACtB,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;QACtB,IAAI,CAAC,eAAe,GAAG,OAAO,CAAC,UAAU,EAAE,CAAC;IAC9C,CAAC;IACD,+BAA+B;IACvB,eAAe;QACrB,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;IACxB,CAAC;IACD,+CAA+C;IACxC,UAAU,CAAC,MAAgB;QAChC,OAAO,IAAI,CAAC,eAAe,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;IAC5C,CAAC;IACD,qCAAqC;IAC9B,QAAQ,CAAC,KAAmB,EAAE,GAAM;QACzC,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;QACrB,MAAM,OAAO,GAAG,OAAO,CAAC,UAAU,EAAE,CAAC;QACpC,OAAe,CAAC,GAAG,GAAG,GAAG,CAAC;QAC3B,OAAO,CAAC,QAAQ,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,EAAE,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;QAC3C,OAAO,CAAC,QAAQ,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,EAAE,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QAC7C,IAAI,CAAC,eAAe,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC;QAC1C,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IACjC,CAAC;IACD;;;;;;;OAOG;IACI,QAAQ,CAAC,CAAS,EAAE,CAAS,EAAE,OAA4C;QAChF,IAAI,IAAI,CAAC,QAAQ;YACf,IAAI,CAAC,eAAe,EAAE,CAAC;QACzB,+CAA+C;QAC/C,KAAK,MAAM,SAAS,IAAI,IAAI,CAAC,WAAW,EAAE,CAAC;YACzC,IAAI,SAAS,CAAC,UAAU,CAAC,CAAC,EAAE,CAAC,CAAC;gBAC5B,IAAI,CAAC,OAAO,CAAC,SAAS,EAAG,SAAiB,CAAC,GAAG,CAAC;oBAC7C,OAAO,KAAK,CAAC;QACnB,CAAC;QACD,OAAO,IAAI,CAAC;IACd,CAAC;IACD;;;;;;;OAOG;IACI,aAAa,CAAC,SAAuB,EAAE,OAA4C;QACxF,IAAI,IAAI,CAAC,QAAQ;YACf,IAAI,CAAC,eAAe,EAAE,CAAC;QACzB,KAAK,MAAM,SAAS,IAAI,IAAI,CAAC,WAAW,EAAE,CAAC;YACzC,IAAI,SAAS,CAAC,eAAe,CAAC,SAAS,CAAC;gBACtC,IAAI,CAAC,OAAO,CAAC,SAAS,EAAG,SAAiB,CAAC,GAAG,CAAC;oBAC7C,OAAO,KAAK,CAAC;QACnB,CAAC;QACD,OAAO,IAAI,CAAC;IACd,CAAC;CACF","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 RangeSearch\r\n */\r\n\r\nimport { Range2d } from \"../../geometry3d/Range\";\r\nimport { LowAndHighXY } from \"../../geometry3d/XYZProps\";\r\nimport { Range2dSearchInterface } from \"./Range2dSearchInterface\";\r\n\r\n/**\r\n * An array of decorated Range2d.\r\n * * User data is attached to each range via `(myRange as any).tag = myTag`.\r\n * * Search operations are simple linear.\r\n * * This class can be used directly for \"smallish\" range sets, or as the leaf level of hierarchical structures for larger range sets.\r\n * @internal\r\n */\r\nexport class LinearSearchRange2dArray<T> implements Range2dSearchInterface<T> {\r\n private _rangeArray: Range2d[];\r\n private _isDirty: boolean;\r\n private _compositeRange: Range2d;\r\n public constructor() {\r\n this._rangeArray = [];\r\n this._isDirty = false;\r\n this._compositeRange = Range2d.createNull();\r\n }\r\n // TODO: build search structure\r\n private updateForSearch() {\r\n this._isDirty = false;\r\n }\r\n /** Return the overall range of all members. */\r\n public totalRange(result?: Range2d): Range2d {\r\n return this._compositeRange.clone(result);\r\n }\r\n /** Add a range to the search set. */\r\n public addRange(range: LowAndHighXY, tag: T): void {\r\n this._isDirty = true;\r\n const myRange = Range2d.createNull();\r\n (myRange as any).tag = tag;\r\n myRange.extendXY(range.low.x, range.low.y);\r\n myRange.extendXY(range.high.x, range.high.y);\r\n this._compositeRange.extendRange(myRange);\r\n this._rangeArray.push(myRange);\r\n }\r\n /**\r\n * * Search for ranges containing testRange\r\n * * Pass each range and tag to handler\r\n * * terminate search if handler returns false.\r\n * @param testRange search range.\r\n * @param handler function to receive range and tag hits.\r\n * @return false if search terminated by handler. Return true if no handler returned false.\r\n */\r\n public searchXY(x: number, y: number, handler: (range: Range2d, tag: T) => boolean): boolean {\r\n if (this._isDirty)\r\n this.updateForSearch();\r\n // NEEDS WORK: Linear search here -- do better!\r\n for (const candidate of this._rangeArray) {\r\n if (candidate.containsXY(x, y))\r\n if (!handler(candidate, (candidate as any).tag))\r\n return false;\r\n }\r\n return true;\r\n }\r\n /**\r\n * * Search for ranges overlapping testRange\r\n * * Pass each range and tag to handler\r\n * * terminate search if handler returns false.\r\n * @param testRange search range.\r\n * @param handler function to receive range and tag hits.\r\n * @return false if search terminated by handler. Return true if no handler returned false.\r\n */\r\n public searchRange2d(testRange: LowAndHighXY, handler: (range: Range2d, tag: T) => boolean): boolean {\r\n if (this._isDirty)\r\n this.updateForSearch();\r\n for (const candidate of this._rangeArray) {\r\n if (candidate.intersectsRange(testRange))\r\n if (!handler(candidate, (candidate as any).tag))\r\n return false;\r\n }\r\n return true;\r\n }\r\n}\r\n"]}
@@ -600,7 +600,7 @@ export class OffsetMeshContext {
600
600
  assignOffsetByAverageNormalAroundVertex(vertexSeed, maxAllowedDeviationRadians, data, distance) {
601
601
  const maxDeviationRadians = this.computeAverageNormalAndMaxDeviationAroundVertex(vertexSeed, data);
602
602
  if (OffsetMeshContext.stringDebugFunction) {
603
- OffsetMeshContext.stringDebugFunction(`XYZ ${HalfEdge.nodeToIdXYZString(vertexSeed)} Average Normal ${data.averageNormal.toJSON()}`);
603
+ OffsetMeshContext.stringDebugFunction(`XYZ ${HalfEdge.nodeToIdXYZString(vertexSeed)} Average Normal ${JSON.stringify(data.averageNormal.toJSON())}`);
604
604
  OffsetMeshContext.stringDebugFunction(` angle ratio ${data.radiansSum / (2 * Math.PI)} maxDeviation ${data.maxDeviationRadiansFromAverage}`);
605
605
  }
606
606
  if (maxDeviationRadians !== undefined && maxDeviationRadians <= maxAllowedDeviationRadians) {
@@ -883,7 +883,7 @@ export class OffsetMeshContext {
883
883
  vertexSeed = vertexSeedA;
884
884
  if (OffsetMeshContext.stringDebugFunction !== undefined) {
885
885
  OffsetMeshContext.stringDebugFunction("");
886
- OffsetMeshContext.stringDebugFunction(` VERTEX LOOP ${vertexSeed.getPoint3d().toJSON()} `);
886
+ OffsetMeshContext.stringDebugFunction(` VERTEX LOOP ${JSON.stringify(vertexSeed.getPoint3d().toJSON())} `);
887
887
  vertexSeed.sumAroundVertex((node) => { OffsetMeshContext.stringDebugFunction(this.inspectMasks(node, false, true)); return 0; });
888
888
  }
889
889
  // Take care of the easiest vertices directly . . . note that this returns from the lambda, not computeOffsetFacetIntersections