@woosh/meep-engine 2.155.0 → 2.156.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (475) hide show
  1. package/README.md +1 -1
  2. package/build/bundle-worker-image-decoder.js +1 -1
  3. package/build/bundle-worker-terrain.js +1 -1
  4. package/editor/view/ecs/ComponentControlView.d.ts +0 -9
  5. package/editor/view/ecs/ComponentControlView.js +2 -98
  6. package/package.json +1 -1
  7. package/src/core/binary/32BitEncoder.js +1 -1
  8. package/src/core/binary/to_half_float_uint16.js +3 -3
  9. package/src/core/bvh2/bvh3/ebvh_build_hierarchy_radix.d.ts.map +1 -1
  10. package/src/core/bvh2/bvh3/ebvh_build_hierarchy_radix.js +275 -253
  11. package/src/core/cache/Cache.d.ts.map +1 -1
  12. package/src/core/cache/Cache.js +7 -0
  13. package/src/core/cache/FrequencySketch.d.ts.map +1 -1
  14. package/src/core/cache/FrequencySketch.js +8 -4
  15. package/src/core/clipboard/obtainClipBoard.d.ts +6 -0
  16. package/src/core/clipboard/obtainClipBoard.d.ts.map +1 -0
  17. package/src/core/clipboard/obtainClipBoard.js +29 -0
  18. package/src/core/clipboard/safeClipboardReadText.d.ts +6 -0
  19. package/src/core/clipboard/safeClipboardReadText.d.ts.map +1 -0
  20. package/src/core/clipboard/safeClipboardReadText.js +55 -0
  21. package/src/core/clipboard/safeClipboardWriteText.d.ts +8 -0
  22. package/src/core/clipboard/safeClipboardWriteText.d.ts.map +1 -0
  23. package/src/core/clipboard/safeClipboardWriteText.js +23 -0
  24. package/src/core/collection/array/array_quick_sort_by_lookup_map.js +1 -1
  25. package/src/core/collection/array/array_set_diff_sorting.d.ts.map +1 -1
  26. package/src/core/collection/array/array_set_diff_sorting.js +4 -1
  27. package/src/core/collection/array/array_shuffle.d.ts.map +1 -1
  28. package/src/core/collection/array/array_shuffle.js +30 -27
  29. package/src/core/collection/array/binarySearchLowIndex.d.ts.map +1 -1
  30. package/src/core/collection/array/binarySearchLowIndex.js +4 -3
  31. package/src/core/collection/array/typed/array_buffer_hash.js +1 -1
  32. package/src/core/collection/array/typed/is_typed_array_equals.d.ts.map +1 -1
  33. package/src/core/collection/array/typed/is_typed_array_equals.js +12 -2
  34. package/src/core/collection/heap/BinaryHeap.d.ts.map +1 -1
  35. package/src/core/collection/heap/BinaryHeap.js +12 -2
  36. package/src/core/collection/queue/Deque.d.ts.map +1 -1
  37. package/src/core/collection/queue/Deque.js +10 -8
  38. package/src/core/collection/table/RowFirstTable.d.ts.map +1 -1
  39. package/src/core/collection/table/RowFirstTable.js +4 -2
  40. package/src/core/collection/table/RowFirstTableSpec.js +2 -2
  41. package/src/core/color/operations/color_lerp.d.ts.map +1 -1
  42. package/src/core/color/operations/color_lerp.js +10 -3
  43. package/src/core/color/rgb2uint32.js +1 -1
  44. package/src/core/color/rgbe9995_to_rgb.js +1 -1
  45. package/src/core/function/objectsEqual.d.ts.map +1 -1
  46. package/src/core/function/objectsEqual.js +2 -1
  47. package/src/core/geom/2d/aabb/AABB2.d.ts.map +1 -1
  48. package/src/core/geom/2d/aabb/AABB2.js +12 -11
  49. package/src/core/geom/2d/convex-hull/convex_hull_jarvis_2d.d.ts.map +1 -1
  50. package/src/core/geom/2d/convex-hull/convex_hull_jarvis_2d.js +30 -4
  51. package/src/core/geom/2d/convex-hull/fixed_convex_hull_relaxation.d.ts.map +1 -1
  52. package/src/core/geom/2d/convex-hull/fixed_convex_hull_relaxation.js +6 -2
  53. package/src/core/geom/2d/hash-grid/SpatialHashGrid.d.ts.map +1 -1
  54. package/src/core/geom/2d/hash-grid/SpatialHashGrid.js +388 -386
  55. package/src/core/geom/2d/hash-grid/shg_query_elements_line.d.ts.map +1 -1
  56. package/src/core/geom/2d/hash-grid/shg_query_elements_line.js +8 -3
  57. package/src/core/geom/2d/quad-tree/QuadTreeDatum.d.ts.map +1 -1
  58. package/src/core/geom/2d/quad-tree/QuadTreeDatum.js +9 -1
  59. package/src/core/geom/2d/quad-tree/qt_query_data_nearest_to_point.d.ts +3 -1
  60. package/src/core/geom/2d/quad-tree/qt_query_data_nearest_to_point.d.ts.map +1 -1
  61. package/src/core/geom/2d/quad-tree/qt_query_data_nearest_to_point.js +3 -1
  62. package/src/core/geom/2d/quad-tree-binary/QuadTree.js +714 -714
  63. package/src/core/geom/2d/r-tree/StaticR2Tree.d.ts.map +1 -1
  64. package/src/core/geom/2d/r-tree/StaticR2Tree.js +5 -4
  65. package/src/core/geom/3d/aabb/aabb3_detailed_volume_intersection.d.ts.map +1 -1
  66. package/src/core/geom/3d/aabb/aabb3_detailed_volume_intersection.js +33 -29
  67. package/src/core/geom/3d/aabb/aabb3_near_distance_to_intersection_ray_segment.d.ts.map +1 -1
  68. package/src/core/geom/3d/aabb/aabb3_near_distance_to_intersection_ray_segment.js +3 -1
  69. package/src/core/geom/3d/aabb/aabb3_signed_distance_to_aabb3.d.ts.map +1 -1
  70. package/src/core/geom/3d/aabb/aabb3_signed_distance_to_aabb3.js +10 -7
  71. package/src/core/geom/3d/aabb/aabb3_transformed_compute_plane_side.d.ts.map +1 -1
  72. package/src/core/geom/3d/aabb/aabb3_transformed_compute_plane_side.js +30 -9
  73. package/src/core/geom/3d/aabb/compute_aabb_from_points.js +3 -3
  74. package/src/core/geom/3d/box/box3_raycast.d.ts +37 -0
  75. package/src/core/geom/3d/box/box3_raycast.d.ts.map +1 -0
  76. package/src/core/geom/3d/box/box3_raycast.js +81 -0
  77. package/src/core/geom/3d/capsule/capsule_raycast.d.ts +35 -0
  78. package/src/core/geom/3d/capsule/capsule_raycast.d.ts.map +1 -0
  79. package/src/core/geom/3d/capsule/capsule_raycast.js +93 -0
  80. package/src/core/geom/3d/cone/compute_bounding_cone_of_2_cones.d.ts.map +1 -1
  81. package/src/core/geom/3d/cone/compute_bounding_cone_of_2_cones.js +4 -0
  82. package/src/core/geom/3d/frustum/frustum3_computeNearestPointToPoint.js +1 -1
  83. package/src/core/geom/3d/line/line3_compute_segment_point_distance_eikonal.d.ts.map +1 -1
  84. package/src/core/geom/3d/line/line3_compute_segment_point_distance_eikonal.js +3 -2
  85. package/src/core/geom/3d/mat4/decompose_matrix_4_array.d.ts.map +1 -1
  86. package/src/core/geom/3d/mat4/decompose_matrix_4_array.js +12 -2
  87. package/src/core/geom/3d/mat4/eulerAnglesFromMatrix.js +2 -2
  88. package/src/core/geom/3d/mat4/m4_multiply_alphatensor.d.ts +1 -1
  89. package/src/core/geom/3d/mat4/m4_multiply_alphatensor.d.ts.map +1 -1
  90. package/src/core/geom/3d/mat4/m4_multiply_alphatensor.js +19 -13
  91. package/src/core/geom/3d/octahedra/octahedral_direction_to_uv.d.ts.map +1 -1
  92. package/src/core/geom/3d/octahedra/octahedral_direction_to_uv.js +3 -2
  93. package/src/core/geom/3d/plane/plane3_compute_plane_intersection.js +3 -2
  94. package/src/core/geom/3d/shape/MeshShape3D.d.ts.map +1 -1
  95. package/src/core/geom/3d/shape/MeshShape3D.js +7 -0
  96. package/src/core/geom/3d/shape/UnionShape3D.d.ts.map +1 -1
  97. package/src/core/geom/3d/shape/UnionShape3D.js +3 -2
  98. package/src/core/geom/3d/shape/util/shape3d_voxelize_to_grid.d.ts.map +1 -1
  99. package/src/core/geom/3d/shape/util/shape3d_voxelize_to_grid.js +153 -148
  100. package/src/core/geom/3d/sphere/harmonics/sh3_dering_optimize_positive.d.ts.map +1 -1
  101. package/src/core/geom/3d/sphere/harmonics/sh3_dering_optimize_positive.js +7 -0
  102. package/src/core/geom/3d/sphere/harmonics/sh3_sample_by_direction.d.ts.map +1 -1
  103. package/src/core/geom/3d/sphere/harmonics/sh3_sample_by_direction.js +13 -10
  104. package/src/core/geom/3d/sphere/sphere_projected_sphere_radius_sqr.d.ts +1 -1
  105. package/src/core/geom/3d/sphere/sphere_projected_sphere_radius_sqr.js +2 -2
  106. package/src/core/geom/3d/sphere/sphere_raycast.d.ts +33 -0
  107. package/src/core/geom/3d/sphere/sphere_raycast.d.ts.map +1 -0
  108. package/src/core/geom/3d/sphere/sphere_raycast.js +47 -0
  109. package/src/core/geom/3d/tetrahedra/tetrahedral_mesh_tet_get_neighbours.d.ts +24 -0
  110. package/src/core/geom/3d/tetrahedra/tetrahedral_mesh_tet_get_neighbours.d.ts.map +1 -0
  111. package/src/core/geom/3d/tetrahedra/tetrahedral_mesh_tet_get_neighbours.js +39 -0
  112. package/src/core/geom/3d/tetrahedra/triangle/trace_triangular_depth_map.d.ts.map +1 -1
  113. package/src/core/geom/3d/tetrahedra/triangle/trace_triangular_depth_map.js +4 -2
  114. package/src/core/geom/3d/topology/bounds/computeTriangleClusterNormalBoundingCone.js +3 -3
  115. package/src/core/geom/3d/topology/simplify/decimate_edge_collapse_snap.js +1 -1
  116. package/src/core/geom/3d/topology/tm_vertex_compute_normal.d.ts.map +1 -1
  117. package/src/core/geom/3d/topology/tm_vertex_compute_normal.js +4 -2
  118. package/src/core/geom/3d/util/make_justified_point_grid.d.ts.map +1 -1
  119. package/src/core/geom/3d/util/make_justified_point_grid.js +18 -10
  120. package/src/core/geom/ConicRay.d.ts.map +1 -1
  121. package/src/core/geom/ConicRay.js +11 -13
  122. package/src/core/geom/packing/max-rect/removeRedundantBoxes.d.ts.map +1 -1
  123. package/src/core/geom/packing/max-rect/removeRedundantBoxes.js +19 -4
  124. package/src/core/geom/vec3/v3_orthonormal_matrix_from_normal.d.ts.map +1 -0
  125. package/src/{engine/graphics/sh3/path_tracer/sampling → core/geom/vec3}/v3_orthonormal_matrix_from_normal.js +1 -1
  126. package/src/core/graph/coloring/colorizeGraph.js +2 -2
  127. package/src/core/graph/csr/CSRGraph.d.ts.map +1 -1
  128. package/src/core/graph/csr/CSRGraph.js +325 -319
  129. package/src/core/graph/layout/CircleLayout.d.ts.map +1 -1
  130. package/src/core/graph/layout/CircleLayout.js +8 -6
  131. package/src/core/graph/metis/native/refine/compute_kway_params.d.ts.map +1 -1
  132. package/src/core/graph/metis/native/refine/compute_kway_params.js +139 -138
  133. package/src/core/graph/mn_graph_coarsen.d.ts.map +1 -1
  134. package/src/core/graph/mn_graph_coarsen.js +4 -2
  135. package/src/core/graph/v2/NodeContainer.js +7 -7
  136. package/src/core/localization/LocalizationEngine.js +1 -1
  137. package/src/core/math/bell_membership_function.d.ts.map +1 -1
  138. package/src/core/math/bell_membership_function.js +3 -1
  139. package/src/core/math/complex/complex_add.d.ts +4 -4
  140. package/src/core/math/complex/complex_add.d.ts.map +1 -1
  141. package/src/core/math/complex/complex_add.js +3 -3
  142. package/src/core/math/complex/complex_div.d.ts +4 -4
  143. package/src/core/math/complex/complex_div.d.ts.map +1 -1
  144. package/src/core/math/complex/complex_div.js +3 -3
  145. package/src/core/math/complex/complex_mul.d.ts +4 -4
  146. package/src/core/math/complex/complex_mul.d.ts.map +1 -1
  147. package/src/core/math/complex/complex_mul.js +3 -3
  148. package/src/core/math/complex/complex_sub.d.ts +4 -4
  149. package/src/core/math/complex/complex_sub.d.ts.map +1 -1
  150. package/src/core/math/complex/complex_sub.js +3 -3
  151. package/src/core/math/idct_1d.d.ts +4 -4
  152. package/src/core/math/idct_1d.d.ts.map +1 -1
  153. package/src/core/math/idct_1d.js +3 -3
  154. package/src/core/math/noise/create_simplex_noise_2d.d.ts.map +1 -1
  155. package/src/core/math/noise/create_simplex_noise_2d.js +4 -2
  156. package/src/core/math/noise/sdnoise.d.ts.map +1 -1
  157. package/src/core/math/noise/sdnoise.js +12 -9
  158. package/src/core/math/physics/mie/compute_bhmie_optical_properties.d.ts.map +1 -1
  159. package/src/core/math/physics/mie/compute_bhmie_optical_properties.js +94 -50
  160. package/src/core/math/physics/mie/lorenz_mie_coefs.d.ts +3 -6
  161. package/src/core/math/physics/mie/lorenz_mie_coefs.d.ts.map +1 -1
  162. package/src/core/math/physics/mie/lorenz_mie_coefs.js +180 -157
  163. package/src/core/math/physics/mie/mie_ab_to_optical_properties.d.ts +3 -4
  164. package/src/core/math/physics/mie/mie_ab_to_optical_properties.d.ts.map +1 -1
  165. package/src/core/math/physics/mie/mie_ab_to_optical_properties.js +47 -21
  166. package/src/core/math/random/randomIntegerBetween.d.ts.map +1 -1
  167. package/src/core/math/random/randomIntegerBetween.js +4 -1
  168. package/src/core/math/solveCubic.d.ts.map +1 -1
  169. package/src/core/math/solveCubic.js +95 -82
  170. package/src/core/math/spline/computeCatmullRomSplineUniformDistance.d.ts.map +1 -1
  171. package/src/core/math/spline/computeCatmullRomSplineUniformDistance.js +13 -0
  172. package/src/core/math/statistics/softmax.js +1 -1
  173. package/src/core/model/node-graph/visual/NodeGraphVisualData.d.ts +1 -0
  174. package/src/core/model/node-graph/visual/NodeGraphVisualData.d.ts.map +1 -1
  175. package/src/core/model/node-graph/visual/NodeGraphVisualData.js +2 -1
  176. package/src/core/model/node-graph/visual/NodeVisualData.js +1 -1
  177. package/src/core/model/object/ImmutableObjectPool.d.ts +7 -0
  178. package/src/core/model/object/ImmutableObjectPool.d.ts.map +1 -1
  179. package/src/core/model/object/ImmutableObjectPool.js +20 -10
  180. package/src/core/model/reactive/evaluation/MultiPredicateEvaluator.d.ts.map +1 -1
  181. package/src/core/model/reactive/evaluation/MultiPredicateEvaluator.js +39 -2
  182. package/src/core/model/reactive/model/terminal/ReactiveReference.d.ts.map +1 -1
  183. package/src/core/model/reactive/model/terminal/ReactiveReference.js +2 -0
  184. package/src/core/parser/simple/readHexToken.d.ts.map +1 -1
  185. package/src/core/parser/simple/readHexToken.js +6 -0
  186. package/src/core/primitives/numbers/number_pretty_print.d.ts.map +1 -1
  187. package/src/core/primitives/numbers/number_pretty_print.js +4 -1
  188. package/src/core/primitives/strings/string_jaro_winkler.js +1 -1
  189. package/src/core/process/CompositeProcess.js +1 -1
  190. package/src/core/process/action/AsynchronousDelayAction.d.ts.map +1 -1
  191. package/src/core/process/action/AsynchronousDelayAction.js +3 -0
  192. package/src/core/process/executor/ConcurrentExecutor.d.ts.map +1 -1
  193. package/src/core/process/executor/ConcurrentExecutor.js +3 -2
  194. package/src/core/process/task/util/randomCountTask.d.ts.map +1 -1
  195. package/src/core/process/task/util/randomCountTask.js +3 -1
  196. package/src/core/process/undo/ActionProcessor.d.ts.map +1 -1
  197. package/src/core/process/undo/ActionProcessor.js +5 -3
  198. package/src/core/process/worker/WorkerBuilder.js +3 -3
  199. package/src/engine/animation/curve/AnimationCurve.d.ts.map +1 -1
  200. package/src/engine/animation/curve/AnimationCurve.js +4 -2
  201. package/src/engine/control/first-person/DESIGN.md +1 -1
  202. package/src/engine/control/first-person/FirstPersonMotionPhase.d.ts +55 -0
  203. package/src/engine/control/first-person/FirstPersonMotionPhase.d.ts.map +1 -0
  204. package/src/engine/control/first-person/FirstPersonMotionPhase.js +134 -0
  205. package/src/engine/control/first-person/FirstPersonPlayerController.d.ts +23 -2
  206. package/src/engine/control/first-person/FirstPersonPlayerController.d.ts.map +1 -1
  207. package/src/engine/control/first-person/FirstPersonPlayerController.js +1 -1
  208. package/src/engine/control/first-person/FirstPersonPlayerControllerConfig.d.ts +168 -0
  209. package/src/engine/control/first-person/FirstPersonPlayerControllerConfig.d.ts.map +1 -1
  210. package/src/engine/control/first-person/FirstPersonPlayerControllerConfig.js +115 -0
  211. package/src/engine/control/first-person/FirstPersonPlayerControllerSystem.d.ts +71 -0
  212. package/src/engine/control/first-person/FirstPersonPlayerControllerSystem.d.ts.map +1 -1
  213. package/src/engine/control/first-person/FirstPersonPlayerControllerSystem.js +255 -55
  214. package/src/engine/control/first-person/abilities/LedgeGrab.d.ts +82 -43
  215. package/src/engine/control/first-person/abilities/LedgeGrab.d.ts.map +1 -1
  216. package/src/engine/control/first-person/abilities/LedgeGrab.js +405 -213
  217. package/src/engine/control/first-person/abilities/Mantle.d.ts +6 -0
  218. package/src/engine/control/first-person/abilities/Mantle.d.ts.map +1 -1
  219. package/src/engine/control/first-person/abilities/Mantle.js +104 -45
  220. package/src/engine/control/first-person/abilities/ScrambleUp.d.ts +61 -0
  221. package/src/engine/control/first-person/abilities/ScrambleUp.d.ts.map +1 -0
  222. package/src/engine/control/first-person/abilities/ScrambleUp.js +182 -0
  223. package/src/engine/control/first-person/math/jumpDynamics.d.ts +84 -0
  224. package/src/engine/control/first-person/math/jumpDynamics.d.ts.map +1 -0
  225. package/src/engine/control/first-person/math/jumpDynamics.js +108 -0
  226. package/src/engine/control/first-person/prototype_first_person_controller.js +45 -1
  227. package/src/engine/graphics/camera/testClippingPlaneComputation.js +1 -1
  228. package/src/engine/graphics/ecs/path/tube/prototypeAnimatedPathMask.js +1 -1
  229. package/src/engine/graphics/particles/particular/engine/utils/volume/prototypeParticleVolume.js +1 -1
  230. package/src/engine/graphics/render/buffer/buffers/prototypeNormalFrameBuffer.js +1 -1
  231. package/src/engine/graphics/render/forward_plus/plugin/ptototypeFPPlugin.js +1 -1
  232. package/src/engine/graphics/render/visibility/hiz/prototypeHiZ.js +1 -1
  233. package/src/engine/graphics/sh3/path_tracer/texture/sample_material.js +1 -1
  234. package/src/engine/graphics/shadows/testShadowMapRendering.js +1 -1
  235. package/src/engine/physics/CONSTRAINT_SOLVER_BENCH_LOG.md +208 -0
  236. package/src/engine/physics/CONSTRAINT_SOLVER_IMPROVEMENTS_PLAN.md +364 -0
  237. package/src/engine/physics/PLAN.md +6 -5
  238. package/src/engine/physics/constraint/solve_constraints.d.ts +4 -1
  239. package/src/engine/physics/constraint/solve_constraints.d.ts.map +1 -1
  240. package/src/engine/physics/constraint/solve_constraints.js +147 -33
  241. package/src/engine/physics/ecs/PhysicsSystem.d.ts.map +1 -1
  242. package/src/engine/physics/ecs/PhysicsSystem.js +1750 -1747
  243. package/src/engine/physics/fluid/ecs/FluidSystem.d.ts +3 -3
  244. package/src/engine/physics/gjk/gjk_epa_penetration.d.ts.map +1 -1
  245. package/src/engine/physics/gjk/gjk_epa_penetration.js +5 -9
  246. package/src/engine/physics/narrowphase/convex_convex_manifold.d.ts.map +1 -1
  247. package/src/engine/physics/narrowphase/convex_convex_manifold.js +22 -25
  248. package/src/engine/physics/narrowphase/convex_decomposition.d.ts +32 -13
  249. package/src/engine/physics/narrowphase/convex_decomposition.d.ts.map +1 -1
  250. package/src/engine/physics/narrowphase/convex_decomposition.js +61 -65
  251. package/src/engine/physics/narrowphase/mesh_convex_hull.d.ts.map +1 -1
  252. package/src/engine/physics/narrowphase/mesh_convex_hull.js +13 -8
  253. package/src/engine/physics/narrowphase/refine_ray_concave.d.ts.map +1 -1
  254. package/src/engine/physics/narrowphase/refine_ray_concave.js +5 -3
  255. package/src/engine/physics/narrowphase/refine_ray_hit.d.ts.map +1 -1
  256. package/src/engine/physics/narrowphase/refine_ray_hit.js +81 -78
  257. package/src/engine/sound/SoundEngine.d.ts.map +1 -1
  258. package/src/engine/sound/SoundEngine.js +28 -0
  259. package/src/engine/sound/dB2Volume.d.ts +1 -1
  260. package/src/engine/sound/dB2Volume.d.ts.map +1 -1
  261. package/src/engine/sound/dB2Volume.js +1 -1
  262. package/src/engine/sound/ecs/SoundController.d.ts +4 -0
  263. package/src/engine/sound/ecs/SoundController.d.ts.map +1 -1
  264. package/src/engine/sound/ecs/SoundController.js +4 -0
  265. package/src/engine/sound/ecs/SoundControllerSystem.d.ts +5 -0
  266. package/src/engine/sound/ecs/SoundControllerSystem.d.ts.map +1 -1
  267. package/src/engine/sound/ecs/SoundControllerSystem.js +5 -0
  268. package/src/engine/sound/ecs/audio/AudioEmitter.d.ts +69 -0
  269. package/src/engine/sound/ecs/audio/AudioEmitter.d.ts.map +1 -0
  270. package/src/engine/sound/ecs/audio/AudioEmitter.js +83 -0
  271. package/src/engine/sound/ecs/audio/AudioEmitterSystem.d.ts +97 -0
  272. package/src/engine/sound/ecs/audio/AudioEmitterSystem.d.ts.map +1 -0
  273. package/src/engine/sound/ecs/audio/AudioEmitterSystem.js +238 -0
  274. package/src/engine/sound/ecs/audio/LiveEmitterSet.d.ts +90 -0
  275. package/src/engine/sound/ecs/audio/LiveEmitterSet.d.ts.map +1 -0
  276. package/src/engine/sound/ecs/audio/LiveEmitterSet.js +324 -0
  277. package/src/engine/sound/ecs/audio/SpatialAudioIndex.d.ts +59 -0
  278. package/src/engine/sound/ecs/audio/SpatialAudioIndex.d.ts.map +1 -0
  279. package/src/engine/sound/ecs/audio/SpatialAudioIndex.js +140 -0
  280. package/src/engine/sound/ecs/emitter/SoundEmitter.d.ts +16 -65
  281. package/src/engine/sound/ecs/emitter/SoundEmitter.d.ts.map +1 -1
  282. package/src/engine/sound/ecs/emitter/SoundEmitter.js +19 -224
  283. package/src/engine/sound/ecs/emitter/SoundEmitterComponentContext.d.ts +26 -29
  284. package/src/engine/sound/ecs/emitter/SoundEmitterComponentContext.d.ts.map +1 -1
  285. package/src/engine/sound/ecs/emitter/SoundEmitterComponentContext.js +168 -135
  286. package/src/engine/sound/ecs/emitter/SoundEmitterSystem.d.ts +36 -59
  287. package/src/engine/sound/ecs/emitter/SoundEmitterSystem.d.ts.map +1 -1
  288. package/src/engine/sound/ecs/emitter/SoundEmitterSystem.js +154 -390
  289. package/src/engine/sound/ecs/emitter/SoundTrack.d.ts +20 -23
  290. package/src/engine/sound/ecs/emitter/SoundTrack.d.ts.map +1 -1
  291. package/src/engine/sound/ecs/emitter/SoundTrack.js +34 -152
  292. package/src/engine/sound/sopra/IMPLEMENTATION_PLAN.md +993 -0
  293. package/src/engine/sound/sopra/README.md +643 -7
  294. package/src/engine/sound/sopra/SopraEngine.d.ts +229 -0
  295. package/src/engine/sound/sopra/SopraEngine.d.ts.map +1 -0
  296. package/src/engine/sound/sopra/SopraEngine.js +423 -0
  297. package/src/engine/sound/sopra/asset/AssetManagerBufferProvider.d.ts +26 -0
  298. package/src/engine/sound/sopra/asset/AssetManagerBufferProvider.d.ts.map +1 -0
  299. package/src/engine/sound/sopra/asset/AssetManagerBufferProvider.js +71 -0
  300. package/src/engine/sound/sopra/asset/BufferProvider.d.ts +24 -0
  301. package/src/engine/sound/sopra/asset/BufferProvider.d.ts.map +1 -0
  302. package/src/engine/sound/sopra/asset/BufferProvider.js +29 -0
  303. package/src/engine/sound/sopra/asset/StubBufferProvider.d.ts +31 -0
  304. package/src/engine/sound/sopra/asset/StubBufferProvider.d.ts.map +1 -0
  305. package/src/engine/sound/sopra/asset/StubBufferProvider.js +58 -0
  306. package/src/engine/sound/sopra/definition/BusDefinition.d.ts +83 -0
  307. package/src/engine/sound/sopra/definition/BusDefinition.d.ts.map +1 -0
  308. package/src/engine/sound/sopra/definition/BusDefinition.js +142 -0
  309. package/src/engine/sound/sopra/definition/BusDefinitionSerializationAdapter.d.ts +17 -0
  310. package/src/engine/sound/sopra/definition/BusDefinitionSerializationAdapter.d.ts.map +1 -0
  311. package/src/engine/sound/sopra/definition/BusDefinitionSerializationAdapter.js +54 -0
  312. package/src/engine/sound/sopra/definition/DuckingRule.d.ts +71 -0
  313. package/src/engine/sound/sopra/definition/DuckingRule.d.ts.map +1 -0
  314. package/src/engine/sound/sopra/definition/DuckingRule.js +106 -0
  315. package/src/engine/sound/sopra/definition/DuckingRuleSerializationAdapter.d.ts +18 -0
  316. package/src/engine/sound/sopra/definition/DuckingRuleSerializationAdapter.d.ts.map +1 -0
  317. package/src/engine/sound/sopra/definition/DuckingRuleSerializationAdapter.js +31 -0
  318. package/src/engine/sound/sopra/definition/EventDescription.d.ts +132 -0
  319. package/src/engine/sound/sopra/definition/EventDescription.d.ts.map +1 -0
  320. package/src/engine/sound/sopra/definition/EventDescription.js +259 -0
  321. package/src/engine/sound/sopra/definition/EventDescriptionSerializationAdapter.d.ts +17 -0
  322. package/src/engine/sound/sopra/definition/EventDescriptionSerializationAdapter.d.ts.map +1 -0
  323. package/src/engine/sound/sopra/definition/EventDescriptionSerializationAdapter.js +71 -0
  324. package/src/engine/sound/sopra/definition/MixerSnapshot.d.ts +51 -0
  325. package/src/engine/sound/sopra/definition/MixerSnapshot.d.ts.map +1 -0
  326. package/src/engine/sound/sopra/definition/MixerSnapshot.js +83 -0
  327. package/src/engine/sound/sopra/definition/MixerSnapshotSerializationAdapter.d.ts +18 -0
  328. package/src/engine/sound/sopra/definition/MixerSnapshotSerializationAdapter.d.ts.map +1 -0
  329. package/src/engine/sound/sopra/definition/MixerSnapshotSerializationAdapter.js +39 -0
  330. package/src/engine/sound/sopra/definition/ParameterDefinition.d.ts +72 -0
  331. package/src/engine/sound/sopra/definition/ParameterDefinition.d.ts.map +1 -0
  332. package/src/engine/sound/sopra/definition/ParameterDefinition.js +117 -0
  333. package/src/engine/sound/sopra/definition/ParameterDefinitionSerializationAdapter.d.ts +18 -0
  334. package/src/engine/sound/sopra/definition/ParameterDefinitionSerializationAdapter.d.ts.map +1 -0
  335. package/src/engine/sound/sopra/definition/ParameterDefinitionSerializationAdapter.js +31 -0
  336. package/src/engine/sound/sopra/definition/SopraPanningModel.d.ts +14 -0
  337. package/src/engine/sound/sopra/definition/SopraPanningModel.d.ts.map +1 -0
  338. package/src/engine/sound/sopra/definition/SopraPanningModel.js +20 -0
  339. package/src/engine/sound/sopra/definition/VoiceStealMode.d.ts +10 -0
  340. package/src/engine/sound/sopra/definition/VoiceStealMode.d.ts.map +1 -0
  341. package/src/engine/sound/sopra/definition/VoiceStealMode.js +18 -0
  342. package/src/engine/sound/sopra/definition/clip/AbstractAudioClip.d.ts +93 -0
  343. package/src/engine/sound/sopra/definition/clip/AbstractAudioClip.d.ts.map +1 -0
  344. package/src/engine/sound/sopra/definition/clip/AbstractAudioClip.js +109 -0
  345. package/src/engine/sound/sopra/definition/clip/BlendContainerAudioClip.d.ts +80 -0
  346. package/src/engine/sound/sopra/definition/clip/BlendContainerAudioClip.d.ts.map +1 -0
  347. package/src/engine/sound/sopra/definition/clip/BlendContainerAudioClip.js +181 -0
  348. package/src/engine/sound/sopra/definition/clip/BlendContainerAudioClipSerializationAdapter.d.ts +17 -0
  349. package/src/engine/sound/sopra/definition/clip/BlendContainerAudioClipSerializationAdapter.d.ts.map +1 -0
  350. package/src/engine/sound/sopra/definition/clip/BlendContainerAudioClipSerializationAdapter.js +74 -0
  351. package/src/engine/sound/sopra/definition/clip/ContainerAudioClip.d.ts +34 -0
  352. package/src/engine/sound/sopra/definition/clip/ContainerAudioClip.d.ts.map +1 -0
  353. package/src/engine/sound/sopra/definition/clip/ContainerAudioClip.js +100 -0
  354. package/src/engine/sound/sopra/definition/clip/RandomContainerAudioClip.d.ts +101 -0
  355. package/src/engine/sound/sopra/definition/clip/RandomContainerAudioClip.d.ts.map +1 -0
  356. package/src/engine/sound/sopra/definition/clip/RandomContainerAudioClip.js +230 -0
  357. package/src/engine/sound/sopra/definition/clip/RandomContainerAudioClipSerializationAdapter.d.ts +17 -0
  358. package/src/engine/sound/sopra/definition/clip/RandomContainerAudioClipSerializationAdapter.d.ts.map +1 -0
  359. package/src/engine/sound/sopra/definition/clip/RandomContainerAudioClipSerializationAdapter.js +54 -0
  360. package/src/engine/sound/sopra/definition/clip/SampleAudioClip.d.ts +103 -0
  361. package/src/engine/sound/sopra/definition/clip/SampleAudioClip.d.ts.map +1 -0
  362. package/src/engine/sound/sopra/definition/clip/SampleAudioClip.js +191 -0
  363. package/src/engine/sound/sopra/definition/clip/SampleAudioClipSerializationAdapter.d.ts +18 -0
  364. package/src/engine/sound/sopra/definition/clip/SampleAudioClipSerializationAdapter.d.ts.map +1 -0
  365. package/src/engine/sound/sopra/definition/clip/SampleAudioClipSerializationAdapter.js +39 -0
  366. package/src/engine/sound/sopra/definition/clip/SequenceContainerAudioClip.d.ts +40 -0
  367. package/src/engine/sound/sopra/definition/clip/SequenceContainerAudioClip.d.ts.map +1 -0
  368. package/src/engine/sound/sopra/definition/clip/SequenceContainerAudioClip.js +91 -0
  369. package/src/engine/sound/sopra/definition/clip/SequenceContainerAudioClipSerializationAdapter.d.ts +17 -0
  370. package/src/engine/sound/sopra/definition/clip/SequenceContainerAudioClipSerializationAdapter.d.ts.map +1 -0
  371. package/src/engine/sound/sopra/definition/clip/SequenceContainerAudioClipSerializationAdapter.js +42 -0
  372. package/src/engine/sound/sopra/definition/clip/SilenceAudioClip.d.ts +44 -0
  373. package/src/engine/sound/sopra/definition/clip/SilenceAudioClip.d.ts.map +1 -0
  374. package/src/engine/sound/sopra/definition/clip/SilenceAudioClip.js +77 -0
  375. package/src/engine/sound/sopra/definition/clip/SilenceAudioClipSerializationAdapter.d.ts +18 -0
  376. package/src/engine/sound/sopra/definition/clip/SilenceAudioClipSerializationAdapter.d.ts.map +1 -0
  377. package/src/engine/sound/sopra/definition/clip/SilenceAudioClipSerializationAdapter.js +27 -0
  378. package/src/engine/sound/sopra/definition/clip/SwitchContainerAudioClip.d.ts +65 -0
  379. package/src/engine/sound/sopra/definition/clip/SwitchContainerAudioClip.d.ts.map +1 -0
  380. package/src/engine/sound/sopra/definition/clip/SwitchContainerAudioClip.js +131 -0
  381. package/src/engine/sound/sopra/definition/clip/SwitchContainerAudioClipSerializationAdapter.d.ts +17 -0
  382. package/src/engine/sound/sopra/definition/clip/SwitchContainerAudioClipSerializationAdapter.d.ts.map +1 -0
  383. package/src/engine/sound/sopra/definition/clip/SwitchContainerAudioClipSerializationAdapter.js +41 -0
  384. package/src/engine/sound/sopra/definition/effect/AbstractAudioEffect.d.ts +24 -0
  385. package/src/engine/sound/sopra/definition/effect/AbstractAudioEffect.d.ts.map +1 -0
  386. package/src/engine/sound/sopra/definition/effect/AbstractAudioEffect.js +24 -0
  387. package/src/engine/sound/sopra/definition/effect/CompressorEffect.d.ts +70 -0
  388. package/src/engine/sound/sopra/definition/effect/CompressorEffect.d.ts.map +1 -0
  389. package/src/engine/sound/sopra/definition/effect/CompressorEffect.js +120 -0
  390. package/src/engine/sound/sopra/definition/effect/CompressorEffectSerializationAdapter.d.ts +18 -0
  391. package/src/engine/sound/sopra/definition/effect/CompressorEffectSerializationAdapter.d.ts.map +1 -0
  392. package/src/engine/sound/sopra/definition/effect/CompressorEffectSerializationAdapter.js +31 -0
  393. package/src/engine/sound/sopra/definition/effect/EqEffect.d.ts +74 -0
  394. package/src/engine/sound/sopra/definition/effect/EqEffect.d.ts.map +1 -0
  395. package/src/engine/sound/sopra/definition/effect/EqEffect.js +128 -0
  396. package/src/engine/sound/sopra/definition/effect/EqEffectSerializationAdapter.d.ts +18 -0
  397. package/src/engine/sound/sopra/definition/effect/EqEffectSerializationAdapter.d.ts.map +1 -0
  398. package/src/engine/sound/sopra/definition/effect/EqEffectSerializationAdapter.js +29 -0
  399. package/src/engine/sound/sopra/definition/effect/ReverbEffect.d.ts +49 -0
  400. package/src/engine/sound/sopra/definition/effect/ReverbEffect.d.ts.map +1 -0
  401. package/src/engine/sound/sopra/definition/effect/ReverbEffect.js +101 -0
  402. package/src/engine/sound/sopra/definition/effect/ReverbEffectSerializationAdapter.d.ts +18 -0
  403. package/src/engine/sound/sopra/definition/effect/ReverbEffectSerializationAdapter.d.ts.map +1 -0
  404. package/src/engine/sound/sopra/definition/effect/ReverbEffectSerializationAdapter.js +25 -0
  405. package/src/engine/sound/sopra/legacy/soundEmitterToEventDescription.d.ts +31 -0
  406. package/src/engine/sound/sopra/legacy/soundEmitterToEventDescription.d.ts.map +1 -0
  407. package/src/engine/sound/sopra/legacy/soundEmitterToEventDescription.js +106 -0
  408. package/src/engine/sound/sopra/runtime/BusGraph.d.ts +79 -0
  409. package/src/engine/sound/sopra/runtime/BusGraph.d.ts.map +1 -0
  410. package/src/engine/sound/sopra/runtime/BusGraph.js +227 -0
  411. package/src/engine/sound/sopra/runtime/EventInstance.d.ts +144 -0
  412. package/src/engine/sound/sopra/runtime/EventInstance.d.ts.map +1 -0
  413. package/src/engine/sound/sopra/runtime/EventInstance.js +579 -0
  414. package/src/engine/sound/sopra/runtime/ParameterStore.d.ts +42 -0
  415. package/src/engine/sound/sopra/runtime/ParameterStore.d.ts.map +1 -0
  416. package/src/engine/sound/sopra/runtime/ParameterStore.js +98 -0
  417. package/src/engine/sound/sopra/runtime/SopraPlaybackContext.d.ts +42 -0
  418. package/src/engine/sound/sopra/runtime/SopraPlaybackContext.d.ts.map +1 -0
  419. package/src/engine/sound/sopra/runtime/SopraPlaybackContext.js +68 -0
  420. package/src/engine/sound/sopra/runtime/Voice.d.ts +67 -0
  421. package/src/engine/sound/sopra/runtime/Voice.d.ts.map +1 -0
  422. package/src/engine/sound/sopra/runtime/Voice.js +145 -0
  423. package/src/engine/sound/sopra/runtime/VoiceManager.d.ts +38 -0
  424. package/src/engine/sound/sopra/runtime/VoiceManager.d.ts.map +1 -0
  425. package/src/engine/sound/sopra/runtime/VoiceManager.js +136 -0
  426. package/src/engine/sound/sopra/runtime/VoicePool.d.ts +12 -0
  427. package/src/engine/sound/sopra/runtime/VoicePool.d.ts.map +1 -0
  428. package/src/engine/sound/sopra/runtime/VoicePool.js +17 -0
  429. package/src/engine/sound/sopra/serialization/populateSopraSerializationRegistry.d.ts +11 -0
  430. package/src/engine/sound/sopra/serialization/populateSopraSerializationRegistry.d.ts.map +1 -0
  431. package/src/engine/sound/sopra/serialization/populateSopraSerializationRegistry.js +42 -0
  432. package/src/engine/sound/sopra/serialization/sopraJSON.d.ts +33 -0
  433. package/src/engine/sound/sopra/serialization/sopraJSON.d.ts.map +1 -0
  434. package/src/engine/sound/sopra/serialization/sopraJSON.js +99 -0
  435. package/src/engine/sound/sopra/serialization/sopraSerializationHarness.d.ts +27 -0
  436. package/src/engine/sound/sopra/serialization/sopraSerializationHarness.d.ts.map +1 -0
  437. package/src/engine/sound/sopra/serialization/sopraSerializationHarness.js +49 -0
  438. package/src/engine/sound/sopra/util/MockAudioContext.d.ts +74 -0
  439. package/src/engine/sound/sopra/util/MockAudioContext.d.ts.map +1 -0
  440. package/src/engine/sound/sopra/util/MockAudioContext.js +215 -0
  441. package/src/engine/sound/sopra/util/buildAttenuationCurve.d.ts +15 -0
  442. package/src/engine/sound/sopra/util/buildAttenuationCurve.d.ts.map +1 -0
  443. package/src/engine/sound/sopra/util/buildAttenuationCurve.js +40 -0
  444. package/src/engine/sound/sopra/util/fadeOutAndStop.d.ts +34 -0
  445. package/src/engine/sound/sopra/util/fadeOutAndStop.d.ts.map +1 -0
  446. package/src/engine/sound/sopra/util/fadeOutAndStop.js +60 -0
  447. package/src/engine/sound/volume2dB.d.ts +1 -1
  448. package/src/engine/sound/volume2dB.d.ts.map +1 -1
  449. package/src/engine/sound/volume2dB.js +1 -1
  450. package/src/engine/graphics/sh3/path_tracer/sampling/v3_orthonormal_matrix_from_normal.d.ts.map +0 -1
  451. package/src/engine/physics/narrowphase/ray_shapes.d.ts +0 -66
  452. package/src/engine/physics/narrowphase/ray_shapes.d.ts.map +0 -1
  453. package/src/engine/physics/narrowphase/ray_shapes.js +0 -187
  454. package/src/engine/sound/ecs/emitter/SoundEmitterChannel.d.ts +0 -23
  455. package/src/engine/sound/ecs/emitter/SoundEmitterChannel.d.ts.map +0 -1
  456. package/src/engine/sound/ecs/emitter/SoundEmitterChannel.js +0 -32
  457. package/src/engine/sound/ecs/emitter/SoundTrackNodes.d.ts +0 -18
  458. package/src/engine/sound/ecs/emitter/SoundTrackNodes.d.ts.map +0 -1
  459. package/src/engine/sound/ecs/emitter/SoundTrackNodes.js +0 -18
  460. package/src/engine/sound/sopra/AbstractAudioClip.d.ts +0 -26
  461. package/src/engine/sound/sopra/AbstractAudioClip.d.ts.map +0 -1
  462. package/src/engine/sound/sopra/AbstractAudioClip.js +0 -29
  463. package/src/engine/sound/sopra/ContainerAudioClip.d.ts +0 -12
  464. package/src/engine/sound/sopra/ContainerAudioClip.d.ts.map +0 -1
  465. package/src/engine/sound/sopra/ContainerAudioClip.js +0 -13
  466. package/src/engine/sound/sopra/RandomContainerAudioClip.d.ts +0 -12
  467. package/src/engine/sound/sopra/RandomContainerAudioClip.d.ts.map +0 -1
  468. package/src/engine/sound/sopra/RandomContainerAudioClip.js +0 -15
  469. package/src/engine/sound/sopra/SequenceContainerAudioClip.d.ts +0 -7
  470. package/src/engine/sound/sopra/SequenceContainerAudioClip.d.ts.map +0 -1
  471. package/src/engine/sound/sopra/SequenceContainerAudioClip.js +0 -8
  472. package/src/engine/sound/sopra/SilenceAudioClip.d.ts +0 -13
  473. package/src/engine/sound/sopra/SilenceAudioClip.d.ts.map +0 -1
  474. package/src/engine/sound/sopra/SilenceAudioClip.js +0 -15
  475. /package/src/{engine/graphics/sh3/path_tracer/sampling → core/geom/vec3}/v3_orthonormal_matrix_from_normal.d.ts +0 -0
@@ -1,387 +1,389 @@
1
- import { assert } from "../../../assert.js";
2
- import { UINT32_MAX } from "../../../binary/UINT32_MAX.js";
3
- import { clamp } from "../../../math/clamp.js";
4
- import { BinaryElementPool } from "../../3d/topology/struct/binary/BinaryElementPool.js";
5
-
6
-
7
- export const NULL_POINTER = UINT32_MAX;
8
- /**
9
- * Single-linked list
10
- * Pointer to next NODE in the same grid cell
11
- * @type {number}
12
- */
13
- const COLUMN_NODE_SAME_NODE_NEXT = 0;
14
- /**
15
- * Single-linked list
16
- * Pointer to next NODE containing the same element
17
- * @type {number}
18
- */
19
- const COLUMN_NODE_SAME_ELEMENT_NEXT = 1;
20
- /**
21
- * Pointer to ELEMENT
22
- * @type {number}
23
- */
24
- const COLUMN_NODE_ELEMENT = 2;
25
-
26
- /**
27
- * Points to grid cell that stores this node
28
- * @type {number}
29
- */
30
- const COLUMN_NODE_GRID_INDEX = 3;
31
-
32
- const COLUMN_ELEMENT_DATA = 0;
33
- const COLUMN_ELEMENT_NODE_FIRST = 1;
34
- export const COLUMN_ELEMENT_X0 = 2;
35
- export const COLUMN_ELEMENT_Y0 = 3;
36
- export const COLUMN_ELEMENT_X1 = 4;
37
- export const COLUMN_ELEMENT_Y1 = 5;
38
-
39
- export class SpatialHashGrid {
40
- #element_pool = new BinaryElementPool(24)
41
- #node_pool = new BinaryElementPool(16);
42
- #grid_data = new Uint32Array(0);
43
-
44
- #size_x = 0;
45
- #size_y = 0;
46
-
47
- #scale = 1;
48
- #scale_inverse = 1;
49
-
50
- get size_x() {
51
- return this.#size_x;
52
- }
53
-
54
- get size_y() {
55
- return this.#size_y;
56
- }
57
-
58
- get node_pool() {
59
- return this.#node_pool;
60
- }
61
-
62
- /**
63
- *
64
- * @return {BinaryElementPool}
65
- */
66
- get element_pool() {
67
- return this.#element_pool;
68
- }
69
-
70
- get scale() {
71
- return this.#scale;
72
- }
73
-
74
- get scale_inverse() {
75
- return this.#scale_inverse;
76
- }
77
-
78
- constructor(size_x = 1, size_y = 1, scale = 8) {
79
-
80
- assert.notNaN(scale, "scale");
81
- assert.isFinite(scale, 'scale');
82
- assert.greaterThan(scale, 0, 'scale must be greater than 0');
83
-
84
- this.#size_x = size_x;
85
- this.#size_y = size_y;
86
- this.#scale = scale;
87
- this.#scale_inverse = 1 / scale;
88
-
89
- this.#build();
90
- }
91
-
92
- #build() {
93
- this.#grid_data = new Uint32Array(this.#size_x * this.#size_y);
94
-
95
- this.#grid_data.fill(NULL_POINTER);
96
- }
97
-
98
- element_allocate() {
99
- const element = this.#element_pool.allocate();
100
-
101
- return element;
102
- }
103
-
104
- element_set_user_data(element, user_data) {
105
- const pool = this.#element_pool;
106
- const address = pool.element_word(element);
107
-
108
- pool.data_uint32[address + COLUMN_ELEMENT_DATA] = user_data;
109
- }
110
-
111
- element_get_user_data(element) {
112
- const pool = this.#element_pool;
113
- const address = pool.element_word(element);
114
-
115
- return pool.data_uint32[address + COLUMN_ELEMENT_DATA];
116
- }
117
-
118
- /**
119
- * You have to remove the element from the grid before changing its bounds
120
- * @param {number} element
121
- * @param {number} x0
122
- * @param {number} y0
123
- * @param {number} x1
124
- * @param {number} y1
125
- */
126
- element_set_bounds_primitive(element, x0, y0, x1, y1) {
127
- const pool = this.#element_pool;
128
- const address = pool.element_word(element);
129
-
130
- const float32 = pool.data_float32;
131
-
132
- float32[address + COLUMN_ELEMENT_X0] = x0;
133
- float32[address + COLUMN_ELEMENT_Y0] = y0;
134
- float32[address + COLUMN_ELEMENT_X1] = x1;
135
- float32[address + COLUMN_ELEMENT_Y1] = y1;
136
- }
137
-
138
- /**
139
- *
140
- * @param {number} element
141
- */
142
- element_release(element) {
143
- this.#element_pool.release(element);
144
- }
145
-
146
- /**
147
- *
148
- * @param {number} element
149
- */
150
- element_insert(element) {
151
- const pool = this.#element_pool;
152
- const address = pool.element_word(element);
153
-
154
- const uint32 = pool.data_uint32;
155
-
156
- // make sure that we don't point at anything yet
157
- uint32[address + COLUMN_ELEMENT_NODE_FIRST] = NULL_POINTER;
158
-
159
- const float32 = pool.data_float32;
160
-
161
- const x0 = float32[address + COLUMN_ELEMENT_X0];
162
- const y0 = float32[address + COLUMN_ELEMENT_Y0];
163
- const x1 = float32[address + COLUMN_ELEMENT_X1];
164
- const y1 = float32[address + COLUMN_ELEMENT_Y1];
165
-
166
- // convert to grid coordinates
167
- const grid_x0 = Math.floor(x0 * this.#scale_inverse);
168
- const grid_y0 = Math.floor(y0 * this.#scale_inverse);
169
-
170
- const grid_x1 = Math.floor(x1 * this.#scale_inverse);
171
- const grid_y1 = Math.floor(y1 * this.#scale_inverse);
172
-
173
- for (let y = grid_y0; y <= grid_y1; y++) {
174
- for (let x = grid_x0; x <= grid_x1; x++) {
175
- this.#element_insert_into_cell(element, x, y);
176
- }
177
- }
178
- }
179
-
180
- /**
181
- *
182
- * @param {number} node
183
- * @return {number}
184
- */
185
- node_get_element(node) {
186
- const address = this.#node_pool.element_word(node);
187
- return this.#node_pool.data_uint32[address + COLUMN_NODE_ELEMENT];
188
- }
189
-
190
- /**
191
- * Next element in the linked list of cell's nodes
192
- * @param {number} node
193
- * @return {number}
194
- */
195
- node_get_same_cell_next_node(node) {
196
- const address = this.#node_pool.element_word(node);
197
-
198
- return this.#node_pool.data_uint32[address + COLUMN_NODE_SAME_NODE_NEXT];
199
- }
200
-
201
- /**
202
- *
203
- * @param {number} cell_index
204
- * @return {number}
205
- */
206
- cell_get_first_node(cell_index) {
207
- assert.lessThan(cell_index, this.#size_x * this.#size_y);
208
-
209
- return this.#grid_data[cell_index]
210
- }
211
-
212
- /**
213
- *
214
- * @param {number} x
215
- * @param {number} y
216
- * @return {number}
217
- */
218
- world_position_to_cell_index(x, y) {
219
- const grid_x = clamp(Math.floor(x * this.#scale_inverse), 0, this.#size_x - 1);
220
- const grid_y = clamp(Math.floor(y * this.#scale_inverse), 0, this.#size_y - 1);
221
-
222
- return this.cell_position_to_index(grid_x, grid_y);
223
- }
224
-
225
- /**
226
- *
227
- * @param {number} x
228
- * @param {number} y
229
- * @returns {number}
230
- */
231
- cell_position_to_index(x, y) {
232
- assert.isNonNegativeInteger(x, 'x');
233
- assert.isNonNegativeInteger(y, 'y');
234
-
235
- return y * this.#size_x + x;
236
-
237
- // const cell_count = this.#size_x * this.#size_y;
238
- //
239
- // const _x = split_by_2(x);
240
- // const _y = split_by_2(y);
241
- //
242
- // const hash = _x | (_y << 1);
243
- //
244
- // return hash % cell_count;
245
- }
246
-
247
- /**
248
- *
249
- * @param {number} cell_x
250
- * @param {number} cell_y
251
- * @return {boolean}
252
- */
253
- is_cell_empty(cell_x, cell_y) {
254
- assert.isNonNegativeInteger(cell_x, 'cell_x');
255
- assert.lessThan(cell_x, this.#size_x, 'cell_x overflow');
256
-
257
- assert.isNonNegativeInteger(cell_y, 'cell_y');
258
- assert.lessThan(cell_y, this.#size_y, 'cell_y overflow');
259
-
260
- const index = this.cell_position_to_index(cell_x, cell_y);
261
-
262
- const grid = this.#grid_data;
263
-
264
- return grid[index] === NULL_POINTER;
265
- }
266
-
267
- /**
268
- *
269
- * @param {number} element
270
- * @param {number} grid_x
271
- * @param {number} grid_y
272
- */
273
- #element_insert_into_cell(element, grid_x, grid_y) {
274
-
275
- // create a node
276
- const node_pool = this.#node_pool;
277
- const node = node_pool.allocate();
278
-
279
- const node_address = node_pool.element_word(node);
280
- const node_data_uint32 = node_pool.data_uint32;
281
-
282
- node_data_uint32[node_address + COLUMN_NODE_ELEMENT] = element;
283
-
284
- // link node to the element
285
- const element_pool = this.#element_pool;
286
- const element_address = element_pool.element_word(element);
287
-
288
- const element_data_uint32 = element_pool.data_uint32;
289
-
290
- const element_first_node = element_data_uint32[element_address + COLUMN_ELEMENT_NODE_FIRST];
291
-
292
- // point to previous first
293
- node_data_uint32[node_address + COLUMN_NODE_SAME_ELEMENT_NEXT] = element_first_node;
294
-
295
-
296
- element_data_uint32[element_address + COLUMN_ELEMENT_NODE_FIRST] = node;
297
-
298
- // link node to the cell
299
- const cell_index = this.cell_position_to_index(grid_x, grid_y);
300
-
301
- node_data_uint32[node_address + COLUMN_NODE_GRID_INDEX] = cell_index;
302
-
303
- const grid_data = this.#grid_data;
304
-
305
- const cell_first_node = grid_data[cell_index];
306
-
307
- node_data_uint32[node_address + COLUMN_NODE_SAME_NODE_NEXT] = cell_first_node;
308
-
309
- grid_data[cell_index] = node;
310
- }
311
-
312
- /**
313
- *
314
- * @param {number} cell_index
315
- * @param {number} node
316
- * @returns {boolean}
317
- */
318
- #grid_cell_remove_node(cell_index, node) {
319
- assert.isNonNegativeInteger(cell_index, 'cell_index');
320
- assert.isNonNegativeInteger(node, 'node');
321
-
322
- const pool = this.#node_pool;
323
- const node_data_uint32 = pool.data_uint32;
324
-
325
- const grid_data = this.#grid_data;
326
- let n = grid_data[cell_index]
327
- let previous = NULL_POINTER;
328
-
329
- while (n !== NULL_POINTER) {
330
- const address = pool.element_word(n);
331
- const next = node_data_uint32[address + COLUMN_NODE_SAME_NODE_NEXT];
332
-
333
- if (n === node) {
334
- // found the node to cut
335
-
336
- if (previous === NULL_POINTER) {
337
- // first element in the list
338
- grid_data[cell_index] = next;
339
- } else {
340
- const previous_address = pool.element_word(previous);
341
-
342
- node_data_uint32[previous_address + COLUMN_NODE_SAME_NODE_NEXT] = next;
343
- }
344
-
345
- return true;
346
- }
347
-
348
- previous = n;
349
- n = next;
350
- }
351
-
352
- return false;
353
- }
354
-
355
- /**
356
- *
357
- * @param {number} element
358
- */
359
- element_remove(element) {
360
- assert.isNonNegativeInteger(element, 'element');
361
-
362
- const element_pool = this.#element_pool;
363
- const address = element_pool.element_word(element);
364
-
365
- let node = element_pool.data_uint32[address + COLUMN_ELEMENT_NODE_FIRST];
366
-
367
- const node_pool = this.#node_pool;
368
- const node_data_uint32 = node_pool.data_uint32;
369
-
370
- do {
371
-
372
- const node_address = node_pool.element_word(node);
373
-
374
- const next = node_data_uint32[node_address + COLUMN_NODE_SAME_ELEMENT_NEXT];
375
-
376
- const grid_index = node_data_uint32[node_address + COLUMN_NODE_GRID_INDEX];
377
-
378
- // cut this node from CELL list
379
- this.#grid_cell_remove_node(grid_index, node);
380
-
381
-
382
- // advance onto next
383
- node = next;
384
- } while (node !== NULL_POINTER)
385
-
386
- }
1
+ import { assert } from "../../../assert.js";
2
+ import { UINT32_MAX } from "../../../binary/UINT32_MAX.js";
3
+ import { clamp } from "../../../math/clamp.js";
4
+ import { BinaryElementPool } from "../../3d/topology/struct/binary/BinaryElementPool.js";
5
+
6
+
7
+ export const NULL_POINTER = UINT32_MAX;
8
+ /**
9
+ * Single-linked list
10
+ * Pointer to next NODE in the same grid cell
11
+ * @type {number}
12
+ */
13
+ const COLUMN_NODE_SAME_NODE_NEXT = 0;
14
+ /**
15
+ * Single-linked list
16
+ * Pointer to next NODE containing the same element
17
+ * @type {number}
18
+ */
19
+ const COLUMN_NODE_SAME_ELEMENT_NEXT = 1;
20
+ /**
21
+ * Pointer to ELEMENT
22
+ * @type {number}
23
+ */
24
+ const COLUMN_NODE_ELEMENT = 2;
25
+
26
+ /**
27
+ * Points to grid cell that stores this node
28
+ * @type {number}
29
+ */
30
+ const COLUMN_NODE_GRID_INDEX = 3;
31
+
32
+ const COLUMN_ELEMENT_DATA = 0;
33
+ const COLUMN_ELEMENT_NODE_FIRST = 1;
34
+ export const COLUMN_ELEMENT_X0 = 2;
35
+ export const COLUMN_ELEMENT_Y0 = 3;
36
+ export const COLUMN_ELEMENT_X1 = 4;
37
+ export const COLUMN_ELEMENT_Y1 = 5;
38
+
39
+ export class SpatialHashGrid {
40
+ #element_pool = new BinaryElementPool(24)
41
+ #node_pool = new BinaryElementPool(16);
42
+ #grid_data = new Uint32Array(0);
43
+
44
+ #size_x = 0;
45
+ #size_y = 0;
46
+
47
+ #scale = 1;
48
+ #scale_inverse = 1;
49
+
50
+ get size_x() {
51
+ return this.#size_x;
52
+ }
53
+
54
+ get size_y() {
55
+ return this.#size_y;
56
+ }
57
+
58
+ get node_pool() {
59
+ return this.#node_pool;
60
+ }
61
+
62
+ /**
63
+ *
64
+ * @return {BinaryElementPool}
65
+ */
66
+ get element_pool() {
67
+ return this.#element_pool;
68
+ }
69
+
70
+ get scale() {
71
+ return this.#scale;
72
+ }
73
+
74
+ get scale_inverse() {
75
+ return this.#scale_inverse;
76
+ }
77
+
78
+ constructor(size_x = 1, size_y = 1, scale = 8) {
79
+
80
+ assert.notNaN(scale, "scale");
81
+ assert.isFinite(scale, 'scale');
82
+ assert.greaterThan(scale, 0, 'scale must be greater than 0');
83
+
84
+ this.#size_x = size_x;
85
+ this.#size_y = size_y;
86
+ this.#scale = scale;
87
+ this.#scale_inverse = 1 / scale;
88
+
89
+ this.#build();
90
+ }
91
+
92
+ #build() {
93
+ this.#grid_data = new Uint32Array(this.#size_x * this.#size_y);
94
+
95
+ this.#grid_data.fill(NULL_POINTER);
96
+ }
97
+
98
+ element_allocate() {
99
+ const element = this.#element_pool.allocate();
100
+
101
+ return element;
102
+ }
103
+
104
+ element_set_user_data(element, user_data) {
105
+ const pool = this.#element_pool;
106
+ const address = pool.element_word(element);
107
+
108
+ pool.data_uint32[address + COLUMN_ELEMENT_DATA] = user_data;
109
+ }
110
+
111
+ element_get_user_data(element) {
112
+ const pool = this.#element_pool;
113
+ const address = pool.element_word(element);
114
+
115
+ return pool.data_uint32[address + COLUMN_ELEMENT_DATA];
116
+ }
117
+
118
+ /**
119
+ * You have to remove the element from the grid before changing its bounds
120
+ * @param {number} element
121
+ * @param {number} x0
122
+ * @param {number} y0
123
+ * @param {number} x1
124
+ * @param {number} y1
125
+ */
126
+ element_set_bounds_primitive(element, x0, y0, x1, y1) {
127
+ const pool = this.#element_pool;
128
+ const address = pool.element_word(element);
129
+
130
+ const float32 = pool.data_float32;
131
+
132
+ float32[address + COLUMN_ELEMENT_X0] = x0;
133
+ float32[address + COLUMN_ELEMENT_Y0] = y0;
134
+ float32[address + COLUMN_ELEMENT_X1] = x1;
135
+ float32[address + COLUMN_ELEMENT_Y1] = y1;
136
+ }
137
+
138
+ /**
139
+ *
140
+ * @param {number} element
141
+ */
142
+ element_release(element) {
143
+ this.#element_pool.release(element);
144
+ }
145
+
146
+ /**
147
+ *
148
+ * @param {number} element
149
+ */
150
+ element_insert(element) {
151
+ const pool = this.#element_pool;
152
+ const address = pool.element_word(element);
153
+
154
+ const uint32 = pool.data_uint32;
155
+
156
+ // make sure that we don't point at anything yet
157
+ uint32[address + COLUMN_ELEMENT_NODE_FIRST] = NULL_POINTER;
158
+
159
+ const float32 = pool.data_float32;
160
+
161
+ const x0 = float32[address + COLUMN_ELEMENT_X0];
162
+ const y0 = float32[address + COLUMN_ELEMENT_Y0];
163
+ const x1 = float32[address + COLUMN_ELEMENT_X1];
164
+ const y1 = float32[address + COLUMN_ELEMENT_Y1];
165
+
166
+ // convert to grid coordinates
167
+ const grid_x0 = Math.floor(x0 * this.#scale_inverse);
168
+ const grid_y0 = Math.floor(y0 * this.#scale_inverse);
169
+
170
+ const grid_x1 = Math.floor(x1 * this.#scale_inverse);
171
+ const grid_y1 = Math.floor(y1 * this.#scale_inverse);
172
+
173
+ for (let y = grid_y0; y <= grid_y1; y++) {
174
+ for (let x = grid_x0; x <= grid_x1; x++) {
175
+ this.#element_insert_into_cell(element, x, y);
176
+ }
177
+ }
178
+ }
179
+
180
+ /**
181
+ *
182
+ * @param {number} node
183
+ * @return {number}
184
+ */
185
+ node_get_element(node) {
186
+ const address = this.#node_pool.element_word(node);
187
+ return this.#node_pool.data_uint32[address + COLUMN_NODE_ELEMENT];
188
+ }
189
+
190
+ /**
191
+ * Next element in the linked list of cell's nodes
192
+ * @param {number} node
193
+ * @return {number}
194
+ */
195
+ node_get_same_cell_next_node(node) {
196
+ const address = this.#node_pool.element_word(node);
197
+
198
+ return this.#node_pool.data_uint32[address + COLUMN_NODE_SAME_NODE_NEXT];
199
+ }
200
+
201
+ /**
202
+ *
203
+ * @param {number} cell_index
204
+ * @return {number}
205
+ */
206
+ cell_get_first_node(cell_index) {
207
+ assert.lessThan(cell_index, this.#size_x * this.#size_y);
208
+
209
+ return this.#grid_data[cell_index]
210
+ }
211
+
212
+ /**
213
+ *
214
+ * @param {number} x
215
+ * @param {number} y
216
+ * @return {number}
217
+ */
218
+ world_position_to_cell_index(x, y) {
219
+ const grid_x = clamp(Math.floor(x * this.#scale_inverse), 0, this.#size_x - 1);
220
+ const grid_y = clamp(Math.floor(y * this.#scale_inverse), 0, this.#size_y - 1);
221
+
222
+ return this.cell_position_to_index(grid_x, grid_y);
223
+ }
224
+
225
+ /**
226
+ *
227
+ * @param {number} x
228
+ * @param {number} y
229
+ * @returns {number}
230
+ */
231
+ cell_position_to_index(x, y) {
232
+ assert.isNonNegativeInteger(x, 'x');
233
+ assert.isNonNegativeInteger(y, 'y');
234
+
235
+ return y * this.#size_x + x;
236
+
237
+ // const cell_count = this.#size_x * this.#size_y;
238
+ //
239
+ // const _x = split_by_2(x);
240
+ // const _y = split_by_2(y);
241
+ //
242
+ // const hash = _x | (_y << 1);
243
+ //
244
+ // return hash % cell_count;
245
+ }
246
+
247
+ /**
248
+ *
249
+ * @param {number} cell_x
250
+ * @param {number} cell_y
251
+ * @return {boolean}
252
+ */
253
+ is_cell_empty(cell_x, cell_y) {
254
+ assert.isNonNegativeInteger(cell_x, 'cell_x');
255
+ assert.lessThan(cell_x, this.#size_x, 'cell_x overflow');
256
+
257
+ assert.isNonNegativeInteger(cell_y, 'cell_y');
258
+ assert.lessThan(cell_y, this.#size_y, 'cell_y overflow');
259
+
260
+ const index = this.cell_position_to_index(cell_x, cell_y);
261
+
262
+ const grid = this.#grid_data;
263
+
264
+ return grid[index] === NULL_POINTER;
265
+ }
266
+
267
+ /**
268
+ *
269
+ * @param {number} element
270
+ * @param {number} grid_x
271
+ * @param {number} grid_y
272
+ */
273
+ #element_insert_into_cell(element, grid_x, grid_y) {
274
+
275
+ // create a node
276
+ const node_pool = this.#node_pool;
277
+ const node = node_pool.allocate();
278
+
279
+ const node_address = node_pool.element_word(node);
280
+ const node_data_uint32 = node_pool.data_uint32;
281
+
282
+ node_data_uint32[node_address + COLUMN_NODE_ELEMENT] = element;
283
+
284
+ // link node to the element
285
+ const element_pool = this.#element_pool;
286
+ const element_address = element_pool.element_word(element);
287
+
288
+ const element_data_uint32 = element_pool.data_uint32;
289
+
290
+ const element_first_node = element_data_uint32[element_address + COLUMN_ELEMENT_NODE_FIRST];
291
+
292
+ // point to previous first
293
+ node_data_uint32[node_address + COLUMN_NODE_SAME_ELEMENT_NEXT] = element_first_node;
294
+
295
+
296
+ element_data_uint32[element_address + COLUMN_ELEMENT_NODE_FIRST] = node;
297
+
298
+ // link node to the cell
299
+ const cell_index = this.cell_position_to_index(grid_x, grid_y);
300
+
301
+ node_data_uint32[node_address + COLUMN_NODE_GRID_INDEX] = cell_index;
302
+
303
+ const grid_data = this.#grid_data;
304
+
305
+ const cell_first_node = grid_data[cell_index];
306
+
307
+ node_data_uint32[node_address + COLUMN_NODE_SAME_NODE_NEXT] = cell_first_node;
308
+
309
+ grid_data[cell_index] = node;
310
+ }
311
+
312
+ /**
313
+ *
314
+ * @param {number} cell_index
315
+ * @param {number} node
316
+ * @returns {boolean}
317
+ */
318
+ #grid_cell_remove_node(cell_index, node) {
319
+ assert.isNonNegativeInteger(cell_index, 'cell_index');
320
+ assert.isNonNegativeInteger(node, 'node');
321
+
322
+ const pool = this.#node_pool;
323
+ const node_data_uint32 = pool.data_uint32;
324
+
325
+ const grid_data = this.#grid_data;
326
+ let n = grid_data[cell_index]
327
+ let previous = NULL_POINTER;
328
+
329
+ while (n !== NULL_POINTER) {
330
+ const address = pool.element_word(n);
331
+ const next = node_data_uint32[address + COLUMN_NODE_SAME_NODE_NEXT];
332
+
333
+ if (n === node) {
334
+ // found the node to cut
335
+
336
+ if (previous === NULL_POINTER) {
337
+ // first element in the list
338
+ grid_data[cell_index] = next;
339
+ } else {
340
+ const previous_address = pool.element_word(previous);
341
+
342
+ node_data_uint32[previous_address + COLUMN_NODE_SAME_NODE_NEXT] = next;
343
+ }
344
+
345
+ return true;
346
+ }
347
+
348
+ previous = n;
349
+ n = next;
350
+ }
351
+
352
+ return false;
353
+ }
354
+
355
+ /**
356
+ *
357
+ * @param {number} element
358
+ */
359
+ element_remove(element) {
360
+ assert.isNonNegativeInteger(element, 'element');
361
+
362
+ const element_pool = this.#element_pool;
363
+ const address = element_pool.element_word(element);
364
+
365
+ let node = element_pool.data_uint32[address + COLUMN_ELEMENT_NODE_FIRST];
366
+
367
+ const node_pool = this.#node_pool;
368
+ const node_data_uint32 = node_pool.data_uint32;
369
+
370
+ // Pre-tested loop: an element with zero nodes has node === NULL_POINTER from the start; a do...while
371
+ // would run the body once and dereference NULL_POINTER, corrupting state.
372
+ while (node !== NULL_POINTER) {
373
+
374
+ const node_address = node_pool.element_word(node);
375
+
376
+ const next = node_data_uint32[node_address + COLUMN_NODE_SAME_ELEMENT_NEXT];
377
+
378
+ const grid_index = node_data_uint32[node_address + COLUMN_NODE_GRID_INDEX];
379
+
380
+ // cut this node from CELL list
381
+ this.#grid_cell_remove_node(grid_index, node);
382
+
383
+
384
+ // advance onto next
385
+ node = next;
386
+ }
387
+
388
+ }
387
389
  }